All files / frontend/.next/server/vendor-chunks @sentry+core@9.46.0.js

0% Statements 0/2995
0% Branches 0/1
0% Functions 0/1
0% Lines 0/2995

Press n or j to go to the next uncovered block, b, p or k for the previous block.

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404 405 406 407 408 409 410 411 412 413 414 415 416 417 418 419 420 421 422 423 424 425 426 427 428 429 430 431 432 433 434 435 436 437 438 439 440 441 442 443 444 445 446 447 448 449 450 451 452 453 454 455 456 457 458 459 460 461 462 463 464 465 466 467 468 469 470 471 472 473 474 475 476 477 478 479 480 481 482 483 484 485 486 487 488 489 490 491 492 493 494 495 496 497 498 499 500 501 502 503 504 505 506 507 508 509 510 511 512 513 514 515 516 517 518 519 520 521 522 523 524 525 526 527 528 529 530 531 532 533 534 535 536 537 538 539 540 541 542 543 544 545 546 547 548 549 550 551 552 553 554 555 556 557 558 559 560 561 562 563 564 565 566 567 568 569 570 571 572 573 574 575 576 577 578 579 580 581 582 583 584 585 586 587 588 589 590 591 592 593 594 595 596 597 598 599 600 601 602 603 604 605 606 607 608 609 610 611 612 613 614 615 616 617 618 619 620 621 622 623 624 625 626 627 628 629 630 631 632 633 634 635 636 637 638 639 640 641 642 643 644 645 646 647 648 649 650 651 652 653 654 655 656 657 658 659 660 661 662 663 664 665 666 667 668 669 670 671 672 673 674 675 676 677 678 679 680 681 682 683 684 685 686 687 688 689 690 691 692 693 694 695 696 697 698 699 700 701 702 703 704 705 706 707 708 709 710 711 712 713 714 715 716 717 718 719 720 721 722 723 724 725 726 727 728 729 730 731 732 733 734 735 736 737 738 739 740 741 742 743 744 745 746 747 748 749 750 751 752 753 754 755 756 757 758 759 760 761 762 763 764 765 766 767 768 769 770 771 772 773 774 775 776 777 778 779 780 781 782 783 784 785 786 787 788 789 790 791 792 793 794 795 796 797 798 799 800 801 802 803 804 805 806 807 808 809 810 811 812 813 814 815 816 817 818 819 820 821 822 823 824 825 826 827 828 829 830 831 832 833 834 835 836 837 838 839 840 841 842 843 844 845 846 847 848 849 850 851 852 853 854 855 856 857 858 859 860 861 862 863 864 865 866 867 868 869 870 871 872 873 874 875 876 877 878 879 880 881 882 883 884 885 886 887 888 889 890 891 892 893 894 895 896 897 898 899 900 901 902 903 904 905 906 907 908 909 910 911 912 913 914 915 916 917 918 919 920 921 922 923 924 925 926 927 928 929 930 931 932 933 934 935 936 937 938 939 940 941 942 943 944 945 946 947 948 949 950 951 952 953 954 955 956 957 958 959 960 961 962 963 964 965 966 967 968 969 970 971 972 973 974 975 976 977 978 979 980 981 982 983 984 985 986 987 988 989 990 991 992 993 994 995 996 997 998 999 1000 1001 1002 1003 1004 1005 1006 1007 1008 1009 1010 1011 1012 1013 1014 1015 1016 1017 1018 1019 1020 1021 1022 1023 1024 1025 1026 1027 1028 1029 1030 1031 1032 1033 1034 1035 1036 1037 1038 1039 1040 1041 1042 1043 1044 1045 1046 1047 1048 1049 1050 1051 1052 1053 1054 1055 1056 1057 1058 1059 1060 1061 1062 1063 1064 1065 1066 1067 1068 1069 1070 1071 1072 1073 1074 1075 1076 1077 1078 1079 1080 1081 1082 1083 1084 1085 1086 1087 1088 1089 1090 1091 1092 1093 1094 1095 1096 1097 1098 1099 1100 1101 1102 1103 1104 1105 1106 1107 1108 1109 1110 1111 1112 1113 1114 1115 1116 1117 1118 1119 1120 1121 1122 1123 1124 1125 1126 1127 1128 1129 1130 1131 1132 1133 1134 1135 1136 1137 1138 1139 1140 1141 1142 1143 1144 1145 1146 1147 1148 1149 1150 1151 1152 1153 1154 1155 1156 1157 1158 1159 1160 1161 1162 1163 1164 1165 1166 1167 1168 1169 1170 1171 1172 1173 1174 1175 1176 1177 1178 1179 1180 1181 1182 1183 1184 1185 1186 1187 1188 1189 1190 1191 1192 1193 1194 1195 1196 1197 1198 1199 1200 1201 1202 1203 1204 1205 1206 1207 1208 1209 1210 1211 1212 1213 1214 1215 1216 1217 1218 1219 1220 1221 1222 1223 1224 1225 1226 1227 1228 1229 1230 1231 1232 1233 1234 1235 1236 1237 1238 1239 1240 1241 1242 1243 1244 1245 1246 1247 1248 1249 1250 1251 1252 1253 1254 1255 1256 1257 1258 1259 1260 1261 1262 1263 1264 1265 1266 1267 1268 1269 1270 1271 1272 1273 1274 1275 1276 1277 1278 1279 1280 1281 1282 1283 1284 1285 1286 1287 1288 1289 1290 1291 1292 1293 1294 1295 1296 1297 1298 1299 1300 1301 1302 1303 1304 1305 1306 1307 1308 1309 1310 1311 1312 1313 1314 1315 1316 1317 1318 1319 1320 1321 1322 1323 1324 1325 1326 1327 1328 1329 1330 1331 1332 1333 1334 1335 1336 1337 1338 1339 1340 1341 1342 1343 1344 1345 1346 1347 1348 1349 1350 1351 1352 1353 1354 1355 1356 1357 1358 1359 1360 1361 1362 1363 1364 1365 1366 1367 1368 1369 1370 1371 1372 1373 1374 1375 1376 1377 1378 1379 1380 1381 1382 1383 1384 1385 1386 1387 1388 1389 1390 1391 1392 1393 1394 1395 1396 1397 1398 1399 1400 1401 1402 1403 1404 1405 1406 1407 1408 1409 1410 1411 1412 1413 1414 1415 1416 1417 1418 1419 1420 1421 1422 1423 1424 1425 1426 1427 1428 1429 1430 1431 1432 1433 1434 1435 1436 1437 1438 1439 1440 1441 1442 1443 1444 1445 1446 1447 1448 1449 1450 1451 1452 1453 1454 1455 1456 1457 1458 1459 1460 1461 1462 1463 1464 1465 1466 1467 1468 1469 1470 1471 1472 1473 1474 1475 1476 1477 1478 1479 1480 1481 1482 1483 1484 1485 1486 1487 1488 1489 1490 1491 1492 1493 1494 1495 1496 1497 1498 1499 1500 1501 1502 1503 1504 1505 1506 1507 1508 1509 1510 1511 1512 1513 1514 1515 1516 1517 1518 1519 1520 1521 1522 1523 1524 1525 1526 1527 1528 1529 1530 1531 1532 1533 1534 1535 1536 1537 1538 1539 1540 1541 1542 1543 1544 1545 1546 1547 1548 1549 1550 1551 1552 1553 1554 1555 1556 1557 1558 1559 1560 1561 1562 1563 1564 1565 1566 1567 1568 1569 1570 1571 1572 1573 1574 1575 1576 1577 1578 1579 1580 1581 1582 1583 1584 1585 1586 1587 1588 1589 1590 1591 1592 1593 1594 1595 1596 1597 1598 1599 1600 1601 1602 1603 1604 1605 1606 1607 1608 1609 1610 1611 1612 1613 1614 1615 1616 1617 1618 1619 1620 1621 1622 1623 1624 1625 1626 1627 1628 1629 1630 1631 1632 1633 1634 1635 1636 1637 1638 1639 1640 1641 1642 1643 1644 1645 1646 1647 1648 1649 1650 1651 1652 1653 1654 1655 1656 1657 1658 1659 1660 1661 1662 1663 1664 1665 1666 1667 1668 1669 1670 1671 1672 1673 1674 1675 1676 1677 1678 1679 1680 1681 1682 1683 1684 1685 1686 1687 1688 1689 1690 1691 1692 1693 1694 1695 1696 1697 1698 1699 1700 1701 1702 1703 1704 1705 1706 1707 1708 1709 1710 1711 1712 1713 1714 1715 1716 1717 1718 1719 1720 1721 1722 1723 1724 1725 1726 1727 1728 1729 1730 1731 1732 1733 1734 1735 1736 1737 1738 1739 1740 1741 1742 1743 1744 1745 1746 1747 1748 1749 1750 1751 1752 1753 1754 1755 1756 1757 1758 1759 1760 1761 1762 1763 1764 1765 1766 1767 1768 1769 1770 1771 1772 1773 1774 1775 1776 1777 1778 1779 1780 1781 1782 1783 1784 1785 1786 1787 1788 1789 1790 1791 1792 1793 1794 1795 1796 1797 1798 1799 1800 1801 1802 1803 1804 1805 1806 1807 1808 1809 1810 1811 1812 1813 1814 1815 1816 1817 1818 1819 1820 1821 1822 1823 1824 1825 1826 1827 1828 1829 1830 1831 1832 1833 1834 1835 1836 1837 1838 1839 1840 1841 1842 1843 1844 1845 1846 1847 1848 1849 1850 1851 1852 1853 1854 1855 1856 1857 1858 1859 1860 1861 1862 1863 1864 1865 1866 1867 1868 1869 1870 1871 1872 1873 1874 1875 1876 1877 1878 1879 1880 1881 1882 1883 1884 1885 1886 1887 1888 1889 1890 1891 1892 1893 1894 1895 1896 1897 1898 1899 1900 1901 1902 1903 1904 1905 1906 1907 1908 1909 1910 1911 1912 1913 1914 1915 1916 1917 1918 1919 1920 1921 1922 1923 1924 1925 1926 1927 1928 1929 1930 1931 1932 1933 1934 1935 1936 1937 1938 1939 1940 1941 1942 1943 1944 1945 1946 1947 1948 1949 1950 1951 1952 1953 1954 1955 1956 1957 1958 1959 1960 1961 1962 1963 1964 1965 1966 1967 1968 1969 1970 1971 1972 1973 1974 1975 1976 1977 1978 1979 1980 1981 1982 1983 1984 1985 1986 1987 1988 1989 1990 1991 1992 1993 1994 1995 1996 1997 1998 1999 2000 2001 2002 2003 2004 2005 2006 2007 2008 2009 2010 2011 2012 2013 2014 2015 2016 2017 2018 2019 2020 2021 2022 2023 2024 2025 2026 2027 2028 2029 2030 2031 2032 2033 2034 2035 2036 2037 2038 2039 2040 2041 2042 2043 2044 2045 2046 2047 2048 2049 2050 2051 2052 2053 2054 2055 2056 2057 2058 2059 2060 2061 2062 2063 2064 2065 2066 2067 2068 2069 2070 2071 2072 2073 2074 2075 2076 2077 2078 2079 2080 2081 2082 2083 2084 2085 2086 2087 2088 2089 2090 2091 2092 2093 2094 2095 2096 2097 2098 2099 2100 2101 2102 2103 2104 2105 2106 2107 2108 2109 2110 2111 2112 2113 2114 2115 2116 2117 2118 2119 2120 2121 2122 2123 2124 2125 2126 2127 2128 2129 2130 2131 2132 2133 2134 2135 2136 2137 2138 2139 2140 2141 2142 2143 2144 2145 2146 2147 2148 2149 2150 2151 2152 2153 2154 2155 2156 2157 2158 2159 2160 2161 2162 2163 2164 2165 2166 2167 2168 2169 2170 2171 2172 2173 2174 2175 2176 2177 2178 2179 2180 2181 2182 2183 2184 2185 2186 2187 2188 2189 2190 2191 2192 2193 2194 2195 2196 2197 2198 2199 2200 2201 2202 2203 2204 2205 2206 2207 2208 2209 2210 2211 2212 2213 2214 2215 2216 2217 2218 2219 2220 2221 2222 2223 2224 2225 2226 2227 2228 2229 2230 2231 2232 2233 2234 2235 2236 2237 2238 2239 2240 2241 2242 2243 2244 2245 2246 2247 2248 2249 2250 2251 2252 2253 2254 2255 2256 2257 2258 2259 2260 2261 2262 2263 2264 2265 2266 2267 2268 2269 2270 2271 2272 2273 2274 2275 2276 2277 2278 2279 2280 2281 2282 2283 2284 2285 2286 2287 2288 2289 2290 2291 2292 2293 2294 2295 2296 2297 2298 2299 2300 2301 2302 2303 2304 2305 2306 2307 2308 2309 2310 2311 2312 2313 2314 2315 2316 2317 2318 2319 2320 2321 2322 2323 2324 2325 2326 2327 2328 2329 2330 2331 2332 2333 2334 2335 2336 2337 2338 2339 2340 2341 2342 2343 2344 2345 2346 2347 2348 2349 2350 2351 2352 2353 2354 2355 2356 2357 2358 2359 2360 2361 2362 2363 2364 2365 2366 2367 2368 2369 2370 2371 2372 2373 2374 2375 2376 2377 2378 2379 2380 2381 2382 2383 2384 2385 2386 2387 2388 2389 2390 2391 2392 2393 2394 2395 2396 2397 2398 2399 2400 2401 2402 2403 2404 2405 2406 2407 2408 2409 2410 2411 2412 2413 2414 2415 2416 2417 2418 2419 2420 2421 2422 2423 2424 2425 2426 2427 2428 2429 2430 2431 2432 2433 2434 2435 2436 2437 2438 2439 2440 2441 2442 2443 2444 2445 2446 2447 2448 2449 2450 2451 2452 2453 2454 2455 2456 2457 2458 2459 2460 2461 2462 2463 2464 2465 2466 2467 2468 2469 2470 2471 2472 2473 2474 2475 2476 2477 2478 2479 2480 2481 2482 2483 2484 2485 2486 2487 2488 2489 2490 2491 2492 2493 2494 2495 2496 2497 2498 2499 2500 2501 2502 2503 2504 2505 2506 2507 2508 2509 2510 2511 2512 2513 2514 2515 2516 2517 2518 2519 2520 2521 2522 2523 2524 2525 2526 2527 2528 2529 2530 2531 2532 2533 2534 2535 2536 2537 2538 2539 2540 2541 2542 2543 2544 2545 2546 2547 2548 2549 2550 2551 2552 2553 2554 2555 2556 2557 2558 2559 2560 2561 2562 2563 2564 2565 2566 2567 2568 2569 2570 2571 2572 2573 2574 2575 2576 2577 2578 2579 2580 2581 2582 2583 2584 2585 2586 2587 2588 2589 2590 2591 2592 2593 2594 2595 2596 2597 2598 2599 2600 2601 2602 2603 2604 2605 2606 2607 2608 2609 2610 2611 2612 2613 2614 2615 2616 2617 2618 2619 2620 2621 2622 2623 2624 2625 2626 2627 2628 2629 2630 2631 2632 2633 2634 2635 2636 2637 2638 2639 2640 2641 2642 2643 2644 2645 2646 2647 2648 2649 2650 2651 2652 2653 2654 2655 2656 2657 2658 2659 2660 2661 2662 2663 2664 2665 2666 2667 2668 2669 2670 2671 2672 2673 2674 2675 2676 2677 2678 2679 2680 2681 2682 2683 2684 2685 2686 2687 2688 2689 2690 2691 2692 2693 2694 2695 2696 2697 2698 2699 2700 2701 2702 2703 2704 2705 2706 2707 2708 2709 2710 2711 2712 2713 2714 2715 2716 2717 2718 2719 2720 2721 2722 2723 2724 2725 2726 2727 2728 2729 2730 2731 2732 2733 2734 2735 2736 2737 2738 2739 2740 2741 2742 2743 2744 2745 2746 2747 2748 2749 2750 2751 2752 2753 2754 2755 2756 2757 2758 2759 2760 2761 2762 2763 2764 2765 2766 2767 2768 2769 2770 2771 2772 2773 2774 2775 2776 2777 2778 2779 2780 2781 2782 2783 2784 2785 2786 2787 2788 2789 2790 2791 2792 2793 2794 2795 2796 2797 2798 2799 2800 2801 2802 2803 2804 2805 2806 2807 2808 2809 2810 2811 2812 2813 2814 2815 2816 2817 2818 2819 2820 2821 2822 2823 2824 2825 2826 2827 2828 2829 2830 2831 2832 2833 2834 2835 2836 2837 2838 2839 2840 2841 2842 2843 2844 2845 2846 2847 2848 2849 2850 2851 2852 2853 2854 2855 2856 2857 2858 2859 2860 2861 2862 2863 2864 2865 2866 2867 2868 2869 2870 2871 2872 2873 2874 2875 2876 2877 2878 2879 2880 2881 2882 2883 2884 2885 2886 2887 2888 2889 2890 2891 2892 2893 2894 2895 2896 2897 2898 2899 2900 2901 2902 2903 2904 2905 2906 2907 2908 2909 2910 2911 2912 2913 2914 2915 2916 2917 2918 2919 2920 2921 2922 2923 2924 2925 2926 2927 2928 2929 2930 2931 2932 2933 2934 2935 2936 2937 2938 2939 2940 2941 2942 2943 2944 2945 2946 2947 2948 2949 2950 2951 2952 2953 2954 2955 2956 2957 2958 2959 2960 2961 2962 2963 2964 2965 2966 2967 2968 2969 2970 2971 2972 2973 2974 2975 2976 2977 2978 2979 2980 2981 2982 2983 2984 2985 2986 2987 2988 2989 2990 2991 2992 2993 2994 2995 2996 2997 2998 2999 3000 3001 3002 3003 3004 3005 3006 3007 3008 3009 3010 3011 3012 3013 3014 3015 3016 3017 3018 3019 3020 3021 3022 3023 3024 3025 3026 3027 3028 3029 3030 3031 3032 3033 3034 3035 3036 3037 3038 3039 3040 3041 3042 3043 3044 3045 3046 3047 3048 3049 3050 3051 3052 3053 3054 3055 3056 3057 3058 3059 3060 3061 3062 3063 3064 3065 3066 3067 3068 3069 3070 3071 3072 3073 3074 3075 3076 3077 3078 3079 3080 3081 3082 3083 3084 3085 3086 3087 3088 3089 3090 3091 3092 3093 3094 3095 3096 3097 3098 3099 3100 3101 3102 3103 3104 3105 3106 3107 3108 3109 3110 3111 3112 3113 3114 3115 3116 3117 3118 3119 3120 3121 3122 3123 3124 3125 3126 3127 3128 3129 3130 3131 3132 3133 3134 3135 3136 3137 3138 3139 3140 3141 3142 3143 3144 3145 3146 3147 3148 3149 3150 3151 3152 3153 3154 3155 3156 3157 3158 3159 3160 3161 3162 3163 3164 3165 3166 3167 3168 3169 3170 3171 3172 3173 3174 3175 3176 3177 3178 3179 3180 3181 3182 3183 3184 3185 3186 3187 3188 3189 3190 3191 3192 3193 3194 3195 3196 3197 3198 3199 3200 3201 3202 3203 3204 3205 3206 3207 3208 3209 3210 3211 3212 3213 3214 3215 3216 3217 3218 3219 3220 3221 3222 3223 3224 3225 3226 3227 3228 3229 3230 3231 3232 3233 3234 3235 3236 3237 3238 3239 3240 3241 3242 3243 3244 3245 3246 3247 3248 3249 3250 3251 3252 3253 3254 3255 3256 3257 3258 3259 3260 3261 3262 3263 3264 3265 3266 3267 3268 3269 3270 3271 3272 3273 3274 3275 3276 3277 3278 3279 3280 3281 3282 3283 3284 3285 3286 3287 3288 3289 3290 3291 3292 3293 3294 3295 3296 3297 3298 3299 3300 3301 3302 3303 3304 3305 3306 3307 3308 3309 3310 3311 3312 3313 3314 3315 3316 3317 3318 3319 3320 3321 3322 3323 3324 3325 3326 3327 3328 3329 3330 3331 3332 3333 3334 3335 3336 3337 3338 3339 3340 3341 3342 3343 3344 3345 3346 3347 3348 3349 3350 3351 3352 3353 3354 3355 3356 3357 3358 3359 3360 3361 3362 3363 3364 3365 3366 3367 3368 3369 3370 3371 3372 3373 3374 3375 3376 3377 3378 3379 3380 3381 3382 3383 3384 3385 3386 3387 3388 3389 3390 3391 3392 3393 3394 3395 3396 3397 3398 3399 3400 3401 3402 3403 3404 3405 3406 3407 3408 3409 3410 3411 3412 3413 3414 3415 3416 3417 3418 3419 3420 3421 3422 3423 3424 3425 3426 3427 3428 3429 3430 3431 3432 3433 3434 3435 3436 3437 3438 3439 3440 3441 3442 3443 3444 3445 3446 3447 3448 3449 3450 3451 3452 3453 3454 3455 3456 3457 3458 3459 3460 3461 3462 3463 3464 3465 3466 3467 3468 3469 3470 3471 3472 3473 3474 3475 3476 3477 3478 3479 3480 3481 3482 3483 3484 3485 3486 3487 3488 3489 3490 3491 3492 3493 3494 3495 3496 3497 3498 3499 3500 3501 3502 3503 3504 3505 3506 3507 3508 3509 3510 3511 3512 3513 3514 3515 3516 3517 3518 3519 3520 3521 3522 3523 3524 3525 3526 3527 3528 3529 3530 3531 3532 3533 3534 3535 3536 3537 3538 3539 3540 3541 3542 3543 3544 3545 3546 3547 3548 3549 3550 3551 3552 3553 3554 3555 3556 3557 3558 3559 3560 3561 3562 3563 3564 3565 3566 3567 3568 3569 3570 3571 3572 3573 3574 3575 3576 3577 3578 3579 3580 3581 3582 3583 3584 3585 3586 3587 3588 3589 3590 3591 3592 3593 3594 3595 3596 3597 3598 3599 3600 3601 3602 3603 3604 3605 3606 3607 3608 3609 3610 3611 3612 3613 3614 3615 3616 3617 3618 3619 3620 3621 3622 3623 3624 3625 3626 3627 3628 3629 3630 3631 3632 3633 3634 3635 3636 3637 3638 3639 3640 3641 3642 3643 3644 3645 3646 3647 3648 3649 3650 3651 3652 3653 3654 3655 3656 3657 3658 3659 3660 3661 3662 3663 3664 3665 3666 3667 3668 3669 3670 3671 3672 3673 3674 3675 3676 3677 3678 3679 3680 3681 3682 3683 3684 3685 3686 3687 3688 3689 3690 3691 3692 3693 3694 3695 3696 3697 3698 3699 3700 3701 3702 3703 3704 3705 3706 3707 3708 3709 3710 3711 3712 3713 3714 3715 3716 3717 3718 3719 3720 3721 3722 3723 3724 3725 3726 3727 3728 3729 3730 3731 3732 3733 3734 3735 3736 3737 3738 3739 3740 3741 3742 3743 3744 3745 3746 3747 3748 3749 3750 3751 3752 3753 3754 3755 3756 3757 3758 3759 3760 3761 3762 3763 3764 3765 3766 3767 3768 3769 3770 3771 3772 3773 3774 3775 3776 3777 3778 3779 3780 3781 3782 3783 3784 3785 3786 3787 3788 3789 3790 3791 3792 3793 3794 3795 3796 3797 3798 3799 3800 3801 3802 3803 3804 3805 3806 3807 3808 3809 3810 3811 3812 3813 3814 3815 3816 3817 3818 3819 3820 3821 3822 3823 3824 3825 3826 3827 3828 3829 3830 3831 3832 3833 3834 3835 3836 3837 3838 3839 3840 3841 3842 3843 3844 3845 3846 3847 3848 3849 3850 3851 3852 3853 3854 3855 3856 3857 3858 3859 3860 3861 3862 3863 3864 3865 3866 3867 3868 3869 3870 3871 3872 3873 3874 3875 3876 3877 3878 3879 3880 3881 3882 3883 3884 3885 3886 3887 3888 3889 3890 3891 3892 3893 3894 3895 3896 3897 3898 3899 3900 3901 3902 3903 3904 3905 3906 3907 3908 3909 3910 3911 3912 3913 3914 3915 3916 3917 3918 3919 3920 3921 3922 3923 3924 3925 3926 3927 3928 3929 3930 3931 3932 3933 3934 3935 3936 3937 3938 3939 3940 3941 3942 3943 3944 3945 3946 3947 3948 3949 3950 3951 3952 3953 3954 3955 3956 3957 3958 3959 3960 3961 3962 3963 3964 3965 3966 3967 3968 3969 3970 3971 3972 3973 3974 3975 3976 3977 3978 3979 3980 3981 3982 3983 3984 3985 3986 3987 3988 3989 3990 3991 3992 3993 3994 3995 3996 3997 3998 3999 4000 4001 4002 4003 4004 4005 4006 4007 4008 4009 4010 4011 4012 4013 4014 4015 4016 4017 4018 4019 4020 4021 4022 4023 4024 4025 4026 4027 4028 4029 4030 4031 4032 4033 4034 4035 4036 4037 4038 4039 4040 4041 4042 4043 4044 4045 4046 4047 4048 4049 4050 4051 4052 4053 4054 4055 4056 4057 4058 4059 4060 4061 4062 4063 4064 4065 4066 4067 4068 4069 4070 4071 4072 4073 4074 4075 4076 4077 4078 4079 4080 4081 4082 4083 4084 4085 4086 4087 4088 4089 4090 4091 4092 4093 4094 4095 4096 4097 4098 4099 4100 4101 4102 4103 4104 4105 4106 4107 4108 4109 4110 4111 4112 4113 4114 4115 4116 4117 4118 4119 4120 4121 4122 4123 4124 4125 4126 4127 4128 4129 4130 4131 4132 4133 4134 4135 4136 4137 4138 4139 4140 4141 4142 4143 4144 4145 4146 4147 4148 4149 4150 4151 4152 4153 4154 4155 4156 4157 4158 4159 4160 4161 4162 4163 4164 4165 4166 4167 4168 4169 4170 4171 4172 4173 4174 4175 4176 4177 4178 4179 4180 4181 4182 4183 4184 4185 4186 4187 4188 4189 4190 4191 4192 4193 4194 4195 4196 4197 4198 4199 4200 4201 4202 4203 4204 4205 4206 4207 4208 4209 4210 4211 4212 4213 4214 4215 4216 4217 4218 4219 4220 4221 4222 4223 4224 4225 4226 4227 4228 4229 4230 4231 4232 4233 4234 4235 4236 4237 4238 4239 4240 4241 4242 4243 4244 4245 4246 4247 4248 4249 4250 4251 4252 4253 4254 4255 4256 4257 4258 4259 4260 4261 4262 4263 4264 4265 4266 4267 4268 4269 4270 4271 4272 4273 4274                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   
/*
 * ATTENTION: An "eval-source-map" devtool has been used.
 * This devtool is neither made for production nor for readable output files.
 * It uses "eval()" calls to create a separate source file with attached SourceMaps in the browser devtools.
 * If you are trying to read the output file, select a different devtool (https://webpack.js.org/configuration/devtool/)
 * or disable the default devtool with "devtool: false".
 * If you are looking for production-ready output files, see mode: "production" (https://webpack.js.org/configuration/mode/).
 */
exports.id = "vendor-chunks/@sentry+core@9.46.0";
exports.ids = ["vendor-chunks/@sentry+core@9.46.0"];
exports.modules = {
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/api.js":
/*!*******************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/api.js ***!
  \*******************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst dsn = __webpack_require__(/*! ./utils/dsn.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/dsn.js\");\n\nconst SENTRY_API_VERSION = '7';\n\n/** Returns the prefix to construct Sentry ingestion API endpoints. */\nfunction getBaseApiEndpoint(dsn) {\n  const protocol = dsn.protocol ? `${dsn.protocol}:` : '';\n  const port = dsn.port ? `:${dsn.port}` : '';\n  return `${protocol}//${dsn.host}${port}${dsn.path ? `/${dsn.path}` : ''}/api/`;\n}\n\n/** Returns the ingest API endpoint for target. */\nfunction _getIngestEndpoint(dsn) {\n  return `${getBaseApiEndpoint(dsn)}${dsn.projectId}/envelope/`;\n}\n\n/** Returns a URL-encoded string with auth config suitable for a query string. */\nfunction _encodedAuth(dsn, sdkInfo) {\n  const params = {\n    sentry_version: SENTRY_API_VERSION,\n  };\n\n  if (dsn.publicKey) {\n    // We send only the minimum set of required information. See\n    // https://github.com/getsentry/sentry-javascript/issues/2572.\n    params.sentry_key = dsn.publicKey;\n  }\n\n  if (sdkInfo) {\n    params.sentry_client = `${sdkInfo.name}/${sdkInfo.version}`;\n  }\n\n  return new URLSearchParams(params).toString();\n}\n\n/**\n * Returns the envelope endpoint URL with auth in the query string.\n *\n * Sending auth as part of the query string and not as custom HTTP headers avoids CORS preflight requests.\n */\nfunction getEnvelopeEndpointWithUrlEncodedAuth(dsn, tunnel, sdkInfo) {\n  return tunnel ? tunnel : `${_getIngestEndpoint(dsn)}?${_encodedAuth(dsn, sdkInfo)}`;\n}\n\n/** Returns the url to the report dialog endpoint. */\nfunction getReportDialogEndpoint(dsnLike, dialogOptions) {\n  const dsn$1 = dsn.makeDsn(dsnLike);\n  if (!dsn$1) {\n    return '';\n  }\n\n  const endpoint = `${getBaseApiEndpoint(dsn$1)}embed/error-page/`;\n\n  let encodedOptions = `dsn=${dsn.dsnToString(dsn$1)}`;\n  for (const key in dialogOptions) {\n    if (key === 'dsn') {\n      continue;\n    }\n\n    if (key === 'onClose') {\n      continue;\n    }\n\n    if (key === 'user') {\n      const user = dialogOptions.user;\n      if (!user) {\n        continue;\n      }\n      if (user.name) {\n        encodedOptions += `&name=${encodeURIComponent(user.name)}`;\n      }\n      if (user.email) {\n        encodedOptions += `&email=${encodeURIComponent(user.email)}`;\n      }\n    } else {\n      encodedOptions += `&${encodeURIComponent(key)}=${encodeURIComponent(dialogOptions[key] )}`;\n    }\n  }\n\n  return `${endpoint}?${encodedOptions}`;\n}\n\nexports.getEnvelopeEndpointWithUrlEncodedAuth = getEnvelopeEndpointWithUrlEncodedAuth;\nexports.getReportDialogEndpoint = getReportDialogEndpoint;\n//# sourceMappingURL=api.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvYXBpLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLFlBQVksbUJBQU8sQ0FBQyw4SEFBZ0I7O0FBRXBDOztBQUVBO0FBQ0E7QUFDQSxxQ0FBcUMsYUFBYTtBQUNsRCw4QkFBOEIsU0FBUztBQUN2QyxZQUFZLFNBQVMsSUFBSSxTQUFTLEVBQUUsS0FBSyxFQUFFLGVBQWUsU0FBUyxPQUFPO0FBQzFFOztBQUVBO0FBQ0E7QUFDQSxZQUFZLHdCQUF3QixFQUFFLGNBQWM7QUFDcEQ7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0EsOEJBQThCLGFBQWEsR0FBRyxnQkFBZ0I7QUFDOUQ7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSw4QkFBOEIsd0JBQXdCLEdBQUcsMkJBQTJCO0FBQ3BGOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSxzQkFBc0IsMEJBQTBCOztBQUVoRCw4QkFBOEIsdUJBQXVCO0FBQ3JEO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxtQ0FBbUMsOEJBQThCO0FBQ2pFO0FBQ0E7QUFDQSxvQ0FBb0MsK0JBQStCO0FBQ25FO0FBQ0EsTUFBTTtBQUNOLDRCQUE0Qix3QkFBd0IsR0FBRyx3Q0FBd0M7QUFDL0Y7QUFDQTs7QUFFQSxZQUFZLFNBQVMsR0FBRyxlQUFlO0FBQ3ZDOztBQUVBLDZDQUE2QztBQUM3QywrQkFBK0I7QUFDL0IiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9hcGkuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGRzbiA9IHJlcXVpcmUoJy4vdXRpbHMvZHNuLmpzJyk7XG5cbmNvbnN0IFNFTlRSWV9BUElfVkVSU0lPTiA9ICc3JztcblxuLyoqIFJldHVybnMgdGhlIHByZWZpeCB0byBjb25zdHJ1Y3QgU2VudHJ5IGluZ2VzdGlvbiBBUEkgZW5kcG9pbnRzLiAqL1xuZnVuY3Rpb24gZ2V0QmFzZUFwaUVuZHBvaW50KGRzbikge1xuICBjb25zdCBwcm90b2NvbCA9IGRzbi5wcm90b2NvbCA/IGAke2Rzbi5wcm90b2NvbH06YCA6ICcnO1xuICBjb25zdCBwb3J0ID0gZHNuLnBvcnQgPyBgOiR7ZHNuLnBvcnR9YCA6ICcnO1xuICByZXR1cm4gYCR7cHJvdG9jb2x9Ly8ke2Rzbi5ob3N0fSR7cG9ydH0ke2Rzbi5wYXRoID8gYC8ke2Rzbi5wYXRofWAgOiAnJ30vYXBpL2A7XG59XG5cbi8qKiBSZXR1cm5zIHRoZSBpbmdlc3QgQVBJIGVuZHBvaW50IGZvciB0YXJnZXQuICovXG5mdW5jdGlvbiBfZ2V0SW5nZXN0RW5kcG9pbnQoZHNuKSB7XG4gIHJldHVybiBgJHtnZXRCYXNlQXBpRW5kcG9pbnQoZHNuKX0ke2Rzbi5wcm9qZWN0SWR9L2VudmVsb3BlL2A7XG59XG5cbi8qKiBSZXR1cm5zIGEgVVJMLWVuY29kZWQgc3RyaW5nIHdpdGggYXV0aCBjb25maWcgc3VpdGFibGUgZm9yIGEgcXVlcnkgc3RyaW5nLiAqL1xuZnVuY3Rpb24gX2VuY29kZWRBdXRoKGRzbiwgc2RrSW5mbykge1xuICBjb25zdCBwYXJhbXMgPSB7XG4gICAgc2VudHJ5X3ZlcnNpb246IFNFTlRSWV9BUElfVkVSU0lPTixcbiAgfTtcblxuICBpZiAoZHNuLnB1YmxpY0tleSkge1xuICAgIC8vIFdlIHNlbmQgb25seSB0aGUgbWluaW11bSBzZXQgb2YgcmVxdWlyZWQgaW5mb3JtYXRpb24uIFNlZVxuICAgIC8vIGh0dHBzOi8vZ2l0aHViLmNvbS9nZXRzZW50cnkvc2VudHJ5LWphdmFzY3JpcHQvaXNzdWVzLzI1NzIuXG4gICAgcGFyYW1zLnNlbnRyeV9rZXkgPSBkc24ucHVibGljS2V5O1xuICB9XG5cbiAgaWYgKHNka0luZm8pIHtcbiAgICBwYXJhbXMuc2VudHJ5X2NsaWVudCA9IGAke3Nka0luZm8ubmFtZX0vJHtzZGtJbmZvLnZlcnNpb259YDtcbiAgfVxuXG4gIHJldHVybiBuZXcgVVJMU2VhcmNoUGFyYW1zKHBhcmFtcykudG9TdHJpbmcoKTtcbn1cblxuLyoqXG4gKiBSZXR1cm5zIHRoZSBlbnZlbG9wZSBlbmRwb2ludCBVUkwgd2l0aCBhdXRoIGluIHRoZSBxdWVyeSBzdHJpbmcuXG4gKlxuICogU2VuZGluZyBhdXRoIGFzIHBhcnQgb2YgdGhlIHF1ZXJ5IHN0cmluZyBhbmQgbm90IGFzIGN1c3RvbSBIVFRQIGhlYWRlcnMgYXZvaWRzIENPUlMgcHJlZmxpZ2h0IHJlcXVlc3RzLlxuICovXG5mdW5jdGlvbiBnZXRFbnZlbG9wZUVuZHBvaW50V2l0aFVybEVuY29kZWRBdXRoKGRzbiwgdHVubmVsLCBzZGtJbmZvKSB7XG4gIHJldHVybiB0dW5uZWwgPyB0dW5uZWwgOiBgJHtfZ2V0SW5nZXN0RW5kcG9pbnQoZHNuKX0/JHtfZW5jb2RlZEF1dGgoZHNuLCBzZGtJbmZvKX1gO1xufVxuXG4vKiogUmV0dXJucyB0aGUgdXJsIHRvIHRoZSByZXBvcnQgZGlhbG9nIGVuZHBvaW50LiAqL1xuZnVuY3Rpb24gZ2V0UmVwb3J0RGlhbG9nRW5kcG9pbnQoZHNuTGlrZSwgZGlhbG9nT3B0aW9ucykge1xuICBjb25zdCBkc24kMSA9IGRzbi5tYWtlRHNuKGRzbkxpa2UpO1xuICBpZiAoIWRzbiQxKSB7XG4gICAgcmV0dXJuICcnO1xuICB9XG5cbiAgY29uc3QgZW5kcG9pbnQgPSBgJHtnZXRCYXNlQXBpRW5kcG9pbnQoZHNuJDEpfWVtYmVkL2Vycm9yLXBhZ2UvYDtcblxuICBsZXQgZW5jb2RlZE9wdGlvbnMgPSBgZHNuPSR7ZHNuLmRzblRvU3RyaW5nKGRzbiQxKX1gO1xuICBmb3IgKGNvbnN0IGtleSBpbiBkaWFsb2dPcHRpb25zKSB7XG4gICAgaWYgKGtleSA9PT0gJ2RzbicpIHtcbiAgICAgIGNvbnRpbnVlO1xuICAgIH1cblxuICAgIGlmIChrZXkgPT09ICdvbkNsb3NlJykge1xuICAgICAgY29udGludWU7XG4gICAgfVxuXG4gICAgaWYgKGtleSA9PT0gJ3VzZXInKSB7XG4gICAgICBjb25zdCB1c2VyID0gZGlhbG9nT3B0aW9ucy51c2VyO1xuICAgICAgaWYgKCF1c2VyKSB7XG4gICAgICAgIGNvbnRpbnVlO1xuICAgICAgfVxuICAgICAgaWYgKHVzZXIubmFtZSkge1xuICAgICAgICBlbmNvZGVkT3B0aW9ucyArPSBgJm5hbWU9JHtlbmNvZGVVUklDb21wb25lbnQodXNlci5uYW1lKX1gO1xuICAgICAgfVxuICAgICAgaWYgKHVzZXIuZW1haWwpIHtcbiAgICAgICAgZW5jb2RlZE9wdGlvbnMgKz0gYCZlbWFpbD0ke2VuY29kZVVSSUNvbXBvbmVudCh1c2VyLmVtYWlsKX1gO1xuICAgICAgfVxuICAgIH0gZWxzZSB7XG4gICAgICBlbmNvZGVkT3B0aW9ucyArPSBgJiR7ZW5jb2RlVVJJQ29tcG9uZW50KGtleSl9PSR7ZW5jb2RlVVJJQ29tcG9uZW50KGRpYWxvZ09wdGlvbnNba2V5XSApfWA7XG4gICAgfVxuICB9XG5cbiAgcmV0dXJuIGAke2VuZHBvaW50fT8ke2VuY29kZWRPcHRpb25zfWA7XG59XG5cbmV4cG9ydHMuZ2V0RW52ZWxvcGVFbmRwb2ludFdpdGhVcmxFbmNvZGVkQXV0aCA9IGdldEVudmVsb3BlRW5kcG9pbnRXaXRoVXJsRW5jb2RlZEF1dGg7XG5leHBvcnRzLmdldFJlcG9ydERpYWxvZ0VuZHBvaW50ID0gZ2V0UmVwb3J0RGlhbG9nRW5kcG9pbnQ7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1hcGkuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/api.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/asyncContext/index.js":
/*!**********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/asyncContext/index.js ***!
  \**********************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst carrier = __webpack_require__(/*! ../carrier.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/carrier.js\");\nconst stackStrategy = __webpack_require__(/*! ./stackStrategy.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/asyncContext/stackStrategy.js\");\n\n/**\n * @private Private API with no semver guarantees!\n *\n * Sets the global async context strategy\n */\nfunction setAsyncContextStrategy(strategy) {\n  // Get main carrier (global for every environment)\n  const registry = carrier.getMainCarrier();\n  const sentry = carrier.getSentryCarrier(registry);\n  sentry.acs = strategy;\n}\n\n/**\n * Get the current async context strategy.\n * If none has been setup, the default will be used.\n */\nfunction getAsyncContextStrategy(carrier$1) {\n  const sentry = carrier.getSentryCarrier(carrier$1);\n\n  if (sentry.acs) {\n    return sentry.acs;\n  }\n\n  // Otherwise, use the default one (stack)\n  return stackStrategy.getStackAsyncContextStrategy();\n}\n\nexports.getAsyncContextStrategy = getAsyncContextStrategy;\nexports.setAsyncContextStrategy = setAsyncContextStrategy;\n//# sourceMappingURL=index.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvYXN5bmNDb250ZXh0L2luZGV4LmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLGdCQUFnQixtQkFBTyxDQUFDLDJIQUFlO0FBQ3ZDLHNCQUFzQixtQkFBTyxDQUFDLG1KQUFvQjs7QUFFbEQ7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQSwrQkFBK0I7QUFDL0IsK0JBQStCO0FBQy9CIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvYXN5bmNDb250ZXh0L2luZGV4LmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBjYXJyaWVyID0gcmVxdWlyZSgnLi4vY2Fycmllci5qcycpO1xuY29uc3Qgc3RhY2tTdHJhdGVneSA9IHJlcXVpcmUoJy4vc3RhY2tTdHJhdGVneS5qcycpO1xuXG4vKipcbiAqIEBwcml2YXRlIFByaXZhdGUgQVBJIHdpdGggbm8gc2VtdmVyIGd1YXJhbnRlZXMhXG4gKlxuICogU2V0cyB0aGUgZ2xvYmFsIGFzeW5jIGNvbnRleHQgc3RyYXRlZ3lcbiAqL1xuZnVuY3Rpb24gc2V0QXN5bmNDb250ZXh0U3RyYXRlZ3koc3RyYXRlZ3kpIHtcbiAgLy8gR2V0IG1haW4gY2FycmllciAoZ2xvYmFsIGZvciBldmVyeSBlbnZpcm9ubWVudClcbiAgY29uc3QgcmVnaXN0cnkgPSBjYXJyaWVyLmdldE1haW5DYXJyaWVyKCk7XG4gIGNvbnN0IHNlbnRyeSA9IGNhcnJpZXIuZ2V0U2VudHJ5Q2FycmllcihyZWdpc3RyeSk7XG4gIHNlbnRyeS5hY3MgPSBzdHJhdGVneTtcbn1cblxuLyoqXG4gKiBHZXQgdGhlIGN1cnJlbnQgYXN5bmMgY29udGV4dCBzdHJhdGVneS5cbiAqIElmIG5vbmUgaGFzIGJlZW4gc2V0dXAsIHRoZSBkZWZhdWx0IHdpbGwgYmUgdXNlZC5cbiAqL1xuZnVuY3Rpb24gZ2V0QXN5bmNDb250ZXh0U3RyYXRlZ3koY2FycmllciQxKSB7XG4gIGNvbnN0IHNlbnRyeSA9IGNhcnJpZXIuZ2V0U2VudHJ5Q2FycmllcihjYXJyaWVyJDEpO1xuXG4gIGlmIChzZW50cnkuYWNzKSB7XG4gICAgcmV0dXJuIHNlbnRyeS5hY3M7XG4gIH1cblxuICAvLyBPdGhlcndpc2UsIHVzZSB0aGUgZGVmYXVsdCBvbmUgKHN0YWNrKVxuICByZXR1cm4gc3RhY2tTdHJhdGVneS5nZXRTdGFja0FzeW5jQ29udGV4dFN0cmF0ZWd5KCk7XG59XG5cbmV4cG9ydHMuZ2V0QXN5bmNDb250ZXh0U3RyYXRlZ3kgPSBnZXRBc3luY0NvbnRleHRTdHJhdGVneTtcbmV4cG9ydHMuc2V0QXN5bmNDb250ZXh0U3RyYXRlZ3kgPSBzZXRBc3luY0NvbnRleHRTdHJhdGVneTtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWluZGV4LmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/asyncContext/index.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/asyncContext/stackStrategy.js":
/*!******************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/asyncContext/stackStrategy.js ***!
  \******************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst defaultScopes = __webpack_require__(/*! ../defaultScopes.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/defaultScopes.js\");\nconst scope = __webpack_require__(/*! ../scope.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/scope.js\");\nconst is = __webpack_require__(/*! ../utils/is.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js\");\nconst carrier = __webpack_require__(/*! ../carrier.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/carrier.js\");\n\n/**\n * This is an object that holds a stack of scopes.\n */\nclass AsyncContextStack {\n\n   constructor(scope$1, isolationScope) {\n    let assignedScope;\n    if (!scope$1) {\n      assignedScope = new scope.Scope();\n    } else {\n      assignedScope = scope$1;\n    }\n\n    let assignedIsolationScope;\n    if (!isolationScope) {\n      assignedIsolationScope = new scope.Scope();\n    } else {\n      assignedIsolationScope = isolationScope;\n    }\n\n    // scope stack for domains or the process\n    this._stack = [{ scope: assignedScope }];\n    this._isolationScope = assignedIsolationScope;\n  }\n\n  /**\n   * Fork a scope for the stack.\n   */\n   withScope(callback) {\n    const scope = this._pushScope();\n\n    let maybePromiseResult;\n    try {\n      maybePromiseResult = callback(scope);\n    } catch (e) {\n      this._popScope();\n      throw e;\n    }\n\n    if (is.isThenable(maybePromiseResult)) {\n      // @ts-expect-error - isThenable returns the wrong type\n      return maybePromiseResult.then(\n        res => {\n          this._popScope();\n          return res;\n        },\n        e => {\n          this._popScope();\n          throw e;\n        },\n      );\n    }\n\n    this._popScope();\n    return maybePromiseResult;\n  }\n\n  /**\n   * Get the client of the stack.\n   */\n   getClient() {\n    return this.getStackTop().client ;\n  }\n\n  /**\n   * Returns the scope of the top stack.\n   */\n   getScope() {\n    return this.getStackTop().scope;\n  }\n\n  /**\n   * Get the isolation scope for the stack.\n   */\n   getIsolationScope() {\n    return this._isolationScope;\n  }\n\n  /**\n   * Returns the topmost scope layer in the order domain > local > process.\n   */\n   getStackTop() {\n    return this._stack[this._stack.length - 1] ;\n  }\n\n  /**\n   * Push a scope to the stack.\n   */\n   _pushScope() {\n    // We want to clone the content of prev scope\n    const scope = this.getScope().clone();\n    this._stack.push({\n      client: this.getClient(),\n      scope,\n    });\n    return scope;\n  }\n\n  /**\n   * Pop a scope from the stack.\n   */\n   _popScope() {\n    if (this._stack.length <= 1) return false;\n    return !!this._stack.pop();\n  }\n}\n\n/**\n * Get the global async context stack.\n * This will be removed during the v8 cycle and is only here to make migration easier.\n */\nfunction getAsyncContextStack() {\n  const registry = carrier.getMainCarrier();\n  const sentry = carrier.getSentryCarrier(registry);\n\n  return (sentry.stack = sentry.stack || new AsyncContextStack(defaultScopes.getDefaultCurrentScope(), defaultScopes.getDefaultIsolationScope()));\n}\n\nfunction withScope(callback) {\n  return getAsyncContextStack().withScope(callback);\n}\n\nfunction withSetScope(scope, callback) {\n  const stack = getAsyncContextStack() ;\n  return stack.withScope(() => {\n    stack.getStackTop().scope = scope;\n    return callback(scope);\n  });\n}\n\nfunction withIsolationScope(callback) {\n  return getAsyncContextStack().withScope(() => {\n    return callback(getAsyncContextStack().getIsolationScope());\n  });\n}\n\n/**\n * Get the stack-based async context strategy.\n */\nfunction getStackAsyncContextStrategy() {\n  return {\n    withIsolationScope,\n    withScope,\n    withSetScope,\n    withSetIsolationScope: (_isolationScope, callback) => {\n      return withIsolationScope(callback);\n    },\n    getCurrentScope: () => getAsyncContextStack().getScope(),\n    getIsolationScope: () => getAsyncContextStack().getIsolationScope(),\n  };\n}\n\nexports.AsyncContextStack = AsyncContextStack;\nexports.getStackAsyncContextStrategy = getStackAsyncContextStrategy;\n//# sourceMappingURL=stackStrategy.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvYXN5bmNDb250ZXh0L3N0YWNrU3RyYXRlZ3kuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsc0JBQXNCLG1CQUFPLENBQUMsdUlBQXFCO0FBQ25ELGNBQWMsbUJBQU8sQ0FBQyx1SEFBYTtBQUNuQyxXQUFXLG1CQUFPLENBQUMsNkhBQWdCO0FBQ25DLGdCQUFnQixtQkFBTyxDQUFDLDJIQUFlOztBQUV2QztBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLE1BQU07QUFDTjtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBLE1BQU07QUFDTjtBQUNBOztBQUVBO0FBQ0EscUJBQXFCLHNCQUFzQjtBQUMzQztBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0EsTUFBTTtBQUNOO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxTQUFTO0FBQ1Q7QUFDQTtBQUNBO0FBQ0EsU0FBUztBQUNUO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxLQUFLO0FBQ0w7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxHQUFHO0FBQ0g7O0FBRUE7QUFDQTtBQUNBO0FBQ0EsR0FBRztBQUNIOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsS0FBSztBQUNMO0FBQ0E7QUFDQTtBQUNBOztBQUVBLHlCQUF5QjtBQUN6QixvQ0FBb0M7QUFDcEMiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9hc3luY0NvbnRleHQvc3RhY2tTdHJhdGVneS5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgZGVmYXVsdFNjb3BlcyA9IHJlcXVpcmUoJy4uL2RlZmF1bHRTY29wZXMuanMnKTtcbmNvbnN0IHNjb3BlID0gcmVxdWlyZSgnLi4vc2NvcGUuanMnKTtcbmNvbnN0IGlzID0gcmVxdWlyZSgnLi4vdXRpbHMvaXMuanMnKTtcbmNvbnN0IGNhcnJpZXIgPSByZXF1aXJlKCcuLi9jYXJyaWVyLmpzJyk7XG5cbi8qKlxuICogVGhpcyBpcyBhbiBvYmplY3QgdGhhdCBob2xkcyBhIHN0YWNrIG9mIHNjb3Blcy5cbiAqL1xuY2xhc3MgQXN5bmNDb250ZXh0U3RhY2sge1xuXG4gICBjb25zdHJ1Y3RvcihzY29wZSQxLCBpc29sYXRpb25TY29wZSkge1xuICAgIGxldCBhc3NpZ25lZFNjb3BlO1xuICAgIGlmICghc2NvcGUkMSkge1xuICAgICAgYXNzaWduZWRTY29wZSA9IG5ldyBzY29wZS5TY29wZSgpO1xuICAgIH0gZWxzZSB7XG4gICAgICBhc3NpZ25lZFNjb3BlID0gc2NvcGUkMTtcbiAgICB9XG5cbiAgICBsZXQgYXNzaWduZWRJc29sYXRpb25TY29wZTtcbiAgICBpZiAoIWlzb2xhdGlvblNjb3BlKSB7XG4gICAgICBhc3NpZ25lZElzb2xhdGlvblNjb3BlID0gbmV3IHNjb3BlLlNjb3BlKCk7XG4gICAgfSBlbHNlIHtcbiAgICAgIGFzc2lnbmVkSXNvbGF0aW9uU2NvcGUgPSBpc29sYXRpb25TY29wZTtcbiAgICB9XG5cbiAgICAvLyBzY29wZSBzdGFjayBmb3IgZG9tYWlucyBvciB0aGUgcHJvY2Vzc1xuICAgIHRoaXMuX3N0YWNrID0gW3sgc2NvcGU6IGFzc2lnbmVkU2NvcGUgfV07XG4gICAgdGhpcy5faXNvbGF0aW9uU2NvcGUgPSBhc3NpZ25lZElzb2xhdGlvblNjb3BlO1xuICB9XG5cbiAgLyoqXG4gICAqIEZvcmsgYSBzY29wZSBmb3IgdGhlIHN0YWNrLlxuICAgKi9cbiAgIHdpdGhTY29wZShjYWxsYmFjaykge1xuICAgIGNvbnN0IHNjb3BlID0gdGhpcy5fcHVzaFNjb3BlKCk7XG5cbiAgICBsZXQgbWF5YmVQcm9taXNlUmVzdWx0O1xuICAgIHRyeSB7XG4gICAgICBtYXliZVByb21pc2VSZXN1bHQgPSBjYWxsYmFjayhzY29wZSk7XG4gICAgfSBjYXRjaCAoZSkge1xuICAgICAgdGhpcy5fcG9wU2NvcGUoKTtcbiAgICAgIHRocm93IGU7XG4gICAgfVxuXG4gICAgaWYgKGlzLmlzVGhlbmFibGUobWF5YmVQcm9taXNlUmVzdWx0KSkge1xuICAgICAgLy8gQHRzLWV4cGVjdC1lcnJvciAtIGlzVGhlbmFibGUgcmV0dXJucyB0aGUgd3JvbmcgdHlwZVxuICAgICAgcmV0dXJuIG1heWJlUHJvbWlzZVJlc3VsdC50aGVuKFxuICAgICAgICByZXMgPT4ge1xuICAgICAgICAgIHRoaXMuX3BvcFNjb3BlKCk7XG4gICAgICAgICAgcmV0dXJuIHJlcztcbiAgICAgICAgfSxcbiAgICAgICAgZSA9PiB7XG4gICAgICAgICAgdGhpcy5fcG9wU2NvcGUoKTtcbiAgICAgICAgICB0aHJvdyBlO1xuICAgICAgICB9LFxuICAgICAgKTtcbiAgICB9XG5cbiAgICB0aGlzLl9wb3BTY29wZSgpO1xuICAgIHJldHVybiBtYXliZVByb21pc2VSZXN1bHQ7XG4gIH1cblxuICAvKipcbiAgICogR2V0IHRoZSBjbGllbnQgb2YgdGhlIHN0YWNrLlxuICAgKi9cbiAgIGdldENsaWVudCgpIHtcbiAgICByZXR1cm4gdGhpcy5nZXRTdGFja1RvcCgpLmNsaWVudCA7XG4gIH1cblxuICAvKipcbiAgICogUmV0dXJucyB0aGUgc2NvcGUgb2YgdGhlIHRvcCBzdGFjay5cbiAgICovXG4gICBnZXRTY29wZSgpIHtcbiAgICByZXR1cm4gdGhpcy5nZXRTdGFja1RvcCgpLnNjb3BlO1xuICB9XG5cbiAgLyoqXG4gICAqIEdldCB0aGUgaXNvbGF0aW9uIHNjb3BlIGZvciB0aGUgc3RhY2suXG4gICAqL1xuICAgZ2V0SXNvbGF0aW9uU2NvcGUoKSB7XG4gICAgcmV0dXJuIHRoaXMuX2lzb2xhdGlvblNjb3BlO1xuICB9XG5cbiAgLyoqXG4gICAqIFJldHVybnMgdGhlIHRvcG1vc3Qgc2NvcGUgbGF5ZXIgaW4gdGhlIG9yZGVyIGRvbWFpbiA+IGxvY2FsID4gcHJvY2Vzcy5cbiAgICovXG4gICBnZXRTdGFja1RvcCgpIHtcbiAgICByZXR1cm4gdGhpcy5fc3RhY2tbdGhpcy5fc3RhY2subGVuZ3RoIC0gMV0gO1xuICB9XG5cbiAgLyoqXG4gICAqIFB1c2ggYSBzY29wZSB0byB0aGUgc3RhY2suXG4gICAqL1xuICAgX3B1c2hTY29wZSgpIHtcbiAgICAvLyBXZSB3YW50IHRvIGNsb25lIHRoZSBjb250ZW50IG9mIHByZXYgc2NvcGVcbiAgICBjb25zdCBzY29wZSA9IHRoaXMuZ2V0U2NvcGUoKS5jbG9uZSgpO1xuICAgIHRoaXMuX3N0YWNrLnB1c2goe1xuICAgICAgY2xpZW50OiB0aGlzLmdldENsaWVudCgpLFxuICAgICAgc2NvcGUsXG4gICAgfSk7XG4gICAgcmV0dXJuIHNjb3BlO1xuICB9XG5cbiAgLyoqXG4gICAqIFBvcCBhIHNjb3BlIGZyb20gdGhlIHN0YWNrLlxuICAgKi9cbiAgIF9wb3BTY29wZSgpIHtcbiAgICBpZiAodGhpcy5fc3RhY2subGVuZ3RoIDw9IDEpIHJldHVybiBmYWxzZTtcbiAgICByZXR1cm4gISF0aGlzLl9zdGFjay5wb3AoKTtcbiAgfVxufVxuXG4vKipcbiAqIEdldCB0aGUgZ2xvYmFsIGFzeW5jIGNvbnRleHQgc3RhY2suXG4gKiBUaGlzIHdpbGwgYmUgcmVtb3ZlZCBkdXJpbmcgdGhlIHY4IGN5Y2xlIGFuZCBpcyBvbmx5IGhlcmUgdG8gbWFrZSBtaWdyYXRpb24gZWFzaWVyLlxuICovXG5mdW5jdGlvbiBnZXRBc3luY0NvbnRleHRTdGFjaygpIHtcbiAgY29uc3QgcmVnaXN0cnkgPSBjYXJyaWVyLmdldE1haW5DYXJyaWVyKCk7XG4gIGNvbnN0IHNlbnRyeSA9IGNhcnJpZXIuZ2V0U2VudHJ5Q2FycmllcihyZWdpc3RyeSk7XG5cbiAgcmV0dXJuIChzZW50cnkuc3RhY2sgPSBzZW50cnkuc3RhY2sgfHwgbmV3IEFzeW5jQ29udGV4dFN0YWNrKGRlZmF1bHRTY29wZXMuZ2V0RGVmYXVsdEN1cnJlbnRTY29wZSgpLCBkZWZhdWx0U2NvcGVzLmdldERlZmF1bHRJc29sYXRpb25TY29wZSgpKSk7XG59XG5cbmZ1bmN0aW9uIHdpdGhTY29wZShjYWxsYmFjaykge1xuICByZXR1cm4gZ2V0QXN5bmNDb250ZXh0U3RhY2soKS53aXRoU2NvcGUoY2FsbGJhY2spO1xufVxuXG5mdW5jdGlvbiB3aXRoU2V0U2NvcGUoc2NvcGUsIGNhbGxiYWNrKSB7XG4gIGNvbnN0IHN0YWNrID0gZ2V0QXN5bmNDb250ZXh0U3RhY2soKSA7XG4gIHJldHVybiBzdGFjay53aXRoU2NvcGUoKCkgPT4ge1xuICAgIHN0YWNrLmdldFN0YWNrVG9wKCkuc2NvcGUgPSBzY29wZTtcbiAgICByZXR1cm4gY2FsbGJhY2soc2NvcGUpO1xuICB9KTtcbn1cblxuZnVuY3Rpb24gd2l0aElzb2xhdGlvblNjb3BlKGNhbGxiYWNrKSB7XG4gIHJldHVybiBnZXRBc3luY0NvbnRleHRTdGFjaygpLndpdGhTY29wZSgoKSA9PiB7XG4gICAgcmV0dXJuIGNhbGxiYWNrKGdldEFzeW5jQ29udGV4dFN0YWNrKCkuZ2V0SXNvbGF0aW9uU2NvcGUoKSk7XG4gIH0pO1xufVxuXG4vKipcbiAqIEdldCB0aGUgc3RhY2stYmFzZWQgYXN5bmMgY29udGV4dCBzdHJhdGVneS5cbiAqL1xuZnVuY3Rpb24gZ2V0U3RhY2tBc3luY0NvbnRleHRTdHJhdGVneSgpIHtcbiAgcmV0dXJuIHtcbiAgICB3aXRoSXNvbGF0aW9uU2NvcGUsXG4gICAgd2l0aFNjb3BlLFxuICAgIHdpdGhTZXRTY29wZSxcbiAgICB3aXRoU2V0SXNvbGF0aW9uU2NvcGU6IChfaXNvbGF0aW9uU2NvcGUsIGNhbGxiYWNrKSA9PiB7XG4gICAgICByZXR1cm4gd2l0aElzb2xhdGlvblNjb3BlKGNhbGxiYWNrKTtcbiAgICB9LFxuICAgIGdldEN1cnJlbnRTY29wZTogKCkgPT4gZ2V0QXN5bmNDb250ZXh0U3RhY2soKS5nZXRTY29wZSgpLFxuICAgIGdldElzb2xhdGlvblNjb3BlOiAoKSA9PiBnZXRBc3luY0NvbnRleHRTdGFjaygpLmdldElzb2xhdGlvblNjb3BlKCksXG4gIH07XG59XG5cbmV4cG9ydHMuQXN5bmNDb250ZXh0U3RhY2sgPSBBc3luY0NvbnRleHRTdGFjaztcbmV4cG9ydHMuZ2V0U3RhY2tBc3luY0NvbnRleHRTdHJhdGVneSA9IGdldFN0YWNrQXN5bmNDb250ZXh0U3RyYXRlZ3k7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1zdGFja1N0cmF0ZWd5LmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/asyncContext/stackStrategy.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/breadcrumbs.js":
/*!***************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/breadcrumbs.js ***!
  \***************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst currentScopes = __webpack_require__(/*! ./currentScopes.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst debugLogger = __webpack_require__(/*! ./utils/debug-logger.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst time = __webpack_require__(/*! ./utils/time.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/time.js\");\n\n/**\n * Default maximum number of breadcrumbs added to an event. Can be overwritten\n * with {@link Options.maxBreadcrumbs}.\n */\nconst DEFAULT_BREADCRUMBS = 100;\n\n/**\n * Records a new breadcrumb which will be attached to future events.\n *\n * Breadcrumbs will be added to subsequent events to provide more context on\n * user's actions prior to an error or crash.\n */\nfunction addBreadcrumb(breadcrumb, hint) {\n  const client = currentScopes.getClient();\n  const isolationScope = currentScopes.getIsolationScope();\n\n  if (!client) return;\n\n  const { beforeBreadcrumb = null, maxBreadcrumbs = DEFAULT_BREADCRUMBS } = client.getOptions();\n\n  if (maxBreadcrumbs <= 0) return;\n\n  const timestamp = time.dateTimestampInSeconds();\n  const mergedBreadcrumb = { timestamp, ...breadcrumb };\n  const finalBreadcrumb = beforeBreadcrumb\n    ? (debugLogger.consoleSandbox(() => beforeBreadcrumb(mergedBreadcrumb, hint)) )\n    : mergedBreadcrumb;\n\n  if (finalBreadcrumb === null) return;\n\n  if (client.emit) {\n    client.emit('beforeAddBreadcrumb', finalBreadcrumb, hint);\n  }\n\n  isolationScope.addBreadcrumb(finalBreadcrumb, maxBreadcrumbs);\n}\n\nexports.addBreadcrumb = addBreadcrumb;\n//# sourceMappingURL=breadcrumbs.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvYnJlYWRjcnVtYnMuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsc0JBQXNCLG1CQUFPLENBQUMsc0lBQW9CO0FBQ2xELG9CQUFvQixtQkFBTyxDQUFDLGdKQUF5QjtBQUNyRCxhQUFhLG1CQUFPLENBQUMsZ0lBQWlCOztBQUV0QztBQUNBO0FBQ0EsU0FBUyw2QkFBNkI7QUFDdEM7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUEsVUFBVSxnRUFBZ0U7O0FBRTFFOztBQUVBO0FBQ0EsNkJBQTZCO0FBQzdCO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQSxxQkFBcUI7QUFDckIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9icmVhZGNydW1icy5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgY3VycmVudFNjb3BlcyA9IHJlcXVpcmUoJy4vY3VycmVudFNjb3Blcy5qcycpO1xuY29uc3QgZGVidWdMb2dnZXIgPSByZXF1aXJlKCcuL3V0aWxzL2RlYnVnLWxvZ2dlci5qcycpO1xuY29uc3QgdGltZSA9IHJlcXVpcmUoJy4vdXRpbHMvdGltZS5qcycpO1xuXG4vKipcbiAqIERlZmF1bHQgbWF4aW11bSBudW1iZXIgb2YgYnJlYWRjcnVtYnMgYWRkZWQgdG8gYW4gZXZlbnQuIENhbiBiZSBvdmVyd3JpdHRlblxuICogd2l0aCB7QGxpbmsgT3B0aW9ucy5tYXhCcmVhZGNydW1ic30uXG4gKi9cbmNvbnN0IERFRkFVTFRfQlJFQURDUlVNQlMgPSAxMDA7XG5cbi8qKlxuICogUmVjb3JkcyBhIG5ldyBicmVhZGNydW1iIHdoaWNoIHdpbGwgYmUgYXR0YWNoZWQgdG8gZnV0dXJlIGV2ZW50cy5cbiAqXG4gKiBCcmVhZGNydW1icyB3aWxsIGJlIGFkZGVkIHRvIHN1YnNlcXVlbnQgZXZlbnRzIHRvIHByb3ZpZGUgbW9yZSBjb250ZXh0IG9uXG4gKiB1c2VyJ3MgYWN0aW9ucyBwcmlvciB0byBhbiBlcnJvciBvciBjcmFzaC5cbiAqL1xuZnVuY3Rpb24gYWRkQnJlYWRjcnVtYihicmVhZGNydW1iLCBoaW50KSB7XG4gIGNvbnN0IGNsaWVudCA9IGN1cnJlbnRTY29wZXMuZ2V0Q2xpZW50KCk7XG4gIGNvbnN0IGlzb2xhdGlvblNjb3BlID0gY3VycmVudFNjb3Blcy5nZXRJc29sYXRpb25TY29wZSgpO1xuXG4gIGlmICghY2xpZW50KSByZXR1cm47XG5cbiAgY29uc3QgeyBiZWZvcmVCcmVhZGNydW1iID0gbnVsbCwgbWF4QnJlYWRjcnVtYnMgPSBERUZBVUxUX0JSRUFEQ1JVTUJTIH0gPSBjbGllbnQuZ2V0T3B0aW9ucygpO1xuXG4gIGlmIChtYXhCcmVhZGNydW1icyA8PSAwKSByZXR1cm47XG5cbiAgY29uc3QgdGltZXN0YW1wID0gdGltZS5kYXRlVGltZXN0YW1wSW5TZWNvbmRzKCk7XG4gIGNvbnN0IG1lcmdlZEJyZWFkY3J1bWIgPSB7IHRpbWVzdGFtcCwgLi4uYnJlYWRjcnVtYiB9O1xuICBjb25zdCBmaW5hbEJyZWFkY3J1bWIgPSBiZWZvcmVCcmVhZGNydW1iXG4gICAgPyAoZGVidWdMb2dnZXIuY29uc29sZVNhbmRib3goKCkgPT4gYmVmb3JlQnJlYWRjcnVtYihtZXJnZWRCcmVhZGNydW1iLCBoaW50KSkgKVxuICAgIDogbWVyZ2VkQnJlYWRjcnVtYjtcblxuICBpZiAoZmluYWxCcmVhZGNydW1iID09PSBudWxsKSByZXR1cm47XG5cbiAgaWYgKGNsaWVudC5lbWl0KSB7XG4gICAgY2xpZW50LmVtaXQoJ2JlZm9yZUFkZEJyZWFkY3J1bWInLCBmaW5hbEJyZWFkY3J1bWIsIGhpbnQpO1xuICB9XG5cbiAgaXNvbGF0aW9uU2NvcGUuYWRkQnJlYWRjcnVtYihmaW5hbEJyZWFkY3J1bWIsIG1heEJyZWFkY3J1bWJzKTtcbn1cblxuZXhwb3J0cy5hZGRCcmVhZGNydW1iID0gYWRkQnJlYWRjcnVtYjtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWJyZWFkY3J1bWJzLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/breadcrumbs.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/carrier.js":
/*!***********************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/carrier.js ***!
  \***********************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst version = __webpack_require__(/*! ./utils/version.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/version.js\");\nconst worldwide = __webpack_require__(/*! ./utils/worldwide.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/worldwide.js\");\n\n/**\n * An object that contains globally accessible properties and maintains a scope stack.\n * @hidden\n */\n\n/**\n * Returns the global shim registry.\n *\n * FIXME: This function is problematic, because despite always returning a valid Carrier,\n * it has an optional `__SENTRY__` property, which then in turn requires us to always perform an unnecessary check\n * at the call-site. We always access the carrier through this function, so we can guarantee that `__SENTRY__` is there.\n **/\nfunction getMainCarrier() {\n  // This ensures a Sentry carrier exists\n  getSentryCarrier(worldwide.GLOBAL_OBJ);\n  return worldwide.GLOBAL_OBJ;\n}\n\n/** Will either get the existing sentry carrier, or create a new one. */\nfunction getSentryCarrier(carrier) {\n  const __SENTRY__ = (carrier.__SENTRY__ = carrier.__SENTRY__ || {});\n\n  // For now: First SDK that sets the .version property wins\n  __SENTRY__.version = __SENTRY__.version || version.SDK_VERSION;\n\n  // Intentionally populating and returning the version of \"this\" SDK instance\n  // rather than what's set in .version so that \"this\" SDK always gets its carrier\n  return (__SENTRY__[version.SDK_VERSION] = __SENTRY__[version.SDK_VERSION] || {});\n}\n\n/**\n * Returns a global singleton contained in the global `__SENTRY__[]` object.\n *\n * If the singleton doesn't already exist in `__SENTRY__`, it will be created using the given factory\n * function and added to the `__SENTRY__` object.\n *\n * @param name name of the global singleton on __SENTRY__\n * @param creator creator Factory function to create the singleton if it doesn't already exist on `__SENTRY__`\n * @param obj (Optional) The global object on which to look for `__SENTRY__`, if not `GLOBAL_OBJ`'s return value\n * @returns the singleton\n */\nfunction getGlobalSingleton(\n  name,\n  creator,\n  obj = worldwide.GLOBAL_OBJ,\n) {\n  const __SENTRY__ = (obj.__SENTRY__ = obj.__SENTRY__ || {});\n  const carrier = (__SENTRY__[version.SDK_VERSION] = __SENTRY__[version.SDK_VERSION] || {});\n  // Note: We do not want to set `carrier.version` here, as this may be called before any `init` is called, e.g. for the default scopes\n  return carrier[name] || (carrier[name] = creator());\n}\n\nexports.getGlobalSingleton = getGlobalSingleton;\nexports.getMainCarrier = getMainCarrier;\nexports.getSentryCarrier = getSentryCarrier;\n//# sourceMappingURL=carrier.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvY2Fycmllci5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxnQkFBZ0IsbUJBQU8sQ0FBQyxzSUFBb0I7QUFDNUMsa0JBQWtCLG1CQUFPLENBQUMsMElBQXNCOztBQUVoRDtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLG1FQUFtRTs7QUFFbkU7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsaUZBQWlGO0FBQ2pGOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsMkRBQTJEO0FBQzNELDBGQUEwRjtBQUMxRjtBQUNBO0FBQ0E7O0FBRUEsMEJBQTBCO0FBQzFCLHNCQUFzQjtBQUN0Qix3QkFBd0I7QUFDeEIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9jYXJyaWVyLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCB2ZXJzaW9uID0gcmVxdWlyZSgnLi91dGlscy92ZXJzaW9uLmpzJyk7XG5jb25zdCB3b3JsZHdpZGUgPSByZXF1aXJlKCcuL3V0aWxzL3dvcmxkd2lkZS5qcycpO1xuXG4vKipcbiAqIEFuIG9iamVjdCB0aGF0IGNvbnRhaW5zIGdsb2JhbGx5IGFjY2Vzc2libGUgcHJvcGVydGllcyBhbmQgbWFpbnRhaW5zIGEgc2NvcGUgc3RhY2suXG4gKiBAaGlkZGVuXG4gKi9cblxuLyoqXG4gKiBSZXR1cm5zIHRoZSBnbG9iYWwgc2hpbSByZWdpc3RyeS5cbiAqXG4gKiBGSVhNRTogVGhpcyBmdW5jdGlvbiBpcyBwcm9ibGVtYXRpYywgYmVjYXVzZSBkZXNwaXRlIGFsd2F5cyByZXR1cm5pbmcgYSB2YWxpZCBDYXJyaWVyLFxuICogaXQgaGFzIGFuIG9wdGlvbmFsIGBfX1NFTlRSWV9fYCBwcm9wZXJ0eSwgd2hpY2ggdGhlbiBpbiB0dXJuIHJlcXVpcmVzIHVzIHRvIGFsd2F5cyBwZXJmb3JtIGFuIHVubmVjZXNzYXJ5IGNoZWNrXG4gKiBhdCB0aGUgY2FsbC1zaXRlLiBXZSBhbHdheXMgYWNjZXNzIHRoZSBjYXJyaWVyIHRocm91Z2ggdGhpcyBmdW5jdGlvbiwgc28gd2UgY2FuIGd1YXJhbnRlZSB0aGF0IGBfX1NFTlRSWV9fYCBpcyB0aGVyZS5cbiAqKi9cbmZ1bmN0aW9uIGdldE1haW5DYXJyaWVyKCkge1xuICAvLyBUaGlzIGVuc3VyZXMgYSBTZW50cnkgY2FycmllciBleGlzdHNcbiAgZ2V0U2VudHJ5Q2Fycmllcih3b3JsZHdpZGUuR0xPQkFMX09CSik7XG4gIHJldHVybiB3b3JsZHdpZGUuR0xPQkFMX09CSjtcbn1cblxuLyoqIFdpbGwgZWl0aGVyIGdldCB0aGUgZXhpc3Rpbmcgc2VudHJ5IGNhcnJpZXIsIG9yIGNyZWF0ZSBhIG5ldyBvbmUuICovXG5mdW5jdGlvbiBnZXRTZW50cnlDYXJyaWVyKGNhcnJpZXIpIHtcbiAgY29uc3QgX19TRU5UUllfXyA9IChjYXJyaWVyLl9fU0VOVFJZX18gPSBjYXJyaWVyLl9fU0VOVFJZX18gfHwge30pO1xuXG4gIC8vIEZvciBub3c6IEZpcnN0IFNESyB0aGF0IHNldHMgdGhlIC52ZXJzaW9uIHByb3BlcnR5IHdpbnNcbiAgX19TRU5UUllfXy52ZXJzaW9uID0gX19TRU5UUllfXy52ZXJzaW9uIHx8IHZlcnNpb24uU0RLX1ZFUlNJT047XG5cbiAgLy8gSW50ZW50aW9uYWxseSBwb3B1bGF0aW5nIGFuZCByZXR1cm5pbmcgdGhlIHZlcnNpb24gb2YgXCJ0aGlzXCIgU0RLIGluc3RhbmNlXG4gIC8vIHJhdGhlciB0aGFuIHdoYXQncyBzZXQgaW4gLnZlcnNpb24gc28gdGhhdCBcInRoaXNcIiBTREsgYWx3YXlzIGdldHMgaXRzIGNhcnJpZXJcbiAgcmV0dXJuIChfX1NFTlRSWV9fW3ZlcnNpb24uU0RLX1ZFUlNJT05dID0gX19TRU5UUllfX1t2ZXJzaW9uLlNES19WRVJTSU9OXSB8fCB7fSk7XG59XG5cbi8qKlxuICogUmV0dXJucyBhIGdsb2JhbCBzaW5nbGV0b24gY29udGFpbmVkIGluIHRoZSBnbG9iYWwgYF9fU0VOVFJZX19bXWAgb2JqZWN0LlxuICpcbiAqIElmIHRoZSBzaW5nbGV0b24gZG9lc24ndCBhbHJlYWR5IGV4aXN0IGluIGBfX1NFTlRSWV9fYCwgaXQgd2lsbCBiZSBjcmVhdGVkIHVzaW5nIHRoZSBnaXZlbiBmYWN0b3J5XG4gKiBmdW5jdGlvbiBhbmQgYWRkZWQgdG8gdGhlIGBfX1NFTlRSWV9fYCBvYmplY3QuXG4gKlxuICogQHBhcmFtIG5hbWUgbmFtZSBvZiB0aGUgZ2xvYmFsIHNpbmdsZXRvbiBvbiBfX1NFTlRSWV9fXG4gKiBAcGFyYW0gY3JlYXRvciBjcmVhdG9yIEZhY3RvcnkgZnVuY3Rpb24gdG8gY3JlYXRlIHRoZSBzaW5nbGV0b24gaWYgaXQgZG9lc24ndCBhbHJlYWR5IGV4aXN0IG9uIGBfX1NFTlRSWV9fYFxuICogQHBhcmFtIG9iaiAoT3B0aW9uYWwpIFRoZSBnbG9iYWwgb2JqZWN0IG9uIHdoaWNoIHRvIGxvb2sgZm9yIGBfX1NFTlRSWV9fYCwgaWYgbm90IGBHTE9CQUxfT0JKYCdzIHJldHVybiB2YWx1ZVxuICogQHJldHVybnMgdGhlIHNpbmdsZXRvblxuICovXG5mdW5jdGlvbiBnZXRHbG9iYWxTaW5nbGV0b24oXG4gIG5hbWUsXG4gIGNyZWF0b3IsXG4gIG9iaiA9IHdvcmxkd2lkZS5HTE9CQUxfT0JKLFxuKSB7XG4gIGNvbnN0IF9fU0VOVFJZX18gPSAob2JqLl9fU0VOVFJZX18gPSBvYmouX19TRU5UUllfXyB8fCB7fSk7XG4gIGNvbnN0IGNhcnJpZXIgPSAoX19TRU5UUllfX1t2ZXJzaW9uLlNES19WRVJTSU9OXSA9IF9fU0VOVFJZX19bdmVyc2lvbi5TREtfVkVSU0lPTl0gfHwge30pO1xuICAvLyBOb3RlOiBXZSBkbyBub3Qgd2FudCB0byBzZXQgYGNhcnJpZXIudmVyc2lvbmAgaGVyZSwgYXMgdGhpcyBtYXkgYmUgY2FsbGVkIGJlZm9yZSBhbnkgYGluaXRgIGlzIGNhbGxlZCwgZS5nLiBmb3IgdGhlIGRlZmF1bHQgc2NvcGVzXG4gIHJldHVybiBjYXJyaWVyW25hbWVdIHx8IChjYXJyaWVyW25hbWVdID0gY3JlYXRvcigpKTtcbn1cblxuZXhwb3J0cy5nZXRHbG9iYWxTaW5nbGV0b24gPSBnZXRHbG9iYWxTaW5nbGV0b247XG5leHBvcnRzLmdldE1haW5DYXJyaWVyID0gZ2V0TWFpbkNhcnJpZXI7XG5leHBvcnRzLmdldFNlbnRyeUNhcnJpZXIgPSBnZXRTZW50cnlDYXJyaWVyO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9Y2Fycmllci5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/carrier.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/checkin.js":
/*!***********************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/checkin.js ***!
  \***********************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst dsn = __webpack_require__(/*! ./utils/dsn.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/dsn.js\");\nconst envelope = __webpack_require__(/*! ./utils/envelope.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/envelope.js\");\n\n/**\n * Create envelope from check in item.\n */\nfunction createCheckInEnvelope(\n  checkIn,\n  dynamicSamplingContext,\n  metadata,\n  tunnel,\n  dsn$1,\n) {\n  const headers = {\n    sent_at: new Date().toISOString(),\n  };\n\n  if (metadata?.sdk) {\n    headers.sdk = {\n      name: metadata.sdk.name,\n      version: metadata.sdk.version,\n    };\n  }\n\n  if (!!tunnel && !!dsn$1) {\n    headers.dsn = dsn.dsnToString(dsn$1);\n  }\n\n  if (dynamicSamplingContext) {\n    headers.trace = dynamicSamplingContext ;\n  }\n\n  const item = createCheckInEnvelopeItem(checkIn);\n  return envelope.createEnvelope(headers, [item]);\n}\n\nfunction createCheckInEnvelopeItem(checkIn) {\n  const checkInHeaders = {\n    type: 'check_in',\n  };\n  return [checkInHeaders, checkIn];\n}\n\nexports.createCheckInEnvelope = createCheckInEnvelope;\n//# sourceMappingURL=checkin.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvY2hlY2tpbi5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxZQUFZLG1CQUFPLENBQUMsOEhBQWdCO0FBQ3BDLGlCQUFpQixtQkFBTyxDQUFDLHdJQUFxQjs7QUFFOUM7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSw2QkFBNkI7QUFDN0IiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9jaGVja2luLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBkc24gPSByZXF1aXJlKCcuL3V0aWxzL2Rzbi5qcycpO1xuY29uc3QgZW52ZWxvcGUgPSByZXF1aXJlKCcuL3V0aWxzL2VudmVsb3BlLmpzJyk7XG5cbi8qKlxuICogQ3JlYXRlIGVudmVsb3BlIGZyb20gY2hlY2sgaW4gaXRlbS5cbiAqL1xuZnVuY3Rpb24gY3JlYXRlQ2hlY2tJbkVudmVsb3BlKFxuICBjaGVja0luLFxuICBkeW5hbWljU2FtcGxpbmdDb250ZXh0LFxuICBtZXRhZGF0YSxcbiAgdHVubmVsLFxuICBkc24kMSxcbikge1xuICBjb25zdCBoZWFkZXJzID0ge1xuICAgIHNlbnRfYXQ6IG5ldyBEYXRlKCkudG9JU09TdHJpbmcoKSxcbiAgfTtcblxuICBpZiAobWV0YWRhdGE/LnNkaykge1xuICAgIGhlYWRlcnMuc2RrID0ge1xuICAgICAgbmFtZTogbWV0YWRhdGEuc2RrLm5hbWUsXG4gICAgICB2ZXJzaW9uOiBtZXRhZGF0YS5zZGsudmVyc2lvbixcbiAgICB9O1xuICB9XG5cbiAgaWYgKCEhdHVubmVsICYmICEhZHNuJDEpIHtcbiAgICBoZWFkZXJzLmRzbiA9IGRzbi5kc25Ub1N0cmluZyhkc24kMSk7XG4gIH1cblxuICBpZiAoZHluYW1pY1NhbXBsaW5nQ29udGV4dCkge1xuICAgIGhlYWRlcnMudHJhY2UgPSBkeW5hbWljU2FtcGxpbmdDb250ZXh0IDtcbiAgfVxuXG4gIGNvbnN0IGl0ZW0gPSBjcmVhdGVDaGVja0luRW52ZWxvcGVJdGVtKGNoZWNrSW4pO1xuICByZXR1cm4gZW52ZWxvcGUuY3JlYXRlRW52ZWxvcGUoaGVhZGVycywgW2l0ZW1dKTtcbn1cblxuZnVuY3Rpb24gY3JlYXRlQ2hlY2tJbkVudmVsb3BlSXRlbShjaGVja0luKSB7XG4gIGNvbnN0IGNoZWNrSW5IZWFkZXJzID0ge1xuICAgIHR5cGU6ICdjaGVja19pbicsXG4gIH07XG4gIHJldHVybiBbY2hlY2tJbkhlYWRlcnMsIGNoZWNrSW5dO1xufVxuXG5leHBvcnRzLmNyZWF0ZUNoZWNrSW5FbnZlbG9wZSA9IGNyZWF0ZUNoZWNrSW5FbnZlbG9wZTtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWNoZWNraW4uanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/checkin.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/client.js":
/*!**********************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/client.js ***!
  \**********************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst api = __webpack_require__(/*! ./api.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/api.js\");\nconst constants = __webpack_require__(/*! ./constants.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/constants.js\");\nconst currentScopes = __webpack_require__(/*! ./currentScopes.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst debugBuild = __webpack_require__(/*! ./debug-build.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst envelope = __webpack_require__(/*! ./envelope.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/envelope.js\");\nconst integration = __webpack_require__(/*! ./integration.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integration.js\");\nconst session = __webpack_require__(/*! ./session.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/session.js\");\nconst dynamicSamplingContext = __webpack_require__(/*! ./tracing/dynamicSamplingContext.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/dynamicSamplingContext.js\");\nconst clientreport = __webpack_require__(/*! ./utils/clientreport.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/clientreport.js\");\nconst debugLogger = __webpack_require__(/*! ./utils/debug-logger.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst dsn = __webpack_require__(/*! ./utils/dsn.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/dsn.js\");\nconst envelope$1 = __webpack_require__(/*! ./utils/envelope.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/envelope.js\");\nconst eventUtils = __webpack_require__(/*! ./utils/eventUtils.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/eventUtils.js\");\nconst is = __webpack_require__(/*! ./utils/is.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js\");\nconst merge = __webpack_require__(/*! ./utils/merge.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/merge.js\");\nconst misc = __webpack_require__(/*! ./utils/misc.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/misc.js\");\nconst parseSampleRate = __webpack_require__(/*! ./utils/parseSampleRate.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/parseSampleRate.js\");\nconst prepareEvent = __webpack_require__(/*! ./utils/prepareEvent.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/prepareEvent.js\");\nconst spanUtils = __webpack_require__(/*! ./utils/spanUtils.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanUtils.js\");\nconst syncpromise = __webpack_require__(/*! ./utils/syncpromise.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/syncpromise.js\");\nconst transactionEvent = __webpack_require__(/*! ./utils/transactionEvent.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/transactionEvent.js\");\n\n/* eslint-disable max-lines */\n\nconst ALREADY_SEEN_ERROR = \"Not capturing exception because it's already been captured.\";\nconst MISSING_RELEASE_FOR_SESSION_ERROR = 'Discarded session because of missing or non-string release';\n\nconst INTERNAL_ERROR_SYMBOL = Symbol.for('SentryInternalError');\nconst DO_NOT_SEND_EVENT_SYMBOL = Symbol.for('SentryDoNotSendEventError');\n\nfunction _makeInternalError(message) {\n  return {\n    message,\n    [INTERNAL_ERROR_SYMBOL]: true,\n  };\n}\n\nfunction _makeDoNotSendEventError(message) {\n  return {\n    message,\n    [DO_NOT_SEND_EVENT_SYMBOL]: true,\n  };\n}\n\nfunction _isInternalError(error) {\n  return !!error && typeof error === 'object' && INTERNAL_ERROR_SYMBOL in error;\n}\n\nfunction _isDoNotSendEventError(error) {\n  return !!error && typeof error === 'object' && DO_NOT_SEND_EVENT_SYMBOL in error;\n}\n\n/**\n * Base implementation for all JavaScript SDK clients.\n *\n * Call the constructor with the corresponding options\n * specific to the client subclass. To access these options later, use\n * {@link Client.getOptions}.\n *\n * If a Dsn is specified in the options, it will be parsed and stored. Use\n * {@link Client.getDsn} to retrieve the Dsn at any moment. In case the Dsn is\n * invalid, the constructor will throw a {@link SentryException}. Note that\n * without a valid Dsn, the SDK will not send any events to Sentry.\n *\n * Before sending an event, it is passed through\n * {@link Client._prepareEvent} to add SDK information and scope data\n * (breadcrumbs and context). To add more custom information, override this\n * method and extend the resulting prepared event.\n *\n * To issue automatically created events (e.g. via instrumentation), use\n * {@link Client.captureEvent}. It will prepare the event and pass it through\n * the callback lifecycle. To issue auto-breadcrumbs, use\n * {@link Client.addBreadcrumb}.\n *\n * @example\n * class NodeClient extends Client<NodeOptions> {\n *   public constructor(options: NodeOptions) {\n *     super(options);\n *   }\n *\n *   // ...\n * }\n */\nclass Client {\n  /** Options passed to the SDK. */\n\n  /** The client Dsn, if specified in options. Without this Dsn, the SDK will be disabled. */\n\n  /** Array of set up integrations. */\n\n  /** Number of calls being processed */\n\n  /** Holds flushable  */\n\n  // eslint-disable-next-line @typescript-eslint/ban-types\n\n  /**\n   * Initializes this client instance.\n   *\n   * @param options Options for the client.\n   */\n   constructor(options) {\n    this._options = options;\n    this._integrations = {};\n    this._numProcessing = 0;\n    this._outcomes = {};\n    this._hooks = {};\n    this._eventProcessors = [];\n\n    if (options.dsn) {\n      this._dsn = dsn.makeDsn(options.dsn);\n    } else {\n      debugBuild.DEBUG_BUILD && debugLogger.debug.warn('No DSN provided, client will not send events.');\n    }\n\n    if (this._dsn) {\n      const url = api.getEnvelopeEndpointWithUrlEncodedAuth(\n        this._dsn,\n        options.tunnel,\n        options._metadata ? options._metadata.sdk : undefined,\n      );\n      this._transport = options.transport({\n        tunnel: this._options.tunnel,\n        recordDroppedEvent: this.recordDroppedEvent.bind(this),\n        ...options.transportOptions,\n        url,\n      });\n    }\n  }\n\n  /**\n   * Captures an exception event and sends it to Sentry.\n   *\n   * Unlike `captureException` exported from every SDK, this method requires that you pass it the current scope.\n   */\n   captureException(exception, hint, scope) {\n    const eventId = misc.uuid4();\n\n    // ensure we haven't captured this very object before\n    if (misc.checkOrSetAlreadyCaught(exception)) {\n      debugBuild.DEBUG_BUILD && debugLogger.debug.log(ALREADY_SEEN_ERROR);\n      return eventId;\n    }\n\n    const hintWithEventId = {\n      event_id: eventId,\n      ...hint,\n    };\n\n    this._process(\n      this.eventFromException(exception, hintWithEventId).then(event =>\n        this._captureEvent(event, hintWithEventId, scope),\n      ),\n    );\n\n    return hintWithEventId.event_id;\n  }\n\n  /**\n   * Captures a message event and sends it to Sentry.\n   *\n   * Unlike `captureMessage` exported from every SDK, this method requires that you pass it the current scope.\n   */\n   captureMessage(\n    message,\n    level,\n    hint,\n    currentScope,\n  ) {\n    const hintWithEventId = {\n      event_id: misc.uuid4(),\n      ...hint,\n    };\n\n    const eventMessage = is.isParameterizedString(message) ? message : String(message);\n\n    const promisedEvent = is.isPrimitive(message)\n      ? this.eventFromMessage(eventMessage, level, hintWithEventId)\n      : this.eventFromException(message, hintWithEventId);\n\n    this._process(promisedEvent.then(event => this._captureEvent(event, hintWithEventId, currentScope)));\n\n    return hintWithEventId.event_id;\n  }\n\n  /**\n   * Captures a manually created event and sends it to Sentry.\n   *\n   * Unlike `captureEvent` exported from every SDK, this method requires that you pass it the current scope.\n   */\n   captureEvent(event, hint, currentScope) {\n    const eventId = misc.uuid4();\n\n    // ensure we haven't captured this very object before\n    if (hint?.originalException && misc.checkOrSetAlreadyCaught(hint.originalException)) {\n      debugBuild.DEBUG_BUILD && debugLogger.debug.log(ALREADY_SEEN_ERROR);\n      return eventId;\n    }\n\n    const hintWithEventId = {\n      event_id: eventId,\n      ...hint,\n    };\n\n    const sdkProcessingMetadata = event.sdkProcessingMetadata || {};\n    const capturedSpanScope = sdkProcessingMetadata.capturedSpanScope;\n    const capturedSpanIsolationScope = sdkProcessingMetadata.capturedSpanIsolationScope;\n\n    this._process(\n      this._captureEvent(event, hintWithEventId, capturedSpanScope || currentScope, capturedSpanIsolationScope),\n    );\n\n    return hintWithEventId.event_id;\n  }\n\n  /**\n   * Captures a session.\n   */\n   captureSession(session$1) {\n    this.sendSession(session$1);\n    // After sending, we set init false to indicate it's not the first occurrence\n    session.updateSession(session$1, { init: false });\n  }\n\n  /**\n   * Create a cron monitor check in and send it to Sentry. This method is not available on all clients.\n   *\n   * @param checkIn An object that describes a check in.\n   * @param upsertMonitorConfig An optional object that describes a monitor config. Use this if you want\n   * to create a monitor automatically when sending a check in.\n   * @param scope An optional scope containing event metadata.\n   * @returns A string representing the id of the check in.\n   */\n\n  /**\n   * Get the current Dsn.\n   */\n   getDsn() {\n    return this._dsn;\n  }\n\n  /**\n   * Get the current options.\n   */\n   getOptions() {\n    return this._options;\n  }\n\n  /**\n   * Get the SDK metadata.\n   * @see SdkMetadata\n   */\n   getSdkMetadata() {\n    return this._options._metadata;\n  }\n\n  /**\n   * Returns the transport that is used by the client.\n   * Please note that the transport gets lazy initialized so it will only be there once the first event has been sent.\n   */\n   getTransport() {\n    return this._transport;\n  }\n\n  /**\n   * Wait for all events to be sent or the timeout to expire, whichever comes first.\n   *\n   * @param timeout Maximum time in ms the client should wait for events to be flushed. Omitting this parameter will\n   *   cause the client to wait until all events are sent before resolving the promise.\n   * @returns A promise that will resolve with `true` if all events are sent before the timeout, or `false` if there are\n   * still events in the queue when the timeout is reached.\n   */\n   flush(timeout) {\n    const transport = this._transport;\n    if (transport) {\n      this.emit('flush');\n      return this._isClientDoneProcessing(timeout).then(clientFinished => {\n        return transport.flush(timeout).then(transportFlushed => clientFinished && transportFlushed);\n      });\n    } else {\n      return syncpromise.resolvedSyncPromise(true);\n    }\n  }\n\n  /**\n   * Flush the event queue and set the client to `enabled = false`. See {@link Client.flush}.\n   *\n   * @param {number} timeout Maximum time in ms the client should wait before shutting down. Omitting this parameter will cause\n   *   the client to wait until all events are sent before disabling itself.\n   * @returns {Promise<boolean>} A promise which resolves to `true` if the flush completes successfully before the timeout, or `false` if\n   * it doesn't.\n   */\n   close(timeout) {\n    return this.flush(timeout).then(result => {\n      this.getOptions().enabled = false;\n      this.emit('close');\n      return result;\n    });\n  }\n\n  /**\n   * Get all installed event processors.\n   */\n   getEventProcessors() {\n    return this._eventProcessors;\n  }\n\n  /**\n   * Adds an event processor that applies to any event processed by this client.\n   */\n   addEventProcessor(eventProcessor) {\n    this._eventProcessors.push(eventProcessor);\n  }\n\n  /**\n   * Initialize this client.\n   * Call this after the client was set on a scope.\n   */\n   init() {\n    if (\n      this._isEnabled() ||\n      // Force integrations to be setup even if no DSN was set when we have\n      // Spotlight enabled. This is particularly important for browser as we\n      // don't support the `spotlight` option there and rely on the users\n      // adding the `spotlightBrowserIntegration()` to their integrations which\n      // wouldn't get initialized with the check below when there's no DSN set.\n      this._options.integrations.some(({ name }) => name.startsWith('Spotlight'))\n    ) {\n      this._setupIntegrations();\n    }\n  }\n\n  /**\n   * Gets an installed integration by its name.\n   *\n   * @returns {Integration|undefined} The installed integration or `undefined` if no integration with that `name` was installed.\n   */\n   getIntegrationByName(integrationName) {\n    return this._integrations[integrationName] ;\n  }\n\n  /**\n   * Add an integration to the client.\n   * This can be used to e.g. lazy load integrations.\n   * In most cases, this should not be necessary,\n   * and you're better off just passing the integrations via `integrations: []` at initialization time.\n   * However, if you find the need to conditionally load & add an integration, you can use `addIntegration` to do so.\n   */\n   addIntegration(integration$1) {\n    const isAlreadyInstalled = this._integrations[integration$1.name];\n\n    // This hook takes care of only installing if not already installed\n    integration.setupIntegration(this, integration$1, this._integrations);\n    // Here we need to check manually to make sure to not run this multiple times\n    if (!isAlreadyInstalled) {\n      integration.afterSetupIntegrations(this, [integration$1]);\n    }\n  }\n\n  /**\n   * Send a fully prepared event to Sentry.\n   */\n   sendEvent(event, hint = {}) {\n    this.emit('beforeSendEvent', event, hint);\n\n    let env = envelope.createEventEnvelope(event, this._dsn, this._options._metadata, this._options.tunnel);\n\n    for (const attachment of hint.attachments || []) {\n      env = envelope$1.addItemToEnvelope(env, envelope$1.createAttachmentEnvelopeItem(attachment));\n    }\n\n    const promise = this.sendEnvelope(env);\n    if (promise) {\n      promise.then(sendResponse => this.emit('afterSendEvent', event, sendResponse), null);\n    }\n  }\n\n  /**\n   * Send a session or session aggregrates to Sentry.\n   */\n   sendSession(session) {\n    // Backfill release and environment on session\n    const { release: clientReleaseOption, environment: clientEnvironmentOption = constants.DEFAULT_ENVIRONMENT } = this._options;\n    if ('aggregates' in session) {\n      const sessionAttrs = session.attrs || {};\n      if (!sessionAttrs.release && !clientReleaseOption) {\n        debugBuild.DEBUG_BUILD && debugLogger.debug.warn(MISSING_RELEASE_FOR_SESSION_ERROR);\n        return;\n      }\n      sessionAttrs.release = sessionAttrs.release || clientReleaseOption;\n      sessionAttrs.environment = sessionAttrs.environment || clientEnvironmentOption;\n      session.attrs = sessionAttrs;\n    } else {\n      if (!session.release && !clientReleaseOption) {\n        debugBuild.DEBUG_BUILD && debugLogger.debug.warn(MISSING_RELEASE_FOR_SESSION_ERROR);\n        return;\n      }\n      session.release = session.release || clientReleaseOption;\n      session.environment = session.environment || clientEnvironmentOption;\n    }\n\n    this.emit('beforeSendSession', session);\n\n    const env = envelope.createSessionEnvelope(session, this._dsn, this._options._metadata, this._options.tunnel);\n\n    // sendEnvelope should not throw\n    // eslint-disable-next-line @typescript-eslint/no-floating-promises\n    this.sendEnvelope(env);\n  }\n\n  /**\n   * Record on the client that an event got dropped (ie, an event that will not be sent to Sentry).\n   */\n   recordDroppedEvent(reason, category, count = 1) {\n    if (this._options.sendClientReports) {\n      // We want to track each category (error, transaction, session, replay_event) separately\n      // but still keep the distinction between different type of outcomes.\n      // We could use nested maps, but it's much easier to read and type this way.\n      // A correct type for map-based implementation if we want to go that route\n      // would be `Partial<Record<SentryRequestType, Partial<Record<Outcome, number>>>>`\n      // With typescript 4.1 we could even use template literal types\n      const key = `${reason}:${category}`;\n      debugBuild.DEBUG_BUILD && debugLogger.debug.log(`Recording outcome: \"${key}\"${count > 1 ? ` (${count} times)` : ''}`);\n      this._outcomes[key] = (this._outcomes[key] || 0) + count;\n    }\n  }\n\n  /* eslint-disable @typescript-eslint/unified-signatures */\n  /**\n   * Register a callback for whenever a span is started.\n   * Receives the span as argument.\n   * @returns {() => void} A function that, when executed, removes the registered callback.\n   */\n\n  /**\n   * Register a hook on this client.\n   */\n   on(hook, callback) {\n    const hooks = (this._hooks[hook] = this._hooks[hook] || []);\n\n    // @ts-expect-error We assume the types are correct\n    hooks.push(callback);\n\n    // This function returns a callback execution handler that, when invoked,\n    // deregisters a callback. This is crucial for managing instances where callbacks\n    // need to be unregistered to prevent self-referencing in callback closures,\n    // ensuring proper garbage collection.\n    return () => {\n      // @ts-expect-error We assume the types are correct\n      const cbIndex = hooks.indexOf(callback);\n      if (cbIndex > -1) {\n        hooks.splice(cbIndex, 1);\n      }\n    };\n  }\n\n  /** Fire a hook whenever a span starts. */\n\n  /**\n   * Emit a hook that was previously registered via `on()`.\n   */\n   emit(hook, ...rest) {\n    const callbacks = this._hooks[hook];\n    if (callbacks) {\n      callbacks.forEach(callback => callback(...rest));\n    }\n  }\n\n  /**\n   * Send an envelope to Sentry.\n   */\n   sendEnvelope(envelope) {\n    this.emit('beforeEnvelope', envelope);\n\n    if (this._isEnabled() && this._transport) {\n      return this._transport.send(envelope).then(null, reason => {\n        debugBuild.DEBUG_BUILD && debugLogger.debug.error('Error while sending envelope:', reason);\n        return reason;\n      });\n    }\n\n    debugBuild.DEBUG_BUILD && debugLogger.debug.error('Transport disabled');\n\n    return syncpromise.resolvedSyncPromise({});\n  }\n\n  /* eslint-enable @typescript-eslint/unified-signatures */\n\n  /** Setup integrations for this client. */\n   _setupIntegrations() {\n    const { integrations } = this._options;\n    this._integrations = integration.setupIntegrations(this, integrations);\n    integration.afterSetupIntegrations(this, integrations);\n  }\n\n  /** Updates existing session based on the provided event */\n   _updateSessionFromEvent(session$1, event) {\n    let crashed = event.level === 'fatal';\n    let errored = false;\n    const exceptions = event.exception?.values;\n\n    if (exceptions) {\n      errored = true;\n\n      for (const ex of exceptions) {\n        const mechanism = ex.mechanism;\n        if (mechanism?.handled === false) {\n          crashed = true;\n          break;\n        }\n      }\n    }\n\n    // A session is updated and that session update is sent in only one of the two following scenarios:\n    // 1. Session with non terminal status and 0 errors + an error occurred -> Will set error count to 1 and send update\n    // 2. Session with non terminal status and 1 error + a crash occurred -> Will set status crashed and send update\n    const sessionNonTerminal = session$1.status === 'ok';\n    const shouldUpdateAndSend = (sessionNonTerminal && session$1.errors === 0) || (sessionNonTerminal && crashed);\n\n    if (shouldUpdateAndSend) {\n      session.updateSession(session$1, {\n        ...(crashed && { status: 'crashed' }),\n        errors: session$1.errors || Number(errored || crashed),\n      });\n      this.captureSession(session$1);\n    }\n  }\n\n  /**\n   * Determine if the client is finished processing. Returns a promise because it will wait `timeout` ms before saying\n   * \"no\" (resolving to `false`) in order to give the client a chance to potentially finish first.\n   *\n   * @param timeout The time, in ms, after which to resolve to `false` if the client is still busy. Passing `0` (or not\n   * passing anything) will make the promise wait as long as it takes for processing to finish before resolving to\n   * `true`.\n   * @returns A promise which will resolve to `true` if processing is already done or finishes before the timeout, and\n   * `false` otherwise\n   */\n   _isClientDoneProcessing(timeout) {\n    return new syncpromise.SyncPromise(resolve => {\n      let ticked = 0;\n      const tick = 1;\n\n      const interval = setInterval(() => {\n        if (this._numProcessing == 0) {\n          clearInterval(interval);\n          resolve(true);\n        } else {\n          ticked += tick;\n          if (timeout && ticked >= timeout) {\n            clearInterval(interval);\n            resolve(false);\n          }\n        }\n      }, tick);\n    });\n  }\n\n  /** Determines whether this SDK is enabled and a transport is present. */\n   _isEnabled() {\n    return this.getOptions().enabled !== false && this._transport !== undefined;\n  }\n\n  /**\n   * Adds common information to events.\n   *\n   * The information includes release and environment from `options`,\n   * breadcrumbs and context (extra, tags and user) from the scope.\n   *\n   * Information that is already present in the event is never overwritten. For\n   * nested objects, such as the context, keys are merged.\n   *\n   * @param event The original event.\n   * @param hint May contain additional information about the original exception.\n   * @param currentScope A scope containing event metadata.\n   * @returns A new event with more information.\n   */\n   _prepareEvent(\n    event,\n    hint,\n    currentScope,\n    isolationScope,\n  ) {\n    const options = this.getOptions();\n    const integrations = Object.keys(this._integrations);\n    if (!hint.integrations && integrations?.length) {\n      hint.integrations = integrations;\n    }\n\n    this.emit('preprocessEvent', event, hint);\n\n    if (!event.type) {\n      isolationScope.setLastEventId(event.event_id || hint.event_id);\n    }\n\n    return prepareEvent.prepareEvent(options, event, hint, currentScope, this, isolationScope).then(evt => {\n      if (evt === null) {\n        return evt;\n      }\n\n      this.emit('postprocessEvent', evt, hint);\n\n      evt.contexts = {\n        trace: currentScopes.getTraceContextFromScope(currentScope),\n        ...evt.contexts,\n      };\n\n      const dynamicSamplingContext$1 = dynamicSamplingContext.getDynamicSamplingContextFromScope(this, currentScope);\n\n      evt.sdkProcessingMetadata = {\n        dynamicSamplingContext: dynamicSamplingContext$1,\n        ...evt.sdkProcessingMetadata,\n      };\n\n      return evt;\n    });\n  }\n\n  /**\n   * Processes the event and logs an error in case of rejection\n   * @param event\n   * @param hint\n   * @param scope\n   */\n   _captureEvent(\n    event,\n    hint = {},\n    currentScope = currentScopes.getCurrentScope(),\n    isolationScope = currentScopes.getIsolationScope(),\n  ) {\n    if (debugBuild.DEBUG_BUILD && isErrorEvent(event)) {\n      debugLogger.debug.log(`Captured error event \\`${eventUtils.getPossibleEventMessages(event)[0] || '<unknown>'}\\``);\n    }\n\n    return this._processEvent(event, hint, currentScope, isolationScope).then(\n      finalEvent => {\n        return finalEvent.event_id;\n      },\n      reason => {\n        if (debugBuild.DEBUG_BUILD) {\n          if (_isDoNotSendEventError(reason)) {\n            debugLogger.debug.log(reason.message);\n          } else if (_isInternalError(reason)) {\n            debugLogger.debug.warn(reason.message);\n          } else {\n            debugLogger.debug.warn(reason);\n          }\n        }\n        return undefined;\n      },\n    );\n  }\n\n  /**\n   * Processes an event (either error or message) and sends it to Sentry.\n   *\n   * This also adds breadcrumbs and context information to the event. However,\n   * platform specific meta data (such as the User's IP address) must be added\n   * by the SDK implementor.\n   *\n   *\n   * @param event The event to send to Sentry.\n   * @param hint May contain additional information about the original exception.\n   * @param currentScope A scope containing event metadata.\n   * @returns A SyncPromise that resolves with the event or rejects in case event was/will not be send.\n   */\n   _processEvent(\n    event,\n    hint,\n    currentScope,\n    isolationScope,\n  ) {\n    const options = this.getOptions();\n    const { sampleRate } = options;\n\n    const isTransaction = isTransactionEvent(event);\n    const isError = isErrorEvent(event);\n    const eventType = event.type || 'error';\n    const beforeSendLabel = `before send for type \\`${eventType}\\``;\n\n    // 1.0 === 100% events are sent\n    // 0.0 === 0% events are sent\n    // Sampling for transaction happens somewhere else\n    const parsedSampleRate = typeof sampleRate === 'undefined' ? undefined : parseSampleRate.parseSampleRate(sampleRate);\n    if (isError && typeof parsedSampleRate === 'number' && Math.random() > parsedSampleRate) {\n      this.recordDroppedEvent('sample_rate', 'error');\n      return syncpromise.rejectedSyncPromise(\n        _makeDoNotSendEventError(\n          `Discarding event because it's not included in the random sample (sampling rate = ${sampleRate})`,\n        ),\n      );\n    }\n\n    const dataCategory = (eventType === 'replay_event' ? 'replay' : eventType) ;\n\n    return this._prepareEvent(event, hint, currentScope, isolationScope)\n      .then(prepared => {\n        if (prepared === null) {\n          this.recordDroppedEvent('event_processor', dataCategory);\n          throw _makeDoNotSendEventError('An event processor returned `null`, will not send event.');\n        }\n\n        const isInternalException = hint.data && (hint.data ).__sentry__ === true;\n        if (isInternalException) {\n          return prepared;\n        }\n\n        const result = processBeforeSend(this, options, prepared, hint);\n        return _validateBeforeSendResult(result, beforeSendLabel);\n      })\n      .then(processedEvent => {\n        if (processedEvent === null) {\n          this.recordDroppedEvent('before_send', dataCategory);\n          if (isTransaction) {\n            const spans = event.spans || [];\n            // the transaction itself counts as one span, plus all the child spans that are added\n            const spanCount = 1 + spans.length;\n            this.recordDroppedEvent('before_send', 'span', spanCount);\n          }\n          throw _makeDoNotSendEventError(`${beforeSendLabel} returned \\`null\\`, will not send event.`);\n        }\n\n        const session = currentScope.getSession() || isolationScope.getSession();\n        if (isError && session) {\n          this._updateSessionFromEvent(session, processedEvent);\n        }\n\n        if (isTransaction) {\n          const spanCountBefore = processedEvent.sdkProcessingMetadata?.spanCountBeforeProcessing || 0;\n          const spanCountAfter = processedEvent.spans ? processedEvent.spans.length : 0;\n\n          const droppedSpanCount = spanCountBefore - spanCountAfter;\n          if (droppedSpanCount > 0) {\n            this.recordDroppedEvent('before_send', 'span', droppedSpanCount);\n          }\n        }\n\n        // None of the Sentry built event processor will update transaction name,\n        // so if the transaction name has been changed by an event processor, we know\n        // it has to come from custom event processor added by a user\n        const transactionInfo = processedEvent.transaction_info;\n        if (isTransaction && transactionInfo && processedEvent.transaction !== event.transaction) {\n          const source = 'custom';\n          processedEvent.transaction_info = {\n            ...transactionInfo,\n            source,\n          };\n        }\n\n        this.sendEvent(processedEvent, hint);\n        return processedEvent;\n      })\n      .then(null, reason => {\n        if (_isDoNotSendEventError(reason) || _isInternalError(reason)) {\n          throw reason;\n        }\n\n        this.captureException(reason, {\n          data: {\n            __sentry__: true,\n          },\n          originalException: reason,\n        });\n        throw _makeInternalError(\n          `Event processing pipeline threw an error, original event will not be sent. Details have been sent as a new event.\\nReason: ${reason}`,\n        );\n      });\n  }\n\n  /**\n   * Occupies the client with processing and event\n   */\n   _process(promise) {\n    this._numProcessing++;\n    void promise.then(\n      value => {\n        this._numProcessing--;\n        return value;\n      },\n      reason => {\n        this._numProcessing--;\n        return reason;\n      },\n    );\n  }\n\n  /**\n   * Clears outcomes on this client and returns them.\n   */\n   _clearOutcomes() {\n    const outcomes = this._outcomes;\n    this._outcomes = {};\n    return Object.entries(outcomes).map(([key, quantity]) => {\n      const [reason, category] = key.split(':') ;\n      return {\n        reason,\n        category,\n        quantity,\n      };\n    });\n  }\n\n  /**\n   * Sends client reports as an envelope.\n   */\n   _flushOutcomes() {\n    debugBuild.DEBUG_BUILD && debugLogger.debug.log('Flushing outcomes...');\n\n    const outcomes = this._clearOutcomes();\n\n    if (outcomes.length === 0) {\n      debugBuild.DEBUG_BUILD && debugLogger.debug.log('No outcomes to send');\n      return;\n    }\n\n    // This is really the only place where we want to check for a DSN and only send outcomes then\n    if (!this._dsn) {\n      debugBuild.DEBUG_BUILD && debugLogger.debug.log('No dsn provided, will not send outcomes');\n      return;\n    }\n\n    debugBuild.DEBUG_BUILD && debugLogger.debug.log('Sending outcomes:', outcomes);\n\n    const envelope = clientreport.createClientReportEnvelope(outcomes, this._options.tunnel && dsn.dsnToString(this._dsn));\n\n    // sendEnvelope should not throw\n    // eslint-disable-next-line @typescript-eslint/no-floating-promises\n    this.sendEnvelope(envelope);\n  }\n\n  /**\n   * Creates an {@link Event} from all inputs to `captureException` and non-primitive inputs to `captureMessage`.\n   */\n\n}\n\n/**\n * @deprecated Use `Client` instead. This alias may be removed in a future major version.\n */\n// TODO(v10): Remove\n\n/**\n * @deprecated Use `Client` instead. This alias may be removed in a future major version.\n */\n// TODO(v10): Remove\nconst BaseClient = Client;\n\n/**\n * Verifies that return value of configured `beforeSend` or `beforeSendTransaction` is of expected type, and returns the value if so.\n */\nfunction _validateBeforeSendResult(\n  beforeSendResult,\n  beforeSendLabel,\n) {\n  const invalidValueError = `${beforeSendLabel} must return \\`null\\` or a valid event.`;\n  if (is.isThenable(beforeSendResult)) {\n    return beforeSendResult.then(\n      event => {\n        if (!is.isPlainObject(event) && event !== null) {\n          throw _makeInternalError(invalidValueError);\n        }\n        return event;\n      },\n      e => {\n        throw _makeInternalError(`${beforeSendLabel} rejected with ${e}`);\n      },\n    );\n  } else if (!is.isPlainObject(beforeSendResult) && beforeSendResult !== null) {\n    throw _makeInternalError(invalidValueError);\n  }\n  return beforeSendResult;\n}\n\n/**\n * Process the matching `beforeSendXXX` callback.\n */\nfunction processBeforeSend(\n  client,\n  options,\n  event,\n  hint,\n) {\n  const { beforeSend, beforeSendTransaction, beforeSendSpan } = options;\n  let processedEvent = event;\n\n  if (isErrorEvent(processedEvent) && beforeSend) {\n    return beforeSend(processedEvent, hint);\n  }\n\n  if (isTransactionEvent(processedEvent)) {\n    if (beforeSendSpan) {\n      // process root span\n      const processedRootSpanJson = beforeSendSpan(transactionEvent.convertTransactionEventToSpanJson(processedEvent));\n      if (!processedRootSpanJson) {\n        spanUtils.showSpanDropWarning();\n      } else {\n        // update event with processed root span values\n        processedEvent = merge.merge(event, transactionEvent.convertSpanJsonToTransactionEvent(processedRootSpanJson));\n      }\n\n      // process child spans\n      if (processedEvent.spans) {\n        const processedSpans = [];\n        for (const span of processedEvent.spans) {\n          const processedSpan = beforeSendSpan(span);\n          if (!processedSpan) {\n            spanUtils.showSpanDropWarning();\n            processedSpans.push(span);\n          } else {\n            processedSpans.push(processedSpan);\n          }\n        }\n        processedEvent.spans = processedSpans;\n      }\n    }\n\n    if (beforeSendTransaction) {\n      if (processedEvent.spans) {\n        // We store the # of spans before processing in SDK metadata,\n        // so we can compare it afterwards to determine how many spans were dropped\n        const spanCountBefore = processedEvent.spans.length;\n        processedEvent.sdkProcessingMetadata = {\n          ...event.sdkProcessingMetadata,\n          spanCountBeforeProcessing: spanCountBefore,\n        };\n      }\n      return beforeSendTransaction(processedEvent , hint);\n    }\n  }\n\n  return processedEvent;\n}\n\nfunction isErrorEvent(event) {\n  return event.type === undefined;\n}\n\nfunction isTransactionEvent(event) {\n  return event.type === 'transaction';\n}\n\n/** Extract trace information from scope */\nfunction _getTraceInfoFromScope(\n  client,\n  scope,\n) {\n  if (!scope) {\n    return [undefined, undefined];\n  }\n\n  return currentScopes.withScope(scope, () => {\n    const span = spanUtils.getActiveSpan();\n    const traceContext = span ? spanUtils.spanToTraceContext(span) : currentScopes.getTraceContextFromScope(scope);\n    const dynamicSamplingContext$1 = span\n      ? dynamicSamplingContext.getDynamicSamplingContextFromSpan(span)\n      : dynamicSamplingContext.getDynamicSamplingContextFromScope(client, scope);\n    return [dynamicSamplingContext$1, traceContext];\n  });\n}\n\nexports.BaseClient = BaseClient;\nexports.Client = Client;\nexports._getTraceInfoFromScope = _getTraceInfoFromScope;\n//# sourceMappingURL=client.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvY2xpZW50LmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLFlBQVksbUJBQU8sQ0FBQyxrSEFBVTtBQUM5QixrQkFBa0IsbUJBQU8sQ0FBQyw4SEFBZ0I7QUFDMUMsc0JBQXNCLG1CQUFPLENBQUMsc0lBQW9CO0FBQ2xELG1CQUFtQixtQkFBTyxDQUFDLGtJQUFrQjtBQUM3QyxpQkFBaUIsbUJBQU8sQ0FBQyw0SEFBZTtBQUN4QyxvQkFBb0IsbUJBQU8sQ0FBQyxrSUFBa0I7QUFDOUMsZ0JBQWdCLG1CQUFPLENBQUMsMEhBQWM7QUFDdEMsK0JBQStCLG1CQUFPLENBQUMsd0tBQXFDO0FBQzVFLHFCQUFxQixtQkFBTyxDQUFDLGdKQUF5QjtBQUN0RCxvQkFBb0IsbUJBQU8sQ0FBQyxnSkFBeUI7QUFDckQsWUFBWSxtQkFBTyxDQUFDLDhIQUFnQjtBQUNwQyxtQkFBbUIsbUJBQU8sQ0FBQyx3SUFBcUI7QUFDaEQsbUJBQW1CLG1CQUFPLENBQUMsNElBQXVCO0FBQ2xELFdBQVcsbUJBQU8sQ0FBQyw0SEFBZTtBQUNsQyxjQUFjLG1CQUFPLENBQUMsa0lBQWtCO0FBQ3hDLGFBQWEsbUJBQU8sQ0FBQyxnSUFBaUI7QUFDdEMsd0JBQXdCLG1CQUFPLENBQUMsc0pBQTRCO0FBQzVELHFCQUFxQixtQkFBTyxDQUFDLGdKQUF5QjtBQUN0RCxrQkFBa0IsbUJBQU8sQ0FBQywwSUFBc0I7QUFDaEQsb0JBQW9CLG1CQUFPLENBQUMsOElBQXdCO0FBQ3BELHlCQUF5QixtQkFBTyxDQUFDLHdKQUE2Qjs7QUFFOUQ7O0FBRUE7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsSUFBSSx3QkFBd0I7QUFDNUI7QUFDQTtBQUNBLElBQUkscUJBQXFCO0FBQ3pCLDBDQUEwQyxzQkFBc0I7QUFDaEU7QUFDQTtBQUNBO0FBQ0EsSUFBSSw0QkFBNEI7QUFDaEM7QUFDQTtBQUNBO0FBQ0E7QUFDQSxJQUFJLDBCQUEwQjtBQUM5QjtBQUNBLElBQUksMkJBQTJCO0FBQy9CO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTs7QUFFQTs7QUFFQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLE1BQU07QUFDTjtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxPQUFPO0FBQ1A7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsdUNBQXVDLGFBQWE7QUFDcEQ7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLE9BQU87QUFDUCxNQUFNO0FBQ047QUFDQTtBQUNBOztBQUVBO0FBQ0EseUVBQXlFLG1CQUFtQjtBQUM1RjtBQUNBLGFBQWEsUUFBUTtBQUNyQjtBQUNBLGVBQWUsa0JBQWtCO0FBQ2pDO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsS0FBSztBQUNMOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EseUNBQXlDLE1BQU07QUFDL0M7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0EsZUFBZSx1QkFBdUI7QUFDdEM7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBLDZCQUE2QjtBQUM3Qjs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsWUFBWSxxR0FBcUc7QUFDakg7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsTUFBTTtBQUNOO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxxQkFBcUIsT0FBTyxHQUFHLFNBQVM7QUFDeEMsNkVBQTZFLElBQUksR0FBRyxpQkFBaUIsT0FBTyxhQUFhO0FBQ3pIO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGVBQWUsWUFBWTtBQUMzQjs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsT0FBTztBQUNQOztBQUVBOztBQUVBLDZDQUE2QztBQUM3Qzs7QUFFQTs7QUFFQTtBQUNBO0FBQ0EsWUFBWSxlQUFlO0FBQzNCO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQSx5QkFBeUIsbUJBQW1CO0FBQzVDO0FBQ0EsT0FBTztBQUNQO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsVUFBVTtBQUNWO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLE9BQU87QUFDUCxLQUFLO0FBQ0w7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0EsS0FBSztBQUNMOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxhQUFhO0FBQ2I7QUFDQTtBQUNBO0FBQ0E7QUFDQSxzREFBc0QsNkRBQTZEO0FBQ25IOztBQUVBO0FBQ0E7QUFDQTtBQUNBLE9BQU87QUFDUDtBQUNBO0FBQ0E7QUFDQTtBQUNBLFlBQVk7QUFDWjtBQUNBLFlBQVk7QUFDWjtBQUNBO0FBQ0E7QUFDQTtBQUNBLE9BQU87QUFDUDtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxZQUFZLGFBQWE7O0FBRXpCO0FBQ0E7QUFDQTtBQUNBLHNEQUFzRCxVQUFVOztBQUVoRTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsOEZBQThGLFdBQVc7QUFDekc7QUFDQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsT0FBTztBQUNQO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLDRDQUE0QyxpQkFBaUI7QUFDN0Q7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsT0FBTztBQUNQO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBLFdBQVc7QUFDWDtBQUNBLFNBQVM7QUFDVDtBQUNBLHdJQUF3SSxPQUFPO0FBQy9JO0FBQ0EsT0FBTztBQUNQOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLE9BQU87QUFDUDtBQUNBO0FBQ0E7QUFDQSxPQUFPO0FBQ1A7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEtBQUs7QUFDTDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQSxpQkFBaUIsYUFBYTtBQUM5Qjs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsK0JBQStCLGlCQUFpQjtBQUNoRDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLE9BQU87QUFDUDtBQUNBLG9DQUFvQyxpQkFBaUIsZ0JBQWdCLEVBQUU7QUFDdkUsT0FBTztBQUNQO0FBQ0EsSUFBSTtBQUNKO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFVBQVUsb0RBQW9EO0FBQzlEOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxRQUFRO0FBQ1I7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxZQUFZO0FBQ1o7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsR0FBRztBQUNIOztBQUVBLGtCQUFrQjtBQUNsQixjQUFjO0FBQ2QsOEJBQThCO0FBQzlCIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvY2xpZW50LmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBhcGkgPSByZXF1aXJlKCcuL2FwaS5qcycpO1xuY29uc3QgY29uc3RhbnRzID0gcmVxdWlyZSgnLi9jb25zdGFudHMuanMnKTtcbmNvbnN0IGN1cnJlbnRTY29wZXMgPSByZXF1aXJlKCcuL2N1cnJlbnRTY29wZXMuanMnKTtcbmNvbnN0IGRlYnVnQnVpbGQgPSByZXF1aXJlKCcuL2RlYnVnLWJ1aWxkLmpzJyk7XG5jb25zdCBlbnZlbG9wZSA9IHJlcXVpcmUoJy4vZW52ZWxvcGUuanMnKTtcbmNvbnN0IGludGVncmF0aW9uID0gcmVxdWlyZSgnLi9pbnRlZ3JhdGlvbi5qcycpO1xuY29uc3Qgc2Vzc2lvbiA9IHJlcXVpcmUoJy4vc2Vzc2lvbi5qcycpO1xuY29uc3QgZHluYW1pY1NhbXBsaW5nQ29udGV4dCA9IHJlcXVpcmUoJy4vdHJhY2luZy9keW5hbWljU2FtcGxpbmdDb250ZXh0LmpzJyk7XG5jb25zdCBjbGllbnRyZXBvcnQgPSByZXF1aXJlKCcuL3V0aWxzL2NsaWVudHJlcG9ydC5qcycpO1xuY29uc3QgZGVidWdMb2dnZXIgPSByZXF1aXJlKCcuL3V0aWxzL2RlYnVnLWxvZ2dlci5qcycpO1xuY29uc3QgZHNuID0gcmVxdWlyZSgnLi91dGlscy9kc24uanMnKTtcbmNvbnN0IGVudmVsb3BlJDEgPSByZXF1aXJlKCcuL3V0aWxzL2VudmVsb3BlLmpzJyk7XG5jb25zdCBldmVudFV0aWxzID0gcmVxdWlyZSgnLi91dGlscy9ldmVudFV0aWxzLmpzJyk7XG5jb25zdCBpcyA9IHJlcXVpcmUoJy4vdXRpbHMvaXMuanMnKTtcbmNvbnN0IG1lcmdlID0gcmVxdWlyZSgnLi91dGlscy9tZXJnZS5qcycpO1xuY29uc3QgbWlzYyA9IHJlcXVpcmUoJy4vdXRpbHMvbWlzYy5qcycpO1xuY29uc3QgcGFyc2VTYW1wbGVSYXRlID0gcmVxdWlyZSgnLi91dGlscy9wYXJzZVNhbXBsZVJhdGUuanMnKTtcbmNvbnN0IHByZXBhcmVFdmVudCA9IHJlcXVpcmUoJy4vdXRpbHMvcHJlcGFyZUV2ZW50LmpzJyk7XG5jb25zdCBzcGFuVXRpbHMgPSByZXF1aXJlKCcuL3V0aWxzL3NwYW5VdGlscy5qcycpO1xuY29uc3Qgc3luY3Byb21pc2UgPSByZXF1aXJlKCcuL3V0aWxzL3N5bmNwcm9taXNlLmpzJyk7XG5jb25zdCB0cmFuc2FjdGlvbkV2ZW50ID0gcmVxdWlyZSgnLi91dGlscy90cmFuc2FjdGlvbkV2ZW50LmpzJyk7XG5cbi8qIGVzbGludC1kaXNhYmxlIG1heC1saW5lcyAqL1xuXG5jb25zdCBBTFJFQURZX1NFRU5fRVJST1IgPSBcIk5vdCBjYXB0dXJpbmcgZXhjZXB0aW9uIGJlY2F1c2UgaXQncyBhbHJlYWR5IGJlZW4gY2FwdHVyZWQuXCI7XG5jb25zdCBNSVNTSU5HX1JFTEVBU0VfRk9SX1NFU1NJT05fRVJST1IgPSAnRGlzY2FyZGVkIHNlc3Npb24gYmVjYXVzZSBvZiBtaXNzaW5nIG9yIG5vbi1zdHJpbmcgcmVsZWFzZSc7XG5cbmNvbnN0IElOVEVSTkFMX0VSUk9SX1NZTUJPTCA9IFN5bWJvbC5mb3IoJ1NlbnRyeUludGVybmFsRXJyb3InKTtcbmNvbnN0IERPX05PVF9TRU5EX0VWRU5UX1NZTUJPTCA9IFN5bWJvbC5mb3IoJ1NlbnRyeURvTm90U2VuZEV2ZW50RXJyb3InKTtcblxuZnVuY3Rpb24gX21ha2VJbnRlcm5hbEVycm9yKG1lc3NhZ2UpIHtcbiAgcmV0dXJuIHtcbiAgICBtZXNzYWdlLFxuICAgIFtJTlRFUk5BTF9FUlJPUl9TWU1CT0xdOiB0cnVlLFxuICB9O1xufVxuXG5mdW5jdGlvbiBfbWFrZURvTm90U2VuZEV2ZW50RXJyb3IobWVzc2FnZSkge1xuICByZXR1cm4ge1xuICAgIG1lc3NhZ2UsXG4gICAgW0RPX05PVF9TRU5EX0VWRU5UX1NZTUJPTF06IHRydWUsXG4gIH07XG59XG5cbmZ1bmN0aW9uIF9pc0ludGVybmFsRXJyb3IoZXJyb3IpIHtcbiAgcmV0dXJuICEhZXJyb3IgJiYgdHlwZW9mIGVycm9yID09PSAnb2JqZWN0JyAmJiBJTlRFUk5BTF9FUlJPUl9TWU1CT0wgaW4gZXJyb3I7XG59XG5cbmZ1bmN0aW9uIF9pc0RvTm90U2VuZEV2ZW50RXJyb3IoZXJyb3IpIHtcbiAgcmV0dXJuICEhZXJyb3IgJiYgdHlwZW9mIGVycm9yID09PSAnb2JqZWN0JyAmJiBET19OT1RfU0VORF9FVkVOVF9TWU1CT0wgaW4gZXJyb3I7XG59XG5cbi8qKlxuICogQmFzZSBpbXBsZW1lbnRhdGlvbiBmb3IgYWxsIEphdmFTY3JpcHQgU0RLIGNsaWVudHMuXG4gKlxuICogQ2FsbCB0aGUgY29uc3RydWN0b3Igd2l0aCB0aGUgY29ycmVzcG9uZGluZyBvcHRpb25zXG4gKiBzcGVjaWZpYyB0byB0aGUgY2xpZW50IHN1YmNsYXNzLiBUbyBhY2Nlc3MgdGhlc2Ugb3B0aW9ucyBsYXRlciwgdXNlXG4gKiB7QGxpbmsgQ2xpZW50LmdldE9wdGlvbnN9LlxuICpcbiAqIElmIGEgRHNuIGlzIHNwZWNpZmllZCBpbiB0aGUgb3B0aW9ucywgaXQgd2lsbCBiZSBwYXJzZWQgYW5kIHN0b3JlZC4gVXNlXG4gKiB7QGxpbmsgQ2xpZW50LmdldERzbn0gdG8gcmV0cmlldmUgdGhlIERzbiBhdCBhbnkgbW9tZW50LiBJbiBjYXNlIHRoZSBEc24gaXNcbiAqIGludmFsaWQsIHRoZSBjb25zdHJ1Y3RvciB3aWxsIHRocm93IGEge0BsaW5rIFNlbnRyeUV4Y2VwdGlvbn0uIE5vdGUgdGhhdFxuICogd2l0aG91dCBhIHZhbGlkIERzbiwgdGhlIFNESyB3aWxsIG5vdCBzZW5kIGFueSBldmVudHMgdG8gU2VudHJ5LlxuICpcbiAqIEJlZm9yZSBzZW5kaW5nIGFuIGV2ZW50LCBpdCBpcyBwYXNzZWQgdGhyb3VnaFxuICoge0BsaW5rIENsaWVudC5fcHJlcGFyZUV2ZW50fSB0byBhZGQgU0RLIGluZm9ybWF0aW9uIGFuZCBzY29wZSBkYXRhXG4gKiAoYnJlYWRjcnVtYnMgYW5kIGNvbnRleHQpLiBUbyBhZGQgbW9yZSBjdXN0b20gaW5mb3JtYXRpb24sIG92ZXJyaWRlIHRoaXNcbiAqIG1ldGhvZCBhbmQgZXh0ZW5kIHRoZSByZXN1bHRpbmcgcHJlcGFyZWQgZXZlbnQuXG4gKlxuICogVG8gaXNzdWUgYXV0b21hdGljYWxseSBjcmVhdGVkIGV2ZW50cyAoZS5nLiB2aWEgaW5zdHJ1bWVudGF0aW9uKSwgdXNlXG4gKiB7QGxpbmsgQ2xpZW50LmNhcHR1cmVFdmVudH0uIEl0IHdpbGwgcHJlcGFyZSB0aGUgZXZlbnQgYW5kIHBhc3MgaXQgdGhyb3VnaFxuICogdGhlIGNhbGxiYWNrIGxpZmVjeWNsZS4gVG8gaXNzdWUgYXV0by1icmVhZGNydW1icywgdXNlXG4gKiB7QGxpbmsgQ2xpZW50LmFkZEJyZWFkY3J1bWJ9LlxuICpcbiAqIEBleGFtcGxlXG4gKiBjbGFzcyBOb2RlQ2xpZW50IGV4dGVuZHMgQ2xpZW50PE5vZGVPcHRpb25zPiB7XG4gKiAgIHB1YmxpYyBjb25zdHJ1Y3RvcihvcHRpb25zOiBOb2RlT3B0aW9ucykge1xuICogICAgIHN1cGVyKG9wdGlvbnMpO1xuICogICB9XG4gKlxuICogICAvLyAuLi5cbiAqIH1cbiAqL1xuY2xhc3MgQ2xpZW50IHtcbiAgLyoqIE9wdGlvbnMgcGFzc2VkIHRvIHRoZSBTREsuICovXG5cbiAgLyoqIFRoZSBjbGllbnQgRHNuLCBpZiBzcGVjaWZpZWQgaW4gb3B0aW9ucy4gV2l0aG91dCB0aGlzIERzbiwgdGhlIFNESyB3aWxsIGJlIGRpc2FibGVkLiAqL1xuXG4gIC8qKiBBcnJheSBvZiBzZXQgdXAgaW50ZWdyYXRpb25zLiAqL1xuXG4gIC8qKiBOdW1iZXIgb2YgY2FsbHMgYmVpbmcgcHJvY2Vzc2VkICovXG5cbiAgLyoqIEhvbGRzIGZsdXNoYWJsZSAgKi9cblxuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L2Jhbi10eXBlc1xuXG4gIC8qKlxuICAgKiBJbml0aWFsaXplcyB0aGlzIGNsaWVudCBpbnN0YW5jZS5cbiAgICpcbiAgICogQHBhcmFtIG9wdGlvbnMgT3B0aW9ucyBmb3IgdGhlIGNsaWVudC5cbiAgICovXG4gICBjb25zdHJ1Y3RvcihvcHRpb25zKSB7XG4gICAgdGhpcy5fb3B0aW9ucyA9IG9wdGlvbnM7XG4gICAgdGhpcy5faW50ZWdyYXRpb25zID0ge307XG4gICAgdGhpcy5fbnVtUHJvY2Vzc2luZyA9IDA7XG4gICAgdGhpcy5fb3V0Y29tZXMgPSB7fTtcbiAgICB0aGlzLl9ob29rcyA9IHt9O1xuICAgIHRoaXMuX2V2ZW50UHJvY2Vzc29ycyA9IFtdO1xuXG4gICAgaWYgKG9wdGlvbnMuZHNuKSB7XG4gICAgICB0aGlzLl9kc24gPSBkc24ubWFrZURzbihvcHRpb25zLmRzbik7XG4gICAgfSBlbHNlIHtcbiAgICAgIGRlYnVnQnVpbGQuREVCVUdfQlVJTEQgJiYgZGVidWdMb2dnZXIuZGVidWcud2FybignTm8gRFNOIHByb3ZpZGVkLCBjbGllbnQgd2lsbCBub3Qgc2VuZCBldmVudHMuJyk7XG4gICAgfVxuXG4gICAgaWYgKHRoaXMuX2Rzbikge1xuICAgICAgY29uc3QgdXJsID0gYXBpLmdldEVudmVsb3BlRW5kcG9pbnRXaXRoVXJsRW5jb2RlZEF1dGgoXG4gICAgICAgIHRoaXMuX2RzbixcbiAgICAgICAgb3B0aW9ucy50dW5uZWwsXG4gICAgICAgIG9wdGlvbnMuX21ldGFkYXRhID8gb3B0aW9ucy5fbWV0YWRhdGEuc2RrIDogdW5kZWZpbmVkLFxuICAgICAgKTtcbiAgICAgIHRoaXMuX3RyYW5zcG9ydCA9IG9wdGlvbnMudHJhbnNwb3J0KHtcbiAgICAgICAgdHVubmVsOiB0aGlzLl9vcHRpb25zLnR1bm5lbCxcbiAgICAgICAgcmVjb3JkRHJvcHBlZEV2ZW50OiB0aGlzLnJlY29yZERyb3BwZWRFdmVudC5iaW5kKHRoaXMpLFxuICAgICAgICAuLi5vcHRpb25zLnRyYW5zcG9ydE9wdGlvbnMsXG4gICAgICAgIHVybCxcbiAgICAgIH0pO1xuICAgIH1cbiAgfVxuXG4gIC8qKlxuICAgKiBDYXB0dXJlcyBhbiBleGNlcHRpb24gZXZlbnQgYW5kIHNlbmRzIGl0IHRvIFNlbnRyeS5cbiAgICpcbiAgICogVW5saWtlIGBjYXB0dXJlRXhjZXB0aW9uYCBleHBvcnRlZCBmcm9tIGV2ZXJ5IFNESywgdGhpcyBtZXRob2QgcmVxdWlyZXMgdGhhdCB5b3UgcGFzcyBpdCB0aGUgY3VycmVudCBzY29wZS5cbiAgICovXG4gICBjYXB0dXJlRXhjZXB0aW9uKGV4Y2VwdGlvbiwgaGludCwgc2NvcGUpIHtcbiAgICBjb25zdCBldmVudElkID0gbWlzYy51dWlkNCgpO1xuXG4gICAgLy8gZW5zdXJlIHdlIGhhdmVuJ3QgY2FwdHVyZWQgdGhpcyB2ZXJ5IG9iamVjdCBiZWZvcmVcbiAgICBpZiAobWlzYy5jaGVja09yU2V0QWxyZWFkeUNhdWdodChleGNlcHRpb24pKSB7XG4gICAgICBkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEICYmIGRlYnVnTG9nZ2VyLmRlYnVnLmxvZyhBTFJFQURZX1NFRU5fRVJST1IpO1xuICAgICAgcmV0dXJuIGV2ZW50SWQ7XG4gICAgfVxuXG4gICAgY29uc3QgaGludFdpdGhFdmVudElkID0ge1xuICAgICAgZXZlbnRfaWQ6IGV2ZW50SWQsXG4gICAgICAuLi5oaW50LFxuICAgIH07XG5cbiAgICB0aGlzLl9wcm9jZXNzKFxuICAgICAgdGhpcy5ldmVudEZyb21FeGNlcHRpb24oZXhjZXB0aW9uLCBoaW50V2l0aEV2ZW50SWQpLnRoZW4oZXZlbnQgPT5cbiAgICAgICAgdGhpcy5fY2FwdHVyZUV2ZW50KGV2ZW50LCBoaW50V2l0aEV2ZW50SWQsIHNjb3BlKSxcbiAgICAgICksXG4gICAgKTtcblxuICAgIHJldHVybiBoaW50V2l0aEV2ZW50SWQuZXZlbnRfaWQ7XG4gIH1cblxuICAvKipcbiAgICogQ2FwdHVyZXMgYSBtZXNzYWdlIGV2ZW50IGFuZCBzZW5kcyBpdCB0byBTZW50cnkuXG4gICAqXG4gICAqIFVubGlrZSBgY2FwdHVyZU1lc3NhZ2VgIGV4cG9ydGVkIGZyb20gZXZlcnkgU0RLLCB0aGlzIG1ldGhvZCByZXF1aXJlcyB0aGF0IHlvdSBwYXNzIGl0IHRoZSBjdXJyZW50IHNjb3BlLlxuICAgKi9cbiAgIGNhcHR1cmVNZXNzYWdlKFxuICAgIG1lc3NhZ2UsXG4gICAgbGV2ZWwsXG4gICAgaGludCxcbiAgICBjdXJyZW50U2NvcGUsXG4gICkge1xuICAgIGNvbnN0IGhpbnRXaXRoRXZlbnRJZCA9IHtcbiAgICAgIGV2ZW50X2lkOiBtaXNjLnV1aWQ0KCksXG4gICAgICAuLi5oaW50LFxuICAgIH07XG5cbiAgICBjb25zdCBldmVudE1lc3NhZ2UgPSBpcy5pc1BhcmFtZXRlcml6ZWRTdHJpbmcobWVzc2FnZSkgPyBtZXNzYWdlIDogU3RyaW5nKG1lc3NhZ2UpO1xuXG4gICAgY29uc3QgcHJvbWlzZWRFdmVudCA9IGlzLmlzUHJpbWl0aXZlKG1lc3NhZ2UpXG4gICAgICA/IHRoaXMuZXZlbnRGcm9tTWVzc2FnZShldmVudE1lc3NhZ2UsIGxldmVsLCBoaW50V2l0aEV2ZW50SWQpXG4gICAgICA6IHRoaXMuZXZlbnRGcm9tRXhjZXB0aW9uKG1lc3NhZ2UsIGhpbnRXaXRoRXZlbnRJZCk7XG5cbiAgICB0aGlzLl9wcm9jZXNzKHByb21pc2VkRXZlbnQudGhlbihldmVudCA9PiB0aGlzLl9jYXB0dXJlRXZlbnQoZXZlbnQsIGhpbnRXaXRoRXZlbnRJZCwgY3VycmVudFNjb3BlKSkpO1xuXG4gICAgcmV0dXJuIGhpbnRXaXRoRXZlbnRJZC5ldmVudF9pZDtcbiAgfVxuXG4gIC8qKlxuICAgKiBDYXB0dXJlcyBhIG1hbnVhbGx5IGNyZWF0ZWQgZXZlbnQgYW5kIHNlbmRzIGl0IHRvIFNlbnRyeS5cbiAgICpcbiAgICogVW5saWtlIGBjYXB0dXJlRXZlbnRgIGV4cG9ydGVkIGZyb20gZXZlcnkgU0RLLCB0aGlzIG1ldGhvZCByZXF1aXJlcyB0aGF0IHlvdSBwYXNzIGl0IHRoZSBjdXJyZW50IHNjb3BlLlxuICAgKi9cbiAgIGNhcHR1cmVFdmVudChldmVudCwgaGludCwgY3VycmVudFNjb3BlKSB7XG4gICAgY29uc3QgZXZlbnRJZCA9IG1pc2MudXVpZDQoKTtcblxuICAgIC8vIGVuc3VyZSB3ZSBoYXZlbid0IGNhcHR1cmVkIHRoaXMgdmVyeSBvYmplY3QgYmVmb3JlXG4gICAgaWYgKGhpbnQ/Lm9yaWdpbmFsRXhjZXB0aW9uICYmIG1pc2MuY2hlY2tPclNldEFscmVhZHlDYXVnaHQoaGludC5vcmlnaW5hbEV4Y2VwdGlvbikpIHtcbiAgICAgIGRlYnVnQnVpbGQuREVCVUdfQlVJTEQgJiYgZGVidWdMb2dnZXIuZGVidWcubG9nKEFMUkVBRFlfU0VFTl9FUlJPUik7XG4gICAgICByZXR1cm4gZXZlbnRJZDtcbiAgICB9XG5cbiAgICBjb25zdCBoaW50V2l0aEV2ZW50SWQgPSB7XG4gICAgICBldmVudF9pZDogZXZlbnRJZCxcbiAgICAgIC4uLmhpbnQsXG4gICAgfTtcblxuICAgIGNvbnN0IHNka1Byb2Nlc3NpbmdNZXRhZGF0YSA9IGV2ZW50LnNka1Byb2Nlc3NpbmdNZXRhZGF0YSB8fCB7fTtcbiAgICBjb25zdCBjYXB0dXJlZFNwYW5TY29wZSA9IHNka1Byb2Nlc3NpbmdNZXRhZGF0YS5jYXB0dXJlZFNwYW5TY29wZTtcbiAgICBjb25zdCBjYXB0dXJlZFNwYW5Jc29sYXRpb25TY29wZSA9IHNka1Byb2Nlc3NpbmdNZXRhZGF0YS5jYXB0dXJlZFNwYW5Jc29sYXRpb25TY29wZTtcblxuICAgIHRoaXMuX3Byb2Nlc3MoXG4gICAgICB0aGlzLl9jYXB0dXJlRXZlbnQoZXZlbnQsIGhpbnRXaXRoRXZlbnRJZCwgY2FwdHVyZWRTcGFuU2NvcGUgfHwgY3VycmVudFNjb3BlLCBjYXB0dXJlZFNwYW5Jc29sYXRpb25TY29wZSksXG4gICAgKTtcblxuICAgIHJldHVybiBoaW50V2l0aEV2ZW50SWQuZXZlbnRfaWQ7XG4gIH1cblxuICAvKipcbiAgICogQ2FwdHVyZXMgYSBzZXNzaW9uLlxuICAgKi9cbiAgIGNhcHR1cmVTZXNzaW9uKHNlc3Npb24kMSkge1xuICAgIHRoaXMuc2VuZFNlc3Npb24oc2Vzc2lvbiQxKTtcbiAgICAvLyBBZnRlciBzZW5kaW5nLCB3ZSBzZXQgaW5pdCBmYWxzZSB0byBpbmRpY2F0ZSBpdCdzIG5vdCB0aGUgZmlyc3Qgb2NjdXJyZW5jZVxuICAgIHNlc3Npb24udXBkYXRlU2Vzc2lvbihzZXNzaW9uJDEsIHsgaW5pdDogZmFsc2UgfSk7XG4gIH1cblxuICAvKipcbiAgICogQ3JlYXRlIGEgY3JvbiBtb25pdG9yIGNoZWNrIGluIGFuZCBzZW5kIGl0IHRvIFNlbnRyeS4gVGhpcyBtZXRob2QgaXMgbm90IGF2YWlsYWJsZSBvbiBhbGwgY2xpZW50cy5cbiAgICpcbiAgICogQHBhcmFtIGNoZWNrSW4gQW4gb2JqZWN0IHRoYXQgZGVzY3JpYmVzIGEgY2hlY2sgaW4uXG4gICAqIEBwYXJhbSB1cHNlcnRNb25pdG9yQ29uZmlnIEFuIG9wdGlvbmFsIG9iamVjdCB0aGF0IGRlc2NyaWJlcyBhIG1vbml0b3IgY29uZmlnLiBVc2UgdGhpcyBpZiB5b3Ugd2FudFxuICAgKiB0byBjcmVhdGUgYSBtb25pdG9yIGF1dG9tYXRpY2FsbHkgd2hlbiBzZW5kaW5nIGEgY2hlY2sgaW4uXG4gICAqIEBwYXJhbSBzY29wZSBBbiBvcHRpb25hbCBzY29wZSBjb250YWluaW5nIGV2ZW50IG1ldGFkYXRhLlxuICAgKiBAcmV0dXJucyBBIHN0cmluZyByZXByZXNlbnRpbmcgdGhlIGlkIG9mIHRoZSBjaGVjayBpbi5cbiAgICovXG5cbiAgLyoqXG4gICAqIEdldCB0aGUgY3VycmVudCBEc24uXG4gICAqL1xuICAgZ2V0RHNuKCkge1xuICAgIHJldHVybiB0aGlzLl9kc247XG4gIH1cblxuICAvKipcbiAgICogR2V0IHRoZSBjdXJyZW50IG9wdGlvbnMuXG4gICAqL1xuICAgZ2V0T3B0aW9ucygpIHtcbiAgICByZXR1cm4gdGhpcy5fb3B0aW9ucztcbiAgfVxuXG4gIC8qKlxuICAgKiBHZXQgdGhlIFNESyBtZXRhZGF0YS5cbiAgICogQHNlZSBTZGtNZXRhZGF0YVxuICAgKi9cbiAgIGdldFNka01ldGFkYXRhKCkge1xuICAgIHJldHVybiB0aGlzLl9vcHRpb25zLl9tZXRhZGF0YTtcbiAgfVxuXG4gIC8qKlxuICAgKiBSZXR1cm5zIHRoZSB0cmFuc3BvcnQgdGhhdCBpcyB1c2VkIGJ5IHRoZSBjbGllbnQuXG4gICAqIFBsZWFzZSBub3RlIHRoYXQgdGhlIHRyYW5zcG9ydCBnZXRzIGxhenkgaW5pdGlhbGl6ZWQgc28gaXQgd2lsbCBvbmx5IGJlIHRoZXJlIG9uY2UgdGhlIGZpcnN0IGV2ZW50IGhhcyBiZWVuIHNlbnQuXG4gICAqL1xuICAgZ2V0VHJhbnNwb3J0KCkge1xuICAgIHJldHVybiB0aGlzLl90cmFuc3BvcnQ7XG4gIH1cblxuICAvKipcbiAgICogV2FpdCBmb3IgYWxsIGV2ZW50cyB0byBiZSBzZW50IG9yIHRoZSB0aW1lb3V0IHRvIGV4cGlyZSwgd2hpY2hldmVyIGNvbWVzIGZpcnN0LlxuICAgKlxuICAgKiBAcGFyYW0gdGltZW91dCBNYXhpbXVtIHRpbWUgaW4gbXMgdGhlIGNsaWVudCBzaG91bGQgd2FpdCBmb3IgZXZlbnRzIHRvIGJlIGZsdXNoZWQuIE9taXR0aW5nIHRoaXMgcGFyYW1ldGVyIHdpbGxcbiAgICogICBjYXVzZSB0aGUgY2xpZW50IHRvIHdhaXQgdW50aWwgYWxsIGV2ZW50cyBhcmUgc2VudCBiZWZvcmUgcmVzb2x2aW5nIHRoZSBwcm9taXNlLlxuICAgKiBAcmV0dXJucyBBIHByb21pc2UgdGhhdCB3aWxsIHJlc29sdmUgd2l0aCBgdHJ1ZWAgaWYgYWxsIGV2ZW50cyBhcmUgc2VudCBiZWZvcmUgdGhlIHRpbWVvdXQsIG9yIGBmYWxzZWAgaWYgdGhlcmUgYXJlXG4gICAqIHN0aWxsIGV2ZW50cyBpbiB0aGUgcXVldWUgd2hlbiB0aGUgdGltZW91dCBpcyByZWFjaGVkLlxuICAgKi9cbiAgIGZsdXNoKHRpbWVvdXQpIHtcbiAgICBjb25zdCB0cmFuc3BvcnQgPSB0aGlzLl90cmFuc3BvcnQ7XG4gICAgaWYgKHRyYW5zcG9ydCkge1xuICAgICAgdGhpcy5lbWl0KCdmbHVzaCcpO1xuICAgICAgcmV0dXJuIHRoaXMuX2lzQ2xpZW50RG9uZVByb2Nlc3NpbmcodGltZW91dCkudGhlbihjbGllbnRGaW5pc2hlZCA9PiB7XG4gICAgICAgIHJldHVybiB0cmFuc3BvcnQuZmx1c2godGltZW91dCkudGhlbih0cmFuc3BvcnRGbHVzaGVkID0+IGNsaWVudEZpbmlzaGVkICYmIHRyYW5zcG9ydEZsdXNoZWQpO1xuICAgICAgfSk7XG4gICAgfSBlbHNlIHtcbiAgICAgIHJldHVybiBzeW5jcHJvbWlzZS5yZXNvbHZlZFN5bmNQcm9taXNlKHRydWUpO1xuICAgIH1cbiAgfVxuXG4gIC8qKlxuICAgKiBGbHVzaCB0aGUgZXZlbnQgcXVldWUgYW5kIHNldCB0aGUgY2xpZW50IHRvIGBlbmFibGVkID0gZmFsc2VgLiBTZWUge0BsaW5rIENsaWVudC5mbHVzaH0uXG4gICAqXG4gICAqIEBwYXJhbSB7bnVtYmVyfSB0aW1lb3V0IE1heGltdW0gdGltZSBpbiBtcyB0aGUgY2xpZW50IHNob3VsZCB3YWl0IGJlZm9yZSBzaHV0dGluZyBkb3duLiBPbWl0dGluZyB0aGlzIHBhcmFtZXRlciB3aWxsIGNhdXNlXG4gICAqICAgdGhlIGNsaWVudCB0byB3YWl0IHVudGlsIGFsbCBldmVudHMgYXJlIHNlbnQgYmVmb3JlIGRpc2FibGluZyBpdHNlbGYuXG4gICAqIEByZXR1cm5zIHtQcm9taXNlPGJvb2xlYW4+fSBBIHByb21pc2Ugd2hpY2ggcmVzb2x2ZXMgdG8gYHRydWVgIGlmIHRoZSBmbHVzaCBjb21wbGV0ZXMgc3VjY2Vzc2Z1bGx5IGJlZm9yZSB0aGUgdGltZW91dCwgb3IgYGZhbHNlYCBpZlxuICAgKiBpdCBkb2Vzbid0LlxuICAgKi9cbiAgIGNsb3NlKHRpbWVvdXQpIHtcbiAgICByZXR1cm4gdGhpcy5mbHVzaCh0aW1lb3V0KS50aGVuKHJlc3VsdCA9PiB7XG4gICAgICB0aGlzLmdldE9wdGlvbnMoKS5lbmFibGVkID0gZmFsc2U7XG4gICAgICB0aGlzLmVtaXQoJ2Nsb3NlJyk7XG4gICAgICByZXR1cm4gcmVzdWx0O1xuICAgIH0pO1xuICB9XG5cbiAgLyoqXG4gICAqIEdldCBhbGwgaW5zdGFsbGVkIGV2ZW50IHByb2Nlc3NvcnMuXG4gICAqL1xuICAgZ2V0RXZlbnRQcm9jZXNzb3JzKCkge1xuICAgIHJldHVybiB0aGlzLl9ldmVudFByb2Nlc3NvcnM7XG4gIH1cblxuICAvKipcbiAgICogQWRkcyBhbiBldmVudCBwcm9jZXNzb3IgdGhhdCBhcHBsaWVzIHRvIGFueSBldmVudCBwcm9jZXNzZWQgYnkgdGhpcyBjbGllbnQuXG4gICAqL1xuICAgYWRkRXZlbnRQcm9jZXNzb3IoZXZlbnRQcm9jZXNzb3IpIHtcbiAgICB0aGlzLl9ldmVudFByb2Nlc3NvcnMucHVzaChldmVudFByb2Nlc3Nvcik7XG4gIH1cblxuICAvKipcbiAgICogSW5pdGlhbGl6ZSB0aGlzIGNsaWVudC5cbiAgICogQ2FsbCB0aGlzIGFmdGVyIHRoZSBjbGllbnQgd2FzIHNldCBvbiBhIHNjb3BlLlxuICAgKi9cbiAgIGluaXQoKSB7XG4gICAgaWYgKFxuICAgICAgdGhpcy5faXNFbmFibGVkKCkgfHxcbiAgICAgIC8vIEZvcmNlIGludGVncmF0aW9ucyB0byBiZSBzZXR1cCBldmVuIGlmIG5vIERTTiB3YXMgc2V0IHdoZW4gd2UgaGF2ZVxuICAgICAgLy8gU3BvdGxpZ2h0IGVuYWJsZWQuIFRoaXMgaXMgcGFydGljdWxhcmx5IGltcG9ydGFudCBmb3IgYnJvd3NlciBhcyB3ZVxuICAgICAgLy8gZG9uJ3Qgc3VwcG9ydCB0aGUgYHNwb3RsaWdodGAgb3B0aW9uIHRoZXJlIGFuZCByZWx5IG9uIHRoZSB1c2Vyc1xuICAgICAgLy8gYWRkaW5nIHRoZSBgc3BvdGxpZ2h0QnJvd3NlckludGVncmF0aW9uKClgIHRvIHRoZWlyIGludGVncmF0aW9ucyB3aGljaFxuICAgICAgLy8gd291bGRuJ3QgZ2V0IGluaXRpYWxpemVkIHdpdGggdGhlIGNoZWNrIGJlbG93IHdoZW4gdGhlcmUncyBubyBEU04gc2V0LlxuICAgICAgdGhpcy5fb3B0aW9ucy5pbnRlZ3JhdGlvbnMuc29tZSgoeyBuYW1lIH0pID0+IG5hbWUuc3RhcnRzV2l0aCgnU3BvdGxpZ2h0JykpXG4gICAgKSB7XG4gICAgICB0aGlzLl9zZXR1cEludGVncmF0aW9ucygpO1xuICAgIH1cbiAgfVxuXG4gIC8qKlxuICAgKiBHZXRzIGFuIGluc3RhbGxlZCBpbnRlZ3JhdGlvbiBieSBpdHMgbmFtZS5cbiAgICpcbiAgICogQHJldHVybnMge0ludGVncmF0aW9ufHVuZGVmaW5lZH0gVGhlIGluc3RhbGxlZCBpbnRlZ3JhdGlvbiBvciBgdW5kZWZpbmVkYCBpZiBubyBpbnRlZ3JhdGlvbiB3aXRoIHRoYXQgYG5hbWVgIHdhcyBpbnN0YWxsZWQuXG4gICAqL1xuICAgZ2V0SW50ZWdyYXRpb25CeU5hbWUoaW50ZWdyYXRpb25OYW1lKSB7XG4gICAgcmV0dXJuIHRoaXMuX2ludGVncmF0aW9uc1tpbnRlZ3JhdGlvbk5hbWVdIDtcbiAgfVxuXG4gIC8qKlxuICAgKiBBZGQgYW4gaW50ZWdyYXRpb24gdG8gdGhlIGNsaWVudC5cbiAgICogVGhpcyBjYW4gYmUgdXNlZCB0byBlLmcuIGxhenkgbG9hZCBpbnRlZ3JhdGlvbnMuXG4gICAqIEluIG1vc3QgY2FzZXMsIHRoaXMgc2hvdWxkIG5vdCBiZSBuZWNlc3NhcnksXG4gICAqIGFuZCB5b3UncmUgYmV0dGVyIG9mZiBqdXN0IHBhc3NpbmcgdGhlIGludGVncmF0aW9ucyB2aWEgYGludGVncmF0aW9uczogW11gIGF0IGluaXRpYWxpemF0aW9uIHRpbWUuXG4gICAqIEhvd2V2ZXIsIGlmIHlvdSBmaW5kIHRoZSBuZWVkIHRvIGNvbmRpdGlvbmFsbHkgbG9hZCAmIGFkZCBhbiBpbnRlZ3JhdGlvbiwgeW91IGNhbiB1c2UgYGFkZEludGVncmF0aW9uYCB0byBkbyBzby5cbiAgICovXG4gICBhZGRJbnRlZ3JhdGlvbihpbnRlZ3JhdGlvbiQxKSB7XG4gICAgY29uc3QgaXNBbHJlYWR5SW5zdGFsbGVkID0gdGhpcy5faW50ZWdyYXRpb25zW2ludGVncmF0aW9uJDEubmFtZV07XG5cbiAgICAvLyBUaGlzIGhvb2sgdGFrZXMgY2FyZSBvZiBvbmx5IGluc3RhbGxpbmcgaWYgbm90IGFscmVhZHkgaW5zdGFsbGVkXG4gICAgaW50ZWdyYXRpb24uc2V0dXBJbnRlZ3JhdGlvbih0aGlzLCBpbnRlZ3JhdGlvbiQxLCB0aGlzLl9pbnRlZ3JhdGlvbnMpO1xuICAgIC8vIEhlcmUgd2UgbmVlZCB0byBjaGVjayBtYW51YWxseSB0byBtYWtlIHN1cmUgdG8gbm90IHJ1biB0aGlzIG11bHRpcGxlIHRpbWVzXG4gICAgaWYgKCFpc0FscmVhZHlJbnN0YWxsZWQpIHtcbiAgICAgIGludGVncmF0aW9uLmFmdGVyU2V0dXBJbnRlZ3JhdGlvbnModGhpcywgW2ludGVncmF0aW9uJDFdKTtcbiAgICB9XG4gIH1cblxuICAvKipcbiAgICogU2VuZCBhIGZ1bGx5IHByZXBhcmVkIGV2ZW50IHRvIFNlbnRyeS5cbiAgICovXG4gICBzZW5kRXZlbnQoZXZlbnQsIGhpbnQgPSB7fSkge1xuICAgIHRoaXMuZW1pdCgnYmVmb3JlU2VuZEV2ZW50JywgZXZlbnQsIGhpbnQpO1xuXG4gICAgbGV0IGVudiA9IGVudmVsb3BlLmNyZWF0ZUV2ZW50RW52ZWxvcGUoZXZlbnQsIHRoaXMuX2RzbiwgdGhpcy5fb3B0aW9ucy5fbWV0YWRhdGEsIHRoaXMuX29wdGlvbnMudHVubmVsKTtcblxuICAgIGZvciAoY29uc3QgYXR0YWNobWVudCBvZiBoaW50LmF0dGFjaG1lbnRzIHx8IFtdKSB7XG4gICAgICBlbnYgPSBlbnZlbG9wZSQxLmFkZEl0ZW1Ub0VudmVsb3BlKGVudiwgZW52ZWxvcGUkMS5jcmVhdGVBdHRhY2htZW50RW52ZWxvcGVJdGVtKGF0dGFjaG1lbnQpKTtcbiAgICB9XG5cbiAgICBjb25zdCBwcm9taXNlID0gdGhpcy5zZW5kRW52ZWxvcGUoZW52KTtcbiAgICBpZiAocHJvbWlzZSkge1xuICAgICAgcHJvbWlzZS50aGVuKHNlbmRSZXNwb25zZSA9PiB0aGlzLmVtaXQoJ2FmdGVyU2VuZEV2ZW50JywgZXZlbnQsIHNlbmRSZXNwb25zZSksIG51bGwpO1xuICAgIH1cbiAgfVxuXG4gIC8qKlxuICAgKiBTZW5kIGEgc2Vzc2lvbiBvciBzZXNzaW9uIGFnZ3JlZ3JhdGVzIHRvIFNlbnRyeS5cbiAgICovXG4gICBzZW5kU2Vzc2lvbihzZXNzaW9uKSB7XG4gICAgLy8gQmFja2ZpbGwgcmVsZWFzZSBhbmQgZW52aXJvbm1lbnQgb24gc2Vzc2lvblxuICAgIGNvbnN0IHsgcmVsZWFzZTogY2xpZW50UmVsZWFzZU9wdGlvbiwgZW52aXJvbm1lbnQ6IGNsaWVudEVudmlyb25tZW50T3B0aW9uID0gY29uc3RhbnRzLkRFRkFVTFRfRU5WSVJPTk1FTlQgfSA9IHRoaXMuX29wdGlvbnM7XG4gICAgaWYgKCdhZ2dyZWdhdGVzJyBpbiBzZXNzaW9uKSB7XG4gICAgICBjb25zdCBzZXNzaW9uQXR0cnMgPSBzZXNzaW9uLmF0dHJzIHx8IHt9O1xuICAgICAgaWYgKCFzZXNzaW9uQXR0cnMucmVsZWFzZSAmJiAhY2xpZW50UmVsZWFzZU9wdGlvbikge1xuICAgICAgICBkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEICYmIGRlYnVnTG9nZ2VyLmRlYnVnLndhcm4oTUlTU0lOR19SRUxFQVNFX0ZPUl9TRVNTSU9OX0VSUk9SKTtcbiAgICAgICAgcmV0dXJuO1xuICAgICAgfVxuICAgICAgc2Vzc2lvbkF0dHJzLnJlbGVhc2UgPSBzZXNzaW9uQXR0cnMucmVsZWFzZSB8fCBjbGllbnRSZWxlYXNlT3B0aW9uO1xuICAgICAgc2Vzc2lvbkF0dHJzLmVudmlyb25tZW50ID0gc2Vzc2lvbkF0dHJzLmVudmlyb25tZW50IHx8IGNsaWVudEVudmlyb25tZW50T3B0aW9uO1xuICAgICAgc2Vzc2lvbi5hdHRycyA9IHNlc3Npb25BdHRycztcbiAgICB9IGVsc2Uge1xuICAgICAgaWYgKCFzZXNzaW9uLnJlbGVhc2UgJiYgIWNsaWVudFJlbGVhc2VPcHRpb24pIHtcbiAgICAgICAgZGVidWdCdWlsZC5ERUJVR19CVUlMRCAmJiBkZWJ1Z0xvZ2dlci5kZWJ1Zy53YXJuKE1JU1NJTkdfUkVMRUFTRV9GT1JfU0VTU0lPTl9FUlJPUik7XG4gICAgICAgIHJldHVybjtcbiAgICAgIH1cbiAgICAgIHNlc3Npb24ucmVsZWFzZSA9IHNlc3Npb24ucmVsZWFzZSB8fCBjbGllbnRSZWxlYXNlT3B0aW9uO1xuICAgICAgc2Vzc2lvbi5lbnZpcm9ubWVudCA9IHNlc3Npb24uZW52aXJvbm1lbnQgfHwgY2xpZW50RW52aXJvbm1lbnRPcHRpb247XG4gICAgfVxuXG4gICAgdGhpcy5lbWl0KCdiZWZvcmVTZW5kU2Vzc2lvbicsIHNlc3Npb24pO1xuXG4gICAgY29uc3QgZW52ID0gZW52ZWxvcGUuY3JlYXRlU2Vzc2lvbkVudmVsb3BlKHNlc3Npb24sIHRoaXMuX2RzbiwgdGhpcy5fb3B0aW9ucy5fbWV0YWRhdGEsIHRoaXMuX29wdGlvbnMudHVubmVsKTtcblxuICAgIC8vIHNlbmRFbnZlbG9wZSBzaG91bGQgbm90IHRocm93XG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uby1mbG9hdGluZy1wcm9taXNlc1xuICAgIHRoaXMuc2VuZEVudmVsb3BlKGVudik7XG4gIH1cblxuICAvKipcbiAgICogUmVjb3JkIG9uIHRoZSBjbGllbnQgdGhhdCBhbiBldmVudCBnb3QgZHJvcHBlZCAoaWUsIGFuIGV2ZW50IHRoYXQgd2lsbCBub3QgYmUgc2VudCB0byBTZW50cnkpLlxuICAgKi9cbiAgIHJlY29yZERyb3BwZWRFdmVudChyZWFzb24sIGNhdGVnb3J5LCBjb3VudCA9IDEpIHtcbiAgICBpZiAodGhpcy5fb3B0aW9ucy5zZW5kQ2xpZW50UmVwb3J0cykge1xuICAgICAgLy8gV2Ugd2FudCB0byB0cmFjayBlYWNoIGNhdGVnb3J5IChlcnJvciwgdHJhbnNhY3Rpb24sIHNlc3Npb24sIHJlcGxheV9ldmVudCkgc2VwYXJhdGVseVxuICAgICAgLy8gYnV0IHN0aWxsIGtlZXAgdGhlIGRpc3RpbmN0aW9uIGJldHdlZW4gZGlmZmVyZW50IHR5cGUgb2Ygb3V0Y29tZXMuXG4gICAgICAvLyBXZSBjb3VsZCB1c2UgbmVzdGVkIG1hcHMsIGJ1dCBpdCdzIG11Y2ggZWFzaWVyIHRvIHJlYWQgYW5kIHR5cGUgdGhpcyB3YXkuXG4gICAgICAvLyBBIGNvcnJlY3QgdHlwZSBmb3IgbWFwLWJhc2VkIGltcGxlbWVudGF0aW9uIGlmIHdlIHdhbnQgdG8gZ28gdGhhdCByb3V0ZVxuICAgICAgLy8gd291bGQgYmUgYFBhcnRpYWw8UmVjb3JkPFNlbnRyeVJlcXVlc3RUeXBlLCBQYXJ0aWFsPFJlY29yZDxPdXRjb21lLCBudW1iZXI+Pj4+YFxuICAgICAgLy8gV2l0aCB0eXBlc2NyaXB0IDQuMSB3ZSBjb3VsZCBldmVuIHVzZSB0ZW1wbGF0ZSBsaXRlcmFsIHR5cGVzXG4gICAgICBjb25zdCBrZXkgPSBgJHtyZWFzb259OiR7Y2F0ZWdvcnl9YDtcbiAgICAgIGRlYnVnQnVpbGQuREVCVUdfQlVJTEQgJiYgZGVidWdMb2dnZXIuZGVidWcubG9nKGBSZWNvcmRpbmcgb3V0Y29tZTogXCIke2tleX1cIiR7Y291bnQgPiAxID8gYCAoJHtjb3VudH0gdGltZXMpYCA6ICcnfWApO1xuICAgICAgdGhpcy5fb3V0Y29tZXNba2V5XSA9ICh0aGlzLl9vdXRjb21lc1trZXldIHx8IDApICsgY291bnQ7XG4gICAgfVxuICB9XG5cbiAgLyogZXNsaW50LWRpc2FibGUgQHR5cGVzY3JpcHQtZXNsaW50L3VuaWZpZWQtc2lnbmF0dXJlcyAqL1xuICAvKipcbiAgICogUmVnaXN0ZXIgYSBjYWxsYmFjayBmb3Igd2hlbmV2ZXIgYSBzcGFuIGlzIHN0YXJ0ZWQuXG4gICAqIFJlY2VpdmVzIHRoZSBzcGFuIGFzIGFyZ3VtZW50LlxuICAgKiBAcmV0dXJucyB7KCkgPT4gdm9pZH0gQSBmdW5jdGlvbiB0aGF0LCB3aGVuIGV4ZWN1dGVkLCByZW1vdmVzIHRoZSByZWdpc3RlcmVkIGNhbGxiYWNrLlxuICAgKi9cblxuICAvKipcbiAgICogUmVnaXN0ZXIgYSBob29rIG9uIHRoaXMgY2xpZW50LlxuICAgKi9cbiAgIG9uKGhvb2ssIGNhbGxiYWNrKSB7XG4gICAgY29uc3QgaG9va3MgPSAodGhpcy5faG9va3NbaG9va10gPSB0aGlzLl9ob29rc1tob29rXSB8fCBbXSk7XG5cbiAgICAvLyBAdHMtZXhwZWN0LWVycm9yIFdlIGFzc3VtZSB0aGUgdHlwZXMgYXJlIGNvcnJlY3RcbiAgICBob29rcy5wdXNoKGNhbGxiYWNrKTtcblxuICAgIC8vIFRoaXMgZnVuY3Rpb24gcmV0dXJucyBhIGNhbGxiYWNrIGV4ZWN1dGlvbiBoYW5kbGVyIHRoYXQsIHdoZW4gaW52b2tlZCxcbiAgICAvLyBkZXJlZ2lzdGVycyBhIGNhbGxiYWNrLiBUaGlzIGlzIGNydWNpYWwgZm9yIG1hbmFnaW5nIGluc3RhbmNlcyB3aGVyZSBjYWxsYmFja3NcbiAgICAvLyBuZWVkIHRvIGJlIHVucmVnaXN0ZXJlZCB0byBwcmV2ZW50IHNlbGYtcmVmZXJlbmNpbmcgaW4gY2FsbGJhY2sgY2xvc3VyZXMsXG4gICAgLy8gZW5zdXJpbmcgcHJvcGVyIGdhcmJhZ2UgY29sbGVjdGlvbi5cbiAgICByZXR1cm4gKCkgPT4ge1xuICAgICAgLy8gQHRzLWV4cGVjdC1lcnJvciBXZSBhc3N1bWUgdGhlIHR5cGVzIGFyZSBjb3JyZWN0XG4gICAgICBjb25zdCBjYkluZGV4ID0gaG9va3MuaW5kZXhPZihjYWxsYmFjayk7XG4gICAgICBpZiAoY2JJbmRleCA+IC0xKSB7XG4gICAgICAgIGhvb2tzLnNwbGljZShjYkluZGV4LCAxKTtcbiAgICAgIH1cbiAgICB9O1xuICB9XG5cbiAgLyoqIEZpcmUgYSBob29rIHdoZW5ldmVyIGEgc3BhbiBzdGFydHMuICovXG5cbiAgLyoqXG4gICAqIEVtaXQgYSBob29rIHRoYXQgd2FzIHByZXZpb3VzbHkgcmVnaXN0ZXJlZCB2aWEgYG9uKClgLlxuICAgKi9cbiAgIGVtaXQoaG9vaywgLi4ucmVzdCkge1xuICAgIGNvbnN0IGNhbGxiYWNrcyA9IHRoaXMuX2hvb2tzW2hvb2tdO1xuICAgIGlmIChjYWxsYmFja3MpIHtcbiAgICAgIGNhbGxiYWNrcy5mb3JFYWNoKGNhbGxiYWNrID0+IGNhbGxiYWNrKC4uLnJlc3QpKTtcbiAgICB9XG4gIH1cblxuICAvKipcbiAgICogU2VuZCBhbiBlbnZlbG9wZSB0byBTZW50cnkuXG4gICAqL1xuICAgc2VuZEVudmVsb3BlKGVudmVsb3BlKSB7XG4gICAgdGhpcy5lbWl0KCdiZWZvcmVFbnZlbG9wZScsIGVudmVsb3BlKTtcblxuICAgIGlmICh0aGlzLl9pc0VuYWJsZWQoKSAmJiB0aGlzLl90cmFuc3BvcnQpIHtcbiAgICAgIHJldHVybiB0aGlzLl90cmFuc3BvcnQuc2VuZChlbnZlbG9wZSkudGhlbihudWxsLCByZWFzb24gPT4ge1xuICAgICAgICBkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEICYmIGRlYnVnTG9nZ2VyLmRlYnVnLmVycm9yKCdFcnJvciB3aGlsZSBzZW5kaW5nIGVudmVsb3BlOicsIHJlYXNvbik7XG4gICAgICAgIHJldHVybiByZWFzb247XG4gICAgICB9KTtcbiAgICB9XG5cbiAgICBkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEICYmIGRlYnVnTG9nZ2VyLmRlYnVnLmVycm9yKCdUcmFuc3BvcnQgZGlzYWJsZWQnKTtcblxuICAgIHJldHVybiBzeW5jcHJvbWlzZS5yZXNvbHZlZFN5bmNQcm9taXNlKHt9KTtcbiAgfVxuXG4gIC8qIGVzbGludC1lbmFibGUgQHR5cGVzY3JpcHQtZXNsaW50L3VuaWZpZWQtc2lnbmF0dXJlcyAqL1xuXG4gIC8qKiBTZXR1cCBpbnRlZ3JhdGlvbnMgZm9yIHRoaXMgY2xpZW50LiAqL1xuICAgX3NldHVwSW50ZWdyYXRpb25zKCkge1xuICAgIGNvbnN0IHsgaW50ZWdyYXRpb25zIH0gPSB0aGlzLl9vcHRpb25zO1xuICAgIHRoaXMuX2ludGVncmF0aW9ucyA9IGludGVncmF0aW9uLnNldHVwSW50ZWdyYXRpb25zKHRoaXMsIGludGVncmF0aW9ucyk7XG4gICAgaW50ZWdyYXRpb24uYWZ0ZXJTZXR1cEludGVncmF0aW9ucyh0aGlzLCBpbnRlZ3JhdGlvbnMpO1xuICB9XG5cbiAgLyoqIFVwZGF0ZXMgZXhpc3Rpbmcgc2Vzc2lvbiBiYXNlZCBvbiB0aGUgcHJvdmlkZWQgZXZlbnQgKi9cbiAgIF91cGRhdGVTZXNzaW9uRnJvbUV2ZW50KHNlc3Npb24kMSwgZXZlbnQpIHtcbiAgICBsZXQgY3Jhc2hlZCA9IGV2ZW50LmxldmVsID09PSAnZmF0YWwnO1xuICAgIGxldCBlcnJvcmVkID0gZmFsc2U7XG4gICAgY29uc3QgZXhjZXB0aW9ucyA9IGV2ZW50LmV4Y2VwdGlvbj8udmFsdWVzO1xuXG4gICAgaWYgKGV4Y2VwdGlvbnMpIHtcbiAgICAgIGVycm9yZWQgPSB0cnVlO1xuXG4gICAgICBmb3IgKGNvbnN0IGV4IG9mIGV4Y2VwdGlvbnMpIHtcbiAgICAgICAgY29uc3QgbWVjaGFuaXNtID0gZXgubWVjaGFuaXNtO1xuICAgICAgICBpZiAobWVjaGFuaXNtPy5oYW5kbGVkID09PSBmYWxzZSkge1xuICAgICAgICAgIGNyYXNoZWQgPSB0cnVlO1xuICAgICAgICAgIGJyZWFrO1xuICAgICAgICB9XG4gICAgICB9XG4gICAgfVxuXG4gICAgLy8gQSBzZXNzaW9uIGlzIHVwZGF0ZWQgYW5kIHRoYXQgc2Vzc2lvbiB1cGRhdGUgaXMgc2VudCBpbiBvbmx5IG9uZSBvZiB0aGUgdHdvIGZvbGxvd2luZyBzY2VuYXJpb3M6XG4gICAgLy8gMS4gU2Vzc2lvbiB3aXRoIG5vbiB0ZXJtaW5hbCBzdGF0dXMgYW5kIDAgZXJyb3JzICsgYW4gZXJyb3Igb2NjdXJyZWQgLT4gV2lsbCBzZXQgZXJyb3IgY291bnQgdG8gMSBhbmQgc2VuZCB1cGRhdGVcbiAgICAvLyAyLiBTZXNzaW9uIHdpdGggbm9uIHRlcm1pbmFsIHN0YXR1cyBhbmQgMSBlcnJvciArIGEgY3Jhc2ggb2NjdXJyZWQgLT4gV2lsbCBzZXQgc3RhdHVzIGNyYXNoZWQgYW5kIHNlbmQgdXBkYXRlXG4gICAgY29uc3Qgc2Vzc2lvbk5vblRlcm1pbmFsID0gc2Vzc2lvbiQxLnN0YXR1cyA9PT0gJ29rJztcbiAgICBjb25zdCBzaG91bGRVcGRhdGVBbmRTZW5kID0gKHNlc3Npb25Ob25UZXJtaW5hbCAmJiBzZXNzaW9uJDEuZXJyb3JzID09PSAwKSB8fCAoc2Vzc2lvbk5vblRlcm1pbmFsICYmIGNyYXNoZWQpO1xuXG4gICAgaWYgKHNob3VsZFVwZGF0ZUFuZFNlbmQpIHtcbiAgICAgIHNlc3Npb24udXBkYXRlU2Vzc2lvbihzZXNzaW9uJDEsIHtcbiAgICAgICAgLi4uKGNyYXNoZWQgJiYgeyBzdGF0dXM6ICdjcmFzaGVkJyB9KSxcbiAgICAgICAgZXJyb3JzOiBzZXNzaW9uJDEuZXJyb3JzIHx8IE51bWJlcihlcnJvcmVkIHx8IGNyYXNoZWQpLFxuICAgICAgfSk7XG4gICAgICB0aGlzLmNhcHR1cmVTZXNzaW9uKHNlc3Npb24kMSk7XG4gICAgfVxuICB9XG5cbiAgLyoqXG4gICAqIERldGVybWluZSBpZiB0aGUgY2xpZW50IGlzIGZpbmlzaGVkIHByb2Nlc3NpbmcuIFJldHVybnMgYSBwcm9taXNlIGJlY2F1c2UgaXQgd2lsbCB3YWl0IGB0aW1lb3V0YCBtcyBiZWZvcmUgc2F5aW5nXG4gICAqIFwibm9cIiAocmVzb2x2aW5nIHRvIGBmYWxzZWApIGluIG9yZGVyIHRvIGdpdmUgdGhlIGNsaWVudCBhIGNoYW5jZSB0byBwb3RlbnRpYWxseSBmaW5pc2ggZmlyc3QuXG4gICAqXG4gICAqIEBwYXJhbSB0aW1lb3V0IFRoZSB0aW1lLCBpbiBtcywgYWZ0ZXIgd2hpY2ggdG8gcmVzb2x2ZSB0byBgZmFsc2VgIGlmIHRoZSBjbGllbnQgaXMgc3RpbGwgYnVzeS4gUGFzc2luZyBgMGAgKG9yIG5vdFxuICAgKiBwYXNzaW5nIGFueXRoaW5nKSB3aWxsIG1ha2UgdGhlIHByb21pc2Ugd2FpdCBhcyBsb25nIGFzIGl0IHRha2VzIGZvciBwcm9jZXNzaW5nIHRvIGZpbmlzaCBiZWZvcmUgcmVzb2x2aW5nIHRvXG4gICAqIGB0cnVlYC5cbiAgICogQHJldHVybnMgQSBwcm9taXNlIHdoaWNoIHdpbGwgcmVzb2x2ZSB0byBgdHJ1ZWAgaWYgcHJvY2Vzc2luZyBpcyBhbHJlYWR5IGRvbmUgb3IgZmluaXNoZXMgYmVmb3JlIHRoZSB0aW1lb3V0LCBhbmRcbiAgICogYGZhbHNlYCBvdGhlcndpc2VcbiAgICovXG4gICBfaXNDbGllbnREb25lUHJvY2Vzc2luZyh0aW1lb3V0KSB7XG4gICAgcmV0dXJuIG5ldyBzeW5jcHJvbWlzZS5TeW5jUHJvbWlzZShyZXNvbHZlID0+IHtcbiAgICAgIGxldCB0aWNrZWQgPSAwO1xuICAgICAgY29uc3QgdGljayA9IDE7XG5cbiAgICAgIGNvbnN0IGludGVydmFsID0gc2V0SW50ZXJ2YWwoKCkgPT4ge1xuICAgICAgICBpZiAodGhpcy5fbnVtUHJvY2Vzc2luZyA9PSAwKSB7XG4gICAgICAgICAgY2xlYXJJbnRlcnZhbChpbnRlcnZhbCk7XG4gICAgICAgICAgcmVzb2x2ZSh0cnVlKTtcbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICB0aWNrZWQgKz0gdGljaztcbiAgICAgICAgICBpZiAodGltZW91dCAmJiB0aWNrZWQgPj0gdGltZW91dCkge1xuICAgICAgICAgICAgY2xlYXJJbnRlcnZhbChpbnRlcnZhbCk7XG4gICAgICAgICAgICByZXNvbHZlKGZhbHNlKTtcbiAgICAgICAgICB9XG4gICAgICAgIH1cbiAgICAgIH0sIHRpY2spO1xuICAgIH0pO1xuICB9XG5cbiAgLyoqIERldGVybWluZXMgd2hldGhlciB0aGlzIFNESyBpcyBlbmFibGVkIGFuZCBhIHRyYW5zcG9ydCBpcyBwcmVzZW50LiAqL1xuICAgX2lzRW5hYmxlZCgpIHtcbiAgICByZXR1cm4gdGhpcy5nZXRPcHRpb25zKCkuZW5hYmxlZCAhPT0gZmFsc2UgJiYgdGhpcy5fdHJhbnNwb3J0ICE9PSB1bmRlZmluZWQ7XG4gIH1cblxuICAvKipcbiAgICogQWRkcyBjb21tb24gaW5mb3JtYXRpb24gdG8gZXZlbnRzLlxuICAgKlxuICAgKiBUaGUgaW5mb3JtYXRpb24gaW5jbHVkZXMgcmVsZWFzZSBhbmQgZW52aXJvbm1lbnQgZnJvbSBgb3B0aW9uc2AsXG4gICAqIGJyZWFkY3J1bWJzIGFuZCBjb250ZXh0IChleHRyYSwgdGFncyBhbmQgdXNlcikgZnJvbSB0aGUgc2NvcGUuXG4gICAqXG4gICAqIEluZm9ybWF0aW9uIHRoYXQgaXMgYWxyZWFkeSBwcmVzZW50IGluIHRoZSBldmVudCBpcyBuZXZlciBvdmVyd3JpdHRlbi4gRm9yXG4gICAqIG5lc3RlZCBvYmplY3RzLCBzdWNoIGFzIHRoZSBjb250ZXh0LCBrZXlzIGFyZSBtZXJnZWQuXG4gICAqXG4gICAqIEBwYXJhbSBldmVudCBUaGUgb3JpZ2luYWwgZXZlbnQuXG4gICAqIEBwYXJhbSBoaW50IE1heSBjb250YWluIGFkZGl0aW9uYWwgaW5mb3JtYXRpb24gYWJvdXQgdGhlIG9yaWdpbmFsIGV4Y2VwdGlvbi5cbiAgICogQHBhcmFtIGN1cnJlbnRTY29wZSBBIHNjb3BlIGNvbnRhaW5pbmcgZXZlbnQgbWV0YWRhdGEuXG4gICAqIEByZXR1cm5zIEEgbmV3IGV2ZW50IHdpdGggbW9yZSBpbmZvcm1hdGlvbi5cbiAgICovXG4gICBfcHJlcGFyZUV2ZW50KFxuICAgIGV2ZW50LFxuICAgIGhpbnQsXG4gICAgY3VycmVudFNjb3BlLFxuICAgIGlzb2xhdGlvblNjb3BlLFxuICApIHtcbiAgICBjb25zdCBvcHRpb25zID0gdGhpcy5nZXRPcHRpb25zKCk7XG4gICAgY29uc3QgaW50ZWdyYXRpb25zID0gT2JqZWN0LmtleXModGhpcy5faW50ZWdyYXRpb25zKTtcbiAgICBpZiAoIWhpbnQuaW50ZWdyYXRpb25zICYmIGludGVncmF0aW9ucz8ubGVuZ3RoKSB7XG4gICAgICBoaW50LmludGVncmF0aW9ucyA9IGludGVncmF0aW9ucztcbiAgICB9XG5cbiAgICB0aGlzLmVtaXQoJ3ByZXByb2Nlc3NFdmVudCcsIGV2ZW50LCBoaW50KTtcblxuICAgIGlmICghZXZlbnQudHlwZSkge1xuICAgICAgaXNvbGF0aW9uU2NvcGUuc2V0TGFzdEV2ZW50SWQoZXZlbnQuZXZlbnRfaWQgfHwgaGludC5ldmVudF9pZCk7XG4gICAgfVxuXG4gICAgcmV0dXJuIHByZXBhcmVFdmVudC5wcmVwYXJlRXZlbnQob3B0aW9ucywgZXZlbnQsIGhpbnQsIGN1cnJlbnRTY29wZSwgdGhpcywgaXNvbGF0aW9uU2NvcGUpLnRoZW4oZXZ0ID0+IHtcbiAgICAgIGlmIChldnQgPT09IG51bGwpIHtcbiAgICAgICAgcmV0dXJuIGV2dDtcbiAgICAgIH1cblxuICAgICAgdGhpcy5lbWl0KCdwb3N0cHJvY2Vzc0V2ZW50JywgZXZ0LCBoaW50KTtcblxuICAgICAgZXZ0LmNvbnRleHRzID0ge1xuICAgICAgICB0cmFjZTogY3VycmVudFNjb3Blcy5nZXRUcmFjZUNvbnRleHRGcm9tU2NvcGUoY3VycmVudFNjb3BlKSxcbiAgICAgICAgLi4uZXZ0LmNvbnRleHRzLFxuICAgICAgfTtcblxuICAgICAgY29uc3QgZHluYW1pY1NhbXBsaW5nQ29udGV4dCQxID0gZHluYW1pY1NhbXBsaW5nQ29udGV4dC5nZXREeW5hbWljU2FtcGxpbmdDb250ZXh0RnJvbVNjb3BlKHRoaXMsIGN1cnJlbnRTY29wZSk7XG5cbiAgICAgIGV2dC5zZGtQcm9jZXNzaW5nTWV0YWRhdGEgPSB7XG4gICAgICAgIGR5bmFtaWNTYW1wbGluZ0NvbnRleHQ6IGR5bmFtaWNTYW1wbGluZ0NvbnRleHQkMSxcbiAgICAgICAgLi4uZXZ0LnNka1Byb2Nlc3NpbmdNZXRhZGF0YSxcbiAgICAgIH07XG5cbiAgICAgIHJldHVybiBldnQ7XG4gICAgfSk7XG4gIH1cblxuICAvKipcbiAgICogUHJvY2Vzc2VzIHRoZSBldmVudCBhbmQgbG9ncyBhbiBlcnJvciBpbiBjYXNlIG9mIHJlamVjdGlvblxuICAgKiBAcGFyYW0gZXZlbnRcbiAgICogQHBhcmFtIGhpbnRcbiAgICogQHBhcmFtIHNjb3BlXG4gICAqL1xuICAgX2NhcHR1cmVFdmVudChcbiAgICBldmVudCxcbiAgICBoaW50ID0ge30sXG4gICAgY3VycmVudFNjb3BlID0gY3VycmVudFNjb3Blcy5nZXRDdXJyZW50U2NvcGUoKSxcbiAgICBpc29sYXRpb25TY29wZSA9IGN1cnJlbnRTY29wZXMuZ2V0SXNvbGF0aW9uU2NvcGUoKSxcbiAgKSB7XG4gICAgaWYgKGRlYnVnQnVpbGQuREVCVUdfQlVJTEQgJiYgaXNFcnJvckV2ZW50KGV2ZW50KSkge1xuICAgICAgZGVidWdMb2dnZXIuZGVidWcubG9nKGBDYXB0dXJlZCBlcnJvciBldmVudCBcXGAke2V2ZW50VXRpbHMuZ2V0UG9zc2libGVFdmVudE1lc3NhZ2VzKGV2ZW50KVswXSB8fCAnPHVua25vd24+J31cXGBgKTtcbiAgICB9XG5cbiAgICByZXR1cm4gdGhpcy5fcHJvY2Vzc0V2ZW50KGV2ZW50LCBoaW50LCBjdXJyZW50U2NvcGUsIGlzb2xhdGlvblNjb3BlKS50aGVuKFxuICAgICAgZmluYWxFdmVudCA9PiB7XG4gICAgICAgIHJldHVybiBmaW5hbEV2ZW50LmV2ZW50X2lkO1xuICAgICAgfSxcbiAgICAgIHJlYXNvbiA9PiB7XG4gICAgICAgIGlmIChkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEKSB7XG4gICAgICAgICAgaWYgKF9pc0RvTm90U2VuZEV2ZW50RXJyb3IocmVhc29uKSkge1xuICAgICAgICAgICAgZGVidWdMb2dnZXIuZGVidWcubG9nKHJlYXNvbi5tZXNzYWdlKTtcbiAgICAgICAgICB9IGVsc2UgaWYgKF9pc0ludGVybmFsRXJyb3IocmVhc29uKSkge1xuICAgICAgICAgICAgZGVidWdMb2dnZXIuZGVidWcud2FybihyZWFzb24ubWVzc2FnZSk7XG4gICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgIGRlYnVnTG9nZ2VyLmRlYnVnLndhcm4ocmVhc29uKTtcbiAgICAgICAgICB9XG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuIHVuZGVmaW5lZDtcbiAgICAgIH0sXG4gICAgKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBQcm9jZXNzZXMgYW4gZXZlbnQgKGVpdGhlciBlcnJvciBvciBtZXNzYWdlKSBhbmQgc2VuZHMgaXQgdG8gU2VudHJ5LlxuICAgKlxuICAgKiBUaGlzIGFsc28gYWRkcyBicmVhZGNydW1icyBhbmQgY29udGV4dCBpbmZvcm1hdGlvbiB0byB0aGUgZXZlbnQuIEhvd2V2ZXIsXG4gICAqIHBsYXRmb3JtIHNwZWNpZmljIG1ldGEgZGF0YSAoc3VjaCBhcyB0aGUgVXNlcidzIElQIGFkZHJlc3MpIG11c3QgYmUgYWRkZWRcbiAgICogYnkgdGhlIFNESyBpbXBsZW1lbnRvci5cbiAgICpcbiAgICpcbiAgICogQHBhcmFtIGV2ZW50IFRoZSBldmVudCB0byBzZW5kIHRvIFNlbnRyeS5cbiAgICogQHBhcmFtIGhpbnQgTWF5IGNvbnRhaW4gYWRkaXRpb25hbCBpbmZvcm1hdGlvbiBhYm91dCB0aGUgb3JpZ2luYWwgZXhjZXB0aW9uLlxuICAgKiBAcGFyYW0gY3VycmVudFNjb3BlIEEgc2NvcGUgY29udGFpbmluZyBldmVudCBtZXRhZGF0YS5cbiAgICogQHJldHVybnMgQSBTeW5jUHJvbWlzZSB0aGF0IHJlc29sdmVzIHdpdGggdGhlIGV2ZW50IG9yIHJlamVjdHMgaW4gY2FzZSBldmVudCB3YXMvd2lsbCBub3QgYmUgc2VuZC5cbiAgICovXG4gICBfcHJvY2Vzc0V2ZW50KFxuICAgIGV2ZW50LFxuICAgIGhpbnQsXG4gICAgY3VycmVudFNjb3BlLFxuICAgIGlzb2xhdGlvblNjb3BlLFxuICApIHtcbiAgICBjb25zdCBvcHRpb25zID0gdGhpcy5nZXRPcHRpb25zKCk7XG4gICAgY29uc3QgeyBzYW1wbGVSYXRlIH0gPSBvcHRpb25zO1xuXG4gICAgY29uc3QgaXNUcmFuc2FjdGlvbiA9IGlzVHJhbnNhY3Rpb25FdmVudChldmVudCk7XG4gICAgY29uc3QgaXNFcnJvciA9IGlzRXJyb3JFdmVudChldmVudCk7XG4gICAgY29uc3QgZXZlbnRUeXBlID0gZXZlbnQudHlwZSB8fCAnZXJyb3InO1xuICAgIGNvbnN0IGJlZm9yZVNlbmRMYWJlbCA9IGBiZWZvcmUgc2VuZCBmb3IgdHlwZSBcXGAke2V2ZW50VHlwZX1cXGBgO1xuXG4gICAgLy8gMS4wID09PSAxMDAlIGV2ZW50cyBhcmUgc2VudFxuICAgIC8vIDAuMCA9PT0gMCUgZXZlbnRzIGFyZSBzZW50XG4gICAgLy8gU2FtcGxpbmcgZm9yIHRyYW5zYWN0aW9uIGhhcHBlbnMgc29tZXdoZXJlIGVsc2VcbiAgICBjb25zdCBwYXJzZWRTYW1wbGVSYXRlID0gdHlwZW9mIHNhbXBsZVJhdGUgPT09ICd1bmRlZmluZWQnID8gdW5kZWZpbmVkIDogcGFyc2VTYW1wbGVSYXRlLnBhcnNlU2FtcGxlUmF0ZShzYW1wbGVSYXRlKTtcbiAgICBpZiAoaXNFcnJvciAmJiB0eXBlb2YgcGFyc2VkU2FtcGxlUmF0ZSA9PT0gJ251bWJlcicgJiYgTWF0aC5yYW5kb20oKSA+IHBhcnNlZFNhbXBsZVJhdGUpIHtcbiAgICAgIHRoaXMucmVjb3JkRHJvcHBlZEV2ZW50KCdzYW1wbGVfcmF0ZScsICdlcnJvcicpO1xuICAgICAgcmV0dXJuIHN5bmNwcm9taXNlLnJlamVjdGVkU3luY1Byb21pc2UoXG4gICAgICAgIF9tYWtlRG9Ob3RTZW5kRXZlbnRFcnJvcihcbiAgICAgICAgICBgRGlzY2FyZGluZyBldmVudCBiZWNhdXNlIGl0J3Mgbm90IGluY2x1ZGVkIGluIHRoZSByYW5kb20gc2FtcGxlIChzYW1wbGluZyByYXRlID0gJHtzYW1wbGVSYXRlfSlgLFxuICAgICAgICApLFxuICAgICAgKTtcbiAgICB9XG5cbiAgICBjb25zdCBkYXRhQ2F0ZWdvcnkgPSAoZXZlbnRUeXBlID09PSAncmVwbGF5X2V2ZW50JyA/ICdyZXBsYXknIDogZXZlbnRUeXBlKSA7XG5cbiAgICByZXR1cm4gdGhpcy5fcHJlcGFyZUV2ZW50KGV2ZW50LCBoaW50LCBjdXJyZW50U2NvcGUsIGlzb2xhdGlvblNjb3BlKVxuICAgICAgLnRoZW4ocHJlcGFyZWQgPT4ge1xuICAgICAgICBpZiAocHJlcGFyZWQgPT09IG51bGwpIHtcbiAgICAgICAgICB0aGlzLnJlY29yZERyb3BwZWRFdmVudCgnZXZlbnRfcHJvY2Vzc29yJywgZGF0YUNhdGVnb3J5KTtcbiAgICAgICAgICB0aHJvdyBfbWFrZURvTm90U2VuZEV2ZW50RXJyb3IoJ0FuIGV2ZW50IHByb2Nlc3NvciByZXR1cm5lZCBgbnVsbGAsIHdpbGwgbm90IHNlbmQgZXZlbnQuJyk7XG4gICAgICAgIH1cblxuICAgICAgICBjb25zdCBpc0ludGVybmFsRXhjZXB0aW9uID0gaGludC5kYXRhICYmIChoaW50LmRhdGEgKS5fX3NlbnRyeV9fID09PSB0cnVlO1xuICAgICAgICBpZiAoaXNJbnRlcm5hbEV4Y2VwdGlvbikge1xuICAgICAgICAgIHJldHVybiBwcmVwYXJlZDtcbiAgICAgICAgfVxuXG4gICAgICAgIGNvbnN0IHJlc3VsdCA9IHByb2Nlc3NCZWZvcmVTZW5kKHRoaXMsIG9wdGlvbnMsIHByZXBhcmVkLCBoaW50KTtcbiAgICAgICAgcmV0dXJuIF92YWxpZGF0ZUJlZm9yZVNlbmRSZXN1bHQocmVzdWx0LCBiZWZvcmVTZW5kTGFiZWwpO1xuICAgICAgfSlcbiAgICAgIC50aGVuKHByb2Nlc3NlZEV2ZW50ID0+IHtcbiAgICAgICAgaWYgKHByb2Nlc3NlZEV2ZW50ID09PSBudWxsKSB7XG4gICAgICAgICAgdGhpcy5yZWNvcmREcm9wcGVkRXZlbnQoJ2JlZm9yZV9zZW5kJywgZGF0YUNhdGVnb3J5KTtcbiAgICAgICAgICBpZiAoaXNUcmFuc2FjdGlvbikge1xuICAgICAgICAgICAgY29uc3Qgc3BhbnMgPSBldmVudC5zcGFucyB8fCBbXTtcbiAgICAgICAgICAgIC8vIHRoZSB0cmFuc2FjdGlvbiBpdHNlbGYgY291bnRzIGFzIG9uZSBzcGFuLCBwbHVzIGFsbCB0aGUgY2hpbGQgc3BhbnMgdGhhdCBhcmUgYWRkZWRcbiAgICAgICAgICAgIGNvbnN0IHNwYW5Db3VudCA9IDEgKyBzcGFucy5sZW5ndGg7XG4gICAgICAgICAgICB0aGlzLnJlY29yZERyb3BwZWRFdmVudCgnYmVmb3JlX3NlbmQnLCAnc3BhbicsIHNwYW5Db3VudCk7XG4gICAgICAgICAgfVxuICAgICAgICAgIHRocm93IF9tYWtlRG9Ob3RTZW5kRXZlbnRFcnJvcihgJHtiZWZvcmVTZW5kTGFiZWx9IHJldHVybmVkIFxcYG51bGxcXGAsIHdpbGwgbm90IHNlbmQgZXZlbnQuYCk7XG4gICAgICAgIH1cblxuICAgICAgICBjb25zdCBzZXNzaW9uID0gY3VycmVudFNjb3BlLmdldFNlc3Npb24oKSB8fCBpc29sYXRpb25TY29wZS5nZXRTZXNzaW9uKCk7XG4gICAgICAgIGlmIChpc0Vycm9yICYmIHNlc3Npb24pIHtcbiAgICAgICAgICB0aGlzLl91cGRhdGVTZXNzaW9uRnJvbUV2ZW50KHNlc3Npb24sIHByb2Nlc3NlZEV2ZW50KTtcbiAgICAgICAgfVxuXG4gICAgICAgIGlmIChpc1RyYW5zYWN0aW9uKSB7XG4gICAgICAgICAgY29uc3Qgc3BhbkNvdW50QmVmb3JlID0gcHJvY2Vzc2VkRXZlbnQuc2RrUHJvY2Vzc2luZ01ldGFkYXRhPy5zcGFuQ291bnRCZWZvcmVQcm9jZXNzaW5nIHx8IDA7XG4gICAgICAgICAgY29uc3Qgc3BhbkNvdW50QWZ0ZXIgPSBwcm9jZXNzZWRFdmVudC5zcGFucyA/IHByb2Nlc3NlZEV2ZW50LnNwYW5zLmxlbmd0aCA6IDA7XG5cbiAgICAgICAgICBjb25zdCBkcm9wcGVkU3BhbkNvdW50ID0gc3BhbkNvdW50QmVmb3JlIC0gc3BhbkNvdW50QWZ0ZXI7XG4gICAgICAgICAgaWYgKGRyb3BwZWRTcGFuQ291bnQgPiAwKSB7XG4gICAgICAgICAgICB0aGlzLnJlY29yZERyb3BwZWRFdmVudCgnYmVmb3JlX3NlbmQnLCAnc3BhbicsIGRyb3BwZWRTcGFuQ291bnQpO1xuICAgICAgICAgIH1cbiAgICAgICAgfVxuXG4gICAgICAgIC8vIE5vbmUgb2YgdGhlIFNlbnRyeSBidWlsdCBldmVudCBwcm9jZXNzb3Igd2lsbCB1cGRhdGUgdHJhbnNhY3Rpb24gbmFtZSxcbiAgICAgICAgLy8gc28gaWYgdGhlIHRyYW5zYWN0aW9uIG5hbWUgaGFzIGJlZW4gY2hhbmdlZCBieSBhbiBldmVudCBwcm9jZXNzb3IsIHdlIGtub3dcbiAgICAgICAgLy8gaXQgaGFzIHRvIGNvbWUgZnJvbSBjdXN0b20gZXZlbnQgcHJvY2Vzc29yIGFkZGVkIGJ5IGEgdXNlclxuICAgICAgICBjb25zdCB0cmFuc2FjdGlvbkluZm8gPSBwcm9jZXNzZWRFdmVudC50cmFuc2FjdGlvbl9pbmZvO1xuICAgICAgICBpZiAoaXNUcmFuc2FjdGlvbiAmJiB0cmFuc2FjdGlvbkluZm8gJiYgcHJvY2Vzc2VkRXZlbnQudHJhbnNhY3Rpb24gIT09IGV2ZW50LnRyYW5zYWN0aW9uKSB7XG4gICAgICAgICAgY29uc3Qgc291cmNlID0gJ2N1c3RvbSc7XG4gICAgICAgICAgcHJvY2Vzc2VkRXZlbnQudHJhbnNhY3Rpb25faW5mbyA9IHtcbiAgICAgICAgICAgIC4uLnRyYW5zYWN0aW9uSW5mbyxcbiAgICAgICAgICAgIHNvdXJjZSxcbiAgICAgICAgICB9O1xuICAgICAgICB9XG5cbiAgICAgICAgdGhpcy5zZW5kRXZlbnQocHJvY2Vzc2VkRXZlbnQsIGhpbnQpO1xuICAgICAgICByZXR1cm4gcHJvY2Vzc2VkRXZlbnQ7XG4gICAgICB9KVxuICAgICAgLnRoZW4obnVsbCwgcmVhc29uID0+IHtcbiAgICAgICAgaWYgKF9pc0RvTm90U2VuZEV2ZW50RXJyb3IocmVhc29uKSB8fCBfaXNJbnRlcm5hbEVycm9yKHJlYXNvbikpIHtcbiAgICAgICAgICB0aHJvdyByZWFzb247XG4gICAgICAgIH1cblxuICAgICAgICB0aGlzLmNhcHR1cmVFeGNlcHRpb24ocmVhc29uLCB7XG4gICAgICAgICAgZGF0YToge1xuICAgICAgICAgICAgX19zZW50cnlfXzogdHJ1ZSxcbiAgICAgICAgICB9LFxuICAgICAgICAgIG9yaWdpbmFsRXhjZXB0aW9uOiByZWFzb24sXG4gICAgICAgIH0pO1xuICAgICAgICB0aHJvdyBfbWFrZUludGVybmFsRXJyb3IoXG4gICAgICAgICAgYEV2ZW50IHByb2Nlc3NpbmcgcGlwZWxpbmUgdGhyZXcgYW4gZXJyb3IsIG9yaWdpbmFsIGV2ZW50IHdpbGwgbm90IGJlIHNlbnQuIERldGFpbHMgaGF2ZSBiZWVuIHNlbnQgYXMgYSBuZXcgZXZlbnQuXFxuUmVhc29uOiAke3JlYXNvbn1gLFxuICAgICAgICApO1xuICAgICAgfSk7XG4gIH1cblxuICAvKipcbiAgICogT2NjdXBpZXMgdGhlIGNsaWVudCB3aXRoIHByb2Nlc3NpbmcgYW5kIGV2ZW50XG4gICAqL1xuICAgX3Byb2Nlc3MocHJvbWlzZSkge1xuICAgIHRoaXMuX251bVByb2Nlc3NpbmcrKztcbiAgICB2b2lkIHByb21pc2UudGhlbihcbiAgICAgIHZhbHVlID0+IHtcbiAgICAgICAgdGhpcy5fbnVtUHJvY2Vzc2luZy0tO1xuICAgICAgICByZXR1cm4gdmFsdWU7XG4gICAgICB9LFxuICAgICAgcmVhc29uID0+IHtcbiAgICAgICAgdGhpcy5fbnVtUHJvY2Vzc2luZy0tO1xuICAgICAgICByZXR1cm4gcmVhc29uO1xuICAgICAgfSxcbiAgICApO1xuICB9XG5cbiAgLyoqXG4gICAqIENsZWFycyBvdXRjb21lcyBvbiB0aGlzIGNsaWVudCBhbmQgcmV0dXJucyB0aGVtLlxuICAgKi9cbiAgIF9jbGVhck91dGNvbWVzKCkge1xuICAgIGNvbnN0IG91dGNvbWVzID0gdGhpcy5fb3V0Y29tZXM7XG4gICAgdGhpcy5fb3V0Y29tZXMgPSB7fTtcbiAgICByZXR1cm4gT2JqZWN0LmVudHJpZXMob3V0Y29tZXMpLm1hcCgoW2tleSwgcXVhbnRpdHldKSA9PiB7XG4gICAgICBjb25zdCBbcmVhc29uLCBjYXRlZ29yeV0gPSBrZXkuc3BsaXQoJzonKSA7XG4gICAgICByZXR1cm4ge1xuICAgICAgICByZWFzb24sXG4gICAgICAgIGNhdGVnb3J5LFxuICAgICAgICBxdWFudGl0eSxcbiAgICAgIH07XG4gICAgfSk7XG4gIH1cblxuICAvKipcbiAgICogU2VuZHMgY2xpZW50IHJlcG9ydHMgYXMgYW4gZW52ZWxvcGUuXG4gICAqL1xuICAgX2ZsdXNoT3V0Y29tZXMoKSB7XG4gICAgZGVidWdCdWlsZC5ERUJVR19CVUlMRCAmJiBkZWJ1Z0xvZ2dlci5kZWJ1Zy5sb2coJ0ZsdXNoaW5nIG91dGNvbWVzLi4uJyk7XG5cbiAgICBjb25zdCBvdXRjb21lcyA9IHRoaXMuX2NsZWFyT3V0Y29tZXMoKTtcblxuICAgIGlmIChvdXRjb21lcy5sZW5ndGggPT09IDApIHtcbiAgICAgIGRlYnVnQnVpbGQuREVCVUdfQlVJTEQgJiYgZGVidWdMb2dnZXIuZGVidWcubG9nKCdObyBvdXRjb21lcyB0byBzZW5kJyk7XG4gICAgICByZXR1cm47XG4gICAgfVxuXG4gICAgLy8gVGhpcyBpcyByZWFsbHkgdGhlIG9ubHkgcGxhY2Ugd2hlcmUgd2Ugd2FudCB0byBjaGVjayBmb3IgYSBEU04gYW5kIG9ubHkgc2VuZCBvdXRjb21lcyB0aGVuXG4gICAgaWYgKCF0aGlzLl9kc24pIHtcbiAgICAgIGRlYnVnQnVpbGQuREVCVUdfQlVJTEQgJiYgZGVidWdMb2dnZXIuZGVidWcubG9nKCdObyBkc24gcHJvdmlkZWQsIHdpbGwgbm90IHNlbmQgb3V0Y29tZXMnKTtcbiAgICAgIHJldHVybjtcbiAgICB9XG5cbiAgICBkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEICYmIGRlYnVnTG9nZ2VyLmRlYnVnLmxvZygnU2VuZGluZyBvdXRjb21lczonLCBvdXRjb21lcyk7XG5cbiAgICBjb25zdCBlbnZlbG9wZSA9IGNsaWVudHJlcG9ydC5jcmVhdGVDbGllbnRSZXBvcnRFbnZlbG9wZShvdXRjb21lcywgdGhpcy5fb3B0aW9ucy50dW5uZWwgJiYgZHNuLmRzblRvU3RyaW5nKHRoaXMuX2RzbikpO1xuXG4gICAgLy8gc2VuZEVudmVsb3BlIHNob3VsZCBub3QgdGhyb3dcbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25vLWZsb2F0aW5nLXByb21pc2VzXG4gICAgdGhpcy5zZW5kRW52ZWxvcGUoZW52ZWxvcGUpO1xuICB9XG5cbiAgLyoqXG4gICAqIENyZWF0ZXMgYW4ge0BsaW5rIEV2ZW50fSBmcm9tIGFsbCBpbnB1dHMgdG8gYGNhcHR1cmVFeGNlcHRpb25gIGFuZCBub24tcHJpbWl0aXZlIGlucHV0cyB0byBgY2FwdHVyZU1lc3NhZ2VgLlxuICAgKi9cblxufVxuXG4vKipcbiAqIEBkZXByZWNhdGVkIFVzZSBgQ2xpZW50YCBpbnN0ZWFkLiBUaGlzIGFsaWFzIG1heSBiZSByZW1vdmVkIGluIGEgZnV0dXJlIG1ham9yIHZlcnNpb24uXG4gKi9cbi8vIFRPRE8odjEwKTogUmVtb3ZlXG5cbi8qKlxuICogQGRlcHJlY2F0ZWQgVXNlIGBDbGllbnRgIGluc3RlYWQuIFRoaXMgYWxpYXMgbWF5IGJlIHJlbW92ZWQgaW4gYSBmdXR1cmUgbWFqb3IgdmVyc2lvbi5cbiAqL1xuLy8gVE9ETyh2MTApOiBSZW1vdmVcbmNvbnN0IEJhc2VDbGllbnQgPSBDbGllbnQ7XG5cbi8qKlxuICogVmVyaWZpZXMgdGhhdCByZXR1cm4gdmFsdWUgb2YgY29uZmlndXJlZCBgYmVmb3JlU2VuZGAgb3IgYGJlZm9yZVNlbmRUcmFuc2FjdGlvbmAgaXMgb2YgZXhwZWN0ZWQgdHlwZSwgYW5kIHJldHVybnMgdGhlIHZhbHVlIGlmIHNvLlxuICovXG5mdW5jdGlvbiBfdmFsaWRhdGVCZWZvcmVTZW5kUmVzdWx0KFxuICBiZWZvcmVTZW5kUmVzdWx0LFxuICBiZWZvcmVTZW5kTGFiZWwsXG4pIHtcbiAgY29uc3QgaW52YWxpZFZhbHVlRXJyb3IgPSBgJHtiZWZvcmVTZW5kTGFiZWx9IG11c3QgcmV0dXJuIFxcYG51bGxcXGAgb3IgYSB2YWxpZCBldmVudC5gO1xuICBpZiAoaXMuaXNUaGVuYWJsZShiZWZvcmVTZW5kUmVzdWx0KSkge1xuICAgIHJldHVybiBiZWZvcmVTZW5kUmVzdWx0LnRoZW4oXG4gICAgICBldmVudCA9PiB7XG4gICAgICAgIGlmICghaXMuaXNQbGFpbk9iamVjdChldmVudCkgJiYgZXZlbnQgIT09IG51bGwpIHtcbiAgICAgICAgICB0aHJvdyBfbWFrZUludGVybmFsRXJyb3IoaW52YWxpZFZhbHVlRXJyb3IpO1xuICAgICAgICB9XG4gICAgICAgIHJldHVybiBldmVudDtcbiAgICAgIH0sXG4gICAgICBlID0+IHtcbiAgICAgICAgdGhyb3cgX21ha2VJbnRlcm5hbEVycm9yKGAke2JlZm9yZVNlbmRMYWJlbH0gcmVqZWN0ZWQgd2l0aCAke2V9YCk7XG4gICAgICB9LFxuICAgICk7XG4gIH0gZWxzZSBpZiAoIWlzLmlzUGxhaW5PYmplY3QoYmVmb3JlU2VuZFJlc3VsdCkgJiYgYmVmb3JlU2VuZFJlc3VsdCAhPT0gbnVsbCkge1xuICAgIHRocm93IF9tYWtlSW50ZXJuYWxFcnJvcihpbnZhbGlkVmFsdWVFcnJvcik7XG4gIH1cbiAgcmV0dXJuIGJlZm9yZVNlbmRSZXN1bHQ7XG59XG5cbi8qKlxuICogUHJvY2VzcyB0aGUgbWF0Y2hpbmcgYGJlZm9yZVNlbmRYWFhgIGNhbGxiYWNrLlxuICovXG5mdW5jdGlvbiBwcm9jZXNzQmVmb3JlU2VuZChcbiAgY2xpZW50LFxuICBvcHRpb25zLFxuICBldmVudCxcbiAgaGludCxcbikge1xuICBjb25zdCB7IGJlZm9yZVNlbmQsIGJlZm9yZVNlbmRUcmFuc2FjdGlvbiwgYmVmb3JlU2VuZFNwYW4gfSA9IG9wdGlvbnM7XG4gIGxldCBwcm9jZXNzZWRFdmVudCA9IGV2ZW50O1xuXG4gIGlmIChpc0Vycm9yRXZlbnQocHJvY2Vzc2VkRXZlbnQpICYmIGJlZm9yZVNlbmQpIHtcbiAgICByZXR1cm4gYmVmb3JlU2VuZChwcm9jZXNzZWRFdmVudCwgaGludCk7XG4gIH1cblxuICBpZiAoaXNUcmFuc2FjdGlvbkV2ZW50KHByb2Nlc3NlZEV2ZW50KSkge1xuICAgIGlmIChiZWZvcmVTZW5kU3Bhbikge1xuICAgICAgLy8gcHJvY2VzcyByb290IHNwYW5cbiAgICAgIGNvbnN0IHByb2Nlc3NlZFJvb3RTcGFuSnNvbiA9IGJlZm9yZVNlbmRTcGFuKHRyYW5zYWN0aW9uRXZlbnQuY29udmVydFRyYW5zYWN0aW9uRXZlbnRUb1NwYW5Kc29uKHByb2Nlc3NlZEV2ZW50KSk7XG4gICAgICBpZiAoIXByb2Nlc3NlZFJvb3RTcGFuSnNvbikge1xuICAgICAgICBzcGFuVXRpbHMuc2hvd1NwYW5Ecm9wV2FybmluZygpO1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgLy8gdXBkYXRlIGV2ZW50IHdpdGggcHJvY2Vzc2VkIHJvb3Qgc3BhbiB2YWx1ZXNcbiAgICAgICAgcHJvY2Vzc2VkRXZlbnQgPSBtZXJnZS5tZXJnZShldmVudCwgdHJhbnNhY3Rpb25FdmVudC5jb252ZXJ0U3Bhbkpzb25Ub1RyYW5zYWN0aW9uRXZlbnQocHJvY2Vzc2VkUm9vdFNwYW5Kc29uKSk7XG4gICAgICB9XG5cbiAgICAgIC8vIHByb2Nlc3MgY2hpbGQgc3BhbnNcbiAgICAgIGlmIChwcm9jZXNzZWRFdmVudC5zcGFucykge1xuICAgICAgICBjb25zdCBwcm9jZXNzZWRTcGFucyA9IFtdO1xuICAgICAgICBmb3IgKGNvbnN0IHNwYW4gb2YgcHJvY2Vzc2VkRXZlbnQuc3BhbnMpIHtcbiAgICAgICAgICBjb25zdCBwcm9jZXNzZWRTcGFuID0gYmVmb3JlU2VuZFNwYW4oc3Bhbik7XG4gICAgICAgICAgaWYgKCFwcm9jZXNzZWRTcGFuKSB7XG4gICAgICAgICAgICBzcGFuVXRpbHMuc2hvd1NwYW5Ecm9wV2FybmluZygpO1xuICAgICAgICAgICAgcHJvY2Vzc2VkU3BhbnMucHVzaChzcGFuKTtcbiAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgcHJvY2Vzc2VkU3BhbnMucHVzaChwcm9jZXNzZWRTcGFuKTtcbiAgICAgICAgICB9XG4gICAgICAgIH1cbiAgICAgICAgcHJvY2Vzc2VkRXZlbnQuc3BhbnMgPSBwcm9jZXNzZWRTcGFucztcbiAgICAgIH1cbiAgICB9XG5cbiAgICBpZiAoYmVmb3JlU2VuZFRyYW5zYWN0aW9uKSB7XG4gICAgICBpZiAocHJvY2Vzc2VkRXZlbnQuc3BhbnMpIHtcbiAgICAgICAgLy8gV2Ugc3RvcmUgdGhlICMgb2Ygc3BhbnMgYmVmb3JlIHByb2Nlc3NpbmcgaW4gU0RLIG1ldGFkYXRhLFxuICAgICAgICAvLyBzbyB3ZSBjYW4gY29tcGFyZSBpdCBhZnRlcndhcmRzIHRvIGRldGVybWluZSBob3cgbWFueSBzcGFucyB3ZXJlIGRyb3BwZWRcbiAgICAgICAgY29uc3Qgc3BhbkNvdW50QmVmb3JlID0gcHJvY2Vzc2VkRXZlbnQuc3BhbnMubGVuZ3RoO1xuICAgICAgICBwcm9jZXNzZWRFdmVudC5zZGtQcm9jZXNzaW5nTWV0YWRhdGEgPSB7XG4gICAgICAgICAgLi4uZXZlbnQuc2RrUHJvY2Vzc2luZ01ldGFkYXRhLFxuICAgICAgICAgIHNwYW5Db3VudEJlZm9yZVByb2Nlc3Npbmc6IHNwYW5Db3VudEJlZm9yZSxcbiAgICAgICAgfTtcbiAgICAgIH1cbiAgICAgIHJldHVybiBiZWZvcmVTZW5kVHJhbnNhY3Rpb24ocHJvY2Vzc2VkRXZlbnQgLCBoaW50KTtcbiAgICB9XG4gIH1cblxuICByZXR1cm4gcHJvY2Vzc2VkRXZlbnQ7XG59XG5cbmZ1bmN0aW9uIGlzRXJyb3JFdmVudChldmVudCkge1xuICByZXR1cm4gZXZlbnQudHlwZSA9PT0gdW5kZWZpbmVkO1xufVxuXG5mdW5jdGlvbiBpc1RyYW5zYWN0aW9uRXZlbnQoZXZlbnQpIHtcbiAgcmV0dXJuIGV2ZW50LnR5cGUgPT09ICd0cmFuc2FjdGlvbic7XG59XG5cbi8qKiBFeHRyYWN0IHRyYWNlIGluZm9ybWF0aW9uIGZyb20gc2NvcGUgKi9cbmZ1bmN0aW9uIF9nZXRUcmFjZUluZm9Gcm9tU2NvcGUoXG4gIGNsaWVudCxcbiAgc2NvcGUsXG4pIHtcbiAgaWYgKCFzY29wZSkge1xuICAgIHJldHVybiBbdW5kZWZpbmVkLCB1bmRlZmluZWRdO1xuICB9XG5cbiAgcmV0dXJuIGN1cnJlbnRTY29wZXMud2l0aFNjb3BlKHNjb3BlLCAoKSA9PiB7XG4gICAgY29uc3Qgc3BhbiA9IHNwYW5VdGlscy5nZXRBY3RpdmVTcGFuKCk7XG4gICAgY29uc3QgdHJhY2VDb250ZXh0ID0gc3BhbiA/IHNwYW5VdGlscy5zcGFuVG9UcmFjZUNvbnRleHQoc3BhbikgOiBjdXJyZW50U2NvcGVzLmdldFRyYWNlQ29udGV4dEZyb21TY29wZShzY29wZSk7XG4gICAgY29uc3QgZHluYW1pY1NhbXBsaW5nQ29udGV4dCQxID0gc3BhblxuICAgICAgPyBkeW5hbWljU2FtcGxpbmdDb250ZXh0LmdldER5bmFtaWNTYW1wbGluZ0NvbnRleHRGcm9tU3BhbihzcGFuKVxuICAgICAgOiBkeW5hbWljU2FtcGxpbmdDb250ZXh0LmdldER5bmFtaWNTYW1wbGluZ0NvbnRleHRGcm9tU2NvcGUoY2xpZW50LCBzY29wZSk7XG4gICAgcmV0dXJuIFtkeW5hbWljU2FtcGxpbmdDb250ZXh0JDEsIHRyYWNlQ29udGV4dF07XG4gIH0pO1xufVxuXG5leHBvcnRzLkJhc2VDbGllbnQgPSBCYXNlQ2xpZW50O1xuZXhwb3J0cy5DbGllbnQgPSBDbGllbnQ7XG5leHBvcnRzLl9nZXRUcmFjZUluZm9Gcm9tU2NvcGUgPSBfZ2V0VHJhY2VJbmZvRnJvbVNjb3BlO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9Y2xpZW50LmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/client.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/constants.js":
/*!*************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/constants.js ***!
  \*************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst DEFAULT_ENVIRONMENT = 'production';\n\nexports.DEFAULT_ENVIRONMENT = DEFAULT_ENVIRONMENT;\n//# sourceMappingURL=constants.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvY29uc3RhbnRzLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFOztBQUVBLDJCQUEyQjtBQUMzQiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL2NvbnN0YW50cy5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgREVGQVVMVF9FTlZJUk9OTUVOVCA9ICdwcm9kdWN0aW9uJztcblxuZXhwb3J0cy5ERUZBVUxUX0VOVklST05NRU5UID0gREVGQVVMVF9FTlZJUk9OTUVOVDtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWNvbnN0YW50cy5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/constants.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js":
/*!*****************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js ***!
  \*****************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst index = __webpack_require__(/*! ./asyncContext/index.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/asyncContext/index.js\");\nconst carrier = __webpack_require__(/*! ./carrier.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/carrier.js\");\nconst scope = __webpack_require__(/*! ./scope.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/scope.js\");\nconst propagationContext = __webpack_require__(/*! ./utils/propagationContext.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/propagationContext.js\");\n\n/**\n * Get the currently active scope.\n */\nfunction getCurrentScope() {\n  const carrier$1 = carrier.getMainCarrier();\n  const acs = index.getAsyncContextStrategy(carrier$1);\n  return acs.getCurrentScope();\n}\n\n/**\n * Get the currently active isolation scope.\n * The isolation scope is active for the current execution context.\n */\nfunction getIsolationScope() {\n  const carrier$1 = carrier.getMainCarrier();\n  const acs = index.getAsyncContextStrategy(carrier$1);\n  return acs.getIsolationScope();\n}\n\n/**\n * Get the global scope.\n * This scope is applied to _all_ events.\n */\nfunction getGlobalScope() {\n  return carrier.getGlobalSingleton('globalScope', () => new scope.Scope());\n}\n\n/**\n * Creates a new scope with and executes the given operation within.\n * The scope is automatically removed once the operation\n * finishes or throws.\n */\n\n/**\n * Either creates a new active scope, or sets the given scope as active scope in the given callback.\n */\nfunction withScope(\n  ...rest\n) {\n  const carrier$1 = carrier.getMainCarrier();\n  const acs = index.getAsyncContextStrategy(carrier$1);\n\n  // If a scope is defined, we want to make this the active scope instead of the default one\n  if (rest.length === 2) {\n    const [scope, callback] = rest;\n\n    if (!scope) {\n      return acs.withScope(callback);\n    }\n\n    return acs.withSetScope(scope, callback);\n  }\n\n  return acs.withScope(rest[0]);\n}\n\n/**\n * Attempts to fork the current isolation scope and the current scope based on the current async context strategy. If no\n * async context strategy is set, the isolation scope and the current scope will not be forked (this is currently the\n * case, for example, in the browser).\n *\n * Usage of this function in environments without async context strategy is discouraged and may lead to unexpected behaviour.\n *\n * This function is intended for Sentry SDK and SDK integration development. It is not recommended to be used in \"normal\"\n * applications directly because it comes with pitfalls. Use at your own risk!\n */\n\n/**\n * Either creates a new active isolation scope, or sets the given isolation scope as active scope in the given callback.\n */\nfunction withIsolationScope(\n  ...rest\n\n) {\n  const carrier$1 = carrier.getMainCarrier();\n  const acs = index.getAsyncContextStrategy(carrier$1);\n\n  // If a scope is defined, we want to make this the active scope instead of the default one\n  if (rest.length === 2) {\n    const [isolationScope, callback] = rest;\n\n    if (!isolationScope) {\n      return acs.withIsolationScope(callback);\n    }\n\n    return acs.withSetIsolationScope(isolationScope, callback);\n  }\n\n  return acs.withIsolationScope(rest[0]);\n}\n\n/**\n * Get the currently active client.\n */\nfunction getClient() {\n  return getCurrentScope().getClient();\n}\n\n/**\n * Get a trace context for the given scope.\n */\nfunction getTraceContextFromScope(scope) {\n  const propagationContext$1 = scope.getPropagationContext();\n\n  const { traceId, parentSpanId, propagationSpanId } = propagationContext$1;\n\n  const traceContext = {\n    trace_id: traceId,\n    span_id: propagationSpanId || propagationContext.generateSpanId(),\n  };\n\n  if (parentSpanId) {\n    traceContext.parent_span_id = parentSpanId;\n  }\n\n  return traceContext;\n}\n\nexports.getClient = getClient;\nexports.getCurrentScope = getCurrentScope;\nexports.getGlobalScope = getGlobalScope;\nexports.getIsolationScope = getIsolationScope;\nexports.getTraceContextFromScope = getTraceContextFromScope;\nexports.withIsolationScope = withIsolationScope;\nexports.withScope = withScope;\n//# sourceMappingURL=currentScopes.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvY3VycmVudFNjb3Blcy5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxjQUFjLG1CQUFPLENBQUMsZ0pBQXlCO0FBQy9DLGdCQUFnQixtQkFBTyxDQUFDLDBIQUFjO0FBQ3RDLGNBQWMsbUJBQU8sQ0FBQyxzSEFBWTtBQUNsQywyQkFBMkIsbUJBQU8sQ0FBQyw0SkFBK0I7O0FBRWxFO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSxVQUFVLDJDQUEyQzs7QUFFckQ7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUEsaUJBQWlCO0FBQ2pCLHVCQUF1QjtBQUN2QixzQkFBc0I7QUFDdEIseUJBQXlCO0FBQ3pCLGdDQUFnQztBQUNoQywwQkFBMEI7QUFDMUIsaUJBQWlCO0FBQ2pCIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvY3VycmVudFNjb3Blcy5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgaW5kZXggPSByZXF1aXJlKCcuL2FzeW5jQ29udGV4dC9pbmRleC5qcycpO1xuY29uc3QgY2FycmllciA9IHJlcXVpcmUoJy4vY2Fycmllci5qcycpO1xuY29uc3Qgc2NvcGUgPSByZXF1aXJlKCcuL3Njb3BlLmpzJyk7XG5jb25zdCBwcm9wYWdhdGlvbkNvbnRleHQgPSByZXF1aXJlKCcuL3V0aWxzL3Byb3BhZ2F0aW9uQ29udGV4dC5qcycpO1xuXG4vKipcbiAqIEdldCB0aGUgY3VycmVudGx5IGFjdGl2ZSBzY29wZS5cbiAqL1xuZnVuY3Rpb24gZ2V0Q3VycmVudFNjb3BlKCkge1xuICBjb25zdCBjYXJyaWVyJDEgPSBjYXJyaWVyLmdldE1haW5DYXJyaWVyKCk7XG4gIGNvbnN0IGFjcyA9IGluZGV4LmdldEFzeW5jQ29udGV4dFN0cmF0ZWd5KGNhcnJpZXIkMSk7XG4gIHJldHVybiBhY3MuZ2V0Q3VycmVudFNjb3BlKCk7XG59XG5cbi8qKlxuICogR2V0IHRoZSBjdXJyZW50bHkgYWN0aXZlIGlzb2xhdGlvbiBzY29wZS5cbiAqIFRoZSBpc29sYXRpb24gc2NvcGUgaXMgYWN0aXZlIGZvciB0aGUgY3VycmVudCBleGVjdXRpb24gY29udGV4dC5cbiAqL1xuZnVuY3Rpb24gZ2V0SXNvbGF0aW9uU2NvcGUoKSB7XG4gIGNvbnN0IGNhcnJpZXIkMSA9IGNhcnJpZXIuZ2V0TWFpbkNhcnJpZXIoKTtcbiAgY29uc3QgYWNzID0gaW5kZXguZ2V0QXN5bmNDb250ZXh0U3RyYXRlZ3koY2FycmllciQxKTtcbiAgcmV0dXJuIGFjcy5nZXRJc29sYXRpb25TY29wZSgpO1xufVxuXG4vKipcbiAqIEdldCB0aGUgZ2xvYmFsIHNjb3BlLlxuICogVGhpcyBzY29wZSBpcyBhcHBsaWVkIHRvIF9hbGxfIGV2ZW50cy5cbiAqL1xuZnVuY3Rpb24gZ2V0R2xvYmFsU2NvcGUoKSB7XG4gIHJldHVybiBjYXJyaWVyLmdldEdsb2JhbFNpbmdsZXRvbignZ2xvYmFsU2NvcGUnLCAoKSA9PiBuZXcgc2NvcGUuU2NvcGUoKSk7XG59XG5cbi8qKlxuICogQ3JlYXRlcyBhIG5ldyBzY29wZSB3aXRoIGFuZCBleGVjdXRlcyB0aGUgZ2l2ZW4gb3BlcmF0aW9uIHdpdGhpbi5cbiAqIFRoZSBzY29wZSBpcyBhdXRvbWF0aWNhbGx5IHJlbW92ZWQgb25jZSB0aGUgb3BlcmF0aW9uXG4gKiBmaW5pc2hlcyBvciB0aHJvd3MuXG4gKi9cblxuLyoqXG4gKiBFaXRoZXIgY3JlYXRlcyBhIG5ldyBhY3RpdmUgc2NvcGUsIG9yIHNldHMgdGhlIGdpdmVuIHNjb3BlIGFzIGFjdGl2ZSBzY29wZSBpbiB0aGUgZ2l2ZW4gY2FsbGJhY2suXG4gKi9cbmZ1bmN0aW9uIHdpdGhTY29wZShcbiAgLi4ucmVzdFxuKSB7XG4gIGNvbnN0IGNhcnJpZXIkMSA9IGNhcnJpZXIuZ2V0TWFpbkNhcnJpZXIoKTtcbiAgY29uc3QgYWNzID0gaW5kZXguZ2V0QXN5bmNDb250ZXh0U3RyYXRlZ3koY2FycmllciQxKTtcblxuICAvLyBJZiBhIHNjb3BlIGlzIGRlZmluZWQsIHdlIHdhbnQgdG8gbWFrZSB0aGlzIHRoZSBhY3RpdmUgc2NvcGUgaW5zdGVhZCBvZiB0aGUgZGVmYXVsdCBvbmVcbiAgaWYgKHJlc3QubGVuZ3RoID09PSAyKSB7XG4gICAgY29uc3QgW3Njb3BlLCBjYWxsYmFja10gPSByZXN0O1xuXG4gICAgaWYgKCFzY29wZSkge1xuICAgICAgcmV0dXJuIGFjcy53aXRoU2NvcGUoY2FsbGJhY2spO1xuICAgIH1cblxuICAgIHJldHVybiBhY3Mud2l0aFNldFNjb3BlKHNjb3BlLCBjYWxsYmFjayk7XG4gIH1cblxuICByZXR1cm4gYWNzLndpdGhTY29wZShyZXN0WzBdKTtcbn1cblxuLyoqXG4gKiBBdHRlbXB0cyB0byBmb3JrIHRoZSBjdXJyZW50IGlzb2xhdGlvbiBzY29wZSBhbmQgdGhlIGN1cnJlbnQgc2NvcGUgYmFzZWQgb24gdGhlIGN1cnJlbnQgYXN5bmMgY29udGV4dCBzdHJhdGVneS4gSWYgbm9cbiAqIGFzeW5jIGNvbnRleHQgc3RyYXRlZ3kgaXMgc2V0LCB0aGUgaXNvbGF0aW9uIHNjb3BlIGFuZCB0aGUgY3VycmVudCBzY29wZSB3aWxsIG5vdCBiZSBmb3JrZWQgKHRoaXMgaXMgY3VycmVudGx5IHRoZVxuICogY2FzZSwgZm9yIGV4YW1wbGUsIGluIHRoZSBicm93c2VyKS5cbiAqXG4gKiBVc2FnZSBvZiB0aGlzIGZ1bmN0aW9uIGluIGVudmlyb25tZW50cyB3aXRob3V0IGFzeW5jIGNvbnRleHQgc3RyYXRlZ3kgaXMgZGlzY291cmFnZWQgYW5kIG1heSBsZWFkIHRvIHVuZXhwZWN0ZWQgYmVoYXZpb3VyLlxuICpcbiAqIFRoaXMgZnVuY3Rpb24gaXMgaW50ZW5kZWQgZm9yIFNlbnRyeSBTREsgYW5kIFNESyBpbnRlZ3JhdGlvbiBkZXZlbG9wbWVudC4gSXQgaXMgbm90IHJlY29tbWVuZGVkIHRvIGJlIHVzZWQgaW4gXCJub3JtYWxcIlxuICogYXBwbGljYXRpb25zIGRpcmVjdGx5IGJlY2F1c2UgaXQgY29tZXMgd2l0aCBwaXRmYWxscy4gVXNlIGF0IHlvdXIgb3duIHJpc2shXG4gKi9cblxuLyoqXG4gKiBFaXRoZXIgY3JlYXRlcyBhIG5ldyBhY3RpdmUgaXNvbGF0aW9uIHNjb3BlLCBvciBzZXRzIHRoZSBnaXZlbiBpc29sYXRpb24gc2NvcGUgYXMgYWN0aXZlIHNjb3BlIGluIHRoZSBnaXZlbiBjYWxsYmFjay5cbiAqL1xuZnVuY3Rpb24gd2l0aElzb2xhdGlvblNjb3BlKFxuICAuLi5yZXN0XG5cbikge1xuICBjb25zdCBjYXJyaWVyJDEgPSBjYXJyaWVyLmdldE1haW5DYXJyaWVyKCk7XG4gIGNvbnN0IGFjcyA9IGluZGV4LmdldEFzeW5jQ29udGV4dFN0cmF0ZWd5KGNhcnJpZXIkMSk7XG5cbiAgLy8gSWYgYSBzY29wZSBpcyBkZWZpbmVkLCB3ZSB3YW50IHRvIG1ha2UgdGhpcyB0aGUgYWN0aXZlIHNjb3BlIGluc3RlYWQgb2YgdGhlIGRlZmF1bHQgb25lXG4gIGlmIChyZXN0Lmxlbmd0aCA9PT0gMikge1xuICAgIGNvbnN0IFtpc29sYXRpb25TY29wZSwgY2FsbGJhY2tdID0gcmVzdDtcblxuICAgIGlmICghaXNvbGF0aW9uU2NvcGUpIHtcbiAgICAgIHJldHVybiBhY3Mud2l0aElzb2xhdGlvblNjb3BlKGNhbGxiYWNrKTtcbiAgICB9XG5cbiAgICByZXR1cm4gYWNzLndpdGhTZXRJc29sYXRpb25TY29wZShpc29sYXRpb25TY29wZSwgY2FsbGJhY2spO1xuICB9XG5cbiAgcmV0dXJuIGFjcy53aXRoSXNvbGF0aW9uU2NvcGUocmVzdFswXSk7XG59XG5cbi8qKlxuICogR2V0IHRoZSBjdXJyZW50bHkgYWN0aXZlIGNsaWVudC5cbiAqL1xuZnVuY3Rpb24gZ2V0Q2xpZW50KCkge1xuICByZXR1cm4gZ2V0Q3VycmVudFNjb3BlKCkuZ2V0Q2xpZW50KCk7XG59XG5cbi8qKlxuICogR2V0IGEgdHJhY2UgY29udGV4dCBmb3IgdGhlIGdpdmVuIHNjb3BlLlxuICovXG5mdW5jdGlvbiBnZXRUcmFjZUNvbnRleHRGcm9tU2NvcGUoc2NvcGUpIHtcbiAgY29uc3QgcHJvcGFnYXRpb25Db250ZXh0JDEgPSBzY29wZS5nZXRQcm9wYWdhdGlvbkNvbnRleHQoKTtcblxuICBjb25zdCB7IHRyYWNlSWQsIHBhcmVudFNwYW5JZCwgcHJvcGFnYXRpb25TcGFuSWQgfSA9IHByb3BhZ2F0aW9uQ29udGV4dCQxO1xuXG4gIGNvbnN0IHRyYWNlQ29udGV4dCA9IHtcbiAgICB0cmFjZV9pZDogdHJhY2VJZCxcbiAgICBzcGFuX2lkOiBwcm9wYWdhdGlvblNwYW5JZCB8fCBwcm9wYWdhdGlvbkNvbnRleHQuZ2VuZXJhdGVTcGFuSWQoKSxcbiAgfTtcblxuICBpZiAocGFyZW50U3BhbklkKSB7XG4gICAgdHJhY2VDb250ZXh0LnBhcmVudF9zcGFuX2lkID0gcGFyZW50U3BhbklkO1xuICB9XG5cbiAgcmV0dXJuIHRyYWNlQ29udGV4dDtcbn1cblxuZXhwb3J0cy5nZXRDbGllbnQgPSBnZXRDbGllbnQ7XG5leHBvcnRzLmdldEN1cnJlbnRTY29wZSA9IGdldEN1cnJlbnRTY29wZTtcbmV4cG9ydHMuZ2V0R2xvYmFsU2NvcGUgPSBnZXRHbG9iYWxTY29wZTtcbmV4cG9ydHMuZ2V0SXNvbGF0aW9uU2NvcGUgPSBnZXRJc29sYXRpb25TY29wZTtcbmV4cG9ydHMuZ2V0VHJhY2VDb250ZXh0RnJvbVNjb3BlID0gZ2V0VHJhY2VDb250ZXh0RnJvbVNjb3BlO1xuZXhwb3J0cy53aXRoSXNvbGF0aW9uU2NvcGUgPSB3aXRoSXNvbGF0aW9uU2NvcGU7XG5leHBvcnRzLndpdGhTY29wZSA9IHdpdGhTY29wZTtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWN1cnJlbnRTY29wZXMuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js":
/*!***************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js ***!
  \***************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n/**\n * This serves as a build time flag that will be true by default, but false in non-debug builds or if users replace `__SENTRY_DEBUG__` in their generated code.\n *\n * ATTENTION: This constant must never cross package boundaries (i.e. be exported) to guarantee that it can be used for tree shaking.\n */\nconst DEBUG_BUILD = ( false || false);\n\nexports.DEBUG_BUILD = DEBUG_BUILD;\n//# sourceMappingURL=debug-build.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvZGVidWctYnVpbGQuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEU7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLHFCQUFxQixNQUF1QyxJQUFJLEtBQWdCOztBQUVoRixtQkFBbUI7QUFDbkIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9kZWJ1Zy1idWlsZC5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuLyoqXG4gKiBUaGlzIHNlcnZlcyBhcyBhIGJ1aWxkIHRpbWUgZmxhZyB0aGF0IHdpbGwgYmUgdHJ1ZSBieSBkZWZhdWx0LCBidXQgZmFsc2UgaW4gbm9uLWRlYnVnIGJ1aWxkcyBvciBpZiB1c2VycyByZXBsYWNlIGBfX1NFTlRSWV9ERUJVR19fYCBpbiB0aGVpciBnZW5lcmF0ZWQgY29kZS5cbiAqXG4gKiBBVFRFTlRJT046IFRoaXMgY29uc3RhbnQgbXVzdCBuZXZlciBjcm9zcyBwYWNrYWdlIGJvdW5kYXJpZXMgKGkuZS4gYmUgZXhwb3J0ZWQpIHRvIGd1YXJhbnRlZSB0aGF0IGl0IGNhbiBiZSB1c2VkIGZvciB0cmVlIHNoYWtpbmcuXG4gKi9cbmNvbnN0IERFQlVHX0JVSUxEID0gKHR5cGVvZiBfX1NFTlRSWV9ERUJVR19fID09PSAndW5kZWZpbmVkJyB8fCBfX1NFTlRSWV9ERUJVR19fKTtcblxuZXhwb3J0cy5ERUJVR19CVUlMRCA9IERFQlVHX0JVSUxEO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9ZGVidWctYnVpbGQuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/defaultScopes.js":
/*!*****************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/defaultScopes.js ***!
  \*****************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst carrier = __webpack_require__(/*! ./carrier.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/carrier.js\");\nconst scope = __webpack_require__(/*! ./scope.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/scope.js\");\n\n/** Get the default current scope. */\nfunction getDefaultCurrentScope() {\n  return carrier.getGlobalSingleton('defaultCurrentScope', () => new scope.Scope());\n}\n\n/** Get the default isolation scope. */\nfunction getDefaultIsolationScope() {\n  return carrier.getGlobalSingleton('defaultIsolationScope', () => new scope.Scope());\n}\n\nexports.getDefaultCurrentScope = getDefaultCurrentScope;\nexports.getDefaultIsolationScope = getDefaultIsolationScope;\n//# sourceMappingURL=defaultScopes.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvZGVmYXVsdFNjb3Blcy5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxnQkFBZ0IsbUJBQU8sQ0FBQywwSEFBYztBQUN0QyxjQUFjLG1CQUFPLENBQUMsc0hBQVk7O0FBRWxDO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLDhCQUE4QjtBQUM5QixnQ0FBZ0M7QUFDaEMiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9kZWZhdWx0U2NvcGVzLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBjYXJyaWVyID0gcmVxdWlyZSgnLi9jYXJyaWVyLmpzJyk7XG5jb25zdCBzY29wZSA9IHJlcXVpcmUoJy4vc2NvcGUuanMnKTtcblxuLyoqIEdldCB0aGUgZGVmYXVsdCBjdXJyZW50IHNjb3BlLiAqL1xuZnVuY3Rpb24gZ2V0RGVmYXVsdEN1cnJlbnRTY29wZSgpIHtcbiAgcmV0dXJuIGNhcnJpZXIuZ2V0R2xvYmFsU2luZ2xldG9uKCdkZWZhdWx0Q3VycmVudFNjb3BlJywgKCkgPT4gbmV3IHNjb3BlLlNjb3BlKCkpO1xufVxuXG4vKiogR2V0IHRoZSBkZWZhdWx0IGlzb2xhdGlvbiBzY29wZS4gKi9cbmZ1bmN0aW9uIGdldERlZmF1bHRJc29sYXRpb25TY29wZSgpIHtcbiAgcmV0dXJuIGNhcnJpZXIuZ2V0R2xvYmFsU2luZ2xldG9uKCdkZWZhdWx0SXNvbGF0aW9uU2NvcGUnLCAoKSA9PiBuZXcgc2NvcGUuU2NvcGUoKSk7XG59XG5cbmV4cG9ydHMuZ2V0RGVmYXVsdEN1cnJlbnRTY29wZSA9IGdldERlZmF1bHRDdXJyZW50U2NvcGU7XG5leHBvcnRzLmdldERlZmF1bHRJc29sYXRpb25TY29wZSA9IGdldERlZmF1bHRJc29sYXRpb25TY29wZTtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWRlZmF1bHRTY29wZXMuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/defaultScopes.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/envelope.js":
/*!************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/envelope.js ***!
  \************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst dynamicSamplingContext = __webpack_require__(/*! ./tracing/dynamicSamplingContext.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/dynamicSamplingContext.js\");\nconst dsn = __webpack_require__(/*! ./utils/dsn.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/dsn.js\");\nconst envelope = __webpack_require__(/*! ./utils/envelope.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/envelope.js\");\nconst spanUtils = __webpack_require__(/*! ./utils/spanUtils.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanUtils.js\");\n\n/**\n * Apply SdkInfo (name, version, packages, integrations) to the corresponding event key.\n * Merge with existing data if any.\n **/\nfunction enhanceEventWithSdkInfo(event, sdkInfo) {\n  if (!sdkInfo) {\n    return event;\n  }\n  event.sdk = event.sdk || {};\n  event.sdk.name = event.sdk.name || sdkInfo.name;\n  event.sdk.version = event.sdk.version || sdkInfo.version;\n  event.sdk.integrations = [...(event.sdk.integrations || []), ...(sdkInfo.integrations || [])];\n  event.sdk.packages = [...(event.sdk.packages || []), ...(sdkInfo.packages || [])];\n  return event;\n}\n\n/** Creates an envelope from a Session */\nfunction createSessionEnvelope(\n  session,\n  dsn$1,\n  metadata,\n  tunnel,\n) {\n  const sdkInfo = envelope.getSdkMetadataForEnvelopeHeader(metadata);\n  const envelopeHeaders = {\n    sent_at: new Date().toISOString(),\n    ...(sdkInfo && { sdk: sdkInfo }),\n    ...(!!tunnel && dsn$1 && { dsn: dsn.dsnToString(dsn$1) }),\n  };\n\n  const envelopeItem =\n    'aggregates' in session ? [{ type: 'sessions' }, session] : [{ type: 'session' }, session.toJSON()];\n\n  return envelope.createEnvelope(envelopeHeaders, [envelopeItem]);\n}\n\n/**\n * Create an Envelope from an event.\n */\nfunction createEventEnvelope(\n  event,\n  dsn,\n  metadata,\n  tunnel,\n) {\n  const sdkInfo = envelope.getSdkMetadataForEnvelopeHeader(metadata);\n\n  /*\n    Note: Due to TS, event.type may be `replay_event`, theoretically.\n    In practice, we never call `createEventEnvelope` with `replay_event` type,\n    and we'd have to adjust a looot of types to make this work properly.\n    We want to avoid casting this around, as that could lead to bugs (e.g. when we add another type)\n    So the safe choice is to really guard against the replay_event type here.\n  */\n  const eventType = event.type && event.type !== 'replay_event' ? event.type : 'event';\n\n  enhanceEventWithSdkInfo(event, metadata?.sdk);\n\n  const envelopeHeaders = envelope.createEventEnvelopeHeaders(event, sdkInfo, tunnel, dsn);\n\n  // Prevent this data (which, if it exists, was used in earlier steps in the processing pipeline) from being sent to\n  // sentry. (Note: Our use of this property comes and goes with whatever we might be debugging, whatever hacks we may\n  // have temporarily added, etc. Even if we don't happen to be using it at some point in the future, let's not get rid\n  // of this `delete`, lest we miss putting it back in the next time the property is in use.)\n  delete event.sdkProcessingMetadata;\n\n  const eventItem = [{ type: eventType }, event];\n  return envelope.createEnvelope(envelopeHeaders, [eventItem]);\n}\n\n/**\n * Create envelope from Span item.\n *\n * Takes an optional client and runs spans through `beforeSendSpan` if available.\n */\nfunction createSpanEnvelope(spans, client) {\n  function dscHasRequiredProps(dsc) {\n    return !!dsc.trace_id && !!dsc.public_key;\n  }\n\n  // For the moment we'll obtain the DSC from the first span in the array\n  // This might need to be changed if we permit sending multiple spans from\n  // different segments in one envelope\n  const dsc = dynamicSamplingContext.getDynamicSamplingContextFromSpan(spans[0]);\n\n  const dsn$1 = client?.getDsn();\n  const tunnel = client?.getOptions().tunnel;\n\n  const headers = {\n    sent_at: new Date().toISOString(),\n    ...(dscHasRequiredProps(dsc) && { trace: dsc }),\n    ...(!!tunnel && dsn$1 && { dsn: dsn.dsnToString(dsn$1) }),\n  };\n\n  const beforeSendSpan = client?.getOptions().beforeSendSpan;\n  const convertToSpanJSON = beforeSendSpan\n    ? (span) => {\n        const spanJson = spanUtils.spanToJSON(span);\n        const processedSpan = beforeSendSpan(spanJson);\n\n        if (!processedSpan) {\n          spanUtils.showSpanDropWarning();\n          return spanJson;\n        }\n\n        return processedSpan;\n      }\n    : spanUtils.spanToJSON;\n\n  const items = [];\n  for (const span of spans) {\n    const spanJson = convertToSpanJSON(span);\n    if (spanJson) {\n      items.push(envelope.createSpanEnvelopeItem(spanJson));\n    }\n  }\n\n  return envelope.createEnvelope(headers, items);\n}\n\nexports.createEventEnvelope = createEventEnvelope;\nexports.createSessionEnvelope = createSessionEnvelope;\nexports.createSpanEnvelope = createSpanEnvelope;\n//# sourceMappingURL=envelope.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvZW52ZWxvcGUuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsK0JBQStCLG1CQUFPLENBQUMsd0tBQXFDO0FBQzVFLFlBQVksbUJBQU8sQ0FBQyw4SEFBZ0I7QUFDcEMsaUJBQWlCLG1CQUFPLENBQUMsd0lBQXFCO0FBQzlDLGtCQUFrQixtQkFBTyxDQUFDLDBJQUFzQjs7QUFFaEQ7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EscUJBQXFCLGNBQWM7QUFDbkMsK0JBQStCLDZCQUE2QjtBQUM1RDs7QUFFQTtBQUNBLGlDQUFpQyxrQkFBa0IsZ0JBQWdCLGlCQUFpQjs7QUFFcEY7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsdUJBQXVCLGlCQUFpQjtBQUN4QztBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQSxzQ0FBc0MsWUFBWTtBQUNsRCwrQkFBK0IsNkJBQTZCO0FBQzVEOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUEsMkJBQTJCO0FBQzNCLDZCQUE2QjtBQUM3QiwwQkFBMEI7QUFDMUIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9lbnZlbG9wZS5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgZHluYW1pY1NhbXBsaW5nQ29udGV4dCA9IHJlcXVpcmUoJy4vdHJhY2luZy9keW5hbWljU2FtcGxpbmdDb250ZXh0LmpzJyk7XG5jb25zdCBkc24gPSByZXF1aXJlKCcuL3V0aWxzL2Rzbi5qcycpO1xuY29uc3QgZW52ZWxvcGUgPSByZXF1aXJlKCcuL3V0aWxzL2VudmVsb3BlLmpzJyk7XG5jb25zdCBzcGFuVXRpbHMgPSByZXF1aXJlKCcuL3V0aWxzL3NwYW5VdGlscy5qcycpO1xuXG4vKipcbiAqIEFwcGx5IFNka0luZm8gKG5hbWUsIHZlcnNpb24sIHBhY2thZ2VzLCBpbnRlZ3JhdGlvbnMpIHRvIHRoZSBjb3JyZXNwb25kaW5nIGV2ZW50IGtleS5cbiAqIE1lcmdlIHdpdGggZXhpc3RpbmcgZGF0YSBpZiBhbnkuXG4gKiovXG5mdW5jdGlvbiBlbmhhbmNlRXZlbnRXaXRoU2RrSW5mbyhldmVudCwgc2RrSW5mbykge1xuICBpZiAoIXNka0luZm8pIHtcbiAgICByZXR1cm4gZXZlbnQ7XG4gIH1cbiAgZXZlbnQuc2RrID0gZXZlbnQuc2RrIHx8IHt9O1xuICBldmVudC5zZGsubmFtZSA9IGV2ZW50LnNkay5uYW1lIHx8IHNka0luZm8ubmFtZTtcbiAgZXZlbnQuc2RrLnZlcnNpb24gPSBldmVudC5zZGsudmVyc2lvbiB8fCBzZGtJbmZvLnZlcnNpb247XG4gIGV2ZW50LnNkay5pbnRlZ3JhdGlvbnMgPSBbLi4uKGV2ZW50LnNkay5pbnRlZ3JhdGlvbnMgfHwgW10pLCAuLi4oc2RrSW5mby5pbnRlZ3JhdGlvbnMgfHwgW10pXTtcbiAgZXZlbnQuc2RrLnBhY2thZ2VzID0gWy4uLihldmVudC5zZGsucGFja2FnZXMgfHwgW10pLCAuLi4oc2RrSW5mby5wYWNrYWdlcyB8fCBbXSldO1xuICByZXR1cm4gZXZlbnQ7XG59XG5cbi8qKiBDcmVhdGVzIGFuIGVudmVsb3BlIGZyb20gYSBTZXNzaW9uICovXG5mdW5jdGlvbiBjcmVhdGVTZXNzaW9uRW52ZWxvcGUoXG4gIHNlc3Npb24sXG4gIGRzbiQxLFxuICBtZXRhZGF0YSxcbiAgdHVubmVsLFxuKSB7XG4gIGNvbnN0IHNka0luZm8gPSBlbnZlbG9wZS5nZXRTZGtNZXRhZGF0YUZvckVudmVsb3BlSGVhZGVyKG1ldGFkYXRhKTtcbiAgY29uc3QgZW52ZWxvcGVIZWFkZXJzID0ge1xuICAgIHNlbnRfYXQ6IG5ldyBEYXRlKCkudG9JU09TdHJpbmcoKSxcbiAgICAuLi4oc2RrSW5mbyAmJiB7IHNkazogc2RrSW5mbyB9KSxcbiAgICAuLi4oISF0dW5uZWwgJiYgZHNuJDEgJiYgeyBkc246IGRzbi5kc25Ub1N0cmluZyhkc24kMSkgfSksXG4gIH07XG5cbiAgY29uc3QgZW52ZWxvcGVJdGVtID1cbiAgICAnYWdncmVnYXRlcycgaW4gc2Vzc2lvbiA/IFt7IHR5cGU6ICdzZXNzaW9ucycgfSwgc2Vzc2lvbl0gOiBbeyB0eXBlOiAnc2Vzc2lvbicgfSwgc2Vzc2lvbi50b0pTT04oKV07XG5cbiAgcmV0dXJuIGVudmVsb3BlLmNyZWF0ZUVudmVsb3BlKGVudmVsb3BlSGVhZGVycywgW2VudmVsb3BlSXRlbV0pO1xufVxuXG4vKipcbiAqIENyZWF0ZSBhbiBFbnZlbG9wZSBmcm9tIGFuIGV2ZW50LlxuICovXG5mdW5jdGlvbiBjcmVhdGVFdmVudEVudmVsb3BlKFxuICBldmVudCxcbiAgZHNuLFxuICBtZXRhZGF0YSxcbiAgdHVubmVsLFxuKSB7XG4gIGNvbnN0IHNka0luZm8gPSBlbnZlbG9wZS5nZXRTZGtNZXRhZGF0YUZvckVudmVsb3BlSGVhZGVyKG1ldGFkYXRhKTtcblxuICAvKlxuICAgIE5vdGU6IER1ZSB0byBUUywgZXZlbnQudHlwZSBtYXkgYmUgYHJlcGxheV9ldmVudGAsIHRoZW9yZXRpY2FsbHkuXG4gICAgSW4gcHJhY3RpY2UsIHdlIG5ldmVyIGNhbGwgYGNyZWF0ZUV2ZW50RW52ZWxvcGVgIHdpdGggYHJlcGxheV9ldmVudGAgdHlwZSxcbiAgICBhbmQgd2UnZCBoYXZlIHRvIGFkanVzdCBhIGxvb290IG9mIHR5cGVzIHRvIG1ha2UgdGhpcyB3b3JrIHByb3Blcmx5LlxuICAgIFdlIHdhbnQgdG8gYXZvaWQgY2FzdGluZyB0aGlzIGFyb3VuZCwgYXMgdGhhdCBjb3VsZCBsZWFkIHRvIGJ1Z3MgKGUuZy4gd2hlbiB3ZSBhZGQgYW5vdGhlciB0eXBlKVxuICAgIFNvIHRoZSBzYWZlIGNob2ljZSBpcyB0byByZWFsbHkgZ3VhcmQgYWdhaW5zdCB0aGUgcmVwbGF5X2V2ZW50IHR5cGUgaGVyZS5cbiAgKi9cbiAgY29uc3QgZXZlbnRUeXBlID0gZXZlbnQudHlwZSAmJiBldmVudC50eXBlICE9PSAncmVwbGF5X2V2ZW50JyA/IGV2ZW50LnR5cGUgOiAnZXZlbnQnO1xuXG4gIGVuaGFuY2VFdmVudFdpdGhTZGtJbmZvKGV2ZW50LCBtZXRhZGF0YT8uc2RrKTtcblxuICBjb25zdCBlbnZlbG9wZUhlYWRlcnMgPSBlbnZlbG9wZS5jcmVhdGVFdmVudEVudmVsb3BlSGVhZGVycyhldmVudCwgc2RrSW5mbywgdHVubmVsLCBkc24pO1xuXG4gIC8vIFByZXZlbnQgdGhpcyBkYXRhICh3aGljaCwgaWYgaXQgZXhpc3RzLCB3YXMgdXNlZCBpbiBlYXJsaWVyIHN0ZXBzIGluIHRoZSBwcm9jZXNzaW5nIHBpcGVsaW5lKSBmcm9tIGJlaW5nIHNlbnQgdG9cbiAgLy8gc2VudHJ5LiAoTm90ZTogT3VyIHVzZSBvZiB0aGlzIHByb3BlcnR5IGNvbWVzIGFuZCBnb2VzIHdpdGggd2hhdGV2ZXIgd2UgbWlnaHQgYmUgZGVidWdnaW5nLCB3aGF0ZXZlciBoYWNrcyB3ZSBtYXlcbiAgLy8gaGF2ZSB0ZW1wb3JhcmlseSBhZGRlZCwgZXRjLiBFdmVuIGlmIHdlIGRvbid0IGhhcHBlbiB0byBiZSB1c2luZyBpdCBhdCBzb21lIHBvaW50IGluIHRoZSBmdXR1cmUsIGxldCdzIG5vdCBnZXQgcmlkXG4gIC8vIG9mIHRoaXMgYGRlbGV0ZWAsIGxlc3Qgd2UgbWlzcyBwdXR0aW5nIGl0IGJhY2sgaW4gdGhlIG5leHQgdGltZSB0aGUgcHJvcGVydHkgaXMgaW4gdXNlLilcbiAgZGVsZXRlIGV2ZW50LnNka1Byb2Nlc3NpbmdNZXRhZGF0YTtcblxuICBjb25zdCBldmVudEl0ZW0gPSBbeyB0eXBlOiBldmVudFR5cGUgfSwgZXZlbnRdO1xuICByZXR1cm4gZW52ZWxvcGUuY3JlYXRlRW52ZWxvcGUoZW52ZWxvcGVIZWFkZXJzLCBbZXZlbnRJdGVtXSk7XG59XG5cbi8qKlxuICogQ3JlYXRlIGVudmVsb3BlIGZyb20gU3BhbiBpdGVtLlxuICpcbiAqIFRha2VzIGFuIG9wdGlvbmFsIGNsaWVudCBhbmQgcnVucyBzcGFucyB0aHJvdWdoIGBiZWZvcmVTZW5kU3BhbmAgaWYgYXZhaWxhYmxlLlxuICovXG5mdW5jdGlvbiBjcmVhdGVTcGFuRW52ZWxvcGUoc3BhbnMsIGNsaWVudCkge1xuICBmdW5jdGlvbiBkc2NIYXNSZXF1aXJlZFByb3BzKGRzYykge1xuICAgIHJldHVybiAhIWRzYy50cmFjZV9pZCAmJiAhIWRzYy5wdWJsaWNfa2V5O1xuICB9XG5cbiAgLy8gRm9yIHRoZSBtb21lbnQgd2UnbGwgb2J0YWluIHRoZSBEU0MgZnJvbSB0aGUgZmlyc3Qgc3BhbiBpbiB0aGUgYXJyYXlcbiAgLy8gVGhpcyBtaWdodCBuZWVkIHRvIGJlIGNoYW5nZWQgaWYgd2UgcGVybWl0IHNlbmRpbmcgbXVsdGlwbGUgc3BhbnMgZnJvbVxuICAvLyBkaWZmZXJlbnQgc2VnbWVudHMgaW4gb25lIGVudmVsb3BlXG4gIGNvbnN0IGRzYyA9IGR5bmFtaWNTYW1wbGluZ0NvbnRleHQuZ2V0RHluYW1pY1NhbXBsaW5nQ29udGV4dEZyb21TcGFuKHNwYW5zWzBdKTtcblxuICBjb25zdCBkc24kMSA9IGNsaWVudD8uZ2V0RHNuKCk7XG4gIGNvbnN0IHR1bm5lbCA9IGNsaWVudD8uZ2V0T3B0aW9ucygpLnR1bm5lbDtcblxuICBjb25zdCBoZWFkZXJzID0ge1xuICAgIHNlbnRfYXQ6IG5ldyBEYXRlKCkudG9JU09TdHJpbmcoKSxcbiAgICAuLi4oZHNjSGFzUmVxdWlyZWRQcm9wcyhkc2MpICYmIHsgdHJhY2U6IGRzYyB9KSxcbiAgICAuLi4oISF0dW5uZWwgJiYgZHNuJDEgJiYgeyBkc246IGRzbi5kc25Ub1N0cmluZyhkc24kMSkgfSksXG4gIH07XG5cbiAgY29uc3QgYmVmb3JlU2VuZFNwYW4gPSBjbGllbnQ/LmdldE9wdGlvbnMoKS5iZWZvcmVTZW5kU3BhbjtcbiAgY29uc3QgY29udmVydFRvU3BhbkpTT04gPSBiZWZvcmVTZW5kU3BhblxuICAgID8gKHNwYW4pID0+IHtcbiAgICAgICAgY29uc3Qgc3Bhbkpzb24gPSBzcGFuVXRpbHMuc3BhblRvSlNPTihzcGFuKTtcbiAgICAgICAgY29uc3QgcHJvY2Vzc2VkU3BhbiA9IGJlZm9yZVNlbmRTcGFuKHNwYW5Kc29uKTtcblxuICAgICAgICBpZiAoIXByb2Nlc3NlZFNwYW4pIHtcbiAgICAgICAgICBzcGFuVXRpbHMuc2hvd1NwYW5Ecm9wV2FybmluZygpO1xuICAgICAgICAgIHJldHVybiBzcGFuSnNvbjtcbiAgICAgICAgfVxuXG4gICAgICAgIHJldHVybiBwcm9jZXNzZWRTcGFuO1xuICAgICAgfVxuICAgIDogc3BhblV0aWxzLnNwYW5Ub0pTT047XG5cbiAgY29uc3QgaXRlbXMgPSBbXTtcbiAgZm9yIChjb25zdCBzcGFuIG9mIHNwYW5zKSB7XG4gICAgY29uc3Qgc3Bhbkpzb24gPSBjb252ZXJ0VG9TcGFuSlNPTihzcGFuKTtcbiAgICBpZiAoc3Bhbkpzb24pIHtcbiAgICAgIGl0ZW1zLnB1c2goZW52ZWxvcGUuY3JlYXRlU3BhbkVudmVsb3BlSXRlbShzcGFuSnNvbikpO1xuICAgIH1cbiAgfVxuXG4gIHJldHVybiBlbnZlbG9wZS5jcmVhdGVFbnZlbG9wZShoZWFkZXJzLCBpdGVtcyk7XG59XG5cbmV4cG9ydHMuY3JlYXRlRXZlbnRFbnZlbG9wZSA9IGNyZWF0ZUV2ZW50RW52ZWxvcGU7XG5leHBvcnRzLmNyZWF0ZVNlc3Npb25FbnZlbG9wZSA9IGNyZWF0ZVNlc3Npb25FbnZlbG9wZTtcbmV4cG9ydHMuY3JlYXRlU3BhbkVudmVsb3BlID0gY3JlYXRlU3BhbkVudmVsb3BlO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9ZW52ZWxvcGUuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/envelope.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/eventProcessors.js":
/*!*******************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/eventProcessors.js ***!
  \*******************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst debugBuild = __webpack_require__(/*! ./debug-build.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst debugLogger = __webpack_require__(/*! ./utils/debug-logger.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst is = __webpack_require__(/*! ./utils/is.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js\");\nconst syncpromise = __webpack_require__(/*! ./utils/syncpromise.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/syncpromise.js\");\n\n/**\n * Process an array of event processors, returning the processed event (or `null` if the event was dropped).\n */\nfunction notifyEventProcessors(\n  processors,\n  event,\n  hint,\n  index = 0,\n) {\n  return new syncpromise.SyncPromise((resolve, reject) => {\n    const processor = processors[index];\n    if (event === null || typeof processor !== 'function') {\n      resolve(event);\n    } else {\n      const result = processor({ ...event }, hint) ;\n\n      debugBuild.DEBUG_BUILD && processor.id && result === null && debugLogger.debug.log(`Event processor \"${processor.id}\" dropped event`);\n\n      if (is.isThenable(result)) {\n        void result\n          .then(final => notifyEventProcessors(processors, final, hint, index + 1).then(resolve))\n          .then(null, reject);\n      } else {\n        void notifyEventProcessors(processors, result, hint, index + 1)\n          .then(resolve)\n          .then(null, reject);\n      }\n    }\n  });\n}\n\nexports.notifyEventProcessors = notifyEventProcessors;\n//# sourceMappingURL=eventProcessors.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvZXZlbnRQcm9jZXNzb3JzLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLG1CQUFtQixtQkFBTyxDQUFDLGtJQUFrQjtBQUM3QyxvQkFBb0IsbUJBQU8sQ0FBQyxnSkFBeUI7QUFDckQsV0FBVyxtQkFBTyxDQUFDLDRIQUFlO0FBQ2xDLG9CQUFvQixtQkFBTyxDQUFDLDhJQUF3Qjs7QUFFcEQ7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxNQUFNO0FBQ04saUNBQWlDLFVBQVU7O0FBRTNDLDZHQUE2RyxhQUFhOztBQUUxSDtBQUNBO0FBQ0E7QUFDQTtBQUNBLFFBQVE7QUFDUjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsR0FBRztBQUNIOztBQUVBLDZCQUE2QjtBQUM3QiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL2V2ZW50UHJvY2Vzc29ycy5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgZGVidWdCdWlsZCA9IHJlcXVpcmUoJy4vZGVidWctYnVpbGQuanMnKTtcbmNvbnN0IGRlYnVnTG9nZ2VyID0gcmVxdWlyZSgnLi91dGlscy9kZWJ1Zy1sb2dnZXIuanMnKTtcbmNvbnN0IGlzID0gcmVxdWlyZSgnLi91dGlscy9pcy5qcycpO1xuY29uc3Qgc3luY3Byb21pc2UgPSByZXF1aXJlKCcuL3V0aWxzL3N5bmNwcm9taXNlLmpzJyk7XG5cbi8qKlxuICogUHJvY2VzcyBhbiBhcnJheSBvZiBldmVudCBwcm9jZXNzb3JzLCByZXR1cm5pbmcgdGhlIHByb2Nlc3NlZCBldmVudCAob3IgYG51bGxgIGlmIHRoZSBldmVudCB3YXMgZHJvcHBlZCkuXG4gKi9cbmZ1bmN0aW9uIG5vdGlmeUV2ZW50UHJvY2Vzc29ycyhcbiAgcHJvY2Vzc29ycyxcbiAgZXZlbnQsXG4gIGhpbnQsXG4gIGluZGV4ID0gMCxcbikge1xuICByZXR1cm4gbmV3IHN5bmNwcm9taXNlLlN5bmNQcm9taXNlKChyZXNvbHZlLCByZWplY3QpID0+IHtcbiAgICBjb25zdCBwcm9jZXNzb3IgPSBwcm9jZXNzb3JzW2luZGV4XTtcbiAgICBpZiAoZXZlbnQgPT09IG51bGwgfHwgdHlwZW9mIHByb2Nlc3NvciAhPT0gJ2Z1bmN0aW9uJykge1xuICAgICAgcmVzb2x2ZShldmVudCk7XG4gICAgfSBlbHNlIHtcbiAgICAgIGNvbnN0IHJlc3VsdCA9IHByb2Nlc3Nvcih7IC4uLmV2ZW50IH0sIGhpbnQpIDtcblxuICAgICAgZGVidWdCdWlsZC5ERUJVR19CVUlMRCAmJiBwcm9jZXNzb3IuaWQgJiYgcmVzdWx0ID09PSBudWxsICYmIGRlYnVnTG9nZ2VyLmRlYnVnLmxvZyhgRXZlbnQgcHJvY2Vzc29yIFwiJHtwcm9jZXNzb3IuaWR9XCIgZHJvcHBlZCBldmVudGApO1xuXG4gICAgICBpZiAoaXMuaXNUaGVuYWJsZShyZXN1bHQpKSB7XG4gICAgICAgIHZvaWQgcmVzdWx0XG4gICAgICAgICAgLnRoZW4oZmluYWwgPT4gbm90aWZ5RXZlbnRQcm9jZXNzb3JzKHByb2Nlc3NvcnMsIGZpbmFsLCBoaW50LCBpbmRleCArIDEpLnRoZW4ocmVzb2x2ZSkpXG4gICAgICAgICAgLnRoZW4obnVsbCwgcmVqZWN0KTtcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIHZvaWQgbm90aWZ5RXZlbnRQcm9jZXNzb3JzKHByb2Nlc3NvcnMsIHJlc3VsdCwgaGludCwgaW5kZXggKyAxKVxuICAgICAgICAgIC50aGVuKHJlc29sdmUpXG4gICAgICAgICAgLnRoZW4obnVsbCwgcmVqZWN0KTtcbiAgICAgIH1cbiAgICB9XG4gIH0pO1xufVxuXG5leHBvcnRzLm5vdGlmeUV2ZW50UHJvY2Vzc29ycyA9IG5vdGlmeUV2ZW50UHJvY2Vzc29ycztcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWV2ZW50UHJvY2Vzc29ycy5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/eventProcessors.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/exports.js":
/*!***********************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/exports.js ***!
  \***********************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst currentScopes = __webpack_require__(/*! ./currentScopes.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst debugBuild = __webpack_require__(/*! ./debug-build.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst session = __webpack_require__(/*! ./session.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/session.js\");\nconst debugLogger = __webpack_require__(/*! ./utils/debug-logger.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst is = __webpack_require__(/*! ./utils/is.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js\");\nconst misc = __webpack_require__(/*! ./utils/misc.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/misc.js\");\nconst prepareEvent = __webpack_require__(/*! ./utils/prepareEvent.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/prepareEvent.js\");\nconst time = __webpack_require__(/*! ./utils/time.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/time.js\");\nconst worldwide = __webpack_require__(/*! ./utils/worldwide.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/worldwide.js\");\n\n/**\n * Captures an exception event and sends it to Sentry.\n *\n * @param exception The exception to capture.\n * @param hint Optional additional data to attach to the Sentry event.\n * @returns the id of the captured Sentry event.\n */\nfunction captureException(exception, hint) {\n  return currentScopes.getCurrentScope().captureException(exception, prepareEvent.parseEventHintOrCaptureContext(hint));\n}\n\n/**\n * Captures a message event and sends it to Sentry.\n *\n * @param message The message to send to Sentry.\n * @param captureContext Define the level of the message or pass in additional data to attach to the message.\n * @returns the id of the captured message.\n */\nfunction captureMessage(message, captureContext) {\n  // This is necessary to provide explicit scopes upgrade, without changing the original\n  // arity of the `captureMessage(message, level)` method.\n  const level = typeof captureContext === 'string' ? captureContext : undefined;\n  const context = typeof captureContext !== 'string' ? { captureContext } : undefined;\n  return currentScopes.getCurrentScope().captureMessage(message, level, context);\n}\n\n/**\n * Captures a manually created event and sends it to Sentry.\n *\n * @param event The event to send to Sentry.\n * @param hint Optional additional data to attach to the Sentry event.\n * @returns the id of the captured event.\n */\nfunction captureEvent(event, hint) {\n  return currentScopes.getCurrentScope().captureEvent(event, hint);\n}\n\n/**\n * Sets context data with the given name.\n * @param name of the context\n * @param context Any kind of data. This data will be normalized.\n */\nfunction setContext(name, context) {\n  currentScopes.getIsolationScope().setContext(name, context);\n}\n\n/**\n * Set an object that will be merged sent as extra data with the event.\n * @param extras Extras object to merge into current context.\n */\nfunction setExtras(extras) {\n  currentScopes.getIsolationScope().setExtras(extras);\n}\n\n/**\n * Set key:value that will be sent as extra data with the event.\n * @param key String of extra\n * @param extra Any kind of data. This data will be normalized.\n */\nfunction setExtra(key, extra) {\n  currentScopes.getIsolationScope().setExtra(key, extra);\n}\n\n/**\n * Set an object that will be merged sent as tags data with the event.\n * @param tags Tags context object to merge into current context.\n */\nfunction setTags(tags) {\n  currentScopes.getIsolationScope().setTags(tags);\n}\n\n/**\n * Set key:value that will be sent as tags data with the event.\n *\n * Can also be used to unset a tag, by passing `undefined`.\n *\n * @param key String key of tag\n * @param value Value of tag\n */\nfunction setTag(key, value) {\n  currentScopes.getIsolationScope().setTag(key, value);\n}\n\n/**\n * Updates user context information for future events.\n *\n * @param user User context object to be set in the current context. Pass `null` to unset the user.\n */\nfunction setUser(user) {\n  currentScopes.getIsolationScope().setUser(user);\n}\n\n/**\n * The last error event id of the isolation scope.\n *\n * Warning: This function really returns the last recorded error event id on the current\n * isolation scope. If you call this function after handling a certain error and another error\n * is captured in between, the last one is returned instead of the one you might expect.\n * Also, ids of events that were never sent to Sentry (for example because\n * they were dropped in `beforeSend`) could be returned.\n *\n * @returns The last event id of the isolation scope.\n */\nfunction lastEventId() {\n  return currentScopes.getIsolationScope().lastEventId();\n}\n\n/**\n * Create a cron monitor check in and send it to Sentry.\n *\n * @param checkIn An object that describes a check in.\n * @param upsertMonitorConfig An optional object that describes a monitor config. Use this if you want\n * to create a monitor automatically when sending a check in.\n */\nfunction captureCheckIn(checkIn, upsertMonitorConfig) {\n  const scope = currentScopes.getCurrentScope();\n  const client = currentScopes.getClient();\n  if (!client) {\n    debugBuild.DEBUG_BUILD && debugLogger.debug.warn('Cannot capture check-in. No client defined.');\n  } else if (!client.captureCheckIn) {\n    debugBuild.DEBUG_BUILD && debugLogger.debug.warn('Cannot capture check-in. Client does not support sending check-ins.');\n  } else {\n    return client.captureCheckIn(checkIn, upsertMonitorConfig, scope);\n  }\n\n  return misc.uuid4();\n}\n\n/**\n * Wraps a callback with a cron monitor check in. The check in will be sent to Sentry when the callback finishes.\n *\n * @param monitorSlug The distinct slug of the monitor.\n * @param callback Callback to be monitored\n * @param upsertMonitorConfig An optional object that describes a monitor config. Use this if you want\n * to create a monitor automatically when sending a check in.\n */\nfunction withMonitor(\n  monitorSlug,\n  callback,\n  upsertMonitorConfig,\n) {\n  const checkInId = captureCheckIn({ monitorSlug, status: 'in_progress' }, upsertMonitorConfig);\n  const now = time.timestampInSeconds();\n\n  function finishCheckIn(status) {\n    captureCheckIn({ monitorSlug, status, checkInId, duration: time.timestampInSeconds() - now });\n  }\n\n  return currentScopes.withIsolationScope(() => {\n    let maybePromiseResult;\n    try {\n      maybePromiseResult = callback();\n    } catch (e) {\n      finishCheckIn('error');\n      throw e;\n    }\n\n    if (is.isThenable(maybePromiseResult)) {\n      return maybePromiseResult.then(\n        r => {\n          finishCheckIn('ok');\n          return r;\n        },\n        e => {\n          finishCheckIn('error');\n          throw e;\n        },\n      ) ;\n    }\n    finishCheckIn('ok');\n\n    return maybePromiseResult;\n  });\n}\n\n/**\n * Call `flush()` on the current client, if there is one. See {@link Client.flush}.\n *\n * @param timeout Maximum time in ms the client should wait to flush its event queue. Omitting this parameter will cause\n * the client to wait until all events are sent before resolving the promise.\n * @returns A promise which resolves to `true` if the queue successfully drains before the timeout, or `false` if it\n * doesn't (or if there's no client defined).\n */\nasync function flush(timeout) {\n  const client = currentScopes.getClient();\n  if (client) {\n    return client.flush(timeout);\n  }\n  debugBuild.DEBUG_BUILD && debugLogger.debug.warn('Cannot flush events. No client defined.');\n  return Promise.resolve(false);\n}\n\n/**\n * Call `close()` on the current client, if there is one. See {@link Client.close}.\n *\n * @param timeout Maximum time in ms the client should wait to flush its event queue before shutting down. Omitting this\n * parameter will cause the client to wait until all events are sent before disabling itself.\n * @returns A promise which resolves to `true` if the queue successfully drains before the timeout, or `false` if it\n * doesn't (or if there's no client defined).\n */\nasync function close(timeout) {\n  const client = currentScopes.getClient();\n  if (client) {\n    return client.close(timeout);\n  }\n  debugBuild.DEBUG_BUILD && debugLogger.debug.warn('Cannot flush events and disable SDK. No client defined.');\n  return Promise.resolve(false);\n}\n\n/**\n * Returns true if Sentry has been properly initialized.\n */\nfunction isInitialized() {\n  return !!currentScopes.getClient();\n}\n\n/** If the SDK is initialized & enabled. */\nfunction isEnabled() {\n  const client = currentScopes.getClient();\n  return client?.getOptions().enabled !== false && !!client?.getTransport();\n}\n\n/**\n * Add an event processor.\n * This will be added to the current isolation scope, ensuring any event that is processed in the current execution\n * context will have the processor applied.\n */\nfunction addEventProcessor(callback) {\n  currentScopes.getIsolationScope().addEventProcessor(callback);\n}\n\n/**\n * Start a session on the current isolation scope.\n *\n * @param context (optional) additional properties to be applied to the returned session object\n *\n * @returns the new active session\n */\nfunction startSession(context) {\n  const isolationScope = currentScopes.getIsolationScope();\n  const currentScope = currentScopes.getCurrentScope();\n\n  // Will fetch userAgent if called from browser sdk\n  const { userAgent } = worldwide.GLOBAL_OBJ.navigator || {};\n\n  const session$1 = session.makeSession({\n    user: currentScope.getUser() || isolationScope.getUser(),\n    ...(userAgent && { userAgent }),\n    ...context,\n  });\n\n  // End existing session if there's one\n  const currentSession = isolationScope.getSession();\n  if (currentSession?.status === 'ok') {\n    session.updateSession(currentSession, { status: 'exited' });\n  }\n\n  endSession();\n\n  // Afterwards we set the new session on the scope\n  isolationScope.setSession(session$1);\n\n  return session$1;\n}\n\n/**\n * End the session on the current isolation scope.\n */\nfunction endSession() {\n  const isolationScope = currentScopes.getIsolationScope();\n  const currentScope = currentScopes.getCurrentScope();\n\n  const session$1 = currentScope.getSession() || isolationScope.getSession();\n  if (session$1) {\n    session.closeSession(session$1);\n  }\n  _sendSessionUpdate();\n\n  // the session is over; take it off of the scope\n  isolationScope.setSession();\n}\n\n/**\n * Sends the current Session on the scope\n */\nfunction _sendSessionUpdate() {\n  const isolationScope = currentScopes.getIsolationScope();\n  const client = currentScopes.getClient();\n  const session = isolationScope.getSession();\n  if (session && client) {\n    client.captureSession(session);\n  }\n}\n\n/**\n * Sends the current session on the scope to Sentry\n *\n * @param end If set the session will be marked as exited and removed from the scope.\n *            Defaults to `false`.\n */\nfunction captureSession(end = false) {\n  // both send the update and pull the session from the scope\n  if (end) {\n    endSession();\n    return;\n  }\n\n  // only send the update\n  _sendSessionUpdate();\n}\n\nexports.addEventProcessor = addEventProcessor;\nexports.captureCheckIn = captureCheckIn;\nexports.captureEvent = captureEvent;\nexports.captureException = captureException;\nexports.captureMessage = captureMessage;\nexports.captureSession = captureSession;\nexports.close = close;\nexports.endSession = endSession;\nexports.flush = flush;\nexports.isEnabled = isEnabled;\nexports.isInitialized = isInitialized;\nexports.lastEventId = lastEventId;\nexports.setContext = setContext;\nexports.setExtra = setExtra;\nexports.setExtras = setExtras;\nexports.setTag = setTag;\nexports.setTags = setTags;\nexports.setUser = setUser;\nexports.startSession = startSession;\nexports.withMonitor = withMonitor;\n//# sourceMappingURL=exports.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvZXhwb3J0cy5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxzQkFBc0IsbUJBQU8sQ0FBQyxzSUFBb0I7QUFDbEQsbUJBQW1CLG1CQUFPLENBQUMsa0lBQWtCO0FBQzdDLGdCQUFnQixtQkFBTyxDQUFDLDBIQUFjO0FBQ3RDLG9CQUFvQixtQkFBTyxDQUFDLGdKQUF5QjtBQUNyRCxXQUFXLG1CQUFPLENBQUMsNEhBQWU7QUFDbEMsYUFBYSxtQkFBTyxDQUFDLGdJQUFpQjtBQUN0QyxxQkFBcUIsbUJBQU8sQ0FBQyxnSkFBeUI7QUFDdEQsYUFBYSxtQkFBTyxDQUFDLGdJQUFpQjtBQUN0QyxrQkFBa0IsbUJBQU8sQ0FBQywwSUFBc0I7O0FBRWhEO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSx5REFBeUQsaUJBQWlCO0FBQzFFO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLElBQUk7QUFDSjtBQUNBLElBQUk7QUFDSjtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxxQ0FBcUMsb0NBQW9DO0FBQ3pFOztBQUVBO0FBQ0EscUJBQXFCLDJFQUEyRTtBQUNoRzs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLE1BQU07QUFDTjtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFNBQVM7QUFDVDtBQUNBO0FBQ0E7QUFDQSxTQUFTO0FBQ1Q7QUFDQTtBQUNBOztBQUVBO0FBQ0EsR0FBRztBQUNIOztBQUVBO0FBQ0EsK0RBQStELG1CQUFtQjtBQUNsRjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0EsK0RBQStELG1CQUFtQjtBQUNsRjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQSxVQUFVLFlBQVk7O0FBRXRCO0FBQ0E7QUFDQSx1QkFBdUIsV0FBVztBQUNsQztBQUNBLEdBQUc7O0FBRUg7QUFDQTtBQUNBO0FBQ0EsNENBQTRDLGtCQUFrQjtBQUM5RDs7QUFFQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsMEJBQTBCO0FBQzFCO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBLHlCQUF5QjtBQUN6QixzQkFBc0I7QUFDdEIsb0JBQW9CO0FBQ3BCLHdCQUF3QjtBQUN4QixzQkFBc0I7QUFDdEIsc0JBQXNCO0FBQ3RCLGFBQWE7QUFDYixrQkFBa0I7QUFDbEIsYUFBYTtBQUNiLGlCQUFpQjtBQUNqQixxQkFBcUI7QUFDckIsbUJBQW1CO0FBQ25CLGtCQUFrQjtBQUNsQixnQkFBZ0I7QUFDaEIsaUJBQWlCO0FBQ2pCLGNBQWM7QUFDZCxlQUFlO0FBQ2YsZUFBZTtBQUNmLG9CQUFvQjtBQUNwQixtQkFBbUI7QUFDbkIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9leHBvcnRzLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBjdXJyZW50U2NvcGVzID0gcmVxdWlyZSgnLi9jdXJyZW50U2NvcGVzLmpzJyk7XG5jb25zdCBkZWJ1Z0J1aWxkID0gcmVxdWlyZSgnLi9kZWJ1Zy1idWlsZC5qcycpO1xuY29uc3Qgc2Vzc2lvbiA9IHJlcXVpcmUoJy4vc2Vzc2lvbi5qcycpO1xuY29uc3QgZGVidWdMb2dnZXIgPSByZXF1aXJlKCcuL3V0aWxzL2RlYnVnLWxvZ2dlci5qcycpO1xuY29uc3QgaXMgPSByZXF1aXJlKCcuL3V0aWxzL2lzLmpzJyk7XG5jb25zdCBtaXNjID0gcmVxdWlyZSgnLi91dGlscy9taXNjLmpzJyk7XG5jb25zdCBwcmVwYXJlRXZlbnQgPSByZXF1aXJlKCcuL3V0aWxzL3ByZXBhcmVFdmVudC5qcycpO1xuY29uc3QgdGltZSA9IHJlcXVpcmUoJy4vdXRpbHMvdGltZS5qcycpO1xuY29uc3Qgd29ybGR3aWRlID0gcmVxdWlyZSgnLi91dGlscy93b3JsZHdpZGUuanMnKTtcblxuLyoqXG4gKiBDYXB0dXJlcyBhbiBleGNlcHRpb24gZXZlbnQgYW5kIHNlbmRzIGl0IHRvIFNlbnRyeS5cbiAqXG4gKiBAcGFyYW0gZXhjZXB0aW9uIFRoZSBleGNlcHRpb24gdG8gY2FwdHVyZS5cbiAqIEBwYXJhbSBoaW50IE9wdGlvbmFsIGFkZGl0aW9uYWwgZGF0YSB0byBhdHRhY2ggdG8gdGhlIFNlbnRyeSBldmVudC5cbiAqIEByZXR1cm5zIHRoZSBpZCBvZiB0aGUgY2FwdHVyZWQgU2VudHJ5IGV2ZW50LlxuICovXG5mdW5jdGlvbiBjYXB0dXJlRXhjZXB0aW9uKGV4Y2VwdGlvbiwgaGludCkge1xuICByZXR1cm4gY3VycmVudFNjb3Blcy5nZXRDdXJyZW50U2NvcGUoKS5jYXB0dXJlRXhjZXB0aW9uKGV4Y2VwdGlvbiwgcHJlcGFyZUV2ZW50LnBhcnNlRXZlbnRIaW50T3JDYXB0dXJlQ29udGV4dChoaW50KSk7XG59XG5cbi8qKlxuICogQ2FwdHVyZXMgYSBtZXNzYWdlIGV2ZW50IGFuZCBzZW5kcyBpdCB0byBTZW50cnkuXG4gKlxuICogQHBhcmFtIG1lc3NhZ2UgVGhlIG1lc3NhZ2UgdG8gc2VuZCB0byBTZW50cnkuXG4gKiBAcGFyYW0gY2FwdHVyZUNvbnRleHQgRGVmaW5lIHRoZSBsZXZlbCBvZiB0aGUgbWVzc2FnZSBvciBwYXNzIGluIGFkZGl0aW9uYWwgZGF0YSB0byBhdHRhY2ggdG8gdGhlIG1lc3NhZ2UuXG4gKiBAcmV0dXJucyB0aGUgaWQgb2YgdGhlIGNhcHR1cmVkIG1lc3NhZ2UuXG4gKi9cbmZ1bmN0aW9uIGNhcHR1cmVNZXNzYWdlKG1lc3NhZ2UsIGNhcHR1cmVDb250ZXh0KSB7XG4gIC8vIFRoaXMgaXMgbmVjZXNzYXJ5IHRvIHByb3ZpZGUgZXhwbGljaXQgc2NvcGVzIHVwZ3JhZGUsIHdpdGhvdXQgY2hhbmdpbmcgdGhlIG9yaWdpbmFsXG4gIC8vIGFyaXR5IG9mIHRoZSBgY2FwdHVyZU1lc3NhZ2UobWVzc2FnZSwgbGV2ZWwpYCBtZXRob2QuXG4gIGNvbnN0IGxldmVsID0gdHlwZW9mIGNhcHR1cmVDb250ZXh0ID09PSAnc3RyaW5nJyA/IGNhcHR1cmVDb250ZXh0IDogdW5kZWZpbmVkO1xuICBjb25zdCBjb250ZXh0ID0gdHlwZW9mIGNhcHR1cmVDb250ZXh0ICE9PSAnc3RyaW5nJyA/IHsgY2FwdHVyZUNvbnRleHQgfSA6IHVuZGVmaW5lZDtcbiAgcmV0dXJuIGN1cnJlbnRTY29wZXMuZ2V0Q3VycmVudFNjb3BlKCkuY2FwdHVyZU1lc3NhZ2UobWVzc2FnZSwgbGV2ZWwsIGNvbnRleHQpO1xufVxuXG4vKipcbiAqIENhcHR1cmVzIGEgbWFudWFsbHkgY3JlYXRlZCBldmVudCBhbmQgc2VuZHMgaXQgdG8gU2VudHJ5LlxuICpcbiAqIEBwYXJhbSBldmVudCBUaGUgZXZlbnQgdG8gc2VuZCB0byBTZW50cnkuXG4gKiBAcGFyYW0gaGludCBPcHRpb25hbCBhZGRpdGlvbmFsIGRhdGEgdG8gYXR0YWNoIHRvIHRoZSBTZW50cnkgZXZlbnQuXG4gKiBAcmV0dXJucyB0aGUgaWQgb2YgdGhlIGNhcHR1cmVkIGV2ZW50LlxuICovXG5mdW5jdGlvbiBjYXB0dXJlRXZlbnQoZXZlbnQsIGhpbnQpIHtcbiAgcmV0dXJuIGN1cnJlbnRTY29wZXMuZ2V0Q3VycmVudFNjb3BlKCkuY2FwdHVyZUV2ZW50KGV2ZW50LCBoaW50KTtcbn1cblxuLyoqXG4gKiBTZXRzIGNvbnRleHQgZGF0YSB3aXRoIHRoZSBnaXZlbiBuYW1lLlxuICogQHBhcmFtIG5hbWUgb2YgdGhlIGNvbnRleHRcbiAqIEBwYXJhbSBjb250ZXh0IEFueSBraW5kIG9mIGRhdGEuIFRoaXMgZGF0YSB3aWxsIGJlIG5vcm1hbGl6ZWQuXG4gKi9cbmZ1bmN0aW9uIHNldENvbnRleHQobmFtZSwgY29udGV4dCkge1xuICBjdXJyZW50U2NvcGVzLmdldElzb2xhdGlvblNjb3BlKCkuc2V0Q29udGV4dChuYW1lLCBjb250ZXh0KTtcbn1cblxuLyoqXG4gKiBTZXQgYW4gb2JqZWN0IHRoYXQgd2lsbCBiZSBtZXJnZWQgc2VudCBhcyBleHRyYSBkYXRhIHdpdGggdGhlIGV2ZW50LlxuICogQHBhcmFtIGV4dHJhcyBFeHRyYXMgb2JqZWN0IHRvIG1lcmdlIGludG8gY3VycmVudCBjb250ZXh0LlxuICovXG5mdW5jdGlvbiBzZXRFeHRyYXMoZXh0cmFzKSB7XG4gIGN1cnJlbnRTY29wZXMuZ2V0SXNvbGF0aW9uU2NvcGUoKS5zZXRFeHRyYXMoZXh0cmFzKTtcbn1cblxuLyoqXG4gKiBTZXQga2V5OnZhbHVlIHRoYXQgd2lsbCBiZSBzZW50IGFzIGV4dHJhIGRhdGEgd2l0aCB0aGUgZXZlbnQuXG4gKiBAcGFyYW0ga2V5IFN0cmluZyBvZiBleHRyYVxuICogQHBhcmFtIGV4dHJhIEFueSBraW5kIG9mIGRhdGEuIFRoaXMgZGF0YSB3aWxsIGJlIG5vcm1hbGl6ZWQuXG4gKi9cbmZ1bmN0aW9uIHNldEV4dHJhKGtleSwgZXh0cmEpIHtcbiAgY3VycmVudFNjb3Blcy5nZXRJc29sYXRpb25TY29wZSgpLnNldEV4dHJhKGtleSwgZXh0cmEpO1xufVxuXG4vKipcbiAqIFNldCBhbiBvYmplY3QgdGhhdCB3aWxsIGJlIG1lcmdlZCBzZW50IGFzIHRhZ3MgZGF0YSB3aXRoIHRoZSBldmVudC5cbiAqIEBwYXJhbSB0YWdzIFRhZ3MgY29udGV4dCBvYmplY3QgdG8gbWVyZ2UgaW50byBjdXJyZW50IGNvbnRleHQuXG4gKi9cbmZ1bmN0aW9uIHNldFRhZ3ModGFncykge1xuICBjdXJyZW50U2NvcGVzLmdldElzb2xhdGlvblNjb3BlKCkuc2V0VGFncyh0YWdzKTtcbn1cblxuLyoqXG4gKiBTZXQga2V5OnZhbHVlIHRoYXQgd2lsbCBiZSBzZW50IGFzIHRhZ3MgZGF0YSB3aXRoIHRoZSBldmVudC5cbiAqXG4gKiBDYW4gYWxzbyBiZSB1c2VkIHRvIHVuc2V0IGEgdGFnLCBieSBwYXNzaW5nIGB1bmRlZmluZWRgLlxuICpcbiAqIEBwYXJhbSBrZXkgU3RyaW5nIGtleSBvZiB0YWdcbiAqIEBwYXJhbSB2YWx1ZSBWYWx1ZSBvZiB0YWdcbiAqL1xuZnVuY3Rpb24gc2V0VGFnKGtleSwgdmFsdWUpIHtcbiAgY3VycmVudFNjb3Blcy5nZXRJc29sYXRpb25TY29wZSgpLnNldFRhZyhrZXksIHZhbHVlKTtcbn1cblxuLyoqXG4gKiBVcGRhdGVzIHVzZXIgY29udGV4dCBpbmZvcm1hdGlvbiBmb3IgZnV0dXJlIGV2ZW50cy5cbiAqXG4gKiBAcGFyYW0gdXNlciBVc2VyIGNvbnRleHQgb2JqZWN0IHRvIGJlIHNldCBpbiB0aGUgY3VycmVudCBjb250ZXh0LiBQYXNzIGBudWxsYCB0byB1bnNldCB0aGUgdXNlci5cbiAqL1xuZnVuY3Rpb24gc2V0VXNlcih1c2VyKSB7XG4gIGN1cnJlbnRTY29wZXMuZ2V0SXNvbGF0aW9uU2NvcGUoKS5zZXRVc2VyKHVzZXIpO1xufVxuXG4vKipcbiAqIFRoZSBsYXN0IGVycm9yIGV2ZW50IGlkIG9mIHRoZSBpc29sYXRpb24gc2NvcGUuXG4gKlxuICogV2FybmluZzogVGhpcyBmdW5jdGlvbiByZWFsbHkgcmV0dXJucyB0aGUgbGFzdCByZWNvcmRlZCBlcnJvciBldmVudCBpZCBvbiB0aGUgY3VycmVudFxuICogaXNvbGF0aW9uIHNjb3BlLiBJZiB5b3UgY2FsbCB0aGlzIGZ1bmN0aW9uIGFmdGVyIGhhbmRsaW5nIGEgY2VydGFpbiBlcnJvciBhbmQgYW5vdGhlciBlcnJvclxuICogaXMgY2FwdHVyZWQgaW4gYmV0d2VlbiwgdGhlIGxhc3Qgb25lIGlzIHJldHVybmVkIGluc3RlYWQgb2YgdGhlIG9uZSB5b3UgbWlnaHQgZXhwZWN0LlxuICogQWxzbywgaWRzIG9mIGV2ZW50cyB0aGF0IHdlcmUgbmV2ZXIgc2VudCB0byBTZW50cnkgKGZvciBleGFtcGxlIGJlY2F1c2VcbiAqIHRoZXkgd2VyZSBkcm9wcGVkIGluIGBiZWZvcmVTZW5kYCkgY291bGQgYmUgcmV0dXJuZWQuXG4gKlxuICogQHJldHVybnMgVGhlIGxhc3QgZXZlbnQgaWQgb2YgdGhlIGlzb2xhdGlvbiBzY29wZS5cbiAqL1xuZnVuY3Rpb24gbGFzdEV2ZW50SWQoKSB7XG4gIHJldHVybiBjdXJyZW50U2NvcGVzLmdldElzb2xhdGlvblNjb3BlKCkubGFzdEV2ZW50SWQoKTtcbn1cblxuLyoqXG4gKiBDcmVhdGUgYSBjcm9uIG1vbml0b3IgY2hlY2sgaW4gYW5kIHNlbmQgaXQgdG8gU2VudHJ5LlxuICpcbiAqIEBwYXJhbSBjaGVja0luIEFuIG9iamVjdCB0aGF0IGRlc2NyaWJlcyBhIGNoZWNrIGluLlxuICogQHBhcmFtIHVwc2VydE1vbml0b3JDb25maWcgQW4gb3B0aW9uYWwgb2JqZWN0IHRoYXQgZGVzY3JpYmVzIGEgbW9uaXRvciBjb25maWcuIFVzZSB0aGlzIGlmIHlvdSB3YW50XG4gKiB0byBjcmVhdGUgYSBtb25pdG9yIGF1dG9tYXRpY2FsbHkgd2hlbiBzZW5kaW5nIGEgY2hlY2sgaW4uXG4gKi9cbmZ1bmN0aW9uIGNhcHR1cmVDaGVja0luKGNoZWNrSW4sIHVwc2VydE1vbml0b3JDb25maWcpIHtcbiAgY29uc3Qgc2NvcGUgPSBjdXJyZW50U2NvcGVzLmdldEN1cnJlbnRTY29wZSgpO1xuICBjb25zdCBjbGllbnQgPSBjdXJyZW50U2NvcGVzLmdldENsaWVudCgpO1xuICBpZiAoIWNsaWVudCkge1xuICAgIGRlYnVnQnVpbGQuREVCVUdfQlVJTEQgJiYgZGVidWdMb2dnZXIuZGVidWcud2FybignQ2Fubm90IGNhcHR1cmUgY2hlY2staW4uIE5vIGNsaWVudCBkZWZpbmVkLicpO1xuICB9IGVsc2UgaWYgKCFjbGllbnQuY2FwdHVyZUNoZWNrSW4pIHtcbiAgICBkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEICYmIGRlYnVnTG9nZ2VyLmRlYnVnLndhcm4oJ0Nhbm5vdCBjYXB0dXJlIGNoZWNrLWluLiBDbGllbnQgZG9lcyBub3Qgc3VwcG9ydCBzZW5kaW5nIGNoZWNrLWlucy4nKTtcbiAgfSBlbHNlIHtcbiAgICByZXR1cm4gY2xpZW50LmNhcHR1cmVDaGVja0luKGNoZWNrSW4sIHVwc2VydE1vbml0b3JDb25maWcsIHNjb3BlKTtcbiAgfVxuXG4gIHJldHVybiBtaXNjLnV1aWQ0KCk7XG59XG5cbi8qKlxuICogV3JhcHMgYSBjYWxsYmFjayB3aXRoIGEgY3JvbiBtb25pdG9yIGNoZWNrIGluLiBUaGUgY2hlY2sgaW4gd2lsbCBiZSBzZW50IHRvIFNlbnRyeSB3aGVuIHRoZSBjYWxsYmFjayBmaW5pc2hlcy5cbiAqXG4gKiBAcGFyYW0gbW9uaXRvclNsdWcgVGhlIGRpc3RpbmN0IHNsdWcgb2YgdGhlIG1vbml0b3IuXG4gKiBAcGFyYW0gY2FsbGJhY2sgQ2FsbGJhY2sgdG8gYmUgbW9uaXRvcmVkXG4gKiBAcGFyYW0gdXBzZXJ0TW9uaXRvckNvbmZpZyBBbiBvcHRpb25hbCBvYmplY3QgdGhhdCBkZXNjcmliZXMgYSBtb25pdG9yIGNvbmZpZy4gVXNlIHRoaXMgaWYgeW91IHdhbnRcbiAqIHRvIGNyZWF0ZSBhIG1vbml0b3IgYXV0b21hdGljYWxseSB3aGVuIHNlbmRpbmcgYSBjaGVjayBpbi5cbiAqL1xuZnVuY3Rpb24gd2l0aE1vbml0b3IoXG4gIG1vbml0b3JTbHVnLFxuICBjYWxsYmFjayxcbiAgdXBzZXJ0TW9uaXRvckNvbmZpZyxcbikge1xuICBjb25zdCBjaGVja0luSWQgPSBjYXB0dXJlQ2hlY2tJbih7IG1vbml0b3JTbHVnLCBzdGF0dXM6ICdpbl9wcm9ncmVzcycgfSwgdXBzZXJ0TW9uaXRvckNvbmZpZyk7XG4gIGNvbnN0IG5vdyA9IHRpbWUudGltZXN0YW1wSW5TZWNvbmRzKCk7XG5cbiAgZnVuY3Rpb24gZmluaXNoQ2hlY2tJbihzdGF0dXMpIHtcbiAgICBjYXB0dXJlQ2hlY2tJbih7IG1vbml0b3JTbHVnLCBzdGF0dXMsIGNoZWNrSW5JZCwgZHVyYXRpb246IHRpbWUudGltZXN0YW1wSW5TZWNvbmRzKCkgLSBub3cgfSk7XG4gIH1cblxuICByZXR1cm4gY3VycmVudFNjb3Blcy53aXRoSXNvbGF0aW9uU2NvcGUoKCkgPT4ge1xuICAgIGxldCBtYXliZVByb21pc2VSZXN1bHQ7XG4gICAgdHJ5IHtcbiAgICAgIG1heWJlUHJvbWlzZVJlc3VsdCA9IGNhbGxiYWNrKCk7XG4gICAgfSBjYXRjaCAoZSkge1xuICAgICAgZmluaXNoQ2hlY2tJbignZXJyb3InKTtcbiAgICAgIHRocm93IGU7XG4gICAgfVxuXG4gICAgaWYgKGlzLmlzVGhlbmFibGUobWF5YmVQcm9taXNlUmVzdWx0KSkge1xuICAgICAgcmV0dXJuIG1heWJlUHJvbWlzZVJlc3VsdC50aGVuKFxuICAgICAgICByID0+IHtcbiAgICAgICAgICBmaW5pc2hDaGVja0luKCdvaycpO1xuICAgICAgICAgIHJldHVybiByO1xuICAgICAgICB9LFxuICAgICAgICBlID0+IHtcbiAgICAgICAgICBmaW5pc2hDaGVja0luKCdlcnJvcicpO1xuICAgICAgICAgIHRocm93IGU7XG4gICAgICAgIH0sXG4gICAgICApIDtcbiAgICB9XG4gICAgZmluaXNoQ2hlY2tJbignb2snKTtcblxuICAgIHJldHVybiBtYXliZVByb21pc2VSZXN1bHQ7XG4gIH0pO1xufVxuXG4vKipcbiAqIENhbGwgYGZsdXNoKClgIG9uIHRoZSBjdXJyZW50IGNsaWVudCwgaWYgdGhlcmUgaXMgb25lLiBTZWUge0BsaW5rIENsaWVudC5mbHVzaH0uXG4gKlxuICogQHBhcmFtIHRpbWVvdXQgTWF4aW11bSB0aW1lIGluIG1zIHRoZSBjbGllbnQgc2hvdWxkIHdhaXQgdG8gZmx1c2ggaXRzIGV2ZW50IHF1ZXVlLiBPbWl0dGluZyB0aGlzIHBhcmFtZXRlciB3aWxsIGNhdXNlXG4gKiB0aGUgY2xpZW50IHRvIHdhaXQgdW50aWwgYWxsIGV2ZW50cyBhcmUgc2VudCBiZWZvcmUgcmVzb2x2aW5nIHRoZSBwcm9taXNlLlxuICogQHJldHVybnMgQSBwcm9taXNlIHdoaWNoIHJlc29sdmVzIHRvIGB0cnVlYCBpZiB0aGUgcXVldWUgc3VjY2Vzc2Z1bGx5IGRyYWlucyBiZWZvcmUgdGhlIHRpbWVvdXQsIG9yIGBmYWxzZWAgaWYgaXRcbiAqIGRvZXNuJ3QgKG9yIGlmIHRoZXJlJ3Mgbm8gY2xpZW50IGRlZmluZWQpLlxuICovXG5hc3luYyBmdW5jdGlvbiBmbHVzaCh0aW1lb3V0KSB7XG4gIGNvbnN0IGNsaWVudCA9IGN1cnJlbnRTY29wZXMuZ2V0Q2xpZW50KCk7XG4gIGlmIChjbGllbnQpIHtcbiAgICByZXR1cm4gY2xpZW50LmZsdXNoKHRpbWVvdXQpO1xuICB9XG4gIGRlYnVnQnVpbGQuREVCVUdfQlVJTEQgJiYgZGVidWdMb2dnZXIuZGVidWcud2FybignQ2Fubm90IGZsdXNoIGV2ZW50cy4gTm8gY2xpZW50IGRlZmluZWQuJyk7XG4gIHJldHVybiBQcm9taXNlLnJlc29sdmUoZmFsc2UpO1xufVxuXG4vKipcbiAqIENhbGwgYGNsb3NlKClgIG9uIHRoZSBjdXJyZW50IGNsaWVudCwgaWYgdGhlcmUgaXMgb25lLiBTZWUge0BsaW5rIENsaWVudC5jbG9zZX0uXG4gKlxuICogQHBhcmFtIHRpbWVvdXQgTWF4aW11bSB0aW1lIGluIG1zIHRoZSBjbGllbnQgc2hvdWxkIHdhaXQgdG8gZmx1c2ggaXRzIGV2ZW50IHF1ZXVlIGJlZm9yZSBzaHV0dGluZyBkb3duLiBPbWl0dGluZyB0aGlzXG4gKiBwYXJhbWV0ZXIgd2lsbCBjYXVzZSB0aGUgY2xpZW50IHRvIHdhaXQgdW50aWwgYWxsIGV2ZW50cyBhcmUgc2VudCBiZWZvcmUgZGlzYWJsaW5nIGl0c2VsZi5cbiAqIEByZXR1cm5zIEEgcHJvbWlzZSB3aGljaCByZXNvbHZlcyB0byBgdHJ1ZWAgaWYgdGhlIHF1ZXVlIHN1Y2Nlc3NmdWxseSBkcmFpbnMgYmVmb3JlIHRoZSB0aW1lb3V0LCBvciBgZmFsc2VgIGlmIGl0XG4gKiBkb2Vzbid0IChvciBpZiB0aGVyZSdzIG5vIGNsaWVudCBkZWZpbmVkKS5cbiAqL1xuYXN5bmMgZnVuY3Rpb24gY2xvc2UodGltZW91dCkge1xuICBjb25zdCBjbGllbnQgPSBjdXJyZW50U2NvcGVzLmdldENsaWVudCgpO1xuICBpZiAoY2xpZW50KSB7XG4gICAgcmV0dXJuIGNsaWVudC5jbG9zZSh0aW1lb3V0KTtcbiAgfVxuICBkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEICYmIGRlYnVnTG9nZ2VyLmRlYnVnLndhcm4oJ0Nhbm5vdCBmbHVzaCBldmVudHMgYW5kIGRpc2FibGUgU0RLLiBObyBjbGllbnQgZGVmaW5lZC4nKTtcbiAgcmV0dXJuIFByb21pc2UucmVzb2x2ZShmYWxzZSk7XG59XG5cbi8qKlxuICogUmV0dXJucyB0cnVlIGlmIFNlbnRyeSBoYXMgYmVlbiBwcm9wZXJseSBpbml0aWFsaXplZC5cbiAqL1xuZnVuY3Rpb24gaXNJbml0aWFsaXplZCgpIHtcbiAgcmV0dXJuICEhY3VycmVudFNjb3Blcy5nZXRDbGllbnQoKTtcbn1cblxuLyoqIElmIHRoZSBTREsgaXMgaW5pdGlhbGl6ZWQgJiBlbmFibGVkLiAqL1xuZnVuY3Rpb24gaXNFbmFibGVkKCkge1xuICBjb25zdCBjbGllbnQgPSBjdXJyZW50U2NvcGVzLmdldENsaWVudCgpO1xuICByZXR1cm4gY2xpZW50Py5nZXRPcHRpb25zKCkuZW5hYmxlZCAhPT0gZmFsc2UgJiYgISFjbGllbnQ/LmdldFRyYW5zcG9ydCgpO1xufVxuXG4vKipcbiAqIEFkZCBhbiBldmVudCBwcm9jZXNzb3IuXG4gKiBUaGlzIHdpbGwgYmUgYWRkZWQgdG8gdGhlIGN1cnJlbnQgaXNvbGF0aW9uIHNjb3BlLCBlbnN1cmluZyBhbnkgZXZlbnQgdGhhdCBpcyBwcm9jZXNzZWQgaW4gdGhlIGN1cnJlbnQgZXhlY3V0aW9uXG4gKiBjb250ZXh0IHdpbGwgaGF2ZSB0aGUgcHJvY2Vzc29yIGFwcGxpZWQuXG4gKi9cbmZ1bmN0aW9uIGFkZEV2ZW50UHJvY2Vzc29yKGNhbGxiYWNrKSB7XG4gIGN1cnJlbnRTY29wZXMuZ2V0SXNvbGF0aW9uU2NvcGUoKS5hZGRFdmVudFByb2Nlc3NvcihjYWxsYmFjayk7XG59XG5cbi8qKlxuICogU3RhcnQgYSBzZXNzaW9uIG9uIHRoZSBjdXJyZW50IGlzb2xhdGlvbiBzY29wZS5cbiAqXG4gKiBAcGFyYW0gY29udGV4dCAob3B0aW9uYWwpIGFkZGl0aW9uYWwgcHJvcGVydGllcyB0byBiZSBhcHBsaWVkIHRvIHRoZSByZXR1cm5lZCBzZXNzaW9uIG9iamVjdFxuICpcbiAqIEByZXR1cm5zIHRoZSBuZXcgYWN0aXZlIHNlc3Npb25cbiAqL1xuZnVuY3Rpb24gc3RhcnRTZXNzaW9uKGNvbnRleHQpIHtcbiAgY29uc3QgaXNvbGF0aW9uU2NvcGUgPSBjdXJyZW50U2NvcGVzLmdldElzb2xhdGlvblNjb3BlKCk7XG4gIGNvbnN0IGN1cnJlbnRTY29wZSA9IGN1cnJlbnRTY29wZXMuZ2V0Q3VycmVudFNjb3BlKCk7XG5cbiAgLy8gV2lsbCBmZXRjaCB1c2VyQWdlbnQgaWYgY2FsbGVkIGZyb20gYnJvd3NlciBzZGtcbiAgY29uc3QgeyB1c2VyQWdlbnQgfSA9IHdvcmxkd2lkZS5HTE9CQUxfT0JKLm5hdmlnYXRvciB8fCB7fTtcblxuICBjb25zdCBzZXNzaW9uJDEgPSBzZXNzaW9uLm1ha2VTZXNzaW9uKHtcbiAgICB1c2VyOiBjdXJyZW50U2NvcGUuZ2V0VXNlcigpIHx8IGlzb2xhdGlvblNjb3BlLmdldFVzZXIoKSxcbiAgICAuLi4odXNlckFnZW50ICYmIHsgdXNlckFnZW50IH0pLFxuICAgIC4uLmNvbnRleHQsXG4gIH0pO1xuXG4gIC8vIEVuZCBleGlzdGluZyBzZXNzaW9uIGlmIHRoZXJlJ3Mgb25lXG4gIGNvbnN0IGN1cnJlbnRTZXNzaW9uID0gaXNvbGF0aW9uU2NvcGUuZ2V0U2Vzc2lvbigpO1xuICBpZiAoY3VycmVudFNlc3Npb24/LnN0YXR1cyA9PT0gJ29rJykge1xuICAgIHNlc3Npb24udXBkYXRlU2Vzc2lvbihjdXJyZW50U2Vzc2lvbiwgeyBzdGF0dXM6ICdleGl0ZWQnIH0pO1xuICB9XG5cbiAgZW5kU2Vzc2lvbigpO1xuXG4gIC8vIEFmdGVyd2FyZHMgd2Ugc2V0IHRoZSBuZXcgc2Vzc2lvbiBvbiB0aGUgc2NvcGVcbiAgaXNvbGF0aW9uU2NvcGUuc2V0U2Vzc2lvbihzZXNzaW9uJDEpO1xuXG4gIHJldHVybiBzZXNzaW9uJDE7XG59XG5cbi8qKlxuICogRW5kIHRoZSBzZXNzaW9uIG9uIHRoZSBjdXJyZW50IGlzb2xhdGlvbiBzY29wZS5cbiAqL1xuZnVuY3Rpb24gZW5kU2Vzc2lvbigpIHtcbiAgY29uc3QgaXNvbGF0aW9uU2NvcGUgPSBjdXJyZW50U2NvcGVzLmdldElzb2xhdGlvblNjb3BlKCk7XG4gIGNvbnN0IGN1cnJlbnRTY29wZSA9IGN1cnJlbnRTY29wZXMuZ2V0Q3VycmVudFNjb3BlKCk7XG5cbiAgY29uc3Qgc2Vzc2lvbiQxID0gY3VycmVudFNjb3BlLmdldFNlc3Npb24oKSB8fCBpc29sYXRpb25TY29wZS5nZXRTZXNzaW9uKCk7XG4gIGlmIChzZXNzaW9uJDEpIHtcbiAgICBzZXNzaW9uLmNsb3NlU2Vzc2lvbihzZXNzaW9uJDEpO1xuICB9XG4gIF9zZW5kU2Vzc2lvblVwZGF0ZSgpO1xuXG4gIC8vIHRoZSBzZXNzaW9uIGlzIG92ZXI7IHRha2UgaXQgb2ZmIG9mIHRoZSBzY29wZVxuICBpc29sYXRpb25TY29wZS5zZXRTZXNzaW9uKCk7XG59XG5cbi8qKlxuICogU2VuZHMgdGhlIGN1cnJlbnQgU2Vzc2lvbiBvbiB0aGUgc2NvcGVcbiAqL1xuZnVuY3Rpb24gX3NlbmRTZXNzaW9uVXBkYXRlKCkge1xuICBjb25zdCBpc29sYXRpb25TY29wZSA9IGN1cnJlbnRTY29wZXMuZ2V0SXNvbGF0aW9uU2NvcGUoKTtcbiAgY29uc3QgY2xpZW50ID0gY3VycmVudFNjb3Blcy5nZXRDbGllbnQoKTtcbiAgY29uc3Qgc2Vzc2lvbiA9IGlzb2xhdGlvblNjb3BlLmdldFNlc3Npb24oKTtcbiAgaWYgKHNlc3Npb24gJiYgY2xpZW50KSB7XG4gICAgY2xpZW50LmNhcHR1cmVTZXNzaW9uKHNlc3Npb24pO1xuICB9XG59XG5cbi8qKlxuICogU2VuZHMgdGhlIGN1cnJlbnQgc2Vzc2lvbiBvbiB0aGUgc2NvcGUgdG8gU2VudHJ5XG4gKlxuICogQHBhcmFtIGVuZCBJZiBzZXQgdGhlIHNlc3Npb24gd2lsbCBiZSBtYXJrZWQgYXMgZXhpdGVkIGFuZCByZW1vdmVkIGZyb20gdGhlIHNjb3BlLlxuICogICAgICAgICAgICBEZWZhdWx0cyB0byBgZmFsc2VgLlxuICovXG5mdW5jdGlvbiBjYXB0dXJlU2Vzc2lvbihlbmQgPSBmYWxzZSkge1xuICAvLyBib3RoIHNlbmQgdGhlIHVwZGF0ZSBhbmQgcHVsbCB0aGUgc2Vzc2lvbiBmcm9tIHRoZSBzY29wZVxuICBpZiAoZW5kKSB7XG4gICAgZW5kU2Vzc2lvbigpO1xuICAgIHJldHVybjtcbiAgfVxuXG4gIC8vIG9ubHkgc2VuZCB0aGUgdXBkYXRlXG4gIF9zZW5kU2Vzc2lvblVwZGF0ZSgpO1xufVxuXG5leHBvcnRzLmFkZEV2ZW50UHJvY2Vzc29yID0gYWRkRXZlbnRQcm9jZXNzb3I7XG5leHBvcnRzLmNhcHR1cmVDaGVja0luID0gY2FwdHVyZUNoZWNrSW47XG5leHBvcnRzLmNhcHR1cmVFdmVudCA9IGNhcHR1cmVFdmVudDtcbmV4cG9ydHMuY2FwdHVyZUV4Y2VwdGlvbiA9IGNhcHR1cmVFeGNlcHRpb247XG5leHBvcnRzLmNhcHR1cmVNZXNzYWdlID0gY2FwdHVyZU1lc3NhZ2U7XG5leHBvcnRzLmNhcHR1cmVTZXNzaW9uID0gY2FwdHVyZVNlc3Npb247XG5leHBvcnRzLmNsb3NlID0gY2xvc2U7XG5leHBvcnRzLmVuZFNlc3Npb24gPSBlbmRTZXNzaW9uO1xuZXhwb3J0cy5mbHVzaCA9IGZsdXNoO1xuZXhwb3J0cy5pc0VuYWJsZWQgPSBpc0VuYWJsZWQ7XG5leHBvcnRzLmlzSW5pdGlhbGl6ZWQgPSBpc0luaXRpYWxpemVkO1xuZXhwb3J0cy5sYXN0RXZlbnRJZCA9IGxhc3RFdmVudElkO1xuZXhwb3J0cy5zZXRDb250ZXh0ID0gc2V0Q29udGV4dDtcbmV4cG9ydHMuc2V0RXh0cmEgPSBzZXRFeHRyYTtcbmV4cG9ydHMuc2V0RXh0cmFzID0gc2V0RXh0cmFzO1xuZXhwb3J0cy5zZXRUYWcgPSBzZXRUYWc7XG5leHBvcnRzLnNldFRhZ3MgPSBzZXRUYWdzO1xuZXhwb3J0cy5zZXRVc2VyID0gc2V0VXNlcjtcbmV4cG9ydHMuc3RhcnRTZXNzaW9uID0gc3RhcnRTZXNzaW9uO1xuZXhwb3J0cy53aXRoTW9uaXRvciA9IHdpdGhNb25pdG9yO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9ZXhwb3J0cy5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/exports.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/feedback.js":
/*!************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/feedback.js ***!
  \************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst currentScopes = __webpack_require__(/*! ./currentScopes.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\n\n/**\n * Send user feedback to Sentry.\n */\nfunction captureFeedback(\n  params,\n  hint = {},\n  scope = currentScopes.getCurrentScope(),\n) {\n  const { message, name, email, url, source, associatedEventId, tags } = params;\n\n  const feedbackEvent = {\n    contexts: {\n      feedback: {\n        contact_email: email,\n        name,\n        message,\n        url,\n        source,\n        associated_event_id: associatedEventId,\n      },\n    },\n    type: 'feedback',\n    level: 'info',\n    tags,\n  };\n\n  const client = scope?.getClient() || currentScopes.getClient();\n\n  if (client) {\n    client.emit('beforeSendFeedback', feedbackEvent, hint);\n  }\n\n  const eventId = scope.captureEvent(feedbackEvent, hint);\n\n  return eventId;\n}\n\nexports.captureFeedback = captureFeedback;\n//# sourceMappingURL=feedback.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvZmVlZGJhY2suanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsc0JBQXNCLG1CQUFPLENBQUMsc0lBQW9COztBQUVsRDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsV0FBVztBQUNYO0FBQ0E7QUFDQSxVQUFVLDZEQUE2RDs7QUFFdkU7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsT0FBTztBQUNQLEtBQUs7QUFDTDtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTs7QUFFQSx1QkFBdUI7QUFDdkIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9mZWVkYmFjay5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgY3VycmVudFNjb3BlcyA9IHJlcXVpcmUoJy4vY3VycmVudFNjb3Blcy5qcycpO1xuXG4vKipcbiAqIFNlbmQgdXNlciBmZWVkYmFjayB0byBTZW50cnkuXG4gKi9cbmZ1bmN0aW9uIGNhcHR1cmVGZWVkYmFjayhcbiAgcGFyYW1zLFxuICBoaW50ID0ge30sXG4gIHNjb3BlID0gY3VycmVudFNjb3Blcy5nZXRDdXJyZW50U2NvcGUoKSxcbikge1xuICBjb25zdCB7IG1lc3NhZ2UsIG5hbWUsIGVtYWlsLCB1cmwsIHNvdXJjZSwgYXNzb2NpYXRlZEV2ZW50SWQsIHRhZ3MgfSA9IHBhcmFtcztcblxuICBjb25zdCBmZWVkYmFja0V2ZW50ID0ge1xuICAgIGNvbnRleHRzOiB7XG4gICAgICBmZWVkYmFjazoge1xuICAgICAgICBjb250YWN0X2VtYWlsOiBlbWFpbCxcbiAgICAgICAgbmFtZSxcbiAgICAgICAgbWVzc2FnZSxcbiAgICAgICAgdXJsLFxuICAgICAgICBzb3VyY2UsXG4gICAgICAgIGFzc29jaWF0ZWRfZXZlbnRfaWQ6IGFzc29jaWF0ZWRFdmVudElkLFxuICAgICAgfSxcbiAgICB9LFxuICAgIHR5cGU6ICdmZWVkYmFjaycsXG4gICAgbGV2ZWw6ICdpbmZvJyxcbiAgICB0YWdzLFxuICB9O1xuXG4gIGNvbnN0IGNsaWVudCA9IHNjb3BlPy5nZXRDbGllbnQoKSB8fCBjdXJyZW50U2NvcGVzLmdldENsaWVudCgpO1xuXG4gIGlmIChjbGllbnQpIHtcbiAgICBjbGllbnQuZW1pdCgnYmVmb3JlU2VuZEZlZWRiYWNrJywgZmVlZGJhY2tFdmVudCwgaGludCk7XG4gIH1cblxuICBjb25zdCBldmVudElkID0gc2NvcGUuY2FwdHVyZUV2ZW50KGZlZWRiYWNrRXZlbnQsIGhpbnQpO1xuXG4gIHJldHVybiBldmVudElkO1xufVxuXG5leHBvcnRzLmNhcHR1cmVGZWVkYmFjayA9IGNhcHR1cmVGZWVkYmFjaztcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWZlZWRiYWNrLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/feedback.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/fetch.js":
/*!*********************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/fetch.js ***!
  \*********************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst currentScopes = __webpack_require__(/*! ./currentScopes.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst semanticAttributes = __webpack_require__(/*! ./semanticAttributes.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/semanticAttributes.js\");\nconst spanUtils = __webpack_require__(/*! ./utils/spanUtils.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanUtils.js\");\nconst spanstatus = __webpack_require__(/*! ./tracing/spanstatus.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/spanstatus.js\");\nconst is = __webpack_require__(/*! ./utils/is.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js\");\nconst hasSpansEnabled = __webpack_require__(/*! ./utils/hasSpansEnabled.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/hasSpansEnabled.js\");\nconst baggage = __webpack_require__(/*! ./utils/baggage.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/baggage.js\");\nconst sentryNonRecordingSpan = __webpack_require__(/*! ./tracing/sentryNonRecordingSpan.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/sentryNonRecordingSpan.js\");\nconst trace = __webpack_require__(/*! ./tracing/trace.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/trace.js\");\nconst traceData = __webpack_require__(/*! ./utils/traceData.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/traceData.js\");\nconst url = __webpack_require__(/*! ./utils/url.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/url.js\");\n\n/**\n * Create and track fetch request spans for usage in combination with `addFetchInstrumentationHandler`.\n *\n * @returns Span if a span was created, otherwise void.\n */\nfunction instrumentFetchRequest(\n  handlerData,\n  shouldCreateSpan,\n  shouldAttachHeaders,\n  spans,\n  spanOrigin = 'auto.http.browser',\n) {\n  if (!handlerData.fetchData) {\n    return undefined;\n  }\n\n  const { method, url } = handlerData.fetchData;\n\n  const shouldCreateSpanResult = hasSpansEnabled.hasSpansEnabled() && shouldCreateSpan(url);\n\n  if (handlerData.endTimestamp && shouldCreateSpanResult) {\n    const spanId = handlerData.fetchData.__span;\n    if (!spanId) return;\n\n    const span = spans[spanId];\n    if (span) {\n      endSpan(span, handlerData);\n\n      // eslint-disable-next-line @typescript-eslint/no-dynamic-delete\n      delete spans[spanId];\n    }\n    return undefined;\n  }\n\n  const hasParent = !!spanUtils.getActiveSpan();\n\n  const span =\n    shouldCreateSpanResult && hasParent\n      ? trace.startInactiveSpan(getSpanStartOptions(url, method, spanOrigin))\n      : new sentryNonRecordingSpan.SentryNonRecordingSpan();\n\n  handlerData.fetchData.__span = span.spanContext().spanId;\n  spans[span.spanContext().spanId] = span;\n\n  if (shouldAttachHeaders(handlerData.fetchData.url)) {\n    const request = handlerData.args[0];\n\n    const options = handlerData.args[1] || {};\n\n    const headers = _addTracingHeadersToFetchRequest(\n      request,\n      options,\n      // If performance is disabled (TWP) or there's no active root span (pageload/navigation/interaction),\n      // we do not want to use the span as base for the trace headers,\n      // which means that the headers will be generated from the scope and the sampling decision is deferred\n      hasSpansEnabled.hasSpansEnabled() && hasParent ? span : undefined,\n    );\n    if (headers) {\n      // Ensure this is actually set, if no options have been passed previously\n      handlerData.args[1] = options;\n      options.headers = headers;\n    }\n  }\n\n  const client = currentScopes.getClient();\n\n  if (client) {\n    const fetchHint = {\n      input: handlerData.args,\n      response: handlerData.response,\n      startTimestamp: handlerData.startTimestamp,\n      endTimestamp: handlerData.endTimestamp,\n    } ;\n\n    client.emit('beforeOutgoingRequestSpan', span, fetchHint);\n  }\n\n  return span;\n}\n\n/**\n * Adds sentry-trace and baggage headers to the various forms of fetch headers.\n * exported only for testing purposes\n *\n * When we determine if we should add a baggage header, there are 3 cases:\n * 1. No previous baggage header -> add baggage\n * 2. Previous baggage header has no sentry baggage values -> add our baggage\n * 3. Previous baggage header has sentry baggage values -> do nothing (might have been added manually by users)\n */\n// eslint-disable-next-line complexity -- yup it's this complicated :(\nfunction _addTracingHeadersToFetchRequest(\n  request,\n  fetchOptionsObj\n\n,\n  span,\n) {\n  const traceHeaders = traceData.getTraceData({ span });\n  const sentryTrace = traceHeaders['sentry-trace'];\n  const baggage = traceHeaders.baggage;\n\n  // Nothing to do, when we return undefined here, the original headers will be used\n  if (!sentryTrace) {\n    return undefined;\n  }\n\n  const originalHeaders = fetchOptionsObj.headers || (is.isRequest(request) ? request.headers : undefined);\n\n  if (!originalHeaders) {\n    return { ...traceHeaders };\n  } else if (isHeaders(originalHeaders)) {\n    const newHeaders = new Headers(originalHeaders);\n\n    // We don't want to override manually added sentry headers\n    if (!newHeaders.get('sentry-trace')) {\n      newHeaders.set('sentry-trace', sentryTrace);\n    }\n\n    if (baggage) {\n      const prevBaggageHeader = newHeaders.get('baggage');\n\n      if (!prevBaggageHeader) {\n        newHeaders.set('baggage', baggage);\n      } else if (!baggageHeaderHasSentryBaggageValues(prevBaggageHeader)) {\n        newHeaders.set('baggage', `${prevBaggageHeader},${baggage}`);\n      }\n    }\n\n    return newHeaders;\n  } else if (Array.isArray(originalHeaders)) {\n    const newHeaders = [...originalHeaders];\n\n    if (!originalHeaders.find(header => header[0] === 'sentry-trace')) {\n      newHeaders.push(['sentry-trace', sentryTrace]);\n    }\n\n    const prevBaggageHeaderWithSentryValues = originalHeaders.find(\n      header => header[0] === 'baggage' && baggageHeaderHasSentryBaggageValues(header[1]),\n    );\n\n    if (baggage && !prevBaggageHeaderWithSentryValues) {\n      // If there are multiple entries with the same key, the browser will merge the values into a single request header.\n      // Its therefore safe to simply push a \"baggage\" entry, even though there might already be another baggage header.\n      newHeaders.push(['baggage', baggage]);\n    }\n\n    return newHeaders ;\n  } else {\n    const existingSentryTraceHeader = 'sentry-trace' in originalHeaders ? originalHeaders['sentry-trace'] : undefined;\n\n    const existingBaggageHeader = 'baggage' in originalHeaders ? originalHeaders.baggage : undefined;\n    const newBaggageHeaders = existingBaggageHeader\n      ? Array.isArray(existingBaggageHeader)\n        ? [...existingBaggageHeader]\n        : [existingBaggageHeader]\n      : [];\n\n    const prevBaggageHeaderWithSentryValues =\n      existingBaggageHeader &&\n      (Array.isArray(existingBaggageHeader)\n        ? existingBaggageHeader.find(headerItem => baggageHeaderHasSentryBaggageValues(headerItem))\n        : baggageHeaderHasSentryBaggageValues(existingBaggageHeader));\n\n    if (baggage && !prevBaggageHeaderWithSentryValues) {\n      newBaggageHeaders.push(baggage);\n    }\n\n    return {\n      ...(originalHeaders ),\n      'sentry-trace': (existingSentryTraceHeader ) ?? sentryTrace,\n      baggage: newBaggageHeaders.length > 0 ? newBaggageHeaders.join(',') : undefined,\n    };\n  }\n}\n\nfunction endSpan(span, handlerData) {\n  if (handlerData.response) {\n    spanstatus.setHttpStatus(span, handlerData.response.status);\n\n    const contentLength = handlerData.response?.headers?.get('content-length');\n\n    if (contentLength) {\n      const contentLengthNum = parseInt(contentLength);\n      if (contentLengthNum > 0) {\n        span.setAttribute('http.response_content_length', contentLengthNum);\n      }\n    }\n  } else if (handlerData.error) {\n    span.setStatus({ code: spanstatus.SPAN_STATUS_ERROR, message: 'internal_error' });\n  }\n  span.end();\n}\n\nfunction baggageHeaderHasSentryBaggageValues(baggageHeader) {\n  return baggageHeader.split(',').some(baggageEntry => baggageEntry.trim().startsWith(baggage.SENTRY_BAGGAGE_KEY_PREFIX));\n}\n\nfunction isHeaders(headers) {\n  return typeof Headers !== 'undefined' && is.isInstanceOf(headers, Headers);\n}\n\nfunction getSpanStartOptions(\n  url$1,\n  method,\n  spanOrigin,\n) {\n  const parsedUrl = url.parseStringToURLObject(url$1);\n  return {\n    name: parsedUrl ? `${method} ${url.getSanitizedUrlStringFromUrlObject(parsedUrl)}` : method,\n    attributes: getFetchSpanAttributes(url$1, parsedUrl, method, spanOrigin),\n  };\n}\n\nfunction getFetchSpanAttributes(\n  url$1,\n  parsedUrl,\n  method,\n  spanOrigin,\n) {\n  const attributes = {\n    url: url$1,\n    type: 'fetch',\n    'http.method': method,\n    [semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_ORIGIN]: spanOrigin,\n    [semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_OP]: 'http.client',\n  };\n  if (parsedUrl) {\n    if (!url.isURLObjectRelative(parsedUrl)) {\n      attributes['http.url'] = parsedUrl.href;\n      attributes['server.address'] = parsedUrl.host;\n    }\n    if (parsedUrl.search) {\n      attributes['http.query'] = parsedUrl.search;\n    }\n    if (parsedUrl.hash) {\n      attributes['http.fragment'] = parsedUrl.hash;\n    }\n  }\n  return attributes;\n}\n\nexports._addTracingHeadersToFetchRequest = _addTracingHeadersToFetchRequest;\nexports.instrumentFetchRequest = instrumentFetchRequest;\n//# sourceMappingURL=fetch.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvZmV0Y2guanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsc0JBQXNCLG1CQUFPLENBQUMsc0lBQW9CO0FBQ2xELDJCQUEyQixtQkFBTyxDQUFDLGdKQUF5QjtBQUM1RCxrQkFBa0IsbUJBQU8sQ0FBQywwSUFBc0I7QUFDaEQsbUJBQW1CLG1CQUFPLENBQUMsZ0pBQXlCO0FBQ3BELFdBQVcsbUJBQU8sQ0FBQyw0SEFBZTtBQUNsQyx3QkFBd0IsbUJBQU8sQ0FBQyxzSkFBNEI7QUFDNUQsZ0JBQWdCLG1CQUFPLENBQUMsc0lBQW9CO0FBQzVDLCtCQUErQixtQkFBTyxDQUFDLHdLQUFxQztBQUM1RSxjQUFjLG1CQUFPLENBQUMsc0lBQW9CO0FBQzFDLGtCQUFrQixtQkFBTyxDQUFDLDBJQUFzQjtBQUNoRCxZQUFZLG1CQUFPLENBQUMsOEhBQWdCOztBQUVwQztBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsVUFBVSxjQUFjOztBQUV4Qjs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBLGdEQUFnRCxNQUFNO0FBQ3REO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQSxhQUFhO0FBQ2IsSUFBSTtBQUNKOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLFFBQVE7QUFDUixxQ0FBcUMsa0JBQWtCLEdBQUcsUUFBUTtBQUNsRTtBQUNBOztBQUVBO0FBQ0EsSUFBSTtBQUNKOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBLElBQUk7QUFDSjs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLElBQUk7QUFDSixxQkFBcUIsK0RBQStEO0FBQ3BGO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EseUJBQXlCLFFBQVEsRUFBRSxrREFBa0Q7QUFDckY7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSx3Q0FBd0M7QUFDeEMsOEJBQThCO0FBQzlCIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvZmV0Y2guanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGN1cnJlbnRTY29wZXMgPSByZXF1aXJlKCcuL2N1cnJlbnRTY29wZXMuanMnKTtcbmNvbnN0IHNlbWFudGljQXR0cmlidXRlcyA9IHJlcXVpcmUoJy4vc2VtYW50aWNBdHRyaWJ1dGVzLmpzJyk7XG5jb25zdCBzcGFuVXRpbHMgPSByZXF1aXJlKCcuL3V0aWxzL3NwYW5VdGlscy5qcycpO1xuY29uc3Qgc3BhbnN0YXR1cyA9IHJlcXVpcmUoJy4vdHJhY2luZy9zcGFuc3RhdHVzLmpzJyk7XG5jb25zdCBpcyA9IHJlcXVpcmUoJy4vdXRpbHMvaXMuanMnKTtcbmNvbnN0IGhhc1NwYW5zRW5hYmxlZCA9IHJlcXVpcmUoJy4vdXRpbHMvaGFzU3BhbnNFbmFibGVkLmpzJyk7XG5jb25zdCBiYWdnYWdlID0gcmVxdWlyZSgnLi91dGlscy9iYWdnYWdlLmpzJyk7XG5jb25zdCBzZW50cnlOb25SZWNvcmRpbmdTcGFuID0gcmVxdWlyZSgnLi90cmFjaW5nL3NlbnRyeU5vblJlY29yZGluZ1NwYW4uanMnKTtcbmNvbnN0IHRyYWNlID0gcmVxdWlyZSgnLi90cmFjaW5nL3RyYWNlLmpzJyk7XG5jb25zdCB0cmFjZURhdGEgPSByZXF1aXJlKCcuL3V0aWxzL3RyYWNlRGF0YS5qcycpO1xuY29uc3QgdXJsID0gcmVxdWlyZSgnLi91dGlscy91cmwuanMnKTtcblxuLyoqXG4gKiBDcmVhdGUgYW5kIHRyYWNrIGZldGNoIHJlcXVlc3Qgc3BhbnMgZm9yIHVzYWdlIGluIGNvbWJpbmF0aW9uIHdpdGggYGFkZEZldGNoSW5zdHJ1bWVudGF0aW9uSGFuZGxlcmAuXG4gKlxuICogQHJldHVybnMgU3BhbiBpZiBhIHNwYW4gd2FzIGNyZWF0ZWQsIG90aGVyd2lzZSB2b2lkLlxuICovXG5mdW5jdGlvbiBpbnN0cnVtZW50RmV0Y2hSZXF1ZXN0KFxuICBoYW5kbGVyRGF0YSxcbiAgc2hvdWxkQ3JlYXRlU3BhbixcbiAgc2hvdWxkQXR0YWNoSGVhZGVycyxcbiAgc3BhbnMsXG4gIHNwYW5PcmlnaW4gPSAnYXV0by5odHRwLmJyb3dzZXInLFxuKSB7XG4gIGlmICghaGFuZGxlckRhdGEuZmV0Y2hEYXRhKSB7XG4gICAgcmV0dXJuIHVuZGVmaW5lZDtcbiAgfVxuXG4gIGNvbnN0IHsgbWV0aG9kLCB1cmwgfSA9IGhhbmRsZXJEYXRhLmZldGNoRGF0YTtcblxuICBjb25zdCBzaG91bGRDcmVhdGVTcGFuUmVzdWx0ID0gaGFzU3BhbnNFbmFibGVkLmhhc1NwYW5zRW5hYmxlZCgpICYmIHNob3VsZENyZWF0ZVNwYW4odXJsKTtcblxuICBpZiAoaGFuZGxlckRhdGEuZW5kVGltZXN0YW1wICYmIHNob3VsZENyZWF0ZVNwYW5SZXN1bHQpIHtcbiAgICBjb25zdCBzcGFuSWQgPSBoYW5kbGVyRGF0YS5mZXRjaERhdGEuX19zcGFuO1xuICAgIGlmICghc3BhbklkKSByZXR1cm47XG5cbiAgICBjb25zdCBzcGFuID0gc3BhbnNbc3BhbklkXTtcbiAgICBpZiAoc3Bhbikge1xuICAgICAgZW5kU3BhbihzcGFuLCBoYW5kbGVyRGF0YSk7XG5cbiAgICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tZHluYW1pYy1kZWxldGVcbiAgICAgIGRlbGV0ZSBzcGFuc1tzcGFuSWRdO1xuICAgIH1cbiAgICByZXR1cm4gdW5kZWZpbmVkO1xuICB9XG5cbiAgY29uc3QgaGFzUGFyZW50ID0gISFzcGFuVXRpbHMuZ2V0QWN0aXZlU3BhbigpO1xuXG4gIGNvbnN0IHNwYW4gPVxuICAgIHNob3VsZENyZWF0ZVNwYW5SZXN1bHQgJiYgaGFzUGFyZW50XG4gICAgICA/IHRyYWNlLnN0YXJ0SW5hY3RpdmVTcGFuKGdldFNwYW5TdGFydE9wdGlvbnModXJsLCBtZXRob2QsIHNwYW5PcmlnaW4pKVxuICAgICAgOiBuZXcgc2VudHJ5Tm9uUmVjb3JkaW5nU3Bhbi5TZW50cnlOb25SZWNvcmRpbmdTcGFuKCk7XG5cbiAgaGFuZGxlckRhdGEuZmV0Y2hEYXRhLl9fc3BhbiA9IHNwYW4uc3BhbkNvbnRleHQoKS5zcGFuSWQ7XG4gIHNwYW5zW3NwYW4uc3BhbkNvbnRleHQoKS5zcGFuSWRdID0gc3BhbjtcblxuICBpZiAoc2hvdWxkQXR0YWNoSGVhZGVycyhoYW5kbGVyRGF0YS5mZXRjaERhdGEudXJsKSkge1xuICAgIGNvbnN0IHJlcXVlc3QgPSBoYW5kbGVyRGF0YS5hcmdzWzBdO1xuXG4gICAgY29uc3Qgb3B0aW9ucyA9IGhhbmRsZXJEYXRhLmFyZ3NbMV0gfHwge307XG5cbiAgICBjb25zdCBoZWFkZXJzID0gX2FkZFRyYWNpbmdIZWFkZXJzVG9GZXRjaFJlcXVlc3QoXG4gICAgICByZXF1ZXN0LFxuICAgICAgb3B0aW9ucyxcbiAgICAgIC8vIElmIHBlcmZvcm1hbmNlIGlzIGRpc2FibGVkIChUV1ApIG9yIHRoZXJlJ3Mgbm8gYWN0aXZlIHJvb3Qgc3BhbiAocGFnZWxvYWQvbmF2aWdhdGlvbi9pbnRlcmFjdGlvbiksXG4gICAgICAvLyB3ZSBkbyBub3Qgd2FudCB0byB1c2UgdGhlIHNwYW4gYXMgYmFzZSBmb3IgdGhlIHRyYWNlIGhlYWRlcnMsXG4gICAgICAvLyB3aGljaCBtZWFucyB0aGF0IHRoZSBoZWFkZXJzIHdpbGwgYmUgZ2VuZXJhdGVkIGZyb20gdGhlIHNjb3BlIGFuZCB0aGUgc2FtcGxpbmcgZGVjaXNpb24gaXMgZGVmZXJyZWRcbiAgICAgIGhhc1NwYW5zRW5hYmxlZC5oYXNTcGFuc0VuYWJsZWQoKSAmJiBoYXNQYXJlbnQgPyBzcGFuIDogdW5kZWZpbmVkLFxuICAgICk7XG4gICAgaWYgKGhlYWRlcnMpIHtcbiAgICAgIC8vIEVuc3VyZSB0aGlzIGlzIGFjdHVhbGx5IHNldCwgaWYgbm8gb3B0aW9ucyBoYXZlIGJlZW4gcGFzc2VkIHByZXZpb3VzbHlcbiAgICAgIGhhbmRsZXJEYXRhLmFyZ3NbMV0gPSBvcHRpb25zO1xuICAgICAgb3B0aW9ucy5oZWFkZXJzID0gaGVhZGVycztcbiAgICB9XG4gIH1cblxuICBjb25zdCBjbGllbnQgPSBjdXJyZW50U2NvcGVzLmdldENsaWVudCgpO1xuXG4gIGlmIChjbGllbnQpIHtcbiAgICBjb25zdCBmZXRjaEhpbnQgPSB7XG4gICAgICBpbnB1dDogaGFuZGxlckRhdGEuYXJncyxcbiAgICAgIHJlc3BvbnNlOiBoYW5kbGVyRGF0YS5yZXNwb25zZSxcbiAgICAgIHN0YXJ0VGltZXN0YW1wOiBoYW5kbGVyRGF0YS5zdGFydFRpbWVzdGFtcCxcbiAgICAgIGVuZFRpbWVzdGFtcDogaGFuZGxlckRhdGEuZW5kVGltZXN0YW1wLFxuICAgIH0gO1xuXG4gICAgY2xpZW50LmVtaXQoJ2JlZm9yZU91dGdvaW5nUmVxdWVzdFNwYW4nLCBzcGFuLCBmZXRjaEhpbnQpO1xuICB9XG5cbiAgcmV0dXJuIHNwYW47XG59XG5cbi8qKlxuICogQWRkcyBzZW50cnktdHJhY2UgYW5kIGJhZ2dhZ2UgaGVhZGVycyB0byB0aGUgdmFyaW91cyBmb3JtcyBvZiBmZXRjaCBoZWFkZXJzLlxuICogZXhwb3J0ZWQgb25seSBmb3IgdGVzdGluZyBwdXJwb3Nlc1xuICpcbiAqIFdoZW4gd2UgZGV0ZXJtaW5lIGlmIHdlIHNob3VsZCBhZGQgYSBiYWdnYWdlIGhlYWRlciwgdGhlcmUgYXJlIDMgY2FzZXM6XG4gKiAxLiBObyBwcmV2aW91cyBiYWdnYWdlIGhlYWRlciAtPiBhZGQgYmFnZ2FnZVxuICogMi4gUHJldmlvdXMgYmFnZ2FnZSBoZWFkZXIgaGFzIG5vIHNlbnRyeSBiYWdnYWdlIHZhbHVlcyAtPiBhZGQgb3VyIGJhZ2dhZ2VcbiAqIDMuIFByZXZpb3VzIGJhZ2dhZ2UgaGVhZGVyIGhhcyBzZW50cnkgYmFnZ2FnZSB2YWx1ZXMgLT4gZG8gbm90aGluZyAobWlnaHQgaGF2ZSBiZWVuIGFkZGVkIG1hbnVhbGx5IGJ5IHVzZXJzKVxuICovXG4vLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgY29tcGxleGl0eSAtLSB5dXAgaXQncyB0aGlzIGNvbXBsaWNhdGVkIDooXG5mdW5jdGlvbiBfYWRkVHJhY2luZ0hlYWRlcnNUb0ZldGNoUmVxdWVzdChcbiAgcmVxdWVzdCxcbiAgZmV0Y2hPcHRpb25zT2JqXG5cbixcbiAgc3Bhbixcbikge1xuICBjb25zdCB0cmFjZUhlYWRlcnMgPSB0cmFjZURhdGEuZ2V0VHJhY2VEYXRhKHsgc3BhbiB9KTtcbiAgY29uc3Qgc2VudHJ5VHJhY2UgPSB0cmFjZUhlYWRlcnNbJ3NlbnRyeS10cmFjZSddO1xuICBjb25zdCBiYWdnYWdlID0gdHJhY2VIZWFkZXJzLmJhZ2dhZ2U7XG5cbiAgLy8gTm90aGluZyB0byBkbywgd2hlbiB3ZSByZXR1cm4gdW5kZWZpbmVkIGhlcmUsIHRoZSBvcmlnaW5hbCBoZWFkZXJzIHdpbGwgYmUgdXNlZFxuICBpZiAoIXNlbnRyeVRyYWNlKSB7XG4gICAgcmV0dXJuIHVuZGVmaW5lZDtcbiAgfVxuXG4gIGNvbnN0IG9yaWdpbmFsSGVhZGVycyA9IGZldGNoT3B0aW9uc09iai5oZWFkZXJzIHx8IChpcy5pc1JlcXVlc3QocmVxdWVzdCkgPyByZXF1ZXN0LmhlYWRlcnMgOiB1bmRlZmluZWQpO1xuXG4gIGlmICghb3JpZ2luYWxIZWFkZXJzKSB7XG4gICAgcmV0dXJuIHsgLi4udHJhY2VIZWFkZXJzIH07XG4gIH0gZWxzZSBpZiAoaXNIZWFkZXJzKG9yaWdpbmFsSGVhZGVycykpIHtcbiAgICBjb25zdCBuZXdIZWFkZXJzID0gbmV3IEhlYWRlcnMob3JpZ2luYWxIZWFkZXJzKTtcblxuICAgIC8vIFdlIGRvbid0IHdhbnQgdG8gb3ZlcnJpZGUgbWFudWFsbHkgYWRkZWQgc2VudHJ5IGhlYWRlcnNcbiAgICBpZiAoIW5ld0hlYWRlcnMuZ2V0KCdzZW50cnktdHJhY2UnKSkge1xuICAgICAgbmV3SGVhZGVycy5zZXQoJ3NlbnRyeS10cmFjZScsIHNlbnRyeVRyYWNlKTtcbiAgICB9XG5cbiAgICBpZiAoYmFnZ2FnZSkge1xuICAgICAgY29uc3QgcHJldkJhZ2dhZ2VIZWFkZXIgPSBuZXdIZWFkZXJzLmdldCgnYmFnZ2FnZScpO1xuXG4gICAgICBpZiAoIXByZXZCYWdnYWdlSGVhZGVyKSB7XG4gICAgICAgIG5ld0hlYWRlcnMuc2V0KCdiYWdnYWdlJywgYmFnZ2FnZSk7XG4gICAgICB9IGVsc2UgaWYgKCFiYWdnYWdlSGVhZGVySGFzU2VudHJ5QmFnZ2FnZVZhbHVlcyhwcmV2QmFnZ2FnZUhlYWRlcikpIHtcbiAgICAgICAgbmV3SGVhZGVycy5zZXQoJ2JhZ2dhZ2UnLCBgJHtwcmV2QmFnZ2FnZUhlYWRlcn0sJHtiYWdnYWdlfWApO1xuICAgICAgfVxuICAgIH1cblxuICAgIHJldHVybiBuZXdIZWFkZXJzO1xuICB9IGVsc2UgaWYgKEFycmF5LmlzQXJyYXkob3JpZ2luYWxIZWFkZXJzKSkge1xuICAgIGNvbnN0IG5ld0hlYWRlcnMgPSBbLi4ub3JpZ2luYWxIZWFkZXJzXTtcblxuICAgIGlmICghb3JpZ2luYWxIZWFkZXJzLmZpbmQoaGVhZGVyID0+IGhlYWRlclswXSA9PT0gJ3NlbnRyeS10cmFjZScpKSB7XG4gICAgICBuZXdIZWFkZXJzLnB1c2goWydzZW50cnktdHJhY2UnLCBzZW50cnlUcmFjZV0pO1xuICAgIH1cblxuICAgIGNvbnN0IHByZXZCYWdnYWdlSGVhZGVyV2l0aFNlbnRyeVZhbHVlcyA9IG9yaWdpbmFsSGVhZGVycy5maW5kKFxuICAgICAgaGVhZGVyID0+IGhlYWRlclswXSA9PT0gJ2JhZ2dhZ2UnICYmIGJhZ2dhZ2VIZWFkZXJIYXNTZW50cnlCYWdnYWdlVmFsdWVzKGhlYWRlclsxXSksXG4gICAgKTtcblxuICAgIGlmIChiYWdnYWdlICYmICFwcmV2QmFnZ2FnZUhlYWRlcldpdGhTZW50cnlWYWx1ZXMpIHtcbiAgICAgIC8vIElmIHRoZXJlIGFyZSBtdWx0aXBsZSBlbnRyaWVzIHdpdGggdGhlIHNhbWUga2V5LCB0aGUgYnJvd3NlciB3aWxsIG1lcmdlIHRoZSB2YWx1ZXMgaW50byBhIHNpbmdsZSByZXF1ZXN0IGhlYWRlci5cbiAgICAgIC8vIEl0cyB0aGVyZWZvcmUgc2FmZSB0byBzaW1wbHkgcHVzaCBhIFwiYmFnZ2FnZVwiIGVudHJ5LCBldmVuIHRob3VnaCB0aGVyZSBtaWdodCBhbHJlYWR5IGJlIGFub3RoZXIgYmFnZ2FnZSBoZWFkZXIuXG4gICAgICBuZXdIZWFkZXJzLnB1c2goWydiYWdnYWdlJywgYmFnZ2FnZV0pO1xuICAgIH1cblxuICAgIHJldHVybiBuZXdIZWFkZXJzIDtcbiAgfSBlbHNlIHtcbiAgICBjb25zdCBleGlzdGluZ1NlbnRyeVRyYWNlSGVhZGVyID0gJ3NlbnRyeS10cmFjZScgaW4gb3JpZ2luYWxIZWFkZXJzID8gb3JpZ2luYWxIZWFkZXJzWydzZW50cnktdHJhY2UnXSA6IHVuZGVmaW5lZDtcblxuICAgIGNvbnN0IGV4aXN0aW5nQmFnZ2FnZUhlYWRlciA9ICdiYWdnYWdlJyBpbiBvcmlnaW5hbEhlYWRlcnMgPyBvcmlnaW5hbEhlYWRlcnMuYmFnZ2FnZSA6IHVuZGVmaW5lZDtcbiAgICBjb25zdCBuZXdCYWdnYWdlSGVhZGVycyA9IGV4aXN0aW5nQmFnZ2FnZUhlYWRlclxuICAgICAgPyBBcnJheS5pc0FycmF5KGV4aXN0aW5nQmFnZ2FnZUhlYWRlcilcbiAgICAgICAgPyBbLi4uZXhpc3RpbmdCYWdnYWdlSGVhZGVyXVxuICAgICAgICA6IFtleGlzdGluZ0JhZ2dhZ2VIZWFkZXJdXG4gICAgICA6IFtdO1xuXG4gICAgY29uc3QgcHJldkJhZ2dhZ2VIZWFkZXJXaXRoU2VudHJ5VmFsdWVzID1cbiAgICAgIGV4aXN0aW5nQmFnZ2FnZUhlYWRlciAmJlxuICAgICAgKEFycmF5LmlzQXJyYXkoZXhpc3RpbmdCYWdnYWdlSGVhZGVyKVxuICAgICAgICA/IGV4aXN0aW5nQmFnZ2FnZUhlYWRlci5maW5kKGhlYWRlckl0ZW0gPT4gYmFnZ2FnZUhlYWRlckhhc1NlbnRyeUJhZ2dhZ2VWYWx1ZXMoaGVhZGVySXRlbSkpXG4gICAgICAgIDogYmFnZ2FnZUhlYWRlckhhc1NlbnRyeUJhZ2dhZ2VWYWx1ZXMoZXhpc3RpbmdCYWdnYWdlSGVhZGVyKSk7XG5cbiAgICBpZiAoYmFnZ2FnZSAmJiAhcHJldkJhZ2dhZ2VIZWFkZXJXaXRoU2VudHJ5VmFsdWVzKSB7XG4gICAgICBuZXdCYWdnYWdlSGVhZGVycy5wdXNoKGJhZ2dhZ2UpO1xuICAgIH1cblxuICAgIHJldHVybiB7XG4gICAgICAuLi4ob3JpZ2luYWxIZWFkZXJzICksXG4gICAgICAnc2VudHJ5LXRyYWNlJzogKGV4aXN0aW5nU2VudHJ5VHJhY2VIZWFkZXIgKSA/PyBzZW50cnlUcmFjZSxcbiAgICAgIGJhZ2dhZ2U6IG5ld0JhZ2dhZ2VIZWFkZXJzLmxlbmd0aCA+IDAgPyBuZXdCYWdnYWdlSGVhZGVycy5qb2luKCcsJykgOiB1bmRlZmluZWQsXG4gICAgfTtcbiAgfVxufVxuXG5mdW5jdGlvbiBlbmRTcGFuKHNwYW4sIGhhbmRsZXJEYXRhKSB7XG4gIGlmIChoYW5kbGVyRGF0YS5yZXNwb25zZSkge1xuICAgIHNwYW5zdGF0dXMuc2V0SHR0cFN0YXR1cyhzcGFuLCBoYW5kbGVyRGF0YS5yZXNwb25zZS5zdGF0dXMpO1xuXG4gICAgY29uc3QgY29udGVudExlbmd0aCA9IGhhbmRsZXJEYXRhLnJlc3BvbnNlPy5oZWFkZXJzPy5nZXQoJ2NvbnRlbnQtbGVuZ3RoJyk7XG5cbiAgICBpZiAoY29udGVudExlbmd0aCkge1xuICAgICAgY29uc3QgY29udGVudExlbmd0aE51bSA9IHBhcnNlSW50KGNvbnRlbnRMZW5ndGgpO1xuICAgICAgaWYgKGNvbnRlbnRMZW5ndGhOdW0gPiAwKSB7XG4gICAgICAgIHNwYW4uc2V0QXR0cmlidXRlKCdodHRwLnJlc3BvbnNlX2NvbnRlbnRfbGVuZ3RoJywgY29udGVudExlbmd0aE51bSk7XG4gICAgICB9XG4gICAgfVxuICB9IGVsc2UgaWYgKGhhbmRsZXJEYXRhLmVycm9yKSB7XG4gICAgc3Bhbi5zZXRTdGF0dXMoeyBjb2RlOiBzcGFuc3RhdHVzLlNQQU5fU1RBVFVTX0VSUk9SLCBtZXNzYWdlOiAnaW50ZXJuYWxfZXJyb3InIH0pO1xuICB9XG4gIHNwYW4uZW5kKCk7XG59XG5cbmZ1bmN0aW9uIGJhZ2dhZ2VIZWFkZXJIYXNTZW50cnlCYWdnYWdlVmFsdWVzKGJhZ2dhZ2VIZWFkZXIpIHtcbiAgcmV0dXJuIGJhZ2dhZ2VIZWFkZXIuc3BsaXQoJywnKS5zb21lKGJhZ2dhZ2VFbnRyeSA9PiBiYWdnYWdlRW50cnkudHJpbSgpLnN0YXJ0c1dpdGgoYmFnZ2FnZS5TRU5UUllfQkFHR0FHRV9LRVlfUFJFRklYKSk7XG59XG5cbmZ1bmN0aW9uIGlzSGVhZGVycyhoZWFkZXJzKSB7XG4gIHJldHVybiB0eXBlb2YgSGVhZGVycyAhPT0gJ3VuZGVmaW5lZCcgJiYgaXMuaXNJbnN0YW5jZU9mKGhlYWRlcnMsIEhlYWRlcnMpO1xufVxuXG5mdW5jdGlvbiBnZXRTcGFuU3RhcnRPcHRpb25zKFxuICB1cmwkMSxcbiAgbWV0aG9kLFxuICBzcGFuT3JpZ2luLFxuKSB7XG4gIGNvbnN0IHBhcnNlZFVybCA9IHVybC5wYXJzZVN0cmluZ1RvVVJMT2JqZWN0KHVybCQxKTtcbiAgcmV0dXJuIHtcbiAgICBuYW1lOiBwYXJzZWRVcmwgPyBgJHttZXRob2R9ICR7dXJsLmdldFNhbml0aXplZFVybFN0cmluZ0Zyb21VcmxPYmplY3QocGFyc2VkVXJsKX1gIDogbWV0aG9kLFxuICAgIGF0dHJpYnV0ZXM6IGdldEZldGNoU3BhbkF0dHJpYnV0ZXModXJsJDEsIHBhcnNlZFVybCwgbWV0aG9kLCBzcGFuT3JpZ2luKSxcbiAgfTtcbn1cblxuZnVuY3Rpb24gZ2V0RmV0Y2hTcGFuQXR0cmlidXRlcyhcbiAgdXJsJDEsXG4gIHBhcnNlZFVybCxcbiAgbWV0aG9kLFxuICBzcGFuT3JpZ2luLFxuKSB7XG4gIGNvbnN0IGF0dHJpYnV0ZXMgPSB7XG4gICAgdXJsOiB1cmwkMSxcbiAgICB0eXBlOiAnZmV0Y2gnLFxuICAgICdodHRwLm1ldGhvZCc6IG1ldGhvZCxcbiAgICBbc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfT1JJR0lOXTogc3Bhbk9yaWdpbixcbiAgICBbc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfT1BdOiAnaHR0cC5jbGllbnQnLFxuICB9O1xuICBpZiAocGFyc2VkVXJsKSB7XG4gICAgaWYgKCF1cmwuaXNVUkxPYmplY3RSZWxhdGl2ZShwYXJzZWRVcmwpKSB7XG4gICAgICBhdHRyaWJ1dGVzWydodHRwLnVybCddID0gcGFyc2VkVXJsLmhyZWY7XG4gICAgICBhdHRyaWJ1dGVzWydzZXJ2ZXIuYWRkcmVzcyddID0gcGFyc2VkVXJsLmhvc3Q7XG4gICAgfVxuICAgIGlmIChwYXJzZWRVcmwuc2VhcmNoKSB7XG4gICAgICBhdHRyaWJ1dGVzWydodHRwLnF1ZXJ5J10gPSBwYXJzZWRVcmwuc2VhcmNoO1xuICAgIH1cbiAgICBpZiAocGFyc2VkVXJsLmhhc2gpIHtcbiAgICAgIGF0dHJpYnV0ZXNbJ2h0dHAuZnJhZ21lbnQnXSA9IHBhcnNlZFVybC5oYXNoO1xuICAgIH1cbiAgfVxuICByZXR1cm4gYXR0cmlidXRlcztcbn1cblxuZXhwb3J0cy5fYWRkVHJhY2luZ0hlYWRlcnNUb0ZldGNoUmVxdWVzdCA9IF9hZGRUcmFjaW5nSGVhZGVyc1RvRmV0Y2hSZXF1ZXN0O1xuZXhwb3J0cy5pbnN0cnVtZW50RmV0Y2hSZXF1ZXN0ID0gaW5zdHJ1bWVudEZldGNoUmVxdWVzdDtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWZldGNoLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/fetch.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/index.js":
/*!*********************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/index.js ***!
  \*********************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst errors = __webpack_require__(/*! ./tracing/errors.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/errors.js\");\nconst utils = __webpack_require__(/*! ./tracing/utils.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/utils.js\");\nconst idleSpan = __webpack_require__(/*! ./tracing/idleSpan.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/idleSpan.js\");\nconst sentrySpan = __webpack_require__(/*! ./tracing/sentrySpan.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/sentrySpan.js\");\nconst sentryNonRecordingSpan = __webpack_require__(/*! ./tracing/sentryNonRecordingSpan.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/sentryNonRecordingSpan.js\");\nconst spanstatus = __webpack_require__(/*! ./tracing/spanstatus.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/spanstatus.js\");\nconst trace = __webpack_require__(/*! ./tracing/trace.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/trace.js\");\nconst dynamicSamplingContext = __webpack_require__(/*! ./tracing/dynamicSamplingContext.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/dynamicSamplingContext.js\");\nconst measurement = __webpack_require__(/*! ./tracing/measurement.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/measurement.js\");\nconst sampling = __webpack_require__(/*! ./tracing/sampling.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/sampling.js\");\nconst logSpans = __webpack_require__(/*! ./tracing/logSpans.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/logSpans.js\");\nconst semanticAttributes = __webpack_require__(/*! ./semanticAttributes.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/semanticAttributes.js\");\nconst envelope = __webpack_require__(/*! ./envelope.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/envelope.js\");\nconst exports$1 = __webpack_require__(/*! ./exports.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/exports.js\");\nconst currentScopes = __webpack_require__(/*! ./currentScopes.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst defaultScopes = __webpack_require__(/*! ./defaultScopes.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/defaultScopes.js\");\nconst index = __webpack_require__(/*! ./asyncContext/index.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/asyncContext/index.js\");\nconst carrier = __webpack_require__(/*! ./carrier.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/carrier.js\");\nconst session = __webpack_require__(/*! ./session.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/session.js\");\nconst scope = __webpack_require__(/*! ./scope.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/scope.js\");\nconst eventProcessors = __webpack_require__(/*! ./eventProcessors.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/eventProcessors.js\");\nconst api = __webpack_require__(/*! ./api.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/api.js\");\nconst client = __webpack_require__(/*! ./client.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/client.js\");\nconst serverRuntimeClient = __webpack_require__(/*! ./server-runtime-client.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/server-runtime-client.js\");\nconst sdk = __webpack_require__(/*! ./sdk.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/sdk.js\");\nconst base = __webpack_require__(/*! ./transports/base.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/transports/base.js\");\nconst offline = __webpack_require__(/*! ./transports/offline.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/transports/offline.js\");\nconst multiplexed = __webpack_require__(/*! ./transports/multiplexed.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/transports/multiplexed.js\");\nconst integration = __webpack_require__(/*! ./integration.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integration.js\");\nconst applyScopeDataToEvent = __webpack_require__(/*! ./utils/applyScopeDataToEvent.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/applyScopeDataToEvent.js\");\nconst prepareEvent = __webpack_require__(/*! ./utils/prepareEvent.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/prepareEvent.js\");\nconst checkin = __webpack_require__(/*! ./checkin.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/checkin.js\");\nconst hasSpansEnabled = __webpack_require__(/*! ./utils/hasSpansEnabled.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/hasSpansEnabled.js\");\nconst isSentryRequestUrl = __webpack_require__(/*! ./utils/isSentryRequestUrl.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/isSentryRequestUrl.js\");\nconst handleCallbackErrors = __webpack_require__(/*! ./utils/handleCallbackErrors.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/handleCallbackErrors.js\");\nconst parameterize = __webpack_require__(/*! ./utils/parameterize.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/parameterize.js\");\nconst ipAddress = __webpack_require__(/*! ./utils/ipAddress.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/ipAddress.js\");\nconst spanUtils = __webpack_require__(/*! ./utils/spanUtils.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanUtils.js\");\nconst parseSampleRate = __webpack_require__(/*! ./utils/parseSampleRate.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/parseSampleRate.js\");\nconst sdkMetadata = __webpack_require__(/*! ./utils/sdkMetadata.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/sdkMetadata.js\");\nconst traceData = __webpack_require__(/*! ./utils/traceData.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/traceData.js\");\nconst meta = __webpack_require__(/*! ./utils/meta.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/meta.js\");\nconst debounce = __webpack_require__(/*! ./utils/debounce.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debounce.js\");\nconst request = __webpack_require__(/*! ./utils/request.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/request.js\");\nconst constants = __webpack_require__(/*! ./constants.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/constants.js\");\nconst breadcrumbs = __webpack_require__(/*! ./breadcrumbs.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/breadcrumbs.js\");\nconst functiontostring = __webpack_require__(/*! ./integrations/functiontostring.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/functiontostring.js\");\nconst eventFilters = __webpack_require__(/*! ./integrations/eventFilters.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/eventFilters.js\");\nconst linkederrors = __webpack_require__(/*! ./integrations/linkederrors.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/linkederrors.js\");\nconst metadata = __webpack_require__(/*! ./integrations/metadata.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/metadata.js\");\nconst requestdata = __webpack_require__(/*! ./integrations/requestdata.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/requestdata.js\");\nconst captureconsole = __webpack_require__(/*! ./integrations/captureconsole.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/captureconsole.js\");\nconst dedupe = __webpack_require__(/*! ./integrations/dedupe.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/dedupe.js\");\nconst extraerrordata = __webpack_require__(/*! ./integrations/extraerrordata.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/extraerrordata.js\");\nconst rewriteframes = __webpack_require__(/*! ./integrations/rewriteframes.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/rewriteframes.js\");\nconst supabase = __webpack_require__(/*! ./integrations/supabase.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/supabase.js\");\nconst zoderrors = __webpack_require__(/*! ./integrations/zoderrors.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/zoderrors.js\");\nconst thirdPartyErrorsFilter = __webpack_require__(/*! ./integrations/third-party-errors-filter.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/third-party-errors-filter.js\");\nconst console = __webpack_require__(/*! ./integrations/console.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/console.js\");\nconst featureFlagsIntegration = __webpack_require__(/*! ./integrations/featureFlags/featureFlagsIntegration.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/featureFlags/featureFlagsIntegration.js\");\nconst profiling = __webpack_require__(/*! ./profiling.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/profiling.js\");\nconst fetch = __webpack_require__(/*! ./fetch.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/fetch.js\");\nconst trpc = __webpack_require__(/*! ./trpc.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/trpc.js\");\nconst index$1 = __webpack_require__(/*! ./integrations/mcp-server/index.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/index.js\");\nconst feedback = __webpack_require__(/*! ./feedback.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/feedback.js\");\nconst exports$2 = __webpack_require__(/*! ./logs/exports.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/logs/exports.js\");\nconst consoleIntegration = __webpack_require__(/*! ./logs/console-integration.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/logs/console-integration.js\");\nconst vercelAi = __webpack_require__(/*! ./utils/vercel-ai.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/vercel-ai.js\");\nconst index$2 = __webpack_require__(/*! ./utils/openai/index.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/openai/index.js\");\nconst constants$1 = __webpack_require__(/*! ./utils/openai/constants.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/openai/constants.js\");\nconst featureFlags = __webpack_require__(/*! ./utils/featureFlags.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/featureFlags.js\");\nconst aggregateErrors = __webpack_require__(/*! ./utils/aggregate-errors.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/aggregate-errors.js\");\nconst breadcrumbLogLevel = __webpack_require__(/*! ./utils/breadcrumb-log-level.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/breadcrumb-log-level.js\");\nconst browser = __webpack_require__(/*! ./utils/browser.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/browser.js\");\nconst dsn = __webpack_require__(/*! ./utils/dsn.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/dsn.js\");\nconst error = __webpack_require__(/*! ./utils/error.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/error.js\");\nconst worldwide = __webpack_require__(/*! ./utils/worldwide.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/worldwide.js\");\nconst console$1 = __webpack_require__(/*! ./instrument/console.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/console.js\");\nconst fetch$1 = __webpack_require__(/*! ./instrument/fetch.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/fetch.js\");\nconst globalError = __webpack_require__(/*! ./instrument/globalError.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/globalError.js\");\nconst globalUnhandledRejection = __webpack_require__(/*! ./instrument/globalUnhandledRejection.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/globalUnhandledRejection.js\");\nconst handlers = __webpack_require__(/*! ./instrument/handlers.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/handlers.js\");\nconst is = __webpack_require__(/*! ./utils/is.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js\");\nconst isBrowser = __webpack_require__(/*! ./utils/isBrowser.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/isBrowser.js\");\nconst debugLogger = __webpack_require__(/*! ./utils/debug-logger.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst misc = __webpack_require__(/*! ./utils/misc.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/misc.js\");\nconst node = __webpack_require__(/*! ./utils/node.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/node.js\");\nconst normalize = __webpack_require__(/*! ./utils/normalize.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/normalize.js\");\nconst object = __webpack_require__(/*! ./utils/object.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/object.js\");\nconst path = __webpack_require__(/*! ./utils/path.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/path.js\");\nconst promisebuffer = __webpack_require__(/*! ./utils/promisebuffer.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/promisebuffer.js\");\nconst severity = __webpack_require__(/*! ./utils/severity.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/severity.js\");\nconst stacktrace = __webpack_require__(/*! ./utils/stacktrace.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/stacktrace.js\");\nconst nodeStackTrace = __webpack_require__(/*! ./utils/node-stack-trace.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/node-stack-trace.js\");\nconst string = __webpack_require__(/*! ./utils/string.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/string.js\");\nconst supports = __webpack_require__(/*! ./utils/supports.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/supports.js\");\nconst syncpromise = __webpack_require__(/*! ./utils/syncpromise.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/syncpromise.js\");\nconst time = __webpack_require__(/*! ./utils/time.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/time.js\");\nconst tracing = __webpack_require__(/*! ./utils/tracing.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/tracing.js\");\nconst env = __webpack_require__(/*! ./utils/env.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/env.js\");\nconst envelope$1 = __webpack_require__(/*! ./utils/envelope.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/envelope.js\");\nconst clientreport = __webpack_require__(/*! ./utils/clientreport.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/clientreport.js\");\nconst ratelimit = __webpack_require__(/*! ./utils/ratelimit.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/ratelimit.js\");\nconst baggage = __webpack_require__(/*! ./utils/baggage.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/baggage.js\");\nconst url = __webpack_require__(/*! ./utils/url.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/url.js\");\nconst eventbuilder = __webpack_require__(/*! ./utils/eventbuilder.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/eventbuilder.js\");\nconst anr = __webpack_require__(/*! ./utils/anr.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/anr.js\");\nconst lru = __webpack_require__(/*! ./utils/lru.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/lru.js\");\nconst propagationContext = __webpack_require__(/*! ./utils/propagationContext.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/propagationContext.js\");\nconst vercelWaitUntil = __webpack_require__(/*! ./utils/vercelWaitUntil.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/vercelWaitUntil.js\");\nconst flushIfServerless = __webpack_require__(/*! ./utils/flushIfServerless.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/flushIfServerless.js\");\nconst version = __webpack_require__(/*! ./utils/version.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/version.js\");\nconst debugIds = __webpack_require__(/*! ./utils/debug-ids.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-ids.js\");\nconst escapeStringForRegex = __webpack_require__(/*! ./vendor/escapeStringForRegex.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/vendor/escapeStringForRegex.js\");\n\n\n\nexports.registerSpanErrorInstrumentation = errors.registerSpanErrorInstrumentation;\nexports.getCapturedScopesOnSpan = utils.getCapturedScopesOnSpan;\nexports.setCapturedScopesOnSpan = utils.setCapturedScopesOnSpan;\nexports.TRACING_DEFAULTS = idleSpan.TRACING_DEFAULTS;\nexports.startIdleSpan = idleSpan.startIdleSpan;\nexports.SentrySpan = sentrySpan.SentrySpan;\nexports.SentryNonRecordingSpan = sentryNonRecordingSpan.SentryNonRecordingSpan;\nexports.SPAN_STATUS_ERROR = spanstatus.SPAN_STATUS_ERROR;\nexports.SPAN_STATUS_OK = spanstatus.SPAN_STATUS_OK;\nexports.SPAN_STATUS_UNSET = spanstatus.SPAN_STATUS_UNSET;\nexports.getSpanStatusFromHttpCode = spanstatus.getSpanStatusFromHttpCode;\nexports.setHttpStatus = spanstatus.setHttpStatus;\nexports.continueTrace = trace.continueTrace;\nexports.startInactiveSpan = trace.startInactiveSpan;\nexports.startNewTrace = trace.startNewTrace;\nexports.startSpan = trace.startSpan;\nexports.startSpanManual = trace.startSpanManual;\nexports.suppressTracing = trace.suppressTracing;\nexports.withActiveSpan = trace.withActiveSpan;\nexports.getDynamicSamplingContextFromClient = dynamicSamplingContext.getDynamicSamplingContextFromClient;\nexports.getDynamicSamplingContextFromScope = dynamicSamplingContext.getDynamicSamplingContextFromScope;\nexports.getDynamicSamplingContextFromSpan = dynamicSamplingContext.getDynamicSamplingContextFromSpan;\nexports.spanToBaggageHeader = dynamicSamplingContext.spanToBaggageHeader;\nexports.setMeasurement = measurement.setMeasurement;\nexports.timedEventsToMeasurements = measurement.timedEventsToMeasurements;\nexports.sampleSpan = sampling.sampleSpan;\nexports.logSpanEnd = logSpans.logSpanEnd;\nexports.logSpanStart = logSpans.logSpanStart;\nexports.SEMANTIC_ATTRIBUTE_CACHE_HIT = semanticAttributes.SEMANTIC_ATTRIBUTE_CACHE_HIT;\nexports.SEMANTIC_ATTRIBUTE_CACHE_ITEM_SIZE = semanticAttributes.SEMANTIC_ATTRIBUTE_CACHE_ITEM_SIZE;\nexports.SEMANTIC_ATTRIBUTE_CACHE_KEY = semanticAttributes.SEMANTIC_ATTRIBUTE_CACHE_KEY;\nexports.SEMANTIC_ATTRIBUTE_EXCLUSIVE_TIME = semanticAttributes.SEMANTIC_ATTRIBUTE_EXCLUSIVE_TIME;\nexports.SEMANTIC_ATTRIBUTE_HTTP_REQUEST_METHOD = semanticAttributes.SEMANTIC_ATTRIBUTE_HTTP_REQUEST_METHOD;\nexports.SEMANTIC_ATTRIBUTE_PROFILE_ID = semanticAttributes.SEMANTIC_ATTRIBUTE_PROFILE_ID;\nexports.SEMANTIC_ATTRIBUTE_SENTRY_CUSTOM_SPAN_NAME = semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_CUSTOM_SPAN_NAME;\nexports.SEMANTIC_ATTRIBUTE_SENTRY_IDLE_SPAN_FINISH_REASON = semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_IDLE_SPAN_FINISH_REASON;\nexports.SEMANTIC_ATTRIBUTE_SENTRY_MEASUREMENT_UNIT = semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_MEASUREMENT_UNIT;\nexports.SEMANTIC_ATTRIBUTE_SENTRY_MEASUREMENT_VALUE = semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_MEASUREMENT_VALUE;\nexports.SEMANTIC_ATTRIBUTE_SENTRY_OP = semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_OP;\nexports.SEMANTIC_ATTRIBUTE_SENTRY_ORIGIN = semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_ORIGIN;\nexports.SEMANTIC_ATTRIBUTE_SENTRY_PREVIOUS_TRACE_SAMPLE_RATE = semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_PREVIOUS_TRACE_SAMPLE_RATE;\nexports.SEMANTIC_ATTRIBUTE_SENTRY_SAMPLE_RATE = semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_SAMPLE_RATE;\nexports.SEMANTIC_ATTRIBUTE_SENTRY_SOURCE = semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_SOURCE;\nexports.SEMANTIC_ATTRIBUTE_URL_FULL = semanticAttributes.SEMANTIC_ATTRIBUTE_URL_FULL;\nexports.SEMANTIC_LINK_ATTRIBUTE_LINK_TYPE = semanticAttributes.SEMANTIC_LINK_ATTRIBUTE_LINK_TYPE;\nexports.createEventEnvelope = envelope.createEventEnvelope;\nexports.createSessionEnvelope = envelope.createSessionEnvelope;\nexports.createSpanEnvelope = envelope.createSpanEnvelope;\nexports.addEventProcessor = exports$1.addEventProcessor;\nexports.captureCheckIn = exports$1.captureCheckIn;\nexports.captureEvent = exports$1.captureEvent;\nexports.captureException = exports$1.captureException;\nexports.captureMessage = exports$1.captureMessage;\nexports.captureSession = exports$1.captureSession;\nexports.close = exports$1.close;\nexports.endSession = exports$1.endSession;\nexports.flush = exports$1.flush;\nexports.isEnabled = exports$1.isEnabled;\nexports.isInitialized = exports$1.isInitialized;\nexports.lastEventId = exports$1.lastEventId;\nexports.setContext = exports$1.setContext;\nexports.setExtra = exports$1.setExtra;\nexports.setExtras = exports$1.setExtras;\nexports.setTag = exports$1.setTag;\nexports.setTags = exports$1.setTags;\nexports.setUser = exports$1.setUser;\nexports.startSession = exports$1.startSession;\nexports.withMonitor = exports$1.withMonitor;\nexports.getClient = currentScopes.getClient;\nexports.getCurrentScope = currentScopes.getCurrentScope;\nexports.getGlobalScope = currentScopes.getGlobalScope;\nexports.getIsolationScope = currentScopes.getIsolationScope;\nexports.getTraceContextFromScope = currentScopes.getTraceContextFromScope;\nexports.withIsolationScope = currentScopes.withIsolationScope;\nexports.withScope = currentScopes.withScope;\nexports.getDefaultCurrentScope = defaultScopes.getDefaultCurrentScope;\nexports.getDefaultIsolationScope = defaultScopes.getDefaultIsolationScope;\nexports.setAsyncContextStrategy = index.setAsyncContextStrategy;\nexports.getGlobalSingleton = carrier.getGlobalSingleton;\nexports.getMainCarrier = carrier.getMainCarrier;\nexports.closeSession = session.closeSession;\nexports.makeSession = session.makeSession;\nexports.updateSession = session.updateSession;\nexports.Scope = scope.Scope;\nexports.notifyEventProcessors = eventProcessors.notifyEventProcessors;\nexports.getEnvelopeEndpointWithUrlEncodedAuth = api.getEnvelopeEndpointWithUrlEncodedAuth;\nexports.getReportDialogEndpoint = api.getReportDialogEndpoint;\nexports.BaseClient = client.BaseClient;\nexports.Client = client.Client;\nexports.ServerRuntimeClient = serverRuntimeClient.ServerRuntimeClient;\nexports.initAndBind = sdk.initAndBind;\nexports.setCurrentClient = sdk.setCurrentClient;\nexports.createTransport = base.createTransport;\nexports.makeOfflineTransport = offline.makeOfflineTransport;\nexports.makeMultiplexedTransport = multiplexed.makeMultiplexedTransport;\nexports.addIntegration = integration.addIntegration;\nexports.defineIntegration = integration.defineIntegration;\nexports.getIntegrationsToSetup = integration.getIntegrationsToSetup;\nexports.applyScopeDataToEvent = applyScopeDataToEvent.applyScopeDataToEvent;\nexports.mergeScopeData = applyScopeDataToEvent.mergeScopeData;\nexports.prepareEvent = prepareEvent.prepareEvent;\nexports.createCheckInEnvelope = checkin.createCheckInEnvelope;\nexports.hasSpansEnabled = hasSpansEnabled.hasSpansEnabled;\nexports.hasTracingEnabled = hasSpansEnabled.hasTracingEnabled;\nexports.isSentryRequestUrl = isSentryRequestUrl.isSentryRequestUrl;\nexports.handleCallbackErrors = handleCallbackErrors.handleCallbackErrors;\nexports.fmt = parameterize.fmt;\nexports.parameterize = parameterize.parameterize;\nexports.addAutoIpAddressToSession = ipAddress.addAutoIpAddressToSession;\nexports.addAutoIpAddressToUser = ipAddress.addAutoIpAddressToUser;\nexports.addChildSpanToSpan = spanUtils.addChildSpanToSpan;\nexports.convertSpanLinksForEnvelope = spanUtils.convertSpanLinksForEnvelope;\nexports.getActiveSpan = spanUtils.getActiveSpan;\nexports.getRootSpan = spanUtils.getRootSpan;\nexports.getSpanDescendants = spanUtils.getSpanDescendants;\nexports.getStatusMessage = spanUtils.getStatusMessage;\nexports.spanIsSampled = spanUtils.spanIsSampled;\nexports.spanTimeInputToSeconds = spanUtils.spanTimeInputToSeconds;\nexports.spanToJSON = spanUtils.spanToJSON;\nexports.spanToTraceContext = spanUtils.spanToTraceContext;\nexports.spanToTraceHeader = spanUtils.spanToTraceHeader;\nexports.updateSpanName = spanUtils.updateSpanName;\nexports.parseSampleRate = parseSampleRate.parseSampleRate;\nexports.applySdkMetadata = sdkMetadata.applySdkMetadata;\nexports.getTraceData = traceData.getTraceData;\nexports.getTraceMetaTags = meta.getTraceMetaTags;\nexports.debounce = debounce.debounce;\nexports.extractQueryParamsFromUrl = request.extractQueryParamsFromUrl;\nexports.headersToDict = request.headersToDict;\nexports.httpRequestToRequestData = request.httpRequestToRequestData;\nexports.winterCGHeadersToDict = request.winterCGHeadersToDict;\nexports.winterCGRequestToRequestData = request.winterCGRequestToRequestData;\nexports.DEFAULT_ENVIRONMENT = constants.DEFAULT_ENVIRONMENT;\nexports.addBreadcrumb = breadcrumbs.addBreadcrumb;\nexports.functionToStringIntegration = functiontostring.functionToStringIntegration;\nexports.eventFiltersIntegration = eventFilters.eventFiltersIntegration;\nexports.inboundFiltersIntegration = eventFilters.inboundFiltersIntegration;\nexports.linkedErrorsIntegration = linkederrors.linkedErrorsIntegration;\nexports.moduleMetadataIntegration = metadata.moduleMetadataIntegration;\nexports.requestDataIntegration = requestdata.requestDataIntegration;\nexports.captureConsoleIntegration = captureconsole.captureConsoleIntegration;\nexports.dedupeIntegration = dedupe.dedupeIntegration;\nexports.extraErrorDataIntegration = extraerrordata.extraErrorDataIntegration;\nexports.rewriteFramesIntegration = rewriteframes.rewriteFramesIntegration;\nexports.instrumentSupabaseClient = supabase.instrumentSupabaseClient;\nexports.supabaseIntegration = supabase.supabaseIntegration;\nexports.zodErrorsIntegration = zoderrors.zodErrorsIntegration;\nexports.thirdPartyErrorFilterIntegration = thirdPartyErrorsFilter.thirdPartyErrorFilterIntegration;\nexports.consoleIntegration = console.consoleIntegration;\nexports.featureFlagsIntegration = featureFlagsIntegration.featureFlagsIntegration;\nexports.profiler = profiling.profiler;\nexports.instrumentFetchRequest = fetch.instrumentFetchRequest;\nexports.trpcMiddleware = trpc.trpcMiddleware;\nexports.wrapMcpServerWithSentry = index$1.wrapMcpServerWithSentry;\nexports.captureFeedback = feedback.captureFeedback;\nexports._INTERNAL_captureLog = exports$2._INTERNAL_captureLog;\nexports._INTERNAL_captureSerializedLog = exports$2._INTERNAL_captureSerializedLog;\nexports._INTERNAL_flushLogsBuffer = exports$2._INTERNAL_flushLogsBuffer;\nexports.consoleLoggingIntegration = consoleIntegration.consoleLoggingIntegration;\nexports.addVercelAiProcessors = vercelAi.addVercelAiProcessors;\nexports.instrumentOpenAiClient = index$2.instrumentOpenAiClient;\nexports.OPENAI_INTEGRATION_NAME = constants$1.OPENAI_INTEGRATION_NAME;\nexports._INTERNAL_FLAG_BUFFER_SIZE = featureFlags._INTERNAL_FLAG_BUFFER_SIZE;\nexports._INTERNAL_MAX_FLAGS_PER_SPAN = featureFlags._INTERNAL_MAX_FLAGS_PER_SPAN;\nexports._INTERNAL_addFeatureFlagToActiveSpan = featureFlags._INTERNAL_addFeatureFlagToActiveSpan;\nexports._INTERNAL_copyFlagsFromScopeToEvent = featureFlags._INTERNAL_copyFlagsFromScopeToEvent;\nexports._INTERNAL_insertFlagToScope = featureFlags._INTERNAL_insertFlagToScope;\nexports.applyAggregateErrorsToEvent = aggregateErrors.applyAggregateErrorsToEvent;\nexports.getBreadcrumbLogLevelFromHttpStatusCode = breadcrumbLogLevel.getBreadcrumbLogLevelFromHttpStatusCode;\nexports.getComponentName = browser.getComponentName;\nexports.getLocationHref = browser.getLocationHref;\nexports.htmlTreeAsString = browser.htmlTreeAsString;\nexports.dsnFromString = dsn.dsnFromString;\nexports.dsnToString = dsn.dsnToString;\nexports.makeDsn = dsn.makeDsn;\nexports.SentryError = error.SentryError;\nexports.GLOBAL_OBJ = worldwide.GLOBAL_OBJ;\nexports.addConsoleInstrumentationHandler = console$1.addConsoleInstrumentationHandler;\nexports.addFetchEndInstrumentationHandler = fetch$1.addFetchEndInstrumentationHandler;\nexports.addFetchInstrumentationHandler = fetch$1.addFetchInstrumentationHandler;\nexports.addGlobalErrorInstrumentationHandler = globalError.addGlobalErrorInstrumentationHandler;\nexports.addGlobalUnhandledRejectionInstrumentationHandler = globalUnhandledRejection.addGlobalUnhandledRejectionInstrumentationHandler;\nexports.addHandler = handlers.addHandler;\nexports.maybeInstrument = handlers.maybeInstrument;\nexports.resetInstrumentationHandlers = handlers.resetInstrumentationHandlers;\nexports.triggerHandlers = handlers.triggerHandlers;\nexports.isDOMError = is.isDOMError;\nexports.isDOMException = is.isDOMException;\nexports.isElement = is.isElement;\nexports.isError = is.isError;\nexports.isErrorEvent = is.isErrorEvent;\nexports.isEvent = is.isEvent;\nexports.isInstanceOf = is.isInstanceOf;\nexports.isParameterizedString = is.isParameterizedString;\nexports.isPlainObject = is.isPlainObject;\nexports.isPrimitive = is.isPrimitive;\nexports.isRegExp = is.isRegExp;\nexports.isString = is.isString;\nexports.isSyntheticEvent = is.isSyntheticEvent;\nexports.isThenable = is.isThenable;\nexports.isVueViewModel = is.isVueViewModel;\nexports.isBrowser = isBrowser.isBrowser;\nexports.CONSOLE_LEVELS = debugLogger.CONSOLE_LEVELS;\nexports.consoleSandbox = debugLogger.consoleSandbox;\nexports.debug = debugLogger.debug;\nexports.logger = debugLogger.logger;\nexports.originalConsoleMethods = debugLogger.originalConsoleMethods;\nexports.addContextToFrame = misc.addContextToFrame;\nexports.addExceptionMechanism = misc.addExceptionMechanism;\nexports.addExceptionTypeValue = misc.addExceptionTypeValue;\nexports.checkOrSetAlreadyCaught = misc.checkOrSetAlreadyCaught;\nexports.getEventDescription = misc.getEventDescription;\nexports.parseSemver = misc.parseSemver;\nexports.uuid4 = misc.uuid4;\nexports.isNodeEnv = node.isNodeEnv;\nexports.loadModule = node.loadModule;\nexports.normalize = normalize.normalize;\nexports.normalizeToSize = normalize.normalizeToSize;\nexports.normalizeUrlToBase = normalize.normalizeUrlToBase;\nexports.addNonEnumerableProperty = object.addNonEnumerableProperty;\nexports.convertToPlainObject = object.convertToPlainObject;\nexports.dropUndefinedKeys = object.dropUndefinedKeys;\nexports.extractExceptionKeysForMessage = object.extractExceptionKeysForMessage;\nexports.fill = object.fill;\nexports.getOriginalFunction = object.getOriginalFunction;\nexports.markFunctionWrapped = object.markFunctionWrapped;\nexports.objectify = object.objectify;\nexports.basename = path.basename;\nexports.dirname = path.dirname;\nexports.isAbsolute = path.isAbsolute;\nexports.join = path.join;\nexports.normalizePath = path.normalizePath;\nexports.relative = path.relative;\nexports.resolve = path.resolve;\nexports.SENTRY_BUFFER_FULL_ERROR = promisebuffer.SENTRY_BUFFER_FULL_ERROR;\nexports.makePromiseBuffer = promisebuffer.makePromiseBuffer;\nexports.severityLevelFromString = severity.severityLevelFromString;\nexports.UNKNOWN_FUNCTION = stacktrace.UNKNOWN_FUNCTION;\nexports.createStackParser = stacktrace.createStackParser;\nexports.getFramesFromEvent = stacktrace.getFramesFromEvent;\nexports.getFunctionName = stacktrace.getFunctionName;\nexports.stackParserFromStackParserOptions = stacktrace.stackParserFromStackParserOptions;\nexports.stripSentryFramesAndReverse = stacktrace.stripSentryFramesAndReverse;\nexports.filenameIsInApp = nodeStackTrace.filenameIsInApp;\nexports.node = nodeStackTrace.node;\nexports.nodeStackLineParser = nodeStackTrace.nodeStackLineParser;\nexports.isMatchingPattern = string.isMatchingPattern;\nexports.safeJoin = string.safeJoin;\nexports.snipLine = string.snipLine;\nexports.stringMatchesSomePattern = string.stringMatchesSomePattern;\nexports.truncate = string.truncate;\nexports.isNativeFunction = supports.isNativeFunction;\nexports.supportsDOMError = supports.supportsDOMError;\nexports.supportsDOMException = supports.supportsDOMException;\nexports.supportsErrorEvent = supports.supportsErrorEvent;\nexports.supportsFetch = supports.supportsFetch;\nexports.supportsHistory = supports.supportsHistory;\nexports.supportsNativeFetch = supports.supportsNativeFetch;\nexports.supportsReferrerPolicy = supports.supportsReferrerPolicy;\nexports.supportsReportingObserver = supports.supportsReportingObserver;\nexports.SyncPromise = syncpromise.SyncPromise;\nexports.rejectedSyncPromise = syncpromise.rejectedSyncPromise;\nexports.resolvedSyncPromise = syncpromise.resolvedSyncPromise;\nexports.browserPerformanceTimeOrigin = time.browserPerformanceTimeOrigin;\nexports.dateTimestampInSeconds = time.dateTimestampInSeconds;\nexports.timestampInSeconds = time.timestampInSeconds;\nexports.TRACEPARENT_REGEXP = tracing.TRACEPARENT_REGEXP;\nexports.extractTraceparentData = tracing.extractTraceparentData;\nexports.generateSentryTraceHeader = tracing.generateSentryTraceHeader;\nexports.propagationContextFromHeaders = tracing.propagationContextFromHeaders;\nexports.getSDKSource = env.getSDKSource;\nexports.isBrowserBundle = env.isBrowserBundle;\nexports.addItemToEnvelope = envelope$1.addItemToEnvelope;\nexports.createAttachmentEnvelopeItem = envelope$1.createAttachmentEnvelopeItem;\nexports.createEnvelope = envelope$1.createEnvelope;\nexports.createEventEnvelopeHeaders = envelope$1.createEventEnvelopeHeaders;\nexports.createSpanEnvelopeItem = envelope$1.createSpanEnvelopeItem;\nexports.envelopeContainsItemType = envelope$1.envelopeContainsItemType;\nexports.envelopeItemTypeToDataCategory = envelope$1.envelopeItemTypeToDataCategory;\nexports.forEachEnvelopeItem = envelope$1.forEachEnvelopeItem;\nexports.getSdkMetadataForEnvelopeHeader = envelope$1.getSdkMetadataForEnvelopeHeader;\nexports.parseEnvelope = envelope$1.parseEnvelope;\nexports.serializeEnvelope = envelope$1.serializeEnvelope;\nexports.createClientReportEnvelope = clientreport.createClientReportEnvelope;\nexports.DEFAULT_RETRY_AFTER = ratelimit.DEFAULT_RETRY_AFTER;\nexports.disabledUntil = ratelimit.disabledUntil;\nexports.isRateLimited = ratelimit.isRateLimited;\nexports.parseRetryAfterHeader = ratelimit.parseRetryAfterHeader;\nexports.updateRateLimits = ratelimit.updateRateLimits;\nexports.MAX_BAGGAGE_STRING_LENGTH = baggage.MAX_BAGGAGE_STRING_LENGTH;\nexports.SENTRY_BAGGAGE_KEY_PREFIX = baggage.SENTRY_BAGGAGE_KEY_PREFIX;\nexports.SENTRY_BAGGAGE_KEY_PREFIX_REGEX = baggage.SENTRY_BAGGAGE_KEY_PREFIX_REGEX;\nexports.baggageHeaderToDynamicSamplingContext = baggage.baggageHeaderToDynamicSamplingContext;\nexports.dynamicSamplingContextToSentryBaggageHeader = baggage.dynamicSamplingContextToSentryBaggageHeader;\nexports.objectToBaggageHeader = baggage.objectToBaggageHeader;\nexports.parseBaggageHeader = baggage.parseBaggageHeader;\nexports.getHttpSpanDetailsFromUrlObject = url.getHttpSpanDetailsFromUrlObject;\nexports.getSanitizedUrlString = url.getSanitizedUrlString;\nexports.getSanitizedUrlStringFromUrlObject = url.getSanitizedUrlStringFromUrlObject;\nexports.isURLObjectRelative = url.isURLObjectRelative;\nexports.parseStringToURLObject = url.parseStringToURLObject;\nexports.parseUrl = url.parseUrl;\nexports.stripUrlQueryAndFragment = url.stripUrlQueryAndFragment;\nexports.eventFromMessage = eventbuilder.eventFromMessage;\nexports.eventFromUnknownInput = eventbuilder.eventFromUnknownInput;\nexports.exceptionFromError = eventbuilder.exceptionFromError;\nexports.parseStackFrames = eventbuilder.parseStackFrames;\nexports.callFrameToStackFrame = anr.callFrameToStackFrame;\nexports.watchdogTimer = anr.watchdogTimer;\nexports.LRUMap = lru.LRUMap;\nexports.generateSpanId = propagationContext.generateSpanId;\nexports.generateTraceId = propagationContext.generateTraceId;\nexports.vercelWaitUntil = vercelWaitUntil.vercelWaitUntil;\nexports.flushIfServerless = flushIfServerless.flushIfServerless;\nexports.SDK_VERSION = version.SDK_VERSION;\nexports.getDebugImagesForResources = debugIds.getDebugImagesForResources;\nexports.getFilenameToDebugIdMap = debugIds.getFilenameToDebugIdMap;\nexports.escapeStringForRegex = escapeStringForRegex.escapeStringForRegex;\n//# sourceMappingURL=index.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvaW5kZXguanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsZUFBZSxtQkFBTyxDQUFDLHdJQUFxQjtBQUM1QyxjQUFjLG1CQUFPLENBQUMsc0lBQW9CO0FBQzFDLGlCQUFpQixtQkFBTyxDQUFDLDRJQUF1QjtBQUNoRCxtQkFBbUIsbUJBQU8sQ0FBQyxnSkFBeUI7QUFDcEQsK0JBQStCLG1CQUFPLENBQUMsd0tBQXFDO0FBQzVFLG1CQUFtQixtQkFBTyxDQUFDLGdKQUF5QjtBQUNwRCxjQUFjLG1CQUFPLENBQUMsc0lBQW9CO0FBQzFDLCtCQUErQixtQkFBTyxDQUFDLHdLQUFxQztBQUM1RSxvQkFBb0IsbUJBQU8sQ0FBQyxrSkFBMEI7QUFDdEQsaUJBQWlCLG1CQUFPLENBQUMsNElBQXVCO0FBQ2hELGlCQUFpQixtQkFBTyxDQUFDLDRJQUF1QjtBQUNoRCwyQkFBMkIsbUJBQU8sQ0FBQyxnSkFBeUI7QUFDNUQsaUJBQWlCLG1CQUFPLENBQUMsNEhBQWU7QUFDeEMsa0JBQWtCLG1CQUFPLENBQUMsMEhBQWM7QUFDeEMsc0JBQXNCLG1CQUFPLENBQUMsc0lBQW9CO0FBQ2xELHNCQUFzQixtQkFBTyxDQUFDLHNJQUFvQjtBQUNsRCxjQUFjLG1CQUFPLENBQUMsZ0pBQXlCO0FBQy9DLGdCQUFnQixtQkFBTyxDQUFDLDBIQUFjO0FBQ3RDLGdCQUFnQixtQkFBTyxDQUFDLDBIQUFjO0FBQ3RDLGNBQWMsbUJBQU8sQ0FBQyxzSEFBWTtBQUNsQyx3QkFBd0IsbUJBQU8sQ0FBQywwSUFBc0I7QUFDdEQsWUFBWSxtQkFBTyxDQUFDLGtIQUFVO0FBQzlCLGVBQWUsbUJBQU8sQ0FBQyx3SEFBYTtBQUNwQyw0QkFBNEIsbUJBQU8sQ0FBQyxzSkFBNEI7QUFDaEUsWUFBWSxtQkFBTyxDQUFDLGtIQUFVO0FBQzlCLGFBQWEsbUJBQU8sQ0FBQywwSUFBc0I7QUFDM0MsZ0JBQWdCLG1CQUFPLENBQUMsZ0pBQXlCO0FBQ2pELG9CQUFvQixtQkFBTyxDQUFDLHdKQUE2QjtBQUN6RCxvQkFBb0IsbUJBQU8sQ0FBQyxrSUFBa0I7QUFDOUMsOEJBQThCLG1CQUFPLENBQUMsa0tBQWtDO0FBQ3hFLHFCQUFxQixtQkFBTyxDQUFDLGdKQUF5QjtBQUN0RCxnQkFBZ0IsbUJBQU8sQ0FBQywwSEFBYztBQUN0Qyx3QkFBd0IsbUJBQU8sQ0FBQyxzSkFBNEI7QUFDNUQsMkJBQTJCLG1CQUFPLENBQUMsNEpBQStCO0FBQ2xFLDZCQUE2QixtQkFBTyxDQUFDLGdLQUFpQztBQUN0RSxxQkFBcUIsbUJBQU8sQ0FBQyxnSkFBeUI7QUFDdEQsa0JBQWtCLG1CQUFPLENBQUMsMElBQXNCO0FBQ2hELGtCQUFrQixtQkFBTyxDQUFDLDBJQUFzQjtBQUNoRCx3QkFBd0IsbUJBQU8sQ0FBQyxzSkFBNEI7QUFDNUQsb0JBQW9CLG1CQUFPLENBQUMsOElBQXdCO0FBQ3BELGtCQUFrQixtQkFBTyxDQUFDLDBJQUFzQjtBQUNoRCxhQUFhLG1CQUFPLENBQUMsZ0lBQWlCO0FBQ3RDLGlCQUFpQixtQkFBTyxDQUFDLHdJQUFxQjtBQUM5QyxnQkFBZ0IsbUJBQU8sQ0FBQyxzSUFBb0I7QUFDNUMsa0JBQWtCLG1CQUFPLENBQUMsOEhBQWdCO0FBQzFDLG9CQUFvQixtQkFBTyxDQUFDLGtJQUFrQjtBQUM5Qyx5QkFBeUIsbUJBQU8sQ0FBQyxzS0FBb0M7QUFDckUscUJBQXFCLG1CQUFPLENBQUMsOEpBQWdDO0FBQzdELHFCQUFxQixtQkFBTyxDQUFDLDhKQUFnQztBQUM3RCxpQkFBaUIsbUJBQU8sQ0FBQyxzSkFBNEI7QUFDckQsb0JBQW9CLG1CQUFPLENBQUMsNEpBQStCO0FBQzNELHVCQUF1QixtQkFBTyxDQUFDLGtLQUFrQztBQUNqRSxlQUFlLG1CQUFPLENBQUMsa0pBQTBCO0FBQ2pELHVCQUF1QixtQkFBTyxDQUFDLGtLQUFrQztBQUNqRSxzQkFBc0IsbUJBQU8sQ0FBQyxnS0FBaUM7QUFDL0QsaUJBQWlCLG1CQUFPLENBQUMsc0pBQTRCO0FBQ3JELGtCQUFrQixtQkFBTyxDQUFDLHdKQUE2QjtBQUN2RCwrQkFBK0IsbUJBQU8sQ0FBQyx3TEFBNkM7QUFDcEYsZ0JBQWdCLG1CQUFPLENBQUMsb0pBQTJCO0FBQ25ELGdDQUFnQyxtQkFBTyxDQUFDLDhNQUF3RDtBQUNoRyxrQkFBa0IsbUJBQU8sQ0FBQyw4SEFBZ0I7QUFDMUMsY0FBYyxtQkFBTyxDQUFDLHNIQUFZO0FBQ2xDLGFBQWEsbUJBQU8sQ0FBQyxvSEFBVztBQUNoQyxnQkFBZ0IsbUJBQU8sQ0FBQyxzS0FBb0M7QUFDNUQsaUJBQWlCLG1CQUFPLENBQUMsNEhBQWU7QUFDeEMsa0JBQWtCLG1CQUFPLENBQUMsb0lBQW1CO0FBQzdDLDJCQUEyQixtQkFBTyxDQUFDLDRKQUErQjtBQUNsRSxpQkFBaUIsbUJBQU8sQ0FBQywwSUFBc0I7QUFDL0MsZ0JBQWdCLG1CQUFPLENBQUMsZ0pBQXlCO0FBQ2pELG9CQUFvQixtQkFBTyxDQUFDLHdKQUE2QjtBQUN6RCxxQkFBcUIsbUJBQU8sQ0FBQyxnSkFBeUI7QUFDdEQsd0JBQXdCLG1CQUFPLENBQUMsd0pBQTZCO0FBQzdELDJCQUEyQixtQkFBTyxDQUFDLGdLQUFpQztBQUNwRSxnQkFBZ0IsbUJBQU8sQ0FBQyxzSUFBb0I7QUFDNUMsWUFBWSxtQkFBTyxDQUFDLDhIQUFnQjtBQUNwQyxjQUFjLG1CQUFPLENBQUMsa0lBQWtCO0FBQ3hDLGtCQUFrQixtQkFBTyxDQUFDLDBJQUFzQjtBQUNoRCxrQkFBa0IsbUJBQU8sQ0FBQyxnSkFBeUI7QUFDbkQsZ0JBQWdCLG1CQUFPLENBQUMsNElBQXVCO0FBQy9DLG9CQUFvQixtQkFBTyxDQUFDLHdKQUE2QjtBQUN6RCxpQ0FBaUMsbUJBQU8sQ0FBQyxrTEFBMEM7QUFDbkYsaUJBQWlCLG1CQUFPLENBQUMsa0pBQTBCO0FBQ25ELFdBQVcsbUJBQU8sQ0FBQyw0SEFBZTtBQUNsQyxrQkFBa0IsbUJBQU8sQ0FBQywwSUFBc0I7QUFDaEQsb0JBQW9CLG1CQUFPLENBQUMsZ0pBQXlCO0FBQ3JELGFBQWEsbUJBQU8sQ0FBQyxnSUFBaUI7QUFDdEMsYUFBYSxtQkFBTyxDQUFDLGdJQUFpQjtBQUN0QyxrQkFBa0IsbUJBQU8sQ0FBQywwSUFBc0I7QUFDaEQsZUFBZSxtQkFBTyxDQUFDLG9JQUFtQjtBQUMxQyxhQUFhLG1CQUFPLENBQUMsZ0lBQWlCO0FBQ3RDLHNCQUFzQixtQkFBTyxDQUFDLGtKQUEwQjtBQUN4RCxpQkFBaUIsbUJBQU8sQ0FBQyx3SUFBcUI7QUFDOUMsbUJBQW1CLG1CQUFPLENBQUMsNElBQXVCO0FBQ2xELHVCQUF1QixtQkFBTyxDQUFDLHdKQUE2QjtBQUM1RCxlQUFlLG1CQUFPLENBQUMsb0lBQW1CO0FBQzFDLGlCQUFpQixtQkFBTyxDQUFDLHdJQUFxQjtBQUM5QyxvQkFBb0IsbUJBQU8sQ0FBQyw4SUFBd0I7QUFDcEQsYUFBYSxtQkFBTyxDQUFDLGdJQUFpQjtBQUN0QyxnQkFBZ0IsbUJBQU8sQ0FBQyxzSUFBb0I7QUFDNUMsWUFBWSxtQkFBTyxDQUFDLDhIQUFnQjtBQUNwQyxtQkFBbUIsbUJBQU8sQ0FBQyx3SUFBcUI7QUFDaEQscUJBQXFCLG1CQUFPLENBQUMsZ0pBQXlCO0FBQ3RELGtCQUFrQixtQkFBTyxDQUFDLDBJQUFzQjtBQUNoRCxnQkFBZ0IsbUJBQU8sQ0FBQyxzSUFBb0I7QUFDNUMsWUFBWSxtQkFBTyxDQUFDLDhIQUFnQjtBQUNwQyxxQkFBcUIsbUJBQU8sQ0FBQyxnSkFBeUI7QUFDdEQsWUFBWSxtQkFBTyxDQUFDLDhIQUFnQjtBQUNwQyxZQUFZLG1CQUFPLENBQUMsOEhBQWdCO0FBQ3BDLDJCQUEyQixtQkFBTyxDQUFDLDRKQUErQjtBQUNsRSx3QkFBd0IsbUJBQU8sQ0FBQyxzSkFBNEI7QUFDNUQsMEJBQTBCLG1CQUFPLENBQUMsMEpBQThCO0FBQ2hFLGdCQUFnQixtQkFBTyxDQUFDLHNJQUFvQjtBQUM1QyxpQkFBaUIsbUJBQU8sQ0FBQywwSUFBc0I7QUFDL0MsNkJBQTZCLG1CQUFPLENBQUMsa0tBQWtDOzs7O0FBSXZFLHdDQUF3QztBQUN4QywrQkFBK0I7QUFDL0IsK0JBQStCO0FBQy9CLHdCQUF3QjtBQUN4QixxQkFBcUI7QUFDckIsa0JBQWtCO0FBQ2xCLDhCQUE4QjtBQUM5Qix5QkFBeUI7QUFDekIsc0JBQXNCO0FBQ3RCLHlCQUF5QjtBQUN6QixpQ0FBaUM7QUFDakMscUJBQXFCO0FBQ3JCLHFCQUFxQjtBQUNyQix5QkFBeUI7QUFDekIscUJBQXFCO0FBQ3JCLGlCQUFpQjtBQUNqQix1QkFBdUI7QUFDdkIsdUJBQXVCO0FBQ3ZCLHNCQUFzQjtBQUN0QiwyQ0FBMkM7QUFDM0MsMENBQTBDO0FBQzFDLHlDQUF5QztBQUN6QywyQkFBMkI7QUFDM0Isc0JBQXNCO0FBQ3RCLGlDQUFpQztBQUNqQyxrQkFBa0I7QUFDbEIsa0JBQWtCO0FBQ2xCLG9CQUFvQjtBQUNwQixvQ0FBb0M7QUFDcEMsMENBQTBDO0FBQzFDLG9DQUFvQztBQUNwQyx5Q0FBeUM7QUFDekMsOENBQThDO0FBQzlDLHFDQUFxQztBQUNyQyxrREFBa0Q7QUFDbEQseURBQXlEO0FBQ3pELGtEQUFrRDtBQUNsRCxtREFBbUQ7QUFDbkQsb0NBQW9DO0FBQ3BDLHdDQUF3QztBQUN4Qyw0REFBNEQ7QUFDNUQsNkNBQTZDO0FBQzdDLHdDQUF3QztBQUN4QyxtQ0FBbUM7QUFDbkMseUNBQXlDO0FBQ3pDLDJCQUEyQjtBQUMzQiw2QkFBNkI7QUFDN0IsMEJBQTBCO0FBQzFCLHlCQUF5QjtBQUN6QixzQkFBc0I7QUFDdEIsb0JBQW9CO0FBQ3BCLHdCQUF3QjtBQUN4QixzQkFBc0I7QUFDdEIsc0JBQXNCO0FBQ3RCLGFBQWE7QUFDYixrQkFBa0I7QUFDbEIsYUFBYTtBQUNiLGlCQUFpQjtBQUNqQixxQkFBcUI7QUFDckIsbUJBQW1CO0FBQ25CLGtCQUFrQjtBQUNsQixnQkFBZ0I7QUFDaEIsaUJBQWlCO0FBQ2pCLGNBQWM7QUFDZCxlQUFlO0FBQ2YsZUFBZTtBQUNmLG9CQUFvQjtBQUNwQixtQkFBbUI7QUFDbkIsaUJBQWlCO0FBQ2pCLHVCQUF1QjtBQUN2QixzQkFBc0I7QUFDdEIseUJBQXlCO0FBQ3pCLGdDQUFnQztBQUNoQywwQkFBMEI7QUFDMUIsaUJBQWlCO0FBQ2pCLDhCQUE4QjtBQUM5QixnQ0FBZ0M7QUFDaEMsK0JBQStCO0FBQy9CLDBCQUEwQjtBQUMxQixzQkFBc0I7QUFDdEIsb0JBQW9CO0FBQ3BCLG1CQUFtQjtBQUNuQixxQkFBcUI7QUFDckIsYUFBYTtBQUNiLDZCQUE2QjtBQUM3Qiw2Q0FBNkM7QUFDN0MsK0JBQStCO0FBQy9CLGtCQUFrQjtBQUNsQixjQUFjO0FBQ2QsMkJBQTJCO0FBQzNCLG1CQUFtQjtBQUNuQix3QkFBd0I7QUFDeEIsdUJBQXVCO0FBQ3ZCLDRCQUE0QjtBQUM1QixnQ0FBZ0M7QUFDaEMsc0JBQXNCO0FBQ3RCLHlCQUF5QjtBQUN6Qiw4QkFBOEI7QUFDOUIsNkJBQTZCO0FBQzdCLHNCQUFzQjtBQUN0QixvQkFBb0I7QUFDcEIsNkJBQTZCO0FBQzdCLHVCQUF1QjtBQUN2Qix5QkFBeUI7QUFDekIsMEJBQTBCO0FBQzFCLDRCQUE0QjtBQUM1QixXQUFXO0FBQ1gsb0JBQW9CO0FBQ3BCLGlDQUFpQztBQUNqQyw4QkFBOEI7QUFDOUIsMEJBQTBCO0FBQzFCLG1DQUFtQztBQUNuQyxxQkFBcUI7QUFDckIsbUJBQW1CO0FBQ25CLDBCQUEwQjtBQUMxQix3QkFBd0I7QUFDeEIscUJBQXFCO0FBQ3JCLDhCQUE4QjtBQUM5QixrQkFBa0I7QUFDbEIsMEJBQTBCO0FBQzFCLHlCQUF5QjtBQUN6QixzQkFBc0I7QUFDdEIsdUJBQXVCO0FBQ3ZCLHdCQUF3QjtBQUN4QixvQkFBb0I7QUFDcEIsd0JBQXdCO0FBQ3hCLGdCQUFnQjtBQUNoQixpQ0FBaUM7QUFDakMscUJBQXFCO0FBQ3JCLGdDQUFnQztBQUNoQyw2QkFBNkI7QUFDN0Isb0NBQW9DO0FBQ3BDLDJCQUEyQjtBQUMzQixxQkFBcUI7QUFDckIsbUNBQW1DO0FBQ25DLCtCQUErQjtBQUMvQixpQ0FBaUM7QUFDakMsK0JBQStCO0FBQy9CLGlDQUFpQztBQUNqQyw4QkFBOEI7QUFDOUIsaUNBQWlDO0FBQ2pDLHlCQUF5QjtBQUN6QixpQ0FBaUM7QUFDakMsZ0NBQWdDO0FBQ2hDLGdDQUFnQztBQUNoQywyQkFBMkI7QUFDM0IsNEJBQTRCO0FBQzVCLHdDQUF3QztBQUN4QywwQkFBMEI7QUFDMUIsK0JBQStCO0FBQy9CLGdCQUFnQjtBQUNoQiw4QkFBOEI7QUFDOUIsc0JBQXNCO0FBQ3RCLCtCQUErQjtBQUMvQix1QkFBdUI7QUFDdkIsNEJBQTRCO0FBQzVCLHNDQUFzQztBQUN0QyxpQ0FBaUM7QUFDakMsaUNBQWlDO0FBQ2pDLDZCQUE2QjtBQUM3Qiw4QkFBOEI7QUFDOUIsK0JBQStCO0FBQy9CLGtDQUFrQztBQUNsQyxvQ0FBb0M7QUFDcEMsNENBQTRDO0FBQzVDLDJDQUEyQztBQUMzQyxtQ0FBbUM7QUFDbkMsbUNBQW1DO0FBQ25DLCtDQUErQztBQUMvQyx3QkFBd0I7QUFDeEIsdUJBQXVCO0FBQ3ZCLHdCQUF3QjtBQUN4QixxQkFBcUI7QUFDckIsbUJBQW1CO0FBQ25CLGVBQWU7QUFDZixtQkFBbUI7QUFDbkIsa0JBQWtCO0FBQ2xCLHdDQUF3QztBQUN4Qyx5Q0FBeUM7QUFDekMsc0NBQXNDO0FBQ3RDLDRDQUE0QztBQUM1Qyx5REFBeUQ7QUFDekQsa0JBQWtCO0FBQ2xCLHVCQUF1QjtBQUN2QixvQ0FBb0M7QUFDcEMsdUJBQXVCO0FBQ3ZCLGtCQUFrQjtBQUNsQixzQkFBc0I7QUFDdEIsaUJBQWlCO0FBQ2pCLGVBQWU7QUFDZixvQkFBb0I7QUFDcEIsZUFBZTtBQUNmLG9CQUFvQjtBQUNwQiw2QkFBNkI7QUFDN0IscUJBQXFCO0FBQ3JCLG1CQUFtQjtBQUNuQixnQkFBZ0I7QUFDaEIsZ0JBQWdCO0FBQ2hCLHdCQUF3QjtBQUN4QixrQkFBa0I7QUFDbEIsc0JBQXNCO0FBQ3RCLGlCQUFpQjtBQUNqQixzQkFBc0I7QUFDdEIsc0JBQXNCO0FBQ3RCLGFBQWE7QUFDYixjQUFjO0FBQ2QsOEJBQThCO0FBQzlCLHlCQUF5QjtBQUN6Qiw2QkFBNkI7QUFDN0IsNkJBQTZCO0FBQzdCLCtCQUErQjtBQUMvQiwyQkFBMkI7QUFDM0IsbUJBQW1CO0FBQ25CLGFBQWE7QUFDYixpQkFBaUI7QUFDakIsa0JBQWtCO0FBQ2xCLGlCQUFpQjtBQUNqQix1QkFBdUI7QUFDdkIsMEJBQTBCO0FBQzFCLGdDQUFnQztBQUNoQyw0QkFBNEI7QUFDNUIseUJBQXlCO0FBQ3pCLHNDQUFzQztBQUN0QyxZQUFZO0FBQ1osMkJBQTJCO0FBQzNCLDJCQUEyQjtBQUMzQixpQkFBaUI7QUFDakIsZ0JBQWdCO0FBQ2hCLGVBQWU7QUFDZixrQkFBa0I7QUFDbEIsWUFBWTtBQUNaLHFCQUFxQjtBQUNyQixnQkFBZ0I7QUFDaEIsZUFBZTtBQUNmLGdDQUFnQztBQUNoQyx5QkFBeUI7QUFDekIsK0JBQStCO0FBQy9CLHdCQUF3QjtBQUN4Qix5QkFBeUI7QUFDekIsMEJBQTBCO0FBQzFCLHVCQUF1QjtBQUN2Qix5Q0FBeUM7QUFDekMsbUNBQW1DO0FBQ25DLHVCQUF1QjtBQUN2QixZQUFZO0FBQ1osMkJBQTJCO0FBQzNCLHlCQUF5QjtBQUN6QixnQkFBZ0I7QUFDaEIsZ0JBQWdCO0FBQ2hCLGdDQUFnQztBQUNoQyxnQkFBZ0I7QUFDaEIsd0JBQXdCO0FBQ3hCLHdCQUF3QjtBQUN4Qiw0QkFBNEI7QUFDNUIsMEJBQTBCO0FBQzFCLHFCQUFxQjtBQUNyQix1QkFBdUI7QUFDdkIsMkJBQTJCO0FBQzNCLDhCQUE4QjtBQUM5QixpQ0FBaUM7QUFDakMsbUJBQW1CO0FBQ25CLDJCQUEyQjtBQUMzQiwyQkFBMkI7QUFDM0Isb0NBQW9DO0FBQ3BDLDhCQUE4QjtBQUM5QiwwQkFBMEI7QUFDMUIsMEJBQTBCO0FBQzFCLDhCQUE4QjtBQUM5QixpQ0FBaUM7QUFDakMscUNBQXFDO0FBQ3JDLG9CQUFvQjtBQUNwQix1QkFBdUI7QUFDdkIseUJBQXlCO0FBQ3pCLG9DQUFvQztBQUNwQyxzQkFBc0I7QUFDdEIsa0NBQWtDO0FBQ2xDLDhCQUE4QjtBQUM5QixnQ0FBZ0M7QUFDaEMsc0NBQXNDO0FBQ3RDLDJCQUEyQjtBQUMzQix1Q0FBdUM7QUFDdkMscUJBQXFCO0FBQ3JCLHlCQUF5QjtBQUN6QixrQ0FBa0M7QUFDbEMsMkJBQTJCO0FBQzNCLHFCQUFxQjtBQUNyQixxQkFBcUI7QUFDckIsNkJBQTZCO0FBQzdCLHdCQUF3QjtBQUN4QixpQ0FBaUM7QUFDakMsaUNBQWlDO0FBQ2pDLHVDQUF1QztBQUN2Qyw2Q0FBNkM7QUFDN0MsbURBQW1EO0FBQ25ELDZCQUE2QjtBQUM3QiwwQkFBMEI7QUFDMUIsdUNBQXVDO0FBQ3ZDLDZCQUE2QjtBQUM3QiwwQ0FBMEM7QUFDMUMsMkJBQTJCO0FBQzNCLDhCQUE4QjtBQUM5QixnQkFBZ0I7QUFDaEIsZ0NBQWdDO0FBQ2hDLHdCQUF3QjtBQUN4Qiw2QkFBNkI7QUFDN0IsMEJBQTBCO0FBQzFCLHdCQUF3QjtBQUN4Qiw2QkFBNkI7QUFDN0IscUJBQXFCO0FBQ3JCLGNBQWM7QUFDZCxzQkFBc0I7QUFDdEIsdUJBQXVCO0FBQ3ZCLHVCQUF1QjtBQUN2Qix5QkFBeUI7QUFDekIsbUJBQW1CO0FBQ25CLGtDQUFrQztBQUNsQywrQkFBK0I7QUFDL0IsNEJBQTRCO0FBQzVCIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvaW5kZXguanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGVycm9ycyA9IHJlcXVpcmUoJy4vdHJhY2luZy9lcnJvcnMuanMnKTtcbmNvbnN0IHV0aWxzID0gcmVxdWlyZSgnLi90cmFjaW5nL3V0aWxzLmpzJyk7XG5jb25zdCBpZGxlU3BhbiA9IHJlcXVpcmUoJy4vdHJhY2luZy9pZGxlU3Bhbi5qcycpO1xuY29uc3Qgc2VudHJ5U3BhbiA9IHJlcXVpcmUoJy4vdHJhY2luZy9zZW50cnlTcGFuLmpzJyk7XG5jb25zdCBzZW50cnlOb25SZWNvcmRpbmdTcGFuID0gcmVxdWlyZSgnLi90cmFjaW5nL3NlbnRyeU5vblJlY29yZGluZ1NwYW4uanMnKTtcbmNvbnN0IHNwYW5zdGF0dXMgPSByZXF1aXJlKCcuL3RyYWNpbmcvc3BhbnN0YXR1cy5qcycpO1xuY29uc3QgdHJhY2UgPSByZXF1aXJlKCcuL3RyYWNpbmcvdHJhY2UuanMnKTtcbmNvbnN0IGR5bmFtaWNTYW1wbGluZ0NvbnRleHQgPSByZXF1aXJlKCcuL3RyYWNpbmcvZHluYW1pY1NhbXBsaW5nQ29udGV4dC5qcycpO1xuY29uc3QgbWVhc3VyZW1lbnQgPSByZXF1aXJlKCcuL3RyYWNpbmcvbWVhc3VyZW1lbnQuanMnKTtcbmNvbnN0IHNhbXBsaW5nID0gcmVxdWlyZSgnLi90cmFjaW5nL3NhbXBsaW5nLmpzJyk7XG5jb25zdCBsb2dTcGFucyA9IHJlcXVpcmUoJy4vdHJhY2luZy9sb2dTcGFucy5qcycpO1xuY29uc3Qgc2VtYW50aWNBdHRyaWJ1dGVzID0gcmVxdWlyZSgnLi9zZW1hbnRpY0F0dHJpYnV0ZXMuanMnKTtcbmNvbnN0IGVudmVsb3BlID0gcmVxdWlyZSgnLi9lbnZlbG9wZS5qcycpO1xuY29uc3QgZXhwb3J0cyQxID0gcmVxdWlyZSgnLi9leHBvcnRzLmpzJyk7XG5jb25zdCBjdXJyZW50U2NvcGVzID0gcmVxdWlyZSgnLi9jdXJyZW50U2NvcGVzLmpzJyk7XG5jb25zdCBkZWZhdWx0U2NvcGVzID0gcmVxdWlyZSgnLi9kZWZhdWx0U2NvcGVzLmpzJyk7XG5jb25zdCBpbmRleCA9IHJlcXVpcmUoJy4vYXN5bmNDb250ZXh0L2luZGV4LmpzJyk7XG5jb25zdCBjYXJyaWVyID0gcmVxdWlyZSgnLi9jYXJyaWVyLmpzJyk7XG5jb25zdCBzZXNzaW9uID0gcmVxdWlyZSgnLi9zZXNzaW9uLmpzJyk7XG5jb25zdCBzY29wZSA9IHJlcXVpcmUoJy4vc2NvcGUuanMnKTtcbmNvbnN0IGV2ZW50UHJvY2Vzc29ycyA9IHJlcXVpcmUoJy4vZXZlbnRQcm9jZXNzb3JzLmpzJyk7XG5jb25zdCBhcGkgPSByZXF1aXJlKCcuL2FwaS5qcycpO1xuY29uc3QgY2xpZW50ID0gcmVxdWlyZSgnLi9jbGllbnQuanMnKTtcbmNvbnN0IHNlcnZlclJ1bnRpbWVDbGllbnQgPSByZXF1aXJlKCcuL3NlcnZlci1ydW50aW1lLWNsaWVudC5qcycpO1xuY29uc3Qgc2RrID0gcmVxdWlyZSgnLi9zZGsuanMnKTtcbmNvbnN0IGJhc2UgPSByZXF1aXJlKCcuL3RyYW5zcG9ydHMvYmFzZS5qcycpO1xuY29uc3Qgb2ZmbGluZSA9IHJlcXVpcmUoJy4vdHJhbnNwb3J0cy9vZmZsaW5lLmpzJyk7XG5jb25zdCBtdWx0aXBsZXhlZCA9IHJlcXVpcmUoJy4vdHJhbnNwb3J0cy9tdWx0aXBsZXhlZC5qcycpO1xuY29uc3QgaW50ZWdyYXRpb24gPSByZXF1aXJlKCcuL2ludGVncmF0aW9uLmpzJyk7XG5jb25zdCBhcHBseVNjb3BlRGF0YVRvRXZlbnQgPSByZXF1aXJlKCcuL3V0aWxzL2FwcGx5U2NvcGVEYXRhVG9FdmVudC5qcycpO1xuY29uc3QgcHJlcGFyZUV2ZW50ID0gcmVxdWlyZSgnLi91dGlscy9wcmVwYXJlRXZlbnQuanMnKTtcbmNvbnN0IGNoZWNraW4gPSByZXF1aXJlKCcuL2NoZWNraW4uanMnKTtcbmNvbnN0IGhhc1NwYW5zRW5hYmxlZCA9IHJlcXVpcmUoJy4vdXRpbHMvaGFzU3BhbnNFbmFibGVkLmpzJyk7XG5jb25zdCBpc1NlbnRyeVJlcXVlc3RVcmwgPSByZXF1aXJlKCcuL3V0aWxzL2lzU2VudHJ5UmVxdWVzdFVybC5qcycpO1xuY29uc3QgaGFuZGxlQ2FsbGJhY2tFcnJvcnMgPSByZXF1aXJlKCcuL3V0aWxzL2hhbmRsZUNhbGxiYWNrRXJyb3JzLmpzJyk7XG5jb25zdCBwYXJhbWV0ZXJpemUgPSByZXF1aXJlKCcuL3V0aWxzL3BhcmFtZXRlcml6ZS5qcycpO1xuY29uc3QgaXBBZGRyZXNzID0gcmVxdWlyZSgnLi91dGlscy9pcEFkZHJlc3MuanMnKTtcbmNvbnN0IHNwYW5VdGlscyA9IHJlcXVpcmUoJy4vdXRpbHMvc3BhblV0aWxzLmpzJyk7XG5jb25zdCBwYXJzZVNhbXBsZVJhdGUgPSByZXF1aXJlKCcuL3V0aWxzL3BhcnNlU2FtcGxlUmF0ZS5qcycpO1xuY29uc3Qgc2RrTWV0YWRhdGEgPSByZXF1aXJlKCcuL3V0aWxzL3Nka01ldGFkYXRhLmpzJyk7XG5jb25zdCB0cmFjZURhdGEgPSByZXF1aXJlKCcuL3V0aWxzL3RyYWNlRGF0YS5qcycpO1xuY29uc3QgbWV0YSA9IHJlcXVpcmUoJy4vdXRpbHMvbWV0YS5qcycpO1xuY29uc3QgZGVib3VuY2UgPSByZXF1aXJlKCcuL3V0aWxzL2RlYm91bmNlLmpzJyk7XG5jb25zdCByZXF1ZXN0ID0gcmVxdWlyZSgnLi91dGlscy9yZXF1ZXN0LmpzJyk7XG5jb25zdCBjb25zdGFudHMgPSByZXF1aXJlKCcuL2NvbnN0YW50cy5qcycpO1xuY29uc3QgYnJlYWRjcnVtYnMgPSByZXF1aXJlKCcuL2JyZWFkY3J1bWJzLmpzJyk7XG5jb25zdCBmdW5jdGlvbnRvc3RyaW5nID0gcmVxdWlyZSgnLi9pbnRlZ3JhdGlvbnMvZnVuY3Rpb250b3N0cmluZy5qcycpO1xuY29uc3QgZXZlbnRGaWx0ZXJzID0gcmVxdWlyZSgnLi9pbnRlZ3JhdGlvbnMvZXZlbnRGaWx0ZXJzLmpzJyk7XG5jb25zdCBsaW5rZWRlcnJvcnMgPSByZXF1aXJlKCcuL2ludGVncmF0aW9ucy9saW5rZWRlcnJvcnMuanMnKTtcbmNvbnN0IG1ldGFkYXRhID0gcmVxdWlyZSgnLi9pbnRlZ3JhdGlvbnMvbWV0YWRhdGEuanMnKTtcbmNvbnN0IHJlcXVlc3RkYXRhID0gcmVxdWlyZSgnLi9pbnRlZ3JhdGlvbnMvcmVxdWVzdGRhdGEuanMnKTtcbmNvbnN0IGNhcHR1cmVjb25zb2xlID0gcmVxdWlyZSgnLi9pbnRlZ3JhdGlvbnMvY2FwdHVyZWNvbnNvbGUuanMnKTtcbmNvbnN0IGRlZHVwZSA9IHJlcXVpcmUoJy4vaW50ZWdyYXRpb25zL2RlZHVwZS5qcycpO1xuY29uc3QgZXh0cmFlcnJvcmRhdGEgPSByZXF1aXJlKCcuL2ludGVncmF0aW9ucy9leHRyYWVycm9yZGF0YS5qcycpO1xuY29uc3QgcmV3cml0ZWZyYW1lcyA9IHJlcXVpcmUoJy4vaW50ZWdyYXRpb25zL3Jld3JpdGVmcmFtZXMuanMnKTtcbmNvbnN0IHN1cGFiYXNlID0gcmVxdWlyZSgnLi9pbnRlZ3JhdGlvbnMvc3VwYWJhc2UuanMnKTtcbmNvbnN0IHpvZGVycm9ycyA9IHJlcXVpcmUoJy4vaW50ZWdyYXRpb25zL3pvZGVycm9ycy5qcycpO1xuY29uc3QgdGhpcmRQYXJ0eUVycm9yc0ZpbHRlciA9IHJlcXVpcmUoJy4vaW50ZWdyYXRpb25zL3RoaXJkLXBhcnR5LWVycm9ycy1maWx0ZXIuanMnKTtcbmNvbnN0IGNvbnNvbGUgPSByZXF1aXJlKCcuL2ludGVncmF0aW9ucy9jb25zb2xlLmpzJyk7XG5jb25zdCBmZWF0dXJlRmxhZ3NJbnRlZ3JhdGlvbiA9IHJlcXVpcmUoJy4vaW50ZWdyYXRpb25zL2ZlYXR1cmVGbGFncy9mZWF0dXJlRmxhZ3NJbnRlZ3JhdGlvbi5qcycpO1xuY29uc3QgcHJvZmlsaW5nID0gcmVxdWlyZSgnLi9wcm9maWxpbmcuanMnKTtcbmNvbnN0IGZldGNoID0gcmVxdWlyZSgnLi9mZXRjaC5qcycpO1xuY29uc3QgdHJwYyA9IHJlcXVpcmUoJy4vdHJwYy5qcycpO1xuY29uc3QgaW5kZXgkMSA9IHJlcXVpcmUoJy4vaW50ZWdyYXRpb25zL21jcC1zZXJ2ZXIvaW5kZXguanMnKTtcbmNvbnN0IGZlZWRiYWNrID0gcmVxdWlyZSgnLi9mZWVkYmFjay5qcycpO1xuY29uc3QgZXhwb3J0cyQyID0gcmVxdWlyZSgnLi9sb2dzL2V4cG9ydHMuanMnKTtcbmNvbnN0IGNvbnNvbGVJbnRlZ3JhdGlvbiA9IHJlcXVpcmUoJy4vbG9ncy9jb25zb2xlLWludGVncmF0aW9uLmpzJyk7XG5jb25zdCB2ZXJjZWxBaSA9IHJlcXVpcmUoJy4vdXRpbHMvdmVyY2VsLWFpLmpzJyk7XG5jb25zdCBpbmRleCQyID0gcmVxdWlyZSgnLi91dGlscy9vcGVuYWkvaW5kZXguanMnKTtcbmNvbnN0IGNvbnN0YW50cyQxID0gcmVxdWlyZSgnLi91dGlscy9vcGVuYWkvY29uc3RhbnRzLmpzJyk7XG5jb25zdCBmZWF0dXJlRmxhZ3MgPSByZXF1aXJlKCcuL3V0aWxzL2ZlYXR1cmVGbGFncy5qcycpO1xuY29uc3QgYWdncmVnYXRlRXJyb3JzID0gcmVxdWlyZSgnLi91dGlscy9hZ2dyZWdhdGUtZXJyb3JzLmpzJyk7XG5jb25zdCBicmVhZGNydW1iTG9nTGV2ZWwgPSByZXF1aXJlKCcuL3V0aWxzL2JyZWFkY3J1bWItbG9nLWxldmVsLmpzJyk7XG5jb25zdCBicm93c2VyID0gcmVxdWlyZSgnLi91dGlscy9icm93c2VyLmpzJyk7XG5jb25zdCBkc24gPSByZXF1aXJlKCcuL3V0aWxzL2Rzbi5qcycpO1xuY29uc3QgZXJyb3IgPSByZXF1aXJlKCcuL3V0aWxzL2Vycm9yLmpzJyk7XG5jb25zdCB3b3JsZHdpZGUgPSByZXF1aXJlKCcuL3V0aWxzL3dvcmxkd2lkZS5qcycpO1xuY29uc3QgY29uc29sZSQxID0gcmVxdWlyZSgnLi9pbnN0cnVtZW50L2NvbnNvbGUuanMnKTtcbmNvbnN0IGZldGNoJDEgPSByZXF1aXJlKCcuL2luc3RydW1lbnQvZmV0Y2guanMnKTtcbmNvbnN0IGdsb2JhbEVycm9yID0gcmVxdWlyZSgnLi9pbnN0cnVtZW50L2dsb2JhbEVycm9yLmpzJyk7XG5jb25zdCBnbG9iYWxVbmhhbmRsZWRSZWplY3Rpb24gPSByZXF1aXJlKCcuL2luc3RydW1lbnQvZ2xvYmFsVW5oYW5kbGVkUmVqZWN0aW9uLmpzJyk7XG5jb25zdCBoYW5kbGVycyA9IHJlcXVpcmUoJy4vaW5zdHJ1bWVudC9oYW5kbGVycy5qcycpO1xuY29uc3QgaXMgPSByZXF1aXJlKCcuL3V0aWxzL2lzLmpzJyk7XG5jb25zdCBpc0Jyb3dzZXIgPSByZXF1aXJlKCcuL3V0aWxzL2lzQnJvd3Nlci5qcycpO1xuY29uc3QgZGVidWdMb2dnZXIgPSByZXF1aXJlKCcuL3V0aWxzL2RlYnVnLWxvZ2dlci5qcycpO1xuY29uc3QgbWlzYyA9IHJlcXVpcmUoJy4vdXRpbHMvbWlzYy5qcycpO1xuY29uc3Qgbm9kZSA9IHJlcXVpcmUoJy4vdXRpbHMvbm9kZS5qcycpO1xuY29uc3Qgbm9ybWFsaXplID0gcmVxdWlyZSgnLi91dGlscy9ub3JtYWxpemUuanMnKTtcbmNvbnN0IG9iamVjdCA9IHJlcXVpcmUoJy4vdXRpbHMvb2JqZWN0LmpzJyk7XG5jb25zdCBwYXRoID0gcmVxdWlyZSgnLi91dGlscy9wYXRoLmpzJyk7XG5jb25zdCBwcm9taXNlYnVmZmVyID0gcmVxdWlyZSgnLi91dGlscy9wcm9taXNlYnVmZmVyLmpzJyk7XG5jb25zdCBzZXZlcml0eSA9IHJlcXVpcmUoJy4vdXRpbHMvc2V2ZXJpdHkuanMnKTtcbmNvbnN0IHN0YWNrdHJhY2UgPSByZXF1aXJlKCcuL3V0aWxzL3N0YWNrdHJhY2UuanMnKTtcbmNvbnN0IG5vZGVTdGFja1RyYWNlID0gcmVxdWlyZSgnLi91dGlscy9ub2RlLXN0YWNrLXRyYWNlLmpzJyk7XG5jb25zdCBzdHJpbmcgPSByZXF1aXJlKCcuL3V0aWxzL3N0cmluZy5qcycpO1xuY29uc3Qgc3VwcG9ydHMgPSByZXF1aXJlKCcuL3V0aWxzL3N1cHBvcnRzLmpzJyk7XG5jb25zdCBzeW5jcHJvbWlzZSA9IHJlcXVpcmUoJy4vdXRpbHMvc3luY3Byb21pc2UuanMnKTtcbmNvbnN0IHRpbWUgPSByZXF1aXJlKCcuL3V0aWxzL3RpbWUuanMnKTtcbmNvbnN0IHRyYWNpbmcgPSByZXF1aXJlKCcuL3V0aWxzL3RyYWNpbmcuanMnKTtcbmNvbnN0IGVudiA9IHJlcXVpcmUoJy4vdXRpbHMvZW52LmpzJyk7XG5jb25zdCBlbnZlbG9wZSQxID0gcmVxdWlyZSgnLi91dGlscy9lbnZlbG9wZS5qcycpO1xuY29uc3QgY2xpZW50cmVwb3J0ID0gcmVxdWlyZSgnLi91dGlscy9jbGllbnRyZXBvcnQuanMnKTtcbmNvbnN0IHJhdGVsaW1pdCA9IHJlcXVpcmUoJy4vdXRpbHMvcmF0ZWxpbWl0LmpzJyk7XG5jb25zdCBiYWdnYWdlID0gcmVxdWlyZSgnLi91dGlscy9iYWdnYWdlLmpzJyk7XG5jb25zdCB1cmwgPSByZXF1aXJlKCcuL3V0aWxzL3VybC5qcycpO1xuY29uc3QgZXZlbnRidWlsZGVyID0gcmVxdWlyZSgnLi91dGlscy9ldmVudGJ1aWxkZXIuanMnKTtcbmNvbnN0IGFuciA9IHJlcXVpcmUoJy4vdXRpbHMvYW5yLmpzJyk7XG5jb25zdCBscnUgPSByZXF1aXJlKCcuL3V0aWxzL2xydS5qcycpO1xuY29uc3QgcHJvcGFnYXRpb25Db250ZXh0ID0gcmVxdWlyZSgnLi91dGlscy9wcm9wYWdhdGlvbkNvbnRleHQuanMnKTtcbmNvbnN0IHZlcmNlbFdhaXRVbnRpbCA9IHJlcXVpcmUoJy4vdXRpbHMvdmVyY2VsV2FpdFVudGlsLmpzJyk7XG5jb25zdCBmbHVzaElmU2VydmVybGVzcyA9IHJlcXVpcmUoJy4vdXRpbHMvZmx1c2hJZlNlcnZlcmxlc3MuanMnKTtcbmNvbnN0IHZlcnNpb24gPSByZXF1aXJlKCcuL3V0aWxzL3ZlcnNpb24uanMnKTtcbmNvbnN0IGRlYnVnSWRzID0gcmVxdWlyZSgnLi91dGlscy9kZWJ1Zy1pZHMuanMnKTtcbmNvbnN0IGVzY2FwZVN0cmluZ0ZvclJlZ2V4ID0gcmVxdWlyZSgnLi92ZW5kb3IvZXNjYXBlU3RyaW5nRm9yUmVnZXguanMnKTtcblxuXG5cbmV4cG9ydHMucmVnaXN0ZXJTcGFuRXJyb3JJbnN0cnVtZW50YXRpb24gPSBlcnJvcnMucmVnaXN0ZXJTcGFuRXJyb3JJbnN0cnVtZW50YXRpb247XG5leHBvcnRzLmdldENhcHR1cmVkU2NvcGVzT25TcGFuID0gdXRpbHMuZ2V0Q2FwdHVyZWRTY29wZXNPblNwYW47XG5leHBvcnRzLnNldENhcHR1cmVkU2NvcGVzT25TcGFuID0gdXRpbHMuc2V0Q2FwdHVyZWRTY29wZXNPblNwYW47XG5leHBvcnRzLlRSQUNJTkdfREVGQVVMVFMgPSBpZGxlU3Bhbi5UUkFDSU5HX0RFRkFVTFRTO1xuZXhwb3J0cy5zdGFydElkbGVTcGFuID0gaWRsZVNwYW4uc3RhcnRJZGxlU3BhbjtcbmV4cG9ydHMuU2VudHJ5U3BhbiA9IHNlbnRyeVNwYW4uU2VudHJ5U3BhbjtcbmV4cG9ydHMuU2VudHJ5Tm9uUmVjb3JkaW5nU3BhbiA9IHNlbnRyeU5vblJlY29yZGluZ1NwYW4uU2VudHJ5Tm9uUmVjb3JkaW5nU3BhbjtcbmV4cG9ydHMuU1BBTl9TVEFUVVNfRVJST1IgPSBzcGFuc3RhdHVzLlNQQU5fU1RBVFVTX0VSUk9SO1xuZXhwb3J0cy5TUEFOX1NUQVRVU19PSyA9IHNwYW5zdGF0dXMuU1BBTl9TVEFUVVNfT0s7XG5leHBvcnRzLlNQQU5fU1RBVFVTX1VOU0VUID0gc3BhbnN0YXR1cy5TUEFOX1NUQVRVU19VTlNFVDtcbmV4cG9ydHMuZ2V0U3BhblN0YXR1c0Zyb21IdHRwQ29kZSA9IHNwYW5zdGF0dXMuZ2V0U3BhblN0YXR1c0Zyb21IdHRwQ29kZTtcbmV4cG9ydHMuc2V0SHR0cFN0YXR1cyA9IHNwYW5zdGF0dXMuc2V0SHR0cFN0YXR1cztcbmV4cG9ydHMuY29udGludWVUcmFjZSA9IHRyYWNlLmNvbnRpbnVlVHJhY2U7XG5leHBvcnRzLnN0YXJ0SW5hY3RpdmVTcGFuID0gdHJhY2Uuc3RhcnRJbmFjdGl2ZVNwYW47XG5leHBvcnRzLnN0YXJ0TmV3VHJhY2UgPSB0cmFjZS5zdGFydE5ld1RyYWNlO1xuZXhwb3J0cy5zdGFydFNwYW4gPSB0cmFjZS5zdGFydFNwYW47XG5leHBvcnRzLnN0YXJ0U3Bhbk1hbnVhbCA9IHRyYWNlLnN0YXJ0U3Bhbk1hbnVhbDtcbmV4cG9ydHMuc3VwcHJlc3NUcmFjaW5nID0gdHJhY2Uuc3VwcHJlc3NUcmFjaW5nO1xuZXhwb3J0cy53aXRoQWN0aXZlU3BhbiA9IHRyYWNlLndpdGhBY3RpdmVTcGFuO1xuZXhwb3J0cy5nZXREeW5hbWljU2FtcGxpbmdDb250ZXh0RnJvbUNsaWVudCA9IGR5bmFtaWNTYW1wbGluZ0NvbnRleHQuZ2V0RHluYW1pY1NhbXBsaW5nQ29udGV4dEZyb21DbGllbnQ7XG5leHBvcnRzLmdldER5bmFtaWNTYW1wbGluZ0NvbnRleHRGcm9tU2NvcGUgPSBkeW5hbWljU2FtcGxpbmdDb250ZXh0LmdldER5bmFtaWNTYW1wbGluZ0NvbnRleHRGcm9tU2NvcGU7XG5leHBvcnRzLmdldER5bmFtaWNTYW1wbGluZ0NvbnRleHRGcm9tU3BhbiA9IGR5bmFtaWNTYW1wbGluZ0NvbnRleHQuZ2V0RHluYW1pY1NhbXBsaW5nQ29udGV4dEZyb21TcGFuO1xuZXhwb3J0cy5zcGFuVG9CYWdnYWdlSGVhZGVyID0gZHluYW1pY1NhbXBsaW5nQ29udGV4dC5zcGFuVG9CYWdnYWdlSGVhZGVyO1xuZXhwb3J0cy5zZXRNZWFzdXJlbWVudCA9IG1lYXN1cmVtZW50LnNldE1lYXN1cmVtZW50O1xuZXhwb3J0cy50aW1lZEV2ZW50c1RvTWVhc3VyZW1lbnRzID0gbWVhc3VyZW1lbnQudGltZWRFdmVudHNUb01lYXN1cmVtZW50cztcbmV4cG9ydHMuc2FtcGxlU3BhbiA9IHNhbXBsaW5nLnNhbXBsZVNwYW47XG5leHBvcnRzLmxvZ1NwYW5FbmQgPSBsb2dTcGFucy5sb2dTcGFuRW5kO1xuZXhwb3J0cy5sb2dTcGFuU3RhcnQgPSBsb2dTcGFucy5sb2dTcGFuU3RhcnQ7XG5leHBvcnRzLlNFTUFOVElDX0FUVFJJQlVURV9DQUNIRV9ISVQgPSBzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX0NBQ0hFX0hJVDtcbmV4cG9ydHMuU0VNQU5USUNfQVRUUklCVVRFX0NBQ0hFX0lURU1fU0laRSA9IHNlbWFudGljQXR0cmlidXRlcy5TRU1BTlRJQ19BVFRSSUJVVEVfQ0FDSEVfSVRFTV9TSVpFO1xuZXhwb3J0cy5TRU1BTlRJQ19BVFRSSUJVVEVfQ0FDSEVfS0VZID0gc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9DQUNIRV9LRVk7XG5leHBvcnRzLlNFTUFOVElDX0FUVFJJQlVURV9FWENMVVNJVkVfVElNRSA9IHNlbWFudGljQXR0cmlidXRlcy5TRU1BTlRJQ19BVFRSSUJVVEVfRVhDTFVTSVZFX1RJTUU7XG5leHBvcnRzLlNFTUFOVElDX0FUVFJJQlVURV9IVFRQX1JFUVVFU1RfTUVUSE9EID0gc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9IVFRQX1JFUVVFU1RfTUVUSE9EO1xuZXhwb3J0cy5TRU1BTlRJQ19BVFRSSUJVVEVfUFJPRklMRV9JRCA9IHNlbWFudGljQXR0cmlidXRlcy5TRU1BTlRJQ19BVFRSSUJVVEVfUFJPRklMRV9JRDtcbmV4cG9ydHMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9DVVNUT01fU1BBTl9OQU1FID0gc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfQ1VTVE9NX1NQQU5fTkFNRTtcbmV4cG9ydHMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9JRExFX1NQQU5fRklOSVNIX1JFQVNPTiA9IHNlbWFudGljQXR0cmlidXRlcy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX0lETEVfU1BBTl9GSU5JU0hfUkVBU09OO1xuZXhwb3J0cy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX01FQVNVUkVNRU5UX1VOSVQgPSBzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9NRUFTVVJFTUVOVF9VTklUO1xuZXhwb3J0cy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX01FQVNVUkVNRU5UX1ZBTFVFID0gc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfTUVBU1VSRU1FTlRfVkFMVUU7XG5leHBvcnRzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfT1AgPSBzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9PUDtcbmV4cG9ydHMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9PUklHSU4gPSBzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9PUklHSU47XG5leHBvcnRzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfUFJFVklPVVNfVFJBQ0VfU0FNUExFX1JBVEUgPSBzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9QUkVWSU9VU19UUkFDRV9TQU1QTEVfUkFURTtcbmV4cG9ydHMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9TQU1QTEVfUkFURSA9IHNlbWFudGljQXR0cmlidXRlcy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX1NBTVBMRV9SQVRFO1xuZXhwb3J0cy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX1NPVVJDRSA9IHNlbWFudGljQXR0cmlidXRlcy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX1NPVVJDRTtcbmV4cG9ydHMuU0VNQU5USUNfQVRUUklCVVRFX1VSTF9GVUxMID0gc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9VUkxfRlVMTDtcbmV4cG9ydHMuU0VNQU5USUNfTElOS19BVFRSSUJVVEVfTElOS19UWVBFID0gc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0xJTktfQVRUUklCVVRFX0xJTktfVFlQRTtcbmV4cG9ydHMuY3JlYXRlRXZlbnRFbnZlbG9wZSA9IGVudmVsb3BlLmNyZWF0ZUV2ZW50RW52ZWxvcGU7XG5leHBvcnRzLmNyZWF0ZVNlc3Npb25FbnZlbG9wZSA9IGVudmVsb3BlLmNyZWF0ZVNlc3Npb25FbnZlbG9wZTtcbmV4cG9ydHMuY3JlYXRlU3BhbkVudmVsb3BlID0gZW52ZWxvcGUuY3JlYXRlU3BhbkVudmVsb3BlO1xuZXhwb3J0cy5hZGRFdmVudFByb2Nlc3NvciA9IGV4cG9ydHMkMS5hZGRFdmVudFByb2Nlc3NvcjtcbmV4cG9ydHMuY2FwdHVyZUNoZWNrSW4gPSBleHBvcnRzJDEuY2FwdHVyZUNoZWNrSW47XG5leHBvcnRzLmNhcHR1cmVFdmVudCA9IGV4cG9ydHMkMS5jYXB0dXJlRXZlbnQ7XG5leHBvcnRzLmNhcHR1cmVFeGNlcHRpb24gPSBleHBvcnRzJDEuY2FwdHVyZUV4Y2VwdGlvbjtcbmV4cG9ydHMuY2FwdHVyZU1lc3NhZ2UgPSBleHBvcnRzJDEuY2FwdHVyZU1lc3NhZ2U7XG5leHBvcnRzLmNhcHR1cmVTZXNzaW9uID0gZXhwb3J0cyQxLmNhcHR1cmVTZXNzaW9uO1xuZXhwb3J0cy5jbG9zZSA9IGV4cG9ydHMkMS5jbG9zZTtcbmV4cG9ydHMuZW5kU2Vzc2lvbiA9IGV4cG9ydHMkMS5lbmRTZXNzaW9uO1xuZXhwb3J0cy5mbHVzaCA9IGV4cG9ydHMkMS5mbHVzaDtcbmV4cG9ydHMuaXNFbmFibGVkID0gZXhwb3J0cyQxLmlzRW5hYmxlZDtcbmV4cG9ydHMuaXNJbml0aWFsaXplZCA9IGV4cG9ydHMkMS5pc0luaXRpYWxpemVkO1xuZXhwb3J0cy5sYXN0RXZlbnRJZCA9IGV4cG9ydHMkMS5sYXN0RXZlbnRJZDtcbmV4cG9ydHMuc2V0Q29udGV4dCA9IGV4cG9ydHMkMS5zZXRDb250ZXh0O1xuZXhwb3J0cy5zZXRFeHRyYSA9IGV4cG9ydHMkMS5zZXRFeHRyYTtcbmV4cG9ydHMuc2V0RXh0cmFzID0gZXhwb3J0cyQxLnNldEV4dHJhcztcbmV4cG9ydHMuc2V0VGFnID0gZXhwb3J0cyQxLnNldFRhZztcbmV4cG9ydHMuc2V0VGFncyA9IGV4cG9ydHMkMS5zZXRUYWdzO1xuZXhwb3J0cy5zZXRVc2VyID0gZXhwb3J0cyQxLnNldFVzZXI7XG5leHBvcnRzLnN0YXJ0U2Vzc2lvbiA9IGV4cG9ydHMkMS5zdGFydFNlc3Npb247XG5leHBvcnRzLndpdGhNb25pdG9yID0gZXhwb3J0cyQxLndpdGhNb25pdG9yO1xuZXhwb3J0cy5nZXRDbGllbnQgPSBjdXJyZW50U2NvcGVzLmdldENsaWVudDtcbmV4cG9ydHMuZ2V0Q3VycmVudFNjb3BlID0gY3VycmVudFNjb3Blcy5nZXRDdXJyZW50U2NvcGU7XG5leHBvcnRzLmdldEdsb2JhbFNjb3BlID0gY3VycmVudFNjb3Blcy5nZXRHbG9iYWxTY29wZTtcbmV4cG9ydHMuZ2V0SXNvbGF0aW9uU2NvcGUgPSBjdXJyZW50U2NvcGVzLmdldElzb2xhdGlvblNjb3BlO1xuZXhwb3J0cy5nZXRUcmFjZUNvbnRleHRGcm9tU2NvcGUgPSBjdXJyZW50U2NvcGVzLmdldFRyYWNlQ29udGV4dEZyb21TY29wZTtcbmV4cG9ydHMud2l0aElzb2xhdGlvblNjb3BlID0gY3VycmVudFNjb3Blcy53aXRoSXNvbGF0aW9uU2NvcGU7XG5leHBvcnRzLndpdGhTY29wZSA9IGN1cnJlbnRTY29wZXMud2l0aFNjb3BlO1xuZXhwb3J0cy5nZXREZWZhdWx0Q3VycmVudFNjb3BlID0gZGVmYXVsdFNjb3Blcy5nZXREZWZhdWx0Q3VycmVudFNjb3BlO1xuZXhwb3J0cy5nZXREZWZhdWx0SXNvbGF0aW9uU2NvcGUgPSBkZWZhdWx0U2NvcGVzLmdldERlZmF1bHRJc29sYXRpb25TY29wZTtcbmV4cG9ydHMuc2V0QXN5bmNDb250ZXh0U3RyYXRlZ3kgPSBpbmRleC5zZXRBc3luY0NvbnRleHRTdHJhdGVneTtcbmV4cG9ydHMuZ2V0R2xvYmFsU2luZ2xldG9uID0gY2Fycmllci5nZXRHbG9iYWxTaW5nbGV0b247XG5leHBvcnRzLmdldE1haW5DYXJyaWVyID0gY2Fycmllci5nZXRNYWluQ2FycmllcjtcbmV4cG9ydHMuY2xvc2VTZXNzaW9uID0gc2Vzc2lvbi5jbG9zZVNlc3Npb247XG5leHBvcnRzLm1ha2VTZXNzaW9uID0gc2Vzc2lvbi5tYWtlU2Vzc2lvbjtcbmV4cG9ydHMudXBkYXRlU2Vzc2lvbiA9IHNlc3Npb24udXBkYXRlU2Vzc2lvbjtcbmV4cG9ydHMuU2NvcGUgPSBzY29wZS5TY29wZTtcbmV4cG9ydHMubm90aWZ5RXZlbnRQcm9jZXNzb3JzID0gZXZlbnRQcm9jZXNzb3JzLm5vdGlmeUV2ZW50UHJvY2Vzc29ycztcbmV4cG9ydHMuZ2V0RW52ZWxvcGVFbmRwb2ludFdpdGhVcmxFbmNvZGVkQXV0aCA9IGFwaS5nZXRFbnZlbG9wZUVuZHBvaW50V2l0aFVybEVuY29kZWRBdXRoO1xuZXhwb3J0cy5nZXRSZXBvcnREaWFsb2dFbmRwb2ludCA9IGFwaS5nZXRSZXBvcnREaWFsb2dFbmRwb2ludDtcbmV4cG9ydHMuQmFzZUNsaWVudCA9IGNsaWVudC5CYXNlQ2xpZW50O1xuZXhwb3J0cy5DbGllbnQgPSBjbGllbnQuQ2xpZW50O1xuZXhwb3J0cy5TZXJ2ZXJSdW50aW1lQ2xpZW50ID0gc2VydmVyUnVudGltZUNsaWVudC5TZXJ2ZXJSdW50aW1lQ2xpZW50O1xuZXhwb3J0cy5pbml0QW5kQmluZCA9IHNkay5pbml0QW5kQmluZDtcbmV4cG9ydHMuc2V0Q3VycmVudENsaWVudCA9IHNkay5zZXRDdXJyZW50Q2xpZW50O1xuZXhwb3J0cy5jcmVhdGVUcmFuc3BvcnQgPSBiYXNlLmNyZWF0ZVRyYW5zcG9ydDtcbmV4cG9ydHMubWFrZU9mZmxpbmVUcmFuc3BvcnQgPSBvZmZsaW5lLm1ha2VPZmZsaW5lVHJhbnNwb3J0O1xuZXhwb3J0cy5tYWtlTXVsdGlwbGV4ZWRUcmFuc3BvcnQgPSBtdWx0aXBsZXhlZC5tYWtlTXVsdGlwbGV4ZWRUcmFuc3BvcnQ7XG5leHBvcnRzLmFkZEludGVncmF0aW9uID0gaW50ZWdyYXRpb24uYWRkSW50ZWdyYXRpb247XG5leHBvcnRzLmRlZmluZUludGVncmF0aW9uID0gaW50ZWdyYXRpb24uZGVmaW5lSW50ZWdyYXRpb247XG5leHBvcnRzLmdldEludGVncmF0aW9uc1RvU2V0dXAgPSBpbnRlZ3JhdGlvbi5nZXRJbnRlZ3JhdGlvbnNUb1NldHVwO1xuZXhwb3J0cy5hcHBseVNjb3BlRGF0YVRvRXZlbnQgPSBhcHBseVNjb3BlRGF0YVRvRXZlbnQuYXBwbHlTY29wZURhdGFUb0V2ZW50O1xuZXhwb3J0cy5tZXJnZVNjb3BlRGF0YSA9IGFwcGx5U2NvcGVEYXRhVG9FdmVudC5tZXJnZVNjb3BlRGF0YTtcbmV4cG9ydHMucHJlcGFyZUV2ZW50ID0gcHJlcGFyZUV2ZW50LnByZXBhcmVFdmVudDtcbmV4cG9ydHMuY3JlYXRlQ2hlY2tJbkVudmVsb3BlID0gY2hlY2tpbi5jcmVhdGVDaGVja0luRW52ZWxvcGU7XG5leHBvcnRzLmhhc1NwYW5zRW5hYmxlZCA9IGhhc1NwYW5zRW5hYmxlZC5oYXNTcGFuc0VuYWJsZWQ7XG5leHBvcnRzLmhhc1RyYWNpbmdFbmFibGVkID0gaGFzU3BhbnNFbmFibGVkLmhhc1RyYWNpbmdFbmFibGVkO1xuZXhwb3J0cy5pc1NlbnRyeVJlcXVlc3RVcmwgPSBpc1NlbnRyeVJlcXVlc3RVcmwuaXNTZW50cnlSZXF1ZXN0VXJsO1xuZXhwb3J0cy5oYW5kbGVDYWxsYmFja0Vycm9ycyA9IGhhbmRsZUNhbGxiYWNrRXJyb3JzLmhhbmRsZUNhbGxiYWNrRXJyb3JzO1xuZXhwb3J0cy5mbXQgPSBwYXJhbWV0ZXJpemUuZm10O1xuZXhwb3J0cy5wYXJhbWV0ZXJpemUgPSBwYXJhbWV0ZXJpemUucGFyYW1ldGVyaXplO1xuZXhwb3J0cy5hZGRBdXRvSXBBZGRyZXNzVG9TZXNzaW9uID0gaXBBZGRyZXNzLmFkZEF1dG9JcEFkZHJlc3NUb1Nlc3Npb247XG5leHBvcnRzLmFkZEF1dG9JcEFkZHJlc3NUb1VzZXIgPSBpcEFkZHJlc3MuYWRkQXV0b0lwQWRkcmVzc1RvVXNlcjtcbmV4cG9ydHMuYWRkQ2hpbGRTcGFuVG9TcGFuID0gc3BhblV0aWxzLmFkZENoaWxkU3BhblRvU3BhbjtcbmV4cG9ydHMuY29udmVydFNwYW5MaW5rc0ZvckVudmVsb3BlID0gc3BhblV0aWxzLmNvbnZlcnRTcGFuTGlua3NGb3JFbnZlbG9wZTtcbmV4cG9ydHMuZ2V0QWN0aXZlU3BhbiA9IHNwYW5VdGlscy5nZXRBY3RpdmVTcGFuO1xuZXhwb3J0cy5nZXRSb290U3BhbiA9IHNwYW5VdGlscy5nZXRSb290U3BhbjtcbmV4cG9ydHMuZ2V0U3BhbkRlc2NlbmRhbnRzID0gc3BhblV0aWxzLmdldFNwYW5EZXNjZW5kYW50cztcbmV4cG9ydHMuZ2V0U3RhdHVzTWVzc2FnZSA9IHNwYW5VdGlscy5nZXRTdGF0dXNNZXNzYWdlO1xuZXhwb3J0cy5zcGFuSXNTYW1wbGVkID0gc3BhblV0aWxzLnNwYW5Jc1NhbXBsZWQ7XG5leHBvcnRzLnNwYW5UaW1lSW5wdXRUb1NlY29uZHMgPSBzcGFuVXRpbHMuc3BhblRpbWVJbnB1dFRvU2Vjb25kcztcbmV4cG9ydHMuc3BhblRvSlNPTiA9IHNwYW5VdGlscy5zcGFuVG9KU09OO1xuZXhwb3J0cy5zcGFuVG9UcmFjZUNvbnRleHQgPSBzcGFuVXRpbHMuc3BhblRvVHJhY2VDb250ZXh0O1xuZXhwb3J0cy5zcGFuVG9UcmFjZUhlYWRlciA9IHNwYW5VdGlscy5zcGFuVG9UcmFjZUhlYWRlcjtcbmV4cG9ydHMudXBkYXRlU3Bhbk5hbWUgPSBzcGFuVXRpbHMudXBkYXRlU3Bhbk5hbWU7XG5leHBvcnRzLnBhcnNlU2FtcGxlUmF0ZSA9IHBhcnNlU2FtcGxlUmF0ZS5wYXJzZVNhbXBsZVJhdGU7XG5leHBvcnRzLmFwcGx5U2RrTWV0YWRhdGEgPSBzZGtNZXRhZGF0YS5hcHBseVNka01ldGFkYXRhO1xuZXhwb3J0cy5nZXRUcmFjZURhdGEgPSB0cmFjZURhdGEuZ2V0VHJhY2VEYXRhO1xuZXhwb3J0cy5nZXRUcmFjZU1ldGFUYWdzID0gbWV0YS5nZXRUcmFjZU1ldGFUYWdzO1xuZXhwb3J0cy5kZWJvdW5jZSA9IGRlYm91bmNlLmRlYm91bmNlO1xuZXhwb3J0cy5leHRyYWN0UXVlcnlQYXJhbXNGcm9tVXJsID0gcmVxdWVzdC5leHRyYWN0UXVlcnlQYXJhbXNGcm9tVXJsO1xuZXhwb3J0cy5oZWFkZXJzVG9EaWN0ID0gcmVxdWVzdC5oZWFkZXJzVG9EaWN0O1xuZXhwb3J0cy5odHRwUmVxdWVzdFRvUmVxdWVzdERhdGEgPSByZXF1ZXN0Lmh0dHBSZXF1ZXN0VG9SZXF1ZXN0RGF0YTtcbmV4cG9ydHMud2ludGVyQ0dIZWFkZXJzVG9EaWN0ID0gcmVxdWVzdC53aW50ZXJDR0hlYWRlcnNUb0RpY3Q7XG5leHBvcnRzLndpbnRlckNHUmVxdWVzdFRvUmVxdWVzdERhdGEgPSByZXF1ZXN0LndpbnRlckNHUmVxdWVzdFRvUmVxdWVzdERhdGE7XG5leHBvcnRzLkRFRkFVTFRfRU5WSVJPTk1FTlQgPSBjb25zdGFudHMuREVGQVVMVF9FTlZJUk9OTUVOVDtcbmV4cG9ydHMuYWRkQnJlYWRjcnVtYiA9IGJyZWFkY3J1bWJzLmFkZEJyZWFkY3J1bWI7XG5leHBvcnRzLmZ1bmN0aW9uVG9TdHJpbmdJbnRlZ3JhdGlvbiA9IGZ1bmN0aW9udG9zdHJpbmcuZnVuY3Rpb25Ub1N0cmluZ0ludGVncmF0aW9uO1xuZXhwb3J0cy5ldmVudEZpbHRlcnNJbnRlZ3JhdGlvbiA9IGV2ZW50RmlsdGVycy5ldmVudEZpbHRlcnNJbnRlZ3JhdGlvbjtcbmV4cG9ydHMuaW5ib3VuZEZpbHRlcnNJbnRlZ3JhdGlvbiA9IGV2ZW50RmlsdGVycy5pbmJvdW5kRmlsdGVyc0ludGVncmF0aW9uO1xuZXhwb3J0cy5saW5rZWRFcnJvcnNJbnRlZ3JhdGlvbiA9IGxpbmtlZGVycm9ycy5saW5rZWRFcnJvcnNJbnRlZ3JhdGlvbjtcbmV4cG9ydHMubW9kdWxlTWV0YWRhdGFJbnRlZ3JhdGlvbiA9IG1ldGFkYXRhLm1vZHVsZU1ldGFkYXRhSW50ZWdyYXRpb247XG5leHBvcnRzLnJlcXVlc3REYXRhSW50ZWdyYXRpb24gPSByZXF1ZXN0ZGF0YS5yZXF1ZXN0RGF0YUludGVncmF0aW9uO1xuZXhwb3J0cy5jYXB0dXJlQ29uc29sZUludGVncmF0aW9uID0gY2FwdHVyZWNvbnNvbGUuY2FwdHVyZUNvbnNvbGVJbnRlZ3JhdGlvbjtcbmV4cG9ydHMuZGVkdXBlSW50ZWdyYXRpb24gPSBkZWR1cGUuZGVkdXBlSW50ZWdyYXRpb247XG5leHBvcnRzLmV4dHJhRXJyb3JEYXRhSW50ZWdyYXRpb24gPSBleHRyYWVycm9yZGF0YS5leHRyYUVycm9yRGF0YUludGVncmF0aW9uO1xuZXhwb3J0cy5yZXdyaXRlRnJhbWVzSW50ZWdyYXRpb24gPSByZXdyaXRlZnJhbWVzLnJld3JpdGVGcmFtZXNJbnRlZ3JhdGlvbjtcbmV4cG9ydHMuaW5zdHJ1bWVudFN1cGFiYXNlQ2xpZW50ID0gc3VwYWJhc2UuaW5zdHJ1bWVudFN1cGFiYXNlQ2xpZW50O1xuZXhwb3J0cy5zdXBhYmFzZUludGVncmF0aW9uID0gc3VwYWJhc2Uuc3VwYWJhc2VJbnRlZ3JhdGlvbjtcbmV4cG9ydHMuem9kRXJyb3JzSW50ZWdyYXRpb24gPSB6b2RlcnJvcnMuem9kRXJyb3JzSW50ZWdyYXRpb247XG5leHBvcnRzLnRoaXJkUGFydHlFcnJvckZpbHRlckludGVncmF0aW9uID0gdGhpcmRQYXJ0eUVycm9yc0ZpbHRlci50aGlyZFBhcnR5RXJyb3JGaWx0ZXJJbnRlZ3JhdGlvbjtcbmV4cG9ydHMuY29uc29sZUludGVncmF0aW9uID0gY29uc29sZS5jb25zb2xlSW50ZWdyYXRpb247XG5leHBvcnRzLmZlYXR1cmVGbGFnc0ludGVncmF0aW9uID0gZmVhdHVyZUZsYWdzSW50ZWdyYXRpb24uZmVhdHVyZUZsYWdzSW50ZWdyYXRpb247XG5leHBvcnRzLnByb2ZpbGVyID0gcHJvZmlsaW5nLnByb2ZpbGVyO1xuZXhwb3J0cy5pbnN0cnVtZW50RmV0Y2hSZXF1ZXN0ID0gZmV0Y2guaW5zdHJ1bWVudEZldGNoUmVxdWVzdDtcbmV4cG9ydHMudHJwY01pZGRsZXdhcmUgPSB0cnBjLnRycGNNaWRkbGV3YXJlO1xuZXhwb3J0cy53cmFwTWNwU2VydmVyV2l0aFNlbnRyeSA9IGluZGV4JDEud3JhcE1jcFNlcnZlcldpdGhTZW50cnk7XG5leHBvcnRzLmNhcHR1cmVGZWVkYmFjayA9IGZlZWRiYWNrLmNhcHR1cmVGZWVkYmFjaztcbmV4cG9ydHMuX0lOVEVSTkFMX2NhcHR1cmVMb2cgPSBleHBvcnRzJDIuX0lOVEVSTkFMX2NhcHR1cmVMb2c7XG5leHBvcnRzLl9JTlRFUk5BTF9jYXB0dXJlU2VyaWFsaXplZExvZyA9IGV4cG9ydHMkMi5fSU5URVJOQUxfY2FwdHVyZVNlcmlhbGl6ZWRMb2c7XG5leHBvcnRzLl9JTlRFUk5BTF9mbHVzaExvZ3NCdWZmZXIgPSBleHBvcnRzJDIuX0lOVEVSTkFMX2ZsdXNoTG9nc0J1ZmZlcjtcbmV4cG9ydHMuY29uc29sZUxvZ2dpbmdJbnRlZ3JhdGlvbiA9IGNvbnNvbGVJbnRlZ3JhdGlvbi5jb25zb2xlTG9nZ2luZ0ludGVncmF0aW9uO1xuZXhwb3J0cy5hZGRWZXJjZWxBaVByb2Nlc3NvcnMgPSB2ZXJjZWxBaS5hZGRWZXJjZWxBaVByb2Nlc3NvcnM7XG5leHBvcnRzLmluc3RydW1lbnRPcGVuQWlDbGllbnQgPSBpbmRleCQyLmluc3RydW1lbnRPcGVuQWlDbGllbnQ7XG5leHBvcnRzLk9QRU5BSV9JTlRFR1JBVElPTl9OQU1FID0gY29uc3RhbnRzJDEuT1BFTkFJX0lOVEVHUkFUSU9OX05BTUU7XG5leHBvcnRzLl9JTlRFUk5BTF9GTEFHX0JVRkZFUl9TSVpFID0gZmVhdHVyZUZsYWdzLl9JTlRFUk5BTF9GTEFHX0JVRkZFUl9TSVpFO1xuZXhwb3J0cy5fSU5URVJOQUxfTUFYX0ZMQUdTX1BFUl9TUEFOID0gZmVhdHVyZUZsYWdzLl9JTlRFUk5BTF9NQVhfRkxBR1NfUEVSX1NQQU47XG5leHBvcnRzLl9JTlRFUk5BTF9hZGRGZWF0dXJlRmxhZ1RvQWN0aXZlU3BhbiA9IGZlYXR1cmVGbGFncy5fSU5URVJOQUxfYWRkRmVhdHVyZUZsYWdUb0FjdGl2ZVNwYW47XG5leHBvcnRzLl9JTlRFUk5BTF9jb3B5RmxhZ3NGcm9tU2NvcGVUb0V2ZW50ID0gZmVhdHVyZUZsYWdzLl9JTlRFUk5BTF9jb3B5RmxhZ3NGcm9tU2NvcGVUb0V2ZW50O1xuZXhwb3J0cy5fSU5URVJOQUxfaW5zZXJ0RmxhZ1RvU2NvcGUgPSBmZWF0dXJlRmxhZ3MuX0lOVEVSTkFMX2luc2VydEZsYWdUb1Njb3BlO1xuZXhwb3J0cy5hcHBseUFnZ3JlZ2F0ZUVycm9yc1RvRXZlbnQgPSBhZ2dyZWdhdGVFcnJvcnMuYXBwbHlBZ2dyZWdhdGVFcnJvcnNUb0V2ZW50O1xuZXhwb3J0cy5nZXRCcmVhZGNydW1iTG9nTGV2ZWxGcm9tSHR0cFN0YXR1c0NvZGUgPSBicmVhZGNydW1iTG9nTGV2ZWwuZ2V0QnJlYWRjcnVtYkxvZ0xldmVsRnJvbUh0dHBTdGF0dXNDb2RlO1xuZXhwb3J0cy5nZXRDb21wb25lbnROYW1lID0gYnJvd3Nlci5nZXRDb21wb25lbnROYW1lO1xuZXhwb3J0cy5nZXRMb2NhdGlvbkhyZWYgPSBicm93c2VyLmdldExvY2F0aW9uSHJlZjtcbmV4cG9ydHMuaHRtbFRyZWVBc1N0cmluZyA9IGJyb3dzZXIuaHRtbFRyZWVBc1N0cmluZztcbmV4cG9ydHMuZHNuRnJvbVN0cmluZyA9IGRzbi5kc25Gcm9tU3RyaW5nO1xuZXhwb3J0cy5kc25Ub1N0cmluZyA9IGRzbi5kc25Ub1N0cmluZztcbmV4cG9ydHMubWFrZURzbiA9IGRzbi5tYWtlRHNuO1xuZXhwb3J0cy5TZW50cnlFcnJvciA9IGVycm9yLlNlbnRyeUVycm9yO1xuZXhwb3J0cy5HTE9CQUxfT0JKID0gd29ybGR3aWRlLkdMT0JBTF9PQko7XG5leHBvcnRzLmFkZENvbnNvbGVJbnN0cnVtZW50YXRpb25IYW5kbGVyID0gY29uc29sZSQxLmFkZENvbnNvbGVJbnN0cnVtZW50YXRpb25IYW5kbGVyO1xuZXhwb3J0cy5hZGRGZXRjaEVuZEluc3RydW1lbnRhdGlvbkhhbmRsZXIgPSBmZXRjaCQxLmFkZEZldGNoRW5kSW5zdHJ1bWVudGF0aW9uSGFuZGxlcjtcbmV4cG9ydHMuYWRkRmV0Y2hJbnN0cnVtZW50YXRpb25IYW5kbGVyID0gZmV0Y2gkMS5hZGRGZXRjaEluc3RydW1lbnRhdGlvbkhhbmRsZXI7XG5leHBvcnRzLmFkZEdsb2JhbEVycm9ySW5zdHJ1bWVudGF0aW9uSGFuZGxlciA9IGdsb2JhbEVycm9yLmFkZEdsb2JhbEVycm9ySW5zdHJ1bWVudGF0aW9uSGFuZGxlcjtcbmV4cG9ydHMuYWRkR2xvYmFsVW5oYW5kbGVkUmVqZWN0aW9uSW5zdHJ1bWVudGF0aW9uSGFuZGxlciA9IGdsb2JhbFVuaGFuZGxlZFJlamVjdGlvbi5hZGRHbG9iYWxVbmhhbmRsZWRSZWplY3Rpb25JbnN0cnVtZW50YXRpb25IYW5kbGVyO1xuZXhwb3J0cy5hZGRIYW5kbGVyID0gaGFuZGxlcnMuYWRkSGFuZGxlcjtcbmV4cG9ydHMubWF5YmVJbnN0cnVtZW50ID0gaGFuZGxlcnMubWF5YmVJbnN0cnVtZW50O1xuZXhwb3J0cy5yZXNldEluc3RydW1lbnRhdGlvbkhhbmRsZXJzID0gaGFuZGxlcnMucmVzZXRJbnN0cnVtZW50YXRpb25IYW5kbGVycztcbmV4cG9ydHMudHJpZ2dlckhhbmRsZXJzID0gaGFuZGxlcnMudHJpZ2dlckhhbmRsZXJzO1xuZXhwb3J0cy5pc0RPTUVycm9yID0gaXMuaXNET01FcnJvcjtcbmV4cG9ydHMuaXNET01FeGNlcHRpb24gPSBpcy5pc0RPTUV4Y2VwdGlvbjtcbmV4cG9ydHMuaXNFbGVtZW50ID0gaXMuaXNFbGVtZW50O1xuZXhwb3J0cy5pc0Vycm9yID0gaXMuaXNFcnJvcjtcbmV4cG9ydHMuaXNFcnJvckV2ZW50ID0gaXMuaXNFcnJvckV2ZW50O1xuZXhwb3J0cy5pc0V2ZW50ID0gaXMuaXNFdmVudDtcbmV4cG9ydHMuaXNJbnN0YW5jZU9mID0gaXMuaXNJbnN0YW5jZU9mO1xuZXhwb3J0cy5pc1BhcmFtZXRlcml6ZWRTdHJpbmcgPSBpcy5pc1BhcmFtZXRlcml6ZWRTdHJpbmc7XG5leHBvcnRzLmlzUGxhaW5PYmplY3QgPSBpcy5pc1BsYWluT2JqZWN0O1xuZXhwb3J0cy5pc1ByaW1pdGl2ZSA9IGlzLmlzUHJpbWl0aXZlO1xuZXhwb3J0cy5pc1JlZ0V4cCA9IGlzLmlzUmVnRXhwO1xuZXhwb3J0cy5pc1N0cmluZyA9IGlzLmlzU3RyaW5nO1xuZXhwb3J0cy5pc1N5bnRoZXRpY0V2ZW50ID0gaXMuaXNTeW50aGV0aWNFdmVudDtcbmV4cG9ydHMuaXNUaGVuYWJsZSA9IGlzLmlzVGhlbmFibGU7XG5leHBvcnRzLmlzVnVlVmlld01vZGVsID0gaXMuaXNWdWVWaWV3TW9kZWw7XG5leHBvcnRzLmlzQnJvd3NlciA9IGlzQnJvd3Nlci5pc0Jyb3dzZXI7XG5leHBvcnRzLkNPTlNPTEVfTEVWRUxTID0gZGVidWdMb2dnZXIuQ09OU09MRV9MRVZFTFM7XG5leHBvcnRzLmNvbnNvbGVTYW5kYm94ID0gZGVidWdMb2dnZXIuY29uc29sZVNhbmRib3g7XG5leHBvcnRzLmRlYnVnID0gZGVidWdMb2dnZXIuZGVidWc7XG5leHBvcnRzLmxvZ2dlciA9IGRlYnVnTG9nZ2VyLmxvZ2dlcjtcbmV4cG9ydHMub3JpZ2luYWxDb25zb2xlTWV0aG9kcyA9IGRlYnVnTG9nZ2VyLm9yaWdpbmFsQ29uc29sZU1ldGhvZHM7XG5leHBvcnRzLmFkZENvbnRleHRUb0ZyYW1lID0gbWlzYy5hZGRDb250ZXh0VG9GcmFtZTtcbmV4cG9ydHMuYWRkRXhjZXB0aW9uTWVjaGFuaXNtID0gbWlzYy5hZGRFeGNlcHRpb25NZWNoYW5pc207XG5leHBvcnRzLmFkZEV4Y2VwdGlvblR5cGVWYWx1ZSA9IG1pc2MuYWRkRXhjZXB0aW9uVHlwZVZhbHVlO1xuZXhwb3J0cy5jaGVja09yU2V0QWxyZWFkeUNhdWdodCA9IG1pc2MuY2hlY2tPclNldEFscmVhZHlDYXVnaHQ7XG5leHBvcnRzLmdldEV2ZW50RGVzY3JpcHRpb24gPSBtaXNjLmdldEV2ZW50RGVzY3JpcHRpb247XG5leHBvcnRzLnBhcnNlU2VtdmVyID0gbWlzYy5wYXJzZVNlbXZlcjtcbmV4cG9ydHMudXVpZDQgPSBtaXNjLnV1aWQ0O1xuZXhwb3J0cy5pc05vZGVFbnYgPSBub2RlLmlzTm9kZUVudjtcbmV4cG9ydHMubG9hZE1vZHVsZSA9IG5vZGUubG9hZE1vZHVsZTtcbmV4cG9ydHMubm9ybWFsaXplID0gbm9ybWFsaXplLm5vcm1hbGl6ZTtcbmV4cG9ydHMubm9ybWFsaXplVG9TaXplID0gbm9ybWFsaXplLm5vcm1hbGl6ZVRvU2l6ZTtcbmV4cG9ydHMubm9ybWFsaXplVXJsVG9CYXNlID0gbm9ybWFsaXplLm5vcm1hbGl6ZVVybFRvQmFzZTtcbmV4cG9ydHMuYWRkTm9uRW51bWVyYWJsZVByb3BlcnR5ID0gb2JqZWN0LmFkZE5vbkVudW1lcmFibGVQcm9wZXJ0eTtcbmV4cG9ydHMuY29udmVydFRvUGxhaW5PYmplY3QgPSBvYmplY3QuY29udmVydFRvUGxhaW5PYmplY3Q7XG5leHBvcnRzLmRyb3BVbmRlZmluZWRLZXlzID0gb2JqZWN0LmRyb3BVbmRlZmluZWRLZXlzO1xuZXhwb3J0cy5leHRyYWN0RXhjZXB0aW9uS2V5c0Zvck1lc3NhZ2UgPSBvYmplY3QuZXh0cmFjdEV4Y2VwdGlvbktleXNGb3JNZXNzYWdlO1xuZXhwb3J0cy5maWxsID0gb2JqZWN0LmZpbGw7XG5leHBvcnRzLmdldE9yaWdpbmFsRnVuY3Rpb24gPSBvYmplY3QuZ2V0T3JpZ2luYWxGdW5jdGlvbjtcbmV4cG9ydHMubWFya0Z1bmN0aW9uV3JhcHBlZCA9IG9iamVjdC5tYXJrRnVuY3Rpb25XcmFwcGVkO1xuZXhwb3J0cy5vYmplY3RpZnkgPSBvYmplY3Qub2JqZWN0aWZ5O1xuZXhwb3J0cy5iYXNlbmFtZSA9IHBhdGguYmFzZW5hbWU7XG5leHBvcnRzLmRpcm5hbWUgPSBwYXRoLmRpcm5hbWU7XG5leHBvcnRzLmlzQWJzb2x1dGUgPSBwYXRoLmlzQWJzb2x1dGU7XG5leHBvcnRzLmpvaW4gPSBwYXRoLmpvaW47XG5leHBvcnRzLm5vcm1hbGl6ZVBhdGggPSBwYXRoLm5vcm1hbGl6ZVBhdGg7XG5leHBvcnRzLnJlbGF0aXZlID0gcGF0aC5yZWxhdGl2ZTtcbmV4cG9ydHMucmVzb2x2ZSA9IHBhdGgucmVzb2x2ZTtcbmV4cG9ydHMuU0VOVFJZX0JVRkZFUl9GVUxMX0VSUk9SID0gcHJvbWlzZWJ1ZmZlci5TRU5UUllfQlVGRkVSX0ZVTExfRVJST1I7XG5leHBvcnRzLm1ha2VQcm9taXNlQnVmZmVyID0gcHJvbWlzZWJ1ZmZlci5tYWtlUHJvbWlzZUJ1ZmZlcjtcbmV4cG9ydHMuc2V2ZXJpdHlMZXZlbEZyb21TdHJpbmcgPSBzZXZlcml0eS5zZXZlcml0eUxldmVsRnJvbVN0cmluZztcbmV4cG9ydHMuVU5LTk9XTl9GVU5DVElPTiA9IHN0YWNrdHJhY2UuVU5LTk9XTl9GVU5DVElPTjtcbmV4cG9ydHMuY3JlYXRlU3RhY2tQYXJzZXIgPSBzdGFja3RyYWNlLmNyZWF0ZVN0YWNrUGFyc2VyO1xuZXhwb3J0cy5nZXRGcmFtZXNGcm9tRXZlbnQgPSBzdGFja3RyYWNlLmdldEZyYW1lc0Zyb21FdmVudDtcbmV4cG9ydHMuZ2V0RnVuY3Rpb25OYW1lID0gc3RhY2t0cmFjZS5nZXRGdW5jdGlvbk5hbWU7XG5leHBvcnRzLnN0YWNrUGFyc2VyRnJvbVN0YWNrUGFyc2VyT3B0aW9ucyA9IHN0YWNrdHJhY2Uuc3RhY2tQYXJzZXJGcm9tU3RhY2tQYXJzZXJPcHRpb25zO1xuZXhwb3J0cy5zdHJpcFNlbnRyeUZyYW1lc0FuZFJldmVyc2UgPSBzdGFja3RyYWNlLnN0cmlwU2VudHJ5RnJhbWVzQW5kUmV2ZXJzZTtcbmV4cG9ydHMuZmlsZW5hbWVJc0luQXBwID0gbm9kZVN0YWNrVHJhY2UuZmlsZW5hbWVJc0luQXBwO1xuZXhwb3J0cy5ub2RlID0gbm9kZVN0YWNrVHJhY2Uubm9kZTtcbmV4cG9ydHMubm9kZVN0YWNrTGluZVBhcnNlciA9IG5vZGVTdGFja1RyYWNlLm5vZGVTdGFja0xpbmVQYXJzZXI7XG5leHBvcnRzLmlzTWF0Y2hpbmdQYXR0ZXJuID0gc3RyaW5nLmlzTWF0Y2hpbmdQYXR0ZXJuO1xuZXhwb3J0cy5zYWZlSm9pbiA9IHN0cmluZy5zYWZlSm9pbjtcbmV4cG9ydHMuc25pcExpbmUgPSBzdHJpbmcuc25pcExpbmU7XG5leHBvcnRzLnN0cmluZ01hdGNoZXNTb21lUGF0dGVybiA9IHN0cmluZy5zdHJpbmdNYXRjaGVzU29tZVBhdHRlcm47XG5leHBvcnRzLnRydW5jYXRlID0gc3RyaW5nLnRydW5jYXRlO1xuZXhwb3J0cy5pc05hdGl2ZUZ1bmN0aW9uID0gc3VwcG9ydHMuaXNOYXRpdmVGdW5jdGlvbjtcbmV4cG9ydHMuc3VwcG9ydHNET01FcnJvciA9IHN1cHBvcnRzLnN1cHBvcnRzRE9NRXJyb3I7XG5leHBvcnRzLnN1cHBvcnRzRE9NRXhjZXB0aW9uID0gc3VwcG9ydHMuc3VwcG9ydHNET01FeGNlcHRpb247XG5leHBvcnRzLnN1cHBvcnRzRXJyb3JFdmVudCA9IHN1cHBvcnRzLnN1cHBvcnRzRXJyb3JFdmVudDtcbmV4cG9ydHMuc3VwcG9ydHNGZXRjaCA9IHN1cHBvcnRzLnN1cHBvcnRzRmV0Y2g7XG5leHBvcnRzLnN1cHBvcnRzSGlzdG9yeSA9IHN1cHBvcnRzLnN1cHBvcnRzSGlzdG9yeTtcbmV4cG9ydHMuc3VwcG9ydHNOYXRpdmVGZXRjaCA9IHN1cHBvcnRzLnN1cHBvcnRzTmF0aXZlRmV0Y2g7XG5leHBvcnRzLnN1cHBvcnRzUmVmZXJyZXJQb2xpY3kgPSBzdXBwb3J0cy5zdXBwb3J0c1JlZmVycmVyUG9saWN5O1xuZXhwb3J0cy5zdXBwb3J0c1JlcG9ydGluZ09ic2VydmVyID0gc3VwcG9ydHMuc3VwcG9ydHNSZXBvcnRpbmdPYnNlcnZlcjtcbmV4cG9ydHMuU3luY1Byb21pc2UgPSBzeW5jcHJvbWlzZS5TeW5jUHJvbWlzZTtcbmV4cG9ydHMucmVqZWN0ZWRTeW5jUHJvbWlzZSA9IHN5bmNwcm9taXNlLnJlamVjdGVkU3luY1Byb21pc2U7XG5leHBvcnRzLnJlc29sdmVkU3luY1Byb21pc2UgPSBzeW5jcHJvbWlzZS5yZXNvbHZlZFN5bmNQcm9taXNlO1xuZXhwb3J0cy5icm93c2VyUGVyZm9ybWFuY2VUaW1lT3JpZ2luID0gdGltZS5icm93c2VyUGVyZm9ybWFuY2VUaW1lT3JpZ2luO1xuZXhwb3J0cy5kYXRlVGltZXN0YW1wSW5TZWNvbmRzID0gdGltZS5kYXRlVGltZXN0YW1wSW5TZWNvbmRzO1xuZXhwb3J0cy50aW1lc3RhbXBJblNlY29uZHMgPSB0aW1lLnRpbWVzdGFtcEluU2Vjb25kcztcbmV4cG9ydHMuVFJBQ0VQQVJFTlRfUkVHRVhQID0gdHJhY2luZy5UUkFDRVBBUkVOVF9SRUdFWFA7XG5leHBvcnRzLmV4dHJhY3RUcmFjZXBhcmVudERhdGEgPSB0cmFjaW5nLmV4dHJhY3RUcmFjZXBhcmVudERhdGE7XG5leHBvcnRzLmdlbmVyYXRlU2VudHJ5VHJhY2VIZWFkZXIgPSB0cmFjaW5nLmdlbmVyYXRlU2VudHJ5VHJhY2VIZWFkZXI7XG5leHBvcnRzLnByb3BhZ2F0aW9uQ29udGV4dEZyb21IZWFkZXJzID0gdHJhY2luZy5wcm9wYWdhdGlvbkNvbnRleHRGcm9tSGVhZGVycztcbmV4cG9ydHMuZ2V0U0RLU291cmNlID0gZW52LmdldFNES1NvdXJjZTtcbmV4cG9ydHMuaXNCcm93c2VyQnVuZGxlID0gZW52LmlzQnJvd3NlckJ1bmRsZTtcbmV4cG9ydHMuYWRkSXRlbVRvRW52ZWxvcGUgPSBlbnZlbG9wZSQxLmFkZEl0ZW1Ub0VudmVsb3BlO1xuZXhwb3J0cy5jcmVhdGVBdHRhY2htZW50RW52ZWxvcGVJdGVtID0gZW52ZWxvcGUkMS5jcmVhdGVBdHRhY2htZW50RW52ZWxvcGVJdGVtO1xuZXhwb3J0cy5jcmVhdGVFbnZlbG9wZSA9IGVudmVsb3BlJDEuY3JlYXRlRW52ZWxvcGU7XG5leHBvcnRzLmNyZWF0ZUV2ZW50RW52ZWxvcGVIZWFkZXJzID0gZW52ZWxvcGUkMS5jcmVhdGVFdmVudEVudmVsb3BlSGVhZGVycztcbmV4cG9ydHMuY3JlYXRlU3BhbkVudmVsb3BlSXRlbSA9IGVudmVsb3BlJDEuY3JlYXRlU3BhbkVudmVsb3BlSXRlbTtcbmV4cG9ydHMuZW52ZWxvcGVDb250YWluc0l0ZW1UeXBlID0gZW52ZWxvcGUkMS5lbnZlbG9wZUNvbnRhaW5zSXRlbVR5cGU7XG5leHBvcnRzLmVudmVsb3BlSXRlbVR5cGVUb0RhdGFDYXRlZ29yeSA9IGVudmVsb3BlJDEuZW52ZWxvcGVJdGVtVHlwZVRvRGF0YUNhdGVnb3J5O1xuZXhwb3J0cy5mb3JFYWNoRW52ZWxvcGVJdGVtID0gZW52ZWxvcGUkMS5mb3JFYWNoRW52ZWxvcGVJdGVtO1xuZXhwb3J0cy5nZXRTZGtNZXRhZGF0YUZvckVudmVsb3BlSGVhZGVyID0gZW52ZWxvcGUkMS5nZXRTZGtNZXRhZGF0YUZvckVudmVsb3BlSGVhZGVyO1xuZXhwb3J0cy5wYXJzZUVudmVsb3BlID0gZW52ZWxvcGUkMS5wYXJzZUVudmVsb3BlO1xuZXhwb3J0cy5zZXJpYWxpemVFbnZlbG9wZSA9IGVudmVsb3BlJDEuc2VyaWFsaXplRW52ZWxvcGU7XG5leHBvcnRzLmNyZWF0ZUNsaWVudFJlcG9ydEVudmVsb3BlID0gY2xpZW50cmVwb3J0LmNyZWF0ZUNsaWVudFJlcG9ydEVudmVsb3BlO1xuZXhwb3J0cy5ERUZBVUxUX1JFVFJZX0FGVEVSID0gcmF0ZWxpbWl0LkRFRkFVTFRfUkVUUllfQUZURVI7XG5leHBvcnRzLmRpc2FibGVkVW50aWwgPSByYXRlbGltaXQuZGlzYWJsZWRVbnRpbDtcbmV4cG9ydHMuaXNSYXRlTGltaXRlZCA9IHJhdGVsaW1pdC5pc1JhdGVMaW1pdGVkO1xuZXhwb3J0cy5wYXJzZVJldHJ5QWZ0ZXJIZWFkZXIgPSByYXRlbGltaXQucGFyc2VSZXRyeUFmdGVySGVhZGVyO1xuZXhwb3J0cy51cGRhdGVSYXRlTGltaXRzID0gcmF0ZWxpbWl0LnVwZGF0ZVJhdGVMaW1pdHM7XG5leHBvcnRzLk1BWF9CQUdHQUdFX1NUUklOR19MRU5HVEggPSBiYWdnYWdlLk1BWF9CQUdHQUdFX1NUUklOR19MRU5HVEg7XG5leHBvcnRzLlNFTlRSWV9CQUdHQUdFX0tFWV9QUkVGSVggPSBiYWdnYWdlLlNFTlRSWV9CQUdHQUdFX0tFWV9QUkVGSVg7XG5leHBvcnRzLlNFTlRSWV9CQUdHQUdFX0tFWV9QUkVGSVhfUkVHRVggPSBiYWdnYWdlLlNFTlRSWV9CQUdHQUdFX0tFWV9QUkVGSVhfUkVHRVg7XG5leHBvcnRzLmJhZ2dhZ2VIZWFkZXJUb0R5bmFtaWNTYW1wbGluZ0NvbnRleHQgPSBiYWdnYWdlLmJhZ2dhZ2VIZWFkZXJUb0R5bmFtaWNTYW1wbGluZ0NvbnRleHQ7XG5leHBvcnRzLmR5bmFtaWNTYW1wbGluZ0NvbnRleHRUb1NlbnRyeUJhZ2dhZ2VIZWFkZXIgPSBiYWdnYWdlLmR5bmFtaWNTYW1wbGluZ0NvbnRleHRUb1NlbnRyeUJhZ2dhZ2VIZWFkZXI7XG5leHBvcnRzLm9iamVjdFRvQmFnZ2FnZUhlYWRlciA9IGJhZ2dhZ2Uub2JqZWN0VG9CYWdnYWdlSGVhZGVyO1xuZXhwb3J0cy5wYXJzZUJhZ2dhZ2VIZWFkZXIgPSBiYWdnYWdlLnBhcnNlQmFnZ2FnZUhlYWRlcjtcbmV4cG9ydHMuZ2V0SHR0cFNwYW5EZXRhaWxzRnJvbVVybE9iamVjdCA9IHVybC5nZXRIdHRwU3BhbkRldGFpbHNGcm9tVXJsT2JqZWN0O1xuZXhwb3J0cy5nZXRTYW5pdGl6ZWRVcmxTdHJpbmcgPSB1cmwuZ2V0U2FuaXRpemVkVXJsU3RyaW5nO1xuZXhwb3J0cy5nZXRTYW5pdGl6ZWRVcmxTdHJpbmdGcm9tVXJsT2JqZWN0ID0gdXJsLmdldFNhbml0aXplZFVybFN0cmluZ0Zyb21VcmxPYmplY3Q7XG5leHBvcnRzLmlzVVJMT2JqZWN0UmVsYXRpdmUgPSB1cmwuaXNVUkxPYmplY3RSZWxhdGl2ZTtcbmV4cG9ydHMucGFyc2VTdHJpbmdUb1VSTE9iamVjdCA9IHVybC5wYXJzZVN0cmluZ1RvVVJMT2JqZWN0O1xuZXhwb3J0cy5wYXJzZVVybCA9IHVybC5wYXJzZVVybDtcbmV4cG9ydHMuc3RyaXBVcmxRdWVyeUFuZEZyYWdtZW50ID0gdXJsLnN0cmlwVXJsUXVlcnlBbmRGcmFnbWVudDtcbmV4cG9ydHMuZXZlbnRGcm9tTWVzc2FnZSA9IGV2ZW50YnVpbGRlci5ldmVudEZyb21NZXNzYWdlO1xuZXhwb3J0cy5ldmVudEZyb21Vbmtub3duSW5wdXQgPSBldmVudGJ1aWxkZXIuZXZlbnRGcm9tVW5rbm93bklucHV0O1xuZXhwb3J0cy5leGNlcHRpb25Gcm9tRXJyb3IgPSBldmVudGJ1aWxkZXIuZXhjZXB0aW9uRnJvbUVycm9yO1xuZXhwb3J0cy5wYXJzZVN0YWNrRnJhbWVzID0gZXZlbnRidWlsZGVyLnBhcnNlU3RhY2tGcmFtZXM7XG5leHBvcnRzLmNhbGxGcmFtZVRvU3RhY2tGcmFtZSA9IGFuci5jYWxsRnJhbWVUb1N0YWNrRnJhbWU7XG5leHBvcnRzLndhdGNoZG9nVGltZXIgPSBhbnIud2F0Y2hkb2dUaW1lcjtcbmV4cG9ydHMuTFJVTWFwID0gbHJ1LkxSVU1hcDtcbmV4cG9ydHMuZ2VuZXJhdGVTcGFuSWQgPSBwcm9wYWdhdGlvbkNvbnRleHQuZ2VuZXJhdGVTcGFuSWQ7XG5leHBvcnRzLmdlbmVyYXRlVHJhY2VJZCA9IHByb3BhZ2F0aW9uQ29udGV4dC5nZW5lcmF0ZVRyYWNlSWQ7XG5leHBvcnRzLnZlcmNlbFdhaXRVbnRpbCA9IHZlcmNlbFdhaXRVbnRpbC52ZXJjZWxXYWl0VW50aWw7XG5leHBvcnRzLmZsdXNoSWZTZXJ2ZXJsZXNzID0gZmx1c2hJZlNlcnZlcmxlc3MuZmx1c2hJZlNlcnZlcmxlc3M7XG5leHBvcnRzLlNES19WRVJTSU9OID0gdmVyc2lvbi5TREtfVkVSU0lPTjtcbmV4cG9ydHMuZ2V0RGVidWdJbWFnZXNGb3JSZXNvdXJjZXMgPSBkZWJ1Z0lkcy5nZXREZWJ1Z0ltYWdlc0ZvclJlc291cmNlcztcbmV4cG9ydHMuZ2V0RmlsZW5hbWVUb0RlYnVnSWRNYXAgPSBkZWJ1Z0lkcy5nZXRGaWxlbmFtZVRvRGVidWdJZE1hcDtcbmV4cG9ydHMuZXNjYXBlU3RyaW5nRm9yUmVnZXggPSBlc2NhcGVTdHJpbmdGb3JSZWdleC5lc2NhcGVTdHJpbmdGb3JSZWdleDtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWluZGV4LmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/index.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/console.js":
/*!**********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/console.js ***!
  \**********************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst debugLogger = __webpack_require__(/*! ../utils/debug-logger.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst object = __webpack_require__(/*! ../utils/object.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/object.js\");\nconst worldwide = __webpack_require__(/*! ../utils/worldwide.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/worldwide.js\");\nconst handlers = __webpack_require__(/*! ./handlers.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/handlers.js\");\n\n/**\n * Add an instrumentation handler for when a console.xxx method is called.\n *\n * Use at your own risk, this might break without changelog notice, only used internally.\n * @hidden\n */\nfunction addConsoleInstrumentationHandler(handler) {\n  const type = 'console';\n  handlers.addHandler(type, handler);\n  handlers.maybeInstrument(type, instrumentConsole);\n}\n\nfunction instrumentConsole() {\n  if (!('console' in worldwide.GLOBAL_OBJ)) {\n    return;\n  }\n\n  debugLogger.CONSOLE_LEVELS.forEach(function (level) {\n    if (!(level in worldwide.GLOBAL_OBJ.console)) {\n      return;\n    }\n\n    object.fill(worldwide.GLOBAL_OBJ.console, level, function (originalConsoleMethod) {\n      debugLogger.originalConsoleMethods[level] = originalConsoleMethod;\n\n      return function (...args) {\n        const handlerData = { args, level };\n        handlers.triggerHandlers('console', handlerData);\n\n        const log = debugLogger.originalConsoleMethods[level];\n        log?.apply(worldwide.GLOBAL_OBJ.console, args);\n      };\n    });\n  });\n}\n\nexports.addConsoleInstrumentationHandler = addConsoleInstrumentationHandler;\n//# sourceMappingURL=console.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvaW5zdHJ1bWVudC9jb25zb2xlLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLG9CQUFvQixtQkFBTyxDQUFDLGlKQUEwQjtBQUN0RCxlQUFlLG1CQUFPLENBQUMscUlBQW9CO0FBQzNDLGtCQUFrQixtQkFBTyxDQUFDLDJJQUF1QjtBQUNqRCxpQkFBaUIsbUJBQU8sQ0FBQyx1SUFBZTs7QUFFeEM7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0EsOEJBQThCO0FBQzlCOztBQUVBO0FBQ0E7QUFDQTtBQUNBLEtBQUs7QUFDTCxHQUFHO0FBQ0g7O0FBRUEsd0NBQXdDO0FBQ3hDIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvaW5zdHJ1bWVudC9jb25zb2xlLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBkZWJ1Z0xvZ2dlciA9IHJlcXVpcmUoJy4uL3V0aWxzL2RlYnVnLWxvZ2dlci5qcycpO1xuY29uc3Qgb2JqZWN0ID0gcmVxdWlyZSgnLi4vdXRpbHMvb2JqZWN0LmpzJyk7XG5jb25zdCB3b3JsZHdpZGUgPSByZXF1aXJlKCcuLi91dGlscy93b3JsZHdpZGUuanMnKTtcbmNvbnN0IGhhbmRsZXJzID0gcmVxdWlyZSgnLi9oYW5kbGVycy5qcycpO1xuXG4vKipcbiAqIEFkZCBhbiBpbnN0cnVtZW50YXRpb24gaGFuZGxlciBmb3Igd2hlbiBhIGNvbnNvbGUueHh4IG1ldGhvZCBpcyBjYWxsZWQuXG4gKlxuICogVXNlIGF0IHlvdXIgb3duIHJpc2ssIHRoaXMgbWlnaHQgYnJlYWsgd2l0aG91dCBjaGFuZ2Vsb2cgbm90aWNlLCBvbmx5IHVzZWQgaW50ZXJuYWxseS5cbiAqIEBoaWRkZW5cbiAqL1xuZnVuY3Rpb24gYWRkQ29uc29sZUluc3RydW1lbnRhdGlvbkhhbmRsZXIoaGFuZGxlcikge1xuICBjb25zdCB0eXBlID0gJ2NvbnNvbGUnO1xuICBoYW5kbGVycy5hZGRIYW5kbGVyKHR5cGUsIGhhbmRsZXIpO1xuICBoYW5kbGVycy5tYXliZUluc3RydW1lbnQodHlwZSwgaW5zdHJ1bWVudENvbnNvbGUpO1xufVxuXG5mdW5jdGlvbiBpbnN0cnVtZW50Q29uc29sZSgpIHtcbiAgaWYgKCEoJ2NvbnNvbGUnIGluIHdvcmxkd2lkZS5HTE9CQUxfT0JKKSkge1xuICAgIHJldHVybjtcbiAgfVxuXG4gIGRlYnVnTG9nZ2VyLkNPTlNPTEVfTEVWRUxTLmZvckVhY2goZnVuY3Rpb24gKGxldmVsKSB7XG4gICAgaWYgKCEobGV2ZWwgaW4gd29ybGR3aWRlLkdMT0JBTF9PQkouY29uc29sZSkpIHtcbiAgICAgIHJldHVybjtcbiAgICB9XG5cbiAgICBvYmplY3QuZmlsbCh3b3JsZHdpZGUuR0xPQkFMX09CSi5jb25zb2xlLCBsZXZlbCwgZnVuY3Rpb24gKG9yaWdpbmFsQ29uc29sZU1ldGhvZCkge1xuICAgICAgZGVidWdMb2dnZXIub3JpZ2luYWxDb25zb2xlTWV0aG9kc1tsZXZlbF0gPSBvcmlnaW5hbENvbnNvbGVNZXRob2Q7XG5cbiAgICAgIHJldHVybiBmdW5jdGlvbiAoLi4uYXJncykge1xuICAgICAgICBjb25zdCBoYW5kbGVyRGF0YSA9IHsgYXJncywgbGV2ZWwgfTtcbiAgICAgICAgaGFuZGxlcnMudHJpZ2dlckhhbmRsZXJzKCdjb25zb2xlJywgaGFuZGxlckRhdGEpO1xuXG4gICAgICAgIGNvbnN0IGxvZyA9IGRlYnVnTG9nZ2VyLm9yaWdpbmFsQ29uc29sZU1ldGhvZHNbbGV2ZWxdO1xuICAgICAgICBsb2c/LmFwcGx5KHdvcmxkd2lkZS5HTE9CQUxfT0JKLmNvbnNvbGUsIGFyZ3MpO1xuICAgICAgfTtcbiAgICB9KTtcbiAgfSk7XG59XG5cbmV4cG9ydHMuYWRkQ29uc29sZUluc3RydW1lbnRhdGlvbkhhbmRsZXIgPSBhZGRDb25zb2xlSW5zdHJ1bWVudGF0aW9uSGFuZGxlcjtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWNvbnNvbGUuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/console.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/fetch.js":
/*!********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/fetch.js ***!
  \********************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst is = __webpack_require__(/*! ../utils/is.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js\");\nconst object = __webpack_require__(/*! ../utils/object.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/object.js\");\nconst supports = __webpack_require__(/*! ../utils/supports.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/supports.js\");\nconst time = __webpack_require__(/*! ../utils/time.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/time.js\");\nconst worldwide = __webpack_require__(/*! ../utils/worldwide.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/worldwide.js\");\nconst handlers = __webpack_require__(/*! ./handlers.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/handlers.js\");\n\n/**\n * Add an instrumentation handler for when a fetch request happens.\n * The handler function is called once when the request starts and once when it ends,\n * which can be identified by checking if it has an `endTimestamp`.\n *\n * Use at your own risk, this might break without changelog notice, only used internally.\n * @hidden\n */\nfunction addFetchInstrumentationHandler(\n  handler,\n  skipNativeFetchCheck,\n) {\n  const type = 'fetch';\n  handlers.addHandler(type, handler);\n  handlers.maybeInstrument(type, () => instrumentFetch(undefined, skipNativeFetchCheck));\n}\n\n/**\n * Add an instrumentation handler for long-lived fetch requests, like consuming server-sent events (SSE) via fetch.\n * The handler will resolve the request body and emit the actual `endTimestamp`, so that the\n * span can be updated accordingly.\n *\n * Only used internally\n * @hidden\n */\nfunction addFetchEndInstrumentationHandler(handler) {\n  const type = 'fetch-body-resolved';\n  handlers.addHandler(type, handler);\n  handlers.maybeInstrument(type, () => instrumentFetch(streamHandler));\n}\n\nfunction instrumentFetch(onFetchResolved, skipNativeFetchCheck = false) {\n  if (skipNativeFetchCheck && !supports.supportsNativeFetch()) {\n    return;\n  }\n\n  object.fill(worldwide.GLOBAL_OBJ, 'fetch', function (originalFetch) {\n    return function (...args) {\n      // We capture the error right here and not in the Promise error callback because Safari (and probably other\n      // browsers too) will wipe the stack trace up to this point, only leaving us with this file which is useless.\n\n      // NOTE: If you are a Sentry user, and you are seeing this stack frame,\n      //       it means the error, that was caused by your fetch call did not\n      //       have a stack trace, so the SDK backfilled the stack trace so\n      //       you can see which fetch call failed.\n      const virtualError = new Error();\n\n      const { method, url } = parseFetchArgs(args);\n      const handlerData = {\n        args,\n        fetchData: {\n          method,\n          url,\n        },\n        startTimestamp: time.timestampInSeconds() * 1000,\n        // // Adding the error to be able to fingerprint the failed fetch event in HttpClient instrumentation\n        virtualError,\n        headers: getHeadersFromFetchArgs(args),\n      };\n\n      // if there is no callback, fetch is instrumented directly\n      if (!onFetchResolved) {\n        handlers.triggerHandlers('fetch', {\n          ...handlerData,\n        });\n      }\n\n      // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n      return originalFetch.apply(worldwide.GLOBAL_OBJ, args).then(\n        async (response) => {\n          if (onFetchResolved) {\n            onFetchResolved(response);\n          } else {\n            handlers.triggerHandlers('fetch', {\n              ...handlerData,\n              endTimestamp: time.timestampInSeconds() * 1000,\n              response,\n            });\n          }\n\n          return response;\n        },\n        (error) => {\n          handlers.triggerHandlers('fetch', {\n            ...handlerData,\n            endTimestamp: time.timestampInSeconds() * 1000,\n            error,\n          });\n\n          if (is.isError(error) && error.stack === undefined) {\n            // NOTE: If you are a Sentry user, and you are seeing this stack frame,\n            //       it means the error, that was caused by your fetch call did not\n            //       have a stack trace, so the SDK backfilled the stack trace so\n            //       you can see which fetch call failed.\n            error.stack = virtualError.stack;\n            object.addNonEnumerableProperty(error, 'framesToPop', 1);\n          }\n\n          // We enhance the not-so-helpful \"Failed to fetch\" error messages with the host\n          // Possible messages we handle here:\n          // * \"Failed to fetch\" (chromium)\n          // * \"Load failed\" (webkit)\n          // * \"NetworkError when attempting to fetch resource.\" (firefox)\n          if (\n            error instanceof TypeError &&\n            (error.message === 'Failed to fetch' ||\n              error.message === 'Load failed' ||\n              error.message === 'NetworkError when attempting to fetch resource.')\n          ) {\n            try {\n              const url = new URL(handlerData.fetchData.url);\n              error.message = `${error.message} (${url.host})`;\n            } catch {\n              // ignore it if errors happen here\n            }\n          }\n\n          // NOTE: If you are a Sentry user, and you are seeing this stack frame,\n          //       it means the sentry.javascript SDK caught an error invoking your application code.\n          //       This is expected behavior and NOT indicative of a bug with sentry.javascript.\n          throw error;\n        },\n      );\n    };\n  });\n}\n\nasync function resolveResponse(res, onFinishedResolving) {\n  if (res?.body) {\n    const body = res.body;\n    const responseReader = body.getReader();\n\n    // Define a maximum duration after which we just cancel\n    const maxFetchDurationTimeout = setTimeout(\n      () => {\n        body.cancel().then(null, () => {\n          // noop\n        });\n      },\n      90 * 1000, // 90s\n    );\n\n    let readingActive = true;\n    while (readingActive) {\n      let chunkTimeout;\n      try {\n        // abort reading if read op takes more than 5s\n        chunkTimeout = setTimeout(() => {\n          body.cancel().then(null, () => {\n            // noop on error\n          });\n        }, 5000);\n\n        // This .read() call will reject/throw when we abort due to timeouts through `body.cancel()`\n        const { done } = await responseReader.read();\n\n        clearTimeout(chunkTimeout);\n\n        if (done) {\n          onFinishedResolving();\n          readingActive = false;\n        }\n      } catch {\n        readingActive = false;\n      } finally {\n        clearTimeout(chunkTimeout);\n      }\n    }\n\n    clearTimeout(maxFetchDurationTimeout);\n\n    responseReader.releaseLock();\n    body.cancel().then(null, () => {\n      // noop on error\n    });\n  }\n}\n\nfunction streamHandler(response) {\n  // clone response for awaiting stream\n  let clonedResponseForResolving;\n  try {\n    clonedResponseForResolving = response.clone();\n  } catch {\n    return;\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-floating-promises\n  resolveResponse(clonedResponseForResolving, () => {\n    handlers.triggerHandlers('fetch-body-resolved', {\n      endTimestamp: time.timestampInSeconds() * 1000,\n      response,\n    });\n  });\n}\n\nfunction hasProp(obj, prop) {\n  return !!obj && typeof obj === 'object' && !!(obj )[prop];\n}\n\nfunction getUrlFromResource(resource) {\n  if (typeof resource === 'string') {\n    return resource;\n  }\n\n  if (!resource) {\n    return '';\n  }\n\n  if (hasProp(resource, 'url')) {\n    return resource.url;\n  }\n\n  if (resource.toString) {\n    return resource.toString();\n  }\n\n  return '';\n}\n\n/**\n * Parses the fetch arguments to find the used Http method and the url of the request.\n * Exported for tests only.\n */\nfunction parseFetchArgs(fetchArgs) {\n  if (fetchArgs.length === 0) {\n    return { method: 'GET', url: '' };\n  }\n\n  if (fetchArgs.length === 2) {\n    const [url, options] = fetchArgs ;\n\n    return {\n      url: getUrlFromResource(url),\n      method: hasProp(options, 'method') ? String(options.method).toUpperCase() : 'GET',\n    };\n  }\n\n  const arg = fetchArgs[0];\n  return {\n    url: getUrlFromResource(arg ),\n    method: hasProp(arg, 'method') ? String(arg.method).toUpperCase() : 'GET',\n  };\n}\n\nfunction getHeadersFromFetchArgs(fetchArgs) {\n  const [requestArgument, optionsArgument] = fetchArgs;\n\n  try {\n    if (\n      typeof optionsArgument === 'object' &&\n      optionsArgument !== null &&\n      'headers' in optionsArgument &&\n      optionsArgument.headers\n    ) {\n      return new Headers(optionsArgument.headers );\n    }\n\n    if (is.isRequest(requestArgument)) {\n      return new Headers(requestArgument.headers);\n    }\n  } catch {\n    // noop\n  }\n\n  return;\n}\n\nexports.addFetchEndInstrumentationHandler = addFetchEndInstrumentationHandler;\nexports.addFetchInstrumentationHandler = addFetchInstrumentationHandler;\nexports.parseFetchArgs = parseFetchArgs;\n//# sourceMappingURL=fetch.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvaW5zdHJ1bWVudC9mZXRjaC5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxXQUFXLG1CQUFPLENBQUMsNkhBQWdCO0FBQ25DLGVBQWUsbUJBQU8sQ0FBQyxxSUFBb0I7QUFDM0MsaUJBQWlCLG1CQUFPLENBQUMseUlBQXNCO0FBQy9DLGFBQWEsbUJBQU8sQ0FBQyxpSUFBa0I7QUFDdkMsa0JBQWtCLG1CQUFPLENBQUMsMklBQXVCO0FBQ2pELGlCQUFpQixtQkFBTyxDQUFDLHVJQUFlOztBQUV4QztBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLGNBQWMsY0FBYztBQUM1QjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsU0FBUztBQUNUO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQSxTQUFTO0FBQ1Q7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFlBQVk7QUFDWjtBQUNBO0FBQ0E7QUFDQTtBQUNBLGFBQWE7QUFDYjs7QUFFQTtBQUNBLFNBQVM7QUFDVDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsV0FBVzs7QUFFWDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsaUNBQWlDLGVBQWUsR0FBRyxTQUFTO0FBQzVELGNBQWM7QUFDZDtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQSxTQUFTO0FBQ1Q7QUFDQTtBQUNBLEdBQUc7QUFDSDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsU0FBUztBQUNULE9BQU87QUFDUDtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxXQUFXO0FBQ1gsU0FBUzs7QUFFVDtBQUNBLGdCQUFnQixPQUFPOztBQUV2Qjs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFFBQVE7QUFDUjtBQUNBLFFBQVE7QUFDUjtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0EsS0FBSztBQUNMO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLElBQUk7QUFDSjtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxLQUFLO0FBQ0wsR0FBRztBQUNIOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGFBQWE7QUFDYjs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBLElBQUk7QUFDSjtBQUNBOztBQUVBO0FBQ0E7O0FBRUEseUNBQXlDO0FBQ3pDLHNDQUFzQztBQUN0QyxzQkFBc0I7QUFDdEIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnN0cnVtZW50L2ZldGNoLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBpcyA9IHJlcXVpcmUoJy4uL3V0aWxzL2lzLmpzJyk7XG5jb25zdCBvYmplY3QgPSByZXF1aXJlKCcuLi91dGlscy9vYmplY3QuanMnKTtcbmNvbnN0IHN1cHBvcnRzID0gcmVxdWlyZSgnLi4vdXRpbHMvc3VwcG9ydHMuanMnKTtcbmNvbnN0IHRpbWUgPSByZXF1aXJlKCcuLi91dGlscy90aW1lLmpzJyk7XG5jb25zdCB3b3JsZHdpZGUgPSByZXF1aXJlKCcuLi91dGlscy93b3JsZHdpZGUuanMnKTtcbmNvbnN0IGhhbmRsZXJzID0gcmVxdWlyZSgnLi9oYW5kbGVycy5qcycpO1xuXG4vKipcbiAqIEFkZCBhbiBpbnN0cnVtZW50YXRpb24gaGFuZGxlciBmb3Igd2hlbiBhIGZldGNoIHJlcXVlc3QgaGFwcGVucy5cbiAqIFRoZSBoYW5kbGVyIGZ1bmN0aW9uIGlzIGNhbGxlZCBvbmNlIHdoZW4gdGhlIHJlcXVlc3Qgc3RhcnRzIGFuZCBvbmNlIHdoZW4gaXQgZW5kcyxcbiAqIHdoaWNoIGNhbiBiZSBpZGVudGlmaWVkIGJ5IGNoZWNraW5nIGlmIGl0IGhhcyBhbiBgZW5kVGltZXN0YW1wYC5cbiAqXG4gKiBVc2UgYXQgeW91ciBvd24gcmlzaywgdGhpcyBtaWdodCBicmVhayB3aXRob3V0IGNoYW5nZWxvZyBub3RpY2UsIG9ubHkgdXNlZCBpbnRlcm5hbGx5LlxuICogQGhpZGRlblxuICovXG5mdW5jdGlvbiBhZGRGZXRjaEluc3RydW1lbnRhdGlvbkhhbmRsZXIoXG4gIGhhbmRsZXIsXG4gIHNraXBOYXRpdmVGZXRjaENoZWNrLFxuKSB7XG4gIGNvbnN0IHR5cGUgPSAnZmV0Y2gnO1xuICBoYW5kbGVycy5hZGRIYW5kbGVyKHR5cGUsIGhhbmRsZXIpO1xuICBoYW5kbGVycy5tYXliZUluc3RydW1lbnQodHlwZSwgKCkgPT4gaW5zdHJ1bWVudEZldGNoKHVuZGVmaW5lZCwgc2tpcE5hdGl2ZUZldGNoQ2hlY2spKTtcbn1cblxuLyoqXG4gKiBBZGQgYW4gaW5zdHJ1bWVudGF0aW9uIGhhbmRsZXIgZm9yIGxvbmctbGl2ZWQgZmV0Y2ggcmVxdWVzdHMsIGxpa2UgY29uc3VtaW5nIHNlcnZlci1zZW50IGV2ZW50cyAoU1NFKSB2aWEgZmV0Y2guXG4gKiBUaGUgaGFuZGxlciB3aWxsIHJlc29sdmUgdGhlIHJlcXVlc3QgYm9keSBhbmQgZW1pdCB0aGUgYWN0dWFsIGBlbmRUaW1lc3RhbXBgLCBzbyB0aGF0IHRoZVxuICogc3BhbiBjYW4gYmUgdXBkYXRlZCBhY2NvcmRpbmdseS5cbiAqXG4gKiBPbmx5IHVzZWQgaW50ZXJuYWxseVxuICogQGhpZGRlblxuICovXG5mdW5jdGlvbiBhZGRGZXRjaEVuZEluc3RydW1lbnRhdGlvbkhhbmRsZXIoaGFuZGxlcikge1xuICBjb25zdCB0eXBlID0gJ2ZldGNoLWJvZHktcmVzb2x2ZWQnO1xuICBoYW5kbGVycy5hZGRIYW5kbGVyKHR5cGUsIGhhbmRsZXIpO1xuICBoYW5kbGVycy5tYXliZUluc3RydW1lbnQodHlwZSwgKCkgPT4gaW5zdHJ1bWVudEZldGNoKHN0cmVhbUhhbmRsZXIpKTtcbn1cblxuZnVuY3Rpb24gaW5zdHJ1bWVudEZldGNoKG9uRmV0Y2hSZXNvbHZlZCwgc2tpcE5hdGl2ZUZldGNoQ2hlY2sgPSBmYWxzZSkge1xuICBpZiAoc2tpcE5hdGl2ZUZldGNoQ2hlY2sgJiYgIXN1cHBvcnRzLnN1cHBvcnRzTmF0aXZlRmV0Y2goKSkge1xuICAgIHJldHVybjtcbiAgfVxuXG4gIG9iamVjdC5maWxsKHdvcmxkd2lkZS5HTE9CQUxfT0JKLCAnZmV0Y2gnLCBmdW5jdGlvbiAob3JpZ2luYWxGZXRjaCkge1xuICAgIHJldHVybiBmdW5jdGlvbiAoLi4uYXJncykge1xuICAgICAgLy8gV2UgY2FwdHVyZSB0aGUgZXJyb3IgcmlnaHQgaGVyZSBhbmQgbm90IGluIHRoZSBQcm9taXNlIGVycm9yIGNhbGxiYWNrIGJlY2F1c2UgU2FmYXJpIChhbmQgcHJvYmFibHkgb3RoZXJcbiAgICAgIC8vIGJyb3dzZXJzIHRvbykgd2lsbCB3aXBlIHRoZSBzdGFjayB0cmFjZSB1cCB0byB0aGlzIHBvaW50LCBvbmx5IGxlYXZpbmcgdXMgd2l0aCB0aGlzIGZpbGUgd2hpY2ggaXMgdXNlbGVzcy5cblxuICAgICAgLy8gTk9URTogSWYgeW91IGFyZSBhIFNlbnRyeSB1c2VyLCBhbmQgeW91IGFyZSBzZWVpbmcgdGhpcyBzdGFjayBmcmFtZSxcbiAgICAgIC8vICAgICAgIGl0IG1lYW5zIHRoZSBlcnJvciwgdGhhdCB3YXMgY2F1c2VkIGJ5IHlvdXIgZmV0Y2ggY2FsbCBkaWQgbm90XG4gICAgICAvLyAgICAgICBoYXZlIGEgc3RhY2sgdHJhY2UsIHNvIHRoZSBTREsgYmFja2ZpbGxlZCB0aGUgc3RhY2sgdHJhY2Ugc29cbiAgICAgIC8vICAgICAgIHlvdSBjYW4gc2VlIHdoaWNoIGZldGNoIGNhbGwgZmFpbGVkLlxuICAgICAgY29uc3QgdmlydHVhbEVycm9yID0gbmV3IEVycm9yKCk7XG5cbiAgICAgIGNvbnN0IHsgbWV0aG9kLCB1cmwgfSA9IHBhcnNlRmV0Y2hBcmdzKGFyZ3MpO1xuICAgICAgY29uc3QgaGFuZGxlckRhdGEgPSB7XG4gICAgICAgIGFyZ3MsXG4gICAgICAgIGZldGNoRGF0YToge1xuICAgICAgICAgIG1ldGhvZCxcbiAgICAgICAgICB1cmwsXG4gICAgICAgIH0sXG4gICAgICAgIHN0YXJ0VGltZXN0YW1wOiB0aW1lLnRpbWVzdGFtcEluU2Vjb25kcygpICogMTAwMCxcbiAgICAgICAgLy8gLy8gQWRkaW5nIHRoZSBlcnJvciB0byBiZSBhYmxlIHRvIGZpbmdlcnByaW50IHRoZSBmYWlsZWQgZmV0Y2ggZXZlbnQgaW4gSHR0cENsaWVudCBpbnN0cnVtZW50YXRpb25cbiAgICAgICAgdmlydHVhbEVycm9yLFxuICAgICAgICBoZWFkZXJzOiBnZXRIZWFkZXJzRnJvbUZldGNoQXJncyhhcmdzKSxcbiAgICAgIH07XG5cbiAgICAgIC8vIGlmIHRoZXJlIGlzIG5vIGNhbGxiYWNrLCBmZXRjaCBpcyBpbnN0cnVtZW50ZWQgZGlyZWN0bHlcbiAgICAgIGlmICghb25GZXRjaFJlc29sdmVkKSB7XG4gICAgICAgIGhhbmRsZXJzLnRyaWdnZXJIYW5kbGVycygnZmV0Y2gnLCB7XG4gICAgICAgICAgLi4uaGFuZGxlckRhdGEsXG4gICAgICAgIH0pO1xuICAgICAgfVxuXG4gICAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25vLXVuc2FmZS1tZW1iZXItYWNjZXNzXG4gICAgICByZXR1cm4gb3JpZ2luYWxGZXRjaC5hcHBseSh3b3JsZHdpZGUuR0xPQkFMX09CSiwgYXJncykudGhlbihcbiAgICAgICAgYXN5bmMgKHJlc3BvbnNlKSA9PiB7XG4gICAgICAgICAgaWYgKG9uRmV0Y2hSZXNvbHZlZCkge1xuICAgICAgICAgICAgb25GZXRjaFJlc29sdmVkKHJlc3BvbnNlKTtcbiAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgaGFuZGxlcnMudHJpZ2dlckhhbmRsZXJzKCdmZXRjaCcsIHtcbiAgICAgICAgICAgICAgLi4uaGFuZGxlckRhdGEsXG4gICAgICAgICAgICAgIGVuZFRpbWVzdGFtcDogdGltZS50aW1lc3RhbXBJblNlY29uZHMoKSAqIDEwMDAsXG4gICAgICAgICAgICAgIHJlc3BvbnNlLFxuICAgICAgICAgICAgfSk7XG4gICAgICAgICAgfVxuXG4gICAgICAgICAgcmV0dXJuIHJlc3BvbnNlO1xuICAgICAgICB9LFxuICAgICAgICAoZXJyb3IpID0+IHtcbiAgICAgICAgICBoYW5kbGVycy50cmlnZ2VySGFuZGxlcnMoJ2ZldGNoJywge1xuICAgICAgICAgICAgLi4uaGFuZGxlckRhdGEsXG4gICAgICAgICAgICBlbmRUaW1lc3RhbXA6IHRpbWUudGltZXN0YW1wSW5TZWNvbmRzKCkgKiAxMDAwLFxuICAgICAgICAgICAgZXJyb3IsXG4gICAgICAgICAgfSk7XG5cbiAgICAgICAgICBpZiAoaXMuaXNFcnJvcihlcnJvcikgJiYgZXJyb3Iuc3RhY2sgPT09IHVuZGVmaW5lZCkge1xuICAgICAgICAgICAgLy8gTk9URTogSWYgeW91IGFyZSBhIFNlbnRyeSB1c2VyLCBhbmQgeW91IGFyZSBzZWVpbmcgdGhpcyBzdGFjayBmcmFtZSxcbiAgICAgICAgICAgIC8vICAgICAgIGl0IG1lYW5zIHRoZSBlcnJvciwgdGhhdCB3YXMgY2F1c2VkIGJ5IHlvdXIgZmV0Y2ggY2FsbCBkaWQgbm90XG4gICAgICAgICAgICAvLyAgICAgICBoYXZlIGEgc3RhY2sgdHJhY2UsIHNvIHRoZSBTREsgYmFja2ZpbGxlZCB0aGUgc3RhY2sgdHJhY2Ugc29cbiAgICAgICAgICAgIC8vICAgICAgIHlvdSBjYW4gc2VlIHdoaWNoIGZldGNoIGNhbGwgZmFpbGVkLlxuICAgICAgICAgICAgZXJyb3Iuc3RhY2sgPSB2aXJ0dWFsRXJyb3Iuc3RhY2s7XG4gICAgICAgICAgICBvYmplY3QuYWRkTm9uRW51bWVyYWJsZVByb3BlcnR5KGVycm9yLCAnZnJhbWVzVG9Qb3AnLCAxKTtcbiAgICAgICAgICB9XG5cbiAgICAgICAgICAvLyBXZSBlbmhhbmNlIHRoZSBub3Qtc28taGVscGZ1bCBcIkZhaWxlZCB0byBmZXRjaFwiIGVycm9yIG1lc3NhZ2VzIHdpdGggdGhlIGhvc3RcbiAgICAgICAgICAvLyBQb3NzaWJsZSBtZXNzYWdlcyB3ZSBoYW5kbGUgaGVyZTpcbiAgICAgICAgICAvLyAqIFwiRmFpbGVkIHRvIGZldGNoXCIgKGNocm9taXVtKVxuICAgICAgICAgIC8vICogXCJMb2FkIGZhaWxlZFwiICh3ZWJraXQpXG4gICAgICAgICAgLy8gKiBcIk5ldHdvcmtFcnJvciB3aGVuIGF0dGVtcHRpbmcgdG8gZmV0Y2ggcmVzb3VyY2UuXCIgKGZpcmVmb3gpXG4gICAgICAgICAgaWYgKFxuICAgICAgICAgICAgZXJyb3IgaW5zdGFuY2VvZiBUeXBlRXJyb3IgJiZcbiAgICAgICAgICAgIChlcnJvci5tZXNzYWdlID09PSAnRmFpbGVkIHRvIGZldGNoJyB8fFxuICAgICAgICAgICAgICBlcnJvci5tZXNzYWdlID09PSAnTG9hZCBmYWlsZWQnIHx8XG4gICAgICAgICAgICAgIGVycm9yLm1lc3NhZ2UgPT09ICdOZXR3b3JrRXJyb3Igd2hlbiBhdHRlbXB0aW5nIHRvIGZldGNoIHJlc291cmNlLicpXG4gICAgICAgICAgKSB7XG4gICAgICAgICAgICB0cnkge1xuICAgICAgICAgICAgICBjb25zdCB1cmwgPSBuZXcgVVJMKGhhbmRsZXJEYXRhLmZldGNoRGF0YS51cmwpO1xuICAgICAgICAgICAgICBlcnJvci5tZXNzYWdlID0gYCR7ZXJyb3IubWVzc2FnZX0gKCR7dXJsLmhvc3R9KWA7XG4gICAgICAgICAgICB9IGNhdGNoIHtcbiAgICAgICAgICAgICAgLy8gaWdub3JlIGl0IGlmIGVycm9ycyBoYXBwZW4gaGVyZVxuICAgICAgICAgICAgfVxuICAgICAgICAgIH1cblxuICAgICAgICAgIC8vIE5PVEU6IElmIHlvdSBhcmUgYSBTZW50cnkgdXNlciwgYW5kIHlvdSBhcmUgc2VlaW5nIHRoaXMgc3RhY2sgZnJhbWUsXG4gICAgICAgICAgLy8gICAgICAgaXQgbWVhbnMgdGhlIHNlbnRyeS5qYXZhc2NyaXB0IFNESyBjYXVnaHQgYW4gZXJyb3IgaW52b2tpbmcgeW91ciBhcHBsaWNhdGlvbiBjb2RlLlxuICAgICAgICAgIC8vICAgICAgIFRoaXMgaXMgZXhwZWN0ZWQgYmVoYXZpb3IgYW5kIE5PVCBpbmRpY2F0aXZlIG9mIGEgYnVnIHdpdGggc2VudHJ5LmphdmFzY3JpcHQuXG4gICAgICAgICAgdGhyb3cgZXJyb3I7XG4gICAgICAgIH0sXG4gICAgICApO1xuICAgIH07XG4gIH0pO1xufVxuXG5hc3luYyBmdW5jdGlvbiByZXNvbHZlUmVzcG9uc2UocmVzLCBvbkZpbmlzaGVkUmVzb2x2aW5nKSB7XG4gIGlmIChyZXM/LmJvZHkpIHtcbiAgICBjb25zdCBib2R5ID0gcmVzLmJvZHk7XG4gICAgY29uc3QgcmVzcG9uc2VSZWFkZXIgPSBib2R5LmdldFJlYWRlcigpO1xuXG4gICAgLy8gRGVmaW5lIGEgbWF4aW11bSBkdXJhdGlvbiBhZnRlciB3aGljaCB3ZSBqdXN0IGNhbmNlbFxuICAgIGNvbnN0IG1heEZldGNoRHVyYXRpb25UaW1lb3V0ID0gc2V0VGltZW91dChcbiAgICAgICgpID0+IHtcbiAgICAgICAgYm9keS5jYW5jZWwoKS50aGVuKG51bGwsICgpID0+IHtcbiAgICAgICAgICAvLyBub29wXG4gICAgICAgIH0pO1xuICAgICAgfSxcbiAgICAgIDkwICogMTAwMCwgLy8gOTBzXG4gICAgKTtcblxuICAgIGxldCByZWFkaW5nQWN0aXZlID0gdHJ1ZTtcbiAgICB3aGlsZSAocmVhZGluZ0FjdGl2ZSkge1xuICAgICAgbGV0IGNodW5rVGltZW91dDtcbiAgICAgIHRyeSB7XG4gICAgICAgIC8vIGFib3J0IHJlYWRpbmcgaWYgcmVhZCBvcCB0YWtlcyBtb3JlIHRoYW4gNXNcbiAgICAgICAgY2h1bmtUaW1lb3V0ID0gc2V0VGltZW91dCgoKSA9PiB7XG4gICAgICAgICAgYm9keS5jYW5jZWwoKS50aGVuKG51bGwsICgpID0+IHtcbiAgICAgICAgICAgIC8vIG5vb3Agb24gZXJyb3JcbiAgICAgICAgICB9KTtcbiAgICAgICAgfSwgNTAwMCk7XG5cbiAgICAgICAgLy8gVGhpcyAucmVhZCgpIGNhbGwgd2lsbCByZWplY3QvdGhyb3cgd2hlbiB3ZSBhYm9ydCBkdWUgdG8gdGltZW91dHMgdGhyb3VnaCBgYm9keS5jYW5jZWwoKWBcbiAgICAgICAgY29uc3QgeyBkb25lIH0gPSBhd2FpdCByZXNwb25zZVJlYWRlci5yZWFkKCk7XG5cbiAgICAgICAgY2xlYXJUaW1lb3V0KGNodW5rVGltZW91dCk7XG5cbiAgICAgICAgaWYgKGRvbmUpIHtcbiAgICAgICAgICBvbkZpbmlzaGVkUmVzb2x2aW5nKCk7XG4gICAgICAgICAgcmVhZGluZ0FjdGl2ZSA9IGZhbHNlO1xuICAgICAgICB9XG4gICAgICB9IGNhdGNoIHtcbiAgICAgICAgcmVhZGluZ0FjdGl2ZSA9IGZhbHNlO1xuICAgICAgfSBmaW5hbGx5IHtcbiAgICAgICAgY2xlYXJUaW1lb3V0KGNodW5rVGltZW91dCk7XG4gICAgICB9XG4gICAgfVxuXG4gICAgY2xlYXJUaW1lb3V0KG1heEZldGNoRHVyYXRpb25UaW1lb3V0KTtcblxuICAgIHJlc3BvbnNlUmVhZGVyLnJlbGVhc2VMb2NrKCk7XG4gICAgYm9keS5jYW5jZWwoKS50aGVuKG51bGwsICgpID0+IHtcbiAgICAgIC8vIG5vb3Agb24gZXJyb3JcbiAgICB9KTtcbiAgfVxufVxuXG5mdW5jdGlvbiBzdHJlYW1IYW5kbGVyKHJlc3BvbnNlKSB7XG4gIC8vIGNsb25lIHJlc3BvbnNlIGZvciBhd2FpdGluZyBzdHJlYW1cbiAgbGV0IGNsb25lZFJlc3BvbnNlRm9yUmVzb2x2aW5nO1xuICB0cnkge1xuICAgIGNsb25lZFJlc3BvbnNlRm9yUmVzb2x2aW5nID0gcmVzcG9uc2UuY2xvbmUoKTtcbiAgfSBjYXRjaCB7XG4gICAgcmV0dXJuO1xuICB9XG5cbiAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uby1mbG9hdGluZy1wcm9taXNlc1xuICByZXNvbHZlUmVzcG9uc2UoY2xvbmVkUmVzcG9uc2VGb3JSZXNvbHZpbmcsICgpID0+IHtcbiAgICBoYW5kbGVycy50cmlnZ2VySGFuZGxlcnMoJ2ZldGNoLWJvZHktcmVzb2x2ZWQnLCB7XG4gICAgICBlbmRUaW1lc3RhbXA6IHRpbWUudGltZXN0YW1wSW5TZWNvbmRzKCkgKiAxMDAwLFxuICAgICAgcmVzcG9uc2UsXG4gICAgfSk7XG4gIH0pO1xufVxuXG5mdW5jdGlvbiBoYXNQcm9wKG9iaiwgcHJvcCkge1xuICByZXR1cm4gISFvYmogJiYgdHlwZW9mIG9iaiA9PT0gJ29iamVjdCcgJiYgISEob2JqIClbcHJvcF07XG59XG5cbmZ1bmN0aW9uIGdldFVybEZyb21SZXNvdXJjZShyZXNvdXJjZSkge1xuICBpZiAodHlwZW9mIHJlc291cmNlID09PSAnc3RyaW5nJykge1xuICAgIHJldHVybiByZXNvdXJjZTtcbiAgfVxuXG4gIGlmICghcmVzb3VyY2UpIHtcbiAgICByZXR1cm4gJyc7XG4gIH1cblxuICBpZiAoaGFzUHJvcChyZXNvdXJjZSwgJ3VybCcpKSB7XG4gICAgcmV0dXJuIHJlc291cmNlLnVybDtcbiAgfVxuXG4gIGlmIChyZXNvdXJjZS50b1N0cmluZykge1xuICAgIHJldHVybiByZXNvdXJjZS50b1N0cmluZygpO1xuICB9XG5cbiAgcmV0dXJuICcnO1xufVxuXG4vKipcbiAqIFBhcnNlcyB0aGUgZmV0Y2ggYXJndW1lbnRzIHRvIGZpbmQgdGhlIHVzZWQgSHR0cCBtZXRob2QgYW5kIHRoZSB1cmwgb2YgdGhlIHJlcXVlc3QuXG4gKiBFeHBvcnRlZCBmb3IgdGVzdHMgb25seS5cbiAqL1xuZnVuY3Rpb24gcGFyc2VGZXRjaEFyZ3MoZmV0Y2hBcmdzKSB7XG4gIGlmIChmZXRjaEFyZ3MubGVuZ3RoID09PSAwKSB7XG4gICAgcmV0dXJuIHsgbWV0aG9kOiAnR0VUJywgdXJsOiAnJyB9O1xuICB9XG5cbiAgaWYgKGZldGNoQXJncy5sZW5ndGggPT09IDIpIHtcbiAgICBjb25zdCBbdXJsLCBvcHRpb25zXSA9IGZldGNoQXJncyA7XG5cbiAgICByZXR1cm4ge1xuICAgICAgdXJsOiBnZXRVcmxGcm9tUmVzb3VyY2UodXJsKSxcbiAgICAgIG1ldGhvZDogaGFzUHJvcChvcHRpb25zLCAnbWV0aG9kJykgPyBTdHJpbmcob3B0aW9ucy5tZXRob2QpLnRvVXBwZXJDYXNlKCkgOiAnR0VUJyxcbiAgICB9O1xuICB9XG5cbiAgY29uc3QgYXJnID0gZmV0Y2hBcmdzWzBdO1xuICByZXR1cm4ge1xuICAgIHVybDogZ2V0VXJsRnJvbVJlc291cmNlKGFyZyApLFxuICAgIG1ldGhvZDogaGFzUHJvcChhcmcsICdtZXRob2QnKSA/IFN0cmluZyhhcmcubWV0aG9kKS50b1VwcGVyQ2FzZSgpIDogJ0dFVCcsXG4gIH07XG59XG5cbmZ1bmN0aW9uIGdldEhlYWRlcnNGcm9tRmV0Y2hBcmdzKGZldGNoQXJncykge1xuICBjb25zdCBbcmVxdWVzdEFyZ3VtZW50LCBvcHRpb25zQXJndW1lbnRdID0gZmV0Y2hBcmdzO1xuXG4gIHRyeSB7XG4gICAgaWYgKFxuICAgICAgdHlwZW9mIG9wdGlvbnNBcmd1bWVudCA9PT0gJ29iamVjdCcgJiZcbiAgICAgIG9wdGlvbnNBcmd1bWVudCAhPT0gbnVsbCAmJlxuICAgICAgJ2hlYWRlcnMnIGluIG9wdGlvbnNBcmd1bWVudCAmJlxuICAgICAgb3B0aW9uc0FyZ3VtZW50LmhlYWRlcnNcbiAgICApIHtcbiAgICAgIHJldHVybiBuZXcgSGVhZGVycyhvcHRpb25zQXJndW1lbnQuaGVhZGVycyApO1xuICAgIH1cblxuICAgIGlmIChpcy5pc1JlcXVlc3QocmVxdWVzdEFyZ3VtZW50KSkge1xuICAgICAgcmV0dXJuIG5ldyBIZWFkZXJzKHJlcXVlc3RBcmd1bWVudC5oZWFkZXJzKTtcbiAgICB9XG4gIH0gY2F0Y2gge1xuICAgIC8vIG5vb3BcbiAgfVxuXG4gIHJldHVybjtcbn1cblxuZXhwb3J0cy5hZGRGZXRjaEVuZEluc3RydW1lbnRhdGlvbkhhbmRsZXIgPSBhZGRGZXRjaEVuZEluc3RydW1lbnRhdGlvbkhhbmRsZXI7XG5leHBvcnRzLmFkZEZldGNoSW5zdHJ1bWVudGF0aW9uSGFuZGxlciA9IGFkZEZldGNoSW5zdHJ1bWVudGF0aW9uSGFuZGxlcjtcbmV4cG9ydHMucGFyc2VGZXRjaEFyZ3MgPSBwYXJzZUZldGNoQXJncztcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWZldGNoLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/fetch.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/globalError.js":
/*!**************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/globalError.js ***!
  \**************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst worldwide = __webpack_require__(/*! ../utils/worldwide.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/worldwide.js\");\nconst handlers = __webpack_require__(/*! ./handlers.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/handlers.js\");\n\nlet _oldOnErrorHandler = null;\n\n/**\n * Add an instrumentation handler for when an error is captured by the global error handler.\n *\n * Use at your own risk, this might break without changelog notice, only used internally.\n * @hidden\n */\nfunction addGlobalErrorInstrumentationHandler(handler) {\n  const type = 'error';\n  handlers.addHandler(type, handler);\n  handlers.maybeInstrument(type, instrumentError);\n}\n\nfunction instrumentError() {\n  _oldOnErrorHandler = worldwide.GLOBAL_OBJ.onerror;\n\n  // Note: The reason we are doing window.onerror instead of window.addEventListener('error')\n  // is that we are using this handler in the Loader Script, to handle buffered errors consistently\n  worldwide.GLOBAL_OBJ.onerror = function (\n    msg,\n    url,\n    line,\n    column,\n    error,\n  ) {\n    const handlerData = {\n      column,\n      error,\n      line,\n      msg,\n      url,\n    };\n    handlers.triggerHandlers('error', handlerData);\n\n    if (_oldOnErrorHandler) {\n      // eslint-disable-next-line prefer-rest-params\n      return _oldOnErrorHandler.apply(this, arguments);\n    }\n\n    return false;\n  };\n\n  worldwide.GLOBAL_OBJ.onerror.__SENTRY_INSTRUMENTED__ = true;\n}\n\nexports.addGlobalErrorInstrumentationHandler = addGlobalErrorInstrumentationHandler;\n//# sourceMappingURL=globalError.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvaW5zdHJ1bWVudC9nbG9iYWxFcnJvci5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxrQkFBa0IsbUJBQU8sQ0FBQywySUFBdUI7QUFDakQsaUJBQWlCLG1CQUFPLENBQUMsdUlBQWU7O0FBRXhDOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQSw0Q0FBNEM7QUFDNUMiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnN0cnVtZW50L2dsb2JhbEVycm9yLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCB3b3JsZHdpZGUgPSByZXF1aXJlKCcuLi91dGlscy93b3JsZHdpZGUuanMnKTtcbmNvbnN0IGhhbmRsZXJzID0gcmVxdWlyZSgnLi9oYW5kbGVycy5qcycpO1xuXG5sZXQgX29sZE9uRXJyb3JIYW5kbGVyID0gbnVsbDtcblxuLyoqXG4gKiBBZGQgYW4gaW5zdHJ1bWVudGF0aW9uIGhhbmRsZXIgZm9yIHdoZW4gYW4gZXJyb3IgaXMgY2FwdHVyZWQgYnkgdGhlIGdsb2JhbCBlcnJvciBoYW5kbGVyLlxuICpcbiAqIFVzZSBhdCB5b3VyIG93biByaXNrLCB0aGlzIG1pZ2h0IGJyZWFrIHdpdGhvdXQgY2hhbmdlbG9nIG5vdGljZSwgb25seSB1c2VkIGludGVybmFsbHkuXG4gKiBAaGlkZGVuXG4gKi9cbmZ1bmN0aW9uIGFkZEdsb2JhbEVycm9ySW5zdHJ1bWVudGF0aW9uSGFuZGxlcihoYW5kbGVyKSB7XG4gIGNvbnN0IHR5cGUgPSAnZXJyb3InO1xuICBoYW5kbGVycy5hZGRIYW5kbGVyKHR5cGUsIGhhbmRsZXIpO1xuICBoYW5kbGVycy5tYXliZUluc3RydW1lbnQodHlwZSwgaW5zdHJ1bWVudEVycm9yKTtcbn1cblxuZnVuY3Rpb24gaW5zdHJ1bWVudEVycm9yKCkge1xuICBfb2xkT25FcnJvckhhbmRsZXIgPSB3b3JsZHdpZGUuR0xPQkFMX09CSi5vbmVycm9yO1xuXG4gIC8vIE5vdGU6IFRoZSByZWFzb24gd2UgYXJlIGRvaW5nIHdpbmRvdy5vbmVycm9yIGluc3RlYWQgb2Ygd2luZG93LmFkZEV2ZW50TGlzdGVuZXIoJ2Vycm9yJylcbiAgLy8gaXMgdGhhdCB3ZSBhcmUgdXNpbmcgdGhpcyBoYW5kbGVyIGluIHRoZSBMb2FkZXIgU2NyaXB0LCB0byBoYW5kbGUgYnVmZmVyZWQgZXJyb3JzIGNvbnNpc3RlbnRseVxuICB3b3JsZHdpZGUuR0xPQkFMX09CSi5vbmVycm9yID0gZnVuY3Rpb24gKFxuICAgIG1zZyxcbiAgICB1cmwsXG4gICAgbGluZSxcbiAgICBjb2x1bW4sXG4gICAgZXJyb3IsXG4gICkge1xuICAgIGNvbnN0IGhhbmRsZXJEYXRhID0ge1xuICAgICAgY29sdW1uLFxuICAgICAgZXJyb3IsXG4gICAgICBsaW5lLFxuICAgICAgbXNnLFxuICAgICAgdXJsLFxuICAgIH07XG4gICAgaGFuZGxlcnMudHJpZ2dlckhhbmRsZXJzKCdlcnJvcicsIGhhbmRsZXJEYXRhKTtcblxuICAgIGlmIChfb2xkT25FcnJvckhhbmRsZXIpIHtcbiAgICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBwcmVmZXItcmVzdC1wYXJhbXNcbiAgICAgIHJldHVybiBfb2xkT25FcnJvckhhbmRsZXIuYXBwbHkodGhpcywgYXJndW1lbnRzKTtcbiAgICB9XG5cbiAgICByZXR1cm4gZmFsc2U7XG4gIH07XG5cbiAgd29ybGR3aWRlLkdMT0JBTF9PQkoub25lcnJvci5fX1NFTlRSWV9JTlNUUlVNRU5URURfXyA9IHRydWU7XG59XG5cbmV4cG9ydHMuYWRkR2xvYmFsRXJyb3JJbnN0cnVtZW50YXRpb25IYW5kbGVyID0gYWRkR2xvYmFsRXJyb3JJbnN0cnVtZW50YXRpb25IYW5kbGVyO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9Z2xvYmFsRXJyb3IuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/globalError.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/globalUnhandledRejection.js":
/*!***************************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/globalUnhandledRejection.js ***!
  \***************************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst worldwide = __webpack_require__(/*! ../utils/worldwide.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/worldwide.js\");\nconst handlers = __webpack_require__(/*! ./handlers.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/handlers.js\");\n\nlet _oldOnUnhandledRejectionHandler = null;\n\n/**\n * Add an instrumentation handler for when an unhandled promise rejection is captured.\n *\n * Use at your own risk, this might break without changelog notice, only used internally.\n * @hidden\n */\nfunction addGlobalUnhandledRejectionInstrumentationHandler(\n  handler,\n) {\n  const type = 'unhandledrejection';\n  handlers.addHandler(type, handler);\n  handlers.maybeInstrument(type, instrumentUnhandledRejection);\n}\n\nfunction instrumentUnhandledRejection() {\n  _oldOnUnhandledRejectionHandler = worldwide.GLOBAL_OBJ.onunhandledrejection;\n\n  // Note: The reason we are doing window.onunhandledrejection instead of window.addEventListener('unhandledrejection')\n  // is that we are using this handler in the Loader Script, to handle buffered rejections consistently\n  worldwide.GLOBAL_OBJ.onunhandledrejection = function (e) {\n    const handlerData = e;\n    handlers.triggerHandlers('unhandledrejection', handlerData);\n\n    if (_oldOnUnhandledRejectionHandler) {\n      // eslint-disable-next-line prefer-rest-params\n      return _oldOnUnhandledRejectionHandler.apply(this, arguments);\n    }\n\n    return true;\n  };\n\n  worldwide.GLOBAL_OBJ.onunhandledrejection.__SENTRY_INSTRUMENTED__ = true;\n}\n\nexports.addGlobalUnhandledRejectionInstrumentationHandler = addGlobalUnhandledRejectionInstrumentationHandler;\n//# sourceMappingURL=globalUnhandledRejection.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvaW5zdHJ1bWVudC9nbG9iYWxVbmhhbmRsZWRSZWplY3Rpb24uanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsa0JBQWtCLG1CQUFPLENBQUMsMklBQXVCO0FBQ2pELGlCQUFpQixtQkFBTyxDQUFDLHVJQUFlOztBQUV4Qzs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBOztBQUVBLHlEQUF5RDtBQUN6RCIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL2luc3RydW1lbnQvZ2xvYmFsVW5oYW5kbGVkUmVqZWN0aW9uLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCB3b3JsZHdpZGUgPSByZXF1aXJlKCcuLi91dGlscy93b3JsZHdpZGUuanMnKTtcbmNvbnN0IGhhbmRsZXJzID0gcmVxdWlyZSgnLi9oYW5kbGVycy5qcycpO1xuXG5sZXQgX29sZE9uVW5oYW5kbGVkUmVqZWN0aW9uSGFuZGxlciA9IG51bGw7XG5cbi8qKlxuICogQWRkIGFuIGluc3RydW1lbnRhdGlvbiBoYW5kbGVyIGZvciB3aGVuIGFuIHVuaGFuZGxlZCBwcm9taXNlIHJlamVjdGlvbiBpcyBjYXB0dXJlZC5cbiAqXG4gKiBVc2UgYXQgeW91ciBvd24gcmlzaywgdGhpcyBtaWdodCBicmVhayB3aXRob3V0IGNoYW5nZWxvZyBub3RpY2UsIG9ubHkgdXNlZCBpbnRlcm5hbGx5LlxuICogQGhpZGRlblxuICovXG5mdW5jdGlvbiBhZGRHbG9iYWxVbmhhbmRsZWRSZWplY3Rpb25JbnN0cnVtZW50YXRpb25IYW5kbGVyKFxuICBoYW5kbGVyLFxuKSB7XG4gIGNvbnN0IHR5cGUgPSAndW5oYW5kbGVkcmVqZWN0aW9uJztcbiAgaGFuZGxlcnMuYWRkSGFuZGxlcih0eXBlLCBoYW5kbGVyKTtcbiAgaGFuZGxlcnMubWF5YmVJbnN0cnVtZW50KHR5cGUsIGluc3RydW1lbnRVbmhhbmRsZWRSZWplY3Rpb24pO1xufVxuXG5mdW5jdGlvbiBpbnN0cnVtZW50VW5oYW5kbGVkUmVqZWN0aW9uKCkge1xuICBfb2xkT25VbmhhbmRsZWRSZWplY3Rpb25IYW5kbGVyID0gd29ybGR3aWRlLkdMT0JBTF9PQkoub251bmhhbmRsZWRyZWplY3Rpb247XG5cbiAgLy8gTm90ZTogVGhlIHJlYXNvbiB3ZSBhcmUgZG9pbmcgd2luZG93Lm9udW5oYW5kbGVkcmVqZWN0aW9uIGluc3RlYWQgb2Ygd2luZG93LmFkZEV2ZW50TGlzdGVuZXIoJ3VuaGFuZGxlZHJlamVjdGlvbicpXG4gIC8vIGlzIHRoYXQgd2UgYXJlIHVzaW5nIHRoaXMgaGFuZGxlciBpbiB0aGUgTG9hZGVyIFNjcmlwdCwgdG8gaGFuZGxlIGJ1ZmZlcmVkIHJlamVjdGlvbnMgY29uc2lzdGVudGx5XG4gIHdvcmxkd2lkZS5HTE9CQUxfT0JKLm9udW5oYW5kbGVkcmVqZWN0aW9uID0gZnVuY3Rpb24gKGUpIHtcbiAgICBjb25zdCBoYW5kbGVyRGF0YSA9IGU7XG4gICAgaGFuZGxlcnMudHJpZ2dlckhhbmRsZXJzKCd1bmhhbmRsZWRyZWplY3Rpb24nLCBoYW5kbGVyRGF0YSk7XG5cbiAgICBpZiAoX29sZE9uVW5oYW5kbGVkUmVqZWN0aW9uSGFuZGxlcikge1xuICAgICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIHByZWZlci1yZXN0LXBhcmFtc1xuICAgICAgcmV0dXJuIF9vbGRPblVuaGFuZGxlZFJlamVjdGlvbkhhbmRsZXIuYXBwbHkodGhpcywgYXJndW1lbnRzKTtcbiAgICB9XG5cbiAgICByZXR1cm4gdHJ1ZTtcbiAgfTtcblxuICB3b3JsZHdpZGUuR0xPQkFMX09CSi5vbnVuaGFuZGxlZHJlamVjdGlvbi5fX1NFTlRSWV9JTlNUUlVNRU5URURfXyA9IHRydWU7XG59XG5cbmV4cG9ydHMuYWRkR2xvYmFsVW5oYW5kbGVkUmVqZWN0aW9uSW5zdHJ1bWVudGF0aW9uSGFuZGxlciA9IGFkZEdsb2JhbFVuaGFuZGxlZFJlamVjdGlvbkluc3RydW1lbnRhdGlvbkhhbmRsZXI7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1nbG9iYWxVbmhhbmRsZWRSZWplY3Rpb24uanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/globalUnhandledRejection.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/handlers.js":
/*!***********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/handlers.js ***!
  \***********************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst debugBuild = __webpack_require__(/*! ../debug-build.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst debugLogger = __webpack_require__(/*! ../utils/debug-logger.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst stacktrace = __webpack_require__(/*! ../utils/stacktrace.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/stacktrace.js\");\n\n// We keep the handlers globally\nconst handlers = {};\nconst instrumented = {};\n\n/** Add a handler function. */\nfunction addHandler(type, handler) {\n  handlers[type] = handlers[type] || [];\n  (handlers[type] ).push(handler);\n}\n\n/**\n * Reset all instrumentation handlers.\n * This can be used by tests to ensure we have a clean slate of instrumentation handlers.\n */\nfunction resetInstrumentationHandlers() {\n  Object.keys(handlers).forEach(key => {\n    handlers[key ] = undefined;\n  });\n}\n\n/** Maybe run an instrumentation function, unless it was already called. */\nfunction maybeInstrument(type, instrumentFn) {\n  if (!instrumented[type]) {\n    instrumented[type] = true;\n    try {\n      instrumentFn();\n    } catch (e) {\n      debugBuild.DEBUG_BUILD && debugLogger.debug.error(`Error while instrumenting ${type}`, e);\n    }\n  }\n}\n\n/** Trigger handlers for a given instrumentation type. */\nfunction triggerHandlers(type, data) {\n  const typeHandlers = type && handlers[type];\n  if (!typeHandlers) {\n    return;\n  }\n\n  for (const handler of typeHandlers) {\n    try {\n      handler(data);\n    } catch (e) {\n      debugBuild.DEBUG_BUILD &&\n        debugLogger.debug.error(\n          `Error while triggering instrumentation handler.\\nType: ${type}\\nName: ${stacktrace.getFunctionName(handler)}\\nError:`,\n          e,\n        );\n    }\n  }\n}\n\nexports.addHandler = addHandler;\nexports.maybeInstrument = maybeInstrument;\nexports.resetInstrumentationHandlers = resetInstrumentationHandlers;\nexports.triggerHandlers = triggerHandlers;\n//# sourceMappingURL=handlers.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvaW5zdHJ1bWVudC9oYW5kbGVycy5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxtQkFBbUIsbUJBQU8sQ0FBQyxtSUFBbUI7QUFDOUMsb0JBQW9CLG1CQUFPLENBQUMsaUpBQTBCO0FBQ3RELG1CQUFtQixtQkFBTyxDQUFDLDZJQUF3Qjs7QUFFbkQ7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxHQUFHO0FBQ0g7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsTUFBTTtBQUNOLHFGQUFxRixLQUFLO0FBQzFGO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0EsTUFBTTtBQUNOO0FBQ0E7QUFDQSxvRUFBb0UsS0FBSyxVQUFVLG9DQUFvQztBQUN2SDtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLGtCQUFrQjtBQUNsQix1QkFBdUI7QUFDdkIsb0NBQW9DO0FBQ3BDLHVCQUF1QjtBQUN2QiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL2luc3RydW1lbnQvaGFuZGxlcnMuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGRlYnVnQnVpbGQgPSByZXF1aXJlKCcuLi9kZWJ1Zy1idWlsZC5qcycpO1xuY29uc3QgZGVidWdMb2dnZXIgPSByZXF1aXJlKCcuLi91dGlscy9kZWJ1Zy1sb2dnZXIuanMnKTtcbmNvbnN0IHN0YWNrdHJhY2UgPSByZXF1aXJlKCcuLi91dGlscy9zdGFja3RyYWNlLmpzJyk7XG5cbi8vIFdlIGtlZXAgdGhlIGhhbmRsZXJzIGdsb2JhbGx5XG5jb25zdCBoYW5kbGVycyA9IHt9O1xuY29uc3QgaW5zdHJ1bWVudGVkID0ge307XG5cbi8qKiBBZGQgYSBoYW5kbGVyIGZ1bmN0aW9uLiAqL1xuZnVuY3Rpb24gYWRkSGFuZGxlcih0eXBlLCBoYW5kbGVyKSB7XG4gIGhhbmRsZXJzW3R5cGVdID0gaGFuZGxlcnNbdHlwZV0gfHwgW107XG4gIChoYW5kbGVyc1t0eXBlXSApLnB1c2goaGFuZGxlcik7XG59XG5cbi8qKlxuICogUmVzZXQgYWxsIGluc3RydW1lbnRhdGlvbiBoYW5kbGVycy5cbiAqIFRoaXMgY2FuIGJlIHVzZWQgYnkgdGVzdHMgdG8gZW5zdXJlIHdlIGhhdmUgYSBjbGVhbiBzbGF0ZSBvZiBpbnN0cnVtZW50YXRpb24gaGFuZGxlcnMuXG4gKi9cbmZ1bmN0aW9uIHJlc2V0SW5zdHJ1bWVudGF0aW9uSGFuZGxlcnMoKSB7XG4gIE9iamVjdC5rZXlzKGhhbmRsZXJzKS5mb3JFYWNoKGtleSA9PiB7XG4gICAgaGFuZGxlcnNba2V5IF0gPSB1bmRlZmluZWQ7XG4gIH0pO1xufVxuXG4vKiogTWF5YmUgcnVuIGFuIGluc3RydW1lbnRhdGlvbiBmdW5jdGlvbiwgdW5sZXNzIGl0IHdhcyBhbHJlYWR5IGNhbGxlZC4gKi9cbmZ1bmN0aW9uIG1heWJlSW5zdHJ1bWVudCh0eXBlLCBpbnN0cnVtZW50Rm4pIHtcbiAgaWYgKCFpbnN0cnVtZW50ZWRbdHlwZV0pIHtcbiAgICBpbnN0cnVtZW50ZWRbdHlwZV0gPSB0cnVlO1xuICAgIHRyeSB7XG4gICAgICBpbnN0cnVtZW50Rm4oKTtcbiAgICB9IGNhdGNoIChlKSB7XG4gICAgICBkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEICYmIGRlYnVnTG9nZ2VyLmRlYnVnLmVycm9yKGBFcnJvciB3aGlsZSBpbnN0cnVtZW50aW5nICR7dHlwZX1gLCBlKTtcbiAgICB9XG4gIH1cbn1cblxuLyoqIFRyaWdnZXIgaGFuZGxlcnMgZm9yIGEgZ2l2ZW4gaW5zdHJ1bWVudGF0aW9uIHR5cGUuICovXG5mdW5jdGlvbiB0cmlnZ2VySGFuZGxlcnModHlwZSwgZGF0YSkge1xuICBjb25zdCB0eXBlSGFuZGxlcnMgPSB0eXBlICYmIGhhbmRsZXJzW3R5cGVdO1xuICBpZiAoIXR5cGVIYW5kbGVycykge1xuICAgIHJldHVybjtcbiAgfVxuXG4gIGZvciAoY29uc3QgaGFuZGxlciBvZiB0eXBlSGFuZGxlcnMpIHtcbiAgICB0cnkge1xuICAgICAgaGFuZGxlcihkYXRhKTtcbiAgICB9IGNhdGNoIChlKSB7XG4gICAgICBkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEICYmXG4gICAgICAgIGRlYnVnTG9nZ2VyLmRlYnVnLmVycm9yKFxuICAgICAgICAgIGBFcnJvciB3aGlsZSB0cmlnZ2VyaW5nIGluc3RydW1lbnRhdGlvbiBoYW5kbGVyLlxcblR5cGU6ICR7dHlwZX1cXG5OYW1lOiAke3N0YWNrdHJhY2UuZ2V0RnVuY3Rpb25OYW1lKGhhbmRsZXIpfVxcbkVycm9yOmAsXG4gICAgICAgICAgZSxcbiAgICAgICAgKTtcbiAgICB9XG4gIH1cbn1cblxuZXhwb3J0cy5hZGRIYW5kbGVyID0gYWRkSGFuZGxlcjtcbmV4cG9ydHMubWF5YmVJbnN0cnVtZW50ID0gbWF5YmVJbnN0cnVtZW50O1xuZXhwb3J0cy5yZXNldEluc3RydW1lbnRhdGlvbkhhbmRsZXJzID0gcmVzZXRJbnN0cnVtZW50YXRpb25IYW5kbGVycztcbmV4cG9ydHMudHJpZ2dlckhhbmRsZXJzID0gdHJpZ2dlckhhbmRsZXJzO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9aGFuZGxlcnMuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/handlers.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integration.js":
/*!***************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integration.js ***!
  \***************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst currentScopes = __webpack_require__(/*! ./currentScopes.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst debugBuild = __webpack_require__(/*! ./debug-build.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst debugLogger = __webpack_require__(/*! ./utils/debug-logger.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\n\nconst installedIntegrations = [];\n\n/** Map of integrations assigned to a client */\n\n/**\n * Remove duplicates from the given array, preferring the last instance of any duplicate. Not guaranteed to\n * preserve the order of integrations in the array.\n *\n * @private\n */\nfunction filterDuplicates(integrations) {\n  const integrationsByName = {};\n\n  integrations.forEach((currentInstance) => {\n    const { name } = currentInstance;\n\n    const existingInstance = integrationsByName[name];\n\n    // We want integrations later in the array to overwrite earlier ones of the same type, except that we never want a\n    // default instance to overwrite an existing user instance\n    if (existingInstance && !existingInstance.isDefaultInstance && currentInstance.isDefaultInstance) {\n      return;\n    }\n\n    integrationsByName[name] = currentInstance;\n  });\n\n  return Object.values(integrationsByName);\n}\n\n/** Gets integrations to install */\nfunction getIntegrationsToSetup(options) {\n  const defaultIntegrations = options.defaultIntegrations || [];\n  const userIntegrations = options.integrations;\n\n  // We flag default instances, so that later we can tell them apart from any user-created instances of the same class\n  defaultIntegrations.forEach((integration) => {\n    integration.isDefaultInstance = true;\n  });\n\n  let integrations;\n\n  if (Array.isArray(userIntegrations)) {\n    integrations = [...defaultIntegrations, ...userIntegrations];\n  } else if (typeof userIntegrations === 'function') {\n    const resolvedUserIntegrations = userIntegrations(defaultIntegrations);\n    integrations = Array.isArray(resolvedUserIntegrations) ? resolvedUserIntegrations : [resolvedUserIntegrations];\n  } else {\n    integrations = defaultIntegrations;\n  }\n\n  return filterDuplicates(integrations);\n}\n\n/**\n * Given a list of integration instances this installs them all. When `withDefaults` is set to `true` then all default\n * integrations are added unless they were already provided before.\n * @param integrations array of integration instances\n * @param withDefault should enable default integrations\n */\nfunction setupIntegrations(client, integrations) {\n  const integrationIndex = {};\n\n  integrations.forEach((integration) => {\n    // guard against empty provided integrations\n    if (integration) {\n      setupIntegration(client, integration, integrationIndex);\n    }\n  });\n\n  return integrationIndex;\n}\n\n/**\n * Execute the `afterAllSetup` hooks of the given integrations.\n */\nfunction afterSetupIntegrations(client, integrations) {\n  for (const integration of integrations) {\n    // guard against empty provided integrations\n    if (integration?.afterAllSetup) {\n      integration.afterAllSetup(client);\n    }\n  }\n}\n\n/** Setup a single integration.  */\nfunction setupIntegration(client, integration, integrationIndex) {\n  if (integrationIndex[integration.name]) {\n    debugBuild.DEBUG_BUILD && debugLogger.debug.log(`Integration skipped because it was already installed: ${integration.name}`);\n    return;\n  }\n  integrationIndex[integration.name] = integration;\n\n  // `setupOnce` is only called the first time\n  if (installedIntegrations.indexOf(integration.name) === -1 && typeof integration.setupOnce === 'function') {\n    integration.setupOnce();\n    installedIntegrations.push(integration.name);\n  }\n\n  // `setup` is run for each client\n  if (integration.setup && typeof integration.setup === 'function') {\n    integration.setup(client);\n  }\n\n  if (typeof integration.preprocessEvent === 'function') {\n    const callback = integration.preprocessEvent.bind(integration) ;\n    client.on('preprocessEvent', (event, hint) => callback(event, hint, client));\n  }\n\n  if (typeof integration.processEvent === 'function') {\n    const callback = integration.processEvent.bind(integration) ;\n\n    const processor = Object.assign((event, hint) => callback(event, hint, client), {\n      id: integration.name,\n    });\n\n    client.addEventProcessor(processor);\n  }\n\n  debugBuild.DEBUG_BUILD && debugLogger.debug.log(`Integration installed: ${integration.name}`);\n}\n\n/** Add an integration to the current scope's client. */\nfunction addIntegration(integration) {\n  const client = currentScopes.getClient();\n\n  if (!client) {\n    debugBuild.DEBUG_BUILD && debugLogger.debug.warn(`Cannot add integration \"${integration.name}\" because no SDK Client is available.`);\n    return;\n  }\n\n  client.addIntegration(integration);\n}\n\n/**\n * Define an integration function that can be used to create an integration instance.\n * Note that this by design hides the implementation details of the integration, as they are considered internal.\n */\nfunction defineIntegration(fn) {\n  return fn;\n}\n\nexports.addIntegration = addIntegration;\nexports.afterSetupIntegrations = afterSetupIntegrations;\nexports.defineIntegration = defineIntegration;\nexports.getIntegrationsToSetup = getIntegrationsToSetup;\nexports.installedIntegrations = installedIntegrations;\nexports.setupIntegration = setupIntegration;\nexports.setupIntegrations = setupIntegrations;\n//# sourceMappingURL=integration.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvaW50ZWdyYXRpb24uanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsc0JBQXNCLG1CQUFPLENBQUMsc0lBQW9CO0FBQ2xELG1CQUFtQixtQkFBTyxDQUFDLGtJQUFrQjtBQUM3QyxvQkFBb0IsbUJBQU8sQ0FBQyxnSkFBeUI7O0FBRXJEOztBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQSxZQUFZLE9BQU87O0FBRW5COztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQSxHQUFHOztBQUVIO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0EsR0FBRzs7QUFFSDs7QUFFQTtBQUNBO0FBQ0EsSUFBSTtBQUNKO0FBQ0E7QUFDQSxJQUFJO0FBQ0o7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEdBQUc7O0FBRUg7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBLDZHQUE2RyxpQkFBaUI7QUFDOUg7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsS0FBSzs7QUFFTDtBQUNBOztBQUVBLDRFQUE0RSxpQkFBaUI7QUFDN0Y7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0EsZ0ZBQWdGLGlCQUFpQjtBQUNqRztBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsc0JBQXNCO0FBQ3RCLDhCQUE4QjtBQUM5Qix5QkFBeUI7QUFDekIsOEJBQThCO0FBQzlCLDZCQUE2QjtBQUM3Qix3QkFBd0I7QUFDeEIseUJBQXlCO0FBQ3pCIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvaW50ZWdyYXRpb24uanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGN1cnJlbnRTY29wZXMgPSByZXF1aXJlKCcuL2N1cnJlbnRTY29wZXMuanMnKTtcbmNvbnN0IGRlYnVnQnVpbGQgPSByZXF1aXJlKCcuL2RlYnVnLWJ1aWxkLmpzJyk7XG5jb25zdCBkZWJ1Z0xvZ2dlciA9IHJlcXVpcmUoJy4vdXRpbHMvZGVidWctbG9nZ2VyLmpzJyk7XG5cbmNvbnN0IGluc3RhbGxlZEludGVncmF0aW9ucyA9IFtdO1xuXG4vKiogTWFwIG9mIGludGVncmF0aW9ucyBhc3NpZ25lZCB0byBhIGNsaWVudCAqL1xuXG4vKipcbiAqIFJlbW92ZSBkdXBsaWNhdGVzIGZyb20gdGhlIGdpdmVuIGFycmF5LCBwcmVmZXJyaW5nIHRoZSBsYXN0IGluc3RhbmNlIG9mIGFueSBkdXBsaWNhdGUuIE5vdCBndWFyYW50ZWVkIHRvXG4gKiBwcmVzZXJ2ZSB0aGUgb3JkZXIgb2YgaW50ZWdyYXRpb25zIGluIHRoZSBhcnJheS5cbiAqXG4gKiBAcHJpdmF0ZVxuICovXG5mdW5jdGlvbiBmaWx0ZXJEdXBsaWNhdGVzKGludGVncmF0aW9ucykge1xuICBjb25zdCBpbnRlZ3JhdGlvbnNCeU5hbWUgPSB7fTtcblxuICBpbnRlZ3JhdGlvbnMuZm9yRWFjaCgoY3VycmVudEluc3RhbmNlKSA9PiB7XG4gICAgY29uc3QgeyBuYW1lIH0gPSBjdXJyZW50SW5zdGFuY2U7XG5cbiAgICBjb25zdCBleGlzdGluZ0luc3RhbmNlID0gaW50ZWdyYXRpb25zQnlOYW1lW25hbWVdO1xuXG4gICAgLy8gV2Ugd2FudCBpbnRlZ3JhdGlvbnMgbGF0ZXIgaW4gdGhlIGFycmF5IHRvIG92ZXJ3cml0ZSBlYXJsaWVyIG9uZXMgb2YgdGhlIHNhbWUgdHlwZSwgZXhjZXB0IHRoYXQgd2UgbmV2ZXIgd2FudCBhXG4gICAgLy8gZGVmYXVsdCBpbnN0YW5jZSB0byBvdmVyd3JpdGUgYW4gZXhpc3RpbmcgdXNlciBpbnN0YW5jZVxuICAgIGlmIChleGlzdGluZ0luc3RhbmNlICYmICFleGlzdGluZ0luc3RhbmNlLmlzRGVmYXVsdEluc3RhbmNlICYmIGN1cnJlbnRJbnN0YW5jZS5pc0RlZmF1bHRJbnN0YW5jZSkge1xuICAgICAgcmV0dXJuO1xuICAgIH1cblxuICAgIGludGVncmF0aW9uc0J5TmFtZVtuYW1lXSA9IGN1cnJlbnRJbnN0YW5jZTtcbiAgfSk7XG5cbiAgcmV0dXJuIE9iamVjdC52YWx1ZXMoaW50ZWdyYXRpb25zQnlOYW1lKTtcbn1cblxuLyoqIEdldHMgaW50ZWdyYXRpb25zIHRvIGluc3RhbGwgKi9cbmZ1bmN0aW9uIGdldEludGVncmF0aW9uc1RvU2V0dXAob3B0aW9ucykge1xuICBjb25zdCBkZWZhdWx0SW50ZWdyYXRpb25zID0gb3B0aW9ucy5kZWZhdWx0SW50ZWdyYXRpb25zIHx8IFtdO1xuICBjb25zdCB1c2VySW50ZWdyYXRpb25zID0gb3B0aW9ucy5pbnRlZ3JhdGlvbnM7XG5cbiAgLy8gV2UgZmxhZyBkZWZhdWx0IGluc3RhbmNlcywgc28gdGhhdCBsYXRlciB3ZSBjYW4gdGVsbCB0aGVtIGFwYXJ0IGZyb20gYW55IHVzZXItY3JlYXRlZCBpbnN0YW5jZXMgb2YgdGhlIHNhbWUgY2xhc3NcbiAgZGVmYXVsdEludGVncmF0aW9ucy5mb3JFYWNoKChpbnRlZ3JhdGlvbikgPT4ge1xuICAgIGludGVncmF0aW9uLmlzRGVmYXVsdEluc3RhbmNlID0gdHJ1ZTtcbiAgfSk7XG5cbiAgbGV0IGludGVncmF0aW9ucztcblxuICBpZiAoQXJyYXkuaXNBcnJheSh1c2VySW50ZWdyYXRpb25zKSkge1xuICAgIGludGVncmF0aW9ucyA9IFsuLi5kZWZhdWx0SW50ZWdyYXRpb25zLCAuLi51c2VySW50ZWdyYXRpb25zXTtcbiAgfSBlbHNlIGlmICh0eXBlb2YgdXNlckludGVncmF0aW9ucyA9PT0gJ2Z1bmN0aW9uJykge1xuICAgIGNvbnN0IHJlc29sdmVkVXNlckludGVncmF0aW9ucyA9IHVzZXJJbnRlZ3JhdGlvbnMoZGVmYXVsdEludGVncmF0aW9ucyk7XG4gICAgaW50ZWdyYXRpb25zID0gQXJyYXkuaXNBcnJheShyZXNvbHZlZFVzZXJJbnRlZ3JhdGlvbnMpID8gcmVzb2x2ZWRVc2VySW50ZWdyYXRpb25zIDogW3Jlc29sdmVkVXNlckludGVncmF0aW9uc107XG4gIH0gZWxzZSB7XG4gICAgaW50ZWdyYXRpb25zID0gZGVmYXVsdEludGVncmF0aW9ucztcbiAgfVxuXG4gIHJldHVybiBmaWx0ZXJEdXBsaWNhdGVzKGludGVncmF0aW9ucyk7XG59XG5cbi8qKlxuICogR2l2ZW4gYSBsaXN0IG9mIGludGVncmF0aW9uIGluc3RhbmNlcyB0aGlzIGluc3RhbGxzIHRoZW0gYWxsLiBXaGVuIGB3aXRoRGVmYXVsdHNgIGlzIHNldCB0byBgdHJ1ZWAgdGhlbiBhbGwgZGVmYXVsdFxuICogaW50ZWdyYXRpb25zIGFyZSBhZGRlZCB1bmxlc3MgdGhleSB3ZXJlIGFscmVhZHkgcHJvdmlkZWQgYmVmb3JlLlxuICogQHBhcmFtIGludGVncmF0aW9ucyBhcnJheSBvZiBpbnRlZ3JhdGlvbiBpbnN0YW5jZXNcbiAqIEBwYXJhbSB3aXRoRGVmYXVsdCBzaG91bGQgZW5hYmxlIGRlZmF1bHQgaW50ZWdyYXRpb25zXG4gKi9cbmZ1bmN0aW9uIHNldHVwSW50ZWdyYXRpb25zKGNsaWVudCwgaW50ZWdyYXRpb25zKSB7XG4gIGNvbnN0IGludGVncmF0aW9uSW5kZXggPSB7fTtcblxuICBpbnRlZ3JhdGlvbnMuZm9yRWFjaCgoaW50ZWdyYXRpb24pID0+IHtcbiAgICAvLyBndWFyZCBhZ2FpbnN0IGVtcHR5IHByb3ZpZGVkIGludGVncmF0aW9uc1xuICAgIGlmIChpbnRlZ3JhdGlvbikge1xuICAgICAgc2V0dXBJbnRlZ3JhdGlvbihjbGllbnQsIGludGVncmF0aW9uLCBpbnRlZ3JhdGlvbkluZGV4KTtcbiAgICB9XG4gIH0pO1xuXG4gIHJldHVybiBpbnRlZ3JhdGlvbkluZGV4O1xufVxuXG4vKipcbiAqIEV4ZWN1dGUgdGhlIGBhZnRlckFsbFNldHVwYCBob29rcyBvZiB0aGUgZ2l2ZW4gaW50ZWdyYXRpb25zLlxuICovXG5mdW5jdGlvbiBhZnRlclNldHVwSW50ZWdyYXRpb25zKGNsaWVudCwgaW50ZWdyYXRpb25zKSB7XG4gIGZvciAoY29uc3QgaW50ZWdyYXRpb24gb2YgaW50ZWdyYXRpb25zKSB7XG4gICAgLy8gZ3VhcmQgYWdhaW5zdCBlbXB0eSBwcm92aWRlZCBpbnRlZ3JhdGlvbnNcbiAgICBpZiAoaW50ZWdyYXRpb24/LmFmdGVyQWxsU2V0dXApIHtcbiAgICAgIGludGVncmF0aW9uLmFmdGVyQWxsU2V0dXAoY2xpZW50KTtcbiAgICB9XG4gIH1cbn1cblxuLyoqIFNldHVwIGEgc2luZ2xlIGludGVncmF0aW9uLiAgKi9cbmZ1bmN0aW9uIHNldHVwSW50ZWdyYXRpb24oY2xpZW50LCBpbnRlZ3JhdGlvbiwgaW50ZWdyYXRpb25JbmRleCkge1xuICBpZiAoaW50ZWdyYXRpb25JbmRleFtpbnRlZ3JhdGlvbi5uYW1lXSkge1xuICAgIGRlYnVnQnVpbGQuREVCVUdfQlVJTEQgJiYgZGVidWdMb2dnZXIuZGVidWcubG9nKGBJbnRlZ3JhdGlvbiBza2lwcGVkIGJlY2F1c2UgaXQgd2FzIGFscmVhZHkgaW5zdGFsbGVkOiAke2ludGVncmF0aW9uLm5hbWV9YCk7XG4gICAgcmV0dXJuO1xuICB9XG4gIGludGVncmF0aW9uSW5kZXhbaW50ZWdyYXRpb24ubmFtZV0gPSBpbnRlZ3JhdGlvbjtcblxuICAvLyBgc2V0dXBPbmNlYCBpcyBvbmx5IGNhbGxlZCB0aGUgZmlyc3QgdGltZVxuICBpZiAoaW5zdGFsbGVkSW50ZWdyYXRpb25zLmluZGV4T2YoaW50ZWdyYXRpb24ubmFtZSkgPT09IC0xICYmIHR5cGVvZiBpbnRlZ3JhdGlvbi5zZXR1cE9uY2UgPT09ICdmdW5jdGlvbicpIHtcbiAgICBpbnRlZ3JhdGlvbi5zZXR1cE9uY2UoKTtcbiAgICBpbnN0YWxsZWRJbnRlZ3JhdGlvbnMucHVzaChpbnRlZ3JhdGlvbi5uYW1lKTtcbiAgfVxuXG4gIC8vIGBzZXR1cGAgaXMgcnVuIGZvciBlYWNoIGNsaWVudFxuICBpZiAoaW50ZWdyYXRpb24uc2V0dXAgJiYgdHlwZW9mIGludGVncmF0aW9uLnNldHVwID09PSAnZnVuY3Rpb24nKSB7XG4gICAgaW50ZWdyYXRpb24uc2V0dXAoY2xpZW50KTtcbiAgfVxuXG4gIGlmICh0eXBlb2YgaW50ZWdyYXRpb24ucHJlcHJvY2Vzc0V2ZW50ID09PSAnZnVuY3Rpb24nKSB7XG4gICAgY29uc3QgY2FsbGJhY2sgPSBpbnRlZ3JhdGlvbi5wcmVwcm9jZXNzRXZlbnQuYmluZChpbnRlZ3JhdGlvbikgO1xuICAgIGNsaWVudC5vbigncHJlcHJvY2Vzc0V2ZW50JywgKGV2ZW50LCBoaW50KSA9PiBjYWxsYmFjayhldmVudCwgaGludCwgY2xpZW50KSk7XG4gIH1cblxuICBpZiAodHlwZW9mIGludGVncmF0aW9uLnByb2Nlc3NFdmVudCA9PT0gJ2Z1bmN0aW9uJykge1xuICAgIGNvbnN0IGNhbGxiYWNrID0gaW50ZWdyYXRpb24ucHJvY2Vzc0V2ZW50LmJpbmQoaW50ZWdyYXRpb24pIDtcblxuICAgIGNvbnN0IHByb2Nlc3NvciA9IE9iamVjdC5hc3NpZ24oKGV2ZW50LCBoaW50KSA9PiBjYWxsYmFjayhldmVudCwgaGludCwgY2xpZW50KSwge1xuICAgICAgaWQ6IGludGVncmF0aW9uLm5hbWUsXG4gICAgfSk7XG5cbiAgICBjbGllbnQuYWRkRXZlbnRQcm9jZXNzb3IocHJvY2Vzc29yKTtcbiAgfVxuXG4gIGRlYnVnQnVpbGQuREVCVUdfQlVJTEQgJiYgZGVidWdMb2dnZXIuZGVidWcubG9nKGBJbnRlZ3JhdGlvbiBpbnN0YWxsZWQ6ICR7aW50ZWdyYXRpb24ubmFtZX1gKTtcbn1cblxuLyoqIEFkZCBhbiBpbnRlZ3JhdGlvbiB0byB0aGUgY3VycmVudCBzY29wZSdzIGNsaWVudC4gKi9cbmZ1bmN0aW9uIGFkZEludGVncmF0aW9uKGludGVncmF0aW9uKSB7XG4gIGNvbnN0IGNsaWVudCA9IGN1cnJlbnRTY29wZXMuZ2V0Q2xpZW50KCk7XG5cbiAgaWYgKCFjbGllbnQpIHtcbiAgICBkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEICYmIGRlYnVnTG9nZ2VyLmRlYnVnLndhcm4oYENhbm5vdCBhZGQgaW50ZWdyYXRpb24gXCIke2ludGVncmF0aW9uLm5hbWV9XCIgYmVjYXVzZSBubyBTREsgQ2xpZW50IGlzIGF2YWlsYWJsZS5gKTtcbiAgICByZXR1cm47XG4gIH1cblxuICBjbGllbnQuYWRkSW50ZWdyYXRpb24oaW50ZWdyYXRpb24pO1xufVxuXG4vKipcbiAqIERlZmluZSBhbiBpbnRlZ3JhdGlvbiBmdW5jdGlvbiB0aGF0IGNhbiBiZSB1c2VkIHRvIGNyZWF0ZSBhbiBpbnRlZ3JhdGlvbiBpbnN0YW5jZS5cbiAqIE5vdGUgdGhhdCB0aGlzIGJ5IGRlc2lnbiBoaWRlcyB0aGUgaW1wbGVtZW50YXRpb24gZGV0YWlscyBvZiB0aGUgaW50ZWdyYXRpb24sIGFzIHRoZXkgYXJlIGNvbnNpZGVyZWQgaW50ZXJuYWwuXG4gKi9cbmZ1bmN0aW9uIGRlZmluZUludGVncmF0aW9uKGZuKSB7XG4gIHJldHVybiBmbjtcbn1cblxuZXhwb3J0cy5hZGRJbnRlZ3JhdGlvbiA9IGFkZEludGVncmF0aW9uO1xuZXhwb3J0cy5hZnRlclNldHVwSW50ZWdyYXRpb25zID0gYWZ0ZXJTZXR1cEludGVncmF0aW9ucztcbmV4cG9ydHMuZGVmaW5lSW50ZWdyYXRpb24gPSBkZWZpbmVJbnRlZ3JhdGlvbjtcbmV4cG9ydHMuZ2V0SW50ZWdyYXRpb25zVG9TZXR1cCA9IGdldEludGVncmF0aW9uc1RvU2V0dXA7XG5leHBvcnRzLmluc3RhbGxlZEludGVncmF0aW9ucyA9IGluc3RhbGxlZEludGVncmF0aW9ucztcbmV4cG9ydHMuc2V0dXBJbnRlZ3JhdGlvbiA9IHNldHVwSW50ZWdyYXRpb247XG5leHBvcnRzLnNldHVwSW50ZWdyYXRpb25zID0gc2V0dXBJbnRlZ3JhdGlvbnM7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1pbnRlZ3JhdGlvbi5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integration.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/captureconsole.js":
/*!*******************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/captureconsole.js ***!
  \*******************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst currentScopes = __webpack_require__(/*! ../currentScopes.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst exports$1 = __webpack_require__(/*! ../exports.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/exports.js\");\nconst console = __webpack_require__(/*! ../instrument/console.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/console.js\");\nconst integration = __webpack_require__(/*! ../integration.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integration.js\");\nconst debugLogger = __webpack_require__(/*! ../utils/debug-logger.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst misc = __webpack_require__(/*! ../utils/misc.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/misc.js\");\nconst severity = __webpack_require__(/*! ../utils/severity.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/severity.js\");\nconst string = __webpack_require__(/*! ../utils/string.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/string.js\");\nconst worldwide = __webpack_require__(/*! ../utils/worldwide.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/worldwide.js\");\n\nconst INTEGRATION_NAME = 'CaptureConsole';\n\nconst _captureConsoleIntegration = ((options = {}) => {\n  const levels = options.levels || debugLogger.CONSOLE_LEVELS;\n  const handled = options.handled ?? true;\n\n  return {\n    name: INTEGRATION_NAME,\n    setup(client) {\n      if (!('console' in worldwide.GLOBAL_OBJ)) {\n        return;\n      }\n\n      console.addConsoleInstrumentationHandler(({ args, level }) => {\n        if (currentScopes.getClient() !== client || !levels.includes(level)) {\n          return;\n        }\n\n        consoleHandler(args, level, handled);\n      });\n    },\n  };\n}) ;\n\n/**\n * Send Console API calls as Sentry Events.\n */\nconst captureConsoleIntegration = integration.defineIntegration(_captureConsoleIntegration);\n\nfunction consoleHandler(args, level, handled) {\n  const captureContext = {\n    level: severity.severityLevelFromString(level),\n    extra: {\n      arguments: args,\n    },\n  };\n\n  currentScopes.withScope(scope => {\n    scope.addEventProcessor(event => {\n      event.logger = 'console';\n\n      misc.addExceptionMechanism(event, {\n        handled,\n        type: 'console',\n      });\n\n      return event;\n    });\n\n    if (level === 'assert') {\n      if (!args[0]) {\n        const message = `Assertion failed: ${string.safeJoin(args.slice(1), ' ') || 'console.assert'}`;\n        scope.setExtra('arguments', args.slice(1));\n        exports$1.captureMessage(message, captureContext);\n      }\n      return;\n    }\n\n    const error = args.find(arg => arg instanceof Error);\n    if (error) {\n      exports$1.captureException(error, captureContext);\n      return;\n    }\n\n    const message = string.safeJoin(args, ' ');\n    exports$1.captureMessage(message, captureContext);\n  });\n}\n\nexports.captureConsoleIntegration = captureConsoleIntegration;\n//# sourceMappingURL=captureconsole.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvaW50ZWdyYXRpb25zL2NhcHR1cmVjb25zb2xlLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLHNCQUFzQixtQkFBTyxDQUFDLHVJQUFxQjtBQUNuRCxrQkFBa0IsbUJBQU8sQ0FBQywySEFBZTtBQUN6QyxnQkFBZ0IsbUJBQU8sQ0FBQyxpSkFBMEI7QUFDbEQsb0JBQW9CLG1CQUFPLENBQUMsbUlBQW1CO0FBQy9DLG9CQUFvQixtQkFBTyxDQUFDLGlKQUEwQjtBQUN0RCxhQUFhLG1CQUFPLENBQUMsaUlBQWtCO0FBQ3ZDLGlCQUFpQixtQkFBTyxDQUFDLHlJQUFzQjtBQUMvQyxlQUFlLG1CQUFPLENBQUMscUlBQW9CO0FBQzNDLGtCQUFrQixtQkFBTyxDQUFDLDJJQUF1Qjs7QUFFakQ7O0FBRUEsaURBQWlEO0FBQ2pEO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLGtEQUFrRCxhQUFhO0FBQy9EO0FBQ0E7QUFDQTs7QUFFQTtBQUNBLE9BQU87QUFDUCxLQUFLO0FBQ0w7QUFDQSxDQUFDOztBQUVEO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxLQUFLO0FBQ0w7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBLE9BQU87O0FBRVA7QUFDQSxLQUFLOztBQUVMO0FBQ0E7QUFDQSw2Q0FBNkMsd0RBQXdEO0FBQ3JHO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsR0FBRztBQUNIOztBQUVBLGlDQUFpQztBQUNqQyIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL2ludGVncmF0aW9ucy9jYXB0dXJlY29uc29sZS5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgY3VycmVudFNjb3BlcyA9IHJlcXVpcmUoJy4uL2N1cnJlbnRTY29wZXMuanMnKTtcbmNvbnN0IGV4cG9ydHMkMSA9IHJlcXVpcmUoJy4uL2V4cG9ydHMuanMnKTtcbmNvbnN0IGNvbnNvbGUgPSByZXF1aXJlKCcuLi9pbnN0cnVtZW50L2NvbnNvbGUuanMnKTtcbmNvbnN0IGludGVncmF0aW9uID0gcmVxdWlyZSgnLi4vaW50ZWdyYXRpb24uanMnKTtcbmNvbnN0IGRlYnVnTG9nZ2VyID0gcmVxdWlyZSgnLi4vdXRpbHMvZGVidWctbG9nZ2VyLmpzJyk7XG5jb25zdCBtaXNjID0gcmVxdWlyZSgnLi4vdXRpbHMvbWlzYy5qcycpO1xuY29uc3Qgc2V2ZXJpdHkgPSByZXF1aXJlKCcuLi91dGlscy9zZXZlcml0eS5qcycpO1xuY29uc3Qgc3RyaW5nID0gcmVxdWlyZSgnLi4vdXRpbHMvc3RyaW5nLmpzJyk7XG5jb25zdCB3b3JsZHdpZGUgPSByZXF1aXJlKCcuLi91dGlscy93b3JsZHdpZGUuanMnKTtcblxuY29uc3QgSU5URUdSQVRJT05fTkFNRSA9ICdDYXB0dXJlQ29uc29sZSc7XG5cbmNvbnN0IF9jYXB0dXJlQ29uc29sZUludGVncmF0aW9uID0gKChvcHRpb25zID0ge30pID0+IHtcbiAgY29uc3QgbGV2ZWxzID0gb3B0aW9ucy5sZXZlbHMgfHwgZGVidWdMb2dnZXIuQ09OU09MRV9MRVZFTFM7XG4gIGNvbnN0IGhhbmRsZWQgPSBvcHRpb25zLmhhbmRsZWQgPz8gdHJ1ZTtcblxuICByZXR1cm4ge1xuICAgIG5hbWU6IElOVEVHUkFUSU9OX05BTUUsXG4gICAgc2V0dXAoY2xpZW50KSB7XG4gICAgICBpZiAoISgnY29uc29sZScgaW4gd29ybGR3aWRlLkdMT0JBTF9PQkopKSB7XG4gICAgICAgIHJldHVybjtcbiAgICAgIH1cblxuICAgICAgY29uc29sZS5hZGRDb25zb2xlSW5zdHJ1bWVudGF0aW9uSGFuZGxlcigoeyBhcmdzLCBsZXZlbCB9KSA9PiB7XG4gICAgICAgIGlmIChjdXJyZW50U2NvcGVzLmdldENsaWVudCgpICE9PSBjbGllbnQgfHwgIWxldmVscy5pbmNsdWRlcyhsZXZlbCkpIHtcbiAgICAgICAgICByZXR1cm47XG4gICAgICAgIH1cblxuICAgICAgICBjb25zb2xlSGFuZGxlcihhcmdzLCBsZXZlbCwgaGFuZGxlZCk7XG4gICAgICB9KTtcbiAgICB9LFxuICB9O1xufSkgO1xuXG4vKipcbiAqIFNlbmQgQ29uc29sZSBBUEkgY2FsbHMgYXMgU2VudHJ5IEV2ZW50cy5cbiAqL1xuY29uc3QgY2FwdHVyZUNvbnNvbGVJbnRlZ3JhdGlvbiA9IGludGVncmF0aW9uLmRlZmluZUludGVncmF0aW9uKF9jYXB0dXJlQ29uc29sZUludGVncmF0aW9uKTtcblxuZnVuY3Rpb24gY29uc29sZUhhbmRsZXIoYXJncywgbGV2ZWwsIGhhbmRsZWQpIHtcbiAgY29uc3QgY2FwdHVyZUNvbnRleHQgPSB7XG4gICAgbGV2ZWw6IHNldmVyaXR5LnNldmVyaXR5TGV2ZWxGcm9tU3RyaW5nKGxldmVsKSxcbiAgICBleHRyYToge1xuICAgICAgYXJndW1lbnRzOiBhcmdzLFxuICAgIH0sXG4gIH07XG5cbiAgY3VycmVudFNjb3Blcy53aXRoU2NvcGUoc2NvcGUgPT4ge1xuICAgIHNjb3BlLmFkZEV2ZW50UHJvY2Vzc29yKGV2ZW50ID0+IHtcbiAgICAgIGV2ZW50LmxvZ2dlciA9ICdjb25zb2xlJztcblxuICAgICAgbWlzYy5hZGRFeGNlcHRpb25NZWNoYW5pc20oZXZlbnQsIHtcbiAgICAgICAgaGFuZGxlZCxcbiAgICAgICAgdHlwZTogJ2NvbnNvbGUnLFxuICAgICAgfSk7XG5cbiAgICAgIHJldHVybiBldmVudDtcbiAgICB9KTtcblxuICAgIGlmIChsZXZlbCA9PT0gJ2Fzc2VydCcpIHtcbiAgICAgIGlmICghYXJnc1swXSkge1xuICAgICAgICBjb25zdCBtZXNzYWdlID0gYEFzc2VydGlvbiBmYWlsZWQ6ICR7c3RyaW5nLnNhZmVKb2luKGFyZ3Muc2xpY2UoMSksICcgJykgfHwgJ2NvbnNvbGUuYXNzZXJ0J31gO1xuICAgICAgICBzY29wZS5zZXRFeHRyYSgnYXJndW1lbnRzJywgYXJncy5zbGljZSgxKSk7XG4gICAgICAgIGV4cG9ydHMkMS5jYXB0dXJlTWVzc2FnZShtZXNzYWdlLCBjYXB0dXJlQ29udGV4dCk7XG4gICAgICB9XG4gICAgICByZXR1cm47XG4gICAgfVxuXG4gICAgY29uc3QgZXJyb3IgPSBhcmdzLmZpbmQoYXJnID0+IGFyZyBpbnN0YW5jZW9mIEVycm9yKTtcbiAgICBpZiAoZXJyb3IpIHtcbiAgICAgIGV4cG9ydHMkMS5jYXB0dXJlRXhjZXB0aW9uKGVycm9yLCBjYXB0dXJlQ29udGV4dCk7XG4gICAgICByZXR1cm47XG4gICAgfVxuXG4gICAgY29uc3QgbWVzc2FnZSA9IHN0cmluZy5zYWZlSm9pbihhcmdzLCAnICcpO1xuICAgIGV4cG9ydHMkMS5jYXB0dXJlTWVzc2FnZShtZXNzYWdlLCBjYXB0dXJlQ29udGV4dCk7XG4gIH0pO1xufVxuXG5leHBvcnRzLmNhcHR1cmVDb25zb2xlSW50ZWdyYXRpb24gPSBjYXB0dXJlQ29uc29sZUludGVncmF0aW9uO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9Y2FwdHVyZWNvbnNvbGUuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/captureconsole.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/console.js":
/*!************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/console.js ***!
  \************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst breadcrumbs = __webpack_require__(/*! ../breadcrumbs.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/breadcrumbs.js\");\nconst currentScopes = __webpack_require__(/*! ../currentScopes.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst console = __webpack_require__(/*! ../instrument/console.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/console.js\");\nconst integration = __webpack_require__(/*! ../integration.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integration.js\");\nconst debugLogger = __webpack_require__(/*! ../utils/debug-logger.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst severity = __webpack_require__(/*! ../utils/severity.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/severity.js\");\nconst string = __webpack_require__(/*! ../utils/string.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/string.js\");\nconst worldwide = __webpack_require__(/*! ../utils/worldwide.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/worldwide.js\");\n\nconst INTEGRATION_NAME = 'Console';\n\n/**\n * Captures calls to the `console` API as breadcrumbs in Sentry.\n *\n * By default the integration instruments `console.debug`, `console.info`, `console.warn`, `console.error`,\n * `console.log`, `console.trace`, and `console.assert`. You can use the `levels` option to customize which\n * levels are captured.\n *\n * @example\n *\n * ```js\n * Sentry.init({\n *   integrations: [Sentry.consoleIntegration({ levels: ['error', 'warn'] })],\n * });\n * ```\n */\nconst consoleIntegration = integration.defineIntegration((options = {}) => {\n  const levels = new Set(options.levels || debugLogger.CONSOLE_LEVELS);\n\n  return {\n    name: INTEGRATION_NAME,\n    setup(client) {\n      console.addConsoleInstrumentationHandler(({ args, level }) => {\n        if (currentScopes.getClient() !== client || !levels.has(level)) {\n          return;\n        }\n\n        addConsoleBreadcrumb(level, args);\n      });\n    },\n  };\n});\n\n/**\n * Capture a console breadcrumb.\n *\n * Exported just for tests.\n */\nfunction addConsoleBreadcrumb(level, args) {\n  const breadcrumb = {\n    category: 'console',\n    data: {\n      arguments: args,\n      logger: 'console',\n    },\n    level: severity.severityLevelFromString(level),\n    message: formatConsoleArgs(args),\n  };\n\n  if (level === 'assert') {\n    if (args[0] === false) {\n      const assertionArgs = args.slice(1);\n      breadcrumb.message =\n        assertionArgs.length > 0 ? `Assertion failed: ${formatConsoleArgs(assertionArgs)}` : 'Assertion failed';\n      breadcrumb.data.arguments = assertionArgs;\n    } else {\n      // Don't capture a breadcrumb for passed assertions\n      return;\n    }\n  }\n\n  breadcrumbs.addBreadcrumb(breadcrumb, {\n    input: args,\n    level,\n  });\n}\n\nfunction formatConsoleArgs(values) {\n  return 'util' in worldwide.GLOBAL_OBJ && typeof (worldwide.GLOBAL_OBJ ).util.format === 'function'\n    ? (worldwide.GLOBAL_OBJ ).util.format(...values)\n    : string.safeJoin(values, ' ');\n}\n\nexports.addConsoleBreadcrumb = addConsoleBreadcrumb;\nexports.consoleIntegration = consoleIntegration;\n//# sourceMappingURL=console.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvaW50ZWdyYXRpb25zL2NvbnNvbGUuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsb0JBQW9CLG1CQUFPLENBQUMsbUlBQW1CO0FBQy9DLHNCQUFzQixtQkFBTyxDQUFDLHVJQUFxQjtBQUNuRCxnQkFBZ0IsbUJBQU8sQ0FBQyxpSkFBMEI7QUFDbEQsb0JBQW9CLG1CQUFPLENBQUMsbUlBQW1CO0FBQy9DLG9CQUFvQixtQkFBTyxDQUFDLGlKQUEwQjtBQUN0RCxpQkFBaUIsbUJBQU8sQ0FBQyx5SUFBc0I7QUFDL0MsZUFBZSxtQkFBTyxDQUFDLHFJQUFvQjtBQUMzQyxrQkFBa0IsbUJBQU8sQ0FBQywySUFBdUI7O0FBRWpEOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxnREFBZ0QsMkJBQTJCO0FBQzNFLElBQUk7QUFDSjtBQUNBO0FBQ0Esc0VBQXNFO0FBQ3RFOztBQUVBO0FBQ0E7QUFDQTtBQUNBLGtEQUFrRCxhQUFhO0FBQy9EO0FBQ0E7QUFDQTs7QUFFQTtBQUNBLE9BQU87QUFDUCxLQUFLO0FBQ0w7QUFDQSxDQUFDOztBQUVEO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxLQUFLO0FBQ0w7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0Esd0RBQXdELGlDQUFpQztBQUN6RjtBQUNBLE1BQU07QUFDTjtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQSxHQUFHO0FBQ0g7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSw0QkFBNEI7QUFDNUIsMEJBQTBCO0FBQzFCIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvaW50ZWdyYXRpb25zL2NvbnNvbGUuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGJyZWFkY3J1bWJzID0gcmVxdWlyZSgnLi4vYnJlYWRjcnVtYnMuanMnKTtcbmNvbnN0IGN1cnJlbnRTY29wZXMgPSByZXF1aXJlKCcuLi9jdXJyZW50U2NvcGVzLmpzJyk7XG5jb25zdCBjb25zb2xlID0gcmVxdWlyZSgnLi4vaW5zdHJ1bWVudC9jb25zb2xlLmpzJyk7XG5jb25zdCBpbnRlZ3JhdGlvbiA9IHJlcXVpcmUoJy4uL2ludGVncmF0aW9uLmpzJyk7XG5jb25zdCBkZWJ1Z0xvZ2dlciA9IHJlcXVpcmUoJy4uL3V0aWxzL2RlYnVnLWxvZ2dlci5qcycpO1xuY29uc3Qgc2V2ZXJpdHkgPSByZXF1aXJlKCcuLi91dGlscy9zZXZlcml0eS5qcycpO1xuY29uc3Qgc3RyaW5nID0gcmVxdWlyZSgnLi4vdXRpbHMvc3RyaW5nLmpzJyk7XG5jb25zdCB3b3JsZHdpZGUgPSByZXF1aXJlKCcuLi91dGlscy93b3JsZHdpZGUuanMnKTtcblxuY29uc3QgSU5URUdSQVRJT05fTkFNRSA9ICdDb25zb2xlJztcblxuLyoqXG4gKiBDYXB0dXJlcyBjYWxscyB0byB0aGUgYGNvbnNvbGVgIEFQSSBhcyBicmVhZGNydW1icyBpbiBTZW50cnkuXG4gKlxuICogQnkgZGVmYXVsdCB0aGUgaW50ZWdyYXRpb24gaW5zdHJ1bWVudHMgYGNvbnNvbGUuZGVidWdgLCBgY29uc29sZS5pbmZvYCwgYGNvbnNvbGUud2FybmAsIGBjb25zb2xlLmVycm9yYCxcbiAqIGBjb25zb2xlLmxvZ2AsIGBjb25zb2xlLnRyYWNlYCwgYW5kIGBjb25zb2xlLmFzc2VydGAuIFlvdSBjYW4gdXNlIHRoZSBgbGV2ZWxzYCBvcHRpb24gdG8gY3VzdG9taXplIHdoaWNoXG4gKiBsZXZlbHMgYXJlIGNhcHR1cmVkLlxuICpcbiAqIEBleGFtcGxlXG4gKlxuICogYGBganNcbiAqIFNlbnRyeS5pbml0KHtcbiAqICAgaW50ZWdyYXRpb25zOiBbU2VudHJ5LmNvbnNvbGVJbnRlZ3JhdGlvbih7IGxldmVsczogWydlcnJvcicsICd3YXJuJ10gfSldLFxuICogfSk7XG4gKiBgYGBcbiAqL1xuY29uc3QgY29uc29sZUludGVncmF0aW9uID0gaW50ZWdyYXRpb24uZGVmaW5lSW50ZWdyYXRpb24oKG9wdGlvbnMgPSB7fSkgPT4ge1xuICBjb25zdCBsZXZlbHMgPSBuZXcgU2V0KG9wdGlvbnMubGV2ZWxzIHx8IGRlYnVnTG9nZ2VyLkNPTlNPTEVfTEVWRUxTKTtcblxuICByZXR1cm4ge1xuICAgIG5hbWU6IElOVEVHUkFUSU9OX05BTUUsXG4gICAgc2V0dXAoY2xpZW50KSB7XG4gICAgICBjb25zb2xlLmFkZENvbnNvbGVJbnN0cnVtZW50YXRpb25IYW5kbGVyKCh7IGFyZ3MsIGxldmVsIH0pID0+IHtcbiAgICAgICAgaWYgKGN1cnJlbnRTY29wZXMuZ2V0Q2xpZW50KCkgIT09IGNsaWVudCB8fCAhbGV2ZWxzLmhhcyhsZXZlbCkpIHtcbiAgICAgICAgICByZXR1cm47XG4gICAgICAgIH1cblxuICAgICAgICBhZGRDb25zb2xlQnJlYWRjcnVtYihsZXZlbCwgYXJncyk7XG4gICAgICB9KTtcbiAgICB9LFxuICB9O1xufSk7XG5cbi8qKlxuICogQ2FwdHVyZSBhIGNvbnNvbGUgYnJlYWRjcnVtYi5cbiAqXG4gKiBFeHBvcnRlZCBqdXN0IGZvciB0ZXN0cy5cbiAqL1xuZnVuY3Rpb24gYWRkQ29uc29sZUJyZWFkY3J1bWIobGV2ZWwsIGFyZ3MpIHtcbiAgY29uc3QgYnJlYWRjcnVtYiA9IHtcbiAgICBjYXRlZ29yeTogJ2NvbnNvbGUnLFxuICAgIGRhdGE6IHtcbiAgICAgIGFyZ3VtZW50czogYXJncyxcbiAgICAgIGxvZ2dlcjogJ2NvbnNvbGUnLFxuICAgIH0sXG4gICAgbGV2ZWw6IHNldmVyaXR5LnNldmVyaXR5TGV2ZWxGcm9tU3RyaW5nKGxldmVsKSxcbiAgICBtZXNzYWdlOiBmb3JtYXRDb25zb2xlQXJncyhhcmdzKSxcbiAgfTtcblxuICBpZiAobGV2ZWwgPT09ICdhc3NlcnQnKSB7XG4gICAgaWYgKGFyZ3NbMF0gPT09IGZhbHNlKSB7XG4gICAgICBjb25zdCBhc3NlcnRpb25BcmdzID0gYXJncy5zbGljZSgxKTtcbiAgICAgIGJyZWFkY3J1bWIubWVzc2FnZSA9XG4gICAgICAgIGFzc2VydGlvbkFyZ3MubGVuZ3RoID4gMCA/IGBBc3NlcnRpb24gZmFpbGVkOiAke2Zvcm1hdENvbnNvbGVBcmdzKGFzc2VydGlvbkFyZ3MpfWAgOiAnQXNzZXJ0aW9uIGZhaWxlZCc7XG4gICAgICBicmVhZGNydW1iLmRhdGEuYXJndW1lbnRzID0gYXNzZXJ0aW9uQXJncztcbiAgICB9IGVsc2Uge1xuICAgICAgLy8gRG9uJ3QgY2FwdHVyZSBhIGJyZWFkY3J1bWIgZm9yIHBhc3NlZCBhc3NlcnRpb25zXG4gICAgICByZXR1cm47XG4gICAgfVxuICB9XG5cbiAgYnJlYWRjcnVtYnMuYWRkQnJlYWRjcnVtYihicmVhZGNydW1iLCB7XG4gICAgaW5wdXQ6IGFyZ3MsXG4gICAgbGV2ZWwsXG4gIH0pO1xufVxuXG5mdW5jdGlvbiBmb3JtYXRDb25zb2xlQXJncyh2YWx1ZXMpIHtcbiAgcmV0dXJuICd1dGlsJyBpbiB3b3JsZHdpZGUuR0xPQkFMX09CSiAmJiB0eXBlb2YgKHdvcmxkd2lkZS5HTE9CQUxfT0JKICkudXRpbC5mb3JtYXQgPT09ICdmdW5jdGlvbidcbiAgICA/ICh3b3JsZHdpZGUuR0xPQkFMX09CSiApLnV0aWwuZm9ybWF0KC4uLnZhbHVlcylcbiAgICA6IHN0cmluZy5zYWZlSm9pbih2YWx1ZXMsICcgJyk7XG59XG5cbmV4cG9ydHMuYWRkQ29uc29sZUJyZWFkY3J1bWIgPSBhZGRDb25zb2xlQnJlYWRjcnVtYjtcbmV4cG9ydHMuY29uc29sZUludGVncmF0aW9uID0gY29uc29sZUludGVncmF0aW9uO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9Y29uc29sZS5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/console.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/dedupe.js":
/*!***********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/dedupe.js ***!
  \***********************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst debugBuild = __webpack_require__(/*! ../debug-build.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst integration = __webpack_require__(/*! ../integration.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integration.js\");\nconst debugLogger = __webpack_require__(/*! ../utils/debug-logger.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst stacktrace = __webpack_require__(/*! ../utils/stacktrace.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/stacktrace.js\");\n\nconst INTEGRATION_NAME = 'Dedupe';\n\nconst _dedupeIntegration = (() => {\n  let previousEvent;\n\n  return {\n    name: INTEGRATION_NAME,\n    processEvent(currentEvent) {\n      // We want to ignore any non-error type events, e.g. transactions or replays\n      // These should never be deduped, and also not be compared against as _previousEvent.\n      if (currentEvent.type) {\n        return currentEvent;\n      }\n\n      // Juuust in case something goes wrong\n      try {\n        if (_shouldDropEvent(currentEvent, previousEvent)) {\n          debugBuild.DEBUG_BUILD && debugLogger.debug.warn('Event dropped due to being a duplicate of previously captured event.');\n          return null;\n        }\n      } catch {} // eslint-disable-line no-empty\n\n      return (previousEvent = currentEvent);\n    },\n  };\n}) ;\n\n/**\n * Deduplication filter.\n */\nconst dedupeIntegration = integration.defineIntegration(_dedupeIntegration);\n\n/** only exported for tests. */\nfunction _shouldDropEvent(currentEvent, previousEvent) {\n  if (!previousEvent) {\n    return false;\n  }\n\n  if (_isSameMessageEvent(currentEvent, previousEvent)) {\n    return true;\n  }\n\n  if (_isSameExceptionEvent(currentEvent, previousEvent)) {\n    return true;\n  }\n\n  return false;\n}\n\nfunction _isSameMessageEvent(currentEvent, previousEvent) {\n  const currentMessage = currentEvent.message;\n  const previousMessage = previousEvent.message;\n\n  // If neither event has a message property, they were both exceptions, so bail out\n  if (!currentMessage && !previousMessage) {\n    return false;\n  }\n\n  // If only one event has a stacktrace, but not the other one, they are not the same\n  if ((currentMessage && !previousMessage) || (!currentMessage && previousMessage)) {\n    return false;\n  }\n\n  if (currentMessage !== previousMessage) {\n    return false;\n  }\n\n  if (!_isSameFingerprint(currentEvent, previousEvent)) {\n    return false;\n  }\n\n  if (!_isSameStacktrace(currentEvent, previousEvent)) {\n    return false;\n  }\n\n  return true;\n}\n\nfunction _isSameExceptionEvent(currentEvent, previousEvent) {\n  const previousException = _getExceptionFromEvent(previousEvent);\n  const currentException = _getExceptionFromEvent(currentEvent);\n\n  if (!previousException || !currentException) {\n    return false;\n  }\n\n  if (previousException.type !== currentException.type || previousException.value !== currentException.value) {\n    return false;\n  }\n\n  if (!_isSameFingerprint(currentEvent, previousEvent)) {\n    return false;\n  }\n\n  if (!_isSameStacktrace(currentEvent, previousEvent)) {\n    return false;\n  }\n\n  return true;\n}\n\nfunction _isSameStacktrace(currentEvent, previousEvent) {\n  let currentFrames = stacktrace.getFramesFromEvent(currentEvent);\n  let previousFrames = stacktrace.getFramesFromEvent(previousEvent);\n\n  // If neither event has a stacktrace, they are assumed to be the same\n  if (!currentFrames && !previousFrames) {\n    return true;\n  }\n\n  // If only one event has a stacktrace, but not the other one, they are not the same\n  if ((currentFrames && !previousFrames) || (!currentFrames && previousFrames)) {\n    return false;\n  }\n\n  currentFrames = currentFrames ;\n  previousFrames = previousFrames ;\n\n  // If number of frames differ, they are not the same\n  if (previousFrames.length !== currentFrames.length) {\n    return false;\n  }\n\n  // Otherwise, compare the two\n  for (let i = 0; i < previousFrames.length; i++) {\n    // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n    const frameA = previousFrames[i];\n    // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n    const frameB = currentFrames[i];\n\n    if (\n      frameA.filename !== frameB.filename ||\n      frameA.lineno !== frameB.lineno ||\n      frameA.colno !== frameB.colno ||\n      frameA.function !== frameB.function\n    ) {\n      return false;\n    }\n  }\n\n  return true;\n}\n\nfunction _isSameFingerprint(currentEvent, previousEvent) {\n  let currentFingerprint = currentEvent.fingerprint;\n  let previousFingerprint = previousEvent.fingerprint;\n\n  // If neither event has a fingerprint, they are assumed to be the same\n  if (!currentFingerprint && !previousFingerprint) {\n    return true;\n  }\n\n  // If only one event has a fingerprint, but not the other one, they are not the same\n  if ((currentFingerprint && !previousFingerprint) || (!currentFingerprint && previousFingerprint)) {\n    return false;\n  }\n\n  currentFingerprint = currentFingerprint ;\n  previousFingerprint = previousFingerprint ;\n\n  // Otherwise, compare the two\n  try {\n    return !!(currentFingerprint.join('') === previousFingerprint.join(''));\n  } catch {\n    return false;\n  }\n}\n\nfunction _getExceptionFromEvent(event) {\n  return event.exception?.values?.[0];\n}\n\nexports._shouldDropEvent = _shouldDropEvent;\nexports.dedupeIntegration = dedupeIntegration;\n//# sourceMappingURL=dedupe.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvaW50ZWdyYXRpb25zL2RlZHVwZS5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxtQkFBbUIsbUJBQU8sQ0FBQyxtSUFBbUI7QUFDOUMsb0JBQW9CLG1CQUFPLENBQUMsbUlBQW1CO0FBQy9DLG9CQUFvQixtQkFBTyxDQUFDLGlKQUEwQjtBQUN0RCxtQkFBbUIsbUJBQU8sQ0FBQyw2SUFBd0I7O0FBRW5EOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxRQUFRLFNBQVM7O0FBRWpCO0FBQ0EsS0FBSztBQUNMO0FBQ0EsQ0FBQzs7QUFFRDtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQSxrQkFBa0IsMkJBQTJCO0FBQzdDO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBLElBQUk7QUFDSjtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBLHdCQUF3QjtBQUN4Qix5QkFBeUI7QUFDekIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvZGVkdXBlLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBkZWJ1Z0J1aWxkID0gcmVxdWlyZSgnLi4vZGVidWctYnVpbGQuanMnKTtcbmNvbnN0IGludGVncmF0aW9uID0gcmVxdWlyZSgnLi4vaW50ZWdyYXRpb24uanMnKTtcbmNvbnN0IGRlYnVnTG9nZ2VyID0gcmVxdWlyZSgnLi4vdXRpbHMvZGVidWctbG9nZ2VyLmpzJyk7XG5jb25zdCBzdGFja3RyYWNlID0gcmVxdWlyZSgnLi4vdXRpbHMvc3RhY2t0cmFjZS5qcycpO1xuXG5jb25zdCBJTlRFR1JBVElPTl9OQU1FID0gJ0RlZHVwZSc7XG5cbmNvbnN0IF9kZWR1cGVJbnRlZ3JhdGlvbiA9ICgoKSA9PiB7XG4gIGxldCBwcmV2aW91c0V2ZW50O1xuXG4gIHJldHVybiB7XG4gICAgbmFtZTogSU5URUdSQVRJT05fTkFNRSxcbiAgICBwcm9jZXNzRXZlbnQoY3VycmVudEV2ZW50KSB7XG4gICAgICAvLyBXZSB3YW50IHRvIGlnbm9yZSBhbnkgbm9uLWVycm9yIHR5cGUgZXZlbnRzLCBlLmcuIHRyYW5zYWN0aW9ucyBvciByZXBsYXlzXG4gICAgICAvLyBUaGVzZSBzaG91bGQgbmV2ZXIgYmUgZGVkdXBlZCwgYW5kIGFsc28gbm90IGJlIGNvbXBhcmVkIGFnYWluc3QgYXMgX3ByZXZpb3VzRXZlbnQuXG4gICAgICBpZiAoY3VycmVudEV2ZW50LnR5cGUpIHtcbiAgICAgICAgcmV0dXJuIGN1cnJlbnRFdmVudDtcbiAgICAgIH1cblxuICAgICAgLy8gSnV1dXN0IGluIGNhc2Ugc29tZXRoaW5nIGdvZXMgd3JvbmdcbiAgICAgIHRyeSB7XG4gICAgICAgIGlmIChfc2hvdWxkRHJvcEV2ZW50KGN1cnJlbnRFdmVudCwgcHJldmlvdXNFdmVudCkpIHtcbiAgICAgICAgICBkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEICYmIGRlYnVnTG9nZ2VyLmRlYnVnLndhcm4oJ0V2ZW50IGRyb3BwZWQgZHVlIHRvIGJlaW5nIGEgZHVwbGljYXRlIG9mIHByZXZpb3VzbHkgY2FwdHVyZWQgZXZlbnQuJyk7XG4gICAgICAgICAgcmV0dXJuIG51bGw7XG4gICAgICAgIH1cbiAgICAgIH0gY2F0Y2gge30gLy8gZXNsaW50LWRpc2FibGUtbGluZSBuby1lbXB0eVxuXG4gICAgICByZXR1cm4gKHByZXZpb3VzRXZlbnQgPSBjdXJyZW50RXZlbnQpO1xuICAgIH0sXG4gIH07XG59KSA7XG5cbi8qKlxuICogRGVkdXBsaWNhdGlvbiBmaWx0ZXIuXG4gKi9cbmNvbnN0IGRlZHVwZUludGVncmF0aW9uID0gaW50ZWdyYXRpb24uZGVmaW5lSW50ZWdyYXRpb24oX2RlZHVwZUludGVncmF0aW9uKTtcblxuLyoqIG9ubHkgZXhwb3J0ZWQgZm9yIHRlc3RzLiAqL1xuZnVuY3Rpb24gX3Nob3VsZERyb3BFdmVudChjdXJyZW50RXZlbnQsIHByZXZpb3VzRXZlbnQpIHtcbiAgaWYgKCFwcmV2aW91c0V2ZW50KSB7XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG5cbiAgaWYgKF9pc1NhbWVNZXNzYWdlRXZlbnQoY3VycmVudEV2ZW50LCBwcmV2aW91c0V2ZW50KSkge1xuICAgIHJldHVybiB0cnVlO1xuICB9XG5cbiAgaWYgKF9pc1NhbWVFeGNlcHRpb25FdmVudChjdXJyZW50RXZlbnQsIHByZXZpb3VzRXZlbnQpKSB7XG4gICAgcmV0dXJuIHRydWU7XG4gIH1cblxuICByZXR1cm4gZmFsc2U7XG59XG5cbmZ1bmN0aW9uIF9pc1NhbWVNZXNzYWdlRXZlbnQoY3VycmVudEV2ZW50LCBwcmV2aW91c0V2ZW50KSB7XG4gIGNvbnN0IGN1cnJlbnRNZXNzYWdlID0gY3VycmVudEV2ZW50Lm1lc3NhZ2U7XG4gIGNvbnN0IHByZXZpb3VzTWVzc2FnZSA9IHByZXZpb3VzRXZlbnQubWVzc2FnZTtcblxuICAvLyBJZiBuZWl0aGVyIGV2ZW50IGhhcyBhIG1lc3NhZ2UgcHJvcGVydHksIHRoZXkgd2VyZSBib3RoIGV4Y2VwdGlvbnMsIHNvIGJhaWwgb3V0XG4gIGlmICghY3VycmVudE1lc3NhZ2UgJiYgIXByZXZpb3VzTWVzc2FnZSkge1xuICAgIHJldHVybiBmYWxzZTtcbiAgfVxuXG4gIC8vIElmIG9ubHkgb25lIGV2ZW50IGhhcyBhIHN0YWNrdHJhY2UsIGJ1dCBub3QgdGhlIG90aGVyIG9uZSwgdGhleSBhcmUgbm90IHRoZSBzYW1lXG4gIGlmICgoY3VycmVudE1lc3NhZ2UgJiYgIXByZXZpb3VzTWVzc2FnZSkgfHwgKCFjdXJyZW50TWVzc2FnZSAmJiBwcmV2aW91c01lc3NhZ2UpKSB7XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG5cbiAgaWYgKGN1cnJlbnRNZXNzYWdlICE9PSBwcmV2aW91c01lc3NhZ2UpIHtcbiAgICByZXR1cm4gZmFsc2U7XG4gIH1cblxuICBpZiAoIV9pc1NhbWVGaW5nZXJwcmludChjdXJyZW50RXZlbnQsIHByZXZpb3VzRXZlbnQpKSB7XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG5cbiAgaWYgKCFfaXNTYW1lU3RhY2t0cmFjZShjdXJyZW50RXZlbnQsIHByZXZpb3VzRXZlbnQpKSB7XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG5cbiAgcmV0dXJuIHRydWU7XG59XG5cbmZ1bmN0aW9uIF9pc1NhbWVFeGNlcHRpb25FdmVudChjdXJyZW50RXZlbnQsIHByZXZpb3VzRXZlbnQpIHtcbiAgY29uc3QgcHJldmlvdXNFeGNlcHRpb24gPSBfZ2V0RXhjZXB0aW9uRnJvbUV2ZW50KHByZXZpb3VzRXZlbnQpO1xuICBjb25zdCBjdXJyZW50RXhjZXB0aW9uID0gX2dldEV4Y2VwdGlvbkZyb21FdmVudChjdXJyZW50RXZlbnQpO1xuXG4gIGlmICghcHJldmlvdXNFeGNlcHRpb24gfHwgIWN1cnJlbnRFeGNlcHRpb24pIHtcbiAgICByZXR1cm4gZmFsc2U7XG4gIH1cblxuICBpZiAocHJldmlvdXNFeGNlcHRpb24udHlwZSAhPT0gY3VycmVudEV4Y2VwdGlvbi50eXBlIHx8IHByZXZpb3VzRXhjZXB0aW9uLnZhbHVlICE9PSBjdXJyZW50RXhjZXB0aW9uLnZhbHVlKSB7XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG5cbiAgaWYgKCFfaXNTYW1lRmluZ2VycHJpbnQoY3VycmVudEV2ZW50LCBwcmV2aW91c0V2ZW50KSkge1xuICAgIHJldHVybiBmYWxzZTtcbiAgfVxuXG4gIGlmICghX2lzU2FtZVN0YWNrdHJhY2UoY3VycmVudEV2ZW50LCBwcmV2aW91c0V2ZW50KSkge1xuICAgIHJldHVybiBmYWxzZTtcbiAgfVxuXG4gIHJldHVybiB0cnVlO1xufVxuXG5mdW5jdGlvbiBfaXNTYW1lU3RhY2t0cmFjZShjdXJyZW50RXZlbnQsIHByZXZpb3VzRXZlbnQpIHtcbiAgbGV0IGN1cnJlbnRGcmFtZXMgPSBzdGFja3RyYWNlLmdldEZyYW1lc0Zyb21FdmVudChjdXJyZW50RXZlbnQpO1xuICBsZXQgcHJldmlvdXNGcmFtZXMgPSBzdGFja3RyYWNlLmdldEZyYW1lc0Zyb21FdmVudChwcmV2aW91c0V2ZW50KTtcblxuICAvLyBJZiBuZWl0aGVyIGV2ZW50IGhhcyBhIHN0YWNrdHJhY2UsIHRoZXkgYXJlIGFzc3VtZWQgdG8gYmUgdGhlIHNhbWVcbiAgaWYgKCFjdXJyZW50RnJhbWVzICYmICFwcmV2aW91c0ZyYW1lcykge1xuICAgIHJldHVybiB0cnVlO1xuICB9XG5cbiAgLy8gSWYgb25seSBvbmUgZXZlbnQgaGFzIGEgc3RhY2t0cmFjZSwgYnV0IG5vdCB0aGUgb3RoZXIgb25lLCB0aGV5IGFyZSBub3QgdGhlIHNhbWVcbiAgaWYgKChjdXJyZW50RnJhbWVzICYmICFwcmV2aW91c0ZyYW1lcykgfHwgKCFjdXJyZW50RnJhbWVzICYmIHByZXZpb3VzRnJhbWVzKSkge1xuICAgIHJldHVybiBmYWxzZTtcbiAgfVxuXG4gIGN1cnJlbnRGcmFtZXMgPSBjdXJyZW50RnJhbWVzIDtcbiAgcHJldmlvdXNGcmFtZXMgPSBwcmV2aW91c0ZyYW1lcyA7XG5cbiAgLy8gSWYgbnVtYmVyIG9mIGZyYW1lcyBkaWZmZXIsIHRoZXkgYXJlIG5vdCB0aGUgc2FtZVxuICBpZiAocHJldmlvdXNGcmFtZXMubGVuZ3RoICE9PSBjdXJyZW50RnJhbWVzLmxlbmd0aCkge1xuICAgIHJldHVybiBmYWxzZTtcbiAgfVxuXG4gIC8vIE90aGVyd2lzZSwgY29tcGFyZSB0aGUgdHdvXG4gIGZvciAobGV0IGkgPSAwOyBpIDwgcHJldmlvdXNGcmFtZXMubGVuZ3RoOyBpKyspIHtcbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25vLW5vbi1udWxsLWFzc2VydGlvblxuICAgIGNvbnN0IGZyYW1lQSA9IHByZXZpb3VzRnJhbWVzW2ldO1xuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tbm9uLW51bGwtYXNzZXJ0aW9uXG4gICAgY29uc3QgZnJhbWVCID0gY3VycmVudEZyYW1lc1tpXTtcblxuICAgIGlmIChcbiAgICAgIGZyYW1lQS5maWxlbmFtZSAhPT0gZnJhbWVCLmZpbGVuYW1lIHx8XG4gICAgICBmcmFtZUEubGluZW5vICE9PSBmcmFtZUIubGluZW5vIHx8XG4gICAgICBmcmFtZUEuY29sbm8gIT09IGZyYW1lQi5jb2xubyB8fFxuICAgICAgZnJhbWVBLmZ1bmN0aW9uICE9PSBmcmFtZUIuZnVuY3Rpb25cbiAgICApIHtcbiAgICAgIHJldHVybiBmYWxzZTtcbiAgICB9XG4gIH1cblxuICByZXR1cm4gdHJ1ZTtcbn1cblxuZnVuY3Rpb24gX2lzU2FtZUZpbmdlcnByaW50KGN1cnJlbnRFdmVudCwgcHJldmlvdXNFdmVudCkge1xuICBsZXQgY3VycmVudEZpbmdlcnByaW50ID0gY3VycmVudEV2ZW50LmZpbmdlcnByaW50O1xuICBsZXQgcHJldmlvdXNGaW5nZXJwcmludCA9IHByZXZpb3VzRXZlbnQuZmluZ2VycHJpbnQ7XG5cbiAgLy8gSWYgbmVpdGhlciBldmVudCBoYXMgYSBmaW5nZXJwcmludCwgdGhleSBhcmUgYXNzdW1lZCB0byBiZSB0aGUgc2FtZVxuICBpZiAoIWN1cnJlbnRGaW5nZXJwcmludCAmJiAhcHJldmlvdXNGaW5nZXJwcmludCkge1xuICAgIHJldHVybiB0cnVlO1xuICB9XG5cbiAgLy8gSWYgb25seSBvbmUgZXZlbnQgaGFzIGEgZmluZ2VycHJpbnQsIGJ1dCBub3QgdGhlIG90aGVyIG9uZSwgdGhleSBhcmUgbm90IHRoZSBzYW1lXG4gIGlmICgoY3VycmVudEZpbmdlcnByaW50ICYmICFwcmV2aW91c0ZpbmdlcnByaW50KSB8fCAoIWN1cnJlbnRGaW5nZXJwcmludCAmJiBwcmV2aW91c0ZpbmdlcnByaW50KSkge1xuICAgIHJldHVybiBmYWxzZTtcbiAgfVxuXG4gIGN1cnJlbnRGaW5nZXJwcmludCA9IGN1cnJlbnRGaW5nZXJwcmludCA7XG4gIHByZXZpb3VzRmluZ2VycHJpbnQgPSBwcmV2aW91c0ZpbmdlcnByaW50IDtcblxuICAvLyBPdGhlcndpc2UsIGNvbXBhcmUgdGhlIHR3b1xuICB0cnkge1xuICAgIHJldHVybiAhIShjdXJyZW50RmluZ2VycHJpbnQuam9pbignJykgPT09IHByZXZpb3VzRmluZ2VycHJpbnQuam9pbignJykpO1xuICB9IGNhdGNoIHtcbiAgICByZXR1cm4gZmFsc2U7XG4gIH1cbn1cblxuZnVuY3Rpb24gX2dldEV4Y2VwdGlvbkZyb21FdmVudChldmVudCkge1xuICByZXR1cm4gZXZlbnQuZXhjZXB0aW9uPy52YWx1ZXM/LlswXTtcbn1cblxuZXhwb3J0cy5fc2hvdWxkRHJvcEV2ZW50ID0gX3Nob3VsZERyb3BFdmVudDtcbmV4cG9ydHMuZGVkdXBlSW50ZWdyYXRpb24gPSBkZWR1cGVJbnRlZ3JhdGlvbjtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWRlZHVwZS5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/dedupe.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/eventFilters.js":
/*!*****************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/eventFilters.js ***!
  \*****************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst debugBuild = __webpack_require__(/*! ../debug-build.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst integration = __webpack_require__(/*! ../integration.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integration.js\");\nconst debugLogger = __webpack_require__(/*! ../utils/debug-logger.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst eventUtils = __webpack_require__(/*! ../utils/eventUtils.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/eventUtils.js\");\nconst misc = __webpack_require__(/*! ../utils/misc.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/misc.js\");\nconst string = __webpack_require__(/*! ../utils/string.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/string.js\");\n\n// \"Script error.\" is hard coded into browsers for errors that it can't read.\n// this is the result of a script being pulled in from an external domain and CORS.\nconst DEFAULT_IGNORE_ERRORS = [\n  /^Script error\\.?$/,\n  /^Javascript error: Script error\\.? on line 0$/,\n  /^ResizeObserver loop completed with undelivered notifications.$/, // The browser logs this when a ResizeObserver handler takes a bit longer. Usually this is not an actual issue though. It indicates slowness.\n  /^Cannot redefine property: googletag$/, // This is thrown when google tag manager is used in combination with an ad blocker\n  /^Can't find variable: gmo$/, // Error from Google Search App https://issuetracker.google.com/issues/396043331\n  /^undefined is not an object \\(evaluating 'a\\.[A-Z]'\\)$/, // Random error that happens but not actionable or noticeable to end-users.\n  'can\\'t redefine non-configurable property \"solana\"', // Probably a browser extension or custom browser (Brave) throwing this error\n  \"vv().getRestrictions is not a function. (In 'vv().getRestrictions(1,a)', 'vv().getRestrictions' is undefined)\", // Error thrown by GTM, seemingly not affecting end-users\n  \"Can't find variable: _AutofillCallbackHandler\", // Unactionable error in instagram webview https://developers.facebook.com/community/threads/320013549791141/\n  /^Non-Error promise rejection captured with value: Object Not Found Matching Id:\\d+, MethodName:simulateEvent, ParamCount:\\d+$/, // unactionable error from CEFSharp, a .NET library that embeds chromium in .NET apps\n  /^Java exception was raised during method invocation$/, // error from Facebook Mobile browser (https://github.com/getsentry/sentry-javascript/issues/15065)\n];\n\n/** Options for the EventFilters integration */\n\nconst INTEGRATION_NAME = 'EventFilters';\n\n/**\n * An integration that filters out events (errors and transactions) based on:\n *\n * - (Errors) A curated list of known low-value or irrelevant errors (see {@link DEFAULT_IGNORE_ERRORS})\n * - (Errors) A list of error messages or urls/filenames passed in via\n *   - Top level Sentry.init options (`ignoreErrors`, `denyUrls`, `allowUrls`)\n *   - The same options passed to the integration directly via @param options\n * - (Transactions/Spans) A list of root span (transaction) names passed in via\n *   - Top level Sentry.init option (`ignoreTransactions`)\n *   - The same option passed to the integration directly via @param options\n *\n * Events filtered by this integration will not be sent to Sentry.\n */\nconst eventFiltersIntegration = integration.defineIntegration((options = {}) => {\n  let mergedOptions;\n  return {\n    name: INTEGRATION_NAME,\n    setup(client) {\n      const clientOptions = client.getOptions();\n      mergedOptions = _mergeOptions(options, clientOptions);\n    },\n    processEvent(event, _hint, client) {\n      if (!mergedOptions) {\n        const clientOptions = client.getOptions();\n        mergedOptions = _mergeOptions(options, clientOptions);\n      }\n      return _shouldDropEvent(event, mergedOptions) ? null : event;\n    },\n  };\n});\n\n/**\n * An integration that filters out events (errors and transactions) based on:\n *\n * - (Errors) A curated list of known low-value or irrelevant errors (see {@link DEFAULT_IGNORE_ERRORS})\n * - (Errors) A list of error messages or urls/filenames passed in via\n *   - Top level Sentry.init options (`ignoreErrors`, `denyUrls`, `allowUrls`)\n *   - The same options passed to the integration directly via @param options\n * - (Transactions/Spans) A list of root span (transaction) names passed in via\n *   - Top level Sentry.init option (`ignoreTransactions`)\n *   - The same option passed to the integration directly via @param options\n *\n * Events filtered by this integration will not be sent to Sentry.\n *\n * @deprecated this integration was renamed and will be removed in a future major version.\n * Use `eventFiltersIntegration` instead.\n */\nconst inboundFiltersIntegration = integration.defineIntegration(((options = {}) => {\n  return {\n    ...eventFiltersIntegration(options),\n    name: 'InboundFilters',\n  };\n}) );\n\nfunction _mergeOptions(\n  internalOptions = {},\n  clientOptions = {},\n) {\n  return {\n    allowUrls: [...(internalOptions.allowUrls || []), ...(clientOptions.allowUrls || [])],\n    denyUrls: [...(internalOptions.denyUrls || []), ...(clientOptions.denyUrls || [])],\n    ignoreErrors: [\n      ...(internalOptions.ignoreErrors || []),\n      ...(clientOptions.ignoreErrors || []),\n      ...(internalOptions.disableErrorDefaults ? [] : DEFAULT_IGNORE_ERRORS),\n    ],\n    ignoreTransactions: [...(internalOptions.ignoreTransactions || []), ...(clientOptions.ignoreTransactions || [])],\n  };\n}\n\nfunction _shouldDropEvent(event, options) {\n  if (!event.type) {\n    // Filter errors\n    if (_isIgnoredError(event, options.ignoreErrors)) {\n      debugBuild.DEBUG_BUILD &&\n        debugLogger.debug.warn(\n          `Event dropped due to being matched by \\`ignoreErrors\\` option.\\nEvent: ${misc.getEventDescription(event)}`,\n        );\n      return true;\n    }\n    if (_isUselessError(event)) {\n      debugBuild.DEBUG_BUILD &&\n        debugLogger.debug.warn(\n          `Event dropped due to not having an error message, error type or stacktrace.\\nEvent: ${misc.getEventDescription(\n            event,\n          )}`,\n        );\n      return true;\n    }\n    if (_isDeniedUrl(event, options.denyUrls)) {\n      debugBuild.DEBUG_BUILD &&\n        debugLogger.debug.warn(\n          `Event dropped due to being matched by \\`denyUrls\\` option.\\nEvent: ${misc.getEventDescription(\n            event,\n          )}.\\nUrl: ${_getEventFilterUrl(event)}`,\n        );\n      return true;\n    }\n    if (!_isAllowedUrl(event, options.allowUrls)) {\n      debugBuild.DEBUG_BUILD &&\n        debugLogger.debug.warn(\n          `Event dropped due to not being matched by \\`allowUrls\\` option.\\nEvent: ${misc.getEventDescription(\n            event,\n          )}.\\nUrl: ${_getEventFilterUrl(event)}`,\n        );\n      return true;\n    }\n  } else if (event.type === 'transaction') {\n    // Filter transactions\n\n    if (_isIgnoredTransaction(event, options.ignoreTransactions)) {\n      debugBuild.DEBUG_BUILD &&\n        debugLogger.debug.warn(\n          `Event dropped due to being matched by \\`ignoreTransactions\\` option.\\nEvent: ${misc.getEventDescription(event)}`,\n        );\n      return true;\n    }\n  }\n  return false;\n}\n\nfunction _isIgnoredError(event, ignoreErrors) {\n  if (!ignoreErrors?.length) {\n    return false;\n  }\n\n  return eventUtils.getPossibleEventMessages(event).some(message => string.stringMatchesSomePattern(message, ignoreErrors));\n}\n\nfunction _isIgnoredTransaction(event, ignoreTransactions) {\n  if (!ignoreTransactions?.length) {\n    return false;\n  }\n\n  const name = event.transaction;\n  return name ? string.stringMatchesSomePattern(name, ignoreTransactions) : false;\n}\n\nfunction _isDeniedUrl(event, denyUrls) {\n  if (!denyUrls?.length) {\n    return false;\n  }\n  const url = _getEventFilterUrl(event);\n  return !url ? false : string.stringMatchesSomePattern(url, denyUrls);\n}\n\nfunction _isAllowedUrl(event, allowUrls) {\n  if (!allowUrls?.length) {\n    return true;\n  }\n  const url = _getEventFilterUrl(event);\n  return !url ? true : string.stringMatchesSomePattern(url, allowUrls);\n}\n\nfunction _getLastValidUrl(frames = []) {\n  for (let i = frames.length - 1; i >= 0; i--) {\n    const frame = frames[i];\n\n    if (frame && frame.filename !== '<anonymous>' && frame.filename !== '[native code]') {\n      return frame.filename || null;\n    }\n  }\n\n  return null;\n}\n\nfunction _getEventFilterUrl(event) {\n  try {\n    // If there are linked exceptions or exception aggregates we only want to match against the top frame of the \"root\" (the main exception)\n    // The root always comes last in linked exceptions\n    const rootException = [...(event.exception?.values ?? [])]\n      .reverse()\n      .find(value => value.mechanism?.parent_id === undefined && value.stacktrace?.frames?.length);\n    const frames = rootException?.stacktrace?.frames;\n    return frames ? _getLastValidUrl(frames) : null;\n  } catch {\n    debugBuild.DEBUG_BUILD && debugLogger.debug.error(`Cannot extract url for event ${misc.getEventDescription(event)}`);\n    return null;\n  }\n}\n\nfunction _isUselessError(event) {\n  // We only want to consider events for dropping that actually have recorded exception values.\n  if (!event.exception?.values?.length) {\n    return false;\n  }\n\n  return (\n    // No top-level message\n    !event.message &&\n    // There are no exception values that have a stacktrace, a non-generic-Error type or value\n    !event.exception.values.some(value => value.stacktrace || (value.type && value.type !== 'Error') || value.value)\n  );\n}\n\nexports.eventFiltersIntegration = eventFiltersIntegration;\nexports.inboundFiltersIntegration = inboundFiltersIntegration;\n//# sourceMappingURL=eventFilters.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvaW50ZWdyYXRpb25zL2V2ZW50RmlsdGVycy5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxtQkFBbUIsbUJBQU8sQ0FBQyxtSUFBbUI7QUFDOUMsb0JBQW9CLG1CQUFPLENBQUMsbUlBQW1CO0FBQy9DLG9CQUFvQixtQkFBTyxDQUFDLGlKQUEwQjtBQUN0RCxtQkFBbUIsbUJBQU8sQ0FBQyw2SUFBd0I7QUFDbkQsYUFBYSxtQkFBTyxDQUFDLGlJQUFrQjtBQUN2QyxlQUFlLG1CQUFPLENBQUMscUlBQW9COztBQUUzQztBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0EsMkVBQTJFLDRCQUE0QjtBQUN2RztBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSwyRUFBMkU7QUFDM0U7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsS0FBSztBQUNMO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEtBQUs7QUFDTDtBQUNBLENBQUM7O0FBRUQ7QUFDQTtBQUNBO0FBQ0EsMkVBQTJFLDRCQUE0QjtBQUN2RztBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSw4RUFBOEU7QUFDOUU7QUFDQTtBQUNBO0FBQ0E7QUFDQSxDQUFDOztBQUVEO0FBQ0Esc0JBQXNCO0FBQ3RCLG9CQUFvQjtBQUNwQjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0Esb0ZBQW9GLGdDQUFnQztBQUNwSDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxpR0FBaUc7QUFDakc7QUFDQSxZQUFZO0FBQ1o7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsZ0ZBQWdGO0FBQ2hGO0FBQ0EsWUFBWSxVQUFVLDBCQUEwQjtBQUNoRDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxxRkFBcUY7QUFDckY7QUFDQSxZQUFZLFVBQVUsMEJBQTBCO0FBQ2hEO0FBQ0E7QUFDQTtBQUNBLElBQUk7QUFDSjs7QUFFQTtBQUNBO0FBQ0E7QUFDQSwwRkFBMEYsZ0NBQWdDO0FBQzFIO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBLGtDQUFrQyxRQUFRO0FBQzFDOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsSUFBSTtBQUNKLHNGQUFzRixnQ0FBZ0M7QUFDdEg7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsK0JBQStCO0FBQy9CLGlDQUFpQztBQUNqQyIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL2ludGVncmF0aW9ucy9ldmVudEZpbHRlcnMuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGRlYnVnQnVpbGQgPSByZXF1aXJlKCcuLi9kZWJ1Zy1idWlsZC5qcycpO1xuY29uc3QgaW50ZWdyYXRpb24gPSByZXF1aXJlKCcuLi9pbnRlZ3JhdGlvbi5qcycpO1xuY29uc3QgZGVidWdMb2dnZXIgPSByZXF1aXJlKCcuLi91dGlscy9kZWJ1Zy1sb2dnZXIuanMnKTtcbmNvbnN0IGV2ZW50VXRpbHMgPSByZXF1aXJlKCcuLi91dGlscy9ldmVudFV0aWxzLmpzJyk7XG5jb25zdCBtaXNjID0gcmVxdWlyZSgnLi4vdXRpbHMvbWlzYy5qcycpO1xuY29uc3Qgc3RyaW5nID0gcmVxdWlyZSgnLi4vdXRpbHMvc3RyaW5nLmpzJyk7XG5cbi8vIFwiU2NyaXB0IGVycm9yLlwiIGlzIGhhcmQgY29kZWQgaW50byBicm93c2VycyBmb3IgZXJyb3JzIHRoYXQgaXQgY2FuJ3QgcmVhZC5cbi8vIHRoaXMgaXMgdGhlIHJlc3VsdCBvZiBhIHNjcmlwdCBiZWluZyBwdWxsZWQgaW4gZnJvbSBhbiBleHRlcm5hbCBkb21haW4gYW5kIENPUlMuXG5jb25zdCBERUZBVUxUX0lHTk9SRV9FUlJPUlMgPSBbXG4gIC9eU2NyaXB0IGVycm9yXFwuPyQvLFxuICAvXkphdmFzY3JpcHQgZXJyb3I6IFNjcmlwdCBlcnJvclxcLj8gb24gbGluZSAwJC8sXG4gIC9eUmVzaXplT2JzZXJ2ZXIgbG9vcCBjb21wbGV0ZWQgd2l0aCB1bmRlbGl2ZXJlZCBub3RpZmljYXRpb25zLiQvLCAvLyBUaGUgYnJvd3NlciBsb2dzIHRoaXMgd2hlbiBhIFJlc2l6ZU9ic2VydmVyIGhhbmRsZXIgdGFrZXMgYSBiaXQgbG9uZ2VyLiBVc3VhbGx5IHRoaXMgaXMgbm90IGFuIGFjdHVhbCBpc3N1ZSB0aG91Z2guIEl0IGluZGljYXRlcyBzbG93bmVzcy5cbiAgL15DYW5ub3QgcmVkZWZpbmUgcHJvcGVydHk6IGdvb2dsZXRhZyQvLCAvLyBUaGlzIGlzIHRocm93biB3aGVuIGdvb2dsZSB0YWcgbWFuYWdlciBpcyB1c2VkIGluIGNvbWJpbmF0aW9uIHdpdGggYW4gYWQgYmxvY2tlclxuICAvXkNhbid0IGZpbmQgdmFyaWFibGU6IGdtbyQvLCAvLyBFcnJvciBmcm9tIEdvb2dsZSBTZWFyY2ggQXBwIGh0dHBzOi8vaXNzdWV0cmFja2VyLmdvb2dsZS5jb20vaXNzdWVzLzM5NjA0MzMzMVxuICAvXnVuZGVmaW5lZCBpcyBub3QgYW4gb2JqZWN0IFxcKGV2YWx1YXRpbmcgJ2FcXC5bQS1aXSdcXCkkLywgLy8gUmFuZG9tIGVycm9yIHRoYXQgaGFwcGVucyBidXQgbm90IGFjdGlvbmFibGUgb3Igbm90aWNlYWJsZSB0byBlbmQtdXNlcnMuXG4gICdjYW5cXCd0IHJlZGVmaW5lIG5vbi1jb25maWd1cmFibGUgcHJvcGVydHkgXCJzb2xhbmFcIicsIC8vIFByb2JhYmx5IGEgYnJvd3NlciBleHRlbnNpb24gb3IgY3VzdG9tIGJyb3dzZXIgKEJyYXZlKSB0aHJvd2luZyB0aGlzIGVycm9yXG4gIFwidnYoKS5nZXRSZXN0cmljdGlvbnMgaXMgbm90IGEgZnVuY3Rpb24uIChJbiAndnYoKS5nZXRSZXN0cmljdGlvbnMoMSxhKScsICd2digpLmdldFJlc3RyaWN0aW9ucycgaXMgdW5kZWZpbmVkKVwiLCAvLyBFcnJvciB0aHJvd24gYnkgR1RNLCBzZWVtaW5nbHkgbm90IGFmZmVjdGluZyBlbmQtdXNlcnNcbiAgXCJDYW4ndCBmaW5kIHZhcmlhYmxlOiBfQXV0b2ZpbGxDYWxsYmFja0hhbmRsZXJcIiwgLy8gVW5hY3Rpb25hYmxlIGVycm9yIGluIGluc3RhZ3JhbSB3ZWJ2aWV3IGh0dHBzOi8vZGV2ZWxvcGVycy5mYWNlYm9vay5jb20vY29tbXVuaXR5L3RocmVhZHMvMzIwMDEzNTQ5NzkxMTQxL1xuICAvXk5vbi1FcnJvciBwcm9taXNlIHJlamVjdGlvbiBjYXB0dXJlZCB3aXRoIHZhbHVlOiBPYmplY3QgTm90IEZvdW5kIE1hdGNoaW5nIElkOlxcZCssIE1ldGhvZE5hbWU6c2ltdWxhdGVFdmVudCwgUGFyYW1Db3VudDpcXGQrJC8sIC8vIHVuYWN0aW9uYWJsZSBlcnJvciBmcm9tIENFRlNoYXJwLCBhIC5ORVQgbGlicmFyeSB0aGF0IGVtYmVkcyBjaHJvbWl1bSBpbiAuTkVUIGFwcHNcbiAgL15KYXZhIGV4Y2VwdGlvbiB3YXMgcmFpc2VkIGR1cmluZyBtZXRob2QgaW52b2NhdGlvbiQvLCAvLyBlcnJvciBmcm9tIEZhY2Vib29rIE1vYmlsZSBicm93c2VyIChodHRwczovL2dpdGh1Yi5jb20vZ2V0c2VudHJ5L3NlbnRyeS1qYXZhc2NyaXB0L2lzc3Vlcy8xNTA2NSlcbl07XG5cbi8qKiBPcHRpb25zIGZvciB0aGUgRXZlbnRGaWx0ZXJzIGludGVncmF0aW9uICovXG5cbmNvbnN0IElOVEVHUkFUSU9OX05BTUUgPSAnRXZlbnRGaWx0ZXJzJztcblxuLyoqXG4gKiBBbiBpbnRlZ3JhdGlvbiB0aGF0IGZpbHRlcnMgb3V0IGV2ZW50cyAoZXJyb3JzIGFuZCB0cmFuc2FjdGlvbnMpIGJhc2VkIG9uOlxuICpcbiAqIC0gKEVycm9ycykgQSBjdXJhdGVkIGxpc3Qgb2Yga25vd24gbG93LXZhbHVlIG9yIGlycmVsZXZhbnQgZXJyb3JzIChzZWUge0BsaW5rIERFRkFVTFRfSUdOT1JFX0VSUk9SU30pXG4gKiAtIChFcnJvcnMpIEEgbGlzdCBvZiBlcnJvciBtZXNzYWdlcyBvciB1cmxzL2ZpbGVuYW1lcyBwYXNzZWQgaW4gdmlhXG4gKiAgIC0gVG9wIGxldmVsIFNlbnRyeS5pbml0IG9wdGlvbnMgKGBpZ25vcmVFcnJvcnNgLCBgZGVueVVybHNgLCBgYWxsb3dVcmxzYClcbiAqICAgLSBUaGUgc2FtZSBvcHRpb25zIHBhc3NlZCB0byB0aGUgaW50ZWdyYXRpb24gZGlyZWN0bHkgdmlhIEBwYXJhbSBvcHRpb25zXG4gKiAtIChUcmFuc2FjdGlvbnMvU3BhbnMpIEEgbGlzdCBvZiByb290IHNwYW4gKHRyYW5zYWN0aW9uKSBuYW1lcyBwYXNzZWQgaW4gdmlhXG4gKiAgIC0gVG9wIGxldmVsIFNlbnRyeS5pbml0IG9wdGlvbiAoYGlnbm9yZVRyYW5zYWN0aW9uc2ApXG4gKiAgIC0gVGhlIHNhbWUgb3B0aW9uIHBhc3NlZCB0byB0aGUgaW50ZWdyYXRpb24gZGlyZWN0bHkgdmlhIEBwYXJhbSBvcHRpb25zXG4gKlxuICogRXZlbnRzIGZpbHRlcmVkIGJ5IHRoaXMgaW50ZWdyYXRpb24gd2lsbCBub3QgYmUgc2VudCB0byBTZW50cnkuXG4gKi9cbmNvbnN0IGV2ZW50RmlsdGVyc0ludGVncmF0aW9uID0gaW50ZWdyYXRpb24uZGVmaW5lSW50ZWdyYXRpb24oKG9wdGlvbnMgPSB7fSkgPT4ge1xuICBsZXQgbWVyZ2VkT3B0aW9ucztcbiAgcmV0dXJuIHtcbiAgICBuYW1lOiBJTlRFR1JBVElPTl9OQU1FLFxuICAgIHNldHVwKGNsaWVudCkge1xuICAgICAgY29uc3QgY2xpZW50T3B0aW9ucyA9IGNsaWVudC5nZXRPcHRpb25zKCk7XG4gICAgICBtZXJnZWRPcHRpb25zID0gX21lcmdlT3B0aW9ucyhvcHRpb25zLCBjbGllbnRPcHRpb25zKTtcbiAgICB9LFxuICAgIHByb2Nlc3NFdmVudChldmVudCwgX2hpbnQsIGNsaWVudCkge1xuICAgICAgaWYgKCFtZXJnZWRPcHRpb25zKSB7XG4gICAgICAgIGNvbnN0IGNsaWVudE9wdGlvbnMgPSBjbGllbnQuZ2V0T3B0aW9ucygpO1xuICAgICAgICBtZXJnZWRPcHRpb25zID0gX21lcmdlT3B0aW9ucyhvcHRpb25zLCBjbGllbnRPcHRpb25zKTtcbiAgICAgIH1cbiAgICAgIHJldHVybiBfc2hvdWxkRHJvcEV2ZW50KGV2ZW50LCBtZXJnZWRPcHRpb25zKSA/IG51bGwgOiBldmVudDtcbiAgICB9LFxuICB9O1xufSk7XG5cbi8qKlxuICogQW4gaW50ZWdyYXRpb24gdGhhdCBmaWx0ZXJzIG91dCBldmVudHMgKGVycm9ycyBhbmQgdHJhbnNhY3Rpb25zKSBiYXNlZCBvbjpcbiAqXG4gKiAtIChFcnJvcnMpIEEgY3VyYXRlZCBsaXN0IG9mIGtub3duIGxvdy12YWx1ZSBvciBpcnJlbGV2YW50IGVycm9ycyAoc2VlIHtAbGluayBERUZBVUxUX0lHTk9SRV9FUlJPUlN9KVxuICogLSAoRXJyb3JzKSBBIGxpc3Qgb2YgZXJyb3IgbWVzc2FnZXMgb3IgdXJscy9maWxlbmFtZXMgcGFzc2VkIGluIHZpYVxuICogICAtIFRvcCBsZXZlbCBTZW50cnkuaW5pdCBvcHRpb25zIChgaWdub3JlRXJyb3JzYCwgYGRlbnlVcmxzYCwgYGFsbG93VXJsc2ApXG4gKiAgIC0gVGhlIHNhbWUgb3B0aW9ucyBwYXNzZWQgdG8gdGhlIGludGVncmF0aW9uIGRpcmVjdGx5IHZpYSBAcGFyYW0gb3B0aW9uc1xuICogLSAoVHJhbnNhY3Rpb25zL1NwYW5zKSBBIGxpc3Qgb2Ygcm9vdCBzcGFuICh0cmFuc2FjdGlvbikgbmFtZXMgcGFzc2VkIGluIHZpYVxuICogICAtIFRvcCBsZXZlbCBTZW50cnkuaW5pdCBvcHRpb24gKGBpZ25vcmVUcmFuc2FjdGlvbnNgKVxuICogICAtIFRoZSBzYW1lIG9wdGlvbiBwYXNzZWQgdG8gdGhlIGludGVncmF0aW9uIGRpcmVjdGx5IHZpYSBAcGFyYW0gb3B0aW9uc1xuICpcbiAqIEV2ZW50cyBmaWx0ZXJlZCBieSB0aGlzIGludGVncmF0aW9uIHdpbGwgbm90IGJlIHNlbnQgdG8gU2VudHJ5LlxuICpcbiAqIEBkZXByZWNhdGVkIHRoaXMgaW50ZWdyYXRpb24gd2FzIHJlbmFtZWQgYW5kIHdpbGwgYmUgcmVtb3ZlZCBpbiBhIGZ1dHVyZSBtYWpvciB2ZXJzaW9uLlxuICogVXNlIGBldmVudEZpbHRlcnNJbnRlZ3JhdGlvbmAgaW5zdGVhZC5cbiAqL1xuY29uc3QgaW5ib3VuZEZpbHRlcnNJbnRlZ3JhdGlvbiA9IGludGVncmF0aW9uLmRlZmluZUludGVncmF0aW9uKCgob3B0aW9ucyA9IHt9KSA9PiB7XG4gIHJldHVybiB7XG4gICAgLi4uZXZlbnRGaWx0ZXJzSW50ZWdyYXRpb24ob3B0aW9ucyksXG4gICAgbmFtZTogJ0luYm91bmRGaWx0ZXJzJyxcbiAgfTtcbn0pICk7XG5cbmZ1bmN0aW9uIF9tZXJnZU9wdGlvbnMoXG4gIGludGVybmFsT3B0aW9ucyA9IHt9LFxuICBjbGllbnRPcHRpb25zID0ge30sXG4pIHtcbiAgcmV0dXJuIHtcbiAgICBhbGxvd1VybHM6IFsuLi4oaW50ZXJuYWxPcHRpb25zLmFsbG93VXJscyB8fCBbXSksIC4uLihjbGllbnRPcHRpb25zLmFsbG93VXJscyB8fCBbXSldLFxuICAgIGRlbnlVcmxzOiBbLi4uKGludGVybmFsT3B0aW9ucy5kZW55VXJscyB8fCBbXSksIC4uLihjbGllbnRPcHRpb25zLmRlbnlVcmxzIHx8IFtdKV0sXG4gICAgaWdub3JlRXJyb3JzOiBbXG4gICAgICAuLi4oaW50ZXJuYWxPcHRpb25zLmlnbm9yZUVycm9ycyB8fCBbXSksXG4gICAgICAuLi4oY2xpZW50T3B0aW9ucy5pZ25vcmVFcnJvcnMgfHwgW10pLFxuICAgICAgLi4uKGludGVybmFsT3B0aW9ucy5kaXNhYmxlRXJyb3JEZWZhdWx0cyA/IFtdIDogREVGQVVMVF9JR05PUkVfRVJST1JTKSxcbiAgICBdLFxuICAgIGlnbm9yZVRyYW5zYWN0aW9uczogWy4uLihpbnRlcm5hbE9wdGlvbnMuaWdub3JlVHJhbnNhY3Rpb25zIHx8IFtdKSwgLi4uKGNsaWVudE9wdGlvbnMuaWdub3JlVHJhbnNhY3Rpb25zIHx8IFtdKV0sXG4gIH07XG59XG5cbmZ1bmN0aW9uIF9zaG91bGREcm9wRXZlbnQoZXZlbnQsIG9wdGlvbnMpIHtcbiAgaWYgKCFldmVudC50eXBlKSB7XG4gICAgLy8gRmlsdGVyIGVycm9yc1xuICAgIGlmIChfaXNJZ25vcmVkRXJyb3IoZXZlbnQsIG9wdGlvbnMuaWdub3JlRXJyb3JzKSkge1xuICAgICAgZGVidWdCdWlsZC5ERUJVR19CVUlMRCAmJlxuICAgICAgICBkZWJ1Z0xvZ2dlci5kZWJ1Zy53YXJuKFxuICAgICAgICAgIGBFdmVudCBkcm9wcGVkIGR1ZSB0byBiZWluZyBtYXRjaGVkIGJ5IFxcYGlnbm9yZUVycm9yc1xcYCBvcHRpb24uXFxuRXZlbnQ6ICR7bWlzYy5nZXRFdmVudERlc2NyaXB0aW9uKGV2ZW50KX1gLFxuICAgICAgICApO1xuICAgICAgcmV0dXJuIHRydWU7XG4gICAgfVxuICAgIGlmIChfaXNVc2VsZXNzRXJyb3IoZXZlbnQpKSB7XG4gICAgICBkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEICYmXG4gICAgICAgIGRlYnVnTG9nZ2VyLmRlYnVnLndhcm4oXG4gICAgICAgICAgYEV2ZW50IGRyb3BwZWQgZHVlIHRvIG5vdCBoYXZpbmcgYW4gZXJyb3IgbWVzc2FnZSwgZXJyb3IgdHlwZSBvciBzdGFja3RyYWNlLlxcbkV2ZW50OiAke21pc2MuZ2V0RXZlbnREZXNjcmlwdGlvbihcbiAgICAgICAgICAgIGV2ZW50LFxuICAgICAgICAgICl9YCxcbiAgICAgICAgKTtcbiAgICAgIHJldHVybiB0cnVlO1xuICAgIH1cbiAgICBpZiAoX2lzRGVuaWVkVXJsKGV2ZW50LCBvcHRpb25zLmRlbnlVcmxzKSkge1xuICAgICAgZGVidWdCdWlsZC5ERUJVR19CVUlMRCAmJlxuICAgICAgICBkZWJ1Z0xvZ2dlci5kZWJ1Zy53YXJuKFxuICAgICAgICAgIGBFdmVudCBkcm9wcGVkIGR1ZSB0byBiZWluZyBtYXRjaGVkIGJ5IFxcYGRlbnlVcmxzXFxgIG9wdGlvbi5cXG5FdmVudDogJHttaXNjLmdldEV2ZW50RGVzY3JpcHRpb24oXG4gICAgICAgICAgICBldmVudCxcbiAgICAgICAgICApfS5cXG5Vcmw6ICR7X2dldEV2ZW50RmlsdGVyVXJsKGV2ZW50KX1gLFxuICAgICAgICApO1xuICAgICAgcmV0dXJuIHRydWU7XG4gICAgfVxuICAgIGlmICghX2lzQWxsb3dlZFVybChldmVudCwgb3B0aW9ucy5hbGxvd1VybHMpKSB7XG4gICAgICBkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEICYmXG4gICAgICAgIGRlYnVnTG9nZ2VyLmRlYnVnLndhcm4oXG4gICAgICAgICAgYEV2ZW50IGRyb3BwZWQgZHVlIHRvIG5vdCBiZWluZyBtYXRjaGVkIGJ5IFxcYGFsbG93VXJsc1xcYCBvcHRpb24uXFxuRXZlbnQ6ICR7bWlzYy5nZXRFdmVudERlc2NyaXB0aW9uKFxuICAgICAgICAgICAgZXZlbnQsXG4gICAgICAgICAgKX0uXFxuVXJsOiAke19nZXRFdmVudEZpbHRlclVybChldmVudCl9YCxcbiAgICAgICAgKTtcbiAgICAgIHJldHVybiB0cnVlO1xuICAgIH1cbiAgfSBlbHNlIGlmIChldmVudC50eXBlID09PSAndHJhbnNhY3Rpb24nKSB7XG4gICAgLy8gRmlsdGVyIHRyYW5zYWN0aW9uc1xuXG4gICAgaWYgKF9pc0lnbm9yZWRUcmFuc2FjdGlvbihldmVudCwgb3B0aW9ucy5pZ25vcmVUcmFuc2FjdGlvbnMpKSB7XG4gICAgICBkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEICYmXG4gICAgICAgIGRlYnVnTG9nZ2VyLmRlYnVnLndhcm4oXG4gICAgICAgICAgYEV2ZW50IGRyb3BwZWQgZHVlIHRvIGJlaW5nIG1hdGNoZWQgYnkgXFxgaWdub3JlVHJhbnNhY3Rpb25zXFxgIG9wdGlvbi5cXG5FdmVudDogJHttaXNjLmdldEV2ZW50RGVzY3JpcHRpb24oZXZlbnQpfWAsXG4gICAgICAgICk7XG4gICAgICByZXR1cm4gdHJ1ZTtcbiAgICB9XG4gIH1cbiAgcmV0dXJuIGZhbHNlO1xufVxuXG5mdW5jdGlvbiBfaXNJZ25vcmVkRXJyb3IoZXZlbnQsIGlnbm9yZUVycm9ycykge1xuICBpZiAoIWlnbm9yZUVycm9ycz8ubGVuZ3RoKSB7XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG5cbiAgcmV0dXJuIGV2ZW50VXRpbHMuZ2V0UG9zc2libGVFdmVudE1lc3NhZ2VzKGV2ZW50KS5zb21lKG1lc3NhZ2UgPT4gc3RyaW5nLnN0cmluZ01hdGNoZXNTb21lUGF0dGVybihtZXNzYWdlLCBpZ25vcmVFcnJvcnMpKTtcbn1cblxuZnVuY3Rpb24gX2lzSWdub3JlZFRyYW5zYWN0aW9uKGV2ZW50LCBpZ25vcmVUcmFuc2FjdGlvbnMpIHtcbiAgaWYgKCFpZ25vcmVUcmFuc2FjdGlvbnM/Lmxlbmd0aCkge1xuICAgIHJldHVybiBmYWxzZTtcbiAgfVxuXG4gIGNvbnN0IG5hbWUgPSBldmVudC50cmFuc2FjdGlvbjtcbiAgcmV0dXJuIG5hbWUgPyBzdHJpbmcuc3RyaW5nTWF0Y2hlc1NvbWVQYXR0ZXJuKG5hbWUsIGlnbm9yZVRyYW5zYWN0aW9ucykgOiBmYWxzZTtcbn1cblxuZnVuY3Rpb24gX2lzRGVuaWVkVXJsKGV2ZW50LCBkZW55VXJscykge1xuICBpZiAoIWRlbnlVcmxzPy5sZW5ndGgpIHtcbiAgICByZXR1cm4gZmFsc2U7XG4gIH1cbiAgY29uc3QgdXJsID0gX2dldEV2ZW50RmlsdGVyVXJsKGV2ZW50KTtcbiAgcmV0dXJuICF1cmwgPyBmYWxzZSA6IHN0cmluZy5zdHJpbmdNYXRjaGVzU29tZVBhdHRlcm4odXJsLCBkZW55VXJscyk7XG59XG5cbmZ1bmN0aW9uIF9pc0FsbG93ZWRVcmwoZXZlbnQsIGFsbG93VXJscykge1xuICBpZiAoIWFsbG93VXJscz8ubGVuZ3RoKSB7XG4gICAgcmV0dXJuIHRydWU7XG4gIH1cbiAgY29uc3QgdXJsID0gX2dldEV2ZW50RmlsdGVyVXJsKGV2ZW50KTtcbiAgcmV0dXJuICF1cmwgPyB0cnVlIDogc3RyaW5nLnN0cmluZ01hdGNoZXNTb21lUGF0dGVybih1cmwsIGFsbG93VXJscyk7XG59XG5cbmZ1bmN0aW9uIF9nZXRMYXN0VmFsaWRVcmwoZnJhbWVzID0gW10pIHtcbiAgZm9yIChsZXQgaSA9IGZyYW1lcy5sZW5ndGggLSAxOyBpID49IDA7IGktLSkge1xuICAgIGNvbnN0IGZyYW1lID0gZnJhbWVzW2ldO1xuXG4gICAgaWYgKGZyYW1lICYmIGZyYW1lLmZpbGVuYW1lICE9PSAnPGFub255bW91cz4nICYmIGZyYW1lLmZpbGVuYW1lICE9PSAnW25hdGl2ZSBjb2RlXScpIHtcbiAgICAgIHJldHVybiBmcmFtZS5maWxlbmFtZSB8fCBudWxsO1xuICAgIH1cbiAgfVxuXG4gIHJldHVybiBudWxsO1xufVxuXG5mdW5jdGlvbiBfZ2V0RXZlbnRGaWx0ZXJVcmwoZXZlbnQpIHtcbiAgdHJ5IHtcbiAgICAvLyBJZiB0aGVyZSBhcmUgbGlua2VkIGV4Y2VwdGlvbnMgb3IgZXhjZXB0aW9uIGFnZ3JlZ2F0ZXMgd2Ugb25seSB3YW50IHRvIG1hdGNoIGFnYWluc3QgdGhlIHRvcCBmcmFtZSBvZiB0aGUgXCJyb290XCIgKHRoZSBtYWluIGV4Y2VwdGlvbilcbiAgICAvLyBUaGUgcm9vdCBhbHdheXMgY29tZXMgbGFzdCBpbiBsaW5rZWQgZXhjZXB0aW9uc1xuICAgIGNvbnN0IHJvb3RFeGNlcHRpb24gPSBbLi4uKGV2ZW50LmV4Y2VwdGlvbj8udmFsdWVzID8/IFtdKV1cbiAgICAgIC5yZXZlcnNlKClcbiAgICAgIC5maW5kKHZhbHVlID0+IHZhbHVlLm1lY2hhbmlzbT8ucGFyZW50X2lkID09PSB1bmRlZmluZWQgJiYgdmFsdWUuc3RhY2t0cmFjZT8uZnJhbWVzPy5sZW5ndGgpO1xuICAgIGNvbnN0IGZyYW1lcyA9IHJvb3RFeGNlcHRpb24/LnN0YWNrdHJhY2U/LmZyYW1lcztcbiAgICByZXR1cm4gZnJhbWVzID8gX2dldExhc3RWYWxpZFVybChmcmFtZXMpIDogbnVsbDtcbiAgfSBjYXRjaCB7XG4gICAgZGVidWdCdWlsZC5ERUJVR19CVUlMRCAmJiBkZWJ1Z0xvZ2dlci5kZWJ1Zy5lcnJvcihgQ2Fubm90IGV4dHJhY3QgdXJsIGZvciBldmVudCAke21pc2MuZ2V0RXZlbnREZXNjcmlwdGlvbihldmVudCl9YCk7XG4gICAgcmV0dXJuIG51bGw7XG4gIH1cbn1cblxuZnVuY3Rpb24gX2lzVXNlbGVzc0Vycm9yKGV2ZW50KSB7XG4gIC8vIFdlIG9ubHkgd2FudCB0byBjb25zaWRlciBldmVudHMgZm9yIGRyb3BwaW5nIHRoYXQgYWN0dWFsbHkgaGF2ZSByZWNvcmRlZCBleGNlcHRpb24gdmFsdWVzLlxuICBpZiAoIWV2ZW50LmV4Y2VwdGlvbj8udmFsdWVzPy5sZW5ndGgpIHtcbiAgICByZXR1cm4gZmFsc2U7XG4gIH1cblxuICByZXR1cm4gKFxuICAgIC8vIE5vIHRvcC1sZXZlbCBtZXNzYWdlXG4gICAgIWV2ZW50Lm1lc3NhZ2UgJiZcbiAgICAvLyBUaGVyZSBhcmUgbm8gZXhjZXB0aW9uIHZhbHVlcyB0aGF0IGhhdmUgYSBzdGFja3RyYWNlLCBhIG5vbi1nZW5lcmljLUVycm9yIHR5cGUgb3IgdmFsdWVcbiAgICAhZXZlbnQuZXhjZXB0aW9uLnZhbHVlcy5zb21lKHZhbHVlID0+IHZhbHVlLnN0YWNrdHJhY2UgfHwgKHZhbHVlLnR5cGUgJiYgdmFsdWUudHlwZSAhPT0gJ0Vycm9yJykgfHwgdmFsdWUudmFsdWUpXG4gICk7XG59XG5cbmV4cG9ydHMuZXZlbnRGaWx0ZXJzSW50ZWdyYXRpb24gPSBldmVudEZpbHRlcnNJbnRlZ3JhdGlvbjtcbmV4cG9ydHMuaW5ib3VuZEZpbHRlcnNJbnRlZ3JhdGlvbiA9IGluYm91bmRGaWx0ZXJzSW50ZWdyYXRpb247XG4vLyMgc291cmNlTWFwcGluZ1VSTD1ldmVudEZpbHRlcnMuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/eventFilters.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/extraerrordata.js":
/*!*******************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/extraerrordata.js ***!
  \*******************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst debugBuild = __webpack_require__(/*! ../debug-build.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst integration = __webpack_require__(/*! ../integration.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integration.js\");\nconst debugLogger = __webpack_require__(/*! ../utils/debug-logger.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst is = __webpack_require__(/*! ../utils/is.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js\");\nconst normalize = __webpack_require__(/*! ../utils/normalize.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/normalize.js\");\nconst object = __webpack_require__(/*! ../utils/object.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/object.js\");\nconst string = __webpack_require__(/*! ../utils/string.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/string.js\");\n\nconst INTEGRATION_NAME = 'ExtraErrorData';\n\n/**\n * Extract additional data for from original exceptions.\n */\nconst _extraErrorDataIntegration = ((options = {}) => {\n  const { depth = 3, captureErrorCause = true } = options;\n  return {\n    name: INTEGRATION_NAME,\n    processEvent(event, hint, client) {\n      const { maxValueLength = 250 } = client.getOptions();\n      return _enhanceEventWithErrorData(event, hint, depth, captureErrorCause, maxValueLength);\n    },\n  };\n}) ;\n\nconst extraErrorDataIntegration = integration.defineIntegration(_extraErrorDataIntegration);\n\nfunction _enhanceEventWithErrorData(\n  event,\n  hint = {},\n  depth,\n  captureErrorCause,\n  maxValueLength,\n) {\n  if (!hint.originalException || !is.isError(hint.originalException)) {\n    return event;\n  }\n  const exceptionName = (hint.originalException ).name || hint.originalException.constructor.name;\n\n  const errorData = _extractErrorData(hint.originalException , captureErrorCause, maxValueLength);\n\n  if (errorData) {\n    const contexts = {\n      ...event.contexts,\n    };\n\n    const normalizedErrorData = normalize.normalize(errorData, depth);\n\n    if (is.isPlainObject(normalizedErrorData)) {\n      // We mark the error data as \"already normalized\" here, because we don't want other normalization procedures to\n      // potentially truncate the data we just already normalized, with a certain depth setting.\n      object.addNonEnumerableProperty(normalizedErrorData, '__sentry_skip_normalization__', true);\n      contexts[exceptionName] = normalizedErrorData;\n    }\n\n    return {\n      ...event,\n      contexts,\n    };\n  }\n\n  return event;\n}\n\n/**\n * Extract extra information from the Error object\n */\nfunction _extractErrorData(\n  error,\n  captureErrorCause,\n  maxValueLength,\n) {\n  // We are trying to enhance already existing event, so no harm done if it won't succeed\n  try {\n    const nativeKeys = [\n      'name',\n      'message',\n      'stack',\n      'line',\n      'column',\n      'fileName',\n      'lineNumber',\n      'columnNumber',\n      'toJSON',\n    ];\n\n    const extraErrorInfo = {};\n\n    // We want only enumerable properties, thus `getOwnPropertyNames` is redundant here, as we filter keys anyway.\n    for (const key of Object.keys(error)) {\n      if (nativeKeys.indexOf(key) !== -1) {\n        continue;\n      }\n      const value = error[key];\n      extraErrorInfo[key] = is.isError(value) || typeof value === 'string' ? string.truncate(`${value}`, maxValueLength) : value;\n    }\n\n    // Error.cause is a standard property that is non enumerable, we therefore need to access it separately.\n    // https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Error/cause\n    if (captureErrorCause && error.cause !== undefined) {\n      extraErrorInfo.cause = is.isError(error.cause) ? error.cause.toString() : error.cause;\n    }\n\n    // Check if someone attached `toJSON` method to grab even more properties (eg. axios is doing that)\n    if (typeof error.toJSON === 'function') {\n      const serializedError = error.toJSON() ;\n\n      for (const key of Object.keys(serializedError)) {\n        const value = serializedError[key];\n        extraErrorInfo[key] = is.isError(value) ? value.toString() : value;\n      }\n    }\n\n    return extraErrorInfo;\n  } catch (oO) {\n    debugBuild.DEBUG_BUILD && debugLogger.debug.error('Unable to extract extra data from the Error object:', oO);\n  }\n\n  return null;\n}\n\nexports.extraErrorDataIntegration = extraErrorDataIntegration;\n//# sourceMappingURL=extraerrordata.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvaW50ZWdyYXRpb25zL2V4dHJhZXJyb3JkYXRhLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLG1CQUFtQixtQkFBTyxDQUFDLG1JQUFtQjtBQUM5QyxvQkFBb0IsbUJBQU8sQ0FBQyxtSUFBbUI7QUFDL0Msb0JBQW9CLG1CQUFPLENBQUMsaUpBQTBCO0FBQ3RELFdBQVcsbUJBQU8sQ0FBQyw2SEFBZ0I7QUFDbkMsa0JBQWtCLG1CQUFPLENBQUMsMklBQXVCO0FBQ2pELGVBQWUsbUJBQU8sQ0FBQyxxSUFBb0I7QUFDM0MsZUFBZSxtQkFBTyxDQUFDLHFJQUFvQjs7QUFFM0M7O0FBRUE7QUFDQTtBQUNBO0FBQ0EsaURBQWlEO0FBQ2pELFVBQVUsc0NBQXNDO0FBQ2hEO0FBQ0E7QUFDQTtBQUNBLGNBQWMsdUJBQXVCO0FBQ3JDO0FBQ0EsS0FBSztBQUNMO0FBQ0EsQ0FBQzs7QUFFRDs7QUFFQTtBQUNBO0FBQ0EsV0FBVztBQUNYO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsZ0dBQWdHLE1BQU07QUFDdEc7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBLElBQUk7QUFDSjtBQUNBOztBQUVBO0FBQ0E7O0FBRUEsaUNBQWlDO0FBQ2pDIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvaW50ZWdyYXRpb25zL2V4dHJhZXJyb3JkYXRhLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBkZWJ1Z0J1aWxkID0gcmVxdWlyZSgnLi4vZGVidWctYnVpbGQuanMnKTtcbmNvbnN0IGludGVncmF0aW9uID0gcmVxdWlyZSgnLi4vaW50ZWdyYXRpb24uanMnKTtcbmNvbnN0IGRlYnVnTG9nZ2VyID0gcmVxdWlyZSgnLi4vdXRpbHMvZGVidWctbG9nZ2VyLmpzJyk7XG5jb25zdCBpcyA9IHJlcXVpcmUoJy4uL3V0aWxzL2lzLmpzJyk7XG5jb25zdCBub3JtYWxpemUgPSByZXF1aXJlKCcuLi91dGlscy9ub3JtYWxpemUuanMnKTtcbmNvbnN0IG9iamVjdCA9IHJlcXVpcmUoJy4uL3V0aWxzL29iamVjdC5qcycpO1xuY29uc3Qgc3RyaW5nID0gcmVxdWlyZSgnLi4vdXRpbHMvc3RyaW5nLmpzJyk7XG5cbmNvbnN0IElOVEVHUkFUSU9OX05BTUUgPSAnRXh0cmFFcnJvckRhdGEnO1xuXG4vKipcbiAqIEV4dHJhY3QgYWRkaXRpb25hbCBkYXRhIGZvciBmcm9tIG9yaWdpbmFsIGV4Y2VwdGlvbnMuXG4gKi9cbmNvbnN0IF9leHRyYUVycm9yRGF0YUludGVncmF0aW9uID0gKChvcHRpb25zID0ge30pID0+IHtcbiAgY29uc3QgeyBkZXB0aCA9IDMsIGNhcHR1cmVFcnJvckNhdXNlID0gdHJ1ZSB9ID0gb3B0aW9ucztcbiAgcmV0dXJuIHtcbiAgICBuYW1lOiBJTlRFR1JBVElPTl9OQU1FLFxuICAgIHByb2Nlc3NFdmVudChldmVudCwgaGludCwgY2xpZW50KSB7XG4gICAgICBjb25zdCB7IG1heFZhbHVlTGVuZ3RoID0gMjUwIH0gPSBjbGllbnQuZ2V0T3B0aW9ucygpO1xuICAgICAgcmV0dXJuIF9lbmhhbmNlRXZlbnRXaXRoRXJyb3JEYXRhKGV2ZW50LCBoaW50LCBkZXB0aCwgY2FwdHVyZUVycm9yQ2F1c2UsIG1heFZhbHVlTGVuZ3RoKTtcbiAgICB9LFxuICB9O1xufSkgO1xuXG5jb25zdCBleHRyYUVycm9yRGF0YUludGVncmF0aW9uID0gaW50ZWdyYXRpb24uZGVmaW5lSW50ZWdyYXRpb24oX2V4dHJhRXJyb3JEYXRhSW50ZWdyYXRpb24pO1xuXG5mdW5jdGlvbiBfZW5oYW5jZUV2ZW50V2l0aEVycm9yRGF0YShcbiAgZXZlbnQsXG4gIGhpbnQgPSB7fSxcbiAgZGVwdGgsXG4gIGNhcHR1cmVFcnJvckNhdXNlLFxuICBtYXhWYWx1ZUxlbmd0aCxcbikge1xuICBpZiAoIWhpbnQub3JpZ2luYWxFeGNlcHRpb24gfHwgIWlzLmlzRXJyb3IoaGludC5vcmlnaW5hbEV4Y2VwdGlvbikpIHtcbiAgICByZXR1cm4gZXZlbnQ7XG4gIH1cbiAgY29uc3QgZXhjZXB0aW9uTmFtZSA9IChoaW50Lm9yaWdpbmFsRXhjZXB0aW9uICkubmFtZSB8fCBoaW50Lm9yaWdpbmFsRXhjZXB0aW9uLmNvbnN0cnVjdG9yLm5hbWU7XG5cbiAgY29uc3QgZXJyb3JEYXRhID0gX2V4dHJhY3RFcnJvckRhdGEoaGludC5vcmlnaW5hbEV4Y2VwdGlvbiAsIGNhcHR1cmVFcnJvckNhdXNlLCBtYXhWYWx1ZUxlbmd0aCk7XG5cbiAgaWYgKGVycm9yRGF0YSkge1xuICAgIGNvbnN0IGNvbnRleHRzID0ge1xuICAgICAgLi4uZXZlbnQuY29udGV4dHMsXG4gICAgfTtcblxuICAgIGNvbnN0IG5vcm1hbGl6ZWRFcnJvckRhdGEgPSBub3JtYWxpemUubm9ybWFsaXplKGVycm9yRGF0YSwgZGVwdGgpO1xuXG4gICAgaWYgKGlzLmlzUGxhaW5PYmplY3Qobm9ybWFsaXplZEVycm9yRGF0YSkpIHtcbiAgICAgIC8vIFdlIG1hcmsgdGhlIGVycm9yIGRhdGEgYXMgXCJhbHJlYWR5IG5vcm1hbGl6ZWRcIiBoZXJlLCBiZWNhdXNlIHdlIGRvbid0IHdhbnQgb3RoZXIgbm9ybWFsaXphdGlvbiBwcm9jZWR1cmVzIHRvXG4gICAgICAvLyBwb3RlbnRpYWxseSB0cnVuY2F0ZSB0aGUgZGF0YSB3ZSBqdXN0IGFscmVhZHkgbm9ybWFsaXplZCwgd2l0aCBhIGNlcnRhaW4gZGVwdGggc2V0dGluZy5cbiAgICAgIG9iamVjdC5hZGROb25FbnVtZXJhYmxlUHJvcGVydHkobm9ybWFsaXplZEVycm9yRGF0YSwgJ19fc2VudHJ5X3NraXBfbm9ybWFsaXphdGlvbl9fJywgdHJ1ZSk7XG4gICAgICBjb250ZXh0c1tleGNlcHRpb25OYW1lXSA9IG5vcm1hbGl6ZWRFcnJvckRhdGE7XG4gICAgfVxuXG4gICAgcmV0dXJuIHtcbiAgICAgIC4uLmV2ZW50LFxuICAgICAgY29udGV4dHMsXG4gICAgfTtcbiAgfVxuXG4gIHJldHVybiBldmVudDtcbn1cblxuLyoqXG4gKiBFeHRyYWN0IGV4dHJhIGluZm9ybWF0aW9uIGZyb20gdGhlIEVycm9yIG9iamVjdFxuICovXG5mdW5jdGlvbiBfZXh0cmFjdEVycm9yRGF0YShcbiAgZXJyb3IsXG4gIGNhcHR1cmVFcnJvckNhdXNlLFxuICBtYXhWYWx1ZUxlbmd0aCxcbikge1xuICAvLyBXZSBhcmUgdHJ5aW5nIHRvIGVuaGFuY2UgYWxyZWFkeSBleGlzdGluZyBldmVudCwgc28gbm8gaGFybSBkb25lIGlmIGl0IHdvbid0IHN1Y2NlZWRcbiAgdHJ5IHtcbiAgICBjb25zdCBuYXRpdmVLZXlzID0gW1xuICAgICAgJ25hbWUnLFxuICAgICAgJ21lc3NhZ2UnLFxuICAgICAgJ3N0YWNrJyxcbiAgICAgICdsaW5lJyxcbiAgICAgICdjb2x1bW4nLFxuICAgICAgJ2ZpbGVOYW1lJyxcbiAgICAgICdsaW5lTnVtYmVyJyxcbiAgICAgICdjb2x1bW5OdW1iZXInLFxuICAgICAgJ3RvSlNPTicsXG4gICAgXTtcblxuICAgIGNvbnN0IGV4dHJhRXJyb3JJbmZvID0ge307XG5cbiAgICAvLyBXZSB3YW50IG9ubHkgZW51bWVyYWJsZSBwcm9wZXJ0aWVzLCB0aHVzIGBnZXRPd25Qcm9wZXJ0eU5hbWVzYCBpcyByZWR1bmRhbnQgaGVyZSwgYXMgd2UgZmlsdGVyIGtleXMgYW55d2F5LlxuICAgIGZvciAoY29uc3Qga2V5IG9mIE9iamVjdC5rZXlzKGVycm9yKSkge1xuICAgICAgaWYgKG5hdGl2ZUtleXMuaW5kZXhPZihrZXkpICE9PSAtMSkge1xuICAgICAgICBjb250aW51ZTtcbiAgICAgIH1cbiAgICAgIGNvbnN0IHZhbHVlID0gZXJyb3Jba2V5XTtcbiAgICAgIGV4dHJhRXJyb3JJbmZvW2tleV0gPSBpcy5pc0Vycm9yKHZhbHVlKSB8fCB0eXBlb2YgdmFsdWUgPT09ICdzdHJpbmcnID8gc3RyaW5nLnRydW5jYXRlKGAke3ZhbHVlfWAsIG1heFZhbHVlTGVuZ3RoKSA6IHZhbHVlO1xuICAgIH1cblxuICAgIC8vIEVycm9yLmNhdXNlIGlzIGEgc3RhbmRhcmQgcHJvcGVydHkgdGhhdCBpcyBub24gZW51bWVyYWJsZSwgd2UgdGhlcmVmb3JlIG5lZWQgdG8gYWNjZXNzIGl0IHNlcGFyYXRlbHkuXG4gICAgLy8gaHR0cHM6Ly9kZXZlbG9wZXIubW96aWxsYS5vcmcvZW4tVVMvZG9jcy9XZWIvSmF2YVNjcmlwdC9SZWZlcmVuY2UvR2xvYmFsX09iamVjdHMvRXJyb3IvY2F1c2VcbiAgICBpZiAoY2FwdHVyZUVycm9yQ2F1c2UgJiYgZXJyb3IuY2F1c2UgIT09IHVuZGVmaW5lZCkge1xuICAgICAgZXh0cmFFcnJvckluZm8uY2F1c2UgPSBpcy5pc0Vycm9yKGVycm9yLmNhdXNlKSA/IGVycm9yLmNhdXNlLnRvU3RyaW5nKCkgOiBlcnJvci5jYXVzZTtcbiAgICB9XG5cbiAgICAvLyBDaGVjayBpZiBzb21lb25lIGF0dGFjaGVkIGB0b0pTT05gIG1ldGhvZCB0byBncmFiIGV2ZW4gbW9yZSBwcm9wZXJ0aWVzIChlZy4gYXhpb3MgaXMgZG9pbmcgdGhhdClcbiAgICBpZiAodHlwZW9mIGVycm9yLnRvSlNPTiA9PT0gJ2Z1bmN0aW9uJykge1xuICAgICAgY29uc3Qgc2VyaWFsaXplZEVycm9yID0gZXJyb3IudG9KU09OKCkgO1xuXG4gICAgICBmb3IgKGNvbnN0IGtleSBvZiBPYmplY3Qua2V5cyhzZXJpYWxpemVkRXJyb3IpKSB7XG4gICAgICAgIGNvbnN0IHZhbHVlID0gc2VyaWFsaXplZEVycm9yW2tleV07XG4gICAgICAgIGV4dHJhRXJyb3JJbmZvW2tleV0gPSBpcy5pc0Vycm9yKHZhbHVlKSA/IHZhbHVlLnRvU3RyaW5nKCkgOiB2YWx1ZTtcbiAgICAgIH1cbiAgICB9XG5cbiAgICByZXR1cm4gZXh0cmFFcnJvckluZm87XG4gIH0gY2F0Y2ggKG9PKSB7XG4gICAgZGVidWdCdWlsZC5ERUJVR19CVUlMRCAmJiBkZWJ1Z0xvZ2dlci5kZWJ1Zy5lcnJvcignVW5hYmxlIHRvIGV4dHJhY3QgZXh0cmEgZGF0YSBmcm9tIHRoZSBFcnJvciBvYmplY3Q6Jywgb08pO1xuICB9XG5cbiAgcmV0dXJuIG51bGw7XG59XG5cbmV4cG9ydHMuZXh0cmFFcnJvckRhdGFJbnRlZ3JhdGlvbiA9IGV4dHJhRXJyb3JEYXRhSW50ZWdyYXRpb247XG4vLyMgc291cmNlTWFwcGluZ1VSTD1leHRyYWVycm9yZGF0YS5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/extraerrordata.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/featureFlags/featureFlagsIntegration.js":
/*!*****************************************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/featureFlags/featureFlagsIntegration.js ***!
  \*****************************************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst integration = __webpack_require__(/*! ../../integration.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integration.js\");\nconst featureFlags = __webpack_require__(/*! ../../utils/featureFlags.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/featureFlags.js\");\n\n/**\n * Sentry integration for buffering feature flag evaluations manually with an API, and\n * capturing them on error events and spans.\n *\n * See the [feature flag documentation](https://develop.sentry.dev/sdk/expected-features/#feature-flags) for more information.\n *\n * @example\n * ```\n * import * as Sentry from '@sentry/browser';\n * import { type FeatureFlagsIntegration } from '@sentry/browser';\n *\n * // Setup\n * Sentry.init(..., integrations: [Sentry.featureFlagsIntegration()])\n *\n * // Verify\n * const flagsIntegration = Sentry.getClient()?.getIntegrationByName<FeatureFlagsIntegration>('FeatureFlags');\n * if (flagsIntegration) {\n *   flagsIntegration.addFeatureFlag('my-flag', true);\n * } else {\n *   // check your setup\n * }\n * Sentry.captureException(Exception('broke')); // 'my-flag' should be captured to this Sentry event.\n * ```\n */\nconst featureFlagsIntegration = integration.defineIntegration(() => {\n  return {\n    name: 'FeatureFlags',\n\n    processEvent(event, _hint, _client) {\n      return featureFlags._INTERNAL_copyFlagsFromScopeToEvent(event);\n    },\n\n    addFeatureFlag(name, value) {\n      featureFlags._INTERNAL_insertFlagToScope(name, value);\n      featureFlags._INTERNAL_addFeatureFlagToActiveSpan(name, value);\n    },\n  };\n}) ;\n\nexports.featureFlagsIntegration = featureFlagsIntegration;\n//# sourceMappingURL=featureFlagsIntegration.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvaW50ZWdyYXRpb25zL2ZlYXR1cmVGbGFncy9mZWF0dXJlRmxhZ3NJbnRlZ3JhdGlvbi5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxvQkFBb0IsbUJBQU8sQ0FBQyxzSUFBc0I7QUFDbEQscUJBQXFCLG1CQUFPLENBQUMsb0pBQTZCOztBQUUxRDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxZQUFZLCtCQUErQjtBQUMzQztBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsS0FBSztBQUNMO0FBQ0E7QUFDQSxnREFBZ0Q7QUFDaEQ7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsS0FBSzs7QUFFTDtBQUNBO0FBQ0E7QUFDQSxLQUFLO0FBQ0w7QUFDQSxDQUFDOztBQUVELCtCQUErQjtBQUMvQiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL2ludGVncmF0aW9ucy9mZWF0dXJlRmxhZ3MvZmVhdHVyZUZsYWdzSW50ZWdyYXRpb24uanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGludGVncmF0aW9uID0gcmVxdWlyZSgnLi4vLi4vaW50ZWdyYXRpb24uanMnKTtcbmNvbnN0IGZlYXR1cmVGbGFncyA9IHJlcXVpcmUoJy4uLy4uL3V0aWxzL2ZlYXR1cmVGbGFncy5qcycpO1xuXG4vKipcbiAqIFNlbnRyeSBpbnRlZ3JhdGlvbiBmb3IgYnVmZmVyaW5nIGZlYXR1cmUgZmxhZyBldmFsdWF0aW9ucyBtYW51YWxseSB3aXRoIGFuIEFQSSwgYW5kXG4gKiBjYXB0dXJpbmcgdGhlbSBvbiBlcnJvciBldmVudHMgYW5kIHNwYW5zLlxuICpcbiAqIFNlZSB0aGUgW2ZlYXR1cmUgZmxhZyBkb2N1bWVudGF0aW9uXShodHRwczovL2RldmVsb3Auc2VudHJ5LmRldi9zZGsvZXhwZWN0ZWQtZmVhdHVyZXMvI2ZlYXR1cmUtZmxhZ3MpIGZvciBtb3JlIGluZm9ybWF0aW9uLlxuICpcbiAqIEBleGFtcGxlXG4gKiBgYGBcbiAqIGltcG9ydCAqIGFzIFNlbnRyeSBmcm9tICdAc2VudHJ5L2Jyb3dzZXInO1xuICogaW1wb3J0IHsgdHlwZSBGZWF0dXJlRmxhZ3NJbnRlZ3JhdGlvbiB9IGZyb20gJ0BzZW50cnkvYnJvd3Nlcic7XG4gKlxuICogLy8gU2V0dXBcbiAqIFNlbnRyeS5pbml0KC4uLiwgaW50ZWdyYXRpb25zOiBbU2VudHJ5LmZlYXR1cmVGbGFnc0ludGVncmF0aW9uKCldKVxuICpcbiAqIC8vIFZlcmlmeVxuICogY29uc3QgZmxhZ3NJbnRlZ3JhdGlvbiA9IFNlbnRyeS5nZXRDbGllbnQoKT8uZ2V0SW50ZWdyYXRpb25CeU5hbWU8RmVhdHVyZUZsYWdzSW50ZWdyYXRpb24+KCdGZWF0dXJlRmxhZ3MnKTtcbiAqIGlmIChmbGFnc0ludGVncmF0aW9uKSB7XG4gKiAgIGZsYWdzSW50ZWdyYXRpb24uYWRkRmVhdHVyZUZsYWcoJ215LWZsYWcnLCB0cnVlKTtcbiAqIH0gZWxzZSB7XG4gKiAgIC8vIGNoZWNrIHlvdXIgc2V0dXBcbiAqIH1cbiAqIFNlbnRyeS5jYXB0dXJlRXhjZXB0aW9uKEV4Y2VwdGlvbignYnJva2UnKSk7IC8vICdteS1mbGFnJyBzaG91bGQgYmUgY2FwdHVyZWQgdG8gdGhpcyBTZW50cnkgZXZlbnQuXG4gKiBgYGBcbiAqL1xuY29uc3QgZmVhdHVyZUZsYWdzSW50ZWdyYXRpb24gPSBpbnRlZ3JhdGlvbi5kZWZpbmVJbnRlZ3JhdGlvbigoKSA9PiB7XG4gIHJldHVybiB7XG4gICAgbmFtZTogJ0ZlYXR1cmVGbGFncycsXG5cbiAgICBwcm9jZXNzRXZlbnQoZXZlbnQsIF9oaW50LCBfY2xpZW50KSB7XG4gICAgICByZXR1cm4gZmVhdHVyZUZsYWdzLl9JTlRFUk5BTF9jb3B5RmxhZ3NGcm9tU2NvcGVUb0V2ZW50KGV2ZW50KTtcbiAgICB9LFxuXG4gICAgYWRkRmVhdHVyZUZsYWcobmFtZSwgdmFsdWUpIHtcbiAgICAgIGZlYXR1cmVGbGFncy5fSU5URVJOQUxfaW5zZXJ0RmxhZ1RvU2NvcGUobmFtZSwgdmFsdWUpO1xuICAgICAgZmVhdHVyZUZsYWdzLl9JTlRFUk5BTF9hZGRGZWF0dXJlRmxhZ1RvQWN0aXZlU3BhbihuYW1lLCB2YWx1ZSk7XG4gICAgfSxcbiAgfTtcbn0pIDtcblxuZXhwb3J0cy5mZWF0dXJlRmxhZ3NJbnRlZ3JhdGlvbiA9IGZlYXR1cmVGbGFnc0ludGVncmF0aW9uO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9ZmVhdHVyZUZsYWdzSW50ZWdyYXRpb24uanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/featureFlags/featureFlagsIntegration.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/functiontostring.js":
/*!*********************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/functiontostring.js ***!
  \*********************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst currentScopes = __webpack_require__(/*! ../currentScopes.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst integration = __webpack_require__(/*! ../integration.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integration.js\");\nconst object = __webpack_require__(/*! ../utils/object.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/object.js\");\n\nlet originalFunctionToString;\n\nconst INTEGRATION_NAME = 'FunctionToString';\n\nconst SETUP_CLIENTS = new WeakMap();\n\nconst _functionToStringIntegration = (() => {\n  return {\n    name: INTEGRATION_NAME,\n    setupOnce() {\n      // eslint-disable-next-line @typescript-eslint/unbound-method\n      originalFunctionToString = Function.prototype.toString;\n\n      // intrinsics (like Function.prototype) might be immutable in some environments\n      // e.g. Node with --frozen-intrinsics, XS (an embedded JavaScript engine) or SES (a JavaScript proposal)\n      try {\n        Function.prototype.toString = function ( ...args) {\n          const originalFunction = object.getOriginalFunction(this);\n          const context =\n            SETUP_CLIENTS.has(currentScopes.getClient() ) && originalFunction !== undefined ? originalFunction : this;\n          return originalFunctionToString.apply(context, args);\n        };\n      } catch {\n        // ignore errors here, just don't patch this\n      }\n    },\n    setup(client) {\n      SETUP_CLIENTS.set(client, true);\n    },\n  };\n}) ;\n\n/**\n * Patch toString calls to return proper name for wrapped functions.\n *\n * ```js\n * Sentry.init({\n *   integrations: [\n *     functionToStringIntegration(),\n *   ],\n * });\n * ```\n */\nconst functionToStringIntegration = integration.defineIntegration(_functionToStringIntegration);\n\nexports.functionToStringIntegration = functionToStringIntegration;\n//# sourceMappingURL=functiontostring.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvaW50ZWdyYXRpb25zL2Z1bmN0aW9udG9zdHJpbmcuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsc0JBQXNCLG1CQUFPLENBQUMsdUlBQXFCO0FBQ25ELG9CQUFvQixtQkFBTyxDQUFDLG1JQUFtQjtBQUMvQyxlQUFlLG1CQUFPLENBQUMscUlBQW9COztBQUUzQzs7QUFFQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsUUFBUTtBQUNSO0FBQ0E7QUFDQSxLQUFLO0FBQ0w7QUFDQTtBQUNBLEtBQUs7QUFDTDtBQUNBLENBQUM7O0FBRUQ7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLElBQUk7QUFDSjtBQUNBO0FBQ0E7O0FBRUEsbUNBQW1DO0FBQ25DIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvaW50ZWdyYXRpb25zL2Z1bmN0aW9udG9zdHJpbmcuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGN1cnJlbnRTY29wZXMgPSByZXF1aXJlKCcuLi9jdXJyZW50U2NvcGVzLmpzJyk7XG5jb25zdCBpbnRlZ3JhdGlvbiA9IHJlcXVpcmUoJy4uL2ludGVncmF0aW9uLmpzJyk7XG5jb25zdCBvYmplY3QgPSByZXF1aXJlKCcuLi91dGlscy9vYmplY3QuanMnKTtcblxubGV0IG9yaWdpbmFsRnVuY3Rpb25Ub1N0cmluZztcblxuY29uc3QgSU5URUdSQVRJT05fTkFNRSA9ICdGdW5jdGlvblRvU3RyaW5nJztcblxuY29uc3QgU0VUVVBfQ0xJRU5UUyA9IG5ldyBXZWFrTWFwKCk7XG5cbmNvbnN0IF9mdW5jdGlvblRvU3RyaW5nSW50ZWdyYXRpb24gPSAoKCkgPT4ge1xuICByZXR1cm4ge1xuICAgIG5hbWU6IElOVEVHUkFUSU9OX05BTUUsXG4gICAgc2V0dXBPbmNlKCkge1xuICAgICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC91bmJvdW5kLW1ldGhvZFxuICAgICAgb3JpZ2luYWxGdW5jdGlvblRvU3RyaW5nID0gRnVuY3Rpb24ucHJvdG90eXBlLnRvU3RyaW5nO1xuXG4gICAgICAvLyBpbnRyaW5zaWNzIChsaWtlIEZ1bmN0aW9uLnByb3RvdHlwZSkgbWlnaHQgYmUgaW1tdXRhYmxlIGluIHNvbWUgZW52aXJvbm1lbnRzXG4gICAgICAvLyBlLmcuIE5vZGUgd2l0aCAtLWZyb3plbi1pbnRyaW5zaWNzLCBYUyAoYW4gZW1iZWRkZWQgSmF2YVNjcmlwdCBlbmdpbmUpIG9yIFNFUyAoYSBKYXZhU2NyaXB0IHByb3Bvc2FsKVxuICAgICAgdHJ5IHtcbiAgICAgICAgRnVuY3Rpb24ucHJvdG90eXBlLnRvU3RyaW5nID0gZnVuY3Rpb24gKCAuLi5hcmdzKSB7XG4gICAgICAgICAgY29uc3Qgb3JpZ2luYWxGdW5jdGlvbiA9IG9iamVjdC5nZXRPcmlnaW5hbEZ1bmN0aW9uKHRoaXMpO1xuICAgICAgICAgIGNvbnN0IGNvbnRleHQgPVxuICAgICAgICAgICAgU0VUVVBfQ0xJRU5UUy5oYXMoY3VycmVudFNjb3Blcy5nZXRDbGllbnQoKSApICYmIG9yaWdpbmFsRnVuY3Rpb24gIT09IHVuZGVmaW5lZCA/IG9yaWdpbmFsRnVuY3Rpb24gOiB0aGlzO1xuICAgICAgICAgIHJldHVybiBvcmlnaW5hbEZ1bmN0aW9uVG9TdHJpbmcuYXBwbHkoY29udGV4dCwgYXJncyk7XG4gICAgICAgIH07XG4gICAgICB9IGNhdGNoIHtcbiAgICAgICAgLy8gaWdub3JlIGVycm9ycyBoZXJlLCBqdXN0IGRvbid0IHBhdGNoIHRoaXNcbiAgICAgIH1cbiAgICB9LFxuICAgIHNldHVwKGNsaWVudCkge1xuICAgICAgU0VUVVBfQ0xJRU5UUy5zZXQoY2xpZW50LCB0cnVlKTtcbiAgICB9LFxuICB9O1xufSkgO1xuXG4vKipcbiAqIFBhdGNoIHRvU3RyaW5nIGNhbGxzIHRvIHJldHVybiBwcm9wZXIgbmFtZSBmb3Igd3JhcHBlZCBmdW5jdGlvbnMuXG4gKlxuICogYGBganNcbiAqIFNlbnRyeS5pbml0KHtcbiAqICAgaW50ZWdyYXRpb25zOiBbXG4gKiAgICAgZnVuY3Rpb25Ub1N0cmluZ0ludGVncmF0aW9uKCksXG4gKiAgIF0sXG4gKiB9KTtcbiAqIGBgYFxuICovXG5jb25zdCBmdW5jdGlvblRvU3RyaW5nSW50ZWdyYXRpb24gPSBpbnRlZ3JhdGlvbi5kZWZpbmVJbnRlZ3JhdGlvbihfZnVuY3Rpb25Ub1N0cmluZ0ludGVncmF0aW9uKTtcblxuZXhwb3J0cy5mdW5jdGlvblRvU3RyaW5nSW50ZWdyYXRpb24gPSBmdW5jdGlvblRvU3RyaW5nSW50ZWdyYXRpb247XG4vLyMgc291cmNlTWFwcGluZ1VSTD1mdW5jdGlvbnRvc3RyaW5nLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/functiontostring.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/linkederrors.js":
/*!*****************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/linkederrors.js ***!
  \*****************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst integration = __webpack_require__(/*! ../integration.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integration.js\");\nconst aggregateErrors = __webpack_require__(/*! ../utils/aggregate-errors.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/aggregate-errors.js\");\nconst eventbuilder = __webpack_require__(/*! ../utils/eventbuilder.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/eventbuilder.js\");\n\nconst DEFAULT_KEY = 'cause';\nconst DEFAULT_LIMIT = 5;\n\nconst INTEGRATION_NAME = 'LinkedErrors';\n\nconst _linkedErrorsIntegration = ((options = {}) => {\n  const limit = options.limit || DEFAULT_LIMIT;\n  const key = options.key || DEFAULT_KEY;\n\n  return {\n    name: INTEGRATION_NAME,\n    preprocessEvent(event, hint, client) {\n      const options = client.getOptions();\n\n      aggregateErrors.applyAggregateErrorsToEvent(eventbuilder.exceptionFromError, options.stackParser, key, limit, event, hint);\n    },\n  };\n}) ;\n\nconst linkedErrorsIntegration = integration.defineIntegration(_linkedErrorsIntegration);\n\nexports.linkedErrorsIntegration = linkedErrorsIntegration;\n//# sourceMappingURL=linkederrors.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvaW50ZWdyYXRpb25zL2xpbmtlZGVycm9ycy5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxvQkFBb0IsbUJBQU8sQ0FBQyxtSUFBbUI7QUFDL0Msd0JBQXdCLG1CQUFPLENBQUMseUpBQThCO0FBQzlELHFCQUFxQixtQkFBTyxDQUFDLGlKQUEwQjs7QUFFdkQ7QUFDQTs7QUFFQTs7QUFFQSwrQ0FBK0M7QUFDL0M7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBLEtBQUs7QUFDTDtBQUNBLENBQUM7O0FBRUQ7O0FBRUEsK0JBQStCO0FBQy9CIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvaW50ZWdyYXRpb25zL2xpbmtlZGVycm9ycy5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgaW50ZWdyYXRpb24gPSByZXF1aXJlKCcuLi9pbnRlZ3JhdGlvbi5qcycpO1xuY29uc3QgYWdncmVnYXRlRXJyb3JzID0gcmVxdWlyZSgnLi4vdXRpbHMvYWdncmVnYXRlLWVycm9ycy5qcycpO1xuY29uc3QgZXZlbnRidWlsZGVyID0gcmVxdWlyZSgnLi4vdXRpbHMvZXZlbnRidWlsZGVyLmpzJyk7XG5cbmNvbnN0IERFRkFVTFRfS0VZID0gJ2NhdXNlJztcbmNvbnN0IERFRkFVTFRfTElNSVQgPSA1O1xuXG5jb25zdCBJTlRFR1JBVElPTl9OQU1FID0gJ0xpbmtlZEVycm9ycyc7XG5cbmNvbnN0IF9saW5rZWRFcnJvcnNJbnRlZ3JhdGlvbiA9ICgob3B0aW9ucyA9IHt9KSA9PiB7XG4gIGNvbnN0IGxpbWl0ID0gb3B0aW9ucy5saW1pdCB8fCBERUZBVUxUX0xJTUlUO1xuICBjb25zdCBrZXkgPSBvcHRpb25zLmtleSB8fCBERUZBVUxUX0tFWTtcblxuICByZXR1cm4ge1xuICAgIG5hbWU6IElOVEVHUkFUSU9OX05BTUUsXG4gICAgcHJlcHJvY2Vzc0V2ZW50KGV2ZW50LCBoaW50LCBjbGllbnQpIHtcbiAgICAgIGNvbnN0IG9wdGlvbnMgPSBjbGllbnQuZ2V0T3B0aW9ucygpO1xuXG4gICAgICBhZ2dyZWdhdGVFcnJvcnMuYXBwbHlBZ2dyZWdhdGVFcnJvcnNUb0V2ZW50KGV2ZW50YnVpbGRlci5leGNlcHRpb25Gcm9tRXJyb3IsIG9wdGlvbnMuc3RhY2tQYXJzZXIsIGtleSwgbGltaXQsIGV2ZW50LCBoaW50KTtcbiAgICB9LFxuICB9O1xufSkgO1xuXG5jb25zdCBsaW5rZWRFcnJvcnNJbnRlZ3JhdGlvbiA9IGludGVncmF0aW9uLmRlZmluZUludGVncmF0aW9uKF9saW5rZWRFcnJvcnNJbnRlZ3JhdGlvbik7XG5cbmV4cG9ydHMubGlua2VkRXJyb3JzSW50ZWdyYXRpb24gPSBsaW5rZWRFcnJvcnNJbnRlZ3JhdGlvbjtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWxpbmtlZGVycm9ycy5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/linkederrors.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/attributeExtraction.js":
/*!***********************************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/attributeExtraction.js ***!
  \***********************************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst url = __webpack_require__(/*! ../../utils/url.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/url.js\");\nconst attributes = __webpack_require__(/*! ./attributes.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/attributes.js\");\nconst methodConfig = __webpack_require__(/*! ./methodConfig.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/methodConfig.js\");\n\n/**\n * Core attribute extraction and building functions for MCP server instrumentation\n */\n\n\n/**\n * Extracts additional attributes for specific notification types\n * @param method - Notification method name\n * @param params - Notification parameters\n * @returns Method-specific attributes for span instrumentation\n */\nfunction getNotificationAttributes(\n  method,\n  params,\n) {\n  const attributes$1 = {};\n\n  switch (method) {\n    case 'notifications/cancelled':\n      if (params?.requestId) {\n        attributes$1['mcp.cancelled.request_id'] = String(params.requestId);\n      }\n      if (params?.reason) {\n        attributes$1['mcp.cancelled.reason'] = String(params.reason);\n      }\n      break;\n\n    case 'notifications/message':\n      if (params?.level) {\n        attributes$1[attributes.MCP_LOGGING_LEVEL_ATTRIBUTE] = String(params.level);\n      }\n      if (params?.logger) {\n        attributes$1[attributes.MCP_LOGGING_LOGGER_ATTRIBUTE] = String(params.logger);\n      }\n      if (params?.data !== undefined) {\n        attributes$1[attributes.MCP_LOGGING_DATA_TYPE_ATTRIBUTE] = typeof params.data;\n        if (typeof params.data === 'string') {\n          attributes$1[attributes.MCP_LOGGING_MESSAGE_ATTRIBUTE] = params.data;\n        } else {\n          attributes$1[attributes.MCP_LOGGING_MESSAGE_ATTRIBUTE] = JSON.stringify(params.data);\n        }\n      }\n      break;\n\n    case 'notifications/progress':\n      if (params?.progressToken) {\n        attributes$1['mcp.progress.token'] = String(params.progressToken);\n      }\n      if (typeof params?.progress === 'number') {\n        attributes$1['mcp.progress.current'] = params.progress;\n      }\n      if (typeof params?.total === 'number') {\n        attributes$1['mcp.progress.total'] = params.total;\n        if (typeof params?.progress === 'number') {\n          attributes$1['mcp.progress.percentage'] = (params.progress / params.total) * 100;\n        }\n      }\n      if (params?.message) {\n        attributes$1['mcp.progress.message'] = String(params.message);\n      }\n      break;\n\n    case 'notifications/resources/updated':\n      if (params?.uri) {\n        attributes$1[attributes.MCP_RESOURCE_URI_ATTRIBUTE] = String(params.uri);\n        const urlObject = url.parseStringToURLObject(String(params.uri));\n        if (urlObject && !url.isURLObjectRelative(urlObject)) {\n          attributes$1['mcp.resource.protocol'] = urlObject.protocol.replace(':', '');\n        }\n      }\n      break;\n\n    case 'notifications/initialized':\n      attributes$1['mcp.lifecycle.phase'] = 'initialization_complete';\n      attributes$1['mcp.protocol.ready'] = 1;\n      break;\n  }\n\n  return attributes$1;\n}\n\n/**\n * Build type-specific attributes based on message type\n * @param type - Span type (request or notification)\n * @param message - JSON-RPC message\n * @param params - Optional parameters for attribute extraction\n * @returns Type-specific attributes for span instrumentation\n */\nfunction buildTypeSpecificAttributes(\n  type,\n  message,\n  params,\n) {\n  if (type === 'request') {\n    const request = message ;\n    const targetInfo = methodConfig.extractTargetInfo(request.method, params || {});\n\n    return {\n      ...(request.id !== undefined && { [attributes.MCP_REQUEST_ID_ATTRIBUTE]: String(request.id) }),\n      ...targetInfo.attributes,\n      ...methodConfig.getRequestArguments(request.method, params || {}),\n    };\n  }\n\n  return getNotificationAttributes(message.method, params || {});\n}\n\nexports.buildTypeSpecificAttributes = buildTypeSpecificAttributes;\nexports.getNotificationAttributes = getNotificationAttributes;\n//# sourceMappingURL=attributeExtraction.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvaW50ZWdyYXRpb25zL21jcC1zZXJ2ZXIvYXR0cmlidXRlRXh0cmFjdGlvbi5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxZQUFZLG1CQUFPLENBQUMsa0lBQW9CO0FBQ3hDLG1CQUFtQixtQkFBTyxDQUFDLHdKQUFpQjtBQUM1QyxxQkFBcUIsbUJBQU8sQ0FBQyw0SkFBbUI7O0FBRWhEO0FBQ0E7QUFDQTs7O0FBR0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFVBQVU7QUFDVjtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGtGQUFrRjs7QUFFbEY7QUFDQSx3Q0FBd0MsMkRBQTJEO0FBQ25HO0FBQ0Esc0VBQXNFO0FBQ3RFO0FBQ0E7O0FBRUEsK0RBQStEO0FBQy9EOztBQUVBLG1DQUFtQztBQUNuQyxpQ0FBaUM7QUFDakMiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvbWNwLXNlcnZlci9hdHRyaWJ1dGVFeHRyYWN0aW9uLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCB1cmwgPSByZXF1aXJlKCcuLi8uLi91dGlscy91cmwuanMnKTtcbmNvbnN0IGF0dHJpYnV0ZXMgPSByZXF1aXJlKCcuL2F0dHJpYnV0ZXMuanMnKTtcbmNvbnN0IG1ldGhvZENvbmZpZyA9IHJlcXVpcmUoJy4vbWV0aG9kQ29uZmlnLmpzJyk7XG5cbi8qKlxuICogQ29yZSBhdHRyaWJ1dGUgZXh0cmFjdGlvbiBhbmQgYnVpbGRpbmcgZnVuY3Rpb25zIGZvciBNQ1Agc2VydmVyIGluc3RydW1lbnRhdGlvblxuICovXG5cblxuLyoqXG4gKiBFeHRyYWN0cyBhZGRpdGlvbmFsIGF0dHJpYnV0ZXMgZm9yIHNwZWNpZmljIG5vdGlmaWNhdGlvbiB0eXBlc1xuICogQHBhcmFtIG1ldGhvZCAtIE5vdGlmaWNhdGlvbiBtZXRob2QgbmFtZVxuICogQHBhcmFtIHBhcmFtcyAtIE5vdGlmaWNhdGlvbiBwYXJhbWV0ZXJzXG4gKiBAcmV0dXJucyBNZXRob2Qtc3BlY2lmaWMgYXR0cmlidXRlcyBmb3Igc3BhbiBpbnN0cnVtZW50YXRpb25cbiAqL1xuZnVuY3Rpb24gZ2V0Tm90aWZpY2F0aW9uQXR0cmlidXRlcyhcbiAgbWV0aG9kLFxuICBwYXJhbXMsXG4pIHtcbiAgY29uc3QgYXR0cmlidXRlcyQxID0ge307XG5cbiAgc3dpdGNoIChtZXRob2QpIHtcbiAgICBjYXNlICdub3RpZmljYXRpb25zL2NhbmNlbGxlZCc6XG4gICAgICBpZiAocGFyYW1zPy5yZXF1ZXN0SWQpIHtcbiAgICAgICAgYXR0cmlidXRlcyQxWydtY3AuY2FuY2VsbGVkLnJlcXVlc3RfaWQnXSA9IFN0cmluZyhwYXJhbXMucmVxdWVzdElkKTtcbiAgICAgIH1cbiAgICAgIGlmIChwYXJhbXM/LnJlYXNvbikge1xuICAgICAgICBhdHRyaWJ1dGVzJDFbJ21jcC5jYW5jZWxsZWQucmVhc29uJ10gPSBTdHJpbmcocGFyYW1zLnJlYXNvbik7XG4gICAgICB9XG4gICAgICBicmVhaztcblxuICAgIGNhc2UgJ25vdGlmaWNhdGlvbnMvbWVzc2FnZSc6XG4gICAgICBpZiAocGFyYW1zPy5sZXZlbCkge1xuICAgICAgICBhdHRyaWJ1dGVzJDFbYXR0cmlidXRlcy5NQ1BfTE9HR0lOR19MRVZFTF9BVFRSSUJVVEVdID0gU3RyaW5nKHBhcmFtcy5sZXZlbCk7XG4gICAgICB9XG4gICAgICBpZiAocGFyYW1zPy5sb2dnZXIpIHtcbiAgICAgICAgYXR0cmlidXRlcyQxW2F0dHJpYnV0ZXMuTUNQX0xPR0dJTkdfTE9HR0VSX0FUVFJJQlVURV0gPSBTdHJpbmcocGFyYW1zLmxvZ2dlcik7XG4gICAgICB9XG4gICAgICBpZiAocGFyYW1zPy5kYXRhICE9PSB1bmRlZmluZWQpIHtcbiAgICAgICAgYXR0cmlidXRlcyQxW2F0dHJpYnV0ZXMuTUNQX0xPR0dJTkdfREFUQV9UWVBFX0FUVFJJQlVURV0gPSB0eXBlb2YgcGFyYW1zLmRhdGE7XG4gICAgICAgIGlmICh0eXBlb2YgcGFyYW1zLmRhdGEgPT09ICdzdHJpbmcnKSB7XG4gICAgICAgICAgYXR0cmlidXRlcyQxW2F0dHJpYnV0ZXMuTUNQX0xPR0dJTkdfTUVTU0FHRV9BVFRSSUJVVEVdID0gcGFyYW1zLmRhdGE7XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgYXR0cmlidXRlcyQxW2F0dHJpYnV0ZXMuTUNQX0xPR0dJTkdfTUVTU0FHRV9BVFRSSUJVVEVdID0gSlNPTi5zdHJpbmdpZnkocGFyYW1zLmRhdGEpO1xuICAgICAgICB9XG4gICAgICB9XG4gICAgICBicmVhaztcblxuICAgIGNhc2UgJ25vdGlmaWNhdGlvbnMvcHJvZ3Jlc3MnOlxuICAgICAgaWYgKHBhcmFtcz8ucHJvZ3Jlc3NUb2tlbikge1xuICAgICAgICBhdHRyaWJ1dGVzJDFbJ21jcC5wcm9ncmVzcy50b2tlbiddID0gU3RyaW5nKHBhcmFtcy5wcm9ncmVzc1Rva2VuKTtcbiAgICAgIH1cbiAgICAgIGlmICh0eXBlb2YgcGFyYW1zPy5wcm9ncmVzcyA9PT0gJ251bWJlcicpIHtcbiAgICAgICAgYXR0cmlidXRlcyQxWydtY3AucHJvZ3Jlc3MuY3VycmVudCddID0gcGFyYW1zLnByb2dyZXNzO1xuICAgICAgfVxuICAgICAgaWYgKHR5cGVvZiBwYXJhbXM/LnRvdGFsID09PSAnbnVtYmVyJykge1xuICAgICAgICBhdHRyaWJ1dGVzJDFbJ21jcC5wcm9ncmVzcy50b3RhbCddID0gcGFyYW1zLnRvdGFsO1xuICAgICAgICBpZiAodHlwZW9mIHBhcmFtcz8ucHJvZ3Jlc3MgPT09ICdudW1iZXInKSB7XG4gICAgICAgICAgYXR0cmlidXRlcyQxWydtY3AucHJvZ3Jlc3MucGVyY2VudGFnZSddID0gKHBhcmFtcy5wcm9ncmVzcyAvIHBhcmFtcy50b3RhbCkgKiAxMDA7XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICAgIGlmIChwYXJhbXM/Lm1lc3NhZ2UpIHtcbiAgICAgICAgYXR0cmlidXRlcyQxWydtY3AucHJvZ3Jlc3MubWVzc2FnZSddID0gU3RyaW5nKHBhcmFtcy5tZXNzYWdlKTtcbiAgICAgIH1cbiAgICAgIGJyZWFrO1xuXG4gICAgY2FzZSAnbm90aWZpY2F0aW9ucy9yZXNvdXJjZXMvdXBkYXRlZCc6XG4gICAgICBpZiAocGFyYW1zPy51cmkpIHtcbiAgICAgICAgYXR0cmlidXRlcyQxW2F0dHJpYnV0ZXMuTUNQX1JFU09VUkNFX1VSSV9BVFRSSUJVVEVdID0gU3RyaW5nKHBhcmFtcy51cmkpO1xuICAgICAgICBjb25zdCB1cmxPYmplY3QgPSB1cmwucGFyc2VTdHJpbmdUb1VSTE9iamVjdChTdHJpbmcocGFyYW1zLnVyaSkpO1xuICAgICAgICBpZiAodXJsT2JqZWN0ICYmICF1cmwuaXNVUkxPYmplY3RSZWxhdGl2ZSh1cmxPYmplY3QpKSB7XG4gICAgICAgICAgYXR0cmlidXRlcyQxWydtY3AucmVzb3VyY2UucHJvdG9jb2wnXSA9IHVybE9iamVjdC5wcm90b2NvbC5yZXBsYWNlKCc6JywgJycpO1xuICAgICAgICB9XG4gICAgICB9XG4gICAgICBicmVhaztcblxuICAgIGNhc2UgJ25vdGlmaWNhdGlvbnMvaW5pdGlhbGl6ZWQnOlxuICAgICAgYXR0cmlidXRlcyQxWydtY3AubGlmZWN5Y2xlLnBoYXNlJ10gPSAnaW5pdGlhbGl6YXRpb25fY29tcGxldGUnO1xuICAgICAgYXR0cmlidXRlcyQxWydtY3AucHJvdG9jb2wucmVhZHknXSA9IDE7XG4gICAgICBicmVhaztcbiAgfVxuXG4gIHJldHVybiBhdHRyaWJ1dGVzJDE7XG59XG5cbi8qKlxuICogQnVpbGQgdHlwZS1zcGVjaWZpYyBhdHRyaWJ1dGVzIGJhc2VkIG9uIG1lc3NhZ2UgdHlwZVxuICogQHBhcmFtIHR5cGUgLSBTcGFuIHR5cGUgKHJlcXVlc3Qgb3Igbm90aWZpY2F0aW9uKVxuICogQHBhcmFtIG1lc3NhZ2UgLSBKU09OLVJQQyBtZXNzYWdlXG4gKiBAcGFyYW0gcGFyYW1zIC0gT3B0aW9uYWwgcGFyYW1ldGVycyBmb3IgYXR0cmlidXRlIGV4dHJhY3Rpb25cbiAqIEByZXR1cm5zIFR5cGUtc3BlY2lmaWMgYXR0cmlidXRlcyBmb3Igc3BhbiBpbnN0cnVtZW50YXRpb25cbiAqL1xuZnVuY3Rpb24gYnVpbGRUeXBlU3BlY2lmaWNBdHRyaWJ1dGVzKFxuICB0eXBlLFxuICBtZXNzYWdlLFxuICBwYXJhbXMsXG4pIHtcbiAgaWYgKHR5cGUgPT09ICdyZXF1ZXN0Jykge1xuICAgIGNvbnN0IHJlcXVlc3QgPSBtZXNzYWdlIDtcbiAgICBjb25zdCB0YXJnZXRJbmZvID0gbWV0aG9kQ29uZmlnLmV4dHJhY3RUYXJnZXRJbmZvKHJlcXVlc3QubWV0aG9kLCBwYXJhbXMgfHwge30pO1xuXG4gICAgcmV0dXJuIHtcbiAgICAgIC4uLihyZXF1ZXN0LmlkICE9PSB1bmRlZmluZWQgJiYgeyBbYXR0cmlidXRlcy5NQ1BfUkVRVUVTVF9JRF9BVFRSSUJVVEVdOiBTdHJpbmcocmVxdWVzdC5pZCkgfSksXG4gICAgICAuLi50YXJnZXRJbmZvLmF0dHJpYnV0ZXMsXG4gICAgICAuLi5tZXRob2RDb25maWcuZ2V0UmVxdWVzdEFyZ3VtZW50cyhyZXF1ZXN0Lm1ldGhvZCwgcGFyYW1zIHx8IHt9KSxcbiAgICB9O1xuICB9XG5cbiAgcmV0dXJuIGdldE5vdGlmaWNhdGlvbkF0dHJpYnV0ZXMobWVzc2FnZS5tZXRob2QsIHBhcmFtcyB8fCB7fSk7XG59XG5cbmV4cG9ydHMuYnVpbGRUeXBlU3BlY2lmaWNBdHRyaWJ1dGVzID0gYnVpbGRUeXBlU3BlY2lmaWNBdHRyaWJ1dGVzO1xuZXhwb3J0cy5nZXROb3RpZmljYXRpb25BdHRyaWJ1dGVzID0gZ2V0Tm90aWZpY2F0aW9uQXR0cmlidXRlcztcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWF0dHJpYnV0ZUV4dHJhY3Rpb24uanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/attributeExtraction.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/attributes.js":
/*!**************************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/attributes.js ***!
  \**************************************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n/**\n * Essential MCP attribute constants for Sentry instrumentation\n *\n * Based on OpenTelemetry MCP semantic conventions\n * @see https://github.com/open-telemetry/semantic-conventions/blob/3097fb0af5b9492b0e3f55dc5f6c21a3dc2be8df/docs/gen-ai/mcp.md\n */\n\n// =============================================================================\n// CORE MCP ATTRIBUTES\n// =============================================================================\n\n/** The name of the request or notification method */\nconst MCP_METHOD_NAME_ATTRIBUTE = 'mcp.method.name';\n\n/** JSON-RPC request identifier for the request. Unique within the MCP session. */\nconst MCP_REQUEST_ID_ATTRIBUTE = 'mcp.request.id';\n\n/** Identifies the MCP session */\nconst MCP_SESSION_ID_ATTRIBUTE = 'mcp.session.id';\n\n/** Transport method used for MCP communication */\nconst MCP_TRANSPORT_ATTRIBUTE = 'mcp.transport';\n\n// =============================================================================\n// SERVER ATTRIBUTES\n// =============================================================================\n\n/** Name of the MCP server application */\nconst MCP_SERVER_NAME_ATTRIBUTE = 'mcp.server.name';\n\n/** Display title of the MCP server application */\nconst MCP_SERVER_TITLE_ATTRIBUTE = 'mcp.server.title';\n\n/** Version of the MCP server application */\nconst MCP_SERVER_VERSION_ATTRIBUTE = 'mcp.server.version';\n\n/** MCP protocol version used in the session */\nconst MCP_PROTOCOL_VERSION_ATTRIBUTE = 'mcp.protocol.version';\n\n// =============================================================================\n// METHOD-SPECIFIC ATTRIBUTES\n// =============================================================================\n\n/** Name of the tool being called */\nconst MCP_TOOL_NAME_ATTRIBUTE = 'mcp.tool.name';\n\n/** The resource URI being accessed */\nconst MCP_RESOURCE_URI_ATTRIBUTE = 'mcp.resource.uri';\n\n/** Name of the prompt template */\nconst MCP_PROMPT_NAME_ATTRIBUTE = 'mcp.prompt.name';\n\n// =============================================================================\n// TOOL RESULT ATTRIBUTES\n// =============================================================================\n\n/** Whether a tool execution resulted in an error */\nconst MCP_TOOL_RESULT_IS_ERROR_ATTRIBUTE = 'mcp.tool.result.is_error';\n\n/** Number of content items in the tool result */\nconst MCP_TOOL_RESULT_CONTENT_COUNT_ATTRIBUTE = 'mcp.tool.result.content_count';\n\n/** Serialized content of the tool result */\nconst MCP_TOOL_RESULT_CONTENT_ATTRIBUTE = 'mcp.tool.result.content';\n\n/** Prefix for tool result attributes that contain sensitive content */\nconst MCP_TOOL_RESULT_PREFIX = 'mcp.tool.result';\n\n// =============================================================================\n// PROMPT RESULT ATTRIBUTES\n// =============================================================================\n\n/** Description of the prompt result */\nconst MCP_PROMPT_RESULT_DESCRIPTION_ATTRIBUTE = 'mcp.prompt.result.description';\n\n/** Number of messages in the prompt result */\nconst MCP_PROMPT_RESULT_MESSAGE_COUNT_ATTRIBUTE = 'mcp.prompt.result.message_count';\n\n/** Content of the message in the prompt result (for single message results) */\nconst MCP_PROMPT_RESULT_MESSAGE_CONTENT_ATTRIBUTE = 'mcp.prompt.result.message_content';\n\n/** Prefix for prompt result attributes that contain sensitive content */\nconst MCP_PROMPT_RESULT_PREFIX = 'mcp.prompt.result';\n\n// =============================================================================\n// REQUEST ARGUMENT ATTRIBUTES\n// =============================================================================\n\n/** Prefix for MCP request argument prefix for each argument */\nconst MCP_REQUEST_ARGUMENT = 'mcp.request.argument';\n\n// =============================================================================\n// LOGGING ATTRIBUTES\n// =============================================================================\n\n/** Log level for MCP logging operations */\nconst MCP_LOGGING_LEVEL_ATTRIBUTE = 'mcp.logging.level';\n\n/** Logger name for MCP logging operations */\nconst MCP_LOGGING_LOGGER_ATTRIBUTE = 'mcp.logging.logger';\n\n/** Data type of the logged message */\nconst MCP_LOGGING_DATA_TYPE_ATTRIBUTE = 'mcp.logging.data_type';\n\n/** Log message content */\nconst MCP_LOGGING_MESSAGE_ATTRIBUTE = 'mcp.logging.message';\n\n// =============================================================================\n// NETWORK ATTRIBUTES (OpenTelemetry Standard)\n// =============================================================================\n\n/** OSI transport layer protocol */\nconst NETWORK_TRANSPORT_ATTRIBUTE = 'network.transport';\n\n/** The version of JSON RPC protocol used */\nconst NETWORK_PROTOCOL_VERSION_ATTRIBUTE = 'network.protocol.version';\n\n/** Client address - domain name if available without reverse DNS lookup; otherwise, IP address or Unix domain socket name */\nconst CLIENT_ADDRESS_ATTRIBUTE = 'client.address';\n\n/** Client port number */\nconst CLIENT_PORT_ATTRIBUTE = 'client.port';\n\n// =============================================================================\n// SENTRY-SPECIFIC MCP ATTRIBUTE VALUES\n// =============================================================================\n\n/** Sentry operation value for MCP server spans */\nconst MCP_SERVER_OP_VALUE = 'mcp.server';\n\n/**\n * Sentry operation value for client-to-server notifications\n * Following OpenTelemetry MCP semantic conventions\n */\nconst MCP_NOTIFICATION_CLIENT_TO_SERVER_OP_VALUE = 'mcp.notification.client_to_server';\n\n/**\n * Sentry operation value for server-to-client notifications\n * Following OpenTelemetry MCP semantic conventions\n */\nconst MCP_NOTIFICATION_SERVER_TO_CLIENT_OP_VALUE = 'mcp.notification.server_to_client';\n\n/** Sentry origin value for MCP function spans */\nconst MCP_FUNCTION_ORIGIN_VALUE = 'auto.function.mcp_server';\n\n/** Sentry origin value for MCP notification spans */\nconst MCP_NOTIFICATION_ORIGIN_VALUE = 'auto.mcp.notification';\n\n/** Sentry source value for MCP route spans */\nconst MCP_ROUTE_SOURCE_VALUE = 'route';\n\nexports.CLIENT_ADDRESS_ATTRIBUTE = CLIENT_ADDRESS_ATTRIBUTE;\nexports.CLIENT_PORT_ATTRIBUTE = CLIENT_PORT_ATTRIBUTE;\nexports.MCP_FUNCTION_ORIGIN_VALUE = MCP_FUNCTION_ORIGIN_VALUE;\nexports.MCP_LOGGING_DATA_TYPE_ATTRIBUTE = MCP_LOGGING_DATA_TYPE_ATTRIBUTE;\nexports.MCP_LOGGING_LEVEL_ATTRIBUTE = MCP_LOGGING_LEVEL_ATTRIBUTE;\nexports.MCP_LOGGING_LOGGER_ATTRIBUTE = MCP_LOGGING_LOGGER_ATTRIBUTE;\nexports.MCP_LOGGING_MESSAGE_ATTRIBUTE = MCP_LOGGING_MESSAGE_ATTRIBUTE;\nexports.MCP_METHOD_NAME_ATTRIBUTE = MCP_METHOD_NAME_ATTRIBUTE;\nexports.MCP_NOTIFICATION_CLIENT_TO_SERVER_OP_VALUE = MCP_NOTIFICATION_CLIENT_TO_SERVER_OP_VALUE;\nexports.MCP_NOTIFICATION_ORIGIN_VALUE = MCP_NOTIFICATION_ORIGIN_VALUE;\nexports.MCP_NOTIFICATION_SERVER_TO_CLIENT_OP_VALUE = MCP_NOTIFICATION_SERVER_TO_CLIENT_OP_VALUE;\nexports.MCP_PROMPT_NAME_ATTRIBUTE = MCP_PROMPT_NAME_ATTRIBUTE;\nexports.MCP_PROMPT_RESULT_DESCRIPTION_ATTRIBUTE = MCP_PROMPT_RESULT_DESCRIPTION_ATTRIBUTE;\nexports.MCP_PROMPT_RESULT_MESSAGE_CONTENT_ATTRIBUTE = MCP_PROMPT_RESULT_MESSAGE_CONTENT_ATTRIBUTE;\nexports.MCP_PROMPT_RESULT_MESSAGE_COUNT_ATTRIBUTE = MCP_PROMPT_RESULT_MESSAGE_COUNT_ATTRIBUTE;\nexports.MCP_PROMPT_RESULT_PREFIX = MCP_PROMPT_RESULT_PREFIX;\nexports.MCP_PROTOCOL_VERSION_ATTRIBUTE = MCP_PROTOCOL_VERSION_ATTRIBUTE;\nexports.MCP_REQUEST_ARGUMENT = MCP_REQUEST_ARGUMENT;\nexports.MCP_REQUEST_ID_ATTRIBUTE = MCP_REQUEST_ID_ATTRIBUTE;\nexports.MCP_RESOURCE_URI_ATTRIBUTE = MCP_RESOURCE_URI_ATTRIBUTE;\nexports.MCP_ROUTE_SOURCE_VALUE = MCP_ROUTE_SOURCE_VALUE;\nexports.MCP_SERVER_NAME_ATTRIBUTE = MCP_SERVER_NAME_ATTRIBUTE;\nexports.MCP_SERVER_OP_VALUE = MCP_SERVER_OP_VALUE;\nexports.MCP_SERVER_TITLE_ATTRIBUTE = MCP_SERVER_TITLE_ATTRIBUTE;\nexports.MCP_SERVER_VERSION_ATTRIBUTE = MCP_SERVER_VERSION_ATTRIBUTE;\nexports.MCP_SESSION_ID_ATTRIBUTE = MCP_SESSION_ID_ATTRIBUTE;\nexports.MCP_TOOL_NAME_ATTRIBUTE = MCP_TOOL_NAME_ATTRIBUTE;\nexports.MCP_TOOL_RESULT_CONTENT_ATTRIBUTE = MCP_TOOL_RESULT_CONTENT_ATTRIBUTE;\nexports.MCP_TOOL_RESULT_CONTENT_COUNT_ATTRIBUTE = MCP_TOOL_RESULT_CONTENT_COUNT_ATTRIBUTE;\nexports.MCP_TOOL_RESULT_IS_ERROR_ATTRIBUTE = MCP_TOOL_RESULT_IS_ERROR_ATTRIBUTE;\nexports.MCP_TOOL_RESULT_PREFIX = MCP_TOOL_RESULT_PREFIX;\nexports.MCP_TRANSPORT_ATTRIBUTE = MCP_TRANSPORT_ATTRIBUTE;\nexports.NETWORK_PROTOCOL_VERSION_ATTRIBUTE = NETWORK_PROTOCOL_VERSION_ATTRIBUTE;\nexports.NETWORK_TRANSPORT_ATTRIBUTE = NETWORK_TRANSPORT_ATTRIBUTE;\n//# sourceMappingURL=attributes.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvaW50ZWdyYXRpb25zL21jcC1zZXJ2ZXIvYXR0cmlidXRlcy5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUEsMEVBQTBFO0FBQzFFOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBOztBQUVBLGdDQUFnQztBQUNoQyw2QkFBNkI7QUFDN0IsaUNBQWlDO0FBQ2pDLHVDQUF1QztBQUN2QyxtQ0FBbUM7QUFDbkMsb0NBQW9DO0FBQ3BDLHFDQUFxQztBQUNyQyxpQ0FBaUM7QUFDakMsa0RBQWtEO0FBQ2xELHFDQUFxQztBQUNyQyxrREFBa0Q7QUFDbEQsaUNBQWlDO0FBQ2pDLCtDQUErQztBQUMvQyxtREFBbUQ7QUFDbkQsaURBQWlEO0FBQ2pELGdDQUFnQztBQUNoQyxzQ0FBc0M7QUFDdEMsNEJBQTRCO0FBQzVCLGdDQUFnQztBQUNoQyxrQ0FBa0M7QUFDbEMsOEJBQThCO0FBQzlCLGlDQUFpQztBQUNqQywyQkFBMkI7QUFDM0Isa0NBQWtDO0FBQ2xDLG9DQUFvQztBQUNwQyxnQ0FBZ0M7QUFDaEMsK0JBQStCO0FBQy9CLHlDQUF5QztBQUN6QywrQ0FBK0M7QUFDL0MsMENBQTBDO0FBQzFDLDhCQUE4QjtBQUM5QiwrQkFBK0I7QUFDL0IsMENBQTBDO0FBQzFDLG1DQUFtQztBQUNuQyIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL2ludGVncmF0aW9ucy9tY3Atc2VydmVyL2F0dHJpYnV0ZXMuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbi8qKlxuICogRXNzZW50aWFsIE1DUCBhdHRyaWJ1dGUgY29uc3RhbnRzIGZvciBTZW50cnkgaW5zdHJ1bWVudGF0aW9uXG4gKlxuICogQmFzZWQgb24gT3BlblRlbGVtZXRyeSBNQ1Agc2VtYW50aWMgY29udmVudGlvbnNcbiAqIEBzZWUgaHR0cHM6Ly9naXRodWIuY29tL29wZW4tdGVsZW1ldHJ5L3NlbWFudGljLWNvbnZlbnRpb25zL2Jsb2IvMzA5N2ZiMGFmNWI5NDkyYjBlM2Y1NWRjNWY2YzIxYTNkYzJiZThkZi9kb2NzL2dlbi1haS9tY3AubWRcbiAqL1xuXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuLy8gQ09SRSBNQ1AgQVRUUklCVVRFU1xuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cblxuLyoqIFRoZSBuYW1lIG9mIHRoZSByZXF1ZXN0IG9yIG5vdGlmaWNhdGlvbiBtZXRob2QgKi9cbmNvbnN0IE1DUF9NRVRIT0RfTkFNRV9BVFRSSUJVVEUgPSAnbWNwLm1ldGhvZC5uYW1lJztcblxuLyoqIEpTT04tUlBDIHJlcXVlc3QgaWRlbnRpZmllciBmb3IgdGhlIHJlcXVlc3QuIFVuaXF1ZSB3aXRoaW4gdGhlIE1DUCBzZXNzaW9uLiAqL1xuY29uc3QgTUNQX1JFUVVFU1RfSURfQVRUUklCVVRFID0gJ21jcC5yZXF1ZXN0LmlkJztcblxuLyoqIElkZW50aWZpZXMgdGhlIE1DUCBzZXNzaW9uICovXG5jb25zdCBNQ1BfU0VTU0lPTl9JRF9BVFRSSUJVVEUgPSAnbWNwLnNlc3Npb24uaWQnO1xuXG4vKiogVHJhbnNwb3J0IG1ldGhvZCB1c2VkIGZvciBNQ1AgY29tbXVuaWNhdGlvbiAqL1xuY29uc3QgTUNQX1RSQU5TUE9SVF9BVFRSSUJVVEUgPSAnbWNwLnRyYW5zcG9ydCc7XG5cbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG4vLyBTRVJWRVIgQVRUUklCVVRFU1xuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cblxuLyoqIE5hbWUgb2YgdGhlIE1DUCBzZXJ2ZXIgYXBwbGljYXRpb24gKi9cbmNvbnN0IE1DUF9TRVJWRVJfTkFNRV9BVFRSSUJVVEUgPSAnbWNwLnNlcnZlci5uYW1lJztcblxuLyoqIERpc3BsYXkgdGl0bGUgb2YgdGhlIE1DUCBzZXJ2ZXIgYXBwbGljYXRpb24gKi9cbmNvbnN0IE1DUF9TRVJWRVJfVElUTEVfQVRUUklCVVRFID0gJ21jcC5zZXJ2ZXIudGl0bGUnO1xuXG4vKiogVmVyc2lvbiBvZiB0aGUgTUNQIHNlcnZlciBhcHBsaWNhdGlvbiAqL1xuY29uc3QgTUNQX1NFUlZFUl9WRVJTSU9OX0FUVFJJQlVURSA9ICdtY3Auc2VydmVyLnZlcnNpb24nO1xuXG4vKiogTUNQIHByb3RvY29sIHZlcnNpb24gdXNlZCBpbiB0aGUgc2Vzc2lvbiAqL1xuY29uc3QgTUNQX1BST1RPQ09MX1ZFUlNJT05fQVRUUklCVVRFID0gJ21jcC5wcm90b2NvbC52ZXJzaW9uJztcblxuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cbi8vIE1FVEhPRC1TUEVDSUZJQyBBVFRSSUJVVEVTXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuXG4vKiogTmFtZSBvZiB0aGUgdG9vbCBiZWluZyBjYWxsZWQgKi9cbmNvbnN0IE1DUF9UT09MX05BTUVfQVRUUklCVVRFID0gJ21jcC50b29sLm5hbWUnO1xuXG4vKiogVGhlIHJlc291cmNlIFVSSSBiZWluZyBhY2Nlc3NlZCAqL1xuY29uc3QgTUNQX1JFU09VUkNFX1VSSV9BVFRSSUJVVEUgPSAnbWNwLnJlc291cmNlLnVyaSc7XG5cbi8qKiBOYW1lIG9mIHRoZSBwcm9tcHQgdGVtcGxhdGUgKi9cbmNvbnN0IE1DUF9QUk9NUFRfTkFNRV9BVFRSSUJVVEUgPSAnbWNwLnByb21wdC5uYW1lJztcblxuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cbi8vIFRPT0wgUkVTVUxUIEFUVFJJQlVURVNcbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG5cbi8qKiBXaGV0aGVyIGEgdG9vbCBleGVjdXRpb24gcmVzdWx0ZWQgaW4gYW4gZXJyb3IgKi9cbmNvbnN0IE1DUF9UT09MX1JFU1VMVF9JU19FUlJPUl9BVFRSSUJVVEUgPSAnbWNwLnRvb2wucmVzdWx0LmlzX2Vycm9yJztcblxuLyoqIE51bWJlciBvZiBjb250ZW50IGl0ZW1zIGluIHRoZSB0b29sIHJlc3VsdCAqL1xuY29uc3QgTUNQX1RPT0xfUkVTVUxUX0NPTlRFTlRfQ09VTlRfQVRUUklCVVRFID0gJ21jcC50b29sLnJlc3VsdC5jb250ZW50X2NvdW50JztcblxuLyoqIFNlcmlhbGl6ZWQgY29udGVudCBvZiB0aGUgdG9vbCByZXN1bHQgKi9cbmNvbnN0IE1DUF9UT09MX1JFU1VMVF9DT05URU5UX0FUVFJJQlVURSA9ICdtY3AudG9vbC5yZXN1bHQuY29udGVudCc7XG5cbi8qKiBQcmVmaXggZm9yIHRvb2wgcmVzdWx0IGF0dHJpYnV0ZXMgdGhhdCBjb250YWluIHNlbnNpdGl2ZSBjb250ZW50ICovXG5jb25zdCBNQ1BfVE9PTF9SRVNVTFRfUFJFRklYID0gJ21jcC50b29sLnJlc3VsdCc7XG5cbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG4vLyBQUk9NUFQgUkVTVUxUIEFUVFJJQlVURVNcbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG5cbi8qKiBEZXNjcmlwdGlvbiBvZiB0aGUgcHJvbXB0IHJlc3VsdCAqL1xuY29uc3QgTUNQX1BST01QVF9SRVNVTFRfREVTQ1JJUFRJT05fQVRUUklCVVRFID0gJ21jcC5wcm9tcHQucmVzdWx0LmRlc2NyaXB0aW9uJztcblxuLyoqIE51bWJlciBvZiBtZXNzYWdlcyBpbiB0aGUgcHJvbXB0IHJlc3VsdCAqL1xuY29uc3QgTUNQX1BST01QVF9SRVNVTFRfTUVTU0FHRV9DT1VOVF9BVFRSSUJVVEUgPSAnbWNwLnByb21wdC5yZXN1bHQubWVzc2FnZV9jb3VudCc7XG5cbi8qKiBDb250ZW50IG9mIHRoZSBtZXNzYWdlIGluIHRoZSBwcm9tcHQgcmVzdWx0IChmb3Igc2luZ2xlIG1lc3NhZ2UgcmVzdWx0cykgKi9cbmNvbnN0IE1DUF9QUk9NUFRfUkVTVUxUX01FU1NBR0VfQ09OVEVOVF9BVFRSSUJVVEUgPSAnbWNwLnByb21wdC5yZXN1bHQubWVzc2FnZV9jb250ZW50JztcblxuLyoqIFByZWZpeCBmb3IgcHJvbXB0IHJlc3VsdCBhdHRyaWJ1dGVzIHRoYXQgY29udGFpbiBzZW5zaXRpdmUgY29udGVudCAqL1xuY29uc3QgTUNQX1BST01QVF9SRVNVTFRfUFJFRklYID0gJ21jcC5wcm9tcHQucmVzdWx0JztcblxuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cbi8vIFJFUVVFU1QgQVJHVU1FTlQgQVRUUklCVVRFU1xuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cblxuLyoqIFByZWZpeCBmb3IgTUNQIHJlcXVlc3QgYXJndW1lbnQgcHJlZml4IGZvciBlYWNoIGFyZ3VtZW50ICovXG5jb25zdCBNQ1BfUkVRVUVTVF9BUkdVTUVOVCA9ICdtY3AucmVxdWVzdC5hcmd1bWVudCc7XG5cbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG4vLyBMT0dHSU5HIEFUVFJJQlVURVNcbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG5cbi8qKiBMb2cgbGV2ZWwgZm9yIE1DUCBsb2dnaW5nIG9wZXJhdGlvbnMgKi9cbmNvbnN0IE1DUF9MT0dHSU5HX0xFVkVMX0FUVFJJQlVURSA9ICdtY3AubG9nZ2luZy5sZXZlbCc7XG5cbi8qKiBMb2dnZXIgbmFtZSBmb3IgTUNQIGxvZ2dpbmcgb3BlcmF0aW9ucyAqL1xuY29uc3QgTUNQX0xPR0dJTkdfTE9HR0VSX0FUVFJJQlVURSA9ICdtY3AubG9nZ2luZy5sb2dnZXInO1xuXG4vKiogRGF0YSB0eXBlIG9mIHRoZSBsb2dnZWQgbWVzc2FnZSAqL1xuY29uc3QgTUNQX0xPR0dJTkdfREFUQV9UWVBFX0FUVFJJQlVURSA9ICdtY3AubG9nZ2luZy5kYXRhX3R5cGUnO1xuXG4vKiogTG9nIG1lc3NhZ2UgY29udGVudCAqL1xuY29uc3QgTUNQX0xPR0dJTkdfTUVTU0FHRV9BVFRSSUJVVEUgPSAnbWNwLmxvZ2dpbmcubWVzc2FnZSc7XG5cbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG4vLyBORVRXT1JLIEFUVFJJQlVURVMgKE9wZW5UZWxlbWV0cnkgU3RhbmRhcmQpXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuXG4vKiogT1NJIHRyYW5zcG9ydCBsYXllciBwcm90b2NvbCAqL1xuY29uc3QgTkVUV09SS19UUkFOU1BPUlRfQVRUUklCVVRFID0gJ25ldHdvcmsudHJhbnNwb3J0JztcblxuLyoqIFRoZSB2ZXJzaW9uIG9mIEpTT04gUlBDIHByb3RvY29sIHVzZWQgKi9cbmNvbnN0IE5FVFdPUktfUFJPVE9DT0xfVkVSU0lPTl9BVFRSSUJVVEUgPSAnbmV0d29yay5wcm90b2NvbC52ZXJzaW9uJztcblxuLyoqIENsaWVudCBhZGRyZXNzIC0gZG9tYWluIG5hbWUgaWYgYXZhaWxhYmxlIHdpdGhvdXQgcmV2ZXJzZSBETlMgbG9va3VwOyBvdGhlcndpc2UsIElQIGFkZHJlc3Mgb3IgVW5peCBkb21haW4gc29ja2V0IG5hbWUgKi9cbmNvbnN0IENMSUVOVF9BRERSRVNTX0FUVFJJQlVURSA9ICdjbGllbnQuYWRkcmVzcyc7XG5cbi8qKiBDbGllbnQgcG9ydCBudW1iZXIgKi9cbmNvbnN0IENMSUVOVF9QT1JUX0FUVFJJQlVURSA9ICdjbGllbnQucG9ydCc7XG5cbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG4vLyBTRU5UUlktU1BFQ0lGSUMgTUNQIEFUVFJJQlVURSBWQUxVRVNcbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG5cbi8qKiBTZW50cnkgb3BlcmF0aW9uIHZhbHVlIGZvciBNQ1Agc2VydmVyIHNwYW5zICovXG5jb25zdCBNQ1BfU0VSVkVSX09QX1ZBTFVFID0gJ21jcC5zZXJ2ZXInO1xuXG4vKipcbiAqIFNlbnRyeSBvcGVyYXRpb24gdmFsdWUgZm9yIGNsaWVudC10by1zZXJ2ZXIgbm90aWZpY2F0aW9uc1xuICogRm9sbG93aW5nIE9wZW5UZWxlbWV0cnkgTUNQIHNlbWFudGljIGNvbnZlbnRpb25zXG4gKi9cbmNvbnN0IE1DUF9OT1RJRklDQVRJT05fQ0xJRU5UX1RPX1NFUlZFUl9PUF9WQUxVRSA9ICdtY3Aubm90aWZpY2F0aW9uLmNsaWVudF90b19zZXJ2ZXInO1xuXG4vKipcbiAqIFNlbnRyeSBvcGVyYXRpb24gdmFsdWUgZm9yIHNlcnZlci10by1jbGllbnQgbm90aWZpY2F0aW9uc1xuICogRm9sbG93aW5nIE9wZW5UZWxlbWV0cnkgTUNQIHNlbWFudGljIGNvbnZlbnRpb25zXG4gKi9cbmNvbnN0IE1DUF9OT1RJRklDQVRJT05fU0VSVkVSX1RPX0NMSUVOVF9PUF9WQUxVRSA9ICdtY3Aubm90aWZpY2F0aW9uLnNlcnZlcl90b19jbGllbnQnO1xuXG4vKiogU2VudHJ5IG9yaWdpbiB2YWx1ZSBmb3IgTUNQIGZ1bmN0aW9uIHNwYW5zICovXG5jb25zdCBNQ1BfRlVOQ1RJT05fT1JJR0lOX1ZBTFVFID0gJ2F1dG8uZnVuY3Rpb24ubWNwX3NlcnZlcic7XG5cbi8qKiBTZW50cnkgb3JpZ2luIHZhbHVlIGZvciBNQ1Agbm90aWZpY2F0aW9uIHNwYW5zICovXG5jb25zdCBNQ1BfTk9USUZJQ0FUSU9OX09SSUdJTl9WQUxVRSA9ICdhdXRvLm1jcC5ub3RpZmljYXRpb24nO1xuXG4vKiogU2VudHJ5IHNvdXJjZSB2YWx1ZSBmb3IgTUNQIHJvdXRlIHNwYW5zICovXG5jb25zdCBNQ1BfUk9VVEVfU09VUkNFX1ZBTFVFID0gJ3JvdXRlJztcblxuZXhwb3J0cy5DTElFTlRfQUREUkVTU19BVFRSSUJVVEUgPSBDTElFTlRfQUREUkVTU19BVFRSSUJVVEU7XG5leHBvcnRzLkNMSUVOVF9QT1JUX0FUVFJJQlVURSA9IENMSUVOVF9QT1JUX0FUVFJJQlVURTtcbmV4cG9ydHMuTUNQX0ZVTkNUSU9OX09SSUdJTl9WQUxVRSA9IE1DUF9GVU5DVElPTl9PUklHSU5fVkFMVUU7XG5leHBvcnRzLk1DUF9MT0dHSU5HX0RBVEFfVFlQRV9BVFRSSUJVVEUgPSBNQ1BfTE9HR0lOR19EQVRBX1RZUEVfQVRUUklCVVRFO1xuZXhwb3J0cy5NQ1BfTE9HR0lOR19MRVZFTF9BVFRSSUJVVEUgPSBNQ1BfTE9HR0lOR19MRVZFTF9BVFRSSUJVVEU7XG5leHBvcnRzLk1DUF9MT0dHSU5HX0xPR0dFUl9BVFRSSUJVVEUgPSBNQ1BfTE9HR0lOR19MT0dHRVJfQVRUUklCVVRFO1xuZXhwb3J0cy5NQ1BfTE9HR0lOR19NRVNTQUdFX0FUVFJJQlVURSA9IE1DUF9MT0dHSU5HX01FU1NBR0VfQVRUUklCVVRFO1xuZXhwb3J0cy5NQ1BfTUVUSE9EX05BTUVfQVRUUklCVVRFID0gTUNQX01FVEhPRF9OQU1FX0FUVFJJQlVURTtcbmV4cG9ydHMuTUNQX05PVElGSUNBVElPTl9DTElFTlRfVE9fU0VSVkVSX09QX1ZBTFVFID0gTUNQX05PVElGSUNBVElPTl9DTElFTlRfVE9fU0VSVkVSX09QX1ZBTFVFO1xuZXhwb3J0cy5NQ1BfTk9USUZJQ0FUSU9OX09SSUdJTl9WQUxVRSA9IE1DUF9OT1RJRklDQVRJT05fT1JJR0lOX1ZBTFVFO1xuZXhwb3J0cy5NQ1BfTk9USUZJQ0FUSU9OX1NFUlZFUl9UT19DTElFTlRfT1BfVkFMVUUgPSBNQ1BfTk9USUZJQ0FUSU9OX1NFUlZFUl9UT19DTElFTlRfT1BfVkFMVUU7XG5leHBvcnRzLk1DUF9QUk9NUFRfTkFNRV9BVFRSSUJVVEUgPSBNQ1BfUFJPTVBUX05BTUVfQVRUUklCVVRFO1xuZXhwb3J0cy5NQ1BfUFJPTVBUX1JFU1VMVF9ERVNDUklQVElPTl9BVFRSSUJVVEUgPSBNQ1BfUFJPTVBUX1JFU1VMVF9ERVNDUklQVElPTl9BVFRSSUJVVEU7XG5leHBvcnRzLk1DUF9QUk9NUFRfUkVTVUxUX01FU1NBR0VfQ09OVEVOVF9BVFRSSUJVVEUgPSBNQ1BfUFJPTVBUX1JFU1VMVF9NRVNTQUdFX0NPTlRFTlRfQVRUUklCVVRFO1xuZXhwb3J0cy5NQ1BfUFJPTVBUX1JFU1VMVF9NRVNTQUdFX0NPVU5UX0FUVFJJQlVURSA9IE1DUF9QUk9NUFRfUkVTVUxUX01FU1NBR0VfQ09VTlRfQVRUUklCVVRFO1xuZXhwb3J0cy5NQ1BfUFJPTVBUX1JFU1VMVF9QUkVGSVggPSBNQ1BfUFJPTVBUX1JFU1VMVF9QUkVGSVg7XG5leHBvcnRzLk1DUF9QUk9UT0NPTF9WRVJTSU9OX0FUVFJJQlVURSA9IE1DUF9QUk9UT0NPTF9WRVJTSU9OX0FUVFJJQlVURTtcbmV4cG9ydHMuTUNQX1JFUVVFU1RfQVJHVU1FTlQgPSBNQ1BfUkVRVUVTVF9BUkdVTUVOVDtcbmV4cG9ydHMuTUNQX1JFUVVFU1RfSURfQVRUUklCVVRFID0gTUNQX1JFUVVFU1RfSURfQVRUUklCVVRFO1xuZXhwb3J0cy5NQ1BfUkVTT1VSQ0VfVVJJX0FUVFJJQlVURSA9IE1DUF9SRVNPVVJDRV9VUklfQVRUUklCVVRFO1xuZXhwb3J0cy5NQ1BfUk9VVEVfU09VUkNFX1ZBTFVFID0gTUNQX1JPVVRFX1NPVVJDRV9WQUxVRTtcbmV4cG9ydHMuTUNQX1NFUlZFUl9OQU1FX0FUVFJJQlVURSA9IE1DUF9TRVJWRVJfTkFNRV9BVFRSSUJVVEU7XG5leHBvcnRzLk1DUF9TRVJWRVJfT1BfVkFMVUUgPSBNQ1BfU0VSVkVSX09QX1ZBTFVFO1xuZXhwb3J0cy5NQ1BfU0VSVkVSX1RJVExFX0FUVFJJQlVURSA9IE1DUF9TRVJWRVJfVElUTEVfQVRUUklCVVRFO1xuZXhwb3J0cy5NQ1BfU0VSVkVSX1ZFUlNJT05fQVRUUklCVVRFID0gTUNQX1NFUlZFUl9WRVJTSU9OX0FUVFJJQlVURTtcbmV4cG9ydHMuTUNQX1NFU1NJT05fSURfQVRUUklCVVRFID0gTUNQX1NFU1NJT05fSURfQVRUUklCVVRFO1xuZXhwb3J0cy5NQ1BfVE9PTF9OQU1FX0FUVFJJQlVURSA9IE1DUF9UT09MX05BTUVfQVRUUklCVVRFO1xuZXhwb3J0cy5NQ1BfVE9PTF9SRVNVTFRfQ09OVEVOVF9BVFRSSUJVVEUgPSBNQ1BfVE9PTF9SRVNVTFRfQ09OVEVOVF9BVFRSSUJVVEU7XG5leHBvcnRzLk1DUF9UT09MX1JFU1VMVF9DT05URU5UX0NPVU5UX0FUVFJJQlVURSA9IE1DUF9UT09MX1JFU1VMVF9DT05URU5UX0NPVU5UX0FUVFJJQlVURTtcbmV4cG9ydHMuTUNQX1RPT0xfUkVTVUxUX0lTX0VSUk9SX0FUVFJJQlVURSA9IE1DUF9UT09MX1JFU1VMVF9JU19FUlJPUl9BVFRSSUJVVEU7XG5leHBvcnRzLk1DUF9UT09MX1JFU1VMVF9QUkVGSVggPSBNQ1BfVE9PTF9SRVNVTFRfUFJFRklYO1xuZXhwb3J0cy5NQ1BfVFJBTlNQT1JUX0FUVFJJQlVURSA9IE1DUF9UUkFOU1BPUlRfQVRUUklCVVRFO1xuZXhwb3J0cy5ORVRXT1JLX1BST1RPQ09MX1ZFUlNJT05fQVRUUklCVVRFID0gTkVUV09SS19QUk9UT0NPTF9WRVJTSU9OX0FUVFJJQlVURTtcbmV4cG9ydHMuTkVUV09SS19UUkFOU1BPUlRfQVRUUklCVVRFID0gTkVUV09SS19UUkFOU1BPUlRfQVRUUklCVVRFO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9YXR0cmlidXRlcy5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/attributes.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/correlation.js":
/*!***************************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/correlation.js ***!
  \***************************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst currentScopes = __webpack_require__(/*! ../../currentScopes.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst spanstatus = __webpack_require__(/*! ../../tracing/spanstatus.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/spanstatus.js\");\nconst piiFiltering = __webpack_require__(/*! ./piiFiltering.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/piiFiltering.js\");\nconst resultExtraction = __webpack_require__(/*! ./resultExtraction.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/resultExtraction.js\");\n\n/**\n * Request-span correlation system for MCP server instrumentation\n *\n * Handles mapping requestId to span data for correlation with handler execution.\n * Uses WeakMap to scope correlation maps per transport instance, preventing\n * request ID collisions between different MCP sessions.\n */\n\n\n/**\n * Transport-scoped correlation system that prevents collisions between different MCP sessions\n * @internal Each transport instance gets its own correlation map, eliminating request ID conflicts\n */\nconst transportToSpanMap = new WeakMap();\n\n/**\n * Gets or creates the span map for a specific transport instance\n * @internal\n * @param transport - MCP transport instance\n * @returns Span map for the transport\n */\nfunction getOrCreateSpanMap(transport) {\n  let spanMap = transportToSpanMap.get(transport);\n  if (!spanMap) {\n    spanMap = new Map();\n    transportToSpanMap.set(transport, spanMap);\n  }\n  return spanMap;\n}\n\n/**\n * Stores span context for later correlation with handler execution\n * @param transport - MCP transport instance\n * @param requestId - Request identifier\n * @param span - Active span to correlate\n * @param method - MCP method name\n */\nfunction storeSpanForRequest(transport, requestId, span, method) {\n  const spanMap = getOrCreateSpanMap(transport);\n  spanMap.set(requestId, {\n    span,\n    method,\n    startTime: Date.now(),\n  });\n}\n\n/**\n * Completes span with tool results and cleans up correlation\n * @param transport - MCP transport instance\n * @param requestId - Request identifier\n * @param result - Tool execution result for attribute extraction\n */\nfunction completeSpanWithResults(transport, requestId, result) {\n  const spanMap = getOrCreateSpanMap(transport);\n  const spanData = spanMap.get(requestId);\n  if (spanData) {\n    const { span, method } = spanData;\n\n    if (method === 'tools/call') {\n      const rawToolAttributes = resultExtraction.extractToolResultAttributes(result);\n      const client = currentScopes.getClient();\n      const sendDefaultPii = Boolean(client?.getOptions().sendDefaultPii);\n      const toolAttributes = piiFiltering.filterMcpPiiFromSpanData(rawToolAttributes, sendDefaultPii);\n\n      span.setAttributes(toolAttributes);\n    } else if (method === 'prompts/get') {\n      const rawPromptAttributes = resultExtraction.extractPromptResultAttributes(result);\n      const client = currentScopes.getClient();\n      const sendDefaultPii = Boolean(client?.getOptions().sendDefaultPii);\n      const promptAttributes = piiFiltering.filterMcpPiiFromSpanData(rawPromptAttributes, sendDefaultPii);\n\n      span.setAttributes(promptAttributes);\n    }\n\n    span.end();\n    spanMap.delete(requestId);\n  }\n}\n\n/**\n * Cleans up pending spans for a specific transport (when that transport closes)\n * @param transport - MCP transport instance\n * @returns Number of pending spans that were cleaned up\n */\nfunction cleanupPendingSpansForTransport(transport) {\n  const spanMap = transportToSpanMap.get(transport);\n  if (!spanMap) {\n    return 0;\n  }\n\n  const pendingCount = spanMap.size;\n\n  for (const [, spanData] of spanMap) {\n    spanData.span.setStatus({\n      code: spanstatus.SPAN_STATUS_ERROR,\n      message: 'cancelled',\n    });\n    spanData.span.end();\n  }\n\n  spanMap.clear();\n  return pendingCount;\n}\n\nexports.cleanupPendingSpansForTransport = cleanupPendingSpansForTransport;\nexports.completeSpanWithResults = completeSpanWithResults;\nexports.storeSpanForRequest = storeSpanForRequest;\n//# sourceMappingURL=correlation.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvaW50ZWdyYXRpb25zL21jcC1zZXJ2ZXIvY29ycmVsYXRpb24uanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsc0JBQXNCLG1CQUFPLENBQUMsMElBQXdCO0FBQ3RELG1CQUFtQixtQkFBTyxDQUFDLG9KQUE2QjtBQUN4RCxxQkFBcUIsbUJBQU8sQ0FBQyw0SkFBbUI7QUFDaEQseUJBQXlCLG1CQUFPLENBQUMsb0tBQXVCOztBQUV4RDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7O0FBR0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsR0FBRztBQUNIOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsWUFBWSxlQUFlOztBQUUzQjtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0EsTUFBTTtBQUNOO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQSxLQUFLO0FBQ0w7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUEsdUNBQXVDO0FBQ3ZDLCtCQUErQjtBQUMvQiwyQkFBMkI7QUFDM0IiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvbWNwLXNlcnZlci9jb3JyZWxhdGlvbi5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgY3VycmVudFNjb3BlcyA9IHJlcXVpcmUoJy4uLy4uL2N1cnJlbnRTY29wZXMuanMnKTtcbmNvbnN0IHNwYW5zdGF0dXMgPSByZXF1aXJlKCcuLi8uLi90cmFjaW5nL3NwYW5zdGF0dXMuanMnKTtcbmNvbnN0IHBpaUZpbHRlcmluZyA9IHJlcXVpcmUoJy4vcGlpRmlsdGVyaW5nLmpzJyk7XG5jb25zdCByZXN1bHRFeHRyYWN0aW9uID0gcmVxdWlyZSgnLi9yZXN1bHRFeHRyYWN0aW9uLmpzJyk7XG5cbi8qKlxuICogUmVxdWVzdC1zcGFuIGNvcnJlbGF0aW9uIHN5c3RlbSBmb3IgTUNQIHNlcnZlciBpbnN0cnVtZW50YXRpb25cbiAqXG4gKiBIYW5kbGVzIG1hcHBpbmcgcmVxdWVzdElkIHRvIHNwYW4gZGF0YSBmb3IgY29ycmVsYXRpb24gd2l0aCBoYW5kbGVyIGV4ZWN1dGlvbi5cbiAqIFVzZXMgV2Vha01hcCB0byBzY29wZSBjb3JyZWxhdGlvbiBtYXBzIHBlciB0cmFuc3BvcnQgaW5zdGFuY2UsIHByZXZlbnRpbmdcbiAqIHJlcXVlc3QgSUQgY29sbGlzaW9ucyBiZXR3ZWVuIGRpZmZlcmVudCBNQ1Agc2Vzc2lvbnMuXG4gKi9cblxuXG4vKipcbiAqIFRyYW5zcG9ydC1zY29wZWQgY29ycmVsYXRpb24gc3lzdGVtIHRoYXQgcHJldmVudHMgY29sbGlzaW9ucyBiZXR3ZWVuIGRpZmZlcmVudCBNQ1Agc2Vzc2lvbnNcbiAqIEBpbnRlcm5hbCBFYWNoIHRyYW5zcG9ydCBpbnN0YW5jZSBnZXRzIGl0cyBvd24gY29ycmVsYXRpb24gbWFwLCBlbGltaW5hdGluZyByZXF1ZXN0IElEIGNvbmZsaWN0c1xuICovXG5jb25zdCB0cmFuc3BvcnRUb1NwYW5NYXAgPSBuZXcgV2Vha01hcCgpO1xuXG4vKipcbiAqIEdldHMgb3IgY3JlYXRlcyB0aGUgc3BhbiBtYXAgZm9yIGEgc3BlY2lmaWMgdHJhbnNwb3J0IGluc3RhbmNlXG4gKiBAaW50ZXJuYWxcbiAqIEBwYXJhbSB0cmFuc3BvcnQgLSBNQ1AgdHJhbnNwb3J0IGluc3RhbmNlXG4gKiBAcmV0dXJucyBTcGFuIG1hcCBmb3IgdGhlIHRyYW5zcG9ydFxuICovXG5mdW5jdGlvbiBnZXRPckNyZWF0ZVNwYW5NYXAodHJhbnNwb3J0KSB7XG4gIGxldCBzcGFuTWFwID0gdHJhbnNwb3J0VG9TcGFuTWFwLmdldCh0cmFuc3BvcnQpO1xuICBpZiAoIXNwYW5NYXApIHtcbiAgICBzcGFuTWFwID0gbmV3IE1hcCgpO1xuICAgIHRyYW5zcG9ydFRvU3Bhbk1hcC5zZXQodHJhbnNwb3J0LCBzcGFuTWFwKTtcbiAgfVxuICByZXR1cm4gc3Bhbk1hcDtcbn1cblxuLyoqXG4gKiBTdG9yZXMgc3BhbiBjb250ZXh0IGZvciBsYXRlciBjb3JyZWxhdGlvbiB3aXRoIGhhbmRsZXIgZXhlY3V0aW9uXG4gKiBAcGFyYW0gdHJhbnNwb3J0IC0gTUNQIHRyYW5zcG9ydCBpbnN0YW5jZVxuICogQHBhcmFtIHJlcXVlc3RJZCAtIFJlcXVlc3QgaWRlbnRpZmllclxuICogQHBhcmFtIHNwYW4gLSBBY3RpdmUgc3BhbiB0byBjb3JyZWxhdGVcbiAqIEBwYXJhbSBtZXRob2QgLSBNQ1AgbWV0aG9kIG5hbWVcbiAqL1xuZnVuY3Rpb24gc3RvcmVTcGFuRm9yUmVxdWVzdCh0cmFuc3BvcnQsIHJlcXVlc3RJZCwgc3BhbiwgbWV0aG9kKSB7XG4gIGNvbnN0IHNwYW5NYXAgPSBnZXRPckNyZWF0ZVNwYW5NYXAodHJhbnNwb3J0KTtcbiAgc3Bhbk1hcC5zZXQocmVxdWVzdElkLCB7XG4gICAgc3BhbixcbiAgICBtZXRob2QsXG4gICAgc3RhcnRUaW1lOiBEYXRlLm5vdygpLFxuICB9KTtcbn1cblxuLyoqXG4gKiBDb21wbGV0ZXMgc3BhbiB3aXRoIHRvb2wgcmVzdWx0cyBhbmQgY2xlYW5zIHVwIGNvcnJlbGF0aW9uXG4gKiBAcGFyYW0gdHJhbnNwb3J0IC0gTUNQIHRyYW5zcG9ydCBpbnN0YW5jZVxuICogQHBhcmFtIHJlcXVlc3RJZCAtIFJlcXVlc3QgaWRlbnRpZmllclxuICogQHBhcmFtIHJlc3VsdCAtIFRvb2wgZXhlY3V0aW9uIHJlc3VsdCBmb3IgYXR0cmlidXRlIGV4dHJhY3Rpb25cbiAqL1xuZnVuY3Rpb24gY29tcGxldGVTcGFuV2l0aFJlc3VsdHModHJhbnNwb3J0LCByZXF1ZXN0SWQsIHJlc3VsdCkge1xuICBjb25zdCBzcGFuTWFwID0gZ2V0T3JDcmVhdGVTcGFuTWFwKHRyYW5zcG9ydCk7XG4gIGNvbnN0IHNwYW5EYXRhID0gc3Bhbk1hcC5nZXQocmVxdWVzdElkKTtcbiAgaWYgKHNwYW5EYXRhKSB7XG4gICAgY29uc3QgeyBzcGFuLCBtZXRob2QgfSA9IHNwYW5EYXRhO1xuXG4gICAgaWYgKG1ldGhvZCA9PT0gJ3Rvb2xzL2NhbGwnKSB7XG4gICAgICBjb25zdCByYXdUb29sQXR0cmlidXRlcyA9IHJlc3VsdEV4dHJhY3Rpb24uZXh0cmFjdFRvb2xSZXN1bHRBdHRyaWJ1dGVzKHJlc3VsdCk7XG4gICAgICBjb25zdCBjbGllbnQgPSBjdXJyZW50U2NvcGVzLmdldENsaWVudCgpO1xuICAgICAgY29uc3Qgc2VuZERlZmF1bHRQaWkgPSBCb29sZWFuKGNsaWVudD8uZ2V0T3B0aW9ucygpLnNlbmREZWZhdWx0UGlpKTtcbiAgICAgIGNvbnN0IHRvb2xBdHRyaWJ1dGVzID0gcGlpRmlsdGVyaW5nLmZpbHRlck1jcFBpaUZyb21TcGFuRGF0YShyYXdUb29sQXR0cmlidXRlcywgc2VuZERlZmF1bHRQaWkpO1xuXG4gICAgICBzcGFuLnNldEF0dHJpYnV0ZXModG9vbEF0dHJpYnV0ZXMpO1xuICAgIH0gZWxzZSBpZiAobWV0aG9kID09PSAncHJvbXB0cy9nZXQnKSB7XG4gICAgICBjb25zdCByYXdQcm9tcHRBdHRyaWJ1dGVzID0gcmVzdWx0RXh0cmFjdGlvbi5leHRyYWN0UHJvbXB0UmVzdWx0QXR0cmlidXRlcyhyZXN1bHQpO1xuICAgICAgY29uc3QgY2xpZW50ID0gY3VycmVudFNjb3Blcy5nZXRDbGllbnQoKTtcbiAgICAgIGNvbnN0IHNlbmREZWZhdWx0UGlpID0gQm9vbGVhbihjbGllbnQ/LmdldE9wdGlvbnMoKS5zZW5kRGVmYXVsdFBpaSk7XG4gICAgICBjb25zdCBwcm9tcHRBdHRyaWJ1dGVzID0gcGlpRmlsdGVyaW5nLmZpbHRlck1jcFBpaUZyb21TcGFuRGF0YShyYXdQcm9tcHRBdHRyaWJ1dGVzLCBzZW5kRGVmYXVsdFBpaSk7XG5cbiAgICAgIHNwYW4uc2V0QXR0cmlidXRlcyhwcm9tcHRBdHRyaWJ1dGVzKTtcbiAgICB9XG5cbiAgICBzcGFuLmVuZCgpO1xuICAgIHNwYW5NYXAuZGVsZXRlKHJlcXVlc3RJZCk7XG4gIH1cbn1cblxuLyoqXG4gKiBDbGVhbnMgdXAgcGVuZGluZyBzcGFucyBmb3IgYSBzcGVjaWZpYyB0cmFuc3BvcnQgKHdoZW4gdGhhdCB0cmFuc3BvcnQgY2xvc2VzKVxuICogQHBhcmFtIHRyYW5zcG9ydCAtIE1DUCB0cmFuc3BvcnQgaW5zdGFuY2VcbiAqIEByZXR1cm5zIE51bWJlciBvZiBwZW5kaW5nIHNwYW5zIHRoYXQgd2VyZSBjbGVhbmVkIHVwXG4gKi9cbmZ1bmN0aW9uIGNsZWFudXBQZW5kaW5nU3BhbnNGb3JUcmFuc3BvcnQodHJhbnNwb3J0KSB7XG4gIGNvbnN0IHNwYW5NYXAgPSB0cmFuc3BvcnRUb1NwYW5NYXAuZ2V0KHRyYW5zcG9ydCk7XG4gIGlmICghc3Bhbk1hcCkge1xuICAgIHJldHVybiAwO1xuICB9XG5cbiAgY29uc3QgcGVuZGluZ0NvdW50ID0gc3Bhbk1hcC5zaXplO1xuXG4gIGZvciAoY29uc3QgWywgc3BhbkRhdGFdIG9mIHNwYW5NYXApIHtcbiAgICBzcGFuRGF0YS5zcGFuLnNldFN0YXR1cyh7XG4gICAgICBjb2RlOiBzcGFuc3RhdHVzLlNQQU5fU1RBVFVTX0VSUk9SLFxuICAgICAgbWVzc2FnZTogJ2NhbmNlbGxlZCcsXG4gICAgfSk7XG4gICAgc3BhbkRhdGEuc3Bhbi5lbmQoKTtcbiAgfVxuXG4gIHNwYW5NYXAuY2xlYXIoKTtcbiAgcmV0dXJuIHBlbmRpbmdDb3VudDtcbn1cblxuZXhwb3J0cy5jbGVhbnVwUGVuZGluZ1NwYW5zRm9yVHJhbnNwb3J0ID0gY2xlYW51cFBlbmRpbmdTcGFuc0ZvclRyYW5zcG9ydDtcbmV4cG9ydHMuY29tcGxldGVTcGFuV2l0aFJlc3VsdHMgPSBjb21wbGV0ZVNwYW5XaXRoUmVzdWx0cztcbmV4cG9ydHMuc3RvcmVTcGFuRm9yUmVxdWVzdCA9IHN0b3JlU3BhbkZvclJlcXVlc3Q7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1jb3JyZWxhdGlvbi5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/correlation.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/errorCapture.js":
/*!****************************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/errorCapture.js ***!
  \****************************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst currentScopes = __webpack_require__(/*! ../../currentScopes.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst exports$1 = __webpack_require__(/*! ../../exports.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/exports.js\");\nconst spanUtils = __webpack_require__(/*! ../../utils/spanUtils.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanUtils.js\");\nconst spanstatus = __webpack_require__(/*! ../../tracing/spanstatus.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/spanstatus.js\");\n\n/**\n * Safe error capture utilities for MCP server instrumentation\n *\n * Ensures error reporting never interferes with MCP server operation.\n * All capture operations are wrapped in try-catch to prevent side effects.\n */\n\n\n/**\n * Captures an error without affecting MCP server operation.\n *\n * The active span already contains all MCP context (method, tool, arguments, etc.)\n * @param error - Error to capture\n * @param errorType - Classification of error type for filtering\n * @param extraData - Additional context data to include\n */\nfunction captureError(error, errorType, extraData) {\n  try {\n    const client = currentScopes.getClient();\n    if (!client) {\n      return;\n    }\n\n    const activeSpan = spanUtils.getActiveSpan();\n    if (activeSpan?.isRecording()) {\n      activeSpan.setStatus({\n        code: spanstatus.SPAN_STATUS_ERROR,\n        message: 'internal_error',\n      });\n    }\n\n    exports$1.captureException(error, {\n      mechanism: {\n        type: 'mcp_server',\n        handled: false,\n        data: {\n          error_type: errorType || 'handler_execution',\n          ...extraData,\n        },\n      },\n    });\n  } catch {\n    // noop\n  }\n}\n\nexports.captureError = captureError;\n//# sourceMappingURL=errorCapture.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvaW50ZWdyYXRpb25zL21jcC1zZXJ2ZXIvZXJyb3JDYXB0dXJlLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLHNCQUFzQixtQkFBTyxDQUFDLDBJQUF3QjtBQUN0RCxrQkFBa0IsbUJBQU8sQ0FBQyw4SEFBa0I7QUFDNUMsa0JBQWtCLG1CQUFPLENBQUMsOElBQTBCO0FBQ3BELG1CQUFtQixtQkFBTyxDQUFDLG9KQUE2Qjs7QUFFeEQ7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOzs7QUFHQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxPQUFPO0FBQ1A7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxTQUFTO0FBQ1QsT0FBTztBQUNQLEtBQUs7QUFDTCxJQUFJO0FBQ0o7QUFDQTtBQUNBOztBQUVBLG9CQUFvQjtBQUNwQiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL2ludGVncmF0aW9ucy9tY3Atc2VydmVyL2Vycm9yQ2FwdHVyZS5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgY3VycmVudFNjb3BlcyA9IHJlcXVpcmUoJy4uLy4uL2N1cnJlbnRTY29wZXMuanMnKTtcbmNvbnN0IGV4cG9ydHMkMSA9IHJlcXVpcmUoJy4uLy4uL2V4cG9ydHMuanMnKTtcbmNvbnN0IHNwYW5VdGlscyA9IHJlcXVpcmUoJy4uLy4uL3V0aWxzL3NwYW5VdGlscy5qcycpO1xuY29uc3Qgc3BhbnN0YXR1cyA9IHJlcXVpcmUoJy4uLy4uL3RyYWNpbmcvc3BhbnN0YXR1cy5qcycpO1xuXG4vKipcbiAqIFNhZmUgZXJyb3IgY2FwdHVyZSB1dGlsaXRpZXMgZm9yIE1DUCBzZXJ2ZXIgaW5zdHJ1bWVudGF0aW9uXG4gKlxuICogRW5zdXJlcyBlcnJvciByZXBvcnRpbmcgbmV2ZXIgaW50ZXJmZXJlcyB3aXRoIE1DUCBzZXJ2ZXIgb3BlcmF0aW9uLlxuICogQWxsIGNhcHR1cmUgb3BlcmF0aW9ucyBhcmUgd3JhcHBlZCBpbiB0cnktY2F0Y2ggdG8gcHJldmVudCBzaWRlIGVmZmVjdHMuXG4gKi9cblxuXG4vKipcbiAqIENhcHR1cmVzIGFuIGVycm9yIHdpdGhvdXQgYWZmZWN0aW5nIE1DUCBzZXJ2ZXIgb3BlcmF0aW9uLlxuICpcbiAqIFRoZSBhY3RpdmUgc3BhbiBhbHJlYWR5IGNvbnRhaW5zIGFsbCBNQ1AgY29udGV4dCAobWV0aG9kLCB0b29sLCBhcmd1bWVudHMsIGV0Yy4pXG4gKiBAcGFyYW0gZXJyb3IgLSBFcnJvciB0byBjYXB0dXJlXG4gKiBAcGFyYW0gZXJyb3JUeXBlIC0gQ2xhc3NpZmljYXRpb24gb2YgZXJyb3IgdHlwZSBmb3IgZmlsdGVyaW5nXG4gKiBAcGFyYW0gZXh0cmFEYXRhIC0gQWRkaXRpb25hbCBjb250ZXh0IGRhdGEgdG8gaW5jbHVkZVxuICovXG5mdW5jdGlvbiBjYXB0dXJlRXJyb3IoZXJyb3IsIGVycm9yVHlwZSwgZXh0cmFEYXRhKSB7XG4gIHRyeSB7XG4gICAgY29uc3QgY2xpZW50ID0gY3VycmVudFNjb3Blcy5nZXRDbGllbnQoKTtcbiAgICBpZiAoIWNsaWVudCkge1xuICAgICAgcmV0dXJuO1xuICAgIH1cblxuICAgIGNvbnN0IGFjdGl2ZVNwYW4gPSBzcGFuVXRpbHMuZ2V0QWN0aXZlU3BhbigpO1xuICAgIGlmIChhY3RpdmVTcGFuPy5pc1JlY29yZGluZygpKSB7XG4gICAgICBhY3RpdmVTcGFuLnNldFN0YXR1cyh7XG4gICAgICAgIGNvZGU6IHNwYW5zdGF0dXMuU1BBTl9TVEFUVVNfRVJST1IsXG4gICAgICAgIG1lc3NhZ2U6ICdpbnRlcm5hbF9lcnJvcicsXG4gICAgICB9KTtcbiAgICB9XG5cbiAgICBleHBvcnRzJDEuY2FwdHVyZUV4Y2VwdGlvbihlcnJvciwge1xuICAgICAgbWVjaGFuaXNtOiB7XG4gICAgICAgIHR5cGU6ICdtY3Bfc2VydmVyJyxcbiAgICAgICAgaGFuZGxlZDogZmFsc2UsXG4gICAgICAgIGRhdGE6IHtcbiAgICAgICAgICBlcnJvcl90eXBlOiBlcnJvclR5cGUgfHwgJ2hhbmRsZXJfZXhlY3V0aW9uJyxcbiAgICAgICAgICAuLi5leHRyYURhdGEsXG4gICAgICAgIH0sXG4gICAgICB9LFxuICAgIH0pO1xuICB9IGNhdGNoIHtcbiAgICAvLyBub29wXG4gIH1cbn1cblxuZXhwb3J0cy5jYXB0dXJlRXJyb3IgPSBjYXB0dXJlRXJyb3I7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1lcnJvckNhcHR1cmUuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/errorCapture.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/handlers.js":
/*!************************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/handlers.js ***!
  \************************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst debugBuild = __webpack_require__(/*! ../../debug-build.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst debugLogger = __webpack_require__(/*! ../../utils/debug-logger.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst object = __webpack_require__(/*! ../../utils/object.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/object.js\");\nconst errorCapture = __webpack_require__(/*! ./errorCapture.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/errorCapture.js\");\n\n/**\n * Handler method wrapping for MCP server instrumentation\n *\n * Provides automatic error capture and span correlation for tool, resource,\n * and prompt handlers.\n */\n\n\n/**\n * Generic function to wrap MCP server method handlers\n * @internal\n * @param serverInstance - MCP server instance\n * @param methodName - Method name to wrap (tool, resource, prompt)\n */\nfunction wrapMethodHandler(serverInstance, methodName) {\n  object.fill(serverInstance, methodName, originalMethod => {\n    return function ( name, ...args) {\n      const handler = args[args.length - 1];\n\n      if (typeof handler !== 'function') {\n        return (originalMethod ).call(this, name, ...args);\n      }\n\n      const wrappedHandler = createWrappedHandler(handler , methodName, name);\n      return (originalMethod ).call(this, name, ...args.slice(0, -1), wrappedHandler);\n    };\n  });\n}\n\n/**\n * Creates a wrapped handler with span correlation and error capture\n * @internal\n * @param originalHandler - Original handler function\n * @param methodName - MCP method name\n * @param handlerName - Handler identifier\n * @returns Wrapped handler function\n */\nfunction createWrappedHandler(originalHandler, methodName, handlerName) {\n  return function ( ...handlerArgs) {\n    try {\n      return createErrorCapturingHandler.call(this, originalHandler, methodName, handlerName, handlerArgs);\n    } catch (error) {\n      debugBuild.DEBUG_BUILD && debugLogger.debug.warn('MCP handler wrapping failed:', error);\n      return originalHandler.apply(this, handlerArgs);\n    }\n  };\n}\n\n/**\n * Creates an error-capturing wrapper for handler execution\n * @internal\n * @param originalHandler - Original handler function\n * @param methodName - MCP method name\n * @param handlerName - Handler identifier\n * @param handlerArgs - Handler arguments\n * @param extraHandlerData - Additional handler context\n * @returns Handler execution result\n */\nfunction createErrorCapturingHandler(\n\n  originalHandler,\n  methodName,\n  handlerName,\n  handlerArgs,\n) {\n  try {\n    const result = originalHandler.apply(this, handlerArgs);\n\n    if (result && typeof result === 'object' && typeof (result ).then === 'function') {\n      return Promise.resolve(result).catch(error => {\n        captureHandlerError(error, methodName, handlerName);\n        throw error;\n      });\n    }\n\n    return result;\n  } catch (error) {\n    captureHandlerError(error , methodName, handlerName);\n    throw error;\n  }\n}\n\n/**\n * Captures handler execution errors based on handler type\n * @internal\n * @param error - Error to capture\n * @param methodName - MCP method name\n * @param handlerName - Handler identifier\n */\nfunction captureHandlerError(error, methodName, handlerName) {\n  try {\n    const extraData = {};\n\n    if (methodName === 'tool') {\n      extraData.tool_name = handlerName;\n\n      if (\n        error.name === 'ProtocolValidationError' ||\n        error.message.includes('validation') ||\n        error.message.includes('protocol')\n      ) {\n        errorCapture.captureError(error, 'validation', extraData);\n      } else if (\n        error.name === 'ServerTimeoutError' ||\n        error.message.includes('timed out') ||\n        error.message.includes('timeout')\n      ) {\n        errorCapture.captureError(error, 'timeout', extraData);\n      } else {\n        errorCapture.captureError(error, 'tool_execution', extraData);\n      }\n    } else if (methodName === 'resource') {\n      extraData.resource_uri = handlerName;\n      errorCapture.captureError(error, 'resource_execution', extraData);\n    } else if (methodName === 'prompt') {\n      extraData.prompt_name = handlerName;\n      errorCapture.captureError(error, 'prompt_execution', extraData);\n    }\n  } catch (captureErr) {\n    // noop\n  }\n}\n\n/**\n * Wraps tool handlers to associate them with request spans\n * @param serverInstance - MCP server instance\n */\nfunction wrapToolHandlers(serverInstance) {\n  wrapMethodHandler(serverInstance, 'tool');\n}\n\n/**\n * Wraps resource handlers to associate them with request spans\n * @param serverInstance - MCP server instance\n */\nfunction wrapResourceHandlers(serverInstance) {\n  wrapMethodHandler(serverInstance, 'resource');\n}\n\n/**\n * Wraps prompt handlers to associate them with request spans\n * @param serverInstance - MCP server instance\n */\nfunction wrapPromptHandlers(serverInstance) {\n  wrapMethodHandler(serverInstance, 'prompt');\n}\n\n/**\n * Wraps all MCP handler types (tool, resource, prompt) for span correlation\n * @param serverInstance - MCP server instance\n */\nfunction wrapAllMCPHandlers(serverInstance) {\n  wrapToolHandlers(serverInstance);\n  wrapResourceHandlers(serverInstance);\n  wrapPromptHandlers(serverInstance);\n}\n\nexports.wrapAllMCPHandlers = wrapAllMCPHandlers;\nexports.wrapPromptHandlers = wrapPromptHandlers;\nexports.wrapResourceHandlers = wrapResourceHandlers;\nexports.wrapToolHandlers = wrapToolHandlers;\n//# sourceMappingURL=handlers.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvaW50ZWdyYXRpb25zL21jcC1zZXJ2ZXIvaGFuZGxlcnMuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsbUJBQW1CLG1CQUFPLENBQUMsc0lBQXNCO0FBQ2pELG9CQUFvQixtQkFBTyxDQUFDLG9KQUE2QjtBQUN6RCxlQUFlLG1CQUFPLENBQUMsd0lBQXVCO0FBQzlDLHFCQUFxQixtQkFBTyxDQUFDLDRKQUFtQjs7QUFFaEQ7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOzs7QUFHQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0EsR0FBRztBQUNIOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLE1BQU07QUFDTjtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQSxPQUFPO0FBQ1A7O0FBRUE7QUFDQSxJQUFJO0FBQ0o7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxRQUFRO0FBQ1I7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFFBQVE7QUFDUjtBQUNBO0FBQ0EsTUFBTTtBQUNOO0FBQ0E7QUFDQSxNQUFNO0FBQ047QUFDQTtBQUNBO0FBQ0EsSUFBSTtBQUNKO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsMEJBQTBCO0FBQzFCLDBCQUEwQjtBQUMxQiw0QkFBNEI7QUFDNUIsd0JBQXdCO0FBQ3hCIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvaW50ZWdyYXRpb25zL21jcC1zZXJ2ZXIvaGFuZGxlcnMuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGRlYnVnQnVpbGQgPSByZXF1aXJlKCcuLi8uLi9kZWJ1Zy1idWlsZC5qcycpO1xuY29uc3QgZGVidWdMb2dnZXIgPSByZXF1aXJlKCcuLi8uLi91dGlscy9kZWJ1Zy1sb2dnZXIuanMnKTtcbmNvbnN0IG9iamVjdCA9IHJlcXVpcmUoJy4uLy4uL3V0aWxzL29iamVjdC5qcycpO1xuY29uc3QgZXJyb3JDYXB0dXJlID0gcmVxdWlyZSgnLi9lcnJvckNhcHR1cmUuanMnKTtcblxuLyoqXG4gKiBIYW5kbGVyIG1ldGhvZCB3cmFwcGluZyBmb3IgTUNQIHNlcnZlciBpbnN0cnVtZW50YXRpb25cbiAqXG4gKiBQcm92aWRlcyBhdXRvbWF0aWMgZXJyb3IgY2FwdHVyZSBhbmQgc3BhbiBjb3JyZWxhdGlvbiBmb3IgdG9vbCwgcmVzb3VyY2UsXG4gKiBhbmQgcHJvbXB0IGhhbmRsZXJzLlxuICovXG5cblxuLyoqXG4gKiBHZW5lcmljIGZ1bmN0aW9uIHRvIHdyYXAgTUNQIHNlcnZlciBtZXRob2QgaGFuZGxlcnNcbiAqIEBpbnRlcm5hbFxuICogQHBhcmFtIHNlcnZlckluc3RhbmNlIC0gTUNQIHNlcnZlciBpbnN0YW5jZVxuICogQHBhcmFtIG1ldGhvZE5hbWUgLSBNZXRob2QgbmFtZSB0byB3cmFwICh0b29sLCByZXNvdXJjZSwgcHJvbXB0KVxuICovXG5mdW5jdGlvbiB3cmFwTWV0aG9kSGFuZGxlcihzZXJ2ZXJJbnN0YW5jZSwgbWV0aG9kTmFtZSkge1xuICBvYmplY3QuZmlsbChzZXJ2ZXJJbnN0YW5jZSwgbWV0aG9kTmFtZSwgb3JpZ2luYWxNZXRob2QgPT4ge1xuICAgIHJldHVybiBmdW5jdGlvbiAoIG5hbWUsIC4uLmFyZ3MpIHtcbiAgICAgIGNvbnN0IGhhbmRsZXIgPSBhcmdzW2FyZ3MubGVuZ3RoIC0gMV07XG5cbiAgICAgIGlmICh0eXBlb2YgaGFuZGxlciAhPT0gJ2Z1bmN0aW9uJykge1xuICAgICAgICByZXR1cm4gKG9yaWdpbmFsTWV0aG9kICkuY2FsbCh0aGlzLCBuYW1lLCAuLi5hcmdzKTtcbiAgICAgIH1cblxuICAgICAgY29uc3Qgd3JhcHBlZEhhbmRsZXIgPSBjcmVhdGVXcmFwcGVkSGFuZGxlcihoYW5kbGVyICwgbWV0aG9kTmFtZSwgbmFtZSk7XG4gICAgICByZXR1cm4gKG9yaWdpbmFsTWV0aG9kICkuY2FsbCh0aGlzLCBuYW1lLCAuLi5hcmdzLnNsaWNlKDAsIC0xKSwgd3JhcHBlZEhhbmRsZXIpO1xuICAgIH07XG4gIH0pO1xufVxuXG4vKipcbiAqIENyZWF0ZXMgYSB3cmFwcGVkIGhhbmRsZXIgd2l0aCBzcGFuIGNvcnJlbGF0aW9uIGFuZCBlcnJvciBjYXB0dXJlXG4gKiBAaW50ZXJuYWxcbiAqIEBwYXJhbSBvcmlnaW5hbEhhbmRsZXIgLSBPcmlnaW5hbCBoYW5kbGVyIGZ1bmN0aW9uXG4gKiBAcGFyYW0gbWV0aG9kTmFtZSAtIE1DUCBtZXRob2QgbmFtZVxuICogQHBhcmFtIGhhbmRsZXJOYW1lIC0gSGFuZGxlciBpZGVudGlmaWVyXG4gKiBAcmV0dXJucyBXcmFwcGVkIGhhbmRsZXIgZnVuY3Rpb25cbiAqL1xuZnVuY3Rpb24gY3JlYXRlV3JhcHBlZEhhbmRsZXIob3JpZ2luYWxIYW5kbGVyLCBtZXRob2ROYW1lLCBoYW5kbGVyTmFtZSkge1xuICByZXR1cm4gZnVuY3Rpb24gKCAuLi5oYW5kbGVyQXJncykge1xuICAgIHRyeSB7XG4gICAgICByZXR1cm4gY3JlYXRlRXJyb3JDYXB0dXJpbmdIYW5kbGVyLmNhbGwodGhpcywgb3JpZ2luYWxIYW5kbGVyLCBtZXRob2ROYW1lLCBoYW5kbGVyTmFtZSwgaGFuZGxlckFyZ3MpO1xuICAgIH0gY2F0Y2ggKGVycm9yKSB7XG4gICAgICBkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEICYmIGRlYnVnTG9nZ2VyLmRlYnVnLndhcm4oJ01DUCBoYW5kbGVyIHdyYXBwaW5nIGZhaWxlZDonLCBlcnJvcik7XG4gICAgICByZXR1cm4gb3JpZ2luYWxIYW5kbGVyLmFwcGx5KHRoaXMsIGhhbmRsZXJBcmdzKTtcbiAgICB9XG4gIH07XG59XG5cbi8qKlxuICogQ3JlYXRlcyBhbiBlcnJvci1jYXB0dXJpbmcgd3JhcHBlciBmb3IgaGFuZGxlciBleGVjdXRpb25cbiAqIEBpbnRlcm5hbFxuICogQHBhcmFtIG9yaWdpbmFsSGFuZGxlciAtIE9yaWdpbmFsIGhhbmRsZXIgZnVuY3Rpb25cbiAqIEBwYXJhbSBtZXRob2ROYW1lIC0gTUNQIG1ldGhvZCBuYW1lXG4gKiBAcGFyYW0gaGFuZGxlck5hbWUgLSBIYW5kbGVyIGlkZW50aWZpZXJcbiAqIEBwYXJhbSBoYW5kbGVyQXJncyAtIEhhbmRsZXIgYXJndW1lbnRzXG4gKiBAcGFyYW0gZXh0cmFIYW5kbGVyRGF0YSAtIEFkZGl0aW9uYWwgaGFuZGxlciBjb250ZXh0XG4gKiBAcmV0dXJucyBIYW5kbGVyIGV4ZWN1dGlvbiByZXN1bHRcbiAqL1xuZnVuY3Rpb24gY3JlYXRlRXJyb3JDYXB0dXJpbmdIYW5kbGVyKFxuXG4gIG9yaWdpbmFsSGFuZGxlcixcbiAgbWV0aG9kTmFtZSxcbiAgaGFuZGxlck5hbWUsXG4gIGhhbmRsZXJBcmdzLFxuKSB7XG4gIHRyeSB7XG4gICAgY29uc3QgcmVzdWx0ID0gb3JpZ2luYWxIYW5kbGVyLmFwcGx5KHRoaXMsIGhhbmRsZXJBcmdzKTtcblxuICAgIGlmIChyZXN1bHQgJiYgdHlwZW9mIHJlc3VsdCA9PT0gJ29iamVjdCcgJiYgdHlwZW9mIChyZXN1bHQgKS50aGVuID09PSAnZnVuY3Rpb24nKSB7XG4gICAgICByZXR1cm4gUHJvbWlzZS5yZXNvbHZlKHJlc3VsdCkuY2F0Y2goZXJyb3IgPT4ge1xuICAgICAgICBjYXB0dXJlSGFuZGxlckVycm9yKGVycm9yLCBtZXRob2ROYW1lLCBoYW5kbGVyTmFtZSk7XG4gICAgICAgIHRocm93IGVycm9yO1xuICAgICAgfSk7XG4gICAgfVxuXG4gICAgcmV0dXJuIHJlc3VsdDtcbiAgfSBjYXRjaCAoZXJyb3IpIHtcbiAgICBjYXB0dXJlSGFuZGxlckVycm9yKGVycm9yICwgbWV0aG9kTmFtZSwgaGFuZGxlck5hbWUpO1xuICAgIHRocm93IGVycm9yO1xuICB9XG59XG5cbi8qKlxuICogQ2FwdHVyZXMgaGFuZGxlciBleGVjdXRpb24gZXJyb3JzIGJhc2VkIG9uIGhhbmRsZXIgdHlwZVxuICogQGludGVybmFsXG4gKiBAcGFyYW0gZXJyb3IgLSBFcnJvciB0byBjYXB0dXJlXG4gKiBAcGFyYW0gbWV0aG9kTmFtZSAtIE1DUCBtZXRob2QgbmFtZVxuICogQHBhcmFtIGhhbmRsZXJOYW1lIC0gSGFuZGxlciBpZGVudGlmaWVyXG4gKi9cbmZ1bmN0aW9uIGNhcHR1cmVIYW5kbGVyRXJyb3IoZXJyb3IsIG1ldGhvZE5hbWUsIGhhbmRsZXJOYW1lKSB7XG4gIHRyeSB7XG4gICAgY29uc3QgZXh0cmFEYXRhID0ge307XG5cbiAgICBpZiAobWV0aG9kTmFtZSA9PT0gJ3Rvb2wnKSB7XG4gICAgICBleHRyYURhdGEudG9vbF9uYW1lID0gaGFuZGxlck5hbWU7XG5cbiAgICAgIGlmIChcbiAgICAgICAgZXJyb3IubmFtZSA9PT0gJ1Byb3RvY29sVmFsaWRhdGlvbkVycm9yJyB8fFxuICAgICAgICBlcnJvci5tZXNzYWdlLmluY2x1ZGVzKCd2YWxpZGF0aW9uJykgfHxcbiAgICAgICAgZXJyb3IubWVzc2FnZS5pbmNsdWRlcygncHJvdG9jb2wnKVxuICAgICAgKSB7XG4gICAgICAgIGVycm9yQ2FwdHVyZS5jYXB0dXJlRXJyb3IoZXJyb3IsICd2YWxpZGF0aW9uJywgZXh0cmFEYXRhKTtcbiAgICAgIH0gZWxzZSBpZiAoXG4gICAgICAgIGVycm9yLm5hbWUgPT09ICdTZXJ2ZXJUaW1lb3V0RXJyb3InIHx8XG4gICAgICAgIGVycm9yLm1lc3NhZ2UuaW5jbHVkZXMoJ3RpbWVkIG91dCcpIHx8XG4gICAgICAgIGVycm9yLm1lc3NhZ2UuaW5jbHVkZXMoJ3RpbWVvdXQnKVxuICAgICAgKSB7XG4gICAgICAgIGVycm9yQ2FwdHVyZS5jYXB0dXJlRXJyb3IoZXJyb3IsICd0aW1lb3V0JywgZXh0cmFEYXRhKTtcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIGVycm9yQ2FwdHVyZS5jYXB0dXJlRXJyb3IoZXJyb3IsICd0b29sX2V4ZWN1dGlvbicsIGV4dHJhRGF0YSk7XG4gICAgICB9XG4gICAgfSBlbHNlIGlmIChtZXRob2ROYW1lID09PSAncmVzb3VyY2UnKSB7XG4gICAgICBleHRyYURhdGEucmVzb3VyY2VfdXJpID0gaGFuZGxlck5hbWU7XG4gICAgICBlcnJvckNhcHR1cmUuY2FwdHVyZUVycm9yKGVycm9yLCAncmVzb3VyY2VfZXhlY3V0aW9uJywgZXh0cmFEYXRhKTtcbiAgICB9IGVsc2UgaWYgKG1ldGhvZE5hbWUgPT09ICdwcm9tcHQnKSB7XG4gICAgICBleHRyYURhdGEucHJvbXB0X25hbWUgPSBoYW5kbGVyTmFtZTtcbiAgICAgIGVycm9yQ2FwdHVyZS5jYXB0dXJlRXJyb3IoZXJyb3IsICdwcm9tcHRfZXhlY3V0aW9uJywgZXh0cmFEYXRhKTtcbiAgICB9XG4gIH0gY2F0Y2ggKGNhcHR1cmVFcnIpIHtcbiAgICAvLyBub29wXG4gIH1cbn1cblxuLyoqXG4gKiBXcmFwcyB0b29sIGhhbmRsZXJzIHRvIGFzc29jaWF0ZSB0aGVtIHdpdGggcmVxdWVzdCBzcGFuc1xuICogQHBhcmFtIHNlcnZlckluc3RhbmNlIC0gTUNQIHNlcnZlciBpbnN0YW5jZVxuICovXG5mdW5jdGlvbiB3cmFwVG9vbEhhbmRsZXJzKHNlcnZlckluc3RhbmNlKSB7XG4gIHdyYXBNZXRob2RIYW5kbGVyKHNlcnZlckluc3RhbmNlLCAndG9vbCcpO1xufVxuXG4vKipcbiAqIFdyYXBzIHJlc291cmNlIGhhbmRsZXJzIHRvIGFzc29jaWF0ZSB0aGVtIHdpdGggcmVxdWVzdCBzcGFuc1xuICogQHBhcmFtIHNlcnZlckluc3RhbmNlIC0gTUNQIHNlcnZlciBpbnN0YW5jZVxuICovXG5mdW5jdGlvbiB3cmFwUmVzb3VyY2VIYW5kbGVycyhzZXJ2ZXJJbnN0YW5jZSkge1xuICB3cmFwTWV0aG9kSGFuZGxlcihzZXJ2ZXJJbnN0YW5jZSwgJ3Jlc291cmNlJyk7XG59XG5cbi8qKlxuICogV3JhcHMgcHJvbXB0IGhhbmRsZXJzIHRvIGFzc29jaWF0ZSB0aGVtIHdpdGggcmVxdWVzdCBzcGFuc1xuICogQHBhcmFtIHNlcnZlckluc3RhbmNlIC0gTUNQIHNlcnZlciBpbnN0YW5jZVxuICovXG5mdW5jdGlvbiB3cmFwUHJvbXB0SGFuZGxlcnMoc2VydmVySW5zdGFuY2UpIHtcbiAgd3JhcE1ldGhvZEhhbmRsZXIoc2VydmVySW5zdGFuY2UsICdwcm9tcHQnKTtcbn1cblxuLyoqXG4gKiBXcmFwcyBhbGwgTUNQIGhhbmRsZXIgdHlwZXMgKHRvb2wsIHJlc291cmNlLCBwcm9tcHQpIGZvciBzcGFuIGNvcnJlbGF0aW9uXG4gKiBAcGFyYW0gc2VydmVySW5zdGFuY2UgLSBNQ1Agc2VydmVyIGluc3RhbmNlXG4gKi9cbmZ1bmN0aW9uIHdyYXBBbGxNQ1BIYW5kbGVycyhzZXJ2ZXJJbnN0YW5jZSkge1xuICB3cmFwVG9vbEhhbmRsZXJzKHNlcnZlckluc3RhbmNlKTtcbiAgd3JhcFJlc291cmNlSGFuZGxlcnMoc2VydmVySW5zdGFuY2UpO1xuICB3cmFwUHJvbXB0SGFuZGxlcnMoc2VydmVySW5zdGFuY2UpO1xufVxuXG5leHBvcnRzLndyYXBBbGxNQ1BIYW5kbGVycyA9IHdyYXBBbGxNQ1BIYW5kbGVycztcbmV4cG9ydHMud3JhcFByb21wdEhhbmRsZXJzID0gd3JhcFByb21wdEhhbmRsZXJzO1xuZXhwb3J0cy53cmFwUmVzb3VyY2VIYW5kbGVycyA9IHdyYXBSZXNvdXJjZUhhbmRsZXJzO1xuZXhwb3J0cy53cmFwVG9vbEhhbmRsZXJzID0gd3JhcFRvb2xIYW5kbGVycztcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWhhbmRsZXJzLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/handlers.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/index.js":
/*!*********************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/index.js ***!
  \*********************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst object = __webpack_require__(/*! ../../utils/object.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/object.js\");\nconst handlers = __webpack_require__(/*! ./handlers.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/handlers.js\");\nconst transport = __webpack_require__(/*! ./transport.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/transport.js\");\nconst validation = __webpack_require__(/*! ./validation.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/validation.js\");\n\n/**\n * Tracks wrapped MCP server instances to prevent double-wrapping\n * @internal\n */\nconst wrappedMcpServerInstances = new WeakSet();\n\n/**\n * Wraps a MCP Server instance from the `@modelcontextprotocol/sdk` package with Sentry instrumentation.\n *\n * Compatible with versions `^1.9.0` of the `@modelcontextprotocol/sdk` package.\n * Automatically instruments transport methods and handler functions for comprehensive monitoring.\n *\n * @example\n * ```typescript\n * import * as Sentry from '@sentry/core';\n * import { McpServer } from '@modelcontextprotocol/sdk/server/mcp.js';\n * import { StreamableHTTPServerTransport } from '@modelcontextprotocol/sdk/server/streamableHttp.js';\n *\n * const server = Sentry.wrapMcpServerWithSentry(\n *   new McpServer({ name: \"my-server\", version: \"1.0.0\" })\n * );\n *\n * const transport = new StreamableHTTPServerTransport();\n * await server.connect(transport);\n * ```\n *\n * @param mcpServerInstance - MCP server instance to instrument\n * @returns Instrumented server instance (same reference)\n */\nfunction wrapMcpServerWithSentry(mcpServerInstance) {\n  if (wrappedMcpServerInstances.has(mcpServerInstance)) {\n    return mcpServerInstance;\n  }\n\n  if (!validation.validateMcpServerInstance(mcpServerInstance)) {\n    return mcpServerInstance;\n  }\n\n  const serverInstance = mcpServerInstance ;\n\n  object.fill(serverInstance, 'connect', originalConnect => {\n    return async function ( transport$1, ...restArgs) {\n      const result = await (originalConnect ).call(\n        this,\n        transport$1,\n        ...restArgs,\n      );\n\n      transport.wrapTransportOnMessage(transport$1);\n      transport.wrapTransportSend(transport$1);\n      transport.wrapTransportOnClose(transport$1);\n      transport.wrapTransportError(transport$1);\n\n      return result;\n    };\n  });\n\n  handlers.wrapAllMCPHandlers(serverInstance);\n\n  wrappedMcpServerInstances.add(mcpServerInstance);\n  return mcpServerInstance ;\n}\n\nexports.wrapMcpServerWithSentry = wrapMcpServerWithSentry;\n//# sourceMappingURL=index.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvaW50ZWdyYXRpb25zL21jcC1zZXJ2ZXIvaW5kZXguanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsZUFBZSxtQkFBTyxDQUFDLHdJQUF1QjtBQUM5QyxpQkFBaUIsbUJBQU8sQ0FBQyxvSkFBZTtBQUN4QyxrQkFBa0IsbUJBQU8sQ0FBQyxzSkFBZ0I7QUFDMUMsbUJBQW1CLG1CQUFPLENBQUMsd0pBQWlCOztBQUU1QztBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFlBQVksWUFBWTtBQUN4QixZQUFZLGdDQUFnQztBQUM1QztBQUNBO0FBQ0EscUJBQXFCLHFDQUFxQztBQUMxRDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLEdBQUc7O0FBRUg7O0FBRUE7QUFDQTtBQUNBOztBQUVBLCtCQUErQjtBQUMvQiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL2ludGVncmF0aW9ucy9tY3Atc2VydmVyL2luZGV4LmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBvYmplY3QgPSByZXF1aXJlKCcuLi8uLi91dGlscy9vYmplY3QuanMnKTtcbmNvbnN0IGhhbmRsZXJzID0gcmVxdWlyZSgnLi9oYW5kbGVycy5qcycpO1xuY29uc3QgdHJhbnNwb3J0ID0gcmVxdWlyZSgnLi90cmFuc3BvcnQuanMnKTtcbmNvbnN0IHZhbGlkYXRpb24gPSByZXF1aXJlKCcuL3ZhbGlkYXRpb24uanMnKTtcblxuLyoqXG4gKiBUcmFja3Mgd3JhcHBlZCBNQ1Agc2VydmVyIGluc3RhbmNlcyB0byBwcmV2ZW50IGRvdWJsZS13cmFwcGluZ1xuICogQGludGVybmFsXG4gKi9cbmNvbnN0IHdyYXBwZWRNY3BTZXJ2ZXJJbnN0YW5jZXMgPSBuZXcgV2Vha1NldCgpO1xuXG4vKipcbiAqIFdyYXBzIGEgTUNQIFNlcnZlciBpbnN0YW5jZSBmcm9tIHRoZSBgQG1vZGVsY29udGV4dHByb3RvY29sL3Nka2AgcGFja2FnZSB3aXRoIFNlbnRyeSBpbnN0cnVtZW50YXRpb24uXG4gKlxuICogQ29tcGF0aWJsZSB3aXRoIHZlcnNpb25zIGBeMS45LjBgIG9mIHRoZSBgQG1vZGVsY29udGV4dHByb3RvY29sL3Nka2AgcGFja2FnZS5cbiAqIEF1dG9tYXRpY2FsbHkgaW5zdHJ1bWVudHMgdHJhbnNwb3J0IG1ldGhvZHMgYW5kIGhhbmRsZXIgZnVuY3Rpb25zIGZvciBjb21wcmVoZW5zaXZlIG1vbml0b3JpbmcuXG4gKlxuICogQGV4YW1wbGVcbiAqIGBgYHR5cGVzY3JpcHRcbiAqIGltcG9ydCAqIGFzIFNlbnRyeSBmcm9tICdAc2VudHJ5L2NvcmUnO1xuICogaW1wb3J0IHsgTWNwU2VydmVyIH0gZnJvbSAnQG1vZGVsY29udGV4dHByb3RvY29sL3Nkay9zZXJ2ZXIvbWNwLmpzJztcbiAqIGltcG9ydCB7IFN0cmVhbWFibGVIVFRQU2VydmVyVHJhbnNwb3J0IH0gZnJvbSAnQG1vZGVsY29udGV4dHByb3RvY29sL3Nkay9zZXJ2ZXIvc3RyZWFtYWJsZUh0dHAuanMnO1xuICpcbiAqIGNvbnN0IHNlcnZlciA9IFNlbnRyeS53cmFwTWNwU2VydmVyV2l0aFNlbnRyeShcbiAqICAgbmV3IE1jcFNlcnZlcih7IG5hbWU6IFwibXktc2VydmVyXCIsIHZlcnNpb246IFwiMS4wLjBcIiB9KVxuICogKTtcbiAqXG4gKiBjb25zdCB0cmFuc3BvcnQgPSBuZXcgU3RyZWFtYWJsZUhUVFBTZXJ2ZXJUcmFuc3BvcnQoKTtcbiAqIGF3YWl0IHNlcnZlci5jb25uZWN0KHRyYW5zcG9ydCk7XG4gKiBgYGBcbiAqXG4gKiBAcGFyYW0gbWNwU2VydmVySW5zdGFuY2UgLSBNQ1Agc2VydmVyIGluc3RhbmNlIHRvIGluc3RydW1lbnRcbiAqIEByZXR1cm5zIEluc3RydW1lbnRlZCBzZXJ2ZXIgaW5zdGFuY2UgKHNhbWUgcmVmZXJlbmNlKVxuICovXG5mdW5jdGlvbiB3cmFwTWNwU2VydmVyV2l0aFNlbnRyeShtY3BTZXJ2ZXJJbnN0YW5jZSkge1xuICBpZiAod3JhcHBlZE1jcFNlcnZlckluc3RhbmNlcy5oYXMobWNwU2VydmVySW5zdGFuY2UpKSB7XG4gICAgcmV0dXJuIG1jcFNlcnZlckluc3RhbmNlO1xuICB9XG5cbiAgaWYgKCF2YWxpZGF0aW9uLnZhbGlkYXRlTWNwU2VydmVySW5zdGFuY2UobWNwU2VydmVySW5zdGFuY2UpKSB7XG4gICAgcmV0dXJuIG1jcFNlcnZlckluc3RhbmNlO1xuICB9XG5cbiAgY29uc3Qgc2VydmVySW5zdGFuY2UgPSBtY3BTZXJ2ZXJJbnN0YW5jZSA7XG5cbiAgb2JqZWN0LmZpbGwoc2VydmVySW5zdGFuY2UsICdjb25uZWN0Jywgb3JpZ2luYWxDb25uZWN0ID0+IHtcbiAgICByZXR1cm4gYXN5bmMgZnVuY3Rpb24gKCB0cmFuc3BvcnQkMSwgLi4ucmVzdEFyZ3MpIHtcbiAgICAgIGNvbnN0IHJlc3VsdCA9IGF3YWl0IChvcmlnaW5hbENvbm5lY3QgKS5jYWxsKFxuICAgICAgICB0aGlzLFxuICAgICAgICB0cmFuc3BvcnQkMSxcbiAgICAgICAgLi4ucmVzdEFyZ3MsXG4gICAgICApO1xuXG4gICAgICB0cmFuc3BvcnQud3JhcFRyYW5zcG9ydE9uTWVzc2FnZSh0cmFuc3BvcnQkMSk7XG4gICAgICB0cmFuc3BvcnQud3JhcFRyYW5zcG9ydFNlbmQodHJhbnNwb3J0JDEpO1xuICAgICAgdHJhbnNwb3J0LndyYXBUcmFuc3BvcnRPbkNsb3NlKHRyYW5zcG9ydCQxKTtcbiAgICAgIHRyYW5zcG9ydC53cmFwVHJhbnNwb3J0RXJyb3IodHJhbnNwb3J0JDEpO1xuXG4gICAgICByZXR1cm4gcmVzdWx0O1xuICAgIH07XG4gIH0pO1xuXG4gIGhhbmRsZXJzLndyYXBBbGxNQ1BIYW5kbGVycyhzZXJ2ZXJJbnN0YW5jZSk7XG5cbiAgd3JhcHBlZE1jcFNlcnZlckluc3RhbmNlcy5hZGQobWNwU2VydmVySW5zdGFuY2UpO1xuICByZXR1cm4gbWNwU2VydmVySW5zdGFuY2UgO1xufVxuXG5leHBvcnRzLndyYXBNY3BTZXJ2ZXJXaXRoU2VudHJ5ID0gd3JhcE1jcFNlcnZlcldpdGhTZW50cnk7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1pbmRleC5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/index.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/methodConfig.js":
/*!****************************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/methodConfig.js ***!
  \****************************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst attributes = __webpack_require__(/*! ./attributes.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/attributes.js\");\n\n/**\n * Method configuration and request processing for MCP server instrumentation\n */\n\n\n/**\n * Configuration for MCP methods to extract targets and arguments\n * @internal Maps method names to their extraction configuration\n */\nconst METHOD_CONFIGS = {\n  'tools/call': {\n    targetField: 'name',\n    targetAttribute: attributes.MCP_TOOL_NAME_ATTRIBUTE,\n    captureArguments: true,\n    argumentsField: 'arguments',\n  },\n  'resources/read': {\n    targetField: 'uri',\n    targetAttribute: attributes.MCP_RESOURCE_URI_ATTRIBUTE,\n    captureUri: true,\n  },\n  'resources/subscribe': {\n    targetField: 'uri',\n    targetAttribute: attributes.MCP_RESOURCE_URI_ATTRIBUTE,\n  },\n  'resources/unsubscribe': {\n    targetField: 'uri',\n    targetAttribute: attributes.MCP_RESOURCE_URI_ATTRIBUTE,\n  },\n  'prompts/get': {\n    targetField: 'name',\n    targetAttribute: attributes.MCP_PROMPT_NAME_ATTRIBUTE,\n    captureName: true,\n    captureArguments: true,\n    argumentsField: 'arguments',\n  },\n};\n\n/**\n * Extracts target info from method and params based on method type\n * @param method - MCP method name\n * @param params - Method parameters\n * @returns Target name and attributes for span instrumentation\n */\nfunction extractTargetInfo(\n  method,\n  params,\n)\n\n {\n  const config = METHOD_CONFIGS[method ];\n  if (!config) {\n    return { attributes: {} };\n  }\n\n  const target =\n    config.targetField && typeof params?.[config.targetField] === 'string'\n      ? (params[config.targetField] )\n      : undefined;\n\n  return {\n    target,\n    attributes: target && config.targetAttribute ? { [config.targetAttribute]: target } : {},\n  };\n}\n\n/**\n * Extracts request arguments based on method type\n * @param method - MCP method name\n * @param params - Method parameters\n * @returns Arguments as span attributes with mcp.request.argument prefix\n */\nfunction getRequestArguments(method, params) {\n  const args = {};\n  const config = METHOD_CONFIGS[method ];\n\n  if (!config) {\n    return args;\n  }\n\n  if (config.captureArguments && config.argumentsField && params?.[config.argumentsField]) {\n    const argumentsObj = params[config.argumentsField];\n    if (typeof argumentsObj === 'object' && argumentsObj !== null) {\n      for (const [key, value] of Object.entries(argumentsObj )) {\n        args[`${attributes.MCP_REQUEST_ARGUMENT}.${key.toLowerCase()}`] = JSON.stringify(value);\n      }\n    }\n  }\n\n  if (config.captureUri && params?.uri) {\n    args[`${attributes.MCP_REQUEST_ARGUMENT}.uri`] = JSON.stringify(params.uri);\n  }\n\n  if (config.captureName && params?.name) {\n    args[`${attributes.MCP_REQUEST_ARGUMENT}.name`] = JSON.stringify(params.name);\n  }\n\n  return args;\n}\n\nexports.extractTargetInfo = extractTargetInfo;\nexports.getRequestArguments = getRequestArguments;\n//# sourceMappingURL=methodConfig.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvaW50ZWdyYXRpb25zL21jcC1zZXJ2ZXIvbWV0aG9kQ29uZmlnLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLG1CQUFtQixtQkFBTyxDQUFDLHdKQUFpQjs7QUFFNUM7QUFDQTtBQUNBOzs7QUFHQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEdBQUc7QUFDSDtBQUNBO0FBQ0E7QUFDQTtBQUNBLEdBQUc7QUFDSDtBQUNBO0FBQ0E7QUFDQSxHQUFHO0FBQ0g7QUFDQTtBQUNBO0FBQ0EsR0FBRztBQUNIO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEdBQUc7QUFDSDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQSxhQUFhO0FBQ2I7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLHFEQUFxRCxtQ0FBbUMsSUFBSTtBQUM1RjtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQSxnQkFBZ0IsZ0NBQWdDLEdBQUcsa0JBQWtCO0FBQ3JFO0FBQ0E7QUFDQTs7QUFFQTtBQUNBLFlBQVksZ0NBQWdDO0FBQzVDOztBQUVBO0FBQ0EsWUFBWSxnQ0FBZ0M7QUFDNUM7O0FBRUE7QUFDQTs7QUFFQSx5QkFBeUI7QUFDekIsMkJBQTJCO0FBQzNCIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvaW50ZWdyYXRpb25zL21jcC1zZXJ2ZXIvbWV0aG9kQ29uZmlnLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBhdHRyaWJ1dGVzID0gcmVxdWlyZSgnLi9hdHRyaWJ1dGVzLmpzJyk7XG5cbi8qKlxuICogTWV0aG9kIGNvbmZpZ3VyYXRpb24gYW5kIHJlcXVlc3QgcHJvY2Vzc2luZyBmb3IgTUNQIHNlcnZlciBpbnN0cnVtZW50YXRpb25cbiAqL1xuXG5cbi8qKlxuICogQ29uZmlndXJhdGlvbiBmb3IgTUNQIG1ldGhvZHMgdG8gZXh0cmFjdCB0YXJnZXRzIGFuZCBhcmd1bWVudHNcbiAqIEBpbnRlcm5hbCBNYXBzIG1ldGhvZCBuYW1lcyB0byB0aGVpciBleHRyYWN0aW9uIGNvbmZpZ3VyYXRpb25cbiAqL1xuY29uc3QgTUVUSE9EX0NPTkZJR1MgPSB7XG4gICd0b29scy9jYWxsJzoge1xuICAgIHRhcmdldEZpZWxkOiAnbmFtZScsXG4gICAgdGFyZ2V0QXR0cmlidXRlOiBhdHRyaWJ1dGVzLk1DUF9UT09MX05BTUVfQVRUUklCVVRFLFxuICAgIGNhcHR1cmVBcmd1bWVudHM6IHRydWUsXG4gICAgYXJndW1lbnRzRmllbGQ6ICdhcmd1bWVudHMnLFxuICB9LFxuICAncmVzb3VyY2VzL3JlYWQnOiB7XG4gICAgdGFyZ2V0RmllbGQ6ICd1cmknLFxuICAgIHRhcmdldEF0dHJpYnV0ZTogYXR0cmlidXRlcy5NQ1BfUkVTT1VSQ0VfVVJJX0FUVFJJQlVURSxcbiAgICBjYXB0dXJlVXJpOiB0cnVlLFxuICB9LFxuICAncmVzb3VyY2VzL3N1YnNjcmliZSc6IHtcbiAgICB0YXJnZXRGaWVsZDogJ3VyaScsXG4gICAgdGFyZ2V0QXR0cmlidXRlOiBhdHRyaWJ1dGVzLk1DUF9SRVNPVVJDRV9VUklfQVRUUklCVVRFLFxuICB9LFxuICAncmVzb3VyY2VzL3Vuc3Vic2NyaWJlJzoge1xuICAgIHRhcmdldEZpZWxkOiAndXJpJyxcbiAgICB0YXJnZXRBdHRyaWJ1dGU6IGF0dHJpYnV0ZXMuTUNQX1JFU09VUkNFX1VSSV9BVFRSSUJVVEUsXG4gIH0sXG4gICdwcm9tcHRzL2dldCc6IHtcbiAgICB0YXJnZXRGaWVsZDogJ25hbWUnLFxuICAgIHRhcmdldEF0dHJpYnV0ZTogYXR0cmlidXRlcy5NQ1BfUFJPTVBUX05BTUVfQVRUUklCVVRFLFxuICAgIGNhcHR1cmVOYW1lOiB0cnVlLFxuICAgIGNhcHR1cmVBcmd1bWVudHM6IHRydWUsXG4gICAgYXJndW1lbnRzRmllbGQ6ICdhcmd1bWVudHMnLFxuICB9LFxufTtcblxuLyoqXG4gKiBFeHRyYWN0cyB0YXJnZXQgaW5mbyBmcm9tIG1ldGhvZCBhbmQgcGFyYW1zIGJhc2VkIG9uIG1ldGhvZCB0eXBlXG4gKiBAcGFyYW0gbWV0aG9kIC0gTUNQIG1ldGhvZCBuYW1lXG4gKiBAcGFyYW0gcGFyYW1zIC0gTWV0aG9kIHBhcmFtZXRlcnNcbiAqIEByZXR1cm5zIFRhcmdldCBuYW1lIGFuZCBhdHRyaWJ1dGVzIGZvciBzcGFuIGluc3RydW1lbnRhdGlvblxuICovXG5mdW5jdGlvbiBleHRyYWN0VGFyZ2V0SW5mbyhcbiAgbWV0aG9kLFxuICBwYXJhbXMsXG4pXG5cbiB7XG4gIGNvbnN0IGNvbmZpZyA9IE1FVEhPRF9DT05GSUdTW21ldGhvZCBdO1xuICBpZiAoIWNvbmZpZykge1xuICAgIHJldHVybiB7IGF0dHJpYnV0ZXM6IHt9IH07XG4gIH1cblxuICBjb25zdCB0YXJnZXQgPVxuICAgIGNvbmZpZy50YXJnZXRGaWVsZCAmJiB0eXBlb2YgcGFyYW1zPy5bY29uZmlnLnRhcmdldEZpZWxkXSA9PT0gJ3N0cmluZydcbiAgICAgID8gKHBhcmFtc1tjb25maWcudGFyZ2V0RmllbGRdIClcbiAgICAgIDogdW5kZWZpbmVkO1xuXG4gIHJldHVybiB7XG4gICAgdGFyZ2V0LFxuICAgIGF0dHJpYnV0ZXM6IHRhcmdldCAmJiBjb25maWcudGFyZ2V0QXR0cmlidXRlID8geyBbY29uZmlnLnRhcmdldEF0dHJpYnV0ZV06IHRhcmdldCB9IDoge30sXG4gIH07XG59XG5cbi8qKlxuICogRXh0cmFjdHMgcmVxdWVzdCBhcmd1bWVudHMgYmFzZWQgb24gbWV0aG9kIHR5cGVcbiAqIEBwYXJhbSBtZXRob2QgLSBNQ1AgbWV0aG9kIG5hbWVcbiAqIEBwYXJhbSBwYXJhbXMgLSBNZXRob2QgcGFyYW1ldGVyc1xuICogQHJldHVybnMgQXJndW1lbnRzIGFzIHNwYW4gYXR0cmlidXRlcyB3aXRoIG1jcC5yZXF1ZXN0LmFyZ3VtZW50IHByZWZpeFxuICovXG5mdW5jdGlvbiBnZXRSZXF1ZXN0QXJndW1lbnRzKG1ldGhvZCwgcGFyYW1zKSB7XG4gIGNvbnN0IGFyZ3MgPSB7fTtcbiAgY29uc3QgY29uZmlnID0gTUVUSE9EX0NPTkZJR1NbbWV0aG9kIF07XG5cbiAgaWYgKCFjb25maWcpIHtcbiAgICByZXR1cm4gYXJncztcbiAgfVxuXG4gIGlmIChjb25maWcuY2FwdHVyZUFyZ3VtZW50cyAmJiBjb25maWcuYXJndW1lbnRzRmllbGQgJiYgcGFyYW1zPy5bY29uZmlnLmFyZ3VtZW50c0ZpZWxkXSkge1xuICAgIGNvbnN0IGFyZ3VtZW50c09iaiA9IHBhcmFtc1tjb25maWcuYXJndW1lbnRzRmllbGRdO1xuICAgIGlmICh0eXBlb2YgYXJndW1lbnRzT2JqID09PSAnb2JqZWN0JyAmJiBhcmd1bWVudHNPYmogIT09IG51bGwpIHtcbiAgICAgIGZvciAoY29uc3QgW2tleSwgdmFsdWVdIG9mIE9iamVjdC5lbnRyaWVzKGFyZ3VtZW50c09iaiApKSB7XG4gICAgICAgIGFyZ3NbYCR7YXR0cmlidXRlcy5NQ1BfUkVRVUVTVF9BUkdVTUVOVH0uJHtrZXkudG9Mb3dlckNhc2UoKX1gXSA9IEpTT04uc3RyaW5naWZ5KHZhbHVlKTtcbiAgICAgIH1cbiAgICB9XG4gIH1cblxuICBpZiAoY29uZmlnLmNhcHR1cmVVcmkgJiYgcGFyYW1zPy51cmkpIHtcbiAgICBhcmdzW2Ake2F0dHJpYnV0ZXMuTUNQX1JFUVVFU1RfQVJHVU1FTlR9LnVyaWBdID0gSlNPTi5zdHJpbmdpZnkocGFyYW1zLnVyaSk7XG4gIH1cblxuICBpZiAoY29uZmlnLmNhcHR1cmVOYW1lICYmIHBhcmFtcz8ubmFtZSkge1xuICAgIGFyZ3NbYCR7YXR0cmlidXRlcy5NQ1BfUkVRVUVTVF9BUkdVTUVOVH0ubmFtZWBdID0gSlNPTi5zdHJpbmdpZnkocGFyYW1zLm5hbWUpO1xuICB9XG5cbiAgcmV0dXJuIGFyZ3M7XG59XG5cbmV4cG9ydHMuZXh0cmFjdFRhcmdldEluZm8gPSBleHRyYWN0VGFyZ2V0SW5mbztcbmV4cG9ydHMuZ2V0UmVxdWVzdEFyZ3VtZW50cyA9IGdldFJlcXVlc3RBcmd1bWVudHM7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1tZXRob2RDb25maWcuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/methodConfig.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/piiFiltering.js":
/*!****************************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/piiFiltering.js ***!
  \****************************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst attributes = __webpack_require__(/*! ./attributes.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/attributes.js\");\n\n/**\n * PII attributes that should be removed when sendDefaultPii is false\n * @internal\n */\nconst PII_ATTRIBUTES = new Set([\n  attributes.CLIENT_ADDRESS_ATTRIBUTE,\n  attributes.CLIENT_PORT_ATTRIBUTE,\n  attributes.MCP_LOGGING_MESSAGE_ATTRIBUTE,\n  attributes.MCP_PROMPT_RESULT_DESCRIPTION_ATTRIBUTE,\n  attributes.MCP_PROMPT_RESULT_MESSAGE_CONTENT_ATTRIBUTE,\n  attributes.MCP_RESOURCE_URI_ATTRIBUTE,\n  attributes.MCP_TOOL_RESULT_CONTENT_ATTRIBUTE,\n]);\n\n/**\n * Checks if an attribute key should be considered PII.\n *\n * Returns true for:\n * - Explicit PII attributes (client.address, client.port, mcp.logging.message, etc.)\n * - All request arguments (mcp.request.argument.*)\n * - Tool and prompt result content (mcp.tool.result.*, mcp.prompt.result.*) except metadata\n *\n * Preserves metadata attributes ending with _count, _error, or .is_error as they don't contain sensitive data.\n *\n * @param key - Attribute key to evaluate\n * @returns true if the attribute should be filtered out (is PII), false if it should be preserved\n * @internal\n */\nfunction isPiiAttribute(key) {\n  if (PII_ATTRIBUTES.has(key)) {\n    return true;\n  }\n\n  if (key.startsWith(`${attributes.MCP_REQUEST_ARGUMENT}.`)) {\n    return true;\n  }\n\n  if (key.startsWith(`${attributes.MCP_TOOL_RESULT_PREFIX}.`) || key.startsWith(`${attributes.MCP_PROMPT_RESULT_PREFIX}.`)) {\n    if (!key.endsWith('_count') && !key.endsWith('_error') && !key.endsWith('.is_error')) {\n      return true;\n    }\n  }\n\n  return false;\n}\n\n/**\n * Removes PII attributes from span data when sendDefaultPii is false\n * @param spanData - Raw span attributes\n * @param sendDefaultPii - Whether to include PII data\n * @returns Filtered span attributes\n */\nfunction filterMcpPiiFromSpanData(\n  spanData,\n  sendDefaultPii,\n) {\n  if (sendDefaultPii) {\n    return spanData ;\n  }\n\n  return Object.entries(spanData).reduce(\n    (acc, [key, value]) => {\n      if (!isPiiAttribute(key)) {\n        acc[key] = value ;\n      }\n      return acc;\n    },\n    {} ,\n  );\n}\n\nexports.filterMcpPiiFromSpanData = filterMcpPiiFromSpanData;\n//# sourceMappingURL=piiFiltering.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvaW50ZWdyYXRpb25zL21jcC1zZXJ2ZXIvcGlpRmlsdGVyaW5nLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLG1CQUFtQixtQkFBTyxDQUFDLHdKQUFpQjs7QUFFNUM7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLHdCQUF3QixnQ0FBZ0M7QUFDeEQ7QUFDQTs7QUFFQSx3QkFBd0Isa0NBQWtDLHlCQUF5QixvQ0FBb0M7QUFDdkg7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxLQUFLO0FBQ0wsT0FBTztBQUNQO0FBQ0E7O0FBRUEsZ0NBQWdDO0FBQ2hDIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvaW50ZWdyYXRpb25zL21jcC1zZXJ2ZXIvcGlpRmlsdGVyaW5nLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBhdHRyaWJ1dGVzID0gcmVxdWlyZSgnLi9hdHRyaWJ1dGVzLmpzJyk7XG5cbi8qKlxuICogUElJIGF0dHJpYnV0ZXMgdGhhdCBzaG91bGQgYmUgcmVtb3ZlZCB3aGVuIHNlbmREZWZhdWx0UGlpIGlzIGZhbHNlXG4gKiBAaW50ZXJuYWxcbiAqL1xuY29uc3QgUElJX0FUVFJJQlVURVMgPSBuZXcgU2V0KFtcbiAgYXR0cmlidXRlcy5DTElFTlRfQUREUkVTU19BVFRSSUJVVEUsXG4gIGF0dHJpYnV0ZXMuQ0xJRU5UX1BPUlRfQVRUUklCVVRFLFxuICBhdHRyaWJ1dGVzLk1DUF9MT0dHSU5HX01FU1NBR0VfQVRUUklCVVRFLFxuICBhdHRyaWJ1dGVzLk1DUF9QUk9NUFRfUkVTVUxUX0RFU0NSSVBUSU9OX0FUVFJJQlVURSxcbiAgYXR0cmlidXRlcy5NQ1BfUFJPTVBUX1JFU1VMVF9NRVNTQUdFX0NPTlRFTlRfQVRUUklCVVRFLFxuICBhdHRyaWJ1dGVzLk1DUF9SRVNPVVJDRV9VUklfQVRUUklCVVRFLFxuICBhdHRyaWJ1dGVzLk1DUF9UT09MX1JFU1VMVF9DT05URU5UX0FUVFJJQlVURSxcbl0pO1xuXG4vKipcbiAqIENoZWNrcyBpZiBhbiBhdHRyaWJ1dGUga2V5IHNob3VsZCBiZSBjb25zaWRlcmVkIFBJSS5cbiAqXG4gKiBSZXR1cm5zIHRydWUgZm9yOlxuICogLSBFeHBsaWNpdCBQSUkgYXR0cmlidXRlcyAoY2xpZW50LmFkZHJlc3MsIGNsaWVudC5wb3J0LCBtY3AubG9nZ2luZy5tZXNzYWdlLCBldGMuKVxuICogLSBBbGwgcmVxdWVzdCBhcmd1bWVudHMgKG1jcC5yZXF1ZXN0LmFyZ3VtZW50LiopXG4gKiAtIFRvb2wgYW5kIHByb21wdCByZXN1bHQgY29udGVudCAobWNwLnRvb2wucmVzdWx0LiosIG1jcC5wcm9tcHQucmVzdWx0LiopIGV4Y2VwdCBtZXRhZGF0YVxuICpcbiAqIFByZXNlcnZlcyBtZXRhZGF0YSBhdHRyaWJ1dGVzIGVuZGluZyB3aXRoIF9jb3VudCwgX2Vycm9yLCBvciAuaXNfZXJyb3IgYXMgdGhleSBkb24ndCBjb250YWluIHNlbnNpdGl2ZSBkYXRhLlxuICpcbiAqIEBwYXJhbSBrZXkgLSBBdHRyaWJ1dGUga2V5IHRvIGV2YWx1YXRlXG4gKiBAcmV0dXJucyB0cnVlIGlmIHRoZSBhdHRyaWJ1dGUgc2hvdWxkIGJlIGZpbHRlcmVkIG91dCAoaXMgUElJKSwgZmFsc2UgaWYgaXQgc2hvdWxkIGJlIHByZXNlcnZlZFxuICogQGludGVybmFsXG4gKi9cbmZ1bmN0aW9uIGlzUGlpQXR0cmlidXRlKGtleSkge1xuICBpZiAoUElJX0FUVFJJQlVURVMuaGFzKGtleSkpIHtcbiAgICByZXR1cm4gdHJ1ZTtcbiAgfVxuXG4gIGlmIChrZXkuc3RhcnRzV2l0aChgJHthdHRyaWJ1dGVzLk1DUF9SRVFVRVNUX0FSR1VNRU5UfS5gKSkge1xuICAgIHJldHVybiB0cnVlO1xuICB9XG5cbiAgaWYgKGtleS5zdGFydHNXaXRoKGAke2F0dHJpYnV0ZXMuTUNQX1RPT0xfUkVTVUxUX1BSRUZJWH0uYCkgfHwga2V5LnN0YXJ0c1dpdGgoYCR7YXR0cmlidXRlcy5NQ1BfUFJPTVBUX1JFU1VMVF9QUkVGSVh9LmApKSB7XG4gICAgaWYgKCFrZXkuZW5kc1dpdGgoJ19jb3VudCcpICYmICFrZXkuZW5kc1dpdGgoJ19lcnJvcicpICYmICFrZXkuZW5kc1dpdGgoJy5pc19lcnJvcicpKSB7XG4gICAgICByZXR1cm4gdHJ1ZTtcbiAgICB9XG4gIH1cblxuICByZXR1cm4gZmFsc2U7XG59XG5cbi8qKlxuICogUmVtb3ZlcyBQSUkgYXR0cmlidXRlcyBmcm9tIHNwYW4gZGF0YSB3aGVuIHNlbmREZWZhdWx0UGlpIGlzIGZhbHNlXG4gKiBAcGFyYW0gc3BhbkRhdGEgLSBSYXcgc3BhbiBhdHRyaWJ1dGVzXG4gKiBAcGFyYW0gc2VuZERlZmF1bHRQaWkgLSBXaGV0aGVyIHRvIGluY2x1ZGUgUElJIGRhdGFcbiAqIEByZXR1cm5zIEZpbHRlcmVkIHNwYW4gYXR0cmlidXRlc1xuICovXG5mdW5jdGlvbiBmaWx0ZXJNY3BQaWlGcm9tU3BhbkRhdGEoXG4gIHNwYW5EYXRhLFxuICBzZW5kRGVmYXVsdFBpaSxcbikge1xuICBpZiAoc2VuZERlZmF1bHRQaWkpIHtcbiAgICByZXR1cm4gc3BhbkRhdGEgO1xuICB9XG5cbiAgcmV0dXJuIE9iamVjdC5lbnRyaWVzKHNwYW5EYXRhKS5yZWR1Y2UoXG4gICAgKGFjYywgW2tleSwgdmFsdWVdKSA9PiB7XG4gICAgICBpZiAoIWlzUGlpQXR0cmlidXRlKGtleSkpIHtcbiAgICAgICAgYWNjW2tleV0gPSB2YWx1ZSA7XG4gICAgICB9XG4gICAgICByZXR1cm4gYWNjO1xuICAgIH0sXG4gICAge30gLFxuICApO1xufVxuXG5leHBvcnRzLmZpbHRlck1jcFBpaUZyb21TcGFuRGF0YSA9IGZpbHRlck1jcFBpaUZyb21TcGFuRGF0YTtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPXBpaUZpbHRlcmluZy5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/piiFiltering.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/resultExtraction.js":
/*!********************************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/resultExtraction.js ***!
  \********************************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst attributes = __webpack_require__(/*! ./attributes.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/attributes.js\");\nconst validation = __webpack_require__(/*! ./validation.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/validation.js\");\n\n/**\n * Result extraction functions for MCP server instrumentation\n *\n * Handles extraction of attributes from tool and prompt execution results.\n */\n\n\n/**\n * Build attributes for tool result content items\n * @param content - Array of content items from tool result\n * @returns Attributes extracted from each content item including type, text, mime type, URI, and resource info\n */\nfunction buildAllContentItemAttributes(content) {\n  const attributes$1 = {\n    [attributes.MCP_TOOL_RESULT_CONTENT_COUNT_ATTRIBUTE]: content.length,\n  };\n\n  for (const [i, item] of content.entries()) {\n    if (!validation.isValidContentItem(item)) {\n      continue;\n    }\n\n    const prefix = content.length === 1 ? 'mcp.tool.result' : `mcp.tool.result.${i}`;\n\n    const safeSet = (key, value) => {\n      if (typeof value === 'string') {\n        attributes$1[`${prefix}.${key}`] = value;\n      }\n    };\n\n    safeSet('content_type', item.type);\n    safeSet('mime_type', item.mimeType);\n    safeSet('uri', item.uri);\n    safeSet('name', item.name);\n\n    if (typeof item.text === 'string') {\n      attributes$1[`${prefix}.content`] = item.text;\n    }\n\n    if (typeof item.data === 'string') {\n      attributes$1[`${prefix}.data_size`] = item.data.length;\n    }\n\n    const resource = item.resource;\n    if (validation.isValidContentItem(resource)) {\n      safeSet('resource_uri', resource.uri);\n      safeSet('resource_mime_type', resource.mimeType);\n    }\n  }\n\n  return attributes$1;\n}\n\n/**\n * Extract tool result attributes for span instrumentation\n * @param result - Tool execution result\n * @returns Attributes extracted from tool result content\n */\nfunction extractToolResultAttributes(result) {\n  if (!validation.isValidContentItem(result)) {\n    return {};\n  }\n\n  const attributes$1 = Array.isArray(result.content) ? buildAllContentItemAttributes(result.content) : {};\n\n  if (typeof result.isError === 'boolean') {\n    attributes$1[attributes.MCP_TOOL_RESULT_IS_ERROR_ATTRIBUTE] = result.isError;\n  }\n\n  return attributes$1;\n}\n\n/**\n * Extract prompt result attributes for span instrumentation\n * @param result - Prompt execution result\n * @returns Attributes extracted from prompt result\n */\nfunction extractPromptResultAttributes(result) {\n  const attributes$1 = {};\n  if (!validation.isValidContentItem(result)) {\n    return attributes$1;\n  }\n\n  if (typeof result.description === 'string') {\n    attributes$1[attributes.MCP_PROMPT_RESULT_DESCRIPTION_ATTRIBUTE] = result.description;\n  }\n\n  if (Array.isArray(result.messages)) {\n    attributes$1[attributes.MCP_PROMPT_RESULT_MESSAGE_COUNT_ATTRIBUTE] = result.messages.length;\n\n    const messages = result.messages;\n    for (const [i, message] of messages.entries()) {\n      if (!validation.isValidContentItem(message)) {\n        continue;\n      }\n\n      const prefix = messages.length === 1 ? 'mcp.prompt.result' : `mcp.prompt.result.${i}`;\n\n      const safeSet = (key, value) => {\n        if (typeof value === 'string') {\n          const attrName = messages.length === 1 ? `${prefix}.message_${key}` : `${prefix}.${key}`;\n          attributes$1[attrName] = value;\n        }\n      };\n\n      safeSet('role', message.role);\n\n      if (validation.isValidContentItem(message.content)) {\n        const content = message.content;\n        if (typeof content.text === 'string') {\n          const attrName = messages.length === 1 ? `${prefix}.message_content` : `${prefix}.content`;\n          attributes$1[attrName] = content.text;\n        }\n      }\n    }\n  }\n\n  return attributes$1;\n}\n\nexports.extractPromptResultAttributes = extractPromptResultAttributes;\nexports.extractToolResultAttributes = extractToolResultAttributes;\n//# sourceMappingURL=resultExtraction.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvaW50ZWdyYXRpb25zL21jcC1zZXJ2ZXIvcmVzdWx0RXh0cmFjdGlvbi5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxtQkFBbUIsbUJBQU8sQ0FBQyx3SkFBaUI7QUFDNUMsbUJBQW1CLG1CQUFPLENBQUMsd0pBQWlCOztBQUU1QztBQUNBO0FBQ0E7QUFDQTtBQUNBOzs7QUFHQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsaUZBQWlGLEVBQUU7O0FBRW5GO0FBQ0E7QUFDQSx3QkFBd0IsT0FBTyxHQUFHLElBQUk7QUFDdEM7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBLHNCQUFzQixPQUFPO0FBQzdCOztBQUVBO0FBQ0Esc0JBQXNCLE9BQU87QUFDN0I7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsd0ZBQXdGLEVBQUU7O0FBRTFGO0FBQ0E7QUFDQSxzREFBc0QsT0FBTyxXQUFXLElBQUksT0FBTyxPQUFPLEdBQUcsSUFBSTtBQUNqRztBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0Esc0RBQXNELE9BQU8sdUJBQXVCLE9BQU87QUFDM0Y7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBLHFDQUFxQztBQUNyQyxtQ0FBbUM7QUFDbkMiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvbWNwLXNlcnZlci9yZXN1bHRFeHRyYWN0aW9uLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBhdHRyaWJ1dGVzID0gcmVxdWlyZSgnLi9hdHRyaWJ1dGVzLmpzJyk7XG5jb25zdCB2YWxpZGF0aW9uID0gcmVxdWlyZSgnLi92YWxpZGF0aW9uLmpzJyk7XG5cbi8qKlxuICogUmVzdWx0IGV4dHJhY3Rpb24gZnVuY3Rpb25zIGZvciBNQ1Agc2VydmVyIGluc3RydW1lbnRhdGlvblxuICpcbiAqIEhhbmRsZXMgZXh0cmFjdGlvbiBvZiBhdHRyaWJ1dGVzIGZyb20gdG9vbCBhbmQgcHJvbXB0IGV4ZWN1dGlvbiByZXN1bHRzLlxuICovXG5cblxuLyoqXG4gKiBCdWlsZCBhdHRyaWJ1dGVzIGZvciB0b29sIHJlc3VsdCBjb250ZW50IGl0ZW1zXG4gKiBAcGFyYW0gY29udGVudCAtIEFycmF5IG9mIGNvbnRlbnQgaXRlbXMgZnJvbSB0b29sIHJlc3VsdFxuICogQHJldHVybnMgQXR0cmlidXRlcyBleHRyYWN0ZWQgZnJvbSBlYWNoIGNvbnRlbnQgaXRlbSBpbmNsdWRpbmcgdHlwZSwgdGV4dCwgbWltZSB0eXBlLCBVUkksIGFuZCByZXNvdXJjZSBpbmZvXG4gKi9cbmZ1bmN0aW9uIGJ1aWxkQWxsQ29udGVudEl0ZW1BdHRyaWJ1dGVzKGNvbnRlbnQpIHtcbiAgY29uc3QgYXR0cmlidXRlcyQxID0ge1xuICAgIFthdHRyaWJ1dGVzLk1DUF9UT09MX1JFU1VMVF9DT05URU5UX0NPVU5UX0FUVFJJQlVURV06IGNvbnRlbnQubGVuZ3RoLFxuICB9O1xuXG4gIGZvciAoY29uc3QgW2ksIGl0ZW1dIG9mIGNvbnRlbnQuZW50cmllcygpKSB7XG4gICAgaWYgKCF2YWxpZGF0aW9uLmlzVmFsaWRDb250ZW50SXRlbShpdGVtKSkge1xuICAgICAgY29udGludWU7XG4gICAgfVxuXG4gICAgY29uc3QgcHJlZml4ID0gY29udGVudC5sZW5ndGggPT09IDEgPyAnbWNwLnRvb2wucmVzdWx0JyA6IGBtY3AudG9vbC5yZXN1bHQuJHtpfWA7XG5cbiAgICBjb25zdCBzYWZlU2V0ID0gKGtleSwgdmFsdWUpID0+IHtcbiAgICAgIGlmICh0eXBlb2YgdmFsdWUgPT09ICdzdHJpbmcnKSB7XG4gICAgICAgIGF0dHJpYnV0ZXMkMVtgJHtwcmVmaXh9LiR7a2V5fWBdID0gdmFsdWU7XG4gICAgICB9XG4gICAgfTtcblxuICAgIHNhZmVTZXQoJ2NvbnRlbnRfdHlwZScsIGl0ZW0udHlwZSk7XG4gICAgc2FmZVNldCgnbWltZV90eXBlJywgaXRlbS5taW1lVHlwZSk7XG4gICAgc2FmZVNldCgndXJpJywgaXRlbS51cmkpO1xuICAgIHNhZmVTZXQoJ25hbWUnLCBpdGVtLm5hbWUpO1xuXG4gICAgaWYgKHR5cGVvZiBpdGVtLnRleHQgPT09ICdzdHJpbmcnKSB7XG4gICAgICBhdHRyaWJ1dGVzJDFbYCR7cHJlZml4fS5jb250ZW50YF0gPSBpdGVtLnRleHQ7XG4gICAgfVxuXG4gICAgaWYgKHR5cGVvZiBpdGVtLmRhdGEgPT09ICdzdHJpbmcnKSB7XG4gICAgICBhdHRyaWJ1dGVzJDFbYCR7cHJlZml4fS5kYXRhX3NpemVgXSA9IGl0ZW0uZGF0YS5sZW5ndGg7XG4gICAgfVxuXG4gICAgY29uc3QgcmVzb3VyY2UgPSBpdGVtLnJlc291cmNlO1xuICAgIGlmICh2YWxpZGF0aW9uLmlzVmFsaWRDb250ZW50SXRlbShyZXNvdXJjZSkpIHtcbiAgICAgIHNhZmVTZXQoJ3Jlc291cmNlX3VyaScsIHJlc291cmNlLnVyaSk7XG4gICAgICBzYWZlU2V0KCdyZXNvdXJjZV9taW1lX3R5cGUnLCByZXNvdXJjZS5taW1lVHlwZSk7XG4gICAgfVxuICB9XG5cbiAgcmV0dXJuIGF0dHJpYnV0ZXMkMTtcbn1cblxuLyoqXG4gKiBFeHRyYWN0IHRvb2wgcmVzdWx0IGF0dHJpYnV0ZXMgZm9yIHNwYW4gaW5zdHJ1bWVudGF0aW9uXG4gKiBAcGFyYW0gcmVzdWx0IC0gVG9vbCBleGVjdXRpb24gcmVzdWx0XG4gKiBAcmV0dXJucyBBdHRyaWJ1dGVzIGV4dHJhY3RlZCBmcm9tIHRvb2wgcmVzdWx0IGNvbnRlbnRcbiAqL1xuZnVuY3Rpb24gZXh0cmFjdFRvb2xSZXN1bHRBdHRyaWJ1dGVzKHJlc3VsdCkge1xuICBpZiAoIXZhbGlkYXRpb24uaXNWYWxpZENvbnRlbnRJdGVtKHJlc3VsdCkpIHtcbiAgICByZXR1cm4ge307XG4gIH1cblxuICBjb25zdCBhdHRyaWJ1dGVzJDEgPSBBcnJheS5pc0FycmF5KHJlc3VsdC5jb250ZW50KSA/IGJ1aWxkQWxsQ29udGVudEl0ZW1BdHRyaWJ1dGVzKHJlc3VsdC5jb250ZW50KSA6IHt9O1xuXG4gIGlmICh0eXBlb2YgcmVzdWx0LmlzRXJyb3IgPT09ICdib29sZWFuJykge1xuICAgIGF0dHJpYnV0ZXMkMVthdHRyaWJ1dGVzLk1DUF9UT09MX1JFU1VMVF9JU19FUlJPUl9BVFRSSUJVVEVdID0gcmVzdWx0LmlzRXJyb3I7XG4gIH1cblxuICByZXR1cm4gYXR0cmlidXRlcyQxO1xufVxuXG4vKipcbiAqIEV4dHJhY3QgcHJvbXB0IHJlc3VsdCBhdHRyaWJ1dGVzIGZvciBzcGFuIGluc3RydW1lbnRhdGlvblxuICogQHBhcmFtIHJlc3VsdCAtIFByb21wdCBleGVjdXRpb24gcmVzdWx0XG4gKiBAcmV0dXJucyBBdHRyaWJ1dGVzIGV4dHJhY3RlZCBmcm9tIHByb21wdCByZXN1bHRcbiAqL1xuZnVuY3Rpb24gZXh0cmFjdFByb21wdFJlc3VsdEF0dHJpYnV0ZXMocmVzdWx0KSB7XG4gIGNvbnN0IGF0dHJpYnV0ZXMkMSA9IHt9O1xuICBpZiAoIXZhbGlkYXRpb24uaXNWYWxpZENvbnRlbnRJdGVtKHJlc3VsdCkpIHtcbiAgICByZXR1cm4gYXR0cmlidXRlcyQxO1xuICB9XG5cbiAgaWYgKHR5cGVvZiByZXN1bHQuZGVzY3JpcHRpb24gPT09ICdzdHJpbmcnKSB7XG4gICAgYXR0cmlidXRlcyQxW2F0dHJpYnV0ZXMuTUNQX1BST01QVF9SRVNVTFRfREVTQ1JJUFRJT05fQVRUUklCVVRFXSA9IHJlc3VsdC5kZXNjcmlwdGlvbjtcbiAgfVxuXG4gIGlmIChBcnJheS5pc0FycmF5KHJlc3VsdC5tZXNzYWdlcykpIHtcbiAgICBhdHRyaWJ1dGVzJDFbYXR0cmlidXRlcy5NQ1BfUFJPTVBUX1JFU1VMVF9NRVNTQUdFX0NPVU5UX0FUVFJJQlVURV0gPSByZXN1bHQubWVzc2FnZXMubGVuZ3RoO1xuXG4gICAgY29uc3QgbWVzc2FnZXMgPSByZXN1bHQubWVzc2FnZXM7XG4gICAgZm9yIChjb25zdCBbaSwgbWVzc2FnZV0gb2YgbWVzc2FnZXMuZW50cmllcygpKSB7XG4gICAgICBpZiAoIXZhbGlkYXRpb24uaXNWYWxpZENvbnRlbnRJdGVtKG1lc3NhZ2UpKSB7XG4gICAgICAgIGNvbnRpbnVlO1xuICAgICAgfVxuXG4gICAgICBjb25zdCBwcmVmaXggPSBtZXNzYWdlcy5sZW5ndGggPT09IDEgPyAnbWNwLnByb21wdC5yZXN1bHQnIDogYG1jcC5wcm9tcHQucmVzdWx0LiR7aX1gO1xuXG4gICAgICBjb25zdCBzYWZlU2V0ID0gKGtleSwgdmFsdWUpID0+IHtcbiAgICAgICAgaWYgKHR5cGVvZiB2YWx1ZSA9PT0gJ3N0cmluZycpIHtcbiAgICAgICAgICBjb25zdCBhdHRyTmFtZSA9IG1lc3NhZ2VzLmxlbmd0aCA9PT0gMSA/IGAke3ByZWZpeH0ubWVzc2FnZV8ke2tleX1gIDogYCR7cHJlZml4fS4ke2tleX1gO1xuICAgICAgICAgIGF0dHJpYnV0ZXMkMVthdHRyTmFtZV0gPSB2YWx1ZTtcbiAgICAgICAgfVxuICAgICAgfTtcblxuICAgICAgc2FmZVNldCgncm9sZScsIG1lc3NhZ2Uucm9sZSk7XG5cbiAgICAgIGlmICh2YWxpZGF0aW9uLmlzVmFsaWRDb250ZW50SXRlbShtZXNzYWdlLmNvbnRlbnQpKSB7XG4gICAgICAgIGNvbnN0IGNvbnRlbnQgPSBtZXNzYWdlLmNvbnRlbnQ7XG4gICAgICAgIGlmICh0eXBlb2YgY29udGVudC50ZXh0ID09PSAnc3RyaW5nJykge1xuICAgICAgICAgIGNvbnN0IGF0dHJOYW1lID0gbWVzc2FnZXMubGVuZ3RoID09PSAxID8gYCR7cHJlZml4fS5tZXNzYWdlX2NvbnRlbnRgIDogYCR7cHJlZml4fS5jb250ZW50YDtcbiAgICAgICAgICBhdHRyaWJ1dGVzJDFbYXR0ck5hbWVdID0gY29udGVudC50ZXh0O1xuICAgICAgICB9XG4gICAgICB9XG4gICAgfVxuICB9XG5cbiAgcmV0dXJuIGF0dHJpYnV0ZXMkMTtcbn1cblxuZXhwb3J0cy5leHRyYWN0UHJvbXB0UmVzdWx0QXR0cmlidXRlcyA9IGV4dHJhY3RQcm9tcHRSZXN1bHRBdHRyaWJ1dGVzO1xuZXhwb3J0cy5leHRyYWN0VG9vbFJlc3VsdEF0dHJpYnV0ZXMgPSBleHRyYWN0VG9vbFJlc3VsdEF0dHJpYnV0ZXM7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1yZXN1bHRFeHRyYWN0aW9uLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/resultExtraction.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/sessionExtraction.js":
/*!*********************************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/sessionExtraction.js ***!
  \*********************************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst attributes = __webpack_require__(/*! ./attributes.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/attributes.js\");\nconst sessionManagement = __webpack_require__(/*! ./sessionManagement.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/sessionManagement.js\");\nconst validation = __webpack_require__(/*! ./validation.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/validation.js\");\n\n/**\n * Session and party info extraction functions for MCP server instrumentation\n *\n * Handles extraction of client/server info and session data from MCP messages.\n */\n\n\n/**\n * Extracts and validates PartyInfo from an unknown object\n * @param obj - Unknown object that might contain party info\n * @returns Validated PartyInfo object with only string properties\n */\nfunction extractPartyInfo(obj) {\n  const partyInfo = {};\n\n  if (validation.isValidContentItem(obj)) {\n    if (typeof obj.name === 'string') {\n      partyInfo.name = obj.name;\n    }\n    if (typeof obj.title === 'string') {\n      partyInfo.title = obj.title;\n    }\n    if (typeof obj.version === 'string') {\n      partyInfo.version = obj.version;\n    }\n  }\n\n  return partyInfo;\n}\n\n/**\n * Extracts session data from \"initialize\" requests\n * @param request - JSON-RPC \"initialize\" request containing client info and protocol version\n * @returns Session data extracted from request parameters including protocol version and client info\n */\nfunction extractSessionDataFromInitializeRequest(request) {\n  const sessionData = {};\n  if (validation.isValidContentItem(request.params)) {\n    if (typeof request.params.protocolVersion === 'string') {\n      sessionData.protocolVersion = request.params.protocolVersion;\n    }\n    if (request.params.clientInfo) {\n      sessionData.clientInfo = extractPartyInfo(request.params.clientInfo);\n    }\n  }\n  return sessionData;\n}\n\n/**\n * Extracts session data from \"initialize\" response\n * @param result - \"initialize\" response result containing server info and protocol version\n * @returns Partial session data extracted from response including protocol version and server info\n */\nfunction extractSessionDataFromInitializeResponse(result) {\n  const sessionData = {};\n  if (validation.isValidContentItem(result)) {\n    if (typeof result.protocolVersion === 'string') {\n      sessionData.protocolVersion = result.protocolVersion;\n    }\n    if (result.serverInfo) {\n      sessionData.serverInfo = extractPartyInfo(result.serverInfo);\n    }\n  }\n  return sessionData;\n}\n\n/**\n * Build client attributes from stored client info\n * @param transport - MCP transport instance\n * @returns Client attributes for span instrumentation\n */\nfunction getClientAttributes(transport) {\n  const clientInfo = sessionManagement.getClientInfoForTransport(transport);\n  const attributes = {};\n\n  if (clientInfo?.name) {\n    attributes['mcp.client.name'] = clientInfo.name;\n  }\n  if (clientInfo?.title) {\n    attributes['mcp.client.title'] = clientInfo.title;\n  }\n  if (clientInfo?.version) {\n    attributes['mcp.client.version'] = clientInfo.version;\n  }\n\n  return attributes;\n}\n\n/**\n * Build server attributes from stored server info\n * @param transport - MCP transport instance\n * @returns Server attributes for span instrumentation\n */\nfunction getServerAttributes(transport) {\n  const serverInfo = sessionManagement.getSessionDataForTransport(transport)?.serverInfo;\n  const attributes$1 = {};\n\n  if (serverInfo?.name) {\n    attributes$1[attributes.MCP_SERVER_NAME_ATTRIBUTE] = serverInfo.name;\n  }\n  if (serverInfo?.title) {\n    attributes$1[attributes.MCP_SERVER_TITLE_ATTRIBUTE] = serverInfo.title;\n  }\n  if (serverInfo?.version) {\n    attributes$1[attributes.MCP_SERVER_VERSION_ATTRIBUTE] = serverInfo.version;\n  }\n\n  return attributes$1;\n}\n\n/**\n * Extracts client connection info from extra handler data\n * @param extra - Extra handler data containing connection info\n * @returns Client address and port information\n */\nfunction extractClientInfo(extra)\n\n {\n  return {\n    address:\n      extra?.requestInfo?.remoteAddress ||\n      extra?.clientAddress ||\n      extra?.request?.ip ||\n      extra?.request?.connection?.remoteAddress,\n    port: extra?.requestInfo?.remotePort || extra?.clientPort || extra?.request?.connection?.remotePort,\n  };\n}\n\n/**\n * Extracts transport types based on transport constructor name\n * @param transport - MCP transport instance\n * @returns Transport type mapping for span attributes\n */\nfunction getTransportTypes(transport) {\n  const transportName = transport.constructor?.name?.toLowerCase() || '';\n\n  if (transportName.includes('stdio')) {\n    return { mcpTransport: 'stdio', networkTransport: 'pipe' };\n  }\n\n  if (transportName.includes('streamablehttp') || transportName.includes('streamable')) {\n    return { mcpTransport: 'http', networkTransport: 'tcp' };\n  }\n\n  if (transportName.includes('sse')) {\n    return { mcpTransport: 'sse', networkTransport: 'tcp' };\n  }\n\n  return { mcpTransport: 'unknown', networkTransport: 'unknown' };\n}\n\n/**\n * Build transport and network attributes\n * @param transport - MCP transport instance\n * @param extra - Optional extra handler data\n * @returns Transport attributes for span instrumentation\n */\nfunction buildTransportAttributes(\n  transport,\n  extra,\n) {\n  const sessionId = transport.sessionId;\n  const clientInfo = extra ? extractClientInfo(extra) : {};\n  const { mcpTransport, networkTransport } = getTransportTypes(transport);\n  const clientAttributes = getClientAttributes(transport);\n  const serverAttributes = getServerAttributes(transport);\n  const protocolVersion = sessionManagement.getProtocolVersionForTransport(transport);\n\n  const attributes$1 = {\n    ...(sessionId && { [attributes.MCP_SESSION_ID_ATTRIBUTE]: sessionId }),\n    ...(clientInfo.address && { [attributes.CLIENT_ADDRESS_ATTRIBUTE]: clientInfo.address }),\n    ...(clientInfo.port && { [attributes.CLIENT_PORT_ATTRIBUTE]: clientInfo.port }),\n    [attributes.MCP_TRANSPORT_ATTRIBUTE]: mcpTransport,\n    [attributes.NETWORK_TRANSPORT_ATTRIBUTE]: networkTransport,\n    [attributes.NETWORK_PROTOCOL_VERSION_ATTRIBUTE]: '2.0',\n    ...(protocolVersion && { [attributes.MCP_PROTOCOL_VERSION_ATTRIBUTE]: protocolVersion }),\n    ...clientAttributes,\n    ...serverAttributes,\n  };\n\n  return attributes$1;\n}\n\nexports.buildTransportAttributes = buildTransportAttributes;\nexports.extractClientInfo = extractClientInfo;\nexports.extractSessionDataFromInitializeRequest = extractSessionDataFromInitializeRequest;\nexports.extractSessionDataFromInitializeResponse = extractSessionDataFromInitializeResponse;\nexports.getClientAttributes = getClientAttributes;\nexports.getServerAttributes = getServerAttributes;\nexports.getTransportTypes = getTransportTypes;\n//# sourceMappingURL=sessionExtraction.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvaW50ZWdyYXRpb25zL21jcC1zZXJ2ZXIvc2Vzc2lvbkV4dHJhY3Rpb24uanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsbUJBQW1CLG1CQUFPLENBQUMsd0pBQWlCO0FBQzVDLDBCQUEwQixtQkFBTyxDQUFDLHNLQUF3QjtBQUMxRCxtQkFBbUIsbUJBQU8sQ0FBQyx3SkFBaUI7O0FBRTVDO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7OztBQUdBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBLGFBQWE7QUFDYjs7QUFFQTtBQUNBLGFBQWE7QUFDYjs7QUFFQTtBQUNBLGFBQWE7QUFDYjs7QUFFQSxXQUFXO0FBQ1g7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsVUFBVSxpQ0FBaUM7QUFDM0M7QUFDQTtBQUNBOztBQUVBO0FBQ0EsdUJBQXVCLGtEQUFrRDtBQUN6RSxnQ0FBZ0MsMkRBQTJEO0FBQzNGLDZCQUE2QixxREFBcUQ7QUFDbEY7QUFDQTtBQUNBO0FBQ0EsNkJBQTZCLDhEQUE4RDtBQUMzRjtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQSxnQ0FBZ0M7QUFDaEMseUJBQXlCO0FBQ3pCLCtDQUErQztBQUMvQyxnREFBZ0Q7QUFDaEQsMkJBQTJCO0FBQzNCLDJCQUEyQjtBQUMzQix5QkFBeUI7QUFDekIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvbWNwLXNlcnZlci9zZXNzaW9uRXh0cmFjdGlvbi5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgYXR0cmlidXRlcyA9IHJlcXVpcmUoJy4vYXR0cmlidXRlcy5qcycpO1xuY29uc3Qgc2Vzc2lvbk1hbmFnZW1lbnQgPSByZXF1aXJlKCcuL3Nlc3Npb25NYW5hZ2VtZW50LmpzJyk7XG5jb25zdCB2YWxpZGF0aW9uID0gcmVxdWlyZSgnLi92YWxpZGF0aW9uLmpzJyk7XG5cbi8qKlxuICogU2Vzc2lvbiBhbmQgcGFydHkgaW5mbyBleHRyYWN0aW9uIGZ1bmN0aW9ucyBmb3IgTUNQIHNlcnZlciBpbnN0cnVtZW50YXRpb25cbiAqXG4gKiBIYW5kbGVzIGV4dHJhY3Rpb24gb2YgY2xpZW50L3NlcnZlciBpbmZvIGFuZCBzZXNzaW9uIGRhdGEgZnJvbSBNQ1AgbWVzc2FnZXMuXG4gKi9cblxuXG4vKipcbiAqIEV4dHJhY3RzIGFuZCB2YWxpZGF0ZXMgUGFydHlJbmZvIGZyb20gYW4gdW5rbm93biBvYmplY3RcbiAqIEBwYXJhbSBvYmogLSBVbmtub3duIG9iamVjdCB0aGF0IG1pZ2h0IGNvbnRhaW4gcGFydHkgaW5mb1xuICogQHJldHVybnMgVmFsaWRhdGVkIFBhcnR5SW5mbyBvYmplY3Qgd2l0aCBvbmx5IHN0cmluZyBwcm9wZXJ0aWVzXG4gKi9cbmZ1bmN0aW9uIGV4dHJhY3RQYXJ0eUluZm8ob2JqKSB7XG4gIGNvbnN0IHBhcnR5SW5mbyA9IHt9O1xuXG4gIGlmICh2YWxpZGF0aW9uLmlzVmFsaWRDb250ZW50SXRlbShvYmopKSB7XG4gICAgaWYgKHR5cGVvZiBvYmoubmFtZSA9PT0gJ3N0cmluZycpIHtcbiAgICAgIHBhcnR5SW5mby5uYW1lID0gb2JqLm5hbWU7XG4gICAgfVxuICAgIGlmICh0eXBlb2Ygb2JqLnRpdGxlID09PSAnc3RyaW5nJykge1xuICAgICAgcGFydHlJbmZvLnRpdGxlID0gb2JqLnRpdGxlO1xuICAgIH1cbiAgICBpZiAodHlwZW9mIG9iai52ZXJzaW9uID09PSAnc3RyaW5nJykge1xuICAgICAgcGFydHlJbmZvLnZlcnNpb24gPSBvYmoudmVyc2lvbjtcbiAgICB9XG4gIH1cblxuICByZXR1cm4gcGFydHlJbmZvO1xufVxuXG4vKipcbiAqIEV4dHJhY3RzIHNlc3Npb24gZGF0YSBmcm9tIFwiaW5pdGlhbGl6ZVwiIHJlcXVlc3RzXG4gKiBAcGFyYW0gcmVxdWVzdCAtIEpTT04tUlBDIFwiaW5pdGlhbGl6ZVwiIHJlcXVlc3QgY29udGFpbmluZyBjbGllbnQgaW5mbyBhbmQgcHJvdG9jb2wgdmVyc2lvblxuICogQHJldHVybnMgU2Vzc2lvbiBkYXRhIGV4dHJhY3RlZCBmcm9tIHJlcXVlc3QgcGFyYW1ldGVycyBpbmNsdWRpbmcgcHJvdG9jb2wgdmVyc2lvbiBhbmQgY2xpZW50IGluZm9cbiAqL1xuZnVuY3Rpb24gZXh0cmFjdFNlc3Npb25EYXRhRnJvbUluaXRpYWxpemVSZXF1ZXN0KHJlcXVlc3QpIHtcbiAgY29uc3Qgc2Vzc2lvbkRhdGEgPSB7fTtcbiAgaWYgKHZhbGlkYXRpb24uaXNWYWxpZENvbnRlbnRJdGVtKHJlcXVlc3QucGFyYW1zKSkge1xuICAgIGlmICh0eXBlb2YgcmVxdWVzdC5wYXJhbXMucHJvdG9jb2xWZXJzaW9uID09PSAnc3RyaW5nJykge1xuICAgICAgc2Vzc2lvbkRhdGEucHJvdG9jb2xWZXJzaW9uID0gcmVxdWVzdC5wYXJhbXMucHJvdG9jb2xWZXJzaW9uO1xuICAgIH1cbiAgICBpZiAocmVxdWVzdC5wYXJhbXMuY2xpZW50SW5mbykge1xuICAgICAgc2Vzc2lvbkRhdGEuY2xpZW50SW5mbyA9IGV4dHJhY3RQYXJ0eUluZm8ocmVxdWVzdC5wYXJhbXMuY2xpZW50SW5mbyk7XG4gICAgfVxuICB9XG4gIHJldHVybiBzZXNzaW9uRGF0YTtcbn1cblxuLyoqXG4gKiBFeHRyYWN0cyBzZXNzaW9uIGRhdGEgZnJvbSBcImluaXRpYWxpemVcIiByZXNwb25zZVxuICogQHBhcmFtIHJlc3VsdCAtIFwiaW5pdGlhbGl6ZVwiIHJlc3BvbnNlIHJlc3VsdCBjb250YWluaW5nIHNlcnZlciBpbmZvIGFuZCBwcm90b2NvbCB2ZXJzaW9uXG4gKiBAcmV0dXJucyBQYXJ0aWFsIHNlc3Npb24gZGF0YSBleHRyYWN0ZWQgZnJvbSByZXNwb25zZSBpbmNsdWRpbmcgcHJvdG9jb2wgdmVyc2lvbiBhbmQgc2VydmVyIGluZm9cbiAqL1xuZnVuY3Rpb24gZXh0cmFjdFNlc3Npb25EYXRhRnJvbUluaXRpYWxpemVSZXNwb25zZShyZXN1bHQpIHtcbiAgY29uc3Qgc2Vzc2lvbkRhdGEgPSB7fTtcbiAgaWYgKHZhbGlkYXRpb24uaXNWYWxpZENvbnRlbnRJdGVtKHJlc3VsdCkpIHtcbiAgICBpZiAodHlwZW9mIHJlc3VsdC5wcm90b2NvbFZlcnNpb24gPT09ICdzdHJpbmcnKSB7XG4gICAgICBzZXNzaW9uRGF0YS5wcm90b2NvbFZlcnNpb24gPSByZXN1bHQucHJvdG9jb2xWZXJzaW9uO1xuICAgIH1cbiAgICBpZiAocmVzdWx0LnNlcnZlckluZm8pIHtcbiAgICAgIHNlc3Npb25EYXRhLnNlcnZlckluZm8gPSBleHRyYWN0UGFydHlJbmZvKHJlc3VsdC5zZXJ2ZXJJbmZvKTtcbiAgICB9XG4gIH1cbiAgcmV0dXJuIHNlc3Npb25EYXRhO1xufVxuXG4vKipcbiAqIEJ1aWxkIGNsaWVudCBhdHRyaWJ1dGVzIGZyb20gc3RvcmVkIGNsaWVudCBpbmZvXG4gKiBAcGFyYW0gdHJhbnNwb3J0IC0gTUNQIHRyYW5zcG9ydCBpbnN0YW5jZVxuICogQHJldHVybnMgQ2xpZW50IGF0dHJpYnV0ZXMgZm9yIHNwYW4gaW5zdHJ1bWVudGF0aW9uXG4gKi9cbmZ1bmN0aW9uIGdldENsaWVudEF0dHJpYnV0ZXModHJhbnNwb3J0KSB7XG4gIGNvbnN0IGNsaWVudEluZm8gPSBzZXNzaW9uTWFuYWdlbWVudC5nZXRDbGllbnRJbmZvRm9yVHJhbnNwb3J0KHRyYW5zcG9ydCk7XG4gIGNvbnN0IGF0dHJpYnV0ZXMgPSB7fTtcblxuICBpZiAoY2xpZW50SW5mbz8ubmFtZSkge1xuICAgIGF0dHJpYnV0ZXNbJ21jcC5jbGllbnQubmFtZSddID0gY2xpZW50SW5mby5uYW1lO1xuICB9XG4gIGlmIChjbGllbnRJbmZvPy50aXRsZSkge1xuICAgIGF0dHJpYnV0ZXNbJ21jcC5jbGllbnQudGl0bGUnXSA9IGNsaWVudEluZm8udGl0bGU7XG4gIH1cbiAgaWYgKGNsaWVudEluZm8/LnZlcnNpb24pIHtcbiAgICBhdHRyaWJ1dGVzWydtY3AuY2xpZW50LnZlcnNpb24nXSA9IGNsaWVudEluZm8udmVyc2lvbjtcbiAgfVxuXG4gIHJldHVybiBhdHRyaWJ1dGVzO1xufVxuXG4vKipcbiAqIEJ1aWxkIHNlcnZlciBhdHRyaWJ1dGVzIGZyb20gc3RvcmVkIHNlcnZlciBpbmZvXG4gKiBAcGFyYW0gdHJhbnNwb3J0IC0gTUNQIHRyYW5zcG9ydCBpbnN0YW5jZVxuICogQHJldHVybnMgU2VydmVyIGF0dHJpYnV0ZXMgZm9yIHNwYW4gaW5zdHJ1bWVudGF0aW9uXG4gKi9cbmZ1bmN0aW9uIGdldFNlcnZlckF0dHJpYnV0ZXModHJhbnNwb3J0KSB7XG4gIGNvbnN0IHNlcnZlckluZm8gPSBzZXNzaW9uTWFuYWdlbWVudC5nZXRTZXNzaW9uRGF0YUZvclRyYW5zcG9ydCh0cmFuc3BvcnQpPy5zZXJ2ZXJJbmZvO1xuICBjb25zdCBhdHRyaWJ1dGVzJDEgPSB7fTtcblxuICBpZiAoc2VydmVySW5mbz8ubmFtZSkge1xuICAgIGF0dHJpYnV0ZXMkMVthdHRyaWJ1dGVzLk1DUF9TRVJWRVJfTkFNRV9BVFRSSUJVVEVdID0gc2VydmVySW5mby5uYW1lO1xuICB9XG4gIGlmIChzZXJ2ZXJJbmZvPy50aXRsZSkge1xuICAgIGF0dHJpYnV0ZXMkMVthdHRyaWJ1dGVzLk1DUF9TRVJWRVJfVElUTEVfQVRUUklCVVRFXSA9IHNlcnZlckluZm8udGl0bGU7XG4gIH1cbiAgaWYgKHNlcnZlckluZm8/LnZlcnNpb24pIHtcbiAgICBhdHRyaWJ1dGVzJDFbYXR0cmlidXRlcy5NQ1BfU0VSVkVSX1ZFUlNJT05fQVRUUklCVVRFXSA9IHNlcnZlckluZm8udmVyc2lvbjtcbiAgfVxuXG4gIHJldHVybiBhdHRyaWJ1dGVzJDE7XG59XG5cbi8qKlxuICogRXh0cmFjdHMgY2xpZW50IGNvbm5lY3Rpb24gaW5mbyBmcm9tIGV4dHJhIGhhbmRsZXIgZGF0YVxuICogQHBhcmFtIGV4dHJhIC0gRXh0cmEgaGFuZGxlciBkYXRhIGNvbnRhaW5pbmcgY29ubmVjdGlvbiBpbmZvXG4gKiBAcmV0dXJucyBDbGllbnQgYWRkcmVzcyBhbmQgcG9ydCBpbmZvcm1hdGlvblxuICovXG5mdW5jdGlvbiBleHRyYWN0Q2xpZW50SW5mbyhleHRyYSlcblxuIHtcbiAgcmV0dXJuIHtcbiAgICBhZGRyZXNzOlxuICAgICAgZXh0cmE/LnJlcXVlc3RJbmZvPy5yZW1vdGVBZGRyZXNzIHx8XG4gICAgICBleHRyYT8uY2xpZW50QWRkcmVzcyB8fFxuICAgICAgZXh0cmE/LnJlcXVlc3Q/LmlwIHx8XG4gICAgICBleHRyYT8ucmVxdWVzdD8uY29ubmVjdGlvbj8ucmVtb3RlQWRkcmVzcyxcbiAgICBwb3J0OiBleHRyYT8ucmVxdWVzdEluZm8/LnJlbW90ZVBvcnQgfHwgZXh0cmE/LmNsaWVudFBvcnQgfHwgZXh0cmE/LnJlcXVlc3Q/LmNvbm5lY3Rpb24/LnJlbW90ZVBvcnQsXG4gIH07XG59XG5cbi8qKlxuICogRXh0cmFjdHMgdHJhbnNwb3J0IHR5cGVzIGJhc2VkIG9uIHRyYW5zcG9ydCBjb25zdHJ1Y3RvciBuYW1lXG4gKiBAcGFyYW0gdHJhbnNwb3J0IC0gTUNQIHRyYW5zcG9ydCBpbnN0YW5jZVxuICogQHJldHVybnMgVHJhbnNwb3J0IHR5cGUgbWFwcGluZyBmb3Igc3BhbiBhdHRyaWJ1dGVzXG4gKi9cbmZ1bmN0aW9uIGdldFRyYW5zcG9ydFR5cGVzKHRyYW5zcG9ydCkge1xuICBjb25zdCB0cmFuc3BvcnROYW1lID0gdHJhbnNwb3J0LmNvbnN0cnVjdG9yPy5uYW1lPy50b0xvd2VyQ2FzZSgpIHx8ICcnO1xuXG4gIGlmICh0cmFuc3BvcnROYW1lLmluY2x1ZGVzKCdzdGRpbycpKSB7XG4gICAgcmV0dXJuIHsgbWNwVHJhbnNwb3J0OiAnc3RkaW8nLCBuZXR3b3JrVHJhbnNwb3J0OiAncGlwZScgfTtcbiAgfVxuXG4gIGlmICh0cmFuc3BvcnROYW1lLmluY2x1ZGVzKCdzdHJlYW1hYmxlaHR0cCcpIHx8IHRyYW5zcG9ydE5hbWUuaW5jbHVkZXMoJ3N0cmVhbWFibGUnKSkge1xuICAgIHJldHVybiB7IG1jcFRyYW5zcG9ydDogJ2h0dHAnLCBuZXR3b3JrVHJhbnNwb3J0OiAndGNwJyB9O1xuICB9XG5cbiAgaWYgKHRyYW5zcG9ydE5hbWUuaW5jbHVkZXMoJ3NzZScpKSB7XG4gICAgcmV0dXJuIHsgbWNwVHJhbnNwb3J0OiAnc3NlJywgbmV0d29ya1RyYW5zcG9ydDogJ3RjcCcgfTtcbiAgfVxuXG4gIHJldHVybiB7IG1jcFRyYW5zcG9ydDogJ3Vua25vd24nLCBuZXR3b3JrVHJhbnNwb3J0OiAndW5rbm93bicgfTtcbn1cblxuLyoqXG4gKiBCdWlsZCB0cmFuc3BvcnQgYW5kIG5ldHdvcmsgYXR0cmlidXRlc1xuICogQHBhcmFtIHRyYW5zcG9ydCAtIE1DUCB0cmFuc3BvcnQgaW5zdGFuY2VcbiAqIEBwYXJhbSBleHRyYSAtIE9wdGlvbmFsIGV4dHJhIGhhbmRsZXIgZGF0YVxuICogQHJldHVybnMgVHJhbnNwb3J0IGF0dHJpYnV0ZXMgZm9yIHNwYW4gaW5zdHJ1bWVudGF0aW9uXG4gKi9cbmZ1bmN0aW9uIGJ1aWxkVHJhbnNwb3J0QXR0cmlidXRlcyhcbiAgdHJhbnNwb3J0LFxuICBleHRyYSxcbikge1xuICBjb25zdCBzZXNzaW9uSWQgPSB0cmFuc3BvcnQuc2Vzc2lvbklkO1xuICBjb25zdCBjbGllbnRJbmZvID0gZXh0cmEgPyBleHRyYWN0Q2xpZW50SW5mbyhleHRyYSkgOiB7fTtcbiAgY29uc3QgeyBtY3BUcmFuc3BvcnQsIG5ldHdvcmtUcmFuc3BvcnQgfSA9IGdldFRyYW5zcG9ydFR5cGVzKHRyYW5zcG9ydCk7XG4gIGNvbnN0IGNsaWVudEF0dHJpYnV0ZXMgPSBnZXRDbGllbnRBdHRyaWJ1dGVzKHRyYW5zcG9ydCk7XG4gIGNvbnN0IHNlcnZlckF0dHJpYnV0ZXMgPSBnZXRTZXJ2ZXJBdHRyaWJ1dGVzKHRyYW5zcG9ydCk7XG4gIGNvbnN0IHByb3RvY29sVmVyc2lvbiA9IHNlc3Npb25NYW5hZ2VtZW50LmdldFByb3RvY29sVmVyc2lvbkZvclRyYW5zcG9ydCh0cmFuc3BvcnQpO1xuXG4gIGNvbnN0IGF0dHJpYnV0ZXMkMSA9IHtcbiAgICAuLi4oc2Vzc2lvbklkICYmIHsgW2F0dHJpYnV0ZXMuTUNQX1NFU1NJT05fSURfQVRUUklCVVRFXTogc2Vzc2lvbklkIH0pLFxuICAgIC4uLihjbGllbnRJbmZvLmFkZHJlc3MgJiYgeyBbYXR0cmlidXRlcy5DTElFTlRfQUREUkVTU19BVFRSSUJVVEVdOiBjbGllbnRJbmZvLmFkZHJlc3MgfSksXG4gICAgLi4uKGNsaWVudEluZm8ucG9ydCAmJiB7IFthdHRyaWJ1dGVzLkNMSUVOVF9QT1JUX0FUVFJJQlVURV06IGNsaWVudEluZm8ucG9ydCB9KSxcbiAgICBbYXR0cmlidXRlcy5NQ1BfVFJBTlNQT1JUX0FUVFJJQlVURV06IG1jcFRyYW5zcG9ydCxcbiAgICBbYXR0cmlidXRlcy5ORVRXT1JLX1RSQU5TUE9SVF9BVFRSSUJVVEVdOiBuZXR3b3JrVHJhbnNwb3J0LFxuICAgIFthdHRyaWJ1dGVzLk5FVFdPUktfUFJPVE9DT0xfVkVSU0lPTl9BVFRSSUJVVEVdOiAnMi4wJyxcbiAgICAuLi4ocHJvdG9jb2xWZXJzaW9uICYmIHsgW2F0dHJpYnV0ZXMuTUNQX1BST1RPQ09MX1ZFUlNJT05fQVRUUklCVVRFXTogcHJvdG9jb2xWZXJzaW9uIH0pLFxuICAgIC4uLmNsaWVudEF0dHJpYnV0ZXMsXG4gICAgLi4uc2VydmVyQXR0cmlidXRlcyxcbiAgfTtcblxuICByZXR1cm4gYXR0cmlidXRlcyQxO1xufVxuXG5leHBvcnRzLmJ1aWxkVHJhbnNwb3J0QXR0cmlidXRlcyA9IGJ1aWxkVHJhbnNwb3J0QXR0cmlidXRlcztcbmV4cG9ydHMuZXh0cmFjdENsaWVudEluZm8gPSBleHRyYWN0Q2xpZW50SW5mbztcbmV4cG9ydHMuZXh0cmFjdFNlc3Npb25EYXRhRnJvbUluaXRpYWxpemVSZXF1ZXN0ID0gZXh0cmFjdFNlc3Npb25EYXRhRnJvbUluaXRpYWxpemVSZXF1ZXN0O1xuZXhwb3J0cy5leHRyYWN0U2Vzc2lvbkRhdGFGcm9tSW5pdGlhbGl6ZVJlc3BvbnNlID0gZXh0cmFjdFNlc3Npb25EYXRhRnJvbUluaXRpYWxpemVSZXNwb25zZTtcbmV4cG9ydHMuZ2V0Q2xpZW50QXR0cmlidXRlcyA9IGdldENsaWVudEF0dHJpYnV0ZXM7XG5leHBvcnRzLmdldFNlcnZlckF0dHJpYnV0ZXMgPSBnZXRTZXJ2ZXJBdHRyaWJ1dGVzO1xuZXhwb3J0cy5nZXRUcmFuc3BvcnRUeXBlcyA9IGdldFRyYW5zcG9ydFR5cGVzO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9c2Vzc2lvbkV4dHJhY3Rpb24uanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/sessionExtraction.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/sessionManagement.js":
/*!*********************************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/sessionManagement.js ***!
  \*********************************************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n/**\n * Transport-scoped session data storage (only for transports with sessionId)\n * @internal Maps transport instances to session-level data\n */\nconst transportToSessionData = new WeakMap();\n\n/**\n * Stores session data for a transport with sessionId\n * @param transport - MCP transport instance\n * @param sessionData - Session data to store\n */\nfunction storeSessionDataForTransport(transport, sessionData) {\n  if (transport.sessionId) {\n    transportToSessionData.set(transport, sessionData);\n  }\n}\n\n/**\n * Updates session data for a transport with sessionId (merges with existing data)\n * @param transport - MCP transport instance\n * @param partialSessionData - Partial session data to merge with existing data\n */\nfunction updateSessionDataForTransport(transport, partialSessionData) {\n  if (transport.sessionId) {\n    const existingData = transportToSessionData.get(transport) || {};\n    transportToSessionData.set(transport, { ...existingData, ...partialSessionData });\n  }\n}\n\n/**\n * Retrieves client information for a transport\n * @param transport - MCP transport instance\n * @returns Client information if available\n */\nfunction getClientInfoForTransport(transport) {\n  return transportToSessionData.get(transport)?.clientInfo;\n}\n\n/**\n * Retrieves protocol version for a transport\n * @param transport - MCP transport instance\n * @returns Protocol version if available\n */\nfunction getProtocolVersionForTransport(transport) {\n  return transportToSessionData.get(transport)?.protocolVersion;\n}\n\n/**\n * Retrieves full session data for a transport\n * @param transport - MCP transport instance\n * @returns Complete session data if available\n */\nfunction getSessionDataForTransport(transport) {\n  return transportToSessionData.get(transport);\n}\n\n/**\n * Cleans up session data for a specific transport (when that transport closes)\n * @param transport - MCP transport instance\n */\nfunction cleanupSessionDataForTransport(transport) {\n  transportToSessionData.delete(transport);\n}\n\nexports.cleanupSessionDataForTransport = cleanupSessionDataForTransport;\nexports.getClientInfoForTransport = getClientInfoForTransport;\nexports.getProtocolVersionForTransport = getProtocolVersionForTransport;\nexports.getSessionDataForTransport = getSessionDataForTransport;\nexports.storeSessionDataForTransport = storeSessionDataForTransport;\nexports.updateSessionDataForTransport = updateSessionDataForTransport;\n//# sourceMappingURL=sessionManagement.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvaW50ZWdyYXRpb25zL21jcC1zZXJ2ZXIvc2Vzc2lvbk1hbmFnZW1lbnQuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEU7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsNENBQTRDLHdDQUF3QztBQUNwRjtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLHNDQUFzQztBQUN0QyxpQ0FBaUM7QUFDakMsc0NBQXNDO0FBQ3RDLGtDQUFrQztBQUNsQyxvQ0FBb0M7QUFDcEMscUNBQXFDO0FBQ3JDIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvaW50ZWdyYXRpb25zL21jcC1zZXJ2ZXIvc2Vzc2lvbk1hbmFnZW1lbnQuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbi8qKlxuICogVHJhbnNwb3J0LXNjb3BlZCBzZXNzaW9uIGRhdGEgc3RvcmFnZSAob25seSBmb3IgdHJhbnNwb3J0cyB3aXRoIHNlc3Npb25JZClcbiAqIEBpbnRlcm5hbCBNYXBzIHRyYW5zcG9ydCBpbnN0YW5jZXMgdG8gc2Vzc2lvbi1sZXZlbCBkYXRhXG4gKi9cbmNvbnN0IHRyYW5zcG9ydFRvU2Vzc2lvbkRhdGEgPSBuZXcgV2Vha01hcCgpO1xuXG4vKipcbiAqIFN0b3JlcyBzZXNzaW9uIGRhdGEgZm9yIGEgdHJhbnNwb3J0IHdpdGggc2Vzc2lvbklkXG4gKiBAcGFyYW0gdHJhbnNwb3J0IC0gTUNQIHRyYW5zcG9ydCBpbnN0YW5jZVxuICogQHBhcmFtIHNlc3Npb25EYXRhIC0gU2Vzc2lvbiBkYXRhIHRvIHN0b3JlXG4gKi9cbmZ1bmN0aW9uIHN0b3JlU2Vzc2lvbkRhdGFGb3JUcmFuc3BvcnQodHJhbnNwb3J0LCBzZXNzaW9uRGF0YSkge1xuICBpZiAodHJhbnNwb3J0LnNlc3Npb25JZCkge1xuICAgIHRyYW5zcG9ydFRvU2Vzc2lvbkRhdGEuc2V0KHRyYW5zcG9ydCwgc2Vzc2lvbkRhdGEpO1xuICB9XG59XG5cbi8qKlxuICogVXBkYXRlcyBzZXNzaW9uIGRhdGEgZm9yIGEgdHJhbnNwb3J0IHdpdGggc2Vzc2lvbklkIChtZXJnZXMgd2l0aCBleGlzdGluZyBkYXRhKVxuICogQHBhcmFtIHRyYW5zcG9ydCAtIE1DUCB0cmFuc3BvcnQgaW5zdGFuY2VcbiAqIEBwYXJhbSBwYXJ0aWFsU2Vzc2lvbkRhdGEgLSBQYXJ0aWFsIHNlc3Npb24gZGF0YSB0byBtZXJnZSB3aXRoIGV4aXN0aW5nIGRhdGFcbiAqL1xuZnVuY3Rpb24gdXBkYXRlU2Vzc2lvbkRhdGFGb3JUcmFuc3BvcnQodHJhbnNwb3J0LCBwYXJ0aWFsU2Vzc2lvbkRhdGEpIHtcbiAgaWYgKHRyYW5zcG9ydC5zZXNzaW9uSWQpIHtcbiAgICBjb25zdCBleGlzdGluZ0RhdGEgPSB0cmFuc3BvcnRUb1Nlc3Npb25EYXRhLmdldCh0cmFuc3BvcnQpIHx8IHt9O1xuICAgIHRyYW5zcG9ydFRvU2Vzc2lvbkRhdGEuc2V0KHRyYW5zcG9ydCwgeyAuLi5leGlzdGluZ0RhdGEsIC4uLnBhcnRpYWxTZXNzaW9uRGF0YSB9KTtcbiAgfVxufVxuXG4vKipcbiAqIFJldHJpZXZlcyBjbGllbnQgaW5mb3JtYXRpb24gZm9yIGEgdHJhbnNwb3J0XG4gKiBAcGFyYW0gdHJhbnNwb3J0IC0gTUNQIHRyYW5zcG9ydCBpbnN0YW5jZVxuICogQHJldHVybnMgQ2xpZW50IGluZm9ybWF0aW9uIGlmIGF2YWlsYWJsZVxuICovXG5mdW5jdGlvbiBnZXRDbGllbnRJbmZvRm9yVHJhbnNwb3J0KHRyYW5zcG9ydCkge1xuICByZXR1cm4gdHJhbnNwb3J0VG9TZXNzaW9uRGF0YS5nZXQodHJhbnNwb3J0KT8uY2xpZW50SW5mbztcbn1cblxuLyoqXG4gKiBSZXRyaWV2ZXMgcHJvdG9jb2wgdmVyc2lvbiBmb3IgYSB0cmFuc3BvcnRcbiAqIEBwYXJhbSB0cmFuc3BvcnQgLSBNQ1AgdHJhbnNwb3J0IGluc3RhbmNlXG4gKiBAcmV0dXJucyBQcm90b2NvbCB2ZXJzaW9uIGlmIGF2YWlsYWJsZVxuICovXG5mdW5jdGlvbiBnZXRQcm90b2NvbFZlcnNpb25Gb3JUcmFuc3BvcnQodHJhbnNwb3J0KSB7XG4gIHJldHVybiB0cmFuc3BvcnRUb1Nlc3Npb25EYXRhLmdldCh0cmFuc3BvcnQpPy5wcm90b2NvbFZlcnNpb247XG59XG5cbi8qKlxuICogUmV0cmlldmVzIGZ1bGwgc2Vzc2lvbiBkYXRhIGZvciBhIHRyYW5zcG9ydFxuICogQHBhcmFtIHRyYW5zcG9ydCAtIE1DUCB0cmFuc3BvcnQgaW5zdGFuY2VcbiAqIEByZXR1cm5zIENvbXBsZXRlIHNlc3Npb24gZGF0YSBpZiBhdmFpbGFibGVcbiAqL1xuZnVuY3Rpb24gZ2V0U2Vzc2lvbkRhdGFGb3JUcmFuc3BvcnQodHJhbnNwb3J0KSB7XG4gIHJldHVybiB0cmFuc3BvcnRUb1Nlc3Npb25EYXRhLmdldCh0cmFuc3BvcnQpO1xufVxuXG4vKipcbiAqIENsZWFucyB1cCBzZXNzaW9uIGRhdGEgZm9yIGEgc3BlY2lmaWMgdHJhbnNwb3J0ICh3aGVuIHRoYXQgdHJhbnNwb3J0IGNsb3NlcylcbiAqIEBwYXJhbSB0cmFuc3BvcnQgLSBNQ1AgdHJhbnNwb3J0IGluc3RhbmNlXG4gKi9cbmZ1bmN0aW9uIGNsZWFudXBTZXNzaW9uRGF0YUZvclRyYW5zcG9ydCh0cmFuc3BvcnQpIHtcbiAgdHJhbnNwb3J0VG9TZXNzaW9uRGF0YS5kZWxldGUodHJhbnNwb3J0KTtcbn1cblxuZXhwb3J0cy5jbGVhbnVwU2Vzc2lvbkRhdGFGb3JUcmFuc3BvcnQgPSBjbGVhbnVwU2Vzc2lvbkRhdGFGb3JUcmFuc3BvcnQ7XG5leHBvcnRzLmdldENsaWVudEluZm9Gb3JUcmFuc3BvcnQgPSBnZXRDbGllbnRJbmZvRm9yVHJhbnNwb3J0O1xuZXhwb3J0cy5nZXRQcm90b2NvbFZlcnNpb25Gb3JUcmFuc3BvcnQgPSBnZXRQcm90b2NvbFZlcnNpb25Gb3JUcmFuc3BvcnQ7XG5leHBvcnRzLmdldFNlc3Npb25EYXRhRm9yVHJhbnNwb3J0ID0gZ2V0U2Vzc2lvbkRhdGFGb3JUcmFuc3BvcnQ7XG5leHBvcnRzLnN0b3JlU2Vzc2lvbkRhdGFGb3JUcmFuc3BvcnQgPSBzdG9yZVNlc3Npb25EYXRhRm9yVHJhbnNwb3J0O1xuZXhwb3J0cy51cGRhdGVTZXNzaW9uRGF0YUZvclRyYW5zcG9ydCA9IHVwZGF0ZVNlc3Npb25EYXRhRm9yVHJhbnNwb3J0O1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9c2Vzc2lvbk1hbmFnZW1lbnQuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/sessionManagement.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/spans.js":
/*!*********************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/spans.js ***!
  \*********************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst currentScopes = __webpack_require__(/*! ../../currentScopes.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst semanticAttributes = __webpack_require__(/*! ../../semanticAttributes.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/semanticAttributes.js\");\nconst trace = __webpack_require__(/*! ../../tracing/trace.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/trace.js\");\nconst attributeExtraction = __webpack_require__(/*! ./attributeExtraction.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/attributeExtraction.js\");\nconst attributes = __webpack_require__(/*! ./attributes.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/attributes.js\");\nconst methodConfig = __webpack_require__(/*! ./methodConfig.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/methodConfig.js\");\nconst piiFiltering = __webpack_require__(/*! ./piiFiltering.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/piiFiltering.js\");\nconst sessionExtraction = __webpack_require__(/*! ./sessionExtraction.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/sessionExtraction.js\");\n\n/**\n * Span creation and management functions for MCP server instrumentation\n *\n * Provides unified span creation following OpenTelemetry MCP semantic conventions and our opinitionated take on MCP.\n * Handles both request and notification spans with attribute extraction.\n */\n\n\n/**\n * Creates a span name based on the method and target\n * @internal\n * @param method - MCP method name\n * @param target - Optional target identifier\n * @returns Formatted span name\n */\nfunction createSpanName(method, target) {\n  return target ? `${method} ${target}` : method;\n}\n\n/**\n * Build Sentry-specific attributes based on span type\n * @internal\n * @param type - Span type configuration\n * @returns Sentry-specific attributes\n */\nfunction buildSentryAttributes(type) {\n  let op;\n  let origin;\n\n  switch (type) {\n    case 'request':\n      op = attributes.MCP_SERVER_OP_VALUE;\n      origin = attributes.MCP_FUNCTION_ORIGIN_VALUE;\n      break;\n    case 'notification-incoming':\n      op = attributes.MCP_NOTIFICATION_CLIENT_TO_SERVER_OP_VALUE;\n      origin = attributes.MCP_NOTIFICATION_ORIGIN_VALUE;\n      break;\n    case 'notification-outgoing':\n      op = attributes.MCP_NOTIFICATION_SERVER_TO_CLIENT_OP_VALUE;\n      origin = attributes.MCP_NOTIFICATION_ORIGIN_VALUE;\n      break;\n  }\n\n  return {\n    [semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_OP]: op,\n    [semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_ORIGIN]: origin,\n    [semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_SOURCE]: attributes.MCP_ROUTE_SOURCE_VALUE,\n  };\n}\n\n/**\n * Unified builder for creating MCP spans\n * @internal\n * @param config - Span configuration\n * @returns Created span\n */\nfunction createMcpSpan(config) {\n  const { type, message, transport, extra, callback } = config;\n  const { method } = message;\n  const params = message.params ;\n\n  // Determine span name based on type and OTEL conventions\n  let spanName;\n  if (type === 'request') {\n    const targetInfo = methodConfig.extractTargetInfo(method, params || {});\n    spanName = createSpanName(method, targetInfo.target);\n  } else {\n    // For notifications, use method name directly per OpenTelemetry conventions\n    spanName = method;\n  }\n\n  const rawAttributes = {\n    ...sessionExtraction.buildTransportAttributes(transport, extra),\n    [attributes.MCP_METHOD_NAME_ATTRIBUTE]: method,\n    ...attributeExtraction.buildTypeSpecificAttributes(type, message, params),\n    ...buildSentryAttributes(type),\n  };\n\n  const client = currentScopes.getClient();\n  const sendDefaultPii = Boolean(client?.getOptions().sendDefaultPii);\n  const attributes$1 = piiFiltering.filterMcpPiiFromSpanData(rawAttributes, sendDefaultPii) ;\n\n  return trace.startSpan(\n    {\n      name: spanName,\n      forceTransaction: true,\n      attributes: attributes$1,\n    },\n    callback,\n  );\n}\n\n/**\n * Creates a span for incoming MCP notifications\n * @param jsonRpcMessage - Notification message\n * @param transport - MCP transport instance\n * @param extra - Extra handler data\n * @param callback - Span execution callback\n * @returns Span execution result\n */\nfunction createMcpNotificationSpan(\n  jsonRpcMessage,\n  transport,\n  extra,\n  callback,\n) {\n  return createMcpSpan({\n    type: 'notification-incoming',\n    message: jsonRpcMessage,\n    transport,\n    extra,\n    callback,\n  });\n}\n\n/**\n * Creates a span for outgoing MCP notifications\n * @param jsonRpcMessage - Notification message\n * @param transport - MCP transport instance\n * @param callback - Span execution callback\n * @returns Span execution result\n */\nfunction createMcpOutgoingNotificationSpan(\n  jsonRpcMessage,\n  transport,\n  callback,\n) {\n  return createMcpSpan({\n    type: 'notification-outgoing',\n    message: jsonRpcMessage,\n    transport,\n    callback,\n  });\n}\n\n/**\n * Builds span configuration for MCP server requests\n * @param jsonRpcMessage - Request message\n * @param transport - MCP transport instance\n * @param extra - Optional extra handler data\n * @returns Span configuration object\n */\nfunction buildMcpServerSpanConfig(\n  jsonRpcMessage,\n  transport,\n  extra,\n)\n\n {\n  const { method } = jsonRpcMessage;\n  const params = jsonRpcMessage.params ;\n\n  const targetInfo = methodConfig.extractTargetInfo(method, params || {});\n  const spanName = createSpanName(method, targetInfo.target);\n\n  const rawAttributes = {\n    ...sessionExtraction.buildTransportAttributes(transport, extra),\n    [attributes.MCP_METHOD_NAME_ATTRIBUTE]: method,\n    ...attributeExtraction.buildTypeSpecificAttributes('request', jsonRpcMessage, params),\n    ...buildSentryAttributes('request'),\n  };\n\n  const client = currentScopes.getClient();\n  const sendDefaultPii = Boolean(client?.getOptions().sendDefaultPii);\n  const attributes$1 = piiFiltering.filterMcpPiiFromSpanData(rawAttributes, sendDefaultPii) ;\n\n  return {\n    name: spanName,\n    op: attributes.MCP_SERVER_OP_VALUE,\n    forceTransaction: true,\n    attributes: attributes$1,\n  };\n}\n\nexports.buildMcpServerSpanConfig = buildMcpServerSpanConfig;\nexports.createMcpNotificationSpan = createMcpNotificationSpan;\nexports.createMcpOutgoingNotificationSpan = createMcpOutgoingNotificationSpan;\n//# sourceMappingURL=spans.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvaW50ZWdyYXRpb25zL21jcC1zZXJ2ZXIvc3BhbnMuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsc0JBQXNCLG1CQUFPLENBQUMsMElBQXdCO0FBQ3RELDJCQUEyQixtQkFBTyxDQUFDLG9KQUE2QjtBQUNoRSxjQUFjLG1CQUFPLENBQUMsMElBQXdCO0FBQzlDLDRCQUE0QixtQkFBTyxDQUFDLDBLQUEwQjtBQUM5RCxtQkFBbUIsbUJBQU8sQ0FBQyx3SkFBaUI7QUFDNUMscUJBQXFCLG1CQUFPLENBQUMsNEpBQW1CO0FBQ2hELHFCQUFxQixtQkFBTyxDQUFDLDRKQUFtQjtBQUNoRCwwQkFBMEIsbUJBQU8sQ0FBQyxzS0FBd0I7O0FBRTFEO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7O0FBR0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLHFCQUFxQixRQUFRLEVBQUUsT0FBTztBQUN0Qzs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxVQUFVLDRDQUE0QztBQUN0RCxVQUFVLFNBQVM7QUFDbkI7O0FBRUE7QUFDQTtBQUNBO0FBQ0EsMEVBQTBFO0FBQzFFO0FBQ0EsSUFBSTtBQUNKO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxLQUFLO0FBQ0w7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxHQUFHO0FBQ0g7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEdBQUc7QUFDSDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQSxVQUFVLFNBQVM7QUFDbkI7O0FBRUEsd0VBQXdFO0FBQ3hFOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsZ0NBQWdDO0FBQ2hDLGlDQUFpQztBQUNqQyx5Q0FBeUM7QUFDekMiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvbWNwLXNlcnZlci9zcGFucy5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgY3VycmVudFNjb3BlcyA9IHJlcXVpcmUoJy4uLy4uL2N1cnJlbnRTY29wZXMuanMnKTtcbmNvbnN0IHNlbWFudGljQXR0cmlidXRlcyA9IHJlcXVpcmUoJy4uLy4uL3NlbWFudGljQXR0cmlidXRlcy5qcycpO1xuY29uc3QgdHJhY2UgPSByZXF1aXJlKCcuLi8uLi90cmFjaW5nL3RyYWNlLmpzJyk7XG5jb25zdCBhdHRyaWJ1dGVFeHRyYWN0aW9uID0gcmVxdWlyZSgnLi9hdHRyaWJ1dGVFeHRyYWN0aW9uLmpzJyk7XG5jb25zdCBhdHRyaWJ1dGVzID0gcmVxdWlyZSgnLi9hdHRyaWJ1dGVzLmpzJyk7XG5jb25zdCBtZXRob2RDb25maWcgPSByZXF1aXJlKCcuL21ldGhvZENvbmZpZy5qcycpO1xuY29uc3QgcGlpRmlsdGVyaW5nID0gcmVxdWlyZSgnLi9waWlGaWx0ZXJpbmcuanMnKTtcbmNvbnN0IHNlc3Npb25FeHRyYWN0aW9uID0gcmVxdWlyZSgnLi9zZXNzaW9uRXh0cmFjdGlvbi5qcycpO1xuXG4vKipcbiAqIFNwYW4gY3JlYXRpb24gYW5kIG1hbmFnZW1lbnQgZnVuY3Rpb25zIGZvciBNQ1Agc2VydmVyIGluc3RydW1lbnRhdGlvblxuICpcbiAqIFByb3ZpZGVzIHVuaWZpZWQgc3BhbiBjcmVhdGlvbiBmb2xsb3dpbmcgT3BlblRlbGVtZXRyeSBNQ1Agc2VtYW50aWMgY29udmVudGlvbnMgYW5kIG91ciBvcGluaXRpb25hdGVkIHRha2Ugb24gTUNQLlxuICogSGFuZGxlcyBib3RoIHJlcXVlc3QgYW5kIG5vdGlmaWNhdGlvbiBzcGFucyB3aXRoIGF0dHJpYnV0ZSBleHRyYWN0aW9uLlxuICovXG5cblxuLyoqXG4gKiBDcmVhdGVzIGEgc3BhbiBuYW1lIGJhc2VkIG9uIHRoZSBtZXRob2QgYW5kIHRhcmdldFxuICogQGludGVybmFsXG4gKiBAcGFyYW0gbWV0aG9kIC0gTUNQIG1ldGhvZCBuYW1lXG4gKiBAcGFyYW0gdGFyZ2V0IC0gT3B0aW9uYWwgdGFyZ2V0IGlkZW50aWZpZXJcbiAqIEByZXR1cm5zIEZvcm1hdHRlZCBzcGFuIG5hbWVcbiAqL1xuZnVuY3Rpb24gY3JlYXRlU3Bhbk5hbWUobWV0aG9kLCB0YXJnZXQpIHtcbiAgcmV0dXJuIHRhcmdldCA/IGAke21ldGhvZH0gJHt0YXJnZXR9YCA6IG1ldGhvZDtcbn1cblxuLyoqXG4gKiBCdWlsZCBTZW50cnktc3BlY2lmaWMgYXR0cmlidXRlcyBiYXNlZCBvbiBzcGFuIHR5cGVcbiAqIEBpbnRlcm5hbFxuICogQHBhcmFtIHR5cGUgLSBTcGFuIHR5cGUgY29uZmlndXJhdGlvblxuICogQHJldHVybnMgU2VudHJ5LXNwZWNpZmljIGF0dHJpYnV0ZXNcbiAqL1xuZnVuY3Rpb24gYnVpbGRTZW50cnlBdHRyaWJ1dGVzKHR5cGUpIHtcbiAgbGV0IG9wO1xuICBsZXQgb3JpZ2luO1xuXG4gIHN3aXRjaCAodHlwZSkge1xuICAgIGNhc2UgJ3JlcXVlc3QnOlxuICAgICAgb3AgPSBhdHRyaWJ1dGVzLk1DUF9TRVJWRVJfT1BfVkFMVUU7XG4gICAgICBvcmlnaW4gPSBhdHRyaWJ1dGVzLk1DUF9GVU5DVElPTl9PUklHSU5fVkFMVUU7XG4gICAgICBicmVhaztcbiAgICBjYXNlICdub3RpZmljYXRpb24taW5jb21pbmcnOlxuICAgICAgb3AgPSBhdHRyaWJ1dGVzLk1DUF9OT1RJRklDQVRJT05fQ0xJRU5UX1RPX1NFUlZFUl9PUF9WQUxVRTtcbiAgICAgIG9yaWdpbiA9IGF0dHJpYnV0ZXMuTUNQX05PVElGSUNBVElPTl9PUklHSU5fVkFMVUU7XG4gICAgICBicmVhaztcbiAgICBjYXNlICdub3RpZmljYXRpb24tb3V0Z29pbmcnOlxuICAgICAgb3AgPSBhdHRyaWJ1dGVzLk1DUF9OT1RJRklDQVRJT05fU0VSVkVSX1RPX0NMSUVOVF9PUF9WQUxVRTtcbiAgICAgIG9yaWdpbiA9IGF0dHJpYnV0ZXMuTUNQX05PVElGSUNBVElPTl9PUklHSU5fVkFMVUU7XG4gICAgICBicmVhaztcbiAgfVxuXG4gIHJldHVybiB7XG4gICAgW3NlbWFudGljQXR0cmlidXRlcy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX09QXTogb3AsXG4gICAgW3NlbWFudGljQXR0cmlidXRlcy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX09SSUdJTl06IG9yaWdpbixcbiAgICBbc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfU09VUkNFXTogYXR0cmlidXRlcy5NQ1BfUk9VVEVfU09VUkNFX1ZBTFVFLFxuICB9O1xufVxuXG4vKipcbiAqIFVuaWZpZWQgYnVpbGRlciBmb3IgY3JlYXRpbmcgTUNQIHNwYW5zXG4gKiBAaW50ZXJuYWxcbiAqIEBwYXJhbSBjb25maWcgLSBTcGFuIGNvbmZpZ3VyYXRpb25cbiAqIEByZXR1cm5zIENyZWF0ZWQgc3BhblxuICovXG5mdW5jdGlvbiBjcmVhdGVNY3BTcGFuKGNvbmZpZykge1xuICBjb25zdCB7IHR5cGUsIG1lc3NhZ2UsIHRyYW5zcG9ydCwgZXh0cmEsIGNhbGxiYWNrIH0gPSBjb25maWc7XG4gIGNvbnN0IHsgbWV0aG9kIH0gPSBtZXNzYWdlO1xuICBjb25zdCBwYXJhbXMgPSBtZXNzYWdlLnBhcmFtcyA7XG5cbiAgLy8gRGV0ZXJtaW5lIHNwYW4gbmFtZSBiYXNlZCBvbiB0eXBlIGFuZCBPVEVMIGNvbnZlbnRpb25zXG4gIGxldCBzcGFuTmFtZTtcbiAgaWYgKHR5cGUgPT09ICdyZXF1ZXN0Jykge1xuICAgIGNvbnN0IHRhcmdldEluZm8gPSBtZXRob2RDb25maWcuZXh0cmFjdFRhcmdldEluZm8obWV0aG9kLCBwYXJhbXMgfHwge30pO1xuICAgIHNwYW5OYW1lID0gY3JlYXRlU3Bhbk5hbWUobWV0aG9kLCB0YXJnZXRJbmZvLnRhcmdldCk7XG4gIH0gZWxzZSB7XG4gICAgLy8gRm9yIG5vdGlmaWNhdGlvbnMsIHVzZSBtZXRob2QgbmFtZSBkaXJlY3RseSBwZXIgT3BlblRlbGVtZXRyeSBjb252ZW50aW9uc1xuICAgIHNwYW5OYW1lID0gbWV0aG9kO1xuICB9XG5cbiAgY29uc3QgcmF3QXR0cmlidXRlcyA9IHtcbiAgICAuLi5zZXNzaW9uRXh0cmFjdGlvbi5idWlsZFRyYW5zcG9ydEF0dHJpYnV0ZXModHJhbnNwb3J0LCBleHRyYSksXG4gICAgW2F0dHJpYnV0ZXMuTUNQX01FVEhPRF9OQU1FX0FUVFJJQlVURV06IG1ldGhvZCxcbiAgICAuLi5hdHRyaWJ1dGVFeHRyYWN0aW9uLmJ1aWxkVHlwZVNwZWNpZmljQXR0cmlidXRlcyh0eXBlLCBtZXNzYWdlLCBwYXJhbXMpLFxuICAgIC4uLmJ1aWxkU2VudHJ5QXR0cmlidXRlcyh0eXBlKSxcbiAgfTtcblxuICBjb25zdCBjbGllbnQgPSBjdXJyZW50U2NvcGVzLmdldENsaWVudCgpO1xuICBjb25zdCBzZW5kRGVmYXVsdFBpaSA9IEJvb2xlYW4oY2xpZW50Py5nZXRPcHRpb25zKCkuc2VuZERlZmF1bHRQaWkpO1xuICBjb25zdCBhdHRyaWJ1dGVzJDEgPSBwaWlGaWx0ZXJpbmcuZmlsdGVyTWNwUGlpRnJvbVNwYW5EYXRhKHJhd0F0dHJpYnV0ZXMsIHNlbmREZWZhdWx0UGlpKSA7XG5cbiAgcmV0dXJuIHRyYWNlLnN0YXJ0U3BhbihcbiAgICB7XG4gICAgICBuYW1lOiBzcGFuTmFtZSxcbiAgICAgIGZvcmNlVHJhbnNhY3Rpb246IHRydWUsXG4gICAgICBhdHRyaWJ1dGVzOiBhdHRyaWJ1dGVzJDEsXG4gICAgfSxcbiAgICBjYWxsYmFjayxcbiAgKTtcbn1cblxuLyoqXG4gKiBDcmVhdGVzIGEgc3BhbiBmb3IgaW5jb21pbmcgTUNQIG5vdGlmaWNhdGlvbnNcbiAqIEBwYXJhbSBqc29uUnBjTWVzc2FnZSAtIE5vdGlmaWNhdGlvbiBtZXNzYWdlXG4gKiBAcGFyYW0gdHJhbnNwb3J0IC0gTUNQIHRyYW5zcG9ydCBpbnN0YW5jZVxuICogQHBhcmFtIGV4dHJhIC0gRXh0cmEgaGFuZGxlciBkYXRhXG4gKiBAcGFyYW0gY2FsbGJhY2sgLSBTcGFuIGV4ZWN1dGlvbiBjYWxsYmFja1xuICogQHJldHVybnMgU3BhbiBleGVjdXRpb24gcmVzdWx0XG4gKi9cbmZ1bmN0aW9uIGNyZWF0ZU1jcE5vdGlmaWNhdGlvblNwYW4oXG4gIGpzb25ScGNNZXNzYWdlLFxuICB0cmFuc3BvcnQsXG4gIGV4dHJhLFxuICBjYWxsYmFjayxcbikge1xuICByZXR1cm4gY3JlYXRlTWNwU3Bhbih7XG4gICAgdHlwZTogJ25vdGlmaWNhdGlvbi1pbmNvbWluZycsXG4gICAgbWVzc2FnZToganNvblJwY01lc3NhZ2UsXG4gICAgdHJhbnNwb3J0LFxuICAgIGV4dHJhLFxuICAgIGNhbGxiYWNrLFxuICB9KTtcbn1cblxuLyoqXG4gKiBDcmVhdGVzIGEgc3BhbiBmb3Igb3V0Z29pbmcgTUNQIG5vdGlmaWNhdGlvbnNcbiAqIEBwYXJhbSBqc29uUnBjTWVzc2FnZSAtIE5vdGlmaWNhdGlvbiBtZXNzYWdlXG4gKiBAcGFyYW0gdHJhbnNwb3J0IC0gTUNQIHRyYW5zcG9ydCBpbnN0YW5jZVxuICogQHBhcmFtIGNhbGxiYWNrIC0gU3BhbiBleGVjdXRpb24gY2FsbGJhY2tcbiAqIEByZXR1cm5zIFNwYW4gZXhlY3V0aW9uIHJlc3VsdFxuICovXG5mdW5jdGlvbiBjcmVhdGVNY3BPdXRnb2luZ05vdGlmaWNhdGlvblNwYW4oXG4gIGpzb25ScGNNZXNzYWdlLFxuICB0cmFuc3BvcnQsXG4gIGNhbGxiYWNrLFxuKSB7XG4gIHJldHVybiBjcmVhdGVNY3BTcGFuKHtcbiAgICB0eXBlOiAnbm90aWZpY2F0aW9uLW91dGdvaW5nJyxcbiAgICBtZXNzYWdlOiBqc29uUnBjTWVzc2FnZSxcbiAgICB0cmFuc3BvcnQsXG4gICAgY2FsbGJhY2ssXG4gIH0pO1xufVxuXG4vKipcbiAqIEJ1aWxkcyBzcGFuIGNvbmZpZ3VyYXRpb24gZm9yIE1DUCBzZXJ2ZXIgcmVxdWVzdHNcbiAqIEBwYXJhbSBqc29uUnBjTWVzc2FnZSAtIFJlcXVlc3QgbWVzc2FnZVxuICogQHBhcmFtIHRyYW5zcG9ydCAtIE1DUCB0cmFuc3BvcnQgaW5zdGFuY2VcbiAqIEBwYXJhbSBleHRyYSAtIE9wdGlvbmFsIGV4dHJhIGhhbmRsZXIgZGF0YVxuICogQHJldHVybnMgU3BhbiBjb25maWd1cmF0aW9uIG9iamVjdFxuICovXG5mdW5jdGlvbiBidWlsZE1jcFNlcnZlclNwYW5Db25maWcoXG4gIGpzb25ScGNNZXNzYWdlLFxuICB0cmFuc3BvcnQsXG4gIGV4dHJhLFxuKVxuXG4ge1xuICBjb25zdCB7IG1ldGhvZCB9ID0ganNvblJwY01lc3NhZ2U7XG4gIGNvbnN0IHBhcmFtcyA9IGpzb25ScGNNZXNzYWdlLnBhcmFtcyA7XG5cbiAgY29uc3QgdGFyZ2V0SW5mbyA9IG1ldGhvZENvbmZpZy5leHRyYWN0VGFyZ2V0SW5mbyhtZXRob2QsIHBhcmFtcyB8fCB7fSk7XG4gIGNvbnN0IHNwYW5OYW1lID0gY3JlYXRlU3Bhbk5hbWUobWV0aG9kLCB0YXJnZXRJbmZvLnRhcmdldCk7XG5cbiAgY29uc3QgcmF3QXR0cmlidXRlcyA9IHtcbiAgICAuLi5zZXNzaW9uRXh0cmFjdGlvbi5idWlsZFRyYW5zcG9ydEF0dHJpYnV0ZXModHJhbnNwb3J0LCBleHRyYSksXG4gICAgW2F0dHJpYnV0ZXMuTUNQX01FVEhPRF9OQU1FX0FUVFJJQlVURV06IG1ldGhvZCxcbiAgICAuLi5hdHRyaWJ1dGVFeHRyYWN0aW9uLmJ1aWxkVHlwZVNwZWNpZmljQXR0cmlidXRlcygncmVxdWVzdCcsIGpzb25ScGNNZXNzYWdlLCBwYXJhbXMpLFxuICAgIC4uLmJ1aWxkU2VudHJ5QXR0cmlidXRlcygncmVxdWVzdCcpLFxuICB9O1xuXG4gIGNvbnN0IGNsaWVudCA9IGN1cnJlbnRTY29wZXMuZ2V0Q2xpZW50KCk7XG4gIGNvbnN0IHNlbmREZWZhdWx0UGlpID0gQm9vbGVhbihjbGllbnQ/LmdldE9wdGlvbnMoKS5zZW5kRGVmYXVsdFBpaSk7XG4gIGNvbnN0IGF0dHJpYnV0ZXMkMSA9IHBpaUZpbHRlcmluZy5maWx0ZXJNY3BQaWlGcm9tU3BhbkRhdGEocmF3QXR0cmlidXRlcywgc2VuZERlZmF1bHRQaWkpIDtcblxuICByZXR1cm4ge1xuICAgIG5hbWU6IHNwYW5OYW1lLFxuICAgIG9wOiBhdHRyaWJ1dGVzLk1DUF9TRVJWRVJfT1BfVkFMVUUsXG4gICAgZm9yY2VUcmFuc2FjdGlvbjogdHJ1ZSxcbiAgICBhdHRyaWJ1dGVzOiBhdHRyaWJ1dGVzJDEsXG4gIH07XG59XG5cbmV4cG9ydHMuYnVpbGRNY3BTZXJ2ZXJTcGFuQ29uZmlnID0gYnVpbGRNY3BTZXJ2ZXJTcGFuQ29uZmlnO1xuZXhwb3J0cy5jcmVhdGVNY3BOb3RpZmljYXRpb25TcGFuID0gY3JlYXRlTWNwTm90aWZpY2F0aW9uU3BhbjtcbmV4cG9ydHMuY3JlYXRlTWNwT3V0Z29pbmdOb3RpZmljYXRpb25TcGFuID0gY3JlYXRlTWNwT3V0Z29pbmdOb3RpZmljYXRpb25TcGFuO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9c3BhbnMuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/spans.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/transport.js":
/*!*************************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/transport.js ***!
  \*************************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst currentScopes = __webpack_require__(/*! ../../currentScopes.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst object = __webpack_require__(/*! ../../utils/object.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/object.js\");\nconst trace = __webpack_require__(/*! ../../tracing/trace.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/trace.js\");\nconst correlation = __webpack_require__(/*! ./correlation.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/correlation.js\");\nconst errorCapture = __webpack_require__(/*! ./errorCapture.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/errorCapture.js\");\nconst sessionExtraction = __webpack_require__(/*! ./sessionExtraction.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/sessionExtraction.js\");\nconst sessionManagement = __webpack_require__(/*! ./sessionManagement.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/sessionManagement.js\");\nconst spans = __webpack_require__(/*! ./spans.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/spans.js\");\nconst validation = __webpack_require__(/*! ./validation.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/validation.js\");\n\n/**\n * Transport layer instrumentation for MCP server\n *\n * Handles message interception and response correlation.\n * @see https://modelcontextprotocol.io/specification/2025-06-18/basic/transports\n */\n\n\n/**\n * Wraps transport.onmessage to create spans for incoming messages.\n * For \"initialize\" requests, extracts and stores client info and protocol version\n * in the session data for the transport.\n * @param transport - MCP transport instance to wrap\n */\nfunction wrapTransportOnMessage(transport) {\n  if (transport.onmessage) {\n    object.fill(transport, 'onmessage', originalOnMessage => {\n      return function ( message, extra) {\n        if (validation.isJsonRpcRequest(message)) {\n          if (message.method === 'initialize') {\n            try {\n              const sessionData = sessionExtraction.extractSessionDataFromInitializeRequest(message);\n              sessionManagement.storeSessionDataForTransport(this, sessionData);\n            } catch {\n              // noop\n            }\n          }\n\n          const isolationScope = currentScopes.getIsolationScope().clone();\n\n          return currentScopes.withIsolationScope(isolationScope, () => {\n            const spanConfig = spans.buildMcpServerSpanConfig(message, this, extra );\n            const span = trace.startInactiveSpan(spanConfig);\n\n            correlation.storeSpanForRequest(this, message.id, span, message.method);\n\n            return trace.withActiveSpan(span, () => {\n              return (originalOnMessage ).call(this, message, extra);\n            });\n          });\n        }\n\n        if (validation.isJsonRpcNotification(message)) {\n          return spans.createMcpNotificationSpan(message, this, extra , () => {\n            return (originalOnMessage ).call(this, message, extra);\n          });\n        }\n\n        return (originalOnMessage ).call(this, message, extra);\n      };\n    });\n  }\n}\n\n/**\n * Wraps transport.send to handle outgoing messages and response correlation.\n * For \"initialize\" responses, extracts and stores protocol version and server info\n * in the session data for the transport.\n * @param transport - MCP transport instance to wrap\n */\nfunction wrapTransportSend(transport) {\n  if (transport.send) {\n    object.fill(transport, 'send', originalSend => {\n      return async function ( ...args) {\n        const [message] = args;\n\n        if (validation.isJsonRpcNotification(message)) {\n          return spans.createMcpOutgoingNotificationSpan(message, this, () => {\n            return (originalSend ).call(this, ...args);\n          });\n        }\n\n        if (validation.isJsonRpcResponse(message)) {\n          if (message.id !== null && message.id !== undefined) {\n            if (message.error) {\n              captureJsonRpcErrorResponse(message.error);\n            }\n\n            if (validation.isValidContentItem(message.result)) {\n              if (message.result.protocolVersion || message.result.serverInfo) {\n                try {\n                  const serverData = sessionExtraction.extractSessionDataFromInitializeResponse(message.result);\n                  sessionManagement.updateSessionDataForTransport(this, serverData);\n                } catch {\n                  // noop\n                }\n              }\n            }\n\n            correlation.completeSpanWithResults(this, message.id, message.result);\n          }\n        }\n\n        return (originalSend ).call(this, ...args);\n      };\n    });\n  }\n}\n\n/**\n * Wraps transport.onclose to clean up pending spans for this transport only\n * @param transport - MCP transport instance to wrap\n */\nfunction wrapTransportOnClose(transport) {\n  if (transport.onclose) {\n    object.fill(transport, 'onclose', originalOnClose => {\n      return function ( ...args) {\n        correlation.cleanupPendingSpansForTransport(this);\n        sessionManagement.cleanupSessionDataForTransport(this);\n        return (originalOnClose ).call(this, ...args);\n      };\n    });\n  }\n}\n\n/**\n * Wraps transport error handlers to capture connection errors\n * @param transport - MCP transport instance to wrap\n */\nfunction wrapTransportError(transport) {\n  if (transport.onerror) {\n    object.fill(transport, 'onerror', (originalOnError) => {\n      return function ( error) {\n        captureTransportError(error);\n        return originalOnError.call(this, error);\n      };\n    });\n  }\n}\n\n/**\n * Captures JSON-RPC error responses for server-side errors.\n * @see https://www.jsonrpc.org/specification#error_object\n * @internal\n * @param errorResponse - JSON-RPC error response\n */\nfunction captureJsonRpcErrorResponse(errorResponse) {\n  try {\n    if (errorResponse && typeof errorResponse === 'object' && 'code' in errorResponse && 'message' in errorResponse) {\n      const jsonRpcError = errorResponse ;\n\n      const isServerError =\n        jsonRpcError.code === -32603 || (jsonRpcError.code >= -32099 && jsonRpcError.code <= -32000);\n\n      if (isServerError) {\n        const error = new Error(jsonRpcError.message);\n        error.name = `JsonRpcError_${jsonRpcError.code}`;\n\n        errorCapture.captureError(error, 'protocol');\n      }\n    }\n  } catch {\n    // noop\n  }\n}\n\n/**\n * Captures transport connection errors\n * @internal\n * @param error - Transport error\n */\nfunction captureTransportError(error) {\n  try {\n    errorCapture.captureError(error, 'transport');\n  } catch {\n    // noop\n  }\n}\n\nexports.wrapTransportError = wrapTransportError;\nexports.wrapTransportOnClose = wrapTransportOnClose;\nexports.wrapTransportOnMessage = wrapTransportOnMessage;\nexports.wrapTransportSend = wrapTransportSend;\n//# sourceMappingURL=transport.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvaW50ZWdyYXRpb25zL21jcC1zZXJ2ZXIvdHJhbnNwb3J0LmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLHNCQUFzQixtQkFBTyxDQUFDLDBJQUF3QjtBQUN0RCxlQUFlLG1CQUFPLENBQUMsd0lBQXVCO0FBQzlDLGNBQWMsbUJBQU8sQ0FBQywwSUFBd0I7QUFDOUMsb0JBQW9CLG1CQUFPLENBQUMsMEpBQWtCO0FBQzlDLHFCQUFxQixtQkFBTyxDQUFDLDRKQUFtQjtBQUNoRCwwQkFBMEIsbUJBQU8sQ0FBQyxzS0FBd0I7QUFDMUQsMEJBQTBCLG1CQUFPLENBQUMsc0tBQXdCO0FBQzFELGNBQWMsbUJBQU8sQ0FBQyw4SUFBWTtBQUNsQyxtQkFBbUIsbUJBQU8sQ0FBQyx3SkFBaUI7O0FBRTVDO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7O0FBR0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsY0FBYztBQUNkO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBLGFBQWE7QUFDYixXQUFXO0FBQ1g7O0FBRUE7QUFDQTtBQUNBO0FBQ0EsV0FBVztBQUNYOztBQUVBO0FBQ0E7QUFDQSxLQUFLO0FBQ0w7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBLFdBQVc7QUFDWDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxrQkFBa0I7QUFDbEI7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQSxLQUFLO0FBQ0w7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxLQUFLO0FBQ0w7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsS0FBSztBQUNMO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0EscUNBQXFDLGtCQUFrQjs7QUFFdkQ7QUFDQTtBQUNBO0FBQ0EsSUFBSTtBQUNKO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsSUFBSTtBQUNKO0FBQ0E7QUFDQTs7QUFFQSwwQkFBMEI7QUFDMUIsNEJBQTRCO0FBQzVCLDhCQUE4QjtBQUM5Qix5QkFBeUI7QUFDekIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvbWNwLXNlcnZlci90cmFuc3BvcnQuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGN1cnJlbnRTY29wZXMgPSByZXF1aXJlKCcuLi8uLi9jdXJyZW50U2NvcGVzLmpzJyk7XG5jb25zdCBvYmplY3QgPSByZXF1aXJlKCcuLi8uLi91dGlscy9vYmplY3QuanMnKTtcbmNvbnN0IHRyYWNlID0gcmVxdWlyZSgnLi4vLi4vdHJhY2luZy90cmFjZS5qcycpO1xuY29uc3QgY29ycmVsYXRpb24gPSByZXF1aXJlKCcuL2NvcnJlbGF0aW9uLmpzJyk7XG5jb25zdCBlcnJvckNhcHR1cmUgPSByZXF1aXJlKCcuL2Vycm9yQ2FwdHVyZS5qcycpO1xuY29uc3Qgc2Vzc2lvbkV4dHJhY3Rpb24gPSByZXF1aXJlKCcuL3Nlc3Npb25FeHRyYWN0aW9uLmpzJyk7XG5jb25zdCBzZXNzaW9uTWFuYWdlbWVudCA9IHJlcXVpcmUoJy4vc2Vzc2lvbk1hbmFnZW1lbnQuanMnKTtcbmNvbnN0IHNwYW5zID0gcmVxdWlyZSgnLi9zcGFucy5qcycpO1xuY29uc3QgdmFsaWRhdGlvbiA9IHJlcXVpcmUoJy4vdmFsaWRhdGlvbi5qcycpO1xuXG4vKipcbiAqIFRyYW5zcG9ydCBsYXllciBpbnN0cnVtZW50YXRpb24gZm9yIE1DUCBzZXJ2ZXJcbiAqXG4gKiBIYW5kbGVzIG1lc3NhZ2UgaW50ZXJjZXB0aW9uIGFuZCByZXNwb25zZSBjb3JyZWxhdGlvbi5cbiAqIEBzZWUgaHR0cHM6Ly9tb2RlbGNvbnRleHRwcm90b2NvbC5pby9zcGVjaWZpY2F0aW9uLzIwMjUtMDYtMTgvYmFzaWMvdHJhbnNwb3J0c1xuICovXG5cblxuLyoqXG4gKiBXcmFwcyB0cmFuc3BvcnQub25tZXNzYWdlIHRvIGNyZWF0ZSBzcGFucyBmb3IgaW5jb21pbmcgbWVzc2FnZXMuXG4gKiBGb3IgXCJpbml0aWFsaXplXCIgcmVxdWVzdHMsIGV4dHJhY3RzIGFuZCBzdG9yZXMgY2xpZW50IGluZm8gYW5kIHByb3RvY29sIHZlcnNpb25cbiAqIGluIHRoZSBzZXNzaW9uIGRhdGEgZm9yIHRoZSB0cmFuc3BvcnQuXG4gKiBAcGFyYW0gdHJhbnNwb3J0IC0gTUNQIHRyYW5zcG9ydCBpbnN0YW5jZSB0byB3cmFwXG4gKi9cbmZ1bmN0aW9uIHdyYXBUcmFuc3BvcnRPbk1lc3NhZ2UodHJhbnNwb3J0KSB7XG4gIGlmICh0cmFuc3BvcnQub25tZXNzYWdlKSB7XG4gICAgb2JqZWN0LmZpbGwodHJhbnNwb3J0LCAnb25tZXNzYWdlJywgb3JpZ2luYWxPbk1lc3NhZ2UgPT4ge1xuICAgICAgcmV0dXJuIGZ1bmN0aW9uICggbWVzc2FnZSwgZXh0cmEpIHtcbiAgICAgICAgaWYgKHZhbGlkYXRpb24uaXNKc29uUnBjUmVxdWVzdChtZXNzYWdlKSkge1xuICAgICAgICAgIGlmIChtZXNzYWdlLm1ldGhvZCA9PT0gJ2luaXRpYWxpemUnKSB7XG4gICAgICAgICAgICB0cnkge1xuICAgICAgICAgICAgICBjb25zdCBzZXNzaW9uRGF0YSA9IHNlc3Npb25FeHRyYWN0aW9uLmV4dHJhY3RTZXNzaW9uRGF0YUZyb21Jbml0aWFsaXplUmVxdWVzdChtZXNzYWdlKTtcbiAgICAgICAgICAgICAgc2Vzc2lvbk1hbmFnZW1lbnQuc3RvcmVTZXNzaW9uRGF0YUZvclRyYW5zcG9ydCh0aGlzLCBzZXNzaW9uRGF0YSk7XG4gICAgICAgICAgICB9IGNhdGNoIHtcbiAgICAgICAgICAgICAgLy8gbm9vcFxuICAgICAgICAgICAgfVxuICAgICAgICAgIH1cblxuICAgICAgICAgIGNvbnN0IGlzb2xhdGlvblNjb3BlID0gY3VycmVudFNjb3Blcy5nZXRJc29sYXRpb25TY29wZSgpLmNsb25lKCk7XG5cbiAgICAgICAgICByZXR1cm4gY3VycmVudFNjb3Blcy53aXRoSXNvbGF0aW9uU2NvcGUoaXNvbGF0aW9uU2NvcGUsICgpID0+IHtcbiAgICAgICAgICAgIGNvbnN0IHNwYW5Db25maWcgPSBzcGFucy5idWlsZE1jcFNlcnZlclNwYW5Db25maWcobWVzc2FnZSwgdGhpcywgZXh0cmEgKTtcbiAgICAgICAgICAgIGNvbnN0IHNwYW4gPSB0cmFjZS5zdGFydEluYWN0aXZlU3BhbihzcGFuQ29uZmlnKTtcblxuICAgICAgICAgICAgY29ycmVsYXRpb24uc3RvcmVTcGFuRm9yUmVxdWVzdCh0aGlzLCBtZXNzYWdlLmlkLCBzcGFuLCBtZXNzYWdlLm1ldGhvZCk7XG5cbiAgICAgICAgICAgIHJldHVybiB0cmFjZS53aXRoQWN0aXZlU3BhbihzcGFuLCAoKSA9PiB7XG4gICAgICAgICAgICAgIHJldHVybiAob3JpZ2luYWxPbk1lc3NhZ2UgKS5jYWxsKHRoaXMsIG1lc3NhZ2UsIGV4dHJhKTtcbiAgICAgICAgICAgIH0pO1xuICAgICAgICAgIH0pO1xuICAgICAgICB9XG5cbiAgICAgICAgaWYgKHZhbGlkYXRpb24uaXNKc29uUnBjTm90aWZpY2F0aW9uKG1lc3NhZ2UpKSB7XG4gICAgICAgICAgcmV0dXJuIHNwYW5zLmNyZWF0ZU1jcE5vdGlmaWNhdGlvblNwYW4obWVzc2FnZSwgdGhpcywgZXh0cmEgLCAoKSA9PiB7XG4gICAgICAgICAgICByZXR1cm4gKG9yaWdpbmFsT25NZXNzYWdlICkuY2FsbCh0aGlzLCBtZXNzYWdlLCBleHRyYSk7XG4gICAgICAgICAgfSk7XG4gICAgICAgIH1cblxuICAgICAgICByZXR1cm4gKG9yaWdpbmFsT25NZXNzYWdlICkuY2FsbCh0aGlzLCBtZXNzYWdlLCBleHRyYSk7XG4gICAgICB9O1xuICAgIH0pO1xuICB9XG59XG5cbi8qKlxuICogV3JhcHMgdHJhbnNwb3J0LnNlbmQgdG8gaGFuZGxlIG91dGdvaW5nIG1lc3NhZ2VzIGFuZCByZXNwb25zZSBjb3JyZWxhdGlvbi5cbiAqIEZvciBcImluaXRpYWxpemVcIiByZXNwb25zZXMsIGV4dHJhY3RzIGFuZCBzdG9yZXMgcHJvdG9jb2wgdmVyc2lvbiBhbmQgc2VydmVyIGluZm9cbiAqIGluIHRoZSBzZXNzaW9uIGRhdGEgZm9yIHRoZSB0cmFuc3BvcnQuXG4gKiBAcGFyYW0gdHJhbnNwb3J0IC0gTUNQIHRyYW5zcG9ydCBpbnN0YW5jZSB0byB3cmFwXG4gKi9cbmZ1bmN0aW9uIHdyYXBUcmFuc3BvcnRTZW5kKHRyYW5zcG9ydCkge1xuICBpZiAodHJhbnNwb3J0LnNlbmQpIHtcbiAgICBvYmplY3QuZmlsbCh0cmFuc3BvcnQsICdzZW5kJywgb3JpZ2luYWxTZW5kID0+IHtcbiAgICAgIHJldHVybiBhc3luYyBmdW5jdGlvbiAoIC4uLmFyZ3MpIHtcbiAgICAgICAgY29uc3QgW21lc3NhZ2VdID0gYXJncztcblxuICAgICAgICBpZiAodmFsaWRhdGlvbi5pc0pzb25ScGNOb3RpZmljYXRpb24obWVzc2FnZSkpIHtcbiAgICAgICAgICByZXR1cm4gc3BhbnMuY3JlYXRlTWNwT3V0Z29pbmdOb3RpZmljYXRpb25TcGFuKG1lc3NhZ2UsIHRoaXMsICgpID0+IHtcbiAgICAgICAgICAgIHJldHVybiAob3JpZ2luYWxTZW5kICkuY2FsbCh0aGlzLCAuLi5hcmdzKTtcbiAgICAgICAgICB9KTtcbiAgICAgICAgfVxuXG4gICAgICAgIGlmICh2YWxpZGF0aW9uLmlzSnNvblJwY1Jlc3BvbnNlKG1lc3NhZ2UpKSB7XG4gICAgICAgICAgaWYgKG1lc3NhZ2UuaWQgIT09IG51bGwgJiYgbWVzc2FnZS5pZCAhPT0gdW5kZWZpbmVkKSB7XG4gICAgICAgICAgICBpZiAobWVzc2FnZS5lcnJvcikge1xuICAgICAgICAgICAgICBjYXB0dXJlSnNvblJwY0Vycm9yUmVzcG9uc2UobWVzc2FnZS5lcnJvcik7XG4gICAgICAgICAgICB9XG5cbiAgICAgICAgICAgIGlmICh2YWxpZGF0aW9uLmlzVmFsaWRDb250ZW50SXRlbShtZXNzYWdlLnJlc3VsdCkpIHtcbiAgICAgICAgICAgICAgaWYgKG1lc3NhZ2UucmVzdWx0LnByb3RvY29sVmVyc2lvbiB8fCBtZXNzYWdlLnJlc3VsdC5zZXJ2ZXJJbmZvKSB7XG4gICAgICAgICAgICAgICAgdHJ5IHtcbiAgICAgICAgICAgICAgICAgIGNvbnN0IHNlcnZlckRhdGEgPSBzZXNzaW9uRXh0cmFjdGlvbi5leHRyYWN0U2Vzc2lvbkRhdGFGcm9tSW5pdGlhbGl6ZVJlc3BvbnNlKG1lc3NhZ2UucmVzdWx0KTtcbiAgICAgICAgICAgICAgICAgIHNlc3Npb25NYW5hZ2VtZW50LnVwZGF0ZVNlc3Npb25EYXRhRm9yVHJhbnNwb3J0KHRoaXMsIHNlcnZlckRhdGEpO1xuICAgICAgICAgICAgICAgIH0gY2F0Y2gge1xuICAgICAgICAgICAgICAgICAgLy8gbm9vcFxuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgfVxuXG4gICAgICAgICAgICBjb3JyZWxhdGlvbi5jb21wbGV0ZVNwYW5XaXRoUmVzdWx0cyh0aGlzLCBtZXNzYWdlLmlkLCBtZXNzYWdlLnJlc3VsdCk7XG4gICAgICAgICAgfVxuICAgICAgICB9XG5cbiAgICAgICAgcmV0dXJuIChvcmlnaW5hbFNlbmQgKS5jYWxsKHRoaXMsIC4uLmFyZ3MpO1xuICAgICAgfTtcbiAgICB9KTtcbiAgfVxufVxuXG4vKipcbiAqIFdyYXBzIHRyYW5zcG9ydC5vbmNsb3NlIHRvIGNsZWFuIHVwIHBlbmRpbmcgc3BhbnMgZm9yIHRoaXMgdHJhbnNwb3J0IG9ubHlcbiAqIEBwYXJhbSB0cmFuc3BvcnQgLSBNQ1AgdHJhbnNwb3J0IGluc3RhbmNlIHRvIHdyYXBcbiAqL1xuZnVuY3Rpb24gd3JhcFRyYW5zcG9ydE9uQ2xvc2UodHJhbnNwb3J0KSB7XG4gIGlmICh0cmFuc3BvcnQub25jbG9zZSkge1xuICAgIG9iamVjdC5maWxsKHRyYW5zcG9ydCwgJ29uY2xvc2UnLCBvcmlnaW5hbE9uQ2xvc2UgPT4ge1xuICAgICAgcmV0dXJuIGZ1bmN0aW9uICggLi4uYXJncykge1xuICAgICAgICBjb3JyZWxhdGlvbi5jbGVhbnVwUGVuZGluZ1NwYW5zRm9yVHJhbnNwb3J0KHRoaXMpO1xuICAgICAgICBzZXNzaW9uTWFuYWdlbWVudC5jbGVhbnVwU2Vzc2lvbkRhdGFGb3JUcmFuc3BvcnQodGhpcyk7XG4gICAgICAgIHJldHVybiAob3JpZ2luYWxPbkNsb3NlICkuY2FsbCh0aGlzLCAuLi5hcmdzKTtcbiAgICAgIH07XG4gICAgfSk7XG4gIH1cbn1cblxuLyoqXG4gKiBXcmFwcyB0cmFuc3BvcnQgZXJyb3IgaGFuZGxlcnMgdG8gY2FwdHVyZSBjb25uZWN0aW9uIGVycm9yc1xuICogQHBhcmFtIHRyYW5zcG9ydCAtIE1DUCB0cmFuc3BvcnQgaW5zdGFuY2UgdG8gd3JhcFxuICovXG5mdW5jdGlvbiB3cmFwVHJhbnNwb3J0RXJyb3IodHJhbnNwb3J0KSB7XG4gIGlmICh0cmFuc3BvcnQub25lcnJvcikge1xuICAgIG9iamVjdC5maWxsKHRyYW5zcG9ydCwgJ29uZXJyb3InLCAob3JpZ2luYWxPbkVycm9yKSA9PiB7XG4gICAgICByZXR1cm4gZnVuY3Rpb24gKCBlcnJvcikge1xuICAgICAgICBjYXB0dXJlVHJhbnNwb3J0RXJyb3IoZXJyb3IpO1xuICAgICAgICByZXR1cm4gb3JpZ2luYWxPbkVycm9yLmNhbGwodGhpcywgZXJyb3IpO1xuICAgICAgfTtcbiAgICB9KTtcbiAgfVxufVxuXG4vKipcbiAqIENhcHR1cmVzIEpTT04tUlBDIGVycm9yIHJlc3BvbnNlcyBmb3Igc2VydmVyLXNpZGUgZXJyb3JzLlxuICogQHNlZSBodHRwczovL3d3dy5qc29ucnBjLm9yZy9zcGVjaWZpY2F0aW9uI2Vycm9yX29iamVjdFxuICogQGludGVybmFsXG4gKiBAcGFyYW0gZXJyb3JSZXNwb25zZSAtIEpTT04tUlBDIGVycm9yIHJlc3BvbnNlXG4gKi9cbmZ1bmN0aW9uIGNhcHR1cmVKc29uUnBjRXJyb3JSZXNwb25zZShlcnJvclJlc3BvbnNlKSB7XG4gIHRyeSB7XG4gICAgaWYgKGVycm9yUmVzcG9uc2UgJiYgdHlwZW9mIGVycm9yUmVzcG9uc2UgPT09ICdvYmplY3QnICYmICdjb2RlJyBpbiBlcnJvclJlc3BvbnNlICYmICdtZXNzYWdlJyBpbiBlcnJvclJlc3BvbnNlKSB7XG4gICAgICBjb25zdCBqc29uUnBjRXJyb3IgPSBlcnJvclJlc3BvbnNlIDtcblxuICAgICAgY29uc3QgaXNTZXJ2ZXJFcnJvciA9XG4gICAgICAgIGpzb25ScGNFcnJvci5jb2RlID09PSAtMzI2MDMgfHwgKGpzb25ScGNFcnJvci5jb2RlID49IC0zMjA5OSAmJiBqc29uUnBjRXJyb3IuY29kZSA8PSAtMzIwMDApO1xuXG4gICAgICBpZiAoaXNTZXJ2ZXJFcnJvcikge1xuICAgICAgICBjb25zdCBlcnJvciA9IG5ldyBFcnJvcihqc29uUnBjRXJyb3IubWVzc2FnZSk7XG4gICAgICAgIGVycm9yLm5hbWUgPSBgSnNvblJwY0Vycm9yXyR7anNvblJwY0Vycm9yLmNvZGV9YDtcblxuICAgICAgICBlcnJvckNhcHR1cmUuY2FwdHVyZUVycm9yKGVycm9yLCAncHJvdG9jb2wnKTtcbiAgICAgIH1cbiAgICB9XG4gIH0gY2F0Y2gge1xuICAgIC8vIG5vb3BcbiAgfVxufVxuXG4vKipcbiAqIENhcHR1cmVzIHRyYW5zcG9ydCBjb25uZWN0aW9uIGVycm9yc1xuICogQGludGVybmFsXG4gKiBAcGFyYW0gZXJyb3IgLSBUcmFuc3BvcnQgZXJyb3JcbiAqL1xuZnVuY3Rpb24gY2FwdHVyZVRyYW5zcG9ydEVycm9yKGVycm9yKSB7XG4gIHRyeSB7XG4gICAgZXJyb3JDYXB0dXJlLmNhcHR1cmVFcnJvcihlcnJvciwgJ3RyYW5zcG9ydCcpO1xuICB9IGNhdGNoIHtcbiAgICAvLyBub29wXG4gIH1cbn1cblxuZXhwb3J0cy53cmFwVHJhbnNwb3J0RXJyb3IgPSB3cmFwVHJhbnNwb3J0RXJyb3I7XG5leHBvcnRzLndyYXBUcmFuc3BvcnRPbkNsb3NlID0gd3JhcFRyYW5zcG9ydE9uQ2xvc2U7XG5leHBvcnRzLndyYXBUcmFuc3BvcnRPbk1lc3NhZ2UgPSB3cmFwVHJhbnNwb3J0T25NZXNzYWdlO1xuZXhwb3J0cy53cmFwVHJhbnNwb3J0U2VuZCA9IHdyYXBUcmFuc3BvcnRTZW5kO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9dHJhbnNwb3J0LmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/transport.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/validation.js":
/*!**************************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/validation.js ***!
  \**************************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst debugBuild = __webpack_require__(/*! ../../debug-build.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst debugLogger = __webpack_require__(/*! ../../utils/debug-logger.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\n\n/**\n * Message validation functions for MCP server instrumentation\n *\n * Provides JSON-RPC 2.0 message type validation and MCP server instance validation.\n */\n\n\n/**\n * Validates if a message is a JSON-RPC request\n * @param message - Message to validate\n * @returns True if message is a JSON-RPC request\n */\nfunction isJsonRpcRequest(message) {\n  return (\n    typeof message === 'object' &&\n    message !== null &&\n    'jsonrpc' in message &&\n    (message ).jsonrpc === '2.0' &&\n    'method' in message &&\n    'id' in message\n  );\n}\n\n/**\n * Validates if a message is a JSON-RPC notification\n * @param message - Message to validate\n * @returns True if message is a JSON-RPC notification\n */\nfunction isJsonRpcNotification(message) {\n  return (\n    typeof message === 'object' &&\n    message !== null &&\n    'jsonrpc' in message &&\n    (message ).jsonrpc === '2.0' &&\n    'method' in message &&\n    !('id' in message)\n  );\n}\n\n/**\n * Validates if a message is a JSON-RPC response\n * @param message - Message to validate\n * @returns True if message is a JSON-RPC response\n */\nfunction isJsonRpcResponse(message) {\n  return (\n    typeof message === 'object' &&\n    message !== null &&\n    'jsonrpc' in message &&\n    (message ).jsonrpc === '2.0' &&\n    'id' in message &&\n    ('result' in message || 'error' in message)\n  );\n}\n\n/**\n * Validates MCP server instance with type checking\n * @param instance - Object to validate as MCP server instance\n * @returns True if instance has required MCP server methods\n */\nfunction validateMcpServerInstance(instance) {\n  if (\n    typeof instance === 'object' &&\n    instance !== null &&\n    'resource' in instance &&\n    'tool' in instance &&\n    'prompt' in instance &&\n    'connect' in instance\n  ) {\n    return true;\n  }\n  debugBuild.DEBUG_BUILD && debugLogger.debug.warn('Did not patch MCP server. Interface is incompatible.');\n  return false;\n}\n\n/**\n * Check if the item is a valid content item\n * @param item - The item to check\n * @returns True if the item is a valid content item, false otherwise\n */\nfunction isValidContentItem(item) {\n  return item != null && typeof item === 'object';\n}\n\nexports.isJsonRpcNotification = isJsonRpcNotification;\nexports.isJsonRpcRequest = isJsonRpcRequest;\nexports.isJsonRpcResponse = isJsonRpcResponse;\nexports.isValidContentItem = isValidContentItem;\nexports.validateMcpServerInstance = validateMcpServerInstance;\n//# sourceMappingURL=validation.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvaW50ZWdyYXRpb25zL21jcC1zZXJ2ZXIvdmFsaWRhdGlvbi5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxtQkFBbUIsbUJBQU8sQ0FBQyxzSUFBc0I7QUFDakQsb0JBQW9CLG1CQUFPLENBQUMsb0pBQTZCOztBQUV6RDtBQUNBO0FBQ0E7QUFDQTtBQUNBOzs7QUFHQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLDZCQUE2QjtBQUM3Qix3QkFBd0I7QUFDeEIseUJBQXlCO0FBQ3pCLDBCQUEwQjtBQUMxQixpQ0FBaUM7QUFDakMiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvbWNwLXNlcnZlci92YWxpZGF0aW9uLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBkZWJ1Z0J1aWxkID0gcmVxdWlyZSgnLi4vLi4vZGVidWctYnVpbGQuanMnKTtcbmNvbnN0IGRlYnVnTG9nZ2VyID0gcmVxdWlyZSgnLi4vLi4vdXRpbHMvZGVidWctbG9nZ2VyLmpzJyk7XG5cbi8qKlxuICogTWVzc2FnZSB2YWxpZGF0aW9uIGZ1bmN0aW9ucyBmb3IgTUNQIHNlcnZlciBpbnN0cnVtZW50YXRpb25cbiAqXG4gKiBQcm92aWRlcyBKU09OLVJQQyAyLjAgbWVzc2FnZSB0eXBlIHZhbGlkYXRpb24gYW5kIE1DUCBzZXJ2ZXIgaW5zdGFuY2UgdmFsaWRhdGlvbi5cbiAqL1xuXG5cbi8qKlxuICogVmFsaWRhdGVzIGlmIGEgbWVzc2FnZSBpcyBhIEpTT04tUlBDIHJlcXVlc3RcbiAqIEBwYXJhbSBtZXNzYWdlIC0gTWVzc2FnZSB0byB2YWxpZGF0ZVxuICogQHJldHVybnMgVHJ1ZSBpZiBtZXNzYWdlIGlzIGEgSlNPTi1SUEMgcmVxdWVzdFxuICovXG5mdW5jdGlvbiBpc0pzb25ScGNSZXF1ZXN0KG1lc3NhZ2UpIHtcbiAgcmV0dXJuIChcbiAgICB0eXBlb2YgbWVzc2FnZSA9PT0gJ29iamVjdCcgJiZcbiAgICBtZXNzYWdlICE9PSBudWxsICYmXG4gICAgJ2pzb25ycGMnIGluIG1lc3NhZ2UgJiZcbiAgICAobWVzc2FnZSApLmpzb25ycGMgPT09ICcyLjAnICYmXG4gICAgJ21ldGhvZCcgaW4gbWVzc2FnZSAmJlxuICAgICdpZCcgaW4gbWVzc2FnZVxuICApO1xufVxuXG4vKipcbiAqIFZhbGlkYXRlcyBpZiBhIG1lc3NhZ2UgaXMgYSBKU09OLVJQQyBub3RpZmljYXRpb25cbiAqIEBwYXJhbSBtZXNzYWdlIC0gTWVzc2FnZSB0byB2YWxpZGF0ZVxuICogQHJldHVybnMgVHJ1ZSBpZiBtZXNzYWdlIGlzIGEgSlNPTi1SUEMgbm90aWZpY2F0aW9uXG4gKi9cbmZ1bmN0aW9uIGlzSnNvblJwY05vdGlmaWNhdGlvbihtZXNzYWdlKSB7XG4gIHJldHVybiAoXG4gICAgdHlwZW9mIG1lc3NhZ2UgPT09ICdvYmplY3QnICYmXG4gICAgbWVzc2FnZSAhPT0gbnVsbCAmJlxuICAgICdqc29ucnBjJyBpbiBtZXNzYWdlICYmXG4gICAgKG1lc3NhZ2UgKS5qc29ucnBjID09PSAnMi4wJyAmJlxuICAgICdtZXRob2QnIGluIG1lc3NhZ2UgJiZcbiAgICAhKCdpZCcgaW4gbWVzc2FnZSlcbiAgKTtcbn1cblxuLyoqXG4gKiBWYWxpZGF0ZXMgaWYgYSBtZXNzYWdlIGlzIGEgSlNPTi1SUEMgcmVzcG9uc2VcbiAqIEBwYXJhbSBtZXNzYWdlIC0gTWVzc2FnZSB0byB2YWxpZGF0ZVxuICogQHJldHVybnMgVHJ1ZSBpZiBtZXNzYWdlIGlzIGEgSlNPTi1SUEMgcmVzcG9uc2VcbiAqL1xuZnVuY3Rpb24gaXNKc29uUnBjUmVzcG9uc2UobWVzc2FnZSkge1xuICByZXR1cm4gKFxuICAgIHR5cGVvZiBtZXNzYWdlID09PSAnb2JqZWN0JyAmJlxuICAgIG1lc3NhZ2UgIT09IG51bGwgJiZcbiAgICAnanNvbnJwYycgaW4gbWVzc2FnZSAmJlxuICAgIChtZXNzYWdlICkuanNvbnJwYyA9PT0gJzIuMCcgJiZcbiAgICAnaWQnIGluIG1lc3NhZ2UgJiZcbiAgICAoJ3Jlc3VsdCcgaW4gbWVzc2FnZSB8fCAnZXJyb3InIGluIG1lc3NhZ2UpXG4gICk7XG59XG5cbi8qKlxuICogVmFsaWRhdGVzIE1DUCBzZXJ2ZXIgaW5zdGFuY2Ugd2l0aCB0eXBlIGNoZWNraW5nXG4gKiBAcGFyYW0gaW5zdGFuY2UgLSBPYmplY3QgdG8gdmFsaWRhdGUgYXMgTUNQIHNlcnZlciBpbnN0YW5jZVxuICogQHJldHVybnMgVHJ1ZSBpZiBpbnN0YW5jZSBoYXMgcmVxdWlyZWQgTUNQIHNlcnZlciBtZXRob2RzXG4gKi9cbmZ1bmN0aW9uIHZhbGlkYXRlTWNwU2VydmVySW5zdGFuY2UoaW5zdGFuY2UpIHtcbiAgaWYgKFxuICAgIHR5cGVvZiBpbnN0YW5jZSA9PT0gJ29iamVjdCcgJiZcbiAgICBpbnN0YW5jZSAhPT0gbnVsbCAmJlxuICAgICdyZXNvdXJjZScgaW4gaW5zdGFuY2UgJiZcbiAgICAndG9vbCcgaW4gaW5zdGFuY2UgJiZcbiAgICAncHJvbXB0JyBpbiBpbnN0YW5jZSAmJlxuICAgICdjb25uZWN0JyBpbiBpbnN0YW5jZVxuICApIHtcbiAgICByZXR1cm4gdHJ1ZTtcbiAgfVxuICBkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEICYmIGRlYnVnTG9nZ2VyLmRlYnVnLndhcm4oJ0RpZCBub3QgcGF0Y2ggTUNQIHNlcnZlci4gSW50ZXJmYWNlIGlzIGluY29tcGF0aWJsZS4nKTtcbiAgcmV0dXJuIGZhbHNlO1xufVxuXG4vKipcbiAqIENoZWNrIGlmIHRoZSBpdGVtIGlzIGEgdmFsaWQgY29udGVudCBpdGVtXG4gKiBAcGFyYW0gaXRlbSAtIFRoZSBpdGVtIHRvIGNoZWNrXG4gKiBAcmV0dXJucyBUcnVlIGlmIHRoZSBpdGVtIGlzIGEgdmFsaWQgY29udGVudCBpdGVtLCBmYWxzZSBvdGhlcndpc2VcbiAqL1xuZnVuY3Rpb24gaXNWYWxpZENvbnRlbnRJdGVtKGl0ZW0pIHtcbiAgcmV0dXJuIGl0ZW0gIT0gbnVsbCAmJiB0eXBlb2YgaXRlbSA9PT0gJ29iamVjdCc7XG59XG5cbmV4cG9ydHMuaXNKc29uUnBjTm90aWZpY2F0aW9uID0gaXNKc29uUnBjTm90aWZpY2F0aW9uO1xuZXhwb3J0cy5pc0pzb25ScGNSZXF1ZXN0ID0gaXNKc29uUnBjUmVxdWVzdDtcbmV4cG9ydHMuaXNKc29uUnBjUmVzcG9uc2UgPSBpc0pzb25ScGNSZXNwb25zZTtcbmV4cG9ydHMuaXNWYWxpZENvbnRlbnRJdGVtID0gaXNWYWxpZENvbnRlbnRJdGVtO1xuZXhwb3J0cy52YWxpZGF0ZU1jcFNlcnZlckluc3RhbmNlID0gdmFsaWRhdGVNY3BTZXJ2ZXJJbnN0YW5jZTtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPXZhbGlkYXRpb24uanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/validation.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/metadata.js":
/*!*************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/metadata.js ***!
  \*************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst integration = __webpack_require__(/*! ../integration.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integration.js\");\nconst metadata = __webpack_require__(/*! ../metadata.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/metadata.js\");\nconst envelope = __webpack_require__(/*! ../utils/envelope.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/envelope.js\");\n\n/**\n * Adds module metadata to stack frames.\n *\n * Metadata can be injected by the Sentry bundler plugins using the `moduleMetadata` config option.\n *\n * When this integration is added, the metadata passed to the bundler plugin is added to the stack frames of all events\n * under the `module_metadata` property. This can be used to help in tagging or routing of events from different teams\n * our sources\n */\nconst moduleMetadataIntegration = integration.defineIntegration(() => {\n  return {\n    name: 'ModuleMetadata',\n    setup(client) {\n      // We need to strip metadata from stack frames before sending them to Sentry since these are client side only.\n      client.on('beforeEnvelope', envelope$1 => {\n        envelope.forEachEnvelopeItem(envelope$1, (item, type) => {\n          if (type === 'event') {\n            const event = Array.isArray(item) ? (item )[1] : undefined;\n\n            if (event) {\n              metadata.stripMetadataFromStackFrames(event);\n              item[1] = event;\n            }\n          }\n        });\n      });\n\n      client.on('applyFrameMetadata', event => {\n        // Only apply stack frame metadata to error events\n        if (event.type) {\n          return;\n        }\n\n        const stackParser = client.getOptions().stackParser;\n        metadata.addMetadataToStackFrames(stackParser, event);\n      });\n    },\n  };\n});\n\nexports.moduleMetadataIntegration = moduleMetadataIntegration;\n//# sourceMappingURL=metadata.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvaW50ZWdyYXRpb25zL21ldGFkYXRhLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLG9CQUFvQixtQkFBTyxDQUFDLG1JQUFtQjtBQUMvQyxpQkFBaUIsbUJBQU8sQ0FBQyw2SEFBZ0I7QUFDekMsaUJBQWlCLG1CQUFPLENBQUMseUlBQXNCOztBQUUvQztBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFNBQVM7QUFDVCxPQUFPOztBQUVQO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLE9BQU87QUFDUCxLQUFLO0FBQ0w7QUFDQSxDQUFDOztBQUVELGlDQUFpQztBQUNqQyIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL2ludGVncmF0aW9ucy9tZXRhZGF0YS5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgaW50ZWdyYXRpb24gPSByZXF1aXJlKCcuLi9pbnRlZ3JhdGlvbi5qcycpO1xuY29uc3QgbWV0YWRhdGEgPSByZXF1aXJlKCcuLi9tZXRhZGF0YS5qcycpO1xuY29uc3QgZW52ZWxvcGUgPSByZXF1aXJlKCcuLi91dGlscy9lbnZlbG9wZS5qcycpO1xuXG4vKipcbiAqIEFkZHMgbW9kdWxlIG1ldGFkYXRhIHRvIHN0YWNrIGZyYW1lcy5cbiAqXG4gKiBNZXRhZGF0YSBjYW4gYmUgaW5qZWN0ZWQgYnkgdGhlIFNlbnRyeSBidW5kbGVyIHBsdWdpbnMgdXNpbmcgdGhlIGBtb2R1bGVNZXRhZGF0YWAgY29uZmlnIG9wdGlvbi5cbiAqXG4gKiBXaGVuIHRoaXMgaW50ZWdyYXRpb24gaXMgYWRkZWQsIHRoZSBtZXRhZGF0YSBwYXNzZWQgdG8gdGhlIGJ1bmRsZXIgcGx1Z2luIGlzIGFkZGVkIHRvIHRoZSBzdGFjayBmcmFtZXMgb2YgYWxsIGV2ZW50c1xuICogdW5kZXIgdGhlIGBtb2R1bGVfbWV0YWRhdGFgIHByb3BlcnR5LiBUaGlzIGNhbiBiZSB1c2VkIHRvIGhlbHAgaW4gdGFnZ2luZyBvciByb3V0aW5nIG9mIGV2ZW50cyBmcm9tIGRpZmZlcmVudCB0ZWFtc1xuICogb3VyIHNvdXJjZXNcbiAqL1xuY29uc3QgbW9kdWxlTWV0YWRhdGFJbnRlZ3JhdGlvbiA9IGludGVncmF0aW9uLmRlZmluZUludGVncmF0aW9uKCgpID0+IHtcbiAgcmV0dXJuIHtcbiAgICBuYW1lOiAnTW9kdWxlTWV0YWRhdGEnLFxuICAgIHNldHVwKGNsaWVudCkge1xuICAgICAgLy8gV2UgbmVlZCB0byBzdHJpcCBtZXRhZGF0YSBmcm9tIHN0YWNrIGZyYW1lcyBiZWZvcmUgc2VuZGluZyB0aGVtIHRvIFNlbnRyeSBzaW5jZSB0aGVzZSBhcmUgY2xpZW50IHNpZGUgb25seS5cbiAgICAgIGNsaWVudC5vbignYmVmb3JlRW52ZWxvcGUnLCBlbnZlbG9wZSQxID0+IHtcbiAgICAgICAgZW52ZWxvcGUuZm9yRWFjaEVudmVsb3BlSXRlbShlbnZlbG9wZSQxLCAoaXRlbSwgdHlwZSkgPT4ge1xuICAgICAgICAgIGlmICh0eXBlID09PSAnZXZlbnQnKSB7XG4gICAgICAgICAgICBjb25zdCBldmVudCA9IEFycmF5LmlzQXJyYXkoaXRlbSkgPyAoaXRlbSApWzFdIDogdW5kZWZpbmVkO1xuXG4gICAgICAgICAgICBpZiAoZXZlbnQpIHtcbiAgICAgICAgICAgICAgbWV0YWRhdGEuc3RyaXBNZXRhZGF0YUZyb21TdGFja0ZyYW1lcyhldmVudCk7XG4gICAgICAgICAgICAgIGl0ZW1bMV0gPSBldmVudDtcbiAgICAgICAgICAgIH1cbiAgICAgICAgICB9XG4gICAgICAgIH0pO1xuICAgICAgfSk7XG5cbiAgICAgIGNsaWVudC5vbignYXBwbHlGcmFtZU1ldGFkYXRhJywgZXZlbnQgPT4ge1xuICAgICAgICAvLyBPbmx5IGFwcGx5IHN0YWNrIGZyYW1lIG1ldGFkYXRhIHRvIGVycm9yIGV2ZW50c1xuICAgICAgICBpZiAoZXZlbnQudHlwZSkge1xuICAgICAgICAgIHJldHVybjtcbiAgICAgICAgfVxuXG4gICAgICAgIGNvbnN0IHN0YWNrUGFyc2VyID0gY2xpZW50LmdldE9wdGlvbnMoKS5zdGFja1BhcnNlcjtcbiAgICAgICAgbWV0YWRhdGEuYWRkTWV0YWRhdGFUb1N0YWNrRnJhbWVzKHN0YWNrUGFyc2VyLCBldmVudCk7XG4gICAgICB9KTtcbiAgICB9LFxuICB9O1xufSk7XG5cbmV4cG9ydHMubW9kdWxlTWV0YWRhdGFJbnRlZ3JhdGlvbiA9IG1vZHVsZU1ldGFkYXRhSW50ZWdyYXRpb247XG4vLyMgc291cmNlTWFwcGluZ1VSTD1tZXRhZGF0YS5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/metadata.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/requestdata.js":
/*!****************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/requestdata.js ***!
  \****************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst integration = __webpack_require__(/*! ../integration.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integration.js\");\nconst cookie = __webpack_require__(/*! ../utils/cookie.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/cookie.js\");\nconst getIpAddress = __webpack_require__(/*! ../vendor/getIpAddress.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/vendor/getIpAddress.js\");\n\n// TODO(v10): Change defaults based on `sendDefaultPii`\nconst DEFAULT_INCLUDE = {\n  cookies: true,\n  data: true,\n  headers: true,\n  query_string: true,\n  url: true,\n};\n\nconst INTEGRATION_NAME = 'RequestData';\n\nconst _requestDataIntegration = ((options = {}) => {\n  const include = {\n    ...DEFAULT_INCLUDE,\n    ...options.include,\n  };\n\n  return {\n    name: INTEGRATION_NAME,\n    processEvent(event, _hint, client) {\n      const { sdkProcessingMetadata = {} } = event;\n      const { normalizedRequest, ipAddress } = sdkProcessingMetadata;\n\n      const includeWithDefaultPiiApplied = {\n        ...include,\n        ip: include.ip ?? client.getOptions().sendDefaultPii,\n      };\n\n      if (normalizedRequest) {\n        addNormalizedRequestDataToEvent(event, normalizedRequest, { ipAddress }, includeWithDefaultPiiApplied);\n      }\n\n      return event;\n    },\n  };\n}) ;\n\n/**\n * Add data about a request to an event. Primarily for use in Node-based SDKs, but included in `@sentry/core`\n * so it can be used in cross-platform SDKs like `@sentry/nextjs`.\n */\nconst requestDataIntegration = integration.defineIntegration(_requestDataIntegration);\n\n/**\n * Add already normalized request data to an event.\n * This mutates the passed in event.\n */\nfunction addNormalizedRequestDataToEvent(\n  event,\n  req,\n  // Data that should not go into `event.request` but is somehow related to requests\n  additionalData,\n  include,\n) {\n  event.request = {\n    ...event.request,\n    ...extractNormalizedRequestData(req, include),\n  };\n\n  if (include.ip) {\n    const ip = (req.headers && getIpAddress.getClientIPAddress(req.headers)) || additionalData.ipAddress;\n    if (ip) {\n      event.user = {\n        ...event.user,\n        ip_address: ip,\n      };\n    }\n  }\n}\n\nfunction extractNormalizedRequestData(\n  normalizedRequest,\n  include,\n) {\n  const requestData = {};\n  const headers = { ...normalizedRequest.headers };\n\n  if (include.headers) {\n    requestData.headers = headers;\n\n    // Remove the Cookie header in case cookie data should not be included in the event\n    if (!include.cookies) {\n      delete (headers ).cookie;\n    }\n\n    // Remove IP headers in case IP data should not be included in the event\n    if (!include.ip) {\n      getIpAddress.ipHeaderNames.forEach(ipHeaderName => {\n        // eslint-disable-next-line @typescript-eslint/no-dynamic-delete\n        delete (headers )[ipHeaderName];\n      });\n    }\n  }\n\n  requestData.method = normalizedRequest.method;\n\n  if (include.url) {\n    requestData.url = normalizedRequest.url;\n  }\n\n  if (include.cookies) {\n    const cookies = normalizedRequest.cookies || (headers?.cookie ? cookie.parseCookie(headers.cookie) : undefined);\n    requestData.cookies = cookies || {};\n  }\n\n  if (include.query_string) {\n    requestData.query_string = normalizedRequest.query_string;\n  }\n\n  if (include.data) {\n    requestData.data = normalizedRequest.data;\n  }\n\n  return requestData;\n}\n\nexports.requestDataIntegration = requestDataIntegration;\n//# sourceMappingURL=requestdata.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvaW50ZWdyYXRpb25zL3JlcXVlc3RkYXRhLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLG9CQUFvQixtQkFBTyxDQUFDLG1JQUFtQjtBQUMvQyxlQUFlLG1CQUFPLENBQUMscUlBQW9CO0FBQzNDLHFCQUFxQixtQkFBTyxDQUFDLG1KQUEyQjs7QUFFeEQ7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQSw4Q0FBOEM7QUFDOUM7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0EsY0FBYyw2QkFBNkI7QUFDM0MsY0FBYywrQkFBK0I7O0FBRTdDO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0Esb0VBQW9FLFdBQVc7QUFDL0U7O0FBRUE7QUFDQSxLQUFLO0FBQ0w7QUFDQSxDQUFDOztBQUVEO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxvQkFBb0I7O0FBRXBCO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLE9BQU87QUFDUDtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUEsOEJBQThCO0FBQzlCIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvaW50ZWdyYXRpb25zL3JlcXVlc3RkYXRhLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBpbnRlZ3JhdGlvbiA9IHJlcXVpcmUoJy4uL2ludGVncmF0aW9uLmpzJyk7XG5jb25zdCBjb29raWUgPSByZXF1aXJlKCcuLi91dGlscy9jb29raWUuanMnKTtcbmNvbnN0IGdldElwQWRkcmVzcyA9IHJlcXVpcmUoJy4uL3ZlbmRvci9nZXRJcEFkZHJlc3MuanMnKTtcblxuLy8gVE9ETyh2MTApOiBDaGFuZ2UgZGVmYXVsdHMgYmFzZWQgb24gYHNlbmREZWZhdWx0UGlpYFxuY29uc3QgREVGQVVMVF9JTkNMVURFID0ge1xuICBjb29raWVzOiB0cnVlLFxuICBkYXRhOiB0cnVlLFxuICBoZWFkZXJzOiB0cnVlLFxuICBxdWVyeV9zdHJpbmc6IHRydWUsXG4gIHVybDogdHJ1ZSxcbn07XG5cbmNvbnN0IElOVEVHUkFUSU9OX05BTUUgPSAnUmVxdWVzdERhdGEnO1xuXG5jb25zdCBfcmVxdWVzdERhdGFJbnRlZ3JhdGlvbiA9ICgob3B0aW9ucyA9IHt9KSA9PiB7XG4gIGNvbnN0IGluY2x1ZGUgPSB7XG4gICAgLi4uREVGQVVMVF9JTkNMVURFLFxuICAgIC4uLm9wdGlvbnMuaW5jbHVkZSxcbiAgfTtcblxuICByZXR1cm4ge1xuICAgIG5hbWU6IElOVEVHUkFUSU9OX05BTUUsXG4gICAgcHJvY2Vzc0V2ZW50KGV2ZW50LCBfaGludCwgY2xpZW50KSB7XG4gICAgICBjb25zdCB7IHNka1Byb2Nlc3NpbmdNZXRhZGF0YSA9IHt9IH0gPSBldmVudDtcbiAgICAgIGNvbnN0IHsgbm9ybWFsaXplZFJlcXVlc3QsIGlwQWRkcmVzcyB9ID0gc2RrUHJvY2Vzc2luZ01ldGFkYXRhO1xuXG4gICAgICBjb25zdCBpbmNsdWRlV2l0aERlZmF1bHRQaWlBcHBsaWVkID0ge1xuICAgICAgICAuLi5pbmNsdWRlLFxuICAgICAgICBpcDogaW5jbHVkZS5pcCA/PyBjbGllbnQuZ2V0T3B0aW9ucygpLnNlbmREZWZhdWx0UGlpLFxuICAgICAgfTtcblxuICAgICAgaWYgKG5vcm1hbGl6ZWRSZXF1ZXN0KSB7XG4gICAgICAgIGFkZE5vcm1hbGl6ZWRSZXF1ZXN0RGF0YVRvRXZlbnQoZXZlbnQsIG5vcm1hbGl6ZWRSZXF1ZXN0LCB7IGlwQWRkcmVzcyB9LCBpbmNsdWRlV2l0aERlZmF1bHRQaWlBcHBsaWVkKTtcbiAgICAgIH1cblxuICAgICAgcmV0dXJuIGV2ZW50O1xuICAgIH0sXG4gIH07XG59KSA7XG5cbi8qKlxuICogQWRkIGRhdGEgYWJvdXQgYSByZXF1ZXN0IHRvIGFuIGV2ZW50LiBQcmltYXJpbHkgZm9yIHVzZSBpbiBOb2RlLWJhc2VkIFNES3MsIGJ1dCBpbmNsdWRlZCBpbiBgQHNlbnRyeS9jb3JlYFxuICogc28gaXQgY2FuIGJlIHVzZWQgaW4gY3Jvc3MtcGxhdGZvcm0gU0RLcyBsaWtlIGBAc2VudHJ5L25leHRqc2AuXG4gKi9cbmNvbnN0IHJlcXVlc3REYXRhSW50ZWdyYXRpb24gPSBpbnRlZ3JhdGlvbi5kZWZpbmVJbnRlZ3JhdGlvbihfcmVxdWVzdERhdGFJbnRlZ3JhdGlvbik7XG5cbi8qKlxuICogQWRkIGFscmVhZHkgbm9ybWFsaXplZCByZXF1ZXN0IGRhdGEgdG8gYW4gZXZlbnQuXG4gKiBUaGlzIG11dGF0ZXMgdGhlIHBhc3NlZCBpbiBldmVudC5cbiAqL1xuZnVuY3Rpb24gYWRkTm9ybWFsaXplZFJlcXVlc3REYXRhVG9FdmVudChcbiAgZXZlbnQsXG4gIHJlcSxcbiAgLy8gRGF0YSB0aGF0IHNob3VsZCBub3QgZ28gaW50byBgZXZlbnQucmVxdWVzdGAgYnV0IGlzIHNvbWVob3cgcmVsYXRlZCB0byByZXF1ZXN0c1xuICBhZGRpdGlvbmFsRGF0YSxcbiAgaW5jbHVkZSxcbikge1xuICBldmVudC5yZXF1ZXN0ID0ge1xuICAgIC4uLmV2ZW50LnJlcXVlc3QsXG4gICAgLi4uZXh0cmFjdE5vcm1hbGl6ZWRSZXF1ZXN0RGF0YShyZXEsIGluY2x1ZGUpLFxuICB9O1xuXG4gIGlmIChpbmNsdWRlLmlwKSB7XG4gICAgY29uc3QgaXAgPSAocmVxLmhlYWRlcnMgJiYgZ2V0SXBBZGRyZXNzLmdldENsaWVudElQQWRkcmVzcyhyZXEuaGVhZGVycykpIHx8IGFkZGl0aW9uYWxEYXRhLmlwQWRkcmVzcztcbiAgICBpZiAoaXApIHtcbiAgICAgIGV2ZW50LnVzZXIgPSB7XG4gICAgICAgIC4uLmV2ZW50LnVzZXIsXG4gICAgICAgIGlwX2FkZHJlc3M6IGlwLFxuICAgICAgfTtcbiAgICB9XG4gIH1cbn1cblxuZnVuY3Rpb24gZXh0cmFjdE5vcm1hbGl6ZWRSZXF1ZXN0RGF0YShcbiAgbm9ybWFsaXplZFJlcXVlc3QsXG4gIGluY2x1ZGUsXG4pIHtcbiAgY29uc3QgcmVxdWVzdERhdGEgPSB7fTtcbiAgY29uc3QgaGVhZGVycyA9IHsgLi4ubm9ybWFsaXplZFJlcXVlc3QuaGVhZGVycyB9O1xuXG4gIGlmIChpbmNsdWRlLmhlYWRlcnMpIHtcbiAgICByZXF1ZXN0RGF0YS5oZWFkZXJzID0gaGVhZGVycztcblxuICAgIC8vIFJlbW92ZSB0aGUgQ29va2llIGhlYWRlciBpbiBjYXNlIGNvb2tpZSBkYXRhIHNob3VsZCBub3QgYmUgaW5jbHVkZWQgaW4gdGhlIGV2ZW50XG4gICAgaWYgKCFpbmNsdWRlLmNvb2tpZXMpIHtcbiAgICAgIGRlbGV0ZSAoaGVhZGVycyApLmNvb2tpZTtcbiAgICB9XG5cbiAgICAvLyBSZW1vdmUgSVAgaGVhZGVycyBpbiBjYXNlIElQIGRhdGEgc2hvdWxkIG5vdCBiZSBpbmNsdWRlZCBpbiB0aGUgZXZlbnRcbiAgICBpZiAoIWluY2x1ZGUuaXApIHtcbiAgICAgIGdldElwQWRkcmVzcy5pcEhlYWRlck5hbWVzLmZvckVhY2goaXBIZWFkZXJOYW1lID0+IHtcbiAgICAgICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uby1keW5hbWljLWRlbGV0ZVxuICAgICAgICBkZWxldGUgKGhlYWRlcnMgKVtpcEhlYWRlck5hbWVdO1xuICAgICAgfSk7XG4gICAgfVxuICB9XG5cbiAgcmVxdWVzdERhdGEubWV0aG9kID0gbm9ybWFsaXplZFJlcXVlc3QubWV0aG9kO1xuXG4gIGlmIChpbmNsdWRlLnVybCkge1xuICAgIHJlcXVlc3REYXRhLnVybCA9IG5vcm1hbGl6ZWRSZXF1ZXN0LnVybDtcbiAgfVxuXG4gIGlmIChpbmNsdWRlLmNvb2tpZXMpIHtcbiAgICBjb25zdCBjb29raWVzID0gbm9ybWFsaXplZFJlcXVlc3QuY29va2llcyB8fCAoaGVhZGVycz8uY29va2llID8gY29va2llLnBhcnNlQ29va2llKGhlYWRlcnMuY29va2llKSA6IHVuZGVmaW5lZCk7XG4gICAgcmVxdWVzdERhdGEuY29va2llcyA9IGNvb2tpZXMgfHwge307XG4gIH1cblxuICBpZiAoaW5jbHVkZS5xdWVyeV9zdHJpbmcpIHtcbiAgICByZXF1ZXN0RGF0YS5xdWVyeV9zdHJpbmcgPSBub3JtYWxpemVkUmVxdWVzdC5xdWVyeV9zdHJpbmc7XG4gIH1cblxuICBpZiAoaW5jbHVkZS5kYXRhKSB7XG4gICAgcmVxdWVzdERhdGEuZGF0YSA9IG5vcm1hbGl6ZWRSZXF1ZXN0LmRhdGE7XG4gIH1cblxuICByZXR1cm4gcmVxdWVzdERhdGE7XG59XG5cbmV4cG9ydHMucmVxdWVzdERhdGFJbnRlZ3JhdGlvbiA9IHJlcXVlc3REYXRhSW50ZWdyYXRpb247XG4vLyMgc291cmNlTWFwcGluZ1VSTD1yZXF1ZXN0ZGF0YS5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/requestdata.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/rewriteframes.js":
/*!******************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/rewriteframes.js ***!
  \******************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst integration = __webpack_require__(/*! ../integration.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integration.js\");\nconst path = __webpack_require__(/*! ../utils/path.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/path.js\");\nconst worldwide = __webpack_require__(/*! ../utils/worldwide.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/worldwide.js\");\n\nconst INTEGRATION_NAME = 'RewriteFrames';\n\n/**\n * Rewrite event frames paths.\n */\nconst rewriteFramesIntegration = integration.defineIntegration((options = {}) => {\n  const root = options.root;\n  const prefix = options.prefix || 'app:///';\n\n  const isBrowser = 'window' in worldwide.GLOBAL_OBJ && !!worldwide.GLOBAL_OBJ.window;\n\n  const iteratee = options.iteratee || generateIteratee({ isBrowser, root, prefix });\n\n  /** Process an exception event. */\n  function _processExceptionsEvent(event) {\n    try {\n      return {\n        ...event,\n        exception: {\n          ...event.exception,\n          // The check for this is performed inside `process` call itself, safe to skip here\n          // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n          values: event.exception.values.map(value => ({\n            ...value,\n            ...(value.stacktrace && { stacktrace: _processStacktrace(value.stacktrace) }),\n          })),\n        },\n      };\n    } catch {\n      return event;\n    }\n  }\n\n  /** Process a stack trace. */\n  function _processStacktrace(stacktrace) {\n    return {\n      ...stacktrace,\n      frames: stacktrace?.frames?.map(f => iteratee(f)),\n    };\n  }\n\n  return {\n    name: INTEGRATION_NAME,\n    processEvent(originalEvent) {\n      let processedEvent = originalEvent;\n\n      if (originalEvent.exception && Array.isArray(originalEvent.exception.values)) {\n        processedEvent = _processExceptionsEvent(processedEvent);\n      }\n\n      return processedEvent;\n    },\n  };\n});\n\n/**\n * Exported only for tests.\n */\nfunction generateIteratee({\n  isBrowser,\n  root,\n  prefix,\n}\n\n) {\n  return (frame) => {\n    if (!frame.filename) {\n      return frame;\n    }\n\n    // Determine if this is a Windows frame by checking for a Windows-style prefix such as `C:\\`\n    const isWindowsFrame =\n      /^[a-zA-Z]:\\\\/.test(frame.filename) ||\n      // or the presence of a backslash without a forward slash (which are not allowed on Windows)\n      (frame.filename.includes('\\\\') && !frame.filename.includes('/'));\n\n    // Check if the frame filename begins with `/`\n    const startsWithSlash = /^\\//.test(frame.filename);\n\n    if (isBrowser) {\n      if (root) {\n        const oldFilename = frame.filename;\n        if (oldFilename.indexOf(root) === 0) {\n          frame.filename = oldFilename.replace(root, prefix);\n        }\n      }\n    } else {\n      if (isWindowsFrame || startsWithSlash) {\n        const filename = isWindowsFrame\n          ? frame.filename\n              .replace(/^[a-zA-Z]:/, '') // remove Windows-style prefix\n              .replace(/\\\\/g, '/') // replace all `\\\\` instances with `/`\n          : frame.filename;\n        const base = root ? path.relative(root, filename) : path.basename(filename);\n        frame.filename = `${prefix}${base}`;\n      }\n    }\n\n    return frame;\n  };\n}\n\nexports.generateIteratee = generateIteratee;\nexports.rewriteFramesIntegration = rewriteFramesIntegration;\n//# sourceMappingURL=rewriteframes.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvaW50ZWdyYXRpb25zL3Jld3JpdGVmcmFtZXMuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsb0JBQW9CLG1CQUFPLENBQUMsbUlBQW1CO0FBQy9DLGFBQWEsbUJBQU8sQ0FBQyxpSUFBa0I7QUFDdkMsa0JBQWtCLG1CQUFPLENBQUMsMklBQXVCOztBQUVqRDs7QUFFQTtBQUNBO0FBQ0E7QUFDQSw0RUFBNEU7QUFDNUU7QUFDQTs7QUFFQTs7QUFFQSwwREFBMEQseUJBQXlCOztBQUVuRjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0Esc0NBQXNDLGtEQUFrRDtBQUN4RixXQUFXO0FBQ1gsU0FBUztBQUNUO0FBQ0EsTUFBTTtBQUNOO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQSxLQUFLO0FBQ0w7QUFDQSxDQUFDOztBQUVEO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxNQUFNO0FBQ047QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSw0QkFBNEIsT0FBTyxFQUFFLEtBQUs7QUFDMUM7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUEsd0JBQXdCO0FBQ3hCLGdDQUFnQztBQUNoQyIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL2ludGVncmF0aW9ucy9yZXdyaXRlZnJhbWVzLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBpbnRlZ3JhdGlvbiA9IHJlcXVpcmUoJy4uL2ludGVncmF0aW9uLmpzJyk7XG5jb25zdCBwYXRoID0gcmVxdWlyZSgnLi4vdXRpbHMvcGF0aC5qcycpO1xuY29uc3Qgd29ybGR3aWRlID0gcmVxdWlyZSgnLi4vdXRpbHMvd29ybGR3aWRlLmpzJyk7XG5cbmNvbnN0IElOVEVHUkFUSU9OX05BTUUgPSAnUmV3cml0ZUZyYW1lcyc7XG5cbi8qKlxuICogUmV3cml0ZSBldmVudCBmcmFtZXMgcGF0aHMuXG4gKi9cbmNvbnN0IHJld3JpdGVGcmFtZXNJbnRlZ3JhdGlvbiA9IGludGVncmF0aW9uLmRlZmluZUludGVncmF0aW9uKChvcHRpb25zID0ge30pID0+IHtcbiAgY29uc3Qgcm9vdCA9IG9wdGlvbnMucm9vdDtcbiAgY29uc3QgcHJlZml4ID0gb3B0aW9ucy5wcmVmaXggfHwgJ2FwcDovLy8nO1xuXG4gIGNvbnN0IGlzQnJvd3NlciA9ICd3aW5kb3cnIGluIHdvcmxkd2lkZS5HTE9CQUxfT0JKICYmICEhd29ybGR3aWRlLkdMT0JBTF9PQkoud2luZG93O1xuXG4gIGNvbnN0IGl0ZXJhdGVlID0gb3B0aW9ucy5pdGVyYXRlZSB8fCBnZW5lcmF0ZUl0ZXJhdGVlKHsgaXNCcm93c2VyLCByb290LCBwcmVmaXggfSk7XG5cbiAgLyoqIFByb2Nlc3MgYW4gZXhjZXB0aW9uIGV2ZW50LiAqL1xuICBmdW5jdGlvbiBfcHJvY2Vzc0V4Y2VwdGlvbnNFdmVudChldmVudCkge1xuICAgIHRyeSB7XG4gICAgICByZXR1cm4ge1xuICAgICAgICAuLi5ldmVudCxcbiAgICAgICAgZXhjZXB0aW9uOiB7XG4gICAgICAgICAgLi4uZXZlbnQuZXhjZXB0aW9uLFxuICAgICAgICAgIC8vIFRoZSBjaGVjayBmb3IgdGhpcyBpcyBwZXJmb3JtZWQgaW5zaWRlIGBwcm9jZXNzYCBjYWxsIGl0c2VsZiwgc2FmZSB0byBza2lwIGhlcmVcbiAgICAgICAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25vLW5vbi1udWxsLWFzc2VydGlvblxuICAgICAgICAgIHZhbHVlczogZXZlbnQuZXhjZXB0aW9uLnZhbHVlcy5tYXAodmFsdWUgPT4gKHtcbiAgICAgICAgICAgIC4uLnZhbHVlLFxuICAgICAgICAgICAgLi4uKHZhbHVlLnN0YWNrdHJhY2UgJiYgeyBzdGFja3RyYWNlOiBfcHJvY2Vzc1N0YWNrdHJhY2UodmFsdWUuc3RhY2t0cmFjZSkgfSksXG4gICAgICAgICAgfSkpLFxuICAgICAgICB9LFxuICAgICAgfTtcbiAgICB9IGNhdGNoIHtcbiAgICAgIHJldHVybiBldmVudDtcbiAgICB9XG4gIH1cblxuICAvKiogUHJvY2VzcyBhIHN0YWNrIHRyYWNlLiAqL1xuICBmdW5jdGlvbiBfcHJvY2Vzc1N0YWNrdHJhY2Uoc3RhY2t0cmFjZSkge1xuICAgIHJldHVybiB7XG4gICAgICAuLi5zdGFja3RyYWNlLFxuICAgICAgZnJhbWVzOiBzdGFja3RyYWNlPy5mcmFtZXM/Lm1hcChmID0+IGl0ZXJhdGVlKGYpKSxcbiAgICB9O1xuICB9XG5cbiAgcmV0dXJuIHtcbiAgICBuYW1lOiBJTlRFR1JBVElPTl9OQU1FLFxuICAgIHByb2Nlc3NFdmVudChvcmlnaW5hbEV2ZW50KSB7XG4gICAgICBsZXQgcHJvY2Vzc2VkRXZlbnQgPSBvcmlnaW5hbEV2ZW50O1xuXG4gICAgICBpZiAob3JpZ2luYWxFdmVudC5leGNlcHRpb24gJiYgQXJyYXkuaXNBcnJheShvcmlnaW5hbEV2ZW50LmV4Y2VwdGlvbi52YWx1ZXMpKSB7XG4gICAgICAgIHByb2Nlc3NlZEV2ZW50ID0gX3Byb2Nlc3NFeGNlcHRpb25zRXZlbnQocHJvY2Vzc2VkRXZlbnQpO1xuICAgICAgfVxuXG4gICAgICByZXR1cm4gcHJvY2Vzc2VkRXZlbnQ7XG4gICAgfSxcbiAgfTtcbn0pO1xuXG4vKipcbiAqIEV4cG9ydGVkIG9ubHkgZm9yIHRlc3RzLlxuICovXG5mdW5jdGlvbiBnZW5lcmF0ZUl0ZXJhdGVlKHtcbiAgaXNCcm93c2VyLFxuICByb290LFxuICBwcmVmaXgsXG59XG5cbikge1xuICByZXR1cm4gKGZyYW1lKSA9PiB7XG4gICAgaWYgKCFmcmFtZS5maWxlbmFtZSkge1xuICAgICAgcmV0dXJuIGZyYW1lO1xuICAgIH1cblxuICAgIC8vIERldGVybWluZSBpZiB0aGlzIGlzIGEgV2luZG93cyBmcmFtZSBieSBjaGVja2luZyBmb3IgYSBXaW5kb3dzLXN0eWxlIHByZWZpeCBzdWNoIGFzIGBDOlxcYFxuICAgIGNvbnN0IGlzV2luZG93c0ZyYW1lID1cbiAgICAgIC9eW2EtekEtWl06XFxcXC8udGVzdChmcmFtZS5maWxlbmFtZSkgfHxcbiAgICAgIC8vIG9yIHRoZSBwcmVzZW5jZSBvZiBhIGJhY2tzbGFzaCB3aXRob3V0IGEgZm9yd2FyZCBzbGFzaCAod2hpY2ggYXJlIG5vdCBhbGxvd2VkIG9uIFdpbmRvd3MpXG4gICAgICAoZnJhbWUuZmlsZW5hbWUuaW5jbHVkZXMoJ1xcXFwnKSAmJiAhZnJhbWUuZmlsZW5hbWUuaW5jbHVkZXMoJy8nKSk7XG5cbiAgICAvLyBDaGVjayBpZiB0aGUgZnJhbWUgZmlsZW5hbWUgYmVnaW5zIHdpdGggYC9gXG4gICAgY29uc3Qgc3RhcnRzV2l0aFNsYXNoID0gL15cXC8vLnRlc3QoZnJhbWUuZmlsZW5hbWUpO1xuXG4gICAgaWYgKGlzQnJvd3Nlcikge1xuICAgICAgaWYgKHJvb3QpIHtcbiAgICAgICAgY29uc3Qgb2xkRmlsZW5hbWUgPSBmcmFtZS5maWxlbmFtZTtcbiAgICAgICAgaWYgKG9sZEZpbGVuYW1lLmluZGV4T2Yocm9vdCkgPT09IDApIHtcbiAgICAgICAgICBmcmFtZS5maWxlbmFtZSA9IG9sZEZpbGVuYW1lLnJlcGxhY2Uocm9vdCwgcHJlZml4KTtcbiAgICAgICAgfVxuICAgICAgfVxuICAgIH0gZWxzZSB7XG4gICAgICBpZiAoaXNXaW5kb3dzRnJhbWUgfHwgc3RhcnRzV2l0aFNsYXNoKSB7XG4gICAgICAgIGNvbnN0IGZpbGVuYW1lID0gaXNXaW5kb3dzRnJhbWVcbiAgICAgICAgICA/IGZyYW1lLmZpbGVuYW1lXG4gICAgICAgICAgICAgIC5yZXBsYWNlKC9eW2EtekEtWl06LywgJycpIC8vIHJlbW92ZSBXaW5kb3dzLXN0eWxlIHByZWZpeFxuICAgICAgICAgICAgICAucmVwbGFjZSgvXFxcXC9nLCAnLycpIC8vIHJlcGxhY2UgYWxsIGBcXFxcYCBpbnN0YW5jZXMgd2l0aCBgL2BcbiAgICAgICAgICA6IGZyYW1lLmZpbGVuYW1lO1xuICAgICAgICBjb25zdCBiYXNlID0gcm9vdCA/IHBhdGgucmVsYXRpdmUocm9vdCwgZmlsZW5hbWUpIDogcGF0aC5iYXNlbmFtZShmaWxlbmFtZSk7XG4gICAgICAgIGZyYW1lLmZpbGVuYW1lID0gYCR7cHJlZml4fSR7YmFzZX1gO1xuICAgICAgfVxuICAgIH1cblxuICAgIHJldHVybiBmcmFtZTtcbiAgfTtcbn1cblxuZXhwb3J0cy5nZW5lcmF0ZUl0ZXJhdGVlID0gZ2VuZXJhdGVJdGVyYXRlZTtcbmV4cG9ydHMucmV3cml0ZUZyYW1lc0ludGVncmF0aW9uID0gcmV3cml0ZUZyYW1lc0ludGVncmF0aW9uO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9cmV3cml0ZWZyYW1lcy5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/rewriteframes.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/supabase.js":
/*!*************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/supabase.js ***!
  \*************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst breadcrumbs = __webpack_require__(/*! ../breadcrumbs.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/breadcrumbs.js\");\nconst debugBuild = __webpack_require__(/*! ../debug-build.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst exports$1 = __webpack_require__(/*! ../exports.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/exports.js\");\nconst integration = __webpack_require__(/*! ../integration.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integration.js\");\nconst semanticAttributes = __webpack_require__(/*! ../semanticAttributes.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/semanticAttributes.js\");\nconst debugLogger = __webpack_require__(/*! ../utils/debug-logger.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst is = __webpack_require__(/*! ../utils/is.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js\");\nconst spanstatus = __webpack_require__(/*! ../tracing/spanstatus.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/spanstatus.js\");\nconst trace = __webpack_require__(/*! ../tracing/trace.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/trace.js\");\n\n// Based on Kamil Ogórek's work on:\n// https://github.com/supabase-community/sentry-integration-js\n\n\nconst AUTH_OPERATIONS_TO_INSTRUMENT = [\n  'reauthenticate',\n  'signInAnonymously',\n  'signInWithOAuth',\n  'signInWithIdToken',\n  'signInWithOtp',\n  'signInWithPassword',\n  'signInWithSSO',\n  'signOut',\n  'signUp',\n  'verifyOtp',\n];\n\nconst AUTH_ADMIN_OPERATIONS_TO_INSTRUMENT = [\n  'createUser',\n  'deleteUser',\n  'listUsers',\n  'getUserById',\n  'updateUserById',\n  'inviteUserByEmail',\n];\n\nconst FILTER_MAPPINGS = {\n  eq: 'eq',\n  neq: 'neq',\n  gt: 'gt',\n  gte: 'gte',\n  lt: 'lt',\n  lte: 'lte',\n  like: 'like',\n  'like(all)': 'likeAllOf',\n  'like(any)': 'likeAnyOf',\n  ilike: 'ilike',\n  'ilike(all)': 'ilikeAllOf',\n  'ilike(any)': 'ilikeAnyOf',\n  is: 'is',\n  in: 'in',\n  cs: 'contains',\n  cd: 'containedBy',\n  sr: 'rangeGt',\n  nxl: 'rangeGte',\n  sl: 'rangeLt',\n  nxr: 'rangeLte',\n  adj: 'rangeAdjacent',\n  ov: 'overlaps',\n  fts: '',\n  plfts: 'plain',\n  phfts: 'phrase',\n  wfts: 'websearch',\n  not: 'not',\n};\n\nconst DB_OPERATIONS_TO_INSTRUMENT = ['select', 'insert', 'upsert', 'update', 'delete'];\n\nfunction markAsInstrumented(fn) {\n  try {\n    (fn ).__SENTRY_INSTRUMENTED__ = true;\n  } catch {\n    // ignore errors here\n  }\n}\n\nfunction isInstrumented(fn) {\n  try {\n    return (fn ).__SENTRY_INSTRUMENTED__;\n  } catch {\n    return false;\n  }\n}\n\n/**\n * Extracts the database operation type from the HTTP method and headers\n * @param method - The HTTP method of the request\n * @param headers - The request headers\n * @returns The database operation type ('select', 'insert', 'upsert', 'update', or 'delete')\n */\nfunction extractOperation(method, headers = {}) {\n  switch (method) {\n    case 'GET': {\n      return 'select';\n    }\n    case 'POST': {\n      if (headers['Prefer']?.includes('resolution=')) {\n        return 'upsert';\n      } else {\n        return 'insert';\n      }\n    }\n    case 'PATCH': {\n      return 'update';\n    }\n    case 'DELETE': {\n      return 'delete';\n    }\n    default: {\n      return '<unknown-op>';\n    }\n  }\n}\n\n/**\n * Translates Supabase filter parameters into readable method names for tracing\n * @param key - The filter key from the URL search parameters\n * @param query - The filter value from the URL search parameters\n * @returns A string representation of the filter as a method call\n */\nfunction translateFiltersIntoMethods(key, query) {\n  if (query === '' || query === '*') {\n    return 'select(*)';\n  }\n\n  if (key === 'select') {\n    return `select(${query})`;\n  }\n\n  if (key === 'or' || key.endsWith('.or')) {\n    return `${key}${query}`;\n  }\n\n  const [filter, ...value] = query.split('.');\n\n  let method;\n  // Handle optional `configPart` of the filter\n  if (filter?.startsWith('fts')) {\n    method = 'textSearch';\n  } else if (filter?.startsWith('plfts')) {\n    method = 'textSearch[plain]';\n  } else if (filter?.startsWith('phfts')) {\n    method = 'textSearch[phrase]';\n  } else if (filter?.startsWith('wfts')) {\n    method = 'textSearch[websearch]';\n  } else {\n    method = (filter && FILTER_MAPPINGS[filter ]) || 'filter';\n  }\n\n  return `${method}(${key}, ${value.join('.')})`;\n}\n\nfunction instrumentAuthOperation(operation, isAdmin = false) {\n  return new Proxy(operation, {\n    apply(target, thisArg, argumentsList) {\n      return trace.startSpan(\n        {\n          name: `auth ${isAdmin ? '(admin) ' : ''}${operation.name}`,\n          attributes: {\n            [semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_ORIGIN]: 'auto.db.supabase',\n            [semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_OP]: 'db',\n            'db.system': 'postgresql',\n            'db.operation': `auth.${isAdmin ? 'admin.' : ''}${operation.name}`,\n          },\n        },\n        span => {\n          return Reflect.apply(target, thisArg, argumentsList)\n            .then((res) => {\n              if (res && typeof res === 'object' && 'error' in res && res.error) {\n                span.setStatus({ code: spanstatus.SPAN_STATUS_ERROR });\n\n                exports$1.captureException(res.error, {\n                  mechanism: {\n                    handled: false,\n                  },\n                });\n              } else {\n                span.setStatus({ code: spanstatus.SPAN_STATUS_OK });\n              }\n\n              span.end();\n              return res;\n            })\n            .catch((err) => {\n              span.setStatus({ code: spanstatus.SPAN_STATUS_ERROR });\n              span.end();\n\n              exports$1.captureException(err, {\n                mechanism: {\n                  handled: false,\n                },\n              });\n\n              throw err;\n            })\n            .then(...argumentsList);\n        },\n      );\n    },\n  });\n}\n\nfunction instrumentSupabaseAuthClient(supabaseClientInstance) {\n  const auth = supabaseClientInstance.auth;\n\n  if (!auth || isInstrumented(supabaseClientInstance.auth)) {\n    return;\n  }\n\n  for (const operation of AUTH_OPERATIONS_TO_INSTRUMENT) {\n    const authOperation = auth[operation];\n\n    if (!authOperation) {\n      continue;\n    }\n\n    if (typeof supabaseClientInstance.auth[operation] === 'function') {\n      supabaseClientInstance.auth[operation] = instrumentAuthOperation(authOperation);\n    }\n  }\n\n  for (const operation of AUTH_ADMIN_OPERATIONS_TO_INSTRUMENT) {\n    const authOperation = auth.admin[operation];\n\n    if (!authOperation) {\n      continue;\n    }\n\n    if (typeof supabaseClientInstance.auth.admin[operation] === 'function') {\n      supabaseClientInstance.auth.admin[operation] = instrumentAuthOperation(authOperation, true);\n    }\n  }\n\n  markAsInstrumented(supabaseClientInstance.auth);\n}\n\nfunction instrumentSupabaseClientConstructor(SupabaseClient) {\n  if (isInstrumented((SupabaseClient ).prototype.from)) {\n    return;\n  }\n\n  (SupabaseClient ).prototype.from = new Proxy(\n    (SupabaseClient ).prototype.from,\n    {\n      apply(target, thisArg, argumentsList) {\n        const rv = Reflect.apply(target, thisArg, argumentsList);\n        const PostgRESTQueryBuilder = (rv ).constructor;\n\n        instrumentPostgRESTQueryBuilder(PostgRESTQueryBuilder );\n\n        return rv;\n      },\n    },\n  );\n\n  markAsInstrumented((SupabaseClient ).prototype.from);\n}\n\nfunction instrumentPostgRESTFilterBuilder(PostgRESTFilterBuilder) {\n  if (isInstrumented((PostgRESTFilterBuilder.prototype ).then)) {\n    return;\n  }\n\n  (PostgRESTFilterBuilder.prototype ).then = new Proxy(\n    (PostgRESTFilterBuilder.prototype ).then,\n    {\n      apply(target, thisArg, argumentsList) {\n        const operations = DB_OPERATIONS_TO_INSTRUMENT;\n        const typedThis = thisArg ;\n        const operation = extractOperation(typedThis.method, typedThis.headers);\n\n        if (!operations.includes(operation)) {\n          return Reflect.apply(target, thisArg, argumentsList);\n        }\n\n        if (!typedThis?.url?.pathname || typeof typedThis.url.pathname !== 'string') {\n          return Reflect.apply(target, thisArg, argumentsList);\n        }\n\n        const pathParts = typedThis.url.pathname.split('/');\n        const table = pathParts.length > 0 ? pathParts[pathParts.length - 1] : '';\n\n        const queryItems = [];\n        for (const [key, value] of typedThis.url.searchParams.entries()) {\n          // It's possible to have multiple entries for the same key, eg. `id=eq.7&id=eq.3`,\n          // so we need to use array instead of object to collect them.\n          queryItems.push(translateFiltersIntoMethods(key, value));\n        }\n        const body = Object.create(null);\n        if (is.isPlainObject(typedThis.body)) {\n          for (const [key, value] of Object.entries(typedThis.body)) {\n            body[key] = value;\n          }\n        }\n\n        // Adding operation to the beginning of the description if it's not a `select` operation\n        // For example, it can be an `insert` or `update` operation but the query can be `select(...)`\n        // For `select` operations, we don't need repeat it in the description\n        const description = `${operation === 'select' ? '' : `${operation}${body ? '(...) ' : ''}`}${queryItems.join(\n          ' ',\n        )} from(${table})`;\n\n        const attributes = {\n          'db.table': table,\n          'db.schema': typedThis.schema,\n          'db.url': typedThis.url.origin,\n          'db.sdk': typedThis.headers['X-Client-Info'],\n          'db.system': 'postgresql',\n          'db.operation': operation,\n          [semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_ORIGIN]: 'auto.db.supabase',\n          [semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_OP]: 'db',\n        };\n\n        if (queryItems.length) {\n          attributes['db.query'] = queryItems;\n        }\n\n        if (Object.keys(body).length) {\n          attributes['db.body'] = body;\n        }\n\n        return trace.startSpan(\n          {\n            name: description,\n            attributes,\n          },\n          span => {\n            return (Reflect.apply(target, thisArg, []) )\n              .then(\n                (res) => {\n                  if (span) {\n                    if (res && typeof res === 'object' && 'status' in res) {\n                      spanstatus.setHttpStatus(span, res.status || 500);\n                    }\n                    span.end();\n                  }\n\n                  if (res.error) {\n                    const err = new Error(res.error.message) ;\n                    if (res.error.code) {\n                      err.code = res.error.code;\n                    }\n                    if (res.error.details) {\n                      err.details = res.error.details;\n                    }\n\n                    const supabaseContext = {};\n                    if (queryItems.length) {\n                      supabaseContext.query = queryItems;\n                    }\n                    if (Object.keys(body).length) {\n                      supabaseContext.body = body;\n                    }\n\n                    exports$1.captureException(err, {\n                      contexts: {\n                        supabase: supabaseContext,\n                      },\n                    });\n                  }\n\n                  const breadcrumb = {\n                    type: 'supabase',\n                    category: `db.${operation}`,\n                    message: description,\n                  };\n\n                  const data = {};\n\n                  if (queryItems.length) {\n                    data.query = queryItems;\n                  }\n\n                  if (Object.keys(body).length) {\n                    data.body = body;\n                  }\n\n                  if (Object.keys(data).length) {\n                    breadcrumb.data = data;\n                  }\n\n                  breadcrumbs.addBreadcrumb(breadcrumb);\n\n                  return res;\n                },\n                (err) => {\n                  if (span) {\n                    spanstatus.setHttpStatus(span, 500);\n                    span.end();\n                  }\n                  throw err;\n                },\n              )\n              .then(...argumentsList);\n          },\n        );\n      },\n    },\n  );\n\n  markAsInstrumented((PostgRESTFilterBuilder.prototype ).then);\n}\n\nfunction instrumentPostgRESTQueryBuilder(PostgRESTQueryBuilder) {\n  // We need to wrap _all_ operations despite them sharing the same `PostgRESTFilterBuilder`\n  // constructor, as we don't know which method will be called first, and we don't want to miss any calls.\n  for (const operation of DB_OPERATIONS_TO_INSTRUMENT) {\n    if (isInstrumented((PostgRESTQueryBuilder.prototype )[operation])) {\n      continue;\n    }\n\n    (PostgRESTQueryBuilder.prototype )[operation ] = new Proxy(\n      (PostgRESTQueryBuilder.prototype )[operation ],\n      {\n        apply(target, thisArg, argumentsList) {\n          const rv = Reflect.apply(target, thisArg, argumentsList);\n          const PostgRESTFilterBuilder = (rv ).constructor;\n\n          debugBuild.DEBUG_BUILD && debugLogger.debug.log(`Instrumenting ${operation} operation's PostgRESTFilterBuilder`);\n\n          instrumentPostgRESTFilterBuilder(PostgRESTFilterBuilder);\n\n          return rv;\n        },\n      },\n    );\n\n    markAsInstrumented((PostgRESTQueryBuilder.prototype )[operation]);\n  }\n}\n\nconst instrumentSupabaseClient = (supabaseClient) => {\n  if (!supabaseClient) {\n    debugBuild.DEBUG_BUILD && debugLogger.debug.warn('Supabase integration was not installed because no Supabase client was provided.');\n    return;\n  }\n  const SupabaseClientConstructor =\n    supabaseClient.constructor === Function ? supabaseClient : supabaseClient.constructor;\n\n  instrumentSupabaseClientConstructor(SupabaseClientConstructor);\n  instrumentSupabaseAuthClient(supabaseClient );\n};\n\nconst INTEGRATION_NAME = 'Supabase';\n\nconst _supabaseIntegration = ((supabaseClient) => {\n  return {\n    setupOnce() {\n      instrumentSupabaseClient(supabaseClient);\n    },\n    name: INTEGRATION_NAME,\n  };\n}) ;\n\nconst supabaseIntegration = integration.defineIntegration((options) => {\n  return _supabaseIntegration(options.supabaseClient);\n}) ;\n\nexports.DB_OPERATIONS_TO_INSTRUMENT = DB_OPERATIONS_TO_INSTRUMENT;\nexports.FILTER_MAPPINGS = FILTER_MAPPINGS;\nexports.extractOperation = extractOperation;\nexports.instrumentSupabaseClient = instrumentSupabaseClient;\nexports.supabaseIntegration = supabaseIntegration;\nexports.translateFiltersIntoMethods = translateFiltersIntoMethods;\n//# sourceMappingURL=supabase.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvaW50ZWdyYXRpb25zL3N1cGFiYXNlLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLG9CQUFvQixtQkFBTyxDQUFDLG1JQUFtQjtBQUMvQyxtQkFBbUIsbUJBQU8sQ0FBQyxtSUFBbUI7QUFDOUMsa0JBQWtCLG1CQUFPLENBQUMsMkhBQWU7QUFDekMsb0JBQW9CLG1CQUFPLENBQUMsbUlBQW1CO0FBQy9DLDJCQUEyQixtQkFBTyxDQUFDLGlKQUEwQjtBQUM3RCxvQkFBb0IsbUJBQU8sQ0FBQyxpSkFBMEI7QUFDdEQsV0FBVyxtQkFBTyxDQUFDLDZIQUFnQjtBQUNuQyxtQkFBbUIsbUJBQU8sQ0FBQyxpSkFBMEI7QUFDckQsY0FBYyxtQkFBTyxDQUFDLHVJQUFxQjs7QUFFM0M7QUFDQTs7O0FBR0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQSxJQUFJO0FBQ0o7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBLElBQUk7QUFDSjtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsOENBQThDO0FBQzlDO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsUUFBUTtBQUNSO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQSxxQkFBcUIsTUFBTTtBQUMzQjs7QUFFQTtBQUNBLGNBQWMsSUFBSSxFQUFFLE1BQU07QUFDMUI7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQSxJQUFJO0FBQ0o7QUFDQSxJQUFJO0FBQ0o7QUFDQSxJQUFJO0FBQ0o7QUFDQSxJQUFJO0FBQ0o7QUFDQTs7QUFFQSxZQUFZLE9BQU8sR0FBRyxJQUFJLElBQUksZ0JBQWdCO0FBQzlDOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSx3QkFBd0IsMEJBQTBCLEVBQUUsZUFBZTtBQUNuRTtBQUNBO0FBQ0E7QUFDQTtBQUNBLG9DQUFvQyx3QkFBd0IsRUFBRSxlQUFlO0FBQzdFLFdBQVc7QUFDWCxTQUFTO0FBQ1Q7QUFDQTtBQUNBO0FBQ0E7QUFDQSxpQ0FBaUMsb0NBQW9DOztBQUVyRTtBQUNBO0FBQ0E7QUFDQSxtQkFBbUI7QUFDbkIsaUJBQWlCO0FBQ2pCLGdCQUFnQjtBQUNoQixpQ0FBaUMsaUNBQWlDO0FBQ2xFOztBQUVBO0FBQ0E7QUFDQSxhQUFhO0FBQ2I7QUFDQSwrQkFBK0Isb0NBQW9DO0FBQ25FOztBQUVBO0FBQ0E7QUFDQTtBQUNBLGlCQUFpQjtBQUNqQixlQUFlOztBQUVmO0FBQ0EsYUFBYTtBQUNiO0FBQ0EsU0FBUztBQUNUO0FBQ0EsS0FBSztBQUNMLEdBQUc7QUFDSDs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBLE9BQU87QUFDUCxLQUFLO0FBQ0w7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBLCtCQUErQixpQ0FBaUMsVUFBVSxFQUFFLHFCQUFxQixFQUFFLEVBQUU7QUFDckc7QUFDQSxXQUFXLE9BQU8sTUFBTTs7QUFFeEI7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFdBQVc7QUFDWDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBLHVCQUF1QjtBQUN2QixxQkFBcUI7QUFDckI7O0FBRUE7QUFDQTtBQUNBLG9DQUFvQyxVQUFVO0FBQzlDO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQSxpQkFBaUI7QUFDakI7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsaUJBQWlCO0FBQ2pCO0FBQ0E7QUFDQSxXQUFXO0FBQ1g7QUFDQSxPQUFPO0FBQ1AsS0FBSztBQUNMOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLDJFQUEyRSxXQUFXOztBQUV0Rjs7QUFFQTtBQUNBLFNBQVM7QUFDVCxPQUFPO0FBQ1A7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEtBQUs7QUFDTDtBQUNBO0FBQ0EsQ0FBQzs7QUFFRDtBQUNBO0FBQ0EsQ0FBQzs7QUFFRCxtQ0FBbUM7QUFDbkMsdUJBQXVCO0FBQ3ZCLHdCQUF3QjtBQUN4QixnQ0FBZ0M7QUFDaEMsMkJBQTJCO0FBQzNCLG1DQUFtQztBQUNuQyIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL2ludGVncmF0aW9ucy9zdXBhYmFzZS5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgYnJlYWRjcnVtYnMgPSByZXF1aXJlKCcuLi9icmVhZGNydW1icy5qcycpO1xuY29uc3QgZGVidWdCdWlsZCA9IHJlcXVpcmUoJy4uL2RlYnVnLWJ1aWxkLmpzJyk7XG5jb25zdCBleHBvcnRzJDEgPSByZXF1aXJlKCcuLi9leHBvcnRzLmpzJyk7XG5jb25zdCBpbnRlZ3JhdGlvbiA9IHJlcXVpcmUoJy4uL2ludGVncmF0aW9uLmpzJyk7XG5jb25zdCBzZW1hbnRpY0F0dHJpYnV0ZXMgPSByZXF1aXJlKCcuLi9zZW1hbnRpY0F0dHJpYnV0ZXMuanMnKTtcbmNvbnN0IGRlYnVnTG9nZ2VyID0gcmVxdWlyZSgnLi4vdXRpbHMvZGVidWctbG9nZ2VyLmpzJyk7XG5jb25zdCBpcyA9IHJlcXVpcmUoJy4uL3V0aWxzL2lzLmpzJyk7XG5jb25zdCBzcGFuc3RhdHVzID0gcmVxdWlyZSgnLi4vdHJhY2luZy9zcGFuc3RhdHVzLmpzJyk7XG5jb25zdCB0cmFjZSA9IHJlcXVpcmUoJy4uL3RyYWNpbmcvdHJhY2UuanMnKTtcblxuLy8gQmFzZWQgb24gS2FtaWwgT2fDs3JlaydzIHdvcmsgb246XG4vLyBodHRwczovL2dpdGh1Yi5jb20vc3VwYWJhc2UtY29tbXVuaXR5L3NlbnRyeS1pbnRlZ3JhdGlvbi1qc1xuXG5cbmNvbnN0IEFVVEhfT1BFUkFUSU9OU19UT19JTlNUUlVNRU5UID0gW1xuICAncmVhdXRoZW50aWNhdGUnLFxuICAnc2lnbkluQW5vbnltb3VzbHknLFxuICAnc2lnbkluV2l0aE9BdXRoJyxcbiAgJ3NpZ25JbldpdGhJZFRva2VuJyxcbiAgJ3NpZ25JbldpdGhPdHAnLFxuICAnc2lnbkluV2l0aFBhc3N3b3JkJyxcbiAgJ3NpZ25JbldpdGhTU08nLFxuICAnc2lnbk91dCcsXG4gICdzaWduVXAnLFxuICAndmVyaWZ5T3RwJyxcbl07XG5cbmNvbnN0IEFVVEhfQURNSU5fT1BFUkFUSU9OU19UT19JTlNUUlVNRU5UID0gW1xuICAnY3JlYXRlVXNlcicsXG4gICdkZWxldGVVc2VyJyxcbiAgJ2xpc3RVc2VycycsXG4gICdnZXRVc2VyQnlJZCcsXG4gICd1cGRhdGVVc2VyQnlJZCcsXG4gICdpbnZpdGVVc2VyQnlFbWFpbCcsXG5dO1xuXG5jb25zdCBGSUxURVJfTUFQUElOR1MgPSB7XG4gIGVxOiAnZXEnLFxuICBuZXE6ICduZXEnLFxuICBndDogJ2d0JyxcbiAgZ3RlOiAnZ3RlJyxcbiAgbHQ6ICdsdCcsXG4gIGx0ZTogJ2x0ZScsXG4gIGxpa2U6ICdsaWtlJyxcbiAgJ2xpa2UoYWxsKSc6ICdsaWtlQWxsT2YnLFxuICAnbGlrZShhbnkpJzogJ2xpa2VBbnlPZicsXG4gIGlsaWtlOiAnaWxpa2UnLFxuICAnaWxpa2UoYWxsKSc6ICdpbGlrZUFsbE9mJyxcbiAgJ2lsaWtlKGFueSknOiAnaWxpa2VBbnlPZicsXG4gIGlzOiAnaXMnLFxuICBpbjogJ2luJyxcbiAgY3M6ICdjb250YWlucycsXG4gIGNkOiAnY29udGFpbmVkQnknLFxuICBzcjogJ3JhbmdlR3QnLFxuICBueGw6ICdyYW5nZUd0ZScsXG4gIHNsOiAncmFuZ2VMdCcsXG4gIG54cjogJ3JhbmdlTHRlJyxcbiAgYWRqOiAncmFuZ2VBZGphY2VudCcsXG4gIG92OiAnb3ZlcmxhcHMnLFxuICBmdHM6ICcnLFxuICBwbGZ0czogJ3BsYWluJyxcbiAgcGhmdHM6ICdwaHJhc2UnLFxuICB3ZnRzOiAnd2Vic2VhcmNoJyxcbiAgbm90OiAnbm90Jyxcbn07XG5cbmNvbnN0IERCX09QRVJBVElPTlNfVE9fSU5TVFJVTUVOVCA9IFsnc2VsZWN0JywgJ2luc2VydCcsICd1cHNlcnQnLCAndXBkYXRlJywgJ2RlbGV0ZSddO1xuXG5mdW5jdGlvbiBtYXJrQXNJbnN0cnVtZW50ZWQoZm4pIHtcbiAgdHJ5IHtcbiAgICAoZm4gKS5fX1NFTlRSWV9JTlNUUlVNRU5URURfXyA9IHRydWU7XG4gIH0gY2F0Y2gge1xuICAgIC8vIGlnbm9yZSBlcnJvcnMgaGVyZVxuICB9XG59XG5cbmZ1bmN0aW9uIGlzSW5zdHJ1bWVudGVkKGZuKSB7XG4gIHRyeSB7XG4gICAgcmV0dXJuIChmbiApLl9fU0VOVFJZX0lOU1RSVU1FTlRFRF9fO1xuICB9IGNhdGNoIHtcbiAgICByZXR1cm4gZmFsc2U7XG4gIH1cbn1cblxuLyoqXG4gKiBFeHRyYWN0cyB0aGUgZGF0YWJhc2Ugb3BlcmF0aW9uIHR5cGUgZnJvbSB0aGUgSFRUUCBtZXRob2QgYW5kIGhlYWRlcnNcbiAqIEBwYXJhbSBtZXRob2QgLSBUaGUgSFRUUCBtZXRob2Qgb2YgdGhlIHJlcXVlc3RcbiAqIEBwYXJhbSBoZWFkZXJzIC0gVGhlIHJlcXVlc3QgaGVhZGVyc1xuICogQHJldHVybnMgVGhlIGRhdGFiYXNlIG9wZXJhdGlvbiB0eXBlICgnc2VsZWN0JywgJ2luc2VydCcsICd1cHNlcnQnLCAndXBkYXRlJywgb3IgJ2RlbGV0ZScpXG4gKi9cbmZ1bmN0aW9uIGV4dHJhY3RPcGVyYXRpb24obWV0aG9kLCBoZWFkZXJzID0ge30pIHtcbiAgc3dpdGNoIChtZXRob2QpIHtcbiAgICBjYXNlICdHRVQnOiB7XG4gICAgICByZXR1cm4gJ3NlbGVjdCc7XG4gICAgfVxuICAgIGNhc2UgJ1BPU1QnOiB7XG4gICAgICBpZiAoaGVhZGVyc1snUHJlZmVyJ10/LmluY2x1ZGVzKCdyZXNvbHV0aW9uPScpKSB7XG4gICAgICAgIHJldHVybiAndXBzZXJ0JztcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIHJldHVybiAnaW5zZXJ0JztcbiAgICAgIH1cbiAgICB9XG4gICAgY2FzZSAnUEFUQ0gnOiB7XG4gICAgICByZXR1cm4gJ3VwZGF0ZSc7XG4gICAgfVxuICAgIGNhc2UgJ0RFTEVURSc6IHtcbiAgICAgIHJldHVybiAnZGVsZXRlJztcbiAgICB9XG4gICAgZGVmYXVsdDoge1xuICAgICAgcmV0dXJuICc8dW5rbm93bi1vcD4nO1xuICAgIH1cbiAgfVxufVxuXG4vKipcbiAqIFRyYW5zbGF0ZXMgU3VwYWJhc2UgZmlsdGVyIHBhcmFtZXRlcnMgaW50byByZWFkYWJsZSBtZXRob2QgbmFtZXMgZm9yIHRyYWNpbmdcbiAqIEBwYXJhbSBrZXkgLSBUaGUgZmlsdGVyIGtleSBmcm9tIHRoZSBVUkwgc2VhcmNoIHBhcmFtZXRlcnNcbiAqIEBwYXJhbSBxdWVyeSAtIFRoZSBmaWx0ZXIgdmFsdWUgZnJvbSB0aGUgVVJMIHNlYXJjaCBwYXJhbWV0ZXJzXG4gKiBAcmV0dXJucyBBIHN0cmluZyByZXByZXNlbnRhdGlvbiBvZiB0aGUgZmlsdGVyIGFzIGEgbWV0aG9kIGNhbGxcbiAqL1xuZnVuY3Rpb24gdHJhbnNsYXRlRmlsdGVyc0ludG9NZXRob2RzKGtleSwgcXVlcnkpIHtcbiAgaWYgKHF1ZXJ5ID09PSAnJyB8fCBxdWVyeSA9PT0gJyonKSB7XG4gICAgcmV0dXJuICdzZWxlY3QoKiknO1xuICB9XG5cbiAgaWYgKGtleSA9PT0gJ3NlbGVjdCcpIHtcbiAgICByZXR1cm4gYHNlbGVjdCgke3F1ZXJ5fSlgO1xuICB9XG5cbiAgaWYgKGtleSA9PT0gJ29yJyB8fCBrZXkuZW5kc1dpdGgoJy5vcicpKSB7XG4gICAgcmV0dXJuIGAke2tleX0ke3F1ZXJ5fWA7XG4gIH1cblxuICBjb25zdCBbZmlsdGVyLCAuLi52YWx1ZV0gPSBxdWVyeS5zcGxpdCgnLicpO1xuXG4gIGxldCBtZXRob2Q7XG4gIC8vIEhhbmRsZSBvcHRpb25hbCBgY29uZmlnUGFydGAgb2YgdGhlIGZpbHRlclxuICBpZiAoZmlsdGVyPy5zdGFydHNXaXRoKCdmdHMnKSkge1xuICAgIG1ldGhvZCA9ICd0ZXh0U2VhcmNoJztcbiAgfSBlbHNlIGlmIChmaWx0ZXI/LnN0YXJ0c1dpdGgoJ3BsZnRzJykpIHtcbiAgICBtZXRob2QgPSAndGV4dFNlYXJjaFtwbGFpbl0nO1xuICB9IGVsc2UgaWYgKGZpbHRlcj8uc3RhcnRzV2l0aCgncGhmdHMnKSkge1xuICAgIG1ldGhvZCA9ICd0ZXh0U2VhcmNoW3BocmFzZV0nO1xuICB9IGVsc2UgaWYgKGZpbHRlcj8uc3RhcnRzV2l0aCgnd2Z0cycpKSB7XG4gICAgbWV0aG9kID0gJ3RleHRTZWFyY2hbd2Vic2VhcmNoXSc7XG4gIH0gZWxzZSB7XG4gICAgbWV0aG9kID0gKGZpbHRlciAmJiBGSUxURVJfTUFQUElOR1NbZmlsdGVyIF0pIHx8ICdmaWx0ZXInO1xuICB9XG5cbiAgcmV0dXJuIGAke21ldGhvZH0oJHtrZXl9LCAke3ZhbHVlLmpvaW4oJy4nKX0pYDtcbn1cblxuZnVuY3Rpb24gaW5zdHJ1bWVudEF1dGhPcGVyYXRpb24ob3BlcmF0aW9uLCBpc0FkbWluID0gZmFsc2UpIHtcbiAgcmV0dXJuIG5ldyBQcm94eShvcGVyYXRpb24sIHtcbiAgICBhcHBseSh0YXJnZXQsIHRoaXNBcmcsIGFyZ3VtZW50c0xpc3QpIHtcbiAgICAgIHJldHVybiB0cmFjZS5zdGFydFNwYW4oXG4gICAgICAgIHtcbiAgICAgICAgICBuYW1lOiBgYXV0aCAke2lzQWRtaW4gPyAnKGFkbWluKSAnIDogJyd9JHtvcGVyYXRpb24ubmFtZX1gLFxuICAgICAgICAgIGF0dHJpYnV0ZXM6IHtcbiAgICAgICAgICAgIFtzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9PUklHSU5dOiAnYXV0by5kYi5zdXBhYmFzZScsXG4gICAgICAgICAgICBbc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfT1BdOiAnZGInLFxuICAgICAgICAgICAgJ2RiLnN5c3RlbSc6ICdwb3N0Z3Jlc3FsJyxcbiAgICAgICAgICAgICdkYi5vcGVyYXRpb24nOiBgYXV0aC4ke2lzQWRtaW4gPyAnYWRtaW4uJyA6ICcnfSR7b3BlcmF0aW9uLm5hbWV9YCxcbiAgICAgICAgICB9LFxuICAgICAgICB9LFxuICAgICAgICBzcGFuID0+IHtcbiAgICAgICAgICByZXR1cm4gUmVmbGVjdC5hcHBseSh0YXJnZXQsIHRoaXNBcmcsIGFyZ3VtZW50c0xpc3QpXG4gICAgICAgICAgICAudGhlbigocmVzKSA9PiB7XG4gICAgICAgICAgICAgIGlmIChyZXMgJiYgdHlwZW9mIHJlcyA9PT0gJ29iamVjdCcgJiYgJ2Vycm9yJyBpbiByZXMgJiYgcmVzLmVycm9yKSB7XG4gICAgICAgICAgICAgICAgc3Bhbi5zZXRTdGF0dXMoeyBjb2RlOiBzcGFuc3RhdHVzLlNQQU5fU1RBVFVTX0VSUk9SIH0pO1xuXG4gICAgICAgICAgICAgICAgZXhwb3J0cyQxLmNhcHR1cmVFeGNlcHRpb24ocmVzLmVycm9yLCB7XG4gICAgICAgICAgICAgICAgICBtZWNoYW5pc206IHtcbiAgICAgICAgICAgICAgICAgICAgaGFuZGxlZDogZmFsc2UsXG4gICAgICAgICAgICAgICAgICB9LFxuICAgICAgICAgICAgICAgIH0pO1xuICAgICAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgICAgIHNwYW4uc2V0U3RhdHVzKHsgY29kZTogc3BhbnN0YXR1cy5TUEFOX1NUQVRVU19PSyB9KTtcbiAgICAgICAgICAgICAgfVxuXG4gICAgICAgICAgICAgIHNwYW4uZW5kKCk7XG4gICAgICAgICAgICAgIHJldHVybiByZXM7XG4gICAgICAgICAgICB9KVxuICAgICAgICAgICAgLmNhdGNoKChlcnIpID0+IHtcbiAgICAgICAgICAgICAgc3Bhbi5zZXRTdGF0dXMoeyBjb2RlOiBzcGFuc3RhdHVzLlNQQU5fU1RBVFVTX0VSUk9SIH0pO1xuICAgICAgICAgICAgICBzcGFuLmVuZCgpO1xuXG4gICAgICAgICAgICAgIGV4cG9ydHMkMS5jYXB0dXJlRXhjZXB0aW9uKGVyciwge1xuICAgICAgICAgICAgICAgIG1lY2hhbmlzbToge1xuICAgICAgICAgICAgICAgICAgaGFuZGxlZDogZmFsc2UsXG4gICAgICAgICAgICAgICAgfSxcbiAgICAgICAgICAgICAgfSk7XG5cbiAgICAgICAgICAgICAgdGhyb3cgZXJyO1xuICAgICAgICAgICAgfSlcbiAgICAgICAgICAgIC50aGVuKC4uLmFyZ3VtZW50c0xpc3QpO1xuICAgICAgICB9LFxuICAgICAgKTtcbiAgICB9LFxuICB9KTtcbn1cblxuZnVuY3Rpb24gaW5zdHJ1bWVudFN1cGFiYXNlQXV0aENsaWVudChzdXBhYmFzZUNsaWVudEluc3RhbmNlKSB7XG4gIGNvbnN0IGF1dGggPSBzdXBhYmFzZUNsaWVudEluc3RhbmNlLmF1dGg7XG5cbiAgaWYgKCFhdXRoIHx8IGlzSW5zdHJ1bWVudGVkKHN1cGFiYXNlQ2xpZW50SW5zdGFuY2UuYXV0aCkpIHtcbiAgICByZXR1cm47XG4gIH1cblxuICBmb3IgKGNvbnN0IG9wZXJhdGlvbiBvZiBBVVRIX09QRVJBVElPTlNfVE9fSU5TVFJVTUVOVCkge1xuICAgIGNvbnN0IGF1dGhPcGVyYXRpb24gPSBhdXRoW29wZXJhdGlvbl07XG5cbiAgICBpZiAoIWF1dGhPcGVyYXRpb24pIHtcbiAgICAgIGNvbnRpbnVlO1xuICAgIH1cblxuICAgIGlmICh0eXBlb2Ygc3VwYWJhc2VDbGllbnRJbnN0YW5jZS5hdXRoW29wZXJhdGlvbl0gPT09ICdmdW5jdGlvbicpIHtcbiAgICAgIHN1cGFiYXNlQ2xpZW50SW5zdGFuY2UuYXV0aFtvcGVyYXRpb25dID0gaW5zdHJ1bWVudEF1dGhPcGVyYXRpb24oYXV0aE9wZXJhdGlvbik7XG4gICAgfVxuICB9XG5cbiAgZm9yIChjb25zdCBvcGVyYXRpb24gb2YgQVVUSF9BRE1JTl9PUEVSQVRJT05TX1RPX0lOU1RSVU1FTlQpIHtcbiAgICBjb25zdCBhdXRoT3BlcmF0aW9uID0gYXV0aC5hZG1pbltvcGVyYXRpb25dO1xuXG4gICAgaWYgKCFhdXRoT3BlcmF0aW9uKSB7XG4gICAgICBjb250aW51ZTtcbiAgICB9XG5cbiAgICBpZiAodHlwZW9mIHN1cGFiYXNlQ2xpZW50SW5zdGFuY2UuYXV0aC5hZG1pbltvcGVyYXRpb25dID09PSAnZnVuY3Rpb24nKSB7XG4gICAgICBzdXBhYmFzZUNsaWVudEluc3RhbmNlLmF1dGguYWRtaW5bb3BlcmF0aW9uXSA9IGluc3RydW1lbnRBdXRoT3BlcmF0aW9uKGF1dGhPcGVyYXRpb24sIHRydWUpO1xuICAgIH1cbiAgfVxuXG4gIG1hcmtBc0luc3RydW1lbnRlZChzdXBhYmFzZUNsaWVudEluc3RhbmNlLmF1dGgpO1xufVxuXG5mdW5jdGlvbiBpbnN0cnVtZW50U3VwYWJhc2VDbGllbnRDb25zdHJ1Y3RvcihTdXBhYmFzZUNsaWVudCkge1xuICBpZiAoaXNJbnN0cnVtZW50ZWQoKFN1cGFiYXNlQ2xpZW50ICkucHJvdG90eXBlLmZyb20pKSB7XG4gICAgcmV0dXJuO1xuICB9XG5cbiAgKFN1cGFiYXNlQ2xpZW50ICkucHJvdG90eXBlLmZyb20gPSBuZXcgUHJveHkoXG4gICAgKFN1cGFiYXNlQ2xpZW50ICkucHJvdG90eXBlLmZyb20sXG4gICAge1xuICAgICAgYXBwbHkodGFyZ2V0LCB0aGlzQXJnLCBhcmd1bWVudHNMaXN0KSB7XG4gICAgICAgIGNvbnN0IHJ2ID0gUmVmbGVjdC5hcHBseSh0YXJnZXQsIHRoaXNBcmcsIGFyZ3VtZW50c0xpc3QpO1xuICAgICAgICBjb25zdCBQb3N0Z1JFU1RRdWVyeUJ1aWxkZXIgPSAocnYgKS5jb25zdHJ1Y3RvcjtcblxuICAgICAgICBpbnN0cnVtZW50UG9zdGdSRVNUUXVlcnlCdWlsZGVyKFBvc3RnUkVTVFF1ZXJ5QnVpbGRlciApO1xuXG4gICAgICAgIHJldHVybiBydjtcbiAgICAgIH0sXG4gICAgfSxcbiAgKTtcblxuICBtYXJrQXNJbnN0cnVtZW50ZWQoKFN1cGFiYXNlQ2xpZW50ICkucHJvdG90eXBlLmZyb20pO1xufVxuXG5mdW5jdGlvbiBpbnN0cnVtZW50UG9zdGdSRVNURmlsdGVyQnVpbGRlcihQb3N0Z1JFU1RGaWx0ZXJCdWlsZGVyKSB7XG4gIGlmIChpc0luc3RydW1lbnRlZCgoUG9zdGdSRVNURmlsdGVyQnVpbGRlci5wcm90b3R5cGUgKS50aGVuKSkge1xuICAgIHJldHVybjtcbiAgfVxuXG4gIChQb3N0Z1JFU1RGaWx0ZXJCdWlsZGVyLnByb3RvdHlwZSApLnRoZW4gPSBuZXcgUHJveHkoXG4gICAgKFBvc3RnUkVTVEZpbHRlckJ1aWxkZXIucHJvdG90eXBlICkudGhlbixcbiAgICB7XG4gICAgICBhcHBseSh0YXJnZXQsIHRoaXNBcmcsIGFyZ3VtZW50c0xpc3QpIHtcbiAgICAgICAgY29uc3Qgb3BlcmF0aW9ucyA9IERCX09QRVJBVElPTlNfVE9fSU5TVFJVTUVOVDtcbiAgICAgICAgY29uc3QgdHlwZWRUaGlzID0gdGhpc0FyZyA7XG4gICAgICAgIGNvbnN0IG9wZXJhdGlvbiA9IGV4dHJhY3RPcGVyYXRpb24odHlwZWRUaGlzLm1ldGhvZCwgdHlwZWRUaGlzLmhlYWRlcnMpO1xuXG4gICAgICAgIGlmICghb3BlcmF0aW9ucy5pbmNsdWRlcyhvcGVyYXRpb24pKSB7XG4gICAgICAgICAgcmV0dXJuIFJlZmxlY3QuYXBwbHkodGFyZ2V0LCB0aGlzQXJnLCBhcmd1bWVudHNMaXN0KTtcbiAgICAgICAgfVxuXG4gICAgICAgIGlmICghdHlwZWRUaGlzPy51cmw/LnBhdGhuYW1lIHx8IHR5cGVvZiB0eXBlZFRoaXMudXJsLnBhdGhuYW1lICE9PSAnc3RyaW5nJykge1xuICAgICAgICAgIHJldHVybiBSZWZsZWN0LmFwcGx5KHRhcmdldCwgdGhpc0FyZywgYXJndW1lbnRzTGlzdCk7XG4gICAgICAgIH1cblxuICAgICAgICBjb25zdCBwYXRoUGFydHMgPSB0eXBlZFRoaXMudXJsLnBhdGhuYW1lLnNwbGl0KCcvJyk7XG4gICAgICAgIGNvbnN0IHRhYmxlID0gcGF0aFBhcnRzLmxlbmd0aCA+IDAgPyBwYXRoUGFydHNbcGF0aFBhcnRzLmxlbmd0aCAtIDFdIDogJyc7XG5cbiAgICAgICAgY29uc3QgcXVlcnlJdGVtcyA9IFtdO1xuICAgICAgICBmb3IgKGNvbnN0IFtrZXksIHZhbHVlXSBvZiB0eXBlZFRoaXMudXJsLnNlYXJjaFBhcmFtcy5lbnRyaWVzKCkpIHtcbiAgICAgICAgICAvLyBJdCdzIHBvc3NpYmxlIHRvIGhhdmUgbXVsdGlwbGUgZW50cmllcyBmb3IgdGhlIHNhbWUga2V5LCBlZy4gYGlkPWVxLjcmaWQ9ZXEuM2AsXG4gICAgICAgICAgLy8gc28gd2UgbmVlZCB0byB1c2UgYXJyYXkgaW5zdGVhZCBvZiBvYmplY3QgdG8gY29sbGVjdCB0aGVtLlxuICAgICAgICAgIHF1ZXJ5SXRlbXMucHVzaCh0cmFuc2xhdGVGaWx0ZXJzSW50b01ldGhvZHMoa2V5LCB2YWx1ZSkpO1xuICAgICAgICB9XG4gICAgICAgIGNvbnN0IGJvZHkgPSBPYmplY3QuY3JlYXRlKG51bGwpO1xuICAgICAgICBpZiAoaXMuaXNQbGFpbk9iamVjdCh0eXBlZFRoaXMuYm9keSkpIHtcbiAgICAgICAgICBmb3IgKGNvbnN0IFtrZXksIHZhbHVlXSBvZiBPYmplY3QuZW50cmllcyh0eXBlZFRoaXMuYm9keSkpIHtcbiAgICAgICAgICAgIGJvZHlba2V5XSA9IHZhbHVlO1xuICAgICAgICAgIH1cbiAgICAgICAgfVxuXG4gICAgICAgIC8vIEFkZGluZyBvcGVyYXRpb24gdG8gdGhlIGJlZ2lubmluZyBvZiB0aGUgZGVzY3JpcHRpb24gaWYgaXQncyBub3QgYSBgc2VsZWN0YCBvcGVyYXRpb25cbiAgICAgICAgLy8gRm9yIGV4YW1wbGUsIGl0IGNhbiBiZSBhbiBgaW5zZXJ0YCBvciBgdXBkYXRlYCBvcGVyYXRpb24gYnV0IHRoZSBxdWVyeSBjYW4gYmUgYHNlbGVjdCguLi4pYFxuICAgICAgICAvLyBGb3IgYHNlbGVjdGAgb3BlcmF0aW9ucywgd2UgZG9uJ3QgbmVlZCByZXBlYXQgaXQgaW4gdGhlIGRlc2NyaXB0aW9uXG4gICAgICAgIGNvbnN0IGRlc2NyaXB0aW9uID0gYCR7b3BlcmF0aW9uID09PSAnc2VsZWN0JyA/ICcnIDogYCR7b3BlcmF0aW9ufSR7Ym9keSA/ICcoLi4uKSAnIDogJyd9YH0ke3F1ZXJ5SXRlbXMuam9pbihcbiAgICAgICAgICAnICcsXG4gICAgICAgICl9IGZyb20oJHt0YWJsZX0pYDtcblxuICAgICAgICBjb25zdCBhdHRyaWJ1dGVzID0ge1xuICAgICAgICAgICdkYi50YWJsZSc6IHRhYmxlLFxuICAgICAgICAgICdkYi5zY2hlbWEnOiB0eXBlZFRoaXMuc2NoZW1hLFxuICAgICAgICAgICdkYi51cmwnOiB0eXBlZFRoaXMudXJsLm9yaWdpbixcbiAgICAgICAgICAnZGIuc2RrJzogdHlwZWRUaGlzLmhlYWRlcnNbJ1gtQ2xpZW50LUluZm8nXSxcbiAgICAgICAgICAnZGIuc3lzdGVtJzogJ3Bvc3RncmVzcWwnLFxuICAgICAgICAgICdkYi5vcGVyYXRpb24nOiBvcGVyYXRpb24sXG4gICAgICAgICAgW3NlbWFudGljQXR0cmlidXRlcy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX09SSUdJTl06ICdhdXRvLmRiLnN1cGFiYXNlJyxcbiAgICAgICAgICBbc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfT1BdOiAnZGInLFxuICAgICAgICB9O1xuXG4gICAgICAgIGlmIChxdWVyeUl0ZW1zLmxlbmd0aCkge1xuICAgICAgICAgIGF0dHJpYnV0ZXNbJ2RiLnF1ZXJ5J10gPSBxdWVyeUl0ZW1zO1xuICAgICAgICB9XG5cbiAgICAgICAgaWYgKE9iamVjdC5rZXlzKGJvZHkpLmxlbmd0aCkge1xuICAgICAgICAgIGF0dHJpYnV0ZXNbJ2RiLmJvZHknXSA9IGJvZHk7XG4gICAgICAgIH1cblxuICAgICAgICByZXR1cm4gdHJhY2Uuc3RhcnRTcGFuKFxuICAgICAgICAgIHtcbiAgICAgICAgICAgIG5hbWU6IGRlc2NyaXB0aW9uLFxuICAgICAgICAgICAgYXR0cmlidXRlcyxcbiAgICAgICAgICB9LFxuICAgICAgICAgIHNwYW4gPT4ge1xuICAgICAgICAgICAgcmV0dXJuIChSZWZsZWN0LmFwcGx5KHRhcmdldCwgdGhpc0FyZywgW10pIClcbiAgICAgICAgICAgICAgLnRoZW4oXG4gICAgICAgICAgICAgICAgKHJlcykgPT4ge1xuICAgICAgICAgICAgICAgICAgaWYgKHNwYW4pIHtcbiAgICAgICAgICAgICAgICAgICAgaWYgKHJlcyAmJiB0eXBlb2YgcmVzID09PSAnb2JqZWN0JyAmJiAnc3RhdHVzJyBpbiByZXMpIHtcbiAgICAgICAgICAgICAgICAgICAgICBzcGFuc3RhdHVzLnNldEh0dHBTdGF0dXMoc3BhbiwgcmVzLnN0YXR1cyB8fCA1MDApO1xuICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgICAgIHNwYW4uZW5kKCk7XG4gICAgICAgICAgICAgICAgICB9XG5cbiAgICAgICAgICAgICAgICAgIGlmIChyZXMuZXJyb3IpIHtcbiAgICAgICAgICAgICAgICAgICAgY29uc3QgZXJyID0gbmV3IEVycm9yKHJlcy5lcnJvci5tZXNzYWdlKSA7XG4gICAgICAgICAgICAgICAgICAgIGlmIChyZXMuZXJyb3IuY29kZSkge1xuICAgICAgICAgICAgICAgICAgICAgIGVyci5jb2RlID0gcmVzLmVycm9yLmNvZGU7XG4gICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICAgICAgaWYgKHJlcy5lcnJvci5kZXRhaWxzKSB7XG4gICAgICAgICAgICAgICAgICAgICAgZXJyLmRldGFpbHMgPSByZXMuZXJyb3IuZGV0YWlscztcbiAgICAgICAgICAgICAgICAgICAgfVxuXG4gICAgICAgICAgICAgICAgICAgIGNvbnN0IHN1cGFiYXNlQ29udGV4dCA9IHt9O1xuICAgICAgICAgICAgICAgICAgICBpZiAocXVlcnlJdGVtcy5sZW5ndGgpIHtcbiAgICAgICAgICAgICAgICAgICAgICBzdXBhYmFzZUNvbnRleHQucXVlcnkgPSBxdWVyeUl0ZW1zO1xuICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgICAgIGlmIChPYmplY3Qua2V5cyhib2R5KS5sZW5ndGgpIHtcbiAgICAgICAgICAgICAgICAgICAgICBzdXBhYmFzZUNvbnRleHQuYm9keSA9IGJvZHk7XG4gICAgICAgICAgICAgICAgICAgIH1cblxuICAgICAgICAgICAgICAgICAgICBleHBvcnRzJDEuY2FwdHVyZUV4Y2VwdGlvbihlcnIsIHtcbiAgICAgICAgICAgICAgICAgICAgICBjb250ZXh0czoge1xuICAgICAgICAgICAgICAgICAgICAgICAgc3VwYWJhc2U6IHN1cGFiYXNlQ29udGV4dCxcbiAgICAgICAgICAgICAgICAgICAgICB9LFxuICAgICAgICAgICAgICAgICAgICB9KTtcbiAgICAgICAgICAgICAgICAgIH1cblxuICAgICAgICAgICAgICAgICAgY29uc3QgYnJlYWRjcnVtYiA9IHtcbiAgICAgICAgICAgICAgICAgICAgdHlwZTogJ3N1cGFiYXNlJyxcbiAgICAgICAgICAgICAgICAgICAgY2F0ZWdvcnk6IGBkYi4ke29wZXJhdGlvbn1gLFxuICAgICAgICAgICAgICAgICAgICBtZXNzYWdlOiBkZXNjcmlwdGlvbixcbiAgICAgICAgICAgICAgICAgIH07XG5cbiAgICAgICAgICAgICAgICAgIGNvbnN0IGRhdGEgPSB7fTtcblxuICAgICAgICAgICAgICAgICAgaWYgKHF1ZXJ5SXRlbXMubGVuZ3RoKSB7XG4gICAgICAgICAgICAgICAgICAgIGRhdGEucXVlcnkgPSBxdWVyeUl0ZW1zO1xuICAgICAgICAgICAgICAgICAgfVxuXG4gICAgICAgICAgICAgICAgICBpZiAoT2JqZWN0LmtleXMoYm9keSkubGVuZ3RoKSB7XG4gICAgICAgICAgICAgICAgICAgIGRhdGEuYm9keSA9IGJvZHk7XG4gICAgICAgICAgICAgICAgICB9XG5cbiAgICAgICAgICAgICAgICAgIGlmIChPYmplY3Qua2V5cyhkYXRhKS5sZW5ndGgpIHtcbiAgICAgICAgICAgICAgICAgICAgYnJlYWRjcnVtYi5kYXRhID0gZGF0YTtcbiAgICAgICAgICAgICAgICAgIH1cblxuICAgICAgICAgICAgICAgICAgYnJlYWRjcnVtYnMuYWRkQnJlYWRjcnVtYihicmVhZGNydW1iKTtcblxuICAgICAgICAgICAgICAgICAgcmV0dXJuIHJlcztcbiAgICAgICAgICAgICAgICB9LFxuICAgICAgICAgICAgICAgIChlcnIpID0+IHtcbiAgICAgICAgICAgICAgICAgIGlmIChzcGFuKSB7XG4gICAgICAgICAgICAgICAgICAgIHNwYW5zdGF0dXMuc2V0SHR0cFN0YXR1cyhzcGFuLCA1MDApO1xuICAgICAgICAgICAgICAgICAgICBzcGFuLmVuZCgpO1xuICAgICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgICAgdGhyb3cgZXJyO1xuICAgICAgICAgICAgICAgIH0sXG4gICAgICAgICAgICAgIClcbiAgICAgICAgICAgICAgLnRoZW4oLi4uYXJndW1lbnRzTGlzdCk7XG4gICAgICAgICAgfSxcbiAgICAgICAgKTtcbiAgICAgIH0sXG4gICAgfSxcbiAgKTtcblxuICBtYXJrQXNJbnN0cnVtZW50ZWQoKFBvc3RnUkVTVEZpbHRlckJ1aWxkZXIucHJvdG90eXBlICkudGhlbik7XG59XG5cbmZ1bmN0aW9uIGluc3RydW1lbnRQb3N0Z1JFU1RRdWVyeUJ1aWxkZXIoUG9zdGdSRVNUUXVlcnlCdWlsZGVyKSB7XG4gIC8vIFdlIG5lZWQgdG8gd3JhcCBfYWxsXyBvcGVyYXRpb25zIGRlc3BpdGUgdGhlbSBzaGFyaW5nIHRoZSBzYW1lIGBQb3N0Z1JFU1RGaWx0ZXJCdWlsZGVyYFxuICAvLyBjb25zdHJ1Y3RvciwgYXMgd2UgZG9uJ3Qga25vdyB3aGljaCBtZXRob2Qgd2lsbCBiZSBjYWxsZWQgZmlyc3QsIGFuZCB3ZSBkb24ndCB3YW50IHRvIG1pc3MgYW55IGNhbGxzLlxuICBmb3IgKGNvbnN0IG9wZXJhdGlvbiBvZiBEQl9PUEVSQVRJT05TX1RPX0lOU1RSVU1FTlQpIHtcbiAgICBpZiAoaXNJbnN0cnVtZW50ZWQoKFBvc3RnUkVTVFF1ZXJ5QnVpbGRlci5wcm90b3R5cGUgKVtvcGVyYXRpb25dKSkge1xuICAgICAgY29udGludWU7XG4gICAgfVxuXG4gICAgKFBvc3RnUkVTVFF1ZXJ5QnVpbGRlci5wcm90b3R5cGUgKVtvcGVyYXRpb24gXSA9IG5ldyBQcm94eShcbiAgICAgIChQb3N0Z1JFU1RRdWVyeUJ1aWxkZXIucHJvdG90eXBlIClbb3BlcmF0aW9uIF0sXG4gICAgICB7XG4gICAgICAgIGFwcGx5KHRhcmdldCwgdGhpc0FyZywgYXJndW1lbnRzTGlzdCkge1xuICAgICAgICAgIGNvbnN0IHJ2ID0gUmVmbGVjdC5hcHBseSh0YXJnZXQsIHRoaXNBcmcsIGFyZ3VtZW50c0xpc3QpO1xuICAgICAgICAgIGNvbnN0IFBvc3RnUkVTVEZpbHRlckJ1aWxkZXIgPSAocnYgKS5jb25zdHJ1Y3RvcjtcblxuICAgICAgICAgIGRlYnVnQnVpbGQuREVCVUdfQlVJTEQgJiYgZGVidWdMb2dnZXIuZGVidWcubG9nKGBJbnN0cnVtZW50aW5nICR7b3BlcmF0aW9ufSBvcGVyYXRpb24ncyBQb3N0Z1JFU1RGaWx0ZXJCdWlsZGVyYCk7XG5cbiAgICAgICAgICBpbnN0cnVtZW50UG9zdGdSRVNURmlsdGVyQnVpbGRlcihQb3N0Z1JFU1RGaWx0ZXJCdWlsZGVyKTtcblxuICAgICAgICAgIHJldHVybiBydjtcbiAgICAgICAgfSxcbiAgICAgIH0sXG4gICAgKTtcblxuICAgIG1hcmtBc0luc3RydW1lbnRlZCgoUG9zdGdSRVNUUXVlcnlCdWlsZGVyLnByb3RvdHlwZSApW29wZXJhdGlvbl0pO1xuICB9XG59XG5cbmNvbnN0IGluc3RydW1lbnRTdXBhYmFzZUNsaWVudCA9IChzdXBhYmFzZUNsaWVudCkgPT4ge1xuICBpZiAoIXN1cGFiYXNlQ2xpZW50KSB7XG4gICAgZGVidWdCdWlsZC5ERUJVR19CVUlMRCAmJiBkZWJ1Z0xvZ2dlci5kZWJ1Zy53YXJuKCdTdXBhYmFzZSBpbnRlZ3JhdGlvbiB3YXMgbm90IGluc3RhbGxlZCBiZWNhdXNlIG5vIFN1cGFiYXNlIGNsaWVudCB3YXMgcHJvdmlkZWQuJyk7XG4gICAgcmV0dXJuO1xuICB9XG4gIGNvbnN0IFN1cGFiYXNlQ2xpZW50Q29uc3RydWN0b3IgPVxuICAgIHN1cGFiYXNlQ2xpZW50LmNvbnN0cnVjdG9yID09PSBGdW5jdGlvbiA/IHN1cGFiYXNlQ2xpZW50IDogc3VwYWJhc2VDbGllbnQuY29uc3RydWN0b3I7XG5cbiAgaW5zdHJ1bWVudFN1cGFiYXNlQ2xpZW50Q29uc3RydWN0b3IoU3VwYWJhc2VDbGllbnRDb25zdHJ1Y3Rvcik7XG4gIGluc3RydW1lbnRTdXBhYmFzZUF1dGhDbGllbnQoc3VwYWJhc2VDbGllbnQgKTtcbn07XG5cbmNvbnN0IElOVEVHUkFUSU9OX05BTUUgPSAnU3VwYWJhc2UnO1xuXG5jb25zdCBfc3VwYWJhc2VJbnRlZ3JhdGlvbiA9ICgoc3VwYWJhc2VDbGllbnQpID0+IHtcbiAgcmV0dXJuIHtcbiAgICBzZXR1cE9uY2UoKSB7XG4gICAgICBpbnN0cnVtZW50U3VwYWJhc2VDbGllbnQoc3VwYWJhc2VDbGllbnQpO1xuICAgIH0sXG4gICAgbmFtZTogSU5URUdSQVRJT05fTkFNRSxcbiAgfTtcbn0pIDtcblxuY29uc3Qgc3VwYWJhc2VJbnRlZ3JhdGlvbiA9IGludGVncmF0aW9uLmRlZmluZUludGVncmF0aW9uKChvcHRpb25zKSA9PiB7XG4gIHJldHVybiBfc3VwYWJhc2VJbnRlZ3JhdGlvbihvcHRpb25zLnN1cGFiYXNlQ2xpZW50KTtcbn0pIDtcblxuZXhwb3J0cy5EQl9PUEVSQVRJT05TX1RPX0lOU1RSVU1FTlQgPSBEQl9PUEVSQVRJT05TX1RPX0lOU1RSVU1FTlQ7XG5leHBvcnRzLkZJTFRFUl9NQVBQSU5HUyA9IEZJTFRFUl9NQVBQSU5HUztcbmV4cG9ydHMuZXh0cmFjdE9wZXJhdGlvbiA9IGV4dHJhY3RPcGVyYXRpb247XG5leHBvcnRzLmluc3RydW1lbnRTdXBhYmFzZUNsaWVudCA9IGluc3RydW1lbnRTdXBhYmFzZUNsaWVudDtcbmV4cG9ydHMuc3VwYWJhc2VJbnRlZ3JhdGlvbiA9IHN1cGFiYXNlSW50ZWdyYXRpb247XG5leHBvcnRzLnRyYW5zbGF0ZUZpbHRlcnNJbnRvTWV0aG9kcyA9IHRyYW5zbGF0ZUZpbHRlcnNJbnRvTWV0aG9kcztcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPXN1cGFiYXNlLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/supabase.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/third-party-errors-filter.js":
/*!******************************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/third-party-errors-filter.js ***!
  \******************************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst integration = __webpack_require__(/*! ../integration.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integration.js\");\nconst metadata = __webpack_require__(/*! ../metadata.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/metadata.js\");\nconst envelope = __webpack_require__(/*! ../utils/envelope.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/envelope.js\");\nconst stacktrace = __webpack_require__(/*! ../utils/stacktrace.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/stacktrace.js\");\n\n/**\n * This integration allows you to filter out, or tag error events that do not come from user code marked with a bundle key via the Sentry bundler plugins.\n */\nconst thirdPartyErrorFilterIntegration = integration.defineIntegration((options) => {\n  return {\n    name: 'ThirdPartyErrorsFilter',\n    setup(client) {\n      // We need to strip metadata from stack frames before sending them to Sentry since these are client side only.\n      // TODO(lforst): Move this cleanup logic into a more central place in the SDK.\n      client.on('beforeEnvelope', envelope$1 => {\n        envelope.forEachEnvelopeItem(envelope$1, (item, type) => {\n          if (type === 'event') {\n            const event = Array.isArray(item) ? (item )[1] : undefined;\n\n            if (event) {\n              metadata.stripMetadataFromStackFrames(event);\n              item[1] = event;\n            }\n          }\n        });\n      });\n\n      client.on('applyFrameMetadata', event => {\n        // Only apply stack frame metadata to error events\n        if (event.type) {\n          return;\n        }\n\n        const stackParser = client.getOptions().stackParser;\n        metadata.addMetadataToStackFrames(stackParser, event);\n      });\n    },\n\n    processEvent(event) {\n      const frameKeys = getBundleKeysForAllFramesWithFilenames(event);\n\n      if (frameKeys) {\n        const arrayMethod =\n          options.behaviour === 'drop-error-if-contains-third-party-frames' ||\n          options.behaviour === 'apply-tag-if-contains-third-party-frames'\n            ? 'some'\n            : 'every';\n\n        const behaviourApplies = frameKeys[arrayMethod](keys => !keys.some(key => options.filterKeys.includes(key)));\n\n        if (behaviourApplies) {\n          const shouldDrop =\n            options.behaviour === 'drop-error-if-contains-third-party-frames' ||\n            options.behaviour === 'drop-error-if-exclusively-contains-third-party-frames';\n          if (shouldDrop) {\n            return null;\n          } else {\n            event.tags = {\n              ...event.tags,\n              third_party_code: true,\n            };\n          }\n        }\n      }\n\n      return event;\n    },\n  };\n});\n\nfunction getBundleKeysForAllFramesWithFilenames(event) {\n  const frames = stacktrace.getFramesFromEvent(event);\n\n  if (!frames) {\n    return undefined;\n  }\n\n  return (\n    frames\n      // Exclude frames without a filename since these are likely native code or built-ins\n      .filter(frame => !!frame.filename)\n      .map(frame => {\n        if (frame.module_metadata) {\n          return Object.keys(frame.module_metadata)\n            .filter(key => key.startsWith(BUNDLER_PLUGIN_APP_KEY_PREFIX))\n            .map(key => key.slice(BUNDLER_PLUGIN_APP_KEY_PREFIX.length));\n        }\n        return [];\n      })\n  );\n}\n\nconst BUNDLER_PLUGIN_APP_KEY_PREFIX = '_sentryBundlerPluginAppKey:';\n\nexports.thirdPartyErrorFilterIntegration = thirdPartyErrorFilterIntegration;\n//# sourceMappingURL=third-party-errors-filter.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvaW50ZWdyYXRpb25zL3RoaXJkLXBhcnR5LWVycm9ycy1maWx0ZXIuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsb0JBQW9CLG1CQUFPLENBQUMsbUlBQW1CO0FBQy9DLGlCQUFpQixtQkFBTyxDQUFDLDZIQUFnQjtBQUN6QyxpQkFBaUIsbUJBQU8sQ0FBQyx5SUFBc0I7QUFDL0MsbUJBQW1CLG1CQUFPLENBQUMsNklBQXdCOztBQUVuRDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsU0FBUztBQUNULE9BQU87O0FBRVA7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsT0FBTztBQUNQLEtBQUs7O0FBRUw7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsWUFBWTtBQUNaO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0EsS0FBSztBQUNMO0FBQ0EsQ0FBQzs7QUFFRDtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsT0FBTztBQUNQO0FBQ0E7O0FBRUE7O0FBRUEsd0NBQXdDO0FBQ3hDIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvaW50ZWdyYXRpb25zL3RoaXJkLXBhcnR5LWVycm9ycy1maWx0ZXIuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGludGVncmF0aW9uID0gcmVxdWlyZSgnLi4vaW50ZWdyYXRpb24uanMnKTtcbmNvbnN0IG1ldGFkYXRhID0gcmVxdWlyZSgnLi4vbWV0YWRhdGEuanMnKTtcbmNvbnN0IGVudmVsb3BlID0gcmVxdWlyZSgnLi4vdXRpbHMvZW52ZWxvcGUuanMnKTtcbmNvbnN0IHN0YWNrdHJhY2UgPSByZXF1aXJlKCcuLi91dGlscy9zdGFja3RyYWNlLmpzJyk7XG5cbi8qKlxuICogVGhpcyBpbnRlZ3JhdGlvbiBhbGxvd3MgeW91IHRvIGZpbHRlciBvdXQsIG9yIHRhZyBlcnJvciBldmVudHMgdGhhdCBkbyBub3QgY29tZSBmcm9tIHVzZXIgY29kZSBtYXJrZWQgd2l0aCBhIGJ1bmRsZSBrZXkgdmlhIHRoZSBTZW50cnkgYnVuZGxlciBwbHVnaW5zLlxuICovXG5jb25zdCB0aGlyZFBhcnR5RXJyb3JGaWx0ZXJJbnRlZ3JhdGlvbiA9IGludGVncmF0aW9uLmRlZmluZUludGVncmF0aW9uKChvcHRpb25zKSA9PiB7XG4gIHJldHVybiB7XG4gICAgbmFtZTogJ1RoaXJkUGFydHlFcnJvcnNGaWx0ZXInLFxuICAgIHNldHVwKGNsaWVudCkge1xuICAgICAgLy8gV2UgbmVlZCB0byBzdHJpcCBtZXRhZGF0YSBmcm9tIHN0YWNrIGZyYW1lcyBiZWZvcmUgc2VuZGluZyB0aGVtIHRvIFNlbnRyeSBzaW5jZSB0aGVzZSBhcmUgY2xpZW50IHNpZGUgb25seS5cbiAgICAgIC8vIFRPRE8obGZvcnN0KTogTW92ZSB0aGlzIGNsZWFudXAgbG9naWMgaW50byBhIG1vcmUgY2VudHJhbCBwbGFjZSBpbiB0aGUgU0RLLlxuICAgICAgY2xpZW50Lm9uKCdiZWZvcmVFbnZlbG9wZScsIGVudmVsb3BlJDEgPT4ge1xuICAgICAgICBlbnZlbG9wZS5mb3JFYWNoRW52ZWxvcGVJdGVtKGVudmVsb3BlJDEsIChpdGVtLCB0eXBlKSA9PiB7XG4gICAgICAgICAgaWYgKHR5cGUgPT09ICdldmVudCcpIHtcbiAgICAgICAgICAgIGNvbnN0IGV2ZW50ID0gQXJyYXkuaXNBcnJheShpdGVtKSA/IChpdGVtIClbMV0gOiB1bmRlZmluZWQ7XG5cbiAgICAgICAgICAgIGlmIChldmVudCkge1xuICAgICAgICAgICAgICBtZXRhZGF0YS5zdHJpcE1ldGFkYXRhRnJvbVN0YWNrRnJhbWVzKGV2ZW50KTtcbiAgICAgICAgICAgICAgaXRlbVsxXSA9IGV2ZW50O1xuICAgICAgICAgICAgfVxuICAgICAgICAgIH1cbiAgICAgICAgfSk7XG4gICAgICB9KTtcblxuICAgICAgY2xpZW50Lm9uKCdhcHBseUZyYW1lTWV0YWRhdGEnLCBldmVudCA9PiB7XG4gICAgICAgIC8vIE9ubHkgYXBwbHkgc3RhY2sgZnJhbWUgbWV0YWRhdGEgdG8gZXJyb3IgZXZlbnRzXG4gICAgICAgIGlmIChldmVudC50eXBlKSB7XG4gICAgICAgICAgcmV0dXJuO1xuICAgICAgICB9XG5cbiAgICAgICAgY29uc3Qgc3RhY2tQYXJzZXIgPSBjbGllbnQuZ2V0T3B0aW9ucygpLnN0YWNrUGFyc2VyO1xuICAgICAgICBtZXRhZGF0YS5hZGRNZXRhZGF0YVRvU3RhY2tGcmFtZXMoc3RhY2tQYXJzZXIsIGV2ZW50KTtcbiAgICAgIH0pO1xuICAgIH0sXG5cbiAgICBwcm9jZXNzRXZlbnQoZXZlbnQpIHtcbiAgICAgIGNvbnN0IGZyYW1lS2V5cyA9IGdldEJ1bmRsZUtleXNGb3JBbGxGcmFtZXNXaXRoRmlsZW5hbWVzKGV2ZW50KTtcblxuICAgICAgaWYgKGZyYW1lS2V5cykge1xuICAgICAgICBjb25zdCBhcnJheU1ldGhvZCA9XG4gICAgICAgICAgb3B0aW9ucy5iZWhhdmlvdXIgPT09ICdkcm9wLWVycm9yLWlmLWNvbnRhaW5zLXRoaXJkLXBhcnR5LWZyYW1lcycgfHxcbiAgICAgICAgICBvcHRpb25zLmJlaGF2aW91ciA9PT0gJ2FwcGx5LXRhZy1pZi1jb250YWlucy10aGlyZC1wYXJ0eS1mcmFtZXMnXG4gICAgICAgICAgICA/ICdzb21lJ1xuICAgICAgICAgICAgOiAnZXZlcnknO1xuXG4gICAgICAgIGNvbnN0IGJlaGF2aW91ckFwcGxpZXMgPSBmcmFtZUtleXNbYXJyYXlNZXRob2RdKGtleXMgPT4gIWtleXMuc29tZShrZXkgPT4gb3B0aW9ucy5maWx0ZXJLZXlzLmluY2x1ZGVzKGtleSkpKTtcblxuICAgICAgICBpZiAoYmVoYXZpb3VyQXBwbGllcykge1xuICAgICAgICAgIGNvbnN0IHNob3VsZERyb3AgPVxuICAgICAgICAgICAgb3B0aW9ucy5iZWhhdmlvdXIgPT09ICdkcm9wLWVycm9yLWlmLWNvbnRhaW5zLXRoaXJkLXBhcnR5LWZyYW1lcycgfHxcbiAgICAgICAgICAgIG9wdGlvbnMuYmVoYXZpb3VyID09PSAnZHJvcC1lcnJvci1pZi1leGNsdXNpdmVseS1jb250YWlucy10aGlyZC1wYXJ0eS1mcmFtZXMnO1xuICAgICAgICAgIGlmIChzaG91bGREcm9wKSB7XG4gICAgICAgICAgICByZXR1cm4gbnVsbDtcbiAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgZXZlbnQudGFncyA9IHtcbiAgICAgICAgICAgICAgLi4uZXZlbnQudGFncyxcbiAgICAgICAgICAgICAgdGhpcmRfcGFydHlfY29kZTogdHJ1ZSxcbiAgICAgICAgICAgIH07XG4gICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICB9XG5cbiAgICAgIHJldHVybiBldmVudDtcbiAgICB9LFxuICB9O1xufSk7XG5cbmZ1bmN0aW9uIGdldEJ1bmRsZUtleXNGb3JBbGxGcmFtZXNXaXRoRmlsZW5hbWVzKGV2ZW50KSB7XG4gIGNvbnN0IGZyYW1lcyA9IHN0YWNrdHJhY2UuZ2V0RnJhbWVzRnJvbUV2ZW50KGV2ZW50KTtcblxuICBpZiAoIWZyYW1lcykge1xuICAgIHJldHVybiB1bmRlZmluZWQ7XG4gIH1cblxuICByZXR1cm4gKFxuICAgIGZyYW1lc1xuICAgICAgLy8gRXhjbHVkZSBmcmFtZXMgd2l0aG91dCBhIGZpbGVuYW1lIHNpbmNlIHRoZXNlIGFyZSBsaWtlbHkgbmF0aXZlIGNvZGUgb3IgYnVpbHQtaW5zXG4gICAgICAuZmlsdGVyKGZyYW1lID0+ICEhZnJhbWUuZmlsZW5hbWUpXG4gICAgICAubWFwKGZyYW1lID0+IHtcbiAgICAgICAgaWYgKGZyYW1lLm1vZHVsZV9tZXRhZGF0YSkge1xuICAgICAgICAgIHJldHVybiBPYmplY3Qua2V5cyhmcmFtZS5tb2R1bGVfbWV0YWRhdGEpXG4gICAgICAgICAgICAuZmlsdGVyKGtleSA9PiBrZXkuc3RhcnRzV2l0aChCVU5ETEVSX1BMVUdJTl9BUFBfS0VZX1BSRUZJWCkpXG4gICAgICAgICAgICAubWFwKGtleSA9PiBrZXkuc2xpY2UoQlVORExFUl9QTFVHSU5fQVBQX0tFWV9QUkVGSVgubGVuZ3RoKSk7XG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuIFtdO1xuICAgICAgfSlcbiAgKTtcbn1cblxuY29uc3QgQlVORExFUl9QTFVHSU5fQVBQX0tFWV9QUkVGSVggPSAnX3NlbnRyeUJ1bmRsZXJQbHVnaW5BcHBLZXk6JztcblxuZXhwb3J0cy50aGlyZFBhcnR5RXJyb3JGaWx0ZXJJbnRlZ3JhdGlvbiA9IHRoaXJkUGFydHlFcnJvckZpbHRlckludGVncmF0aW9uO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9dGhpcmQtcGFydHktZXJyb3JzLWZpbHRlci5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/third-party-errors-filter.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/zoderrors.js":
/*!**************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/zoderrors.js ***!
  \**************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst integration = __webpack_require__(/*! ../integration.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integration.js\");\nconst is = __webpack_require__(/*! ../utils/is.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js\");\nconst string = __webpack_require__(/*! ../utils/string.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/string.js\");\n\nconst DEFAULT_LIMIT = 10;\nconst INTEGRATION_NAME = 'ZodErrors';\n\n/**\n * Simplified ZodIssue type definition\n */\n\nfunction originalExceptionIsZodError(originalException) {\n  return (\n    is.isError(originalException) &&\n    originalException.name === 'ZodError' &&\n    Array.isArray((originalException ).issues)\n  );\n}\n\n/**\n * Formats child objects or arrays to a string\n * that is preserved when sent to Sentry.\n *\n * Without this, we end up with something like this in Sentry:\n *\n * [\n *  [Object],\n *  [Object],\n *  [Object],\n *  [Object]\n * ]\n */\nfunction flattenIssue(issue) {\n  return {\n    ...issue,\n    path: 'path' in issue && Array.isArray(issue.path) ? issue.path.join('.') : undefined,\n    keys: 'keys' in issue ? JSON.stringify(issue.keys) : undefined,\n    unionErrors: 'unionErrors' in issue ? JSON.stringify(issue.unionErrors) : undefined,\n  };\n}\n\n/**\n * Takes ZodError issue path array and returns a flattened version as a string.\n * This makes it easier to display paths within a Sentry error message.\n *\n * Array indexes are normalized to reduce duplicate entries\n *\n * @param path ZodError issue path\n * @returns flattened path\n *\n * @example\n * flattenIssuePath([0, 'foo', 1, 'bar']) // -> '<array>.foo.<array>.bar'\n */\nfunction flattenIssuePath(path) {\n  return path\n    .map(p => {\n      if (typeof p === 'number') {\n        return '<array>';\n      } else {\n        return p;\n      }\n    })\n    .join('.');\n}\n\n/**\n * Zod error message is a stringified version of ZodError.issues\n * This doesn't display well in the Sentry UI. Replace it with something shorter.\n */\nfunction formatIssueMessage(zodError) {\n  const errorKeyMap = new Set();\n  for (const iss of zodError.issues) {\n    const issuePath = flattenIssuePath(iss.path);\n    if (issuePath.length > 0) {\n      errorKeyMap.add(issuePath);\n    }\n  }\n\n  const errorKeys = Array.from(errorKeyMap);\n  if (errorKeys.length === 0) {\n    // If there are no keys, then we're likely validating the root\n    // variable rather than a key within an object. This attempts\n    // to extract what type it was that failed to validate.\n    // For example, z.string().parse(123) would return \"string\" here.\n    let rootExpectedType = 'variable';\n    if (zodError.issues.length > 0) {\n      const iss = zodError.issues[0];\n      if (iss !== undefined && 'expected' in iss && typeof iss.expected === 'string') {\n        rootExpectedType = iss.expected;\n      }\n    }\n    return `Failed to validate ${rootExpectedType}`;\n  }\n  return `Failed to validate keys: ${string.truncate(errorKeys.join(', '), 100)}`;\n}\n\n/**\n * Applies ZodError issues to an event extra and replaces the error message\n */\nfunction applyZodErrorsToEvent(\n  limit,\n  saveZodIssuesAsAttachment = false,\n  event,\n  hint,\n) {\n  if (\n    !event.exception?.values ||\n    !hint.originalException ||\n    !originalExceptionIsZodError(hint.originalException) ||\n    hint.originalException.issues.length === 0\n  ) {\n    return event;\n  }\n\n  try {\n    const issuesToFlatten = saveZodIssuesAsAttachment\n      ? hint.originalException.issues\n      : hint.originalException.issues.slice(0, limit);\n    const flattenedIssues = issuesToFlatten.map(flattenIssue);\n\n    if (saveZodIssuesAsAttachment) {\n      // Sometimes having the full error details can be helpful.\n      // Attachments have much higher limits, so we can include the full list of issues.\n      if (!Array.isArray(hint.attachments)) {\n        hint.attachments = [];\n      }\n      hint.attachments.push({\n        filename: 'zod_issues.json',\n        data: JSON.stringify({\n          issues: flattenedIssues,\n        }),\n      });\n    }\n\n    return {\n      ...event,\n      exception: {\n        ...event.exception,\n        values: [\n          {\n            ...event.exception.values[0],\n            value: formatIssueMessage(hint.originalException),\n          },\n          ...event.exception.values.slice(1),\n        ],\n      },\n      extra: {\n        ...event.extra,\n        'zoderror.issues': flattenedIssues.slice(0, limit),\n      },\n    };\n  } catch (e) {\n    // Hopefully we never throw errors here, but record it\n    // with the event just in case.\n    return {\n      ...event,\n      extra: {\n        ...event.extra,\n        'zoderrors sentry integration parse error': {\n          message: 'an exception was thrown while processing ZodError within applyZodErrorsToEvent()',\n          error: e instanceof Error ? `${e.name}: ${e.message}\\n${e.stack}` : 'unknown',\n        },\n      },\n    };\n  }\n}\n\nconst _zodErrorsIntegration = ((options = {}) => {\n  const limit = options.limit ?? DEFAULT_LIMIT;\n\n  return {\n    name: INTEGRATION_NAME,\n    processEvent(originalEvent, hint) {\n      const processedEvent = applyZodErrorsToEvent(limit, options.saveZodIssuesAsAttachment, originalEvent, hint);\n      return processedEvent;\n    },\n  };\n}) ;\n\n/**\n * Sentry integration to process Zod errors, making them easier to work with in Sentry.\n */\nconst zodErrorsIntegration = integration.defineIntegration(_zodErrorsIntegration);\n\nexports.applyZodErrorsToEvent = applyZodErrorsToEvent;\nexports.flattenIssue = flattenIssue;\nexports.flattenIssuePath = flattenIssuePath;\nexports.formatIssueMessage = formatIssueMessage;\nexports.zodErrorsIntegration = zodErrorsIntegration;\n//# sourceMappingURL=zoderrors.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvaW50ZWdyYXRpb25zL3pvZGVycm9ycy5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxvQkFBb0IsbUJBQU8sQ0FBQyxtSUFBbUI7QUFDL0MsV0FBVyxtQkFBTyxDQUFDLDZIQUFnQjtBQUNuQyxlQUFlLG1CQUFPLENBQUMscUlBQW9COztBQUUzQztBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFFBQVE7QUFDUjtBQUNBO0FBQ0EsS0FBSztBQUNMO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsaUNBQWlDLGlCQUFpQjtBQUNsRDtBQUNBLHFDQUFxQywyQ0FBMkM7QUFDaEY7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsU0FBUztBQUNULE9BQU87QUFDUDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsV0FBVztBQUNYO0FBQ0E7QUFDQSxPQUFPO0FBQ1A7QUFDQTtBQUNBO0FBQ0EsT0FBTztBQUNQO0FBQ0EsSUFBSTtBQUNKO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSx5Q0FBeUMsT0FBTyxJQUFJLFVBQVUsSUFBSSxRQUFRO0FBQzFFLFNBQVM7QUFDVCxPQUFPO0FBQ1A7QUFDQTtBQUNBOztBQUVBLDRDQUE0QztBQUM1Qzs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsS0FBSztBQUNMO0FBQ0EsQ0FBQzs7QUFFRDtBQUNBO0FBQ0E7QUFDQTs7QUFFQSw2QkFBNkI7QUFDN0Isb0JBQW9CO0FBQ3BCLHdCQUF3QjtBQUN4QiwwQkFBMEI7QUFDMUIsNEJBQTRCO0FBQzVCIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvaW50ZWdyYXRpb25zL3pvZGVycm9ycy5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgaW50ZWdyYXRpb24gPSByZXF1aXJlKCcuLi9pbnRlZ3JhdGlvbi5qcycpO1xuY29uc3QgaXMgPSByZXF1aXJlKCcuLi91dGlscy9pcy5qcycpO1xuY29uc3Qgc3RyaW5nID0gcmVxdWlyZSgnLi4vdXRpbHMvc3RyaW5nLmpzJyk7XG5cbmNvbnN0IERFRkFVTFRfTElNSVQgPSAxMDtcbmNvbnN0IElOVEVHUkFUSU9OX05BTUUgPSAnWm9kRXJyb3JzJztcblxuLyoqXG4gKiBTaW1wbGlmaWVkIFpvZElzc3VlIHR5cGUgZGVmaW5pdGlvblxuICovXG5cbmZ1bmN0aW9uIG9yaWdpbmFsRXhjZXB0aW9uSXNab2RFcnJvcihvcmlnaW5hbEV4Y2VwdGlvbikge1xuICByZXR1cm4gKFxuICAgIGlzLmlzRXJyb3Iob3JpZ2luYWxFeGNlcHRpb24pICYmXG4gICAgb3JpZ2luYWxFeGNlcHRpb24ubmFtZSA9PT0gJ1pvZEVycm9yJyAmJlxuICAgIEFycmF5LmlzQXJyYXkoKG9yaWdpbmFsRXhjZXB0aW9uICkuaXNzdWVzKVxuICApO1xufVxuXG4vKipcbiAqIEZvcm1hdHMgY2hpbGQgb2JqZWN0cyBvciBhcnJheXMgdG8gYSBzdHJpbmdcbiAqIHRoYXQgaXMgcHJlc2VydmVkIHdoZW4gc2VudCB0byBTZW50cnkuXG4gKlxuICogV2l0aG91dCB0aGlzLCB3ZSBlbmQgdXAgd2l0aCBzb21ldGhpbmcgbGlrZSB0aGlzIGluIFNlbnRyeTpcbiAqXG4gKiBbXG4gKiAgW09iamVjdF0sXG4gKiAgW09iamVjdF0sXG4gKiAgW09iamVjdF0sXG4gKiAgW09iamVjdF1cbiAqIF1cbiAqL1xuZnVuY3Rpb24gZmxhdHRlbklzc3VlKGlzc3VlKSB7XG4gIHJldHVybiB7XG4gICAgLi4uaXNzdWUsXG4gICAgcGF0aDogJ3BhdGgnIGluIGlzc3VlICYmIEFycmF5LmlzQXJyYXkoaXNzdWUucGF0aCkgPyBpc3N1ZS5wYXRoLmpvaW4oJy4nKSA6IHVuZGVmaW5lZCxcbiAgICBrZXlzOiAna2V5cycgaW4gaXNzdWUgPyBKU09OLnN0cmluZ2lmeShpc3N1ZS5rZXlzKSA6IHVuZGVmaW5lZCxcbiAgICB1bmlvbkVycm9yczogJ3VuaW9uRXJyb3JzJyBpbiBpc3N1ZSA/IEpTT04uc3RyaW5naWZ5KGlzc3VlLnVuaW9uRXJyb3JzKSA6IHVuZGVmaW5lZCxcbiAgfTtcbn1cblxuLyoqXG4gKiBUYWtlcyBab2RFcnJvciBpc3N1ZSBwYXRoIGFycmF5IGFuZCByZXR1cm5zIGEgZmxhdHRlbmVkIHZlcnNpb24gYXMgYSBzdHJpbmcuXG4gKiBUaGlzIG1ha2VzIGl0IGVhc2llciB0byBkaXNwbGF5IHBhdGhzIHdpdGhpbiBhIFNlbnRyeSBlcnJvciBtZXNzYWdlLlxuICpcbiAqIEFycmF5IGluZGV4ZXMgYXJlIG5vcm1hbGl6ZWQgdG8gcmVkdWNlIGR1cGxpY2F0ZSBlbnRyaWVzXG4gKlxuICogQHBhcmFtIHBhdGggWm9kRXJyb3IgaXNzdWUgcGF0aFxuICogQHJldHVybnMgZmxhdHRlbmVkIHBhdGhcbiAqXG4gKiBAZXhhbXBsZVxuICogZmxhdHRlbklzc3VlUGF0aChbMCwgJ2ZvbycsIDEsICdiYXInXSkgLy8gLT4gJzxhcnJheT4uZm9vLjxhcnJheT4uYmFyJ1xuICovXG5mdW5jdGlvbiBmbGF0dGVuSXNzdWVQYXRoKHBhdGgpIHtcbiAgcmV0dXJuIHBhdGhcbiAgICAubWFwKHAgPT4ge1xuICAgICAgaWYgKHR5cGVvZiBwID09PSAnbnVtYmVyJykge1xuICAgICAgICByZXR1cm4gJzxhcnJheT4nO1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgcmV0dXJuIHA7XG4gICAgICB9XG4gICAgfSlcbiAgICAuam9pbignLicpO1xufVxuXG4vKipcbiAqIFpvZCBlcnJvciBtZXNzYWdlIGlzIGEgc3RyaW5naWZpZWQgdmVyc2lvbiBvZiBab2RFcnJvci5pc3N1ZXNcbiAqIFRoaXMgZG9lc24ndCBkaXNwbGF5IHdlbGwgaW4gdGhlIFNlbnRyeSBVSS4gUmVwbGFjZSBpdCB3aXRoIHNvbWV0aGluZyBzaG9ydGVyLlxuICovXG5mdW5jdGlvbiBmb3JtYXRJc3N1ZU1lc3NhZ2Uoem9kRXJyb3IpIHtcbiAgY29uc3QgZXJyb3JLZXlNYXAgPSBuZXcgU2V0KCk7XG4gIGZvciAoY29uc3QgaXNzIG9mIHpvZEVycm9yLmlzc3Vlcykge1xuICAgIGNvbnN0IGlzc3VlUGF0aCA9IGZsYXR0ZW5Jc3N1ZVBhdGgoaXNzLnBhdGgpO1xuICAgIGlmIChpc3N1ZVBhdGgubGVuZ3RoID4gMCkge1xuICAgICAgZXJyb3JLZXlNYXAuYWRkKGlzc3VlUGF0aCk7XG4gICAgfVxuICB9XG5cbiAgY29uc3QgZXJyb3JLZXlzID0gQXJyYXkuZnJvbShlcnJvcktleU1hcCk7XG4gIGlmIChlcnJvcktleXMubGVuZ3RoID09PSAwKSB7XG4gICAgLy8gSWYgdGhlcmUgYXJlIG5vIGtleXMsIHRoZW4gd2UncmUgbGlrZWx5IHZhbGlkYXRpbmcgdGhlIHJvb3RcbiAgICAvLyB2YXJpYWJsZSByYXRoZXIgdGhhbiBhIGtleSB3aXRoaW4gYW4gb2JqZWN0LiBUaGlzIGF0dGVtcHRzXG4gICAgLy8gdG8gZXh0cmFjdCB3aGF0IHR5cGUgaXQgd2FzIHRoYXQgZmFpbGVkIHRvIHZhbGlkYXRlLlxuICAgIC8vIEZvciBleGFtcGxlLCB6LnN0cmluZygpLnBhcnNlKDEyMykgd291bGQgcmV0dXJuIFwic3RyaW5nXCIgaGVyZS5cbiAgICBsZXQgcm9vdEV4cGVjdGVkVHlwZSA9ICd2YXJpYWJsZSc7XG4gICAgaWYgKHpvZEVycm9yLmlzc3Vlcy5sZW5ndGggPiAwKSB7XG4gICAgICBjb25zdCBpc3MgPSB6b2RFcnJvci5pc3N1ZXNbMF07XG4gICAgICBpZiAoaXNzICE9PSB1bmRlZmluZWQgJiYgJ2V4cGVjdGVkJyBpbiBpc3MgJiYgdHlwZW9mIGlzcy5leHBlY3RlZCA9PT0gJ3N0cmluZycpIHtcbiAgICAgICAgcm9vdEV4cGVjdGVkVHlwZSA9IGlzcy5leHBlY3RlZDtcbiAgICAgIH1cbiAgICB9XG4gICAgcmV0dXJuIGBGYWlsZWQgdG8gdmFsaWRhdGUgJHtyb290RXhwZWN0ZWRUeXBlfWA7XG4gIH1cbiAgcmV0dXJuIGBGYWlsZWQgdG8gdmFsaWRhdGUga2V5czogJHtzdHJpbmcudHJ1bmNhdGUoZXJyb3JLZXlzLmpvaW4oJywgJyksIDEwMCl9YDtcbn1cblxuLyoqXG4gKiBBcHBsaWVzIFpvZEVycm9yIGlzc3VlcyB0byBhbiBldmVudCBleHRyYSBhbmQgcmVwbGFjZXMgdGhlIGVycm9yIG1lc3NhZ2VcbiAqL1xuZnVuY3Rpb24gYXBwbHlab2RFcnJvcnNUb0V2ZW50KFxuICBsaW1pdCxcbiAgc2F2ZVpvZElzc3Vlc0FzQXR0YWNobWVudCA9IGZhbHNlLFxuICBldmVudCxcbiAgaGludCxcbikge1xuICBpZiAoXG4gICAgIWV2ZW50LmV4Y2VwdGlvbj8udmFsdWVzIHx8XG4gICAgIWhpbnQub3JpZ2luYWxFeGNlcHRpb24gfHxcbiAgICAhb3JpZ2luYWxFeGNlcHRpb25Jc1pvZEVycm9yKGhpbnQub3JpZ2luYWxFeGNlcHRpb24pIHx8XG4gICAgaGludC5vcmlnaW5hbEV4Y2VwdGlvbi5pc3N1ZXMubGVuZ3RoID09PSAwXG4gICkge1xuICAgIHJldHVybiBldmVudDtcbiAgfVxuXG4gIHRyeSB7XG4gICAgY29uc3QgaXNzdWVzVG9GbGF0dGVuID0gc2F2ZVpvZElzc3Vlc0FzQXR0YWNobWVudFxuICAgICAgPyBoaW50Lm9yaWdpbmFsRXhjZXB0aW9uLmlzc3Vlc1xuICAgICAgOiBoaW50Lm9yaWdpbmFsRXhjZXB0aW9uLmlzc3Vlcy5zbGljZSgwLCBsaW1pdCk7XG4gICAgY29uc3QgZmxhdHRlbmVkSXNzdWVzID0gaXNzdWVzVG9GbGF0dGVuLm1hcChmbGF0dGVuSXNzdWUpO1xuXG4gICAgaWYgKHNhdmVab2RJc3N1ZXNBc0F0dGFjaG1lbnQpIHtcbiAgICAgIC8vIFNvbWV0aW1lcyBoYXZpbmcgdGhlIGZ1bGwgZXJyb3IgZGV0YWlscyBjYW4gYmUgaGVscGZ1bC5cbiAgICAgIC8vIEF0dGFjaG1lbnRzIGhhdmUgbXVjaCBoaWdoZXIgbGltaXRzLCBzbyB3ZSBjYW4gaW5jbHVkZSB0aGUgZnVsbCBsaXN0IG9mIGlzc3Vlcy5cbiAgICAgIGlmICghQXJyYXkuaXNBcnJheShoaW50LmF0dGFjaG1lbnRzKSkge1xuICAgICAgICBoaW50LmF0dGFjaG1lbnRzID0gW107XG4gICAgICB9XG4gICAgICBoaW50LmF0dGFjaG1lbnRzLnB1c2goe1xuICAgICAgICBmaWxlbmFtZTogJ3pvZF9pc3N1ZXMuanNvbicsXG4gICAgICAgIGRhdGE6IEpTT04uc3RyaW5naWZ5KHtcbiAgICAgICAgICBpc3N1ZXM6IGZsYXR0ZW5lZElzc3VlcyxcbiAgICAgICAgfSksXG4gICAgICB9KTtcbiAgICB9XG5cbiAgICByZXR1cm4ge1xuICAgICAgLi4uZXZlbnQsXG4gICAgICBleGNlcHRpb246IHtcbiAgICAgICAgLi4uZXZlbnQuZXhjZXB0aW9uLFxuICAgICAgICB2YWx1ZXM6IFtcbiAgICAgICAgICB7XG4gICAgICAgICAgICAuLi5ldmVudC5leGNlcHRpb24udmFsdWVzWzBdLFxuICAgICAgICAgICAgdmFsdWU6IGZvcm1hdElzc3VlTWVzc2FnZShoaW50Lm9yaWdpbmFsRXhjZXB0aW9uKSxcbiAgICAgICAgICB9LFxuICAgICAgICAgIC4uLmV2ZW50LmV4Y2VwdGlvbi52YWx1ZXMuc2xpY2UoMSksXG4gICAgICAgIF0sXG4gICAgICB9LFxuICAgICAgZXh0cmE6IHtcbiAgICAgICAgLi4uZXZlbnQuZXh0cmEsXG4gICAgICAgICd6b2RlcnJvci5pc3N1ZXMnOiBmbGF0dGVuZWRJc3N1ZXMuc2xpY2UoMCwgbGltaXQpLFxuICAgICAgfSxcbiAgICB9O1xuICB9IGNhdGNoIChlKSB7XG4gICAgLy8gSG9wZWZ1bGx5IHdlIG5ldmVyIHRocm93IGVycm9ycyBoZXJlLCBidXQgcmVjb3JkIGl0XG4gICAgLy8gd2l0aCB0aGUgZXZlbnQganVzdCBpbiBjYXNlLlxuICAgIHJldHVybiB7XG4gICAgICAuLi5ldmVudCxcbiAgICAgIGV4dHJhOiB7XG4gICAgICAgIC4uLmV2ZW50LmV4dHJhLFxuICAgICAgICAnem9kZXJyb3JzIHNlbnRyeSBpbnRlZ3JhdGlvbiBwYXJzZSBlcnJvcic6IHtcbiAgICAgICAgICBtZXNzYWdlOiAnYW4gZXhjZXB0aW9uIHdhcyB0aHJvd24gd2hpbGUgcHJvY2Vzc2luZyBab2RFcnJvciB3aXRoaW4gYXBwbHlab2RFcnJvcnNUb0V2ZW50KCknLFxuICAgICAgICAgIGVycm9yOiBlIGluc3RhbmNlb2YgRXJyb3IgPyBgJHtlLm5hbWV9OiAke2UubWVzc2FnZX1cXG4ke2Uuc3RhY2t9YCA6ICd1bmtub3duJyxcbiAgICAgICAgfSxcbiAgICAgIH0sXG4gICAgfTtcbiAgfVxufVxuXG5jb25zdCBfem9kRXJyb3JzSW50ZWdyYXRpb24gPSAoKG9wdGlvbnMgPSB7fSkgPT4ge1xuICBjb25zdCBsaW1pdCA9IG9wdGlvbnMubGltaXQgPz8gREVGQVVMVF9MSU1JVDtcblxuICByZXR1cm4ge1xuICAgIG5hbWU6IElOVEVHUkFUSU9OX05BTUUsXG4gICAgcHJvY2Vzc0V2ZW50KG9yaWdpbmFsRXZlbnQsIGhpbnQpIHtcbiAgICAgIGNvbnN0IHByb2Nlc3NlZEV2ZW50ID0gYXBwbHlab2RFcnJvcnNUb0V2ZW50KGxpbWl0LCBvcHRpb25zLnNhdmVab2RJc3N1ZXNBc0F0dGFjaG1lbnQsIG9yaWdpbmFsRXZlbnQsIGhpbnQpO1xuICAgICAgcmV0dXJuIHByb2Nlc3NlZEV2ZW50O1xuICAgIH0sXG4gIH07XG59KSA7XG5cbi8qKlxuICogU2VudHJ5IGludGVncmF0aW9uIHRvIHByb2Nlc3MgWm9kIGVycm9ycywgbWFraW5nIHRoZW0gZWFzaWVyIHRvIHdvcmsgd2l0aCBpbiBTZW50cnkuXG4gKi9cbmNvbnN0IHpvZEVycm9yc0ludGVncmF0aW9uID0gaW50ZWdyYXRpb24uZGVmaW5lSW50ZWdyYXRpb24oX3pvZEVycm9yc0ludGVncmF0aW9uKTtcblxuZXhwb3J0cy5hcHBseVpvZEVycm9yc1RvRXZlbnQgPSBhcHBseVpvZEVycm9yc1RvRXZlbnQ7XG5leHBvcnRzLmZsYXR0ZW5Jc3N1ZSA9IGZsYXR0ZW5Jc3N1ZTtcbmV4cG9ydHMuZmxhdHRlbklzc3VlUGF0aCA9IGZsYXR0ZW5Jc3N1ZVBhdGg7XG5leHBvcnRzLmZvcm1hdElzc3VlTWVzc2FnZSA9IGZvcm1hdElzc3VlTWVzc2FnZTtcbmV4cG9ydHMuem9kRXJyb3JzSW50ZWdyYXRpb24gPSB6b2RFcnJvcnNJbnRlZ3JhdGlvbjtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPXpvZGVycm9ycy5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/zoderrors.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/logs/console-integration.js":
/*!****************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/logs/console-integration.js ***!
  \****************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst currentScopes = __webpack_require__(/*! ../currentScopes.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst debugBuild = __webpack_require__(/*! ../debug-build.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst console = __webpack_require__(/*! ../instrument/console.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/console.js\");\nconst integration = __webpack_require__(/*! ../integration.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integration.js\");\nconst semanticAttributes = __webpack_require__(/*! ../semanticAttributes.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/semanticAttributes.js\");\nconst debugLogger = __webpack_require__(/*! ../utils/debug-logger.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst is = __webpack_require__(/*! ../utils/is.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js\");\nconst normalize = __webpack_require__(/*! ../utils/normalize.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/normalize.js\");\nconst worldwide = __webpack_require__(/*! ../utils/worldwide.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/worldwide.js\");\nconst exports$1 = __webpack_require__(/*! ./exports.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/logs/exports.js\");\n\nconst INTEGRATION_NAME = 'ConsoleLogs';\n\nconst DEFAULT_ATTRIBUTES = {\n  [semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_ORIGIN]: 'auto.console.logging',\n};\n\nconst _consoleLoggingIntegration = ((options = {}) => {\n  const levels = options.levels || debugLogger.CONSOLE_LEVELS;\n\n  return {\n    name: INTEGRATION_NAME,\n    setup(client) {\n      const { enableLogs, _experiments, normalizeDepth = 3, normalizeMaxBreadth = 1000 } = client.getOptions();\n      // eslint-disable-next-line deprecation/deprecation\n      const shouldEnableLogs = enableLogs ?? _experiments?.enableLogs;\n      if (!shouldEnableLogs) {\n        debugBuild.DEBUG_BUILD && debugLogger.debug.warn('`enableLogs` is not enabled, ConsoleLogs integration disabled');\n        return;\n      }\n\n      console.addConsoleInstrumentationHandler(({ args, level }) => {\n        if (currentScopes.getClient() !== client || !levels.includes(level)) {\n          return;\n        }\n\n        if (level === 'assert') {\n          if (!args[0]) {\n            const followingArgs = args.slice(1);\n            const assertionMessage =\n              followingArgs.length > 0\n                ? `Assertion failed: ${formatConsoleArgs(followingArgs, normalizeDepth, normalizeMaxBreadth)}`\n                : 'Assertion failed';\n            exports$1._INTERNAL_captureLog({ level: 'error', message: assertionMessage, attributes: DEFAULT_ATTRIBUTES });\n          }\n          return;\n        }\n\n        const isLevelLog = level === 'log';\n        exports$1._INTERNAL_captureLog({\n          level: isLevelLog ? 'info' : level,\n          message: formatConsoleArgs(args, normalizeDepth, normalizeMaxBreadth),\n          severityNumber: isLevelLog ? 10 : undefined,\n          attributes: DEFAULT_ATTRIBUTES,\n        });\n      });\n    },\n  };\n}) ;\n\n/**\n * Captures calls to the `console` API as logs in Sentry. Requires the `enableLogs` option to be enabled.\n *\n * @experimental This feature is experimental and may be changed or removed in future versions.\n *\n * By default the integration instruments `console.debug`, `console.info`, `console.warn`, `console.error`,\n * `console.log`, `console.trace`, and `console.assert`. You can use the `levels` option to customize which\n * levels are captured.\n *\n * @example\n *\n * ```ts\n * import * as Sentry from '@sentry/browser';\n *\n * Sentry.init({\n *   enableLogs: true,\n *   integrations: [Sentry.consoleLoggingIntegration({ levels: ['error', 'warn'] })],\n * });\n * ```\n */\nconst consoleLoggingIntegration = integration.defineIntegration(_consoleLoggingIntegration);\n\nfunction formatConsoleArgs(values, normalizeDepth, normalizeMaxBreadth) {\n  return 'util' in worldwide.GLOBAL_OBJ && typeof (worldwide.GLOBAL_OBJ ).util.format === 'function'\n    ? (worldwide.GLOBAL_OBJ ).util.format(...values)\n    : safeJoinConsoleArgs(values, normalizeDepth, normalizeMaxBreadth);\n}\n\nfunction safeJoinConsoleArgs(values, normalizeDepth, normalizeMaxBreadth) {\n  return values\n    .map(value =>\n      is.isPrimitive(value) ? String(value) : JSON.stringify(normalize.normalize(value, normalizeDepth, normalizeMaxBreadth)),\n    )\n    .join(' ');\n}\n\nexports.consoleLoggingIntegration = consoleLoggingIntegration;\n//# sourceMappingURL=console-integration.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvbG9ncy9jb25zb2xlLWludGVncmF0aW9uLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLHNCQUFzQixtQkFBTyxDQUFDLHVJQUFxQjtBQUNuRCxtQkFBbUIsbUJBQU8sQ0FBQyxtSUFBbUI7QUFDOUMsZ0JBQWdCLG1CQUFPLENBQUMsaUpBQTBCO0FBQ2xELG9CQUFvQixtQkFBTyxDQUFDLG1JQUFtQjtBQUMvQywyQkFBMkIsbUJBQU8sQ0FBQyxpSkFBMEI7QUFDN0Qsb0JBQW9CLG1CQUFPLENBQUMsaUpBQTBCO0FBQ3RELFdBQVcsbUJBQU8sQ0FBQyw2SEFBZ0I7QUFDbkMsa0JBQWtCLG1CQUFPLENBQUMsMklBQXVCO0FBQ2pELGtCQUFrQixtQkFBTyxDQUFDLDJJQUF1QjtBQUNqRCxrQkFBa0IsbUJBQU8sQ0FBQywrSEFBYzs7QUFFeEM7O0FBRUE7QUFDQTtBQUNBOztBQUVBLGlEQUFpRDtBQUNqRDs7QUFFQTtBQUNBO0FBQ0E7QUFDQSxjQUFjLDJFQUEyRTtBQUN6RjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsa0RBQWtELGFBQWE7QUFDL0Q7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSx1Q0FBdUMsc0VBQXNFO0FBQzdHO0FBQ0EsNkNBQTZDLDJFQUEyRTtBQUN4SDtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsU0FBUztBQUNULE9BQU87QUFDUCxLQUFLO0FBQ0w7QUFDQSxDQUFDOztBQUVEO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsdURBQXVELDJCQUEyQjtBQUNsRixJQUFJO0FBQ0o7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsaUNBQWlDO0FBQ2pDIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvbG9ncy9jb25zb2xlLWludGVncmF0aW9uLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBjdXJyZW50U2NvcGVzID0gcmVxdWlyZSgnLi4vY3VycmVudFNjb3Blcy5qcycpO1xuY29uc3QgZGVidWdCdWlsZCA9IHJlcXVpcmUoJy4uL2RlYnVnLWJ1aWxkLmpzJyk7XG5jb25zdCBjb25zb2xlID0gcmVxdWlyZSgnLi4vaW5zdHJ1bWVudC9jb25zb2xlLmpzJyk7XG5jb25zdCBpbnRlZ3JhdGlvbiA9IHJlcXVpcmUoJy4uL2ludGVncmF0aW9uLmpzJyk7XG5jb25zdCBzZW1hbnRpY0F0dHJpYnV0ZXMgPSByZXF1aXJlKCcuLi9zZW1hbnRpY0F0dHJpYnV0ZXMuanMnKTtcbmNvbnN0IGRlYnVnTG9nZ2VyID0gcmVxdWlyZSgnLi4vdXRpbHMvZGVidWctbG9nZ2VyLmpzJyk7XG5jb25zdCBpcyA9IHJlcXVpcmUoJy4uL3V0aWxzL2lzLmpzJyk7XG5jb25zdCBub3JtYWxpemUgPSByZXF1aXJlKCcuLi91dGlscy9ub3JtYWxpemUuanMnKTtcbmNvbnN0IHdvcmxkd2lkZSA9IHJlcXVpcmUoJy4uL3V0aWxzL3dvcmxkd2lkZS5qcycpO1xuY29uc3QgZXhwb3J0cyQxID0gcmVxdWlyZSgnLi9leHBvcnRzLmpzJyk7XG5cbmNvbnN0IElOVEVHUkFUSU9OX05BTUUgPSAnQ29uc29sZUxvZ3MnO1xuXG5jb25zdCBERUZBVUxUX0FUVFJJQlVURVMgPSB7XG4gIFtzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9PUklHSU5dOiAnYXV0by5jb25zb2xlLmxvZ2dpbmcnLFxufTtcblxuY29uc3QgX2NvbnNvbGVMb2dnaW5nSW50ZWdyYXRpb24gPSAoKG9wdGlvbnMgPSB7fSkgPT4ge1xuICBjb25zdCBsZXZlbHMgPSBvcHRpb25zLmxldmVscyB8fCBkZWJ1Z0xvZ2dlci5DT05TT0xFX0xFVkVMUztcblxuICByZXR1cm4ge1xuICAgIG5hbWU6IElOVEVHUkFUSU9OX05BTUUsXG4gICAgc2V0dXAoY2xpZW50KSB7XG4gICAgICBjb25zdCB7IGVuYWJsZUxvZ3MsIF9leHBlcmltZW50cywgbm9ybWFsaXplRGVwdGggPSAzLCBub3JtYWxpemVNYXhCcmVhZHRoID0gMTAwMCB9ID0gY2xpZW50LmdldE9wdGlvbnMoKTtcbiAgICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBkZXByZWNhdGlvbi9kZXByZWNhdGlvblxuICAgICAgY29uc3Qgc2hvdWxkRW5hYmxlTG9ncyA9IGVuYWJsZUxvZ3MgPz8gX2V4cGVyaW1lbnRzPy5lbmFibGVMb2dzO1xuICAgICAgaWYgKCFzaG91bGRFbmFibGVMb2dzKSB7XG4gICAgICAgIGRlYnVnQnVpbGQuREVCVUdfQlVJTEQgJiYgZGVidWdMb2dnZXIuZGVidWcud2FybignYGVuYWJsZUxvZ3NgIGlzIG5vdCBlbmFibGVkLCBDb25zb2xlTG9ncyBpbnRlZ3JhdGlvbiBkaXNhYmxlZCcpO1xuICAgICAgICByZXR1cm47XG4gICAgICB9XG5cbiAgICAgIGNvbnNvbGUuYWRkQ29uc29sZUluc3RydW1lbnRhdGlvbkhhbmRsZXIoKHsgYXJncywgbGV2ZWwgfSkgPT4ge1xuICAgICAgICBpZiAoY3VycmVudFNjb3Blcy5nZXRDbGllbnQoKSAhPT0gY2xpZW50IHx8ICFsZXZlbHMuaW5jbHVkZXMobGV2ZWwpKSB7XG4gICAgICAgICAgcmV0dXJuO1xuICAgICAgICB9XG5cbiAgICAgICAgaWYgKGxldmVsID09PSAnYXNzZXJ0Jykge1xuICAgICAgICAgIGlmICghYXJnc1swXSkge1xuICAgICAgICAgICAgY29uc3QgZm9sbG93aW5nQXJncyA9IGFyZ3Muc2xpY2UoMSk7XG4gICAgICAgICAgICBjb25zdCBhc3NlcnRpb25NZXNzYWdlID1cbiAgICAgICAgICAgICAgZm9sbG93aW5nQXJncy5sZW5ndGggPiAwXG4gICAgICAgICAgICAgICAgPyBgQXNzZXJ0aW9uIGZhaWxlZDogJHtmb3JtYXRDb25zb2xlQXJncyhmb2xsb3dpbmdBcmdzLCBub3JtYWxpemVEZXB0aCwgbm9ybWFsaXplTWF4QnJlYWR0aCl9YFxuICAgICAgICAgICAgICAgIDogJ0Fzc2VydGlvbiBmYWlsZWQnO1xuICAgICAgICAgICAgZXhwb3J0cyQxLl9JTlRFUk5BTF9jYXB0dXJlTG9nKHsgbGV2ZWw6ICdlcnJvcicsIG1lc3NhZ2U6IGFzc2VydGlvbk1lc3NhZ2UsIGF0dHJpYnV0ZXM6IERFRkFVTFRfQVRUUklCVVRFUyB9KTtcbiAgICAgICAgICB9XG4gICAgICAgICAgcmV0dXJuO1xuICAgICAgICB9XG5cbiAgICAgICAgY29uc3QgaXNMZXZlbExvZyA9IGxldmVsID09PSAnbG9nJztcbiAgICAgICAgZXhwb3J0cyQxLl9JTlRFUk5BTF9jYXB0dXJlTG9nKHtcbiAgICAgICAgICBsZXZlbDogaXNMZXZlbExvZyA/ICdpbmZvJyA6IGxldmVsLFxuICAgICAgICAgIG1lc3NhZ2U6IGZvcm1hdENvbnNvbGVBcmdzKGFyZ3MsIG5vcm1hbGl6ZURlcHRoLCBub3JtYWxpemVNYXhCcmVhZHRoKSxcbiAgICAgICAgICBzZXZlcml0eU51bWJlcjogaXNMZXZlbExvZyA/IDEwIDogdW5kZWZpbmVkLFxuICAgICAgICAgIGF0dHJpYnV0ZXM6IERFRkFVTFRfQVRUUklCVVRFUyxcbiAgICAgICAgfSk7XG4gICAgICB9KTtcbiAgICB9LFxuICB9O1xufSkgO1xuXG4vKipcbiAqIENhcHR1cmVzIGNhbGxzIHRvIHRoZSBgY29uc29sZWAgQVBJIGFzIGxvZ3MgaW4gU2VudHJ5LiBSZXF1aXJlcyB0aGUgYGVuYWJsZUxvZ3NgIG9wdGlvbiB0byBiZSBlbmFibGVkLlxuICpcbiAqIEBleHBlcmltZW50YWwgVGhpcyBmZWF0dXJlIGlzIGV4cGVyaW1lbnRhbCBhbmQgbWF5IGJlIGNoYW5nZWQgb3IgcmVtb3ZlZCBpbiBmdXR1cmUgdmVyc2lvbnMuXG4gKlxuICogQnkgZGVmYXVsdCB0aGUgaW50ZWdyYXRpb24gaW5zdHJ1bWVudHMgYGNvbnNvbGUuZGVidWdgLCBgY29uc29sZS5pbmZvYCwgYGNvbnNvbGUud2FybmAsIGBjb25zb2xlLmVycm9yYCxcbiAqIGBjb25zb2xlLmxvZ2AsIGBjb25zb2xlLnRyYWNlYCwgYW5kIGBjb25zb2xlLmFzc2VydGAuIFlvdSBjYW4gdXNlIHRoZSBgbGV2ZWxzYCBvcHRpb24gdG8gY3VzdG9taXplIHdoaWNoXG4gKiBsZXZlbHMgYXJlIGNhcHR1cmVkLlxuICpcbiAqIEBleGFtcGxlXG4gKlxuICogYGBgdHNcbiAqIGltcG9ydCAqIGFzIFNlbnRyeSBmcm9tICdAc2VudHJ5L2Jyb3dzZXInO1xuICpcbiAqIFNlbnRyeS5pbml0KHtcbiAqICAgZW5hYmxlTG9nczogdHJ1ZSxcbiAqICAgaW50ZWdyYXRpb25zOiBbU2VudHJ5LmNvbnNvbGVMb2dnaW5nSW50ZWdyYXRpb24oeyBsZXZlbHM6IFsnZXJyb3InLCAnd2FybiddIH0pXSxcbiAqIH0pO1xuICogYGBgXG4gKi9cbmNvbnN0IGNvbnNvbGVMb2dnaW5nSW50ZWdyYXRpb24gPSBpbnRlZ3JhdGlvbi5kZWZpbmVJbnRlZ3JhdGlvbihfY29uc29sZUxvZ2dpbmdJbnRlZ3JhdGlvbik7XG5cbmZ1bmN0aW9uIGZvcm1hdENvbnNvbGVBcmdzKHZhbHVlcywgbm9ybWFsaXplRGVwdGgsIG5vcm1hbGl6ZU1heEJyZWFkdGgpIHtcbiAgcmV0dXJuICd1dGlsJyBpbiB3b3JsZHdpZGUuR0xPQkFMX09CSiAmJiB0eXBlb2YgKHdvcmxkd2lkZS5HTE9CQUxfT0JKICkudXRpbC5mb3JtYXQgPT09ICdmdW5jdGlvbidcbiAgICA/ICh3b3JsZHdpZGUuR0xPQkFMX09CSiApLnV0aWwuZm9ybWF0KC4uLnZhbHVlcylcbiAgICA6IHNhZmVKb2luQ29uc29sZUFyZ3ModmFsdWVzLCBub3JtYWxpemVEZXB0aCwgbm9ybWFsaXplTWF4QnJlYWR0aCk7XG59XG5cbmZ1bmN0aW9uIHNhZmVKb2luQ29uc29sZUFyZ3ModmFsdWVzLCBub3JtYWxpemVEZXB0aCwgbm9ybWFsaXplTWF4QnJlYWR0aCkge1xuICByZXR1cm4gdmFsdWVzXG4gICAgLm1hcCh2YWx1ZSA9PlxuICAgICAgaXMuaXNQcmltaXRpdmUodmFsdWUpID8gU3RyaW5nKHZhbHVlKSA6IEpTT04uc3RyaW5naWZ5KG5vcm1hbGl6ZS5ub3JtYWxpemUodmFsdWUsIG5vcm1hbGl6ZURlcHRoLCBub3JtYWxpemVNYXhCcmVhZHRoKSksXG4gICAgKVxuICAgIC5qb2luKCcgJyk7XG59XG5cbmV4cG9ydHMuY29uc29sZUxvZ2dpbmdJbnRlZ3JhdGlvbiA9IGNvbnNvbGVMb2dnaW5nSW50ZWdyYXRpb247XG4vLyMgc291cmNlTWFwcGluZ1VSTD1jb25zb2xlLWludGVncmF0aW9uLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/logs/console-integration.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/logs/constants.js":
/*!******************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/logs/constants.js ***!
  \******************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n/**\n * Maps a log severity level to a log severity number.\n *\n * @see LogSeverityLevel\n */\nconst SEVERITY_TEXT_TO_SEVERITY_NUMBER = {\n  trace: 1,\n  debug: 5,\n  info: 9,\n  warn: 13,\n  error: 17,\n  fatal: 21,\n};\n\nexports.SEVERITY_TEXT_TO_SEVERITY_NUMBER = SEVERITY_TEXT_TO_SEVERITY_NUMBER;\n//# sourceMappingURL=constants.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvbG9ncy9jb25zdGFudHMuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEU7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsd0NBQXdDO0FBQ3hDIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvbG9ncy9jb25zdGFudHMuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbi8qKlxuICogTWFwcyBhIGxvZyBzZXZlcml0eSBsZXZlbCB0byBhIGxvZyBzZXZlcml0eSBudW1iZXIuXG4gKlxuICogQHNlZSBMb2dTZXZlcml0eUxldmVsXG4gKi9cbmNvbnN0IFNFVkVSSVRZX1RFWFRfVE9fU0VWRVJJVFlfTlVNQkVSID0ge1xuICB0cmFjZTogMSxcbiAgZGVidWc6IDUsXG4gIGluZm86IDksXG4gIHdhcm46IDEzLFxuICBlcnJvcjogMTcsXG4gIGZhdGFsOiAyMSxcbn07XG5cbmV4cG9ydHMuU0VWRVJJVFlfVEVYVF9UT19TRVZFUklUWV9OVU1CRVIgPSBTRVZFUklUWV9URVhUX1RPX1NFVkVSSVRZX05VTUJFUjtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWNvbnN0YW50cy5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/logs/constants.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/logs/envelope.js":
/*!*****************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/logs/envelope.js ***!
  \*****************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst dsn = __webpack_require__(/*! ../utils/dsn.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/dsn.js\");\nconst envelope = __webpack_require__(/*! ../utils/envelope.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/envelope.js\");\n\n/**\n * Creates a log container envelope item for a list of logs.\n *\n * @param items - The logs to include in the envelope.\n * @returns The created log container envelope item.\n */\nfunction createLogContainerEnvelopeItem(items) {\n  return [\n    {\n      type: 'log',\n      item_count: items.length,\n      content_type: 'application/vnd.sentry.items.log+json',\n    },\n    {\n      items,\n    },\n  ];\n}\n\n/**\n * Creates an envelope for a list of logs.\n *\n * Logs from multiple traces can be included in the same envelope.\n *\n * @param logs - The logs to include in the envelope.\n * @param metadata - The metadata to include in the envelope.\n * @param tunnel - The tunnel to include in the envelope.\n * @param dsn - The DSN to include in the envelope.\n * @returns The created envelope.\n */\nfunction createLogEnvelope(\n  logs,\n  metadata,\n  tunnel,\n  dsn$1,\n) {\n  const headers = {};\n\n  if (metadata?.sdk) {\n    headers.sdk = {\n      name: metadata.sdk.name,\n      version: metadata.sdk.version,\n    };\n  }\n\n  if (!!tunnel && !!dsn$1) {\n    headers.dsn = dsn.dsnToString(dsn$1);\n  }\n\n  return envelope.createEnvelope(headers, [createLogContainerEnvelopeItem(logs)]);\n}\n\nexports.createLogContainerEnvelopeItem = createLogContainerEnvelopeItem;\nexports.createLogEnvelope = createLogEnvelope;\n//# sourceMappingURL=envelope.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvbG9ncy9lbnZlbG9wZS5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxZQUFZLG1CQUFPLENBQUMsK0hBQWlCO0FBQ3JDLGlCQUFpQixtQkFBTyxDQUFDLHlJQUFzQjs7QUFFL0M7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsS0FBSztBQUNMO0FBQ0E7QUFDQSxLQUFLO0FBQ0w7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBLHNDQUFzQztBQUN0Qyx5QkFBeUI7QUFDekIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9sb2dzL2VudmVsb3BlLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBkc24gPSByZXF1aXJlKCcuLi91dGlscy9kc24uanMnKTtcbmNvbnN0IGVudmVsb3BlID0gcmVxdWlyZSgnLi4vdXRpbHMvZW52ZWxvcGUuanMnKTtcblxuLyoqXG4gKiBDcmVhdGVzIGEgbG9nIGNvbnRhaW5lciBlbnZlbG9wZSBpdGVtIGZvciBhIGxpc3Qgb2YgbG9ncy5cbiAqXG4gKiBAcGFyYW0gaXRlbXMgLSBUaGUgbG9ncyB0byBpbmNsdWRlIGluIHRoZSBlbnZlbG9wZS5cbiAqIEByZXR1cm5zIFRoZSBjcmVhdGVkIGxvZyBjb250YWluZXIgZW52ZWxvcGUgaXRlbS5cbiAqL1xuZnVuY3Rpb24gY3JlYXRlTG9nQ29udGFpbmVyRW52ZWxvcGVJdGVtKGl0ZW1zKSB7XG4gIHJldHVybiBbXG4gICAge1xuICAgICAgdHlwZTogJ2xvZycsXG4gICAgICBpdGVtX2NvdW50OiBpdGVtcy5sZW5ndGgsXG4gICAgICBjb250ZW50X3R5cGU6ICdhcHBsaWNhdGlvbi92bmQuc2VudHJ5Lml0ZW1zLmxvZytqc29uJyxcbiAgICB9LFxuICAgIHtcbiAgICAgIGl0ZW1zLFxuICAgIH0sXG4gIF07XG59XG5cbi8qKlxuICogQ3JlYXRlcyBhbiBlbnZlbG9wZSBmb3IgYSBsaXN0IG9mIGxvZ3MuXG4gKlxuICogTG9ncyBmcm9tIG11bHRpcGxlIHRyYWNlcyBjYW4gYmUgaW5jbHVkZWQgaW4gdGhlIHNhbWUgZW52ZWxvcGUuXG4gKlxuICogQHBhcmFtIGxvZ3MgLSBUaGUgbG9ncyB0byBpbmNsdWRlIGluIHRoZSBlbnZlbG9wZS5cbiAqIEBwYXJhbSBtZXRhZGF0YSAtIFRoZSBtZXRhZGF0YSB0byBpbmNsdWRlIGluIHRoZSBlbnZlbG9wZS5cbiAqIEBwYXJhbSB0dW5uZWwgLSBUaGUgdHVubmVsIHRvIGluY2x1ZGUgaW4gdGhlIGVudmVsb3BlLlxuICogQHBhcmFtIGRzbiAtIFRoZSBEU04gdG8gaW5jbHVkZSBpbiB0aGUgZW52ZWxvcGUuXG4gKiBAcmV0dXJucyBUaGUgY3JlYXRlZCBlbnZlbG9wZS5cbiAqL1xuZnVuY3Rpb24gY3JlYXRlTG9nRW52ZWxvcGUoXG4gIGxvZ3MsXG4gIG1ldGFkYXRhLFxuICB0dW5uZWwsXG4gIGRzbiQxLFxuKSB7XG4gIGNvbnN0IGhlYWRlcnMgPSB7fTtcblxuICBpZiAobWV0YWRhdGE/LnNkaykge1xuICAgIGhlYWRlcnMuc2RrID0ge1xuICAgICAgbmFtZTogbWV0YWRhdGEuc2RrLm5hbWUsXG4gICAgICB2ZXJzaW9uOiBtZXRhZGF0YS5zZGsudmVyc2lvbixcbiAgICB9O1xuICB9XG5cbiAgaWYgKCEhdHVubmVsICYmICEhZHNuJDEpIHtcbiAgICBoZWFkZXJzLmRzbiA9IGRzbi5kc25Ub1N0cmluZyhkc24kMSk7XG4gIH1cblxuICByZXR1cm4gZW52ZWxvcGUuY3JlYXRlRW52ZWxvcGUoaGVhZGVycywgW2NyZWF0ZUxvZ0NvbnRhaW5lckVudmVsb3BlSXRlbShsb2dzKV0pO1xufVxuXG5leHBvcnRzLmNyZWF0ZUxvZ0NvbnRhaW5lckVudmVsb3BlSXRlbSA9IGNyZWF0ZUxvZ0NvbnRhaW5lckVudmVsb3BlSXRlbTtcbmV4cG9ydHMuY3JlYXRlTG9nRW52ZWxvcGUgPSBjcmVhdGVMb2dFbnZlbG9wZTtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWVudmVsb3BlLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/logs/envelope.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/logs/exports.js":
/*!****************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/logs/exports.js ***!
  \****************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst carrier = __webpack_require__(/*! ../carrier.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/carrier.js\");\nconst client = __webpack_require__(/*! ../client.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/client.js\");\nconst currentScopes = __webpack_require__(/*! ../currentScopes.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst debugBuild = __webpack_require__(/*! ../debug-build.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst applyScopeDataToEvent = __webpack_require__(/*! ../utils/applyScopeDataToEvent.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/applyScopeDataToEvent.js\");\nconst debugLogger = __webpack_require__(/*! ../utils/debug-logger.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst is = __webpack_require__(/*! ../utils/is.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js\");\nconst spanOnScope = __webpack_require__(/*! ../utils/spanOnScope.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanOnScope.js\");\nconst time = __webpack_require__(/*! ../utils/time.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/time.js\");\nconst constants = __webpack_require__(/*! ./constants.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/logs/constants.js\");\nconst envelope = __webpack_require__(/*! ./envelope.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/logs/envelope.js\");\n\nconst MAX_LOG_BUFFER_SIZE = 100;\n\n/**\n * Converts a log attribute to a serialized log attribute.\n *\n * @param key - The key of the log attribute.\n * @param value - The value of the log attribute.\n * @returns The serialized log attribute.\n */\nfunction logAttributeToSerializedLogAttribute(value) {\n  switch (typeof value) {\n    case 'number':\n      if (Number.isInteger(value)) {\n        return {\n          value,\n          type: 'integer',\n        };\n      }\n      return {\n        value,\n        type: 'double',\n      };\n    case 'boolean':\n      return {\n        value,\n        type: 'boolean',\n      };\n    case 'string':\n      return {\n        value,\n        type: 'string',\n      };\n    default: {\n      let stringValue = '';\n      try {\n        stringValue = JSON.stringify(value) ?? '';\n      } catch {\n        // Do nothing\n      }\n      return {\n        value: stringValue,\n        type: 'string',\n      };\n    }\n  }\n}\n\n/**\n * Sets a log attribute if the value exists and the attribute key is not already present.\n *\n * @param logAttributes - The log attributes object to modify.\n * @param key - The attribute key to set.\n * @param value - The value to set (only sets if truthy and key not present).\n * @param setEvenIfPresent - Whether to set the attribute if it is present. Defaults to true.\n */\nfunction setLogAttribute(\n  logAttributes,\n  key,\n  value,\n  setEvenIfPresent = true,\n) {\n  if (value && (!logAttributes[key] || setEvenIfPresent)) {\n    logAttributes[key] = value;\n  }\n}\n\n/**\n * Captures a serialized log event and adds it to the log buffer for the given client.\n *\n * @param client - A client. Uses the current client if not provided.\n * @param serializedLog - The serialized log event to capture.\n *\n * @experimental This method will experience breaking changes. This is not yet part of\n * the stable Sentry SDK API and can be changed or removed without warning.\n */\nfunction _INTERNAL_captureSerializedLog(client, serializedLog) {\n  const bufferMap = _getBufferMap();\n\n  const logBuffer = _INTERNAL_getLogBuffer(client);\n  if (logBuffer === undefined) {\n    bufferMap.set(client, [serializedLog]);\n  } else {\n    bufferMap.set(client, [...logBuffer, serializedLog]);\n    if (logBuffer.length >= MAX_LOG_BUFFER_SIZE) {\n      _INTERNAL_flushLogsBuffer(client, logBuffer);\n    }\n  }\n}\n\n/**\n * Captures a log event and sends it to Sentry.\n *\n * @param log - The log event to capture.\n * @param scope - A scope. Uses the current scope if not provided.\n * @param client - A client. Uses the current client if not provided.\n * @param captureSerializedLog - A function to capture the serialized log.\n *\n * @experimental This method will experience breaking changes. This is not yet part of\n * the stable Sentry SDK API and can be changed or removed without warning.\n */\nfunction _INTERNAL_captureLog(\n  beforeLog,\n  client$1 = currentScopes.getClient(),\n  currentScope = currentScopes.getCurrentScope(),\n  captureSerializedLog = _INTERNAL_captureSerializedLog,\n) {\n  if (!client$1) {\n    debugBuild.DEBUG_BUILD && debugLogger.debug.warn('No client available to capture log.');\n    return;\n  }\n\n  const { release, environment, enableLogs, beforeSendLog, _experiments } = client$1.getOptions();\n  // eslint-disable-next-line deprecation/deprecation\n  const shouldEnableLogs = enableLogs ?? _experiments?.enableLogs;\n  if (!shouldEnableLogs) {\n    debugBuild.DEBUG_BUILD && debugLogger.debug.warn('logging option not enabled, log will not be captured.');\n    return;\n  }\n  // eslint-disable-next-line deprecation/deprecation\n  const actualBeforeSendLog = beforeSendLog ?? _experiments?.beforeSendLog;\n\n  const [, traceContext] = client._getTraceInfoFromScope(client$1, currentScope);\n\n  const processedLogAttributes = {\n    ...beforeLog.attributes,\n  };\n\n  const {\n    user: { id, email, username },\n  } = getMergedScopeData(currentScope);\n  setLogAttribute(processedLogAttributes, 'user.id', id, false);\n  setLogAttribute(processedLogAttributes, 'user.email', email, false);\n  setLogAttribute(processedLogAttributes, 'user.name', username, false);\n\n  setLogAttribute(processedLogAttributes, 'sentry.release', release);\n  setLogAttribute(processedLogAttributes, 'sentry.environment', environment);\n\n  const { name, version } = client$1.getSdkMetadata()?.sdk ?? {};\n  setLogAttribute(processedLogAttributes, 'sentry.sdk.name', name);\n  setLogAttribute(processedLogAttributes, 'sentry.sdk.version', version);\n\n  const beforeLogMessage = beforeLog.message;\n  if (is.isParameterizedString(beforeLogMessage)) {\n    const { __sentry_template_string__, __sentry_template_values__ = [] } = beforeLogMessage;\n    processedLogAttributes['sentry.message.template'] = __sentry_template_string__;\n    __sentry_template_values__.forEach((param, index) => {\n      processedLogAttributes[`sentry.message.parameter.${index}`] = param;\n    });\n  }\n\n  const span = spanOnScope._getSpanForScope(currentScope);\n  // Add the parent span ID to the log attributes for trace context\n  setLogAttribute(processedLogAttributes, 'sentry.trace.parent_span_id', span?.spanContext().spanId);\n\n  const processedLog = { ...beforeLog, attributes: processedLogAttributes };\n\n  client$1.emit('beforeCaptureLog', processedLog);\n\n  // We need to wrap this in `consoleSandbox` to avoid recursive calls to `beforeSendLog`\n  const log = actualBeforeSendLog ? debugLogger.consoleSandbox(() => actualBeforeSendLog(processedLog)) : processedLog;\n  if (!log) {\n    client$1.recordDroppedEvent('before_send', 'log_item', 1);\n    debugBuild.DEBUG_BUILD && debugLogger.debug.warn('beforeSendLog returned null, log will not be captured.');\n    return;\n  }\n\n  const { level, message, attributes = {}, severityNumber } = log;\n\n  const serializedLog = {\n    timestamp: time.timestampInSeconds(),\n    level,\n    body: message,\n    trace_id: traceContext?.trace_id,\n    severity_number: severityNumber ?? constants.SEVERITY_TEXT_TO_SEVERITY_NUMBER[level],\n    attributes: Object.keys(attributes).reduce(\n      (acc, key) => {\n        acc[key] = logAttributeToSerializedLogAttribute(attributes[key]);\n        return acc;\n      },\n      {} ,\n    ),\n  };\n\n  captureSerializedLog(client$1, serializedLog);\n\n  client$1.emit('afterCaptureLog', log);\n}\n\n/**\n * Flushes the logs buffer to Sentry.\n *\n * @param client - A client.\n * @param maybeLogBuffer - A log buffer. Uses the log buffer for the given client if not provided.\n *\n * @experimental This method will experience breaking changes. This is not yet part of\n * the stable Sentry SDK API and can be changed or removed without warning.\n */\nfunction _INTERNAL_flushLogsBuffer(client, maybeLogBuffer) {\n  const logBuffer = maybeLogBuffer ?? _INTERNAL_getLogBuffer(client) ?? [];\n  if (logBuffer.length === 0) {\n    return;\n  }\n\n  const clientOptions = client.getOptions();\n  const envelope$1 = envelope.createLogEnvelope(logBuffer, clientOptions._metadata, clientOptions.tunnel, client.getDsn());\n\n  // Clear the log buffer after envelopes have been constructed.\n  _getBufferMap().set(client, []);\n\n  client.emit('flushLogs');\n\n  // sendEnvelope should not throw\n  // eslint-disable-next-line @typescript-eslint/no-floating-promises\n  client.sendEnvelope(envelope$1);\n}\n\n/**\n * Returns the log buffer for a given client.\n *\n * Exported for testing purposes.\n *\n * @param client - The client to get the log buffer for.\n * @returns The log buffer for the given client.\n */\nfunction _INTERNAL_getLogBuffer(client) {\n  return _getBufferMap().get(client);\n}\n\n/**\n * Get the scope data for the current scope after merging with the\n * global scope and isolation scope.\n *\n * @param currentScope - The current scope.\n * @returns The scope data.\n */\nfunction getMergedScopeData(currentScope) {\n  const scopeData = currentScopes.getGlobalScope().getScopeData();\n  applyScopeDataToEvent.mergeScopeData(scopeData, currentScopes.getIsolationScope().getScopeData());\n  applyScopeDataToEvent.mergeScopeData(scopeData, currentScope.getScopeData());\n  return scopeData;\n}\n\nfunction _getBufferMap() {\n  // The reference to the Client <> LogBuffer map is stored on the carrier to ensure it's always the same\n  return carrier.getGlobalSingleton('clientToLogBufferMap', () => new WeakMap());\n}\n\nexports._INTERNAL_captureLog = _INTERNAL_captureLog;\nexports._INTERNAL_captureSerializedLog = _INTERNAL_captureSerializedLog;\nexports._INTERNAL_flushLogsBuffer = _INTERNAL_flushLogsBuffer;\nexports._INTERNAL_getLogBuffer = _INTERNAL_getLogBuffer;\nexports.logAttributeToSerializedLogAttribute = logAttributeToSerializedLogAttribute;\n//# sourceMappingURL=exports.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvbG9ncy9leHBvcnRzLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLGdCQUFnQixtQkFBTyxDQUFDLDJIQUFlO0FBQ3ZDLGVBQWUsbUJBQU8sQ0FBQyx5SEFBYztBQUNyQyxzQkFBc0IsbUJBQU8sQ0FBQyx1SUFBcUI7QUFDbkQsbUJBQW1CLG1CQUFPLENBQUMsbUlBQW1CO0FBQzlDLDhCQUE4QixtQkFBTyxDQUFDLG1LQUFtQztBQUN6RSxvQkFBb0IsbUJBQU8sQ0FBQyxpSkFBMEI7QUFDdEQsV0FBVyxtQkFBTyxDQUFDLDZIQUFnQjtBQUNuQyxvQkFBb0IsbUJBQU8sQ0FBQywrSUFBeUI7QUFDckQsYUFBYSxtQkFBTyxDQUFDLGlJQUFrQjtBQUN2QyxrQkFBa0IsbUJBQU8sQ0FBQyxtSUFBZ0I7QUFDMUMsaUJBQWlCLG1CQUFPLENBQUMsaUlBQWU7O0FBRXhDOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsUUFBUTtBQUNSO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQSxJQUFJO0FBQ0o7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSxVQUFVLGdFQUFnRTtBQUMxRTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBLFlBQVkscUJBQXFCO0FBQ2pDLElBQUk7QUFDSjtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQSxVQUFVLGdCQUFnQjtBQUMxQjtBQUNBOztBQUVBO0FBQ0E7QUFDQSxZQUFZLDhEQUE4RDtBQUMxRTtBQUNBO0FBQ0EseURBQXlELE1BQU07QUFDL0QsS0FBSztBQUNMOztBQUVBO0FBQ0E7QUFDQTs7QUFFQSx5QkFBeUI7O0FBRXpCOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLFVBQVUsK0JBQStCLG1CQUFtQjs7QUFFNUQ7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxPQUFPO0FBQ1AsU0FBUztBQUNUO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLDRCQUE0QjtBQUM1QixzQ0FBc0M7QUFDdEMsaUNBQWlDO0FBQ2pDLDhCQUE4QjtBQUM5Qiw0Q0FBNEM7QUFDNUMiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9sb2dzL2V4cG9ydHMuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGNhcnJpZXIgPSByZXF1aXJlKCcuLi9jYXJyaWVyLmpzJyk7XG5jb25zdCBjbGllbnQgPSByZXF1aXJlKCcuLi9jbGllbnQuanMnKTtcbmNvbnN0IGN1cnJlbnRTY29wZXMgPSByZXF1aXJlKCcuLi9jdXJyZW50U2NvcGVzLmpzJyk7XG5jb25zdCBkZWJ1Z0J1aWxkID0gcmVxdWlyZSgnLi4vZGVidWctYnVpbGQuanMnKTtcbmNvbnN0IGFwcGx5U2NvcGVEYXRhVG9FdmVudCA9IHJlcXVpcmUoJy4uL3V0aWxzL2FwcGx5U2NvcGVEYXRhVG9FdmVudC5qcycpO1xuY29uc3QgZGVidWdMb2dnZXIgPSByZXF1aXJlKCcuLi91dGlscy9kZWJ1Zy1sb2dnZXIuanMnKTtcbmNvbnN0IGlzID0gcmVxdWlyZSgnLi4vdXRpbHMvaXMuanMnKTtcbmNvbnN0IHNwYW5PblNjb3BlID0gcmVxdWlyZSgnLi4vdXRpbHMvc3Bhbk9uU2NvcGUuanMnKTtcbmNvbnN0IHRpbWUgPSByZXF1aXJlKCcuLi91dGlscy90aW1lLmpzJyk7XG5jb25zdCBjb25zdGFudHMgPSByZXF1aXJlKCcuL2NvbnN0YW50cy5qcycpO1xuY29uc3QgZW52ZWxvcGUgPSByZXF1aXJlKCcuL2VudmVsb3BlLmpzJyk7XG5cbmNvbnN0IE1BWF9MT0dfQlVGRkVSX1NJWkUgPSAxMDA7XG5cbi8qKlxuICogQ29udmVydHMgYSBsb2cgYXR0cmlidXRlIHRvIGEgc2VyaWFsaXplZCBsb2cgYXR0cmlidXRlLlxuICpcbiAqIEBwYXJhbSBrZXkgLSBUaGUga2V5IG9mIHRoZSBsb2cgYXR0cmlidXRlLlxuICogQHBhcmFtIHZhbHVlIC0gVGhlIHZhbHVlIG9mIHRoZSBsb2cgYXR0cmlidXRlLlxuICogQHJldHVybnMgVGhlIHNlcmlhbGl6ZWQgbG9nIGF0dHJpYnV0ZS5cbiAqL1xuZnVuY3Rpb24gbG9nQXR0cmlidXRlVG9TZXJpYWxpemVkTG9nQXR0cmlidXRlKHZhbHVlKSB7XG4gIHN3aXRjaCAodHlwZW9mIHZhbHVlKSB7XG4gICAgY2FzZSAnbnVtYmVyJzpcbiAgICAgIGlmIChOdW1iZXIuaXNJbnRlZ2VyKHZhbHVlKSkge1xuICAgICAgICByZXR1cm4ge1xuICAgICAgICAgIHZhbHVlLFxuICAgICAgICAgIHR5cGU6ICdpbnRlZ2VyJyxcbiAgICAgICAgfTtcbiAgICAgIH1cbiAgICAgIHJldHVybiB7XG4gICAgICAgIHZhbHVlLFxuICAgICAgICB0eXBlOiAnZG91YmxlJyxcbiAgICAgIH07XG4gICAgY2FzZSAnYm9vbGVhbic6XG4gICAgICByZXR1cm4ge1xuICAgICAgICB2YWx1ZSxcbiAgICAgICAgdHlwZTogJ2Jvb2xlYW4nLFxuICAgICAgfTtcbiAgICBjYXNlICdzdHJpbmcnOlxuICAgICAgcmV0dXJuIHtcbiAgICAgICAgdmFsdWUsXG4gICAgICAgIHR5cGU6ICdzdHJpbmcnLFxuICAgICAgfTtcbiAgICBkZWZhdWx0OiB7XG4gICAgICBsZXQgc3RyaW5nVmFsdWUgPSAnJztcbiAgICAgIHRyeSB7XG4gICAgICAgIHN0cmluZ1ZhbHVlID0gSlNPTi5zdHJpbmdpZnkodmFsdWUpID8/ICcnO1xuICAgICAgfSBjYXRjaCB7XG4gICAgICAgIC8vIERvIG5vdGhpbmdcbiAgICAgIH1cbiAgICAgIHJldHVybiB7XG4gICAgICAgIHZhbHVlOiBzdHJpbmdWYWx1ZSxcbiAgICAgICAgdHlwZTogJ3N0cmluZycsXG4gICAgICB9O1xuICAgIH1cbiAgfVxufVxuXG4vKipcbiAqIFNldHMgYSBsb2cgYXR0cmlidXRlIGlmIHRoZSB2YWx1ZSBleGlzdHMgYW5kIHRoZSBhdHRyaWJ1dGUga2V5IGlzIG5vdCBhbHJlYWR5IHByZXNlbnQuXG4gKlxuICogQHBhcmFtIGxvZ0F0dHJpYnV0ZXMgLSBUaGUgbG9nIGF0dHJpYnV0ZXMgb2JqZWN0IHRvIG1vZGlmeS5cbiAqIEBwYXJhbSBrZXkgLSBUaGUgYXR0cmlidXRlIGtleSB0byBzZXQuXG4gKiBAcGFyYW0gdmFsdWUgLSBUaGUgdmFsdWUgdG8gc2V0IChvbmx5IHNldHMgaWYgdHJ1dGh5IGFuZCBrZXkgbm90IHByZXNlbnQpLlxuICogQHBhcmFtIHNldEV2ZW5JZlByZXNlbnQgLSBXaGV0aGVyIHRvIHNldCB0aGUgYXR0cmlidXRlIGlmIGl0IGlzIHByZXNlbnQuIERlZmF1bHRzIHRvIHRydWUuXG4gKi9cbmZ1bmN0aW9uIHNldExvZ0F0dHJpYnV0ZShcbiAgbG9nQXR0cmlidXRlcyxcbiAga2V5LFxuICB2YWx1ZSxcbiAgc2V0RXZlbklmUHJlc2VudCA9IHRydWUsXG4pIHtcbiAgaWYgKHZhbHVlICYmICghbG9nQXR0cmlidXRlc1trZXldIHx8IHNldEV2ZW5JZlByZXNlbnQpKSB7XG4gICAgbG9nQXR0cmlidXRlc1trZXldID0gdmFsdWU7XG4gIH1cbn1cblxuLyoqXG4gKiBDYXB0dXJlcyBhIHNlcmlhbGl6ZWQgbG9nIGV2ZW50IGFuZCBhZGRzIGl0IHRvIHRoZSBsb2cgYnVmZmVyIGZvciB0aGUgZ2l2ZW4gY2xpZW50LlxuICpcbiAqIEBwYXJhbSBjbGllbnQgLSBBIGNsaWVudC4gVXNlcyB0aGUgY3VycmVudCBjbGllbnQgaWYgbm90IHByb3ZpZGVkLlxuICogQHBhcmFtIHNlcmlhbGl6ZWRMb2cgLSBUaGUgc2VyaWFsaXplZCBsb2cgZXZlbnQgdG8gY2FwdHVyZS5cbiAqXG4gKiBAZXhwZXJpbWVudGFsIFRoaXMgbWV0aG9kIHdpbGwgZXhwZXJpZW5jZSBicmVha2luZyBjaGFuZ2VzLiBUaGlzIGlzIG5vdCB5ZXQgcGFydCBvZlxuICogdGhlIHN0YWJsZSBTZW50cnkgU0RLIEFQSSBhbmQgY2FuIGJlIGNoYW5nZWQgb3IgcmVtb3ZlZCB3aXRob3V0IHdhcm5pbmcuXG4gKi9cbmZ1bmN0aW9uIF9JTlRFUk5BTF9jYXB0dXJlU2VyaWFsaXplZExvZyhjbGllbnQsIHNlcmlhbGl6ZWRMb2cpIHtcbiAgY29uc3QgYnVmZmVyTWFwID0gX2dldEJ1ZmZlck1hcCgpO1xuXG4gIGNvbnN0IGxvZ0J1ZmZlciA9IF9JTlRFUk5BTF9nZXRMb2dCdWZmZXIoY2xpZW50KTtcbiAgaWYgKGxvZ0J1ZmZlciA9PT0gdW5kZWZpbmVkKSB7XG4gICAgYnVmZmVyTWFwLnNldChjbGllbnQsIFtzZXJpYWxpemVkTG9nXSk7XG4gIH0gZWxzZSB7XG4gICAgYnVmZmVyTWFwLnNldChjbGllbnQsIFsuLi5sb2dCdWZmZXIsIHNlcmlhbGl6ZWRMb2ddKTtcbiAgICBpZiAobG9nQnVmZmVyLmxlbmd0aCA+PSBNQVhfTE9HX0JVRkZFUl9TSVpFKSB7XG4gICAgICBfSU5URVJOQUxfZmx1c2hMb2dzQnVmZmVyKGNsaWVudCwgbG9nQnVmZmVyKTtcbiAgICB9XG4gIH1cbn1cblxuLyoqXG4gKiBDYXB0dXJlcyBhIGxvZyBldmVudCBhbmQgc2VuZHMgaXQgdG8gU2VudHJ5LlxuICpcbiAqIEBwYXJhbSBsb2cgLSBUaGUgbG9nIGV2ZW50IHRvIGNhcHR1cmUuXG4gKiBAcGFyYW0gc2NvcGUgLSBBIHNjb3BlLiBVc2VzIHRoZSBjdXJyZW50IHNjb3BlIGlmIG5vdCBwcm92aWRlZC5cbiAqIEBwYXJhbSBjbGllbnQgLSBBIGNsaWVudC4gVXNlcyB0aGUgY3VycmVudCBjbGllbnQgaWYgbm90IHByb3ZpZGVkLlxuICogQHBhcmFtIGNhcHR1cmVTZXJpYWxpemVkTG9nIC0gQSBmdW5jdGlvbiB0byBjYXB0dXJlIHRoZSBzZXJpYWxpemVkIGxvZy5cbiAqXG4gKiBAZXhwZXJpbWVudGFsIFRoaXMgbWV0aG9kIHdpbGwgZXhwZXJpZW5jZSBicmVha2luZyBjaGFuZ2VzLiBUaGlzIGlzIG5vdCB5ZXQgcGFydCBvZlxuICogdGhlIHN0YWJsZSBTZW50cnkgU0RLIEFQSSBhbmQgY2FuIGJlIGNoYW5nZWQgb3IgcmVtb3ZlZCB3aXRob3V0IHdhcm5pbmcuXG4gKi9cbmZ1bmN0aW9uIF9JTlRFUk5BTF9jYXB0dXJlTG9nKFxuICBiZWZvcmVMb2csXG4gIGNsaWVudCQxID0gY3VycmVudFNjb3Blcy5nZXRDbGllbnQoKSxcbiAgY3VycmVudFNjb3BlID0gY3VycmVudFNjb3Blcy5nZXRDdXJyZW50U2NvcGUoKSxcbiAgY2FwdHVyZVNlcmlhbGl6ZWRMb2cgPSBfSU5URVJOQUxfY2FwdHVyZVNlcmlhbGl6ZWRMb2csXG4pIHtcbiAgaWYgKCFjbGllbnQkMSkge1xuICAgIGRlYnVnQnVpbGQuREVCVUdfQlVJTEQgJiYgZGVidWdMb2dnZXIuZGVidWcud2FybignTm8gY2xpZW50IGF2YWlsYWJsZSB0byBjYXB0dXJlIGxvZy4nKTtcbiAgICByZXR1cm47XG4gIH1cblxuICBjb25zdCB7IHJlbGVhc2UsIGVudmlyb25tZW50LCBlbmFibGVMb2dzLCBiZWZvcmVTZW5kTG9nLCBfZXhwZXJpbWVudHMgfSA9IGNsaWVudCQxLmdldE9wdGlvbnMoKTtcbiAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIGRlcHJlY2F0aW9uL2RlcHJlY2F0aW9uXG4gIGNvbnN0IHNob3VsZEVuYWJsZUxvZ3MgPSBlbmFibGVMb2dzID8/IF9leHBlcmltZW50cz8uZW5hYmxlTG9ncztcbiAgaWYgKCFzaG91bGRFbmFibGVMb2dzKSB7XG4gICAgZGVidWdCdWlsZC5ERUJVR19CVUlMRCAmJiBkZWJ1Z0xvZ2dlci5kZWJ1Zy53YXJuKCdsb2dnaW5nIG9wdGlvbiBub3QgZW5hYmxlZCwgbG9nIHdpbGwgbm90IGJlIGNhcHR1cmVkLicpO1xuICAgIHJldHVybjtcbiAgfVxuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgZGVwcmVjYXRpb24vZGVwcmVjYXRpb25cbiAgY29uc3QgYWN0dWFsQmVmb3JlU2VuZExvZyA9IGJlZm9yZVNlbmRMb2cgPz8gX2V4cGVyaW1lbnRzPy5iZWZvcmVTZW5kTG9nO1xuXG4gIGNvbnN0IFssIHRyYWNlQ29udGV4dF0gPSBjbGllbnQuX2dldFRyYWNlSW5mb0Zyb21TY29wZShjbGllbnQkMSwgY3VycmVudFNjb3BlKTtcblxuICBjb25zdCBwcm9jZXNzZWRMb2dBdHRyaWJ1dGVzID0ge1xuICAgIC4uLmJlZm9yZUxvZy5hdHRyaWJ1dGVzLFxuICB9O1xuXG4gIGNvbnN0IHtcbiAgICB1c2VyOiB7IGlkLCBlbWFpbCwgdXNlcm5hbWUgfSxcbiAgfSA9IGdldE1lcmdlZFNjb3BlRGF0YShjdXJyZW50U2NvcGUpO1xuICBzZXRMb2dBdHRyaWJ1dGUocHJvY2Vzc2VkTG9nQXR0cmlidXRlcywgJ3VzZXIuaWQnLCBpZCwgZmFsc2UpO1xuICBzZXRMb2dBdHRyaWJ1dGUocHJvY2Vzc2VkTG9nQXR0cmlidXRlcywgJ3VzZXIuZW1haWwnLCBlbWFpbCwgZmFsc2UpO1xuICBzZXRMb2dBdHRyaWJ1dGUocHJvY2Vzc2VkTG9nQXR0cmlidXRlcywgJ3VzZXIubmFtZScsIHVzZXJuYW1lLCBmYWxzZSk7XG5cbiAgc2V0TG9nQXR0cmlidXRlKHByb2Nlc3NlZExvZ0F0dHJpYnV0ZXMsICdzZW50cnkucmVsZWFzZScsIHJlbGVhc2UpO1xuICBzZXRMb2dBdHRyaWJ1dGUocHJvY2Vzc2VkTG9nQXR0cmlidXRlcywgJ3NlbnRyeS5lbnZpcm9ubWVudCcsIGVudmlyb25tZW50KTtcblxuICBjb25zdCB7IG5hbWUsIHZlcnNpb24gfSA9IGNsaWVudCQxLmdldFNka01ldGFkYXRhKCk/LnNkayA/PyB7fTtcbiAgc2V0TG9nQXR0cmlidXRlKHByb2Nlc3NlZExvZ0F0dHJpYnV0ZXMsICdzZW50cnkuc2RrLm5hbWUnLCBuYW1lKTtcbiAgc2V0TG9nQXR0cmlidXRlKHByb2Nlc3NlZExvZ0F0dHJpYnV0ZXMsICdzZW50cnkuc2RrLnZlcnNpb24nLCB2ZXJzaW9uKTtcblxuICBjb25zdCBiZWZvcmVMb2dNZXNzYWdlID0gYmVmb3JlTG9nLm1lc3NhZ2U7XG4gIGlmIChpcy5pc1BhcmFtZXRlcml6ZWRTdHJpbmcoYmVmb3JlTG9nTWVzc2FnZSkpIHtcbiAgICBjb25zdCB7IF9fc2VudHJ5X3RlbXBsYXRlX3N0cmluZ19fLCBfX3NlbnRyeV90ZW1wbGF0ZV92YWx1ZXNfXyA9IFtdIH0gPSBiZWZvcmVMb2dNZXNzYWdlO1xuICAgIHByb2Nlc3NlZExvZ0F0dHJpYnV0ZXNbJ3NlbnRyeS5tZXNzYWdlLnRlbXBsYXRlJ10gPSBfX3NlbnRyeV90ZW1wbGF0ZV9zdHJpbmdfXztcbiAgICBfX3NlbnRyeV90ZW1wbGF0ZV92YWx1ZXNfXy5mb3JFYWNoKChwYXJhbSwgaW5kZXgpID0+IHtcbiAgICAgIHByb2Nlc3NlZExvZ0F0dHJpYnV0ZXNbYHNlbnRyeS5tZXNzYWdlLnBhcmFtZXRlci4ke2luZGV4fWBdID0gcGFyYW07XG4gICAgfSk7XG4gIH1cblxuICBjb25zdCBzcGFuID0gc3Bhbk9uU2NvcGUuX2dldFNwYW5Gb3JTY29wZShjdXJyZW50U2NvcGUpO1xuICAvLyBBZGQgdGhlIHBhcmVudCBzcGFuIElEIHRvIHRoZSBsb2cgYXR0cmlidXRlcyBmb3IgdHJhY2UgY29udGV4dFxuICBzZXRMb2dBdHRyaWJ1dGUocHJvY2Vzc2VkTG9nQXR0cmlidXRlcywgJ3NlbnRyeS50cmFjZS5wYXJlbnRfc3Bhbl9pZCcsIHNwYW4/LnNwYW5Db250ZXh0KCkuc3BhbklkKTtcblxuICBjb25zdCBwcm9jZXNzZWRMb2cgPSB7IC4uLmJlZm9yZUxvZywgYXR0cmlidXRlczogcHJvY2Vzc2VkTG9nQXR0cmlidXRlcyB9O1xuXG4gIGNsaWVudCQxLmVtaXQoJ2JlZm9yZUNhcHR1cmVMb2cnLCBwcm9jZXNzZWRMb2cpO1xuXG4gIC8vIFdlIG5lZWQgdG8gd3JhcCB0aGlzIGluIGBjb25zb2xlU2FuZGJveGAgdG8gYXZvaWQgcmVjdXJzaXZlIGNhbGxzIHRvIGBiZWZvcmVTZW5kTG9nYFxuICBjb25zdCBsb2cgPSBhY3R1YWxCZWZvcmVTZW5kTG9nID8gZGVidWdMb2dnZXIuY29uc29sZVNhbmRib3goKCkgPT4gYWN0dWFsQmVmb3JlU2VuZExvZyhwcm9jZXNzZWRMb2cpKSA6IHByb2Nlc3NlZExvZztcbiAgaWYgKCFsb2cpIHtcbiAgICBjbGllbnQkMS5yZWNvcmREcm9wcGVkRXZlbnQoJ2JlZm9yZV9zZW5kJywgJ2xvZ19pdGVtJywgMSk7XG4gICAgZGVidWdCdWlsZC5ERUJVR19CVUlMRCAmJiBkZWJ1Z0xvZ2dlci5kZWJ1Zy53YXJuKCdiZWZvcmVTZW5kTG9nIHJldHVybmVkIG51bGwsIGxvZyB3aWxsIG5vdCBiZSBjYXB0dXJlZC4nKTtcbiAgICByZXR1cm47XG4gIH1cblxuICBjb25zdCB7IGxldmVsLCBtZXNzYWdlLCBhdHRyaWJ1dGVzID0ge30sIHNldmVyaXR5TnVtYmVyIH0gPSBsb2c7XG5cbiAgY29uc3Qgc2VyaWFsaXplZExvZyA9IHtcbiAgICB0aW1lc3RhbXA6IHRpbWUudGltZXN0YW1wSW5TZWNvbmRzKCksXG4gICAgbGV2ZWwsXG4gICAgYm9keTogbWVzc2FnZSxcbiAgICB0cmFjZV9pZDogdHJhY2VDb250ZXh0Py50cmFjZV9pZCxcbiAgICBzZXZlcml0eV9udW1iZXI6IHNldmVyaXR5TnVtYmVyID8/IGNvbnN0YW50cy5TRVZFUklUWV9URVhUX1RPX1NFVkVSSVRZX05VTUJFUltsZXZlbF0sXG4gICAgYXR0cmlidXRlczogT2JqZWN0LmtleXMoYXR0cmlidXRlcykucmVkdWNlKFxuICAgICAgKGFjYywga2V5KSA9PiB7XG4gICAgICAgIGFjY1trZXldID0gbG9nQXR0cmlidXRlVG9TZXJpYWxpemVkTG9nQXR0cmlidXRlKGF0dHJpYnV0ZXNba2V5XSk7XG4gICAgICAgIHJldHVybiBhY2M7XG4gICAgICB9LFxuICAgICAge30gLFxuICAgICksXG4gIH07XG5cbiAgY2FwdHVyZVNlcmlhbGl6ZWRMb2coY2xpZW50JDEsIHNlcmlhbGl6ZWRMb2cpO1xuXG4gIGNsaWVudCQxLmVtaXQoJ2FmdGVyQ2FwdHVyZUxvZycsIGxvZyk7XG59XG5cbi8qKlxuICogRmx1c2hlcyB0aGUgbG9ncyBidWZmZXIgdG8gU2VudHJ5LlxuICpcbiAqIEBwYXJhbSBjbGllbnQgLSBBIGNsaWVudC5cbiAqIEBwYXJhbSBtYXliZUxvZ0J1ZmZlciAtIEEgbG9nIGJ1ZmZlci4gVXNlcyB0aGUgbG9nIGJ1ZmZlciBmb3IgdGhlIGdpdmVuIGNsaWVudCBpZiBub3QgcHJvdmlkZWQuXG4gKlxuICogQGV4cGVyaW1lbnRhbCBUaGlzIG1ldGhvZCB3aWxsIGV4cGVyaWVuY2UgYnJlYWtpbmcgY2hhbmdlcy4gVGhpcyBpcyBub3QgeWV0IHBhcnQgb2ZcbiAqIHRoZSBzdGFibGUgU2VudHJ5IFNESyBBUEkgYW5kIGNhbiBiZSBjaGFuZ2VkIG9yIHJlbW92ZWQgd2l0aG91dCB3YXJuaW5nLlxuICovXG5mdW5jdGlvbiBfSU5URVJOQUxfZmx1c2hMb2dzQnVmZmVyKGNsaWVudCwgbWF5YmVMb2dCdWZmZXIpIHtcbiAgY29uc3QgbG9nQnVmZmVyID0gbWF5YmVMb2dCdWZmZXIgPz8gX0lOVEVSTkFMX2dldExvZ0J1ZmZlcihjbGllbnQpID8/IFtdO1xuICBpZiAobG9nQnVmZmVyLmxlbmd0aCA9PT0gMCkge1xuICAgIHJldHVybjtcbiAgfVxuXG4gIGNvbnN0IGNsaWVudE9wdGlvbnMgPSBjbGllbnQuZ2V0T3B0aW9ucygpO1xuICBjb25zdCBlbnZlbG9wZSQxID0gZW52ZWxvcGUuY3JlYXRlTG9nRW52ZWxvcGUobG9nQnVmZmVyLCBjbGllbnRPcHRpb25zLl9tZXRhZGF0YSwgY2xpZW50T3B0aW9ucy50dW5uZWwsIGNsaWVudC5nZXREc24oKSk7XG5cbiAgLy8gQ2xlYXIgdGhlIGxvZyBidWZmZXIgYWZ0ZXIgZW52ZWxvcGVzIGhhdmUgYmVlbiBjb25zdHJ1Y3RlZC5cbiAgX2dldEJ1ZmZlck1hcCgpLnNldChjbGllbnQsIFtdKTtcblxuICBjbGllbnQuZW1pdCgnZmx1c2hMb2dzJyk7XG5cbiAgLy8gc2VuZEVudmVsb3BlIHNob3VsZCBub3QgdGhyb3dcbiAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uby1mbG9hdGluZy1wcm9taXNlc1xuICBjbGllbnQuc2VuZEVudmVsb3BlKGVudmVsb3BlJDEpO1xufVxuXG4vKipcbiAqIFJldHVybnMgdGhlIGxvZyBidWZmZXIgZm9yIGEgZ2l2ZW4gY2xpZW50LlxuICpcbiAqIEV4cG9ydGVkIGZvciB0ZXN0aW5nIHB1cnBvc2VzLlxuICpcbiAqIEBwYXJhbSBjbGllbnQgLSBUaGUgY2xpZW50IHRvIGdldCB0aGUgbG9nIGJ1ZmZlciBmb3IuXG4gKiBAcmV0dXJucyBUaGUgbG9nIGJ1ZmZlciBmb3IgdGhlIGdpdmVuIGNsaWVudC5cbiAqL1xuZnVuY3Rpb24gX0lOVEVSTkFMX2dldExvZ0J1ZmZlcihjbGllbnQpIHtcbiAgcmV0dXJuIF9nZXRCdWZmZXJNYXAoKS5nZXQoY2xpZW50KTtcbn1cblxuLyoqXG4gKiBHZXQgdGhlIHNjb3BlIGRhdGEgZm9yIHRoZSBjdXJyZW50IHNjb3BlIGFmdGVyIG1lcmdpbmcgd2l0aCB0aGVcbiAqIGdsb2JhbCBzY29wZSBhbmQgaXNvbGF0aW9uIHNjb3BlLlxuICpcbiAqIEBwYXJhbSBjdXJyZW50U2NvcGUgLSBUaGUgY3VycmVudCBzY29wZS5cbiAqIEByZXR1cm5zIFRoZSBzY29wZSBkYXRhLlxuICovXG5mdW5jdGlvbiBnZXRNZXJnZWRTY29wZURhdGEoY3VycmVudFNjb3BlKSB7XG4gIGNvbnN0IHNjb3BlRGF0YSA9IGN1cnJlbnRTY29wZXMuZ2V0R2xvYmFsU2NvcGUoKS5nZXRTY29wZURhdGEoKTtcbiAgYXBwbHlTY29wZURhdGFUb0V2ZW50Lm1lcmdlU2NvcGVEYXRhKHNjb3BlRGF0YSwgY3VycmVudFNjb3Blcy5nZXRJc29sYXRpb25TY29wZSgpLmdldFNjb3BlRGF0YSgpKTtcbiAgYXBwbHlTY29wZURhdGFUb0V2ZW50Lm1lcmdlU2NvcGVEYXRhKHNjb3BlRGF0YSwgY3VycmVudFNjb3BlLmdldFNjb3BlRGF0YSgpKTtcbiAgcmV0dXJuIHNjb3BlRGF0YTtcbn1cblxuZnVuY3Rpb24gX2dldEJ1ZmZlck1hcCgpIHtcbiAgLy8gVGhlIHJlZmVyZW5jZSB0byB0aGUgQ2xpZW50IDw+IExvZ0J1ZmZlciBtYXAgaXMgc3RvcmVkIG9uIHRoZSBjYXJyaWVyIHRvIGVuc3VyZSBpdCdzIGFsd2F5cyB0aGUgc2FtZVxuICByZXR1cm4gY2Fycmllci5nZXRHbG9iYWxTaW5nbGV0b24oJ2NsaWVudFRvTG9nQnVmZmVyTWFwJywgKCkgPT4gbmV3IFdlYWtNYXAoKSk7XG59XG5cbmV4cG9ydHMuX0lOVEVSTkFMX2NhcHR1cmVMb2cgPSBfSU5URVJOQUxfY2FwdHVyZUxvZztcbmV4cG9ydHMuX0lOVEVSTkFMX2NhcHR1cmVTZXJpYWxpemVkTG9nID0gX0lOVEVSTkFMX2NhcHR1cmVTZXJpYWxpemVkTG9nO1xuZXhwb3J0cy5fSU5URVJOQUxfZmx1c2hMb2dzQnVmZmVyID0gX0lOVEVSTkFMX2ZsdXNoTG9nc0J1ZmZlcjtcbmV4cG9ydHMuX0lOVEVSTkFMX2dldExvZ0J1ZmZlciA9IF9JTlRFUk5BTF9nZXRMb2dCdWZmZXI7XG5leHBvcnRzLmxvZ0F0dHJpYnV0ZVRvU2VyaWFsaXplZExvZ0F0dHJpYnV0ZSA9IGxvZ0F0dHJpYnV0ZVRvU2VyaWFsaXplZExvZ0F0dHJpYnV0ZTtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWV4cG9ydHMuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/logs/exports.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/metadata.js":
/*!************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/metadata.js ***!
  \************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst worldwide = __webpack_require__(/*! ./utils/worldwide.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/worldwide.js\");\n\n/** Keys are source filename/url, values are metadata objects. */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nconst filenameMetadataMap = new Map();\n/** Set of stack strings that have already been parsed. */\nconst parsedStacks = new Set();\n\nfunction ensureMetadataStacksAreParsed(parser) {\n  if (!worldwide.GLOBAL_OBJ._sentryModuleMetadata) {\n    return;\n  }\n\n  for (const stack of Object.keys(worldwide.GLOBAL_OBJ._sentryModuleMetadata)) {\n    const metadata = worldwide.GLOBAL_OBJ._sentryModuleMetadata[stack];\n\n    if (parsedStacks.has(stack)) {\n      continue;\n    }\n\n    // Ensure this stack doesn't get parsed again\n    parsedStacks.add(stack);\n\n    const frames = parser(stack);\n\n    // Go through the frames starting from the top of the stack and find the first one with a filename\n    for (const frame of frames.reverse()) {\n      if (frame.filename) {\n        // Save the metadata for this filename\n        filenameMetadataMap.set(frame.filename, metadata);\n        break;\n      }\n    }\n  }\n}\n\n/**\n * Retrieve metadata for a specific JavaScript file URL.\n *\n * Metadata is injected by the Sentry bundler plugins using the `_experiments.moduleMetadata` config option.\n */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction getMetadataForUrl(parser, filename) {\n  ensureMetadataStacksAreParsed(parser);\n  return filenameMetadataMap.get(filename);\n}\n\n/**\n * Adds metadata to stack frames.\n *\n * Metadata is injected by the Sentry bundler plugins using the `_experiments.moduleMetadata` config option.\n */\nfunction addMetadataToStackFrames(parser, event) {\n  try {\n    // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n    event.exception.values.forEach(exception => {\n      if (!exception.stacktrace) {\n        return;\n      }\n\n      for (const frame of exception.stacktrace.frames || []) {\n        if (!frame.filename || frame.module_metadata) {\n          continue;\n        }\n\n        const metadata = getMetadataForUrl(parser, frame.filename);\n\n        if (metadata) {\n          frame.module_metadata = metadata;\n        }\n      }\n    });\n  } catch {\n    // To save bundle size we're just try catching here instead of checking for the existence of all the different objects.\n  }\n}\n\n/**\n * Strips metadata from stack frames.\n */\nfunction stripMetadataFromStackFrames(event) {\n  try {\n    // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n    event.exception.values.forEach(exception => {\n      if (!exception.stacktrace) {\n        return;\n      }\n\n      for (const frame of exception.stacktrace.frames || []) {\n        delete frame.module_metadata;\n      }\n    });\n  } catch {\n    // To save bundle size we're just try catching here instead of checking for the existence of all the different objects.\n  }\n}\n\nexports.addMetadataToStackFrames = addMetadataToStackFrames;\nexports.getMetadataForUrl = getMetadataForUrl;\nexports.stripMetadataFromStackFrames = stripMetadataFromStackFrames;\n//# sourceMappingURL=metadata.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvbWV0YWRhdGEuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsa0JBQWtCLG1CQUFPLENBQUMsMElBQXNCOztBQUVoRDtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsS0FBSztBQUNMLElBQUk7QUFDSjtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0EsS0FBSztBQUNMLElBQUk7QUFDSjtBQUNBO0FBQ0E7O0FBRUEsZ0NBQWdDO0FBQ2hDLHlCQUF5QjtBQUN6QixvQ0FBb0M7QUFDcEMiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9tZXRhZGF0YS5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3Qgd29ybGR3aWRlID0gcmVxdWlyZSgnLi91dGlscy93b3JsZHdpZGUuanMnKTtcblxuLyoqIEtleXMgYXJlIHNvdXJjZSBmaWxlbmFtZS91cmwsIHZhbHVlcyBhcmUgbWV0YWRhdGEgb2JqZWN0cy4gKi9cbi8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tZXhwbGljaXQtYW55XG5jb25zdCBmaWxlbmFtZU1ldGFkYXRhTWFwID0gbmV3IE1hcCgpO1xuLyoqIFNldCBvZiBzdGFjayBzdHJpbmdzIHRoYXQgaGF2ZSBhbHJlYWR5IGJlZW4gcGFyc2VkLiAqL1xuY29uc3QgcGFyc2VkU3RhY2tzID0gbmV3IFNldCgpO1xuXG5mdW5jdGlvbiBlbnN1cmVNZXRhZGF0YVN0YWNrc0FyZVBhcnNlZChwYXJzZXIpIHtcbiAgaWYgKCF3b3JsZHdpZGUuR0xPQkFMX09CSi5fc2VudHJ5TW9kdWxlTWV0YWRhdGEpIHtcbiAgICByZXR1cm47XG4gIH1cblxuICBmb3IgKGNvbnN0IHN0YWNrIG9mIE9iamVjdC5rZXlzKHdvcmxkd2lkZS5HTE9CQUxfT0JKLl9zZW50cnlNb2R1bGVNZXRhZGF0YSkpIHtcbiAgICBjb25zdCBtZXRhZGF0YSA9IHdvcmxkd2lkZS5HTE9CQUxfT0JKLl9zZW50cnlNb2R1bGVNZXRhZGF0YVtzdGFja107XG5cbiAgICBpZiAocGFyc2VkU3RhY2tzLmhhcyhzdGFjaykpIHtcbiAgICAgIGNvbnRpbnVlO1xuICAgIH1cblxuICAgIC8vIEVuc3VyZSB0aGlzIHN0YWNrIGRvZXNuJ3QgZ2V0IHBhcnNlZCBhZ2FpblxuICAgIHBhcnNlZFN0YWNrcy5hZGQoc3RhY2spO1xuXG4gICAgY29uc3QgZnJhbWVzID0gcGFyc2VyKHN0YWNrKTtcblxuICAgIC8vIEdvIHRocm91Z2ggdGhlIGZyYW1lcyBzdGFydGluZyBmcm9tIHRoZSB0b3Agb2YgdGhlIHN0YWNrIGFuZCBmaW5kIHRoZSBmaXJzdCBvbmUgd2l0aCBhIGZpbGVuYW1lXG4gICAgZm9yIChjb25zdCBmcmFtZSBvZiBmcmFtZXMucmV2ZXJzZSgpKSB7XG4gICAgICBpZiAoZnJhbWUuZmlsZW5hbWUpIHtcbiAgICAgICAgLy8gU2F2ZSB0aGUgbWV0YWRhdGEgZm9yIHRoaXMgZmlsZW5hbWVcbiAgICAgICAgZmlsZW5hbWVNZXRhZGF0YU1hcC5zZXQoZnJhbWUuZmlsZW5hbWUsIG1ldGFkYXRhKTtcbiAgICAgICAgYnJlYWs7XG4gICAgICB9XG4gICAgfVxuICB9XG59XG5cbi8qKlxuICogUmV0cmlldmUgbWV0YWRhdGEgZm9yIGEgc3BlY2lmaWMgSmF2YVNjcmlwdCBmaWxlIFVSTC5cbiAqXG4gKiBNZXRhZGF0YSBpcyBpbmplY3RlZCBieSB0aGUgU2VudHJ5IGJ1bmRsZXIgcGx1Z2lucyB1c2luZyB0aGUgYF9leHBlcmltZW50cy5tb2R1bGVNZXRhZGF0YWAgY29uZmlnIG9wdGlvbi5cbiAqL1xuLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uby1leHBsaWNpdC1hbnlcbmZ1bmN0aW9uIGdldE1ldGFkYXRhRm9yVXJsKHBhcnNlciwgZmlsZW5hbWUpIHtcbiAgZW5zdXJlTWV0YWRhdGFTdGFja3NBcmVQYXJzZWQocGFyc2VyKTtcbiAgcmV0dXJuIGZpbGVuYW1lTWV0YWRhdGFNYXAuZ2V0KGZpbGVuYW1lKTtcbn1cblxuLyoqXG4gKiBBZGRzIG1ldGFkYXRhIHRvIHN0YWNrIGZyYW1lcy5cbiAqXG4gKiBNZXRhZGF0YSBpcyBpbmplY3RlZCBieSB0aGUgU2VudHJ5IGJ1bmRsZXIgcGx1Z2lucyB1c2luZyB0aGUgYF9leHBlcmltZW50cy5tb2R1bGVNZXRhZGF0YWAgY29uZmlnIG9wdGlvbi5cbiAqL1xuZnVuY3Rpb24gYWRkTWV0YWRhdGFUb1N0YWNrRnJhbWVzKHBhcnNlciwgZXZlbnQpIHtcbiAgdHJ5IHtcbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25vLW5vbi1udWxsLWFzc2VydGlvblxuICAgIGV2ZW50LmV4Y2VwdGlvbi52YWx1ZXMuZm9yRWFjaChleGNlcHRpb24gPT4ge1xuICAgICAgaWYgKCFleGNlcHRpb24uc3RhY2t0cmFjZSkge1xuICAgICAgICByZXR1cm47XG4gICAgICB9XG5cbiAgICAgIGZvciAoY29uc3QgZnJhbWUgb2YgZXhjZXB0aW9uLnN0YWNrdHJhY2UuZnJhbWVzIHx8IFtdKSB7XG4gICAgICAgIGlmICghZnJhbWUuZmlsZW5hbWUgfHwgZnJhbWUubW9kdWxlX21ldGFkYXRhKSB7XG4gICAgICAgICAgY29udGludWU7XG4gICAgICAgIH1cblxuICAgICAgICBjb25zdCBtZXRhZGF0YSA9IGdldE1ldGFkYXRhRm9yVXJsKHBhcnNlciwgZnJhbWUuZmlsZW5hbWUpO1xuXG4gICAgICAgIGlmIChtZXRhZGF0YSkge1xuICAgICAgICAgIGZyYW1lLm1vZHVsZV9tZXRhZGF0YSA9IG1ldGFkYXRhO1xuICAgICAgICB9XG4gICAgICB9XG4gICAgfSk7XG4gIH0gY2F0Y2gge1xuICAgIC8vIFRvIHNhdmUgYnVuZGxlIHNpemUgd2UncmUganVzdCB0cnkgY2F0Y2hpbmcgaGVyZSBpbnN0ZWFkIG9mIGNoZWNraW5nIGZvciB0aGUgZXhpc3RlbmNlIG9mIGFsbCB0aGUgZGlmZmVyZW50IG9iamVjdHMuXG4gIH1cbn1cblxuLyoqXG4gKiBTdHJpcHMgbWV0YWRhdGEgZnJvbSBzdGFjayBmcmFtZXMuXG4gKi9cbmZ1bmN0aW9uIHN0cmlwTWV0YWRhdGFGcm9tU3RhY2tGcmFtZXMoZXZlbnQpIHtcbiAgdHJ5IHtcbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25vLW5vbi1udWxsLWFzc2VydGlvblxuICAgIGV2ZW50LmV4Y2VwdGlvbi52YWx1ZXMuZm9yRWFjaChleGNlcHRpb24gPT4ge1xuICAgICAgaWYgKCFleGNlcHRpb24uc3RhY2t0cmFjZSkge1xuICAgICAgICByZXR1cm47XG4gICAgICB9XG5cbiAgICAgIGZvciAoY29uc3QgZnJhbWUgb2YgZXhjZXB0aW9uLnN0YWNrdHJhY2UuZnJhbWVzIHx8IFtdKSB7XG4gICAgICAgIGRlbGV0ZSBmcmFtZS5tb2R1bGVfbWV0YWRhdGE7XG4gICAgICB9XG4gICAgfSk7XG4gIH0gY2F0Y2gge1xuICAgIC8vIFRvIHNhdmUgYnVuZGxlIHNpemUgd2UncmUganVzdCB0cnkgY2F0Y2hpbmcgaGVyZSBpbnN0ZWFkIG9mIGNoZWNraW5nIGZvciB0aGUgZXhpc3RlbmNlIG9mIGFsbCB0aGUgZGlmZmVyZW50IG9iamVjdHMuXG4gIH1cbn1cblxuZXhwb3J0cy5hZGRNZXRhZGF0YVRvU3RhY2tGcmFtZXMgPSBhZGRNZXRhZGF0YVRvU3RhY2tGcmFtZXM7XG5leHBvcnRzLmdldE1ldGFkYXRhRm9yVXJsID0gZ2V0TWV0YWRhdGFGb3JVcmw7XG5leHBvcnRzLnN0cmlwTWV0YWRhdGFGcm9tU3RhY2tGcmFtZXMgPSBzdHJpcE1ldGFkYXRhRnJvbVN0YWNrRnJhbWVzO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9bWV0YWRhdGEuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/metadata.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/profiling.js":
/*!*************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/profiling.js ***!
  \*************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst currentScopes = __webpack_require__(/*! ./currentScopes.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst debugBuild = __webpack_require__(/*! ./debug-build.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst debugLogger = __webpack_require__(/*! ./utils/debug-logger.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\n\nfunction isProfilingIntegrationWithProfiler(\n  integration,\n) {\n  return (\n    !!integration &&\n    typeof integration['_profiler'] !== 'undefined' &&\n    typeof integration['_profiler']['start'] === 'function' &&\n    typeof integration['_profiler']['stop'] === 'function'\n  );\n}\n/**\n * Starts the Sentry continuous profiler.\n * This mode is exclusive with the transaction profiler and will only work if the profilesSampleRate is set to a falsy value.\n * In continuous profiling mode, the profiler will keep reporting profile chunks to Sentry until it is stopped, which allows for continuous profiling of the application.\n */\nfunction startProfiler() {\n  const client = currentScopes.getClient();\n  if (!client) {\n    debugBuild.DEBUG_BUILD && debugLogger.debug.warn('No Sentry client available, profiling is not started');\n    return;\n  }\n\n  const integration = client.getIntegrationByName('ProfilingIntegration');\n\n  if (!integration) {\n    debugBuild.DEBUG_BUILD && debugLogger.debug.warn('ProfilingIntegration is not available');\n    return;\n  }\n\n  if (!isProfilingIntegrationWithProfiler(integration)) {\n    debugBuild.DEBUG_BUILD && debugLogger.debug.warn('Profiler is not available on profiling integration.');\n    return;\n  }\n\n  integration._profiler.start();\n}\n\n/**\n * Stops the Sentry continuous profiler.\n * Calls to stop will stop the profiler and flush the currently collected profile data to Sentry.\n */\nfunction stopProfiler() {\n  const client = currentScopes.getClient();\n  if (!client) {\n    debugBuild.DEBUG_BUILD && debugLogger.debug.warn('No Sentry client available, profiling is not started');\n    return;\n  }\n\n  const integration = client.getIntegrationByName('ProfilingIntegration');\n  if (!integration) {\n    debugBuild.DEBUG_BUILD && debugLogger.debug.warn('ProfilingIntegration is not available');\n    return;\n  }\n\n  if (!isProfilingIntegrationWithProfiler(integration)) {\n    debugBuild.DEBUG_BUILD && debugLogger.debug.warn('Profiler is not available on profiling integration.');\n    return;\n  }\n\n  integration._profiler.stop();\n}\n\nconst profiler = {\n  startProfiler,\n  stopProfiler,\n};\n\nexports.profiler = profiler;\n//# sourceMappingURL=profiling.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvcHJvZmlsaW5nLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLHNCQUFzQixtQkFBTyxDQUFDLHNJQUFvQjtBQUNsRCxtQkFBbUIsbUJBQU8sQ0FBQyxrSUFBa0I7QUFDN0Msb0JBQW9CLG1CQUFPLENBQUMsZ0pBQXlCOztBQUVyRDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsZ0JBQWdCO0FBQ2hCIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvcHJvZmlsaW5nLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBjdXJyZW50U2NvcGVzID0gcmVxdWlyZSgnLi9jdXJyZW50U2NvcGVzLmpzJyk7XG5jb25zdCBkZWJ1Z0J1aWxkID0gcmVxdWlyZSgnLi9kZWJ1Zy1idWlsZC5qcycpO1xuY29uc3QgZGVidWdMb2dnZXIgPSByZXF1aXJlKCcuL3V0aWxzL2RlYnVnLWxvZ2dlci5qcycpO1xuXG5mdW5jdGlvbiBpc1Byb2ZpbGluZ0ludGVncmF0aW9uV2l0aFByb2ZpbGVyKFxuICBpbnRlZ3JhdGlvbixcbikge1xuICByZXR1cm4gKFxuICAgICEhaW50ZWdyYXRpb24gJiZcbiAgICB0eXBlb2YgaW50ZWdyYXRpb25bJ19wcm9maWxlciddICE9PSAndW5kZWZpbmVkJyAmJlxuICAgIHR5cGVvZiBpbnRlZ3JhdGlvblsnX3Byb2ZpbGVyJ11bJ3N0YXJ0J10gPT09ICdmdW5jdGlvbicgJiZcbiAgICB0eXBlb2YgaW50ZWdyYXRpb25bJ19wcm9maWxlciddWydzdG9wJ10gPT09ICdmdW5jdGlvbidcbiAgKTtcbn1cbi8qKlxuICogU3RhcnRzIHRoZSBTZW50cnkgY29udGludW91cyBwcm9maWxlci5cbiAqIFRoaXMgbW9kZSBpcyBleGNsdXNpdmUgd2l0aCB0aGUgdHJhbnNhY3Rpb24gcHJvZmlsZXIgYW5kIHdpbGwgb25seSB3b3JrIGlmIHRoZSBwcm9maWxlc1NhbXBsZVJhdGUgaXMgc2V0IHRvIGEgZmFsc3kgdmFsdWUuXG4gKiBJbiBjb250aW51b3VzIHByb2ZpbGluZyBtb2RlLCB0aGUgcHJvZmlsZXIgd2lsbCBrZWVwIHJlcG9ydGluZyBwcm9maWxlIGNodW5rcyB0byBTZW50cnkgdW50aWwgaXQgaXMgc3RvcHBlZCwgd2hpY2ggYWxsb3dzIGZvciBjb250aW51b3VzIHByb2ZpbGluZyBvZiB0aGUgYXBwbGljYXRpb24uXG4gKi9cbmZ1bmN0aW9uIHN0YXJ0UHJvZmlsZXIoKSB7XG4gIGNvbnN0IGNsaWVudCA9IGN1cnJlbnRTY29wZXMuZ2V0Q2xpZW50KCk7XG4gIGlmICghY2xpZW50KSB7XG4gICAgZGVidWdCdWlsZC5ERUJVR19CVUlMRCAmJiBkZWJ1Z0xvZ2dlci5kZWJ1Zy53YXJuKCdObyBTZW50cnkgY2xpZW50IGF2YWlsYWJsZSwgcHJvZmlsaW5nIGlzIG5vdCBzdGFydGVkJyk7XG4gICAgcmV0dXJuO1xuICB9XG5cbiAgY29uc3QgaW50ZWdyYXRpb24gPSBjbGllbnQuZ2V0SW50ZWdyYXRpb25CeU5hbWUoJ1Byb2ZpbGluZ0ludGVncmF0aW9uJyk7XG5cbiAgaWYgKCFpbnRlZ3JhdGlvbikge1xuICAgIGRlYnVnQnVpbGQuREVCVUdfQlVJTEQgJiYgZGVidWdMb2dnZXIuZGVidWcud2FybignUHJvZmlsaW5nSW50ZWdyYXRpb24gaXMgbm90IGF2YWlsYWJsZScpO1xuICAgIHJldHVybjtcbiAgfVxuXG4gIGlmICghaXNQcm9maWxpbmdJbnRlZ3JhdGlvbldpdGhQcm9maWxlcihpbnRlZ3JhdGlvbikpIHtcbiAgICBkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEICYmIGRlYnVnTG9nZ2VyLmRlYnVnLndhcm4oJ1Byb2ZpbGVyIGlzIG5vdCBhdmFpbGFibGUgb24gcHJvZmlsaW5nIGludGVncmF0aW9uLicpO1xuICAgIHJldHVybjtcbiAgfVxuXG4gIGludGVncmF0aW9uLl9wcm9maWxlci5zdGFydCgpO1xufVxuXG4vKipcbiAqIFN0b3BzIHRoZSBTZW50cnkgY29udGludW91cyBwcm9maWxlci5cbiAqIENhbGxzIHRvIHN0b3Agd2lsbCBzdG9wIHRoZSBwcm9maWxlciBhbmQgZmx1c2ggdGhlIGN1cnJlbnRseSBjb2xsZWN0ZWQgcHJvZmlsZSBkYXRhIHRvIFNlbnRyeS5cbiAqL1xuZnVuY3Rpb24gc3RvcFByb2ZpbGVyKCkge1xuICBjb25zdCBjbGllbnQgPSBjdXJyZW50U2NvcGVzLmdldENsaWVudCgpO1xuICBpZiAoIWNsaWVudCkge1xuICAgIGRlYnVnQnVpbGQuREVCVUdfQlVJTEQgJiYgZGVidWdMb2dnZXIuZGVidWcud2FybignTm8gU2VudHJ5IGNsaWVudCBhdmFpbGFibGUsIHByb2ZpbGluZyBpcyBub3Qgc3RhcnRlZCcpO1xuICAgIHJldHVybjtcbiAgfVxuXG4gIGNvbnN0IGludGVncmF0aW9uID0gY2xpZW50LmdldEludGVncmF0aW9uQnlOYW1lKCdQcm9maWxpbmdJbnRlZ3JhdGlvbicpO1xuICBpZiAoIWludGVncmF0aW9uKSB7XG4gICAgZGVidWdCdWlsZC5ERUJVR19CVUlMRCAmJiBkZWJ1Z0xvZ2dlci5kZWJ1Zy53YXJuKCdQcm9maWxpbmdJbnRlZ3JhdGlvbiBpcyBub3QgYXZhaWxhYmxlJyk7XG4gICAgcmV0dXJuO1xuICB9XG5cbiAgaWYgKCFpc1Byb2ZpbGluZ0ludGVncmF0aW9uV2l0aFByb2ZpbGVyKGludGVncmF0aW9uKSkge1xuICAgIGRlYnVnQnVpbGQuREVCVUdfQlVJTEQgJiYgZGVidWdMb2dnZXIuZGVidWcud2FybignUHJvZmlsZXIgaXMgbm90IGF2YWlsYWJsZSBvbiBwcm9maWxpbmcgaW50ZWdyYXRpb24uJyk7XG4gICAgcmV0dXJuO1xuICB9XG5cbiAgaW50ZWdyYXRpb24uX3Byb2ZpbGVyLnN0b3AoKTtcbn1cblxuY29uc3QgcHJvZmlsZXIgPSB7XG4gIHN0YXJ0UHJvZmlsZXIsXG4gIHN0b3BQcm9maWxlcixcbn07XG5cbmV4cG9ydHMucHJvZmlsZXIgPSBwcm9maWxlcjtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPXByb2ZpbGluZy5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/profiling.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/scope.js":
/*!*********************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/scope.js ***!
  \*********************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst debugBuild = __webpack_require__(/*! ./debug-build.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst session = __webpack_require__(/*! ./session.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/session.js\");\nconst debugLogger = __webpack_require__(/*! ./utils/debug-logger.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst is = __webpack_require__(/*! ./utils/is.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js\");\nconst merge = __webpack_require__(/*! ./utils/merge.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/merge.js\");\nconst misc = __webpack_require__(/*! ./utils/misc.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/misc.js\");\nconst propagationContext = __webpack_require__(/*! ./utils/propagationContext.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/propagationContext.js\");\nconst spanOnScope = __webpack_require__(/*! ./utils/spanOnScope.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanOnScope.js\");\nconst string = __webpack_require__(/*! ./utils/string.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/string.js\");\nconst time = __webpack_require__(/*! ./utils/time.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/time.js\");\n\n/**\n * Default value for maximum number of breadcrumbs added to an event.\n */\nconst DEFAULT_MAX_BREADCRUMBS = 100;\n\n/**\n * A context to be used for capturing an event.\n * This can either be a Scope, or a partial ScopeContext,\n * or a callback that receives the current scope and returns a new scope to use.\n */\n\n/**\n * Holds additional event information.\n */\nclass Scope {\n  /** Flag if notifying is happening. */\n\n  /** Callback for client to receive scope changes. */\n\n  /** Callback list that will be called during event processing. */\n\n  /** Array of breadcrumbs. */\n\n  /** User */\n\n  /** Tags */\n\n  /** Extra */\n\n  /** Contexts */\n\n  /** Attachments */\n\n  /** Propagation Context for distributed tracing */\n\n  /**\n   * A place to stash data which is needed at some point in the SDK's event processing pipeline but which shouldn't get\n   * sent to Sentry\n   */\n\n  /** Fingerprint */\n\n  /** Severity */\n\n  /**\n   * Transaction Name\n   *\n   * IMPORTANT: The transaction name on the scope has nothing to do with root spans/transaction objects.\n   * It's purpose is to assign a transaction to the scope that's added to non-transaction events.\n   */\n\n  /** Session */\n\n  /** The client on this scope */\n\n  /** Contains the last event id of a captured event.  */\n\n  // NOTE: Any field which gets added here should get added not only to the constructor but also to the `clone` method.\n\n   constructor() {\n    this._notifyingListeners = false;\n    this._scopeListeners = [];\n    this._eventProcessors = [];\n    this._breadcrumbs = [];\n    this._attachments = [];\n    this._user = {};\n    this._tags = {};\n    this._extra = {};\n    this._contexts = {};\n    this._sdkProcessingMetadata = {};\n    this._propagationContext = {\n      traceId: propagationContext.generateTraceId(),\n      sampleRand: Math.random(),\n    };\n  }\n\n  /**\n   * Clone all data from this scope into a new scope.\n   */\n   clone() {\n    const newScope = new Scope();\n    newScope._breadcrumbs = [...this._breadcrumbs];\n    newScope._tags = { ...this._tags };\n    newScope._extra = { ...this._extra };\n    newScope._contexts = { ...this._contexts };\n    if (this._contexts.flags) {\n      // We need to copy the `values` array so insertions on a cloned scope\n      // won't affect the original array.\n      newScope._contexts.flags = {\n        values: [...this._contexts.flags.values],\n      };\n    }\n\n    newScope._user = this._user;\n    newScope._level = this._level;\n    newScope._session = this._session;\n    newScope._transactionName = this._transactionName;\n    newScope._fingerprint = this._fingerprint;\n    newScope._eventProcessors = [...this._eventProcessors];\n    newScope._attachments = [...this._attachments];\n    newScope._sdkProcessingMetadata = { ...this._sdkProcessingMetadata };\n    newScope._propagationContext = { ...this._propagationContext };\n    newScope._client = this._client;\n    newScope._lastEventId = this._lastEventId;\n\n    spanOnScope._setSpanForScope(newScope, spanOnScope._getSpanForScope(this));\n\n    return newScope;\n  }\n\n  /**\n   * Update the client assigned to this scope.\n   * Note that not every scope will have a client assigned - isolation scopes & the global scope will generally not have a client,\n   * as well as manually created scopes.\n   */\n   setClient(client) {\n    this._client = client;\n  }\n\n  /**\n   * Set the ID of the last captured error event.\n   * This is generally only captured on the isolation scope.\n   */\n   setLastEventId(lastEventId) {\n    this._lastEventId = lastEventId;\n  }\n\n  /**\n   * Get the client assigned to this scope.\n   */\n   getClient() {\n    return this._client ;\n  }\n\n  /**\n   * Get the ID of the last captured error event.\n   * This is generally only available on the isolation scope.\n   */\n   lastEventId() {\n    return this._lastEventId;\n  }\n\n  /**\n   * @inheritDoc\n   */\n   addScopeListener(callback) {\n    this._scopeListeners.push(callback);\n  }\n\n  /**\n   * Add an event processor that will be called before an event is sent.\n   */\n   addEventProcessor(callback) {\n    this._eventProcessors.push(callback);\n    return this;\n  }\n\n  /**\n   * Set the user for this scope.\n   * Set to `null` to unset the user.\n   */\n   setUser(user) {\n    // If null is passed we want to unset everything, but still define keys,\n    // so that later down in the pipeline any existing values are cleared.\n    this._user = user || {\n      email: undefined,\n      id: undefined,\n      ip_address: undefined,\n      username: undefined,\n    };\n\n    if (this._session) {\n      session.updateSession(this._session, { user });\n    }\n\n    this._notifyScopeListeners();\n    return this;\n  }\n\n  /**\n   * Get the user from this scope.\n   */\n   getUser() {\n    return this._user;\n  }\n\n  /**\n   * Set an object that will be merged into existing tags on the scope,\n   * and will be sent as tags data with the event.\n   */\n   setTags(tags) {\n    this._tags = {\n      ...this._tags,\n      ...tags,\n    };\n    this._notifyScopeListeners();\n    return this;\n  }\n\n  /**\n   * Set a single tag that will be sent as tags data with the event.\n   */\n   setTag(key, value) {\n    this._tags = { ...this._tags, [key]: value };\n    this._notifyScopeListeners();\n    return this;\n  }\n\n  /**\n   * Set an object that will be merged into existing extra on the scope,\n   * and will be sent as extra data with the event.\n   */\n   setExtras(extras) {\n    this._extra = {\n      ...this._extra,\n      ...extras,\n    };\n    this._notifyScopeListeners();\n    return this;\n  }\n\n  /**\n   * Set a single key:value extra entry that will be sent as extra data with the event.\n   */\n   setExtra(key, extra) {\n    this._extra = { ...this._extra, [key]: extra };\n    this._notifyScopeListeners();\n    return this;\n  }\n\n  /**\n   * Sets the fingerprint on the scope to send with the events.\n   * @param {string[]} fingerprint Fingerprint to group events in Sentry.\n   */\n   setFingerprint(fingerprint) {\n    this._fingerprint = fingerprint;\n    this._notifyScopeListeners();\n    return this;\n  }\n\n  /**\n   * Sets the level on the scope for future events.\n   */\n   setLevel(level) {\n    this._level = level;\n    this._notifyScopeListeners();\n    return this;\n  }\n\n  /**\n   * Sets the transaction name on the scope so that the name of e.g. taken server route or\n   * the page location is attached to future events.\n   *\n   * IMPORTANT: Calling this function does NOT change the name of the currently active\n   * root span. If you want to change the name of the active root span, use\n   * `Sentry.updateSpanName(rootSpan, 'new name')` instead.\n   *\n   * By default, the SDK updates the scope's transaction name automatically on sensible\n   * occasions, such as a page navigation or when handling a new request on the server.\n   */\n   setTransactionName(name) {\n    this._transactionName = name;\n    this._notifyScopeListeners();\n    return this;\n  }\n\n  /**\n   * Sets context data with the given name.\n   * Data passed as context will be normalized. You can also pass `null` to unset the context.\n   * Note that context data will not be merged - calling `setContext` will overwrite an existing context with the same key.\n   */\n   setContext(key, context) {\n    if (context === null) {\n      // eslint-disable-next-line @typescript-eslint/no-dynamic-delete\n      delete this._contexts[key];\n    } else {\n      this._contexts[key] = context;\n    }\n\n    this._notifyScopeListeners();\n    return this;\n  }\n\n  /**\n   * Set the session for the scope.\n   */\n   setSession(session) {\n    if (!session) {\n      delete this._session;\n    } else {\n      this._session = session;\n    }\n    this._notifyScopeListeners();\n    return this;\n  }\n\n  /**\n   * Get the session from the scope.\n   */\n   getSession() {\n    return this._session;\n  }\n\n  /**\n   * Updates the scope with provided data. Can work in three variations:\n   * - plain object containing updatable attributes\n   * - Scope instance that'll extract the attributes from\n   * - callback function that'll receive the current scope as an argument and allow for modifications\n   */\n   update(captureContext) {\n    if (!captureContext) {\n      return this;\n    }\n\n    const scopeToMerge = typeof captureContext === 'function' ? captureContext(this) : captureContext;\n\n    const scopeInstance =\n      scopeToMerge instanceof Scope\n        ? scopeToMerge.getScopeData()\n        : is.isPlainObject(scopeToMerge)\n          ? (captureContext )\n          : undefined;\n\n    const { tags, extra, user, contexts, level, fingerprint = [], propagationContext } = scopeInstance || {};\n\n    this._tags = { ...this._tags, ...tags };\n    this._extra = { ...this._extra, ...extra };\n    this._contexts = { ...this._contexts, ...contexts };\n\n    if (user && Object.keys(user).length) {\n      this._user = user;\n    }\n\n    if (level) {\n      this._level = level;\n    }\n\n    if (fingerprint.length) {\n      this._fingerprint = fingerprint;\n    }\n\n    if (propagationContext) {\n      this._propagationContext = propagationContext;\n    }\n\n    return this;\n  }\n\n  /**\n   * Clears the current scope and resets its properties.\n   * Note: The client will not be cleared.\n   */\n   clear() {\n    // client is not cleared here on purpose!\n    this._breadcrumbs = [];\n    this._tags = {};\n    this._extra = {};\n    this._user = {};\n    this._contexts = {};\n    this._level = undefined;\n    this._transactionName = undefined;\n    this._fingerprint = undefined;\n    this._session = undefined;\n    spanOnScope._setSpanForScope(this, undefined);\n    this._attachments = [];\n    this.setPropagationContext({ traceId: propagationContext.generateTraceId(), sampleRand: Math.random() });\n\n    this._notifyScopeListeners();\n    return this;\n  }\n\n  /**\n   * Adds a breadcrumb to the scope.\n   * By default, the last 100 breadcrumbs are kept.\n   */\n   addBreadcrumb(breadcrumb, maxBreadcrumbs) {\n    const maxCrumbs = typeof maxBreadcrumbs === 'number' ? maxBreadcrumbs : DEFAULT_MAX_BREADCRUMBS;\n\n    // No data has been changed, so don't notify scope listeners\n    if (maxCrumbs <= 0) {\n      return this;\n    }\n\n    const mergedBreadcrumb = {\n      timestamp: time.dateTimestampInSeconds(),\n      ...breadcrumb,\n      // Breadcrumb messages can theoretically be infinitely large and they're held in memory so we truncate them not to leak (too much) memory\n      message: breadcrumb.message ? string.truncate(breadcrumb.message, 2048) : breadcrumb.message,\n    };\n\n    this._breadcrumbs.push(mergedBreadcrumb);\n    if (this._breadcrumbs.length > maxCrumbs) {\n      this._breadcrumbs = this._breadcrumbs.slice(-maxCrumbs);\n      this._client?.recordDroppedEvent('buffer_overflow', 'log_item');\n    }\n\n    this._notifyScopeListeners();\n\n    return this;\n  }\n\n  /**\n   * Get the last breadcrumb of the scope.\n   */\n   getLastBreadcrumb() {\n    return this._breadcrumbs[this._breadcrumbs.length - 1];\n  }\n\n  /**\n   * Clear all breadcrumbs from the scope.\n   */\n   clearBreadcrumbs() {\n    this._breadcrumbs = [];\n    this._notifyScopeListeners();\n    return this;\n  }\n\n  /**\n   * Add an attachment to the scope.\n   */\n   addAttachment(attachment) {\n    this._attachments.push(attachment);\n    return this;\n  }\n\n  /**\n   * Clear all attachments from the scope.\n   */\n   clearAttachments() {\n    this._attachments = [];\n    return this;\n  }\n\n  /**\n   * Get the data of this scope, which should be applied to an event during processing.\n   */\n   getScopeData() {\n    return {\n      breadcrumbs: this._breadcrumbs,\n      attachments: this._attachments,\n      contexts: this._contexts,\n      tags: this._tags,\n      extra: this._extra,\n      user: this._user,\n      level: this._level,\n      fingerprint: this._fingerprint || [],\n      eventProcessors: this._eventProcessors,\n      propagationContext: this._propagationContext,\n      sdkProcessingMetadata: this._sdkProcessingMetadata,\n      transactionName: this._transactionName,\n      span: spanOnScope._getSpanForScope(this),\n    };\n  }\n\n  /**\n   * Add data which will be accessible during event processing but won't get sent to Sentry.\n   */\n   setSDKProcessingMetadata(newData) {\n    this._sdkProcessingMetadata = merge.merge(this._sdkProcessingMetadata, newData, 2);\n    return this;\n  }\n\n  /**\n   * Add propagation context to the scope, used for distributed tracing\n   */\n   setPropagationContext(context) {\n    this._propagationContext = context;\n    return this;\n  }\n\n  /**\n   * Get propagation context from the scope, used for distributed tracing\n   */\n   getPropagationContext() {\n    return this._propagationContext;\n  }\n\n  /**\n   * Capture an exception for this scope.\n   *\n   * @returns {string} The id of the captured Sentry event.\n   */\n   captureException(exception, hint) {\n    const eventId = hint?.event_id || misc.uuid4();\n\n    if (!this._client) {\n      debugBuild.DEBUG_BUILD && debugLogger.debug.warn('No client configured on scope - will not capture exception!');\n      return eventId;\n    }\n\n    const syntheticException = new Error('Sentry syntheticException');\n\n    this._client.captureException(\n      exception,\n      {\n        originalException: exception,\n        syntheticException,\n        ...hint,\n        event_id: eventId,\n      },\n      this,\n    );\n\n    return eventId;\n  }\n\n  /**\n   * Capture a message for this scope.\n   *\n   * @returns {string} The id of the captured message.\n   */\n   captureMessage(message, level, hint) {\n    const eventId = hint?.event_id || misc.uuid4();\n\n    if (!this._client) {\n      debugBuild.DEBUG_BUILD && debugLogger.debug.warn('No client configured on scope - will not capture message!');\n      return eventId;\n    }\n\n    const syntheticException = new Error(message);\n\n    this._client.captureMessage(\n      message,\n      level,\n      {\n        originalException: message,\n        syntheticException,\n        ...hint,\n        event_id: eventId,\n      },\n      this,\n    );\n\n    return eventId;\n  }\n\n  /**\n   * Capture a Sentry event for this scope.\n   *\n   * @returns {string} The id of the captured event.\n   */\n   captureEvent(event, hint) {\n    const eventId = hint?.event_id || misc.uuid4();\n\n    if (!this._client) {\n      debugBuild.DEBUG_BUILD && debugLogger.debug.warn('No client configured on scope - will not capture event!');\n      return eventId;\n    }\n\n    this._client.captureEvent(event, { ...hint, event_id: eventId }, this);\n\n    return eventId;\n  }\n\n  /**\n   * This will be called on every set call.\n   */\n   _notifyScopeListeners() {\n    // We need this check for this._notifyingListeners to be able to work on scope during updates\n    // If this check is not here we'll produce endless recursion when something is done with the scope\n    // during the callback.\n    if (!this._notifyingListeners) {\n      this._notifyingListeners = true;\n      this._scopeListeners.forEach(callback => {\n        callback(this);\n      });\n      this._notifyingListeners = false;\n    }\n  }\n}\n\nexports.Scope = Scope;\n//# sourceMappingURL=scope.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvc2NvcGUuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsbUJBQW1CLG1CQUFPLENBQUMsa0lBQWtCO0FBQzdDLGdCQUFnQixtQkFBTyxDQUFDLDBIQUFjO0FBQ3RDLG9CQUFvQixtQkFBTyxDQUFDLGdKQUF5QjtBQUNyRCxXQUFXLG1CQUFPLENBQUMsNEhBQWU7QUFDbEMsY0FBYyxtQkFBTyxDQUFDLGtJQUFrQjtBQUN4QyxhQUFhLG1CQUFPLENBQUMsZ0lBQWlCO0FBQ3RDLDJCQUEyQixtQkFBTyxDQUFDLDRKQUErQjtBQUNsRSxvQkFBb0IsbUJBQU8sQ0FBQyw4SUFBd0I7QUFDcEQsZUFBZSxtQkFBTyxDQUFDLG9JQUFtQjtBQUMxQyxhQUFhLG1CQUFPLENBQUMsZ0lBQWlCOztBQUV0QztBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7O0FBRUE7O0FBRUE7O0FBRUE7O0FBRUE7O0FBRUE7O0FBRUE7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBOztBQUVBOztBQUVBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLHVCQUF1QjtBQUN2Qix3QkFBd0I7QUFDeEIsMkJBQTJCO0FBQzNCO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0Esd0NBQXdDO0FBQ3hDLHFDQUFxQztBQUNyQztBQUNBOztBQUVBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0EsNkNBQTZDLE1BQU07QUFDbkQ7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQSxtQkFBbUI7QUFDbkI7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLG9CQUFvQjtBQUNwQjtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLGFBQWEsVUFBVTtBQUN2QjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxNQUFNO0FBQ047QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsTUFBTTtBQUNOO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSxZQUFZLDJFQUEyRTs7QUFFdkYsbUJBQW1CO0FBQ25CLG9CQUFvQjtBQUNwQix1QkFBdUI7O0FBRXZCO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxpQ0FBaUMsMEVBQTBFOztBQUUzRztBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0EsZUFBZSxRQUFRO0FBQ3ZCO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLE9BQU87QUFDUDtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0EsZUFBZSxRQUFRO0FBQ3ZCO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsT0FBTztBQUNQO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQSxlQUFlLFFBQVE7QUFDdkI7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLHVDQUF1Qyw0QkFBNEI7O0FBRW5FO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLE9BQU87QUFDUDtBQUNBO0FBQ0E7QUFDQTs7QUFFQSxhQUFhO0FBQ2IiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9zY29wZS5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgZGVidWdCdWlsZCA9IHJlcXVpcmUoJy4vZGVidWctYnVpbGQuanMnKTtcbmNvbnN0IHNlc3Npb24gPSByZXF1aXJlKCcuL3Nlc3Npb24uanMnKTtcbmNvbnN0IGRlYnVnTG9nZ2VyID0gcmVxdWlyZSgnLi91dGlscy9kZWJ1Zy1sb2dnZXIuanMnKTtcbmNvbnN0IGlzID0gcmVxdWlyZSgnLi91dGlscy9pcy5qcycpO1xuY29uc3QgbWVyZ2UgPSByZXF1aXJlKCcuL3V0aWxzL21lcmdlLmpzJyk7XG5jb25zdCBtaXNjID0gcmVxdWlyZSgnLi91dGlscy9taXNjLmpzJyk7XG5jb25zdCBwcm9wYWdhdGlvbkNvbnRleHQgPSByZXF1aXJlKCcuL3V0aWxzL3Byb3BhZ2F0aW9uQ29udGV4dC5qcycpO1xuY29uc3Qgc3Bhbk9uU2NvcGUgPSByZXF1aXJlKCcuL3V0aWxzL3NwYW5PblNjb3BlLmpzJyk7XG5jb25zdCBzdHJpbmcgPSByZXF1aXJlKCcuL3V0aWxzL3N0cmluZy5qcycpO1xuY29uc3QgdGltZSA9IHJlcXVpcmUoJy4vdXRpbHMvdGltZS5qcycpO1xuXG4vKipcbiAqIERlZmF1bHQgdmFsdWUgZm9yIG1heGltdW0gbnVtYmVyIG9mIGJyZWFkY3J1bWJzIGFkZGVkIHRvIGFuIGV2ZW50LlxuICovXG5jb25zdCBERUZBVUxUX01BWF9CUkVBRENSVU1CUyA9IDEwMDtcblxuLyoqXG4gKiBBIGNvbnRleHQgdG8gYmUgdXNlZCBmb3IgY2FwdHVyaW5nIGFuIGV2ZW50LlxuICogVGhpcyBjYW4gZWl0aGVyIGJlIGEgU2NvcGUsIG9yIGEgcGFydGlhbCBTY29wZUNvbnRleHQsXG4gKiBvciBhIGNhbGxiYWNrIHRoYXQgcmVjZWl2ZXMgdGhlIGN1cnJlbnQgc2NvcGUgYW5kIHJldHVybnMgYSBuZXcgc2NvcGUgdG8gdXNlLlxuICovXG5cbi8qKlxuICogSG9sZHMgYWRkaXRpb25hbCBldmVudCBpbmZvcm1hdGlvbi5cbiAqL1xuY2xhc3MgU2NvcGUge1xuICAvKiogRmxhZyBpZiBub3RpZnlpbmcgaXMgaGFwcGVuaW5nLiAqL1xuXG4gIC8qKiBDYWxsYmFjayBmb3IgY2xpZW50IHRvIHJlY2VpdmUgc2NvcGUgY2hhbmdlcy4gKi9cblxuICAvKiogQ2FsbGJhY2sgbGlzdCB0aGF0IHdpbGwgYmUgY2FsbGVkIGR1cmluZyBldmVudCBwcm9jZXNzaW5nLiAqL1xuXG4gIC8qKiBBcnJheSBvZiBicmVhZGNydW1icy4gKi9cblxuICAvKiogVXNlciAqL1xuXG4gIC8qKiBUYWdzICovXG5cbiAgLyoqIEV4dHJhICovXG5cbiAgLyoqIENvbnRleHRzICovXG5cbiAgLyoqIEF0dGFjaG1lbnRzICovXG5cbiAgLyoqIFByb3BhZ2F0aW9uIENvbnRleHQgZm9yIGRpc3RyaWJ1dGVkIHRyYWNpbmcgKi9cblxuICAvKipcbiAgICogQSBwbGFjZSB0byBzdGFzaCBkYXRhIHdoaWNoIGlzIG5lZWRlZCBhdCBzb21lIHBvaW50IGluIHRoZSBTREsncyBldmVudCBwcm9jZXNzaW5nIHBpcGVsaW5lIGJ1dCB3aGljaCBzaG91bGRuJ3QgZ2V0XG4gICAqIHNlbnQgdG8gU2VudHJ5XG4gICAqL1xuXG4gIC8qKiBGaW5nZXJwcmludCAqL1xuXG4gIC8qKiBTZXZlcml0eSAqL1xuXG4gIC8qKlxuICAgKiBUcmFuc2FjdGlvbiBOYW1lXG4gICAqXG4gICAqIElNUE9SVEFOVDogVGhlIHRyYW5zYWN0aW9uIG5hbWUgb24gdGhlIHNjb3BlIGhhcyBub3RoaW5nIHRvIGRvIHdpdGggcm9vdCBzcGFucy90cmFuc2FjdGlvbiBvYmplY3RzLlxuICAgKiBJdCdzIHB1cnBvc2UgaXMgdG8gYXNzaWduIGEgdHJhbnNhY3Rpb24gdG8gdGhlIHNjb3BlIHRoYXQncyBhZGRlZCB0byBub24tdHJhbnNhY3Rpb24gZXZlbnRzLlxuICAgKi9cblxuICAvKiogU2Vzc2lvbiAqL1xuXG4gIC8qKiBUaGUgY2xpZW50IG9uIHRoaXMgc2NvcGUgKi9cblxuICAvKiogQ29udGFpbnMgdGhlIGxhc3QgZXZlbnQgaWQgb2YgYSBjYXB0dXJlZCBldmVudC4gICovXG5cbiAgLy8gTk9URTogQW55IGZpZWxkIHdoaWNoIGdldHMgYWRkZWQgaGVyZSBzaG91bGQgZ2V0IGFkZGVkIG5vdCBvbmx5IHRvIHRoZSBjb25zdHJ1Y3RvciBidXQgYWxzbyB0byB0aGUgYGNsb25lYCBtZXRob2QuXG5cbiAgIGNvbnN0cnVjdG9yKCkge1xuICAgIHRoaXMuX25vdGlmeWluZ0xpc3RlbmVycyA9IGZhbHNlO1xuICAgIHRoaXMuX3Njb3BlTGlzdGVuZXJzID0gW107XG4gICAgdGhpcy5fZXZlbnRQcm9jZXNzb3JzID0gW107XG4gICAgdGhpcy5fYnJlYWRjcnVtYnMgPSBbXTtcbiAgICB0aGlzLl9hdHRhY2htZW50cyA9IFtdO1xuICAgIHRoaXMuX3VzZXIgPSB7fTtcbiAgICB0aGlzLl90YWdzID0ge307XG4gICAgdGhpcy5fZXh0cmEgPSB7fTtcbiAgICB0aGlzLl9jb250ZXh0cyA9IHt9O1xuICAgIHRoaXMuX3Nka1Byb2Nlc3NpbmdNZXRhZGF0YSA9IHt9O1xuICAgIHRoaXMuX3Byb3BhZ2F0aW9uQ29udGV4dCA9IHtcbiAgICAgIHRyYWNlSWQ6IHByb3BhZ2F0aW9uQ29udGV4dC5nZW5lcmF0ZVRyYWNlSWQoKSxcbiAgICAgIHNhbXBsZVJhbmQ6IE1hdGgucmFuZG9tKCksXG4gICAgfTtcbiAgfVxuXG4gIC8qKlxuICAgKiBDbG9uZSBhbGwgZGF0YSBmcm9tIHRoaXMgc2NvcGUgaW50byBhIG5ldyBzY29wZS5cbiAgICovXG4gICBjbG9uZSgpIHtcbiAgICBjb25zdCBuZXdTY29wZSA9IG5ldyBTY29wZSgpO1xuICAgIG5ld1Njb3BlLl9icmVhZGNydW1icyA9IFsuLi50aGlzLl9icmVhZGNydW1ic107XG4gICAgbmV3U2NvcGUuX3RhZ3MgPSB7IC4uLnRoaXMuX3RhZ3MgfTtcbiAgICBuZXdTY29wZS5fZXh0cmEgPSB7IC4uLnRoaXMuX2V4dHJhIH07XG4gICAgbmV3U2NvcGUuX2NvbnRleHRzID0geyAuLi50aGlzLl9jb250ZXh0cyB9O1xuICAgIGlmICh0aGlzLl9jb250ZXh0cy5mbGFncykge1xuICAgICAgLy8gV2UgbmVlZCB0byBjb3B5IHRoZSBgdmFsdWVzYCBhcnJheSBzbyBpbnNlcnRpb25zIG9uIGEgY2xvbmVkIHNjb3BlXG4gICAgICAvLyB3b24ndCBhZmZlY3QgdGhlIG9yaWdpbmFsIGFycmF5LlxuICAgICAgbmV3U2NvcGUuX2NvbnRleHRzLmZsYWdzID0ge1xuICAgICAgICB2YWx1ZXM6IFsuLi50aGlzLl9jb250ZXh0cy5mbGFncy52YWx1ZXNdLFxuICAgICAgfTtcbiAgICB9XG5cbiAgICBuZXdTY29wZS5fdXNlciA9IHRoaXMuX3VzZXI7XG4gICAgbmV3U2NvcGUuX2xldmVsID0gdGhpcy5fbGV2ZWw7XG4gICAgbmV3U2NvcGUuX3Nlc3Npb24gPSB0aGlzLl9zZXNzaW9uO1xuICAgIG5ld1Njb3BlLl90cmFuc2FjdGlvbk5hbWUgPSB0aGlzLl90cmFuc2FjdGlvbk5hbWU7XG4gICAgbmV3U2NvcGUuX2ZpbmdlcnByaW50ID0gdGhpcy5fZmluZ2VycHJpbnQ7XG4gICAgbmV3U2NvcGUuX2V2ZW50UHJvY2Vzc29ycyA9IFsuLi50aGlzLl9ldmVudFByb2Nlc3NvcnNdO1xuICAgIG5ld1Njb3BlLl9hdHRhY2htZW50cyA9IFsuLi50aGlzLl9hdHRhY2htZW50c107XG4gICAgbmV3U2NvcGUuX3Nka1Byb2Nlc3NpbmdNZXRhZGF0YSA9IHsgLi4udGhpcy5fc2RrUHJvY2Vzc2luZ01ldGFkYXRhIH07XG4gICAgbmV3U2NvcGUuX3Byb3BhZ2F0aW9uQ29udGV4dCA9IHsgLi4udGhpcy5fcHJvcGFnYXRpb25Db250ZXh0IH07XG4gICAgbmV3U2NvcGUuX2NsaWVudCA9IHRoaXMuX2NsaWVudDtcbiAgICBuZXdTY29wZS5fbGFzdEV2ZW50SWQgPSB0aGlzLl9sYXN0RXZlbnRJZDtcblxuICAgIHNwYW5PblNjb3BlLl9zZXRTcGFuRm9yU2NvcGUobmV3U2NvcGUsIHNwYW5PblNjb3BlLl9nZXRTcGFuRm9yU2NvcGUodGhpcykpO1xuXG4gICAgcmV0dXJuIG5ld1Njb3BlO1xuICB9XG5cbiAgLyoqXG4gICAqIFVwZGF0ZSB0aGUgY2xpZW50IGFzc2lnbmVkIHRvIHRoaXMgc2NvcGUuXG4gICAqIE5vdGUgdGhhdCBub3QgZXZlcnkgc2NvcGUgd2lsbCBoYXZlIGEgY2xpZW50IGFzc2lnbmVkIC0gaXNvbGF0aW9uIHNjb3BlcyAmIHRoZSBnbG9iYWwgc2NvcGUgd2lsbCBnZW5lcmFsbHkgbm90IGhhdmUgYSBjbGllbnQsXG4gICAqIGFzIHdlbGwgYXMgbWFudWFsbHkgY3JlYXRlZCBzY29wZXMuXG4gICAqL1xuICAgc2V0Q2xpZW50KGNsaWVudCkge1xuICAgIHRoaXMuX2NsaWVudCA9IGNsaWVudDtcbiAgfVxuXG4gIC8qKlxuICAgKiBTZXQgdGhlIElEIG9mIHRoZSBsYXN0IGNhcHR1cmVkIGVycm9yIGV2ZW50LlxuICAgKiBUaGlzIGlzIGdlbmVyYWxseSBvbmx5IGNhcHR1cmVkIG9uIHRoZSBpc29sYXRpb24gc2NvcGUuXG4gICAqL1xuICAgc2V0TGFzdEV2ZW50SWQobGFzdEV2ZW50SWQpIHtcbiAgICB0aGlzLl9sYXN0RXZlbnRJZCA9IGxhc3RFdmVudElkO1xuICB9XG5cbiAgLyoqXG4gICAqIEdldCB0aGUgY2xpZW50IGFzc2lnbmVkIHRvIHRoaXMgc2NvcGUuXG4gICAqL1xuICAgZ2V0Q2xpZW50KCkge1xuICAgIHJldHVybiB0aGlzLl9jbGllbnQgO1xuICB9XG5cbiAgLyoqXG4gICAqIEdldCB0aGUgSUQgb2YgdGhlIGxhc3QgY2FwdHVyZWQgZXJyb3IgZXZlbnQuXG4gICAqIFRoaXMgaXMgZ2VuZXJhbGx5IG9ubHkgYXZhaWxhYmxlIG9uIHRoZSBpc29sYXRpb24gc2NvcGUuXG4gICAqL1xuICAgbGFzdEV2ZW50SWQoKSB7XG4gICAgcmV0dXJuIHRoaXMuX2xhc3RFdmVudElkO1xuICB9XG5cbiAgLyoqXG4gICAqIEBpbmhlcml0RG9jXG4gICAqL1xuICAgYWRkU2NvcGVMaXN0ZW5lcihjYWxsYmFjaykge1xuICAgIHRoaXMuX3Njb3BlTGlzdGVuZXJzLnB1c2goY2FsbGJhY2spO1xuICB9XG5cbiAgLyoqXG4gICAqIEFkZCBhbiBldmVudCBwcm9jZXNzb3IgdGhhdCB3aWxsIGJlIGNhbGxlZCBiZWZvcmUgYW4gZXZlbnQgaXMgc2VudC5cbiAgICovXG4gICBhZGRFdmVudFByb2Nlc3NvcihjYWxsYmFjaykge1xuICAgIHRoaXMuX2V2ZW50UHJvY2Vzc29ycy5wdXNoKGNhbGxiYWNrKTtcbiAgICByZXR1cm4gdGhpcztcbiAgfVxuXG4gIC8qKlxuICAgKiBTZXQgdGhlIHVzZXIgZm9yIHRoaXMgc2NvcGUuXG4gICAqIFNldCB0byBgbnVsbGAgdG8gdW5zZXQgdGhlIHVzZXIuXG4gICAqL1xuICAgc2V0VXNlcih1c2VyKSB7XG4gICAgLy8gSWYgbnVsbCBpcyBwYXNzZWQgd2Ugd2FudCB0byB1bnNldCBldmVyeXRoaW5nLCBidXQgc3RpbGwgZGVmaW5lIGtleXMsXG4gICAgLy8gc28gdGhhdCBsYXRlciBkb3duIGluIHRoZSBwaXBlbGluZSBhbnkgZXhpc3RpbmcgdmFsdWVzIGFyZSBjbGVhcmVkLlxuICAgIHRoaXMuX3VzZXIgPSB1c2VyIHx8IHtcbiAgICAgIGVtYWlsOiB1bmRlZmluZWQsXG4gICAgICBpZDogdW5kZWZpbmVkLFxuICAgICAgaXBfYWRkcmVzczogdW5kZWZpbmVkLFxuICAgICAgdXNlcm5hbWU6IHVuZGVmaW5lZCxcbiAgICB9O1xuXG4gICAgaWYgKHRoaXMuX3Nlc3Npb24pIHtcbiAgICAgIHNlc3Npb24udXBkYXRlU2Vzc2lvbih0aGlzLl9zZXNzaW9uLCB7IHVzZXIgfSk7XG4gICAgfVxuXG4gICAgdGhpcy5fbm90aWZ5U2NvcGVMaXN0ZW5lcnMoKTtcbiAgICByZXR1cm4gdGhpcztcbiAgfVxuXG4gIC8qKlxuICAgKiBHZXQgdGhlIHVzZXIgZnJvbSB0aGlzIHNjb3BlLlxuICAgKi9cbiAgIGdldFVzZXIoKSB7XG4gICAgcmV0dXJuIHRoaXMuX3VzZXI7XG4gIH1cblxuICAvKipcbiAgICogU2V0IGFuIG9iamVjdCB0aGF0IHdpbGwgYmUgbWVyZ2VkIGludG8gZXhpc3RpbmcgdGFncyBvbiB0aGUgc2NvcGUsXG4gICAqIGFuZCB3aWxsIGJlIHNlbnQgYXMgdGFncyBkYXRhIHdpdGggdGhlIGV2ZW50LlxuICAgKi9cbiAgIHNldFRhZ3ModGFncykge1xuICAgIHRoaXMuX3RhZ3MgPSB7XG4gICAgICAuLi50aGlzLl90YWdzLFxuICAgICAgLi4udGFncyxcbiAgICB9O1xuICAgIHRoaXMuX25vdGlmeVNjb3BlTGlzdGVuZXJzKCk7XG4gICAgcmV0dXJuIHRoaXM7XG4gIH1cblxuICAvKipcbiAgICogU2V0IGEgc2luZ2xlIHRhZyB0aGF0IHdpbGwgYmUgc2VudCBhcyB0YWdzIGRhdGEgd2l0aCB0aGUgZXZlbnQuXG4gICAqL1xuICAgc2V0VGFnKGtleSwgdmFsdWUpIHtcbiAgICB0aGlzLl90YWdzID0geyAuLi50aGlzLl90YWdzLCBba2V5XTogdmFsdWUgfTtcbiAgICB0aGlzLl9ub3RpZnlTY29wZUxpc3RlbmVycygpO1xuICAgIHJldHVybiB0aGlzO1xuICB9XG5cbiAgLyoqXG4gICAqIFNldCBhbiBvYmplY3QgdGhhdCB3aWxsIGJlIG1lcmdlZCBpbnRvIGV4aXN0aW5nIGV4dHJhIG9uIHRoZSBzY29wZSxcbiAgICogYW5kIHdpbGwgYmUgc2VudCBhcyBleHRyYSBkYXRhIHdpdGggdGhlIGV2ZW50LlxuICAgKi9cbiAgIHNldEV4dHJhcyhleHRyYXMpIHtcbiAgICB0aGlzLl9leHRyYSA9IHtcbiAgICAgIC4uLnRoaXMuX2V4dHJhLFxuICAgICAgLi4uZXh0cmFzLFxuICAgIH07XG4gICAgdGhpcy5fbm90aWZ5U2NvcGVMaXN0ZW5lcnMoKTtcbiAgICByZXR1cm4gdGhpcztcbiAgfVxuXG4gIC8qKlxuICAgKiBTZXQgYSBzaW5nbGUga2V5OnZhbHVlIGV4dHJhIGVudHJ5IHRoYXQgd2lsbCBiZSBzZW50IGFzIGV4dHJhIGRhdGEgd2l0aCB0aGUgZXZlbnQuXG4gICAqL1xuICAgc2V0RXh0cmEoa2V5LCBleHRyYSkge1xuICAgIHRoaXMuX2V4dHJhID0geyAuLi50aGlzLl9leHRyYSwgW2tleV06IGV4dHJhIH07XG4gICAgdGhpcy5fbm90aWZ5U2NvcGVMaXN0ZW5lcnMoKTtcbiAgICByZXR1cm4gdGhpcztcbiAgfVxuXG4gIC8qKlxuICAgKiBTZXRzIHRoZSBmaW5nZXJwcmludCBvbiB0aGUgc2NvcGUgdG8gc2VuZCB3aXRoIHRoZSBldmVudHMuXG4gICAqIEBwYXJhbSB7c3RyaW5nW119IGZpbmdlcnByaW50IEZpbmdlcnByaW50IHRvIGdyb3VwIGV2ZW50cyBpbiBTZW50cnkuXG4gICAqL1xuICAgc2V0RmluZ2VycHJpbnQoZmluZ2VycHJpbnQpIHtcbiAgICB0aGlzLl9maW5nZXJwcmludCA9IGZpbmdlcnByaW50O1xuICAgIHRoaXMuX25vdGlmeVNjb3BlTGlzdGVuZXJzKCk7XG4gICAgcmV0dXJuIHRoaXM7XG4gIH1cblxuICAvKipcbiAgICogU2V0cyB0aGUgbGV2ZWwgb24gdGhlIHNjb3BlIGZvciBmdXR1cmUgZXZlbnRzLlxuICAgKi9cbiAgIHNldExldmVsKGxldmVsKSB7XG4gICAgdGhpcy5fbGV2ZWwgPSBsZXZlbDtcbiAgICB0aGlzLl9ub3RpZnlTY29wZUxpc3RlbmVycygpO1xuICAgIHJldHVybiB0aGlzO1xuICB9XG5cbiAgLyoqXG4gICAqIFNldHMgdGhlIHRyYW5zYWN0aW9uIG5hbWUgb24gdGhlIHNjb3BlIHNvIHRoYXQgdGhlIG5hbWUgb2YgZS5nLiB0YWtlbiBzZXJ2ZXIgcm91dGUgb3JcbiAgICogdGhlIHBhZ2UgbG9jYXRpb24gaXMgYXR0YWNoZWQgdG8gZnV0dXJlIGV2ZW50cy5cbiAgICpcbiAgICogSU1QT1JUQU5UOiBDYWxsaW5nIHRoaXMgZnVuY3Rpb24gZG9lcyBOT1QgY2hhbmdlIHRoZSBuYW1lIG9mIHRoZSBjdXJyZW50bHkgYWN0aXZlXG4gICAqIHJvb3Qgc3Bhbi4gSWYgeW91IHdhbnQgdG8gY2hhbmdlIHRoZSBuYW1lIG9mIHRoZSBhY3RpdmUgcm9vdCBzcGFuLCB1c2VcbiAgICogYFNlbnRyeS51cGRhdGVTcGFuTmFtZShyb290U3BhbiwgJ25ldyBuYW1lJylgIGluc3RlYWQuXG4gICAqXG4gICAqIEJ5IGRlZmF1bHQsIHRoZSBTREsgdXBkYXRlcyB0aGUgc2NvcGUncyB0cmFuc2FjdGlvbiBuYW1lIGF1dG9tYXRpY2FsbHkgb24gc2Vuc2libGVcbiAgICogb2NjYXNpb25zLCBzdWNoIGFzIGEgcGFnZSBuYXZpZ2F0aW9uIG9yIHdoZW4gaGFuZGxpbmcgYSBuZXcgcmVxdWVzdCBvbiB0aGUgc2VydmVyLlxuICAgKi9cbiAgIHNldFRyYW5zYWN0aW9uTmFtZShuYW1lKSB7XG4gICAgdGhpcy5fdHJhbnNhY3Rpb25OYW1lID0gbmFtZTtcbiAgICB0aGlzLl9ub3RpZnlTY29wZUxpc3RlbmVycygpO1xuICAgIHJldHVybiB0aGlzO1xuICB9XG5cbiAgLyoqXG4gICAqIFNldHMgY29udGV4dCBkYXRhIHdpdGggdGhlIGdpdmVuIG5hbWUuXG4gICAqIERhdGEgcGFzc2VkIGFzIGNvbnRleHQgd2lsbCBiZSBub3JtYWxpemVkLiBZb3UgY2FuIGFsc28gcGFzcyBgbnVsbGAgdG8gdW5zZXQgdGhlIGNvbnRleHQuXG4gICAqIE5vdGUgdGhhdCBjb250ZXh0IGRhdGEgd2lsbCBub3QgYmUgbWVyZ2VkIC0gY2FsbGluZyBgc2V0Q29udGV4dGAgd2lsbCBvdmVyd3JpdGUgYW4gZXhpc3RpbmcgY29udGV4dCB3aXRoIHRoZSBzYW1lIGtleS5cbiAgICovXG4gICBzZXRDb250ZXh0KGtleSwgY29udGV4dCkge1xuICAgIGlmIChjb250ZXh0ID09PSBudWxsKSB7XG4gICAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25vLWR5bmFtaWMtZGVsZXRlXG4gICAgICBkZWxldGUgdGhpcy5fY29udGV4dHNba2V5XTtcbiAgICB9IGVsc2Uge1xuICAgICAgdGhpcy5fY29udGV4dHNba2V5XSA9IGNvbnRleHQ7XG4gICAgfVxuXG4gICAgdGhpcy5fbm90aWZ5U2NvcGVMaXN0ZW5lcnMoKTtcbiAgICByZXR1cm4gdGhpcztcbiAgfVxuXG4gIC8qKlxuICAgKiBTZXQgdGhlIHNlc3Npb24gZm9yIHRoZSBzY29wZS5cbiAgICovXG4gICBzZXRTZXNzaW9uKHNlc3Npb24pIHtcbiAgICBpZiAoIXNlc3Npb24pIHtcbiAgICAgIGRlbGV0ZSB0aGlzLl9zZXNzaW9uO1xuICAgIH0gZWxzZSB7XG4gICAgICB0aGlzLl9zZXNzaW9uID0gc2Vzc2lvbjtcbiAgICB9XG4gICAgdGhpcy5fbm90aWZ5U2NvcGVMaXN0ZW5lcnMoKTtcbiAgICByZXR1cm4gdGhpcztcbiAgfVxuXG4gIC8qKlxuICAgKiBHZXQgdGhlIHNlc3Npb24gZnJvbSB0aGUgc2NvcGUuXG4gICAqL1xuICAgZ2V0U2Vzc2lvbigpIHtcbiAgICByZXR1cm4gdGhpcy5fc2Vzc2lvbjtcbiAgfVxuXG4gIC8qKlxuICAgKiBVcGRhdGVzIHRoZSBzY29wZSB3aXRoIHByb3ZpZGVkIGRhdGEuIENhbiB3b3JrIGluIHRocmVlIHZhcmlhdGlvbnM6XG4gICAqIC0gcGxhaW4gb2JqZWN0IGNvbnRhaW5pbmcgdXBkYXRhYmxlIGF0dHJpYnV0ZXNcbiAgICogLSBTY29wZSBpbnN0YW5jZSB0aGF0J2xsIGV4dHJhY3QgdGhlIGF0dHJpYnV0ZXMgZnJvbVxuICAgKiAtIGNhbGxiYWNrIGZ1bmN0aW9uIHRoYXQnbGwgcmVjZWl2ZSB0aGUgY3VycmVudCBzY29wZSBhcyBhbiBhcmd1bWVudCBhbmQgYWxsb3cgZm9yIG1vZGlmaWNhdGlvbnNcbiAgICovXG4gICB1cGRhdGUoY2FwdHVyZUNvbnRleHQpIHtcbiAgICBpZiAoIWNhcHR1cmVDb250ZXh0KSB7XG4gICAgICByZXR1cm4gdGhpcztcbiAgICB9XG5cbiAgICBjb25zdCBzY29wZVRvTWVyZ2UgPSB0eXBlb2YgY2FwdHVyZUNvbnRleHQgPT09ICdmdW5jdGlvbicgPyBjYXB0dXJlQ29udGV4dCh0aGlzKSA6IGNhcHR1cmVDb250ZXh0O1xuXG4gICAgY29uc3Qgc2NvcGVJbnN0YW5jZSA9XG4gICAgICBzY29wZVRvTWVyZ2UgaW5zdGFuY2VvZiBTY29wZVxuICAgICAgICA/IHNjb3BlVG9NZXJnZS5nZXRTY29wZURhdGEoKVxuICAgICAgICA6IGlzLmlzUGxhaW5PYmplY3Qoc2NvcGVUb01lcmdlKVxuICAgICAgICAgID8gKGNhcHR1cmVDb250ZXh0IClcbiAgICAgICAgICA6IHVuZGVmaW5lZDtcblxuICAgIGNvbnN0IHsgdGFncywgZXh0cmEsIHVzZXIsIGNvbnRleHRzLCBsZXZlbCwgZmluZ2VycHJpbnQgPSBbXSwgcHJvcGFnYXRpb25Db250ZXh0IH0gPSBzY29wZUluc3RhbmNlIHx8IHt9O1xuXG4gICAgdGhpcy5fdGFncyA9IHsgLi4udGhpcy5fdGFncywgLi4udGFncyB9O1xuICAgIHRoaXMuX2V4dHJhID0geyAuLi50aGlzLl9leHRyYSwgLi4uZXh0cmEgfTtcbiAgICB0aGlzLl9jb250ZXh0cyA9IHsgLi4udGhpcy5fY29udGV4dHMsIC4uLmNvbnRleHRzIH07XG5cbiAgICBpZiAodXNlciAmJiBPYmplY3Qua2V5cyh1c2VyKS5sZW5ndGgpIHtcbiAgICAgIHRoaXMuX3VzZXIgPSB1c2VyO1xuICAgIH1cblxuICAgIGlmIChsZXZlbCkge1xuICAgICAgdGhpcy5fbGV2ZWwgPSBsZXZlbDtcbiAgICB9XG5cbiAgICBpZiAoZmluZ2VycHJpbnQubGVuZ3RoKSB7XG4gICAgICB0aGlzLl9maW5nZXJwcmludCA9IGZpbmdlcnByaW50O1xuICAgIH1cblxuICAgIGlmIChwcm9wYWdhdGlvbkNvbnRleHQpIHtcbiAgICAgIHRoaXMuX3Byb3BhZ2F0aW9uQ29udGV4dCA9IHByb3BhZ2F0aW9uQ29udGV4dDtcbiAgICB9XG5cbiAgICByZXR1cm4gdGhpcztcbiAgfVxuXG4gIC8qKlxuICAgKiBDbGVhcnMgdGhlIGN1cnJlbnQgc2NvcGUgYW5kIHJlc2V0cyBpdHMgcHJvcGVydGllcy5cbiAgICogTm90ZTogVGhlIGNsaWVudCB3aWxsIG5vdCBiZSBjbGVhcmVkLlxuICAgKi9cbiAgIGNsZWFyKCkge1xuICAgIC8vIGNsaWVudCBpcyBub3QgY2xlYXJlZCBoZXJlIG9uIHB1cnBvc2UhXG4gICAgdGhpcy5fYnJlYWRjcnVtYnMgPSBbXTtcbiAgICB0aGlzLl90YWdzID0ge307XG4gICAgdGhpcy5fZXh0cmEgPSB7fTtcbiAgICB0aGlzLl91c2VyID0ge307XG4gICAgdGhpcy5fY29udGV4dHMgPSB7fTtcbiAgICB0aGlzLl9sZXZlbCA9IHVuZGVmaW5lZDtcbiAgICB0aGlzLl90cmFuc2FjdGlvbk5hbWUgPSB1bmRlZmluZWQ7XG4gICAgdGhpcy5fZmluZ2VycHJpbnQgPSB1bmRlZmluZWQ7XG4gICAgdGhpcy5fc2Vzc2lvbiA9IHVuZGVmaW5lZDtcbiAgICBzcGFuT25TY29wZS5fc2V0U3BhbkZvclNjb3BlKHRoaXMsIHVuZGVmaW5lZCk7XG4gICAgdGhpcy5fYXR0YWNobWVudHMgPSBbXTtcbiAgICB0aGlzLnNldFByb3BhZ2F0aW9uQ29udGV4dCh7IHRyYWNlSWQ6IHByb3BhZ2F0aW9uQ29udGV4dC5nZW5lcmF0ZVRyYWNlSWQoKSwgc2FtcGxlUmFuZDogTWF0aC5yYW5kb20oKSB9KTtcblxuICAgIHRoaXMuX25vdGlmeVNjb3BlTGlzdGVuZXJzKCk7XG4gICAgcmV0dXJuIHRoaXM7XG4gIH1cblxuICAvKipcbiAgICogQWRkcyBhIGJyZWFkY3J1bWIgdG8gdGhlIHNjb3BlLlxuICAgKiBCeSBkZWZhdWx0LCB0aGUgbGFzdCAxMDAgYnJlYWRjcnVtYnMgYXJlIGtlcHQuXG4gICAqL1xuICAgYWRkQnJlYWRjcnVtYihicmVhZGNydW1iLCBtYXhCcmVhZGNydW1icykge1xuICAgIGNvbnN0IG1heENydW1icyA9IHR5cGVvZiBtYXhCcmVhZGNydW1icyA9PT0gJ251bWJlcicgPyBtYXhCcmVhZGNydW1icyA6IERFRkFVTFRfTUFYX0JSRUFEQ1JVTUJTO1xuXG4gICAgLy8gTm8gZGF0YSBoYXMgYmVlbiBjaGFuZ2VkLCBzbyBkb24ndCBub3RpZnkgc2NvcGUgbGlzdGVuZXJzXG4gICAgaWYgKG1heENydW1icyA8PSAwKSB7XG4gICAgICByZXR1cm4gdGhpcztcbiAgICB9XG5cbiAgICBjb25zdCBtZXJnZWRCcmVhZGNydW1iID0ge1xuICAgICAgdGltZXN0YW1wOiB0aW1lLmRhdGVUaW1lc3RhbXBJblNlY29uZHMoKSxcbiAgICAgIC4uLmJyZWFkY3J1bWIsXG4gICAgICAvLyBCcmVhZGNydW1iIG1lc3NhZ2VzIGNhbiB0aGVvcmV0aWNhbGx5IGJlIGluZmluaXRlbHkgbGFyZ2UgYW5kIHRoZXkncmUgaGVsZCBpbiBtZW1vcnkgc28gd2UgdHJ1bmNhdGUgdGhlbSBub3QgdG8gbGVhayAodG9vIG11Y2gpIG1lbW9yeVxuICAgICAgbWVzc2FnZTogYnJlYWRjcnVtYi5tZXNzYWdlID8gc3RyaW5nLnRydW5jYXRlKGJyZWFkY3J1bWIubWVzc2FnZSwgMjA0OCkgOiBicmVhZGNydW1iLm1lc3NhZ2UsXG4gICAgfTtcblxuICAgIHRoaXMuX2JyZWFkY3J1bWJzLnB1c2gobWVyZ2VkQnJlYWRjcnVtYik7XG4gICAgaWYgKHRoaXMuX2JyZWFkY3J1bWJzLmxlbmd0aCA+IG1heENydW1icykge1xuICAgICAgdGhpcy5fYnJlYWRjcnVtYnMgPSB0aGlzLl9icmVhZGNydW1icy5zbGljZSgtbWF4Q3J1bWJzKTtcbiAgICAgIHRoaXMuX2NsaWVudD8ucmVjb3JkRHJvcHBlZEV2ZW50KCdidWZmZXJfb3ZlcmZsb3cnLCAnbG9nX2l0ZW0nKTtcbiAgICB9XG5cbiAgICB0aGlzLl9ub3RpZnlTY29wZUxpc3RlbmVycygpO1xuXG4gICAgcmV0dXJuIHRoaXM7XG4gIH1cblxuICAvKipcbiAgICogR2V0IHRoZSBsYXN0IGJyZWFkY3J1bWIgb2YgdGhlIHNjb3BlLlxuICAgKi9cbiAgIGdldExhc3RCcmVhZGNydW1iKCkge1xuICAgIHJldHVybiB0aGlzLl9icmVhZGNydW1ic1t0aGlzLl9icmVhZGNydW1icy5sZW5ndGggLSAxXTtcbiAgfVxuXG4gIC8qKlxuICAgKiBDbGVhciBhbGwgYnJlYWRjcnVtYnMgZnJvbSB0aGUgc2NvcGUuXG4gICAqL1xuICAgY2xlYXJCcmVhZGNydW1icygpIHtcbiAgICB0aGlzLl9icmVhZGNydW1icyA9IFtdO1xuICAgIHRoaXMuX25vdGlmeVNjb3BlTGlzdGVuZXJzKCk7XG4gICAgcmV0dXJuIHRoaXM7XG4gIH1cblxuICAvKipcbiAgICogQWRkIGFuIGF0dGFjaG1lbnQgdG8gdGhlIHNjb3BlLlxuICAgKi9cbiAgIGFkZEF0dGFjaG1lbnQoYXR0YWNobWVudCkge1xuICAgIHRoaXMuX2F0dGFjaG1lbnRzLnB1c2goYXR0YWNobWVudCk7XG4gICAgcmV0dXJuIHRoaXM7XG4gIH1cblxuICAvKipcbiAgICogQ2xlYXIgYWxsIGF0dGFjaG1lbnRzIGZyb20gdGhlIHNjb3BlLlxuICAgKi9cbiAgIGNsZWFyQXR0YWNobWVudHMoKSB7XG4gICAgdGhpcy5fYXR0YWNobWVudHMgPSBbXTtcbiAgICByZXR1cm4gdGhpcztcbiAgfVxuXG4gIC8qKlxuICAgKiBHZXQgdGhlIGRhdGEgb2YgdGhpcyBzY29wZSwgd2hpY2ggc2hvdWxkIGJlIGFwcGxpZWQgdG8gYW4gZXZlbnQgZHVyaW5nIHByb2Nlc3NpbmcuXG4gICAqL1xuICAgZ2V0U2NvcGVEYXRhKCkge1xuICAgIHJldHVybiB7XG4gICAgICBicmVhZGNydW1iczogdGhpcy5fYnJlYWRjcnVtYnMsXG4gICAgICBhdHRhY2htZW50czogdGhpcy5fYXR0YWNobWVudHMsXG4gICAgICBjb250ZXh0czogdGhpcy5fY29udGV4dHMsXG4gICAgICB0YWdzOiB0aGlzLl90YWdzLFxuICAgICAgZXh0cmE6IHRoaXMuX2V4dHJhLFxuICAgICAgdXNlcjogdGhpcy5fdXNlcixcbiAgICAgIGxldmVsOiB0aGlzLl9sZXZlbCxcbiAgICAgIGZpbmdlcnByaW50OiB0aGlzLl9maW5nZXJwcmludCB8fCBbXSxcbiAgICAgIGV2ZW50UHJvY2Vzc29yczogdGhpcy5fZXZlbnRQcm9jZXNzb3JzLFxuICAgICAgcHJvcGFnYXRpb25Db250ZXh0OiB0aGlzLl9wcm9wYWdhdGlvbkNvbnRleHQsXG4gICAgICBzZGtQcm9jZXNzaW5nTWV0YWRhdGE6IHRoaXMuX3Nka1Byb2Nlc3NpbmdNZXRhZGF0YSxcbiAgICAgIHRyYW5zYWN0aW9uTmFtZTogdGhpcy5fdHJhbnNhY3Rpb25OYW1lLFxuICAgICAgc3Bhbjogc3Bhbk9uU2NvcGUuX2dldFNwYW5Gb3JTY29wZSh0aGlzKSxcbiAgICB9O1xuICB9XG5cbiAgLyoqXG4gICAqIEFkZCBkYXRhIHdoaWNoIHdpbGwgYmUgYWNjZXNzaWJsZSBkdXJpbmcgZXZlbnQgcHJvY2Vzc2luZyBidXQgd29uJ3QgZ2V0IHNlbnQgdG8gU2VudHJ5LlxuICAgKi9cbiAgIHNldFNES1Byb2Nlc3NpbmdNZXRhZGF0YShuZXdEYXRhKSB7XG4gICAgdGhpcy5fc2RrUHJvY2Vzc2luZ01ldGFkYXRhID0gbWVyZ2UubWVyZ2UodGhpcy5fc2RrUHJvY2Vzc2luZ01ldGFkYXRhLCBuZXdEYXRhLCAyKTtcbiAgICByZXR1cm4gdGhpcztcbiAgfVxuXG4gIC8qKlxuICAgKiBBZGQgcHJvcGFnYXRpb24gY29udGV4dCB0byB0aGUgc2NvcGUsIHVzZWQgZm9yIGRpc3RyaWJ1dGVkIHRyYWNpbmdcbiAgICovXG4gICBzZXRQcm9wYWdhdGlvbkNvbnRleHQoY29udGV4dCkge1xuICAgIHRoaXMuX3Byb3BhZ2F0aW9uQ29udGV4dCA9IGNvbnRleHQ7XG4gICAgcmV0dXJuIHRoaXM7XG4gIH1cblxuICAvKipcbiAgICogR2V0IHByb3BhZ2F0aW9uIGNvbnRleHQgZnJvbSB0aGUgc2NvcGUsIHVzZWQgZm9yIGRpc3RyaWJ1dGVkIHRyYWNpbmdcbiAgICovXG4gICBnZXRQcm9wYWdhdGlvbkNvbnRleHQoKSB7XG4gICAgcmV0dXJuIHRoaXMuX3Byb3BhZ2F0aW9uQ29udGV4dDtcbiAgfVxuXG4gIC8qKlxuICAgKiBDYXB0dXJlIGFuIGV4Y2VwdGlvbiBmb3IgdGhpcyBzY29wZS5cbiAgICpcbiAgICogQHJldHVybnMge3N0cmluZ30gVGhlIGlkIG9mIHRoZSBjYXB0dXJlZCBTZW50cnkgZXZlbnQuXG4gICAqL1xuICAgY2FwdHVyZUV4Y2VwdGlvbihleGNlcHRpb24sIGhpbnQpIHtcbiAgICBjb25zdCBldmVudElkID0gaGludD8uZXZlbnRfaWQgfHwgbWlzYy51dWlkNCgpO1xuXG4gICAgaWYgKCF0aGlzLl9jbGllbnQpIHtcbiAgICAgIGRlYnVnQnVpbGQuREVCVUdfQlVJTEQgJiYgZGVidWdMb2dnZXIuZGVidWcud2FybignTm8gY2xpZW50IGNvbmZpZ3VyZWQgb24gc2NvcGUgLSB3aWxsIG5vdCBjYXB0dXJlIGV4Y2VwdGlvbiEnKTtcbiAgICAgIHJldHVybiBldmVudElkO1xuICAgIH1cblxuICAgIGNvbnN0IHN5bnRoZXRpY0V4Y2VwdGlvbiA9IG5ldyBFcnJvcignU2VudHJ5IHN5bnRoZXRpY0V4Y2VwdGlvbicpO1xuXG4gICAgdGhpcy5fY2xpZW50LmNhcHR1cmVFeGNlcHRpb24oXG4gICAgICBleGNlcHRpb24sXG4gICAgICB7XG4gICAgICAgIG9yaWdpbmFsRXhjZXB0aW9uOiBleGNlcHRpb24sXG4gICAgICAgIHN5bnRoZXRpY0V4Y2VwdGlvbixcbiAgICAgICAgLi4uaGludCxcbiAgICAgICAgZXZlbnRfaWQ6IGV2ZW50SWQsXG4gICAgICB9LFxuICAgICAgdGhpcyxcbiAgICApO1xuXG4gICAgcmV0dXJuIGV2ZW50SWQ7XG4gIH1cblxuICAvKipcbiAgICogQ2FwdHVyZSBhIG1lc3NhZ2UgZm9yIHRoaXMgc2NvcGUuXG4gICAqXG4gICAqIEByZXR1cm5zIHtzdHJpbmd9IFRoZSBpZCBvZiB0aGUgY2FwdHVyZWQgbWVzc2FnZS5cbiAgICovXG4gICBjYXB0dXJlTWVzc2FnZShtZXNzYWdlLCBsZXZlbCwgaGludCkge1xuICAgIGNvbnN0IGV2ZW50SWQgPSBoaW50Py5ldmVudF9pZCB8fCBtaXNjLnV1aWQ0KCk7XG5cbiAgICBpZiAoIXRoaXMuX2NsaWVudCkge1xuICAgICAgZGVidWdCdWlsZC5ERUJVR19CVUlMRCAmJiBkZWJ1Z0xvZ2dlci5kZWJ1Zy53YXJuKCdObyBjbGllbnQgY29uZmlndXJlZCBvbiBzY29wZSAtIHdpbGwgbm90IGNhcHR1cmUgbWVzc2FnZSEnKTtcbiAgICAgIHJldHVybiBldmVudElkO1xuICAgIH1cblxuICAgIGNvbnN0IHN5bnRoZXRpY0V4Y2VwdGlvbiA9IG5ldyBFcnJvcihtZXNzYWdlKTtcblxuICAgIHRoaXMuX2NsaWVudC5jYXB0dXJlTWVzc2FnZShcbiAgICAgIG1lc3NhZ2UsXG4gICAgICBsZXZlbCxcbiAgICAgIHtcbiAgICAgICAgb3JpZ2luYWxFeGNlcHRpb246IG1lc3NhZ2UsXG4gICAgICAgIHN5bnRoZXRpY0V4Y2VwdGlvbixcbiAgICAgICAgLi4uaGludCxcbiAgICAgICAgZXZlbnRfaWQ6IGV2ZW50SWQsXG4gICAgICB9LFxuICAgICAgdGhpcyxcbiAgICApO1xuXG4gICAgcmV0dXJuIGV2ZW50SWQ7XG4gIH1cblxuICAvKipcbiAgICogQ2FwdHVyZSBhIFNlbnRyeSBldmVudCBmb3IgdGhpcyBzY29wZS5cbiAgICpcbiAgICogQHJldHVybnMge3N0cmluZ30gVGhlIGlkIG9mIHRoZSBjYXB0dXJlZCBldmVudC5cbiAgICovXG4gICBjYXB0dXJlRXZlbnQoZXZlbnQsIGhpbnQpIHtcbiAgICBjb25zdCBldmVudElkID0gaGludD8uZXZlbnRfaWQgfHwgbWlzYy51dWlkNCgpO1xuXG4gICAgaWYgKCF0aGlzLl9jbGllbnQpIHtcbiAgICAgIGRlYnVnQnVpbGQuREVCVUdfQlVJTEQgJiYgZGVidWdMb2dnZXIuZGVidWcud2FybignTm8gY2xpZW50IGNvbmZpZ3VyZWQgb24gc2NvcGUgLSB3aWxsIG5vdCBjYXB0dXJlIGV2ZW50IScpO1xuICAgICAgcmV0dXJuIGV2ZW50SWQ7XG4gICAgfVxuXG4gICAgdGhpcy5fY2xpZW50LmNhcHR1cmVFdmVudChldmVudCwgeyAuLi5oaW50LCBldmVudF9pZDogZXZlbnRJZCB9LCB0aGlzKTtcblxuICAgIHJldHVybiBldmVudElkO1xuICB9XG5cbiAgLyoqXG4gICAqIFRoaXMgd2lsbCBiZSBjYWxsZWQgb24gZXZlcnkgc2V0IGNhbGwuXG4gICAqL1xuICAgX25vdGlmeVNjb3BlTGlzdGVuZXJzKCkge1xuICAgIC8vIFdlIG5lZWQgdGhpcyBjaGVjayBmb3IgdGhpcy5fbm90aWZ5aW5nTGlzdGVuZXJzIHRvIGJlIGFibGUgdG8gd29yayBvbiBzY29wZSBkdXJpbmcgdXBkYXRlc1xuICAgIC8vIElmIHRoaXMgY2hlY2sgaXMgbm90IGhlcmUgd2UnbGwgcHJvZHVjZSBlbmRsZXNzIHJlY3Vyc2lvbiB3aGVuIHNvbWV0aGluZyBpcyBkb25lIHdpdGggdGhlIHNjb3BlXG4gICAgLy8gZHVyaW5nIHRoZSBjYWxsYmFjay5cbiAgICBpZiAoIXRoaXMuX25vdGlmeWluZ0xpc3RlbmVycykge1xuICAgICAgdGhpcy5fbm90aWZ5aW5nTGlzdGVuZXJzID0gdHJ1ZTtcbiAgICAgIHRoaXMuX3Njb3BlTGlzdGVuZXJzLmZvckVhY2goY2FsbGJhY2sgPT4ge1xuICAgICAgICBjYWxsYmFjayh0aGlzKTtcbiAgICAgIH0pO1xuICAgICAgdGhpcy5fbm90aWZ5aW5nTGlzdGVuZXJzID0gZmFsc2U7XG4gICAgfVxuICB9XG59XG5cbmV4cG9ydHMuU2NvcGUgPSBTY29wZTtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPXNjb3BlLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/scope.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/sdk.js":
/*!*******************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/sdk.js ***!
  \*******************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst currentScopes = __webpack_require__(/*! ./currentScopes.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst debugBuild = __webpack_require__(/*! ./debug-build.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst debugLogger = __webpack_require__(/*! ./utils/debug-logger.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\n\n/** A class object that can instantiate Client objects. */\n\n/**\n * Internal function to create a new SDK client instance. The client is\n * installed and then bound to the current scope.\n *\n * @param clientClass The client class to instantiate.\n * @param options Options to pass to the client.\n */\nfunction initAndBind(\n  clientClass,\n  options,\n) {\n  if (options.debug === true) {\n    if (debugBuild.DEBUG_BUILD) {\n      debugLogger.debug.enable();\n    } else {\n      // use `console.warn` rather than `debug.warn` since by non-debug bundles have all `debug.x` statements stripped\n      debugLogger.consoleSandbox(() => {\n        // eslint-disable-next-line no-console\n        console.warn('[Sentry] Cannot initialize SDK with `debug` option using a non-debug bundle.');\n      });\n    }\n  }\n  const scope = currentScopes.getCurrentScope();\n  scope.update(options.initialScope);\n\n  const client = new clientClass(options);\n  setCurrentClient(client);\n  client.init();\n  return client;\n}\n\n/**\n * Make the given client the current client.\n */\nfunction setCurrentClient(client) {\n  currentScopes.getCurrentScope().setClient(client);\n}\n\nexports.initAndBind = initAndBind;\nexports.setCurrentClient = setCurrentClient;\n//# sourceMappingURL=sdk.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvc2RrLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLHNCQUFzQixtQkFBTyxDQUFDLHNJQUFvQjtBQUNsRCxtQkFBbUIsbUJBQU8sQ0FBQyxrSUFBa0I7QUFDN0Msb0JBQW9CLG1CQUFPLENBQUMsZ0pBQXlCOztBQUVyRDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsTUFBTTtBQUNOO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsT0FBTztBQUNQO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLG1CQUFtQjtBQUNuQix3QkFBd0I7QUFDeEIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9zZGsuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGN1cnJlbnRTY29wZXMgPSByZXF1aXJlKCcuL2N1cnJlbnRTY29wZXMuanMnKTtcbmNvbnN0IGRlYnVnQnVpbGQgPSByZXF1aXJlKCcuL2RlYnVnLWJ1aWxkLmpzJyk7XG5jb25zdCBkZWJ1Z0xvZ2dlciA9IHJlcXVpcmUoJy4vdXRpbHMvZGVidWctbG9nZ2VyLmpzJyk7XG5cbi8qKiBBIGNsYXNzIG9iamVjdCB0aGF0IGNhbiBpbnN0YW50aWF0ZSBDbGllbnQgb2JqZWN0cy4gKi9cblxuLyoqXG4gKiBJbnRlcm5hbCBmdW5jdGlvbiB0byBjcmVhdGUgYSBuZXcgU0RLIGNsaWVudCBpbnN0YW5jZS4gVGhlIGNsaWVudCBpc1xuICogaW5zdGFsbGVkIGFuZCB0aGVuIGJvdW5kIHRvIHRoZSBjdXJyZW50IHNjb3BlLlxuICpcbiAqIEBwYXJhbSBjbGllbnRDbGFzcyBUaGUgY2xpZW50IGNsYXNzIHRvIGluc3RhbnRpYXRlLlxuICogQHBhcmFtIG9wdGlvbnMgT3B0aW9ucyB0byBwYXNzIHRvIHRoZSBjbGllbnQuXG4gKi9cbmZ1bmN0aW9uIGluaXRBbmRCaW5kKFxuICBjbGllbnRDbGFzcyxcbiAgb3B0aW9ucyxcbikge1xuICBpZiAob3B0aW9ucy5kZWJ1ZyA9PT0gdHJ1ZSkge1xuICAgIGlmIChkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEKSB7XG4gICAgICBkZWJ1Z0xvZ2dlci5kZWJ1Zy5lbmFibGUoKTtcbiAgICB9IGVsc2Uge1xuICAgICAgLy8gdXNlIGBjb25zb2xlLndhcm5gIHJhdGhlciB0aGFuIGBkZWJ1Zy53YXJuYCBzaW5jZSBieSBub24tZGVidWcgYnVuZGxlcyBoYXZlIGFsbCBgZGVidWcueGAgc3RhdGVtZW50cyBzdHJpcHBlZFxuICAgICAgZGVidWdMb2dnZXIuY29uc29sZVNhbmRib3goKCkgPT4ge1xuICAgICAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgbm8tY29uc29sZVxuICAgICAgICBjb25zb2xlLndhcm4oJ1tTZW50cnldIENhbm5vdCBpbml0aWFsaXplIFNESyB3aXRoIGBkZWJ1Z2Agb3B0aW9uIHVzaW5nIGEgbm9uLWRlYnVnIGJ1bmRsZS4nKTtcbiAgICAgIH0pO1xuICAgIH1cbiAgfVxuICBjb25zdCBzY29wZSA9IGN1cnJlbnRTY29wZXMuZ2V0Q3VycmVudFNjb3BlKCk7XG4gIHNjb3BlLnVwZGF0ZShvcHRpb25zLmluaXRpYWxTY29wZSk7XG5cbiAgY29uc3QgY2xpZW50ID0gbmV3IGNsaWVudENsYXNzKG9wdGlvbnMpO1xuICBzZXRDdXJyZW50Q2xpZW50KGNsaWVudCk7XG4gIGNsaWVudC5pbml0KCk7XG4gIHJldHVybiBjbGllbnQ7XG59XG5cbi8qKlxuICogTWFrZSB0aGUgZ2l2ZW4gY2xpZW50IHRoZSBjdXJyZW50IGNsaWVudC5cbiAqL1xuZnVuY3Rpb24gc2V0Q3VycmVudENsaWVudChjbGllbnQpIHtcbiAgY3VycmVudFNjb3Blcy5nZXRDdXJyZW50U2NvcGUoKS5zZXRDbGllbnQoY2xpZW50KTtcbn1cblxuZXhwb3J0cy5pbml0QW5kQmluZCA9IGluaXRBbmRCaW5kO1xuZXhwb3J0cy5zZXRDdXJyZW50Q2xpZW50ID0gc2V0Q3VycmVudENsaWVudDtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPXNkay5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/sdk.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/semanticAttributes.js":
/*!**********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/semanticAttributes.js ***!
  \**********************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n/**\n * Use this attribute to represent the source of a span.\n * Should be one of: custom, url, route, view, component, task, unknown\n *\n */\nconst SEMANTIC_ATTRIBUTE_SENTRY_SOURCE = 'sentry.source';\n\n/**\n * Attributes that holds the sample rate that was locally applied to a span.\n * If this attribute is not defined, it means that the span inherited a sampling decision.\n *\n * NOTE: Is only defined on root spans.\n */\nconst SEMANTIC_ATTRIBUTE_SENTRY_SAMPLE_RATE = 'sentry.sample_rate';\n\n/**\n * Attribute holding the sample rate of the previous trace.\n * This is used to sample consistently across subsequent traces in the browser SDK.\n *\n * Note: Only defined on root spans, if opted into consistent sampling\n */\nconst SEMANTIC_ATTRIBUTE_SENTRY_PREVIOUS_TRACE_SAMPLE_RATE = 'sentry.previous_trace_sample_rate';\n\n/**\n * Use this attribute to represent the operation of a span.\n */\nconst SEMANTIC_ATTRIBUTE_SENTRY_OP = 'sentry.op';\n\n/**\n * Use this attribute to represent the origin of a span.\n */\nconst SEMANTIC_ATTRIBUTE_SENTRY_ORIGIN = 'sentry.origin';\n\n/** The reason why an idle span finished. */\nconst SEMANTIC_ATTRIBUTE_SENTRY_IDLE_SPAN_FINISH_REASON = 'sentry.idle_span_finish_reason';\n\n/** The unit of a measurement, which may be stored as a TimedEvent. */\nconst SEMANTIC_ATTRIBUTE_SENTRY_MEASUREMENT_UNIT = 'sentry.measurement_unit';\n\n/** The value of a measurement, which may be stored as a TimedEvent. */\nconst SEMANTIC_ATTRIBUTE_SENTRY_MEASUREMENT_VALUE = 'sentry.measurement_value';\n\n/**\n * A custom span name set by users guaranteed to be taken over any automatically\n * inferred name. This attribute is removed before the span is sent.\n *\n * @internal only meant for internal SDK usage\n * @hidden\n */\nconst SEMANTIC_ATTRIBUTE_SENTRY_CUSTOM_SPAN_NAME = 'sentry.custom_span_name';\n\n/**\n * The id of the profile that this span occurred in.\n */\nconst SEMANTIC_ATTRIBUTE_PROFILE_ID = 'sentry.profile_id';\n\nconst SEMANTIC_ATTRIBUTE_EXCLUSIVE_TIME = 'sentry.exclusive_time';\n\nconst SEMANTIC_ATTRIBUTE_CACHE_HIT = 'cache.hit';\n\nconst SEMANTIC_ATTRIBUTE_CACHE_KEY = 'cache.key';\n\nconst SEMANTIC_ATTRIBUTE_CACHE_ITEM_SIZE = 'cache.item_size';\n\n/** TODO: Remove these once we update to latest semantic conventions */\nconst SEMANTIC_ATTRIBUTE_HTTP_REQUEST_METHOD = 'http.request.method';\nconst SEMANTIC_ATTRIBUTE_URL_FULL = 'url.full';\n\n/**\n * A span link attribute to mark the link as a special span link.\n *\n * Known values:\n * - `previous_trace`: The span links to the frontend root span of the previous trace.\n * - `next_trace`: The span links to the frontend root span of the next trace. (Not set by the SDK)\n *\n * Other values may be set as appropriate.\n * @see https://develop.sentry.dev/sdk/telemetry/traces/span-links/#link-types\n */\nconst SEMANTIC_LINK_ATTRIBUTE_LINK_TYPE = 'sentry.link.type';\n\nexports.SEMANTIC_ATTRIBUTE_CACHE_HIT = SEMANTIC_ATTRIBUTE_CACHE_HIT;\nexports.SEMANTIC_ATTRIBUTE_CACHE_ITEM_SIZE = SEMANTIC_ATTRIBUTE_CACHE_ITEM_SIZE;\nexports.SEMANTIC_ATTRIBUTE_CACHE_KEY = SEMANTIC_ATTRIBUTE_CACHE_KEY;\nexports.SEMANTIC_ATTRIBUTE_EXCLUSIVE_TIME = SEMANTIC_ATTRIBUTE_EXCLUSIVE_TIME;\nexports.SEMANTIC_ATTRIBUTE_HTTP_REQUEST_METHOD = SEMANTIC_ATTRIBUTE_HTTP_REQUEST_METHOD;\nexports.SEMANTIC_ATTRIBUTE_PROFILE_ID = SEMANTIC_ATTRIBUTE_PROFILE_ID;\nexports.SEMANTIC_ATTRIBUTE_SENTRY_CUSTOM_SPAN_NAME = SEMANTIC_ATTRIBUTE_SENTRY_CUSTOM_SPAN_NAME;\nexports.SEMANTIC_ATTRIBUTE_SENTRY_IDLE_SPAN_FINISH_REASON = SEMANTIC_ATTRIBUTE_SENTRY_IDLE_SPAN_FINISH_REASON;\nexports.SEMANTIC_ATTRIBUTE_SENTRY_MEASUREMENT_UNIT = SEMANTIC_ATTRIBUTE_SENTRY_MEASUREMENT_UNIT;\nexports.SEMANTIC_ATTRIBUTE_SENTRY_MEASUREMENT_VALUE = SEMANTIC_ATTRIBUTE_SENTRY_MEASUREMENT_VALUE;\nexports.SEMANTIC_ATTRIBUTE_SENTRY_OP = SEMANTIC_ATTRIBUTE_SENTRY_OP;\nexports.SEMANTIC_ATTRIBUTE_SENTRY_ORIGIN = SEMANTIC_ATTRIBUTE_SENTRY_ORIGIN;\nexports.SEMANTIC_ATTRIBUTE_SENTRY_PREVIOUS_TRACE_SAMPLE_RATE = SEMANTIC_ATTRIBUTE_SENTRY_PREVIOUS_TRACE_SAMPLE_RATE;\nexports.SEMANTIC_ATTRIBUTE_SENTRY_SAMPLE_RATE = SEMANTIC_ATTRIBUTE_SENTRY_SAMPLE_RATE;\nexports.SEMANTIC_ATTRIBUTE_SENTRY_SOURCE = SEMANTIC_ATTRIBUTE_SENTRY_SOURCE;\nexports.SEMANTIC_ATTRIBUTE_URL_FULL = SEMANTIC_ATTRIBUTE_URL_FULL;\nexports.SEMANTIC_LINK_ATTRIBUTE_LINK_TYPE = SEMANTIC_LINK_ATTRIBUTE_LINK_TYPE;\n//# sourceMappingURL=semanticAttributes.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvc2VtYW50aWNBdHRyaWJ1dGVzLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBOztBQUVBOztBQUVBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLG9DQUFvQztBQUNwQywwQ0FBMEM7QUFDMUMsb0NBQW9DO0FBQ3BDLHlDQUF5QztBQUN6Qyw4Q0FBOEM7QUFDOUMscUNBQXFDO0FBQ3JDLGtEQUFrRDtBQUNsRCx5REFBeUQ7QUFDekQsa0RBQWtEO0FBQ2xELG1EQUFtRDtBQUNuRCxvQ0FBb0M7QUFDcEMsd0NBQXdDO0FBQ3hDLDREQUE0RDtBQUM1RCw2Q0FBNkM7QUFDN0Msd0NBQXdDO0FBQ3hDLG1DQUFtQztBQUNuQyx5Q0FBeUM7QUFDekMiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9zZW1hbnRpY0F0dHJpYnV0ZXMuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbi8qKlxuICogVXNlIHRoaXMgYXR0cmlidXRlIHRvIHJlcHJlc2VudCB0aGUgc291cmNlIG9mIGEgc3Bhbi5cbiAqIFNob3VsZCBiZSBvbmUgb2Y6IGN1c3RvbSwgdXJsLCByb3V0ZSwgdmlldywgY29tcG9uZW50LCB0YXNrLCB1bmtub3duXG4gKlxuICovXG5jb25zdCBTRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX1NPVVJDRSA9ICdzZW50cnkuc291cmNlJztcblxuLyoqXG4gKiBBdHRyaWJ1dGVzIHRoYXQgaG9sZHMgdGhlIHNhbXBsZSByYXRlIHRoYXQgd2FzIGxvY2FsbHkgYXBwbGllZCB0byBhIHNwYW4uXG4gKiBJZiB0aGlzIGF0dHJpYnV0ZSBpcyBub3QgZGVmaW5lZCwgaXQgbWVhbnMgdGhhdCB0aGUgc3BhbiBpbmhlcml0ZWQgYSBzYW1wbGluZyBkZWNpc2lvbi5cbiAqXG4gKiBOT1RFOiBJcyBvbmx5IGRlZmluZWQgb24gcm9vdCBzcGFucy5cbiAqL1xuY29uc3QgU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9TQU1QTEVfUkFURSA9ICdzZW50cnkuc2FtcGxlX3JhdGUnO1xuXG4vKipcbiAqIEF0dHJpYnV0ZSBob2xkaW5nIHRoZSBzYW1wbGUgcmF0ZSBvZiB0aGUgcHJldmlvdXMgdHJhY2UuXG4gKiBUaGlzIGlzIHVzZWQgdG8gc2FtcGxlIGNvbnNpc3RlbnRseSBhY3Jvc3Mgc3Vic2VxdWVudCB0cmFjZXMgaW4gdGhlIGJyb3dzZXIgU0RLLlxuICpcbiAqIE5vdGU6IE9ubHkgZGVmaW5lZCBvbiByb290IHNwYW5zLCBpZiBvcHRlZCBpbnRvIGNvbnNpc3RlbnQgc2FtcGxpbmdcbiAqL1xuY29uc3QgU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9QUkVWSU9VU19UUkFDRV9TQU1QTEVfUkFURSA9ICdzZW50cnkucHJldmlvdXNfdHJhY2Vfc2FtcGxlX3JhdGUnO1xuXG4vKipcbiAqIFVzZSB0aGlzIGF0dHJpYnV0ZSB0byByZXByZXNlbnQgdGhlIG9wZXJhdGlvbiBvZiBhIHNwYW4uXG4gKi9cbmNvbnN0IFNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfT1AgPSAnc2VudHJ5Lm9wJztcblxuLyoqXG4gKiBVc2UgdGhpcyBhdHRyaWJ1dGUgdG8gcmVwcmVzZW50IHRoZSBvcmlnaW4gb2YgYSBzcGFuLlxuICovXG5jb25zdCBTRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX09SSUdJTiA9ICdzZW50cnkub3JpZ2luJztcblxuLyoqIFRoZSByZWFzb24gd2h5IGFuIGlkbGUgc3BhbiBmaW5pc2hlZC4gKi9cbmNvbnN0IFNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfSURMRV9TUEFOX0ZJTklTSF9SRUFTT04gPSAnc2VudHJ5LmlkbGVfc3Bhbl9maW5pc2hfcmVhc29uJztcblxuLyoqIFRoZSB1bml0IG9mIGEgbWVhc3VyZW1lbnQsIHdoaWNoIG1heSBiZSBzdG9yZWQgYXMgYSBUaW1lZEV2ZW50LiAqL1xuY29uc3QgU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9NRUFTVVJFTUVOVF9VTklUID0gJ3NlbnRyeS5tZWFzdXJlbWVudF91bml0JztcblxuLyoqIFRoZSB2YWx1ZSBvZiBhIG1lYXN1cmVtZW50LCB3aGljaCBtYXkgYmUgc3RvcmVkIGFzIGEgVGltZWRFdmVudC4gKi9cbmNvbnN0IFNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfTUVBU1VSRU1FTlRfVkFMVUUgPSAnc2VudHJ5Lm1lYXN1cmVtZW50X3ZhbHVlJztcblxuLyoqXG4gKiBBIGN1c3RvbSBzcGFuIG5hbWUgc2V0IGJ5IHVzZXJzIGd1YXJhbnRlZWQgdG8gYmUgdGFrZW4gb3ZlciBhbnkgYXV0b21hdGljYWxseVxuICogaW5mZXJyZWQgbmFtZS4gVGhpcyBhdHRyaWJ1dGUgaXMgcmVtb3ZlZCBiZWZvcmUgdGhlIHNwYW4gaXMgc2VudC5cbiAqXG4gKiBAaW50ZXJuYWwgb25seSBtZWFudCBmb3IgaW50ZXJuYWwgU0RLIHVzYWdlXG4gKiBAaGlkZGVuXG4gKi9cbmNvbnN0IFNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfQ1VTVE9NX1NQQU5fTkFNRSA9ICdzZW50cnkuY3VzdG9tX3NwYW5fbmFtZSc7XG5cbi8qKlxuICogVGhlIGlkIG9mIHRoZSBwcm9maWxlIHRoYXQgdGhpcyBzcGFuIG9jY3VycmVkIGluLlxuICovXG5jb25zdCBTRU1BTlRJQ19BVFRSSUJVVEVfUFJPRklMRV9JRCA9ICdzZW50cnkucHJvZmlsZV9pZCc7XG5cbmNvbnN0IFNFTUFOVElDX0FUVFJJQlVURV9FWENMVVNJVkVfVElNRSA9ICdzZW50cnkuZXhjbHVzaXZlX3RpbWUnO1xuXG5jb25zdCBTRU1BTlRJQ19BVFRSSUJVVEVfQ0FDSEVfSElUID0gJ2NhY2hlLmhpdCc7XG5cbmNvbnN0IFNFTUFOVElDX0FUVFJJQlVURV9DQUNIRV9LRVkgPSAnY2FjaGUua2V5JztcblxuY29uc3QgU0VNQU5USUNfQVRUUklCVVRFX0NBQ0hFX0lURU1fU0laRSA9ICdjYWNoZS5pdGVtX3NpemUnO1xuXG4vKiogVE9ETzogUmVtb3ZlIHRoZXNlIG9uY2Ugd2UgdXBkYXRlIHRvIGxhdGVzdCBzZW1hbnRpYyBjb252ZW50aW9ucyAqL1xuY29uc3QgU0VNQU5USUNfQVRUUklCVVRFX0hUVFBfUkVRVUVTVF9NRVRIT0QgPSAnaHR0cC5yZXF1ZXN0Lm1ldGhvZCc7XG5jb25zdCBTRU1BTlRJQ19BVFRSSUJVVEVfVVJMX0ZVTEwgPSAndXJsLmZ1bGwnO1xuXG4vKipcbiAqIEEgc3BhbiBsaW5rIGF0dHJpYnV0ZSB0byBtYXJrIHRoZSBsaW5rIGFzIGEgc3BlY2lhbCBzcGFuIGxpbmsuXG4gKlxuICogS25vd24gdmFsdWVzOlxuICogLSBgcHJldmlvdXNfdHJhY2VgOiBUaGUgc3BhbiBsaW5rcyB0byB0aGUgZnJvbnRlbmQgcm9vdCBzcGFuIG9mIHRoZSBwcmV2aW91cyB0cmFjZS5cbiAqIC0gYG5leHRfdHJhY2VgOiBUaGUgc3BhbiBsaW5rcyB0byB0aGUgZnJvbnRlbmQgcm9vdCBzcGFuIG9mIHRoZSBuZXh0IHRyYWNlLiAoTm90IHNldCBieSB0aGUgU0RLKVxuICpcbiAqIE90aGVyIHZhbHVlcyBtYXkgYmUgc2V0IGFzIGFwcHJvcHJpYXRlLlxuICogQHNlZSBodHRwczovL2RldmVsb3Auc2VudHJ5LmRldi9zZGsvdGVsZW1ldHJ5L3RyYWNlcy9zcGFuLWxpbmtzLyNsaW5rLXR5cGVzXG4gKi9cbmNvbnN0IFNFTUFOVElDX0xJTktfQVRUUklCVVRFX0xJTktfVFlQRSA9ICdzZW50cnkubGluay50eXBlJztcblxuZXhwb3J0cy5TRU1BTlRJQ19BVFRSSUJVVEVfQ0FDSEVfSElUID0gU0VNQU5USUNfQVRUUklCVVRFX0NBQ0hFX0hJVDtcbmV4cG9ydHMuU0VNQU5USUNfQVRUUklCVVRFX0NBQ0hFX0lURU1fU0laRSA9IFNFTUFOVElDX0FUVFJJQlVURV9DQUNIRV9JVEVNX1NJWkU7XG5leHBvcnRzLlNFTUFOVElDX0FUVFJJQlVURV9DQUNIRV9LRVkgPSBTRU1BTlRJQ19BVFRSSUJVVEVfQ0FDSEVfS0VZO1xuZXhwb3J0cy5TRU1BTlRJQ19BVFRSSUJVVEVfRVhDTFVTSVZFX1RJTUUgPSBTRU1BTlRJQ19BVFRSSUJVVEVfRVhDTFVTSVZFX1RJTUU7XG5leHBvcnRzLlNFTUFOVElDX0FUVFJJQlVURV9IVFRQX1JFUVVFU1RfTUVUSE9EID0gU0VNQU5USUNfQVRUUklCVVRFX0hUVFBfUkVRVUVTVF9NRVRIT0Q7XG5leHBvcnRzLlNFTUFOVElDX0FUVFJJQlVURV9QUk9GSUxFX0lEID0gU0VNQU5USUNfQVRUUklCVVRFX1BST0ZJTEVfSUQ7XG5leHBvcnRzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfQ1VTVE9NX1NQQU5fTkFNRSA9IFNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfQ1VTVE9NX1NQQU5fTkFNRTtcbmV4cG9ydHMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9JRExFX1NQQU5fRklOSVNIX1JFQVNPTiA9IFNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfSURMRV9TUEFOX0ZJTklTSF9SRUFTT047XG5leHBvcnRzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfTUVBU1VSRU1FTlRfVU5JVCA9IFNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfTUVBU1VSRU1FTlRfVU5JVDtcbmV4cG9ydHMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9NRUFTVVJFTUVOVF9WQUxVRSA9IFNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfTUVBU1VSRU1FTlRfVkFMVUU7XG5leHBvcnRzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfT1AgPSBTRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX09QO1xuZXhwb3J0cy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX09SSUdJTiA9IFNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfT1JJR0lOO1xuZXhwb3J0cy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX1BSRVZJT1VTX1RSQUNFX1NBTVBMRV9SQVRFID0gU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9QUkVWSU9VU19UUkFDRV9TQU1QTEVfUkFURTtcbmV4cG9ydHMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9TQU1QTEVfUkFURSA9IFNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfU0FNUExFX1JBVEU7XG5leHBvcnRzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfU09VUkNFID0gU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9TT1VSQ0U7XG5leHBvcnRzLlNFTUFOVElDX0FUVFJJQlVURV9VUkxfRlVMTCA9IFNFTUFOVElDX0FUVFJJQlVURV9VUkxfRlVMTDtcbmV4cG9ydHMuU0VNQU5USUNfTElOS19BVFRSSUJVVEVfTElOS19UWVBFID0gU0VNQU5USUNfTElOS19BVFRSSUJVVEVfTElOS19UWVBFO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9c2VtYW50aWNBdHRyaWJ1dGVzLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/semanticAttributes.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/server-runtime-client.js":
/*!*************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/server-runtime-client.js ***!
  \*************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst checkin = __webpack_require__(/*! ./checkin.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/checkin.js\");\nconst client = __webpack_require__(/*! ./client.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/client.js\");\nconst currentScopes = __webpack_require__(/*! ./currentScopes.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst debugBuild = __webpack_require__(/*! ./debug-build.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst exports$1 = __webpack_require__(/*! ./logs/exports.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/logs/exports.js\");\nconst errors = __webpack_require__(/*! ./tracing/errors.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/errors.js\");\nconst is = __webpack_require__(/*! ./utils/is.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js\");\nconst debugLogger = __webpack_require__(/*! ./utils/debug-logger.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst misc = __webpack_require__(/*! ./utils/misc.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/misc.js\");\nconst eventbuilder = __webpack_require__(/*! ./utils/eventbuilder.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/eventbuilder.js\");\nconst syncpromise = __webpack_require__(/*! ./utils/syncpromise.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/syncpromise.js\");\n\n// TODO: Make this configurable\nconst DEFAULT_LOG_FLUSH_INTERVAL = 5000;\n\n/**\n * The Sentry Server Runtime Client SDK.\n */\nclass ServerRuntimeClient\n\n extends client.Client {\n\n  /**\n   * Creates a new Edge SDK instance.\n   * @param options Configuration options for this SDK.\n   */\n   constructor(options) {\n    // Server clients always support tracing\n    errors.registerSpanErrorInstrumentation();\n\n    super(options);\n\n    this._logWeight = 0;\n\n    // eslint-disable-next-line deprecation/deprecation\n    const shouldEnableLogs = this._options.enableLogs ?? this._options._experiments?.enableLogs;\n    if (shouldEnableLogs) {\n      // eslint-disable-next-line @typescript-eslint/no-this-alias\n      const client = this;\n\n      client.on('flushLogs', () => {\n        client._logWeight = 0;\n        clearTimeout(client._logFlushIdleTimeout);\n      });\n\n      client.on('afterCaptureLog', log => {\n        client._logWeight += estimateLogSizeInBytes(log);\n\n        // We flush the logs buffer if it exceeds 0.8 MB\n        // The log weight is a rough estimate, so we flush way before\n        // the payload gets too big.\n        if (client._logWeight >= 800000) {\n          exports$1._INTERNAL_flushLogsBuffer(client);\n        } else {\n          // start an idle timeout to flush the logs buffer if no logs are captured for a while\n          client._logFlushIdleTimeout = setTimeout(() => {\n            exports$1._INTERNAL_flushLogsBuffer(client);\n          }, DEFAULT_LOG_FLUSH_INTERVAL);\n        }\n      });\n\n      client.on('flush', () => {\n        exports$1._INTERNAL_flushLogsBuffer(client);\n      });\n    }\n  }\n\n  /**\n   * @inheritDoc\n   */\n   eventFromException(exception, hint) {\n    const event = eventbuilder.eventFromUnknownInput(this, this._options.stackParser, exception, hint);\n    event.level = 'error';\n\n    return syncpromise.resolvedSyncPromise(event);\n  }\n\n  /**\n   * @inheritDoc\n   */\n   eventFromMessage(\n    message,\n    level = 'info',\n    hint,\n  ) {\n    return syncpromise.resolvedSyncPromise(\n      eventbuilder.eventFromMessage(this._options.stackParser, message, level, hint, this._options.attachStacktrace),\n    );\n  }\n\n  /**\n   * @inheritDoc\n   */\n   captureException(exception, hint, scope) {\n    setCurrentRequestSessionErroredOrCrashed(hint);\n    return super.captureException(exception, hint, scope);\n  }\n\n  /**\n   * @inheritDoc\n   */\n   captureEvent(event, hint, scope) {\n    // If the event is of type Exception, then a request session should be captured\n    const isException = !event.type && event.exception?.values && event.exception.values.length > 0;\n    if (isException) {\n      setCurrentRequestSessionErroredOrCrashed(hint);\n    }\n\n    return super.captureEvent(event, hint, scope);\n  }\n\n  /**\n   * Create a cron monitor check in and send it to Sentry.\n   *\n   * @param checkIn An object that describes a check in.\n   * @param upsertMonitorConfig An optional object that describes a monitor config. Use this if you want\n   * to create a monitor automatically when sending a check in.\n   */\n   captureCheckIn(checkIn, monitorConfig, scope) {\n    const id = 'checkInId' in checkIn && checkIn.checkInId ? checkIn.checkInId : misc.uuid4();\n    if (!this._isEnabled()) {\n      debugBuild.DEBUG_BUILD && debugLogger.debug.warn('SDK not enabled, will not capture check-in.');\n      return id;\n    }\n\n    const options = this.getOptions();\n    const { release, environment, tunnel } = options;\n\n    const serializedCheckIn = {\n      check_in_id: id,\n      monitor_slug: checkIn.monitorSlug,\n      status: checkIn.status,\n      release,\n      environment,\n    };\n\n    if ('duration' in checkIn) {\n      serializedCheckIn.duration = checkIn.duration;\n    }\n\n    if (monitorConfig) {\n      serializedCheckIn.monitor_config = {\n        schedule: monitorConfig.schedule,\n        checkin_margin: monitorConfig.checkinMargin,\n        max_runtime: monitorConfig.maxRuntime,\n        timezone: monitorConfig.timezone,\n        failure_issue_threshold: monitorConfig.failureIssueThreshold,\n        recovery_threshold: monitorConfig.recoveryThreshold,\n      };\n    }\n\n    const [dynamicSamplingContext, traceContext] = client._getTraceInfoFromScope(this, scope);\n    if (traceContext) {\n      serializedCheckIn.contexts = {\n        trace: traceContext,\n      };\n    }\n\n    const envelope = checkin.createCheckInEnvelope(\n      serializedCheckIn,\n      dynamicSamplingContext,\n      this.getSdkMetadata(),\n      tunnel,\n      this.getDsn(),\n    );\n\n    debugBuild.DEBUG_BUILD && debugLogger.debug.log('Sending checkin:', checkIn.monitorSlug, checkIn.status);\n\n    // sendEnvelope should not throw\n    // eslint-disable-next-line @typescript-eslint/no-floating-promises\n    this.sendEnvelope(envelope);\n\n    return id;\n  }\n\n  /**\n   * @inheritDoc\n   */\n   _prepareEvent(\n    event,\n    hint,\n    currentScope,\n    isolationScope,\n  ) {\n    if (this._options.platform) {\n      event.platform = event.platform || this._options.platform;\n    }\n\n    if (this._options.runtime) {\n      event.contexts = {\n        ...event.contexts,\n        runtime: event.contexts?.runtime || this._options.runtime,\n      };\n    }\n\n    if (this._options.serverName) {\n      event.server_name = event.server_name || this._options.serverName;\n    }\n\n    return super._prepareEvent(event, hint, currentScope, isolationScope);\n  }\n}\n\nfunction setCurrentRequestSessionErroredOrCrashed(eventHint) {\n  const requestSession = currentScopes.getIsolationScope().getScopeData().sdkProcessingMetadata.requestSession;\n  if (requestSession) {\n    // We mutate instead of doing `setSdkProcessingMetadata` because the http integration stores away a particular\n    // isolationScope. If that isolation scope is forked, setting the processing metadata here will not mutate the\n    // original isolation scope that the http integration stored away.\n    const isHandledException = eventHint?.mechanism?.handled ?? true;\n    // A request session can go from \"errored\" -> \"crashed\" but not \"crashed\" -> \"errored\".\n    // Crashed (unhandled exception) is worse than errored (handled exception).\n    if (isHandledException && requestSession.status !== 'crashed') {\n      requestSession.status = 'errored';\n    } else if (!isHandledException) {\n      requestSession.status = 'crashed';\n    }\n  }\n}\n\n/**\n * Estimate the size of a log in bytes.\n *\n * @param log - The log to estimate the size of.\n * @returns The estimated size of the log in bytes.\n */\nfunction estimateLogSizeInBytes(log) {\n  let weight = 0;\n\n  // Estimate byte size of 2 bytes per character. This is a rough estimate JS strings are stored as UTF-16.\n  if (log.message) {\n    weight += log.message.length * 2;\n  }\n\n  if (log.attributes) {\n    Object.values(log.attributes).forEach(value => {\n      if (Array.isArray(value)) {\n        weight += value.length * estimatePrimitiveSizeInBytes(value[0]);\n      } else if (is.isPrimitive(value)) {\n        weight += estimatePrimitiveSizeInBytes(value);\n      } else {\n        // For objects values, we estimate the size of the object as 100 bytes\n        weight += 100;\n      }\n    });\n  }\n\n  return weight;\n}\n\nfunction estimatePrimitiveSizeInBytes(value) {\n  if (typeof value === 'string') {\n    return value.length * 2;\n  } else if (typeof value === 'number') {\n    return 8;\n  } else if (typeof value === 'boolean') {\n    return 4;\n  }\n\n  return 0;\n}\n\nexports.ServerRuntimeClient = ServerRuntimeClient;\n//# sourceMappingURL=server-runtime-client.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvc2VydmVyLXJ1bnRpbWUtY2xpZW50LmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLGdCQUFnQixtQkFBTyxDQUFDLDBIQUFjO0FBQ3RDLGVBQWUsbUJBQU8sQ0FBQyx3SEFBYTtBQUNwQyxzQkFBc0IsbUJBQU8sQ0FBQyxzSUFBb0I7QUFDbEQsbUJBQW1CLG1CQUFPLENBQUMsa0lBQWtCO0FBQzdDLGtCQUFrQixtQkFBTyxDQUFDLG9JQUFtQjtBQUM3QyxlQUFlLG1CQUFPLENBQUMsd0lBQXFCO0FBQzVDLFdBQVcsbUJBQU8sQ0FBQyw0SEFBZTtBQUNsQyxvQkFBb0IsbUJBQU8sQ0FBQyxnSkFBeUI7QUFDckQsYUFBYSxtQkFBTyxDQUFDLGdJQUFpQjtBQUN0QyxxQkFBcUIsbUJBQU8sQ0FBQyxnSkFBeUI7QUFDdEQsb0JBQW9CLG1CQUFPLENBQUMsOElBQXdCOztBQUVwRDtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0EsT0FBTzs7QUFFUDtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxVQUFVO0FBQ1Y7QUFDQTtBQUNBO0FBQ0EsV0FBVztBQUNYO0FBQ0EsT0FBTzs7QUFFUDtBQUNBO0FBQ0EsT0FBTztBQUNQO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0EsWUFBWSwrQkFBK0I7O0FBRTNDO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxNQUFNO0FBQ047QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFFBQVE7QUFDUjtBQUNBLFFBQVE7QUFDUjtBQUNBO0FBQ0E7QUFDQSxLQUFLO0FBQ0w7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQSxJQUFJO0FBQ0o7QUFDQSxJQUFJO0FBQ0o7QUFDQTs7QUFFQTtBQUNBOztBQUVBLDJCQUEyQjtBQUMzQiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3NlcnZlci1ydW50aW1lLWNsaWVudC5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgY2hlY2tpbiA9IHJlcXVpcmUoJy4vY2hlY2tpbi5qcycpO1xuY29uc3QgY2xpZW50ID0gcmVxdWlyZSgnLi9jbGllbnQuanMnKTtcbmNvbnN0IGN1cnJlbnRTY29wZXMgPSByZXF1aXJlKCcuL2N1cnJlbnRTY29wZXMuanMnKTtcbmNvbnN0IGRlYnVnQnVpbGQgPSByZXF1aXJlKCcuL2RlYnVnLWJ1aWxkLmpzJyk7XG5jb25zdCBleHBvcnRzJDEgPSByZXF1aXJlKCcuL2xvZ3MvZXhwb3J0cy5qcycpO1xuY29uc3QgZXJyb3JzID0gcmVxdWlyZSgnLi90cmFjaW5nL2Vycm9ycy5qcycpO1xuY29uc3QgaXMgPSByZXF1aXJlKCcuL3V0aWxzL2lzLmpzJyk7XG5jb25zdCBkZWJ1Z0xvZ2dlciA9IHJlcXVpcmUoJy4vdXRpbHMvZGVidWctbG9nZ2VyLmpzJyk7XG5jb25zdCBtaXNjID0gcmVxdWlyZSgnLi91dGlscy9taXNjLmpzJyk7XG5jb25zdCBldmVudGJ1aWxkZXIgPSByZXF1aXJlKCcuL3V0aWxzL2V2ZW50YnVpbGRlci5qcycpO1xuY29uc3Qgc3luY3Byb21pc2UgPSByZXF1aXJlKCcuL3V0aWxzL3N5bmNwcm9taXNlLmpzJyk7XG5cbi8vIFRPRE86IE1ha2UgdGhpcyBjb25maWd1cmFibGVcbmNvbnN0IERFRkFVTFRfTE9HX0ZMVVNIX0lOVEVSVkFMID0gNTAwMDtcblxuLyoqXG4gKiBUaGUgU2VudHJ5IFNlcnZlciBSdW50aW1lIENsaWVudCBTREsuXG4gKi9cbmNsYXNzIFNlcnZlclJ1bnRpbWVDbGllbnRcblxuIGV4dGVuZHMgY2xpZW50LkNsaWVudCB7XG5cbiAgLyoqXG4gICAqIENyZWF0ZXMgYSBuZXcgRWRnZSBTREsgaW5zdGFuY2UuXG4gICAqIEBwYXJhbSBvcHRpb25zIENvbmZpZ3VyYXRpb24gb3B0aW9ucyBmb3IgdGhpcyBTREsuXG4gICAqL1xuICAgY29uc3RydWN0b3Iob3B0aW9ucykge1xuICAgIC8vIFNlcnZlciBjbGllbnRzIGFsd2F5cyBzdXBwb3J0IHRyYWNpbmdcbiAgICBlcnJvcnMucmVnaXN0ZXJTcGFuRXJyb3JJbnN0cnVtZW50YXRpb24oKTtcblxuICAgIHN1cGVyKG9wdGlvbnMpO1xuXG4gICAgdGhpcy5fbG9nV2VpZ2h0ID0gMDtcblxuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBkZXByZWNhdGlvbi9kZXByZWNhdGlvblxuICAgIGNvbnN0IHNob3VsZEVuYWJsZUxvZ3MgPSB0aGlzLl9vcHRpb25zLmVuYWJsZUxvZ3MgPz8gdGhpcy5fb3B0aW9ucy5fZXhwZXJpbWVudHM/LmVuYWJsZUxvZ3M7XG4gICAgaWYgKHNob3VsZEVuYWJsZUxvZ3MpIHtcbiAgICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tdGhpcy1hbGlhc1xuICAgICAgY29uc3QgY2xpZW50ID0gdGhpcztcblxuICAgICAgY2xpZW50Lm9uKCdmbHVzaExvZ3MnLCAoKSA9PiB7XG4gICAgICAgIGNsaWVudC5fbG9nV2VpZ2h0ID0gMDtcbiAgICAgICAgY2xlYXJUaW1lb3V0KGNsaWVudC5fbG9nRmx1c2hJZGxlVGltZW91dCk7XG4gICAgICB9KTtcblxuICAgICAgY2xpZW50Lm9uKCdhZnRlckNhcHR1cmVMb2cnLCBsb2cgPT4ge1xuICAgICAgICBjbGllbnQuX2xvZ1dlaWdodCArPSBlc3RpbWF0ZUxvZ1NpemVJbkJ5dGVzKGxvZyk7XG5cbiAgICAgICAgLy8gV2UgZmx1c2ggdGhlIGxvZ3MgYnVmZmVyIGlmIGl0IGV4Y2VlZHMgMC44IE1CXG4gICAgICAgIC8vIFRoZSBsb2cgd2VpZ2h0IGlzIGEgcm91Z2ggZXN0aW1hdGUsIHNvIHdlIGZsdXNoIHdheSBiZWZvcmVcbiAgICAgICAgLy8gdGhlIHBheWxvYWQgZ2V0cyB0b28gYmlnLlxuICAgICAgICBpZiAoY2xpZW50Ll9sb2dXZWlnaHQgPj0gODAwMDAwKSB7XG4gICAgICAgICAgZXhwb3J0cyQxLl9JTlRFUk5BTF9mbHVzaExvZ3NCdWZmZXIoY2xpZW50KTtcbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAvLyBzdGFydCBhbiBpZGxlIHRpbWVvdXQgdG8gZmx1c2ggdGhlIGxvZ3MgYnVmZmVyIGlmIG5vIGxvZ3MgYXJlIGNhcHR1cmVkIGZvciBhIHdoaWxlXG4gICAgICAgICAgY2xpZW50Ll9sb2dGbHVzaElkbGVUaW1lb3V0ID0gc2V0VGltZW91dCgoKSA9PiB7XG4gICAgICAgICAgICBleHBvcnRzJDEuX0lOVEVSTkFMX2ZsdXNoTG9nc0J1ZmZlcihjbGllbnQpO1xuICAgICAgICAgIH0sIERFRkFVTFRfTE9HX0ZMVVNIX0lOVEVSVkFMKTtcbiAgICAgICAgfVxuICAgICAgfSk7XG5cbiAgICAgIGNsaWVudC5vbignZmx1c2gnLCAoKSA9PiB7XG4gICAgICAgIGV4cG9ydHMkMS5fSU5URVJOQUxfZmx1c2hMb2dzQnVmZmVyKGNsaWVudCk7XG4gICAgICB9KTtcbiAgICB9XG4gIH1cblxuICAvKipcbiAgICogQGluaGVyaXREb2NcbiAgICovXG4gICBldmVudEZyb21FeGNlcHRpb24oZXhjZXB0aW9uLCBoaW50KSB7XG4gICAgY29uc3QgZXZlbnQgPSBldmVudGJ1aWxkZXIuZXZlbnRGcm9tVW5rbm93bklucHV0KHRoaXMsIHRoaXMuX29wdGlvbnMuc3RhY2tQYXJzZXIsIGV4Y2VwdGlvbiwgaGludCk7XG4gICAgZXZlbnQubGV2ZWwgPSAnZXJyb3InO1xuXG4gICAgcmV0dXJuIHN5bmNwcm9taXNlLnJlc29sdmVkU3luY1Byb21pc2UoZXZlbnQpO1xuICB9XG5cbiAgLyoqXG4gICAqIEBpbmhlcml0RG9jXG4gICAqL1xuICAgZXZlbnRGcm9tTWVzc2FnZShcbiAgICBtZXNzYWdlLFxuICAgIGxldmVsID0gJ2luZm8nLFxuICAgIGhpbnQsXG4gICkge1xuICAgIHJldHVybiBzeW5jcHJvbWlzZS5yZXNvbHZlZFN5bmNQcm9taXNlKFxuICAgICAgZXZlbnRidWlsZGVyLmV2ZW50RnJvbU1lc3NhZ2UodGhpcy5fb3B0aW9ucy5zdGFja1BhcnNlciwgbWVzc2FnZSwgbGV2ZWwsIGhpbnQsIHRoaXMuX29wdGlvbnMuYXR0YWNoU3RhY2t0cmFjZSksXG4gICAgKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBAaW5oZXJpdERvY1xuICAgKi9cbiAgIGNhcHR1cmVFeGNlcHRpb24oZXhjZXB0aW9uLCBoaW50LCBzY29wZSkge1xuICAgIHNldEN1cnJlbnRSZXF1ZXN0U2Vzc2lvbkVycm9yZWRPckNyYXNoZWQoaGludCk7XG4gICAgcmV0dXJuIHN1cGVyLmNhcHR1cmVFeGNlcHRpb24oZXhjZXB0aW9uLCBoaW50LCBzY29wZSk7XG4gIH1cblxuICAvKipcbiAgICogQGluaGVyaXREb2NcbiAgICovXG4gICBjYXB0dXJlRXZlbnQoZXZlbnQsIGhpbnQsIHNjb3BlKSB7XG4gICAgLy8gSWYgdGhlIGV2ZW50IGlzIG9mIHR5cGUgRXhjZXB0aW9uLCB0aGVuIGEgcmVxdWVzdCBzZXNzaW9uIHNob3VsZCBiZSBjYXB0dXJlZFxuICAgIGNvbnN0IGlzRXhjZXB0aW9uID0gIWV2ZW50LnR5cGUgJiYgZXZlbnQuZXhjZXB0aW9uPy52YWx1ZXMgJiYgZXZlbnQuZXhjZXB0aW9uLnZhbHVlcy5sZW5ndGggPiAwO1xuICAgIGlmIChpc0V4Y2VwdGlvbikge1xuICAgICAgc2V0Q3VycmVudFJlcXVlc3RTZXNzaW9uRXJyb3JlZE9yQ3Jhc2hlZChoaW50KTtcbiAgICB9XG5cbiAgICByZXR1cm4gc3VwZXIuY2FwdHVyZUV2ZW50KGV2ZW50LCBoaW50LCBzY29wZSk7XG4gIH1cblxuICAvKipcbiAgICogQ3JlYXRlIGEgY3JvbiBtb25pdG9yIGNoZWNrIGluIGFuZCBzZW5kIGl0IHRvIFNlbnRyeS5cbiAgICpcbiAgICogQHBhcmFtIGNoZWNrSW4gQW4gb2JqZWN0IHRoYXQgZGVzY3JpYmVzIGEgY2hlY2sgaW4uXG4gICAqIEBwYXJhbSB1cHNlcnRNb25pdG9yQ29uZmlnIEFuIG9wdGlvbmFsIG9iamVjdCB0aGF0IGRlc2NyaWJlcyBhIG1vbml0b3IgY29uZmlnLiBVc2UgdGhpcyBpZiB5b3Ugd2FudFxuICAgKiB0byBjcmVhdGUgYSBtb25pdG9yIGF1dG9tYXRpY2FsbHkgd2hlbiBzZW5kaW5nIGEgY2hlY2sgaW4uXG4gICAqL1xuICAgY2FwdHVyZUNoZWNrSW4oY2hlY2tJbiwgbW9uaXRvckNvbmZpZywgc2NvcGUpIHtcbiAgICBjb25zdCBpZCA9ICdjaGVja0luSWQnIGluIGNoZWNrSW4gJiYgY2hlY2tJbi5jaGVja0luSWQgPyBjaGVja0luLmNoZWNrSW5JZCA6IG1pc2MudXVpZDQoKTtcbiAgICBpZiAoIXRoaXMuX2lzRW5hYmxlZCgpKSB7XG4gICAgICBkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEICYmIGRlYnVnTG9nZ2VyLmRlYnVnLndhcm4oJ1NESyBub3QgZW5hYmxlZCwgd2lsbCBub3QgY2FwdHVyZSBjaGVjay1pbi4nKTtcbiAgICAgIHJldHVybiBpZDtcbiAgICB9XG5cbiAgICBjb25zdCBvcHRpb25zID0gdGhpcy5nZXRPcHRpb25zKCk7XG4gICAgY29uc3QgeyByZWxlYXNlLCBlbnZpcm9ubWVudCwgdHVubmVsIH0gPSBvcHRpb25zO1xuXG4gICAgY29uc3Qgc2VyaWFsaXplZENoZWNrSW4gPSB7XG4gICAgICBjaGVja19pbl9pZDogaWQsXG4gICAgICBtb25pdG9yX3NsdWc6IGNoZWNrSW4ubW9uaXRvclNsdWcsXG4gICAgICBzdGF0dXM6IGNoZWNrSW4uc3RhdHVzLFxuICAgICAgcmVsZWFzZSxcbiAgICAgIGVudmlyb25tZW50LFxuICAgIH07XG5cbiAgICBpZiAoJ2R1cmF0aW9uJyBpbiBjaGVja0luKSB7XG4gICAgICBzZXJpYWxpemVkQ2hlY2tJbi5kdXJhdGlvbiA9IGNoZWNrSW4uZHVyYXRpb247XG4gICAgfVxuXG4gICAgaWYgKG1vbml0b3JDb25maWcpIHtcbiAgICAgIHNlcmlhbGl6ZWRDaGVja0luLm1vbml0b3JfY29uZmlnID0ge1xuICAgICAgICBzY2hlZHVsZTogbW9uaXRvckNvbmZpZy5zY2hlZHVsZSxcbiAgICAgICAgY2hlY2tpbl9tYXJnaW46IG1vbml0b3JDb25maWcuY2hlY2tpbk1hcmdpbixcbiAgICAgICAgbWF4X3J1bnRpbWU6IG1vbml0b3JDb25maWcubWF4UnVudGltZSxcbiAgICAgICAgdGltZXpvbmU6IG1vbml0b3JDb25maWcudGltZXpvbmUsXG4gICAgICAgIGZhaWx1cmVfaXNzdWVfdGhyZXNob2xkOiBtb25pdG9yQ29uZmlnLmZhaWx1cmVJc3N1ZVRocmVzaG9sZCxcbiAgICAgICAgcmVjb3ZlcnlfdGhyZXNob2xkOiBtb25pdG9yQ29uZmlnLnJlY292ZXJ5VGhyZXNob2xkLFxuICAgICAgfTtcbiAgICB9XG5cbiAgICBjb25zdCBbZHluYW1pY1NhbXBsaW5nQ29udGV4dCwgdHJhY2VDb250ZXh0XSA9IGNsaWVudC5fZ2V0VHJhY2VJbmZvRnJvbVNjb3BlKHRoaXMsIHNjb3BlKTtcbiAgICBpZiAodHJhY2VDb250ZXh0KSB7XG4gICAgICBzZXJpYWxpemVkQ2hlY2tJbi5jb250ZXh0cyA9IHtcbiAgICAgICAgdHJhY2U6IHRyYWNlQ29udGV4dCxcbiAgICAgIH07XG4gICAgfVxuXG4gICAgY29uc3QgZW52ZWxvcGUgPSBjaGVja2luLmNyZWF0ZUNoZWNrSW5FbnZlbG9wZShcbiAgICAgIHNlcmlhbGl6ZWRDaGVja0luLFxuICAgICAgZHluYW1pY1NhbXBsaW5nQ29udGV4dCxcbiAgICAgIHRoaXMuZ2V0U2RrTWV0YWRhdGEoKSxcbiAgICAgIHR1bm5lbCxcbiAgICAgIHRoaXMuZ2V0RHNuKCksXG4gICAgKTtcblxuICAgIGRlYnVnQnVpbGQuREVCVUdfQlVJTEQgJiYgZGVidWdMb2dnZXIuZGVidWcubG9nKCdTZW5kaW5nIGNoZWNraW46JywgY2hlY2tJbi5tb25pdG9yU2x1ZywgY2hlY2tJbi5zdGF0dXMpO1xuXG4gICAgLy8gc2VuZEVudmVsb3BlIHNob3VsZCBub3QgdGhyb3dcbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25vLWZsb2F0aW5nLXByb21pc2VzXG4gICAgdGhpcy5zZW5kRW52ZWxvcGUoZW52ZWxvcGUpO1xuXG4gICAgcmV0dXJuIGlkO1xuICB9XG5cbiAgLyoqXG4gICAqIEBpbmhlcml0RG9jXG4gICAqL1xuICAgX3ByZXBhcmVFdmVudChcbiAgICBldmVudCxcbiAgICBoaW50LFxuICAgIGN1cnJlbnRTY29wZSxcbiAgICBpc29sYXRpb25TY29wZSxcbiAgKSB7XG4gICAgaWYgKHRoaXMuX29wdGlvbnMucGxhdGZvcm0pIHtcbiAgICAgIGV2ZW50LnBsYXRmb3JtID0gZXZlbnQucGxhdGZvcm0gfHwgdGhpcy5fb3B0aW9ucy5wbGF0Zm9ybTtcbiAgICB9XG5cbiAgICBpZiAodGhpcy5fb3B0aW9ucy5ydW50aW1lKSB7XG4gICAgICBldmVudC5jb250ZXh0cyA9IHtcbiAgICAgICAgLi4uZXZlbnQuY29udGV4dHMsXG4gICAgICAgIHJ1bnRpbWU6IGV2ZW50LmNvbnRleHRzPy5ydW50aW1lIHx8IHRoaXMuX29wdGlvbnMucnVudGltZSxcbiAgICAgIH07XG4gICAgfVxuXG4gICAgaWYgKHRoaXMuX29wdGlvbnMuc2VydmVyTmFtZSkge1xuICAgICAgZXZlbnQuc2VydmVyX25hbWUgPSBldmVudC5zZXJ2ZXJfbmFtZSB8fCB0aGlzLl9vcHRpb25zLnNlcnZlck5hbWU7XG4gICAgfVxuXG4gICAgcmV0dXJuIHN1cGVyLl9wcmVwYXJlRXZlbnQoZXZlbnQsIGhpbnQsIGN1cnJlbnRTY29wZSwgaXNvbGF0aW9uU2NvcGUpO1xuICB9XG59XG5cbmZ1bmN0aW9uIHNldEN1cnJlbnRSZXF1ZXN0U2Vzc2lvbkVycm9yZWRPckNyYXNoZWQoZXZlbnRIaW50KSB7XG4gIGNvbnN0IHJlcXVlc3RTZXNzaW9uID0gY3VycmVudFNjb3Blcy5nZXRJc29sYXRpb25TY29wZSgpLmdldFNjb3BlRGF0YSgpLnNka1Byb2Nlc3NpbmdNZXRhZGF0YS5yZXF1ZXN0U2Vzc2lvbjtcbiAgaWYgKHJlcXVlc3RTZXNzaW9uKSB7XG4gICAgLy8gV2UgbXV0YXRlIGluc3RlYWQgb2YgZG9pbmcgYHNldFNka1Byb2Nlc3NpbmdNZXRhZGF0YWAgYmVjYXVzZSB0aGUgaHR0cCBpbnRlZ3JhdGlvbiBzdG9yZXMgYXdheSBhIHBhcnRpY3VsYXJcbiAgICAvLyBpc29sYXRpb25TY29wZS4gSWYgdGhhdCBpc29sYXRpb24gc2NvcGUgaXMgZm9ya2VkLCBzZXR0aW5nIHRoZSBwcm9jZXNzaW5nIG1ldGFkYXRhIGhlcmUgd2lsbCBub3QgbXV0YXRlIHRoZVxuICAgIC8vIG9yaWdpbmFsIGlzb2xhdGlvbiBzY29wZSB0aGF0IHRoZSBodHRwIGludGVncmF0aW9uIHN0b3JlZCBhd2F5LlxuICAgIGNvbnN0IGlzSGFuZGxlZEV4Y2VwdGlvbiA9IGV2ZW50SGludD8ubWVjaGFuaXNtPy5oYW5kbGVkID8/IHRydWU7XG4gICAgLy8gQSByZXF1ZXN0IHNlc3Npb24gY2FuIGdvIGZyb20gXCJlcnJvcmVkXCIgLT4gXCJjcmFzaGVkXCIgYnV0IG5vdCBcImNyYXNoZWRcIiAtPiBcImVycm9yZWRcIi5cbiAgICAvLyBDcmFzaGVkICh1bmhhbmRsZWQgZXhjZXB0aW9uKSBpcyB3b3JzZSB0aGFuIGVycm9yZWQgKGhhbmRsZWQgZXhjZXB0aW9uKS5cbiAgICBpZiAoaXNIYW5kbGVkRXhjZXB0aW9uICYmIHJlcXVlc3RTZXNzaW9uLnN0YXR1cyAhPT0gJ2NyYXNoZWQnKSB7XG4gICAgICByZXF1ZXN0U2Vzc2lvbi5zdGF0dXMgPSAnZXJyb3JlZCc7XG4gICAgfSBlbHNlIGlmICghaXNIYW5kbGVkRXhjZXB0aW9uKSB7XG4gICAgICByZXF1ZXN0U2Vzc2lvbi5zdGF0dXMgPSAnY3Jhc2hlZCc7XG4gICAgfVxuICB9XG59XG5cbi8qKlxuICogRXN0aW1hdGUgdGhlIHNpemUgb2YgYSBsb2cgaW4gYnl0ZXMuXG4gKlxuICogQHBhcmFtIGxvZyAtIFRoZSBsb2cgdG8gZXN0aW1hdGUgdGhlIHNpemUgb2YuXG4gKiBAcmV0dXJucyBUaGUgZXN0aW1hdGVkIHNpemUgb2YgdGhlIGxvZyBpbiBieXRlcy5cbiAqL1xuZnVuY3Rpb24gZXN0aW1hdGVMb2dTaXplSW5CeXRlcyhsb2cpIHtcbiAgbGV0IHdlaWdodCA9IDA7XG5cbiAgLy8gRXN0aW1hdGUgYnl0ZSBzaXplIG9mIDIgYnl0ZXMgcGVyIGNoYXJhY3Rlci4gVGhpcyBpcyBhIHJvdWdoIGVzdGltYXRlIEpTIHN0cmluZ3MgYXJlIHN0b3JlZCBhcyBVVEYtMTYuXG4gIGlmIChsb2cubWVzc2FnZSkge1xuICAgIHdlaWdodCArPSBsb2cubWVzc2FnZS5sZW5ndGggKiAyO1xuICB9XG5cbiAgaWYgKGxvZy5hdHRyaWJ1dGVzKSB7XG4gICAgT2JqZWN0LnZhbHVlcyhsb2cuYXR0cmlidXRlcykuZm9yRWFjaCh2YWx1ZSA9PiB7XG4gICAgICBpZiAoQXJyYXkuaXNBcnJheSh2YWx1ZSkpIHtcbiAgICAgICAgd2VpZ2h0ICs9IHZhbHVlLmxlbmd0aCAqIGVzdGltYXRlUHJpbWl0aXZlU2l6ZUluQnl0ZXModmFsdWVbMF0pO1xuICAgICAgfSBlbHNlIGlmIChpcy5pc1ByaW1pdGl2ZSh2YWx1ZSkpIHtcbiAgICAgICAgd2VpZ2h0ICs9IGVzdGltYXRlUHJpbWl0aXZlU2l6ZUluQnl0ZXModmFsdWUpO1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgLy8gRm9yIG9iamVjdHMgdmFsdWVzLCB3ZSBlc3RpbWF0ZSB0aGUgc2l6ZSBvZiB0aGUgb2JqZWN0IGFzIDEwMCBieXRlc1xuICAgICAgICB3ZWlnaHQgKz0gMTAwO1xuICAgICAgfVxuICAgIH0pO1xuICB9XG5cbiAgcmV0dXJuIHdlaWdodDtcbn1cblxuZnVuY3Rpb24gZXN0aW1hdGVQcmltaXRpdmVTaXplSW5CeXRlcyh2YWx1ZSkge1xuICBpZiAodHlwZW9mIHZhbHVlID09PSAnc3RyaW5nJykge1xuICAgIHJldHVybiB2YWx1ZS5sZW5ndGggKiAyO1xuICB9IGVsc2UgaWYgKHR5cGVvZiB2YWx1ZSA9PT0gJ251bWJlcicpIHtcbiAgICByZXR1cm4gODtcbiAgfSBlbHNlIGlmICh0eXBlb2YgdmFsdWUgPT09ICdib29sZWFuJykge1xuICAgIHJldHVybiA0O1xuICB9XG5cbiAgcmV0dXJuIDA7XG59XG5cbmV4cG9ydHMuU2VydmVyUnVudGltZUNsaWVudCA9IFNlcnZlclJ1bnRpbWVDbGllbnQ7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1zZXJ2ZXItcnVudGltZS1jbGllbnQuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/server-runtime-client.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/session.js":
/*!***********************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/session.js ***!
  \***********************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst misc = __webpack_require__(/*! ./utils/misc.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/misc.js\");\nconst time = __webpack_require__(/*! ./utils/time.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/time.js\");\n\n/**\n * Creates a new `Session` object by setting certain default parameters. If optional @param context\n * is passed, the passed properties are applied to the session object.\n *\n * @param context (optional) additional properties to be applied to the returned session object\n *\n * @returns a new `Session` object\n */\nfunction makeSession(context) {\n  // Both timestamp and started are in seconds since the UNIX epoch.\n  const startingTime = time.timestampInSeconds();\n\n  const session = {\n    sid: misc.uuid4(),\n    init: true,\n    timestamp: startingTime,\n    started: startingTime,\n    duration: 0,\n    status: 'ok',\n    errors: 0,\n    ignoreDuration: false,\n    toJSON: () => sessionToJSON(session),\n  };\n\n  if (context) {\n    updateSession(session, context);\n  }\n\n  return session;\n}\n\n/**\n * Updates a session object with the properties passed in the context.\n *\n * Note that this function mutates the passed object and returns void.\n * (Had to do this instead of returning a new and updated session because closing and sending a session\n * makes an update to the session after it was passed to the sending logic.\n * @see Client.captureSession )\n *\n * @param session the `Session` to update\n * @param context the `SessionContext` holding the properties that should be updated in @param session\n */\n// eslint-disable-next-line complexity\nfunction updateSession(session, context = {}) {\n  if (context.user) {\n    if (!session.ipAddress && context.user.ip_address) {\n      session.ipAddress = context.user.ip_address;\n    }\n\n    if (!session.did && !context.did) {\n      session.did = context.user.id || context.user.email || context.user.username;\n    }\n  }\n\n  session.timestamp = context.timestamp || time.timestampInSeconds();\n\n  if (context.abnormal_mechanism) {\n    session.abnormal_mechanism = context.abnormal_mechanism;\n  }\n\n  if (context.ignoreDuration) {\n    session.ignoreDuration = context.ignoreDuration;\n  }\n  if (context.sid) {\n    // Good enough uuid validation. — Kamil\n    session.sid = context.sid.length === 32 ? context.sid : misc.uuid4();\n  }\n  if (context.init !== undefined) {\n    session.init = context.init;\n  }\n  if (!session.did && context.did) {\n    session.did = `${context.did}`;\n  }\n  if (typeof context.started === 'number') {\n    session.started = context.started;\n  }\n  if (session.ignoreDuration) {\n    session.duration = undefined;\n  } else if (typeof context.duration === 'number') {\n    session.duration = context.duration;\n  } else {\n    const duration = session.timestamp - session.started;\n    session.duration = duration >= 0 ? duration : 0;\n  }\n  if (context.release) {\n    session.release = context.release;\n  }\n  if (context.environment) {\n    session.environment = context.environment;\n  }\n  if (!session.ipAddress && context.ipAddress) {\n    session.ipAddress = context.ipAddress;\n  }\n  if (!session.userAgent && context.userAgent) {\n    session.userAgent = context.userAgent;\n  }\n  if (typeof context.errors === 'number') {\n    session.errors = context.errors;\n  }\n  if (context.status) {\n    session.status = context.status;\n  }\n}\n\n/**\n * Closes a session by setting its status and updating the session object with it.\n * Internally calls `updateSession` to update the passed session object.\n *\n * Note that this function mutates the passed session (@see updateSession for explanation).\n *\n * @param session the `Session` object to be closed\n * @param status the `SessionStatus` with which the session was closed. If you don't pass a status,\n *               this function will keep the previously set status, unless it was `'ok'` in which case\n *               it is changed to `'exited'`.\n */\nfunction closeSession(session, status) {\n  let context = {};\n  if (status) {\n    context = { status };\n  } else if (session.status === 'ok') {\n    context = { status: 'exited' };\n  }\n\n  updateSession(session, context);\n}\n\n/**\n * Serializes a passed session object to a JSON object with a slightly different structure.\n * This is necessary because the Sentry backend requires a slightly different schema of a session\n * than the one the JS SDKs use internally.\n *\n * @param session the session to be converted\n *\n * @returns a JSON object of the passed session\n */\nfunction sessionToJSON(session) {\n  return {\n    sid: `${session.sid}`,\n    init: session.init,\n    // Make sure that sec is converted to ms for date constructor\n    started: new Date(session.started * 1000).toISOString(),\n    timestamp: new Date(session.timestamp * 1000).toISOString(),\n    status: session.status,\n    errors: session.errors,\n    did: typeof session.did === 'number' || typeof session.did === 'string' ? `${session.did}` : undefined,\n    duration: session.duration,\n    abnormal_mechanism: session.abnormal_mechanism,\n    attrs: {\n      release: session.release,\n      environment: session.environment,\n      ip_address: session.ipAddress,\n      user_agent: session.userAgent,\n    },\n  };\n}\n\nexports.closeSession = closeSession;\nexports.makeSession = makeSession;\nexports.updateSession = updateSession;\n//# sourceMappingURL=session.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvc2Vzc2lvbi5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxhQUFhLG1CQUFPLENBQUMsZ0lBQWlCO0FBQ3RDLGFBQWEsbUJBQU8sQ0FBQyxnSUFBaUI7O0FBRXRDO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSw0Q0FBNEM7QUFDNUM7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxxQkFBcUIsWUFBWTtBQUNqQztBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxJQUFJO0FBQ0o7QUFDQSxJQUFJO0FBQ0o7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGdCQUFnQjtBQUNoQixJQUFJO0FBQ0osZ0JBQWdCO0FBQ2hCOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFlBQVksWUFBWTtBQUN4QjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxpRkFBaUYsWUFBWTtBQUM3RjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEtBQUs7QUFDTDtBQUNBOztBQUVBLG9CQUFvQjtBQUNwQixtQkFBbUI7QUFDbkIscUJBQXFCO0FBQ3JCIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvc2Vzc2lvbi5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgbWlzYyA9IHJlcXVpcmUoJy4vdXRpbHMvbWlzYy5qcycpO1xuY29uc3QgdGltZSA9IHJlcXVpcmUoJy4vdXRpbHMvdGltZS5qcycpO1xuXG4vKipcbiAqIENyZWF0ZXMgYSBuZXcgYFNlc3Npb25gIG9iamVjdCBieSBzZXR0aW5nIGNlcnRhaW4gZGVmYXVsdCBwYXJhbWV0ZXJzLiBJZiBvcHRpb25hbCBAcGFyYW0gY29udGV4dFxuICogaXMgcGFzc2VkLCB0aGUgcGFzc2VkIHByb3BlcnRpZXMgYXJlIGFwcGxpZWQgdG8gdGhlIHNlc3Npb24gb2JqZWN0LlxuICpcbiAqIEBwYXJhbSBjb250ZXh0IChvcHRpb25hbCkgYWRkaXRpb25hbCBwcm9wZXJ0aWVzIHRvIGJlIGFwcGxpZWQgdG8gdGhlIHJldHVybmVkIHNlc3Npb24gb2JqZWN0XG4gKlxuICogQHJldHVybnMgYSBuZXcgYFNlc3Npb25gIG9iamVjdFxuICovXG5mdW5jdGlvbiBtYWtlU2Vzc2lvbihjb250ZXh0KSB7XG4gIC8vIEJvdGggdGltZXN0YW1wIGFuZCBzdGFydGVkIGFyZSBpbiBzZWNvbmRzIHNpbmNlIHRoZSBVTklYIGVwb2NoLlxuICBjb25zdCBzdGFydGluZ1RpbWUgPSB0aW1lLnRpbWVzdGFtcEluU2Vjb25kcygpO1xuXG4gIGNvbnN0IHNlc3Npb24gPSB7XG4gICAgc2lkOiBtaXNjLnV1aWQ0KCksXG4gICAgaW5pdDogdHJ1ZSxcbiAgICB0aW1lc3RhbXA6IHN0YXJ0aW5nVGltZSxcbiAgICBzdGFydGVkOiBzdGFydGluZ1RpbWUsXG4gICAgZHVyYXRpb246IDAsXG4gICAgc3RhdHVzOiAnb2snLFxuICAgIGVycm9yczogMCxcbiAgICBpZ25vcmVEdXJhdGlvbjogZmFsc2UsXG4gICAgdG9KU09OOiAoKSA9PiBzZXNzaW9uVG9KU09OKHNlc3Npb24pLFxuICB9O1xuXG4gIGlmIChjb250ZXh0KSB7XG4gICAgdXBkYXRlU2Vzc2lvbihzZXNzaW9uLCBjb250ZXh0KTtcbiAgfVxuXG4gIHJldHVybiBzZXNzaW9uO1xufVxuXG4vKipcbiAqIFVwZGF0ZXMgYSBzZXNzaW9uIG9iamVjdCB3aXRoIHRoZSBwcm9wZXJ0aWVzIHBhc3NlZCBpbiB0aGUgY29udGV4dC5cbiAqXG4gKiBOb3RlIHRoYXQgdGhpcyBmdW5jdGlvbiBtdXRhdGVzIHRoZSBwYXNzZWQgb2JqZWN0IGFuZCByZXR1cm5zIHZvaWQuXG4gKiAoSGFkIHRvIGRvIHRoaXMgaW5zdGVhZCBvZiByZXR1cm5pbmcgYSBuZXcgYW5kIHVwZGF0ZWQgc2Vzc2lvbiBiZWNhdXNlIGNsb3NpbmcgYW5kIHNlbmRpbmcgYSBzZXNzaW9uXG4gKiBtYWtlcyBhbiB1cGRhdGUgdG8gdGhlIHNlc3Npb24gYWZ0ZXIgaXQgd2FzIHBhc3NlZCB0byB0aGUgc2VuZGluZyBsb2dpYy5cbiAqIEBzZWUgQ2xpZW50LmNhcHR1cmVTZXNzaW9uIClcbiAqXG4gKiBAcGFyYW0gc2Vzc2lvbiB0aGUgYFNlc3Npb25gIHRvIHVwZGF0ZVxuICogQHBhcmFtIGNvbnRleHQgdGhlIGBTZXNzaW9uQ29udGV4dGAgaG9sZGluZyB0aGUgcHJvcGVydGllcyB0aGF0IHNob3VsZCBiZSB1cGRhdGVkIGluIEBwYXJhbSBzZXNzaW9uXG4gKi9cbi8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBjb21wbGV4aXR5XG5mdW5jdGlvbiB1cGRhdGVTZXNzaW9uKHNlc3Npb24sIGNvbnRleHQgPSB7fSkge1xuICBpZiAoY29udGV4dC51c2VyKSB7XG4gICAgaWYgKCFzZXNzaW9uLmlwQWRkcmVzcyAmJiBjb250ZXh0LnVzZXIuaXBfYWRkcmVzcykge1xuICAgICAgc2Vzc2lvbi5pcEFkZHJlc3MgPSBjb250ZXh0LnVzZXIuaXBfYWRkcmVzcztcbiAgICB9XG5cbiAgICBpZiAoIXNlc3Npb24uZGlkICYmICFjb250ZXh0LmRpZCkge1xuICAgICAgc2Vzc2lvbi5kaWQgPSBjb250ZXh0LnVzZXIuaWQgfHwgY29udGV4dC51c2VyLmVtYWlsIHx8IGNvbnRleHQudXNlci51c2VybmFtZTtcbiAgICB9XG4gIH1cblxuICBzZXNzaW9uLnRpbWVzdGFtcCA9IGNvbnRleHQudGltZXN0YW1wIHx8IHRpbWUudGltZXN0YW1wSW5TZWNvbmRzKCk7XG5cbiAgaWYgKGNvbnRleHQuYWJub3JtYWxfbWVjaGFuaXNtKSB7XG4gICAgc2Vzc2lvbi5hYm5vcm1hbF9tZWNoYW5pc20gPSBjb250ZXh0LmFibm9ybWFsX21lY2hhbmlzbTtcbiAgfVxuXG4gIGlmIChjb250ZXh0Lmlnbm9yZUR1cmF0aW9uKSB7XG4gICAgc2Vzc2lvbi5pZ25vcmVEdXJhdGlvbiA9IGNvbnRleHQuaWdub3JlRHVyYXRpb247XG4gIH1cbiAgaWYgKGNvbnRleHQuc2lkKSB7XG4gICAgLy8gR29vZCBlbm91Z2ggdXVpZCB2YWxpZGF0aW9uLiDigJQgS2FtaWxcbiAgICBzZXNzaW9uLnNpZCA9IGNvbnRleHQuc2lkLmxlbmd0aCA9PT0gMzIgPyBjb250ZXh0LnNpZCA6IG1pc2MudXVpZDQoKTtcbiAgfVxuICBpZiAoY29udGV4dC5pbml0ICE9PSB1bmRlZmluZWQpIHtcbiAgICBzZXNzaW9uLmluaXQgPSBjb250ZXh0LmluaXQ7XG4gIH1cbiAgaWYgKCFzZXNzaW9uLmRpZCAmJiBjb250ZXh0LmRpZCkge1xuICAgIHNlc3Npb24uZGlkID0gYCR7Y29udGV4dC5kaWR9YDtcbiAgfVxuICBpZiAodHlwZW9mIGNvbnRleHQuc3RhcnRlZCA9PT0gJ251bWJlcicpIHtcbiAgICBzZXNzaW9uLnN0YXJ0ZWQgPSBjb250ZXh0LnN0YXJ0ZWQ7XG4gIH1cbiAgaWYgKHNlc3Npb24uaWdub3JlRHVyYXRpb24pIHtcbiAgICBzZXNzaW9uLmR1cmF0aW9uID0gdW5kZWZpbmVkO1xuICB9IGVsc2UgaWYgKHR5cGVvZiBjb250ZXh0LmR1cmF0aW9uID09PSAnbnVtYmVyJykge1xuICAgIHNlc3Npb24uZHVyYXRpb24gPSBjb250ZXh0LmR1cmF0aW9uO1xuICB9IGVsc2Uge1xuICAgIGNvbnN0IGR1cmF0aW9uID0gc2Vzc2lvbi50aW1lc3RhbXAgLSBzZXNzaW9uLnN0YXJ0ZWQ7XG4gICAgc2Vzc2lvbi5kdXJhdGlvbiA9IGR1cmF0aW9uID49IDAgPyBkdXJhdGlvbiA6IDA7XG4gIH1cbiAgaWYgKGNvbnRleHQucmVsZWFzZSkge1xuICAgIHNlc3Npb24ucmVsZWFzZSA9IGNvbnRleHQucmVsZWFzZTtcbiAgfVxuICBpZiAoY29udGV4dC5lbnZpcm9ubWVudCkge1xuICAgIHNlc3Npb24uZW52aXJvbm1lbnQgPSBjb250ZXh0LmVudmlyb25tZW50O1xuICB9XG4gIGlmICghc2Vzc2lvbi5pcEFkZHJlc3MgJiYgY29udGV4dC5pcEFkZHJlc3MpIHtcbiAgICBzZXNzaW9uLmlwQWRkcmVzcyA9IGNvbnRleHQuaXBBZGRyZXNzO1xuICB9XG4gIGlmICghc2Vzc2lvbi51c2VyQWdlbnQgJiYgY29udGV4dC51c2VyQWdlbnQpIHtcbiAgICBzZXNzaW9uLnVzZXJBZ2VudCA9IGNvbnRleHQudXNlckFnZW50O1xuICB9XG4gIGlmICh0eXBlb2YgY29udGV4dC5lcnJvcnMgPT09ICdudW1iZXInKSB7XG4gICAgc2Vzc2lvbi5lcnJvcnMgPSBjb250ZXh0LmVycm9ycztcbiAgfVxuICBpZiAoY29udGV4dC5zdGF0dXMpIHtcbiAgICBzZXNzaW9uLnN0YXR1cyA9IGNvbnRleHQuc3RhdHVzO1xuICB9XG59XG5cbi8qKlxuICogQ2xvc2VzIGEgc2Vzc2lvbiBieSBzZXR0aW5nIGl0cyBzdGF0dXMgYW5kIHVwZGF0aW5nIHRoZSBzZXNzaW9uIG9iamVjdCB3aXRoIGl0LlxuICogSW50ZXJuYWxseSBjYWxscyBgdXBkYXRlU2Vzc2lvbmAgdG8gdXBkYXRlIHRoZSBwYXNzZWQgc2Vzc2lvbiBvYmplY3QuXG4gKlxuICogTm90ZSB0aGF0IHRoaXMgZnVuY3Rpb24gbXV0YXRlcyB0aGUgcGFzc2VkIHNlc3Npb24gKEBzZWUgdXBkYXRlU2Vzc2lvbiBmb3IgZXhwbGFuYXRpb24pLlxuICpcbiAqIEBwYXJhbSBzZXNzaW9uIHRoZSBgU2Vzc2lvbmAgb2JqZWN0IHRvIGJlIGNsb3NlZFxuICogQHBhcmFtIHN0YXR1cyB0aGUgYFNlc3Npb25TdGF0dXNgIHdpdGggd2hpY2ggdGhlIHNlc3Npb24gd2FzIGNsb3NlZC4gSWYgeW91IGRvbid0IHBhc3MgYSBzdGF0dXMsXG4gKiAgICAgICAgICAgICAgIHRoaXMgZnVuY3Rpb24gd2lsbCBrZWVwIHRoZSBwcmV2aW91c2x5IHNldCBzdGF0dXMsIHVubGVzcyBpdCB3YXMgYCdvaydgIGluIHdoaWNoIGNhc2VcbiAqICAgICAgICAgICAgICAgaXQgaXMgY2hhbmdlZCB0byBgJ2V4aXRlZCdgLlxuICovXG5mdW5jdGlvbiBjbG9zZVNlc3Npb24oc2Vzc2lvbiwgc3RhdHVzKSB7XG4gIGxldCBjb250ZXh0ID0ge307XG4gIGlmIChzdGF0dXMpIHtcbiAgICBjb250ZXh0ID0geyBzdGF0dXMgfTtcbiAgfSBlbHNlIGlmIChzZXNzaW9uLnN0YXR1cyA9PT0gJ29rJykge1xuICAgIGNvbnRleHQgPSB7IHN0YXR1czogJ2V4aXRlZCcgfTtcbiAgfVxuXG4gIHVwZGF0ZVNlc3Npb24oc2Vzc2lvbiwgY29udGV4dCk7XG59XG5cbi8qKlxuICogU2VyaWFsaXplcyBhIHBhc3NlZCBzZXNzaW9uIG9iamVjdCB0byBhIEpTT04gb2JqZWN0IHdpdGggYSBzbGlnaHRseSBkaWZmZXJlbnQgc3RydWN0dXJlLlxuICogVGhpcyBpcyBuZWNlc3NhcnkgYmVjYXVzZSB0aGUgU2VudHJ5IGJhY2tlbmQgcmVxdWlyZXMgYSBzbGlnaHRseSBkaWZmZXJlbnQgc2NoZW1hIG9mIGEgc2Vzc2lvblxuICogdGhhbiB0aGUgb25lIHRoZSBKUyBTREtzIHVzZSBpbnRlcm5hbGx5LlxuICpcbiAqIEBwYXJhbSBzZXNzaW9uIHRoZSBzZXNzaW9uIHRvIGJlIGNvbnZlcnRlZFxuICpcbiAqIEByZXR1cm5zIGEgSlNPTiBvYmplY3Qgb2YgdGhlIHBhc3NlZCBzZXNzaW9uXG4gKi9cbmZ1bmN0aW9uIHNlc3Npb25Ub0pTT04oc2Vzc2lvbikge1xuICByZXR1cm4ge1xuICAgIHNpZDogYCR7c2Vzc2lvbi5zaWR9YCxcbiAgICBpbml0OiBzZXNzaW9uLmluaXQsXG4gICAgLy8gTWFrZSBzdXJlIHRoYXQgc2VjIGlzIGNvbnZlcnRlZCB0byBtcyBmb3IgZGF0ZSBjb25zdHJ1Y3RvclxuICAgIHN0YXJ0ZWQ6IG5ldyBEYXRlKHNlc3Npb24uc3RhcnRlZCAqIDEwMDApLnRvSVNPU3RyaW5nKCksXG4gICAgdGltZXN0YW1wOiBuZXcgRGF0ZShzZXNzaW9uLnRpbWVzdGFtcCAqIDEwMDApLnRvSVNPU3RyaW5nKCksXG4gICAgc3RhdHVzOiBzZXNzaW9uLnN0YXR1cyxcbiAgICBlcnJvcnM6IHNlc3Npb24uZXJyb3JzLFxuICAgIGRpZDogdHlwZW9mIHNlc3Npb24uZGlkID09PSAnbnVtYmVyJyB8fCB0eXBlb2Ygc2Vzc2lvbi5kaWQgPT09ICdzdHJpbmcnID8gYCR7c2Vzc2lvbi5kaWR9YCA6IHVuZGVmaW5lZCxcbiAgICBkdXJhdGlvbjogc2Vzc2lvbi5kdXJhdGlvbixcbiAgICBhYm5vcm1hbF9tZWNoYW5pc206IHNlc3Npb24uYWJub3JtYWxfbWVjaGFuaXNtLFxuICAgIGF0dHJzOiB7XG4gICAgICByZWxlYXNlOiBzZXNzaW9uLnJlbGVhc2UsXG4gICAgICBlbnZpcm9ubWVudDogc2Vzc2lvbi5lbnZpcm9ubWVudCxcbiAgICAgIGlwX2FkZHJlc3M6IHNlc3Npb24uaXBBZGRyZXNzLFxuICAgICAgdXNlcl9hZ2VudDogc2Vzc2lvbi51c2VyQWdlbnQsXG4gICAgfSxcbiAgfTtcbn1cblxuZXhwb3J0cy5jbG9zZVNlc3Npb24gPSBjbG9zZVNlc3Npb247XG5leHBvcnRzLm1ha2VTZXNzaW9uID0gbWFrZVNlc3Npb247XG5leHBvcnRzLnVwZGF0ZVNlc3Npb24gPSB1cGRhdGVTZXNzaW9uO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9c2Vzc2lvbi5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/session.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/dynamicSamplingContext.js":
/*!**********************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/dynamicSamplingContext.js ***!
  \**********************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst constants = __webpack_require__(/*! ../constants.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/constants.js\");\nconst currentScopes = __webpack_require__(/*! ../currentScopes.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst semanticAttributes = __webpack_require__(/*! ../semanticAttributes.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/semanticAttributes.js\");\nconst baggage = __webpack_require__(/*! ../utils/baggage.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/baggage.js\");\nconst dsn = __webpack_require__(/*! ../utils/dsn.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/dsn.js\");\nconst hasSpansEnabled = __webpack_require__(/*! ../utils/hasSpansEnabled.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/hasSpansEnabled.js\");\nconst object = __webpack_require__(/*! ../utils/object.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/object.js\");\nconst spanUtils = __webpack_require__(/*! ../utils/spanUtils.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanUtils.js\");\nconst utils = __webpack_require__(/*! ./utils.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/utils.js\");\n\n/**\n * If you change this value, also update the terser plugin config to\n * avoid minification of the object property!\n */\nconst FROZEN_DSC_FIELD = '_frozenDsc';\n\n/**\n * Freeze the given DSC on the given span.\n */\nfunction freezeDscOnSpan(span, dsc) {\n  const spanWithMaybeDsc = span ;\n  object.addNonEnumerableProperty(spanWithMaybeDsc, FROZEN_DSC_FIELD, dsc);\n}\n\n/**\n * Creates a dynamic sampling context from a client.\n *\n * Dispatches the `createDsc` lifecycle hook as a side effect.\n */\nfunction getDynamicSamplingContextFromClient(trace_id, client) {\n  const options = client.getOptions();\n\n  const { publicKey: public_key, host } = client.getDsn() || {};\n\n  let org_id;\n  if (options.orgId) {\n    org_id = String(options.orgId);\n  } else if (host) {\n    org_id = dsn.extractOrgIdFromDsnHost(host);\n  }\n\n  // Instead of conditionally adding non-undefined values, we add them and then remove them if needed\n  // otherwise, the order of baggage entries changes, which \"breaks\" a bunch of tests etc.\n  const dsc = {\n    environment: options.environment || constants.DEFAULT_ENVIRONMENT,\n    release: options.release,\n    public_key,\n    trace_id,\n    org_id,\n  };\n\n  client.emit('createDsc', dsc);\n\n  return dsc;\n}\n\n/**\n * Get the dynamic sampling context for the currently active scopes.\n */\nfunction getDynamicSamplingContextFromScope(client, scope) {\n  const propagationContext = scope.getPropagationContext();\n  return propagationContext.dsc || getDynamicSamplingContextFromClient(propagationContext.traceId, client);\n}\n\n/**\n * Creates a dynamic sampling context from a span (and client and scope)\n *\n * @param span the span from which a few values like the root span name and sample rate are extracted.\n *\n * @returns a dynamic sampling context\n */\nfunction getDynamicSamplingContextFromSpan(span) {\n  const client = currentScopes.getClient();\n  if (!client) {\n    return {};\n  }\n\n  const rootSpan = spanUtils.getRootSpan(span);\n  const rootSpanJson = spanUtils.spanToJSON(rootSpan);\n  const rootSpanAttributes = rootSpanJson.data;\n  const traceState = rootSpan.spanContext().traceState;\n\n  // The span sample rate that was locally applied to the root span should also always be applied to the DSC, even if the DSC is frozen.\n  // This is so that the downstream traces/services can use parentSampleRate in their `tracesSampler` to make consistent sampling decisions across the entire trace.\n  const rootSpanSampleRate =\n    traceState?.get('sentry.sample_rate') ??\n    rootSpanAttributes[semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_SAMPLE_RATE] ??\n    rootSpanAttributes[semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_PREVIOUS_TRACE_SAMPLE_RATE];\n\n  function applyLocalSampleRateToDsc(dsc) {\n    if (typeof rootSpanSampleRate === 'number' || typeof rootSpanSampleRate === 'string') {\n      dsc.sample_rate = `${rootSpanSampleRate}`;\n    }\n    return dsc;\n  }\n\n  // For core implementation, we freeze the DSC onto the span as a non-enumerable property\n  const frozenDsc = (rootSpan )[FROZEN_DSC_FIELD];\n  if (frozenDsc) {\n    return applyLocalSampleRateToDsc(frozenDsc);\n  }\n\n  // For OpenTelemetry, we freeze the DSC on the trace state\n  const traceStateDsc = traceState?.get('sentry.dsc');\n\n  // If the span has a DSC, we want it to take precedence\n  const dscOnTraceState = traceStateDsc && baggage.baggageHeaderToDynamicSamplingContext(traceStateDsc);\n\n  if (dscOnTraceState) {\n    return applyLocalSampleRateToDsc(dscOnTraceState);\n  }\n\n  // Else, we generate it from the span\n  const dsc = getDynamicSamplingContextFromClient(span.spanContext().traceId, client);\n\n  // We don't want to have a transaction name in the DSC if the source is \"url\" because URLs might contain PII\n  const source = rootSpanAttributes[semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_SOURCE];\n\n  // after JSON conversion, txn.name becomes jsonSpan.description\n  const name = rootSpanJson.description;\n  if (source !== 'url' && name) {\n    dsc.transaction = name;\n  }\n\n  // How can we even land here with hasSpansEnabled() returning false?\n  // Otel creates a Non-recording span in Tracing Without Performance mode when handling incoming requests\n  // So we end up with an active span that is not sampled (neither positively nor negatively)\n  if (hasSpansEnabled.hasSpansEnabled()) {\n    dsc.sampled = String(spanUtils.spanIsSampled(rootSpan));\n    dsc.sample_rand =\n      // In OTEL we store the sample rand on the trace state because we cannot access scopes for NonRecordingSpans\n      // The Sentry OTEL SpanSampler takes care of writing the sample rand on the root span\n      traceState?.get('sentry.sample_rand') ??\n      // On all other platforms we can actually get the scopes from a root span (we use this as a fallback)\n      utils.getCapturedScopesOnSpan(rootSpan).scope?.getPropagationContext().sampleRand.toString();\n  }\n\n  applyLocalSampleRateToDsc(dsc);\n\n  client.emit('createDsc', dsc, rootSpan);\n\n  return dsc;\n}\n\n/**\n * Convert a Span to a baggage header.\n */\nfunction spanToBaggageHeader(span) {\n  const dsc = getDynamicSamplingContextFromSpan(span);\n  return baggage.dynamicSamplingContextToSentryBaggageHeader(dsc);\n}\n\nexports.freezeDscOnSpan = freezeDscOnSpan;\nexports.getDynamicSamplingContextFromClient = getDynamicSamplingContextFromClient;\nexports.getDynamicSamplingContextFromScope = getDynamicSamplingContextFromScope;\nexports.getDynamicSamplingContextFromSpan = getDynamicSamplingContextFromSpan;\nexports.spanToBaggageHeader = spanToBaggageHeader;\n//# sourceMappingURL=dynamicSamplingContext.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdHJhY2luZy9keW5hbWljU2FtcGxpbmdDb250ZXh0LmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLGtCQUFrQixtQkFBTyxDQUFDLCtIQUFpQjtBQUMzQyxzQkFBc0IsbUJBQU8sQ0FBQyx1SUFBcUI7QUFDbkQsMkJBQTJCLG1CQUFPLENBQUMsaUpBQTBCO0FBQzdELGdCQUFnQixtQkFBTyxDQUFDLHVJQUFxQjtBQUM3QyxZQUFZLG1CQUFPLENBQUMsK0hBQWlCO0FBQ3JDLHdCQUF3QixtQkFBTyxDQUFDLHVKQUE2QjtBQUM3RCxlQUFlLG1CQUFPLENBQUMscUlBQW9CO0FBQzNDLGtCQUFrQixtQkFBTyxDQUFDLDJJQUF1QjtBQUNqRCxjQUFjLG1CQUFPLENBQUMsOEhBQVk7O0FBRWxDO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsVUFBVSw4QkFBOEI7O0FBRXhDO0FBQ0E7QUFDQTtBQUNBLElBQUk7QUFDSjtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLDJCQUEyQixtQkFBbUI7QUFDOUM7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSx1QkFBdUI7QUFDdkIsMkNBQTJDO0FBQzNDLDBDQUEwQztBQUMxQyx5Q0FBeUM7QUFDekMsMkJBQTJCO0FBQzNCIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdHJhY2luZy9keW5hbWljU2FtcGxpbmdDb250ZXh0LmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBjb25zdGFudHMgPSByZXF1aXJlKCcuLi9jb25zdGFudHMuanMnKTtcbmNvbnN0IGN1cnJlbnRTY29wZXMgPSByZXF1aXJlKCcuLi9jdXJyZW50U2NvcGVzLmpzJyk7XG5jb25zdCBzZW1hbnRpY0F0dHJpYnV0ZXMgPSByZXF1aXJlKCcuLi9zZW1hbnRpY0F0dHJpYnV0ZXMuanMnKTtcbmNvbnN0IGJhZ2dhZ2UgPSByZXF1aXJlKCcuLi91dGlscy9iYWdnYWdlLmpzJyk7XG5jb25zdCBkc24gPSByZXF1aXJlKCcuLi91dGlscy9kc24uanMnKTtcbmNvbnN0IGhhc1NwYW5zRW5hYmxlZCA9IHJlcXVpcmUoJy4uL3V0aWxzL2hhc1NwYW5zRW5hYmxlZC5qcycpO1xuY29uc3Qgb2JqZWN0ID0gcmVxdWlyZSgnLi4vdXRpbHMvb2JqZWN0LmpzJyk7XG5jb25zdCBzcGFuVXRpbHMgPSByZXF1aXJlKCcuLi91dGlscy9zcGFuVXRpbHMuanMnKTtcbmNvbnN0IHV0aWxzID0gcmVxdWlyZSgnLi91dGlscy5qcycpO1xuXG4vKipcbiAqIElmIHlvdSBjaGFuZ2UgdGhpcyB2YWx1ZSwgYWxzbyB1cGRhdGUgdGhlIHRlcnNlciBwbHVnaW4gY29uZmlnIHRvXG4gKiBhdm9pZCBtaW5pZmljYXRpb24gb2YgdGhlIG9iamVjdCBwcm9wZXJ0eSFcbiAqL1xuY29uc3QgRlJPWkVOX0RTQ19GSUVMRCA9ICdfZnJvemVuRHNjJztcblxuLyoqXG4gKiBGcmVlemUgdGhlIGdpdmVuIERTQyBvbiB0aGUgZ2l2ZW4gc3Bhbi5cbiAqL1xuZnVuY3Rpb24gZnJlZXplRHNjT25TcGFuKHNwYW4sIGRzYykge1xuICBjb25zdCBzcGFuV2l0aE1heWJlRHNjID0gc3BhbiA7XG4gIG9iamVjdC5hZGROb25FbnVtZXJhYmxlUHJvcGVydHkoc3BhbldpdGhNYXliZURzYywgRlJPWkVOX0RTQ19GSUVMRCwgZHNjKTtcbn1cblxuLyoqXG4gKiBDcmVhdGVzIGEgZHluYW1pYyBzYW1wbGluZyBjb250ZXh0IGZyb20gYSBjbGllbnQuXG4gKlxuICogRGlzcGF0Y2hlcyB0aGUgYGNyZWF0ZURzY2AgbGlmZWN5Y2xlIGhvb2sgYXMgYSBzaWRlIGVmZmVjdC5cbiAqL1xuZnVuY3Rpb24gZ2V0RHluYW1pY1NhbXBsaW5nQ29udGV4dEZyb21DbGllbnQodHJhY2VfaWQsIGNsaWVudCkge1xuICBjb25zdCBvcHRpb25zID0gY2xpZW50LmdldE9wdGlvbnMoKTtcblxuICBjb25zdCB7IHB1YmxpY0tleTogcHVibGljX2tleSwgaG9zdCB9ID0gY2xpZW50LmdldERzbigpIHx8IHt9O1xuXG4gIGxldCBvcmdfaWQ7XG4gIGlmIChvcHRpb25zLm9yZ0lkKSB7XG4gICAgb3JnX2lkID0gU3RyaW5nKG9wdGlvbnMub3JnSWQpO1xuICB9IGVsc2UgaWYgKGhvc3QpIHtcbiAgICBvcmdfaWQgPSBkc24uZXh0cmFjdE9yZ0lkRnJvbURzbkhvc3QoaG9zdCk7XG4gIH1cblxuICAvLyBJbnN0ZWFkIG9mIGNvbmRpdGlvbmFsbHkgYWRkaW5nIG5vbi11bmRlZmluZWQgdmFsdWVzLCB3ZSBhZGQgdGhlbSBhbmQgdGhlbiByZW1vdmUgdGhlbSBpZiBuZWVkZWRcbiAgLy8gb3RoZXJ3aXNlLCB0aGUgb3JkZXIgb2YgYmFnZ2FnZSBlbnRyaWVzIGNoYW5nZXMsIHdoaWNoIFwiYnJlYWtzXCIgYSBidW5jaCBvZiB0ZXN0cyBldGMuXG4gIGNvbnN0IGRzYyA9IHtcbiAgICBlbnZpcm9ubWVudDogb3B0aW9ucy5lbnZpcm9ubWVudCB8fCBjb25zdGFudHMuREVGQVVMVF9FTlZJUk9OTUVOVCxcbiAgICByZWxlYXNlOiBvcHRpb25zLnJlbGVhc2UsXG4gICAgcHVibGljX2tleSxcbiAgICB0cmFjZV9pZCxcbiAgICBvcmdfaWQsXG4gIH07XG5cbiAgY2xpZW50LmVtaXQoJ2NyZWF0ZURzYycsIGRzYyk7XG5cbiAgcmV0dXJuIGRzYztcbn1cblxuLyoqXG4gKiBHZXQgdGhlIGR5bmFtaWMgc2FtcGxpbmcgY29udGV4dCBmb3IgdGhlIGN1cnJlbnRseSBhY3RpdmUgc2NvcGVzLlxuICovXG5mdW5jdGlvbiBnZXREeW5hbWljU2FtcGxpbmdDb250ZXh0RnJvbVNjb3BlKGNsaWVudCwgc2NvcGUpIHtcbiAgY29uc3QgcHJvcGFnYXRpb25Db250ZXh0ID0gc2NvcGUuZ2V0UHJvcGFnYXRpb25Db250ZXh0KCk7XG4gIHJldHVybiBwcm9wYWdhdGlvbkNvbnRleHQuZHNjIHx8IGdldER5bmFtaWNTYW1wbGluZ0NvbnRleHRGcm9tQ2xpZW50KHByb3BhZ2F0aW9uQ29udGV4dC50cmFjZUlkLCBjbGllbnQpO1xufVxuXG4vKipcbiAqIENyZWF0ZXMgYSBkeW5hbWljIHNhbXBsaW5nIGNvbnRleHQgZnJvbSBhIHNwYW4gKGFuZCBjbGllbnQgYW5kIHNjb3BlKVxuICpcbiAqIEBwYXJhbSBzcGFuIHRoZSBzcGFuIGZyb20gd2hpY2ggYSBmZXcgdmFsdWVzIGxpa2UgdGhlIHJvb3Qgc3BhbiBuYW1lIGFuZCBzYW1wbGUgcmF0ZSBhcmUgZXh0cmFjdGVkLlxuICpcbiAqIEByZXR1cm5zIGEgZHluYW1pYyBzYW1wbGluZyBjb250ZXh0XG4gKi9cbmZ1bmN0aW9uIGdldER5bmFtaWNTYW1wbGluZ0NvbnRleHRGcm9tU3BhbihzcGFuKSB7XG4gIGNvbnN0IGNsaWVudCA9IGN1cnJlbnRTY29wZXMuZ2V0Q2xpZW50KCk7XG4gIGlmICghY2xpZW50KSB7XG4gICAgcmV0dXJuIHt9O1xuICB9XG5cbiAgY29uc3Qgcm9vdFNwYW4gPSBzcGFuVXRpbHMuZ2V0Um9vdFNwYW4oc3Bhbik7XG4gIGNvbnN0IHJvb3RTcGFuSnNvbiA9IHNwYW5VdGlscy5zcGFuVG9KU09OKHJvb3RTcGFuKTtcbiAgY29uc3Qgcm9vdFNwYW5BdHRyaWJ1dGVzID0gcm9vdFNwYW5Kc29uLmRhdGE7XG4gIGNvbnN0IHRyYWNlU3RhdGUgPSByb290U3Bhbi5zcGFuQ29udGV4dCgpLnRyYWNlU3RhdGU7XG5cbiAgLy8gVGhlIHNwYW4gc2FtcGxlIHJhdGUgdGhhdCB3YXMgbG9jYWxseSBhcHBsaWVkIHRvIHRoZSByb290IHNwYW4gc2hvdWxkIGFsc28gYWx3YXlzIGJlIGFwcGxpZWQgdG8gdGhlIERTQywgZXZlbiBpZiB0aGUgRFNDIGlzIGZyb3plbi5cbiAgLy8gVGhpcyBpcyBzbyB0aGF0IHRoZSBkb3duc3RyZWFtIHRyYWNlcy9zZXJ2aWNlcyBjYW4gdXNlIHBhcmVudFNhbXBsZVJhdGUgaW4gdGhlaXIgYHRyYWNlc1NhbXBsZXJgIHRvIG1ha2UgY29uc2lzdGVudCBzYW1wbGluZyBkZWNpc2lvbnMgYWNyb3NzIHRoZSBlbnRpcmUgdHJhY2UuXG4gIGNvbnN0IHJvb3RTcGFuU2FtcGxlUmF0ZSA9XG4gICAgdHJhY2VTdGF0ZT8uZ2V0KCdzZW50cnkuc2FtcGxlX3JhdGUnKSA/P1xuICAgIHJvb3RTcGFuQXR0cmlidXRlc1tzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9TQU1QTEVfUkFURV0gPz9cbiAgICByb290U3BhbkF0dHJpYnV0ZXNbc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfUFJFVklPVVNfVFJBQ0VfU0FNUExFX1JBVEVdO1xuXG4gIGZ1bmN0aW9uIGFwcGx5TG9jYWxTYW1wbGVSYXRlVG9Ec2MoZHNjKSB7XG4gICAgaWYgKHR5cGVvZiByb290U3BhblNhbXBsZVJhdGUgPT09ICdudW1iZXInIHx8IHR5cGVvZiByb290U3BhblNhbXBsZVJhdGUgPT09ICdzdHJpbmcnKSB7XG4gICAgICBkc2Muc2FtcGxlX3JhdGUgPSBgJHtyb290U3BhblNhbXBsZVJhdGV9YDtcbiAgICB9XG4gICAgcmV0dXJuIGRzYztcbiAgfVxuXG4gIC8vIEZvciBjb3JlIGltcGxlbWVudGF0aW9uLCB3ZSBmcmVlemUgdGhlIERTQyBvbnRvIHRoZSBzcGFuIGFzIGEgbm9uLWVudW1lcmFibGUgcHJvcGVydHlcbiAgY29uc3QgZnJvemVuRHNjID0gKHJvb3RTcGFuIClbRlJPWkVOX0RTQ19GSUVMRF07XG4gIGlmIChmcm96ZW5Ec2MpIHtcbiAgICByZXR1cm4gYXBwbHlMb2NhbFNhbXBsZVJhdGVUb0RzYyhmcm96ZW5Ec2MpO1xuICB9XG5cbiAgLy8gRm9yIE9wZW5UZWxlbWV0cnksIHdlIGZyZWV6ZSB0aGUgRFNDIG9uIHRoZSB0cmFjZSBzdGF0ZVxuICBjb25zdCB0cmFjZVN0YXRlRHNjID0gdHJhY2VTdGF0ZT8uZ2V0KCdzZW50cnkuZHNjJyk7XG5cbiAgLy8gSWYgdGhlIHNwYW4gaGFzIGEgRFNDLCB3ZSB3YW50IGl0IHRvIHRha2UgcHJlY2VkZW5jZVxuICBjb25zdCBkc2NPblRyYWNlU3RhdGUgPSB0cmFjZVN0YXRlRHNjICYmIGJhZ2dhZ2UuYmFnZ2FnZUhlYWRlclRvRHluYW1pY1NhbXBsaW5nQ29udGV4dCh0cmFjZVN0YXRlRHNjKTtcblxuICBpZiAoZHNjT25UcmFjZVN0YXRlKSB7XG4gICAgcmV0dXJuIGFwcGx5TG9jYWxTYW1wbGVSYXRlVG9Ec2MoZHNjT25UcmFjZVN0YXRlKTtcbiAgfVxuXG4gIC8vIEVsc2UsIHdlIGdlbmVyYXRlIGl0IGZyb20gdGhlIHNwYW5cbiAgY29uc3QgZHNjID0gZ2V0RHluYW1pY1NhbXBsaW5nQ29udGV4dEZyb21DbGllbnQoc3Bhbi5zcGFuQ29udGV4dCgpLnRyYWNlSWQsIGNsaWVudCk7XG5cbiAgLy8gV2UgZG9uJ3Qgd2FudCB0byBoYXZlIGEgdHJhbnNhY3Rpb24gbmFtZSBpbiB0aGUgRFNDIGlmIHRoZSBzb3VyY2UgaXMgXCJ1cmxcIiBiZWNhdXNlIFVSTHMgbWlnaHQgY29udGFpbiBQSUlcbiAgY29uc3Qgc291cmNlID0gcm9vdFNwYW5BdHRyaWJ1dGVzW3NlbWFudGljQXR0cmlidXRlcy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX1NPVVJDRV07XG5cbiAgLy8gYWZ0ZXIgSlNPTiBjb252ZXJzaW9uLCB0eG4ubmFtZSBiZWNvbWVzIGpzb25TcGFuLmRlc2NyaXB0aW9uXG4gIGNvbnN0IG5hbWUgPSByb290U3Bhbkpzb24uZGVzY3JpcHRpb247XG4gIGlmIChzb3VyY2UgIT09ICd1cmwnICYmIG5hbWUpIHtcbiAgICBkc2MudHJhbnNhY3Rpb24gPSBuYW1lO1xuICB9XG5cbiAgLy8gSG93IGNhbiB3ZSBldmVuIGxhbmQgaGVyZSB3aXRoIGhhc1NwYW5zRW5hYmxlZCgpIHJldHVybmluZyBmYWxzZT9cbiAgLy8gT3RlbCBjcmVhdGVzIGEgTm9uLXJlY29yZGluZyBzcGFuIGluIFRyYWNpbmcgV2l0aG91dCBQZXJmb3JtYW5jZSBtb2RlIHdoZW4gaGFuZGxpbmcgaW5jb21pbmcgcmVxdWVzdHNcbiAgLy8gU28gd2UgZW5kIHVwIHdpdGggYW4gYWN0aXZlIHNwYW4gdGhhdCBpcyBub3Qgc2FtcGxlZCAobmVpdGhlciBwb3NpdGl2ZWx5IG5vciBuZWdhdGl2ZWx5KVxuICBpZiAoaGFzU3BhbnNFbmFibGVkLmhhc1NwYW5zRW5hYmxlZCgpKSB7XG4gICAgZHNjLnNhbXBsZWQgPSBTdHJpbmcoc3BhblV0aWxzLnNwYW5Jc1NhbXBsZWQocm9vdFNwYW4pKTtcbiAgICBkc2Muc2FtcGxlX3JhbmQgPVxuICAgICAgLy8gSW4gT1RFTCB3ZSBzdG9yZSB0aGUgc2FtcGxlIHJhbmQgb24gdGhlIHRyYWNlIHN0YXRlIGJlY2F1c2Ugd2UgY2Fubm90IGFjY2VzcyBzY29wZXMgZm9yIE5vblJlY29yZGluZ1NwYW5zXG4gICAgICAvLyBUaGUgU2VudHJ5IE9URUwgU3BhblNhbXBsZXIgdGFrZXMgY2FyZSBvZiB3cml0aW5nIHRoZSBzYW1wbGUgcmFuZCBvbiB0aGUgcm9vdCBzcGFuXG4gICAgICB0cmFjZVN0YXRlPy5nZXQoJ3NlbnRyeS5zYW1wbGVfcmFuZCcpID8/XG4gICAgICAvLyBPbiBhbGwgb3RoZXIgcGxhdGZvcm1zIHdlIGNhbiBhY3R1YWxseSBnZXQgdGhlIHNjb3BlcyBmcm9tIGEgcm9vdCBzcGFuICh3ZSB1c2UgdGhpcyBhcyBhIGZhbGxiYWNrKVxuICAgICAgdXRpbHMuZ2V0Q2FwdHVyZWRTY29wZXNPblNwYW4ocm9vdFNwYW4pLnNjb3BlPy5nZXRQcm9wYWdhdGlvbkNvbnRleHQoKS5zYW1wbGVSYW5kLnRvU3RyaW5nKCk7XG4gIH1cblxuICBhcHBseUxvY2FsU2FtcGxlUmF0ZVRvRHNjKGRzYyk7XG5cbiAgY2xpZW50LmVtaXQoJ2NyZWF0ZURzYycsIGRzYywgcm9vdFNwYW4pO1xuXG4gIHJldHVybiBkc2M7XG59XG5cbi8qKlxuICogQ29udmVydCBhIFNwYW4gdG8gYSBiYWdnYWdlIGhlYWRlci5cbiAqL1xuZnVuY3Rpb24gc3BhblRvQmFnZ2FnZUhlYWRlcihzcGFuKSB7XG4gIGNvbnN0IGRzYyA9IGdldER5bmFtaWNTYW1wbGluZ0NvbnRleHRGcm9tU3BhbihzcGFuKTtcbiAgcmV0dXJuIGJhZ2dhZ2UuZHluYW1pY1NhbXBsaW5nQ29udGV4dFRvU2VudHJ5QmFnZ2FnZUhlYWRlcihkc2MpO1xufVxuXG5leHBvcnRzLmZyZWV6ZURzY09uU3BhbiA9IGZyZWV6ZURzY09uU3BhbjtcbmV4cG9ydHMuZ2V0RHluYW1pY1NhbXBsaW5nQ29udGV4dEZyb21DbGllbnQgPSBnZXREeW5hbWljU2FtcGxpbmdDb250ZXh0RnJvbUNsaWVudDtcbmV4cG9ydHMuZ2V0RHluYW1pY1NhbXBsaW5nQ29udGV4dEZyb21TY29wZSA9IGdldER5bmFtaWNTYW1wbGluZ0NvbnRleHRGcm9tU2NvcGU7XG5leHBvcnRzLmdldER5bmFtaWNTYW1wbGluZ0NvbnRleHRGcm9tU3BhbiA9IGdldER5bmFtaWNTYW1wbGluZ0NvbnRleHRGcm9tU3BhbjtcbmV4cG9ydHMuc3BhblRvQmFnZ2FnZUhlYWRlciA9IHNwYW5Ub0JhZ2dhZ2VIZWFkZXI7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1keW5hbWljU2FtcGxpbmdDb250ZXh0LmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/dynamicSamplingContext.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/errors.js":
/*!******************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/errors.js ***!
  \******************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst debugBuild = __webpack_require__(/*! ../debug-build.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst globalError = __webpack_require__(/*! ../instrument/globalError.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/globalError.js\");\nconst globalUnhandledRejection = __webpack_require__(/*! ../instrument/globalUnhandledRejection.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/globalUnhandledRejection.js\");\nconst debugLogger = __webpack_require__(/*! ../utils/debug-logger.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst spanUtils = __webpack_require__(/*! ../utils/spanUtils.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanUtils.js\");\nconst spanstatus = __webpack_require__(/*! ./spanstatus.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/spanstatus.js\");\n\nlet errorsInstrumented = false;\n\n/**\n * Ensure that global errors automatically set the active span status.\n */\nfunction registerSpanErrorInstrumentation() {\n  if (errorsInstrumented) {\n    return;\n  }\n\n  /**\n   * If an error or unhandled promise occurs, we mark the active root span as failed\n   */\n  function errorCallback() {\n    const activeSpan = spanUtils.getActiveSpan();\n    const rootSpan = activeSpan && spanUtils.getRootSpan(activeSpan);\n    if (rootSpan) {\n      const message = 'internal_error';\n      debugBuild.DEBUG_BUILD && debugLogger.debug.log(`[Tracing] Root span: ${message} -> Global error occurred`);\n      rootSpan.setStatus({ code: spanstatus.SPAN_STATUS_ERROR, message });\n    }\n  }\n\n  // The function name will be lost when bundling but we need to be able to identify this listener later to maintain the\n  // node.js default exit behaviour\n  errorCallback.tag = 'sentry_tracingErrorCallback';\n\n  errorsInstrumented = true;\n  globalError.addGlobalErrorInstrumentationHandler(errorCallback);\n  globalUnhandledRejection.addGlobalUnhandledRejectionInstrumentationHandler(errorCallback);\n}\n\nexports.registerSpanErrorInstrumentation = registerSpanErrorInstrumentation;\n//# sourceMappingURL=errors.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdHJhY2luZy9lcnJvcnMuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsbUJBQW1CLG1CQUFPLENBQUMsbUlBQW1CO0FBQzlDLG9CQUFvQixtQkFBTyxDQUFDLHlKQUE4QjtBQUMxRCxpQ0FBaUMsbUJBQU8sQ0FBQyxtTEFBMkM7QUFDcEYsb0JBQW9CLG1CQUFPLENBQUMsaUpBQTBCO0FBQ3RELGtCQUFrQixtQkFBTyxDQUFDLDJJQUF1QjtBQUNqRCxtQkFBbUIsbUJBQU8sQ0FBQyx3SUFBaUI7O0FBRTVDOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSw4RUFBOEUsU0FBUztBQUN2RiwyQkFBMkIsNkNBQTZDO0FBQ3hFO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLHdDQUF3QztBQUN4QyIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3RyYWNpbmcvZXJyb3JzLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBkZWJ1Z0J1aWxkID0gcmVxdWlyZSgnLi4vZGVidWctYnVpbGQuanMnKTtcbmNvbnN0IGdsb2JhbEVycm9yID0gcmVxdWlyZSgnLi4vaW5zdHJ1bWVudC9nbG9iYWxFcnJvci5qcycpO1xuY29uc3QgZ2xvYmFsVW5oYW5kbGVkUmVqZWN0aW9uID0gcmVxdWlyZSgnLi4vaW5zdHJ1bWVudC9nbG9iYWxVbmhhbmRsZWRSZWplY3Rpb24uanMnKTtcbmNvbnN0IGRlYnVnTG9nZ2VyID0gcmVxdWlyZSgnLi4vdXRpbHMvZGVidWctbG9nZ2VyLmpzJyk7XG5jb25zdCBzcGFuVXRpbHMgPSByZXF1aXJlKCcuLi91dGlscy9zcGFuVXRpbHMuanMnKTtcbmNvbnN0IHNwYW5zdGF0dXMgPSByZXF1aXJlKCcuL3NwYW5zdGF0dXMuanMnKTtcblxubGV0IGVycm9yc0luc3RydW1lbnRlZCA9IGZhbHNlO1xuXG4vKipcbiAqIEVuc3VyZSB0aGF0IGdsb2JhbCBlcnJvcnMgYXV0b21hdGljYWxseSBzZXQgdGhlIGFjdGl2ZSBzcGFuIHN0YXR1cy5cbiAqL1xuZnVuY3Rpb24gcmVnaXN0ZXJTcGFuRXJyb3JJbnN0cnVtZW50YXRpb24oKSB7XG4gIGlmIChlcnJvcnNJbnN0cnVtZW50ZWQpIHtcbiAgICByZXR1cm47XG4gIH1cblxuICAvKipcbiAgICogSWYgYW4gZXJyb3Igb3IgdW5oYW5kbGVkIHByb21pc2Ugb2NjdXJzLCB3ZSBtYXJrIHRoZSBhY3RpdmUgcm9vdCBzcGFuIGFzIGZhaWxlZFxuICAgKi9cbiAgZnVuY3Rpb24gZXJyb3JDYWxsYmFjaygpIHtcbiAgICBjb25zdCBhY3RpdmVTcGFuID0gc3BhblV0aWxzLmdldEFjdGl2ZVNwYW4oKTtcbiAgICBjb25zdCByb290U3BhbiA9IGFjdGl2ZVNwYW4gJiYgc3BhblV0aWxzLmdldFJvb3RTcGFuKGFjdGl2ZVNwYW4pO1xuICAgIGlmIChyb290U3Bhbikge1xuICAgICAgY29uc3QgbWVzc2FnZSA9ICdpbnRlcm5hbF9lcnJvcic7XG4gICAgICBkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEICYmIGRlYnVnTG9nZ2VyLmRlYnVnLmxvZyhgW1RyYWNpbmddIFJvb3Qgc3BhbjogJHttZXNzYWdlfSAtPiBHbG9iYWwgZXJyb3Igb2NjdXJyZWRgKTtcbiAgICAgIHJvb3RTcGFuLnNldFN0YXR1cyh7IGNvZGU6IHNwYW5zdGF0dXMuU1BBTl9TVEFUVVNfRVJST1IsIG1lc3NhZ2UgfSk7XG4gICAgfVxuICB9XG5cbiAgLy8gVGhlIGZ1bmN0aW9uIG5hbWUgd2lsbCBiZSBsb3N0IHdoZW4gYnVuZGxpbmcgYnV0IHdlIG5lZWQgdG8gYmUgYWJsZSB0byBpZGVudGlmeSB0aGlzIGxpc3RlbmVyIGxhdGVyIHRvIG1haW50YWluIHRoZVxuICAvLyBub2RlLmpzIGRlZmF1bHQgZXhpdCBiZWhhdmlvdXJcbiAgZXJyb3JDYWxsYmFjay50YWcgPSAnc2VudHJ5X3RyYWNpbmdFcnJvckNhbGxiYWNrJztcblxuICBlcnJvcnNJbnN0cnVtZW50ZWQgPSB0cnVlO1xuICBnbG9iYWxFcnJvci5hZGRHbG9iYWxFcnJvckluc3RydW1lbnRhdGlvbkhhbmRsZXIoZXJyb3JDYWxsYmFjayk7XG4gIGdsb2JhbFVuaGFuZGxlZFJlamVjdGlvbi5hZGRHbG9iYWxVbmhhbmRsZWRSZWplY3Rpb25JbnN0cnVtZW50YXRpb25IYW5kbGVyKGVycm9yQ2FsbGJhY2spO1xufVxuXG5leHBvcnRzLnJlZ2lzdGVyU3BhbkVycm9ySW5zdHJ1bWVudGF0aW9uID0gcmVnaXN0ZXJTcGFuRXJyb3JJbnN0cnVtZW50YXRpb247XG4vLyMgc291cmNlTWFwcGluZ1VSTD1lcnJvcnMuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/errors.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/idleSpan.js":
/*!********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/idleSpan.js ***!
  \********************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst currentScopes = __webpack_require__(/*! ../currentScopes.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst debugBuild = __webpack_require__(/*! ../debug-build.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst semanticAttributes = __webpack_require__(/*! ../semanticAttributes.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/semanticAttributes.js\");\nconst debugLogger = __webpack_require__(/*! ../utils/debug-logger.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst hasSpansEnabled = __webpack_require__(/*! ../utils/hasSpansEnabled.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/hasSpansEnabled.js\");\nconst spanOnScope = __webpack_require__(/*! ../utils/spanOnScope.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanOnScope.js\");\nconst spanUtils = __webpack_require__(/*! ../utils/spanUtils.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanUtils.js\");\nconst time = __webpack_require__(/*! ../utils/time.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/time.js\");\nconst dynamicSamplingContext = __webpack_require__(/*! ./dynamicSamplingContext.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/dynamicSamplingContext.js\");\nconst sentryNonRecordingSpan = __webpack_require__(/*! ./sentryNonRecordingSpan.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/sentryNonRecordingSpan.js\");\nconst sentrySpan = __webpack_require__(/*! ./sentrySpan.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/sentrySpan.js\");\nconst spanstatus = __webpack_require__(/*! ./spanstatus.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/spanstatus.js\");\nconst trace = __webpack_require__(/*! ./trace.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/trace.js\");\n\nconst TRACING_DEFAULTS = {\n  idleTimeout: 1000,\n  finalTimeout: 30000,\n  childSpanTimeout: 15000,\n};\n\nconst FINISH_REASON_HEARTBEAT_FAILED = 'heartbeatFailed';\nconst FINISH_REASON_IDLE_TIMEOUT = 'idleTimeout';\nconst FINISH_REASON_FINAL_TIMEOUT = 'finalTimeout';\nconst FINISH_REASON_EXTERNAL_FINISH = 'externalFinish';\n\n/**\n * An idle span is a span that automatically finishes. It does this by tracking child spans as activities.\n * An idle span is always the active span.\n */\nfunction startIdleSpan(startSpanOptions, options = {}) {\n  // Activities store a list of active spans\n  const activities = new Map();\n\n  // We should not use heartbeat if we finished a span\n  let _finished = false;\n\n  // Timer that tracks idleTimeout\n  let _idleTimeoutID;\n\n  // The reason why the span was finished\n  let _finishReason = FINISH_REASON_EXTERNAL_FINISH;\n\n  let _autoFinishAllowed = !options.disableAutoFinish;\n\n  const _cleanupHooks = [];\n\n  const {\n    idleTimeout = TRACING_DEFAULTS.idleTimeout,\n    finalTimeout = TRACING_DEFAULTS.finalTimeout,\n    childSpanTimeout = TRACING_DEFAULTS.childSpanTimeout,\n    beforeSpanEnd,\n  } = options;\n\n  const client = currentScopes.getClient();\n\n  if (!client || !hasSpansEnabled.hasSpansEnabled()) {\n    const span = new sentryNonRecordingSpan.SentryNonRecordingSpan();\n\n    const dsc = {\n      sample_rate: '0',\n      sampled: 'false',\n      ...dynamicSamplingContext.getDynamicSamplingContextFromSpan(span),\n    } ;\n    dynamicSamplingContext.freezeDscOnSpan(span, dsc);\n\n    return span;\n  }\n\n  const scope = currentScopes.getCurrentScope();\n  const previousActiveSpan = spanUtils.getActiveSpan();\n  const span = _startIdleSpan(startSpanOptions);\n\n  // We patch span.end to ensure we can run some things before the span is ended\n  // eslint-disable-next-line @typescript-eslint/unbound-method\n  span.end = new Proxy(span.end, {\n    apply(target, thisArg, args) {\n      if (beforeSpanEnd) {\n        beforeSpanEnd(span);\n      }\n\n      // If the span is non-recording, nothing more to do here...\n      // This is the case if tracing is enabled but this specific span was not sampled\n      if (thisArg instanceof sentryNonRecordingSpan.SentryNonRecordingSpan) {\n        return;\n      }\n\n      // Just ensuring that this keeps working, even if we ever have more arguments here\n      const [definedEndTimestamp, ...rest] = args;\n      const timestamp = definedEndTimestamp || time.timestampInSeconds();\n      const spanEndTimestamp = spanUtils.spanTimeInputToSeconds(timestamp);\n\n      // Ensure we end with the last span timestamp, if possible\n      const spans = spanUtils.getSpanDescendants(span).filter(child => child !== span);\n\n      // If we have no spans, we just end, nothing else to do here\n      if (!spans.length) {\n        onIdleSpanEnded(spanEndTimestamp);\n        return Reflect.apply(target, thisArg, [spanEndTimestamp, ...rest]);\n      }\n\n      const childEndTimestamps = spans\n        .map(span => spanUtils.spanToJSON(span).timestamp)\n        .filter(timestamp => !!timestamp) ;\n      const latestSpanEndTimestamp = childEndTimestamps.length ? Math.max(...childEndTimestamps) : undefined;\n\n      // In reality this should always exist here, but type-wise it may be undefined...\n      const spanStartTimestamp = spanUtils.spanToJSON(span).start_timestamp;\n\n      // The final endTimestamp should:\n      // * Never be before the span start timestamp\n      // * Be the latestSpanEndTimestamp, if there is one, and it is smaller than the passed span end timestamp\n      // * Otherwise be the passed end timestamp\n      // Final timestamp can never be after finalTimeout\n      const endTimestamp = Math.min(\n        spanStartTimestamp ? spanStartTimestamp + finalTimeout / 1000 : Infinity,\n        Math.max(spanStartTimestamp || -Infinity, Math.min(spanEndTimestamp, latestSpanEndTimestamp || Infinity)),\n      );\n\n      onIdleSpanEnded(endTimestamp);\n      return Reflect.apply(target, thisArg, [endTimestamp, ...rest]);\n    },\n  });\n\n  /**\n   * Cancels the existing idle timeout, if there is one.\n   */\n  function _cancelIdleTimeout() {\n    if (_idleTimeoutID) {\n      clearTimeout(_idleTimeoutID);\n      _idleTimeoutID = undefined;\n    }\n  }\n\n  /**\n   * Restarts idle timeout, if there is no running idle timeout it will start one.\n   */\n  function _restartIdleTimeout(endTimestamp) {\n    _cancelIdleTimeout();\n    _idleTimeoutID = setTimeout(() => {\n      if (!_finished && activities.size === 0 && _autoFinishAllowed) {\n        _finishReason = FINISH_REASON_IDLE_TIMEOUT;\n        span.end(endTimestamp);\n      }\n    }, idleTimeout);\n  }\n\n  /**\n   * Restarts child span timeout, if there is none running it will start one.\n   */\n  function _restartChildSpanTimeout(endTimestamp) {\n    _idleTimeoutID = setTimeout(() => {\n      if (!_finished && _autoFinishAllowed) {\n        _finishReason = FINISH_REASON_HEARTBEAT_FAILED;\n        span.end(endTimestamp);\n      }\n    }, childSpanTimeout);\n  }\n\n  /**\n   * Start tracking a specific activity.\n   * @param spanId The span id that represents the activity\n   */\n  function _pushActivity(spanId) {\n    _cancelIdleTimeout();\n    activities.set(spanId, true);\n\n    const endTimestamp = time.timestampInSeconds();\n    // We need to add the timeout here to have the real endtimestamp of the idle span\n    // Remember timestampInSeconds is in seconds, timeout is in ms\n    _restartChildSpanTimeout(endTimestamp + childSpanTimeout / 1000);\n  }\n\n  /**\n   * Remove an activity from usage\n   * @param spanId The span id that represents the activity\n   */\n  function _popActivity(spanId) {\n    if (activities.has(spanId)) {\n      activities.delete(spanId);\n    }\n\n    if (activities.size === 0) {\n      const endTimestamp = time.timestampInSeconds();\n      // We need to add the timeout here to have the real endtimestamp of the idle span\n      // Remember timestampInSeconds is in seconds, timeout is in ms\n      _restartIdleTimeout(endTimestamp + idleTimeout / 1000);\n    }\n  }\n\n  function onIdleSpanEnded(endTimestamp) {\n    _finished = true;\n    activities.clear();\n\n    _cleanupHooks.forEach(cleanup => cleanup());\n\n    spanOnScope._setSpanForScope(scope, previousActiveSpan);\n\n    const spanJSON = spanUtils.spanToJSON(span);\n\n    const { start_timestamp: startTimestamp } = spanJSON;\n    // This should never happen, but to make TS happy...\n    if (!startTimestamp) {\n      return;\n    }\n\n    const attributes = spanJSON.data;\n    if (!attributes[semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_IDLE_SPAN_FINISH_REASON]) {\n      span.setAttribute(semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_IDLE_SPAN_FINISH_REASON, _finishReason);\n    }\n\n    debugLogger.debug.log(`[Tracing] Idle span \"${spanJSON.op}\" finished`);\n\n    const childSpans = spanUtils.getSpanDescendants(span).filter(child => child !== span);\n\n    let discardedSpans = 0;\n    childSpans.forEach(childSpan => {\n      // We cancel all pending spans with status \"cancelled\" to indicate the idle span was finished early\n      if (childSpan.isRecording()) {\n        childSpan.setStatus({ code: spanstatus.SPAN_STATUS_ERROR, message: 'cancelled' });\n        childSpan.end(endTimestamp);\n        debugBuild.DEBUG_BUILD &&\n          debugLogger.debug.log('[Tracing] Cancelling span since span ended early', JSON.stringify(childSpan, undefined, 2));\n      }\n\n      const childSpanJSON = spanUtils.spanToJSON(childSpan);\n      const { timestamp: childEndTimestamp = 0, start_timestamp: childStartTimestamp = 0 } = childSpanJSON;\n\n      const spanStartedBeforeIdleSpanEnd = childStartTimestamp <= endTimestamp;\n\n      // Add a delta with idle timeout so that we prevent false positives\n      const timeoutWithMarginOfError = (finalTimeout + idleTimeout) / 1000;\n      const spanEndedBeforeFinalTimeout = childEndTimestamp - childStartTimestamp <= timeoutWithMarginOfError;\n\n      if (debugBuild.DEBUG_BUILD) {\n        const stringifiedSpan = JSON.stringify(childSpan, undefined, 2);\n        if (!spanStartedBeforeIdleSpanEnd) {\n          debugLogger.debug.log('[Tracing] Discarding span since it happened after idle span was finished', stringifiedSpan);\n        } else if (!spanEndedBeforeFinalTimeout) {\n          debugLogger.debug.log('[Tracing] Discarding span since it finished after idle span final timeout', stringifiedSpan);\n        }\n      }\n\n      if (!spanEndedBeforeFinalTimeout || !spanStartedBeforeIdleSpanEnd) {\n        spanUtils.removeChildSpanFromSpan(span, childSpan);\n        discardedSpans++;\n      }\n    });\n\n    if (discardedSpans > 0) {\n      span.setAttribute('sentry.idle_span_discarded_spans', discardedSpans);\n    }\n  }\n\n  _cleanupHooks.push(\n    client.on('spanStart', startedSpan => {\n      // If we already finished the idle span,\n      // or if this is the idle span itself being started,\n      // or if the started span has already been closed,\n      // we don't care about it for activity\n      if (\n        _finished ||\n        startedSpan === span ||\n        !!spanUtils.spanToJSON(startedSpan).timestamp ||\n        (startedSpan instanceof sentrySpan.SentrySpan && startedSpan.isStandaloneSpan())\n      ) {\n        return;\n      }\n\n      const allSpans = spanUtils.getSpanDescendants(span);\n\n      // If the span that was just started is a child of the idle span, we should track it\n      if (allSpans.includes(startedSpan)) {\n        _pushActivity(startedSpan.spanContext().spanId);\n      }\n    }),\n  );\n\n  _cleanupHooks.push(\n    client.on('spanEnd', endedSpan => {\n      if (_finished) {\n        return;\n      }\n\n      _popActivity(endedSpan.spanContext().spanId);\n    }),\n  );\n\n  _cleanupHooks.push(\n    client.on('idleSpanEnableAutoFinish', spanToAllowAutoFinish => {\n      if (spanToAllowAutoFinish === span) {\n        _autoFinishAllowed = true;\n        _restartIdleTimeout();\n\n        if (activities.size) {\n          _restartChildSpanTimeout();\n        }\n      }\n    }),\n  );\n\n  // We only start the initial idle timeout if we are not delaying the auto finish\n  if (!options.disableAutoFinish) {\n    _restartIdleTimeout();\n  }\n\n  setTimeout(() => {\n    if (!_finished) {\n      span.setStatus({ code: spanstatus.SPAN_STATUS_ERROR, message: 'deadline_exceeded' });\n      _finishReason = FINISH_REASON_FINAL_TIMEOUT;\n      span.end();\n    }\n  }, finalTimeout);\n\n  return span;\n}\n\nfunction _startIdleSpan(options) {\n  const span = trace.startInactiveSpan(options);\n\n  spanOnScope._setSpanForScope(currentScopes.getCurrentScope(), span);\n\n  debugBuild.DEBUG_BUILD && debugLogger.debug.log('[Tracing] Started span is an idle span');\n\n  return span;\n}\n\nexports.TRACING_DEFAULTS = TRACING_DEFAULTS;\nexports.startIdleSpan = startIdleSpan;\n//# sourceMappingURL=idleSpan.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdHJhY2luZy9pZGxlU3Bhbi5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxzQkFBc0IsbUJBQU8sQ0FBQyx1SUFBcUI7QUFDbkQsbUJBQW1CLG1CQUFPLENBQUMsbUlBQW1CO0FBQzlDLDJCQUEyQixtQkFBTyxDQUFDLGlKQUEwQjtBQUM3RCxvQkFBb0IsbUJBQU8sQ0FBQyxpSkFBMEI7QUFDdEQsd0JBQXdCLG1CQUFPLENBQUMsdUpBQTZCO0FBQzdELG9CQUFvQixtQkFBTyxDQUFDLCtJQUF5QjtBQUNyRCxrQkFBa0IsbUJBQU8sQ0FBQywySUFBdUI7QUFDakQsYUFBYSxtQkFBTyxDQUFDLGlJQUFrQjtBQUN2QywrQkFBK0IsbUJBQU8sQ0FBQyxnS0FBNkI7QUFDcEUsK0JBQStCLG1CQUFPLENBQUMsZ0tBQTZCO0FBQ3BFLG1CQUFtQixtQkFBTyxDQUFDLHdJQUFpQjtBQUM1QyxtQkFBbUIsbUJBQU8sQ0FBQyx3SUFBaUI7QUFDNUMsY0FBYyxtQkFBTyxDQUFDLDhIQUFZOztBQUVsQztBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EscURBQXFEO0FBQ3JEO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLElBQUk7O0FBRUo7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLEtBQUs7QUFDTCxHQUFHOztBQUVIO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEtBQUs7QUFDTDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxLQUFLO0FBQ0w7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTs7QUFFQTs7QUFFQSxZQUFZLGtDQUFrQztBQUM5QztBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSxrREFBa0QsWUFBWTs7QUFFOUQ7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQSw4QkFBOEIsMERBQTBEO0FBQ3hGO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0EsY0FBYyw2RUFBNkU7O0FBRTNGOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFVBQVU7QUFDVjtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQSxLQUFLOztBQUVMO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQSxLQUFLO0FBQ0w7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBLEtBQUs7QUFDTDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsS0FBSztBQUNMOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQSx1QkFBdUIsa0VBQWtFO0FBQ3pGO0FBQ0E7QUFDQTtBQUNBLEdBQUc7O0FBRUg7QUFDQTs7QUFFQTtBQUNBOztBQUVBOztBQUVBOztBQUVBO0FBQ0E7O0FBRUEsd0JBQXdCO0FBQ3hCLHFCQUFxQjtBQUNyQiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3RyYWNpbmcvaWRsZVNwYW4uanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGN1cnJlbnRTY29wZXMgPSByZXF1aXJlKCcuLi9jdXJyZW50U2NvcGVzLmpzJyk7XG5jb25zdCBkZWJ1Z0J1aWxkID0gcmVxdWlyZSgnLi4vZGVidWctYnVpbGQuanMnKTtcbmNvbnN0IHNlbWFudGljQXR0cmlidXRlcyA9IHJlcXVpcmUoJy4uL3NlbWFudGljQXR0cmlidXRlcy5qcycpO1xuY29uc3QgZGVidWdMb2dnZXIgPSByZXF1aXJlKCcuLi91dGlscy9kZWJ1Zy1sb2dnZXIuanMnKTtcbmNvbnN0IGhhc1NwYW5zRW5hYmxlZCA9IHJlcXVpcmUoJy4uL3V0aWxzL2hhc1NwYW5zRW5hYmxlZC5qcycpO1xuY29uc3Qgc3Bhbk9uU2NvcGUgPSByZXF1aXJlKCcuLi91dGlscy9zcGFuT25TY29wZS5qcycpO1xuY29uc3Qgc3BhblV0aWxzID0gcmVxdWlyZSgnLi4vdXRpbHMvc3BhblV0aWxzLmpzJyk7XG5jb25zdCB0aW1lID0gcmVxdWlyZSgnLi4vdXRpbHMvdGltZS5qcycpO1xuY29uc3QgZHluYW1pY1NhbXBsaW5nQ29udGV4dCA9IHJlcXVpcmUoJy4vZHluYW1pY1NhbXBsaW5nQ29udGV4dC5qcycpO1xuY29uc3Qgc2VudHJ5Tm9uUmVjb3JkaW5nU3BhbiA9IHJlcXVpcmUoJy4vc2VudHJ5Tm9uUmVjb3JkaW5nU3Bhbi5qcycpO1xuY29uc3Qgc2VudHJ5U3BhbiA9IHJlcXVpcmUoJy4vc2VudHJ5U3Bhbi5qcycpO1xuY29uc3Qgc3BhbnN0YXR1cyA9IHJlcXVpcmUoJy4vc3BhbnN0YXR1cy5qcycpO1xuY29uc3QgdHJhY2UgPSByZXF1aXJlKCcuL3RyYWNlLmpzJyk7XG5cbmNvbnN0IFRSQUNJTkdfREVGQVVMVFMgPSB7XG4gIGlkbGVUaW1lb3V0OiAxMDAwLFxuICBmaW5hbFRpbWVvdXQ6IDMwMDAwLFxuICBjaGlsZFNwYW5UaW1lb3V0OiAxNTAwMCxcbn07XG5cbmNvbnN0IEZJTklTSF9SRUFTT05fSEVBUlRCRUFUX0ZBSUxFRCA9ICdoZWFydGJlYXRGYWlsZWQnO1xuY29uc3QgRklOSVNIX1JFQVNPTl9JRExFX1RJTUVPVVQgPSAnaWRsZVRpbWVvdXQnO1xuY29uc3QgRklOSVNIX1JFQVNPTl9GSU5BTF9USU1FT1VUID0gJ2ZpbmFsVGltZW91dCc7XG5jb25zdCBGSU5JU0hfUkVBU09OX0VYVEVSTkFMX0ZJTklTSCA9ICdleHRlcm5hbEZpbmlzaCc7XG5cbi8qKlxuICogQW4gaWRsZSBzcGFuIGlzIGEgc3BhbiB0aGF0IGF1dG9tYXRpY2FsbHkgZmluaXNoZXMuIEl0IGRvZXMgdGhpcyBieSB0cmFja2luZyBjaGlsZCBzcGFucyBhcyBhY3Rpdml0aWVzLlxuICogQW4gaWRsZSBzcGFuIGlzIGFsd2F5cyB0aGUgYWN0aXZlIHNwYW4uXG4gKi9cbmZ1bmN0aW9uIHN0YXJ0SWRsZVNwYW4oc3RhcnRTcGFuT3B0aW9ucywgb3B0aW9ucyA9IHt9KSB7XG4gIC8vIEFjdGl2aXRpZXMgc3RvcmUgYSBsaXN0IG9mIGFjdGl2ZSBzcGFuc1xuICBjb25zdCBhY3Rpdml0aWVzID0gbmV3IE1hcCgpO1xuXG4gIC8vIFdlIHNob3VsZCBub3QgdXNlIGhlYXJ0YmVhdCBpZiB3ZSBmaW5pc2hlZCBhIHNwYW5cbiAgbGV0IF9maW5pc2hlZCA9IGZhbHNlO1xuXG4gIC8vIFRpbWVyIHRoYXQgdHJhY2tzIGlkbGVUaW1lb3V0XG4gIGxldCBfaWRsZVRpbWVvdXRJRDtcblxuICAvLyBUaGUgcmVhc29uIHdoeSB0aGUgc3BhbiB3YXMgZmluaXNoZWRcbiAgbGV0IF9maW5pc2hSZWFzb24gPSBGSU5JU0hfUkVBU09OX0VYVEVSTkFMX0ZJTklTSDtcblxuICBsZXQgX2F1dG9GaW5pc2hBbGxvd2VkID0gIW9wdGlvbnMuZGlzYWJsZUF1dG9GaW5pc2g7XG5cbiAgY29uc3QgX2NsZWFudXBIb29rcyA9IFtdO1xuXG4gIGNvbnN0IHtcbiAgICBpZGxlVGltZW91dCA9IFRSQUNJTkdfREVGQVVMVFMuaWRsZVRpbWVvdXQsXG4gICAgZmluYWxUaW1lb3V0ID0gVFJBQ0lOR19ERUZBVUxUUy5maW5hbFRpbWVvdXQsXG4gICAgY2hpbGRTcGFuVGltZW91dCA9IFRSQUNJTkdfREVGQVVMVFMuY2hpbGRTcGFuVGltZW91dCxcbiAgICBiZWZvcmVTcGFuRW5kLFxuICB9ID0gb3B0aW9ucztcblxuICBjb25zdCBjbGllbnQgPSBjdXJyZW50U2NvcGVzLmdldENsaWVudCgpO1xuXG4gIGlmICghY2xpZW50IHx8ICFoYXNTcGFuc0VuYWJsZWQuaGFzU3BhbnNFbmFibGVkKCkpIHtcbiAgICBjb25zdCBzcGFuID0gbmV3IHNlbnRyeU5vblJlY29yZGluZ1NwYW4uU2VudHJ5Tm9uUmVjb3JkaW5nU3BhbigpO1xuXG4gICAgY29uc3QgZHNjID0ge1xuICAgICAgc2FtcGxlX3JhdGU6ICcwJyxcbiAgICAgIHNhbXBsZWQ6ICdmYWxzZScsXG4gICAgICAuLi5keW5hbWljU2FtcGxpbmdDb250ZXh0LmdldER5bmFtaWNTYW1wbGluZ0NvbnRleHRGcm9tU3BhbihzcGFuKSxcbiAgICB9IDtcbiAgICBkeW5hbWljU2FtcGxpbmdDb250ZXh0LmZyZWV6ZURzY09uU3BhbihzcGFuLCBkc2MpO1xuXG4gICAgcmV0dXJuIHNwYW47XG4gIH1cblxuICBjb25zdCBzY29wZSA9IGN1cnJlbnRTY29wZXMuZ2V0Q3VycmVudFNjb3BlKCk7XG4gIGNvbnN0IHByZXZpb3VzQWN0aXZlU3BhbiA9IHNwYW5VdGlscy5nZXRBY3RpdmVTcGFuKCk7XG4gIGNvbnN0IHNwYW4gPSBfc3RhcnRJZGxlU3BhbihzdGFydFNwYW5PcHRpb25zKTtcblxuICAvLyBXZSBwYXRjaCBzcGFuLmVuZCB0byBlbnN1cmUgd2UgY2FuIHJ1biBzb21lIHRoaW5ncyBiZWZvcmUgdGhlIHNwYW4gaXMgZW5kZWRcbiAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC91bmJvdW5kLW1ldGhvZFxuICBzcGFuLmVuZCA9IG5ldyBQcm94eShzcGFuLmVuZCwge1xuICAgIGFwcGx5KHRhcmdldCwgdGhpc0FyZywgYXJncykge1xuICAgICAgaWYgKGJlZm9yZVNwYW5FbmQpIHtcbiAgICAgICAgYmVmb3JlU3BhbkVuZChzcGFuKTtcbiAgICAgIH1cblxuICAgICAgLy8gSWYgdGhlIHNwYW4gaXMgbm9uLXJlY29yZGluZywgbm90aGluZyBtb3JlIHRvIGRvIGhlcmUuLi5cbiAgICAgIC8vIFRoaXMgaXMgdGhlIGNhc2UgaWYgdHJhY2luZyBpcyBlbmFibGVkIGJ1dCB0aGlzIHNwZWNpZmljIHNwYW4gd2FzIG5vdCBzYW1wbGVkXG4gICAgICBpZiAodGhpc0FyZyBpbnN0YW5jZW9mIHNlbnRyeU5vblJlY29yZGluZ1NwYW4uU2VudHJ5Tm9uUmVjb3JkaW5nU3Bhbikge1xuICAgICAgICByZXR1cm47XG4gICAgICB9XG5cbiAgICAgIC8vIEp1c3QgZW5zdXJpbmcgdGhhdCB0aGlzIGtlZXBzIHdvcmtpbmcsIGV2ZW4gaWYgd2UgZXZlciBoYXZlIG1vcmUgYXJndW1lbnRzIGhlcmVcbiAgICAgIGNvbnN0IFtkZWZpbmVkRW5kVGltZXN0YW1wLCAuLi5yZXN0XSA9IGFyZ3M7XG4gICAgICBjb25zdCB0aW1lc3RhbXAgPSBkZWZpbmVkRW5kVGltZXN0YW1wIHx8IHRpbWUudGltZXN0YW1wSW5TZWNvbmRzKCk7XG4gICAgICBjb25zdCBzcGFuRW5kVGltZXN0YW1wID0gc3BhblV0aWxzLnNwYW5UaW1lSW5wdXRUb1NlY29uZHModGltZXN0YW1wKTtcblxuICAgICAgLy8gRW5zdXJlIHdlIGVuZCB3aXRoIHRoZSBsYXN0IHNwYW4gdGltZXN0YW1wLCBpZiBwb3NzaWJsZVxuICAgICAgY29uc3Qgc3BhbnMgPSBzcGFuVXRpbHMuZ2V0U3BhbkRlc2NlbmRhbnRzKHNwYW4pLmZpbHRlcihjaGlsZCA9PiBjaGlsZCAhPT0gc3Bhbik7XG5cbiAgICAgIC8vIElmIHdlIGhhdmUgbm8gc3BhbnMsIHdlIGp1c3QgZW5kLCBub3RoaW5nIGVsc2UgdG8gZG8gaGVyZVxuICAgICAgaWYgKCFzcGFucy5sZW5ndGgpIHtcbiAgICAgICAgb25JZGxlU3BhbkVuZGVkKHNwYW5FbmRUaW1lc3RhbXApO1xuICAgICAgICByZXR1cm4gUmVmbGVjdC5hcHBseSh0YXJnZXQsIHRoaXNBcmcsIFtzcGFuRW5kVGltZXN0YW1wLCAuLi5yZXN0XSk7XG4gICAgICB9XG5cbiAgICAgIGNvbnN0IGNoaWxkRW5kVGltZXN0YW1wcyA9IHNwYW5zXG4gICAgICAgIC5tYXAoc3BhbiA9PiBzcGFuVXRpbHMuc3BhblRvSlNPTihzcGFuKS50aW1lc3RhbXApXG4gICAgICAgIC5maWx0ZXIodGltZXN0YW1wID0+ICEhdGltZXN0YW1wKSA7XG4gICAgICBjb25zdCBsYXRlc3RTcGFuRW5kVGltZXN0YW1wID0gY2hpbGRFbmRUaW1lc3RhbXBzLmxlbmd0aCA/IE1hdGgubWF4KC4uLmNoaWxkRW5kVGltZXN0YW1wcykgOiB1bmRlZmluZWQ7XG5cbiAgICAgIC8vIEluIHJlYWxpdHkgdGhpcyBzaG91bGQgYWx3YXlzIGV4aXN0IGhlcmUsIGJ1dCB0eXBlLXdpc2UgaXQgbWF5IGJlIHVuZGVmaW5lZC4uLlxuICAgICAgY29uc3Qgc3BhblN0YXJ0VGltZXN0YW1wID0gc3BhblV0aWxzLnNwYW5Ub0pTT04oc3Bhbikuc3RhcnRfdGltZXN0YW1wO1xuXG4gICAgICAvLyBUaGUgZmluYWwgZW5kVGltZXN0YW1wIHNob3VsZDpcbiAgICAgIC8vICogTmV2ZXIgYmUgYmVmb3JlIHRoZSBzcGFuIHN0YXJ0IHRpbWVzdGFtcFxuICAgICAgLy8gKiBCZSB0aGUgbGF0ZXN0U3BhbkVuZFRpbWVzdGFtcCwgaWYgdGhlcmUgaXMgb25lLCBhbmQgaXQgaXMgc21hbGxlciB0aGFuIHRoZSBwYXNzZWQgc3BhbiBlbmQgdGltZXN0YW1wXG4gICAgICAvLyAqIE90aGVyd2lzZSBiZSB0aGUgcGFzc2VkIGVuZCB0aW1lc3RhbXBcbiAgICAgIC8vIEZpbmFsIHRpbWVzdGFtcCBjYW4gbmV2ZXIgYmUgYWZ0ZXIgZmluYWxUaW1lb3V0XG4gICAgICBjb25zdCBlbmRUaW1lc3RhbXAgPSBNYXRoLm1pbihcbiAgICAgICAgc3BhblN0YXJ0VGltZXN0YW1wID8gc3BhblN0YXJ0VGltZXN0YW1wICsgZmluYWxUaW1lb3V0IC8gMTAwMCA6IEluZmluaXR5LFxuICAgICAgICBNYXRoLm1heChzcGFuU3RhcnRUaW1lc3RhbXAgfHwgLUluZmluaXR5LCBNYXRoLm1pbihzcGFuRW5kVGltZXN0YW1wLCBsYXRlc3RTcGFuRW5kVGltZXN0YW1wIHx8IEluZmluaXR5KSksXG4gICAgICApO1xuXG4gICAgICBvbklkbGVTcGFuRW5kZWQoZW5kVGltZXN0YW1wKTtcbiAgICAgIHJldHVybiBSZWZsZWN0LmFwcGx5KHRhcmdldCwgdGhpc0FyZywgW2VuZFRpbWVzdGFtcCwgLi4ucmVzdF0pO1xuICAgIH0sXG4gIH0pO1xuXG4gIC8qKlxuICAgKiBDYW5jZWxzIHRoZSBleGlzdGluZyBpZGxlIHRpbWVvdXQsIGlmIHRoZXJlIGlzIG9uZS5cbiAgICovXG4gIGZ1bmN0aW9uIF9jYW5jZWxJZGxlVGltZW91dCgpIHtcbiAgICBpZiAoX2lkbGVUaW1lb3V0SUQpIHtcbiAgICAgIGNsZWFyVGltZW91dChfaWRsZVRpbWVvdXRJRCk7XG4gICAgICBfaWRsZVRpbWVvdXRJRCA9IHVuZGVmaW5lZDtcbiAgICB9XG4gIH1cblxuICAvKipcbiAgICogUmVzdGFydHMgaWRsZSB0aW1lb3V0LCBpZiB0aGVyZSBpcyBubyBydW5uaW5nIGlkbGUgdGltZW91dCBpdCB3aWxsIHN0YXJ0IG9uZS5cbiAgICovXG4gIGZ1bmN0aW9uIF9yZXN0YXJ0SWRsZVRpbWVvdXQoZW5kVGltZXN0YW1wKSB7XG4gICAgX2NhbmNlbElkbGVUaW1lb3V0KCk7XG4gICAgX2lkbGVUaW1lb3V0SUQgPSBzZXRUaW1lb3V0KCgpID0+IHtcbiAgICAgIGlmICghX2ZpbmlzaGVkICYmIGFjdGl2aXRpZXMuc2l6ZSA9PT0gMCAmJiBfYXV0b0ZpbmlzaEFsbG93ZWQpIHtcbiAgICAgICAgX2ZpbmlzaFJlYXNvbiA9IEZJTklTSF9SRUFTT05fSURMRV9USU1FT1VUO1xuICAgICAgICBzcGFuLmVuZChlbmRUaW1lc3RhbXApO1xuICAgICAgfVxuICAgIH0sIGlkbGVUaW1lb3V0KTtcbiAgfVxuXG4gIC8qKlxuICAgKiBSZXN0YXJ0cyBjaGlsZCBzcGFuIHRpbWVvdXQsIGlmIHRoZXJlIGlzIG5vbmUgcnVubmluZyBpdCB3aWxsIHN0YXJ0IG9uZS5cbiAgICovXG4gIGZ1bmN0aW9uIF9yZXN0YXJ0Q2hpbGRTcGFuVGltZW91dChlbmRUaW1lc3RhbXApIHtcbiAgICBfaWRsZVRpbWVvdXRJRCA9IHNldFRpbWVvdXQoKCkgPT4ge1xuICAgICAgaWYgKCFfZmluaXNoZWQgJiYgX2F1dG9GaW5pc2hBbGxvd2VkKSB7XG4gICAgICAgIF9maW5pc2hSZWFzb24gPSBGSU5JU0hfUkVBU09OX0hFQVJUQkVBVF9GQUlMRUQ7XG4gICAgICAgIHNwYW4uZW5kKGVuZFRpbWVzdGFtcCk7XG4gICAgICB9XG4gICAgfSwgY2hpbGRTcGFuVGltZW91dCk7XG4gIH1cblxuICAvKipcbiAgICogU3RhcnQgdHJhY2tpbmcgYSBzcGVjaWZpYyBhY3Rpdml0eS5cbiAgICogQHBhcmFtIHNwYW5JZCBUaGUgc3BhbiBpZCB0aGF0IHJlcHJlc2VudHMgdGhlIGFjdGl2aXR5XG4gICAqL1xuICBmdW5jdGlvbiBfcHVzaEFjdGl2aXR5KHNwYW5JZCkge1xuICAgIF9jYW5jZWxJZGxlVGltZW91dCgpO1xuICAgIGFjdGl2aXRpZXMuc2V0KHNwYW5JZCwgdHJ1ZSk7XG5cbiAgICBjb25zdCBlbmRUaW1lc3RhbXAgPSB0aW1lLnRpbWVzdGFtcEluU2Vjb25kcygpO1xuICAgIC8vIFdlIG5lZWQgdG8gYWRkIHRoZSB0aW1lb3V0IGhlcmUgdG8gaGF2ZSB0aGUgcmVhbCBlbmR0aW1lc3RhbXAgb2YgdGhlIGlkbGUgc3BhblxuICAgIC8vIFJlbWVtYmVyIHRpbWVzdGFtcEluU2Vjb25kcyBpcyBpbiBzZWNvbmRzLCB0aW1lb3V0IGlzIGluIG1zXG4gICAgX3Jlc3RhcnRDaGlsZFNwYW5UaW1lb3V0KGVuZFRpbWVzdGFtcCArIGNoaWxkU3BhblRpbWVvdXQgLyAxMDAwKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBSZW1vdmUgYW4gYWN0aXZpdHkgZnJvbSB1c2FnZVxuICAgKiBAcGFyYW0gc3BhbklkIFRoZSBzcGFuIGlkIHRoYXQgcmVwcmVzZW50cyB0aGUgYWN0aXZpdHlcbiAgICovXG4gIGZ1bmN0aW9uIF9wb3BBY3Rpdml0eShzcGFuSWQpIHtcbiAgICBpZiAoYWN0aXZpdGllcy5oYXMoc3BhbklkKSkge1xuICAgICAgYWN0aXZpdGllcy5kZWxldGUoc3BhbklkKTtcbiAgICB9XG5cbiAgICBpZiAoYWN0aXZpdGllcy5zaXplID09PSAwKSB7XG4gICAgICBjb25zdCBlbmRUaW1lc3RhbXAgPSB0aW1lLnRpbWVzdGFtcEluU2Vjb25kcygpO1xuICAgICAgLy8gV2UgbmVlZCB0byBhZGQgdGhlIHRpbWVvdXQgaGVyZSB0byBoYXZlIHRoZSByZWFsIGVuZHRpbWVzdGFtcCBvZiB0aGUgaWRsZSBzcGFuXG4gICAgICAvLyBSZW1lbWJlciB0aW1lc3RhbXBJblNlY29uZHMgaXMgaW4gc2Vjb25kcywgdGltZW91dCBpcyBpbiBtc1xuICAgICAgX3Jlc3RhcnRJZGxlVGltZW91dChlbmRUaW1lc3RhbXAgKyBpZGxlVGltZW91dCAvIDEwMDApO1xuICAgIH1cbiAgfVxuXG4gIGZ1bmN0aW9uIG9uSWRsZVNwYW5FbmRlZChlbmRUaW1lc3RhbXApIHtcbiAgICBfZmluaXNoZWQgPSB0cnVlO1xuICAgIGFjdGl2aXRpZXMuY2xlYXIoKTtcblxuICAgIF9jbGVhbnVwSG9va3MuZm9yRWFjaChjbGVhbnVwID0+IGNsZWFudXAoKSk7XG5cbiAgICBzcGFuT25TY29wZS5fc2V0U3BhbkZvclNjb3BlKHNjb3BlLCBwcmV2aW91c0FjdGl2ZVNwYW4pO1xuXG4gICAgY29uc3Qgc3BhbkpTT04gPSBzcGFuVXRpbHMuc3BhblRvSlNPTihzcGFuKTtcblxuICAgIGNvbnN0IHsgc3RhcnRfdGltZXN0YW1wOiBzdGFydFRpbWVzdGFtcCB9ID0gc3BhbkpTT047XG4gICAgLy8gVGhpcyBzaG91bGQgbmV2ZXIgaGFwcGVuLCBidXQgdG8gbWFrZSBUUyBoYXBweS4uLlxuICAgIGlmICghc3RhcnRUaW1lc3RhbXApIHtcbiAgICAgIHJldHVybjtcbiAgICB9XG5cbiAgICBjb25zdCBhdHRyaWJ1dGVzID0gc3BhbkpTT04uZGF0YTtcbiAgICBpZiAoIWF0dHJpYnV0ZXNbc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfSURMRV9TUEFOX0ZJTklTSF9SRUFTT05dKSB7XG4gICAgICBzcGFuLnNldEF0dHJpYnV0ZShzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9JRExFX1NQQU5fRklOSVNIX1JFQVNPTiwgX2ZpbmlzaFJlYXNvbik7XG4gICAgfVxuXG4gICAgZGVidWdMb2dnZXIuZGVidWcubG9nKGBbVHJhY2luZ10gSWRsZSBzcGFuIFwiJHtzcGFuSlNPTi5vcH1cIiBmaW5pc2hlZGApO1xuXG4gICAgY29uc3QgY2hpbGRTcGFucyA9IHNwYW5VdGlscy5nZXRTcGFuRGVzY2VuZGFudHMoc3BhbikuZmlsdGVyKGNoaWxkID0+IGNoaWxkICE9PSBzcGFuKTtcblxuICAgIGxldCBkaXNjYXJkZWRTcGFucyA9IDA7XG4gICAgY2hpbGRTcGFucy5mb3JFYWNoKGNoaWxkU3BhbiA9PiB7XG4gICAgICAvLyBXZSBjYW5jZWwgYWxsIHBlbmRpbmcgc3BhbnMgd2l0aCBzdGF0dXMgXCJjYW5jZWxsZWRcIiB0byBpbmRpY2F0ZSB0aGUgaWRsZSBzcGFuIHdhcyBmaW5pc2hlZCBlYXJseVxuICAgICAgaWYgKGNoaWxkU3Bhbi5pc1JlY29yZGluZygpKSB7XG4gICAgICAgIGNoaWxkU3Bhbi5zZXRTdGF0dXMoeyBjb2RlOiBzcGFuc3RhdHVzLlNQQU5fU1RBVFVTX0VSUk9SLCBtZXNzYWdlOiAnY2FuY2VsbGVkJyB9KTtcbiAgICAgICAgY2hpbGRTcGFuLmVuZChlbmRUaW1lc3RhbXApO1xuICAgICAgICBkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEICYmXG4gICAgICAgICAgZGVidWdMb2dnZXIuZGVidWcubG9nKCdbVHJhY2luZ10gQ2FuY2VsbGluZyBzcGFuIHNpbmNlIHNwYW4gZW5kZWQgZWFybHknLCBKU09OLnN0cmluZ2lmeShjaGlsZFNwYW4sIHVuZGVmaW5lZCwgMikpO1xuICAgICAgfVxuXG4gICAgICBjb25zdCBjaGlsZFNwYW5KU09OID0gc3BhblV0aWxzLnNwYW5Ub0pTT04oY2hpbGRTcGFuKTtcbiAgICAgIGNvbnN0IHsgdGltZXN0YW1wOiBjaGlsZEVuZFRpbWVzdGFtcCA9IDAsIHN0YXJ0X3RpbWVzdGFtcDogY2hpbGRTdGFydFRpbWVzdGFtcCA9IDAgfSA9IGNoaWxkU3BhbkpTT047XG5cbiAgICAgIGNvbnN0IHNwYW5TdGFydGVkQmVmb3JlSWRsZVNwYW5FbmQgPSBjaGlsZFN0YXJ0VGltZXN0YW1wIDw9IGVuZFRpbWVzdGFtcDtcblxuICAgICAgLy8gQWRkIGEgZGVsdGEgd2l0aCBpZGxlIHRpbWVvdXQgc28gdGhhdCB3ZSBwcmV2ZW50IGZhbHNlIHBvc2l0aXZlc1xuICAgICAgY29uc3QgdGltZW91dFdpdGhNYXJnaW5PZkVycm9yID0gKGZpbmFsVGltZW91dCArIGlkbGVUaW1lb3V0KSAvIDEwMDA7XG4gICAgICBjb25zdCBzcGFuRW5kZWRCZWZvcmVGaW5hbFRpbWVvdXQgPSBjaGlsZEVuZFRpbWVzdGFtcCAtIGNoaWxkU3RhcnRUaW1lc3RhbXAgPD0gdGltZW91dFdpdGhNYXJnaW5PZkVycm9yO1xuXG4gICAgICBpZiAoZGVidWdCdWlsZC5ERUJVR19CVUlMRCkge1xuICAgICAgICBjb25zdCBzdHJpbmdpZmllZFNwYW4gPSBKU09OLnN0cmluZ2lmeShjaGlsZFNwYW4sIHVuZGVmaW5lZCwgMik7XG4gICAgICAgIGlmICghc3BhblN0YXJ0ZWRCZWZvcmVJZGxlU3BhbkVuZCkge1xuICAgICAgICAgIGRlYnVnTG9nZ2VyLmRlYnVnLmxvZygnW1RyYWNpbmddIERpc2NhcmRpbmcgc3BhbiBzaW5jZSBpdCBoYXBwZW5lZCBhZnRlciBpZGxlIHNwYW4gd2FzIGZpbmlzaGVkJywgc3RyaW5naWZpZWRTcGFuKTtcbiAgICAgICAgfSBlbHNlIGlmICghc3BhbkVuZGVkQmVmb3JlRmluYWxUaW1lb3V0KSB7XG4gICAgICAgICAgZGVidWdMb2dnZXIuZGVidWcubG9nKCdbVHJhY2luZ10gRGlzY2FyZGluZyBzcGFuIHNpbmNlIGl0IGZpbmlzaGVkIGFmdGVyIGlkbGUgc3BhbiBmaW5hbCB0aW1lb3V0Jywgc3RyaW5naWZpZWRTcGFuKTtcbiAgICAgICAgfVxuICAgICAgfVxuXG4gICAgICBpZiAoIXNwYW5FbmRlZEJlZm9yZUZpbmFsVGltZW91dCB8fCAhc3BhblN0YXJ0ZWRCZWZvcmVJZGxlU3BhbkVuZCkge1xuICAgICAgICBzcGFuVXRpbHMucmVtb3ZlQ2hpbGRTcGFuRnJvbVNwYW4oc3BhbiwgY2hpbGRTcGFuKTtcbiAgICAgICAgZGlzY2FyZGVkU3BhbnMrKztcbiAgICAgIH1cbiAgICB9KTtcblxuICAgIGlmIChkaXNjYXJkZWRTcGFucyA+IDApIHtcbiAgICAgIHNwYW4uc2V0QXR0cmlidXRlKCdzZW50cnkuaWRsZV9zcGFuX2Rpc2NhcmRlZF9zcGFucycsIGRpc2NhcmRlZFNwYW5zKTtcbiAgICB9XG4gIH1cblxuICBfY2xlYW51cEhvb2tzLnB1c2goXG4gICAgY2xpZW50Lm9uKCdzcGFuU3RhcnQnLCBzdGFydGVkU3BhbiA9PiB7XG4gICAgICAvLyBJZiB3ZSBhbHJlYWR5IGZpbmlzaGVkIHRoZSBpZGxlIHNwYW4sXG4gICAgICAvLyBvciBpZiB0aGlzIGlzIHRoZSBpZGxlIHNwYW4gaXRzZWxmIGJlaW5nIHN0YXJ0ZWQsXG4gICAgICAvLyBvciBpZiB0aGUgc3RhcnRlZCBzcGFuIGhhcyBhbHJlYWR5IGJlZW4gY2xvc2VkLFxuICAgICAgLy8gd2UgZG9uJ3QgY2FyZSBhYm91dCBpdCBmb3IgYWN0aXZpdHlcbiAgICAgIGlmIChcbiAgICAgICAgX2ZpbmlzaGVkIHx8XG4gICAgICAgIHN0YXJ0ZWRTcGFuID09PSBzcGFuIHx8XG4gICAgICAgICEhc3BhblV0aWxzLnNwYW5Ub0pTT04oc3RhcnRlZFNwYW4pLnRpbWVzdGFtcCB8fFxuICAgICAgICAoc3RhcnRlZFNwYW4gaW5zdGFuY2VvZiBzZW50cnlTcGFuLlNlbnRyeVNwYW4gJiYgc3RhcnRlZFNwYW4uaXNTdGFuZGFsb25lU3BhbigpKVxuICAgICAgKSB7XG4gICAgICAgIHJldHVybjtcbiAgICAgIH1cblxuICAgICAgY29uc3QgYWxsU3BhbnMgPSBzcGFuVXRpbHMuZ2V0U3BhbkRlc2NlbmRhbnRzKHNwYW4pO1xuXG4gICAgICAvLyBJZiB0aGUgc3BhbiB0aGF0IHdhcyBqdXN0IHN0YXJ0ZWQgaXMgYSBjaGlsZCBvZiB0aGUgaWRsZSBzcGFuLCB3ZSBzaG91bGQgdHJhY2sgaXRcbiAgICAgIGlmIChhbGxTcGFucy5pbmNsdWRlcyhzdGFydGVkU3BhbikpIHtcbiAgICAgICAgX3B1c2hBY3Rpdml0eShzdGFydGVkU3Bhbi5zcGFuQ29udGV4dCgpLnNwYW5JZCk7XG4gICAgICB9XG4gICAgfSksXG4gICk7XG5cbiAgX2NsZWFudXBIb29rcy5wdXNoKFxuICAgIGNsaWVudC5vbignc3BhbkVuZCcsIGVuZGVkU3BhbiA9PiB7XG4gICAgICBpZiAoX2ZpbmlzaGVkKSB7XG4gICAgICAgIHJldHVybjtcbiAgICAgIH1cblxuICAgICAgX3BvcEFjdGl2aXR5KGVuZGVkU3Bhbi5zcGFuQ29udGV4dCgpLnNwYW5JZCk7XG4gICAgfSksXG4gICk7XG5cbiAgX2NsZWFudXBIb29rcy5wdXNoKFxuICAgIGNsaWVudC5vbignaWRsZVNwYW5FbmFibGVBdXRvRmluaXNoJywgc3BhblRvQWxsb3dBdXRvRmluaXNoID0+IHtcbiAgICAgIGlmIChzcGFuVG9BbGxvd0F1dG9GaW5pc2ggPT09IHNwYW4pIHtcbiAgICAgICAgX2F1dG9GaW5pc2hBbGxvd2VkID0gdHJ1ZTtcbiAgICAgICAgX3Jlc3RhcnRJZGxlVGltZW91dCgpO1xuXG4gICAgICAgIGlmIChhY3Rpdml0aWVzLnNpemUpIHtcbiAgICAgICAgICBfcmVzdGFydENoaWxkU3BhblRpbWVvdXQoKTtcbiAgICAgICAgfVxuICAgICAgfVxuICAgIH0pLFxuICApO1xuXG4gIC8vIFdlIG9ubHkgc3RhcnQgdGhlIGluaXRpYWwgaWRsZSB0aW1lb3V0IGlmIHdlIGFyZSBub3QgZGVsYXlpbmcgdGhlIGF1dG8gZmluaXNoXG4gIGlmICghb3B0aW9ucy5kaXNhYmxlQXV0b0ZpbmlzaCkge1xuICAgIF9yZXN0YXJ0SWRsZVRpbWVvdXQoKTtcbiAgfVxuXG4gIHNldFRpbWVvdXQoKCkgPT4ge1xuICAgIGlmICghX2ZpbmlzaGVkKSB7XG4gICAgICBzcGFuLnNldFN0YXR1cyh7IGNvZGU6IHNwYW5zdGF0dXMuU1BBTl9TVEFUVVNfRVJST1IsIG1lc3NhZ2U6ICdkZWFkbGluZV9leGNlZWRlZCcgfSk7XG4gICAgICBfZmluaXNoUmVhc29uID0gRklOSVNIX1JFQVNPTl9GSU5BTF9USU1FT1VUO1xuICAgICAgc3Bhbi5lbmQoKTtcbiAgICB9XG4gIH0sIGZpbmFsVGltZW91dCk7XG5cbiAgcmV0dXJuIHNwYW47XG59XG5cbmZ1bmN0aW9uIF9zdGFydElkbGVTcGFuKG9wdGlvbnMpIHtcbiAgY29uc3Qgc3BhbiA9IHRyYWNlLnN0YXJ0SW5hY3RpdmVTcGFuKG9wdGlvbnMpO1xuXG4gIHNwYW5PblNjb3BlLl9zZXRTcGFuRm9yU2NvcGUoY3VycmVudFNjb3Blcy5nZXRDdXJyZW50U2NvcGUoKSwgc3Bhbik7XG5cbiAgZGVidWdCdWlsZC5ERUJVR19CVUlMRCAmJiBkZWJ1Z0xvZ2dlci5kZWJ1Zy5sb2coJ1tUcmFjaW5nXSBTdGFydGVkIHNwYW4gaXMgYW4gaWRsZSBzcGFuJyk7XG5cbiAgcmV0dXJuIHNwYW47XG59XG5cbmV4cG9ydHMuVFJBQ0lOR19ERUZBVUxUUyA9IFRSQUNJTkdfREVGQVVMVFM7XG5leHBvcnRzLnN0YXJ0SWRsZVNwYW4gPSBzdGFydElkbGVTcGFuO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9aWRsZVNwYW4uanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/idleSpan.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/logSpans.js":
/*!********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/logSpans.js ***!
  \********************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst debugBuild = __webpack_require__(/*! ../debug-build.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst debugLogger = __webpack_require__(/*! ../utils/debug-logger.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst spanUtils = __webpack_require__(/*! ../utils/spanUtils.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanUtils.js\");\n\n/**\n * Print a log message for a started span.\n */\nfunction logSpanStart(span) {\n  if (!debugBuild.DEBUG_BUILD) return;\n\n  const { description = '< unknown name >', op = '< unknown op >', parent_span_id: parentSpanId } = spanUtils.spanToJSON(span);\n  const { spanId } = span.spanContext();\n\n  const sampled = spanUtils.spanIsSampled(span);\n  const rootSpan = spanUtils.getRootSpan(span);\n  const isRootSpan = rootSpan === span;\n\n  const header = `[Tracing] Starting ${sampled ? 'sampled' : 'unsampled'} ${isRootSpan ? 'root ' : ''}span`;\n\n  const infoParts = [`op: ${op}`, `name: ${description}`, `ID: ${spanId}`];\n\n  if (parentSpanId) {\n    infoParts.push(`parent ID: ${parentSpanId}`);\n  }\n\n  if (!isRootSpan) {\n    const { op, description } = spanUtils.spanToJSON(rootSpan);\n    infoParts.push(`root ID: ${rootSpan.spanContext().spanId}`);\n    if (op) {\n      infoParts.push(`root op: ${op}`);\n    }\n    if (description) {\n      infoParts.push(`root description: ${description}`);\n    }\n  }\n\n  debugLogger.debug.log(`${header}\n  ${infoParts.join('\\n  ')}`);\n}\n\n/**\n * Print a log message for an ended span.\n */\nfunction logSpanEnd(span) {\n  if (!debugBuild.DEBUG_BUILD) return;\n\n  const { description = '< unknown name >', op = '< unknown op >' } = spanUtils.spanToJSON(span);\n  const { spanId } = span.spanContext();\n  const rootSpan = spanUtils.getRootSpan(span);\n  const isRootSpan = rootSpan === span;\n\n  const msg = `[Tracing] Finishing \"${op}\" ${isRootSpan ? 'root ' : ''}span \"${description}\" with ID ${spanId}`;\n  debugLogger.debug.log(msg);\n}\n\nexports.logSpanEnd = logSpanEnd;\nexports.logSpanStart = logSpanStart;\n//# sourceMappingURL=logSpans.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdHJhY2luZy9sb2dTcGFucy5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxtQkFBbUIsbUJBQU8sQ0FBQyxtSUFBbUI7QUFDOUMsb0JBQW9CLG1CQUFPLENBQUMsaUpBQTBCO0FBQ3RELGtCQUFrQixtQkFBTyxDQUFDLDJJQUF1Qjs7QUFFakQ7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSxVQUFVLHdGQUF3RjtBQUNsRyxVQUFVLFNBQVM7O0FBRW5CO0FBQ0E7QUFDQTs7QUFFQSx1Q0FBdUMsbUNBQW1DLEVBQUUsMEJBQTBCOztBQUV0Ryw0QkFBNEIsR0FBRyxZQUFZLFlBQVksVUFBVSxPQUFPOztBQUV4RTtBQUNBLGlDQUFpQyxhQUFhO0FBQzlDOztBQUVBO0FBQ0EsWUFBWSxrQkFBa0I7QUFDOUIsK0JBQStCLDhCQUE4QjtBQUM3RDtBQUNBLGlDQUFpQyxHQUFHO0FBQ3BDO0FBQ0E7QUFDQSwwQ0FBMEMsWUFBWTtBQUN0RDtBQUNBOztBQUVBLDJCQUEyQjtBQUMzQixJQUFJLHVCQUF1QjtBQUMzQjs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLFVBQVUsMERBQTBEO0FBQ3BFLFVBQVUsU0FBUztBQUNuQjtBQUNBOztBQUVBLHNDQUFzQyxHQUFHLElBQUksMEJBQTBCLFFBQVEsWUFBWSxZQUFZLE9BQU87QUFDOUc7QUFDQTs7QUFFQSxrQkFBa0I7QUFDbEIsb0JBQW9CO0FBQ3BCIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdHJhY2luZy9sb2dTcGFucy5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgZGVidWdCdWlsZCA9IHJlcXVpcmUoJy4uL2RlYnVnLWJ1aWxkLmpzJyk7XG5jb25zdCBkZWJ1Z0xvZ2dlciA9IHJlcXVpcmUoJy4uL3V0aWxzL2RlYnVnLWxvZ2dlci5qcycpO1xuY29uc3Qgc3BhblV0aWxzID0gcmVxdWlyZSgnLi4vdXRpbHMvc3BhblV0aWxzLmpzJyk7XG5cbi8qKlxuICogUHJpbnQgYSBsb2cgbWVzc2FnZSBmb3IgYSBzdGFydGVkIHNwYW4uXG4gKi9cbmZ1bmN0aW9uIGxvZ1NwYW5TdGFydChzcGFuKSB7XG4gIGlmICghZGVidWdCdWlsZC5ERUJVR19CVUlMRCkgcmV0dXJuO1xuXG4gIGNvbnN0IHsgZGVzY3JpcHRpb24gPSAnPCB1bmtub3duIG5hbWUgPicsIG9wID0gJzwgdW5rbm93biBvcCA+JywgcGFyZW50X3NwYW5faWQ6IHBhcmVudFNwYW5JZCB9ID0gc3BhblV0aWxzLnNwYW5Ub0pTT04oc3Bhbik7XG4gIGNvbnN0IHsgc3BhbklkIH0gPSBzcGFuLnNwYW5Db250ZXh0KCk7XG5cbiAgY29uc3Qgc2FtcGxlZCA9IHNwYW5VdGlscy5zcGFuSXNTYW1wbGVkKHNwYW4pO1xuICBjb25zdCByb290U3BhbiA9IHNwYW5VdGlscy5nZXRSb290U3BhbihzcGFuKTtcbiAgY29uc3QgaXNSb290U3BhbiA9IHJvb3RTcGFuID09PSBzcGFuO1xuXG4gIGNvbnN0IGhlYWRlciA9IGBbVHJhY2luZ10gU3RhcnRpbmcgJHtzYW1wbGVkID8gJ3NhbXBsZWQnIDogJ3Vuc2FtcGxlZCd9ICR7aXNSb290U3BhbiA/ICdyb290ICcgOiAnJ31zcGFuYDtcblxuICBjb25zdCBpbmZvUGFydHMgPSBbYG9wOiAke29wfWAsIGBuYW1lOiAke2Rlc2NyaXB0aW9ufWAsIGBJRDogJHtzcGFuSWR9YF07XG5cbiAgaWYgKHBhcmVudFNwYW5JZCkge1xuICAgIGluZm9QYXJ0cy5wdXNoKGBwYXJlbnQgSUQ6ICR7cGFyZW50U3BhbklkfWApO1xuICB9XG5cbiAgaWYgKCFpc1Jvb3RTcGFuKSB7XG4gICAgY29uc3QgeyBvcCwgZGVzY3JpcHRpb24gfSA9IHNwYW5VdGlscy5zcGFuVG9KU09OKHJvb3RTcGFuKTtcbiAgICBpbmZvUGFydHMucHVzaChgcm9vdCBJRDogJHtyb290U3Bhbi5zcGFuQ29udGV4dCgpLnNwYW5JZH1gKTtcbiAgICBpZiAob3ApIHtcbiAgICAgIGluZm9QYXJ0cy5wdXNoKGByb290IG9wOiAke29wfWApO1xuICAgIH1cbiAgICBpZiAoZGVzY3JpcHRpb24pIHtcbiAgICAgIGluZm9QYXJ0cy5wdXNoKGByb290IGRlc2NyaXB0aW9uOiAke2Rlc2NyaXB0aW9ufWApO1xuICAgIH1cbiAgfVxuXG4gIGRlYnVnTG9nZ2VyLmRlYnVnLmxvZyhgJHtoZWFkZXJ9XG4gICR7aW5mb1BhcnRzLmpvaW4oJ1xcbiAgJyl9YCk7XG59XG5cbi8qKlxuICogUHJpbnQgYSBsb2cgbWVzc2FnZSBmb3IgYW4gZW5kZWQgc3Bhbi5cbiAqL1xuZnVuY3Rpb24gbG9nU3BhbkVuZChzcGFuKSB7XG4gIGlmICghZGVidWdCdWlsZC5ERUJVR19CVUlMRCkgcmV0dXJuO1xuXG4gIGNvbnN0IHsgZGVzY3JpcHRpb24gPSAnPCB1bmtub3duIG5hbWUgPicsIG9wID0gJzwgdW5rbm93biBvcCA+JyB9ID0gc3BhblV0aWxzLnNwYW5Ub0pTT04oc3Bhbik7XG4gIGNvbnN0IHsgc3BhbklkIH0gPSBzcGFuLnNwYW5Db250ZXh0KCk7XG4gIGNvbnN0IHJvb3RTcGFuID0gc3BhblV0aWxzLmdldFJvb3RTcGFuKHNwYW4pO1xuICBjb25zdCBpc1Jvb3RTcGFuID0gcm9vdFNwYW4gPT09IHNwYW47XG5cbiAgY29uc3QgbXNnID0gYFtUcmFjaW5nXSBGaW5pc2hpbmcgXCIke29wfVwiICR7aXNSb290U3BhbiA/ICdyb290ICcgOiAnJ31zcGFuIFwiJHtkZXNjcmlwdGlvbn1cIiB3aXRoIElEICR7c3BhbklkfWA7XG4gIGRlYnVnTG9nZ2VyLmRlYnVnLmxvZyhtc2cpO1xufVxuXG5leHBvcnRzLmxvZ1NwYW5FbmQgPSBsb2dTcGFuRW5kO1xuZXhwb3J0cy5sb2dTcGFuU3RhcnQgPSBsb2dTcGFuU3RhcnQ7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1sb2dTcGFucy5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/logSpans.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/measurement.js":
/*!***********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/measurement.js ***!
  \***********************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst debugBuild = __webpack_require__(/*! ../debug-build.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst semanticAttributes = __webpack_require__(/*! ../semanticAttributes.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/semanticAttributes.js\");\nconst debugLogger = __webpack_require__(/*! ../utils/debug-logger.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst spanUtils = __webpack_require__(/*! ../utils/spanUtils.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanUtils.js\");\n\n/**\n * Adds a measurement to the active transaction on the current global scope. You can optionally pass in a different span\n * as the 4th parameter.\n */\nfunction setMeasurement(name, value, unit, activeSpan = spanUtils.getActiveSpan()) {\n  const rootSpan = activeSpan && spanUtils.getRootSpan(activeSpan);\n\n  if (rootSpan) {\n    debugBuild.DEBUG_BUILD && debugLogger.debug.log(`[Measurement] Setting measurement on root span: ${name} = ${value} ${unit}`);\n    rootSpan.addEvent(name, {\n      [semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_MEASUREMENT_VALUE]: value,\n      [semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_MEASUREMENT_UNIT]: unit ,\n    });\n  }\n}\n\n/**\n * Convert timed events to measurements.\n */\nfunction timedEventsToMeasurements(events) {\n  if (!events || events.length === 0) {\n    return undefined;\n  }\n\n  const measurements = {};\n  events.forEach(event => {\n    const attributes = event.attributes || {};\n    const unit = attributes[semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_MEASUREMENT_UNIT] ;\n    const value = attributes[semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_MEASUREMENT_VALUE] ;\n\n    if (typeof unit === 'string' && typeof value === 'number') {\n      measurements[event.name] = { value, unit };\n    }\n  });\n\n  return measurements;\n}\n\nexports.setMeasurement = setMeasurement;\nexports.timedEventsToMeasurements = timedEventsToMeasurements;\n//# sourceMappingURL=measurement.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdHJhY2luZy9tZWFzdXJlbWVudC5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxtQkFBbUIsbUJBQU8sQ0FBQyxtSUFBbUI7QUFDOUMsMkJBQTJCLG1CQUFPLENBQUMsaUpBQTBCO0FBQzdELG9CQUFvQixtQkFBTyxDQUFDLGlKQUEwQjtBQUN0RCxrQkFBa0IsbUJBQU8sQ0FBQywySUFBdUI7O0FBRWpEO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBLHVHQUF1RyxNQUFNLElBQUksT0FBTyxFQUFFLEtBQUs7QUFDL0g7QUFDQTtBQUNBO0FBQ0EsS0FBSztBQUNMO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBLG1DQUFtQztBQUNuQztBQUNBLEdBQUc7O0FBRUg7QUFDQTs7QUFFQSxzQkFBc0I7QUFDdEIsaUNBQWlDO0FBQ2pDIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdHJhY2luZy9tZWFzdXJlbWVudC5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgZGVidWdCdWlsZCA9IHJlcXVpcmUoJy4uL2RlYnVnLWJ1aWxkLmpzJyk7XG5jb25zdCBzZW1hbnRpY0F0dHJpYnV0ZXMgPSByZXF1aXJlKCcuLi9zZW1hbnRpY0F0dHJpYnV0ZXMuanMnKTtcbmNvbnN0IGRlYnVnTG9nZ2VyID0gcmVxdWlyZSgnLi4vdXRpbHMvZGVidWctbG9nZ2VyLmpzJyk7XG5jb25zdCBzcGFuVXRpbHMgPSByZXF1aXJlKCcuLi91dGlscy9zcGFuVXRpbHMuanMnKTtcblxuLyoqXG4gKiBBZGRzIGEgbWVhc3VyZW1lbnQgdG8gdGhlIGFjdGl2ZSB0cmFuc2FjdGlvbiBvbiB0aGUgY3VycmVudCBnbG9iYWwgc2NvcGUuIFlvdSBjYW4gb3B0aW9uYWxseSBwYXNzIGluIGEgZGlmZmVyZW50IHNwYW5cbiAqIGFzIHRoZSA0dGggcGFyYW1ldGVyLlxuICovXG5mdW5jdGlvbiBzZXRNZWFzdXJlbWVudChuYW1lLCB2YWx1ZSwgdW5pdCwgYWN0aXZlU3BhbiA9IHNwYW5VdGlscy5nZXRBY3RpdmVTcGFuKCkpIHtcbiAgY29uc3Qgcm9vdFNwYW4gPSBhY3RpdmVTcGFuICYmIHNwYW5VdGlscy5nZXRSb290U3BhbihhY3RpdmVTcGFuKTtcblxuICBpZiAocm9vdFNwYW4pIHtcbiAgICBkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEICYmIGRlYnVnTG9nZ2VyLmRlYnVnLmxvZyhgW01lYXN1cmVtZW50XSBTZXR0aW5nIG1lYXN1cmVtZW50IG9uIHJvb3Qgc3BhbjogJHtuYW1lfSA9ICR7dmFsdWV9ICR7dW5pdH1gKTtcbiAgICByb290U3Bhbi5hZGRFdmVudChuYW1lLCB7XG4gICAgICBbc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfTUVBU1VSRU1FTlRfVkFMVUVdOiB2YWx1ZSxcbiAgICAgIFtzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9NRUFTVVJFTUVOVF9VTklUXTogdW5pdCAsXG4gICAgfSk7XG4gIH1cbn1cblxuLyoqXG4gKiBDb252ZXJ0IHRpbWVkIGV2ZW50cyB0byBtZWFzdXJlbWVudHMuXG4gKi9cbmZ1bmN0aW9uIHRpbWVkRXZlbnRzVG9NZWFzdXJlbWVudHMoZXZlbnRzKSB7XG4gIGlmICghZXZlbnRzIHx8IGV2ZW50cy5sZW5ndGggPT09IDApIHtcbiAgICByZXR1cm4gdW5kZWZpbmVkO1xuICB9XG5cbiAgY29uc3QgbWVhc3VyZW1lbnRzID0ge307XG4gIGV2ZW50cy5mb3JFYWNoKGV2ZW50ID0+IHtcbiAgICBjb25zdCBhdHRyaWJ1dGVzID0gZXZlbnQuYXR0cmlidXRlcyB8fCB7fTtcbiAgICBjb25zdCB1bml0ID0gYXR0cmlidXRlc1tzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9NRUFTVVJFTUVOVF9VTklUXSA7XG4gICAgY29uc3QgdmFsdWUgPSBhdHRyaWJ1dGVzW3NlbWFudGljQXR0cmlidXRlcy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX01FQVNVUkVNRU5UX1ZBTFVFXSA7XG5cbiAgICBpZiAodHlwZW9mIHVuaXQgPT09ICdzdHJpbmcnICYmIHR5cGVvZiB2YWx1ZSA9PT0gJ251bWJlcicpIHtcbiAgICAgIG1lYXN1cmVtZW50c1tldmVudC5uYW1lXSA9IHsgdmFsdWUsIHVuaXQgfTtcbiAgICB9XG4gIH0pO1xuXG4gIHJldHVybiBtZWFzdXJlbWVudHM7XG59XG5cbmV4cG9ydHMuc2V0TWVhc3VyZW1lbnQgPSBzZXRNZWFzdXJlbWVudDtcbmV4cG9ydHMudGltZWRFdmVudHNUb01lYXN1cmVtZW50cyA9IHRpbWVkRXZlbnRzVG9NZWFzdXJlbWVudHM7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1tZWFzdXJlbWVudC5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/measurement.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/sampling.js":
/*!********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/sampling.js ***!
  \********************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst debugBuild = __webpack_require__(/*! ../debug-build.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst debugLogger = __webpack_require__(/*! ../utils/debug-logger.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst hasSpansEnabled = __webpack_require__(/*! ../utils/hasSpansEnabled.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/hasSpansEnabled.js\");\nconst parseSampleRate = __webpack_require__(/*! ../utils/parseSampleRate.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/parseSampleRate.js\");\n\n/**\n * Makes a sampling decision for the given options.\n *\n * Called every time a root span is created. Only root spans which emerge with a `sampled` value of `true` will be\n * sent to Sentry.\n */\nfunction sampleSpan(\n  options,\n  samplingContext,\n  sampleRand,\n) {\n  // nothing to do if span recording is not enabled\n  if (!hasSpansEnabled.hasSpansEnabled(options)) {\n    return [false];\n  }\n\n  let localSampleRateWasApplied = undefined;\n\n  // we would have bailed already if neither `tracesSampler` nor `tracesSampleRate` were defined, so one of these should\n  // work; prefer the hook if so\n  let sampleRate;\n  if (typeof options.tracesSampler === 'function') {\n    sampleRate = options.tracesSampler({\n      ...samplingContext,\n      inheritOrSampleWith: fallbackSampleRate => {\n        // If we have an incoming parent sample rate, we'll just use that one.\n        // The sampling decision will be inherited because of the sample_rand that was generated when the trace reached the incoming boundaries of the SDK.\n        if (typeof samplingContext.parentSampleRate === 'number') {\n          return samplingContext.parentSampleRate;\n        }\n\n        // Fallback if parent sample rate is not on the incoming trace (e.g. if there is no baggage)\n        // This is to provide backwards compatibility if there are incoming traces from older SDKs that don't send a parent sample rate or a sample rand. In these cases we just want to force either a sampling decision on the downstream traces via the sample rate.\n        if (typeof samplingContext.parentSampled === 'boolean') {\n          return Number(samplingContext.parentSampled);\n        }\n\n        return fallbackSampleRate;\n      },\n    });\n    localSampleRateWasApplied = true;\n  } else if (samplingContext.parentSampled !== undefined) {\n    sampleRate = samplingContext.parentSampled;\n  } else if (typeof options.tracesSampleRate !== 'undefined') {\n    sampleRate = options.tracesSampleRate;\n    localSampleRateWasApplied = true;\n  }\n\n  // Since this is coming from the user (or from a function provided by the user), who knows what we might get.\n  // (The only valid values are booleans or numbers between 0 and 1.)\n  const parsedSampleRate = parseSampleRate.parseSampleRate(sampleRate);\n\n  if (parsedSampleRate === undefined) {\n    debugBuild.DEBUG_BUILD &&\n      debugLogger.debug.warn(\n        `[Tracing] Discarding root span because of invalid sample rate. Sample rate must be a boolean or a number between 0 and 1. Got ${JSON.stringify(\n          sampleRate,\n        )} of type ${JSON.stringify(typeof sampleRate)}.`,\n      );\n    return [false];\n  }\n\n  // if the function returned 0 (or false), or if `tracesSampleRate` is 0, it's a sign the transaction should be dropped\n  if (!parsedSampleRate) {\n    debugBuild.DEBUG_BUILD &&\n      debugLogger.debug.log(\n        `[Tracing] Discarding transaction because ${\n          typeof options.tracesSampler === 'function'\n            ? 'tracesSampler returned 0 or false'\n            : 'a negative sampling decision was inherited or tracesSampleRate is set to 0'\n        }`,\n      );\n    return [false, parsedSampleRate, localSampleRateWasApplied];\n  }\n\n  // We always compare the sample rand for the current execution context against the chosen sample rate.\n  // Read more: https://develop.sentry.dev/sdk/telemetry/traces/#propagated-random-value\n  const shouldSample = sampleRand < parsedSampleRate;\n\n  // if we're not going to keep it, we're done\n  if (!shouldSample) {\n    debugBuild.DEBUG_BUILD &&\n      debugLogger.debug.log(\n        `[Tracing] Discarding transaction because it's not included in the random sample (sampling rate = ${Number(\n          sampleRate,\n        )})`,\n      );\n  }\n\n  return [shouldSample, parsedSampleRate, localSampleRateWasApplied];\n}\n\nexports.sampleSpan = sampleSpan;\n//# sourceMappingURL=sampling.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdHJhY2luZy9zYW1wbGluZy5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxtQkFBbUIsbUJBQU8sQ0FBQyxtSUFBbUI7QUFDOUMsb0JBQW9CLG1CQUFPLENBQUMsaUpBQTBCO0FBQ3RELHdCQUF3QixtQkFBTyxDQUFDLHVKQUE2QjtBQUM3RCx3QkFBd0IsbUJBQU8sQ0FBQyx1SkFBNkI7O0FBRTdEO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBLFdBQVc7QUFDWDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0EsT0FBTztBQUNQLEtBQUs7QUFDTDtBQUNBLElBQUk7QUFDSjtBQUNBLElBQUk7QUFDSjtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBLHlJQUF5STtBQUN6STtBQUNBLFdBQVcsVUFBVSxrQ0FBa0M7QUFDdkQ7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxTQUFTO0FBQ1Q7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLDRHQUE0RztBQUM1RztBQUNBLFVBQVU7QUFDVjtBQUNBOztBQUVBO0FBQ0E7O0FBRUEsa0JBQWtCO0FBQ2xCIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdHJhY2luZy9zYW1wbGluZy5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgZGVidWdCdWlsZCA9IHJlcXVpcmUoJy4uL2RlYnVnLWJ1aWxkLmpzJyk7XG5jb25zdCBkZWJ1Z0xvZ2dlciA9IHJlcXVpcmUoJy4uL3V0aWxzL2RlYnVnLWxvZ2dlci5qcycpO1xuY29uc3QgaGFzU3BhbnNFbmFibGVkID0gcmVxdWlyZSgnLi4vdXRpbHMvaGFzU3BhbnNFbmFibGVkLmpzJyk7XG5jb25zdCBwYXJzZVNhbXBsZVJhdGUgPSByZXF1aXJlKCcuLi91dGlscy9wYXJzZVNhbXBsZVJhdGUuanMnKTtcblxuLyoqXG4gKiBNYWtlcyBhIHNhbXBsaW5nIGRlY2lzaW9uIGZvciB0aGUgZ2l2ZW4gb3B0aW9ucy5cbiAqXG4gKiBDYWxsZWQgZXZlcnkgdGltZSBhIHJvb3Qgc3BhbiBpcyBjcmVhdGVkLiBPbmx5IHJvb3Qgc3BhbnMgd2hpY2ggZW1lcmdlIHdpdGggYSBgc2FtcGxlZGAgdmFsdWUgb2YgYHRydWVgIHdpbGwgYmVcbiAqIHNlbnQgdG8gU2VudHJ5LlxuICovXG5mdW5jdGlvbiBzYW1wbGVTcGFuKFxuICBvcHRpb25zLFxuICBzYW1wbGluZ0NvbnRleHQsXG4gIHNhbXBsZVJhbmQsXG4pIHtcbiAgLy8gbm90aGluZyB0byBkbyBpZiBzcGFuIHJlY29yZGluZyBpcyBub3QgZW5hYmxlZFxuICBpZiAoIWhhc1NwYW5zRW5hYmxlZC5oYXNTcGFuc0VuYWJsZWQob3B0aW9ucykpIHtcbiAgICByZXR1cm4gW2ZhbHNlXTtcbiAgfVxuXG4gIGxldCBsb2NhbFNhbXBsZVJhdGVXYXNBcHBsaWVkID0gdW5kZWZpbmVkO1xuXG4gIC8vIHdlIHdvdWxkIGhhdmUgYmFpbGVkIGFscmVhZHkgaWYgbmVpdGhlciBgdHJhY2VzU2FtcGxlcmAgbm9yIGB0cmFjZXNTYW1wbGVSYXRlYCB3ZXJlIGRlZmluZWQsIHNvIG9uZSBvZiB0aGVzZSBzaG91bGRcbiAgLy8gd29yazsgcHJlZmVyIHRoZSBob29rIGlmIHNvXG4gIGxldCBzYW1wbGVSYXRlO1xuICBpZiAodHlwZW9mIG9wdGlvbnMudHJhY2VzU2FtcGxlciA9PT0gJ2Z1bmN0aW9uJykge1xuICAgIHNhbXBsZVJhdGUgPSBvcHRpb25zLnRyYWNlc1NhbXBsZXIoe1xuICAgICAgLi4uc2FtcGxpbmdDb250ZXh0LFxuICAgICAgaW5oZXJpdE9yU2FtcGxlV2l0aDogZmFsbGJhY2tTYW1wbGVSYXRlID0+IHtcbiAgICAgICAgLy8gSWYgd2UgaGF2ZSBhbiBpbmNvbWluZyBwYXJlbnQgc2FtcGxlIHJhdGUsIHdlJ2xsIGp1c3QgdXNlIHRoYXQgb25lLlxuICAgICAgICAvLyBUaGUgc2FtcGxpbmcgZGVjaXNpb24gd2lsbCBiZSBpbmhlcml0ZWQgYmVjYXVzZSBvZiB0aGUgc2FtcGxlX3JhbmQgdGhhdCB3YXMgZ2VuZXJhdGVkIHdoZW4gdGhlIHRyYWNlIHJlYWNoZWQgdGhlIGluY29taW5nIGJvdW5kYXJpZXMgb2YgdGhlIFNESy5cbiAgICAgICAgaWYgKHR5cGVvZiBzYW1wbGluZ0NvbnRleHQucGFyZW50U2FtcGxlUmF0ZSA9PT0gJ251bWJlcicpIHtcbiAgICAgICAgICByZXR1cm4gc2FtcGxpbmdDb250ZXh0LnBhcmVudFNhbXBsZVJhdGU7XG4gICAgICAgIH1cblxuICAgICAgICAvLyBGYWxsYmFjayBpZiBwYXJlbnQgc2FtcGxlIHJhdGUgaXMgbm90IG9uIHRoZSBpbmNvbWluZyB0cmFjZSAoZS5nLiBpZiB0aGVyZSBpcyBubyBiYWdnYWdlKVxuICAgICAgICAvLyBUaGlzIGlzIHRvIHByb3ZpZGUgYmFja3dhcmRzIGNvbXBhdGliaWxpdHkgaWYgdGhlcmUgYXJlIGluY29taW5nIHRyYWNlcyBmcm9tIG9sZGVyIFNES3MgdGhhdCBkb24ndCBzZW5kIGEgcGFyZW50IHNhbXBsZSByYXRlIG9yIGEgc2FtcGxlIHJhbmQuIEluIHRoZXNlIGNhc2VzIHdlIGp1c3Qgd2FudCB0byBmb3JjZSBlaXRoZXIgYSBzYW1wbGluZyBkZWNpc2lvbiBvbiB0aGUgZG93bnN0cmVhbSB0cmFjZXMgdmlhIHRoZSBzYW1wbGUgcmF0ZS5cbiAgICAgICAgaWYgKHR5cGVvZiBzYW1wbGluZ0NvbnRleHQucGFyZW50U2FtcGxlZCA9PT0gJ2Jvb2xlYW4nKSB7XG4gICAgICAgICAgcmV0dXJuIE51bWJlcihzYW1wbGluZ0NvbnRleHQucGFyZW50U2FtcGxlZCk7XG4gICAgICAgIH1cblxuICAgICAgICByZXR1cm4gZmFsbGJhY2tTYW1wbGVSYXRlO1xuICAgICAgfSxcbiAgICB9KTtcbiAgICBsb2NhbFNhbXBsZVJhdGVXYXNBcHBsaWVkID0gdHJ1ZTtcbiAgfSBlbHNlIGlmIChzYW1wbGluZ0NvbnRleHQucGFyZW50U2FtcGxlZCAhPT0gdW5kZWZpbmVkKSB7XG4gICAgc2FtcGxlUmF0ZSA9IHNhbXBsaW5nQ29udGV4dC5wYXJlbnRTYW1wbGVkO1xuICB9IGVsc2UgaWYgKHR5cGVvZiBvcHRpb25zLnRyYWNlc1NhbXBsZVJhdGUgIT09ICd1bmRlZmluZWQnKSB7XG4gICAgc2FtcGxlUmF0ZSA9IG9wdGlvbnMudHJhY2VzU2FtcGxlUmF0ZTtcbiAgICBsb2NhbFNhbXBsZVJhdGVXYXNBcHBsaWVkID0gdHJ1ZTtcbiAgfVxuXG4gIC8vIFNpbmNlIHRoaXMgaXMgY29taW5nIGZyb20gdGhlIHVzZXIgKG9yIGZyb20gYSBmdW5jdGlvbiBwcm92aWRlZCBieSB0aGUgdXNlciksIHdobyBrbm93cyB3aGF0IHdlIG1pZ2h0IGdldC5cbiAgLy8gKFRoZSBvbmx5IHZhbGlkIHZhbHVlcyBhcmUgYm9vbGVhbnMgb3IgbnVtYmVycyBiZXR3ZWVuIDAgYW5kIDEuKVxuICBjb25zdCBwYXJzZWRTYW1wbGVSYXRlID0gcGFyc2VTYW1wbGVSYXRlLnBhcnNlU2FtcGxlUmF0ZShzYW1wbGVSYXRlKTtcblxuICBpZiAocGFyc2VkU2FtcGxlUmF0ZSA9PT0gdW5kZWZpbmVkKSB7XG4gICAgZGVidWdCdWlsZC5ERUJVR19CVUlMRCAmJlxuICAgICAgZGVidWdMb2dnZXIuZGVidWcud2FybihcbiAgICAgICAgYFtUcmFjaW5nXSBEaXNjYXJkaW5nIHJvb3Qgc3BhbiBiZWNhdXNlIG9mIGludmFsaWQgc2FtcGxlIHJhdGUuIFNhbXBsZSByYXRlIG11c3QgYmUgYSBib29sZWFuIG9yIGEgbnVtYmVyIGJldHdlZW4gMCBhbmQgMS4gR290ICR7SlNPTi5zdHJpbmdpZnkoXG4gICAgICAgICAgc2FtcGxlUmF0ZSxcbiAgICAgICAgKX0gb2YgdHlwZSAke0pTT04uc3RyaW5naWZ5KHR5cGVvZiBzYW1wbGVSYXRlKX0uYCxcbiAgICAgICk7XG4gICAgcmV0dXJuIFtmYWxzZV07XG4gIH1cblxuICAvLyBpZiB0aGUgZnVuY3Rpb24gcmV0dXJuZWQgMCAob3IgZmFsc2UpLCBvciBpZiBgdHJhY2VzU2FtcGxlUmF0ZWAgaXMgMCwgaXQncyBhIHNpZ24gdGhlIHRyYW5zYWN0aW9uIHNob3VsZCBiZSBkcm9wcGVkXG4gIGlmICghcGFyc2VkU2FtcGxlUmF0ZSkge1xuICAgIGRlYnVnQnVpbGQuREVCVUdfQlVJTEQgJiZcbiAgICAgIGRlYnVnTG9nZ2VyLmRlYnVnLmxvZyhcbiAgICAgICAgYFtUcmFjaW5nXSBEaXNjYXJkaW5nIHRyYW5zYWN0aW9uIGJlY2F1c2UgJHtcbiAgICAgICAgICB0eXBlb2Ygb3B0aW9ucy50cmFjZXNTYW1wbGVyID09PSAnZnVuY3Rpb24nXG4gICAgICAgICAgICA/ICd0cmFjZXNTYW1wbGVyIHJldHVybmVkIDAgb3IgZmFsc2UnXG4gICAgICAgICAgICA6ICdhIG5lZ2F0aXZlIHNhbXBsaW5nIGRlY2lzaW9uIHdhcyBpbmhlcml0ZWQgb3IgdHJhY2VzU2FtcGxlUmF0ZSBpcyBzZXQgdG8gMCdcbiAgICAgICAgfWAsXG4gICAgICApO1xuICAgIHJldHVybiBbZmFsc2UsIHBhcnNlZFNhbXBsZVJhdGUsIGxvY2FsU2FtcGxlUmF0ZVdhc0FwcGxpZWRdO1xuICB9XG5cbiAgLy8gV2UgYWx3YXlzIGNvbXBhcmUgdGhlIHNhbXBsZSByYW5kIGZvciB0aGUgY3VycmVudCBleGVjdXRpb24gY29udGV4dCBhZ2FpbnN0IHRoZSBjaG9zZW4gc2FtcGxlIHJhdGUuXG4gIC8vIFJlYWQgbW9yZTogaHR0cHM6Ly9kZXZlbG9wLnNlbnRyeS5kZXYvc2RrL3RlbGVtZXRyeS90cmFjZXMvI3Byb3BhZ2F0ZWQtcmFuZG9tLXZhbHVlXG4gIGNvbnN0IHNob3VsZFNhbXBsZSA9IHNhbXBsZVJhbmQgPCBwYXJzZWRTYW1wbGVSYXRlO1xuXG4gIC8vIGlmIHdlJ3JlIG5vdCBnb2luZyB0byBrZWVwIGl0LCB3ZSdyZSBkb25lXG4gIGlmICghc2hvdWxkU2FtcGxlKSB7XG4gICAgZGVidWdCdWlsZC5ERUJVR19CVUlMRCAmJlxuICAgICAgZGVidWdMb2dnZXIuZGVidWcubG9nKFxuICAgICAgICBgW1RyYWNpbmddIERpc2NhcmRpbmcgdHJhbnNhY3Rpb24gYmVjYXVzZSBpdCdzIG5vdCBpbmNsdWRlZCBpbiB0aGUgcmFuZG9tIHNhbXBsZSAoc2FtcGxpbmcgcmF0ZSA9ICR7TnVtYmVyKFxuICAgICAgICAgIHNhbXBsZVJhdGUsXG4gICAgICAgICl9KWAsXG4gICAgICApO1xuICB9XG5cbiAgcmV0dXJuIFtzaG91bGRTYW1wbGUsIHBhcnNlZFNhbXBsZVJhdGUsIGxvY2FsU2FtcGxlUmF0ZVdhc0FwcGxpZWRdO1xufVxuXG5leHBvcnRzLnNhbXBsZVNwYW4gPSBzYW1wbGVTcGFuO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9c2FtcGxpbmcuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/sampling.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/sentryNonRecordingSpan.js":
/*!**********************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/sentryNonRecordingSpan.js ***!
  \**********************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst propagationContext = __webpack_require__(/*! ../utils/propagationContext.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/propagationContext.js\");\nconst spanUtils = __webpack_require__(/*! ../utils/spanUtils.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanUtils.js\");\n\n/**\n * A Sentry Span that is non-recording, meaning it will not be sent to Sentry.\n */\nclass SentryNonRecordingSpan  {\n\n   constructor(spanContext = {}) {\n    this._traceId = spanContext.traceId || propagationContext.generateTraceId();\n    this._spanId = spanContext.spanId || propagationContext.generateSpanId();\n  }\n\n  /** @inheritdoc */\n   spanContext() {\n    return {\n      spanId: this._spanId,\n      traceId: this._traceId,\n      traceFlags: spanUtils.TRACE_FLAG_NONE,\n    };\n  }\n\n  /** @inheritdoc */\n   end(_timestamp) {}\n\n  /** @inheritdoc */\n   setAttribute(_key, _value) {\n    return this;\n  }\n\n  /** @inheritdoc */\n   setAttributes(_values) {\n    return this;\n  }\n\n  /** @inheritdoc */\n   setStatus(_status) {\n    return this;\n  }\n\n  /** @inheritdoc */\n   updateName(_name) {\n    return this;\n  }\n\n  /** @inheritdoc */\n   isRecording() {\n    return false;\n  }\n\n  /** @inheritdoc */\n   addEvent(\n    _name,\n    _attributesOrStartTime,\n    _startTime,\n  ) {\n    return this;\n  }\n\n  /** @inheritDoc */\n   addLink(_link) {\n    return this;\n  }\n\n  /** @inheritDoc */\n   addLinks(_links) {\n    return this;\n  }\n\n  /**\n   * This should generally not be used,\n   * but we need it for being compliant with the OTEL Span interface.\n   *\n   * @hidden\n   * @internal\n   */\n   recordException(_exception, _time) {\n    // noop\n  }\n}\n\nexports.SentryNonRecordingSpan = SentryNonRecordingSpan;\n//# sourceMappingURL=sentryNonRecordingSpan.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdHJhY2luZy9zZW50cnlOb25SZWNvcmRpbmdTcGFuLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLDJCQUEyQixtQkFBTyxDQUFDLDZKQUFnQztBQUNuRSxrQkFBa0IsbUJBQU8sQ0FBQywySUFBdUI7O0FBRWpEO0FBQ0E7QUFDQTtBQUNBOztBQUVBLCtCQUErQjtBQUMvQjtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSw4QkFBOEI7QUFDOUIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy90cmFjaW5nL3NlbnRyeU5vblJlY29yZGluZ1NwYW4uanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IHByb3BhZ2F0aW9uQ29udGV4dCA9IHJlcXVpcmUoJy4uL3V0aWxzL3Byb3BhZ2F0aW9uQ29udGV4dC5qcycpO1xuY29uc3Qgc3BhblV0aWxzID0gcmVxdWlyZSgnLi4vdXRpbHMvc3BhblV0aWxzLmpzJyk7XG5cbi8qKlxuICogQSBTZW50cnkgU3BhbiB0aGF0IGlzIG5vbi1yZWNvcmRpbmcsIG1lYW5pbmcgaXQgd2lsbCBub3QgYmUgc2VudCB0byBTZW50cnkuXG4gKi9cbmNsYXNzIFNlbnRyeU5vblJlY29yZGluZ1NwYW4gIHtcblxuICAgY29uc3RydWN0b3Ioc3BhbkNvbnRleHQgPSB7fSkge1xuICAgIHRoaXMuX3RyYWNlSWQgPSBzcGFuQ29udGV4dC50cmFjZUlkIHx8IHByb3BhZ2F0aW9uQ29udGV4dC5nZW5lcmF0ZVRyYWNlSWQoKTtcbiAgICB0aGlzLl9zcGFuSWQgPSBzcGFuQ29udGV4dC5zcGFuSWQgfHwgcHJvcGFnYXRpb25Db250ZXh0LmdlbmVyYXRlU3BhbklkKCk7XG4gIH1cblxuICAvKiogQGluaGVyaXRkb2MgKi9cbiAgIHNwYW5Db250ZXh0KCkge1xuICAgIHJldHVybiB7XG4gICAgICBzcGFuSWQ6IHRoaXMuX3NwYW5JZCxcbiAgICAgIHRyYWNlSWQ6IHRoaXMuX3RyYWNlSWQsXG4gICAgICB0cmFjZUZsYWdzOiBzcGFuVXRpbHMuVFJBQ0VfRkxBR19OT05FLFxuICAgIH07XG4gIH1cblxuICAvKiogQGluaGVyaXRkb2MgKi9cbiAgIGVuZChfdGltZXN0YW1wKSB7fVxuXG4gIC8qKiBAaW5oZXJpdGRvYyAqL1xuICAgc2V0QXR0cmlidXRlKF9rZXksIF92YWx1ZSkge1xuICAgIHJldHVybiB0aGlzO1xuICB9XG5cbiAgLyoqIEBpbmhlcml0ZG9jICovXG4gICBzZXRBdHRyaWJ1dGVzKF92YWx1ZXMpIHtcbiAgICByZXR1cm4gdGhpcztcbiAgfVxuXG4gIC8qKiBAaW5oZXJpdGRvYyAqL1xuICAgc2V0U3RhdHVzKF9zdGF0dXMpIHtcbiAgICByZXR1cm4gdGhpcztcbiAgfVxuXG4gIC8qKiBAaW5oZXJpdGRvYyAqL1xuICAgdXBkYXRlTmFtZShfbmFtZSkge1xuICAgIHJldHVybiB0aGlzO1xuICB9XG5cbiAgLyoqIEBpbmhlcml0ZG9jICovXG4gICBpc1JlY29yZGluZygpIHtcbiAgICByZXR1cm4gZmFsc2U7XG4gIH1cblxuICAvKiogQGluaGVyaXRkb2MgKi9cbiAgIGFkZEV2ZW50KFxuICAgIF9uYW1lLFxuICAgIF9hdHRyaWJ1dGVzT3JTdGFydFRpbWUsXG4gICAgX3N0YXJ0VGltZSxcbiAgKSB7XG4gICAgcmV0dXJuIHRoaXM7XG4gIH1cblxuICAvKiogQGluaGVyaXREb2MgKi9cbiAgIGFkZExpbmsoX2xpbmspIHtcbiAgICByZXR1cm4gdGhpcztcbiAgfVxuXG4gIC8qKiBAaW5oZXJpdERvYyAqL1xuICAgYWRkTGlua3MoX2xpbmtzKSB7XG4gICAgcmV0dXJuIHRoaXM7XG4gIH1cblxuICAvKipcbiAgICogVGhpcyBzaG91bGQgZ2VuZXJhbGx5IG5vdCBiZSB1c2VkLFxuICAgKiBidXQgd2UgbmVlZCBpdCBmb3IgYmVpbmcgY29tcGxpYW50IHdpdGggdGhlIE9URUwgU3BhbiBpbnRlcmZhY2UuXG4gICAqXG4gICAqIEBoaWRkZW5cbiAgICogQGludGVybmFsXG4gICAqL1xuICAgcmVjb3JkRXhjZXB0aW9uKF9leGNlcHRpb24sIF90aW1lKSB7XG4gICAgLy8gbm9vcFxuICB9XG59XG5cbmV4cG9ydHMuU2VudHJ5Tm9uUmVjb3JkaW5nU3BhbiA9IFNlbnRyeU5vblJlY29yZGluZ1NwYW47XG4vLyMgc291cmNlTWFwcGluZ1VSTD1zZW50cnlOb25SZWNvcmRpbmdTcGFuLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/sentryNonRecordingSpan.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/sentrySpan.js":
/*!**********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/sentrySpan.js ***!
  \**********************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst currentScopes = __webpack_require__(/*! ../currentScopes.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst debugBuild = __webpack_require__(/*! ../debug-build.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst envelope = __webpack_require__(/*! ../envelope.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/envelope.js\");\nconst semanticAttributes = __webpack_require__(/*! ../semanticAttributes.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/semanticAttributes.js\");\nconst debugLogger = __webpack_require__(/*! ../utils/debug-logger.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst propagationContext = __webpack_require__(/*! ../utils/propagationContext.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/propagationContext.js\");\nconst spanUtils = __webpack_require__(/*! ../utils/spanUtils.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanUtils.js\");\nconst time = __webpack_require__(/*! ../utils/time.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/time.js\");\nconst dynamicSamplingContext = __webpack_require__(/*! ./dynamicSamplingContext.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/dynamicSamplingContext.js\");\nconst logSpans = __webpack_require__(/*! ./logSpans.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/logSpans.js\");\nconst measurement = __webpack_require__(/*! ./measurement.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/measurement.js\");\nconst utils = __webpack_require__(/*! ./utils.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/utils.js\");\n\nconst MAX_SPAN_COUNT = 1000;\n\n/**\n * Span contains all data about a span\n */\nclass SentrySpan  {\n\n  /** Epoch timestamp in seconds when the span started. */\n\n  /** Epoch timestamp in seconds when the span ended. */\n\n  /** Internal keeper of the status */\n\n  /** The timed events added to this span. */\n\n  /** if true, treat span as a standalone span (not part of a transaction) */\n\n  /**\n   * You should never call the constructor manually, always use `Sentry.startSpan()`\n   * or other span methods.\n   * @internal\n   * @hideconstructor\n   * @hidden\n   */\n   constructor(spanContext = {}) {\n    this._traceId = spanContext.traceId || propagationContext.generateTraceId();\n    this._spanId = spanContext.spanId || propagationContext.generateSpanId();\n    this._startTime = spanContext.startTimestamp || time.timestampInSeconds();\n    this._links = spanContext.links;\n\n    this._attributes = {};\n    this.setAttributes({\n      [semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_ORIGIN]: 'manual',\n      [semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_OP]: spanContext.op,\n      ...spanContext.attributes,\n    });\n\n    this._name = spanContext.name;\n\n    if (spanContext.parentSpanId) {\n      this._parentSpanId = spanContext.parentSpanId;\n    }\n    // We want to include booleans as well here\n    if ('sampled' in spanContext) {\n      this._sampled = spanContext.sampled;\n    }\n    if (spanContext.endTimestamp) {\n      this._endTime = spanContext.endTimestamp;\n    }\n\n    this._events = [];\n\n    this._isStandaloneSpan = spanContext.isStandalone;\n\n    // If the span is already ended, ensure we finalize the span immediately\n    if (this._endTime) {\n      this._onSpanEnded();\n    }\n  }\n\n  /** @inheritDoc */\n   addLink(link) {\n    if (this._links) {\n      this._links.push(link);\n    } else {\n      this._links = [link];\n    }\n    return this;\n  }\n\n  /** @inheritDoc */\n   addLinks(links) {\n    if (this._links) {\n      this._links.push(...links);\n    } else {\n      this._links = links;\n    }\n    return this;\n  }\n\n  /**\n   * This should generally not be used,\n   * but it is needed for being compliant with the OTEL Span interface.\n   *\n   * @hidden\n   * @internal\n   */\n   recordException(_exception, _time) {\n    // noop\n  }\n\n  /** @inheritdoc */\n   spanContext() {\n    const { _spanId: spanId, _traceId: traceId, _sampled: sampled } = this;\n    return {\n      spanId,\n      traceId,\n      traceFlags: sampled ? spanUtils.TRACE_FLAG_SAMPLED : spanUtils.TRACE_FLAG_NONE,\n    };\n  }\n\n  /** @inheritdoc */\n   setAttribute(key, value) {\n    if (value === undefined) {\n      // eslint-disable-next-line @typescript-eslint/no-dynamic-delete\n      delete this._attributes[key];\n    } else {\n      this._attributes[key] = value;\n    }\n\n    return this;\n  }\n\n  /** @inheritdoc */\n   setAttributes(attributes) {\n    Object.keys(attributes).forEach(key => this.setAttribute(key, attributes[key]));\n    return this;\n  }\n\n  /**\n   * This should generally not be used,\n   * but we need it for browser tracing where we want to adjust the start time afterwards.\n   * USE THIS WITH CAUTION!\n   *\n   * @hidden\n   * @internal\n   */\n   updateStartTime(timeInput) {\n    this._startTime = spanUtils.spanTimeInputToSeconds(timeInput);\n  }\n\n  /**\n   * @inheritDoc\n   */\n   setStatus(value) {\n    this._status = value;\n    return this;\n  }\n\n  /**\n   * @inheritDoc\n   */\n   updateName(name) {\n    this._name = name;\n    this.setAttribute(semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_SOURCE, 'custom');\n    return this;\n  }\n\n  /** @inheritdoc */\n   end(endTimestamp) {\n    // If already ended, skip\n    if (this._endTime) {\n      return;\n    }\n\n    this._endTime = spanUtils.spanTimeInputToSeconds(endTimestamp);\n    logSpans.logSpanEnd(this);\n\n    this._onSpanEnded();\n  }\n\n  /**\n   * Get JSON representation of this span.\n   *\n   * @hidden\n   * @internal This method is purely for internal purposes and should not be used outside\n   * of SDK code. If you need to get a JSON representation of a span,\n   * use `spanToJSON(span)` instead.\n   */\n   getSpanJSON() {\n    return {\n      data: this._attributes,\n      description: this._name,\n      op: this._attributes[semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_OP],\n      parent_span_id: this._parentSpanId,\n      span_id: this._spanId,\n      start_timestamp: this._startTime,\n      status: spanUtils.getStatusMessage(this._status),\n      timestamp: this._endTime,\n      trace_id: this._traceId,\n      origin: this._attributes[semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_ORIGIN] ,\n      profile_id: this._attributes[semanticAttributes.SEMANTIC_ATTRIBUTE_PROFILE_ID] ,\n      exclusive_time: this._attributes[semanticAttributes.SEMANTIC_ATTRIBUTE_EXCLUSIVE_TIME] ,\n      measurements: measurement.timedEventsToMeasurements(this._events),\n      is_segment: (this._isStandaloneSpan && spanUtils.getRootSpan(this) === this) || undefined,\n      segment_id: this._isStandaloneSpan ? spanUtils.getRootSpan(this).spanContext().spanId : undefined,\n      links: spanUtils.convertSpanLinksForEnvelope(this._links),\n    };\n  }\n\n  /** @inheritdoc */\n   isRecording() {\n    return !this._endTime && !!this._sampled;\n  }\n\n  /**\n   * @inheritdoc\n   */\n   addEvent(\n    name,\n    attributesOrStartTime,\n    startTime,\n  ) {\n    debugBuild.DEBUG_BUILD && debugLogger.debug.log('[Tracing] Adding an event to span:', name);\n\n    const time$1 = isSpanTimeInput(attributesOrStartTime) ? attributesOrStartTime : startTime || time.timestampInSeconds();\n    const attributes = isSpanTimeInput(attributesOrStartTime) ? {} : attributesOrStartTime || {};\n\n    const event = {\n      name,\n      time: spanUtils.spanTimeInputToSeconds(time$1),\n      attributes,\n    };\n\n    this._events.push(event);\n\n    return this;\n  }\n\n  /**\n   * This method should generally not be used,\n   * but for now we need a way to publicly check if the `_isStandaloneSpan` flag is set.\n   * USE THIS WITH CAUTION!\n   * @internal\n   * @hidden\n   * @experimental\n   */\n   isStandaloneSpan() {\n    return !!this._isStandaloneSpan;\n  }\n\n  /** Emit `spanEnd` when the span is ended. */\n   _onSpanEnded() {\n    const client = currentScopes.getClient();\n    if (client) {\n      client.emit('spanEnd', this);\n    }\n\n    // A segment span is basically the root span of a local span tree.\n    // So for now, this is either what we previously refer to as the root span,\n    // or a standalone span.\n    const isSegmentSpan = this._isStandaloneSpan || this === spanUtils.getRootSpan(this);\n\n    if (!isSegmentSpan) {\n      return;\n    }\n\n    // if this is a standalone span, we send it immediately\n    if (this._isStandaloneSpan) {\n      if (this._sampled) {\n        sendSpanEnvelope(envelope.createSpanEnvelope([this], client));\n      } else {\n        debugBuild.DEBUG_BUILD &&\n          debugLogger.debug.log('[Tracing] Discarding standalone span because its trace was not chosen to be sampled.');\n        if (client) {\n          client.recordDroppedEvent('sample_rate', 'span');\n        }\n      }\n      return;\n    }\n\n    const transactionEvent = this._convertSpanToTransaction();\n    if (transactionEvent) {\n      const scope = utils.getCapturedScopesOnSpan(this).scope || currentScopes.getCurrentScope();\n      scope.captureEvent(transactionEvent);\n    }\n  }\n\n  /**\n   * Finish the transaction & prepare the event to send to Sentry.\n   */\n   _convertSpanToTransaction() {\n    // We can only convert finished spans\n    if (!isFullFinishedSpan(spanUtils.spanToJSON(this))) {\n      return undefined;\n    }\n\n    if (!this._name) {\n      debugBuild.DEBUG_BUILD && debugLogger.debug.warn('Transaction has no name, falling back to `<unlabeled transaction>`.');\n      this._name = '<unlabeled transaction>';\n    }\n\n    const { scope: capturedSpanScope, isolationScope: capturedSpanIsolationScope } = utils.getCapturedScopesOnSpan(this);\n\n    const normalizedRequest = capturedSpanScope?.getScopeData().sdkProcessingMetadata?.normalizedRequest;\n\n    if (this._sampled !== true) {\n      return undefined;\n    }\n\n    // The transaction span itself as well as any potential standalone spans should be filtered out\n    const finishedSpans = spanUtils.getSpanDescendants(this).filter(span => span !== this && !isStandaloneSpan(span));\n\n    const spans = finishedSpans.map(span => spanUtils.spanToJSON(span)).filter(isFullFinishedSpan);\n\n    const source = this._attributes[semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_SOURCE] ;\n\n    // remove internal root span attributes we don't need to send.\n    /* eslint-disable @typescript-eslint/no-dynamic-delete */\n    delete this._attributes[semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_CUSTOM_SPAN_NAME];\n    spans.forEach(span => {\n      delete span.data[semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_CUSTOM_SPAN_NAME];\n    });\n    // eslint-enabled-next-line @typescript-eslint/no-dynamic-delete\n\n    const transaction = {\n      contexts: {\n        trace: spanUtils.spanToTransactionTraceContext(this),\n      },\n      spans:\n        // spans.sort() mutates the array, but `spans` is already a copy so we can safely do this here\n        // we do not use spans anymore after this point\n        spans.length > MAX_SPAN_COUNT\n          ? spans.sort((a, b) => a.start_timestamp - b.start_timestamp).slice(0, MAX_SPAN_COUNT)\n          : spans,\n      start_timestamp: this._startTime,\n      timestamp: this._endTime,\n      transaction: this._name,\n      type: 'transaction',\n      sdkProcessingMetadata: {\n        capturedSpanScope,\n        capturedSpanIsolationScope,\n        dynamicSamplingContext: dynamicSamplingContext.getDynamicSamplingContextFromSpan(this),\n      },\n      request: normalizedRequest,\n      ...(source && {\n        transaction_info: {\n          source,\n        },\n      }),\n    };\n\n    const measurements = measurement.timedEventsToMeasurements(this._events);\n    const hasMeasurements = measurements && Object.keys(measurements).length;\n\n    if (hasMeasurements) {\n      debugBuild.DEBUG_BUILD &&\n        debugLogger.debug.log(\n          '[Measurements] Adding measurements to transaction event',\n          JSON.stringify(measurements, undefined, 2),\n        );\n      transaction.measurements = measurements;\n    }\n\n    return transaction;\n  }\n}\n\nfunction isSpanTimeInput(value) {\n  return (value && typeof value === 'number') || value instanceof Date || Array.isArray(value);\n}\n\n// We want to filter out any incomplete SpanJSON objects\nfunction isFullFinishedSpan(input) {\n  return !!input.start_timestamp && !!input.timestamp && !!input.span_id && !!input.trace_id;\n}\n\n/** `SentrySpan`s can be sent as a standalone span rather than belonging to a transaction */\nfunction isStandaloneSpan(span) {\n  return span instanceof SentrySpan && span.isStandaloneSpan();\n}\n\n/**\n * Sends a `SpanEnvelope`.\n *\n * Note: If the envelope's spans are dropped, e.g. via `beforeSendSpan`,\n * the envelope will not be sent either.\n */\nfunction sendSpanEnvelope(envelope) {\n  const client = currentScopes.getClient();\n  if (!client) {\n    return;\n  }\n\n  const spanItems = envelope[1];\n  if (!spanItems || spanItems.length === 0) {\n    client.recordDroppedEvent('before_send', 'span');\n    return;\n  }\n\n  // sendEnvelope should not throw\n  // eslint-disable-next-line @typescript-eslint/no-floating-promises\n  client.sendEnvelope(envelope);\n}\n\nexports.SentrySpan = SentrySpan;\n//# sourceMappingURL=sentrySpan.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdHJhY2luZy9zZW50cnlTcGFuLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLHNCQUFzQixtQkFBTyxDQUFDLHVJQUFxQjtBQUNuRCxtQkFBbUIsbUJBQU8sQ0FBQyxtSUFBbUI7QUFDOUMsaUJBQWlCLG1CQUFPLENBQUMsNkhBQWdCO0FBQ3pDLDJCQUEyQixtQkFBTyxDQUFDLGlKQUEwQjtBQUM3RCxvQkFBb0IsbUJBQU8sQ0FBQyxpSkFBMEI7QUFDdEQsMkJBQTJCLG1CQUFPLENBQUMsNkpBQWdDO0FBQ25FLGtCQUFrQixtQkFBTyxDQUFDLDJJQUF1QjtBQUNqRCxhQUFhLG1CQUFPLENBQUMsaUlBQWtCO0FBQ3ZDLCtCQUErQixtQkFBTyxDQUFDLGdLQUE2QjtBQUNwRSxpQkFBaUIsbUJBQU8sQ0FBQyxvSUFBZTtBQUN4QyxvQkFBb0IsbUJBQU8sQ0FBQywwSUFBa0I7QUFDOUMsY0FBYyxtQkFBTyxDQUFDLDhIQUFZOztBQUVsQzs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTs7QUFFQTs7QUFFQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLCtCQUErQjtBQUMvQjtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsS0FBSzs7QUFFTDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsTUFBTTtBQUNOO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsTUFBTTtBQUNOO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQSxZQUFZLHdEQUF3RDtBQUNwRTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLE1BQU07QUFDTjtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQSxtRUFBbUU7O0FBRW5FO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQSxRQUFRO0FBQ1I7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSxZQUFZLHVFQUF1RTs7QUFFbkY7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEtBQUs7QUFDTDs7QUFFQTtBQUNBO0FBQ0E7QUFDQSxPQUFPO0FBQ1A7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLE9BQU87QUFDUDtBQUNBO0FBQ0E7QUFDQTtBQUNBLFNBQVM7QUFDVCxPQUFPO0FBQ1A7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLGtCQUFrQjtBQUNsQiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3RyYWNpbmcvc2VudHJ5U3Bhbi5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgY3VycmVudFNjb3BlcyA9IHJlcXVpcmUoJy4uL2N1cnJlbnRTY29wZXMuanMnKTtcbmNvbnN0IGRlYnVnQnVpbGQgPSByZXF1aXJlKCcuLi9kZWJ1Zy1idWlsZC5qcycpO1xuY29uc3QgZW52ZWxvcGUgPSByZXF1aXJlKCcuLi9lbnZlbG9wZS5qcycpO1xuY29uc3Qgc2VtYW50aWNBdHRyaWJ1dGVzID0gcmVxdWlyZSgnLi4vc2VtYW50aWNBdHRyaWJ1dGVzLmpzJyk7XG5jb25zdCBkZWJ1Z0xvZ2dlciA9IHJlcXVpcmUoJy4uL3V0aWxzL2RlYnVnLWxvZ2dlci5qcycpO1xuY29uc3QgcHJvcGFnYXRpb25Db250ZXh0ID0gcmVxdWlyZSgnLi4vdXRpbHMvcHJvcGFnYXRpb25Db250ZXh0LmpzJyk7XG5jb25zdCBzcGFuVXRpbHMgPSByZXF1aXJlKCcuLi91dGlscy9zcGFuVXRpbHMuanMnKTtcbmNvbnN0IHRpbWUgPSByZXF1aXJlKCcuLi91dGlscy90aW1lLmpzJyk7XG5jb25zdCBkeW5hbWljU2FtcGxpbmdDb250ZXh0ID0gcmVxdWlyZSgnLi9keW5hbWljU2FtcGxpbmdDb250ZXh0LmpzJyk7XG5jb25zdCBsb2dTcGFucyA9IHJlcXVpcmUoJy4vbG9nU3BhbnMuanMnKTtcbmNvbnN0IG1lYXN1cmVtZW50ID0gcmVxdWlyZSgnLi9tZWFzdXJlbWVudC5qcycpO1xuY29uc3QgdXRpbHMgPSByZXF1aXJlKCcuL3V0aWxzLmpzJyk7XG5cbmNvbnN0IE1BWF9TUEFOX0NPVU5UID0gMTAwMDtcblxuLyoqXG4gKiBTcGFuIGNvbnRhaW5zIGFsbCBkYXRhIGFib3V0IGEgc3BhblxuICovXG5jbGFzcyBTZW50cnlTcGFuICB7XG5cbiAgLyoqIEVwb2NoIHRpbWVzdGFtcCBpbiBzZWNvbmRzIHdoZW4gdGhlIHNwYW4gc3RhcnRlZC4gKi9cblxuICAvKiogRXBvY2ggdGltZXN0YW1wIGluIHNlY29uZHMgd2hlbiB0aGUgc3BhbiBlbmRlZC4gKi9cblxuICAvKiogSW50ZXJuYWwga2VlcGVyIG9mIHRoZSBzdGF0dXMgKi9cblxuICAvKiogVGhlIHRpbWVkIGV2ZW50cyBhZGRlZCB0byB0aGlzIHNwYW4uICovXG5cbiAgLyoqIGlmIHRydWUsIHRyZWF0IHNwYW4gYXMgYSBzdGFuZGFsb25lIHNwYW4gKG5vdCBwYXJ0IG9mIGEgdHJhbnNhY3Rpb24pICovXG5cbiAgLyoqXG4gICAqIFlvdSBzaG91bGQgbmV2ZXIgY2FsbCB0aGUgY29uc3RydWN0b3IgbWFudWFsbHksIGFsd2F5cyB1c2UgYFNlbnRyeS5zdGFydFNwYW4oKWBcbiAgICogb3Igb3RoZXIgc3BhbiBtZXRob2RzLlxuICAgKiBAaW50ZXJuYWxcbiAgICogQGhpZGVjb25zdHJ1Y3RvclxuICAgKiBAaGlkZGVuXG4gICAqL1xuICAgY29uc3RydWN0b3Ioc3BhbkNvbnRleHQgPSB7fSkge1xuICAgIHRoaXMuX3RyYWNlSWQgPSBzcGFuQ29udGV4dC50cmFjZUlkIHx8IHByb3BhZ2F0aW9uQ29udGV4dC5nZW5lcmF0ZVRyYWNlSWQoKTtcbiAgICB0aGlzLl9zcGFuSWQgPSBzcGFuQ29udGV4dC5zcGFuSWQgfHwgcHJvcGFnYXRpb25Db250ZXh0LmdlbmVyYXRlU3BhbklkKCk7XG4gICAgdGhpcy5fc3RhcnRUaW1lID0gc3BhbkNvbnRleHQuc3RhcnRUaW1lc3RhbXAgfHwgdGltZS50aW1lc3RhbXBJblNlY29uZHMoKTtcbiAgICB0aGlzLl9saW5rcyA9IHNwYW5Db250ZXh0LmxpbmtzO1xuXG4gICAgdGhpcy5fYXR0cmlidXRlcyA9IHt9O1xuICAgIHRoaXMuc2V0QXR0cmlidXRlcyh7XG4gICAgICBbc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfT1JJR0lOXTogJ21hbnVhbCcsXG4gICAgICBbc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfT1BdOiBzcGFuQ29udGV4dC5vcCxcbiAgICAgIC4uLnNwYW5Db250ZXh0LmF0dHJpYnV0ZXMsXG4gICAgfSk7XG5cbiAgICB0aGlzLl9uYW1lID0gc3BhbkNvbnRleHQubmFtZTtcblxuICAgIGlmIChzcGFuQ29udGV4dC5wYXJlbnRTcGFuSWQpIHtcbiAgICAgIHRoaXMuX3BhcmVudFNwYW5JZCA9IHNwYW5Db250ZXh0LnBhcmVudFNwYW5JZDtcbiAgICB9XG4gICAgLy8gV2Ugd2FudCB0byBpbmNsdWRlIGJvb2xlYW5zIGFzIHdlbGwgaGVyZVxuICAgIGlmICgnc2FtcGxlZCcgaW4gc3BhbkNvbnRleHQpIHtcbiAgICAgIHRoaXMuX3NhbXBsZWQgPSBzcGFuQ29udGV4dC5zYW1wbGVkO1xuICAgIH1cbiAgICBpZiAoc3BhbkNvbnRleHQuZW5kVGltZXN0YW1wKSB7XG4gICAgICB0aGlzLl9lbmRUaW1lID0gc3BhbkNvbnRleHQuZW5kVGltZXN0YW1wO1xuICAgIH1cblxuICAgIHRoaXMuX2V2ZW50cyA9IFtdO1xuXG4gICAgdGhpcy5faXNTdGFuZGFsb25lU3BhbiA9IHNwYW5Db250ZXh0LmlzU3RhbmRhbG9uZTtcblxuICAgIC8vIElmIHRoZSBzcGFuIGlzIGFscmVhZHkgZW5kZWQsIGVuc3VyZSB3ZSBmaW5hbGl6ZSB0aGUgc3BhbiBpbW1lZGlhdGVseVxuICAgIGlmICh0aGlzLl9lbmRUaW1lKSB7XG4gICAgICB0aGlzLl9vblNwYW5FbmRlZCgpO1xuICAgIH1cbiAgfVxuXG4gIC8qKiBAaW5oZXJpdERvYyAqL1xuICAgYWRkTGluayhsaW5rKSB7XG4gICAgaWYgKHRoaXMuX2xpbmtzKSB7XG4gICAgICB0aGlzLl9saW5rcy5wdXNoKGxpbmspO1xuICAgIH0gZWxzZSB7XG4gICAgICB0aGlzLl9saW5rcyA9IFtsaW5rXTtcbiAgICB9XG4gICAgcmV0dXJuIHRoaXM7XG4gIH1cblxuICAvKiogQGluaGVyaXREb2MgKi9cbiAgIGFkZExpbmtzKGxpbmtzKSB7XG4gICAgaWYgKHRoaXMuX2xpbmtzKSB7XG4gICAgICB0aGlzLl9saW5rcy5wdXNoKC4uLmxpbmtzKTtcbiAgICB9IGVsc2Uge1xuICAgICAgdGhpcy5fbGlua3MgPSBsaW5rcztcbiAgICB9XG4gICAgcmV0dXJuIHRoaXM7XG4gIH1cblxuICAvKipcbiAgICogVGhpcyBzaG91bGQgZ2VuZXJhbGx5IG5vdCBiZSB1c2VkLFxuICAgKiBidXQgaXQgaXMgbmVlZGVkIGZvciBiZWluZyBjb21wbGlhbnQgd2l0aCB0aGUgT1RFTCBTcGFuIGludGVyZmFjZS5cbiAgICpcbiAgICogQGhpZGRlblxuICAgKiBAaW50ZXJuYWxcbiAgICovXG4gICByZWNvcmRFeGNlcHRpb24oX2V4Y2VwdGlvbiwgX3RpbWUpIHtcbiAgICAvLyBub29wXG4gIH1cblxuICAvKiogQGluaGVyaXRkb2MgKi9cbiAgIHNwYW5Db250ZXh0KCkge1xuICAgIGNvbnN0IHsgX3NwYW5JZDogc3BhbklkLCBfdHJhY2VJZDogdHJhY2VJZCwgX3NhbXBsZWQ6IHNhbXBsZWQgfSA9IHRoaXM7XG4gICAgcmV0dXJuIHtcbiAgICAgIHNwYW5JZCxcbiAgICAgIHRyYWNlSWQsXG4gICAgICB0cmFjZUZsYWdzOiBzYW1wbGVkID8gc3BhblV0aWxzLlRSQUNFX0ZMQUdfU0FNUExFRCA6IHNwYW5VdGlscy5UUkFDRV9GTEFHX05PTkUsXG4gICAgfTtcbiAgfVxuXG4gIC8qKiBAaW5oZXJpdGRvYyAqL1xuICAgc2V0QXR0cmlidXRlKGtleSwgdmFsdWUpIHtcbiAgICBpZiAodmFsdWUgPT09IHVuZGVmaW5lZCkge1xuICAgICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uby1keW5hbWljLWRlbGV0ZVxuICAgICAgZGVsZXRlIHRoaXMuX2F0dHJpYnV0ZXNba2V5XTtcbiAgICB9IGVsc2Uge1xuICAgICAgdGhpcy5fYXR0cmlidXRlc1trZXldID0gdmFsdWU7XG4gICAgfVxuXG4gICAgcmV0dXJuIHRoaXM7XG4gIH1cblxuICAvKiogQGluaGVyaXRkb2MgKi9cbiAgIHNldEF0dHJpYnV0ZXMoYXR0cmlidXRlcykge1xuICAgIE9iamVjdC5rZXlzKGF0dHJpYnV0ZXMpLmZvckVhY2goa2V5ID0+IHRoaXMuc2V0QXR0cmlidXRlKGtleSwgYXR0cmlidXRlc1trZXldKSk7XG4gICAgcmV0dXJuIHRoaXM7XG4gIH1cblxuICAvKipcbiAgICogVGhpcyBzaG91bGQgZ2VuZXJhbGx5IG5vdCBiZSB1c2VkLFxuICAgKiBidXQgd2UgbmVlZCBpdCBmb3IgYnJvd3NlciB0cmFjaW5nIHdoZXJlIHdlIHdhbnQgdG8gYWRqdXN0IHRoZSBzdGFydCB0aW1lIGFmdGVyd2FyZHMuXG4gICAqIFVTRSBUSElTIFdJVEggQ0FVVElPTiFcbiAgICpcbiAgICogQGhpZGRlblxuICAgKiBAaW50ZXJuYWxcbiAgICovXG4gICB1cGRhdGVTdGFydFRpbWUodGltZUlucHV0KSB7XG4gICAgdGhpcy5fc3RhcnRUaW1lID0gc3BhblV0aWxzLnNwYW5UaW1lSW5wdXRUb1NlY29uZHModGltZUlucHV0KTtcbiAgfVxuXG4gIC8qKlxuICAgKiBAaW5oZXJpdERvY1xuICAgKi9cbiAgIHNldFN0YXR1cyh2YWx1ZSkge1xuICAgIHRoaXMuX3N0YXR1cyA9IHZhbHVlO1xuICAgIHJldHVybiB0aGlzO1xuICB9XG5cbiAgLyoqXG4gICAqIEBpbmhlcml0RG9jXG4gICAqL1xuICAgdXBkYXRlTmFtZShuYW1lKSB7XG4gICAgdGhpcy5fbmFtZSA9IG5hbWU7XG4gICAgdGhpcy5zZXRBdHRyaWJ1dGUoc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfU09VUkNFLCAnY3VzdG9tJyk7XG4gICAgcmV0dXJuIHRoaXM7XG4gIH1cblxuICAvKiogQGluaGVyaXRkb2MgKi9cbiAgIGVuZChlbmRUaW1lc3RhbXApIHtcbiAgICAvLyBJZiBhbHJlYWR5IGVuZGVkLCBza2lwXG4gICAgaWYgKHRoaXMuX2VuZFRpbWUpIHtcbiAgICAgIHJldHVybjtcbiAgICB9XG5cbiAgICB0aGlzLl9lbmRUaW1lID0gc3BhblV0aWxzLnNwYW5UaW1lSW5wdXRUb1NlY29uZHMoZW5kVGltZXN0YW1wKTtcbiAgICBsb2dTcGFucy5sb2dTcGFuRW5kKHRoaXMpO1xuXG4gICAgdGhpcy5fb25TcGFuRW5kZWQoKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBHZXQgSlNPTiByZXByZXNlbnRhdGlvbiBvZiB0aGlzIHNwYW4uXG4gICAqXG4gICAqIEBoaWRkZW5cbiAgICogQGludGVybmFsIFRoaXMgbWV0aG9kIGlzIHB1cmVseSBmb3IgaW50ZXJuYWwgcHVycG9zZXMgYW5kIHNob3VsZCBub3QgYmUgdXNlZCBvdXRzaWRlXG4gICAqIG9mIFNESyBjb2RlLiBJZiB5b3UgbmVlZCB0byBnZXQgYSBKU09OIHJlcHJlc2VudGF0aW9uIG9mIGEgc3BhbixcbiAgICogdXNlIGBzcGFuVG9KU09OKHNwYW4pYCBpbnN0ZWFkLlxuICAgKi9cbiAgIGdldFNwYW5KU09OKCkge1xuICAgIHJldHVybiB7XG4gICAgICBkYXRhOiB0aGlzLl9hdHRyaWJ1dGVzLFxuICAgICAgZGVzY3JpcHRpb246IHRoaXMuX25hbWUsXG4gICAgICBvcDogdGhpcy5fYXR0cmlidXRlc1tzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9PUF0sXG4gICAgICBwYXJlbnRfc3Bhbl9pZDogdGhpcy5fcGFyZW50U3BhbklkLFxuICAgICAgc3Bhbl9pZDogdGhpcy5fc3BhbklkLFxuICAgICAgc3RhcnRfdGltZXN0YW1wOiB0aGlzLl9zdGFydFRpbWUsXG4gICAgICBzdGF0dXM6IHNwYW5VdGlscy5nZXRTdGF0dXNNZXNzYWdlKHRoaXMuX3N0YXR1cyksXG4gICAgICB0aW1lc3RhbXA6IHRoaXMuX2VuZFRpbWUsXG4gICAgICB0cmFjZV9pZDogdGhpcy5fdHJhY2VJZCxcbiAgICAgIG9yaWdpbjogdGhpcy5fYXR0cmlidXRlc1tzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9PUklHSU5dICxcbiAgICAgIHByb2ZpbGVfaWQ6IHRoaXMuX2F0dHJpYnV0ZXNbc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9QUk9GSUxFX0lEXSAsXG4gICAgICBleGNsdXNpdmVfdGltZTogdGhpcy5fYXR0cmlidXRlc1tzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX0VYQ0xVU0lWRV9USU1FXSAsXG4gICAgICBtZWFzdXJlbWVudHM6IG1lYXN1cmVtZW50LnRpbWVkRXZlbnRzVG9NZWFzdXJlbWVudHModGhpcy5fZXZlbnRzKSxcbiAgICAgIGlzX3NlZ21lbnQ6ICh0aGlzLl9pc1N0YW5kYWxvbmVTcGFuICYmIHNwYW5VdGlscy5nZXRSb290U3Bhbih0aGlzKSA9PT0gdGhpcykgfHwgdW5kZWZpbmVkLFxuICAgICAgc2VnbWVudF9pZDogdGhpcy5faXNTdGFuZGFsb25lU3BhbiA/IHNwYW5VdGlscy5nZXRSb290U3Bhbih0aGlzKS5zcGFuQ29udGV4dCgpLnNwYW5JZCA6IHVuZGVmaW5lZCxcbiAgICAgIGxpbmtzOiBzcGFuVXRpbHMuY29udmVydFNwYW5MaW5rc0ZvckVudmVsb3BlKHRoaXMuX2xpbmtzKSxcbiAgICB9O1xuICB9XG5cbiAgLyoqIEBpbmhlcml0ZG9jICovXG4gICBpc1JlY29yZGluZygpIHtcbiAgICByZXR1cm4gIXRoaXMuX2VuZFRpbWUgJiYgISF0aGlzLl9zYW1wbGVkO1xuICB9XG5cbiAgLyoqXG4gICAqIEBpbmhlcml0ZG9jXG4gICAqL1xuICAgYWRkRXZlbnQoXG4gICAgbmFtZSxcbiAgICBhdHRyaWJ1dGVzT3JTdGFydFRpbWUsXG4gICAgc3RhcnRUaW1lLFxuICApIHtcbiAgICBkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEICYmIGRlYnVnTG9nZ2VyLmRlYnVnLmxvZygnW1RyYWNpbmddIEFkZGluZyBhbiBldmVudCB0byBzcGFuOicsIG5hbWUpO1xuXG4gICAgY29uc3QgdGltZSQxID0gaXNTcGFuVGltZUlucHV0KGF0dHJpYnV0ZXNPclN0YXJ0VGltZSkgPyBhdHRyaWJ1dGVzT3JTdGFydFRpbWUgOiBzdGFydFRpbWUgfHwgdGltZS50aW1lc3RhbXBJblNlY29uZHMoKTtcbiAgICBjb25zdCBhdHRyaWJ1dGVzID0gaXNTcGFuVGltZUlucHV0KGF0dHJpYnV0ZXNPclN0YXJ0VGltZSkgPyB7fSA6IGF0dHJpYnV0ZXNPclN0YXJ0VGltZSB8fCB7fTtcblxuICAgIGNvbnN0IGV2ZW50ID0ge1xuICAgICAgbmFtZSxcbiAgICAgIHRpbWU6IHNwYW5VdGlscy5zcGFuVGltZUlucHV0VG9TZWNvbmRzKHRpbWUkMSksXG4gICAgICBhdHRyaWJ1dGVzLFxuICAgIH07XG5cbiAgICB0aGlzLl9ldmVudHMucHVzaChldmVudCk7XG5cbiAgICByZXR1cm4gdGhpcztcbiAgfVxuXG4gIC8qKlxuICAgKiBUaGlzIG1ldGhvZCBzaG91bGQgZ2VuZXJhbGx5IG5vdCBiZSB1c2VkLFxuICAgKiBidXQgZm9yIG5vdyB3ZSBuZWVkIGEgd2F5IHRvIHB1YmxpY2x5IGNoZWNrIGlmIHRoZSBgX2lzU3RhbmRhbG9uZVNwYW5gIGZsYWcgaXMgc2V0LlxuICAgKiBVU0UgVEhJUyBXSVRIIENBVVRJT04hXG4gICAqIEBpbnRlcm5hbFxuICAgKiBAaGlkZGVuXG4gICAqIEBleHBlcmltZW50YWxcbiAgICovXG4gICBpc1N0YW5kYWxvbmVTcGFuKCkge1xuICAgIHJldHVybiAhIXRoaXMuX2lzU3RhbmRhbG9uZVNwYW47XG4gIH1cblxuICAvKiogRW1pdCBgc3BhbkVuZGAgd2hlbiB0aGUgc3BhbiBpcyBlbmRlZC4gKi9cbiAgIF9vblNwYW5FbmRlZCgpIHtcbiAgICBjb25zdCBjbGllbnQgPSBjdXJyZW50U2NvcGVzLmdldENsaWVudCgpO1xuICAgIGlmIChjbGllbnQpIHtcbiAgICAgIGNsaWVudC5lbWl0KCdzcGFuRW5kJywgdGhpcyk7XG4gICAgfVxuXG4gICAgLy8gQSBzZWdtZW50IHNwYW4gaXMgYmFzaWNhbGx5IHRoZSByb290IHNwYW4gb2YgYSBsb2NhbCBzcGFuIHRyZWUuXG4gICAgLy8gU28gZm9yIG5vdywgdGhpcyBpcyBlaXRoZXIgd2hhdCB3ZSBwcmV2aW91c2x5IHJlZmVyIHRvIGFzIHRoZSByb290IHNwYW4sXG4gICAgLy8gb3IgYSBzdGFuZGFsb25lIHNwYW4uXG4gICAgY29uc3QgaXNTZWdtZW50U3BhbiA9IHRoaXMuX2lzU3RhbmRhbG9uZVNwYW4gfHwgdGhpcyA9PT0gc3BhblV0aWxzLmdldFJvb3RTcGFuKHRoaXMpO1xuXG4gICAgaWYgKCFpc1NlZ21lbnRTcGFuKSB7XG4gICAgICByZXR1cm47XG4gICAgfVxuXG4gICAgLy8gaWYgdGhpcyBpcyBhIHN0YW5kYWxvbmUgc3Bhbiwgd2Ugc2VuZCBpdCBpbW1lZGlhdGVseVxuICAgIGlmICh0aGlzLl9pc1N0YW5kYWxvbmVTcGFuKSB7XG4gICAgICBpZiAodGhpcy5fc2FtcGxlZCkge1xuICAgICAgICBzZW5kU3BhbkVudmVsb3BlKGVudmVsb3BlLmNyZWF0ZVNwYW5FbnZlbG9wZShbdGhpc10sIGNsaWVudCkpO1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgZGVidWdCdWlsZC5ERUJVR19CVUlMRCAmJlxuICAgICAgICAgIGRlYnVnTG9nZ2VyLmRlYnVnLmxvZygnW1RyYWNpbmddIERpc2NhcmRpbmcgc3RhbmRhbG9uZSBzcGFuIGJlY2F1c2UgaXRzIHRyYWNlIHdhcyBub3QgY2hvc2VuIHRvIGJlIHNhbXBsZWQuJyk7XG4gICAgICAgIGlmIChjbGllbnQpIHtcbiAgICAgICAgICBjbGllbnQucmVjb3JkRHJvcHBlZEV2ZW50KCdzYW1wbGVfcmF0ZScsICdzcGFuJyk7XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICAgIHJldHVybjtcbiAgICB9XG5cbiAgICBjb25zdCB0cmFuc2FjdGlvbkV2ZW50ID0gdGhpcy5fY29udmVydFNwYW5Ub1RyYW5zYWN0aW9uKCk7XG4gICAgaWYgKHRyYW5zYWN0aW9uRXZlbnQpIHtcbiAgICAgIGNvbnN0IHNjb3BlID0gdXRpbHMuZ2V0Q2FwdHVyZWRTY29wZXNPblNwYW4odGhpcykuc2NvcGUgfHwgY3VycmVudFNjb3Blcy5nZXRDdXJyZW50U2NvcGUoKTtcbiAgICAgIHNjb3BlLmNhcHR1cmVFdmVudCh0cmFuc2FjdGlvbkV2ZW50KTtcbiAgICB9XG4gIH1cblxuICAvKipcbiAgICogRmluaXNoIHRoZSB0cmFuc2FjdGlvbiAmIHByZXBhcmUgdGhlIGV2ZW50IHRvIHNlbmQgdG8gU2VudHJ5LlxuICAgKi9cbiAgIF9jb252ZXJ0U3BhblRvVHJhbnNhY3Rpb24oKSB7XG4gICAgLy8gV2UgY2FuIG9ubHkgY29udmVydCBmaW5pc2hlZCBzcGFuc1xuICAgIGlmICghaXNGdWxsRmluaXNoZWRTcGFuKHNwYW5VdGlscy5zcGFuVG9KU09OKHRoaXMpKSkge1xuICAgICAgcmV0dXJuIHVuZGVmaW5lZDtcbiAgICB9XG5cbiAgICBpZiAoIXRoaXMuX25hbWUpIHtcbiAgICAgIGRlYnVnQnVpbGQuREVCVUdfQlVJTEQgJiYgZGVidWdMb2dnZXIuZGVidWcud2FybignVHJhbnNhY3Rpb24gaGFzIG5vIG5hbWUsIGZhbGxpbmcgYmFjayB0byBgPHVubGFiZWxlZCB0cmFuc2FjdGlvbj5gLicpO1xuICAgICAgdGhpcy5fbmFtZSA9ICc8dW5sYWJlbGVkIHRyYW5zYWN0aW9uPic7XG4gICAgfVxuXG4gICAgY29uc3QgeyBzY29wZTogY2FwdHVyZWRTcGFuU2NvcGUsIGlzb2xhdGlvblNjb3BlOiBjYXB0dXJlZFNwYW5Jc29sYXRpb25TY29wZSB9ID0gdXRpbHMuZ2V0Q2FwdHVyZWRTY29wZXNPblNwYW4odGhpcyk7XG5cbiAgICBjb25zdCBub3JtYWxpemVkUmVxdWVzdCA9IGNhcHR1cmVkU3BhblNjb3BlPy5nZXRTY29wZURhdGEoKS5zZGtQcm9jZXNzaW5nTWV0YWRhdGE/Lm5vcm1hbGl6ZWRSZXF1ZXN0O1xuXG4gICAgaWYgKHRoaXMuX3NhbXBsZWQgIT09IHRydWUpIHtcbiAgICAgIHJldHVybiB1bmRlZmluZWQ7XG4gICAgfVxuXG4gICAgLy8gVGhlIHRyYW5zYWN0aW9uIHNwYW4gaXRzZWxmIGFzIHdlbGwgYXMgYW55IHBvdGVudGlhbCBzdGFuZGFsb25lIHNwYW5zIHNob3VsZCBiZSBmaWx0ZXJlZCBvdXRcbiAgICBjb25zdCBmaW5pc2hlZFNwYW5zID0gc3BhblV0aWxzLmdldFNwYW5EZXNjZW5kYW50cyh0aGlzKS5maWx0ZXIoc3BhbiA9PiBzcGFuICE9PSB0aGlzICYmICFpc1N0YW5kYWxvbmVTcGFuKHNwYW4pKTtcblxuICAgIGNvbnN0IHNwYW5zID0gZmluaXNoZWRTcGFucy5tYXAoc3BhbiA9PiBzcGFuVXRpbHMuc3BhblRvSlNPTihzcGFuKSkuZmlsdGVyKGlzRnVsbEZpbmlzaGVkU3Bhbik7XG5cbiAgICBjb25zdCBzb3VyY2UgPSB0aGlzLl9hdHRyaWJ1dGVzW3NlbWFudGljQXR0cmlidXRlcy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX1NPVVJDRV0gO1xuXG4gICAgLy8gcmVtb3ZlIGludGVybmFsIHJvb3Qgc3BhbiBhdHRyaWJ1dGVzIHdlIGRvbid0IG5lZWQgdG8gc2VuZC5cbiAgICAvKiBlc2xpbnQtZGlzYWJsZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tZHluYW1pYy1kZWxldGUgKi9cbiAgICBkZWxldGUgdGhpcy5fYXR0cmlidXRlc1tzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9DVVNUT01fU1BBTl9OQU1FXTtcbiAgICBzcGFucy5mb3JFYWNoKHNwYW4gPT4ge1xuICAgICAgZGVsZXRlIHNwYW4uZGF0YVtzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9DVVNUT01fU1BBTl9OQU1FXTtcbiAgICB9KTtcbiAgICAvLyBlc2xpbnQtZW5hYmxlZC1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25vLWR5bmFtaWMtZGVsZXRlXG5cbiAgICBjb25zdCB0cmFuc2FjdGlvbiA9IHtcbiAgICAgIGNvbnRleHRzOiB7XG4gICAgICAgIHRyYWNlOiBzcGFuVXRpbHMuc3BhblRvVHJhbnNhY3Rpb25UcmFjZUNvbnRleHQodGhpcyksXG4gICAgICB9LFxuICAgICAgc3BhbnM6XG4gICAgICAgIC8vIHNwYW5zLnNvcnQoKSBtdXRhdGVzIHRoZSBhcnJheSwgYnV0IGBzcGFuc2AgaXMgYWxyZWFkeSBhIGNvcHkgc28gd2UgY2FuIHNhZmVseSBkbyB0aGlzIGhlcmVcbiAgICAgICAgLy8gd2UgZG8gbm90IHVzZSBzcGFucyBhbnltb3JlIGFmdGVyIHRoaXMgcG9pbnRcbiAgICAgICAgc3BhbnMubGVuZ3RoID4gTUFYX1NQQU5fQ09VTlRcbiAgICAgICAgICA/IHNwYW5zLnNvcnQoKGEsIGIpID0+IGEuc3RhcnRfdGltZXN0YW1wIC0gYi5zdGFydF90aW1lc3RhbXApLnNsaWNlKDAsIE1BWF9TUEFOX0NPVU5UKVxuICAgICAgICAgIDogc3BhbnMsXG4gICAgICBzdGFydF90aW1lc3RhbXA6IHRoaXMuX3N0YXJ0VGltZSxcbiAgICAgIHRpbWVzdGFtcDogdGhpcy5fZW5kVGltZSxcbiAgICAgIHRyYW5zYWN0aW9uOiB0aGlzLl9uYW1lLFxuICAgICAgdHlwZTogJ3RyYW5zYWN0aW9uJyxcbiAgICAgIHNka1Byb2Nlc3NpbmdNZXRhZGF0YToge1xuICAgICAgICBjYXB0dXJlZFNwYW5TY29wZSxcbiAgICAgICAgY2FwdHVyZWRTcGFuSXNvbGF0aW9uU2NvcGUsXG4gICAgICAgIGR5bmFtaWNTYW1wbGluZ0NvbnRleHQ6IGR5bmFtaWNTYW1wbGluZ0NvbnRleHQuZ2V0RHluYW1pY1NhbXBsaW5nQ29udGV4dEZyb21TcGFuKHRoaXMpLFxuICAgICAgfSxcbiAgICAgIHJlcXVlc3Q6IG5vcm1hbGl6ZWRSZXF1ZXN0LFxuICAgICAgLi4uKHNvdXJjZSAmJiB7XG4gICAgICAgIHRyYW5zYWN0aW9uX2luZm86IHtcbiAgICAgICAgICBzb3VyY2UsXG4gICAgICAgIH0sXG4gICAgICB9KSxcbiAgICB9O1xuXG4gICAgY29uc3QgbWVhc3VyZW1lbnRzID0gbWVhc3VyZW1lbnQudGltZWRFdmVudHNUb01lYXN1cmVtZW50cyh0aGlzLl9ldmVudHMpO1xuICAgIGNvbnN0IGhhc01lYXN1cmVtZW50cyA9IG1lYXN1cmVtZW50cyAmJiBPYmplY3Qua2V5cyhtZWFzdXJlbWVudHMpLmxlbmd0aDtcblxuICAgIGlmIChoYXNNZWFzdXJlbWVudHMpIHtcbiAgICAgIGRlYnVnQnVpbGQuREVCVUdfQlVJTEQgJiZcbiAgICAgICAgZGVidWdMb2dnZXIuZGVidWcubG9nKFxuICAgICAgICAgICdbTWVhc3VyZW1lbnRzXSBBZGRpbmcgbWVhc3VyZW1lbnRzIHRvIHRyYW5zYWN0aW9uIGV2ZW50JyxcbiAgICAgICAgICBKU09OLnN0cmluZ2lmeShtZWFzdXJlbWVudHMsIHVuZGVmaW5lZCwgMiksXG4gICAgICAgICk7XG4gICAgICB0cmFuc2FjdGlvbi5tZWFzdXJlbWVudHMgPSBtZWFzdXJlbWVudHM7XG4gICAgfVxuXG4gICAgcmV0dXJuIHRyYW5zYWN0aW9uO1xuICB9XG59XG5cbmZ1bmN0aW9uIGlzU3BhblRpbWVJbnB1dCh2YWx1ZSkge1xuICByZXR1cm4gKHZhbHVlICYmIHR5cGVvZiB2YWx1ZSA9PT0gJ251bWJlcicpIHx8IHZhbHVlIGluc3RhbmNlb2YgRGF0ZSB8fCBBcnJheS5pc0FycmF5KHZhbHVlKTtcbn1cblxuLy8gV2Ugd2FudCB0byBmaWx0ZXIgb3V0IGFueSBpbmNvbXBsZXRlIFNwYW5KU09OIG9iamVjdHNcbmZ1bmN0aW9uIGlzRnVsbEZpbmlzaGVkU3BhbihpbnB1dCkge1xuICByZXR1cm4gISFpbnB1dC5zdGFydF90aW1lc3RhbXAgJiYgISFpbnB1dC50aW1lc3RhbXAgJiYgISFpbnB1dC5zcGFuX2lkICYmICEhaW5wdXQudHJhY2VfaWQ7XG59XG5cbi8qKiBgU2VudHJ5U3BhbmBzIGNhbiBiZSBzZW50IGFzIGEgc3RhbmRhbG9uZSBzcGFuIHJhdGhlciB0aGFuIGJlbG9uZ2luZyB0byBhIHRyYW5zYWN0aW9uICovXG5mdW5jdGlvbiBpc1N0YW5kYWxvbmVTcGFuKHNwYW4pIHtcbiAgcmV0dXJuIHNwYW4gaW5zdGFuY2VvZiBTZW50cnlTcGFuICYmIHNwYW4uaXNTdGFuZGFsb25lU3BhbigpO1xufVxuXG4vKipcbiAqIFNlbmRzIGEgYFNwYW5FbnZlbG9wZWAuXG4gKlxuICogTm90ZTogSWYgdGhlIGVudmVsb3BlJ3Mgc3BhbnMgYXJlIGRyb3BwZWQsIGUuZy4gdmlhIGBiZWZvcmVTZW5kU3BhbmAsXG4gKiB0aGUgZW52ZWxvcGUgd2lsbCBub3QgYmUgc2VudCBlaXRoZXIuXG4gKi9cbmZ1bmN0aW9uIHNlbmRTcGFuRW52ZWxvcGUoZW52ZWxvcGUpIHtcbiAgY29uc3QgY2xpZW50ID0gY3VycmVudFNjb3Blcy5nZXRDbGllbnQoKTtcbiAgaWYgKCFjbGllbnQpIHtcbiAgICByZXR1cm47XG4gIH1cblxuICBjb25zdCBzcGFuSXRlbXMgPSBlbnZlbG9wZVsxXTtcbiAgaWYgKCFzcGFuSXRlbXMgfHwgc3Bhbkl0ZW1zLmxlbmd0aCA9PT0gMCkge1xuICAgIGNsaWVudC5yZWNvcmREcm9wcGVkRXZlbnQoJ2JlZm9yZV9zZW5kJywgJ3NwYW4nKTtcbiAgICByZXR1cm47XG4gIH1cblxuICAvLyBzZW5kRW52ZWxvcGUgc2hvdWxkIG5vdCB0aHJvd1xuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25vLWZsb2F0aW5nLXByb21pc2VzXG4gIGNsaWVudC5zZW5kRW52ZWxvcGUoZW52ZWxvcGUpO1xufVxuXG5leHBvcnRzLlNlbnRyeVNwYW4gPSBTZW50cnlTcGFuO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9c2VudHJ5U3Bhbi5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/sentrySpan.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/spanstatus.js":
/*!**********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/spanstatus.js ***!
  \**********************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst SPAN_STATUS_UNSET = 0;\nconst SPAN_STATUS_OK = 1;\nconst SPAN_STATUS_ERROR = 2;\n\n/**\n * Converts a HTTP status code into a sentry status with a message.\n *\n * @param httpStatus The HTTP response status code.\n * @returns The span status or unknown_error.\n */\n// https://develop.sentry.dev/sdk/event-payloads/span/\nfunction getSpanStatusFromHttpCode(httpStatus) {\n  if (httpStatus < 400 && httpStatus >= 100) {\n    return { code: SPAN_STATUS_OK };\n  }\n\n  if (httpStatus >= 400 && httpStatus < 500) {\n    switch (httpStatus) {\n      case 401:\n        return { code: SPAN_STATUS_ERROR, message: 'unauthenticated' };\n      case 403:\n        return { code: SPAN_STATUS_ERROR, message: 'permission_denied' };\n      case 404:\n        return { code: SPAN_STATUS_ERROR, message: 'not_found' };\n      case 409:\n        return { code: SPAN_STATUS_ERROR, message: 'already_exists' };\n      case 413:\n        return { code: SPAN_STATUS_ERROR, message: 'failed_precondition' };\n      case 429:\n        return { code: SPAN_STATUS_ERROR, message: 'resource_exhausted' };\n      case 499:\n        return { code: SPAN_STATUS_ERROR, message: 'cancelled' };\n      default:\n        return { code: SPAN_STATUS_ERROR, message: 'invalid_argument' };\n    }\n  }\n\n  if (httpStatus >= 500 && httpStatus < 600) {\n    switch (httpStatus) {\n      case 501:\n        return { code: SPAN_STATUS_ERROR, message: 'unimplemented' };\n      case 503:\n        return { code: SPAN_STATUS_ERROR, message: 'unavailable' };\n      case 504:\n        return { code: SPAN_STATUS_ERROR, message: 'deadline_exceeded' };\n      default:\n        return { code: SPAN_STATUS_ERROR, message: 'internal_error' };\n    }\n  }\n\n  return { code: SPAN_STATUS_ERROR, message: 'unknown_error' };\n}\n\n/**\n * Sets the Http status attributes on the current span based on the http code.\n * Additionally, the span's status is updated, depending on the http code.\n */\nfunction setHttpStatus(span, httpStatus) {\n  span.setAttribute('http.response.status_code', httpStatus);\n\n  const spanStatus = getSpanStatusFromHttpCode(httpStatus);\n  if (spanStatus.message !== 'unknown_error') {\n    span.setStatus(spanStatus);\n  }\n}\n\nexports.SPAN_STATUS_ERROR = SPAN_STATUS_ERROR;\nexports.SPAN_STATUS_OK = SPAN_STATUS_OK;\nexports.SPAN_STATUS_UNSET = SPAN_STATUS_UNSET;\nexports.getSpanStatusFromHttpCode = getSpanStatusFromHttpCode;\nexports.setHttpStatus = setHttpStatus;\n//# sourceMappingURL=spanstatus.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdHJhY2luZy9zcGFuc3RhdHVzLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxhQUFhO0FBQ2I7O0FBRUE7QUFDQTtBQUNBO0FBQ0EsaUJBQWlCO0FBQ2pCO0FBQ0EsaUJBQWlCO0FBQ2pCO0FBQ0EsaUJBQWlCO0FBQ2pCO0FBQ0EsaUJBQWlCO0FBQ2pCO0FBQ0EsaUJBQWlCO0FBQ2pCO0FBQ0EsaUJBQWlCO0FBQ2pCO0FBQ0EsaUJBQWlCO0FBQ2pCO0FBQ0EsaUJBQWlCO0FBQ2pCO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0EsaUJBQWlCO0FBQ2pCO0FBQ0EsaUJBQWlCO0FBQ2pCO0FBQ0EsaUJBQWlCO0FBQ2pCO0FBQ0EsaUJBQWlCO0FBQ2pCO0FBQ0E7O0FBRUEsV0FBVztBQUNYOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLHlCQUF5QjtBQUN6QixzQkFBc0I7QUFDdEIseUJBQXlCO0FBQ3pCLGlDQUFpQztBQUNqQyxxQkFBcUI7QUFDckIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy90cmFjaW5nL3NwYW5zdGF0dXMuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IFNQQU5fU1RBVFVTX1VOU0VUID0gMDtcbmNvbnN0IFNQQU5fU1RBVFVTX09LID0gMTtcbmNvbnN0IFNQQU5fU1RBVFVTX0VSUk9SID0gMjtcblxuLyoqXG4gKiBDb252ZXJ0cyBhIEhUVFAgc3RhdHVzIGNvZGUgaW50byBhIHNlbnRyeSBzdGF0dXMgd2l0aCBhIG1lc3NhZ2UuXG4gKlxuICogQHBhcmFtIGh0dHBTdGF0dXMgVGhlIEhUVFAgcmVzcG9uc2Ugc3RhdHVzIGNvZGUuXG4gKiBAcmV0dXJucyBUaGUgc3BhbiBzdGF0dXMgb3IgdW5rbm93bl9lcnJvci5cbiAqL1xuLy8gaHR0cHM6Ly9kZXZlbG9wLnNlbnRyeS5kZXYvc2RrL2V2ZW50LXBheWxvYWRzL3NwYW4vXG5mdW5jdGlvbiBnZXRTcGFuU3RhdHVzRnJvbUh0dHBDb2RlKGh0dHBTdGF0dXMpIHtcbiAgaWYgKGh0dHBTdGF0dXMgPCA0MDAgJiYgaHR0cFN0YXR1cyA+PSAxMDApIHtcbiAgICByZXR1cm4geyBjb2RlOiBTUEFOX1NUQVRVU19PSyB9O1xuICB9XG5cbiAgaWYgKGh0dHBTdGF0dXMgPj0gNDAwICYmIGh0dHBTdGF0dXMgPCA1MDApIHtcbiAgICBzd2l0Y2ggKGh0dHBTdGF0dXMpIHtcbiAgICAgIGNhc2UgNDAxOlxuICAgICAgICByZXR1cm4geyBjb2RlOiBTUEFOX1NUQVRVU19FUlJPUiwgbWVzc2FnZTogJ3VuYXV0aGVudGljYXRlZCcgfTtcbiAgICAgIGNhc2UgNDAzOlxuICAgICAgICByZXR1cm4geyBjb2RlOiBTUEFOX1NUQVRVU19FUlJPUiwgbWVzc2FnZTogJ3Blcm1pc3Npb25fZGVuaWVkJyB9O1xuICAgICAgY2FzZSA0MDQ6XG4gICAgICAgIHJldHVybiB7IGNvZGU6IFNQQU5fU1RBVFVTX0VSUk9SLCBtZXNzYWdlOiAnbm90X2ZvdW5kJyB9O1xuICAgICAgY2FzZSA0MDk6XG4gICAgICAgIHJldHVybiB7IGNvZGU6IFNQQU5fU1RBVFVTX0VSUk9SLCBtZXNzYWdlOiAnYWxyZWFkeV9leGlzdHMnIH07XG4gICAgICBjYXNlIDQxMzpcbiAgICAgICAgcmV0dXJuIHsgY29kZTogU1BBTl9TVEFUVVNfRVJST1IsIG1lc3NhZ2U6ICdmYWlsZWRfcHJlY29uZGl0aW9uJyB9O1xuICAgICAgY2FzZSA0Mjk6XG4gICAgICAgIHJldHVybiB7IGNvZGU6IFNQQU5fU1RBVFVTX0VSUk9SLCBtZXNzYWdlOiAncmVzb3VyY2VfZXhoYXVzdGVkJyB9O1xuICAgICAgY2FzZSA0OTk6XG4gICAgICAgIHJldHVybiB7IGNvZGU6IFNQQU5fU1RBVFVTX0VSUk9SLCBtZXNzYWdlOiAnY2FuY2VsbGVkJyB9O1xuICAgICAgZGVmYXVsdDpcbiAgICAgICAgcmV0dXJuIHsgY29kZTogU1BBTl9TVEFUVVNfRVJST1IsIG1lc3NhZ2U6ICdpbnZhbGlkX2FyZ3VtZW50JyB9O1xuICAgIH1cbiAgfVxuXG4gIGlmIChodHRwU3RhdHVzID49IDUwMCAmJiBodHRwU3RhdHVzIDwgNjAwKSB7XG4gICAgc3dpdGNoIChodHRwU3RhdHVzKSB7XG4gICAgICBjYXNlIDUwMTpcbiAgICAgICAgcmV0dXJuIHsgY29kZTogU1BBTl9TVEFUVVNfRVJST1IsIG1lc3NhZ2U6ICd1bmltcGxlbWVudGVkJyB9O1xuICAgICAgY2FzZSA1MDM6XG4gICAgICAgIHJldHVybiB7IGNvZGU6IFNQQU5fU1RBVFVTX0VSUk9SLCBtZXNzYWdlOiAndW5hdmFpbGFibGUnIH07XG4gICAgICBjYXNlIDUwNDpcbiAgICAgICAgcmV0dXJuIHsgY29kZTogU1BBTl9TVEFUVVNfRVJST1IsIG1lc3NhZ2U6ICdkZWFkbGluZV9leGNlZWRlZCcgfTtcbiAgICAgIGRlZmF1bHQ6XG4gICAgICAgIHJldHVybiB7IGNvZGU6IFNQQU5fU1RBVFVTX0VSUk9SLCBtZXNzYWdlOiAnaW50ZXJuYWxfZXJyb3InIH07XG4gICAgfVxuICB9XG5cbiAgcmV0dXJuIHsgY29kZTogU1BBTl9TVEFUVVNfRVJST1IsIG1lc3NhZ2U6ICd1bmtub3duX2Vycm9yJyB9O1xufVxuXG4vKipcbiAqIFNldHMgdGhlIEh0dHAgc3RhdHVzIGF0dHJpYnV0ZXMgb24gdGhlIGN1cnJlbnQgc3BhbiBiYXNlZCBvbiB0aGUgaHR0cCBjb2RlLlxuICogQWRkaXRpb25hbGx5LCB0aGUgc3BhbidzIHN0YXR1cyBpcyB1cGRhdGVkLCBkZXBlbmRpbmcgb24gdGhlIGh0dHAgY29kZS5cbiAqL1xuZnVuY3Rpb24gc2V0SHR0cFN0YXR1cyhzcGFuLCBodHRwU3RhdHVzKSB7XG4gIHNwYW4uc2V0QXR0cmlidXRlKCdodHRwLnJlc3BvbnNlLnN0YXR1c19jb2RlJywgaHR0cFN0YXR1cyk7XG5cbiAgY29uc3Qgc3BhblN0YXR1cyA9IGdldFNwYW5TdGF0dXNGcm9tSHR0cENvZGUoaHR0cFN0YXR1cyk7XG4gIGlmIChzcGFuU3RhdHVzLm1lc3NhZ2UgIT09ICd1bmtub3duX2Vycm9yJykge1xuICAgIHNwYW4uc2V0U3RhdHVzKHNwYW5TdGF0dXMpO1xuICB9XG59XG5cbmV4cG9ydHMuU1BBTl9TVEFUVVNfRVJST1IgPSBTUEFOX1NUQVRVU19FUlJPUjtcbmV4cG9ydHMuU1BBTl9TVEFUVVNfT0sgPSBTUEFOX1NUQVRVU19PSztcbmV4cG9ydHMuU1BBTl9TVEFUVVNfVU5TRVQgPSBTUEFOX1NUQVRVU19VTlNFVDtcbmV4cG9ydHMuZ2V0U3BhblN0YXR1c0Zyb21IdHRwQ29kZSA9IGdldFNwYW5TdGF0dXNGcm9tSHR0cENvZGU7XG5leHBvcnRzLnNldEh0dHBTdGF0dXMgPSBzZXRIdHRwU3RhdHVzO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9c3BhbnN0YXR1cy5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/spanstatus.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/trace.js":
/*!*****************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/trace.js ***!
  \*****************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst index = __webpack_require__(/*! ../asyncContext/index.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/asyncContext/index.js\");\nconst carrier = __webpack_require__(/*! ../carrier.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/carrier.js\");\nconst currentScopes = __webpack_require__(/*! ../currentScopes.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst debugBuild = __webpack_require__(/*! ../debug-build.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst semanticAttributes = __webpack_require__(/*! ../semanticAttributes.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/semanticAttributes.js\");\nconst debugLogger = __webpack_require__(/*! ../utils/debug-logger.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst handleCallbackErrors = __webpack_require__(/*! ../utils/handleCallbackErrors.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/handleCallbackErrors.js\");\nconst hasSpansEnabled = __webpack_require__(/*! ../utils/hasSpansEnabled.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/hasSpansEnabled.js\");\nconst parseSampleRate = __webpack_require__(/*! ../utils/parseSampleRate.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/parseSampleRate.js\");\nconst propagationContext = __webpack_require__(/*! ../utils/propagationContext.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/propagationContext.js\");\nconst spanOnScope = __webpack_require__(/*! ../utils/spanOnScope.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanOnScope.js\");\nconst spanUtils = __webpack_require__(/*! ../utils/spanUtils.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanUtils.js\");\nconst tracing = __webpack_require__(/*! ../utils/tracing.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/tracing.js\");\nconst dynamicSamplingContext = __webpack_require__(/*! ./dynamicSamplingContext.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/dynamicSamplingContext.js\");\nconst logSpans = __webpack_require__(/*! ./logSpans.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/logSpans.js\");\nconst sampling = __webpack_require__(/*! ./sampling.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/sampling.js\");\nconst sentryNonRecordingSpan = __webpack_require__(/*! ./sentryNonRecordingSpan.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/sentryNonRecordingSpan.js\");\nconst sentrySpan = __webpack_require__(/*! ./sentrySpan.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/sentrySpan.js\");\nconst spanstatus = __webpack_require__(/*! ./spanstatus.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/spanstatus.js\");\nconst utils = __webpack_require__(/*! ./utils.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/utils.js\");\n\n/* eslint-disable max-lines */\n\n\nconst SUPPRESS_TRACING_KEY = '__SENTRY_SUPPRESS_TRACING__';\n\n/**\n * Wraps a function with a transaction/span and finishes the span after the function is done.\n * The created span is the active span and will be used as parent by other spans created inside the function\n * and can be accessed via `Sentry.getActiveSpan()`, as long as the function is executed while the scope is active.\n *\n * If you want to create a span that is not set as active, use {@link startInactiveSpan}.\n *\n * You'll always get a span passed to the callback,\n * it may just be a non-recording span if the span is not sampled or if tracing is disabled.\n */\nfunction startSpan(options, callback) {\n  const acs = getAcs();\n  if (acs.startSpan) {\n    return acs.startSpan(options, callback);\n  }\n\n  const spanArguments = parseSentrySpanArguments(options);\n  const { forceTransaction, parentSpan: customParentSpan, scope: customScope } = options;\n\n  // We still need to fork a potentially passed scope, as we set the active span on it\n  // and we need to ensure that it is cleaned up properly once the span ends.\n  const customForkedScope = customScope?.clone();\n\n  return currentScopes.withScope(customForkedScope, () => {\n    // If `options.parentSpan` is defined, we want to wrap the callback in `withActiveSpan`\n    const wrapper = getActiveSpanWrapper(customParentSpan);\n\n    return wrapper(() => {\n      const scope = currentScopes.getCurrentScope();\n      const parentSpan = getParentSpan(scope, customParentSpan);\n\n      const shouldSkipSpan = options.onlyIfParent && !parentSpan;\n      const activeSpan = shouldSkipSpan\n        ? new sentryNonRecordingSpan.SentryNonRecordingSpan()\n        : createChildOrRootSpan({\n            parentSpan,\n            spanArguments,\n            forceTransaction,\n            scope,\n          });\n\n      spanOnScope._setSpanForScope(scope, activeSpan);\n\n      return handleCallbackErrors.handleCallbackErrors(\n        () => callback(activeSpan),\n        () => {\n          // Only update the span status if it hasn't been changed yet, and the span is not yet finished\n          const { status } = spanUtils.spanToJSON(activeSpan);\n          if (activeSpan.isRecording() && (!status || status === 'ok')) {\n            activeSpan.setStatus({ code: spanstatus.SPAN_STATUS_ERROR, message: 'internal_error' });\n          }\n        },\n        () => {\n          activeSpan.end();\n        },\n      );\n    });\n  });\n}\n\n/**\n * Similar to `Sentry.startSpan`. Wraps a function with a transaction/span, but does not finish the span\n * after the function is done automatically. Use `span.end()` to end the span.\n *\n * The created span is the active span and will be used as parent by other spans created inside the function\n * and can be accessed via `Sentry.getActiveSpan()`, as long as the function is executed while the scope is active.\n *\n * You'll always get a span passed to the callback,\n * it may just be a non-recording span if the span is not sampled or if tracing is disabled.\n */\nfunction startSpanManual(options, callback) {\n  const acs = getAcs();\n  if (acs.startSpanManual) {\n    return acs.startSpanManual(options, callback);\n  }\n\n  const spanArguments = parseSentrySpanArguments(options);\n  const { forceTransaction, parentSpan: customParentSpan, scope: customScope } = options;\n\n  const customForkedScope = customScope?.clone();\n\n  return currentScopes.withScope(customForkedScope, () => {\n    // If `options.parentSpan` is defined, we want to wrap the callback in `withActiveSpan`\n    const wrapper = getActiveSpanWrapper(customParentSpan);\n\n    return wrapper(() => {\n      const scope = currentScopes.getCurrentScope();\n      const parentSpan = getParentSpan(scope, customParentSpan);\n\n      const shouldSkipSpan = options.onlyIfParent && !parentSpan;\n      const activeSpan = shouldSkipSpan\n        ? new sentryNonRecordingSpan.SentryNonRecordingSpan()\n        : createChildOrRootSpan({\n            parentSpan,\n            spanArguments,\n            forceTransaction,\n            scope,\n          });\n\n      spanOnScope._setSpanForScope(scope, activeSpan);\n\n      return handleCallbackErrors.handleCallbackErrors(\n        // We pass the `finish` function to the callback, so the user can finish the span manually\n        // this is mainly here for historic purposes because previously, we instructed users to call\n        // `finish` instead of `span.end()` to also clean up the scope. Nowadays, calling `span.end()`\n        // or `finish` has the same effect and we simply leave it here to avoid breaking user code.\n        () => callback(activeSpan, () => activeSpan.end()),\n        () => {\n          // Only update the span status if it hasn't been changed yet, and the span is not yet finished\n          const { status } = spanUtils.spanToJSON(activeSpan);\n          if (activeSpan.isRecording() && (!status || status === 'ok')) {\n            activeSpan.setStatus({ code: spanstatus.SPAN_STATUS_ERROR, message: 'internal_error' });\n          }\n        },\n      );\n    });\n  });\n}\n\n/**\n * Creates a span. This span is not set as active, so will not get automatic instrumentation spans\n * as children or be able to be accessed via `Sentry.getActiveSpan()`.\n *\n * If you want to create a span that is set as active, use {@link startSpan}.\n *\n * This function will always return a span,\n * it may just be a non-recording span if the span is not sampled or if tracing is disabled.\n */\nfunction startInactiveSpan(options) {\n  const acs = getAcs();\n  if (acs.startInactiveSpan) {\n    return acs.startInactiveSpan(options);\n  }\n\n  const spanArguments = parseSentrySpanArguments(options);\n  const { forceTransaction, parentSpan: customParentSpan } = options;\n\n  // If `options.scope` is defined, we use this as as a wrapper,\n  // If `options.parentSpan` is defined, we want to wrap the callback in `withActiveSpan`\n  const wrapper = options.scope\n    ? (callback) => currentScopes.withScope(options.scope, callback)\n    : customParentSpan !== undefined\n      ? (callback) => withActiveSpan(customParentSpan, callback)\n      : (callback) => callback();\n\n  return wrapper(() => {\n    const scope = currentScopes.getCurrentScope();\n    const parentSpan = getParentSpan(scope, customParentSpan);\n\n    const shouldSkipSpan = options.onlyIfParent && !parentSpan;\n\n    if (shouldSkipSpan) {\n      return new sentryNonRecordingSpan.SentryNonRecordingSpan();\n    }\n\n    return createChildOrRootSpan({\n      parentSpan,\n      spanArguments,\n      forceTransaction,\n      scope,\n    });\n  });\n}\n\n/**\n * Continue a trace from `sentry-trace` and `baggage` values.\n * These values can be obtained from incoming request headers, or in the browser from `<meta name=\"sentry-trace\">`\n * and `<meta name=\"baggage\">` HTML tags.\n *\n * Spans started with `startSpan`, `startSpanManual` and `startInactiveSpan`, within the callback will automatically\n * be attached to the incoming trace.\n */\nconst continueTrace = (\n  options\n\n,\n  callback,\n) => {\n  const carrier$1 = carrier.getMainCarrier();\n  const acs = index.getAsyncContextStrategy(carrier$1);\n  if (acs.continueTrace) {\n    return acs.continueTrace(options, callback);\n  }\n\n  const { sentryTrace, baggage } = options;\n\n  return currentScopes.withScope(scope => {\n    const propagationContext = tracing.propagationContextFromHeaders(sentryTrace, baggage);\n    scope.setPropagationContext(propagationContext);\n    return callback();\n  });\n};\n\n/**\n * Forks the current scope and sets the provided span as active span in the context of the provided callback. Can be\n * passed `null` to start an entirely new span tree.\n *\n * @param span Spans started in the context of the provided callback will be children of this span. If `null` is passed,\n * spans started within the callback will not be attached to a parent span.\n * @param callback Execution context in which the provided span will be active. Is passed the newly forked scope.\n * @returns the value returned from the provided callback function.\n */\nfunction withActiveSpan(span, callback) {\n  const acs = getAcs();\n  if (acs.withActiveSpan) {\n    return acs.withActiveSpan(span, callback);\n  }\n\n  return currentScopes.withScope(scope => {\n    spanOnScope._setSpanForScope(scope, span || undefined);\n    return callback(scope);\n  });\n}\n\n/** Suppress tracing in the given callback, ensuring no spans are generated inside of it. */\nfunction suppressTracing(callback) {\n  const acs = getAcs();\n\n  if (acs.suppressTracing) {\n    return acs.suppressTracing(callback);\n  }\n\n  return currentScopes.withScope(scope => {\n    // Note: We do not wait for the callback to finish before we reset the metadata\n    // the reason for this is that otherwise, in the browser this can lead to very weird behavior\n    // as there is only a single top scope, if the callback takes longer to finish,\n    // other, unrelated spans may also be suppressed, which we do not want\n    // so instead, we only suppress tracing synchronoysly in the browser\n    scope.setSDKProcessingMetadata({ [SUPPRESS_TRACING_KEY]: true });\n    const res = callback();\n    scope.setSDKProcessingMetadata({ [SUPPRESS_TRACING_KEY]: undefined });\n    return res;\n  });\n}\n\n/**\n * Starts a new trace for the duration of the provided callback. Spans started within the\n * callback will be part of the new trace instead of a potentially previously started trace.\n *\n * Important: Only use this function if you want to override the default trace lifetime and\n * propagation mechanism of the SDK for the duration and scope of the provided callback.\n * The newly created trace will also be the root of a new distributed trace, for example if\n * you make http requests within the callback.\n * This function might be useful if the operation you want to instrument should not be part\n * of a potentially ongoing trace.\n *\n * Default behavior:\n * - Server-side: A new trace is started for each incoming request.\n * - Browser: A new trace is started for each page our route. Navigating to a new route\n *            or page will automatically create a new trace.\n */\nfunction startNewTrace(callback) {\n  return currentScopes.withScope(scope => {\n    scope.setPropagationContext({\n      traceId: propagationContext.generateTraceId(),\n      sampleRand: Math.random(),\n    });\n    debugBuild.DEBUG_BUILD && debugLogger.debug.log(`Starting a new trace with id ${scope.getPropagationContext().traceId}`);\n    return withActiveSpan(null, callback);\n  });\n}\n\nfunction createChildOrRootSpan({\n  parentSpan,\n  spanArguments,\n  forceTransaction,\n  scope,\n}\n\n) {\n  if (!hasSpansEnabled.hasSpansEnabled()) {\n    const span = new sentryNonRecordingSpan.SentryNonRecordingSpan();\n\n    // If this is a root span, we ensure to freeze a DSC\n    // So we can have at least partial data here\n    if (forceTransaction || !parentSpan) {\n      const dsc = {\n        sampled: 'false',\n        sample_rate: '0',\n        transaction: spanArguments.name,\n        ...dynamicSamplingContext.getDynamicSamplingContextFromSpan(span),\n      } ;\n      dynamicSamplingContext.freezeDscOnSpan(span, dsc);\n    }\n\n    return span;\n  }\n\n  const isolationScope = currentScopes.getIsolationScope();\n\n  let span;\n  if (parentSpan && !forceTransaction) {\n    span = _startChildSpan(parentSpan, scope, spanArguments);\n    spanUtils.addChildSpanToSpan(parentSpan, span);\n  } else if (parentSpan) {\n    // If we forced a transaction but have a parent span, make sure to continue from the parent span, not the scope\n    const dsc = dynamicSamplingContext.getDynamicSamplingContextFromSpan(parentSpan);\n    const { traceId, spanId: parentSpanId } = parentSpan.spanContext();\n    const parentSampled = spanUtils.spanIsSampled(parentSpan);\n\n    span = _startRootSpan(\n      {\n        traceId,\n        parentSpanId,\n        ...spanArguments,\n      },\n      scope,\n      parentSampled,\n    );\n\n    dynamicSamplingContext.freezeDscOnSpan(span, dsc);\n  } else {\n    const {\n      traceId,\n      dsc,\n      parentSpanId,\n      sampled: parentSampled,\n    } = {\n      ...isolationScope.getPropagationContext(),\n      ...scope.getPropagationContext(),\n    };\n\n    span = _startRootSpan(\n      {\n        traceId,\n        parentSpanId,\n        ...spanArguments,\n      },\n      scope,\n      parentSampled,\n    );\n\n    if (dsc) {\n      dynamicSamplingContext.freezeDscOnSpan(span, dsc);\n    }\n  }\n\n  logSpans.logSpanStart(span);\n\n  utils.setCapturedScopesOnSpan(span, scope, isolationScope);\n\n  return span;\n}\n\n/**\n * This converts StartSpanOptions to SentrySpanArguments.\n * For the most part (for now) we accept the same options,\n * but some of them need to be transformed.\n */\nfunction parseSentrySpanArguments(options) {\n  const exp = options.experimental || {};\n  const initialCtx = {\n    isStandalone: exp.standalone,\n    ...options,\n  };\n\n  if (options.startTime) {\n    const ctx = { ...initialCtx };\n    ctx.startTimestamp = spanUtils.spanTimeInputToSeconds(options.startTime);\n    delete ctx.startTime;\n    return ctx;\n  }\n\n  return initialCtx;\n}\n\nfunction getAcs() {\n  const carrier$1 = carrier.getMainCarrier();\n  return index.getAsyncContextStrategy(carrier$1);\n}\n\nfunction _startRootSpan(spanArguments, scope, parentSampled) {\n  const client = currentScopes.getClient();\n  const options = client?.getOptions() || {};\n\n  const { name = '' } = spanArguments;\n\n  const mutableSpanSamplingData = { spanAttributes: { ...spanArguments.attributes }, spanName: name, parentSampled };\n\n  // we don't care about the decision for the moment; this is just a placeholder\n  client?.emit('beforeSampling', mutableSpanSamplingData, { decision: false });\n\n  // If hook consumers override the parentSampled flag, we will use that value instead of the actual one\n  const finalParentSampled = mutableSpanSamplingData.parentSampled ?? parentSampled;\n  const finalAttributes = mutableSpanSamplingData.spanAttributes;\n\n  const currentPropagationContext = scope.getPropagationContext();\n  const [sampled, sampleRate, localSampleRateWasApplied] = scope.getScopeData().sdkProcessingMetadata[\n    SUPPRESS_TRACING_KEY\n  ]\n    ? [false]\n    : sampling.sampleSpan(\n        options,\n        {\n          name,\n          parentSampled: finalParentSampled,\n          attributes: finalAttributes,\n          parentSampleRate: parseSampleRate.parseSampleRate(currentPropagationContext.dsc?.sample_rate),\n        },\n        currentPropagationContext.sampleRand,\n      );\n\n  const rootSpan = new sentrySpan.SentrySpan({\n    ...spanArguments,\n    attributes: {\n      [semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_SOURCE]: 'custom',\n      [semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_SAMPLE_RATE]:\n        sampleRate !== undefined && localSampleRateWasApplied ? sampleRate : undefined,\n      ...finalAttributes,\n    },\n    sampled,\n  });\n\n  if (!sampled && client) {\n    debugBuild.DEBUG_BUILD && debugLogger.debug.log('[Tracing] Discarding root span because its trace was not chosen to be sampled.');\n    client.recordDroppedEvent('sample_rate', 'transaction');\n  }\n\n  if (client) {\n    client.emit('spanStart', rootSpan);\n  }\n\n  return rootSpan;\n}\n\n/**\n * Creates a new `Span` while setting the current `Span.id` as `parentSpanId`.\n * This inherits the sampling decision from the parent span.\n */\nfunction _startChildSpan(parentSpan, scope, spanArguments) {\n  const { spanId, traceId } = parentSpan.spanContext();\n  const sampled = scope.getScopeData().sdkProcessingMetadata[SUPPRESS_TRACING_KEY] ? false : spanUtils.spanIsSampled(parentSpan);\n\n  const childSpan = sampled\n    ? new sentrySpan.SentrySpan({\n        ...spanArguments,\n        parentSpanId: spanId,\n        traceId,\n        sampled,\n      })\n    : new sentryNonRecordingSpan.SentryNonRecordingSpan({ traceId });\n\n  spanUtils.addChildSpanToSpan(parentSpan, childSpan);\n\n  const client = currentScopes.getClient();\n  if (client) {\n    client.emit('spanStart', childSpan);\n    // If it has an endTimestamp, it's already ended\n    if (spanArguments.endTimestamp) {\n      client.emit('spanEnd', childSpan);\n    }\n  }\n\n  return childSpan;\n}\n\nfunction getParentSpan(scope, customParentSpan) {\n  // always use the passed in span directly\n  if (customParentSpan) {\n    return customParentSpan ;\n  }\n\n  // This is different from `undefined` as it means the user explicitly wants no parent span\n  if (customParentSpan === null) {\n    return undefined;\n  }\n\n  const span = spanOnScope._getSpanForScope(scope) ;\n\n  if (!span) {\n    return undefined;\n  }\n\n  const client = currentScopes.getClient();\n  const options = client ? client.getOptions() : {};\n  if (options.parentSpanIsAlwaysRootSpan) {\n    return spanUtils.getRootSpan(span) ;\n  }\n\n  return span;\n}\n\nfunction getActiveSpanWrapper(parentSpan) {\n  return parentSpan !== undefined\n    ? (callback) => {\n        return withActiveSpan(parentSpan, callback);\n      }\n    : (callback) => callback();\n}\n\nexports.continueTrace = continueTrace;\nexports.startInactiveSpan = startInactiveSpan;\nexports.startNewTrace = startNewTrace;\nexports.startSpan = startSpan;\nexports.startSpanManual = startSpanManual;\nexports.suppressTracing = suppressTracing;\nexports.withActiveSpan = withActiveSpan;\n//# sourceMappingURL=trace.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdHJhY2luZy90cmFjZS5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxjQUFjLG1CQUFPLENBQUMsaUpBQTBCO0FBQ2hELGdCQUFnQixtQkFBTyxDQUFDLDJIQUFlO0FBQ3ZDLHNCQUFzQixtQkFBTyxDQUFDLHVJQUFxQjtBQUNuRCxtQkFBbUIsbUJBQU8sQ0FBQyxtSUFBbUI7QUFDOUMsMkJBQTJCLG1CQUFPLENBQUMsaUpBQTBCO0FBQzdELG9CQUFvQixtQkFBTyxDQUFDLGlKQUEwQjtBQUN0RCw2QkFBNkIsbUJBQU8sQ0FBQyxpS0FBa0M7QUFDdkUsd0JBQXdCLG1CQUFPLENBQUMsdUpBQTZCO0FBQzdELHdCQUF3QixtQkFBTyxDQUFDLHVKQUE2QjtBQUM3RCwyQkFBMkIsbUJBQU8sQ0FBQyw2SkFBZ0M7QUFDbkUsb0JBQW9CLG1CQUFPLENBQUMsK0lBQXlCO0FBQ3JELGtCQUFrQixtQkFBTyxDQUFDLDJJQUF1QjtBQUNqRCxnQkFBZ0IsbUJBQU8sQ0FBQyx1SUFBcUI7QUFDN0MsK0JBQStCLG1CQUFPLENBQUMsZ0tBQTZCO0FBQ3BFLGlCQUFpQixtQkFBTyxDQUFDLG9JQUFlO0FBQ3hDLGlCQUFpQixtQkFBTyxDQUFDLG9JQUFlO0FBQ3hDLCtCQUErQixtQkFBTyxDQUFDLGdLQUE2QjtBQUNwRSxtQkFBbUIsbUJBQU8sQ0FBQyx3SUFBaUI7QUFDNUMsbUJBQW1CLG1CQUFPLENBQUMsd0lBQWlCO0FBQzVDLGNBQWMsbUJBQU8sQ0FBQyw4SEFBWTs7QUFFbEM7OztBQUdBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxnRUFBZ0Usd0JBQXdCO0FBQ3hGO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBLFVBQVUscUVBQXFFOztBQUUvRTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsV0FBVzs7QUFFWDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGtCQUFrQixTQUFTO0FBQzNCO0FBQ0EsbUNBQW1DLCtEQUErRDtBQUNsRztBQUNBLFNBQVM7QUFDVDtBQUNBO0FBQ0EsU0FBUztBQUNUO0FBQ0EsS0FBSztBQUNMLEdBQUc7QUFDSDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQSxVQUFVLHFFQUFxRTs7QUFFL0U7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsV0FBVzs7QUFFWDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0Esa0JBQWtCLFNBQVM7QUFDM0I7QUFDQSxtQ0FBbUMsK0RBQStEO0FBQ2xHO0FBQ0EsU0FBUztBQUNUO0FBQ0EsS0FBSztBQUNMLEdBQUc7QUFDSDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLDREQUE0RCxnQkFBZ0I7QUFDNUU7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0EsVUFBVSxpREFBaUQ7O0FBRTNEO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEtBQUs7QUFDTCxHQUFHO0FBQ0g7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSxVQUFVLHVCQUF1Qjs7QUFFakM7QUFDQTtBQUNBO0FBQ0E7QUFDQSxHQUFHO0FBQ0g7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQSxHQUFHO0FBQ0g7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxxQ0FBcUMsOEJBQThCO0FBQ25FO0FBQ0EscUNBQXFDLG1DQUFtQztBQUN4RTtBQUNBLEdBQUc7QUFDSDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxLQUFLO0FBQ0wsb0ZBQW9GLHNDQUFzQztBQUMxSDtBQUNBLEdBQUc7QUFDSDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLElBQUk7QUFDSjtBQUNBO0FBQ0EsWUFBWSxnQ0FBZ0M7QUFDNUM7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLE9BQU87QUFDUDtBQUNBO0FBQ0E7O0FBRUE7QUFDQSxJQUFJO0FBQ0o7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLE1BQU07QUFDTjtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLE9BQU87QUFDUDtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0Esa0JBQWtCO0FBQ2xCO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBLFVBQVUsWUFBWTs7QUFFdEIsb0NBQW9DLGtCQUFrQiw2QkFBNkI7O0FBRW5GLHNEQUFzRDtBQUN0RCw0REFBNEQsaUJBQWlCOztBQUU3RTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsU0FBUztBQUNUO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxLQUFLO0FBQ0w7QUFDQSxHQUFHOztBQUVIO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxVQUFVLGtCQUFrQjtBQUM1Qjs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxPQUFPO0FBQ1AsMERBQTBELFNBQVM7O0FBRW5FOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEscUJBQXFCO0FBQ3JCLHlCQUF5QjtBQUN6QixxQkFBcUI7QUFDckIsaUJBQWlCO0FBQ2pCLHVCQUF1QjtBQUN2Qix1QkFBdUI7QUFDdkIsc0JBQXNCO0FBQ3RCIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdHJhY2luZy90cmFjZS5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgaW5kZXggPSByZXF1aXJlKCcuLi9hc3luY0NvbnRleHQvaW5kZXguanMnKTtcbmNvbnN0IGNhcnJpZXIgPSByZXF1aXJlKCcuLi9jYXJyaWVyLmpzJyk7XG5jb25zdCBjdXJyZW50U2NvcGVzID0gcmVxdWlyZSgnLi4vY3VycmVudFNjb3Blcy5qcycpO1xuY29uc3QgZGVidWdCdWlsZCA9IHJlcXVpcmUoJy4uL2RlYnVnLWJ1aWxkLmpzJyk7XG5jb25zdCBzZW1hbnRpY0F0dHJpYnV0ZXMgPSByZXF1aXJlKCcuLi9zZW1hbnRpY0F0dHJpYnV0ZXMuanMnKTtcbmNvbnN0IGRlYnVnTG9nZ2VyID0gcmVxdWlyZSgnLi4vdXRpbHMvZGVidWctbG9nZ2VyLmpzJyk7XG5jb25zdCBoYW5kbGVDYWxsYmFja0Vycm9ycyA9IHJlcXVpcmUoJy4uL3V0aWxzL2hhbmRsZUNhbGxiYWNrRXJyb3JzLmpzJyk7XG5jb25zdCBoYXNTcGFuc0VuYWJsZWQgPSByZXF1aXJlKCcuLi91dGlscy9oYXNTcGFuc0VuYWJsZWQuanMnKTtcbmNvbnN0IHBhcnNlU2FtcGxlUmF0ZSA9IHJlcXVpcmUoJy4uL3V0aWxzL3BhcnNlU2FtcGxlUmF0ZS5qcycpO1xuY29uc3QgcHJvcGFnYXRpb25Db250ZXh0ID0gcmVxdWlyZSgnLi4vdXRpbHMvcHJvcGFnYXRpb25Db250ZXh0LmpzJyk7XG5jb25zdCBzcGFuT25TY29wZSA9IHJlcXVpcmUoJy4uL3V0aWxzL3NwYW5PblNjb3BlLmpzJyk7XG5jb25zdCBzcGFuVXRpbHMgPSByZXF1aXJlKCcuLi91dGlscy9zcGFuVXRpbHMuanMnKTtcbmNvbnN0IHRyYWNpbmcgPSByZXF1aXJlKCcuLi91dGlscy90cmFjaW5nLmpzJyk7XG5jb25zdCBkeW5hbWljU2FtcGxpbmdDb250ZXh0ID0gcmVxdWlyZSgnLi9keW5hbWljU2FtcGxpbmdDb250ZXh0LmpzJyk7XG5jb25zdCBsb2dTcGFucyA9IHJlcXVpcmUoJy4vbG9nU3BhbnMuanMnKTtcbmNvbnN0IHNhbXBsaW5nID0gcmVxdWlyZSgnLi9zYW1wbGluZy5qcycpO1xuY29uc3Qgc2VudHJ5Tm9uUmVjb3JkaW5nU3BhbiA9IHJlcXVpcmUoJy4vc2VudHJ5Tm9uUmVjb3JkaW5nU3Bhbi5qcycpO1xuY29uc3Qgc2VudHJ5U3BhbiA9IHJlcXVpcmUoJy4vc2VudHJ5U3Bhbi5qcycpO1xuY29uc3Qgc3BhbnN0YXR1cyA9IHJlcXVpcmUoJy4vc3BhbnN0YXR1cy5qcycpO1xuY29uc3QgdXRpbHMgPSByZXF1aXJlKCcuL3V0aWxzLmpzJyk7XG5cbi8qIGVzbGludC1kaXNhYmxlIG1heC1saW5lcyAqL1xuXG5cbmNvbnN0IFNVUFBSRVNTX1RSQUNJTkdfS0VZID0gJ19fU0VOVFJZX1NVUFBSRVNTX1RSQUNJTkdfXyc7XG5cbi8qKlxuICogV3JhcHMgYSBmdW5jdGlvbiB3aXRoIGEgdHJhbnNhY3Rpb24vc3BhbiBhbmQgZmluaXNoZXMgdGhlIHNwYW4gYWZ0ZXIgdGhlIGZ1bmN0aW9uIGlzIGRvbmUuXG4gKiBUaGUgY3JlYXRlZCBzcGFuIGlzIHRoZSBhY3RpdmUgc3BhbiBhbmQgd2lsbCBiZSB1c2VkIGFzIHBhcmVudCBieSBvdGhlciBzcGFucyBjcmVhdGVkIGluc2lkZSB0aGUgZnVuY3Rpb25cbiAqIGFuZCBjYW4gYmUgYWNjZXNzZWQgdmlhIGBTZW50cnkuZ2V0QWN0aXZlU3BhbigpYCwgYXMgbG9uZyBhcyB0aGUgZnVuY3Rpb24gaXMgZXhlY3V0ZWQgd2hpbGUgdGhlIHNjb3BlIGlzIGFjdGl2ZS5cbiAqXG4gKiBJZiB5b3Ugd2FudCB0byBjcmVhdGUgYSBzcGFuIHRoYXQgaXMgbm90IHNldCBhcyBhY3RpdmUsIHVzZSB7QGxpbmsgc3RhcnRJbmFjdGl2ZVNwYW59LlxuICpcbiAqIFlvdSdsbCBhbHdheXMgZ2V0IGEgc3BhbiBwYXNzZWQgdG8gdGhlIGNhbGxiYWNrLFxuICogaXQgbWF5IGp1c3QgYmUgYSBub24tcmVjb3JkaW5nIHNwYW4gaWYgdGhlIHNwYW4gaXMgbm90IHNhbXBsZWQgb3IgaWYgdHJhY2luZyBpcyBkaXNhYmxlZC5cbiAqL1xuZnVuY3Rpb24gc3RhcnRTcGFuKG9wdGlvbnMsIGNhbGxiYWNrKSB7XG4gIGNvbnN0IGFjcyA9IGdldEFjcygpO1xuICBpZiAoYWNzLnN0YXJ0U3Bhbikge1xuICAgIHJldHVybiBhY3Muc3RhcnRTcGFuKG9wdGlvbnMsIGNhbGxiYWNrKTtcbiAgfVxuXG4gIGNvbnN0IHNwYW5Bcmd1bWVudHMgPSBwYXJzZVNlbnRyeVNwYW5Bcmd1bWVudHMob3B0aW9ucyk7XG4gIGNvbnN0IHsgZm9yY2VUcmFuc2FjdGlvbiwgcGFyZW50U3BhbjogY3VzdG9tUGFyZW50U3Bhbiwgc2NvcGU6IGN1c3RvbVNjb3BlIH0gPSBvcHRpb25zO1xuXG4gIC8vIFdlIHN0aWxsIG5lZWQgdG8gZm9yayBhIHBvdGVudGlhbGx5IHBhc3NlZCBzY29wZSwgYXMgd2Ugc2V0IHRoZSBhY3RpdmUgc3BhbiBvbiBpdFxuICAvLyBhbmQgd2UgbmVlZCB0byBlbnN1cmUgdGhhdCBpdCBpcyBjbGVhbmVkIHVwIHByb3Blcmx5IG9uY2UgdGhlIHNwYW4gZW5kcy5cbiAgY29uc3QgY3VzdG9tRm9ya2VkU2NvcGUgPSBjdXN0b21TY29wZT8uY2xvbmUoKTtcblxuICByZXR1cm4gY3VycmVudFNjb3Blcy53aXRoU2NvcGUoY3VzdG9tRm9ya2VkU2NvcGUsICgpID0+IHtcbiAgICAvLyBJZiBgb3B0aW9ucy5wYXJlbnRTcGFuYCBpcyBkZWZpbmVkLCB3ZSB3YW50IHRvIHdyYXAgdGhlIGNhbGxiYWNrIGluIGB3aXRoQWN0aXZlU3BhbmBcbiAgICBjb25zdCB3cmFwcGVyID0gZ2V0QWN0aXZlU3BhbldyYXBwZXIoY3VzdG9tUGFyZW50U3Bhbik7XG5cbiAgICByZXR1cm4gd3JhcHBlcigoKSA9PiB7XG4gICAgICBjb25zdCBzY29wZSA9IGN1cnJlbnRTY29wZXMuZ2V0Q3VycmVudFNjb3BlKCk7XG4gICAgICBjb25zdCBwYXJlbnRTcGFuID0gZ2V0UGFyZW50U3BhbihzY29wZSwgY3VzdG9tUGFyZW50U3Bhbik7XG5cbiAgICAgIGNvbnN0IHNob3VsZFNraXBTcGFuID0gb3B0aW9ucy5vbmx5SWZQYXJlbnQgJiYgIXBhcmVudFNwYW47XG4gICAgICBjb25zdCBhY3RpdmVTcGFuID0gc2hvdWxkU2tpcFNwYW5cbiAgICAgICAgPyBuZXcgc2VudHJ5Tm9uUmVjb3JkaW5nU3Bhbi5TZW50cnlOb25SZWNvcmRpbmdTcGFuKClcbiAgICAgICAgOiBjcmVhdGVDaGlsZE9yUm9vdFNwYW4oe1xuICAgICAgICAgICAgcGFyZW50U3BhbixcbiAgICAgICAgICAgIHNwYW5Bcmd1bWVudHMsXG4gICAgICAgICAgICBmb3JjZVRyYW5zYWN0aW9uLFxuICAgICAgICAgICAgc2NvcGUsXG4gICAgICAgICAgfSk7XG5cbiAgICAgIHNwYW5PblNjb3BlLl9zZXRTcGFuRm9yU2NvcGUoc2NvcGUsIGFjdGl2ZVNwYW4pO1xuXG4gICAgICByZXR1cm4gaGFuZGxlQ2FsbGJhY2tFcnJvcnMuaGFuZGxlQ2FsbGJhY2tFcnJvcnMoXG4gICAgICAgICgpID0+IGNhbGxiYWNrKGFjdGl2ZVNwYW4pLFxuICAgICAgICAoKSA9PiB7XG4gICAgICAgICAgLy8gT25seSB1cGRhdGUgdGhlIHNwYW4gc3RhdHVzIGlmIGl0IGhhc24ndCBiZWVuIGNoYW5nZWQgeWV0LCBhbmQgdGhlIHNwYW4gaXMgbm90IHlldCBmaW5pc2hlZFxuICAgICAgICAgIGNvbnN0IHsgc3RhdHVzIH0gPSBzcGFuVXRpbHMuc3BhblRvSlNPTihhY3RpdmVTcGFuKTtcbiAgICAgICAgICBpZiAoYWN0aXZlU3Bhbi5pc1JlY29yZGluZygpICYmICghc3RhdHVzIHx8IHN0YXR1cyA9PT0gJ29rJykpIHtcbiAgICAgICAgICAgIGFjdGl2ZVNwYW4uc2V0U3RhdHVzKHsgY29kZTogc3BhbnN0YXR1cy5TUEFOX1NUQVRVU19FUlJPUiwgbWVzc2FnZTogJ2ludGVybmFsX2Vycm9yJyB9KTtcbiAgICAgICAgICB9XG4gICAgICAgIH0sXG4gICAgICAgICgpID0+IHtcbiAgICAgICAgICBhY3RpdmVTcGFuLmVuZCgpO1xuICAgICAgICB9LFxuICAgICAgKTtcbiAgICB9KTtcbiAgfSk7XG59XG5cbi8qKlxuICogU2ltaWxhciB0byBgU2VudHJ5LnN0YXJ0U3BhbmAuIFdyYXBzIGEgZnVuY3Rpb24gd2l0aCBhIHRyYW5zYWN0aW9uL3NwYW4sIGJ1dCBkb2VzIG5vdCBmaW5pc2ggdGhlIHNwYW5cbiAqIGFmdGVyIHRoZSBmdW5jdGlvbiBpcyBkb25lIGF1dG9tYXRpY2FsbHkuIFVzZSBgc3Bhbi5lbmQoKWAgdG8gZW5kIHRoZSBzcGFuLlxuICpcbiAqIFRoZSBjcmVhdGVkIHNwYW4gaXMgdGhlIGFjdGl2ZSBzcGFuIGFuZCB3aWxsIGJlIHVzZWQgYXMgcGFyZW50IGJ5IG90aGVyIHNwYW5zIGNyZWF0ZWQgaW5zaWRlIHRoZSBmdW5jdGlvblxuICogYW5kIGNhbiBiZSBhY2Nlc3NlZCB2aWEgYFNlbnRyeS5nZXRBY3RpdmVTcGFuKClgLCBhcyBsb25nIGFzIHRoZSBmdW5jdGlvbiBpcyBleGVjdXRlZCB3aGlsZSB0aGUgc2NvcGUgaXMgYWN0aXZlLlxuICpcbiAqIFlvdSdsbCBhbHdheXMgZ2V0IGEgc3BhbiBwYXNzZWQgdG8gdGhlIGNhbGxiYWNrLFxuICogaXQgbWF5IGp1c3QgYmUgYSBub24tcmVjb3JkaW5nIHNwYW4gaWYgdGhlIHNwYW4gaXMgbm90IHNhbXBsZWQgb3IgaWYgdHJhY2luZyBpcyBkaXNhYmxlZC5cbiAqL1xuZnVuY3Rpb24gc3RhcnRTcGFuTWFudWFsKG9wdGlvbnMsIGNhbGxiYWNrKSB7XG4gIGNvbnN0IGFjcyA9IGdldEFjcygpO1xuICBpZiAoYWNzLnN0YXJ0U3Bhbk1hbnVhbCkge1xuICAgIHJldHVybiBhY3Muc3RhcnRTcGFuTWFudWFsKG9wdGlvbnMsIGNhbGxiYWNrKTtcbiAgfVxuXG4gIGNvbnN0IHNwYW5Bcmd1bWVudHMgPSBwYXJzZVNlbnRyeVNwYW5Bcmd1bWVudHMob3B0aW9ucyk7XG4gIGNvbnN0IHsgZm9yY2VUcmFuc2FjdGlvbiwgcGFyZW50U3BhbjogY3VzdG9tUGFyZW50U3Bhbiwgc2NvcGU6IGN1c3RvbVNjb3BlIH0gPSBvcHRpb25zO1xuXG4gIGNvbnN0IGN1c3RvbUZvcmtlZFNjb3BlID0gY3VzdG9tU2NvcGU/LmNsb25lKCk7XG5cbiAgcmV0dXJuIGN1cnJlbnRTY29wZXMud2l0aFNjb3BlKGN1c3RvbUZvcmtlZFNjb3BlLCAoKSA9PiB7XG4gICAgLy8gSWYgYG9wdGlvbnMucGFyZW50U3BhbmAgaXMgZGVmaW5lZCwgd2Ugd2FudCB0byB3cmFwIHRoZSBjYWxsYmFjayBpbiBgd2l0aEFjdGl2ZVNwYW5gXG4gICAgY29uc3Qgd3JhcHBlciA9IGdldEFjdGl2ZVNwYW5XcmFwcGVyKGN1c3RvbVBhcmVudFNwYW4pO1xuXG4gICAgcmV0dXJuIHdyYXBwZXIoKCkgPT4ge1xuICAgICAgY29uc3Qgc2NvcGUgPSBjdXJyZW50U2NvcGVzLmdldEN1cnJlbnRTY29wZSgpO1xuICAgICAgY29uc3QgcGFyZW50U3BhbiA9IGdldFBhcmVudFNwYW4oc2NvcGUsIGN1c3RvbVBhcmVudFNwYW4pO1xuXG4gICAgICBjb25zdCBzaG91bGRTa2lwU3BhbiA9IG9wdGlvbnMub25seUlmUGFyZW50ICYmICFwYXJlbnRTcGFuO1xuICAgICAgY29uc3QgYWN0aXZlU3BhbiA9IHNob3VsZFNraXBTcGFuXG4gICAgICAgID8gbmV3IHNlbnRyeU5vblJlY29yZGluZ1NwYW4uU2VudHJ5Tm9uUmVjb3JkaW5nU3BhbigpXG4gICAgICAgIDogY3JlYXRlQ2hpbGRPclJvb3RTcGFuKHtcbiAgICAgICAgICAgIHBhcmVudFNwYW4sXG4gICAgICAgICAgICBzcGFuQXJndW1lbnRzLFxuICAgICAgICAgICAgZm9yY2VUcmFuc2FjdGlvbixcbiAgICAgICAgICAgIHNjb3BlLFxuICAgICAgICAgIH0pO1xuXG4gICAgICBzcGFuT25TY29wZS5fc2V0U3BhbkZvclNjb3BlKHNjb3BlLCBhY3RpdmVTcGFuKTtcblxuICAgICAgcmV0dXJuIGhhbmRsZUNhbGxiYWNrRXJyb3JzLmhhbmRsZUNhbGxiYWNrRXJyb3JzKFxuICAgICAgICAvLyBXZSBwYXNzIHRoZSBgZmluaXNoYCBmdW5jdGlvbiB0byB0aGUgY2FsbGJhY2ssIHNvIHRoZSB1c2VyIGNhbiBmaW5pc2ggdGhlIHNwYW4gbWFudWFsbHlcbiAgICAgICAgLy8gdGhpcyBpcyBtYWlubHkgaGVyZSBmb3IgaGlzdG9yaWMgcHVycG9zZXMgYmVjYXVzZSBwcmV2aW91c2x5LCB3ZSBpbnN0cnVjdGVkIHVzZXJzIHRvIGNhbGxcbiAgICAgICAgLy8gYGZpbmlzaGAgaW5zdGVhZCBvZiBgc3Bhbi5lbmQoKWAgdG8gYWxzbyBjbGVhbiB1cCB0aGUgc2NvcGUuIE5vd2FkYXlzLCBjYWxsaW5nIGBzcGFuLmVuZCgpYFxuICAgICAgICAvLyBvciBgZmluaXNoYCBoYXMgdGhlIHNhbWUgZWZmZWN0IGFuZCB3ZSBzaW1wbHkgbGVhdmUgaXQgaGVyZSB0byBhdm9pZCBicmVha2luZyB1c2VyIGNvZGUuXG4gICAgICAgICgpID0+IGNhbGxiYWNrKGFjdGl2ZVNwYW4sICgpID0+IGFjdGl2ZVNwYW4uZW5kKCkpLFxuICAgICAgICAoKSA9PiB7XG4gICAgICAgICAgLy8gT25seSB1cGRhdGUgdGhlIHNwYW4gc3RhdHVzIGlmIGl0IGhhc24ndCBiZWVuIGNoYW5nZWQgeWV0LCBhbmQgdGhlIHNwYW4gaXMgbm90IHlldCBmaW5pc2hlZFxuICAgICAgICAgIGNvbnN0IHsgc3RhdHVzIH0gPSBzcGFuVXRpbHMuc3BhblRvSlNPTihhY3RpdmVTcGFuKTtcbiAgICAgICAgICBpZiAoYWN0aXZlU3Bhbi5pc1JlY29yZGluZygpICYmICghc3RhdHVzIHx8IHN0YXR1cyA9PT0gJ29rJykpIHtcbiAgICAgICAgICAgIGFjdGl2ZVNwYW4uc2V0U3RhdHVzKHsgY29kZTogc3BhbnN0YXR1cy5TUEFOX1NUQVRVU19FUlJPUiwgbWVzc2FnZTogJ2ludGVybmFsX2Vycm9yJyB9KTtcbiAgICAgICAgICB9XG4gICAgICAgIH0sXG4gICAgICApO1xuICAgIH0pO1xuICB9KTtcbn1cblxuLyoqXG4gKiBDcmVhdGVzIGEgc3Bhbi4gVGhpcyBzcGFuIGlzIG5vdCBzZXQgYXMgYWN0aXZlLCBzbyB3aWxsIG5vdCBnZXQgYXV0b21hdGljIGluc3RydW1lbnRhdGlvbiBzcGFuc1xuICogYXMgY2hpbGRyZW4gb3IgYmUgYWJsZSB0byBiZSBhY2Nlc3NlZCB2aWEgYFNlbnRyeS5nZXRBY3RpdmVTcGFuKClgLlxuICpcbiAqIElmIHlvdSB3YW50IHRvIGNyZWF0ZSBhIHNwYW4gdGhhdCBpcyBzZXQgYXMgYWN0aXZlLCB1c2Uge0BsaW5rIHN0YXJ0U3Bhbn0uXG4gKlxuICogVGhpcyBmdW5jdGlvbiB3aWxsIGFsd2F5cyByZXR1cm4gYSBzcGFuLFxuICogaXQgbWF5IGp1c3QgYmUgYSBub24tcmVjb3JkaW5nIHNwYW4gaWYgdGhlIHNwYW4gaXMgbm90IHNhbXBsZWQgb3IgaWYgdHJhY2luZyBpcyBkaXNhYmxlZC5cbiAqL1xuZnVuY3Rpb24gc3RhcnRJbmFjdGl2ZVNwYW4ob3B0aW9ucykge1xuICBjb25zdCBhY3MgPSBnZXRBY3MoKTtcbiAgaWYgKGFjcy5zdGFydEluYWN0aXZlU3Bhbikge1xuICAgIHJldHVybiBhY3Muc3RhcnRJbmFjdGl2ZVNwYW4ob3B0aW9ucyk7XG4gIH1cblxuICBjb25zdCBzcGFuQXJndW1lbnRzID0gcGFyc2VTZW50cnlTcGFuQXJndW1lbnRzKG9wdGlvbnMpO1xuICBjb25zdCB7IGZvcmNlVHJhbnNhY3Rpb24sIHBhcmVudFNwYW46IGN1c3RvbVBhcmVudFNwYW4gfSA9IG9wdGlvbnM7XG5cbiAgLy8gSWYgYG9wdGlvbnMuc2NvcGVgIGlzIGRlZmluZWQsIHdlIHVzZSB0aGlzIGFzIGFzIGEgd3JhcHBlcixcbiAgLy8gSWYgYG9wdGlvbnMucGFyZW50U3BhbmAgaXMgZGVmaW5lZCwgd2Ugd2FudCB0byB3cmFwIHRoZSBjYWxsYmFjayBpbiBgd2l0aEFjdGl2ZVNwYW5gXG4gIGNvbnN0IHdyYXBwZXIgPSBvcHRpb25zLnNjb3BlXG4gICAgPyAoY2FsbGJhY2spID0+IGN1cnJlbnRTY29wZXMud2l0aFNjb3BlKG9wdGlvbnMuc2NvcGUsIGNhbGxiYWNrKVxuICAgIDogY3VzdG9tUGFyZW50U3BhbiAhPT0gdW5kZWZpbmVkXG4gICAgICA/IChjYWxsYmFjaykgPT4gd2l0aEFjdGl2ZVNwYW4oY3VzdG9tUGFyZW50U3BhbiwgY2FsbGJhY2spXG4gICAgICA6IChjYWxsYmFjaykgPT4gY2FsbGJhY2soKTtcblxuICByZXR1cm4gd3JhcHBlcigoKSA9PiB7XG4gICAgY29uc3Qgc2NvcGUgPSBjdXJyZW50U2NvcGVzLmdldEN1cnJlbnRTY29wZSgpO1xuICAgIGNvbnN0IHBhcmVudFNwYW4gPSBnZXRQYXJlbnRTcGFuKHNjb3BlLCBjdXN0b21QYXJlbnRTcGFuKTtcblxuICAgIGNvbnN0IHNob3VsZFNraXBTcGFuID0gb3B0aW9ucy5vbmx5SWZQYXJlbnQgJiYgIXBhcmVudFNwYW47XG5cbiAgICBpZiAoc2hvdWxkU2tpcFNwYW4pIHtcbiAgICAgIHJldHVybiBuZXcgc2VudHJ5Tm9uUmVjb3JkaW5nU3Bhbi5TZW50cnlOb25SZWNvcmRpbmdTcGFuKCk7XG4gICAgfVxuXG4gICAgcmV0dXJuIGNyZWF0ZUNoaWxkT3JSb290U3Bhbih7XG4gICAgICBwYXJlbnRTcGFuLFxuICAgICAgc3BhbkFyZ3VtZW50cyxcbiAgICAgIGZvcmNlVHJhbnNhY3Rpb24sXG4gICAgICBzY29wZSxcbiAgICB9KTtcbiAgfSk7XG59XG5cbi8qKlxuICogQ29udGludWUgYSB0cmFjZSBmcm9tIGBzZW50cnktdHJhY2VgIGFuZCBgYmFnZ2FnZWAgdmFsdWVzLlxuICogVGhlc2UgdmFsdWVzIGNhbiBiZSBvYnRhaW5lZCBmcm9tIGluY29taW5nIHJlcXVlc3QgaGVhZGVycywgb3IgaW4gdGhlIGJyb3dzZXIgZnJvbSBgPG1ldGEgbmFtZT1cInNlbnRyeS10cmFjZVwiPmBcbiAqIGFuZCBgPG1ldGEgbmFtZT1cImJhZ2dhZ2VcIj5gIEhUTUwgdGFncy5cbiAqXG4gKiBTcGFucyBzdGFydGVkIHdpdGggYHN0YXJ0U3BhbmAsIGBzdGFydFNwYW5NYW51YWxgIGFuZCBgc3RhcnRJbmFjdGl2ZVNwYW5gLCB3aXRoaW4gdGhlIGNhbGxiYWNrIHdpbGwgYXV0b21hdGljYWxseVxuICogYmUgYXR0YWNoZWQgdG8gdGhlIGluY29taW5nIHRyYWNlLlxuICovXG5jb25zdCBjb250aW51ZVRyYWNlID0gKFxuICBvcHRpb25zXG5cbixcbiAgY2FsbGJhY2ssXG4pID0+IHtcbiAgY29uc3QgY2FycmllciQxID0gY2Fycmllci5nZXRNYWluQ2FycmllcigpO1xuICBjb25zdCBhY3MgPSBpbmRleC5nZXRBc3luY0NvbnRleHRTdHJhdGVneShjYXJyaWVyJDEpO1xuICBpZiAoYWNzLmNvbnRpbnVlVHJhY2UpIHtcbiAgICByZXR1cm4gYWNzLmNvbnRpbnVlVHJhY2Uob3B0aW9ucywgY2FsbGJhY2spO1xuICB9XG5cbiAgY29uc3QgeyBzZW50cnlUcmFjZSwgYmFnZ2FnZSB9ID0gb3B0aW9ucztcblxuICByZXR1cm4gY3VycmVudFNjb3Blcy53aXRoU2NvcGUoc2NvcGUgPT4ge1xuICAgIGNvbnN0IHByb3BhZ2F0aW9uQ29udGV4dCA9IHRyYWNpbmcucHJvcGFnYXRpb25Db250ZXh0RnJvbUhlYWRlcnMoc2VudHJ5VHJhY2UsIGJhZ2dhZ2UpO1xuICAgIHNjb3BlLnNldFByb3BhZ2F0aW9uQ29udGV4dChwcm9wYWdhdGlvbkNvbnRleHQpO1xuICAgIHJldHVybiBjYWxsYmFjaygpO1xuICB9KTtcbn07XG5cbi8qKlxuICogRm9ya3MgdGhlIGN1cnJlbnQgc2NvcGUgYW5kIHNldHMgdGhlIHByb3ZpZGVkIHNwYW4gYXMgYWN0aXZlIHNwYW4gaW4gdGhlIGNvbnRleHQgb2YgdGhlIHByb3ZpZGVkIGNhbGxiYWNrLiBDYW4gYmVcbiAqIHBhc3NlZCBgbnVsbGAgdG8gc3RhcnQgYW4gZW50aXJlbHkgbmV3IHNwYW4gdHJlZS5cbiAqXG4gKiBAcGFyYW0gc3BhbiBTcGFucyBzdGFydGVkIGluIHRoZSBjb250ZXh0IG9mIHRoZSBwcm92aWRlZCBjYWxsYmFjayB3aWxsIGJlIGNoaWxkcmVuIG9mIHRoaXMgc3Bhbi4gSWYgYG51bGxgIGlzIHBhc3NlZCxcbiAqIHNwYW5zIHN0YXJ0ZWQgd2l0aGluIHRoZSBjYWxsYmFjayB3aWxsIG5vdCBiZSBhdHRhY2hlZCB0byBhIHBhcmVudCBzcGFuLlxuICogQHBhcmFtIGNhbGxiYWNrIEV4ZWN1dGlvbiBjb250ZXh0IGluIHdoaWNoIHRoZSBwcm92aWRlZCBzcGFuIHdpbGwgYmUgYWN0aXZlLiBJcyBwYXNzZWQgdGhlIG5ld2x5IGZvcmtlZCBzY29wZS5cbiAqIEByZXR1cm5zIHRoZSB2YWx1ZSByZXR1cm5lZCBmcm9tIHRoZSBwcm92aWRlZCBjYWxsYmFjayBmdW5jdGlvbi5cbiAqL1xuZnVuY3Rpb24gd2l0aEFjdGl2ZVNwYW4oc3BhbiwgY2FsbGJhY2spIHtcbiAgY29uc3QgYWNzID0gZ2V0QWNzKCk7XG4gIGlmIChhY3Mud2l0aEFjdGl2ZVNwYW4pIHtcbiAgICByZXR1cm4gYWNzLndpdGhBY3RpdmVTcGFuKHNwYW4sIGNhbGxiYWNrKTtcbiAgfVxuXG4gIHJldHVybiBjdXJyZW50U2NvcGVzLndpdGhTY29wZShzY29wZSA9PiB7XG4gICAgc3Bhbk9uU2NvcGUuX3NldFNwYW5Gb3JTY29wZShzY29wZSwgc3BhbiB8fCB1bmRlZmluZWQpO1xuICAgIHJldHVybiBjYWxsYmFjayhzY29wZSk7XG4gIH0pO1xufVxuXG4vKiogU3VwcHJlc3MgdHJhY2luZyBpbiB0aGUgZ2l2ZW4gY2FsbGJhY2ssIGVuc3VyaW5nIG5vIHNwYW5zIGFyZSBnZW5lcmF0ZWQgaW5zaWRlIG9mIGl0LiAqL1xuZnVuY3Rpb24gc3VwcHJlc3NUcmFjaW5nKGNhbGxiYWNrKSB7XG4gIGNvbnN0IGFjcyA9IGdldEFjcygpO1xuXG4gIGlmIChhY3Muc3VwcHJlc3NUcmFjaW5nKSB7XG4gICAgcmV0dXJuIGFjcy5zdXBwcmVzc1RyYWNpbmcoY2FsbGJhY2spO1xuICB9XG5cbiAgcmV0dXJuIGN1cnJlbnRTY29wZXMud2l0aFNjb3BlKHNjb3BlID0+IHtcbiAgICAvLyBOb3RlOiBXZSBkbyBub3Qgd2FpdCBmb3IgdGhlIGNhbGxiYWNrIHRvIGZpbmlzaCBiZWZvcmUgd2UgcmVzZXQgdGhlIG1ldGFkYXRhXG4gICAgLy8gdGhlIHJlYXNvbiBmb3IgdGhpcyBpcyB0aGF0IG90aGVyd2lzZSwgaW4gdGhlIGJyb3dzZXIgdGhpcyBjYW4gbGVhZCB0byB2ZXJ5IHdlaXJkIGJlaGF2aW9yXG4gICAgLy8gYXMgdGhlcmUgaXMgb25seSBhIHNpbmdsZSB0b3Agc2NvcGUsIGlmIHRoZSBjYWxsYmFjayB0YWtlcyBsb25nZXIgdG8gZmluaXNoLFxuICAgIC8vIG90aGVyLCB1bnJlbGF0ZWQgc3BhbnMgbWF5IGFsc28gYmUgc3VwcHJlc3NlZCwgd2hpY2ggd2UgZG8gbm90IHdhbnRcbiAgICAvLyBzbyBpbnN0ZWFkLCB3ZSBvbmx5IHN1cHByZXNzIHRyYWNpbmcgc3luY2hyb25veXNseSBpbiB0aGUgYnJvd3NlclxuICAgIHNjb3BlLnNldFNES1Byb2Nlc3NpbmdNZXRhZGF0YSh7IFtTVVBQUkVTU19UUkFDSU5HX0tFWV06IHRydWUgfSk7XG4gICAgY29uc3QgcmVzID0gY2FsbGJhY2soKTtcbiAgICBzY29wZS5zZXRTREtQcm9jZXNzaW5nTWV0YWRhdGEoeyBbU1VQUFJFU1NfVFJBQ0lOR19LRVldOiB1bmRlZmluZWQgfSk7XG4gICAgcmV0dXJuIHJlcztcbiAgfSk7XG59XG5cbi8qKlxuICogU3RhcnRzIGEgbmV3IHRyYWNlIGZvciB0aGUgZHVyYXRpb24gb2YgdGhlIHByb3ZpZGVkIGNhbGxiYWNrLiBTcGFucyBzdGFydGVkIHdpdGhpbiB0aGVcbiAqIGNhbGxiYWNrIHdpbGwgYmUgcGFydCBvZiB0aGUgbmV3IHRyYWNlIGluc3RlYWQgb2YgYSBwb3RlbnRpYWxseSBwcmV2aW91c2x5IHN0YXJ0ZWQgdHJhY2UuXG4gKlxuICogSW1wb3J0YW50OiBPbmx5IHVzZSB0aGlzIGZ1bmN0aW9uIGlmIHlvdSB3YW50IHRvIG92ZXJyaWRlIHRoZSBkZWZhdWx0IHRyYWNlIGxpZmV0aW1lIGFuZFxuICogcHJvcGFnYXRpb24gbWVjaGFuaXNtIG9mIHRoZSBTREsgZm9yIHRoZSBkdXJhdGlvbiBhbmQgc2NvcGUgb2YgdGhlIHByb3ZpZGVkIGNhbGxiYWNrLlxuICogVGhlIG5ld2x5IGNyZWF0ZWQgdHJhY2Ugd2lsbCBhbHNvIGJlIHRoZSByb290IG9mIGEgbmV3IGRpc3RyaWJ1dGVkIHRyYWNlLCBmb3IgZXhhbXBsZSBpZlxuICogeW91IG1ha2UgaHR0cCByZXF1ZXN0cyB3aXRoaW4gdGhlIGNhbGxiYWNrLlxuICogVGhpcyBmdW5jdGlvbiBtaWdodCBiZSB1c2VmdWwgaWYgdGhlIG9wZXJhdGlvbiB5b3Ugd2FudCB0byBpbnN0cnVtZW50IHNob3VsZCBub3QgYmUgcGFydFxuICogb2YgYSBwb3RlbnRpYWxseSBvbmdvaW5nIHRyYWNlLlxuICpcbiAqIERlZmF1bHQgYmVoYXZpb3I6XG4gKiAtIFNlcnZlci1zaWRlOiBBIG5ldyB0cmFjZSBpcyBzdGFydGVkIGZvciBlYWNoIGluY29taW5nIHJlcXVlc3QuXG4gKiAtIEJyb3dzZXI6IEEgbmV3IHRyYWNlIGlzIHN0YXJ0ZWQgZm9yIGVhY2ggcGFnZSBvdXIgcm91dGUuIE5hdmlnYXRpbmcgdG8gYSBuZXcgcm91dGVcbiAqICAgICAgICAgICAgb3IgcGFnZSB3aWxsIGF1dG9tYXRpY2FsbHkgY3JlYXRlIGEgbmV3IHRyYWNlLlxuICovXG5mdW5jdGlvbiBzdGFydE5ld1RyYWNlKGNhbGxiYWNrKSB7XG4gIHJldHVybiBjdXJyZW50U2NvcGVzLndpdGhTY29wZShzY29wZSA9PiB7XG4gICAgc2NvcGUuc2V0UHJvcGFnYXRpb25Db250ZXh0KHtcbiAgICAgIHRyYWNlSWQ6IHByb3BhZ2F0aW9uQ29udGV4dC5nZW5lcmF0ZVRyYWNlSWQoKSxcbiAgICAgIHNhbXBsZVJhbmQ6IE1hdGgucmFuZG9tKCksXG4gICAgfSk7XG4gICAgZGVidWdCdWlsZC5ERUJVR19CVUlMRCAmJiBkZWJ1Z0xvZ2dlci5kZWJ1Zy5sb2coYFN0YXJ0aW5nIGEgbmV3IHRyYWNlIHdpdGggaWQgJHtzY29wZS5nZXRQcm9wYWdhdGlvbkNvbnRleHQoKS50cmFjZUlkfWApO1xuICAgIHJldHVybiB3aXRoQWN0aXZlU3BhbihudWxsLCBjYWxsYmFjayk7XG4gIH0pO1xufVxuXG5mdW5jdGlvbiBjcmVhdGVDaGlsZE9yUm9vdFNwYW4oe1xuICBwYXJlbnRTcGFuLFxuICBzcGFuQXJndW1lbnRzLFxuICBmb3JjZVRyYW5zYWN0aW9uLFxuICBzY29wZSxcbn1cblxuKSB7XG4gIGlmICghaGFzU3BhbnNFbmFibGVkLmhhc1NwYW5zRW5hYmxlZCgpKSB7XG4gICAgY29uc3Qgc3BhbiA9IG5ldyBzZW50cnlOb25SZWNvcmRpbmdTcGFuLlNlbnRyeU5vblJlY29yZGluZ1NwYW4oKTtcblxuICAgIC8vIElmIHRoaXMgaXMgYSByb290IHNwYW4sIHdlIGVuc3VyZSB0byBmcmVlemUgYSBEU0NcbiAgICAvLyBTbyB3ZSBjYW4gaGF2ZSBhdCBsZWFzdCBwYXJ0aWFsIGRhdGEgaGVyZVxuICAgIGlmIChmb3JjZVRyYW5zYWN0aW9uIHx8ICFwYXJlbnRTcGFuKSB7XG4gICAgICBjb25zdCBkc2MgPSB7XG4gICAgICAgIHNhbXBsZWQ6ICdmYWxzZScsXG4gICAgICAgIHNhbXBsZV9yYXRlOiAnMCcsXG4gICAgICAgIHRyYW5zYWN0aW9uOiBzcGFuQXJndW1lbnRzLm5hbWUsXG4gICAgICAgIC4uLmR5bmFtaWNTYW1wbGluZ0NvbnRleHQuZ2V0RHluYW1pY1NhbXBsaW5nQ29udGV4dEZyb21TcGFuKHNwYW4pLFxuICAgICAgfSA7XG4gICAgICBkeW5hbWljU2FtcGxpbmdDb250ZXh0LmZyZWV6ZURzY09uU3BhbihzcGFuLCBkc2MpO1xuICAgIH1cblxuICAgIHJldHVybiBzcGFuO1xuICB9XG5cbiAgY29uc3QgaXNvbGF0aW9uU2NvcGUgPSBjdXJyZW50U2NvcGVzLmdldElzb2xhdGlvblNjb3BlKCk7XG5cbiAgbGV0IHNwYW47XG4gIGlmIChwYXJlbnRTcGFuICYmICFmb3JjZVRyYW5zYWN0aW9uKSB7XG4gICAgc3BhbiA9IF9zdGFydENoaWxkU3BhbihwYXJlbnRTcGFuLCBzY29wZSwgc3BhbkFyZ3VtZW50cyk7XG4gICAgc3BhblV0aWxzLmFkZENoaWxkU3BhblRvU3BhbihwYXJlbnRTcGFuLCBzcGFuKTtcbiAgfSBlbHNlIGlmIChwYXJlbnRTcGFuKSB7XG4gICAgLy8gSWYgd2UgZm9yY2VkIGEgdHJhbnNhY3Rpb24gYnV0IGhhdmUgYSBwYXJlbnQgc3BhbiwgbWFrZSBzdXJlIHRvIGNvbnRpbnVlIGZyb20gdGhlIHBhcmVudCBzcGFuLCBub3QgdGhlIHNjb3BlXG4gICAgY29uc3QgZHNjID0gZHluYW1pY1NhbXBsaW5nQ29udGV4dC5nZXREeW5hbWljU2FtcGxpbmdDb250ZXh0RnJvbVNwYW4ocGFyZW50U3Bhbik7XG4gICAgY29uc3QgeyB0cmFjZUlkLCBzcGFuSWQ6IHBhcmVudFNwYW5JZCB9ID0gcGFyZW50U3Bhbi5zcGFuQ29udGV4dCgpO1xuICAgIGNvbnN0IHBhcmVudFNhbXBsZWQgPSBzcGFuVXRpbHMuc3BhbklzU2FtcGxlZChwYXJlbnRTcGFuKTtcblxuICAgIHNwYW4gPSBfc3RhcnRSb290U3BhbihcbiAgICAgIHtcbiAgICAgICAgdHJhY2VJZCxcbiAgICAgICAgcGFyZW50U3BhbklkLFxuICAgICAgICAuLi5zcGFuQXJndW1lbnRzLFxuICAgICAgfSxcbiAgICAgIHNjb3BlLFxuICAgICAgcGFyZW50U2FtcGxlZCxcbiAgICApO1xuXG4gICAgZHluYW1pY1NhbXBsaW5nQ29udGV4dC5mcmVlemVEc2NPblNwYW4oc3BhbiwgZHNjKTtcbiAgfSBlbHNlIHtcbiAgICBjb25zdCB7XG4gICAgICB0cmFjZUlkLFxuICAgICAgZHNjLFxuICAgICAgcGFyZW50U3BhbklkLFxuICAgICAgc2FtcGxlZDogcGFyZW50U2FtcGxlZCxcbiAgICB9ID0ge1xuICAgICAgLi4uaXNvbGF0aW9uU2NvcGUuZ2V0UHJvcGFnYXRpb25Db250ZXh0KCksXG4gICAgICAuLi5zY29wZS5nZXRQcm9wYWdhdGlvbkNvbnRleHQoKSxcbiAgICB9O1xuXG4gICAgc3BhbiA9IF9zdGFydFJvb3RTcGFuKFxuICAgICAge1xuICAgICAgICB0cmFjZUlkLFxuICAgICAgICBwYXJlbnRTcGFuSWQsXG4gICAgICAgIC4uLnNwYW5Bcmd1bWVudHMsXG4gICAgICB9LFxuICAgICAgc2NvcGUsXG4gICAgICBwYXJlbnRTYW1wbGVkLFxuICAgICk7XG5cbiAgICBpZiAoZHNjKSB7XG4gICAgICBkeW5hbWljU2FtcGxpbmdDb250ZXh0LmZyZWV6ZURzY09uU3BhbihzcGFuLCBkc2MpO1xuICAgIH1cbiAgfVxuXG4gIGxvZ1NwYW5zLmxvZ1NwYW5TdGFydChzcGFuKTtcblxuICB1dGlscy5zZXRDYXB0dXJlZFNjb3Blc09uU3BhbihzcGFuLCBzY29wZSwgaXNvbGF0aW9uU2NvcGUpO1xuXG4gIHJldHVybiBzcGFuO1xufVxuXG4vKipcbiAqIFRoaXMgY29udmVydHMgU3RhcnRTcGFuT3B0aW9ucyB0byBTZW50cnlTcGFuQXJndW1lbnRzLlxuICogRm9yIHRoZSBtb3N0IHBhcnQgKGZvciBub3cpIHdlIGFjY2VwdCB0aGUgc2FtZSBvcHRpb25zLFxuICogYnV0IHNvbWUgb2YgdGhlbSBuZWVkIHRvIGJlIHRyYW5zZm9ybWVkLlxuICovXG5mdW5jdGlvbiBwYXJzZVNlbnRyeVNwYW5Bcmd1bWVudHMob3B0aW9ucykge1xuICBjb25zdCBleHAgPSBvcHRpb25zLmV4cGVyaW1lbnRhbCB8fCB7fTtcbiAgY29uc3QgaW5pdGlhbEN0eCA9IHtcbiAgICBpc1N0YW5kYWxvbmU6IGV4cC5zdGFuZGFsb25lLFxuICAgIC4uLm9wdGlvbnMsXG4gIH07XG5cbiAgaWYgKG9wdGlvbnMuc3RhcnRUaW1lKSB7XG4gICAgY29uc3QgY3R4ID0geyAuLi5pbml0aWFsQ3R4IH07XG4gICAgY3R4LnN0YXJ0VGltZXN0YW1wID0gc3BhblV0aWxzLnNwYW5UaW1lSW5wdXRUb1NlY29uZHMob3B0aW9ucy5zdGFydFRpbWUpO1xuICAgIGRlbGV0ZSBjdHguc3RhcnRUaW1lO1xuICAgIHJldHVybiBjdHg7XG4gIH1cblxuICByZXR1cm4gaW5pdGlhbEN0eDtcbn1cblxuZnVuY3Rpb24gZ2V0QWNzKCkge1xuICBjb25zdCBjYXJyaWVyJDEgPSBjYXJyaWVyLmdldE1haW5DYXJyaWVyKCk7XG4gIHJldHVybiBpbmRleC5nZXRBc3luY0NvbnRleHRTdHJhdGVneShjYXJyaWVyJDEpO1xufVxuXG5mdW5jdGlvbiBfc3RhcnRSb290U3BhbihzcGFuQXJndW1lbnRzLCBzY29wZSwgcGFyZW50U2FtcGxlZCkge1xuICBjb25zdCBjbGllbnQgPSBjdXJyZW50U2NvcGVzLmdldENsaWVudCgpO1xuICBjb25zdCBvcHRpb25zID0gY2xpZW50Py5nZXRPcHRpb25zKCkgfHwge307XG5cbiAgY29uc3QgeyBuYW1lID0gJycgfSA9IHNwYW5Bcmd1bWVudHM7XG5cbiAgY29uc3QgbXV0YWJsZVNwYW5TYW1wbGluZ0RhdGEgPSB7IHNwYW5BdHRyaWJ1dGVzOiB7IC4uLnNwYW5Bcmd1bWVudHMuYXR0cmlidXRlcyB9LCBzcGFuTmFtZTogbmFtZSwgcGFyZW50U2FtcGxlZCB9O1xuXG4gIC8vIHdlIGRvbid0IGNhcmUgYWJvdXQgdGhlIGRlY2lzaW9uIGZvciB0aGUgbW9tZW50OyB0aGlzIGlzIGp1c3QgYSBwbGFjZWhvbGRlclxuICBjbGllbnQ/LmVtaXQoJ2JlZm9yZVNhbXBsaW5nJywgbXV0YWJsZVNwYW5TYW1wbGluZ0RhdGEsIHsgZGVjaXNpb246IGZhbHNlIH0pO1xuXG4gIC8vIElmIGhvb2sgY29uc3VtZXJzIG92ZXJyaWRlIHRoZSBwYXJlbnRTYW1wbGVkIGZsYWcsIHdlIHdpbGwgdXNlIHRoYXQgdmFsdWUgaW5zdGVhZCBvZiB0aGUgYWN0dWFsIG9uZVxuICBjb25zdCBmaW5hbFBhcmVudFNhbXBsZWQgPSBtdXRhYmxlU3BhblNhbXBsaW5nRGF0YS5wYXJlbnRTYW1wbGVkID8/IHBhcmVudFNhbXBsZWQ7XG4gIGNvbnN0IGZpbmFsQXR0cmlidXRlcyA9IG11dGFibGVTcGFuU2FtcGxpbmdEYXRhLnNwYW5BdHRyaWJ1dGVzO1xuXG4gIGNvbnN0IGN1cnJlbnRQcm9wYWdhdGlvbkNvbnRleHQgPSBzY29wZS5nZXRQcm9wYWdhdGlvbkNvbnRleHQoKTtcbiAgY29uc3QgW3NhbXBsZWQsIHNhbXBsZVJhdGUsIGxvY2FsU2FtcGxlUmF0ZVdhc0FwcGxpZWRdID0gc2NvcGUuZ2V0U2NvcGVEYXRhKCkuc2RrUHJvY2Vzc2luZ01ldGFkYXRhW1xuICAgIFNVUFBSRVNTX1RSQUNJTkdfS0VZXG4gIF1cbiAgICA/IFtmYWxzZV1cbiAgICA6IHNhbXBsaW5nLnNhbXBsZVNwYW4oXG4gICAgICAgIG9wdGlvbnMsXG4gICAgICAgIHtcbiAgICAgICAgICBuYW1lLFxuICAgICAgICAgIHBhcmVudFNhbXBsZWQ6IGZpbmFsUGFyZW50U2FtcGxlZCxcbiAgICAgICAgICBhdHRyaWJ1dGVzOiBmaW5hbEF0dHJpYnV0ZXMsXG4gICAgICAgICAgcGFyZW50U2FtcGxlUmF0ZTogcGFyc2VTYW1wbGVSYXRlLnBhcnNlU2FtcGxlUmF0ZShjdXJyZW50UHJvcGFnYXRpb25Db250ZXh0LmRzYz8uc2FtcGxlX3JhdGUpLFxuICAgICAgICB9LFxuICAgICAgICBjdXJyZW50UHJvcGFnYXRpb25Db250ZXh0LnNhbXBsZVJhbmQsXG4gICAgICApO1xuXG4gIGNvbnN0IHJvb3RTcGFuID0gbmV3IHNlbnRyeVNwYW4uU2VudHJ5U3Bhbih7XG4gICAgLi4uc3BhbkFyZ3VtZW50cyxcbiAgICBhdHRyaWJ1dGVzOiB7XG4gICAgICBbc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfU09VUkNFXTogJ2N1c3RvbScsXG4gICAgICBbc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfU0FNUExFX1JBVEVdOlxuICAgICAgICBzYW1wbGVSYXRlICE9PSB1bmRlZmluZWQgJiYgbG9jYWxTYW1wbGVSYXRlV2FzQXBwbGllZCA/IHNhbXBsZVJhdGUgOiB1bmRlZmluZWQsXG4gICAgICAuLi5maW5hbEF0dHJpYnV0ZXMsXG4gICAgfSxcbiAgICBzYW1wbGVkLFxuICB9KTtcblxuICBpZiAoIXNhbXBsZWQgJiYgY2xpZW50KSB7XG4gICAgZGVidWdCdWlsZC5ERUJVR19CVUlMRCAmJiBkZWJ1Z0xvZ2dlci5kZWJ1Zy5sb2coJ1tUcmFjaW5nXSBEaXNjYXJkaW5nIHJvb3Qgc3BhbiBiZWNhdXNlIGl0cyB0cmFjZSB3YXMgbm90IGNob3NlbiB0byBiZSBzYW1wbGVkLicpO1xuICAgIGNsaWVudC5yZWNvcmREcm9wcGVkRXZlbnQoJ3NhbXBsZV9yYXRlJywgJ3RyYW5zYWN0aW9uJyk7XG4gIH1cblxuICBpZiAoY2xpZW50KSB7XG4gICAgY2xpZW50LmVtaXQoJ3NwYW5TdGFydCcsIHJvb3RTcGFuKTtcbiAgfVxuXG4gIHJldHVybiByb290U3Bhbjtcbn1cblxuLyoqXG4gKiBDcmVhdGVzIGEgbmV3IGBTcGFuYCB3aGlsZSBzZXR0aW5nIHRoZSBjdXJyZW50IGBTcGFuLmlkYCBhcyBgcGFyZW50U3BhbklkYC5cbiAqIFRoaXMgaW5oZXJpdHMgdGhlIHNhbXBsaW5nIGRlY2lzaW9uIGZyb20gdGhlIHBhcmVudCBzcGFuLlxuICovXG5mdW5jdGlvbiBfc3RhcnRDaGlsZFNwYW4ocGFyZW50U3Bhbiwgc2NvcGUsIHNwYW5Bcmd1bWVudHMpIHtcbiAgY29uc3QgeyBzcGFuSWQsIHRyYWNlSWQgfSA9IHBhcmVudFNwYW4uc3BhbkNvbnRleHQoKTtcbiAgY29uc3Qgc2FtcGxlZCA9IHNjb3BlLmdldFNjb3BlRGF0YSgpLnNka1Byb2Nlc3NpbmdNZXRhZGF0YVtTVVBQUkVTU19UUkFDSU5HX0tFWV0gPyBmYWxzZSA6IHNwYW5VdGlscy5zcGFuSXNTYW1wbGVkKHBhcmVudFNwYW4pO1xuXG4gIGNvbnN0IGNoaWxkU3BhbiA9IHNhbXBsZWRcbiAgICA/IG5ldyBzZW50cnlTcGFuLlNlbnRyeVNwYW4oe1xuICAgICAgICAuLi5zcGFuQXJndW1lbnRzLFxuICAgICAgICBwYXJlbnRTcGFuSWQ6IHNwYW5JZCxcbiAgICAgICAgdHJhY2VJZCxcbiAgICAgICAgc2FtcGxlZCxcbiAgICAgIH0pXG4gICAgOiBuZXcgc2VudHJ5Tm9uUmVjb3JkaW5nU3Bhbi5TZW50cnlOb25SZWNvcmRpbmdTcGFuKHsgdHJhY2VJZCB9KTtcblxuICBzcGFuVXRpbHMuYWRkQ2hpbGRTcGFuVG9TcGFuKHBhcmVudFNwYW4sIGNoaWxkU3Bhbik7XG5cbiAgY29uc3QgY2xpZW50ID0gY3VycmVudFNjb3Blcy5nZXRDbGllbnQoKTtcbiAgaWYgKGNsaWVudCkge1xuICAgIGNsaWVudC5lbWl0KCdzcGFuU3RhcnQnLCBjaGlsZFNwYW4pO1xuICAgIC8vIElmIGl0IGhhcyBhbiBlbmRUaW1lc3RhbXAsIGl0J3MgYWxyZWFkeSBlbmRlZFxuICAgIGlmIChzcGFuQXJndW1lbnRzLmVuZFRpbWVzdGFtcCkge1xuICAgICAgY2xpZW50LmVtaXQoJ3NwYW5FbmQnLCBjaGlsZFNwYW4pO1xuICAgIH1cbiAgfVxuXG4gIHJldHVybiBjaGlsZFNwYW47XG59XG5cbmZ1bmN0aW9uIGdldFBhcmVudFNwYW4oc2NvcGUsIGN1c3RvbVBhcmVudFNwYW4pIHtcbiAgLy8gYWx3YXlzIHVzZSB0aGUgcGFzc2VkIGluIHNwYW4gZGlyZWN0bHlcbiAgaWYgKGN1c3RvbVBhcmVudFNwYW4pIHtcbiAgICByZXR1cm4gY3VzdG9tUGFyZW50U3BhbiA7XG4gIH1cblxuICAvLyBUaGlzIGlzIGRpZmZlcmVudCBmcm9tIGB1bmRlZmluZWRgIGFzIGl0IG1lYW5zIHRoZSB1c2VyIGV4cGxpY2l0bHkgd2FudHMgbm8gcGFyZW50IHNwYW5cbiAgaWYgKGN1c3RvbVBhcmVudFNwYW4gPT09IG51bGwpIHtcbiAgICByZXR1cm4gdW5kZWZpbmVkO1xuICB9XG5cbiAgY29uc3Qgc3BhbiA9IHNwYW5PblNjb3BlLl9nZXRTcGFuRm9yU2NvcGUoc2NvcGUpIDtcblxuICBpZiAoIXNwYW4pIHtcbiAgICByZXR1cm4gdW5kZWZpbmVkO1xuICB9XG5cbiAgY29uc3QgY2xpZW50ID0gY3VycmVudFNjb3Blcy5nZXRDbGllbnQoKTtcbiAgY29uc3Qgb3B0aW9ucyA9IGNsaWVudCA/IGNsaWVudC5nZXRPcHRpb25zKCkgOiB7fTtcbiAgaWYgKG9wdGlvbnMucGFyZW50U3BhbklzQWx3YXlzUm9vdFNwYW4pIHtcbiAgICByZXR1cm4gc3BhblV0aWxzLmdldFJvb3RTcGFuKHNwYW4pIDtcbiAgfVxuXG4gIHJldHVybiBzcGFuO1xufVxuXG5mdW5jdGlvbiBnZXRBY3RpdmVTcGFuV3JhcHBlcihwYXJlbnRTcGFuKSB7XG4gIHJldHVybiBwYXJlbnRTcGFuICE9PSB1bmRlZmluZWRcbiAgICA/IChjYWxsYmFjaykgPT4ge1xuICAgICAgICByZXR1cm4gd2l0aEFjdGl2ZVNwYW4ocGFyZW50U3BhbiwgY2FsbGJhY2spO1xuICAgICAgfVxuICAgIDogKGNhbGxiYWNrKSA9PiBjYWxsYmFjaygpO1xufVxuXG5leHBvcnRzLmNvbnRpbnVlVHJhY2UgPSBjb250aW51ZVRyYWNlO1xuZXhwb3J0cy5zdGFydEluYWN0aXZlU3BhbiA9IHN0YXJ0SW5hY3RpdmVTcGFuO1xuZXhwb3J0cy5zdGFydE5ld1RyYWNlID0gc3RhcnROZXdUcmFjZTtcbmV4cG9ydHMuc3RhcnRTcGFuID0gc3RhcnRTcGFuO1xuZXhwb3J0cy5zdGFydFNwYW5NYW51YWwgPSBzdGFydFNwYW5NYW51YWw7XG5leHBvcnRzLnN1cHByZXNzVHJhY2luZyA9IHN1cHByZXNzVHJhY2luZztcbmV4cG9ydHMud2l0aEFjdGl2ZVNwYW4gPSB3aXRoQWN0aXZlU3Bhbjtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPXRyYWNlLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/trace.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/utils.js":
/*!*****************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/utils.js ***!
  \*****************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst object = __webpack_require__(/*! ../utils/object.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/object.js\");\n\nconst SCOPE_ON_START_SPAN_FIELD = '_sentryScope';\nconst ISOLATION_SCOPE_ON_START_SPAN_FIELD = '_sentryIsolationScope';\n\n/** Store the scope & isolation scope for a span, which can the be used when it is finished. */\nfunction setCapturedScopesOnSpan(span, scope, isolationScope) {\n  if (span) {\n    object.addNonEnumerableProperty(span, ISOLATION_SCOPE_ON_START_SPAN_FIELD, isolationScope);\n    object.addNonEnumerableProperty(span, SCOPE_ON_START_SPAN_FIELD, scope);\n  }\n}\n\n/**\n * Grabs the scope and isolation scope off a span that were active when the span was started.\n */\nfunction getCapturedScopesOnSpan(span) {\n  return {\n    scope: (span )[SCOPE_ON_START_SPAN_FIELD],\n    isolationScope: (span )[ISOLATION_SCOPE_ON_START_SPAN_FIELD],\n  };\n}\n\nexports.getCapturedScopesOnSpan = getCapturedScopesOnSpan;\nexports.setCapturedScopesOnSpan = setCapturedScopesOnSpan;\n//# sourceMappingURL=utils.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdHJhY2luZy91dGlscy5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxlQUFlLG1CQUFPLENBQUMscUlBQW9COztBQUUzQztBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSwrQkFBK0I7QUFDL0IsK0JBQStCO0FBQy9CIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdHJhY2luZy91dGlscy5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3Qgb2JqZWN0ID0gcmVxdWlyZSgnLi4vdXRpbHMvb2JqZWN0LmpzJyk7XG5cbmNvbnN0IFNDT1BFX09OX1NUQVJUX1NQQU5fRklFTEQgPSAnX3NlbnRyeVNjb3BlJztcbmNvbnN0IElTT0xBVElPTl9TQ09QRV9PTl9TVEFSVF9TUEFOX0ZJRUxEID0gJ19zZW50cnlJc29sYXRpb25TY29wZSc7XG5cbi8qKiBTdG9yZSB0aGUgc2NvcGUgJiBpc29sYXRpb24gc2NvcGUgZm9yIGEgc3Bhbiwgd2hpY2ggY2FuIHRoZSBiZSB1c2VkIHdoZW4gaXQgaXMgZmluaXNoZWQuICovXG5mdW5jdGlvbiBzZXRDYXB0dXJlZFNjb3Blc09uU3BhbihzcGFuLCBzY29wZSwgaXNvbGF0aW9uU2NvcGUpIHtcbiAgaWYgKHNwYW4pIHtcbiAgICBvYmplY3QuYWRkTm9uRW51bWVyYWJsZVByb3BlcnR5KHNwYW4sIElTT0xBVElPTl9TQ09QRV9PTl9TVEFSVF9TUEFOX0ZJRUxELCBpc29sYXRpb25TY29wZSk7XG4gICAgb2JqZWN0LmFkZE5vbkVudW1lcmFibGVQcm9wZXJ0eShzcGFuLCBTQ09QRV9PTl9TVEFSVF9TUEFOX0ZJRUxELCBzY29wZSk7XG4gIH1cbn1cblxuLyoqXG4gKiBHcmFicyB0aGUgc2NvcGUgYW5kIGlzb2xhdGlvbiBzY29wZSBvZmYgYSBzcGFuIHRoYXQgd2VyZSBhY3RpdmUgd2hlbiB0aGUgc3BhbiB3YXMgc3RhcnRlZC5cbiAqL1xuZnVuY3Rpb24gZ2V0Q2FwdHVyZWRTY29wZXNPblNwYW4oc3Bhbikge1xuICByZXR1cm4ge1xuICAgIHNjb3BlOiAoc3BhbiApW1NDT1BFX09OX1NUQVJUX1NQQU5fRklFTERdLFxuICAgIGlzb2xhdGlvblNjb3BlOiAoc3BhbiApW0lTT0xBVElPTl9TQ09QRV9PTl9TVEFSVF9TUEFOX0ZJRUxEXSxcbiAgfTtcbn1cblxuZXhwb3J0cy5nZXRDYXB0dXJlZFNjb3Blc09uU3BhbiA9IGdldENhcHR1cmVkU2NvcGVzT25TcGFuO1xuZXhwb3J0cy5zZXRDYXB0dXJlZFNjb3Blc09uU3BhbiA9IHNldENhcHR1cmVkU2NvcGVzT25TcGFuO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9dXRpbHMuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/utils.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/transports/base.js":
/*!*******************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/transports/base.js ***!
  \*******************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst debugBuild = __webpack_require__(/*! ../debug-build.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst debugLogger = __webpack_require__(/*! ../utils/debug-logger.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst envelope = __webpack_require__(/*! ../utils/envelope.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/envelope.js\");\nconst promisebuffer = __webpack_require__(/*! ../utils/promisebuffer.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/promisebuffer.js\");\nconst ratelimit = __webpack_require__(/*! ../utils/ratelimit.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/ratelimit.js\");\nconst syncpromise = __webpack_require__(/*! ../utils/syncpromise.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/syncpromise.js\");\n\nconst DEFAULT_TRANSPORT_BUFFER_SIZE = 64;\n\n/**\n * Creates an instance of a Sentry `Transport`\n *\n * @param options\n * @param makeRequest\n */\nfunction createTransport(\n  options,\n  makeRequest,\n  buffer = promisebuffer.makePromiseBuffer(\n    options.bufferSize || DEFAULT_TRANSPORT_BUFFER_SIZE,\n  ),\n) {\n  let rateLimits = {};\n  const flush = (timeout) => buffer.drain(timeout);\n\n  function send(envelope$1) {\n    const filteredEnvelopeItems = [];\n\n    // Drop rate limited items from envelope\n    envelope.forEachEnvelopeItem(envelope$1, (item, type) => {\n      const dataCategory = envelope.envelopeItemTypeToDataCategory(type);\n      if (ratelimit.isRateLimited(rateLimits, dataCategory)) {\n        options.recordDroppedEvent('ratelimit_backoff', dataCategory);\n      } else {\n        filteredEnvelopeItems.push(item);\n      }\n    });\n\n    // Skip sending if envelope is empty after filtering out rate limited events\n    if (filteredEnvelopeItems.length === 0) {\n      return syncpromise.resolvedSyncPromise({});\n    }\n\n    const filteredEnvelope = envelope.createEnvelope(envelope$1[0], filteredEnvelopeItems );\n\n    // Creates client report for each item in an envelope\n    const recordEnvelopeLoss = (reason) => {\n      envelope.forEachEnvelopeItem(filteredEnvelope, (item, type) => {\n        options.recordDroppedEvent(reason, envelope.envelopeItemTypeToDataCategory(type));\n      });\n    };\n\n    const requestTask = () =>\n      makeRequest({ body: envelope.serializeEnvelope(filteredEnvelope) }).then(\n        response => {\n          // We don't want to throw on NOK responses, but we want to at least log them\n          if (response.statusCode !== undefined && (response.statusCode < 200 || response.statusCode >= 300)) {\n            debugBuild.DEBUG_BUILD && debugLogger.debug.warn(`Sentry responded with status code ${response.statusCode} to sent event.`);\n          }\n\n          rateLimits = ratelimit.updateRateLimits(rateLimits, response);\n          return response;\n        },\n        error => {\n          recordEnvelopeLoss('network_error');\n          debugBuild.DEBUG_BUILD && debugLogger.debug.error('Encountered error running transport request:', error);\n          throw error;\n        },\n      );\n\n    return buffer.add(requestTask).then(\n      result => result,\n      error => {\n        if (error === promisebuffer.SENTRY_BUFFER_FULL_ERROR) {\n          debugBuild.DEBUG_BUILD && debugLogger.debug.error('Skipped sending event because buffer is full.');\n          recordEnvelopeLoss('queue_overflow');\n          return syncpromise.resolvedSyncPromise({});\n        } else {\n          throw error;\n        }\n      },\n    );\n  }\n\n  return {\n    send,\n    flush,\n  };\n}\n\nexports.DEFAULT_TRANSPORT_BUFFER_SIZE = DEFAULT_TRANSPORT_BUFFER_SIZE;\nexports.createTransport = createTransport;\n//# sourceMappingURL=base.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdHJhbnNwb3J0cy9iYXNlLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLG1CQUFtQixtQkFBTyxDQUFDLG1JQUFtQjtBQUM5QyxvQkFBb0IsbUJBQU8sQ0FBQyxpSkFBMEI7QUFDdEQsaUJBQWlCLG1CQUFPLENBQUMseUlBQXNCO0FBQy9DLHNCQUFzQixtQkFBTyxDQUFDLG1KQUEyQjtBQUN6RCxrQkFBa0IsbUJBQU8sQ0FBQywySUFBdUI7QUFDakQsb0JBQW9CLG1CQUFPLENBQUMsK0lBQXlCOztBQUVyRDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsUUFBUTtBQUNSO0FBQ0E7QUFDQSxLQUFLOztBQUVMO0FBQ0E7QUFDQSwrQ0FBK0M7QUFDL0M7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQSxPQUFPO0FBQ1A7O0FBRUE7QUFDQSxvQkFBb0Isb0RBQW9EO0FBQ3hFO0FBQ0E7QUFDQTtBQUNBLGtHQUFrRyxxQkFBcUI7QUFDdkg7O0FBRUE7QUFDQTtBQUNBLFNBQVM7QUFDVDtBQUNBO0FBQ0E7QUFDQTtBQUNBLFNBQVM7QUFDVDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxtREFBbUQ7QUFDbkQsVUFBVTtBQUNWO0FBQ0E7QUFDQSxPQUFPO0FBQ1A7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLHFDQUFxQztBQUNyQyx1QkFBdUI7QUFDdkIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy90cmFuc3BvcnRzL2Jhc2UuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGRlYnVnQnVpbGQgPSByZXF1aXJlKCcuLi9kZWJ1Zy1idWlsZC5qcycpO1xuY29uc3QgZGVidWdMb2dnZXIgPSByZXF1aXJlKCcuLi91dGlscy9kZWJ1Zy1sb2dnZXIuanMnKTtcbmNvbnN0IGVudmVsb3BlID0gcmVxdWlyZSgnLi4vdXRpbHMvZW52ZWxvcGUuanMnKTtcbmNvbnN0IHByb21pc2VidWZmZXIgPSByZXF1aXJlKCcuLi91dGlscy9wcm9taXNlYnVmZmVyLmpzJyk7XG5jb25zdCByYXRlbGltaXQgPSByZXF1aXJlKCcuLi91dGlscy9yYXRlbGltaXQuanMnKTtcbmNvbnN0IHN5bmNwcm9taXNlID0gcmVxdWlyZSgnLi4vdXRpbHMvc3luY3Byb21pc2UuanMnKTtcblxuY29uc3QgREVGQVVMVF9UUkFOU1BPUlRfQlVGRkVSX1NJWkUgPSA2NDtcblxuLyoqXG4gKiBDcmVhdGVzIGFuIGluc3RhbmNlIG9mIGEgU2VudHJ5IGBUcmFuc3BvcnRgXG4gKlxuICogQHBhcmFtIG9wdGlvbnNcbiAqIEBwYXJhbSBtYWtlUmVxdWVzdFxuICovXG5mdW5jdGlvbiBjcmVhdGVUcmFuc3BvcnQoXG4gIG9wdGlvbnMsXG4gIG1ha2VSZXF1ZXN0LFxuICBidWZmZXIgPSBwcm9taXNlYnVmZmVyLm1ha2VQcm9taXNlQnVmZmVyKFxuICAgIG9wdGlvbnMuYnVmZmVyU2l6ZSB8fCBERUZBVUxUX1RSQU5TUE9SVF9CVUZGRVJfU0laRSxcbiAgKSxcbikge1xuICBsZXQgcmF0ZUxpbWl0cyA9IHt9O1xuICBjb25zdCBmbHVzaCA9ICh0aW1lb3V0KSA9PiBidWZmZXIuZHJhaW4odGltZW91dCk7XG5cbiAgZnVuY3Rpb24gc2VuZChlbnZlbG9wZSQxKSB7XG4gICAgY29uc3QgZmlsdGVyZWRFbnZlbG9wZUl0ZW1zID0gW107XG5cbiAgICAvLyBEcm9wIHJhdGUgbGltaXRlZCBpdGVtcyBmcm9tIGVudmVsb3BlXG4gICAgZW52ZWxvcGUuZm9yRWFjaEVudmVsb3BlSXRlbShlbnZlbG9wZSQxLCAoaXRlbSwgdHlwZSkgPT4ge1xuICAgICAgY29uc3QgZGF0YUNhdGVnb3J5ID0gZW52ZWxvcGUuZW52ZWxvcGVJdGVtVHlwZVRvRGF0YUNhdGVnb3J5KHR5cGUpO1xuICAgICAgaWYgKHJhdGVsaW1pdC5pc1JhdGVMaW1pdGVkKHJhdGVMaW1pdHMsIGRhdGFDYXRlZ29yeSkpIHtcbiAgICAgICAgb3B0aW9ucy5yZWNvcmREcm9wcGVkRXZlbnQoJ3JhdGVsaW1pdF9iYWNrb2ZmJywgZGF0YUNhdGVnb3J5KTtcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIGZpbHRlcmVkRW52ZWxvcGVJdGVtcy5wdXNoKGl0ZW0pO1xuICAgICAgfVxuICAgIH0pO1xuXG4gICAgLy8gU2tpcCBzZW5kaW5nIGlmIGVudmVsb3BlIGlzIGVtcHR5IGFmdGVyIGZpbHRlcmluZyBvdXQgcmF0ZSBsaW1pdGVkIGV2ZW50c1xuICAgIGlmIChmaWx0ZXJlZEVudmVsb3BlSXRlbXMubGVuZ3RoID09PSAwKSB7XG4gICAgICByZXR1cm4gc3luY3Byb21pc2UucmVzb2x2ZWRTeW5jUHJvbWlzZSh7fSk7XG4gICAgfVxuXG4gICAgY29uc3QgZmlsdGVyZWRFbnZlbG9wZSA9IGVudmVsb3BlLmNyZWF0ZUVudmVsb3BlKGVudmVsb3BlJDFbMF0sIGZpbHRlcmVkRW52ZWxvcGVJdGVtcyApO1xuXG4gICAgLy8gQ3JlYXRlcyBjbGllbnQgcmVwb3J0IGZvciBlYWNoIGl0ZW0gaW4gYW4gZW52ZWxvcGVcbiAgICBjb25zdCByZWNvcmRFbnZlbG9wZUxvc3MgPSAocmVhc29uKSA9PiB7XG4gICAgICBlbnZlbG9wZS5mb3JFYWNoRW52ZWxvcGVJdGVtKGZpbHRlcmVkRW52ZWxvcGUsIChpdGVtLCB0eXBlKSA9PiB7XG4gICAgICAgIG9wdGlvbnMucmVjb3JkRHJvcHBlZEV2ZW50KHJlYXNvbiwgZW52ZWxvcGUuZW52ZWxvcGVJdGVtVHlwZVRvRGF0YUNhdGVnb3J5KHR5cGUpKTtcbiAgICAgIH0pO1xuICAgIH07XG5cbiAgICBjb25zdCByZXF1ZXN0VGFzayA9ICgpID0+XG4gICAgICBtYWtlUmVxdWVzdCh7IGJvZHk6IGVudmVsb3BlLnNlcmlhbGl6ZUVudmVsb3BlKGZpbHRlcmVkRW52ZWxvcGUpIH0pLnRoZW4oXG4gICAgICAgIHJlc3BvbnNlID0+IHtcbiAgICAgICAgICAvLyBXZSBkb24ndCB3YW50IHRvIHRocm93IG9uIE5PSyByZXNwb25zZXMsIGJ1dCB3ZSB3YW50IHRvIGF0IGxlYXN0IGxvZyB0aGVtXG4gICAgICAgICAgaWYgKHJlc3BvbnNlLnN0YXR1c0NvZGUgIT09IHVuZGVmaW5lZCAmJiAocmVzcG9uc2Uuc3RhdHVzQ29kZSA8IDIwMCB8fCByZXNwb25zZS5zdGF0dXNDb2RlID49IDMwMCkpIHtcbiAgICAgICAgICAgIGRlYnVnQnVpbGQuREVCVUdfQlVJTEQgJiYgZGVidWdMb2dnZXIuZGVidWcud2FybihgU2VudHJ5IHJlc3BvbmRlZCB3aXRoIHN0YXR1cyBjb2RlICR7cmVzcG9uc2Uuc3RhdHVzQ29kZX0gdG8gc2VudCBldmVudC5gKTtcbiAgICAgICAgICB9XG5cbiAgICAgICAgICByYXRlTGltaXRzID0gcmF0ZWxpbWl0LnVwZGF0ZVJhdGVMaW1pdHMocmF0ZUxpbWl0cywgcmVzcG9uc2UpO1xuICAgICAgICAgIHJldHVybiByZXNwb25zZTtcbiAgICAgICAgfSxcbiAgICAgICAgZXJyb3IgPT4ge1xuICAgICAgICAgIHJlY29yZEVudmVsb3BlTG9zcygnbmV0d29ya19lcnJvcicpO1xuICAgICAgICAgIGRlYnVnQnVpbGQuREVCVUdfQlVJTEQgJiYgZGVidWdMb2dnZXIuZGVidWcuZXJyb3IoJ0VuY291bnRlcmVkIGVycm9yIHJ1bm5pbmcgdHJhbnNwb3J0IHJlcXVlc3Q6JywgZXJyb3IpO1xuICAgICAgICAgIHRocm93IGVycm9yO1xuICAgICAgICB9LFxuICAgICAgKTtcblxuICAgIHJldHVybiBidWZmZXIuYWRkKHJlcXVlc3RUYXNrKS50aGVuKFxuICAgICAgcmVzdWx0ID0+IHJlc3VsdCxcbiAgICAgIGVycm9yID0+IHtcbiAgICAgICAgaWYgKGVycm9yID09PSBwcm9taXNlYnVmZmVyLlNFTlRSWV9CVUZGRVJfRlVMTF9FUlJPUikge1xuICAgICAgICAgIGRlYnVnQnVpbGQuREVCVUdfQlVJTEQgJiYgZGVidWdMb2dnZXIuZGVidWcuZXJyb3IoJ1NraXBwZWQgc2VuZGluZyBldmVudCBiZWNhdXNlIGJ1ZmZlciBpcyBmdWxsLicpO1xuICAgICAgICAgIHJlY29yZEVudmVsb3BlTG9zcygncXVldWVfb3ZlcmZsb3cnKTtcbiAgICAgICAgICByZXR1cm4gc3luY3Byb21pc2UucmVzb2x2ZWRTeW5jUHJvbWlzZSh7fSk7XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgdGhyb3cgZXJyb3I7XG4gICAgICAgIH1cbiAgICAgIH0sXG4gICAgKTtcbiAgfVxuXG4gIHJldHVybiB7XG4gICAgc2VuZCxcbiAgICBmbHVzaCxcbiAgfTtcbn1cblxuZXhwb3J0cy5ERUZBVUxUX1RSQU5TUE9SVF9CVUZGRVJfU0laRSA9IERFRkFVTFRfVFJBTlNQT1JUX0JVRkZFUl9TSVpFO1xuZXhwb3J0cy5jcmVhdGVUcmFuc3BvcnQgPSBjcmVhdGVUcmFuc3BvcnQ7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1iYXNlLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/transports/base.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/transports/multiplexed.js":
/*!**************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/transports/multiplexed.js ***!
  \**************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst api = __webpack_require__(/*! ../api.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/api.js\");\nconst dsn = __webpack_require__(/*! ../utils/dsn.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/dsn.js\");\nconst envelope = __webpack_require__(/*! ../utils/envelope.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/envelope.js\");\n\n/**\n * Gets an event from an envelope.\n *\n * This is only exported for use in the tests\n */\nfunction eventFromEnvelope(env, types) {\n  let event;\n\n  envelope.forEachEnvelopeItem(env, (item, type) => {\n    if (types.includes(type)) {\n      event = Array.isArray(item) ? (item )[1] : undefined;\n    }\n    // bail out if we found an event\n    return !!event;\n  });\n\n  return event;\n}\n\n/**\n * Creates a transport that overrides the release on all events.\n */\nfunction makeOverrideReleaseTransport(\n  createTransport,\n  release,\n) {\n  return options => {\n    const transport = createTransport(options);\n\n    return {\n      ...transport,\n      send: async (envelope) => {\n        const event = eventFromEnvelope(envelope, ['event', 'transaction', 'profile', 'replay_event']);\n\n        if (event) {\n          event.release = release;\n        }\n        return transport.send(envelope);\n      },\n    };\n  };\n}\n\n/** Overrides the DSN in the envelope header  */\nfunction overrideDsn(envelope$1, dsn) {\n  return envelope.createEnvelope(\n    dsn\n      ? {\n          ...envelope$1[0],\n          dsn,\n        }\n      : envelope$1[0],\n    envelope$1[1],\n  );\n}\n\n/**\n * Creates a transport that can send events to different DSNs depending on the envelope contents.\n */\nfunction makeMultiplexedTransport(\n  createTransport,\n  matcher,\n) {\n  return options => {\n    const fallbackTransport = createTransport(options);\n    const otherTransports = new Map();\n\n    function getTransport(dsn$1, release) {\n      // We create a transport for every unique dsn/release combination as there may be code from multiple releases in\n      // use at the same time\n      const key = release ? `${dsn$1}:${release}` : dsn$1;\n\n      let transport = otherTransports.get(key);\n\n      if (!transport) {\n        const validatedDsn = dsn.dsnFromString(dsn$1);\n        if (!validatedDsn) {\n          return undefined;\n        }\n        const url = api.getEnvelopeEndpointWithUrlEncodedAuth(validatedDsn, options.tunnel);\n\n        transport = release\n          ? makeOverrideReleaseTransport(createTransport, release)({ ...options, url })\n          : createTransport({ ...options, url });\n\n        otherTransports.set(key, transport);\n      }\n\n      return [dsn$1, transport];\n    }\n\n    async function send(envelope) {\n      function getEvent(types) {\n        const eventTypes = types?.length ? types : ['event'];\n        return eventFromEnvelope(envelope, eventTypes);\n      }\n\n      const transports = matcher({ envelope, getEvent })\n        .map(result => {\n          if (typeof result === 'string') {\n            return getTransport(result, undefined);\n          } else {\n            return getTransport(result.dsn, result.release);\n          }\n        })\n        .filter((t) => !!t);\n\n      // If we have no transports to send to, use the fallback transport\n      // Don't override the DSN in the header for the fallback transport. '' is falsy\n      const transportsWithFallback = transports.length ? transports : [['', fallbackTransport]];\n\n      const results = (await Promise.all(\n        transportsWithFallback.map(([dsn, transport]) => transport.send(overrideDsn(envelope, dsn))),\n      )) ;\n\n      return results[0];\n    }\n\n    async function flush(timeout) {\n      const allTransports = [...otherTransports.values(), fallbackTransport];\n      const results = await Promise.all(allTransports.map(transport => transport.flush(timeout)));\n      return results.every(r => r);\n    }\n\n    return {\n      send,\n      flush,\n    };\n  };\n}\n\nexports.eventFromEnvelope = eventFromEnvelope;\nexports.makeMultiplexedTransport = makeMultiplexedTransport;\n//# sourceMappingURL=multiplexed.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdHJhbnNwb3J0cy9tdWx0aXBsZXhlZC5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxZQUFZLG1CQUFPLENBQUMsbUhBQVc7QUFDL0IsWUFBWSxtQkFBTyxDQUFDLCtIQUFpQjtBQUNyQyxpQkFBaUIsbUJBQU8sQ0FBQyx5SUFBc0I7O0FBRS9DO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEdBQUc7O0FBRUg7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQSxPQUFPO0FBQ1A7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQSwrQkFBK0IsTUFBTSxHQUFHLFFBQVE7O0FBRWhEOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBLHFFQUFxRSxpQkFBaUI7QUFDdEYsOEJBQThCLGlCQUFpQjs7QUFFL0M7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsbUNBQW1DLG9CQUFvQjtBQUN2RDtBQUNBO0FBQ0E7QUFDQSxZQUFZO0FBQ1o7QUFDQTtBQUNBLFNBQVM7QUFDVDs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEseUJBQXlCO0FBQ3pCLGdDQUFnQztBQUNoQyIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3RyYW5zcG9ydHMvbXVsdGlwbGV4ZWQuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGFwaSA9IHJlcXVpcmUoJy4uL2FwaS5qcycpO1xuY29uc3QgZHNuID0gcmVxdWlyZSgnLi4vdXRpbHMvZHNuLmpzJyk7XG5jb25zdCBlbnZlbG9wZSA9IHJlcXVpcmUoJy4uL3V0aWxzL2VudmVsb3BlLmpzJyk7XG5cbi8qKlxuICogR2V0cyBhbiBldmVudCBmcm9tIGFuIGVudmVsb3BlLlxuICpcbiAqIFRoaXMgaXMgb25seSBleHBvcnRlZCBmb3IgdXNlIGluIHRoZSB0ZXN0c1xuICovXG5mdW5jdGlvbiBldmVudEZyb21FbnZlbG9wZShlbnYsIHR5cGVzKSB7XG4gIGxldCBldmVudDtcblxuICBlbnZlbG9wZS5mb3JFYWNoRW52ZWxvcGVJdGVtKGVudiwgKGl0ZW0sIHR5cGUpID0+IHtcbiAgICBpZiAodHlwZXMuaW5jbHVkZXModHlwZSkpIHtcbiAgICAgIGV2ZW50ID0gQXJyYXkuaXNBcnJheShpdGVtKSA/IChpdGVtIClbMV0gOiB1bmRlZmluZWQ7XG4gICAgfVxuICAgIC8vIGJhaWwgb3V0IGlmIHdlIGZvdW5kIGFuIGV2ZW50XG4gICAgcmV0dXJuICEhZXZlbnQ7XG4gIH0pO1xuXG4gIHJldHVybiBldmVudDtcbn1cblxuLyoqXG4gKiBDcmVhdGVzIGEgdHJhbnNwb3J0IHRoYXQgb3ZlcnJpZGVzIHRoZSByZWxlYXNlIG9uIGFsbCBldmVudHMuXG4gKi9cbmZ1bmN0aW9uIG1ha2VPdmVycmlkZVJlbGVhc2VUcmFuc3BvcnQoXG4gIGNyZWF0ZVRyYW5zcG9ydCxcbiAgcmVsZWFzZSxcbikge1xuICByZXR1cm4gb3B0aW9ucyA9PiB7XG4gICAgY29uc3QgdHJhbnNwb3J0ID0gY3JlYXRlVHJhbnNwb3J0KG9wdGlvbnMpO1xuXG4gICAgcmV0dXJuIHtcbiAgICAgIC4uLnRyYW5zcG9ydCxcbiAgICAgIHNlbmQ6IGFzeW5jIChlbnZlbG9wZSkgPT4ge1xuICAgICAgICBjb25zdCBldmVudCA9IGV2ZW50RnJvbUVudmVsb3BlKGVudmVsb3BlLCBbJ2V2ZW50JywgJ3RyYW5zYWN0aW9uJywgJ3Byb2ZpbGUnLCAncmVwbGF5X2V2ZW50J10pO1xuXG4gICAgICAgIGlmIChldmVudCkge1xuICAgICAgICAgIGV2ZW50LnJlbGVhc2UgPSByZWxlYXNlO1xuICAgICAgICB9XG4gICAgICAgIHJldHVybiB0cmFuc3BvcnQuc2VuZChlbnZlbG9wZSk7XG4gICAgICB9LFxuICAgIH07XG4gIH07XG59XG5cbi8qKiBPdmVycmlkZXMgdGhlIERTTiBpbiB0aGUgZW52ZWxvcGUgaGVhZGVyICAqL1xuZnVuY3Rpb24gb3ZlcnJpZGVEc24oZW52ZWxvcGUkMSwgZHNuKSB7XG4gIHJldHVybiBlbnZlbG9wZS5jcmVhdGVFbnZlbG9wZShcbiAgICBkc25cbiAgICAgID8ge1xuICAgICAgICAgIC4uLmVudmVsb3BlJDFbMF0sXG4gICAgICAgICAgZHNuLFxuICAgICAgICB9XG4gICAgICA6IGVudmVsb3BlJDFbMF0sXG4gICAgZW52ZWxvcGUkMVsxXSxcbiAgKTtcbn1cblxuLyoqXG4gKiBDcmVhdGVzIGEgdHJhbnNwb3J0IHRoYXQgY2FuIHNlbmQgZXZlbnRzIHRvIGRpZmZlcmVudCBEU05zIGRlcGVuZGluZyBvbiB0aGUgZW52ZWxvcGUgY29udGVudHMuXG4gKi9cbmZ1bmN0aW9uIG1ha2VNdWx0aXBsZXhlZFRyYW5zcG9ydChcbiAgY3JlYXRlVHJhbnNwb3J0LFxuICBtYXRjaGVyLFxuKSB7XG4gIHJldHVybiBvcHRpb25zID0+IHtcbiAgICBjb25zdCBmYWxsYmFja1RyYW5zcG9ydCA9IGNyZWF0ZVRyYW5zcG9ydChvcHRpb25zKTtcbiAgICBjb25zdCBvdGhlclRyYW5zcG9ydHMgPSBuZXcgTWFwKCk7XG5cbiAgICBmdW5jdGlvbiBnZXRUcmFuc3BvcnQoZHNuJDEsIHJlbGVhc2UpIHtcbiAgICAgIC8vIFdlIGNyZWF0ZSBhIHRyYW5zcG9ydCBmb3IgZXZlcnkgdW5pcXVlIGRzbi9yZWxlYXNlIGNvbWJpbmF0aW9uIGFzIHRoZXJlIG1heSBiZSBjb2RlIGZyb20gbXVsdGlwbGUgcmVsZWFzZXMgaW5cbiAgICAgIC8vIHVzZSBhdCB0aGUgc2FtZSB0aW1lXG4gICAgICBjb25zdCBrZXkgPSByZWxlYXNlID8gYCR7ZHNuJDF9OiR7cmVsZWFzZX1gIDogZHNuJDE7XG5cbiAgICAgIGxldCB0cmFuc3BvcnQgPSBvdGhlclRyYW5zcG9ydHMuZ2V0KGtleSk7XG5cbiAgICAgIGlmICghdHJhbnNwb3J0KSB7XG4gICAgICAgIGNvbnN0IHZhbGlkYXRlZERzbiA9IGRzbi5kc25Gcm9tU3RyaW5nKGRzbiQxKTtcbiAgICAgICAgaWYgKCF2YWxpZGF0ZWREc24pIHtcbiAgICAgICAgICByZXR1cm4gdW5kZWZpbmVkO1xuICAgICAgICB9XG4gICAgICAgIGNvbnN0IHVybCA9IGFwaS5nZXRFbnZlbG9wZUVuZHBvaW50V2l0aFVybEVuY29kZWRBdXRoKHZhbGlkYXRlZERzbiwgb3B0aW9ucy50dW5uZWwpO1xuXG4gICAgICAgIHRyYW5zcG9ydCA9IHJlbGVhc2VcbiAgICAgICAgICA/IG1ha2VPdmVycmlkZVJlbGVhc2VUcmFuc3BvcnQoY3JlYXRlVHJhbnNwb3J0LCByZWxlYXNlKSh7IC4uLm9wdGlvbnMsIHVybCB9KVxuICAgICAgICAgIDogY3JlYXRlVHJhbnNwb3J0KHsgLi4ub3B0aW9ucywgdXJsIH0pO1xuXG4gICAgICAgIG90aGVyVHJhbnNwb3J0cy5zZXQoa2V5LCB0cmFuc3BvcnQpO1xuICAgICAgfVxuXG4gICAgICByZXR1cm4gW2RzbiQxLCB0cmFuc3BvcnRdO1xuICAgIH1cblxuICAgIGFzeW5jIGZ1bmN0aW9uIHNlbmQoZW52ZWxvcGUpIHtcbiAgICAgIGZ1bmN0aW9uIGdldEV2ZW50KHR5cGVzKSB7XG4gICAgICAgIGNvbnN0IGV2ZW50VHlwZXMgPSB0eXBlcz8ubGVuZ3RoID8gdHlwZXMgOiBbJ2V2ZW50J107XG4gICAgICAgIHJldHVybiBldmVudEZyb21FbnZlbG9wZShlbnZlbG9wZSwgZXZlbnRUeXBlcyk7XG4gICAgICB9XG5cbiAgICAgIGNvbnN0IHRyYW5zcG9ydHMgPSBtYXRjaGVyKHsgZW52ZWxvcGUsIGdldEV2ZW50IH0pXG4gICAgICAgIC5tYXAocmVzdWx0ID0+IHtcbiAgICAgICAgICBpZiAodHlwZW9mIHJlc3VsdCA9PT0gJ3N0cmluZycpIHtcbiAgICAgICAgICAgIHJldHVybiBnZXRUcmFuc3BvcnQocmVzdWx0LCB1bmRlZmluZWQpO1xuICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICByZXR1cm4gZ2V0VHJhbnNwb3J0KHJlc3VsdC5kc24sIHJlc3VsdC5yZWxlYXNlKTtcbiAgICAgICAgICB9XG4gICAgICAgIH0pXG4gICAgICAgIC5maWx0ZXIoKHQpID0+ICEhdCk7XG5cbiAgICAgIC8vIElmIHdlIGhhdmUgbm8gdHJhbnNwb3J0cyB0byBzZW5kIHRvLCB1c2UgdGhlIGZhbGxiYWNrIHRyYW5zcG9ydFxuICAgICAgLy8gRG9uJ3Qgb3ZlcnJpZGUgdGhlIERTTiBpbiB0aGUgaGVhZGVyIGZvciB0aGUgZmFsbGJhY2sgdHJhbnNwb3J0LiAnJyBpcyBmYWxzeVxuICAgICAgY29uc3QgdHJhbnNwb3J0c1dpdGhGYWxsYmFjayA9IHRyYW5zcG9ydHMubGVuZ3RoID8gdHJhbnNwb3J0cyA6IFtbJycsIGZhbGxiYWNrVHJhbnNwb3J0XV07XG5cbiAgICAgIGNvbnN0IHJlc3VsdHMgPSAoYXdhaXQgUHJvbWlzZS5hbGwoXG4gICAgICAgIHRyYW5zcG9ydHNXaXRoRmFsbGJhY2subWFwKChbZHNuLCB0cmFuc3BvcnRdKSA9PiB0cmFuc3BvcnQuc2VuZChvdmVycmlkZURzbihlbnZlbG9wZSwgZHNuKSkpLFxuICAgICAgKSkgO1xuXG4gICAgICByZXR1cm4gcmVzdWx0c1swXTtcbiAgICB9XG5cbiAgICBhc3luYyBmdW5jdGlvbiBmbHVzaCh0aW1lb3V0KSB7XG4gICAgICBjb25zdCBhbGxUcmFuc3BvcnRzID0gWy4uLm90aGVyVHJhbnNwb3J0cy52YWx1ZXMoKSwgZmFsbGJhY2tUcmFuc3BvcnRdO1xuICAgICAgY29uc3QgcmVzdWx0cyA9IGF3YWl0IFByb21pc2UuYWxsKGFsbFRyYW5zcG9ydHMubWFwKHRyYW5zcG9ydCA9PiB0cmFuc3BvcnQuZmx1c2godGltZW91dCkpKTtcbiAgICAgIHJldHVybiByZXN1bHRzLmV2ZXJ5KHIgPT4gcik7XG4gICAgfVxuXG4gICAgcmV0dXJuIHtcbiAgICAgIHNlbmQsXG4gICAgICBmbHVzaCxcbiAgICB9O1xuICB9O1xufVxuXG5leHBvcnRzLmV2ZW50RnJvbUVudmVsb3BlID0gZXZlbnRGcm9tRW52ZWxvcGU7XG5leHBvcnRzLm1ha2VNdWx0aXBsZXhlZFRyYW5zcG9ydCA9IG1ha2VNdWx0aXBsZXhlZFRyYW5zcG9ydDtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPW11bHRpcGxleGVkLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/transports/multiplexed.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/transports/offline.js":
/*!**********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/transports/offline.js ***!
  \**********************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst debugBuild = __webpack_require__(/*! ../debug-build.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst debugLogger = __webpack_require__(/*! ../utils/debug-logger.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst envelope = __webpack_require__(/*! ../utils/envelope.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/envelope.js\");\nconst ratelimit = __webpack_require__(/*! ../utils/ratelimit.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/ratelimit.js\");\n\nconst MIN_DELAY = 100; // 100 ms\nconst START_DELAY = 5000; // 5 seconds\nconst MAX_DELAY = 3.6e6; // 1 hour\n\n/**\n * Wraps a transport and stores and retries events when they fail to send.\n *\n * @param createTransport The transport to wrap.\n */\nfunction makeOfflineTransport(\n  createTransport,\n) {\n  function log(...args) {\n    debugBuild.DEBUG_BUILD && debugLogger.debug.log('[Offline]:', ...args);\n  }\n\n  return options => {\n    const transport = createTransport(options);\n\n    if (!options.createStore) {\n      throw new Error('No `createStore` function was provided');\n    }\n\n    const store = options.createStore(options);\n\n    let retryDelay = START_DELAY;\n    let flushTimer;\n\n    function shouldQueue(env, error, retryDelay) {\n      // We want to drop client reports because they can be generated when we retry sending events while offline.\n      if (envelope.envelopeContainsItemType(env, ['client_report'])) {\n        return false;\n      }\n\n      if (options.shouldStore) {\n        return options.shouldStore(env, error, retryDelay);\n      }\n\n      return true;\n    }\n\n    function flushIn(delay) {\n      if (flushTimer) {\n        clearTimeout(flushTimer );\n      }\n\n      flushTimer = setTimeout(async () => {\n        flushTimer = undefined;\n\n        const found = await store.shift();\n        if (found) {\n          log('Attempting to send previously queued event');\n\n          // We should to update the sent_at timestamp to the current time.\n          found[0].sent_at = new Date().toISOString();\n\n          void send(found, true).catch(e => {\n            log('Failed to retry sending', e);\n          });\n        }\n      }, delay) ;\n\n      // We need to unref the timer in node.js, otherwise the node process never exit.\n      if (typeof flushTimer !== 'number' && flushTimer.unref) {\n        flushTimer.unref();\n      }\n    }\n\n    function flushWithBackOff() {\n      if (flushTimer) {\n        return;\n      }\n\n      flushIn(retryDelay);\n\n      retryDelay = Math.min(retryDelay * 2, MAX_DELAY);\n    }\n\n    async function send(envelope$1, isRetry = false) {\n      // We queue all replay envelopes to avoid multiple replay envelopes being sent at the same time. If one fails, we\n      // need to retry them in order.\n      if (!isRetry && envelope.envelopeContainsItemType(envelope$1, ['replay_event', 'replay_recording'])) {\n        await store.push(envelope$1);\n        flushIn(MIN_DELAY);\n        return {};\n      }\n\n      try {\n        if (options.shouldSend && (await options.shouldSend(envelope$1)) === false) {\n          throw new Error('Envelope not sent because `shouldSend` callback returned false');\n        }\n\n        const result = await transport.send(envelope$1);\n\n        let delay = MIN_DELAY;\n\n        if (result) {\n          // If there's a retry-after header, use that as the next delay.\n          if (result.headers?.['retry-after']) {\n            delay = ratelimit.parseRetryAfterHeader(result.headers['retry-after']);\n          } else if (result.headers?.['x-sentry-rate-limits']) {\n            delay = 60000; // 60 seconds\n          } // If we have a server error, return now so we don't flush the queue.\n          else if ((result.statusCode || 0) >= 400) {\n            return result;\n          }\n        }\n\n        flushIn(delay);\n        retryDelay = START_DELAY;\n        return result;\n      } catch (e) {\n        if (await shouldQueue(envelope$1, e , retryDelay)) {\n          // If this envelope was a retry, we want to add it to the front of the queue so it's retried again first.\n          if (isRetry) {\n            await store.unshift(envelope$1);\n          } else {\n            await store.push(envelope$1);\n          }\n          flushWithBackOff();\n          log('Error sending. Event queued.', e );\n          return {};\n        } else {\n          throw e;\n        }\n      }\n    }\n\n    if (options.flushAtStartup) {\n      flushWithBackOff();\n    }\n\n    return {\n      send,\n      flush: timeout => {\n        // If there's no timeout, we should attempt to flush the offline queue.\n        if (timeout === undefined) {\n          retryDelay = START_DELAY;\n          flushIn(MIN_DELAY);\n        }\n\n        return transport.flush(timeout);\n      },\n    };\n  };\n}\n\nexports.MIN_DELAY = MIN_DELAY;\nexports.START_DELAY = START_DELAY;\nexports.makeOfflineTransport = makeOfflineTransport;\n//# sourceMappingURL=offline.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdHJhbnNwb3J0cy9vZmZsaW5lLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLG1CQUFtQixtQkFBTyxDQUFDLG1JQUFtQjtBQUM5QyxvQkFBb0IsbUJBQU8sQ0FBQyxpSkFBMEI7QUFDdEQsaUJBQWlCLG1CQUFPLENBQUMseUlBQXNCO0FBQy9DLGtCQUFrQixtQkFBTyxDQUFDLDJJQUF1Qjs7QUFFakQsdUJBQXVCO0FBQ3ZCLDBCQUEwQjtBQUMxQix5QkFBeUI7O0FBRXpCO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLFdBQVc7QUFDWDtBQUNBLE9BQU87O0FBRVA7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQSxZQUFZO0FBQ1osMkJBQTJCO0FBQzNCLFlBQVk7QUFDWjtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQSxRQUFRO0FBQ1I7QUFDQTtBQUNBO0FBQ0E7QUFDQSxZQUFZO0FBQ1o7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFVBQVU7QUFDVjtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBLE9BQU87QUFDUDtBQUNBO0FBQ0E7O0FBRUEsaUJBQWlCO0FBQ2pCLG1CQUFtQjtBQUNuQiw0QkFBNEI7QUFDNUIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy90cmFuc3BvcnRzL29mZmxpbmUuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGRlYnVnQnVpbGQgPSByZXF1aXJlKCcuLi9kZWJ1Zy1idWlsZC5qcycpO1xuY29uc3QgZGVidWdMb2dnZXIgPSByZXF1aXJlKCcuLi91dGlscy9kZWJ1Zy1sb2dnZXIuanMnKTtcbmNvbnN0IGVudmVsb3BlID0gcmVxdWlyZSgnLi4vdXRpbHMvZW52ZWxvcGUuanMnKTtcbmNvbnN0IHJhdGVsaW1pdCA9IHJlcXVpcmUoJy4uL3V0aWxzL3JhdGVsaW1pdC5qcycpO1xuXG5jb25zdCBNSU5fREVMQVkgPSAxMDA7IC8vIDEwMCBtc1xuY29uc3QgU1RBUlRfREVMQVkgPSA1MDAwOyAvLyA1IHNlY29uZHNcbmNvbnN0IE1BWF9ERUxBWSA9IDMuNmU2OyAvLyAxIGhvdXJcblxuLyoqXG4gKiBXcmFwcyBhIHRyYW5zcG9ydCBhbmQgc3RvcmVzIGFuZCByZXRyaWVzIGV2ZW50cyB3aGVuIHRoZXkgZmFpbCB0byBzZW5kLlxuICpcbiAqIEBwYXJhbSBjcmVhdGVUcmFuc3BvcnQgVGhlIHRyYW5zcG9ydCB0byB3cmFwLlxuICovXG5mdW5jdGlvbiBtYWtlT2ZmbGluZVRyYW5zcG9ydChcbiAgY3JlYXRlVHJhbnNwb3J0LFxuKSB7XG4gIGZ1bmN0aW9uIGxvZyguLi5hcmdzKSB7XG4gICAgZGVidWdCdWlsZC5ERUJVR19CVUlMRCAmJiBkZWJ1Z0xvZ2dlci5kZWJ1Zy5sb2coJ1tPZmZsaW5lXTonLCAuLi5hcmdzKTtcbiAgfVxuXG4gIHJldHVybiBvcHRpb25zID0+IHtcbiAgICBjb25zdCB0cmFuc3BvcnQgPSBjcmVhdGVUcmFuc3BvcnQob3B0aW9ucyk7XG5cbiAgICBpZiAoIW9wdGlvbnMuY3JlYXRlU3RvcmUpIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcignTm8gYGNyZWF0ZVN0b3JlYCBmdW5jdGlvbiB3YXMgcHJvdmlkZWQnKTtcbiAgICB9XG5cbiAgICBjb25zdCBzdG9yZSA9IG9wdGlvbnMuY3JlYXRlU3RvcmUob3B0aW9ucyk7XG5cbiAgICBsZXQgcmV0cnlEZWxheSA9IFNUQVJUX0RFTEFZO1xuICAgIGxldCBmbHVzaFRpbWVyO1xuXG4gICAgZnVuY3Rpb24gc2hvdWxkUXVldWUoZW52LCBlcnJvciwgcmV0cnlEZWxheSkge1xuICAgICAgLy8gV2Ugd2FudCB0byBkcm9wIGNsaWVudCByZXBvcnRzIGJlY2F1c2UgdGhleSBjYW4gYmUgZ2VuZXJhdGVkIHdoZW4gd2UgcmV0cnkgc2VuZGluZyBldmVudHMgd2hpbGUgb2ZmbGluZS5cbiAgICAgIGlmIChlbnZlbG9wZS5lbnZlbG9wZUNvbnRhaW5zSXRlbVR5cGUoZW52LCBbJ2NsaWVudF9yZXBvcnQnXSkpIHtcbiAgICAgICAgcmV0dXJuIGZhbHNlO1xuICAgICAgfVxuXG4gICAgICBpZiAob3B0aW9ucy5zaG91bGRTdG9yZSkge1xuICAgICAgICByZXR1cm4gb3B0aW9ucy5zaG91bGRTdG9yZShlbnYsIGVycm9yLCByZXRyeURlbGF5KTtcbiAgICAgIH1cblxuICAgICAgcmV0dXJuIHRydWU7XG4gICAgfVxuXG4gICAgZnVuY3Rpb24gZmx1c2hJbihkZWxheSkge1xuICAgICAgaWYgKGZsdXNoVGltZXIpIHtcbiAgICAgICAgY2xlYXJUaW1lb3V0KGZsdXNoVGltZXIgKTtcbiAgICAgIH1cblxuICAgICAgZmx1c2hUaW1lciA9IHNldFRpbWVvdXQoYXN5bmMgKCkgPT4ge1xuICAgICAgICBmbHVzaFRpbWVyID0gdW5kZWZpbmVkO1xuXG4gICAgICAgIGNvbnN0IGZvdW5kID0gYXdhaXQgc3RvcmUuc2hpZnQoKTtcbiAgICAgICAgaWYgKGZvdW5kKSB7XG4gICAgICAgICAgbG9nKCdBdHRlbXB0aW5nIHRvIHNlbmQgcHJldmlvdXNseSBxdWV1ZWQgZXZlbnQnKTtcblxuICAgICAgICAgIC8vIFdlIHNob3VsZCB0byB1cGRhdGUgdGhlIHNlbnRfYXQgdGltZXN0YW1wIHRvIHRoZSBjdXJyZW50IHRpbWUuXG4gICAgICAgICAgZm91bmRbMF0uc2VudF9hdCA9IG5ldyBEYXRlKCkudG9JU09TdHJpbmcoKTtcblxuICAgICAgICAgIHZvaWQgc2VuZChmb3VuZCwgdHJ1ZSkuY2F0Y2goZSA9PiB7XG4gICAgICAgICAgICBsb2coJ0ZhaWxlZCB0byByZXRyeSBzZW5kaW5nJywgZSk7XG4gICAgICAgICAgfSk7XG4gICAgICAgIH1cbiAgICAgIH0sIGRlbGF5KSA7XG5cbiAgICAgIC8vIFdlIG5lZWQgdG8gdW5yZWYgdGhlIHRpbWVyIGluIG5vZGUuanMsIG90aGVyd2lzZSB0aGUgbm9kZSBwcm9jZXNzIG5ldmVyIGV4aXQuXG4gICAgICBpZiAodHlwZW9mIGZsdXNoVGltZXIgIT09ICdudW1iZXInICYmIGZsdXNoVGltZXIudW5yZWYpIHtcbiAgICAgICAgZmx1c2hUaW1lci51bnJlZigpO1xuICAgICAgfVxuICAgIH1cblxuICAgIGZ1bmN0aW9uIGZsdXNoV2l0aEJhY2tPZmYoKSB7XG4gICAgICBpZiAoZmx1c2hUaW1lcikge1xuICAgICAgICByZXR1cm47XG4gICAgICB9XG5cbiAgICAgIGZsdXNoSW4ocmV0cnlEZWxheSk7XG5cbiAgICAgIHJldHJ5RGVsYXkgPSBNYXRoLm1pbihyZXRyeURlbGF5ICogMiwgTUFYX0RFTEFZKTtcbiAgICB9XG5cbiAgICBhc3luYyBmdW5jdGlvbiBzZW5kKGVudmVsb3BlJDEsIGlzUmV0cnkgPSBmYWxzZSkge1xuICAgICAgLy8gV2UgcXVldWUgYWxsIHJlcGxheSBlbnZlbG9wZXMgdG8gYXZvaWQgbXVsdGlwbGUgcmVwbGF5IGVudmVsb3BlcyBiZWluZyBzZW50IGF0IHRoZSBzYW1lIHRpbWUuIElmIG9uZSBmYWlscywgd2VcbiAgICAgIC8vIG5lZWQgdG8gcmV0cnkgdGhlbSBpbiBvcmRlci5cbiAgICAgIGlmICghaXNSZXRyeSAmJiBlbnZlbG9wZS5lbnZlbG9wZUNvbnRhaW5zSXRlbVR5cGUoZW52ZWxvcGUkMSwgWydyZXBsYXlfZXZlbnQnLCAncmVwbGF5X3JlY29yZGluZyddKSkge1xuICAgICAgICBhd2FpdCBzdG9yZS5wdXNoKGVudmVsb3BlJDEpO1xuICAgICAgICBmbHVzaEluKE1JTl9ERUxBWSk7XG4gICAgICAgIHJldHVybiB7fTtcbiAgICAgIH1cblxuICAgICAgdHJ5IHtcbiAgICAgICAgaWYgKG9wdGlvbnMuc2hvdWxkU2VuZCAmJiAoYXdhaXQgb3B0aW9ucy5zaG91bGRTZW5kKGVudmVsb3BlJDEpKSA9PT0gZmFsc2UpIHtcbiAgICAgICAgICB0aHJvdyBuZXcgRXJyb3IoJ0VudmVsb3BlIG5vdCBzZW50IGJlY2F1c2UgYHNob3VsZFNlbmRgIGNhbGxiYWNrIHJldHVybmVkIGZhbHNlJyk7XG4gICAgICAgIH1cblxuICAgICAgICBjb25zdCByZXN1bHQgPSBhd2FpdCB0cmFuc3BvcnQuc2VuZChlbnZlbG9wZSQxKTtcblxuICAgICAgICBsZXQgZGVsYXkgPSBNSU5fREVMQVk7XG5cbiAgICAgICAgaWYgKHJlc3VsdCkge1xuICAgICAgICAgIC8vIElmIHRoZXJlJ3MgYSByZXRyeS1hZnRlciBoZWFkZXIsIHVzZSB0aGF0IGFzIHRoZSBuZXh0IGRlbGF5LlxuICAgICAgICAgIGlmIChyZXN1bHQuaGVhZGVycz8uWydyZXRyeS1hZnRlciddKSB7XG4gICAgICAgICAgICBkZWxheSA9IHJhdGVsaW1pdC5wYXJzZVJldHJ5QWZ0ZXJIZWFkZXIocmVzdWx0LmhlYWRlcnNbJ3JldHJ5LWFmdGVyJ10pO1xuICAgICAgICAgIH0gZWxzZSBpZiAocmVzdWx0LmhlYWRlcnM/LlsneC1zZW50cnktcmF0ZS1saW1pdHMnXSkge1xuICAgICAgICAgICAgZGVsYXkgPSA2MDAwMDsgLy8gNjAgc2Vjb25kc1xuICAgICAgICAgIH0gLy8gSWYgd2UgaGF2ZSBhIHNlcnZlciBlcnJvciwgcmV0dXJuIG5vdyBzbyB3ZSBkb24ndCBmbHVzaCB0aGUgcXVldWUuXG4gICAgICAgICAgZWxzZSBpZiAoKHJlc3VsdC5zdGF0dXNDb2RlIHx8IDApID49IDQwMCkge1xuICAgICAgICAgICAgcmV0dXJuIHJlc3VsdDtcbiAgICAgICAgICB9XG4gICAgICAgIH1cblxuICAgICAgICBmbHVzaEluKGRlbGF5KTtcbiAgICAgICAgcmV0cnlEZWxheSA9IFNUQVJUX0RFTEFZO1xuICAgICAgICByZXR1cm4gcmVzdWx0O1xuICAgICAgfSBjYXRjaCAoZSkge1xuICAgICAgICBpZiAoYXdhaXQgc2hvdWxkUXVldWUoZW52ZWxvcGUkMSwgZSAsIHJldHJ5RGVsYXkpKSB7XG4gICAgICAgICAgLy8gSWYgdGhpcyBlbnZlbG9wZSB3YXMgYSByZXRyeSwgd2Ugd2FudCB0byBhZGQgaXQgdG8gdGhlIGZyb250IG9mIHRoZSBxdWV1ZSBzbyBpdCdzIHJldHJpZWQgYWdhaW4gZmlyc3QuXG4gICAgICAgICAgaWYgKGlzUmV0cnkpIHtcbiAgICAgICAgICAgIGF3YWl0IHN0b3JlLnVuc2hpZnQoZW52ZWxvcGUkMSk7XG4gICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgIGF3YWl0IHN0b3JlLnB1c2goZW52ZWxvcGUkMSk7XG4gICAgICAgICAgfVxuICAgICAgICAgIGZsdXNoV2l0aEJhY2tPZmYoKTtcbiAgICAgICAgICBsb2coJ0Vycm9yIHNlbmRpbmcuIEV2ZW50IHF1ZXVlZC4nLCBlICk7XG4gICAgICAgICAgcmV0dXJuIHt9O1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgIHRocm93IGU7XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9XG5cbiAgICBpZiAob3B0aW9ucy5mbHVzaEF0U3RhcnR1cCkge1xuICAgICAgZmx1c2hXaXRoQmFja09mZigpO1xuICAgIH1cblxuICAgIHJldHVybiB7XG4gICAgICBzZW5kLFxuICAgICAgZmx1c2g6IHRpbWVvdXQgPT4ge1xuICAgICAgICAvLyBJZiB0aGVyZSdzIG5vIHRpbWVvdXQsIHdlIHNob3VsZCBhdHRlbXB0IHRvIGZsdXNoIHRoZSBvZmZsaW5lIHF1ZXVlLlxuICAgICAgICBpZiAodGltZW91dCA9PT0gdW5kZWZpbmVkKSB7XG4gICAgICAgICAgcmV0cnlEZWxheSA9IFNUQVJUX0RFTEFZO1xuICAgICAgICAgIGZsdXNoSW4oTUlOX0RFTEFZKTtcbiAgICAgICAgfVxuXG4gICAgICAgIHJldHVybiB0cmFuc3BvcnQuZmx1c2godGltZW91dCk7XG4gICAgICB9LFxuICAgIH07XG4gIH07XG59XG5cbmV4cG9ydHMuTUlOX0RFTEFZID0gTUlOX0RFTEFZO1xuZXhwb3J0cy5TVEFSVF9ERUxBWSA9IFNUQVJUX0RFTEFZO1xuZXhwb3J0cy5tYWtlT2ZmbGluZVRyYW5zcG9ydCA9IG1ha2VPZmZsaW5lVHJhbnNwb3J0O1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9b2ZmbGluZS5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/transports/offline.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/trpc.js":
/*!********************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/trpc.js ***!
  \********************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst currentScopes = __webpack_require__(/*! ./currentScopes.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst exports$1 = __webpack_require__(/*! ./exports.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/exports.js\");\nconst semanticAttributes = __webpack_require__(/*! ./semanticAttributes.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/semanticAttributes.js\");\nconst object = __webpack_require__(/*! ./utils/object.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/object.js\");\nconst normalize = __webpack_require__(/*! ./utils/normalize.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/normalize.js\");\nconst trace = __webpack_require__(/*! ./tracing/trace.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/trace.js\");\n\nconst trpcCaptureContext = { mechanism: { handled: false, data: { function: 'trpcMiddleware' } } };\n\nfunction captureIfError(nextResult) {\n  // TODO: Set span status based on what TRPCError was encountered\n  if (\n    typeof nextResult === 'object' &&\n    nextResult !== null &&\n    'ok' in nextResult &&\n    !nextResult.ok &&\n    'error' in nextResult\n  ) {\n    exports$1.captureException(nextResult.error, trpcCaptureContext);\n  }\n}\n\n/**\n * Sentry tRPC middleware that captures errors and creates spans for tRPC procedures.\n */\nfunction trpcMiddleware(options = {}) {\n  // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n  // @ts-ignore\n  return async function (opts) {\n    const { path, type, next, rawInput, getRawInput } = opts;\n\n    const client = currentScopes.getClient();\n    const clientOptions = client?.getOptions();\n\n    const trpcContext = {\n      procedure_path: path,\n      procedure_type: type,\n    };\n\n    object.addNonEnumerableProperty(\n      trpcContext,\n      '__sentry_override_normalization_depth__',\n      1 + // 1 for context.input + the normal normalization depth\n        (clientOptions?.normalizeDepth ?? 5), // 5 is a sane depth\n    );\n\n    if (options.attachRpcInput !== undefined ? options.attachRpcInput : clientOptions?.sendDefaultPii) {\n      if (rawInput !== undefined) {\n        trpcContext.input = normalize.normalize(rawInput);\n      }\n\n      if (getRawInput !== undefined && typeof getRawInput === 'function') {\n        try {\n          const rawRes = await getRawInput();\n\n          trpcContext.input = normalize.normalize(rawRes);\n        } catch {\n          // noop\n        }\n      }\n    }\n\n    return currentScopes.withIsolationScope(scope => {\n      scope.setContext('trpc', trpcContext);\n      return trace.startSpanManual(\n        {\n          name: `trpc/${path}`,\n          op: 'rpc.server',\n          attributes: {\n            [semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_SOURCE]: 'route',\n            [semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_ORIGIN]: 'auto.rpc.trpc',\n          },\n          forceTransaction: !!options.forceTransaction,\n        },\n        async span => {\n          try {\n            const nextResult = await next();\n            captureIfError(nextResult);\n            span.end();\n            return nextResult;\n          } catch (e) {\n            exports$1.captureException(e, trpcCaptureContext);\n            span.end();\n            throw e;\n          }\n        },\n      ) ;\n    });\n  };\n}\n\nexports.trpcMiddleware = trpcMiddleware;\n//# sourceMappingURL=trpc.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdHJwYy5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxzQkFBc0IsbUJBQU8sQ0FBQyxzSUFBb0I7QUFDbEQsa0JBQWtCLG1CQUFPLENBQUMsMEhBQWM7QUFDeEMsMkJBQTJCLG1CQUFPLENBQUMsZ0pBQXlCO0FBQzVELGVBQWUsbUJBQU8sQ0FBQyxvSUFBbUI7QUFDMUMsa0JBQWtCLG1CQUFPLENBQUMsMElBQXNCO0FBQ2hELGNBQWMsbUJBQU8sQ0FBQyxzSUFBb0I7O0FBRTFDLDZCQUE2QixhQUFhLHdCQUF3Qjs7QUFFbEU7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBLG9DQUFvQztBQUNwQztBQUNBO0FBQ0E7QUFDQSxZQUFZLDBDQUEwQzs7QUFFdEQ7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0EsVUFBVTtBQUNWO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0Esd0JBQXdCLEtBQUs7QUFDN0I7QUFDQTtBQUNBO0FBQ0E7QUFDQSxXQUFXO0FBQ1g7QUFDQSxTQUFTO0FBQ1Q7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsWUFBWTtBQUNaO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsU0FBUztBQUNUO0FBQ0EsS0FBSztBQUNMO0FBQ0E7O0FBRUEsc0JBQXNCO0FBQ3RCIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdHJwYy5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgY3VycmVudFNjb3BlcyA9IHJlcXVpcmUoJy4vY3VycmVudFNjb3Blcy5qcycpO1xuY29uc3QgZXhwb3J0cyQxID0gcmVxdWlyZSgnLi9leHBvcnRzLmpzJyk7XG5jb25zdCBzZW1hbnRpY0F0dHJpYnV0ZXMgPSByZXF1aXJlKCcuL3NlbWFudGljQXR0cmlidXRlcy5qcycpO1xuY29uc3Qgb2JqZWN0ID0gcmVxdWlyZSgnLi91dGlscy9vYmplY3QuanMnKTtcbmNvbnN0IG5vcm1hbGl6ZSA9IHJlcXVpcmUoJy4vdXRpbHMvbm9ybWFsaXplLmpzJyk7XG5jb25zdCB0cmFjZSA9IHJlcXVpcmUoJy4vdHJhY2luZy90cmFjZS5qcycpO1xuXG5jb25zdCB0cnBjQ2FwdHVyZUNvbnRleHQgPSB7IG1lY2hhbmlzbTogeyBoYW5kbGVkOiBmYWxzZSwgZGF0YTogeyBmdW5jdGlvbjogJ3RycGNNaWRkbGV3YXJlJyB9IH0gfTtcblxuZnVuY3Rpb24gY2FwdHVyZUlmRXJyb3IobmV4dFJlc3VsdCkge1xuICAvLyBUT0RPOiBTZXQgc3BhbiBzdGF0dXMgYmFzZWQgb24gd2hhdCBUUlBDRXJyb3Igd2FzIGVuY291bnRlcmVkXG4gIGlmIChcbiAgICB0eXBlb2YgbmV4dFJlc3VsdCA9PT0gJ29iamVjdCcgJiZcbiAgICBuZXh0UmVzdWx0ICE9PSBudWxsICYmXG4gICAgJ29rJyBpbiBuZXh0UmVzdWx0ICYmXG4gICAgIW5leHRSZXN1bHQub2sgJiZcbiAgICAnZXJyb3InIGluIG5leHRSZXN1bHRcbiAgKSB7XG4gICAgZXhwb3J0cyQxLmNhcHR1cmVFeGNlcHRpb24obmV4dFJlc3VsdC5lcnJvciwgdHJwY0NhcHR1cmVDb250ZXh0KTtcbiAgfVxufVxuXG4vKipcbiAqIFNlbnRyeSB0UlBDIG1pZGRsZXdhcmUgdGhhdCBjYXB0dXJlcyBlcnJvcnMgYW5kIGNyZWF0ZXMgc3BhbnMgZm9yIHRSUEMgcHJvY2VkdXJlcy5cbiAqL1xuZnVuY3Rpb24gdHJwY01pZGRsZXdhcmUob3B0aW9ucyA9IHt9KSB7XG4gIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvYmFuLXRzLWNvbW1lbnRcbiAgLy8gQHRzLWlnbm9yZVxuICByZXR1cm4gYXN5bmMgZnVuY3Rpb24gKG9wdHMpIHtcbiAgICBjb25zdCB7IHBhdGgsIHR5cGUsIG5leHQsIHJhd0lucHV0LCBnZXRSYXdJbnB1dCB9ID0gb3B0cztcblxuICAgIGNvbnN0IGNsaWVudCA9IGN1cnJlbnRTY29wZXMuZ2V0Q2xpZW50KCk7XG4gICAgY29uc3QgY2xpZW50T3B0aW9ucyA9IGNsaWVudD8uZ2V0T3B0aW9ucygpO1xuXG4gICAgY29uc3QgdHJwY0NvbnRleHQgPSB7XG4gICAgICBwcm9jZWR1cmVfcGF0aDogcGF0aCxcbiAgICAgIHByb2NlZHVyZV90eXBlOiB0eXBlLFxuICAgIH07XG5cbiAgICBvYmplY3QuYWRkTm9uRW51bWVyYWJsZVByb3BlcnR5KFxuICAgICAgdHJwY0NvbnRleHQsXG4gICAgICAnX19zZW50cnlfb3ZlcnJpZGVfbm9ybWFsaXphdGlvbl9kZXB0aF9fJyxcbiAgICAgIDEgKyAvLyAxIGZvciBjb250ZXh0LmlucHV0ICsgdGhlIG5vcm1hbCBub3JtYWxpemF0aW9uIGRlcHRoXG4gICAgICAgIChjbGllbnRPcHRpb25zPy5ub3JtYWxpemVEZXB0aCA/PyA1KSwgLy8gNSBpcyBhIHNhbmUgZGVwdGhcbiAgICApO1xuXG4gICAgaWYgKG9wdGlvbnMuYXR0YWNoUnBjSW5wdXQgIT09IHVuZGVmaW5lZCA/IG9wdGlvbnMuYXR0YWNoUnBjSW5wdXQgOiBjbGllbnRPcHRpb25zPy5zZW5kRGVmYXVsdFBpaSkge1xuICAgICAgaWYgKHJhd0lucHV0ICE9PSB1bmRlZmluZWQpIHtcbiAgICAgICAgdHJwY0NvbnRleHQuaW5wdXQgPSBub3JtYWxpemUubm9ybWFsaXplKHJhd0lucHV0KTtcbiAgICAgIH1cblxuICAgICAgaWYgKGdldFJhd0lucHV0ICE9PSB1bmRlZmluZWQgJiYgdHlwZW9mIGdldFJhd0lucHV0ID09PSAnZnVuY3Rpb24nKSB7XG4gICAgICAgIHRyeSB7XG4gICAgICAgICAgY29uc3QgcmF3UmVzID0gYXdhaXQgZ2V0UmF3SW5wdXQoKTtcblxuICAgICAgICAgIHRycGNDb250ZXh0LmlucHV0ID0gbm9ybWFsaXplLm5vcm1hbGl6ZShyYXdSZXMpO1xuICAgICAgICB9IGNhdGNoIHtcbiAgICAgICAgICAvLyBub29wXG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9XG5cbiAgICByZXR1cm4gY3VycmVudFNjb3Blcy53aXRoSXNvbGF0aW9uU2NvcGUoc2NvcGUgPT4ge1xuICAgICAgc2NvcGUuc2V0Q29udGV4dCgndHJwYycsIHRycGNDb250ZXh0KTtcbiAgICAgIHJldHVybiB0cmFjZS5zdGFydFNwYW5NYW51YWwoXG4gICAgICAgIHtcbiAgICAgICAgICBuYW1lOiBgdHJwYy8ke3BhdGh9YCxcbiAgICAgICAgICBvcDogJ3JwYy5zZXJ2ZXInLFxuICAgICAgICAgIGF0dHJpYnV0ZXM6IHtcbiAgICAgICAgICAgIFtzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9TT1VSQ0VdOiAncm91dGUnLFxuICAgICAgICAgICAgW3NlbWFudGljQXR0cmlidXRlcy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX09SSUdJTl06ICdhdXRvLnJwYy50cnBjJyxcbiAgICAgICAgICB9LFxuICAgICAgICAgIGZvcmNlVHJhbnNhY3Rpb246ICEhb3B0aW9ucy5mb3JjZVRyYW5zYWN0aW9uLFxuICAgICAgICB9LFxuICAgICAgICBhc3luYyBzcGFuID0+IHtcbiAgICAgICAgICB0cnkge1xuICAgICAgICAgICAgY29uc3QgbmV4dFJlc3VsdCA9IGF3YWl0IG5leHQoKTtcbiAgICAgICAgICAgIGNhcHR1cmVJZkVycm9yKG5leHRSZXN1bHQpO1xuICAgICAgICAgICAgc3Bhbi5lbmQoKTtcbiAgICAgICAgICAgIHJldHVybiBuZXh0UmVzdWx0O1xuICAgICAgICAgIH0gY2F0Y2ggKGUpIHtcbiAgICAgICAgICAgIGV4cG9ydHMkMS5jYXB0dXJlRXhjZXB0aW9uKGUsIHRycGNDYXB0dXJlQ29udGV4dCk7XG4gICAgICAgICAgICBzcGFuLmVuZCgpO1xuICAgICAgICAgICAgdGhyb3cgZTtcbiAgICAgICAgICB9XG4gICAgICAgIH0sXG4gICAgICApIDtcbiAgICB9KTtcbiAgfTtcbn1cblxuZXhwb3J0cy50cnBjTWlkZGxld2FyZSA9IHRycGNNaWRkbGV3YXJlO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9dHJwYy5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/trpc.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/aggregate-errors.js":
/*!**************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/aggregate-errors.js ***!
  \**************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst is = __webpack_require__(/*! ./is.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js\");\n\n/**\n * Creates exceptions inside `event.exception.values` for errors that are nested on properties based on the `key` parameter.\n */\nfunction applyAggregateErrorsToEvent(\n  exceptionFromErrorImplementation,\n  parser,\n  key,\n  limit,\n  event,\n  hint,\n) {\n  if (!event.exception?.values || !hint || !is.isInstanceOf(hint.originalException, Error)) {\n    return;\n  }\n\n  // Generally speaking the last item in `event.exception.values` is the exception originating from the original Error\n  const originalException =\n    event.exception.values.length > 0 ? event.exception.values[event.exception.values.length - 1] : undefined;\n\n  // We only create exception grouping if there is an exception in the event.\n  if (originalException) {\n    event.exception.values = aggregateExceptionsFromError(\n      exceptionFromErrorImplementation,\n      parser,\n      limit,\n      hint.originalException ,\n      key,\n      event.exception.values,\n      originalException,\n      0,\n    );\n  }\n}\n\nfunction aggregateExceptionsFromError(\n  exceptionFromErrorImplementation,\n  parser,\n  limit,\n  error,\n  key,\n  prevExceptions,\n  exception,\n  exceptionId,\n) {\n  if (prevExceptions.length >= limit + 1) {\n    return prevExceptions;\n  }\n\n  let newExceptions = [...prevExceptions];\n\n  // Recursively call this function in order to walk down a chain of errors\n  if (is.isInstanceOf(error[key], Error)) {\n    applyExceptionGroupFieldsForParentException(exception, exceptionId);\n    const newException = exceptionFromErrorImplementation(parser, error[key]);\n    const newExceptionId = newExceptions.length;\n    applyExceptionGroupFieldsForChildException(newException, key, newExceptionId, exceptionId);\n    newExceptions = aggregateExceptionsFromError(\n      exceptionFromErrorImplementation,\n      parser,\n      limit,\n      error[key],\n      key,\n      [newException, ...newExceptions],\n      newException,\n      newExceptionId,\n    );\n  }\n\n  // This will create exception grouping for AggregateErrors\n  // https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/AggregateError\n  if (Array.isArray(error.errors)) {\n    error.errors.forEach((childError, i) => {\n      if (is.isInstanceOf(childError, Error)) {\n        applyExceptionGroupFieldsForParentException(exception, exceptionId);\n        const newException = exceptionFromErrorImplementation(parser, childError);\n        const newExceptionId = newExceptions.length;\n        applyExceptionGroupFieldsForChildException(newException, `errors[${i}]`, newExceptionId, exceptionId);\n        newExceptions = aggregateExceptionsFromError(\n          exceptionFromErrorImplementation,\n          parser,\n          limit,\n          childError,\n          key,\n          [newException, ...newExceptions],\n          newException,\n          newExceptionId,\n        );\n      }\n    });\n  }\n\n  return newExceptions;\n}\n\nfunction applyExceptionGroupFieldsForParentException(exception, exceptionId) {\n  // Don't know if this default makes sense. The protocol requires us to set these values so we pick *some* default.\n  exception.mechanism = exception.mechanism || { type: 'generic', handled: true };\n\n  exception.mechanism = {\n    ...exception.mechanism,\n    ...(exception.type === 'AggregateError' && { is_exception_group: true }),\n    exception_id: exceptionId,\n  };\n}\n\nfunction applyExceptionGroupFieldsForChildException(\n  exception,\n  source,\n  exceptionId,\n  parentId,\n) {\n  // Don't know if this default makes sense. The protocol requires us to set these values so we pick *some* default.\n  exception.mechanism = exception.mechanism || { type: 'generic', handled: true };\n\n  exception.mechanism = {\n    ...exception.mechanism,\n    type: 'chained',\n    source,\n    exception_id: exceptionId,\n    parent_id: parentId,\n  };\n}\n\nexports.applyAggregateErrorsToEvent = applyAggregateErrorsToEvent;\n//# sourceMappingURL=aggregate-errors.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvYWdncmVnYXRlLWVycm9ycy5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxXQUFXLG1CQUFPLENBQUMsc0hBQVM7O0FBRTVCO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsMkVBQTJFLEVBQUU7QUFDN0U7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEtBQUs7QUFDTDs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQSxpREFBaUQ7O0FBRWpEO0FBQ0E7QUFDQSxpREFBaUQsMEJBQTBCO0FBQzNFO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGlEQUFpRDs7QUFFakQ7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSxtQ0FBbUM7QUFDbkMiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9hZ2dyZWdhdGUtZXJyb3JzLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBpcyA9IHJlcXVpcmUoJy4vaXMuanMnKTtcblxuLyoqXG4gKiBDcmVhdGVzIGV4Y2VwdGlvbnMgaW5zaWRlIGBldmVudC5leGNlcHRpb24udmFsdWVzYCBmb3IgZXJyb3JzIHRoYXQgYXJlIG5lc3RlZCBvbiBwcm9wZXJ0aWVzIGJhc2VkIG9uIHRoZSBga2V5YCBwYXJhbWV0ZXIuXG4gKi9cbmZ1bmN0aW9uIGFwcGx5QWdncmVnYXRlRXJyb3JzVG9FdmVudChcbiAgZXhjZXB0aW9uRnJvbUVycm9ySW1wbGVtZW50YXRpb24sXG4gIHBhcnNlcixcbiAga2V5LFxuICBsaW1pdCxcbiAgZXZlbnQsXG4gIGhpbnQsXG4pIHtcbiAgaWYgKCFldmVudC5leGNlcHRpb24/LnZhbHVlcyB8fCAhaGludCB8fCAhaXMuaXNJbnN0YW5jZU9mKGhpbnQub3JpZ2luYWxFeGNlcHRpb24sIEVycm9yKSkge1xuICAgIHJldHVybjtcbiAgfVxuXG4gIC8vIEdlbmVyYWxseSBzcGVha2luZyB0aGUgbGFzdCBpdGVtIGluIGBldmVudC5leGNlcHRpb24udmFsdWVzYCBpcyB0aGUgZXhjZXB0aW9uIG9yaWdpbmF0aW5nIGZyb20gdGhlIG9yaWdpbmFsIEVycm9yXG4gIGNvbnN0IG9yaWdpbmFsRXhjZXB0aW9uID1cbiAgICBldmVudC5leGNlcHRpb24udmFsdWVzLmxlbmd0aCA+IDAgPyBldmVudC5leGNlcHRpb24udmFsdWVzW2V2ZW50LmV4Y2VwdGlvbi52YWx1ZXMubGVuZ3RoIC0gMV0gOiB1bmRlZmluZWQ7XG5cbiAgLy8gV2Ugb25seSBjcmVhdGUgZXhjZXB0aW9uIGdyb3VwaW5nIGlmIHRoZXJlIGlzIGFuIGV4Y2VwdGlvbiBpbiB0aGUgZXZlbnQuXG4gIGlmIChvcmlnaW5hbEV4Y2VwdGlvbikge1xuICAgIGV2ZW50LmV4Y2VwdGlvbi52YWx1ZXMgPSBhZ2dyZWdhdGVFeGNlcHRpb25zRnJvbUVycm9yKFxuICAgICAgZXhjZXB0aW9uRnJvbUVycm9ySW1wbGVtZW50YXRpb24sXG4gICAgICBwYXJzZXIsXG4gICAgICBsaW1pdCxcbiAgICAgIGhpbnQub3JpZ2luYWxFeGNlcHRpb24gLFxuICAgICAga2V5LFxuICAgICAgZXZlbnQuZXhjZXB0aW9uLnZhbHVlcyxcbiAgICAgIG9yaWdpbmFsRXhjZXB0aW9uLFxuICAgICAgMCxcbiAgICApO1xuICB9XG59XG5cbmZ1bmN0aW9uIGFnZ3JlZ2F0ZUV4Y2VwdGlvbnNGcm9tRXJyb3IoXG4gIGV4Y2VwdGlvbkZyb21FcnJvckltcGxlbWVudGF0aW9uLFxuICBwYXJzZXIsXG4gIGxpbWl0LFxuICBlcnJvcixcbiAga2V5LFxuICBwcmV2RXhjZXB0aW9ucyxcbiAgZXhjZXB0aW9uLFxuICBleGNlcHRpb25JZCxcbikge1xuICBpZiAocHJldkV4Y2VwdGlvbnMubGVuZ3RoID49IGxpbWl0ICsgMSkge1xuICAgIHJldHVybiBwcmV2RXhjZXB0aW9ucztcbiAgfVxuXG4gIGxldCBuZXdFeGNlcHRpb25zID0gWy4uLnByZXZFeGNlcHRpb25zXTtcblxuICAvLyBSZWN1cnNpdmVseSBjYWxsIHRoaXMgZnVuY3Rpb24gaW4gb3JkZXIgdG8gd2FsayBkb3duIGEgY2hhaW4gb2YgZXJyb3JzXG4gIGlmIChpcy5pc0luc3RhbmNlT2YoZXJyb3Jba2V5XSwgRXJyb3IpKSB7XG4gICAgYXBwbHlFeGNlcHRpb25Hcm91cEZpZWxkc0ZvclBhcmVudEV4Y2VwdGlvbihleGNlcHRpb24sIGV4Y2VwdGlvbklkKTtcbiAgICBjb25zdCBuZXdFeGNlcHRpb24gPSBleGNlcHRpb25Gcm9tRXJyb3JJbXBsZW1lbnRhdGlvbihwYXJzZXIsIGVycm9yW2tleV0pO1xuICAgIGNvbnN0IG5ld0V4Y2VwdGlvbklkID0gbmV3RXhjZXB0aW9ucy5sZW5ndGg7XG4gICAgYXBwbHlFeGNlcHRpb25Hcm91cEZpZWxkc0ZvckNoaWxkRXhjZXB0aW9uKG5ld0V4Y2VwdGlvbiwga2V5LCBuZXdFeGNlcHRpb25JZCwgZXhjZXB0aW9uSWQpO1xuICAgIG5ld0V4Y2VwdGlvbnMgPSBhZ2dyZWdhdGVFeGNlcHRpb25zRnJvbUVycm9yKFxuICAgICAgZXhjZXB0aW9uRnJvbUVycm9ySW1wbGVtZW50YXRpb24sXG4gICAgICBwYXJzZXIsXG4gICAgICBsaW1pdCxcbiAgICAgIGVycm9yW2tleV0sXG4gICAgICBrZXksXG4gICAgICBbbmV3RXhjZXB0aW9uLCAuLi5uZXdFeGNlcHRpb25zXSxcbiAgICAgIG5ld0V4Y2VwdGlvbixcbiAgICAgIG5ld0V4Y2VwdGlvbklkLFxuICAgICk7XG4gIH1cblxuICAvLyBUaGlzIHdpbGwgY3JlYXRlIGV4Y2VwdGlvbiBncm91cGluZyBmb3IgQWdncmVnYXRlRXJyb3JzXG4gIC8vIGh0dHBzOi8vZGV2ZWxvcGVyLm1vemlsbGEub3JnL2VuLVVTL2RvY3MvV2ViL0phdmFTY3JpcHQvUmVmZXJlbmNlL0dsb2JhbF9PYmplY3RzL0FnZ3JlZ2F0ZUVycm9yXG4gIGlmIChBcnJheS5pc0FycmF5KGVycm9yLmVycm9ycykpIHtcbiAgICBlcnJvci5lcnJvcnMuZm9yRWFjaCgoY2hpbGRFcnJvciwgaSkgPT4ge1xuICAgICAgaWYgKGlzLmlzSW5zdGFuY2VPZihjaGlsZEVycm9yLCBFcnJvcikpIHtcbiAgICAgICAgYXBwbHlFeGNlcHRpb25Hcm91cEZpZWxkc0ZvclBhcmVudEV4Y2VwdGlvbihleGNlcHRpb24sIGV4Y2VwdGlvbklkKTtcbiAgICAgICAgY29uc3QgbmV3RXhjZXB0aW9uID0gZXhjZXB0aW9uRnJvbUVycm9ySW1wbGVtZW50YXRpb24ocGFyc2VyLCBjaGlsZEVycm9yKTtcbiAgICAgICAgY29uc3QgbmV3RXhjZXB0aW9uSWQgPSBuZXdFeGNlcHRpb25zLmxlbmd0aDtcbiAgICAgICAgYXBwbHlFeGNlcHRpb25Hcm91cEZpZWxkc0ZvckNoaWxkRXhjZXB0aW9uKG5ld0V4Y2VwdGlvbiwgYGVycm9yc1ske2l9XWAsIG5ld0V4Y2VwdGlvbklkLCBleGNlcHRpb25JZCk7XG4gICAgICAgIG5ld0V4Y2VwdGlvbnMgPSBhZ2dyZWdhdGVFeGNlcHRpb25zRnJvbUVycm9yKFxuICAgICAgICAgIGV4Y2VwdGlvbkZyb21FcnJvckltcGxlbWVudGF0aW9uLFxuICAgICAgICAgIHBhcnNlcixcbiAgICAgICAgICBsaW1pdCxcbiAgICAgICAgICBjaGlsZEVycm9yLFxuICAgICAgICAgIGtleSxcbiAgICAgICAgICBbbmV3RXhjZXB0aW9uLCAuLi5uZXdFeGNlcHRpb25zXSxcbiAgICAgICAgICBuZXdFeGNlcHRpb24sXG4gICAgICAgICAgbmV3RXhjZXB0aW9uSWQsXG4gICAgICAgICk7XG4gICAgICB9XG4gICAgfSk7XG4gIH1cblxuICByZXR1cm4gbmV3RXhjZXB0aW9ucztcbn1cblxuZnVuY3Rpb24gYXBwbHlFeGNlcHRpb25Hcm91cEZpZWxkc0ZvclBhcmVudEV4Y2VwdGlvbihleGNlcHRpb24sIGV4Y2VwdGlvbklkKSB7XG4gIC8vIERvbid0IGtub3cgaWYgdGhpcyBkZWZhdWx0IG1ha2VzIHNlbnNlLiBUaGUgcHJvdG9jb2wgcmVxdWlyZXMgdXMgdG8gc2V0IHRoZXNlIHZhbHVlcyBzbyB3ZSBwaWNrICpzb21lKiBkZWZhdWx0LlxuICBleGNlcHRpb24ubWVjaGFuaXNtID0gZXhjZXB0aW9uLm1lY2hhbmlzbSB8fCB7IHR5cGU6ICdnZW5lcmljJywgaGFuZGxlZDogdHJ1ZSB9O1xuXG4gIGV4Y2VwdGlvbi5tZWNoYW5pc20gPSB7XG4gICAgLi4uZXhjZXB0aW9uLm1lY2hhbmlzbSxcbiAgICAuLi4oZXhjZXB0aW9uLnR5cGUgPT09ICdBZ2dyZWdhdGVFcnJvcicgJiYgeyBpc19leGNlcHRpb25fZ3JvdXA6IHRydWUgfSksXG4gICAgZXhjZXB0aW9uX2lkOiBleGNlcHRpb25JZCxcbiAgfTtcbn1cblxuZnVuY3Rpb24gYXBwbHlFeGNlcHRpb25Hcm91cEZpZWxkc0ZvckNoaWxkRXhjZXB0aW9uKFxuICBleGNlcHRpb24sXG4gIHNvdXJjZSxcbiAgZXhjZXB0aW9uSWQsXG4gIHBhcmVudElkLFxuKSB7XG4gIC8vIERvbid0IGtub3cgaWYgdGhpcyBkZWZhdWx0IG1ha2VzIHNlbnNlLiBUaGUgcHJvdG9jb2wgcmVxdWlyZXMgdXMgdG8gc2V0IHRoZXNlIHZhbHVlcyBzbyB3ZSBwaWNrICpzb21lKiBkZWZhdWx0LlxuICBleGNlcHRpb24ubWVjaGFuaXNtID0gZXhjZXB0aW9uLm1lY2hhbmlzbSB8fCB7IHR5cGU6ICdnZW5lcmljJywgaGFuZGxlZDogdHJ1ZSB9O1xuXG4gIGV4Y2VwdGlvbi5tZWNoYW5pc20gPSB7XG4gICAgLi4uZXhjZXB0aW9uLm1lY2hhbmlzbSxcbiAgICB0eXBlOiAnY2hhaW5lZCcsXG4gICAgc291cmNlLFxuICAgIGV4Y2VwdGlvbl9pZDogZXhjZXB0aW9uSWQsXG4gICAgcGFyZW50X2lkOiBwYXJlbnRJZCxcbiAgfTtcbn1cblxuZXhwb3J0cy5hcHBseUFnZ3JlZ2F0ZUVycm9yc1RvRXZlbnQgPSBhcHBseUFnZ3JlZ2F0ZUVycm9yc1RvRXZlbnQ7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1hZ2dyZWdhdGUtZXJyb3JzLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/aggregate-errors.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/anr.js":
/*!*************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/anr.js ***!
  \*************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst nodeStackTrace = __webpack_require__(/*! ./node-stack-trace.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/node-stack-trace.js\");\nconst stacktrace = __webpack_require__(/*! ./stacktrace.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/stacktrace.js\");\n\n/**\n * A node.js watchdog timer\n * @param pollInterval The interval that we expect to get polled at\n * @param anrThreshold The threshold for when we consider ANR\n * @param callback The callback to call for ANR\n * @returns An object with `poll` and `enabled` functions {@link WatchdogReturn}\n */\nfunction watchdogTimer(\n  createTimer,\n  pollInterval,\n  anrThreshold,\n  callback,\n) {\n  const timer = createTimer();\n  let triggered = false;\n  let enabled = true;\n\n  setInterval(() => {\n    const diffMs = timer.getTimeMs();\n\n    if (triggered === false && diffMs > pollInterval + anrThreshold) {\n      triggered = true;\n      if (enabled) {\n        callback();\n      }\n    }\n\n    if (diffMs < pollInterval + anrThreshold) {\n      triggered = false;\n    }\n  }, 20);\n\n  return {\n    poll: () => {\n      timer.reset();\n    },\n    enabled: (state) => {\n      enabled = state;\n    },\n  };\n}\n\n// types copied from inspector.d.ts\n\n/**\n * Converts Debugger.CallFrame to Sentry StackFrame\n */\nfunction callFrameToStackFrame(\n  frame,\n  url,\n  getModuleFromFilename,\n) {\n  const filename = url ? url.replace(/^file:\\/\\//, '') : undefined;\n\n  // CallFrame row/col are 0 based, whereas StackFrame are 1 based\n  const colno = frame.location.columnNumber ? frame.location.columnNumber + 1 : undefined;\n  const lineno = frame.location.lineNumber ? frame.location.lineNumber + 1 : undefined;\n\n  return {\n    filename,\n    module: getModuleFromFilename(filename),\n    function: frame.functionName || stacktrace.UNKNOWN_FUNCTION,\n    colno,\n    lineno,\n    in_app: filename ? nodeStackTrace.filenameIsInApp(filename) : undefined,\n  };\n}\n\nexports.callFrameToStackFrame = callFrameToStackFrame;\nexports.watchdogTimer = watchdogTimer;\n//# sourceMappingURL=anr.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvYW5yLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLHVCQUF1QixtQkFBTyxDQUFDLGtKQUF1QjtBQUN0RCxtQkFBbUIsbUJBQU8sQ0FBQyxzSUFBaUI7O0FBRTVDO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSwyREFBMkQ7QUFDM0Q7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0EsR0FBRzs7QUFFSDtBQUNBO0FBQ0E7QUFDQSxLQUFLO0FBQ0w7QUFDQTtBQUNBLEtBQUs7QUFDTDtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLDZCQUE2QjtBQUM3QixxQkFBcUI7QUFDckIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9hbnIuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IG5vZGVTdGFja1RyYWNlID0gcmVxdWlyZSgnLi9ub2RlLXN0YWNrLXRyYWNlLmpzJyk7XG5jb25zdCBzdGFja3RyYWNlID0gcmVxdWlyZSgnLi9zdGFja3RyYWNlLmpzJyk7XG5cbi8qKlxuICogQSBub2RlLmpzIHdhdGNoZG9nIHRpbWVyXG4gKiBAcGFyYW0gcG9sbEludGVydmFsIFRoZSBpbnRlcnZhbCB0aGF0IHdlIGV4cGVjdCB0byBnZXQgcG9sbGVkIGF0XG4gKiBAcGFyYW0gYW5yVGhyZXNob2xkIFRoZSB0aHJlc2hvbGQgZm9yIHdoZW4gd2UgY29uc2lkZXIgQU5SXG4gKiBAcGFyYW0gY2FsbGJhY2sgVGhlIGNhbGxiYWNrIHRvIGNhbGwgZm9yIEFOUlxuICogQHJldHVybnMgQW4gb2JqZWN0IHdpdGggYHBvbGxgIGFuZCBgZW5hYmxlZGAgZnVuY3Rpb25zIHtAbGluayBXYXRjaGRvZ1JldHVybn1cbiAqL1xuZnVuY3Rpb24gd2F0Y2hkb2dUaW1lcihcbiAgY3JlYXRlVGltZXIsXG4gIHBvbGxJbnRlcnZhbCxcbiAgYW5yVGhyZXNob2xkLFxuICBjYWxsYmFjayxcbikge1xuICBjb25zdCB0aW1lciA9IGNyZWF0ZVRpbWVyKCk7XG4gIGxldCB0cmlnZ2VyZWQgPSBmYWxzZTtcbiAgbGV0IGVuYWJsZWQgPSB0cnVlO1xuXG4gIHNldEludGVydmFsKCgpID0+IHtcbiAgICBjb25zdCBkaWZmTXMgPSB0aW1lci5nZXRUaW1lTXMoKTtcblxuICAgIGlmICh0cmlnZ2VyZWQgPT09IGZhbHNlICYmIGRpZmZNcyA+IHBvbGxJbnRlcnZhbCArIGFuclRocmVzaG9sZCkge1xuICAgICAgdHJpZ2dlcmVkID0gdHJ1ZTtcbiAgICAgIGlmIChlbmFibGVkKSB7XG4gICAgICAgIGNhbGxiYWNrKCk7XG4gICAgICB9XG4gICAgfVxuXG4gICAgaWYgKGRpZmZNcyA8IHBvbGxJbnRlcnZhbCArIGFuclRocmVzaG9sZCkge1xuICAgICAgdHJpZ2dlcmVkID0gZmFsc2U7XG4gICAgfVxuICB9LCAyMCk7XG5cbiAgcmV0dXJuIHtcbiAgICBwb2xsOiAoKSA9PiB7XG4gICAgICB0aW1lci5yZXNldCgpO1xuICAgIH0sXG4gICAgZW5hYmxlZDogKHN0YXRlKSA9PiB7XG4gICAgICBlbmFibGVkID0gc3RhdGU7XG4gICAgfSxcbiAgfTtcbn1cblxuLy8gdHlwZXMgY29waWVkIGZyb20gaW5zcGVjdG9yLmQudHNcblxuLyoqXG4gKiBDb252ZXJ0cyBEZWJ1Z2dlci5DYWxsRnJhbWUgdG8gU2VudHJ5IFN0YWNrRnJhbWVcbiAqL1xuZnVuY3Rpb24gY2FsbEZyYW1lVG9TdGFja0ZyYW1lKFxuICBmcmFtZSxcbiAgdXJsLFxuICBnZXRNb2R1bGVGcm9tRmlsZW5hbWUsXG4pIHtcbiAgY29uc3QgZmlsZW5hbWUgPSB1cmwgPyB1cmwucmVwbGFjZSgvXmZpbGU6XFwvXFwvLywgJycpIDogdW5kZWZpbmVkO1xuXG4gIC8vIENhbGxGcmFtZSByb3cvY29sIGFyZSAwIGJhc2VkLCB3aGVyZWFzIFN0YWNrRnJhbWUgYXJlIDEgYmFzZWRcbiAgY29uc3QgY29sbm8gPSBmcmFtZS5sb2NhdGlvbi5jb2x1bW5OdW1iZXIgPyBmcmFtZS5sb2NhdGlvbi5jb2x1bW5OdW1iZXIgKyAxIDogdW5kZWZpbmVkO1xuICBjb25zdCBsaW5lbm8gPSBmcmFtZS5sb2NhdGlvbi5saW5lTnVtYmVyID8gZnJhbWUubG9jYXRpb24ubGluZU51bWJlciArIDEgOiB1bmRlZmluZWQ7XG5cbiAgcmV0dXJuIHtcbiAgICBmaWxlbmFtZSxcbiAgICBtb2R1bGU6IGdldE1vZHVsZUZyb21GaWxlbmFtZShmaWxlbmFtZSksXG4gICAgZnVuY3Rpb246IGZyYW1lLmZ1bmN0aW9uTmFtZSB8fCBzdGFja3RyYWNlLlVOS05PV05fRlVOQ1RJT04sXG4gICAgY29sbm8sXG4gICAgbGluZW5vLFxuICAgIGluX2FwcDogZmlsZW5hbWUgPyBub2RlU3RhY2tUcmFjZS5maWxlbmFtZUlzSW5BcHAoZmlsZW5hbWUpIDogdW5kZWZpbmVkLFxuICB9O1xufVxuXG5leHBvcnRzLmNhbGxGcmFtZVRvU3RhY2tGcmFtZSA9IGNhbGxGcmFtZVRvU3RhY2tGcmFtZTtcbmV4cG9ydHMud2F0Y2hkb2dUaW1lciA9IHdhdGNoZG9nVGltZXI7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1hbnIuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/anr.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/applyScopeDataToEvent.js":
/*!*******************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/applyScopeDataToEvent.js ***!
  \*******************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst dynamicSamplingContext = __webpack_require__(/*! ../tracing/dynamicSamplingContext.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/dynamicSamplingContext.js\");\nconst merge = __webpack_require__(/*! ./merge.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/merge.js\");\nconst spanUtils = __webpack_require__(/*! ./spanUtils.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanUtils.js\");\n\n/**\n * Applies data from the scope to the event and runs all event processors on it.\n */\nfunction applyScopeDataToEvent(event, data) {\n  const { fingerprint, span, breadcrumbs, sdkProcessingMetadata } = data;\n\n  // Apply general data\n  applyDataToEvent(event, data);\n\n  // We want to set the trace context for normal events only if there isn't already\n  // a trace context on the event. There is a product feature in place where we link\n  // errors with transaction and it relies on that.\n  if (span) {\n    applySpanToEvent(event, span);\n  }\n\n  applyFingerprintToEvent(event, fingerprint);\n  applyBreadcrumbsToEvent(event, breadcrumbs);\n  applySdkMetadataToEvent(event, sdkProcessingMetadata);\n}\n\n/** Merge data of two scopes together. */\nfunction mergeScopeData(data, mergeData) {\n  const {\n    extra,\n    tags,\n    user,\n    contexts,\n    level,\n    sdkProcessingMetadata,\n    breadcrumbs,\n    fingerprint,\n    eventProcessors,\n    attachments,\n    propagationContext,\n    transactionName,\n    span,\n  } = mergeData;\n\n  mergeAndOverwriteScopeData(data, 'extra', extra);\n  mergeAndOverwriteScopeData(data, 'tags', tags);\n  mergeAndOverwriteScopeData(data, 'user', user);\n  mergeAndOverwriteScopeData(data, 'contexts', contexts);\n\n  data.sdkProcessingMetadata = merge.merge(data.sdkProcessingMetadata, sdkProcessingMetadata, 2);\n\n  if (level) {\n    data.level = level;\n  }\n\n  if (transactionName) {\n    data.transactionName = transactionName;\n  }\n\n  if (span) {\n    data.span = span;\n  }\n\n  if (breadcrumbs.length) {\n    data.breadcrumbs = [...data.breadcrumbs, ...breadcrumbs];\n  }\n\n  if (fingerprint.length) {\n    data.fingerprint = [...data.fingerprint, ...fingerprint];\n  }\n\n  if (eventProcessors.length) {\n    data.eventProcessors = [...data.eventProcessors, ...eventProcessors];\n  }\n\n  if (attachments.length) {\n    data.attachments = [...data.attachments, ...attachments];\n  }\n\n  data.propagationContext = { ...data.propagationContext, ...propagationContext };\n}\n\n/**\n * Merges certain scope data. Undefined values will overwrite any existing values.\n * Exported only for tests.\n */\nfunction mergeAndOverwriteScopeData\n\n(data, prop, mergeVal) {\n  data[prop] = merge.merge(data[prop], mergeVal, 1);\n}\n\nfunction applyDataToEvent(event, data) {\n  const { extra, tags, user, contexts, level, transactionName } = data;\n\n  if (Object.keys(extra).length) {\n    event.extra = { ...extra, ...event.extra };\n  }\n\n  if (Object.keys(tags).length) {\n    event.tags = { ...tags, ...event.tags };\n  }\n\n  if (Object.keys(user).length) {\n    event.user = { ...user, ...event.user };\n  }\n\n  if (Object.keys(contexts).length) {\n    event.contexts = { ...contexts, ...event.contexts };\n  }\n\n  if (level) {\n    event.level = level;\n  }\n\n  // transaction events get their `transaction` from the root span name\n  if (transactionName && event.type !== 'transaction') {\n    event.transaction = transactionName;\n  }\n}\n\nfunction applyBreadcrumbsToEvent(event, breadcrumbs) {\n  const mergedBreadcrumbs = [...(event.breadcrumbs || []), ...breadcrumbs];\n  event.breadcrumbs = mergedBreadcrumbs.length ? mergedBreadcrumbs : undefined;\n}\n\nfunction applySdkMetadataToEvent(event, sdkProcessingMetadata) {\n  event.sdkProcessingMetadata = {\n    ...event.sdkProcessingMetadata,\n    ...sdkProcessingMetadata,\n  };\n}\n\nfunction applySpanToEvent(event, span) {\n  event.contexts = {\n    trace: spanUtils.spanToTraceContext(span),\n    ...event.contexts,\n  };\n\n  event.sdkProcessingMetadata = {\n    dynamicSamplingContext: dynamicSamplingContext.getDynamicSamplingContextFromSpan(span),\n    ...event.sdkProcessingMetadata,\n  };\n\n  const rootSpan = spanUtils.getRootSpan(span);\n  const transactionName = spanUtils.spanToJSON(rootSpan).description;\n  if (transactionName && !event.transaction && event.type === 'transaction') {\n    event.transaction = transactionName;\n  }\n}\n\n/**\n * Applies fingerprint from the scope to the event if there's one,\n * uses message if there's one instead or get rid of empty fingerprint\n */\nfunction applyFingerprintToEvent(event, fingerprint) {\n  // Make sure it's an array first and we actually have something in place\n  event.fingerprint = event.fingerprint\n    ? Array.isArray(event.fingerprint)\n      ? event.fingerprint\n      : [event.fingerprint]\n    : [];\n\n  // If we have something on the scope, then merge it with event\n  if (fingerprint) {\n    event.fingerprint = event.fingerprint.concat(fingerprint);\n  }\n\n  // If we have no data at all, remove empty array default\n  if (!event.fingerprint.length) {\n    delete event.fingerprint;\n  }\n}\n\nexports.applyScopeDataToEvent = applyScopeDataToEvent;\nexports.mergeAndOverwriteScopeData = mergeAndOverwriteScopeData;\nexports.mergeScopeData = mergeScopeData;\n//# sourceMappingURL=applyScopeDataToEvent.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvYXBwbHlTY29wZURhdGFUb0V2ZW50LmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLCtCQUErQixtQkFBTyxDQUFDLHlLQUFzQztBQUM3RSxjQUFjLG1CQUFPLENBQUMsNEhBQVk7QUFDbEMsa0JBQWtCLG1CQUFPLENBQUMsb0lBQWdCOztBQUUxQztBQUNBO0FBQ0E7QUFDQTtBQUNBLFVBQVUsd0RBQXdEOztBQUVsRTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLElBQUk7O0FBRUo7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBLDhCQUE4QjtBQUM5Qjs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBLFVBQVUsc0RBQXNEOztBQUVoRTtBQUNBLG9CQUFvQjtBQUNwQjs7QUFFQTtBQUNBLG1CQUFtQjtBQUNuQjs7QUFFQTtBQUNBLG1CQUFtQjtBQUNuQjs7QUFFQTtBQUNBLHVCQUF1QjtBQUN2Qjs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLDZCQUE2QjtBQUM3QixrQ0FBa0M7QUFDbEMsc0JBQXNCO0FBQ3RCIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvYXBwbHlTY29wZURhdGFUb0V2ZW50LmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBkeW5hbWljU2FtcGxpbmdDb250ZXh0ID0gcmVxdWlyZSgnLi4vdHJhY2luZy9keW5hbWljU2FtcGxpbmdDb250ZXh0LmpzJyk7XG5jb25zdCBtZXJnZSA9IHJlcXVpcmUoJy4vbWVyZ2UuanMnKTtcbmNvbnN0IHNwYW5VdGlscyA9IHJlcXVpcmUoJy4vc3BhblV0aWxzLmpzJyk7XG5cbi8qKlxuICogQXBwbGllcyBkYXRhIGZyb20gdGhlIHNjb3BlIHRvIHRoZSBldmVudCBhbmQgcnVucyBhbGwgZXZlbnQgcHJvY2Vzc29ycyBvbiBpdC5cbiAqL1xuZnVuY3Rpb24gYXBwbHlTY29wZURhdGFUb0V2ZW50KGV2ZW50LCBkYXRhKSB7XG4gIGNvbnN0IHsgZmluZ2VycHJpbnQsIHNwYW4sIGJyZWFkY3J1bWJzLCBzZGtQcm9jZXNzaW5nTWV0YWRhdGEgfSA9IGRhdGE7XG5cbiAgLy8gQXBwbHkgZ2VuZXJhbCBkYXRhXG4gIGFwcGx5RGF0YVRvRXZlbnQoZXZlbnQsIGRhdGEpO1xuXG4gIC8vIFdlIHdhbnQgdG8gc2V0IHRoZSB0cmFjZSBjb250ZXh0IGZvciBub3JtYWwgZXZlbnRzIG9ubHkgaWYgdGhlcmUgaXNuJ3QgYWxyZWFkeVxuICAvLyBhIHRyYWNlIGNvbnRleHQgb24gdGhlIGV2ZW50LiBUaGVyZSBpcyBhIHByb2R1Y3QgZmVhdHVyZSBpbiBwbGFjZSB3aGVyZSB3ZSBsaW5rXG4gIC8vIGVycm9ycyB3aXRoIHRyYW5zYWN0aW9uIGFuZCBpdCByZWxpZXMgb24gdGhhdC5cbiAgaWYgKHNwYW4pIHtcbiAgICBhcHBseVNwYW5Ub0V2ZW50KGV2ZW50LCBzcGFuKTtcbiAgfVxuXG4gIGFwcGx5RmluZ2VycHJpbnRUb0V2ZW50KGV2ZW50LCBmaW5nZXJwcmludCk7XG4gIGFwcGx5QnJlYWRjcnVtYnNUb0V2ZW50KGV2ZW50LCBicmVhZGNydW1icyk7XG4gIGFwcGx5U2RrTWV0YWRhdGFUb0V2ZW50KGV2ZW50LCBzZGtQcm9jZXNzaW5nTWV0YWRhdGEpO1xufVxuXG4vKiogTWVyZ2UgZGF0YSBvZiB0d28gc2NvcGVzIHRvZ2V0aGVyLiAqL1xuZnVuY3Rpb24gbWVyZ2VTY29wZURhdGEoZGF0YSwgbWVyZ2VEYXRhKSB7XG4gIGNvbnN0IHtcbiAgICBleHRyYSxcbiAgICB0YWdzLFxuICAgIHVzZXIsXG4gICAgY29udGV4dHMsXG4gICAgbGV2ZWwsXG4gICAgc2RrUHJvY2Vzc2luZ01ldGFkYXRhLFxuICAgIGJyZWFkY3J1bWJzLFxuICAgIGZpbmdlcnByaW50LFxuICAgIGV2ZW50UHJvY2Vzc29ycyxcbiAgICBhdHRhY2htZW50cyxcbiAgICBwcm9wYWdhdGlvbkNvbnRleHQsXG4gICAgdHJhbnNhY3Rpb25OYW1lLFxuICAgIHNwYW4sXG4gIH0gPSBtZXJnZURhdGE7XG5cbiAgbWVyZ2VBbmRPdmVyd3JpdGVTY29wZURhdGEoZGF0YSwgJ2V4dHJhJywgZXh0cmEpO1xuICBtZXJnZUFuZE92ZXJ3cml0ZVNjb3BlRGF0YShkYXRhLCAndGFncycsIHRhZ3MpO1xuICBtZXJnZUFuZE92ZXJ3cml0ZVNjb3BlRGF0YShkYXRhLCAndXNlcicsIHVzZXIpO1xuICBtZXJnZUFuZE92ZXJ3cml0ZVNjb3BlRGF0YShkYXRhLCAnY29udGV4dHMnLCBjb250ZXh0cyk7XG5cbiAgZGF0YS5zZGtQcm9jZXNzaW5nTWV0YWRhdGEgPSBtZXJnZS5tZXJnZShkYXRhLnNka1Byb2Nlc3NpbmdNZXRhZGF0YSwgc2RrUHJvY2Vzc2luZ01ldGFkYXRhLCAyKTtcblxuICBpZiAobGV2ZWwpIHtcbiAgICBkYXRhLmxldmVsID0gbGV2ZWw7XG4gIH1cblxuICBpZiAodHJhbnNhY3Rpb25OYW1lKSB7XG4gICAgZGF0YS50cmFuc2FjdGlvbk5hbWUgPSB0cmFuc2FjdGlvbk5hbWU7XG4gIH1cblxuICBpZiAoc3Bhbikge1xuICAgIGRhdGEuc3BhbiA9IHNwYW47XG4gIH1cblxuICBpZiAoYnJlYWRjcnVtYnMubGVuZ3RoKSB7XG4gICAgZGF0YS5icmVhZGNydW1icyA9IFsuLi5kYXRhLmJyZWFkY3J1bWJzLCAuLi5icmVhZGNydW1ic107XG4gIH1cblxuICBpZiAoZmluZ2VycHJpbnQubGVuZ3RoKSB7XG4gICAgZGF0YS5maW5nZXJwcmludCA9IFsuLi5kYXRhLmZpbmdlcnByaW50LCAuLi5maW5nZXJwcmludF07XG4gIH1cblxuICBpZiAoZXZlbnRQcm9jZXNzb3JzLmxlbmd0aCkge1xuICAgIGRhdGEuZXZlbnRQcm9jZXNzb3JzID0gWy4uLmRhdGEuZXZlbnRQcm9jZXNzb3JzLCAuLi5ldmVudFByb2Nlc3NvcnNdO1xuICB9XG5cbiAgaWYgKGF0dGFjaG1lbnRzLmxlbmd0aCkge1xuICAgIGRhdGEuYXR0YWNobWVudHMgPSBbLi4uZGF0YS5hdHRhY2htZW50cywgLi4uYXR0YWNobWVudHNdO1xuICB9XG5cbiAgZGF0YS5wcm9wYWdhdGlvbkNvbnRleHQgPSB7IC4uLmRhdGEucHJvcGFnYXRpb25Db250ZXh0LCAuLi5wcm9wYWdhdGlvbkNvbnRleHQgfTtcbn1cblxuLyoqXG4gKiBNZXJnZXMgY2VydGFpbiBzY29wZSBkYXRhLiBVbmRlZmluZWQgdmFsdWVzIHdpbGwgb3ZlcndyaXRlIGFueSBleGlzdGluZyB2YWx1ZXMuXG4gKiBFeHBvcnRlZCBvbmx5IGZvciB0ZXN0cy5cbiAqL1xuZnVuY3Rpb24gbWVyZ2VBbmRPdmVyd3JpdGVTY29wZURhdGFcblxuKGRhdGEsIHByb3AsIG1lcmdlVmFsKSB7XG4gIGRhdGFbcHJvcF0gPSBtZXJnZS5tZXJnZShkYXRhW3Byb3BdLCBtZXJnZVZhbCwgMSk7XG59XG5cbmZ1bmN0aW9uIGFwcGx5RGF0YVRvRXZlbnQoZXZlbnQsIGRhdGEpIHtcbiAgY29uc3QgeyBleHRyYSwgdGFncywgdXNlciwgY29udGV4dHMsIGxldmVsLCB0cmFuc2FjdGlvbk5hbWUgfSA9IGRhdGE7XG5cbiAgaWYgKE9iamVjdC5rZXlzKGV4dHJhKS5sZW5ndGgpIHtcbiAgICBldmVudC5leHRyYSA9IHsgLi4uZXh0cmEsIC4uLmV2ZW50LmV4dHJhIH07XG4gIH1cblxuICBpZiAoT2JqZWN0LmtleXModGFncykubGVuZ3RoKSB7XG4gICAgZXZlbnQudGFncyA9IHsgLi4udGFncywgLi4uZXZlbnQudGFncyB9O1xuICB9XG5cbiAgaWYgKE9iamVjdC5rZXlzKHVzZXIpLmxlbmd0aCkge1xuICAgIGV2ZW50LnVzZXIgPSB7IC4uLnVzZXIsIC4uLmV2ZW50LnVzZXIgfTtcbiAgfVxuXG4gIGlmIChPYmplY3Qua2V5cyhjb250ZXh0cykubGVuZ3RoKSB7XG4gICAgZXZlbnQuY29udGV4dHMgPSB7IC4uLmNvbnRleHRzLCAuLi5ldmVudC5jb250ZXh0cyB9O1xuICB9XG5cbiAgaWYgKGxldmVsKSB7XG4gICAgZXZlbnQubGV2ZWwgPSBsZXZlbDtcbiAgfVxuXG4gIC8vIHRyYW5zYWN0aW9uIGV2ZW50cyBnZXQgdGhlaXIgYHRyYW5zYWN0aW9uYCBmcm9tIHRoZSByb290IHNwYW4gbmFtZVxuICBpZiAodHJhbnNhY3Rpb25OYW1lICYmIGV2ZW50LnR5cGUgIT09ICd0cmFuc2FjdGlvbicpIHtcbiAgICBldmVudC50cmFuc2FjdGlvbiA9IHRyYW5zYWN0aW9uTmFtZTtcbiAgfVxufVxuXG5mdW5jdGlvbiBhcHBseUJyZWFkY3J1bWJzVG9FdmVudChldmVudCwgYnJlYWRjcnVtYnMpIHtcbiAgY29uc3QgbWVyZ2VkQnJlYWRjcnVtYnMgPSBbLi4uKGV2ZW50LmJyZWFkY3J1bWJzIHx8IFtdKSwgLi4uYnJlYWRjcnVtYnNdO1xuICBldmVudC5icmVhZGNydW1icyA9IG1lcmdlZEJyZWFkY3J1bWJzLmxlbmd0aCA/IG1lcmdlZEJyZWFkY3J1bWJzIDogdW5kZWZpbmVkO1xufVxuXG5mdW5jdGlvbiBhcHBseVNka01ldGFkYXRhVG9FdmVudChldmVudCwgc2RrUHJvY2Vzc2luZ01ldGFkYXRhKSB7XG4gIGV2ZW50LnNka1Byb2Nlc3NpbmdNZXRhZGF0YSA9IHtcbiAgICAuLi5ldmVudC5zZGtQcm9jZXNzaW5nTWV0YWRhdGEsXG4gICAgLi4uc2RrUHJvY2Vzc2luZ01ldGFkYXRhLFxuICB9O1xufVxuXG5mdW5jdGlvbiBhcHBseVNwYW5Ub0V2ZW50KGV2ZW50LCBzcGFuKSB7XG4gIGV2ZW50LmNvbnRleHRzID0ge1xuICAgIHRyYWNlOiBzcGFuVXRpbHMuc3BhblRvVHJhY2VDb250ZXh0KHNwYW4pLFxuICAgIC4uLmV2ZW50LmNvbnRleHRzLFxuICB9O1xuXG4gIGV2ZW50LnNka1Byb2Nlc3NpbmdNZXRhZGF0YSA9IHtcbiAgICBkeW5hbWljU2FtcGxpbmdDb250ZXh0OiBkeW5hbWljU2FtcGxpbmdDb250ZXh0LmdldER5bmFtaWNTYW1wbGluZ0NvbnRleHRGcm9tU3BhbihzcGFuKSxcbiAgICAuLi5ldmVudC5zZGtQcm9jZXNzaW5nTWV0YWRhdGEsXG4gIH07XG5cbiAgY29uc3Qgcm9vdFNwYW4gPSBzcGFuVXRpbHMuZ2V0Um9vdFNwYW4oc3Bhbik7XG4gIGNvbnN0IHRyYW5zYWN0aW9uTmFtZSA9IHNwYW5VdGlscy5zcGFuVG9KU09OKHJvb3RTcGFuKS5kZXNjcmlwdGlvbjtcbiAgaWYgKHRyYW5zYWN0aW9uTmFtZSAmJiAhZXZlbnQudHJhbnNhY3Rpb24gJiYgZXZlbnQudHlwZSA9PT0gJ3RyYW5zYWN0aW9uJykge1xuICAgIGV2ZW50LnRyYW5zYWN0aW9uID0gdHJhbnNhY3Rpb25OYW1lO1xuICB9XG59XG5cbi8qKlxuICogQXBwbGllcyBmaW5nZXJwcmludCBmcm9tIHRoZSBzY29wZSB0byB0aGUgZXZlbnQgaWYgdGhlcmUncyBvbmUsXG4gKiB1c2VzIG1lc3NhZ2UgaWYgdGhlcmUncyBvbmUgaW5zdGVhZCBvciBnZXQgcmlkIG9mIGVtcHR5IGZpbmdlcnByaW50XG4gKi9cbmZ1bmN0aW9uIGFwcGx5RmluZ2VycHJpbnRUb0V2ZW50KGV2ZW50LCBmaW5nZXJwcmludCkge1xuICAvLyBNYWtlIHN1cmUgaXQncyBhbiBhcnJheSBmaXJzdCBhbmQgd2UgYWN0dWFsbHkgaGF2ZSBzb21ldGhpbmcgaW4gcGxhY2VcbiAgZXZlbnQuZmluZ2VycHJpbnQgPSBldmVudC5maW5nZXJwcmludFxuICAgID8gQXJyYXkuaXNBcnJheShldmVudC5maW5nZXJwcmludClcbiAgICAgID8gZXZlbnQuZmluZ2VycHJpbnRcbiAgICAgIDogW2V2ZW50LmZpbmdlcnByaW50XVxuICAgIDogW107XG5cbiAgLy8gSWYgd2UgaGF2ZSBzb21ldGhpbmcgb24gdGhlIHNjb3BlLCB0aGVuIG1lcmdlIGl0IHdpdGggZXZlbnRcbiAgaWYgKGZpbmdlcnByaW50KSB7XG4gICAgZXZlbnQuZmluZ2VycHJpbnQgPSBldmVudC5maW5nZXJwcmludC5jb25jYXQoZmluZ2VycHJpbnQpO1xuICB9XG5cbiAgLy8gSWYgd2UgaGF2ZSBubyBkYXRhIGF0IGFsbCwgcmVtb3ZlIGVtcHR5IGFycmF5IGRlZmF1bHRcbiAgaWYgKCFldmVudC5maW5nZXJwcmludC5sZW5ndGgpIHtcbiAgICBkZWxldGUgZXZlbnQuZmluZ2VycHJpbnQ7XG4gIH1cbn1cblxuZXhwb3J0cy5hcHBseVNjb3BlRGF0YVRvRXZlbnQgPSBhcHBseVNjb3BlRGF0YVRvRXZlbnQ7XG5leHBvcnRzLm1lcmdlQW5kT3ZlcndyaXRlU2NvcGVEYXRhID0gbWVyZ2VBbmRPdmVyd3JpdGVTY29wZURhdGE7XG5leHBvcnRzLm1lcmdlU2NvcGVEYXRhID0gbWVyZ2VTY29wZURhdGE7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1hcHBseVNjb3BlRGF0YVRvRXZlbnQuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/applyScopeDataToEvent.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/baggage.js":
/*!*****************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/baggage.js ***!
  \*****************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst debugBuild = __webpack_require__(/*! ../debug-build.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst debugLogger = __webpack_require__(/*! ./debug-logger.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst is = __webpack_require__(/*! ./is.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js\");\n\nconst SENTRY_BAGGAGE_KEY_PREFIX = 'sentry-';\n\nconst SENTRY_BAGGAGE_KEY_PREFIX_REGEX = /^sentry-/;\n\n/**\n * Max length of a serialized baggage string\n *\n * https://www.w3.org/TR/baggage/#limits\n */\nconst MAX_BAGGAGE_STRING_LENGTH = 8192;\n\n/**\n * Takes a baggage header and turns it into Dynamic Sampling Context, by extracting all the \"sentry-\" prefixed values\n * from it.\n *\n * @param baggageHeader A very bread definition of a baggage header as it might appear in various frameworks.\n * @returns The Dynamic Sampling Context that was found on `baggageHeader`, if there was any, `undefined` otherwise.\n */\nfunction baggageHeaderToDynamicSamplingContext(\n  // Very liberal definition of what any incoming header might look like\n  baggageHeader,\n) {\n  const baggageObject = parseBaggageHeader(baggageHeader);\n\n  if (!baggageObject) {\n    return undefined;\n  }\n\n  // Read all \"sentry-\" prefixed values out of the baggage object and put it onto a dynamic sampling context object.\n  const dynamicSamplingContext = Object.entries(baggageObject).reduce((acc, [key, value]) => {\n    if (key.match(SENTRY_BAGGAGE_KEY_PREFIX_REGEX)) {\n      const nonPrefixedKey = key.slice(SENTRY_BAGGAGE_KEY_PREFIX.length);\n      acc[nonPrefixedKey] = value;\n    }\n    return acc;\n  }, {});\n\n  // Only return a dynamic sampling context object if there are keys in it.\n  // A keyless object means there were no sentry values on the header, which means that there is no DSC.\n  if (Object.keys(dynamicSamplingContext).length > 0) {\n    return dynamicSamplingContext ;\n  } else {\n    return undefined;\n  }\n}\n\n/**\n * Turns a Dynamic Sampling Object into a baggage header by prefixing all the keys on the object with \"sentry-\".\n *\n * @param dynamicSamplingContext The Dynamic Sampling Context to turn into a header. For convenience and compatibility\n * with the `getDynamicSamplingContext` method on the Transaction class ,this argument can also be `undefined`. If it is\n * `undefined` the function will return `undefined`.\n * @returns a baggage header, created from `dynamicSamplingContext`, or `undefined` either if `dynamicSamplingContext`\n * was `undefined`, or if `dynamicSamplingContext` didn't contain any values.\n */\nfunction dynamicSamplingContextToSentryBaggageHeader(\n  // this also takes undefined for convenience and bundle size in other places\n  dynamicSamplingContext,\n) {\n  if (!dynamicSamplingContext) {\n    return undefined;\n  }\n\n  // Prefix all DSC keys with \"sentry-\" and put them into a new object\n  const sentryPrefixedDSC = Object.entries(dynamicSamplingContext).reduce(\n    (acc, [dscKey, dscValue]) => {\n      if (dscValue) {\n        acc[`${SENTRY_BAGGAGE_KEY_PREFIX}${dscKey}`] = dscValue;\n      }\n      return acc;\n    },\n    {},\n  );\n\n  return objectToBaggageHeader(sentryPrefixedDSC);\n}\n\n/**\n * Take a baggage header and parse it into an object.\n */\nfunction parseBaggageHeader(\n  baggageHeader,\n) {\n  if (!baggageHeader || (!is.isString(baggageHeader) && !Array.isArray(baggageHeader))) {\n    return undefined;\n  }\n\n  if (Array.isArray(baggageHeader)) {\n    // Combine all baggage headers into one object containing the baggage values so we can later read the Sentry-DSC-values from it\n    return baggageHeader.reduce((acc, curr) => {\n      const currBaggageObject = baggageHeaderToObject(curr);\n      Object.entries(currBaggageObject).forEach(([key, value]) => {\n        acc[key] = value;\n      });\n      return acc;\n    }, {});\n  }\n\n  return baggageHeaderToObject(baggageHeader);\n}\n\n/**\n * Will parse a baggage header, which is a simple key-value map, into a flat object.\n *\n * @param baggageHeader The baggage header to parse.\n * @returns a flat object containing all the key-value pairs from `baggageHeader`.\n */\nfunction baggageHeaderToObject(baggageHeader) {\n  return baggageHeader\n    .split(',')\n    .map(baggageEntry =>\n      baggageEntry.split('=').map(keyOrValue => {\n        try {\n          return decodeURIComponent(keyOrValue.trim());\n        } catch {\n          // We ignore errors here, e.g. if the value cannot be URL decoded.\n          // This will then be skipped in the next step\n          return;\n        }\n      }),\n    )\n    .reduce((acc, [key, value]) => {\n      if (key && value) {\n        acc[key] = value;\n      }\n      return acc;\n    }, {});\n}\n\n/**\n * Turns a flat object (key-value pairs) into a baggage header, which is also just key-value pairs.\n *\n * @param object The object to turn into a baggage header.\n * @returns a baggage header string, or `undefined` if the object didn't have any values, since an empty baggage header\n * is not spec compliant.\n */\nfunction objectToBaggageHeader(object) {\n  if (Object.keys(object).length === 0) {\n    // An empty baggage header is not spec compliant: We return undefined.\n    return undefined;\n  }\n\n  return Object.entries(object).reduce((baggageHeader, [objectKey, objectValue], currentIndex) => {\n    const baggageEntry = `${encodeURIComponent(objectKey)}=${encodeURIComponent(objectValue)}`;\n    const newBaggageHeader = currentIndex === 0 ? baggageEntry : `${baggageHeader},${baggageEntry}`;\n    if (newBaggageHeader.length > MAX_BAGGAGE_STRING_LENGTH) {\n      debugBuild.DEBUG_BUILD &&\n        debugLogger.debug.warn(\n          `Not adding key: ${objectKey} with val: ${objectValue} to baggage header due to exceeding baggage size limits.`,\n        );\n      return baggageHeader;\n    } else {\n      return newBaggageHeader;\n    }\n  }, '');\n}\n\nexports.MAX_BAGGAGE_STRING_LENGTH = MAX_BAGGAGE_STRING_LENGTH;\nexports.SENTRY_BAGGAGE_KEY_PREFIX = SENTRY_BAGGAGE_KEY_PREFIX;\nexports.SENTRY_BAGGAGE_KEY_PREFIX_REGEX = SENTRY_BAGGAGE_KEY_PREFIX_REGEX;\nexports.baggageHeaderToDynamicSamplingContext = baggageHeaderToDynamicSamplingContext;\nexports.dynamicSamplingContextToSentryBaggageHeader = dynamicSamplingContextToSentryBaggageHeader;\nexports.objectToBaggageHeader = objectToBaggageHeader;\nexports.parseBaggageHeader = parseBaggageHeader;\n//# sourceMappingURL=baggage.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvYmFnZ2FnZS5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxtQkFBbUIsbUJBQU8sQ0FBQyxtSUFBbUI7QUFDOUMsb0JBQW9CLG1CQUFPLENBQUMsMElBQW1CO0FBQy9DLFdBQVcsbUJBQU8sQ0FBQyxzSEFBUzs7QUFFNUI7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxHQUFHLElBQUk7O0FBRVA7QUFDQTtBQUNBO0FBQ0E7QUFDQSxJQUFJO0FBQ0o7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsZUFBZSwwQkFBMEIsRUFBRSxPQUFPO0FBQ2xEO0FBQ0E7QUFDQSxLQUFLO0FBQ0wsTUFBTTtBQUNOOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLE9BQU87QUFDUDtBQUNBLEtBQUssSUFBSTtBQUNUOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxVQUFVO0FBQ1Y7QUFDQTtBQUNBO0FBQ0E7QUFDQSxPQUFPO0FBQ1A7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsS0FBSyxJQUFJO0FBQ1Q7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0EsNEJBQTRCLDhCQUE4QixHQUFHLGdDQUFnQztBQUM3RixvRUFBb0UsY0FBYyxHQUFHLGFBQWE7QUFDbEc7QUFDQTtBQUNBO0FBQ0EsNkJBQTZCLFdBQVcsWUFBWSxhQUFhO0FBQ2pFO0FBQ0E7QUFDQSxNQUFNO0FBQ047QUFDQTtBQUNBLEdBQUc7QUFDSDs7QUFFQSxpQ0FBaUM7QUFDakMsaUNBQWlDO0FBQ2pDLHVDQUF1QztBQUN2Qyw2Q0FBNkM7QUFDN0MsbURBQW1EO0FBQ25ELDZCQUE2QjtBQUM3QiwwQkFBMEI7QUFDMUIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9iYWdnYWdlLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBkZWJ1Z0J1aWxkID0gcmVxdWlyZSgnLi4vZGVidWctYnVpbGQuanMnKTtcbmNvbnN0IGRlYnVnTG9nZ2VyID0gcmVxdWlyZSgnLi9kZWJ1Zy1sb2dnZXIuanMnKTtcbmNvbnN0IGlzID0gcmVxdWlyZSgnLi9pcy5qcycpO1xuXG5jb25zdCBTRU5UUllfQkFHR0FHRV9LRVlfUFJFRklYID0gJ3NlbnRyeS0nO1xuXG5jb25zdCBTRU5UUllfQkFHR0FHRV9LRVlfUFJFRklYX1JFR0VYID0gL15zZW50cnktLztcblxuLyoqXG4gKiBNYXggbGVuZ3RoIG9mIGEgc2VyaWFsaXplZCBiYWdnYWdlIHN0cmluZ1xuICpcbiAqIGh0dHBzOi8vd3d3LnczLm9yZy9UUi9iYWdnYWdlLyNsaW1pdHNcbiAqL1xuY29uc3QgTUFYX0JBR0dBR0VfU1RSSU5HX0xFTkdUSCA9IDgxOTI7XG5cbi8qKlxuICogVGFrZXMgYSBiYWdnYWdlIGhlYWRlciBhbmQgdHVybnMgaXQgaW50byBEeW5hbWljIFNhbXBsaW5nIENvbnRleHQsIGJ5IGV4dHJhY3RpbmcgYWxsIHRoZSBcInNlbnRyeS1cIiBwcmVmaXhlZCB2YWx1ZXNcbiAqIGZyb20gaXQuXG4gKlxuICogQHBhcmFtIGJhZ2dhZ2VIZWFkZXIgQSB2ZXJ5IGJyZWFkIGRlZmluaXRpb24gb2YgYSBiYWdnYWdlIGhlYWRlciBhcyBpdCBtaWdodCBhcHBlYXIgaW4gdmFyaW91cyBmcmFtZXdvcmtzLlxuICogQHJldHVybnMgVGhlIER5bmFtaWMgU2FtcGxpbmcgQ29udGV4dCB0aGF0IHdhcyBmb3VuZCBvbiBgYmFnZ2FnZUhlYWRlcmAsIGlmIHRoZXJlIHdhcyBhbnksIGB1bmRlZmluZWRgIG90aGVyd2lzZS5cbiAqL1xuZnVuY3Rpb24gYmFnZ2FnZUhlYWRlclRvRHluYW1pY1NhbXBsaW5nQ29udGV4dChcbiAgLy8gVmVyeSBsaWJlcmFsIGRlZmluaXRpb24gb2Ygd2hhdCBhbnkgaW5jb21pbmcgaGVhZGVyIG1pZ2h0IGxvb2sgbGlrZVxuICBiYWdnYWdlSGVhZGVyLFxuKSB7XG4gIGNvbnN0IGJhZ2dhZ2VPYmplY3QgPSBwYXJzZUJhZ2dhZ2VIZWFkZXIoYmFnZ2FnZUhlYWRlcik7XG5cbiAgaWYgKCFiYWdnYWdlT2JqZWN0KSB7XG4gICAgcmV0dXJuIHVuZGVmaW5lZDtcbiAgfVxuXG4gIC8vIFJlYWQgYWxsIFwic2VudHJ5LVwiIHByZWZpeGVkIHZhbHVlcyBvdXQgb2YgdGhlIGJhZ2dhZ2Ugb2JqZWN0IGFuZCBwdXQgaXQgb250byBhIGR5bmFtaWMgc2FtcGxpbmcgY29udGV4dCBvYmplY3QuXG4gIGNvbnN0IGR5bmFtaWNTYW1wbGluZ0NvbnRleHQgPSBPYmplY3QuZW50cmllcyhiYWdnYWdlT2JqZWN0KS5yZWR1Y2UoKGFjYywgW2tleSwgdmFsdWVdKSA9PiB7XG4gICAgaWYgKGtleS5tYXRjaChTRU5UUllfQkFHR0FHRV9LRVlfUFJFRklYX1JFR0VYKSkge1xuICAgICAgY29uc3Qgbm9uUHJlZml4ZWRLZXkgPSBrZXkuc2xpY2UoU0VOVFJZX0JBR0dBR0VfS0VZX1BSRUZJWC5sZW5ndGgpO1xuICAgICAgYWNjW25vblByZWZpeGVkS2V5XSA9IHZhbHVlO1xuICAgIH1cbiAgICByZXR1cm4gYWNjO1xuICB9LCB7fSk7XG5cbiAgLy8gT25seSByZXR1cm4gYSBkeW5hbWljIHNhbXBsaW5nIGNvbnRleHQgb2JqZWN0IGlmIHRoZXJlIGFyZSBrZXlzIGluIGl0LlxuICAvLyBBIGtleWxlc3Mgb2JqZWN0IG1lYW5zIHRoZXJlIHdlcmUgbm8gc2VudHJ5IHZhbHVlcyBvbiB0aGUgaGVhZGVyLCB3aGljaCBtZWFucyB0aGF0IHRoZXJlIGlzIG5vIERTQy5cbiAgaWYgKE9iamVjdC5rZXlzKGR5bmFtaWNTYW1wbGluZ0NvbnRleHQpLmxlbmd0aCA+IDApIHtcbiAgICByZXR1cm4gZHluYW1pY1NhbXBsaW5nQ29udGV4dCA7XG4gIH0gZWxzZSB7XG4gICAgcmV0dXJuIHVuZGVmaW5lZDtcbiAgfVxufVxuXG4vKipcbiAqIFR1cm5zIGEgRHluYW1pYyBTYW1wbGluZyBPYmplY3QgaW50byBhIGJhZ2dhZ2UgaGVhZGVyIGJ5IHByZWZpeGluZyBhbGwgdGhlIGtleXMgb24gdGhlIG9iamVjdCB3aXRoIFwic2VudHJ5LVwiLlxuICpcbiAqIEBwYXJhbSBkeW5hbWljU2FtcGxpbmdDb250ZXh0IFRoZSBEeW5hbWljIFNhbXBsaW5nIENvbnRleHQgdG8gdHVybiBpbnRvIGEgaGVhZGVyLiBGb3IgY29udmVuaWVuY2UgYW5kIGNvbXBhdGliaWxpdHlcbiAqIHdpdGggdGhlIGBnZXREeW5hbWljU2FtcGxpbmdDb250ZXh0YCBtZXRob2Qgb24gdGhlIFRyYW5zYWN0aW9uIGNsYXNzICx0aGlzIGFyZ3VtZW50IGNhbiBhbHNvIGJlIGB1bmRlZmluZWRgLiBJZiBpdCBpc1xuICogYHVuZGVmaW5lZGAgdGhlIGZ1bmN0aW9uIHdpbGwgcmV0dXJuIGB1bmRlZmluZWRgLlxuICogQHJldHVybnMgYSBiYWdnYWdlIGhlYWRlciwgY3JlYXRlZCBmcm9tIGBkeW5hbWljU2FtcGxpbmdDb250ZXh0YCwgb3IgYHVuZGVmaW5lZGAgZWl0aGVyIGlmIGBkeW5hbWljU2FtcGxpbmdDb250ZXh0YFxuICogd2FzIGB1bmRlZmluZWRgLCBvciBpZiBgZHluYW1pY1NhbXBsaW5nQ29udGV4dGAgZGlkbid0IGNvbnRhaW4gYW55IHZhbHVlcy5cbiAqL1xuZnVuY3Rpb24gZHluYW1pY1NhbXBsaW5nQ29udGV4dFRvU2VudHJ5QmFnZ2FnZUhlYWRlcihcbiAgLy8gdGhpcyBhbHNvIHRha2VzIHVuZGVmaW5lZCBmb3IgY29udmVuaWVuY2UgYW5kIGJ1bmRsZSBzaXplIGluIG90aGVyIHBsYWNlc1xuICBkeW5hbWljU2FtcGxpbmdDb250ZXh0LFxuKSB7XG4gIGlmICghZHluYW1pY1NhbXBsaW5nQ29udGV4dCkge1xuICAgIHJldHVybiB1bmRlZmluZWQ7XG4gIH1cblxuICAvLyBQcmVmaXggYWxsIERTQyBrZXlzIHdpdGggXCJzZW50cnktXCIgYW5kIHB1dCB0aGVtIGludG8gYSBuZXcgb2JqZWN0XG4gIGNvbnN0IHNlbnRyeVByZWZpeGVkRFNDID0gT2JqZWN0LmVudHJpZXMoZHluYW1pY1NhbXBsaW5nQ29udGV4dCkucmVkdWNlKFxuICAgIChhY2MsIFtkc2NLZXksIGRzY1ZhbHVlXSkgPT4ge1xuICAgICAgaWYgKGRzY1ZhbHVlKSB7XG4gICAgICAgIGFjY1tgJHtTRU5UUllfQkFHR0FHRV9LRVlfUFJFRklYfSR7ZHNjS2V5fWBdID0gZHNjVmFsdWU7XG4gICAgICB9XG4gICAgICByZXR1cm4gYWNjO1xuICAgIH0sXG4gICAge30sXG4gICk7XG5cbiAgcmV0dXJuIG9iamVjdFRvQmFnZ2FnZUhlYWRlcihzZW50cnlQcmVmaXhlZERTQyk7XG59XG5cbi8qKlxuICogVGFrZSBhIGJhZ2dhZ2UgaGVhZGVyIGFuZCBwYXJzZSBpdCBpbnRvIGFuIG9iamVjdC5cbiAqL1xuZnVuY3Rpb24gcGFyc2VCYWdnYWdlSGVhZGVyKFxuICBiYWdnYWdlSGVhZGVyLFxuKSB7XG4gIGlmICghYmFnZ2FnZUhlYWRlciB8fCAoIWlzLmlzU3RyaW5nKGJhZ2dhZ2VIZWFkZXIpICYmICFBcnJheS5pc0FycmF5KGJhZ2dhZ2VIZWFkZXIpKSkge1xuICAgIHJldHVybiB1bmRlZmluZWQ7XG4gIH1cblxuICBpZiAoQXJyYXkuaXNBcnJheShiYWdnYWdlSGVhZGVyKSkge1xuICAgIC8vIENvbWJpbmUgYWxsIGJhZ2dhZ2UgaGVhZGVycyBpbnRvIG9uZSBvYmplY3QgY29udGFpbmluZyB0aGUgYmFnZ2FnZSB2YWx1ZXMgc28gd2UgY2FuIGxhdGVyIHJlYWQgdGhlIFNlbnRyeS1EU0MtdmFsdWVzIGZyb20gaXRcbiAgICByZXR1cm4gYmFnZ2FnZUhlYWRlci5yZWR1Y2UoKGFjYywgY3VycikgPT4ge1xuICAgICAgY29uc3QgY3VyckJhZ2dhZ2VPYmplY3QgPSBiYWdnYWdlSGVhZGVyVG9PYmplY3QoY3Vycik7XG4gICAgICBPYmplY3QuZW50cmllcyhjdXJyQmFnZ2FnZU9iamVjdCkuZm9yRWFjaCgoW2tleSwgdmFsdWVdKSA9PiB7XG4gICAgICAgIGFjY1trZXldID0gdmFsdWU7XG4gICAgICB9KTtcbiAgICAgIHJldHVybiBhY2M7XG4gICAgfSwge30pO1xuICB9XG5cbiAgcmV0dXJuIGJhZ2dhZ2VIZWFkZXJUb09iamVjdChiYWdnYWdlSGVhZGVyKTtcbn1cblxuLyoqXG4gKiBXaWxsIHBhcnNlIGEgYmFnZ2FnZSBoZWFkZXIsIHdoaWNoIGlzIGEgc2ltcGxlIGtleS12YWx1ZSBtYXAsIGludG8gYSBmbGF0IG9iamVjdC5cbiAqXG4gKiBAcGFyYW0gYmFnZ2FnZUhlYWRlciBUaGUgYmFnZ2FnZSBoZWFkZXIgdG8gcGFyc2UuXG4gKiBAcmV0dXJucyBhIGZsYXQgb2JqZWN0IGNvbnRhaW5pbmcgYWxsIHRoZSBrZXktdmFsdWUgcGFpcnMgZnJvbSBgYmFnZ2FnZUhlYWRlcmAuXG4gKi9cbmZ1bmN0aW9uIGJhZ2dhZ2VIZWFkZXJUb09iamVjdChiYWdnYWdlSGVhZGVyKSB7XG4gIHJldHVybiBiYWdnYWdlSGVhZGVyXG4gICAgLnNwbGl0KCcsJylcbiAgICAubWFwKGJhZ2dhZ2VFbnRyeSA9PlxuICAgICAgYmFnZ2FnZUVudHJ5LnNwbGl0KCc9JykubWFwKGtleU9yVmFsdWUgPT4ge1xuICAgICAgICB0cnkge1xuICAgICAgICAgIHJldHVybiBkZWNvZGVVUklDb21wb25lbnQoa2V5T3JWYWx1ZS50cmltKCkpO1xuICAgICAgICB9IGNhdGNoIHtcbiAgICAgICAgICAvLyBXZSBpZ25vcmUgZXJyb3JzIGhlcmUsIGUuZy4gaWYgdGhlIHZhbHVlIGNhbm5vdCBiZSBVUkwgZGVjb2RlZC5cbiAgICAgICAgICAvLyBUaGlzIHdpbGwgdGhlbiBiZSBza2lwcGVkIGluIHRoZSBuZXh0IHN0ZXBcbiAgICAgICAgICByZXR1cm47XG4gICAgICAgIH1cbiAgICAgIH0pLFxuICAgIClcbiAgICAucmVkdWNlKChhY2MsIFtrZXksIHZhbHVlXSkgPT4ge1xuICAgICAgaWYgKGtleSAmJiB2YWx1ZSkge1xuICAgICAgICBhY2Nba2V5XSA9IHZhbHVlO1xuICAgICAgfVxuICAgICAgcmV0dXJuIGFjYztcbiAgICB9LCB7fSk7XG59XG5cbi8qKlxuICogVHVybnMgYSBmbGF0IG9iamVjdCAoa2V5LXZhbHVlIHBhaXJzKSBpbnRvIGEgYmFnZ2FnZSBoZWFkZXIsIHdoaWNoIGlzIGFsc28ganVzdCBrZXktdmFsdWUgcGFpcnMuXG4gKlxuICogQHBhcmFtIG9iamVjdCBUaGUgb2JqZWN0IHRvIHR1cm4gaW50byBhIGJhZ2dhZ2UgaGVhZGVyLlxuICogQHJldHVybnMgYSBiYWdnYWdlIGhlYWRlciBzdHJpbmcsIG9yIGB1bmRlZmluZWRgIGlmIHRoZSBvYmplY3QgZGlkbid0IGhhdmUgYW55IHZhbHVlcywgc2luY2UgYW4gZW1wdHkgYmFnZ2FnZSBoZWFkZXJcbiAqIGlzIG5vdCBzcGVjIGNvbXBsaWFudC5cbiAqL1xuZnVuY3Rpb24gb2JqZWN0VG9CYWdnYWdlSGVhZGVyKG9iamVjdCkge1xuICBpZiAoT2JqZWN0LmtleXMob2JqZWN0KS5sZW5ndGggPT09IDApIHtcbiAgICAvLyBBbiBlbXB0eSBiYWdnYWdlIGhlYWRlciBpcyBub3Qgc3BlYyBjb21wbGlhbnQ6IFdlIHJldHVybiB1bmRlZmluZWQuXG4gICAgcmV0dXJuIHVuZGVmaW5lZDtcbiAgfVxuXG4gIHJldHVybiBPYmplY3QuZW50cmllcyhvYmplY3QpLnJlZHVjZSgoYmFnZ2FnZUhlYWRlciwgW29iamVjdEtleSwgb2JqZWN0VmFsdWVdLCBjdXJyZW50SW5kZXgpID0+IHtcbiAgICBjb25zdCBiYWdnYWdlRW50cnkgPSBgJHtlbmNvZGVVUklDb21wb25lbnQob2JqZWN0S2V5KX09JHtlbmNvZGVVUklDb21wb25lbnQob2JqZWN0VmFsdWUpfWA7XG4gICAgY29uc3QgbmV3QmFnZ2FnZUhlYWRlciA9IGN1cnJlbnRJbmRleCA9PT0gMCA/IGJhZ2dhZ2VFbnRyeSA6IGAke2JhZ2dhZ2VIZWFkZXJ9LCR7YmFnZ2FnZUVudHJ5fWA7XG4gICAgaWYgKG5ld0JhZ2dhZ2VIZWFkZXIubGVuZ3RoID4gTUFYX0JBR0dBR0VfU1RSSU5HX0xFTkdUSCkge1xuICAgICAgZGVidWdCdWlsZC5ERUJVR19CVUlMRCAmJlxuICAgICAgICBkZWJ1Z0xvZ2dlci5kZWJ1Zy53YXJuKFxuICAgICAgICAgIGBOb3QgYWRkaW5nIGtleTogJHtvYmplY3RLZXl9IHdpdGggdmFsOiAke29iamVjdFZhbHVlfSB0byBiYWdnYWdlIGhlYWRlciBkdWUgdG8gZXhjZWVkaW5nIGJhZ2dhZ2Ugc2l6ZSBsaW1pdHMuYCxcbiAgICAgICAgKTtcbiAgICAgIHJldHVybiBiYWdnYWdlSGVhZGVyO1xuICAgIH0gZWxzZSB7XG4gICAgICByZXR1cm4gbmV3QmFnZ2FnZUhlYWRlcjtcbiAgICB9XG4gIH0sICcnKTtcbn1cblxuZXhwb3J0cy5NQVhfQkFHR0FHRV9TVFJJTkdfTEVOR1RIID0gTUFYX0JBR0dBR0VfU1RSSU5HX0xFTkdUSDtcbmV4cG9ydHMuU0VOVFJZX0JBR0dBR0VfS0VZX1BSRUZJWCA9IFNFTlRSWV9CQUdHQUdFX0tFWV9QUkVGSVg7XG5leHBvcnRzLlNFTlRSWV9CQUdHQUdFX0tFWV9QUkVGSVhfUkVHRVggPSBTRU5UUllfQkFHR0FHRV9LRVlfUFJFRklYX1JFR0VYO1xuZXhwb3J0cy5iYWdnYWdlSGVhZGVyVG9EeW5hbWljU2FtcGxpbmdDb250ZXh0ID0gYmFnZ2FnZUhlYWRlclRvRHluYW1pY1NhbXBsaW5nQ29udGV4dDtcbmV4cG9ydHMuZHluYW1pY1NhbXBsaW5nQ29udGV4dFRvU2VudHJ5QmFnZ2FnZUhlYWRlciA9IGR5bmFtaWNTYW1wbGluZ0NvbnRleHRUb1NlbnRyeUJhZ2dhZ2VIZWFkZXI7XG5leHBvcnRzLm9iamVjdFRvQmFnZ2FnZUhlYWRlciA9IG9iamVjdFRvQmFnZ2FnZUhlYWRlcjtcbmV4cG9ydHMucGFyc2VCYWdnYWdlSGVhZGVyID0gcGFyc2VCYWdnYWdlSGVhZGVyO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9YmFnZ2FnZS5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/baggage.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/breadcrumb-log-level.js":
/*!******************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/breadcrumb-log-level.js ***!
  \******************************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n/**\n * Determine a breadcrumb's log level (only `warning` or `error`) based on an HTTP status code.\n */\nfunction getBreadcrumbLogLevelFromHttpStatusCode(statusCode) {\n  // NOTE: undefined defaults to 'info' in Sentry\n  if (statusCode === undefined) {\n    return undefined;\n  } else if (statusCode >= 400 && statusCode < 500) {\n    return 'warning';\n  } else if (statusCode >= 500) {\n    return 'error';\n  } else {\n    return undefined;\n  }\n}\n\nexports.getBreadcrumbLogLevelFromHttpStatusCode = getBreadcrumbLogLevelFromHttpStatusCode;\n//# sourceMappingURL=breadcrumb-log-level.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvYnJlYWRjcnVtYi1sb2ctbGV2ZWwuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEU7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxJQUFJO0FBQ0o7QUFDQSxJQUFJO0FBQ0o7QUFDQSxJQUFJO0FBQ0o7QUFDQTtBQUNBOztBQUVBLCtDQUErQztBQUMvQyIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3V0aWxzL2JyZWFkY3J1bWItbG9nLWxldmVsLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG4vKipcbiAqIERldGVybWluZSBhIGJyZWFkY3J1bWIncyBsb2cgbGV2ZWwgKG9ubHkgYHdhcm5pbmdgIG9yIGBlcnJvcmApIGJhc2VkIG9uIGFuIEhUVFAgc3RhdHVzIGNvZGUuXG4gKi9cbmZ1bmN0aW9uIGdldEJyZWFkY3J1bWJMb2dMZXZlbEZyb21IdHRwU3RhdHVzQ29kZShzdGF0dXNDb2RlKSB7XG4gIC8vIE5PVEU6IHVuZGVmaW5lZCBkZWZhdWx0cyB0byAnaW5mbycgaW4gU2VudHJ5XG4gIGlmIChzdGF0dXNDb2RlID09PSB1bmRlZmluZWQpIHtcbiAgICByZXR1cm4gdW5kZWZpbmVkO1xuICB9IGVsc2UgaWYgKHN0YXR1c0NvZGUgPj0gNDAwICYmIHN0YXR1c0NvZGUgPCA1MDApIHtcbiAgICByZXR1cm4gJ3dhcm5pbmcnO1xuICB9IGVsc2UgaWYgKHN0YXR1c0NvZGUgPj0gNTAwKSB7XG4gICAgcmV0dXJuICdlcnJvcic7XG4gIH0gZWxzZSB7XG4gICAgcmV0dXJuIHVuZGVmaW5lZDtcbiAgfVxufVxuXG5leHBvcnRzLmdldEJyZWFkY3J1bWJMb2dMZXZlbEZyb21IdHRwU3RhdHVzQ29kZSA9IGdldEJyZWFkY3J1bWJMb2dMZXZlbEZyb21IdHRwU3RhdHVzQ29kZTtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWJyZWFkY3J1bWItbG9nLWxldmVsLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/breadcrumb-log-level.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/browser.js":
/*!*****************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/browser.js ***!
  \*****************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst is = __webpack_require__(/*! ./is.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js\");\nconst worldwide = __webpack_require__(/*! ./worldwide.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/worldwide.js\");\n\nconst WINDOW = worldwide.GLOBAL_OBJ ;\n\nconst DEFAULT_MAX_STRING_LENGTH = 80;\n\n/**\n * Given a child DOM element, returns a query-selector statement describing that\n * and its ancestors\n * e.g. [HTMLElement] => body > div > input#foo.btn[name=baz]\n * @returns generated DOM path\n */\nfunction htmlTreeAsString(\n  elem,\n  options = {},\n) {\n  if (!elem) {\n    return '<unknown>';\n  }\n\n  // try/catch both:\n  // - accessing event.target (see getsentry/raven-js#838, #768)\n  // - `htmlTreeAsString` because it's complex, and just accessing the DOM incorrectly\n  // - can throw an exception in some circumstances.\n  try {\n    let currentElem = elem ;\n    const MAX_TRAVERSE_HEIGHT = 5;\n    const out = [];\n    let height = 0;\n    let len = 0;\n    const separator = ' > ';\n    const sepLength = separator.length;\n    let nextStr;\n    const keyAttrs = Array.isArray(options) ? options : options.keyAttrs;\n    const maxStringLength = (!Array.isArray(options) && options.maxStringLength) || DEFAULT_MAX_STRING_LENGTH;\n\n    while (currentElem && height++ < MAX_TRAVERSE_HEIGHT) {\n      nextStr = _htmlElementAsString(currentElem, keyAttrs);\n      // bail out if\n      // - nextStr is the 'html' element\n      // - the length of the string that would be created exceeds maxStringLength\n      //   (ignore this limit if we are on the first iteration)\n      if (nextStr === 'html' || (height > 1 && len + out.length * sepLength + nextStr.length >= maxStringLength)) {\n        break;\n      }\n\n      out.push(nextStr);\n\n      len += nextStr.length;\n      currentElem = currentElem.parentNode;\n    }\n\n    return out.reverse().join(separator);\n  } catch {\n    return '<unknown>';\n  }\n}\n\n/**\n * Returns a simple, query-selector representation of a DOM element\n * e.g. [HTMLElement] => input#foo.btn[name=baz]\n * @returns generated DOM path\n */\nfunction _htmlElementAsString(el, keyAttrs) {\n  const elem = el\n\n;\n\n  const out = [];\n\n  if (!elem?.tagName) {\n    return '';\n  }\n\n  // @ts-expect-error WINDOW has HTMLElement\n  if (WINDOW.HTMLElement) {\n    // If using the component name annotation plugin, this value may be available on the DOM node\n    if (elem instanceof HTMLElement && elem.dataset) {\n      if (elem.dataset['sentryComponent']) {\n        return elem.dataset['sentryComponent'];\n      }\n      if (elem.dataset['sentryElement']) {\n        return elem.dataset['sentryElement'];\n      }\n    }\n  }\n\n  out.push(elem.tagName.toLowerCase());\n\n  // Pairs of attribute keys defined in `serializeAttribute` and their values on element.\n  const keyAttrPairs = keyAttrs?.length\n    ? keyAttrs.filter(keyAttr => elem.getAttribute(keyAttr)).map(keyAttr => [keyAttr, elem.getAttribute(keyAttr)])\n    : null;\n\n  if (keyAttrPairs?.length) {\n    keyAttrPairs.forEach(keyAttrPair => {\n      out.push(`[${keyAttrPair[0]}=\"${keyAttrPair[1]}\"]`);\n    });\n  } else {\n    if (elem.id) {\n      out.push(`#${elem.id}`);\n    }\n\n    const className = elem.className;\n    if (className && is.isString(className)) {\n      const classes = className.split(/\\s+/);\n      for (const c of classes) {\n        out.push(`.${c}`);\n      }\n    }\n  }\n  const allowedAttrs = ['aria-label', 'type', 'name', 'title', 'alt'];\n  for (const k of allowedAttrs) {\n    const attr = elem.getAttribute(k);\n    if (attr) {\n      out.push(`[${k}=\"${attr}\"]`);\n    }\n  }\n\n  return out.join('');\n}\n\n/**\n * A safe form of location.href\n */\nfunction getLocationHref() {\n  try {\n    return WINDOW.document.location.href;\n  } catch {\n    return '';\n  }\n}\n\n/**\n * Given a DOM element, traverses up the tree until it finds the first ancestor node\n * that has the `data-sentry-component` or `data-sentry-element` attribute with `data-sentry-component` taking\n * precedence. This attribute is added at build-time by projects that have the component name annotation plugin installed.\n *\n * @returns a string representation of the component for the provided DOM element, or `null` if not found\n */\nfunction getComponentName(elem) {\n  // @ts-expect-error WINDOW has HTMLElement\n  if (!WINDOW.HTMLElement) {\n    return null;\n  }\n\n  let currentElem = elem ;\n  const MAX_TRAVERSE_HEIGHT = 5;\n  for (let i = 0; i < MAX_TRAVERSE_HEIGHT; i++) {\n    if (!currentElem) {\n      return null;\n    }\n\n    if (currentElem instanceof HTMLElement) {\n      if (currentElem.dataset['sentryComponent']) {\n        return currentElem.dataset['sentryComponent'];\n      }\n      if (currentElem.dataset['sentryElement']) {\n        return currentElem.dataset['sentryElement'];\n      }\n    }\n\n    currentElem = currentElem.parentNode;\n  }\n\n  return null;\n}\n\nexports.getComponentName = getComponentName;\nexports.getLocationHref = getLocationHref;\nexports.htmlTreeAsString = htmlTreeAsString;\n//# sourceMappingURL=browser.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvYnJvd3Nlci5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxXQUFXLG1CQUFPLENBQUMsc0hBQVM7QUFDNUIsa0JBQWtCLG1CQUFPLENBQUMsb0lBQWdCOztBQUUxQzs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsY0FBYztBQUNkO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0EsSUFBSTtBQUNKO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQSxtQkFBbUIsZUFBZSxJQUFJLGVBQWU7QUFDckQsS0FBSztBQUNMLElBQUk7QUFDSjtBQUNBLG1CQUFtQixRQUFRO0FBQzNCOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EscUJBQXFCLEVBQUU7QUFDdkI7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxtQkFBbUIsRUFBRSxJQUFJLEtBQUs7QUFDOUI7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLElBQUk7QUFDSjtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQSxrQkFBa0IseUJBQXlCO0FBQzNDO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQSx3QkFBd0I7QUFDeEIsdUJBQXVCO0FBQ3ZCLHdCQUF3QjtBQUN4QiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3V0aWxzL2Jyb3dzZXIuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGlzID0gcmVxdWlyZSgnLi9pcy5qcycpO1xuY29uc3Qgd29ybGR3aWRlID0gcmVxdWlyZSgnLi93b3JsZHdpZGUuanMnKTtcblxuY29uc3QgV0lORE9XID0gd29ybGR3aWRlLkdMT0JBTF9PQkogO1xuXG5jb25zdCBERUZBVUxUX01BWF9TVFJJTkdfTEVOR1RIID0gODA7XG5cbi8qKlxuICogR2l2ZW4gYSBjaGlsZCBET00gZWxlbWVudCwgcmV0dXJucyBhIHF1ZXJ5LXNlbGVjdG9yIHN0YXRlbWVudCBkZXNjcmliaW5nIHRoYXRcbiAqIGFuZCBpdHMgYW5jZXN0b3JzXG4gKiBlLmcuIFtIVE1MRWxlbWVudF0gPT4gYm9keSA+IGRpdiA+IGlucHV0I2Zvby5idG5bbmFtZT1iYXpdXG4gKiBAcmV0dXJucyBnZW5lcmF0ZWQgRE9NIHBhdGhcbiAqL1xuZnVuY3Rpb24gaHRtbFRyZWVBc1N0cmluZyhcbiAgZWxlbSxcbiAgb3B0aW9ucyA9IHt9LFxuKSB7XG4gIGlmICghZWxlbSkge1xuICAgIHJldHVybiAnPHVua25vd24+JztcbiAgfVxuXG4gIC8vIHRyeS9jYXRjaCBib3RoOlxuICAvLyAtIGFjY2Vzc2luZyBldmVudC50YXJnZXQgKHNlZSBnZXRzZW50cnkvcmF2ZW4tanMjODM4LCAjNzY4KVxuICAvLyAtIGBodG1sVHJlZUFzU3RyaW5nYCBiZWNhdXNlIGl0J3MgY29tcGxleCwgYW5kIGp1c3QgYWNjZXNzaW5nIHRoZSBET00gaW5jb3JyZWN0bHlcbiAgLy8gLSBjYW4gdGhyb3cgYW4gZXhjZXB0aW9uIGluIHNvbWUgY2lyY3Vtc3RhbmNlcy5cbiAgdHJ5IHtcbiAgICBsZXQgY3VycmVudEVsZW0gPSBlbGVtIDtcbiAgICBjb25zdCBNQVhfVFJBVkVSU0VfSEVJR0hUID0gNTtcbiAgICBjb25zdCBvdXQgPSBbXTtcbiAgICBsZXQgaGVpZ2h0ID0gMDtcbiAgICBsZXQgbGVuID0gMDtcbiAgICBjb25zdCBzZXBhcmF0b3IgPSAnID4gJztcbiAgICBjb25zdCBzZXBMZW5ndGggPSBzZXBhcmF0b3IubGVuZ3RoO1xuICAgIGxldCBuZXh0U3RyO1xuICAgIGNvbnN0IGtleUF0dHJzID0gQXJyYXkuaXNBcnJheShvcHRpb25zKSA/IG9wdGlvbnMgOiBvcHRpb25zLmtleUF0dHJzO1xuICAgIGNvbnN0IG1heFN0cmluZ0xlbmd0aCA9ICghQXJyYXkuaXNBcnJheShvcHRpb25zKSAmJiBvcHRpb25zLm1heFN0cmluZ0xlbmd0aCkgfHwgREVGQVVMVF9NQVhfU1RSSU5HX0xFTkdUSDtcblxuICAgIHdoaWxlIChjdXJyZW50RWxlbSAmJiBoZWlnaHQrKyA8IE1BWF9UUkFWRVJTRV9IRUlHSFQpIHtcbiAgICAgIG5leHRTdHIgPSBfaHRtbEVsZW1lbnRBc1N0cmluZyhjdXJyZW50RWxlbSwga2V5QXR0cnMpO1xuICAgICAgLy8gYmFpbCBvdXQgaWZcbiAgICAgIC8vIC0gbmV4dFN0ciBpcyB0aGUgJ2h0bWwnIGVsZW1lbnRcbiAgICAgIC8vIC0gdGhlIGxlbmd0aCBvZiB0aGUgc3RyaW5nIHRoYXQgd291bGQgYmUgY3JlYXRlZCBleGNlZWRzIG1heFN0cmluZ0xlbmd0aFxuICAgICAgLy8gICAoaWdub3JlIHRoaXMgbGltaXQgaWYgd2UgYXJlIG9uIHRoZSBmaXJzdCBpdGVyYXRpb24pXG4gICAgICBpZiAobmV4dFN0ciA9PT0gJ2h0bWwnIHx8IChoZWlnaHQgPiAxICYmIGxlbiArIG91dC5sZW5ndGggKiBzZXBMZW5ndGggKyBuZXh0U3RyLmxlbmd0aCA+PSBtYXhTdHJpbmdMZW5ndGgpKSB7XG4gICAgICAgIGJyZWFrO1xuICAgICAgfVxuXG4gICAgICBvdXQucHVzaChuZXh0U3RyKTtcblxuICAgICAgbGVuICs9IG5leHRTdHIubGVuZ3RoO1xuICAgICAgY3VycmVudEVsZW0gPSBjdXJyZW50RWxlbS5wYXJlbnROb2RlO1xuICAgIH1cblxuICAgIHJldHVybiBvdXQucmV2ZXJzZSgpLmpvaW4oc2VwYXJhdG9yKTtcbiAgfSBjYXRjaCB7XG4gICAgcmV0dXJuICc8dW5rbm93bj4nO1xuICB9XG59XG5cbi8qKlxuICogUmV0dXJucyBhIHNpbXBsZSwgcXVlcnktc2VsZWN0b3IgcmVwcmVzZW50YXRpb24gb2YgYSBET00gZWxlbWVudFxuICogZS5nLiBbSFRNTEVsZW1lbnRdID0+IGlucHV0I2Zvby5idG5bbmFtZT1iYXpdXG4gKiBAcmV0dXJucyBnZW5lcmF0ZWQgRE9NIHBhdGhcbiAqL1xuZnVuY3Rpb24gX2h0bWxFbGVtZW50QXNTdHJpbmcoZWwsIGtleUF0dHJzKSB7XG4gIGNvbnN0IGVsZW0gPSBlbFxuXG47XG5cbiAgY29uc3Qgb3V0ID0gW107XG5cbiAgaWYgKCFlbGVtPy50YWdOYW1lKSB7XG4gICAgcmV0dXJuICcnO1xuICB9XG5cbiAgLy8gQHRzLWV4cGVjdC1lcnJvciBXSU5ET1cgaGFzIEhUTUxFbGVtZW50XG4gIGlmIChXSU5ET1cuSFRNTEVsZW1lbnQpIHtcbiAgICAvLyBJZiB1c2luZyB0aGUgY29tcG9uZW50IG5hbWUgYW5ub3RhdGlvbiBwbHVnaW4sIHRoaXMgdmFsdWUgbWF5IGJlIGF2YWlsYWJsZSBvbiB0aGUgRE9NIG5vZGVcbiAgICBpZiAoZWxlbSBpbnN0YW5jZW9mIEhUTUxFbGVtZW50ICYmIGVsZW0uZGF0YXNldCkge1xuICAgICAgaWYgKGVsZW0uZGF0YXNldFsnc2VudHJ5Q29tcG9uZW50J10pIHtcbiAgICAgICAgcmV0dXJuIGVsZW0uZGF0YXNldFsnc2VudHJ5Q29tcG9uZW50J107XG4gICAgICB9XG4gICAgICBpZiAoZWxlbS5kYXRhc2V0WydzZW50cnlFbGVtZW50J10pIHtcbiAgICAgICAgcmV0dXJuIGVsZW0uZGF0YXNldFsnc2VudHJ5RWxlbWVudCddO1xuICAgICAgfVxuICAgIH1cbiAgfVxuXG4gIG91dC5wdXNoKGVsZW0udGFnTmFtZS50b0xvd2VyQ2FzZSgpKTtcblxuICAvLyBQYWlycyBvZiBhdHRyaWJ1dGUga2V5cyBkZWZpbmVkIGluIGBzZXJpYWxpemVBdHRyaWJ1dGVgIGFuZCB0aGVpciB2YWx1ZXMgb24gZWxlbWVudC5cbiAgY29uc3Qga2V5QXR0clBhaXJzID0ga2V5QXR0cnM/Lmxlbmd0aFxuICAgID8ga2V5QXR0cnMuZmlsdGVyKGtleUF0dHIgPT4gZWxlbS5nZXRBdHRyaWJ1dGUoa2V5QXR0cikpLm1hcChrZXlBdHRyID0+IFtrZXlBdHRyLCBlbGVtLmdldEF0dHJpYnV0ZShrZXlBdHRyKV0pXG4gICAgOiBudWxsO1xuXG4gIGlmIChrZXlBdHRyUGFpcnM/Lmxlbmd0aCkge1xuICAgIGtleUF0dHJQYWlycy5mb3JFYWNoKGtleUF0dHJQYWlyID0+IHtcbiAgICAgIG91dC5wdXNoKGBbJHtrZXlBdHRyUGFpclswXX09XCIke2tleUF0dHJQYWlyWzFdfVwiXWApO1xuICAgIH0pO1xuICB9IGVsc2Uge1xuICAgIGlmIChlbGVtLmlkKSB7XG4gICAgICBvdXQucHVzaChgIyR7ZWxlbS5pZH1gKTtcbiAgICB9XG5cbiAgICBjb25zdCBjbGFzc05hbWUgPSBlbGVtLmNsYXNzTmFtZTtcbiAgICBpZiAoY2xhc3NOYW1lICYmIGlzLmlzU3RyaW5nKGNsYXNzTmFtZSkpIHtcbiAgICAgIGNvbnN0IGNsYXNzZXMgPSBjbGFzc05hbWUuc3BsaXQoL1xccysvKTtcbiAgICAgIGZvciAoY29uc3QgYyBvZiBjbGFzc2VzKSB7XG4gICAgICAgIG91dC5wdXNoKGAuJHtjfWApO1xuICAgICAgfVxuICAgIH1cbiAgfVxuICBjb25zdCBhbGxvd2VkQXR0cnMgPSBbJ2FyaWEtbGFiZWwnLCAndHlwZScsICduYW1lJywgJ3RpdGxlJywgJ2FsdCddO1xuICBmb3IgKGNvbnN0IGsgb2YgYWxsb3dlZEF0dHJzKSB7XG4gICAgY29uc3QgYXR0ciA9IGVsZW0uZ2V0QXR0cmlidXRlKGspO1xuICAgIGlmIChhdHRyKSB7XG4gICAgICBvdXQucHVzaChgWyR7a309XCIke2F0dHJ9XCJdYCk7XG4gICAgfVxuICB9XG5cbiAgcmV0dXJuIG91dC5qb2luKCcnKTtcbn1cblxuLyoqXG4gKiBBIHNhZmUgZm9ybSBvZiBsb2NhdGlvbi5ocmVmXG4gKi9cbmZ1bmN0aW9uIGdldExvY2F0aW9uSHJlZigpIHtcbiAgdHJ5IHtcbiAgICByZXR1cm4gV0lORE9XLmRvY3VtZW50LmxvY2F0aW9uLmhyZWY7XG4gIH0gY2F0Y2gge1xuICAgIHJldHVybiAnJztcbiAgfVxufVxuXG4vKipcbiAqIEdpdmVuIGEgRE9NIGVsZW1lbnQsIHRyYXZlcnNlcyB1cCB0aGUgdHJlZSB1bnRpbCBpdCBmaW5kcyB0aGUgZmlyc3QgYW5jZXN0b3Igbm9kZVxuICogdGhhdCBoYXMgdGhlIGBkYXRhLXNlbnRyeS1jb21wb25lbnRgIG9yIGBkYXRhLXNlbnRyeS1lbGVtZW50YCBhdHRyaWJ1dGUgd2l0aCBgZGF0YS1zZW50cnktY29tcG9uZW50YCB0YWtpbmdcbiAqIHByZWNlZGVuY2UuIFRoaXMgYXR0cmlidXRlIGlzIGFkZGVkIGF0IGJ1aWxkLXRpbWUgYnkgcHJvamVjdHMgdGhhdCBoYXZlIHRoZSBjb21wb25lbnQgbmFtZSBhbm5vdGF0aW9uIHBsdWdpbiBpbnN0YWxsZWQuXG4gKlxuICogQHJldHVybnMgYSBzdHJpbmcgcmVwcmVzZW50YXRpb24gb2YgdGhlIGNvbXBvbmVudCBmb3IgdGhlIHByb3ZpZGVkIERPTSBlbGVtZW50LCBvciBgbnVsbGAgaWYgbm90IGZvdW5kXG4gKi9cbmZ1bmN0aW9uIGdldENvbXBvbmVudE5hbWUoZWxlbSkge1xuICAvLyBAdHMtZXhwZWN0LWVycm9yIFdJTkRPVyBoYXMgSFRNTEVsZW1lbnRcbiAgaWYgKCFXSU5ET1cuSFRNTEVsZW1lbnQpIHtcbiAgICByZXR1cm4gbnVsbDtcbiAgfVxuXG4gIGxldCBjdXJyZW50RWxlbSA9IGVsZW0gO1xuICBjb25zdCBNQVhfVFJBVkVSU0VfSEVJR0hUID0gNTtcbiAgZm9yIChsZXQgaSA9IDA7IGkgPCBNQVhfVFJBVkVSU0VfSEVJR0hUOyBpKyspIHtcbiAgICBpZiAoIWN1cnJlbnRFbGVtKSB7XG4gICAgICByZXR1cm4gbnVsbDtcbiAgICB9XG5cbiAgICBpZiAoY3VycmVudEVsZW0gaW5zdGFuY2VvZiBIVE1MRWxlbWVudCkge1xuICAgICAgaWYgKGN1cnJlbnRFbGVtLmRhdGFzZXRbJ3NlbnRyeUNvbXBvbmVudCddKSB7XG4gICAgICAgIHJldHVybiBjdXJyZW50RWxlbS5kYXRhc2V0WydzZW50cnlDb21wb25lbnQnXTtcbiAgICAgIH1cbiAgICAgIGlmIChjdXJyZW50RWxlbS5kYXRhc2V0WydzZW50cnlFbGVtZW50J10pIHtcbiAgICAgICAgcmV0dXJuIGN1cnJlbnRFbGVtLmRhdGFzZXRbJ3NlbnRyeUVsZW1lbnQnXTtcbiAgICAgIH1cbiAgICB9XG5cbiAgICBjdXJyZW50RWxlbSA9IGN1cnJlbnRFbGVtLnBhcmVudE5vZGU7XG4gIH1cblxuICByZXR1cm4gbnVsbDtcbn1cblxuZXhwb3J0cy5nZXRDb21wb25lbnROYW1lID0gZ2V0Q29tcG9uZW50TmFtZTtcbmV4cG9ydHMuZ2V0TG9jYXRpb25IcmVmID0gZ2V0TG9jYXRpb25IcmVmO1xuZXhwb3J0cy5odG1sVHJlZUFzU3RyaW5nID0gaHRtbFRyZWVBc1N0cmluZztcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWJyb3dzZXIuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/browser.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/clientreport.js":
/*!**********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/clientreport.js ***!
  \**********************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst envelope = __webpack_require__(/*! ./envelope.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/envelope.js\");\nconst time = __webpack_require__(/*! ./time.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/time.js\");\n\n/**\n * Creates client report envelope\n * @param discarded_events An array of discard events\n * @param dsn A DSN that can be set on the header. Optional.\n */\nfunction createClientReportEnvelope(\n  discarded_events,\n  dsn,\n  timestamp,\n) {\n  const clientReportItem = [\n    { type: 'client_report' },\n    {\n      timestamp: timestamp || time.dateTimestampInSeconds(),\n      discarded_events,\n    },\n  ];\n  return envelope.createEnvelope(dsn ? { dsn } : {}, [clientReportItem]);\n}\n\nexports.createClientReportEnvelope = createClientReportEnvelope;\n//# sourceMappingURL=clientreport.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvY2xpZW50cmVwb3J0LmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLGlCQUFpQixtQkFBTyxDQUFDLGtJQUFlO0FBQ3hDLGFBQWEsbUJBQU8sQ0FBQywwSEFBVzs7QUFFaEM7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLE1BQU0sdUJBQXVCO0FBQzdCO0FBQ0E7QUFDQTtBQUNBLEtBQUs7QUFDTDtBQUNBLHlDQUF5QyxNQUFNLElBQUk7QUFDbkQ7O0FBRUEsa0NBQWtDO0FBQ2xDIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvY2xpZW50cmVwb3J0LmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBlbnZlbG9wZSA9IHJlcXVpcmUoJy4vZW52ZWxvcGUuanMnKTtcbmNvbnN0IHRpbWUgPSByZXF1aXJlKCcuL3RpbWUuanMnKTtcblxuLyoqXG4gKiBDcmVhdGVzIGNsaWVudCByZXBvcnQgZW52ZWxvcGVcbiAqIEBwYXJhbSBkaXNjYXJkZWRfZXZlbnRzIEFuIGFycmF5IG9mIGRpc2NhcmQgZXZlbnRzXG4gKiBAcGFyYW0gZHNuIEEgRFNOIHRoYXQgY2FuIGJlIHNldCBvbiB0aGUgaGVhZGVyLiBPcHRpb25hbC5cbiAqL1xuZnVuY3Rpb24gY3JlYXRlQ2xpZW50UmVwb3J0RW52ZWxvcGUoXG4gIGRpc2NhcmRlZF9ldmVudHMsXG4gIGRzbixcbiAgdGltZXN0YW1wLFxuKSB7XG4gIGNvbnN0IGNsaWVudFJlcG9ydEl0ZW0gPSBbXG4gICAgeyB0eXBlOiAnY2xpZW50X3JlcG9ydCcgfSxcbiAgICB7XG4gICAgICB0aW1lc3RhbXA6IHRpbWVzdGFtcCB8fCB0aW1lLmRhdGVUaW1lc3RhbXBJblNlY29uZHMoKSxcbiAgICAgIGRpc2NhcmRlZF9ldmVudHMsXG4gICAgfSxcbiAgXTtcbiAgcmV0dXJuIGVudmVsb3BlLmNyZWF0ZUVudmVsb3BlKGRzbiA/IHsgZHNuIH0gOiB7fSwgW2NsaWVudFJlcG9ydEl0ZW1dKTtcbn1cblxuZXhwb3J0cy5jcmVhdGVDbGllbnRSZXBvcnRFbnZlbG9wZSA9IGNyZWF0ZUNsaWVudFJlcG9ydEVudmVsb3BlO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9Y2xpZW50cmVwb3J0LmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/clientreport.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/cookie.js":
/*!****************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/cookie.js ***!
  \****************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n/**\n * This code was originally copied from the 'cookie` module at v0.5.0 and was simplified for our use case.\n * https://github.com/jshttp/cookie/blob/a0c84147aab6266bdb3996cf4062e93907c0b0fc/index.js\n * It had the following license:\n *\n * (The MIT License)\n *\n * Copyright (c) 2012-2014 Roman Shtylman <shtylman@gmail.com>\n * Copyright (c) 2015 Douglas Christopher Wilson <doug@somethingdoug.com>\n *\n * Permission is hereby granted, free of charge, to any person obtaining\n * a copy of this software and associated documentation files (the\n * 'Software'), to deal in the Software without restriction, including\n * without limitation the rights to use, copy, modify, merge, publish,\n * distribute, sublicense, and/or sell copies of the Software, and to\n * permit persons to whom the Software is furnished to do so, subject to\n * the following conditions:\n *\n * The above copyright notice and this permission notice shall be\n * included in all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND,\n * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.\n * IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY\n * CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,\n * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE\n * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.\n */\n\n/**\n * Parses a cookie string\n */\nfunction parseCookie(str) {\n  const obj = {};\n  let index = 0;\n\n  while (index < str.length) {\n    const eqIdx = str.indexOf('=', index);\n\n    // no more cookie pairs\n    if (eqIdx === -1) {\n      break;\n    }\n\n    let endIdx = str.indexOf(';', index);\n\n    if (endIdx === -1) {\n      endIdx = str.length;\n    } else if (endIdx < eqIdx) {\n      // backtrack on prior semicolon\n      index = str.lastIndexOf(';', eqIdx - 1) + 1;\n      continue;\n    }\n\n    const key = str.slice(index, eqIdx).trim();\n\n    // only assign once\n    if (undefined === obj[key]) {\n      let val = str.slice(eqIdx + 1, endIdx).trim();\n\n      // quoted values\n      if (val.charCodeAt(0) === 0x22) {\n        val = val.slice(1, -1);\n      }\n\n      try {\n        obj[key] = val.indexOf('%') !== -1 ? decodeURIComponent(val) : val;\n      } catch {\n        obj[key] = val;\n      }\n    }\n\n    index = endIdx + 1;\n  }\n\n  return obj;\n}\n\nexports.parseCookie = parseCookie;\n//# sourceMappingURL=cookie.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvY29va2llLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsK0JBQStCOztBQUUvQjtBQUNBO0FBQ0EsTUFBTTtBQUNOO0FBQ0EsZ0NBQWdDO0FBQ2hDO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQSxRQUFRO0FBQ1I7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQSxtQkFBbUI7QUFDbkIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9jb29raWUuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbi8qKlxuICogVGhpcyBjb2RlIHdhcyBvcmlnaW5hbGx5IGNvcGllZCBmcm9tIHRoZSAnY29va2llYCBtb2R1bGUgYXQgdjAuNS4wIGFuZCB3YXMgc2ltcGxpZmllZCBmb3Igb3VyIHVzZSBjYXNlLlxuICogaHR0cHM6Ly9naXRodWIuY29tL2pzaHR0cC9jb29raWUvYmxvYi9hMGM4NDE0N2FhYjYyNjZiZGIzOTk2Y2Y0MDYyZTkzOTA3YzBiMGZjL2luZGV4LmpzXG4gKiBJdCBoYWQgdGhlIGZvbGxvd2luZyBsaWNlbnNlOlxuICpcbiAqIChUaGUgTUlUIExpY2Vuc2UpXG4gKlxuICogQ29weXJpZ2h0IChjKSAyMDEyLTIwMTQgUm9tYW4gU2h0eWxtYW4gPHNodHlsbWFuQGdtYWlsLmNvbT5cbiAqIENvcHlyaWdodCAoYykgMjAxNSBEb3VnbGFzIENocmlzdG9waGVyIFdpbHNvbiA8ZG91Z0Bzb21ldGhpbmdkb3VnLmNvbT5cbiAqXG4gKiBQZXJtaXNzaW9uIGlzIGhlcmVieSBncmFudGVkLCBmcmVlIG9mIGNoYXJnZSwgdG8gYW55IHBlcnNvbiBvYnRhaW5pbmdcbiAqIGEgY29weSBvZiB0aGlzIHNvZnR3YXJlIGFuZCBhc3NvY2lhdGVkIGRvY3VtZW50YXRpb24gZmlsZXMgKHRoZVxuICogJ1NvZnR3YXJlJyksIHRvIGRlYWwgaW4gdGhlIFNvZnR3YXJlIHdpdGhvdXQgcmVzdHJpY3Rpb24sIGluY2x1ZGluZ1xuICogd2l0aG91dCBsaW1pdGF0aW9uIHRoZSByaWdodHMgdG8gdXNlLCBjb3B5LCBtb2RpZnksIG1lcmdlLCBwdWJsaXNoLFxuICogZGlzdHJpYnV0ZSwgc3VibGljZW5zZSwgYW5kL29yIHNlbGwgY29waWVzIG9mIHRoZSBTb2Z0d2FyZSwgYW5kIHRvXG4gKiBwZXJtaXQgcGVyc29ucyB0byB3aG9tIHRoZSBTb2Z0d2FyZSBpcyBmdXJuaXNoZWQgdG8gZG8gc28sIHN1YmplY3QgdG9cbiAqIHRoZSBmb2xsb3dpbmcgY29uZGl0aW9uczpcbiAqXG4gKiBUaGUgYWJvdmUgY29weXJpZ2h0IG5vdGljZSBhbmQgdGhpcyBwZXJtaXNzaW9uIG5vdGljZSBzaGFsbCBiZVxuICogaW5jbHVkZWQgaW4gYWxsIGNvcGllcyBvciBzdWJzdGFudGlhbCBwb3J0aW9ucyBvZiB0aGUgU29mdHdhcmUuXG4gKlxuICogVEhFIFNPRlRXQVJFIElTIFBST1ZJREVEICdBUyBJUycsIFdJVEhPVVQgV0FSUkFOVFkgT0YgQU5ZIEtJTkQsXG4gKiBFWFBSRVNTIE9SIElNUExJRUQsIElOQ0xVRElORyBCVVQgTk9UIExJTUlURUQgVE8gVEhFIFdBUlJBTlRJRVMgT0ZcbiAqIE1FUkNIQU5UQUJJTElUWSwgRklUTkVTUyBGT1IgQSBQQVJUSUNVTEFSIFBVUlBPU0UgQU5EIE5PTklORlJJTkdFTUVOVC5cbiAqIElOIE5PIEVWRU5UIFNIQUxMIFRIRSBBVVRIT1JTIE9SIENPUFlSSUdIVCBIT0xERVJTIEJFIExJQUJMRSBGT1IgQU5ZXG4gKiBDTEFJTSwgREFNQUdFUyBPUiBPVEhFUiBMSUFCSUxJVFksIFdIRVRIRVIgSU4gQU4gQUNUSU9OIE9GIENPTlRSQUNULFxuICogVE9SVCBPUiBPVEhFUldJU0UsIEFSSVNJTkcgRlJPTSwgT1VUIE9GIE9SIElOIENPTk5FQ1RJT04gV0lUSCBUSEVcbiAqIFNPRlRXQVJFIE9SIFRIRSBVU0UgT1IgT1RIRVIgREVBTElOR1MgSU4gVEhFIFNPRlRXQVJFLlxuICovXG5cbi8qKlxuICogUGFyc2VzIGEgY29va2llIHN0cmluZ1xuICovXG5mdW5jdGlvbiBwYXJzZUNvb2tpZShzdHIpIHtcbiAgY29uc3Qgb2JqID0ge307XG4gIGxldCBpbmRleCA9IDA7XG5cbiAgd2hpbGUgKGluZGV4IDwgc3RyLmxlbmd0aCkge1xuICAgIGNvbnN0IGVxSWR4ID0gc3RyLmluZGV4T2YoJz0nLCBpbmRleCk7XG5cbiAgICAvLyBubyBtb3JlIGNvb2tpZSBwYWlyc1xuICAgIGlmIChlcUlkeCA9PT0gLTEpIHtcbiAgICAgIGJyZWFrO1xuICAgIH1cblxuICAgIGxldCBlbmRJZHggPSBzdHIuaW5kZXhPZignOycsIGluZGV4KTtcblxuICAgIGlmIChlbmRJZHggPT09IC0xKSB7XG4gICAgICBlbmRJZHggPSBzdHIubGVuZ3RoO1xuICAgIH0gZWxzZSBpZiAoZW5kSWR4IDwgZXFJZHgpIHtcbiAgICAgIC8vIGJhY2t0cmFjayBvbiBwcmlvciBzZW1pY29sb25cbiAgICAgIGluZGV4ID0gc3RyLmxhc3RJbmRleE9mKCc7JywgZXFJZHggLSAxKSArIDE7XG4gICAgICBjb250aW51ZTtcbiAgICB9XG5cbiAgICBjb25zdCBrZXkgPSBzdHIuc2xpY2UoaW5kZXgsIGVxSWR4KS50cmltKCk7XG5cbiAgICAvLyBvbmx5IGFzc2lnbiBvbmNlXG4gICAgaWYgKHVuZGVmaW5lZCA9PT0gb2JqW2tleV0pIHtcbiAgICAgIGxldCB2YWwgPSBzdHIuc2xpY2UoZXFJZHggKyAxLCBlbmRJZHgpLnRyaW0oKTtcblxuICAgICAgLy8gcXVvdGVkIHZhbHVlc1xuICAgICAgaWYgKHZhbC5jaGFyQ29kZUF0KDApID09PSAweDIyKSB7XG4gICAgICAgIHZhbCA9IHZhbC5zbGljZSgxLCAtMSk7XG4gICAgICB9XG5cbiAgICAgIHRyeSB7XG4gICAgICAgIG9ialtrZXldID0gdmFsLmluZGV4T2YoJyUnKSAhPT0gLTEgPyBkZWNvZGVVUklDb21wb25lbnQodmFsKSA6IHZhbDtcbiAgICAgIH0gY2F0Y2gge1xuICAgICAgICBvYmpba2V5XSA9IHZhbDtcbiAgICAgIH1cbiAgICB9XG5cbiAgICBpbmRleCA9IGVuZElkeCArIDE7XG4gIH1cblxuICByZXR1cm4gb2JqO1xufVxuXG5leHBvcnRzLnBhcnNlQ29va2llID0gcGFyc2VDb29raWU7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1jb29raWUuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/cookie.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debounce.js":
/*!******************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debounce.js ***!
  \******************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n/**\n * Heavily simplified debounce function based on lodash.debounce.\n *\n * This function takes a callback function (@param fun) and delays its invocation\n * by @param wait milliseconds. Optionally, a maxWait can be specified in @param options,\n * which ensures that the callback is invoked at least once after the specified max. wait time.\n *\n * @param func the function whose invocation is to be debounced\n * @param wait the minimum time until the function is invoked after it was called once\n * @param options the options object, which can contain the `maxWait` property\n *\n * @returns the debounced version of the function, which needs to be called at least once to start the\n *          debouncing process. Subsequent calls will reset the debouncing timer and, in case @paramfunc\n *          was already invoked in the meantime, return @param func's return value.\n *          The debounced function has two additional properties:\n *          - `flush`: Invokes the debounced function immediately and returns its return value\n *          - `cancel`: Cancels the debouncing process and resets the debouncing timer\n */\nfunction debounce(func, wait, options) {\n  let callbackReturnValue;\n\n  let timerId;\n  let maxTimerId;\n\n  const maxWait = options?.maxWait ? Math.max(options.maxWait, wait) : 0;\n  const setTimeoutImpl = options?.setTimeoutImpl || setTimeout;\n\n  function invokeFunc() {\n    cancelTimers();\n    callbackReturnValue = func();\n    return callbackReturnValue;\n  }\n\n  function cancelTimers() {\n    timerId !== undefined && clearTimeout(timerId);\n    maxTimerId !== undefined && clearTimeout(maxTimerId);\n    timerId = maxTimerId = undefined;\n  }\n\n  function flush() {\n    if (timerId !== undefined || maxTimerId !== undefined) {\n      return invokeFunc();\n    }\n    return callbackReturnValue;\n  }\n\n  function debounced() {\n    if (timerId) {\n      clearTimeout(timerId);\n    }\n    timerId = setTimeoutImpl(invokeFunc, wait);\n\n    if (maxWait && maxTimerId === undefined) {\n      maxTimerId = setTimeoutImpl(invokeFunc, maxWait);\n    }\n\n    return callbackReturnValue;\n  }\n\n  debounced.cancel = cancelTimers;\n  debounced.flush = flush;\n  return debounced;\n}\n\nexports.debounce = debounce;\n//# sourceMappingURL=debounce.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvZGVib3VuY2UuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEU7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLGdCQUFnQjtBQUNoQiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3V0aWxzL2RlYm91bmNlLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG4vKipcbiAqIEhlYXZpbHkgc2ltcGxpZmllZCBkZWJvdW5jZSBmdW5jdGlvbiBiYXNlZCBvbiBsb2Rhc2guZGVib3VuY2UuXG4gKlxuICogVGhpcyBmdW5jdGlvbiB0YWtlcyBhIGNhbGxiYWNrIGZ1bmN0aW9uIChAcGFyYW0gZnVuKSBhbmQgZGVsYXlzIGl0cyBpbnZvY2F0aW9uXG4gKiBieSBAcGFyYW0gd2FpdCBtaWxsaXNlY29uZHMuIE9wdGlvbmFsbHksIGEgbWF4V2FpdCBjYW4gYmUgc3BlY2lmaWVkIGluIEBwYXJhbSBvcHRpb25zLFxuICogd2hpY2ggZW5zdXJlcyB0aGF0IHRoZSBjYWxsYmFjayBpcyBpbnZva2VkIGF0IGxlYXN0IG9uY2UgYWZ0ZXIgdGhlIHNwZWNpZmllZCBtYXguIHdhaXQgdGltZS5cbiAqXG4gKiBAcGFyYW0gZnVuYyB0aGUgZnVuY3Rpb24gd2hvc2UgaW52b2NhdGlvbiBpcyB0byBiZSBkZWJvdW5jZWRcbiAqIEBwYXJhbSB3YWl0IHRoZSBtaW5pbXVtIHRpbWUgdW50aWwgdGhlIGZ1bmN0aW9uIGlzIGludm9rZWQgYWZ0ZXIgaXQgd2FzIGNhbGxlZCBvbmNlXG4gKiBAcGFyYW0gb3B0aW9ucyB0aGUgb3B0aW9ucyBvYmplY3QsIHdoaWNoIGNhbiBjb250YWluIHRoZSBgbWF4V2FpdGAgcHJvcGVydHlcbiAqXG4gKiBAcmV0dXJucyB0aGUgZGVib3VuY2VkIHZlcnNpb24gb2YgdGhlIGZ1bmN0aW9uLCB3aGljaCBuZWVkcyB0byBiZSBjYWxsZWQgYXQgbGVhc3Qgb25jZSB0byBzdGFydCB0aGVcbiAqICAgICAgICAgIGRlYm91bmNpbmcgcHJvY2Vzcy4gU3Vic2VxdWVudCBjYWxscyB3aWxsIHJlc2V0IHRoZSBkZWJvdW5jaW5nIHRpbWVyIGFuZCwgaW4gY2FzZSBAcGFyYW1mdW5jXG4gKiAgICAgICAgICB3YXMgYWxyZWFkeSBpbnZva2VkIGluIHRoZSBtZWFudGltZSwgcmV0dXJuIEBwYXJhbSBmdW5jJ3MgcmV0dXJuIHZhbHVlLlxuICogICAgICAgICAgVGhlIGRlYm91bmNlZCBmdW5jdGlvbiBoYXMgdHdvIGFkZGl0aW9uYWwgcHJvcGVydGllczpcbiAqICAgICAgICAgIC0gYGZsdXNoYDogSW52b2tlcyB0aGUgZGVib3VuY2VkIGZ1bmN0aW9uIGltbWVkaWF0ZWx5IGFuZCByZXR1cm5zIGl0cyByZXR1cm4gdmFsdWVcbiAqICAgICAgICAgIC0gYGNhbmNlbGA6IENhbmNlbHMgdGhlIGRlYm91bmNpbmcgcHJvY2VzcyBhbmQgcmVzZXRzIHRoZSBkZWJvdW5jaW5nIHRpbWVyXG4gKi9cbmZ1bmN0aW9uIGRlYm91bmNlKGZ1bmMsIHdhaXQsIG9wdGlvbnMpIHtcbiAgbGV0IGNhbGxiYWNrUmV0dXJuVmFsdWU7XG5cbiAgbGV0IHRpbWVySWQ7XG4gIGxldCBtYXhUaW1lcklkO1xuXG4gIGNvbnN0IG1heFdhaXQgPSBvcHRpb25zPy5tYXhXYWl0ID8gTWF0aC5tYXgob3B0aW9ucy5tYXhXYWl0LCB3YWl0KSA6IDA7XG4gIGNvbnN0IHNldFRpbWVvdXRJbXBsID0gb3B0aW9ucz8uc2V0VGltZW91dEltcGwgfHwgc2V0VGltZW91dDtcblxuICBmdW5jdGlvbiBpbnZva2VGdW5jKCkge1xuICAgIGNhbmNlbFRpbWVycygpO1xuICAgIGNhbGxiYWNrUmV0dXJuVmFsdWUgPSBmdW5jKCk7XG4gICAgcmV0dXJuIGNhbGxiYWNrUmV0dXJuVmFsdWU7XG4gIH1cblxuICBmdW5jdGlvbiBjYW5jZWxUaW1lcnMoKSB7XG4gICAgdGltZXJJZCAhPT0gdW5kZWZpbmVkICYmIGNsZWFyVGltZW91dCh0aW1lcklkKTtcbiAgICBtYXhUaW1lcklkICE9PSB1bmRlZmluZWQgJiYgY2xlYXJUaW1lb3V0KG1heFRpbWVySWQpO1xuICAgIHRpbWVySWQgPSBtYXhUaW1lcklkID0gdW5kZWZpbmVkO1xuICB9XG5cbiAgZnVuY3Rpb24gZmx1c2goKSB7XG4gICAgaWYgKHRpbWVySWQgIT09IHVuZGVmaW5lZCB8fCBtYXhUaW1lcklkICE9PSB1bmRlZmluZWQpIHtcbiAgICAgIHJldHVybiBpbnZva2VGdW5jKCk7XG4gICAgfVxuICAgIHJldHVybiBjYWxsYmFja1JldHVyblZhbHVlO1xuICB9XG5cbiAgZnVuY3Rpb24gZGVib3VuY2VkKCkge1xuICAgIGlmICh0aW1lcklkKSB7XG4gICAgICBjbGVhclRpbWVvdXQodGltZXJJZCk7XG4gICAgfVxuICAgIHRpbWVySWQgPSBzZXRUaW1lb3V0SW1wbChpbnZva2VGdW5jLCB3YWl0KTtcblxuICAgIGlmIChtYXhXYWl0ICYmIG1heFRpbWVySWQgPT09IHVuZGVmaW5lZCkge1xuICAgICAgbWF4VGltZXJJZCA9IHNldFRpbWVvdXRJbXBsKGludm9rZUZ1bmMsIG1heFdhaXQpO1xuICAgIH1cblxuICAgIHJldHVybiBjYWxsYmFja1JldHVyblZhbHVlO1xuICB9XG5cbiAgZGVib3VuY2VkLmNhbmNlbCA9IGNhbmNlbFRpbWVycztcbiAgZGVib3VuY2VkLmZsdXNoID0gZmx1c2g7XG4gIHJldHVybiBkZWJvdW5jZWQ7XG59XG5cbmV4cG9ydHMuZGVib3VuY2UgPSBkZWJvdW5jZTtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWRlYm91bmNlLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debounce.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-ids.js":
/*!*******************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-ids.js ***!
  \*******************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst worldwide = __webpack_require__(/*! ./worldwide.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/worldwide.js\");\n\nlet parsedStackResults;\nlet lastKeysCount;\nlet cachedFilenameDebugIds;\n\n/**\n * Returns a map of filenames to debug identifiers.\n */\nfunction getFilenameToDebugIdMap(stackParser) {\n  const debugIdMap = worldwide.GLOBAL_OBJ._sentryDebugIds;\n  if (!debugIdMap) {\n    return {};\n  }\n\n  const debugIdKeys = Object.keys(debugIdMap);\n\n  // If the count of registered globals hasn't changed since the last call, we\n  // can just return the cached result.\n  if (cachedFilenameDebugIds && debugIdKeys.length === lastKeysCount) {\n    return cachedFilenameDebugIds;\n  }\n\n  lastKeysCount = debugIdKeys.length;\n\n  // Build a map of filename -> debug_id.\n  cachedFilenameDebugIds = debugIdKeys.reduce((acc, stackKey) => {\n    if (!parsedStackResults) {\n      parsedStackResults = {};\n    }\n\n    const result = parsedStackResults[stackKey];\n\n    if (result) {\n      acc[result[0]] = result[1];\n    } else {\n      const parsedStack = stackParser(stackKey);\n\n      for (let i = parsedStack.length - 1; i >= 0; i--) {\n        const stackFrame = parsedStack[i];\n        const filename = stackFrame?.filename;\n        const debugId = debugIdMap[stackKey];\n\n        if (filename && debugId) {\n          acc[filename] = debugId;\n          parsedStackResults[stackKey] = [filename, debugId];\n          break;\n        }\n      }\n    }\n\n    return acc;\n  }, {});\n\n  return cachedFilenameDebugIds;\n}\n\n/**\n * Returns a list of debug images for the given resources.\n */\nfunction getDebugImagesForResources(\n  stackParser,\n  resource_paths,\n) {\n  const filenameDebugIdMap = getFilenameToDebugIdMap(stackParser);\n\n  if (!filenameDebugIdMap) {\n    return [];\n  }\n\n  const images = [];\n  for (const path of resource_paths) {\n    if (path && filenameDebugIdMap[path]) {\n      images.push({\n        type: 'sourcemap',\n        code_file: path,\n        debug_id: filenameDebugIdMap[path] ,\n      });\n    }\n  }\n\n  return images;\n}\n\nexports.getDebugImagesForResources = getDebugImagesForResources;\nexports.getFilenameToDebugIdMap = getFilenameToDebugIdMap;\n//# sourceMappingURL=debug-ids.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvZGVidWctaWRzLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLGtCQUFrQixtQkFBTyxDQUFDLG9JQUFnQjs7QUFFMUM7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQSxNQUFNO0FBQ047O0FBRUEsMkNBQTJDLFFBQVE7QUFDbkQ7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0EsR0FBRyxJQUFJOztBQUVQO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxPQUFPO0FBQ1A7QUFDQTs7QUFFQTtBQUNBOztBQUVBLGtDQUFrQztBQUNsQywrQkFBK0I7QUFDL0IiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9kZWJ1Zy1pZHMuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IHdvcmxkd2lkZSA9IHJlcXVpcmUoJy4vd29ybGR3aWRlLmpzJyk7XG5cbmxldCBwYXJzZWRTdGFja1Jlc3VsdHM7XG5sZXQgbGFzdEtleXNDb3VudDtcbmxldCBjYWNoZWRGaWxlbmFtZURlYnVnSWRzO1xuXG4vKipcbiAqIFJldHVybnMgYSBtYXAgb2YgZmlsZW5hbWVzIHRvIGRlYnVnIGlkZW50aWZpZXJzLlxuICovXG5mdW5jdGlvbiBnZXRGaWxlbmFtZVRvRGVidWdJZE1hcChzdGFja1BhcnNlcikge1xuICBjb25zdCBkZWJ1Z0lkTWFwID0gd29ybGR3aWRlLkdMT0JBTF9PQkouX3NlbnRyeURlYnVnSWRzO1xuICBpZiAoIWRlYnVnSWRNYXApIHtcbiAgICByZXR1cm4ge307XG4gIH1cblxuICBjb25zdCBkZWJ1Z0lkS2V5cyA9IE9iamVjdC5rZXlzKGRlYnVnSWRNYXApO1xuXG4gIC8vIElmIHRoZSBjb3VudCBvZiByZWdpc3RlcmVkIGdsb2JhbHMgaGFzbid0IGNoYW5nZWQgc2luY2UgdGhlIGxhc3QgY2FsbCwgd2VcbiAgLy8gY2FuIGp1c3QgcmV0dXJuIHRoZSBjYWNoZWQgcmVzdWx0LlxuICBpZiAoY2FjaGVkRmlsZW5hbWVEZWJ1Z0lkcyAmJiBkZWJ1Z0lkS2V5cy5sZW5ndGggPT09IGxhc3RLZXlzQ291bnQpIHtcbiAgICByZXR1cm4gY2FjaGVkRmlsZW5hbWVEZWJ1Z0lkcztcbiAgfVxuXG4gIGxhc3RLZXlzQ291bnQgPSBkZWJ1Z0lkS2V5cy5sZW5ndGg7XG5cbiAgLy8gQnVpbGQgYSBtYXAgb2YgZmlsZW5hbWUgLT4gZGVidWdfaWQuXG4gIGNhY2hlZEZpbGVuYW1lRGVidWdJZHMgPSBkZWJ1Z0lkS2V5cy5yZWR1Y2UoKGFjYywgc3RhY2tLZXkpID0+IHtcbiAgICBpZiAoIXBhcnNlZFN0YWNrUmVzdWx0cykge1xuICAgICAgcGFyc2VkU3RhY2tSZXN1bHRzID0ge307XG4gICAgfVxuXG4gICAgY29uc3QgcmVzdWx0ID0gcGFyc2VkU3RhY2tSZXN1bHRzW3N0YWNrS2V5XTtcblxuICAgIGlmIChyZXN1bHQpIHtcbiAgICAgIGFjY1tyZXN1bHRbMF1dID0gcmVzdWx0WzFdO1xuICAgIH0gZWxzZSB7XG4gICAgICBjb25zdCBwYXJzZWRTdGFjayA9IHN0YWNrUGFyc2VyKHN0YWNrS2V5KTtcblxuICAgICAgZm9yIChsZXQgaSA9IHBhcnNlZFN0YWNrLmxlbmd0aCAtIDE7IGkgPj0gMDsgaS0tKSB7XG4gICAgICAgIGNvbnN0IHN0YWNrRnJhbWUgPSBwYXJzZWRTdGFja1tpXTtcbiAgICAgICAgY29uc3QgZmlsZW5hbWUgPSBzdGFja0ZyYW1lPy5maWxlbmFtZTtcbiAgICAgICAgY29uc3QgZGVidWdJZCA9IGRlYnVnSWRNYXBbc3RhY2tLZXldO1xuXG4gICAgICAgIGlmIChmaWxlbmFtZSAmJiBkZWJ1Z0lkKSB7XG4gICAgICAgICAgYWNjW2ZpbGVuYW1lXSA9IGRlYnVnSWQ7XG4gICAgICAgICAgcGFyc2VkU3RhY2tSZXN1bHRzW3N0YWNrS2V5XSA9IFtmaWxlbmFtZSwgZGVidWdJZF07XG4gICAgICAgICAgYnJlYWs7XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9XG5cbiAgICByZXR1cm4gYWNjO1xuICB9LCB7fSk7XG5cbiAgcmV0dXJuIGNhY2hlZEZpbGVuYW1lRGVidWdJZHM7XG59XG5cbi8qKlxuICogUmV0dXJucyBhIGxpc3Qgb2YgZGVidWcgaW1hZ2VzIGZvciB0aGUgZ2l2ZW4gcmVzb3VyY2VzLlxuICovXG5mdW5jdGlvbiBnZXREZWJ1Z0ltYWdlc0ZvclJlc291cmNlcyhcbiAgc3RhY2tQYXJzZXIsXG4gIHJlc291cmNlX3BhdGhzLFxuKSB7XG4gIGNvbnN0IGZpbGVuYW1lRGVidWdJZE1hcCA9IGdldEZpbGVuYW1lVG9EZWJ1Z0lkTWFwKHN0YWNrUGFyc2VyKTtcblxuICBpZiAoIWZpbGVuYW1lRGVidWdJZE1hcCkge1xuICAgIHJldHVybiBbXTtcbiAgfVxuXG4gIGNvbnN0IGltYWdlcyA9IFtdO1xuICBmb3IgKGNvbnN0IHBhdGggb2YgcmVzb3VyY2VfcGF0aHMpIHtcbiAgICBpZiAocGF0aCAmJiBmaWxlbmFtZURlYnVnSWRNYXBbcGF0aF0pIHtcbiAgICAgIGltYWdlcy5wdXNoKHtcbiAgICAgICAgdHlwZTogJ3NvdXJjZW1hcCcsXG4gICAgICAgIGNvZGVfZmlsZTogcGF0aCxcbiAgICAgICAgZGVidWdfaWQ6IGZpbGVuYW1lRGVidWdJZE1hcFtwYXRoXSAsXG4gICAgICB9KTtcbiAgICB9XG4gIH1cblxuICByZXR1cm4gaW1hZ2VzO1xufVxuXG5leHBvcnRzLmdldERlYnVnSW1hZ2VzRm9yUmVzb3VyY2VzID0gZ2V0RGVidWdJbWFnZXNGb3JSZXNvdXJjZXM7XG5leHBvcnRzLmdldEZpbGVuYW1lVG9EZWJ1Z0lkTWFwID0gZ2V0RmlsZW5hbWVUb0RlYnVnSWRNYXA7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1kZWJ1Zy1pZHMuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-ids.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js":
/*!**********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js ***!
  \**********************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst carrier = __webpack_require__(/*! ../carrier.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/carrier.js\");\nconst debugBuild = __webpack_require__(/*! ../debug-build.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst worldwide = __webpack_require__(/*! ./worldwide.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/worldwide.js\");\n\n/**\n * A Sentry Logger instance.\n *\n * @deprecated Use {@link debug} instead with the {@link SentryDebugLogger} type.\n */\n\nconst CONSOLE_LEVELS = [\n  'debug',\n  'info',\n  'warn',\n  'error',\n  'log',\n  'assert',\n  'trace',\n] ;\n\n/** Prefix for logging strings */\nconst PREFIX = 'Sentry Logger ';\n\n/** This may be mutated by the console instrumentation. */\nconst originalConsoleMethods\n\n = {};\n\n/**\n * Temporarily disable sentry console instrumentations.\n *\n * @param callback The function to run against the original `console` messages\n * @returns The results of the callback\n */\nfunction consoleSandbox(callback) {\n  if (!('console' in worldwide.GLOBAL_OBJ)) {\n    return callback();\n  }\n\n  const console = worldwide.GLOBAL_OBJ.console ;\n  const wrappedFuncs = {};\n\n  const wrappedLevels = Object.keys(originalConsoleMethods) ;\n\n  // Restore all wrapped console methods\n  wrappedLevels.forEach(level => {\n    const originalConsoleMethod = originalConsoleMethods[level];\n    wrappedFuncs[level] = console[level] ;\n    console[level] = originalConsoleMethod ;\n  });\n\n  try {\n    return callback();\n  } finally {\n    // Revert restoration to wrapped state\n    wrappedLevels.forEach(level => {\n      console[level] = wrappedFuncs[level] ;\n    });\n  }\n}\n\nfunction enable() {\n  _getLoggerSettings().enabled = true;\n}\n\nfunction disable() {\n  _getLoggerSettings().enabled = false;\n}\n\nfunction isEnabled() {\n  return _getLoggerSettings().enabled;\n}\n\nfunction log(...args) {\n  _maybeLog('log', ...args);\n}\n\nfunction info(...args) {\n  _maybeLog('info', ...args);\n}\n\nfunction warn(...args) {\n  _maybeLog('warn', ...args);\n}\n\nfunction error(...args) {\n  _maybeLog('error', ...args);\n}\n\nfunction _debug(...args) {\n  _maybeLog('debug', ...args);\n}\n\nfunction assert(...args) {\n  _maybeLog('assert', ...args);\n}\n\nfunction trace(...args) {\n  _maybeLog('trace', ...args);\n}\n\nfunction _maybeLog(level, ...args) {\n  if (!debugBuild.DEBUG_BUILD) {\n    return;\n  }\n\n  if (isEnabled()) {\n    consoleSandbox(() => {\n      worldwide.GLOBAL_OBJ.console[level](`${PREFIX}[${level}]:`, ...args);\n    });\n  }\n}\n\nfunction _getLoggerSettings() {\n  if (!debugBuild.DEBUG_BUILD) {\n    return { enabled: false };\n  }\n\n  return carrier.getGlobalSingleton('loggerSettings', () => ({ enabled: false }));\n}\n\n/**\n * This is a logger singleton which either logs things or no-ops if logging is not enabled.\n * The logger is a singleton on the carrier, to ensure that a consistent logger is used throughout the SDK.\n *\n * @deprecated Use {@link debug} instead.\n */\nconst logger = {\n  /** Enable logging. */\n  enable,\n  /** Disable logging. */\n  disable,\n  /** Check if logging is enabled. */\n  isEnabled,\n  /** Log a message. */\n  log,\n  /** Log level info */\n  info,\n  /** Log a warning. */\n  warn,\n  /** Log an error. */\n  error,\n  /** Log a debug message. */\n  debug: _debug,\n  /** Log an assertion. */\n  assert,\n  /** Log a trace. */\n  trace,\n  // eslint-disable-next-line deprecation/deprecation\n} ;\n\n/**\n * This is a logger singleton which either logs things or no-ops if logging is not enabled.\n */\nconst debug = {\n  /** Enable logging. */\n  enable,\n  /** Disable logging. */\n  disable,\n  /** Check if logging is enabled. */\n  isEnabled,\n  /** Log a message. */\n  log,\n  /** Log a warning. */\n  warn,\n  /** Log an error. */\n  error,\n} ;\n\nexports.CONSOLE_LEVELS = CONSOLE_LEVELS;\nexports.consoleSandbox = consoleSandbox;\nexports.debug = debug;\nexports.logger = logger;\nexports.originalConsoleMethods = originalConsoleMethods;\n//# sourceMappingURL=debug-logger.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvZGVidWctbG9nZ2VyLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLGdCQUFnQixtQkFBTyxDQUFDLDJIQUFlO0FBQ3ZDLG1CQUFtQixtQkFBTyxDQUFDLG1JQUFtQjtBQUM5QyxrQkFBa0IsbUJBQU8sQ0FBQyxvSUFBZ0I7O0FBRTFDO0FBQ0E7QUFDQTtBQUNBLG9CQUFvQixhQUFhLGtCQUFrQix5QkFBeUI7QUFDNUU7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxHQUFHOztBQUVIO0FBQ0E7QUFDQSxJQUFJO0FBQ0o7QUFDQTtBQUNBO0FBQ0EsS0FBSztBQUNMO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQSw2Q0FBNkMsT0FBTyxHQUFHLE1BQU07QUFDN0QsS0FBSztBQUNMO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLGFBQWE7QUFDYjs7QUFFQSwrREFBK0QsZ0JBQWdCO0FBQy9FOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0Esb0JBQW9CLGFBQWE7QUFDakM7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsc0JBQXNCO0FBQ3RCLHNCQUFzQjtBQUN0QixhQUFhO0FBQ2IsY0FBYztBQUNkLDhCQUE4QjtBQUM5QiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3V0aWxzL2RlYnVnLWxvZ2dlci5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgY2FycmllciA9IHJlcXVpcmUoJy4uL2NhcnJpZXIuanMnKTtcbmNvbnN0IGRlYnVnQnVpbGQgPSByZXF1aXJlKCcuLi9kZWJ1Zy1idWlsZC5qcycpO1xuY29uc3Qgd29ybGR3aWRlID0gcmVxdWlyZSgnLi93b3JsZHdpZGUuanMnKTtcblxuLyoqXG4gKiBBIFNlbnRyeSBMb2dnZXIgaW5zdGFuY2UuXG4gKlxuICogQGRlcHJlY2F0ZWQgVXNlIHtAbGluayBkZWJ1Z30gaW5zdGVhZCB3aXRoIHRoZSB7QGxpbmsgU2VudHJ5RGVidWdMb2dnZXJ9IHR5cGUuXG4gKi9cblxuY29uc3QgQ09OU09MRV9MRVZFTFMgPSBbXG4gICdkZWJ1ZycsXG4gICdpbmZvJyxcbiAgJ3dhcm4nLFxuICAnZXJyb3InLFxuICAnbG9nJyxcbiAgJ2Fzc2VydCcsXG4gICd0cmFjZScsXG5dIDtcblxuLyoqIFByZWZpeCBmb3IgbG9nZ2luZyBzdHJpbmdzICovXG5jb25zdCBQUkVGSVggPSAnU2VudHJ5IExvZ2dlciAnO1xuXG4vKiogVGhpcyBtYXkgYmUgbXV0YXRlZCBieSB0aGUgY29uc29sZSBpbnN0cnVtZW50YXRpb24uICovXG5jb25zdCBvcmlnaW5hbENvbnNvbGVNZXRob2RzXG5cbiA9IHt9O1xuXG4vKipcbiAqIFRlbXBvcmFyaWx5IGRpc2FibGUgc2VudHJ5IGNvbnNvbGUgaW5zdHJ1bWVudGF0aW9ucy5cbiAqXG4gKiBAcGFyYW0gY2FsbGJhY2sgVGhlIGZ1bmN0aW9uIHRvIHJ1biBhZ2FpbnN0IHRoZSBvcmlnaW5hbCBgY29uc29sZWAgbWVzc2FnZXNcbiAqIEByZXR1cm5zIFRoZSByZXN1bHRzIG9mIHRoZSBjYWxsYmFja1xuICovXG5mdW5jdGlvbiBjb25zb2xlU2FuZGJveChjYWxsYmFjaykge1xuICBpZiAoISgnY29uc29sZScgaW4gd29ybGR3aWRlLkdMT0JBTF9PQkopKSB7XG4gICAgcmV0dXJuIGNhbGxiYWNrKCk7XG4gIH1cblxuICBjb25zdCBjb25zb2xlID0gd29ybGR3aWRlLkdMT0JBTF9PQkouY29uc29sZSA7XG4gIGNvbnN0IHdyYXBwZWRGdW5jcyA9IHt9O1xuXG4gIGNvbnN0IHdyYXBwZWRMZXZlbHMgPSBPYmplY3Qua2V5cyhvcmlnaW5hbENvbnNvbGVNZXRob2RzKSA7XG5cbiAgLy8gUmVzdG9yZSBhbGwgd3JhcHBlZCBjb25zb2xlIG1ldGhvZHNcbiAgd3JhcHBlZExldmVscy5mb3JFYWNoKGxldmVsID0+IHtcbiAgICBjb25zdCBvcmlnaW5hbENvbnNvbGVNZXRob2QgPSBvcmlnaW5hbENvbnNvbGVNZXRob2RzW2xldmVsXTtcbiAgICB3cmFwcGVkRnVuY3NbbGV2ZWxdID0gY29uc29sZVtsZXZlbF0gO1xuICAgIGNvbnNvbGVbbGV2ZWxdID0gb3JpZ2luYWxDb25zb2xlTWV0aG9kIDtcbiAgfSk7XG5cbiAgdHJ5IHtcbiAgICByZXR1cm4gY2FsbGJhY2soKTtcbiAgfSBmaW5hbGx5IHtcbiAgICAvLyBSZXZlcnQgcmVzdG9yYXRpb24gdG8gd3JhcHBlZCBzdGF0ZVxuICAgIHdyYXBwZWRMZXZlbHMuZm9yRWFjaChsZXZlbCA9PiB7XG4gICAgICBjb25zb2xlW2xldmVsXSA9IHdyYXBwZWRGdW5jc1tsZXZlbF0gO1xuICAgIH0pO1xuICB9XG59XG5cbmZ1bmN0aW9uIGVuYWJsZSgpIHtcbiAgX2dldExvZ2dlclNldHRpbmdzKCkuZW5hYmxlZCA9IHRydWU7XG59XG5cbmZ1bmN0aW9uIGRpc2FibGUoKSB7XG4gIF9nZXRMb2dnZXJTZXR0aW5ncygpLmVuYWJsZWQgPSBmYWxzZTtcbn1cblxuZnVuY3Rpb24gaXNFbmFibGVkKCkge1xuICByZXR1cm4gX2dldExvZ2dlclNldHRpbmdzKCkuZW5hYmxlZDtcbn1cblxuZnVuY3Rpb24gbG9nKC4uLmFyZ3MpIHtcbiAgX21heWJlTG9nKCdsb2cnLCAuLi5hcmdzKTtcbn1cblxuZnVuY3Rpb24gaW5mbyguLi5hcmdzKSB7XG4gIF9tYXliZUxvZygnaW5mbycsIC4uLmFyZ3MpO1xufVxuXG5mdW5jdGlvbiB3YXJuKC4uLmFyZ3MpIHtcbiAgX21heWJlTG9nKCd3YXJuJywgLi4uYXJncyk7XG59XG5cbmZ1bmN0aW9uIGVycm9yKC4uLmFyZ3MpIHtcbiAgX21heWJlTG9nKCdlcnJvcicsIC4uLmFyZ3MpO1xufVxuXG5mdW5jdGlvbiBfZGVidWcoLi4uYXJncykge1xuICBfbWF5YmVMb2coJ2RlYnVnJywgLi4uYXJncyk7XG59XG5cbmZ1bmN0aW9uIGFzc2VydCguLi5hcmdzKSB7XG4gIF9tYXliZUxvZygnYXNzZXJ0JywgLi4uYXJncyk7XG59XG5cbmZ1bmN0aW9uIHRyYWNlKC4uLmFyZ3MpIHtcbiAgX21heWJlTG9nKCd0cmFjZScsIC4uLmFyZ3MpO1xufVxuXG5mdW5jdGlvbiBfbWF5YmVMb2cobGV2ZWwsIC4uLmFyZ3MpIHtcbiAgaWYgKCFkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEKSB7XG4gICAgcmV0dXJuO1xuICB9XG5cbiAgaWYgKGlzRW5hYmxlZCgpKSB7XG4gICAgY29uc29sZVNhbmRib3goKCkgPT4ge1xuICAgICAgd29ybGR3aWRlLkdMT0JBTF9PQkouY29uc29sZVtsZXZlbF0oYCR7UFJFRklYfVske2xldmVsfV06YCwgLi4uYXJncyk7XG4gICAgfSk7XG4gIH1cbn1cblxuZnVuY3Rpb24gX2dldExvZ2dlclNldHRpbmdzKCkge1xuICBpZiAoIWRlYnVnQnVpbGQuREVCVUdfQlVJTEQpIHtcbiAgICByZXR1cm4geyBlbmFibGVkOiBmYWxzZSB9O1xuICB9XG5cbiAgcmV0dXJuIGNhcnJpZXIuZ2V0R2xvYmFsU2luZ2xldG9uKCdsb2dnZXJTZXR0aW5ncycsICgpID0+ICh7IGVuYWJsZWQ6IGZhbHNlIH0pKTtcbn1cblxuLyoqXG4gKiBUaGlzIGlzIGEgbG9nZ2VyIHNpbmdsZXRvbiB3aGljaCBlaXRoZXIgbG9ncyB0aGluZ3Mgb3Igbm8tb3BzIGlmIGxvZ2dpbmcgaXMgbm90IGVuYWJsZWQuXG4gKiBUaGUgbG9nZ2VyIGlzIGEgc2luZ2xldG9uIG9uIHRoZSBjYXJyaWVyLCB0byBlbnN1cmUgdGhhdCBhIGNvbnNpc3RlbnQgbG9nZ2VyIGlzIHVzZWQgdGhyb3VnaG91dCB0aGUgU0RLLlxuICpcbiAqIEBkZXByZWNhdGVkIFVzZSB7QGxpbmsgZGVidWd9IGluc3RlYWQuXG4gKi9cbmNvbnN0IGxvZ2dlciA9IHtcbiAgLyoqIEVuYWJsZSBsb2dnaW5nLiAqL1xuICBlbmFibGUsXG4gIC8qKiBEaXNhYmxlIGxvZ2dpbmcuICovXG4gIGRpc2FibGUsXG4gIC8qKiBDaGVjayBpZiBsb2dnaW5nIGlzIGVuYWJsZWQuICovXG4gIGlzRW5hYmxlZCxcbiAgLyoqIExvZyBhIG1lc3NhZ2UuICovXG4gIGxvZyxcbiAgLyoqIExvZyBsZXZlbCBpbmZvICovXG4gIGluZm8sXG4gIC8qKiBMb2cgYSB3YXJuaW5nLiAqL1xuICB3YXJuLFxuICAvKiogTG9nIGFuIGVycm9yLiAqL1xuICBlcnJvcixcbiAgLyoqIExvZyBhIGRlYnVnIG1lc3NhZ2UuICovXG4gIGRlYnVnOiBfZGVidWcsXG4gIC8qKiBMb2cgYW4gYXNzZXJ0aW9uLiAqL1xuICBhc3NlcnQsXG4gIC8qKiBMb2cgYSB0cmFjZS4gKi9cbiAgdHJhY2UsXG4gIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBkZXByZWNhdGlvbi9kZXByZWNhdGlvblxufSA7XG5cbi8qKlxuICogVGhpcyBpcyBhIGxvZ2dlciBzaW5nbGV0b24gd2hpY2ggZWl0aGVyIGxvZ3MgdGhpbmdzIG9yIG5vLW9wcyBpZiBsb2dnaW5nIGlzIG5vdCBlbmFibGVkLlxuICovXG5jb25zdCBkZWJ1ZyA9IHtcbiAgLyoqIEVuYWJsZSBsb2dnaW5nLiAqL1xuICBlbmFibGUsXG4gIC8qKiBEaXNhYmxlIGxvZ2dpbmcuICovXG4gIGRpc2FibGUsXG4gIC8qKiBDaGVjayBpZiBsb2dnaW5nIGlzIGVuYWJsZWQuICovXG4gIGlzRW5hYmxlZCxcbiAgLyoqIExvZyBhIG1lc3NhZ2UuICovXG4gIGxvZyxcbiAgLyoqIExvZyBhIHdhcm5pbmcuICovXG4gIHdhcm4sXG4gIC8qKiBMb2cgYW4gZXJyb3IuICovXG4gIGVycm9yLFxufSA7XG5cbmV4cG9ydHMuQ09OU09MRV9MRVZFTFMgPSBDT05TT0xFX0xFVkVMUztcbmV4cG9ydHMuY29uc29sZVNhbmRib3ggPSBjb25zb2xlU2FuZGJveDtcbmV4cG9ydHMuZGVidWcgPSBkZWJ1ZztcbmV4cG9ydHMubG9nZ2VyID0gbG9nZ2VyO1xuZXhwb3J0cy5vcmlnaW5hbENvbnNvbGVNZXRob2RzID0gb3JpZ2luYWxDb25zb2xlTWV0aG9kcztcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWRlYnVnLWxvZ2dlci5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/dsn.js":
/*!*************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/dsn.js ***!
  \*************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst debugBuild = __webpack_require__(/*! ../debug-build.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst debugLogger = __webpack_require__(/*! ./debug-logger.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\n\n/** Regular expression used to extract org ID from a DSN host. */\nconst ORG_ID_REGEX = /^o(\\d+)\\./;\n\n/** Regular expression used to parse a Dsn. */\nconst DSN_REGEX = /^(?:(\\w+):)\\/\\/(?:(\\w+)(?::(\\w+)?)?@)([\\w.-]+)(?::(\\d+))?\\/(.+)/;\n\nfunction isValidProtocol(protocol) {\n  return protocol === 'http' || protocol === 'https';\n}\n\n/**\n * Renders the string representation of this Dsn.\n *\n * By default, this will render the public representation without the password\n * component. To get the deprecated private representation, set `withPassword`\n * to true.\n *\n * @param withPassword When set to true, the password will be included.\n */\nfunction dsnToString(dsn, withPassword = false) {\n  const { host, path, pass, port, projectId, protocol, publicKey } = dsn;\n  return (\n    `${protocol}://${publicKey}${withPassword && pass ? `:${pass}` : ''}` +\n    `@${host}${port ? `:${port}` : ''}/${path ? `${path}/` : path}${projectId}`\n  );\n}\n\n/**\n * Parses a Dsn from a given string.\n *\n * @param str A Dsn as string\n * @returns Dsn as DsnComponents or undefined if @param str is not a valid DSN string\n */\nfunction dsnFromString(str) {\n  const match = DSN_REGEX.exec(str);\n\n  if (!match) {\n    // This should be logged to the console\n    debugLogger.consoleSandbox(() => {\n      // eslint-disable-next-line no-console\n      console.error(`Invalid Sentry Dsn: ${str}`);\n    });\n    return undefined;\n  }\n\n  const [protocol, publicKey, pass = '', host = '', port = '', lastPath = ''] = match.slice(1);\n  let path = '';\n  let projectId = lastPath;\n\n  const split = projectId.split('/');\n  if (split.length > 1) {\n    path = split.slice(0, -1).join('/');\n    projectId = split.pop() ;\n  }\n\n  if (projectId) {\n    const projectMatch = projectId.match(/^\\d+/);\n    if (projectMatch) {\n      projectId = projectMatch[0];\n    }\n  }\n\n  return dsnFromComponents({ host, pass, path, projectId, port, protocol: protocol , publicKey });\n}\n\nfunction dsnFromComponents(components) {\n  return {\n    protocol: components.protocol,\n    publicKey: components.publicKey || '',\n    pass: components.pass || '',\n    host: components.host,\n    port: components.port || '',\n    path: components.path || '',\n    projectId: components.projectId,\n  };\n}\n\nfunction validateDsn(dsn) {\n  if (!debugBuild.DEBUG_BUILD) {\n    return true;\n  }\n\n  const { port, projectId, protocol } = dsn;\n\n  const requiredComponents = ['protocol', 'publicKey', 'host', 'projectId'];\n  const hasMissingRequiredComponent = requiredComponents.find(component => {\n    if (!dsn[component]) {\n      debugLogger.debug.error(`Invalid Sentry Dsn: ${component} missing`);\n      return true;\n    }\n    return false;\n  });\n\n  if (hasMissingRequiredComponent) {\n    return false;\n  }\n\n  if (!projectId.match(/^\\d+$/)) {\n    debugLogger.debug.error(`Invalid Sentry Dsn: Invalid projectId ${projectId}`);\n    return false;\n  }\n\n  if (!isValidProtocol(protocol)) {\n    debugLogger.debug.error(`Invalid Sentry Dsn: Invalid protocol ${protocol}`);\n    return false;\n  }\n\n  if (port && isNaN(parseInt(port, 10))) {\n    debugLogger.debug.error(`Invalid Sentry Dsn: Invalid port ${port}`);\n    return false;\n  }\n\n  return true;\n}\n\n/**\n * Extract the org ID from a DSN host.\n *\n * @param host The host from a DSN\n * @returns The org ID if found, undefined otherwise\n */\nfunction extractOrgIdFromDsnHost(host) {\n  const match = host.match(ORG_ID_REGEX);\n\n  return match?.[1];\n}\n\n/**\n * Creates a valid Sentry Dsn object, identifying a Sentry instance and project.\n * @returns a valid DsnComponents object or `undefined` if @param from is an invalid DSN source\n */\nfunction makeDsn(from) {\n  const components = typeof from === 'string' ? dsnFromString(from) : dsnFromComponents(from);\n  if (!components || !validateDsn(components)) {\n    return undefined;\n  }\n  return components;\n}\n\nexports.dsnFromString = dsnFromString;\nexports.dsnToString = dsnToString;\nexports.extractOrgIdFromDsnHost = extractOrgIdFromDsnHost;\nexports.makeDsn = makeDsn;\n//# sourceMappingURL=dsn.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvZHNuLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLG1CQUFtQixtQkFBTyxDQUFDLG1JQUFtQjtBQUM5QyxvQkFBb0IsbUJBQU8sQ0FBQywwSUFBbUI7O0FBRS9DO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxVQUFVLHlEQUF5RDtBQUNuRTtBQUNBLE9BQU8sU0FBUyxLQUFLLFVBQVUsRUFBRSwyQkFBMkIsS0FBSyxPQUFPO0FBQ3hFLFFBQVEsS0FBSyxFQUFFLFdBQVcsS0FBSyxPQUFPLEdBQUcsVUFBVSxLQUFLLFVBQVUsRUFBRSxVQUFVO0FBQzlFO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLDJDQUEyQyxJQUFJO0FBQy9DLEtBQUs7QUFDTDtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSw2QkFBNkIsbUVBQW1FO0FBQ2hHOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsVUFBVSw0QkFBNEI7O0FBRXRDO0FBQ0E7QUFDQTtBQUNBLHFEQUFxRCxXQUFXO0FBQ2hFO0FBQ0E7QUFDQTtBQUNBLEdBQUc7O0FBRUg7QUFDQTtBQUNBOztBQUVBO0FBQ0EscUVBQXFFLFVBQVU7QUFDL0U7QUFDQTs7QUFFQTtBQUNBLG9FQUFvRSxTQUFTO0FBQzdFO0FBQ0E7O0FBRUE7QUFDQSxnRUFBZ0UsS0FBSztBQUNyRTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEscUJBQXFCO0FBQ3JCLG1CQUFtQjtBQUNuQiwrQkFBK0I7QUFDL0IsZUFBZTtBQUNmIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvZHNuLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBkZWJ1Z0J1aWxkID0gcmVxdWlyZSgnLi4vZGVidWctYnVpbGQuanMnKTtcbmNvbnN0IGRlYnVnTG9nZ2VyID0gcmVxdWlyZSgnLi9kZWJ1Zy1sb2dnZXIuanMnKTtcblxuLyoqIFJlZ3VsYXIgZXhwcmVzc2lvbiB1c2VkIHRvIGV4dHJhY3Qgb3JnIElEIGZyb20gYSBEU04gaG9zdC4gKi9cbmNvbnN0IE9SR19JRF9SRUdFWCA9IC9ebyhcXGQrKVxcLi87XG5cbi8qKiBSZWd1bGFyIGV4cHJlc3Npb24gdXNlZCB0byBwYXJzZSBhIERzbi4gKi9cbmNvbnN0IERTTl9SRUdFWCA9IC9eKD86KFxcdyspOilcXC9cXC8oPzooXFx3KykoPzo6KFxcdyspPyk/QCkoW1xcdy4tXSspKD86OihcXGQrKSk/XFwvKC4rKS87XG5cbmZ1bmN0aW9uIGlzVmFsaWRQcm90b2NvbChwcm90b2NvbCkge1xuICByZXR1cm4gcHJvdG9jb2wgPT09ICdodHRwJyB8fCBwcm90b2NvbCA9PT0gJ2h0dHBzJztcbn1cblxuLyoqXG4gKiBSZW5kZXJzIHRoZSBzdHJpbmcgcmVwcmVzZW50YXRpb24gb2YgdGhpcyBEc24uXG4gKlxuICogQnkgZGVmYXVsdCwgdGhpcyB3aWxsIHJlbmRlciB0aGUgcHVibGljIHJlcHJlc2VudGF0aW9uIHdpdGhvdXQgdGhlIHBhc3N3b3JkXG4gKiBjb21wb25lbnQuIFRvIGdldCB0aGUgZGVwcmVjYXRlZCBwcml2YXRlIHJlcHJlc2VudGF0aW9uLCBzZXQgYHdpdGhQYXNzd29yZGBcbiAqIHRvIHRydWUuXG4gKlxuICogQHBhcmFtIHdpdGhQYXNzd29yZCBXaGVuIHNldCB0byB0cnVlLCB0aGUgcGFzc3dvcmQgd2lsbCBiZSBpbmNsdWRlZC5cbiAqL1xuZnVuY3Rpb24gZHNuVG9TdHJpbmcoZHNuLCB3aXRoUGFzc3dvcmQgPSBmYWxzZSkge1xuICBjb25zdCB7IGhvc3QsIHBhdGgsIHBhc3MsIHBvcnQsIHByb2plY3RJZCwgcHJvdG9jb2wsIHB1YmxpY0tleSB9ID0gZHNuO1xuICByZXR1cm4gKFxuICAgIGAke3Byb3RvY29sfTovLyR7cHVibGljS2V5fSR7d2l0aFBhc3N3b3JkICYmIHBhc3MgPyBgOiR7cGFzc31gIDogJyd9YCArXG4gICAgYEAke2hvc3R9JHtwb3J0ID8gYDoke3BvcnR9YCA6ICcnfS8ke3BhdGggPyBgJHtwYXRofS9gIDogcGF0aH0ke3Byb2plY3RJZH1gXG4gICk7XG59XG5cbi8qKlxuICogUGFyc2VzIGEgRHNuIGZyb20gYSBnaXZlbiBzdHJpbmcuXG4gKlxuICogQHBhcmFtIHN0ciBBIERzbiBhcyBzdHJpbmdcbiAqIEByZXR1cm5zIERzbiBhcyBEc25Db21wb25lbnRzIG9yIHVuZGVmaW5lZCBpZiBAcGFyYW0gc3RyIGlzIG5vdCBhIHZhbGlkIERTTiBzdHJpbmdcbiAqL1xuZnVuY3Rpb24gZHNuRnJvbVN0cmluZyhzdHIpIHtcbiAgY29uc3QgbWF0Y2ggPSBEU05fUkVHRVguZXhlYyhzdHIpO1xuXG4gIGlmICghbWF0Y2gpIHtcbiAgICAvLyBUaGlzIHNob3VsZCBiZSBsb2dnZWQgdG8gdGhlIGNvbnNvbGVcbiAgICBkZWJ1Z0xvZ2dlci5jb25zb2xlU2FuZGJveCgoKSA9PiB7XG4gICAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgbm8tY29uc29sZVxuICAgICAgY29uc29sZS5lcnJvcihgSW52YWxpZCBTZW50cnkgRHNuOiAke3N0cn1gKTtcbiAgICB9KTtcbiAgICByZXR1cm4gdW5kZWZpbmVkO1xuICB9XG5cbiAgY29uc3QgW3Byb3RvY29sLCBwdWJsaWNLZXksIHBhc3MgPSAnJywgaG9zdCA9ICcnLCBwb3J0ID0gJycsIGxhc3RQYXRoID0gJyddID0gbWF0Y2guc2xpY2UoMSk7XG4gIGxldCBwYXRoID0gJyc7XG4gIGxldCBwcm9qZWN0SWQgPSBsYXN0UGF0aDtcblxuICBjb25zdCBzcGxpdCA9IHByb2plY3RJZC5zcGxpdCgnLycpO1xuICBpZiAoc3BsaXQubGVuZ3RoID4gMSkge1xuICAgIHBhdGggPSBzcGxpdC5zbGljZSgwLCAtMSkuam9pbignLycpO1xuICAgIHByb2plY3RJZCA9IHNwbGl0LnBvcCgpIDtcbiAgfVxuXG4gIGlmIChwcm9qZWN0SWQpIHtcbiAgICBjb25zdCBwcm9qZWN0TWF0Y2ggPSBwcm9qZWN0SWQubWF0Y2goL15cXGQrLyk7XG4gICAgaWYgKHByb2plY3RNYXRjaCkge1xuICAgICAgcHJvamVjdElkID0gcHJvamVjdE1hdGNoWzBdO1xuICAgIH1cbiAgfVxuXG4gIHJldHVybiBkc25Gcm9tQ29tcG9uZW50cyh7IGhvc3QsIHBhc3MsIHBhdGgsIHByb2plY3RJZCwgcG9ydCwgcHJvdG9jb2w6IHByb3RvY29sICwgcHVibGljS2V5IH0pO1xufVxuXG5mdW5jdGlvbiBkc25Gcm9tQ29tcG9uZW50cyhjb21wb25lbnRzKSB7XG4gIHJldHVybiB7XG4gICAgcHJvdG9jb2w6IGNvbXBvbmVudHMucHJvdG9jb2wsXG4gICAgcHVibGljS2V5OiBjb21wb25lbnRzLnB1YmxpY0tleSB8fCAnJyxcbiAgICBwYXNzOiBjb21wb25lbnRzLnBhc3MgfHwgJycsXG4gICAgaG9zdDogY29tcG9uZW50cy5ob3N0LFxuICAgIHBvcnQ6IGNvbXBvbmVudHMucG9ydCB8fCAnJyxcbiAgICBwYXRoOiBjb21wb25lbnRzLnBhdGggfHwgJycsXG4gICAgcHJvamVjdElkOiBjb21wb25lbnRzLnByb2plY3RJZCxcbiAgfTtcbn1cblxuZnVuY3Rpb24gdmFsaWRhdGVEc24oZHNuKSB7XG4gIGlmICghZGVidWdCdWlsZC5ERUJVR19CVUlMRCkge1xuICAgIHJldHVybiB0cnVlO1xuICB9XG5cbiAgY29uc3QgeyBwb3J0LCBwcm9qZWN0SWQsIHByb3RvY29sIH0gPSBkc247XG5cbiAgY29uc3QgcmVxdWlyZWRDb21wb25lbnRzID0gWydwcm90b2NvbCcsICdwdWJsaWNLZXknLCAnaG9zdCcsICdwcm9qZWN0SWQnXTtcbiAgY29uc3QgaGFzTWlzc2luZ1JlcXVpcmVkQ29tcG9uZW50ID0gcmVxdWlyZWRDb21wb25lbnRzLmZpbmQoY29tcG9uZW50ID0+IHtcbiAgICBpZiAoIWRzbltjb21wb25lbnRdKSB7XG4gICAgICBkZWJ1Z0xvZ2dlci5kZWJ1Zy5lcnJvcihgSW52YWxpZCBTZW50cnkgRHNuOiAke2NvbXBvbmVudH0gbWlzc2luZ2ApO1xuICAgICAgcmV0dXJuIHRydWU7XG4gICAgfVxuICAgIHJldHVybiBmYWxzZTtcbiAgfSk7XG5cbiAgaWYgKGhhc01pc3NpbmdSZXF1aXJlZENvbXBvbmVudCkge1xuICAgIHJldHVybiBmYWxzZTtcbiAgfVxuXG4gIGlmICghcHJvamVjdElkLm1hdGNoKC9eXFxkKyQvKSkge1xuICAgIGRlYnVnTG9nZ2VyLmRlYnVnLmVycm9yKGBJbnZhbGlkIFNlbnRyeSBEc246IEludmFsaWQgcHJvamVjdElkICR7cHJvamVjdElkfWApO1xuICAgIHJldHVybiBmYWxzZTtcbiAgfVxuXG4gIGlmICghaXNWYWxpZFByb3RvY29sKHByb3RvY29sKSkge1xuICAgIGRlYnVnTG9nZ2VyLmRlYnVnLmVycm9yKGBJbnZhbGlkIFNlbnRyeSBEc246IEludmFsaWQgcHJvdG9jb2wgJHtwcm90b2NvbH1gKTtcbiAgICByZXR1cm4gZmFsc2U7XG4gIH1cblxuICBpZiAocG9ydCAmJiBpc05hTihwYXJzZUludChwb3J0LCAxMCkpKSB7XG4gICAgZGVidWdMb2dnZXIuZGVidWcuZXJyb3IoYEludmFsaWQgU2VudHJ5IERzbjogSW52YWxpZCBwb3J0ICR7cG9ydH1gKTtcbiAgICByZXR1cm4gZmFsc2U7XG4gIH1cblxuICByZXR1cm4gdHJ1ZTtcbn1cblxuLyoqXG4gKiBFeHRyYWN0IHRoZSBvcmcgSUQgZnJvbSBhIERTTiBob3N0LlxuICpcbiAqIEBwYXJhbSBob3N0IFRoZSBob3N0IGZyb20gYSBEU05cbiAqIEByZXR1cm5zIFRoZSBvcmcgSUQgaWYgZm91bmQsIHVuZGVmaW5lZCBvdGhlcndpc2VcbiAqL1xuZnVuY3Rpb24gZXh0cmFjdE9yZ0lkRnJvbURzbkhvc3QoaG9zdCkge1xuICBjb25zdCBtYXRjaCA9IGhvc3QubWF0Y2goT1JHX0lEX1JFR0VYKTtcblxuICByZXR1cm4gbWF0Y2g/LlsxXTtcbn1cblxuLyoqXG4gKiBDcmVhdGVzIGEgdmFsaWQgU2VudHJ5IERzbiBvYmplY3QsIGlkZW50aWZ5aW5nIGEgU2VudHJ5IGluc3RhbmNlIGFuZCBwcm9qZWN0LlxuICogQHJldHVybnMgYSB2YWxpZCBEc25Db21wb25lbnRzIG9iamVjdCBvciBgdW5kZWZpbmVkYCBpZiBAcGFyYW0gZnJvbSBpcyBhbiBpbnZhbGlkIERTTiBzb3VyY2VcbiAqL1xuZnVuY3Rpb24gbWFrZURzbihmcm9tKSB7XG4gIGNvbnN0IGNvbXBvbmVudHMgPSB0eXBlb2YgZnJvbSA9PT0gJ3N0cmluZycgPyBkc25Gcm9tU3RyaW5nKGZyb20pIDogZHNuRnJvbUNvbXBvbmVudHMoZnJvbSk7XG4gIGlmICghY29tcG9uZW50cyB8fCAhdmFsaWRhdGVEc24oY29tcG9uZW50cykpIHtcbiAgICByZXR1cm4gdW5kZWZpbmVkO1xuICB9XG4gIHJldHVybiBjb21wb25lbnRzO1xufVxuXG5leHBvcnRzLmRzbkZyb21TdHJpbmcgPSBkc25Gcm9tU3RyaW5nO1xuZXhwb3J0cy5kc25Ub1N0cmluZyA9IGRzblRvU3RyaW5nO1xuZXhwb3J0cy5leHRyYWN0T3JnSWRGcm9tRHNuSG9zdCA9IGV4dHJhY3RPcmdJZEZyb21Ec25Ib3N0O1xuZXhwb3J0cy5tYWtlRHNuID0gbWFrZURzbjtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWRzbi5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/dsn.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/env.js":
/*!*************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/env.js ***!
  \*************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n/*\n * This module exists for optimizations in the build process through rollup and terser.  We define some global\n * constants, which can be overridden during build. By guarding certain pieces of code with functions that return these\n * constants, we can control whether or not they appear in the final bundle. (Any code guarded by a false condition will\n * never run, and will hence be dropped during treeshaking.) The two primary uses for this are stripping out calls to\n * `debug` and preventing node-related code from appearing in browser bundles.\n *\n * Attention:\n * This file should not be used to define constants/flags that are intended to be used for tree-shaking conducted by\n * users. These flags should live in their respective packages, as we identified user tooling (specifically webpack)\n * having issues tree-shaking these constants across package boundaries.\n * An example for this is the __SENTRY_DEBUG__ constant. It is declared in each package individually because we want\n * users to be able to shake away expressions that it guards.\n */\n\n/**\n * Figures out if we're building a browser bundle.\n *\n * @returns true if this is a browser bundle build.\n */\nfunction isBrowserBundle() {\n  return typeof __SENTRY_BROWSER_BUNDLE__ !== 'undefined' && !!__SENTRY_BROWSER_BUNDLE__;\n}\n\n/**\n * Get source of SDK.\n */\nfunction getSDKSource() {\n  // This comment is used to identify this line in the CDN bundle build step and replace this with \"return 'cdn';\"\n  /* __SENTRY_SDK_SOURCE__ */ return 'npm';\n}\n\nexports.getSDKSource = getSDKSource;\nexports.isBrowserBundle = isBrowserBundle;\n//# sourceMappingURL=env.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvZW52LmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGlIQUFpSDtBQUNqSDtBQUNBOztBQUVBLG9CQUFvQjtBQUNwQix1QkFBdUI7QUFDdkIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9lbnYuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbi8qXG4gKiBUaGlzIG1vZHVsZSBleGlzdHMgZm9yIG9wdGltaXphdGlvbnMgaW4gdGhlIGJ1aWxkIHByb2Nlc3MgdGhyb3VnaCByb2xsdXAgYW5kIHRlcnNlci4gIFdlIGRlZmluZSBzb21lIGdsb2JhbFxuICogY29uc3RhbnRzLCB3aGljaCBjYW4gYmUgb3ZlcnJpZGRlbiBkdXJpbmcgYnVpbGQuIEJ5IGd1YXJkaW5nIGNlcnRhaW4gcGllY2VzIG9mIGNvZGUgd2l0aCBmdW5jdGlvbnMgdGhhdCByZXR1cm4gdGhlc2VcbiAqIGNvbnN0YW50cywgd2UgY2FuIGNvbnRyb2wgd2hldGhlciBvciBub3QgdGhleSBhcHBlYXIgaW4gdGhlIGZpbmFsIGJ1bmRsZS4gKEFueSBjb2RlIGd1YXJkZWQgYnkgYSBmYWxzZSBjb25kaXRpb24gd2lsbFxuICogbmV2ZXIgcnVuLCBhbmQgd2lsbCBoZW5jZSBiZSBkcm9wcGVkIGR1cmluZyB0cmVlc2hha2luZy4pIFRoZSB0d28gcHJpbWFyeSB1c2VzIGZvciB0aGlzIGFyZSBzdHJpcHBpbmcgb3V0IGNhbGxzIHRvXG4gKiBgZGVidWdgIGFuZCBwcmV2ZW50aW5nIG5vZGUtcmVsYXRlZCBjb2RlIGZyb20gYXBwZWFyaW5nIGluIGJyb3dzZXIgYnVuZGxlcy5cbiAqXG4gKiBBdHRlbnRpb246XG4gKiBUaGlzIGZpbGUgc2hvdWxkIG5vdCBiZSB1c2VkIHRvIGRlZmluZSBjb25zdGFudHMvZmxhZ3MgdGhhdCBhcmUgaW50ZW5kZWQgdG8gYmUgdXNlZCBmb3IgdHJlZS1zaGFraW5nIGNvbmR1Y3RlZCBieVxuICogdXNlcnMuIFRoZXNlIGZsYWdzIHNob3VsZCBsaXZlIGluIHRoZWlyIHJlc3BlY3RpdmUgcGFja2FnZXMsIGFzIHdlIGlkZW50aWZpZWQgdXNlciB0b29saW5nIChzcGVjaWZpY2FsbHkgd2VicGFjaylcbiAqIGhhdmluZyBpc3N1ZXMgdHJlZS1zaGFraW5nIHRoZXNlIGNvbnN0YW50cyBhY3Jvc3MgcGFja2FnZSBib3VuZGFyaWVzLlxuICogQW4gZXhhbXBsZSBmb3IgdGhpcyBpcyB0aGUgX19TRU5UUllfREVCVUdfXyBjb25zdGFudC4gSXQgaXMgZGVjbGFyZWQgaW4gZWFjaCBwYWNrYWdlIGluZGl2aWR1YWxseSBiZWNhdXNlIHdlIHdhbnRcbiAqIHVzZXJzIHRvIGJlIGFibGUgdG8gc2hha2UgYXdheSBleHByZXNzaW9ucyB0aGF0IGl0IGd1YXJkcy5cbiAqL1xuXG4vKipcbiAqIEZpZ3VyZXMgb3V0IGlmIHdlJ3JlIGJ1aWxkaW5nIGEgYnJvd3NlciBidW5kbGUuXG4gKlxuICogQHJldHVybnMgdHJ1ZSBpZiB0aGlzIGlzIGEgYnJvd3NlciBidW5kbGUgYnVpbGQuXG4gKi9cbmZ1bmN0aW9uIGlzQnJvd3NlckJ1bmRsZSgpIHtcbiAgcmV0dXJuIHR5cGVvZiBfX1NFTlRSWV9CUk9XU0VSX0JVTkRMRV9fICE9PSAndW5kZWZpbmVkJyAmJiAhIV9fU0VOVFJZX0JST1dTRVJfQlVORExFX187XG59XG5cbi8qKlxuICogR2V0IHNvdXJjZSBvZiBTREsuXG4gKi9cbmZ1bmN0aW9uIGdldFNES1NvdXJjZSgpIHtcbiAgLy8gVGhpcyBjb21tZW50IGlzIHVzZWQgdG8gaWRlbnRpZnkgdGhpcyBsaW5lIGluIHRoZSBDRE4gYnVuZGxlIGJ1aWxkIHN0ZXAgYW5kIHJlcGxhY2UgdGhpcyB3aXRoIFwicmV0dXJuICdjZG4nO1wiXG4gIC8qIF9fU0VOVFJZX1NES19TT1VSQ0VfXyAqLyByZXR1cm4gJ25wbSc7XG59XG5cbmV4cG9ydHMuZ2V0U0RLU291cmNlID0gZ2V0U0RLU291cmNlO1xuZXhwb3J0cy5pc0Jyb3dzZXJCdW5kbGUgPSBpc0Jyb3dzZXJCdW5kbGU7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1lbnYuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/env.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/envelope.js":
/*!******************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/envelope.js ***!
  \******************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst carrier = __webpack_require__(/*! ../carrier.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/carrier.js\");\nconst dsn = __webpack_require__(/*! ./dsn.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/dsn.js\");\nconst normalize = __webpack_require__(/*! ./normalize.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/normalize.js\");\nconst worldwide = __webpack_require__(/*! ./worldwide.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/worldwide.js\");\n\n/**\n * Creates an envelope.\n * Make sure to always explicitly provide the generic to this function\n * so that the envelope types resolve correctly.\n */\nfunction createEnvelope(headers, items = []) {\n  return [headers, items] ;\n}\n\n/**\n * Add an item to an envelope.\n * Make sure to always explicitly provide the generic to this function\n * so that the envelope types resolve correctly.\n */\nfunction addItemToEnvelope(envelope, newItem) {\n  const [headers, items] = envelope;\n  return [headers, [...items, newItem]] ;\n}\n\n/**\n * Convenience function to loop through the items and item types of an envelope.\n * (This function was mostly created because working with envelope types is painful at the moment)\n *\n * If the callback returns true, the rest of the items will be skipped.\n */\nfunction forEachEnvelopeItem(\n  envelope,\n  callback,\n) {\n  const envelopeItems = envelope[1];\n\n  for (const envelopeItem of envelopeItems) {\n    const envelopeItemType = envelopeItem[0].type;\n    const result = callback(envelopeItem, envelopeItemType);\n\n    if (result) {\n      return true;\n    }\n  }\n\n  return false;\n}\n\n/**\n * Returns true if the envelope contains any of the given envelope item types\n */\nfunction envelopeContainsItemType(envelope, types) {\n  return forEachEnvelopeItem(envelope, (_, type) => types.includes(type));\n}\n\n/**\n * Encode a string to UTF8 array.\n */\nfunction encodeUTF8(input) {\n  const carrier$1 = carrier.getSentryCarrier(worldwide.GLOBAL_OBJ);\n  return carrier$1.encodePolyfill ? carrier$1.encodePolyfill(input) : new TextEncoder().encode(input);\n}\n\n/**\n * Decode a UTF8 array to string.\n */\nfunction decodeUTF8(input) {\n  const carrier$1 = carrier.getSentryCarrier(worldwide.GLOBAL_OBJ);\n  return carrier$1.decodePolyfill ? carrier$1.decodePolyfill(input) : new TextDecoder().decode(input);\n}\n\n/**\n * Serializes an envelope.\n */\nfunction serializeEnvelope(envelope) {\n  const [envHeaders, items] = envelope;\n  // Initially we construct our envelope as a string and only convert to binary chunks if we encounter binary data\n  let parts = JSON.stringify(envHeaders);\n\n  function append(next) {\n    if (typeof parts === 'string') {\n      parts = typeof next === 'string' ? parts + next : [encodeUTF8(parts), next];\n    } else {\n      parts.push(typeof next === 'string' ? encodeUTF8(next) : next);\n    }\n  }\n\n  for (const item of items) {\n    const [itemHeaders, payload] = item;\n\n    append(`\\n${JSON.stringify(itemHeaders)}\\n`);\n\n    if (typeof payload === 'string' || payload instanceof Uint8Array) {\n      append(payload);\n    } else {\n      let stringifiedPayload;\n      try {\n        stringifiedPayload = JSON.stringify(payload);\n      } catch {\n        // In case, despite all our efforts to keep `payload` circular-dependency-free, `JSON.stringify()` still\n        // fails, we try again after normalizing it again with infinite normalization depth. This of course has a\n        // performance impact but in this case a performance hit is better than throwing.\n        stringifiedPayload = JSON.stringify(normalize.normalize(payload));\n      }\n      append(stringifiedPayload);\n    }\n  }\n\n  return typeof parts === 'string' ? parts : concatBuffers(parts);\n}\n\nfunction concatBuffers(buffers) {\n  const totalLength = buffers.reduce((acc, buf) => acc + buf.length, 0);\n\n  const merged = new Uint8Array(totalLength);\n  let offset = 0;\n  for (const buffer of buffers) {\n    merged.set(buffer, offset);\n    offset += buffer.length;\n  }\n\n  return merged;\n}\n\n/**\n * Parses an envelope\n */\nfunction parseEnvelope(env) {\n  let buffer = typeof env === 'string' ? encodeUTF8(env) : env;\n\n  function readBinary(length) {\n    const bin = buffer.subarray(0, length);\n    // Replace the buffer with the remaining data excluding trailing newline\n    buffer = buffer.subarray(length + 1);\n    return bin;\n  }\n\n  function readJson() {\n    let i = buffer.indexOf(0xa);\n    // If we couldn't find a newline, we must have found the end of the buffer\n    if (i < 0) {\n      i = buffer.length;\n    }\n\n    return JSON.parse(decodeUTF8(readBinary(i))) ;\n  }\n\n  const envelopeHeader = readJson();\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  const items = [];\n\n  while (buffer.length) {\n    const itemHeader = readJson();\n    const binaryLength = typeof itemHeader.length === 'number' ? itemHeader.length : undefined;\n\n    items.push([itemHeader, binaryLength ? readBinary(binaryLength) : readJson()]);\n  }\n\n  return [envelopeHeader, items];\n}\n\n/**\n * Creates envelope item for a single span\n */\nfunction createSpanEnvelopeItem(spanJson) {\n  const spanHeaders = {\n    type: 'span',\n  };\n\n  return [spanHeaders, spanJson];\n}\n\n/**\n * Creates attachment envelope items\n */\nfunction createAttachmentEnvelopeItem(attachment) {\n  const buffer = typeof attachment.data === 'string' ? encodeUTF8(attachment.data) : attachment.data;\n\n  return [\n    {\n      type: 'attachment',\n      length: buffer.length,\n      filename: attachment.filename,\n      content_type: attachment.contentType,\n      attachment_type: attachment.attachmentType,\n    },\n    buffer,\n  ];\n}\n\nconst ITEM_TYPE_TO_DATA_CATEGORY_MAP = {\n  session: 'session',\n  sessions: 'session',\n  attachment: 'attachment',\n  transaction: 'transaction',\n  event: 'error',\n  client_report: 'internal',\n  user_report: 'default',\n  profile: 'profile',\n  profile_chunk: 'profile',\n  replay_event: 'replay',\n  replay_recording: 'replay',\n  check_in: 'monitor',\n  feedback: 'feedback',\n  span: 'span',\n  raw_security: 'security',\n  log: 'log_item',\n};\n\n/**\n * Maps the type of an envelope item to a data category.\n */\nfunction envelopeItemTypeToDataCategory(type) {\n  return ITEM_TYPE_TO_DATA_CATEGORY_MAP[type];\n}\n\n/** Extracts the minimal SDK info from the metadata or an events */\nfunction getSdkMetadataForEnvelopeHeader(metadataOrEvent) {\n  if (!metadataOrEvent?.sdk) {\n    return;\n  }\n  const { name, version } = metadataOrEvent.sdk;\n  return { name, version };\n}\n\n/**\n * Creates event envelope headers, based on event, sdk info and tunnel\n * Note: This function was extracted from the core package to make it available in Replay\n */\nfunction createEventEnvelopeHeaders(\n  event,\n  sdkInfo,\n  tunnel,\n  dsn$1,\n) {\n  const dynamicSamplingContext = event.sdkProcessingMetadata?.dynamicSamplingContext;\n  return {\n    event_id: event.event_id ,\n    sent_at: new Date().toISOString(),\n    ...(sdkInfo && { sdk: sdkInfo }),\n    ...(!!tunnel && dsn$1 && { dsn: dsn.dsnToString(dsn$1) }),\n    ...(dynamicSamplingContext && {\n      trace: dynamicSamplingContext,\n    }),\n  };\n}\n\nexports.addItemToEnvelope = addItemToEnvelope;\nexports.createAttachmentEnvelopeItem = createAttachmentEnvelopeItem;\nexports.createEnvelope = createEnvelope;\nexports.createEventEnvelopeHeaders = createEventEnvelopeHeaders;\nexports.createSpanEnvelopeItem = createSpanEnvelopeItem;\nexports.envelopeContainsItemType = envelopeContainsItemType;\nexports.envelopeItemTypeToDataCategory = envelopeItemTypeToDataCategory;\nexports.forEachEnvelopeItem = forEachEnvelopeItem;\nexports.getSdkMetadataForEnvelopeHeader = getSdkMetadataForEnvelopeHeader;\nexports.parseEnvelope = parseEnvelope;\nexports.serializeEnvelope = serializeEnvelope;\n//# sourceMappingURL=envelope.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvZW52ZWxvcGUuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsZ0JBQWdCLG1CQUFPLENBQUMsMkhBQWU7QUFDdkMsWUFBWSxtQkFBTyxDQUFDLHdIQUFVO0FBQzlCLGtCQUFrQixtQkFBTyxDQUFDLG9JQUFnQjtBQUMxQyxrQkFBa0IsbUJBQU8sQ0FBQyxvSUFBZ0I7O0FBRTFDO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBLE1BQU07QUFDTjtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQSxnQkFBZ0IsNEJBQTRCOztBQUU1QztBQUNBO0FBQ0EsTUFBTTtBQUNOO0FBQ0E7QUFDQTtBQUNBLFFBQVE7QUFDUjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxLQUFLO0FBQ0w7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFVBQVUsZ0JBQWdCO0FBQzFCLFdBQVc7QUFDWDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EscUJBQXFCLGNBQWM7QUFDbkMsK0JBQStCLDZCQUE2QjtBQUM1RDtBQUNBO0FBQ0EsS0FBSztBQUNMO0FBQ0E7O0FBRUEseUJBQXlCO0FBQ3pCLG9DQUFvQztBQUNwQyxzQkFBc0I7QUFDdEIsa0NBQWtDO0FBQ2xDLDhCQUE4QjtBQUM5QixnQ0FBZ0M7QUFDaEMsc0NBQXNDO0FBQ3RDLDJCQUEyQjtBQUMzQix1Q0FBdUM7QUFDdkMscUJBQXFCO0FBQ3JCLHlCQUF5QjtBQUN6QiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3V0aWxzL2VudmVsb3BlLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBjYXJyaWVyID0gcmVxdWlyZSgnLi4vY2Fycmllci5qcycpO1xuY29uc3QgZHNuID0gcmVxdWlyZSgnLi9kc24uanMnKTtcbmNvbnN0IG5vcm1hbGl6ZSA9IHJlcXVpcmUoJy4vbm9ybWFsaXplLmpzJyk7XG5jb25zdCB3b3JsZHdpZGUgPSByZXF1aXJlKCcuL3dvcmxkd2lkZS5qcycpO1xuXG4vKipcbiAqIENyZWF0ZXMgYW4gZW52ZWxvcGUuXG4gKiBNYWtlIHN1cmUgdG8gYWx3YXlzIGV4cGxpY2l0bHkgcHJvdmlkZSB0aGUgZ2VuZXJpYyB0byB0aGlzIGZ1bmN0aW9uXG4gKiBzbyB0aGF0IHRoZSBlbnZlbG9wZSB0eXBlcyByZXNvbHZlIGNvcnJlY3RseS5cbiAqL1xuZnVuY3Rpb24gY3JlYXRlRW52ZWxvcGUoaGVhZGVycywgaXRlbXMgPSBbXSkge1xuICByZXR1cm4gW2hlYWRlcnMsIGl0ZW1zXSA7XG59XG5cbi8qKlxuICogQWRkIGFuIGl0ZW0gdG8gYW4gZW52ZWxvcGUuXG4gKiBNYWtlIHN1cmUgdG8gYWx3YXlzIGV4cGxpY2l0bHkgcHJvdmlkZSB0aGUgZ2VuZXJpYyB0byB0aGlzIGZ1bmN0aW9uXG4gKiBzbyB0aGF0IHRoZSBlbnZlbG9wZSB0eXBlcyByZXNvbHZlIGNvcnJlY3RseS5cbiAqL1xuZnVuY3Rpb24gYWRkSXRlbVRvRW52ZWxvcGUoZW52ZWxvcGUsIG5ld0l0ZW0pIHtcbiAgY29uc3QgW2hlYWRlcnMsIGl0ZW1zXSA9IGVudmVsb3BlO1xuICByZXR1cm4gW2hlYWRlcnMsIFsuLi5pdGVtcywgbmV3SXRlbV1dIDtcbn1cblxuLyoqXG4gKiBDb252ZW5pZW5jZSBmdW5jdGlvbiB0byBsb29wIHRocm91Z2ggdGhlIGl0ZW1zIGFuZCBpdGVtIHR5cGVzIG9mIGFuIGVudmVsb3BlLlxuICogKFRoaXMgZnVuY3Rpb24gd2FzIG1vc3RseSBjcmVhdGVkIGJlY2F1c2Ugd29ya2luZyB3aXRoIGVudmVsb3BlIHR5cGVzIGlzIHBhaW5mdWwgYXQgdGhlIG1vbWVudClcbiAqXG4gKiBJZiB0aGUgY2FsbGJhY2sgcmV0dXJucyB0cnVlLCB0aGUgcmVzdCBvZiB0aGUgaXRlbXMgd2lsbCBiZSBza2lwcGVkLlxuICovXG5mdW5jdGlvbiBmb3JFYWNoRW52ZWxvcGVJdGVtKFxuICBlbnZlbG9wZSxcbiAgY2FsbGJhY2ssXG4pIHtcbiAgY29uc3QgZW52ZWxvcGVJdGVtcyA9IGVudmVsb3BlWzFdO1xuXG4gIGZvciAoY29uc3QgZW52ZWxvcGVJdGVtIG9mIGVudmVsb3BlSXRlbXMpIHtcbiAgICBjb25zdCBlbnZlbG9wZUl0ZW1UeXBlID0gZW52ZWxvcGVJdGVtWzBdLnR5cGU7XG4gICAgY29uc3QgcmVzdWx0ID0gY2FsbGJhY2soZW52ZWxvcGVJdGVtLCBlbnZlbG9wZUl0ZW1UeXBlKTtcblxuICAgIGlmIChyZXN1bHQpIHtcbiAgICAgIHJldHVybiB0cnVlO1xuICAgIH1cbiAgfVxuXG4gIHJldHVybiBmYWxzZTtcbn1cblxuLyoqXG4gKiBSZXR1cm5zIHRydWUgaWYgdGhlIGVudmVsb3BlIGNvbnRhaW5zIGFueSBvZiB0aGUgZ2l2ZW4gZW52ZWxvcGUgaXRlbSB0eXBlc1xuICovXG5mdW5jdGlvbiBlbnZlbG9wZUNvbnRhaW5zSXRlbVR5cGUoZW52ZWxvcGUsIHR5cGVzKSB7XG4gIHJldHVybiBmb3JFYWNoRW52ZWxvcGVJdGVtKGVudmVsb3BlLCAoXywgdHlwZSkgPT4gdHlwZXMuaW5jbHVkZXModHlwZSkpO1xufVxuXG4vKipcbiAqIEVuY29kZSBhIHN0cmluZyB0byBVVEY4IGFycmF5LlxuICovXG5mdW5jdGlvbiBlbmNvZGVVVEY4KGlucHV0KSB7XG4gIGNvbnN0IGNhcnJpZXIkMSA9IGNhcnJpZXIuZ2V0U2VudHJ5Q2Fycmllcih3b3JsZHdpZGUuR0xPQkFMX09CSik7XG4gIHJldHVybiBjYXJyaWVyJDEuZW5jb2RlUG9seWZpbGwgPyBjYXJyaWVyJDEuZW5jb2RlUG9seWZpbGwoaW5wdXQpIDogbmV3IFRleHRFbmNvZGVyKCkuZW5jb2RlKGlucHV0KTtcbn1cblxuLyoqXG4gKiBEZWNvZGUgYSBVVEY4IGFycmF5IHRvIHN0cmluZy5cbiAqL1xuZnVuY3Rpb24gZGVjb2RlVVRGOChpbnB1dCkge1xuICBjb25zdCBjYXJyaWVyJDEgPSBjYXJyaWVyLmdldFNlbnRyeUNhcnJpZXIod29ybGR3aWRlLkdMT0JBTF9PQkopO1xuICByZXR1cm4gY2FycmllciQxLmRlY29kZVBvbHlmaWxsID8gY2FycmllciQxLmRlY29kZVBvbHlmaWxsKGlucHV0KSA6IG5ldyBUZXh0RGVjb2RlcigpLmRlY29kZShpbnB1dCk7XG59XG5cbi8qKlxuICogU2VyaWFsaXplcyBhbiBlbnZlbG9wZS5cbiAqL1xuZnVuY3Rpb24gc2VyaWFsaXplRW52ZWxvcGUoZW52ZWxvcGUpIHtcbiAgY29uc3QgW2VudkhlYWRlcnMsIGl0ZW1zXSA9IGVudmVsb3BlO1xuICAvLyBJbml0aWFsbHkgd2UgY29uc3RydWN0IG91ciBlbnZlbG9wZSBhcyBhIHN0cmluZyBhbmQgb25seSBjb252ZXJ0IHRvIGJpbmFyeSBjaHVua3MgaWYgd2UgZW5jb3VudGVyIGJpbmFyeSBkYXRhXG4gIGxldCBwYXJ0cyA9IEpTT04uc3RyaW5naWZ5KGVudkhlYWRlcnMpO1xuXG4gIGZ1bmN0aW9uIGFwcGVuZChuZXh0KSB7XG4gICAgaWYgKHR5cGVvZiBwYXJ0cyA9PT0gJ3N0cmluZycpIHtcbiAgICAgIHBhcnRzID0gdHlwZW9mIG5leHQgPT09ICdzdHJpbmcnID8gcGFydHMgKyBuZXh0IDogW2VuY29kZVVURjgocGFydHMpLCBuZXh0XTtcbiAgICB9IGVsc2Uge1xuICAgICAgcGFydHMucHVzaCh0eXBlb2YgbmV4dCA9PT0gJ3N0cmluZycgPyBlbmNvZGVVVEY4KG5leHQpIDogbmV4dCk7XG4gICAgfVxuICB9XG5cbiAgZm9yIChjb25zdCBpdGVtIG9mIGl0ZW1zKSB7XG4gICAgY29uc3QgW2l0ZW1IZWFkZXJzLCBwYXlsb2FkXSA9IGl0ZW07XG5cbiAgICBhcHBlbmQoYFxcbiR7SlNPTi5zdHJpbmdpZnkoaXRlbUhlYWRlcnMpfVxcbmApO1xuXG4gICAgaWYgKHR5cGVvZiBwYXlsb2FkID09PSAnc3RyaW5nJyB8fCBwYXlsb2FkIGluc3RhbmNlb2YgVWludDhBcnJheSkge1xuICAgICAgYXBwZW5kKHBheWxvYWQpO1xuICAgIH0gZWxzZSB7XG4gICAgICBsZXQgc3RyaW5naWZpZWRQYXlsb2FkO1xuICAgICAgdHJ5IHtcbiAgICAgICAgc3RyaW5naWZpZWRQYXlsb2FkID0gSlNPTi5zdHJpbmdpZnkocGF5bG9hZCk7XG4gICAgICB9IGNhdGNoIHtcbiAgICAgICAgLy8gSW4gY2FzZSwgZGVzcGl0ZSBhbGwgb3VyIGVmZm9ydHMgdG8ga2VlcCBgcGF5bG9hZGAgY2lyY3VsYXItZGVwZW5kZW5jeS1mcmVlLCBgSlNPTi5zdHJpbmdpZnkoKWAgc3RpbGxcbiAgICAgICAgLy8gZmFpbHMsIHdlIHRyeSBhZ2FpbiBhZnRlciBub3JtYWxpemluZyBpdCBhZ2FpbiB3aXRoIGluZmluaXRlIG5vcm1hbGl6YXRpb24gZGVwdGguIFRoaXMgb2YgY291cnNlIGhhcyBhXG4gICAgICAgIC8vIHBlcmZvcm1hbmNlIGltcGFjdCBidXQgaW4gdGhpcyBjYXNlIGEgcGVyZm9ybWFuY2UgaGl0IGlzIGJldHRlciB0aGFuIHRocm93aW5nLlxuICAgICAgICBzdHJpbmdpZmllZFBheWxvYWQgPSBKU09OLnN0cmluZ2lmeShub3JtYWxpemUubm9ybWFsaXplKHBheWxvYWQpKTtcbiAgICAgIH1cbiAgICAgIGFwcGVuZChzdHJpbmdpZmllZFBheWxvYWQpO1xuICAgIH1cbiAgfVxuXG4gIHJldHVybiB0eXBlb2YgcGFydHMgPT09ICdzdHJpbmcnID8gcGFydHMgOiBjb25jYXRCdWZmZXJzKHBhcnRzKTtcbn1cblxuZnVuY3Rpb24gY29uY2F0QnVmZmVycyhidWZmZXJzKSB7XG4gIGNvbnN0IHRvdGFsTGVuZ3RoID0gYnVmZmVycy5yZWR1Y2UoKGFjYywgYnVmKSA9PiBhY2MgKyBidWYubGVuZ3RoLCAwKTtcblxuICBjb25zdCBtZXJnZWQgPSBuZXcgVWludDhBcnJheSh0b3RhbExlbmd0aCk7XG4gIGxldCBvZmZzZXQgPSAwO1xuICBmb3IgKGNvbnN0IGJ1ZmZlciBvZiBidWZmZXJzKSB7XG4gICAgbWVyZ2VkLnNldChidWZmZXIsIG9mZnNldCk7XG4gICAgb2Zmc2V0ICs9IGJ1ZmZlci5sZW5ndGg7XG4gIH1cblxuICByZXR1cm4gbWVyZ2VkO1xufVxuXG4vKipcbiAqIFBhcnNlcyBhbiBlbnZlbG9wZVxuICovXG5mdW5jdGlvbiBwYXJzZUVudmVsb3BlKGVudikge1xuICBsZXQgYnVmZmVyID0gdHlwZW9mIGVudiA9PT0gJ3N0cmluZycgPyBlbmNvZGVVVEY4KGVudikgOiBlbnY7XG5cbiAgZnVuY3Rpb24gcmVhZEJpbmFyeShsZW5ndGgpIHtcbiAgICBjb25zdCBiaW4gPSBidWZmZXIuc3ViYXJyYXkoMCwgbGVuZ3RoKTtcbiAgICAvLyBSZXBsYWNlIHRoZSBidWZmZXIgd2l0aCB0aGUgcmVtYWluaW5nIGRhdGEgZXhjbHVkaW5nIHRyYWlsaW5nIG5ld2xpbmVcbiAgICBidWZmZXIgPSBidWZmZXIuc3ViYXJyYXkobGVuZ3RoICsgMSk7XG4gICAgcmV0dXJuIGJpbjtcbiAgfVxuXG4gIGZ1bmN0aW9uIHJlYWRKc29uKCkge1xuICAgIGxldCBpID0gYnVmZmVyLmluZGV4T2YoMHhhKTtcbiAgICAvLyBJZiB3ZSBjb3VsZG4ndCBmaW5kIGEgbmV3bGluZSwgd2UgbXVzdCBoYXZlIGZvdW5kIHRoZSBlbmQgb2YgdGhlIGJ1ZmZlclxuICAgIGlmIChpIDwgMCkge1xuICAgICAgaSA9IGJ1ZmZlci5sZW5ndGg7XG4gICAgfVxuXG4gICAgcmV0dXJuIEpTT04ucGFyc2UoZGVjb2RlVVRGOChyZWFkQmluYXJ5KGkpKSkgO1xuICB9XG5cbiAgY29uc3QgZW52ZWxvcGVIZWFkZXIgPSByZWFkSnNvbigpO1xuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25vLWV4cGxpY2l0LWFueVxuICBjb25zdCBpdGVtcyA9IFtdO1xuXG4gIHdoaWxlIChidWZmZXIubGVuZ3RoKSB7XG4gICAgY29uc3QgaXRlbUhlYWRlciA9IHJlYWRKc29uKCk7XG4gICAgY29uc3QgYmluYXJ5TGVuZ3RoID0gdHlwZW9mIGl0ZW1IZWFkZXIubGVuZ3RoID09PSAnbnVtYmVyJyA/IGl0ZW1IZWFkZXIubGVuZ3RoIDogdW5kZWZpbmVkO1xuXG4gICAgaXRlbXMucHVzaChbaXRlbUhlYWRlciwgYmluYXJ5TGVuZ3RoID8gcmVhZEJpbmFyeShiaW5hcnlMZW5ndGgpIDogcmVhZEpzb24oKV0pO1xuICB9XG5cbiAgcmV0dXJuIFtlbnZlbG9wZUhlYWRlciwgaXRlbXNdO1xufVxuXG4vKipcbiAqIENyZWF0ZXMgZW52ZWxvcGUgaXRlbSBmb3IgYSBzaW5nbGUgc3BhblxuICovXG5mdW5jdGlvbiBjcmVhdGVTcGFuRW52ZWxvcGVJdGVtKHNwYW5Kc29uKSB7XG4gIGNvbnN0IHNwYW5IZWFkZXJzID0ge1xuICAgIHR5cGU6ICdzcGFuJyxcbiAgfTtcblxuICByZXR1cm4gW3NwYW5IZWFkZXJzLCBzcGFuSnNvbl07XG59XG5cbi8qKlxuICogQ3JlYXRlcyBhdHRhY2htZW50IGVudmVsb3BlIGl0ZW1zXG4gKi9cbmZ1bmN0aW9uIGNyZWF0ZUF0dGFjaG1lbnRFbnZlbG9wZUl0ZW0oYXR0YWNobWVudCkge1xuICBjb25zdCBidWZmZXIgPSB0eXBlb2YgYXR0YWNobWVudC5kYXRhID09PSAnc3RyaW5nJyA/IGVuY29kZVVURjgoYXR0YWNobWVudC5kYXRhKSA6IGF0dGFjaG1lbnQuZGF0YTtcblxuICByZXR1cm4gW1xuICAgIHtcbiAgICAgIHR5cGU6ICdhdHRhY2htZW50JyxcbiAgICAgIGxlbmd0aDogYnVmZmVyLmxlbmd0aCxcbiAgICAgIGZpbGVuYW1lOiBhdHRhY2htZW50LmZpbGVuYW1lLFxuICAgICAgY29udGVudF90eXBlOiBhdHRhY2htZW50LmNvbnRlbnRUeXBlLFxuICAgICAgYXR0YWNobWVudF90eXBlOiBhdHRhY2htZW50LmF0dGFjaG1lbnRUeXBlLFxuICAgIH0sXG4gICAgYnVmZmVyLFxuICBdO1xufVxuXG5jb25zdCBJVEVNX1RZUEVfVE9fREFUQV9DQVRFR09SWV9NQVAgPSB7XG4gIHNlc3Npb246ICdzZXNzaW9uJyxcbiAgc2Vzc2lvbnM6ICdzZXNzaW9uJyxcbiAgYXR0YWNobWVudDogJ2F0dGFjaG1lbnQnLFxuICB0cmFuc2FjdGlvbjogJ3RyYW5zYWN0aW9uJyxcbiAgZXZlbnQ6ICdlcnJvcicsXG4gIGNsaWVudF9yZXBvcnQ6ICdpbnRlcm5hbCcsXG4gIHVzZXJfcmVwb3J0OiAnZGVmYXVsdCcsXG4gIHByb2ZpbGU6ICdwcm9maWxlJyxcbiAgcHJvZmlsZV9jaHVuazogJ3Byb2ZpbGUnLFxuICByZXBsYXlfZXZlbnQ6ICdyZXBsYXknLFxuICByZXBsYXlfcmVjb3JkaW5nOiAncmVwbGF5JyxcbiAgY2hlY2tfaW46ICdtb25pdG9yJyxcbiAgZmVlZGJhY2s6ICdmZWVkYmFjaycsXG4gIHNwYW46ICdzcGFuJyxcbiAgcmF3X3NlY3VyaXR5OiAnc2VjdXJpdHknLFxuICBsb2c6ICdsb2dfaXRlbScsXG59O1xuXG4vKipcbiAqIE1hcHMgdGhlIHR5cGUgb2YgYW4gZW52ZWxvcGUgaXRlbSB0byBhIGRhdGEgY2F0ZWdvcnkuXG4gKi9cbmZ1bmN0aW9uIGVudmVsb3BlSXRlbVR5cGVUb0RhdGFDYXRlZ29yeSh0eXBlKSB7XG4gIHJldHVybiBJVEVNX1RZUEVfVE9fREFUQV9DQVRFR09SWV9NQVBbdHlwZV07XG59XG5cbi8qKiBFeHRyYWN0cyB0aGUgbWluaW1hbCBTREsgaW5mbyBmcm9tIHRoZSBtZXRhZGF0YSBvciBhbiBldmVudHMgKi9cbmZ1bmN0aW9uIGdldFNka01ldGFkYXRhRm9yRW52ZWxvcGVIZWFkZXIobWV0YWRhdGFPckV2ZW50KSB7XG4gIGlmICghbWV0YWRhdGFPckV2ZW50Py5zZGspIHtcbiAgICByZXR1cm47XG4gIH1cbiAgY29uc3QgeyBuYW1lLCB2ZXJzaW9uIH0gPSBtZXRhZGF0YU9yRXZlbnQuc2RrO1xuICByZXR1cm4geyBuYW1lLCB2ZXJzaW9uIH07XG59XG5cbi8qKlxuICogQ3JlYXRlcyBldmVudCBlbnZlbG9wZSBoZWFkZXJzLCBiYXNlZCBvbiBldmVudCwgc2RrIGluZm8gYW5kIHR1bm5lbFxuICogTm90ZTogVGhpcyBmdW5jdGlvbiB3YXMgZXh0cmFjdGVkIGZyb20gdGhlIGNvcmUgcGFja2FnZSB0byBtYWtlIGl0IGF2YWlsYWJsZSBpbiBSZXBsYXlcbiAqL1xuZnVuY3Rpb24gY3JlYXRlRXZlbnRFbnZlbG9wZUhlYWRlcnMoXG4gIGV2ZW50LFxuICBzZGtJbmZvLFxuICB0dW5uZWwsXG4gIGRzbiQxLFxuKSB7XG4gIGNvbnN0IGR5bmFtaWNTYW1wbGluZ0NvbnRleHQgPSBldmVudC5zZGtQcm9jZXNzaW5nTWV0YWRhdGE/LmR5bmFtaWNTYW1wbGluZ0NvbnRleHQ7XG4gIHJldHVybiB7XG4gICAgZXZlbnRfaWQ6IGV2ZW50LmV2ZW50X2lkICxcbiAgICBzZW50X2F0OiBuZXcgRGF0ZSgpLnRvSVNPU3RyaW5nKCksXG4gICAgLi4uKHNka0luZm8gJiYgeyBzZGs6IHNka0luZm8gfSksXG4gICAgLi4uKCEhdHVubmVsICYmIGRzbiQxICYmIHsgZHNuOiBkc24uZHNuVG9TdHJpbmcoZHNuJDEpIH0pLFxuICAgIC4uLihkeW5hbWljU2FtcGxpbmdDb250ZXh0ICYmIHtcbiAgICAgIHRyYWNlOiBkeW5hbWljU2FtcGxpbmdDb250ZXh0LFxuICAgIH0pLFxuICB9O1xufVxuXG5leHBvcnRzLmFkZEl0ZW1Ub0VudmVsb3BlID0gYWRkSXRlbVRvRW52ZWxvcGU7XG5leHBvcnRzLmNyZWF0ZUF0dGFjaG1lbnRFbnZlbG9wZUl0ZW0gPSBjcmVhdGVBdHRhY2htZW50RW52ZWxvcGVJdGVtO1xuZXhwb3J0cy5jcmVhdGVFbnZlbG9wZSA9IGNyZWF0ZUVudmVsb3BlO1xuZXhwb3J0cy5jcmVhdGVFdmVudEVudmVsb3BlSGVhZGVycyA9IGNyZWF0ZUV2ZW50RW52ZWxvcGVIZWFkZXJzO1xuZXhwb3J0cy5jcmVhdGVTcGFuRW52ZWxvcGVJdGVtID0gY3JlYXRlU3BhbkVudmVsb3BlSXRlbTtcbmV4cG9ydHMuZW52ZWxvcGVDb250YWluc0l0ZW1UeXBlID0gZW52ZWxvcGVDb250YWluc0l0ZW1UeXBlO1xuZXhwb3J0cy5lbnZlbG9wZUl0ZW1UeXBlVG9EYXRhQ2F0ZWdvcnkgPSBlbnZlbG9wZUl0ZW1UeXBlVG9EYXRhQ2F0ZWdvcnk7XG5leHBvcnRzLmZvckVhY2hFbnZlbG9wZUl0ZW0gPSBmb3JFYWNoRW52ZWxvcGVJdGVtO1xuZXhwb3J0cy5nZXRTZGtNZXRhZGF0YUZvckVudmVsb3BlSGVhZGVyID0gZ2V0U2RrTWV0YWRhdGFGb3JFbnZlbG9wZUhlYWRlcjtcbmV4cG9ydHMucGFyc2VFbnZlbG9wZSA9IHBhcnNlRW52ZWxvcGU7XG5leHBvcnRzLnNlcmlhbGl6ZUVudmVsb3BlID0gc2VyaWFsaXplRW52ZWxvcGU7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1lbnZlbG9wZS5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/envelope.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/error.js":
/*!***************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/error.js ***!
  \***************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n/**\n * An error emitted by Sentry SDKs and related utilities.\n * @deprecated This class is no longer used and will be removed in a future version. Use `Error` instead.\n */\nclass SentryError extends Error {\n\n   constructor(\n     message,\n    logLevel = 'warn',\n  ) {\n    super(message);this.message = message;\n    this.logLevel = logLevel;\n  }\n}\n\nexports.SentryError = SentryError;\n//# sourceMappingURL=error.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvZXJyb3IuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEU7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLG1CQUFtQjtBQUNuQjtBQUNBO0FBQ0E7O0FBRUEsbUJBQW1CO0FBQ25CIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvZXJyb3IuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbi8qKlxuICogQW4gZXJyb3IgZW1pdHRlZCBieSBTZW50cnkgU0RLcyBhbmQgcmVsYXRlZCB1dGlsaXRpZXMuXG4gKiBAZGVwcmVjYXRlZCBUaGlzIGNsYXNzIGlzIG5vIGxvbmdlciB1c2VkIGFuZCB3aWxsIGJlIHJlbW92ZWQgaW4gYSBmdXR1cmUgdmVyc2lvbi4gVXNlIGBFcnJvcmAgaW5zdGVhZC5cbiAqL1xuY2xhc3MgU2VudHJ5RXJyb3IgZXh0ZW5kcyBFcnJvciB7XG5cbiAgIGNvbnN0cnVjdG9yKFxuICAgICBtZXNzYWdlLFxuICAgIGxvZ0xldmVsID0gJ3dhcm4nLFxuICApIHtcbiAgICBzdXBlcihtZXNzYWdlKTt0aGlzLm1lc3NhZ2UgPSBtZXNzYWdlO1xuICAgIHRoaXMubG9nTGV2ZWwgPSBsb2dMZXZlbDtcbiAgfVxufVxuXG5leHBvcnRzLlNlbnRyeUVycm9yID0gU2VudHJ5RXJyb3I7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1lcnJvci5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/error.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/eventUtils.js":
/*!********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/eventUtils.js ***!
  \********************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n/**\n * Get a list of possible event messages from a Sentry event.\n */\nfunction getPossibleEventMessages(event) {\n  const possibleMessages = [];\n\n  if (event.message) {\n    possibleMessages.push(event.message);\n  }\n\n  try {\n    // @ts-expect-error Try catching to save bundle size\n    const lastException = event.exception.values[event.exception.values.length - 1];\n    if (lastException?.value) {\n      possibleMessages.push(lastException.value);\n      if (lastException.type) {\n        possibleMessages.push(`${lastException.type}: ${lastException.value}`);\n      }\n    }\n  } catch {\n    // ignore errors here\n  }\n\n  return possibleMessages;\n}\n\nexports.getPossibleEventMessages = getPossibleEventMessages;\n//# sourceMappingURL=eventUtils.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvZXZlbnRVdGlscy5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxpQ0FBaUMsbUJBQW1CLElBQUksb0JBQW9CO0FBQzVFO0FBQ0E7QUFDQSxJQUFJO0FBQ0o7QUFDQTs7QUFFQTtBQUNBOztBQUVBLGdDQUFnQztBQUNoQyIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3V0aWxzL2V2ZW50VXRpbHMuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbi8qKlxuICogR2V0IGEgbGlzdCBvZiBwb3NzaWJsZSBldmVudCBtZXNzYWdlcyBmcm9tIGEgU2VudHJ5IGV2ZW50LlxuICovXG5mdW5jdGlvbiBnZXRQb3NzaWJsZUV2ZW50TWVzc2FnZXMoZXZlbnQpIHtcbiAgY29uc3QgcG9zc2libGVNZXNzYWdlcyA9IFtdO1xuXG4gIGlmIChldmVudC5tZXNzYWdlKSB7XG4gICAgcG9zc2libGVNZXNzYWdlcy5wdXNoKGV2ZW50Lm1lc3NhZ2UpO1xuICB9XG5cbiAgdHJ5IHtcbiAgICAvLyBAdHMtZXhwZWN0LWVycm9yIFRyeSBjYXRjaGluZyB0byBzYXZlIGJ1bmRsZSBzaXplXG4gICAgY29uc3QgbGFzdEV4Y2VwdGlvbiA9IGV2ZW50LmV4Y2VwdGlvbi52YWx1ZXNbZXZlbnQuZXhjZXB0aW9uLnZhbHVlcy5sZW5ndGggLSAxXTtcbiAgICBpZiAobGFzdEV4Y2VwdGlvbj8udmFsdWUpIHtcbiAgICAgIHBvc3NpYmxlTWVzc2FnZXMucHVzaChsYXN0RXhjZXB0aW9uLnZhbHVlKTtcbiAgICAgIGlmIChsYXN0RXhjZXB0aW9uLnR5cGUpIHtcbiAgICAgICAgcG9zc2libGVNZXNzYWdlcy5wdXNoKGAke2xhc3RFeGNlcHRpb24udHlwZX06ICR7bGFzdEV4Y2VwdGlvbi52YWx1ZX1gKTtcbiAgICAgIH1cbiAgICB9XG4gIH0gY2F0Y2gge1xuICAgIC8vIGlnbm9yZSBlcnJvcnMgaGVyZVxuICB9XG5cbiAgcmV0dXJuIHBvc3NpYmxlTWVzc2FnZXM7XG59XG5cbmV4cG9ydHMuZ2V0UG9zc2libGVFdmVudE1lc3NhZ2VzID0gZ2V0UG9zc2libGVFdmVudE1lc3NhZ2VzO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9ZXZlbnRVdGlscy5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/eventUtils.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/eventbuilder.js":
/*!**********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/eventbuilder.js ***!
  \**********************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst is = __webpack_require__(/*! ./is.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js\");\nconst misc = __webpack_require__(/*! ./misc.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/misc.js\");\nconst normalize = __webpack_require__(/*! ./normalize.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/normalize.js\");\nconst object = __webpack_require__(/*! ./object.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/object.js\");\n\n/**\n * Extracts stack frames from the error.stack string\n */\nfunction parseStackFrames(stackParser, error) {\n  return stackParser(error.stack || '', 1);\n}\n\n/**\n * Extracts stack frames from the error and builds a Sentry Exception\n */\nfunction exceptionFromError(stackParser, error) {\n  const exception = {\n    type: error.name || error.constructor.name,\n    value: error.message,\n  };\n\n  const frames = parseStackFrames(stackParser, error);\n  if (frames.length) {\n    exception.stacktrace = { frames };\n  }\n\n  return exception;\n}\n\n/** If a plain object has a property that is an `Error`, return this error. */\nfunction getErrorPropertyFromObject(obj) {\n  for (const prop in obj) {\n    if (Object.prototype.hasOwnProperty.call(obj, prop)) {\n      const value = obj[prop];\n      if (value instanceof Error) {\n        return value;\n      }\n    }\n  }\n\n  return undefined;\n}\n\nfunction getMessageForObject(exception) {\n  if ('name' in exception && typeof exception.name === 'string') {\n    let message = `'${exception.name}' captured as exception`;\n\n    if ('message' in exception && typeof exception.message === 'string') {\n      message += ` with message '${exception.message}'`;\n    }\n\n    return message;\n  } else if ('message' in exception && typeof exception.message === 'string') {\n    return exception.message;\n  }\n\n  const keys = object.extractExceptionKeysForMessage(exception);\n\n  // Some ErrorEvent instances do not have an `error` property, which is why they are not handled before\n  // We still want to try to get a decent message for these cases\n  if (is.isErrorEvent(exception)) {\n    return `Event \\`ErrorEvent\\` captured as exception with message \\`${exception.message}\\``;\n  }\n\n  const className = getObjectClassName(exception);\n\n  return `${\n    className && className !== 'Object' ? `'${className}'` : 'Object'\n  } captured as exception with keys: ${keys}`;\n}\n\nfunction getObjectClassName(obj) {\n  try {\n    const prototype = Object.getPrototypeOf(obj);\n    return prototype ? prototype.constructor.name : undefined;\n  } catch {\n    // ignore errors here\n  }\n}\n\nfunction getException(\n  client,\n  mechanism,\n  exception,\n  hint,\n) {\n  if (is.isError(exception)) {\n    return [exception, undefined];\n  }\n\n  // Mutate this!\n  mechanism.synthetic = true;\n\n  if (is.isPlainObject(exception)) {\n    const normalizeDepth = client?.getOptions().normalizeDepth;\n    const extras = { ['__serialized__']: normalize.normalizeToSize(exception , normalizeDepth) };\n\n    const errorFromProp = getErrorPropertyFromObject(exception);\n    if (errorFromProp) {\n      return [errorFromProp, extras];\n    }\n\n    const message = getMessageForObject(exception);\n    const ex = hint?.syntheticException || new Error(message);\n    ex.message = message;\n\n    return [ex, extras];\n  }\n\n  // This handles when someone does: `throw \"something awesome\";`\n  // We use synthesized Error here so we can extract a (rough) stack trace.\n  const ex = hint?.syntheticException || new Error(exception );\n  ex.message = `${exception}`;\n\n  return [ex, undefined];\n}\n\n/**\n * Builds and Event from a Exception\n * @hidden\n */\nfunction eventFromUnknownInput(\n  client,\n  stackParser,\n  exception,\n  hint,\n) {\n  const providedMechanism = hint?.data && (hint.data ).mechanism;\n  const mechanism = providedMechanism || {\n    handled: true,\n    type: 'generic',\n  };\n\n  const [ex, extras] = getException(client, mechanism, exception, hint);\n\n  const event = {\n    exception: {\n      values: [exceptionFromError(stackParser, ex)],\n    },\n  };\n\n  if (extras) {\n    event.extra = extras;\n  }\n\n  misc.addExceptionTypeValue(event, undefined, undefined);\n  misc.addExceptionMechanism(event, mechanism);\n\n  return {\n    ...event,\n    event_id: hint?.event_id,\n  };\n}\n\n/**\n * Builds and Event from a Message\n * @hidden\n */\nfunction eventFromMessage(\n  stackParser,\n  message,\n  level = 'info',\n  hint,\n  attachStacktrace,\n) {\n  const event = {\n    event_id: hint?.event_id,\n    level,\n  };\n\n  if (attachStacktrace && hint?.syntheticException) {\n    const frames = parseStackFrames(stackParser, hint.syntheticException);\n    if (frames.length) {\n      event.exception = {\n        values: [\n          {\n            value: message,\n            stacktrace: { frames },\n          },\n        ],\n      };\n      misc.addExceptionMechanism(event, { synthetic: true });\n    }\n  }\n\n  if (is.isParameterizedString(message)) {\n    const { __sentry_template_string__, __sentry_template_values__ } = message;\n\n    event.logentry = {\n      message: __sentry_template_string__,\n      params: __sentry_template_values__,\n    };\n    return event;\n  }\n\n  event.message = message;\n  return event;\n}\n\nexports.eventFromMessage = eventFromMessage;\nexports.eventFromUnknownInput = eventFromUnknownInput;\nexports.exceptionFromError = exceptionFromError;\nexports.parseStackFrames = parseStackFrames;\n//# sourceMappingURL=eventbuilder.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvZXZlbnRidWlsZGVyLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLFdBQVcsbUJBQU8sQ0FBQyxzSEFBUztBQUM1QixhQUFhLG1CQUFPLENBQUMsMEhBQVc7QUFDaEMsa0JBQWtCLG1CQUFPLENBQUMsb0lBQWdCO0FBQzFDLGVBQWUsbUJBQU8sQ0FBQyw4SEFBYTs7QUFFcEM7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLDZCQUE2QjtBQUM3Qjs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLHNCQUFzQixlQUFlOztBQUVyQztBQUNBLG1DQUFtQyxrQkFBa0I7QUFDckQ7O0FBRUE7QUFDQSxJQUFJO0FBQ0o7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQSx3RUFBd0Usa0JBQWtCO0FBQzFGOztBQUVBOztBQUVBO0FBQ0EsOENBQThDLFVBQVU7QUFDeEQsSUFBSSxtQ0FBbUMsS0FBSztBQUM1Qzs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLElBQUk7QUFDSjtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLHFCQUFxQjs7QUFFckI7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUEsZ0VBQWdFO0FBQ2hFO0FBQ0E7QUFDQSxrQkFBa0IsVUFBVTs7QUFFNUI7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0EsS0FBSztBQUNMOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsMEJBQTBCLFFBQVE7QUFDbEMsV0FBVztBQUNYO0FBQ0E7QUFDQSwwQ0FBMEMsaUJBQWlCO0FBQzNEO0FBQ0E7O0FBRUE7QUFDQSxZQUFZLHlEQUF5RDs7QUFFckU7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQSx3QkFBd0I7QUFDeEIsNkJBQTZCO0FBQzdCLDBCQUEwQjtBQUMxQix3QkFBd0I7QUFDeEIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9ldmVudGJ1aWxkZXIuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGlzID0gcmVxdWlyZSgnLi9pcy5qcycpO1xuY29uc3QgbWlzYyA9IHJlcXVpcmUoJy4vbWlzYy5qcycpO1xuY29uc3Qgbm9ybWFsaXplID0gcmVxdWlyZSgnLi9ub3JtYWxpemUuanMnKTtcbmNvbnN0IG9iamVjdCA9IHJlcXVpcmUoJy4vb2JqZWN0LmpzJyk7XG5cbi8qKlxuICogRXh0cmFjdHMgc3RhY2sgZnJhbWVzIGZyb20gdGhlIGVycm9yLnN0YWNrIHN0cmluZ1xuICovXG5mdW5jdGlvbiBwYXJzZVN0YWNrRnJhbWVzKHN0YWNrUGFyc2VyLCBlcnJvcikge1xuICByZXR1cm4gc3RhY2tQYXJzZXIoZXJyb3Iuc3RhY2sgfHwgJycsIDEpO1xufVxuXG4vKipcbiAqIEV4dHJhY3RzIHN0YWNrIGZyYW1lcyBmcm9tIHRoZSBlcnJvciBhbmQgYnVpbGRzIGEgU2VudHJ5IEV4Y2VwdGlvblxuICovXG5mdW5jdGlvbiBleGNlcHRpb25Gcm9tRXJyb3Ioc3RhY2tQYXJzZXIsIGVycm9yKSB7XG4gIGNvbnN0IGV4Y2VwdGlvbiA9IHtcbiAgICB0eXBlOiBlcnJvci5uYW1lIHx8IGVycm9yLmNvbnN0cnVjdG9yLm5hbWUsXG4gICAgdmFsdWU6IGVycm9yLm1lc3NhZ2UsXG4gIH07XG5cbiAgY29uc3QgZnJhbWVzID0gcGFyc2VTdGFja0ZyYW1lcyhzdGFja1BhcnNlciwgZXJyb3IpO1xuICBpZiAoZnJhbWVzLmxlbmd0aCkge1xuICAgIGV4Y2VwdGlvbi5zdGFja3RyYWNlID0geyBmcmFtZXMgfTtcbiAgfVxuXG4gIHJldHVybiBleGNlcHRpb247XG59XG5cbi8qKiBJZiBhIHBsYWluIG9iamVjdCBoYXMgYSBwcm9wZXJ0eSB0aGF0IGlzIGFuIGBFcnJvcmAsIHJldHVybiB0aGlzIGVycm9yLiAqL1xuZnVuY3Rpb24gZ2V0RXJyb3JQcm9wZXJ0eUZyb21PYmplY3Qob2JqKSB7XG4gIGZvciAoY29uc3QgcHJvcCBpbiBvYmopIHtcbiAgICBpZiAoT2JqZWN0LnByb3RvdHlwZS5oYXNPd25Qcm9wZXJ0eS5jYWxsKG9iaiwgcHJvcCkpIHtcbiAgICAgIGNvbnN0IHZhbHVlID0gb2JqW3Byb3BdO1xuICAgICAgaWYgKHZhbHVlIGluc3RhbmNlb2YgRXJyb3IpIHtcbiAgICAgICAgcmV0dXJuIHZhbHVlO1xuICAgICAgfVxuICAgIH1cbiAgfVxuXG4gIHJldHVybiB1bmRlZmluZWQ7XG59XG5cbmZ1bmN0aW9uIGdldE1lc3NhZ2VGb3JPYmplY3QoZXhjZXB0aW9uKSB7XG4gIGlmICgnbmFtZScgaW4gZXhjZXB0aW9uICYmIHR5cGVvZiBleGNlcHRpb24ubmFtZSA9PT0gJ3N0cmluZycpIHtcbiAgICBsZXQgbWVzc2FnZSA9IGAnJHtleGNlcHRpb24ubmFtZX0nIGNhcHR1cmVkIGFzIGV4Y2VwdGlvbmA7XG5cbiAgICBpZiAoJ21lc3NhZ2UnIGluIGV4Y2VwdGlvbiAmJiB0eXBlb2YgZXhjZXB0aW9uLm1lc3NhZ2UgPT09ICdzdHJpbmcnKSB7XG4gICAgICBtZXNzYWdlICs9IGAgd2l0aCBtZXNzYWdlICcke2V4Y2VwdGlvbi5tZXNzYWdlfSdgO1xuICAgIH1cblxuICAgIHJldHVybiBtZXNzYWdlO1xuICB9IGVsc2UgaWYgKCdtZXNzYWdlJyBpbiBleGNlcHRpb24gJiYgdHlwZW9mIGV4Y2VwdGlvbi5tZXNzYWdlID09PSAnc3RyaW5nJykge1xuICAgIHJldHVybiBleGNlcHRpb24ubWVzc2FnZTtcbiAgfVxuXG4gIGNvbnN0IGtleXMgPSBvYmplY3QuZXh0cmFjdEV4Y2VwdGlvbktleXNGb3JNZXNzYWdlKGV4Y2VwdGlvbik7XG5cbiAgLy8gU29tZSBFcnJvckV2ZW50IGluc3RhbmNlcyBkbyBub3QgaGF2ZSBhbiBgZXJyb3JgIHByb3BlcnR5LCB3aGljaCBpcyB3aHkgdGhleSBhcmUgbm90IGhhbmRsZWQgYmVmb3JlXG4gIC8vIFdlIHN0aWxsIHdhbnQgdG8gdHJ5IHRvIGdldCBhIGRlY2VudCBtZXNzYWdlIGZvciB0aGVzZSBjYXNlc1xuICBpZiAoaXMuaXNFcnJvckV2ZW50KGV4Y2VwdGlvbikpIHtcbiAgICByZXR1cm4gYEV2ZW50IFxcYEVycm9yRXZlbnRcXGAgY2FwdHVyZWQgYXMgZXhjZXB0aW9uIHdpdGggbWVzc2FnZSBcXGAke2V4Y2VwdGlvbi5tZXNzYWdlfVxcYGA7XG4gIH1cblxuICBjb25zdCBjbGFzc05hbWUgPSBnZXRPYmplY3RDbGFzc05hbWUoZXhjZXB0aW9uKTtcblxuICByZXR1cm4gYCR7XG4gICAgY2xhc3NOYW1lICYmIGNsYXNzTmFtZSAhPT0gJ09iamVjdCcgPyBgJyR7Y2xhc3NOYW1lfSdgIDogJ09iamVjdCdcbiAgfSBjYXB0dXJlZCBhcyBleGNlcHRpb24gd2l0aCBrZXlzOiAke2tleXN9YDtcbn1cblxuZnVuY3Rpb24gZ2V0T2JqZWN0Q2xhc3NOYW1lKG9iaikge1xuICB0cnkge1xuICAgIGNvbnN0IHByb3RvdHlwZSA9IE9iamVjdC5nZXRQcm90b3R5cGVPZihvYmopO1xuICAgIHJldHVybiBwcm90b3R5cGUgPyBwcm90b3R5cGUuY29uc3RydWN0b3IubmFtZSA6IHVuZGVmaW5lZDtcbiAgfSBjYXRjaCB7XG4gICAgLy8gaWdub3JlIGVycm9ycyBoZXJlXG4gIH1cbn1cblxuZnVuY3Rpb24gZ2V0RXhjZXB0aW9uKFxuICBjbGllbnQsXG4gIG1lY2hhbmlzbSxcbiAgZXhjZXB0aW9uLFxuICBoaW50LFxuKSB7XG4gIGlmIChpcy5pc0Vycm9yKGV4Y2VwdGlvbikpIHtcbiAgICByZXR1cm4gW2V4Y2VwdGlvbiwgdW5kZWZpbmVkXTtcbiAgfVxuXG4gIC8vIE11dGF0ZSB0aGlzIVxuICBtZWNoYW5pc20uc3ludGhldGljID0gdHJ1ZTtcblxuICBpZiAoaXMuaXNQbGFpbk9iamVjdChleGNlcHRpb24pKSB7XG4gICAgY29uc3Qgbm9ybWFsaXplRGVwdGggPSBjbGllbnQ/LmdldE9wdGlvbnMoKS5ub3JtYWxpemVEZXB0aDtcbiAgICBjb25zdCBleHRyYXMgPSB7IFsnX19zZXJpYWxpemVkX18nXTogbm9ybWFsaXplLm5vcm1hbGl6ZVRvU2l6ZShleGNlcHRpb24gLCBub3JtYWxpemVEZXB0aCkgfTtcblxuICAgIGNvbnN0IGVycm9yRnJvbVByb3AgPSBnZXRFcnJvclByb3BlcnR5RnJvbU9iamVjdChleGNlcHRpb24pO1xuICAgIGlmIChlcnJvckZyb21Qcm9wKSB7XG4gICAgICByZXR1cm4gW2Vycm9yRnJvbVByb3AsIGV4dHJhc107XG4gICAgfVxuXG4gICAgY29uc3QgbWVzc2FnZSA9IGdldE1lc3NhZ2VGb3JPYmplY3QoZXhjZXB0aW9uKTtcbiAgICBjb25zdCBleCA9IGhpbnQ/LnN5bnRoZXRpY0V4Y2VwdGlvbiB8fCBuZXcgRXJyb3IobWVzc2FnZSk7XG4gICAgZXgubWVzc2FnZSA9IG1lc3NhZ2U7XG5cbiAgICByZXR1cm4gW2V4LCBleHRyYXNdO1xuICB9XG5cbiAgLy8gVGhpcyBoYW5kbGVzIHdoZW4gc29tZW9uZSBkb2VzOiBgdGhyb3cgXCJzb21ldGhpbmcgYXdlc29tZVwiO2BcbiAgLy8gV2UgdXNlIHN5bnRoZXNpemVkIEVycm9yIGhlcmUgc28gd2UgY2FuIGV4dHJhY3QgYSAocm91Z2gpIHN0YWNrIHRyYWNlLlxuICBjb25zdCBleCA9IGhpbnQ/LnN5bnRoZXRpY0V4Y2VwdGlvbiB8fCBuZXcgRXJyb3IoZXhjZXB0aW9uICk7XG4gIGV4Lm1lc3NhZ2UgPSBgJHtleGNlcHRpb259YDtcblxuICByZXR1cm4gW2V4LCB1bmRlZmluZWRdO1xufVxuXG4vKipcbiAqIEJ1aWxkcyBhbmQgRXZlbnQgZnJvbSBhIEV4Y2VwdGlvblxuICogQGhpZGRlblxuICovXG5mdW5jdGlvbiBldmVudEZyb21Vbmtub3duSW5wdXQoXG4gIGNsaWVudCxcbiAgc3RhY2tQYXJzZXIsXG4gIGV4Y2VwdGlvbixcbiAgaGludCxcbikge1xuICBjb25zdCBwcm92aWRlZE1lY2hhbmlzbSA9IGhpbnQ/LmRhdGEgJiYgKGhpbnQuZGF0YSApLm1lY2hhbmlzbTtcbiAgY29uc3QgbWVjaGFuaXNtID0gcHJvdmlkZWRNZWNoYW5pc20gfHwge1xuICAgIGhhbmRsZWQ6IHRydWUsXG4gICAgdHlwZTogJ2dlbmVyaWMnLFxuICB9O1xuXG4gIGNvbnN0IFtleCwgZXh0cmFzXSA9IGdldEV4Y2VwdGlvbihjbGllbnQsIG1lY2hhbmlzbSwgZXhjZXB0aW9uLCBoaW50KTtcblxuICBjb25zdCBldmVudCA9IHtcbiAgICBleGNlcHRpb246IHtcbiAgICAgIHZhbHVlczogW2V4Y2VwdGlvbkZyb21FcnJvcihzdGFja1BhcnNlciwgZXgpXSxcbiAgICB9LFxuICB9O1xuXG4gIGlmIChleHRyYXMpIHtcbiAgICBldmVudC5leHRyYSA9IGV4dHJhcztcbiAgfVxuXG4gIG1pc2MuYWRkRXhjZXB0aW9uVHlwZVZhbHVlKGV2ZW50LCB1bmRlZmluZWQsIHVuZGVmaW5lZCk7XG4gIG1pc2MuYWRkRXhjZXB0aW9uTWVjaGFuaXNtKGV2ZW50LCBtZWNoYW5pc20pO1xuXG4gIHJldHVybiB7XG4gICAgLi4uZXZlbnQsXG4gICAgZXZlbnRfaWQ6IGhpbnQ/LmV2ZW50X2lkLFxuICB9O1xufVxuXG4vKipcbiAqIEJ1aWxkcyBhbmQgRXZlbnQgZnJvbSBhIE1lc3NhZ2VcbiAqIEBoaWRkZW5cbiAqL1xuZnVuY3Rpb24gZXZlbnRGcm9tTWVzc2FnZShcbiAgc3RhY2tQYXJzZXIsXG4gIG1lc3NhZ2UsXG4gIGxldmVsID0gJ2luZm8nLFxuICBoaW50LFxuICBhdHRhY2hTdGFja3RyYWNlLFxuKSB7XG4gIGNvbnN0IGV2ZW50ID0ge1xuICAgIGV2ZW50X2lkOiBoaW50Py5ldmVudF9pZCxcbiAgICBsZXZlbCxcbiAgfTtcblxuICBpZiAoYXR0YWNoU3RhY2t0cmFjZSAmJiBoaW50Py5zeW50aGV0aWNFeGNlcHRpb24pIHtcbiAgICBjb25zdCBmcmFtZXMgPSBwYXJzZVN0YWNrRnJhbWVzKHN0YWNrUGFyc2VyLCBoaW50LnN5bnRoZXRpY0V4Y2VwdGlvbik7XG4gICAgaWYgKGZyYW1lcy5sZW5ndGgpIHtcbiAgICAgIGV2ZW50LmV4Y2VwdGlvbiA9IHtcbiAgICAgICAgdmFsdWVzOiBbXG4gICAgICAgICAge1xuICAgICAgICAgICAgdmFsdWU6IG1lc3NhZ2UsXG4gICAgICAgICAgICBzdGFja3RyYWNlOiB7IGZyYW1lcyB9LFxuICAgICAgICAgIH0sXG4gICAgICAgIF0sXG4gICAgICB9O1xuICAgICAgbWlzYy5hZGRFeGNlcHRpb25NZWNoYW5pc20oZXZlbnQsIHsgc3ludGhldGljOiB0cnVlIH0pO1xuICAgIH1cbiAgfVxuXG4gIGlmIChpcy5pc1BhcmFtZXRlcml6ZWRTdHJpbmcobWVzc2FnZSkpIHtcbiAgICBjb25zdCB7IF9fc2VudHJ5X3RlbXBsYXRlX3N0cmluZ19fLCBfX3NlbnRyeV90ZW1wbGF0ZV92YWx1ZXNfXyB9ID0gbWVzc2FnZTtcblxuICAgIGV2ZW50LmxvZ2VudHJ5ID0ge1xuICAgICAgbWVzc2FnZTogX19zZW50cnlfdGVtcGxhdGVfc3RyaW5nX18sXG4gICAgICBwYXJhbXM6IF9fc2VudHJ5X3RlbXBsYXRlX3ZhbHVlc19fLFxuICAgIH07XG4gICAgcmV0dXJuIGV2ZW50O1xuICB9XG5cbiAgZXZlbnQubWVzc2FnZSA9IG1lc3NhZ2U7XG4gIHJldHVybiBldmVudDtcbn1cblxuZXhwb3J0cy5ldmVudEZyb21NZXNzYWdlID0gZXZlbnRGcm9tTWVzc2FnZTtcbmV4cG9ydHMuZXZlbnRGcm9tVW5rbm93bklucHV0ID0gZXZlbnRGcm9tVW5rbm93bklucHV0O1xuZXhwb3J0cy5leGNlcHRpb25Gcm9tRXJyb3IgPSBleGNlcHRpb25Gcm9tRXJyb3I7XG5leHBvcnRzLnBhcnNlU3RhY2tGcmFtZXMgPSBwYXJzZVN0YWNrRnJhbWVzO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9ZXZlbnRidWlsZGVyLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/eventbuilder.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/featureFlags.js":
/*!**********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/featureFlags.js ***!
  \**********************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst currentScopes = __webpack_require__(/*! ../currentScopes.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst debugBuild = __webpack_require__(/*! ../debug-build.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst debugLogger = __webpack_require__(/*! ./debug-logger.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst spanUtils = __webpack_require__(/*! ./spanUtils.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanUtils.js\");\n\n/**\n * Ordered LRU cache for storing feature flags in the scope context. The name\n * of each flag in the buffer is unique, and the output of getAll() is ordered\n * from oldest to newest.\n */\n\n/**\n * Max size of the LRU flag buffer stored in Sentry scope and event contexts.\n */\nconst _INTERNAL_FLAG_BUFFER_SIZE = 100;\n\n/**\n * Max number of flag evaluations to record per span.\n */\nconst _INTERNAL_MAX_FLAGS_PER_SPAN = 10;\n\nconst SPAN_FLAG_ATTRIBUTE_PREFIX = 'flag.evaluation.';\n\n/**\n * Copies feature flags that are in current scope context to the event context\n */\nfunction _INTERNAL_copyFlagsFromScopeToEvent(event) {\n  const scope = currentScopes.getCurrentScope();\n  const flagContext = scope.getScopeData().contexts.flags;\n  const flagBuffer = flagContext ? flagContext.values : [];\n\n  if (!flagBuffer.length) {\n    return event;\n  }\n\n  if (event.contexts === undefined) {\n    event.contexts = {};\n  }\n  event.contexts.flags = { values: [...flagBuffer] };\n  return event;\n}\n\n/**\n * Inserts a flag into the current scope's context while maintaining ordered LRU properties.\n * Not thread-safe. After inserting:\n * - The flag buffer is sorted in order of recency, with the newest evaluation at the end.\n * - The names in the buffer are always unique.\n * - The length of the buffer never exceeds `maxSize`.\n *\n * @param name     Name of the feature flag to insert.\n * @param value    Value of the feature flag.\n * @param maxSize  Max number of flags the buffer should store. Default value should always be used in production.\n */\nfunction _INTERNAL_insertFlagToScope(\n  name,\n  value,\n  maxSize = _INTERNAL_FLAG_BUFFER_SIZE,\n) {\n  const scopeContexts = currentScopes.getCurrentScope().getScopeData().contexts;\n  if (!scopeContexts.flags) {\n    scopeContexts.flags = { values: [] };\n  }\n  const flags = scopeContexts.flags.values ;\n  _INTERNAL_insertToFlagBuffer(flags, name, value, maxSize);\n}\n\n/**\n * Exported for tests only. Currently only accepts boolean values (otherwise no-op).\n * Inserts a flag into a FeatureFlag array while maintaining the following properties:\n * - Flags are sorted in order of recency, with the newest evaluation at the end.\n * - The flag names are always unique.\n * - The length of the array never exceeds `maxSize`.\n *\n * @param flags      The buffer to insert the flag into.\n * @param name       Name of the feature flag to insert.\n * @param value      Value of the feature flag.\n * @param maxSize    Max number of flags the buffer should store. Default value should always be used in production.\n */\nfunction _INTERNAL_insertToFlagBuffer(\n  flags,\n  name,\n  value,\n  maxSize,\n) {\n  if (typeof value !== 'boolean') {\n    return;\n  }\n\n  if (flags.length > maxSize) {\n    debugBuild.DEBUG_BUILD && debugLogger.debug.error(`[Feature Flags] insertToFlagBuffer called on a buffer larger than maxSize=${maxSize}`);\n    return;\n  }\n\n  // Check if the flag is already in the buffer - O(n)\n  const index = flags.findIndex(f => f.flag === name);\n\n  if (index !== -1) {\n    // The flag was found, remove it from its current position - O(n)\n    flags.splice(index, 1);\n  }\n\n  if (flags.length === maxSize) {\n    // If at capacity, pop the earliest flag - O(n)\n    flags.shift();\n  }\n\n  // Push the flag to the end - O(1)\n  flags.push({\n    flag: name,\n    result: value,\n  });\n}\n\n/**\n * Records a feature flag evaluation for the active span. This is a no-op for non-boolean values.\n * The flag and its value is stored in span attributes with the `flag.evaluation` prefix. Once the\n * unique flags for a span reaches maxFlagsPerSpan, subsequent flags are dropped.\n *\n * @param name             Name of the feature flag.\n * @param value            Value of the feature flag. Non-boolean values are ignored.\n * @param maxFlagsPerSpan  Max number of flags a buffer should store. Default value should always be used in production.\n */\nfunction _INTERNAL_addFeatureFlagToActiveSpan(\n  name,\n  value,\n  maxFlagsPerSpan = _INTERNAL_MAX_FLAGS_PER_SPAN,\n) {\n  if (typeof value !== 'boolean') {\n    return;\n  }\n\n  const span = spanUtils.getActiveSpan();\n  if (!span) {\n    return;\n  }\n\n  const attributes = spanUtils.spanToJSON(span).data;\n\n  // If the flag already exists, always update it\n  if (`${SPAN_FLAG_ATTRIBUTE_PREFIX}${name}` in attributes) {\n    span.setAttribute(`${SPAN_FLAG_ATTRIBUTE_PREFIX}${name}`, value);\n    return;\n  }\n\n  // Else, add the flag to the span if we have not reached the max number of flags\n  const numOfAddedFlags = Object.keys(attributes).filter(key => key.startsWith(SPAN_FLAG_ATTRIBUTE_PREFIX)).length;\n  if (numOfAddedFlags < maxFlagsPerSpan) {\n    span.setAttribute(`${SPAN_FLAG_ATTRIBUTE_PREFIX}${name}`, value);\n  }\n}\n\nexports._INTERNAL_FLAG_BUFFER_SIZE = _INTERNAL_FLAG_BUFFER_SIZE;\nexports._INTERNAL_MAX_FLAGS_PER_SPAN = _INTERNAL_MAX_FLAGS_PER_SPAN;\nexports._INTERNAL_addFeatureFlagToActiveSpan = _INTERNAL_addFeatureFlagToActiveSpan;\nexports._INTERNAL_copyFlagsFromScopeToEvent = _INTERNAL_copyFlagsFromScopeToEvent;\nexports._INTERNAL_insertFlagToScope = _INTERNAL_insertFlagToScope;\nexports._INTERNAL_insertToFlagBuffer = _INTERNAL_insertToFlagBuffer;\n//# sourceMappingURL=featureFlags.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvZmVhdHVyZUZsYWdzLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLHNCQUFzQixtQkFBTyxDQUFDLHVJQUFxQjtBQUNuRCxtQkFBbUIsbUJBQU8sQ0FBQyxtSUFBbUI7QUFDOUMsb0JBQW9CLG1CQUFPLENBQUMsMElBQW1CO0FBQy9DLGtCQUFrQixtQkFBTyxDQUFDLG9JQUFnQjs7QUFFMUM7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0EsMkJBQTJCO0FBQzNCO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsNEJBQTRCO0FBQzVCO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBLG1JQUFtSSxRQUFRO0FBQzNJO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEdBQUc7QUFDSDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBOztBQUVBO0FBQ0EsU0FBUywyQkFBMkIsRUFBRSxLQUFLO0FBQzNDLHlCQUF5QiwyQkFBMkIsRUFBRSxLQUFLO0FBQzNEO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0EseUJBQXlCLDJCQUEyQixFQUFFLEtBQUs7QUFDM0Q7QUFDQTs7QUFFQSxrQ0FBa0M7QUFDbEMsb0NBQW9DO0FBQ3BDLDRDQUE0QztBQUM1QywyQ0FBMkM7QUFDM0MsbUNBQW1DO0FBQ25DLG9DQUFvQztBQUNwQyIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3V0aWxzL2ZlYXR1cmVGbGFncy5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgY3VycmVudFNjb3BlcyA9IHJlcXVpcmUoJy4uL2N1cnJlbnRTY29wZXMuanMnKTtcbmNvbnN0IGRlYnVnQnVpbGQgPSByZXF1aXJlKCcuLi9kZWJ1Zy1idWlsZC5qcycpO1xuY29uc3QgZGVidWdMb2dnZXIgPSByZXF1aXJlKCcuL2RlYnVnLWxvZ2dlci5qcycpO1xuY29uc3Qgc3BhblV0aWxzID0gcmVxdWlyZSgnLi9zcGFuVXRpbHMuanMnKTtcblxuLyoqXG4gKiBPcmRlcmVkIExSVSBjYWNoZSBmb3Igc3RvcmluZyBmZWF0dXJlIGZsYWdzIGluIHRoZSBzY29wZSBjb250ZXh0LiBUaGUgbmFtZVxuICogb2YgZWFjaCBmbGFnIGluIHRoZSBidWZmZXIgaXMgdW5pcXVlLCBhbmQgdGhlIG91dHB1dCBvZiBnZXRBbGwoKSBpcyBvcmRlcmVkXG4gKiBmcm9tIG9sZGVzdCB0byBuZXdlc3QuXG4gKi9cblxuLyoqXG4gKiBNYXggc2l6ZSBvZiB0aGUgTFJVIGZsYWcgYnVmZmVyIHN0b3JlZCBpbiBTZW50cnkgc2NvcGUgYW5kIGV2ZW50IGNvbnRleHRzLlxuICovXG5jb25zdCBfSU5URVJOQUxfRkxBR19CVUZGRVJfU0laRSA9IDEwMDtcblxuLyoqXG4gKiBNYXggbnVtYmVyIG9mIGZsYWcgZXZhbHVhdGlvbnMgdG8gcmVjb3JkIHBlciBzcGFuLlxuICovXG5jb25zdCBfSU5URVJOQUxfTUFYX0ZMQUdTX1BFUl9TUEFOID0gMTA7XG5cbmNvbnN0IFNQQU5fRkxBR19BVFRSSUJVVEVfUFJFRklYID0gJ2ZsYWcuZXZhbHVhdGlvbi4nO1xuXG4vKipcbiAqIENvcGllcyBmZWF0dXJlIGZsYWdzIHRoYXQgYXJlIGluIGN1cnJlbnQgc2NvcGUgY29udGV4dCB0byB0aGUgZXZlbnQgY29udGV4dFxuICovXG5mdW5jdGlvbiBfSU5URVJOQUxfY29weUZsYWdzRnJvbVNjb3BlVG9FdmVudChldmVudCkge1xuICBjb25zdCBzY29wZSA9IGN1cnJlbnRTY29wZXMuZ2V0Q3VycmVudFNjb3BlKCk7XG4gIGNvbnN0IGZsYWdDb250ZXh0ID0gc2NvcGUuZ2V0U2NvcGVEYXRhKCkuY29udGV4dHMuZmxhZ3M7XG4gIGNvbnN0IGZsYWdCdWZmZXIgPSBmbGFnQ29udGV4dCA/IGZsYWdDb250ZXh0LnZhbHVlcyA6IFtdO1xuXG4gIGlmICghZmxhZ0J1ZmZlci5sZW5ndGgpIHtcbiAgICByZXR1cm4gZXZlbnQ7XG4gIH1cblxuICBpZiAoZXZlbnQuY29udGV4dHMgPT09IHVuZGVmaW5lZCkge1xuICAgIGV2ZW50LmNvbnRleHRzID0ge307XG4gIH1cbiAgZXZlbnQuY29udGV4dHMuZmxhZ3MgPSB7IHZhbHVlczogWy4uLmZsYWdCdWZmZXJdIH07XG4gIHJldHVybiBldmVudDtcbn1cblxuLyoqXG4gKiBJbnNlcnRzIGEgZmxhZyBpbnRvIHRoZSBjdXJyZW50IHNjb3BlJ3MgY29udGV4dCB3aGlsZSBtYWludGFpbmluZyBvcmRlcmVkIExSVSBwcm9wZXJ0aWVzLlxuICogTm90IHRocmVhZC1zYWZlLiBBZnRlciBpbnNlcnRpbmc6XG4gKiAtIFRoZSBmbGFnIGJ1ZmZlciBpcyBzb3J0ZWQgaW4gb3JkZXIgb2YgcmVjZW5jeSwgd2l0aCB0aGUgbmV3ZXN0IGV2YWx1YXRpb24gYXQgdGhlIGVuZC5cbiAqIC0gVGhlIG5hbWVzIGluIHRoZSBidWZmZXIgYXJlIGFsd2F5cyB1bmlxdWUuXG4gKiAtIFRoZSBsZW5ndGggb2YgdGhlIGJ1ZmZlciBuZXZlciBleGNlZWRzIGBtYXhTaXplYC5cbiAqXG4gKiBAcGFyYW0gbmFtZSAgICAgTmFtZSBvZiB0aGUgZmVhdHVyZSBmbGFnIHRvIGluc2VydC5cbiAqIEBwYXJhbSB2YWx1ZSAgICBWYWx1ZSBvZiB0aGUgZmVhdHVyZSBmbGFnLlxuICogQHBhcmFtIG1heFNpemUgIE1heCBudW1iZXIgb2YgZmxhZ3MgdGhlIGJ1ZmZlciBzaG91bGQgc3RvcmUuIERlZmF1bHQgdmFsdWUgc2hvdWxkIGFsd2F5cyBiZSB1c2VkIGluIHByb2R1Y3Rpb24uXG4gKi9cbmZ1bmN0aW9uIF9JTlRFUk5BTF9pbnNlcnRGbGFnVG9TY29wZShcbiAgbmFtZSxcbiAgdmFsdWUsXG4gIG1heFNpemUgPSBfSU5URVJOQUxfRkxBR19CVUZGRVJfU0laRSxcbikge1xuICBjb25zdCBzY29wZUNvbnRleHRzID0gY3VycmVudFNjb3Blcy5nZXRDdXJyZW50U2NvcGUoKS5nZXRTY29wZURhdGEoKS5jb250ZXh0cztcbiAgaWYgKCFzY29wZUNvbnRleHRzLmZsYWdzKSB7XG4gICAgc2NvcGVDb250ZXh0cy5mbGFncyA9IHsgdmFsdWVzOiBbXSB9O1xuICB9XG4gIGNvbnN0IGZsYWdzID0gc2NvcGVDb250ZXh0cy5mbGFncy52YWx1ZXMgO1xuICBfSU5URVJOQUxfaW5zZXJ0VG9GbGFnQnVmZmVyKGZsYWdzLCBuYW1lLCB2YWx1ZSwgbWF4U2l6ZSk7XG59XG5cbi8qKlxuICogRXhwb3J0ZWQgZm9yIHRlc3RzIG9ubHkuIEN1cnJlbnRseSBvbmx5IGFjY2VwdHMgYm9vbGVhbiB2YWx1ZXMgKG90aGVyd2lzZSBuby1vcCkuXG4gKiBJbnNlcnRzIGEgZmxhZyBpbnRvIGEgRmVhdHVyZUZsYWcgYXJyYXkgd2hpbGUgbWFpbnRhaW5pbmcgdGhlIGZvbGxvd2luZyBwcm9wZXJ0aWVzOlxuICogLSBGbGFncyBhcmUgc29ydGVkIGluIG9yZGVyIG9mIHJlY2VuY3ksIHdpdGggdGhlIG5ld2VzdCBldmFsdWF0aW9uIGF0IHRoZSBlbmQuXG4gKiAtIFRoZSBmbGFnIG5hbWVzIGFyZSBhbHdheXMgdW5pcXVlLlxuICogLSBUaGUgbGVuZ3RoIG9mIHRoZSBhcnJheSBuZXZlciBleGNlZWRzIGBtYXhTaXplYC5cbiAqXG4gKiBAcGFyYW0gZmxhZ3MgICAgICBUaGUgYnVmZmVyIHRvIGluc2VydCB0aGUgZmxhZyBpbnRvLlxuICogQHBhcmFtIG5hbWUgICAgICAgTmFtZSBvZiB0aGUgZmVhdHVyZSBmbGFnIHRvIGluc2VydC5cbiAqIEBwYXJhbSB2YWx1ZSAgICAgIFZhbHVlIG9mIHRoZSBmZWF0dXJlIGZsYWcuXG4gKiBAcGFyYW0gbWF4U2l6ZSAgICBNYXggbnVtYmVyIG9mIGZsYWdzIHRoZSBidWZmZXIgc2hvdWxkIHN0b3JlLiBEZWZhdWx0IHZhbHVlIHNob3VsZCBhbHdheXMgYmUgdXNlZCBpbiBwcm9kdWN0aW9uLlxuICovXG5mdW5jdGlvbiBfSU5URVJOQUxfaW5zZXJ0VG9GbGFnQnVmZmVyKFxuICBmbGFncyxcbiAgbmFtZSxcbiAgdmFsdWUsXG4gIG1heFNpemUsXG4pIHtcbiAgaWYgKHR5cGVvZiB2YWx1ZSAhPT0gJ2Jvb2xlYW4nKSB7XG4gICAgcmV0dXJuO1xuICB9XG5cbiAgaWYgKGZsYWdzLmxlbmd0aCA+IG1heFNpemUpIHtcbiAgICBkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEICYmIGRlYnVnTG9nZ2VyLmRlYnVnLmVycm9yKGBbRmVhdHVyZSBGbGFnc10gaW5zZXJ0VG9GbGFnQnVmZmVyIGNhbGxlZCBvbiBhIGJ1ZmZlciBsYXJnZXIgdGhhbiBtYXhTaXplPSR7bWF4U2l6ZX1gKTtcbiAgICByZXR1cm47XG4gIH1cblxuICAvLyBDaGVjayBpZiB0aGUgZmxhZyBpcyBhbHJlYWR5IGluIHRoZSBidWZmZXIgLSBPKG4pXG4gIGNvbnN0IGluZGV4ID0gZmxhZ3MuZmluZEluZGV4KGYgPT4gZi5mbGFnID09PSBuYW1lKTtcblxuICBpZiAoaW5kZXggIT09IC0xKSB7XG4gICAgLy8gVGhlIGZsYWcgd2FzIGZvdW5kLCByZW1vdmUgaXQgZnJvbSBpdHMgY3VycmVudCBwb3NpdGlvbiAtIE8obilcbiAgICBmbGFncy5zcGxpY2UoaW5kZXgsIDEpO1xuICB9XG5cbiAgaWYgKGZsYWdzLmxlbmd0aCA9PT0gbWF4U2l6ZSkge1xuICAgIC8vIElmIGF0IGNhcGFjaXR5LCBwb3AgdGhlIGVhcmxpZXN0IGZsYWcgLSBPKG4pXG4gICAgZmxhZ3Muc2hpZnQoKTtcbiAgfVxuXG4gIC8vIFB1c2ggdGhlIGZsYWcgdG8gdGhlIGVuZCAtIE8oMSlcbiAgZmxhZ3MucHVzaCh7XG4gICAgZmxhZzogbmFtZSxcbiAgICByZXN1bHQ6IHZhbHVlLFxuICB9KTtcbn1cblxuLyoqXG4gKiBSZWNvcmRzIGEgZmVhdHVyZSBmbGFnIGV2YWx1YXRpb24gZm9yIHRoZSBhY3RpdmUgc3Bhbi4gVGhpcyBpcyBhIG5vLW9wIGZvciBub24tYm9vbGVhbiB2YWx1ZXMuXG4gKiBUaGUgZmxhZyBhbmQgaXRzIHZhbHVlIGlzIHN0b3JlZCBpbiBzcGFuIGF0dHJpYnV0ZXMgd2l0aCB0aGUgYGZsYWcuZXZhbHVhdGlvbmAgcHJlZml4LiBPbmNlIHRoZVxuICogdW5pcXVlIGZsYWdzIGZvciBhIHNwYW4gcmVhY2hlcyBtYXhGbGFnc1BlclNwYW4sIHN1YnNlcXVlbnQgZmxhZ3MgYXJlIGRyb3BwZWQuXG4gKlxuICogQHBhcmFtIG5hbWUgICAgICAgICAgICAgTmFtZSBvZiB0aGUgZmVhdHVyZSBmbGFnLlxuICogQHBhcmFtIHZhbHVlICAgICAgICAgICAgVmFsdWUgb2YgdGhlIGZlYXR1cmUgZmxhZy4gTm9uLWJvb2xlYW4gdmFsdWVzIGFyZSBpZ25vcmVkLlxuICogQHBhcmFtIG1heEZsYWdzUGVyU3BhbiAgTWF4IG51bWJlciBvZiBmbGFncyBhIGJ1ZmZlciBzaG91bGQgc3RvcmUuIERlZmF1bHQgdmFsdWUgc2hvdWxkIGFsd2F5cyBiZSB1c2VkIGluIHByb2R1Y3Rpb24uXG4gKi9cbmZ1bmN0aW9uIF9JTlRFUk5BTF9hZGRGZWF0dXJlRmxhZ1RvQWN0aXZlU3BhbihcbiAgbmFtZSxcbiAgdmFsdWUsXG4gIG1heEZsYWdzUGVyU3BhbiA9IF9JTlRFUk5BTF9NQVhfRkxBR1NfUEVSX1NQQU4sXG4pIHtcbiAgaWYgKHR5cGVvZiB2YWx1ZSAhPT0gJ2Jvb2xlYW4nKSB7XG4gICAgcmV0dXJuO1xuICB9XG5cbiAgY29uc3Qgc3BhbiA9IHNwYW5VdGlscy5nZXRBY3RpdmVTcGFuKCk7XG4gIGlmICghc3Bhbikge1xuICAgIHJldHVybjtcbiAgfVxuXG4gIGNvbnN0IGF0dHJpYnV0ZXMgPSBzcGFuVXRpbHMuc3BhblRvSlNPTihzcGFuKS5kYXRhO1xuXG4gIC8vIElmIHRoZSBmbGFnIGFscmVhZHkgZXhpc3RzLCBhbHdheXMgdXBkYXRlIGl0XG4gIGlmIChgJHtTUEFOX0ZMQUdfQVRUUklCVVRFX1BSRUZJWH0ke25hbWV9YCBpbiBhdHRyaWJ1dGVzKSB7XG4gICAgc3Bhbi5zZXRBdHRyaWJ1dGUoYCR7U1BBTl9GTEFHX0FUVFJJQlVURV9QUkVGSVh9JHtuYW1lfWAsIHZhbHVlKTtcbiAgICByZXR1cm47XG4gIH1cblxuICAvLyBFbHNlLCBhZGQgdGhlIGZsYWcgdG8gdGhlIHNwYW4gaWYgd2UgaGF2ZSBub3QgcmVhY2hlZCB0aGUgbWF4IG51bWJlciBvZiBmbGFnc1xuICBjb25zdCBudW1PZkFkZGVkRmxhZ3MgPSBPYmplY3Qua2V5cyhhdHRyaWJ1dGVzKS5maWx0ZXIoa2V5ID0+IGtleS5zdGFydHNXaXRoKFNQQU5fRkxBR19BVFRSSUJVVEVfUFJFRklYKSkubGVuZ3RoO1xuICBpZiAobnVtT2ZBZGRlZEZsYWdzIDwgbWF4RmxhZ3NQZXJTcGFuKSB7XG4gICAgc3Bhbi5zZXRBdHRyaWJ1dGUoYCR7U1BBTl9GTEFHX0FUVFJJQlVURV9QUkVGSVh9JHtuYW1lfWAsIHZhbHVlKTtcbiAgfVxufVxuXG5leHBvcnRzLl9JTlRFUk5BTF9GTEFHX0JVRkZFUl9TSVpFID0gX0lOVEVSTkFMX0ZMQUdfQlVGRkVSX1NJWkU7XG5leHBvcnRzLl9JTlRFUk5BTF9NQVhfRkxBR1NfUEVSX1NQQU4gPSBfSU5URVJOQUxfTUFYX0ZMQUdTX1BFUl9TUEFOO1xuZXhwb3J0cy5fSU5URVJOQUxfYWRkRmVhdHVyZUZsYWdUb0FjdGl2ZVNwYW4gPSBfSU5URVJOQUxfYWRkRmVhdHVyZUZsYWdUb0FjdGl2ZVNwYW47XG5leHBvcnRzLl9JTlRFUk5BTF9jb3B5RmxhZ3NGcm9tU2NvcGVUb0V2ZW50ID0gX0lOVEVSTkFMX2NvcHlGbGFnc0Zyb21TY29wZVRvRXZlbnQ7XG5leHBvcnRzLl9JTlRFUk5BTF9pbnNlcnRGbGFnVG9TY29wZSA9IF9JTlRFUk5BTF9pbnNlcnRGbGFnVG9TY29wZTtcbmV4cG9ydHMuX0lOVEVSTkFMX2luc2VydFRvRmxhZ0J1ZmZlciA9IF9JTlRFUk5BTF9pbnNlcnRUb0ZsYWdCdWZmZXI7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1mZWF0dXJlRmxhZ3MuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/featureFlags.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/flushIfServerless.js":
/*!***************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/flushIfServerless.js ***!
  \***************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst exports$1 = __webpack_require__(/*! ../exports.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/exports.js\");\nconst debugLogger = __webpack_require__(/*! ./debug-logger.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst vercelWaitUntil = __webpack_require__(/*! ./vercelWaitUntil.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/vercelWaitUntil.js\");\nconst worldwide = __webpack_require__(/*! ./worldwide.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/worldwide.js\");\n\nasync function flushWithTimeout(timeout) {\n  try {\n    debugLogger.debug.log('Flushing events...');\n    await exports$1.flush(timeout);\n    debugLogger.debug.log('Done flushing events');\n  } catch (e) {\n    debugLogger.debug.log('Error while flushing events:\\n', e);\n  }\n}\n\n/**\n *  Flushes the event queue with a timeout in serverless environments to ensure that events are sent to Sentry before the\n *  serverless function execution ends.\n *\n * The function is async, but in environments that support a `waitUntil` mechanism, it will run synchronously.\n *\n * This function is aware of the following serverless platforms:\n * - Cloudflare: If a Cloudflare context is provided, it will use `ctx.waitUntil()` to flush events (keeps the `this` context of `ctx`).\n *               If a `cloudflareWaitUntil` function is provided, it will use that to flush events (looses the `this` context of `ctx`).\n * - Vercel: It detects the Vercel environment and uses Vercel's `waitUntil` function.\n * - Other Serverless (AWS Lambda, Google Cloud, etc.): It detects the environment via environment variables\n *   and uses a regular `await flush()`.\n *\n *  @internal This function is supposed for internal Sentry SDK usage only.\n *  @hidden\n */\nasync function flushIfServerless(\n  params\n\n = {},\n) {\n  const { timeout = 2000 } = params;\n\n  if ('cloudflareWaitUntil' in params && typeof params?.cloudflareWaitUntil === 'function') {\n    params.cloudflareWaitUntil(flushWithTimeout(timeout));\n    return;\n  }\n\n  if ('cloudflareCtx' in params && typeof params.cloudflareCtx?.waitUntil === 'function') {\n    params.cloudflareCtx.waitUntil(flushWithTimeout(timeout));\n    return;\n  }\n\n  // @ts-expect-error This is not typed\n  if (worldwide.GLOBAL_OBJ[Symbol.for('@vercel/request-context')]) {\n    // Vercel has a waitUntil equivalent that works without execution context\n    vercelWaitUntil.vercelWaitUntil(flushWithTimeout(timeout));\n    return;\n  }\n\n  if (typeof process === 'undefined') {\n    return;\n  }\n\n  const isServerless =\n    !!process.env.FUNCTIONS_WORKER_RUNTIME || // Azure Functions\n    !!process.env.LAMBDA_TASK_ROOT || // AWS Lambda\n    !!process.env.K_SERVICE || // Google Cloud Run\n    !!process.env.CF_PAGES || // Cloudflare Pages\n    !!process.env.VERCEL ||\n    !!process.env.NETLIFY;\n\n  if (isServerless) {\n    // Use regular flush for environments without a generic waitUntil mechanism\n    await flushWithTimeout(timeout);\n  }\n}\n\nexports.flushIfServerless = flushIfServerless;\n//# sourceMappingURL=flushIfServerless.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvZmx1c2hJZlNlcnZlcmxlc3MuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsa0JBQWtCLG1CQUFPLENBQUMsMkhBQWU7QUFDekMsb0JBQW9CLG1CQUFPLENBQUMsMElBQW1CO0FBQy9DLHdCQUF3QixtQkFBTyxDQUFDLGdKQUFzQjtBQUN0RCxrQkFBa0IsbUJBQU8sQ0FBQyxvSUFBZ0I7O0FBRTFDO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxJQUFJO0FBQ0o7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSxLQUFLO0FBQ0w7QUFDQSxVQUFVLGlCQUFpQjs7QUFFM0I7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLHlCQUF5QjtBQUN6QiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3V0aWxzL2ZsdXNoSWZTZXJ2ZXJsZXNzLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBleHBvcnRzJDEgPSByZXF1aXJlKCcuLi9leHBvcnRzLmpzJyk7XG5jb25zdCBkZWJ1Z0xvZ2dlciA9IHJlcXVpcmUoJy4vZGVidWctbG9nZ2VyLmpzJyk7XG5jb25zdCB2ZXJjZWxXYWl0VW50aWwgPSByZXF1aXJlKCcuL3ZlcmNlbFdhaXRVbnRpbC5qcycpO1xuY29uc3Qgd29ybGR3aWRlID0gcmVxdWlyZSgnLi93b3JsZHdpZGUuanMnKTtcblxuYXN5bmMgZnVuY3Rpb24gZmx1c2hXaXRoVGltZW91dCh0aW1lb3V0KSB7XG4gIHRyeSB7XG4gICAgZGVidWdMb2dnZXIuZGVidWcubG9nKCdGbHVzaGluZyBldmVudHMuLi4nKTtcbiAgICBhd2FpdCBleHBvcnRzJDEuZmx1c2godGltZW91dCk7XG4gICAgZGVidWdMb2dnZXIuZGVidWcubG9nKCdEb25lIGZsdXNoaW5nIGV2ZW50cycpO1xuICB9IGNhdGNoIChlKSB7XG4gICAgZGVidWdMb2dnZXIuZGVidWcubG9nKCdFcnJvciB3aGlsZSBmbHVzaGluZyBldmVudHM6XFxuJywgZSk7XG4gIH1cbn1cblxuLyoqXG4gKiAgRmx1c2hlcyB0aGUgZXZlbnQgcXVldWUgd2l0aCBhIHRpbWVvdXQgaW4gc2VydmVybGVzcyBlbnZpcm9ubWVudHMgdG8gZW5zdXJlIHRoYXQgZXZlbnRzIGFyZSBzZW50IHRvIFNlbnRyeSBiZWZvcmUgdGhlXG4gKiAgc2VydmVybGVzcyBmdW5jdGlvbiBleGVjdXRpb24gZW5kcy5cbiAqXG4gKiBUaGUgZnVuY3Rpb24gaXMgYXN5bmMsIGJ1dCBpbiBlbnZpcm9ubWVudHMgdGhhdCBzdXBwb3J0IGEgYHdhaXRVbnRpbGAgbWVjaGFuaXNtLCBpdCB3aWxsIHJ1biBzeW5jaHJvbm91c2x5LlxuICpcbiAqIFRoaXMgZnVuY3Rpb24gaXMgYXdhcmUgb2YgdGhlIGZvbGxvd2luZyBzZXJ2ZXJsZXNzIHBsYXRmb3JtczpcbiAqIC0gQ2xvdWRmbGFyZTogSWYgYSBDbG91ZGZsYXJlIGNvbnRleHQgaXMgcHJvdmlkZWQsIGl0IHdpbGwgdXNlIGBjdHgud2FpdFVudGlsKClgIHRvIGZsdXNoIGV2ZW50cyAoa2VlcHMgdGhlIGB0aGlzYCBjb250ZXh0IG9mIGBjdHhgKS5cbiAqICAgICAgICAgICAgICAgSWYgYSBgY2xvdWRmbGFyZVdhaXRVbnRpbGAgZnVuY3Rpb24gaXMgcHJvdmlkZWQsIGl0IHdpbGwgdXNlIHRoYXQgdG8gZmx1c2ggZXZlbnRzIChsb29zZXMgdGhlIGB0aGlzYCBjb250ZXh0IG9mIGBjdHhgKS5cbiAqIC0gVmVyY2VsOiBJdCBkZXRlY3RzIHRoZSBWZXJjZWwgZW52aXJvbm1lbnQgYW5kIHVzZXMgVmVyY2VsJ3MgYHdhaXRVbnRpbGAgZnVuY3Rpb24uXG4gKiAtIE90aGVyIFNlcnZlcmxlc3MgKEFXUyBMYW1iZGEsIEdvb2dsZSBDbG91ZCwgZXRjLik6IEl0IGRldGVjdHMgdGhlIGVudmlyb25tZW50IHZpYSBlbnZpcm9ubWVudCB2YXJpYWJsZXNcbiAqICAgYW5kIHVzZXMgYSByZWd1bGFyIGBhd2FpdCBmbHVzaCgpYC5cbiAqXG4gKiAgQGludGVybmFsIFRoaXMgZnVuY3Rpb24gaXMgc3VwcG9zZWQgZm9yIGludGVybmFsIFNlbnRyeSBTREsgdXNhZ2Ugb25seS5cbiAqICBAaGlkZGVuXG4gKi9cbmFzeW5jIGZ1bmN0aW9uIGZsdXNoSWZTZXJ2ZXJsZXNzKFxuICBwYXJhbXNcblxuID0ge30sXG4pIHtcbiAgY29uc3QgeyB0aW1lb3V0ID0gMjAwMCB9ID0gcGFyYW1zO1xuXG4gIGlmICgnY2xvdWRmbGFyZVdhaXRVbnRpbCcgaW4gcGFyYW1zICYmIHR5cGVvZiBwYXJhbXM/LmNsb3VkZmxhcmVXYWl0VW50aWwgPT09ICdmdW5jdGlvbicpIHtcbiAgICBwYXJhbXMuY2xvdWRmbGFyZVdhaXRVbnRpbChmbHVzaFdpdGhUaW1lb3V0KHRpbWVvdXQpKTtcbiAgICByZXR1cm47XG4gIH1cblxuICBpZiAoJ2Nsb3VkZmxhcmVDdHgnIGluIHBhcmFtcyAmJiB0eXBlb2YgcGFyYW1zLmNsb3VkZmxhcmVDdHg/LndhaXRVbnRpbCA9PT0gJ2Z1bmN0aW9uJykge1xuICAgIHBhcmFtcy5jbG91ZGZsYXJlQ3R4LndhaXRVbnRpbChmbHVzaFdpdGhUaW1lb3V0KHRpbWVvdXQpKTtcbiAgICByZXR1cm47XG4gIH1cblxuICAvLyBAdHMtZXhwZWN0LWVycm9yIFRoaXMgaXMgbm90IHR5cGVkXG4gIGlmICh3b3JsZHdpZGUuR0xPQkFMX09CSltTeW1ib2wuZm9yKCdAdmVyY2VsL3JlcXVlc3QtY29udGV4dCcpXSkge1xuICAgIC8vIFZlcmNlbCBoYXMgYSB3YWl0VW50aWwgZXF1aXZhbGVudCB0aGF0IHdvcmtzIHdpdGhvdXQgZXhlY3V0aW9uIGNvbnRleHRcbiAgICB2ZXJjZWxXYWl0VW50aWwudmVyY2VsV2FpdFVudGlsKGZsdXNoV2l0aFRpbWVvdXQodGltZW91dCkpO1xuICAgIHJldHVybjtcbiAgfVxuXG4gIGlmICh0eXBlb2YgcHJvY2VzcyA9PT0gJ3VuZGVmaW5lZCcpIHtcbiAgICByZXR1cm47XG4gIH1cblxuICBjb25zdCBpc1NlcnZlcmxlc3MgPVxuICAgICEhcHJvY2Vzcy5lbnYuRlVOQ1RJT05TX1dPUktFUl9SVU5USU1FIHx8IC8vIEF6dXJlIEZ1bmN0aW9uc1xuICAgICEhcHJvY2Vzcy5lbnYuTEFNQkRBX1RBU0tfUk9PVCB8fCAvLyBBV1MgTGFtYmRhXG4gICAgISFwcm9jZXNzLmVudi5LX1NFUlZJQ0UgfHwgLy8gR29vZ2xlIENsb3VkIFJ1blxuICAgICEhcHJvY2Vzcy5lbnYuQ0ZfUEFHRVMgfHwgLy8gQ2xvdWRmbGFyZSBQYWdlc1xuICAgICEhcHJvY2Vzcy5lbnYuVkVSQ0VMIHx8XG4gICAgISFwcm9jZXNzLmVudi5ORVRMSUZZO1xuXG4gIGlmIChpc1NlcnZlcmxlc3MpIHtcbiAgICAvLyBVc2UgcmVndWxhciBmbHVzaCBmb3IgZW52aXJvbm1lbnRzIHdpdGhvdXQgYSBnZW5lcmljIHdhaXRVbnRpbCBtZWNoYW5pc21cbiAgICBhd2FpdCBmbHVzaFdpdGhUaW1lb3V0KHRpbWVvdXQpO1xuICB9XG59XG5cbmV4cG9ydHMuZmx1c2hJZlNlcnZlcmxlc3MgPSBmbHVzaElmU2VydmVybGVzcztcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWZsdXNoSWZTZXJ2ZXJsZXNzLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/flushIfServerless.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/gen-ai-attributes.js":
/*!***************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/gen-ai-attributes.js ***!
  \***************************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n/**\n * OpenAI Integration Telemetry Attributes\n * Based on OpenTelemetry Semantic Conventions for Generative AI\n * @see https://opentelemetry.io/docs/specs/semconv/gen-ai/\n */\n\n// =============================================================================\n// OPENTELEMETRY SEMANTIC CONVENTIONS FOR GENAI\n// =============================================================================\n\n/**\n * The Generative AI system being used\n * For OpenAI, this should always be \"openai\"\n */\nconst GEN_AI_SYSTEM_ATTRIBUTE = 'gen_ai.system';\n\n/**\n * The name of the model as requested\n * Examples: \"gpt-4\", \"gpt-3.5-turbo\"\n */\nconst GEN_AI_REQUEST_MODEL_ATTRIBUTE = 'gen_ai.request.model';\n\n/**\n * The temperature setting for the model request\n */\nconst GEN_AI_REQUEST_TEMPERATURE_ATTRIBUTE = 'gen_ai.request.temperature';\n\n/**\n * The frequency penalty setting for the model request\n */\nconst GEN_AI_REQUEST_FREQUENCY_PENALTY_ATTRIBUTE = 'gen_ai.request.frequency_penalty';\n\n/**\n * The presence penalty setting for the model request\n */\nconst GEN_AI_REQUEST_PRESENCE_PENALTY_ATTRIBUTE = 'gen_ai.request.presence_penalty';\n\n/**\n * The top_p (nucleus sampling) setting for the model request\n */\nconst GEN_AI_REQUEST_TOP_P_ATTRIBUTE = 'gen_ai.request.top_p';\n\n/**\n * Array of reasons why the model stopped generating tokens\n */\nconst GEN_AI_RESPONSE_FINISH_REASONS_ATTRIBUTE = 'gen_ai.response.finish_reasons';\n\n/**\n * The name of the model that generated the response\n */\nconst GEN_AI_RESPONSE_MODEL_ATTRIBUTE = 'gen_ai.response.model';\n\n/**\n * The unique identifier for the response\n */\nconst GEN_AI_RESPONSE_ID_ATTRIBUTE = 'gen_ai.response.id';\n\n/**\n * The number of tokens used in the prompt\n */\nconst GEN_AI_USAGE_INPUT_TOKENS_ATTRIBUTE = 'gen_ai.usage.input_tokens';\n\n/**\n * The number of tokens used in the response\n */\nconst GEN_AI_USAGE_OUTPUT_TOKENS_ATTRIBUTE = 'gen_ai.usage.output_tokens';\n\n/**\n * The total number of tokens used (input + output)\n */\nconst GEN_AI_USAGE_TOTAL_TOKENS_ATTRIBUTE = 'gen_ai.usage.total_tokens';\n\n/**\n * The operation name for OpenAI API calls\n */\nconst GEN_AI_OPERATION_NAME_ATTRIBUTE = 'gen_ai.operation.name';\n\n/**\n * The prompt messages sent to OpenAI (stringified JSON)\n * Only recorded when recordInputs is enabled\n */\nconst GEN_AI_REQUEST_MESSAGES_ATTRIBUTE = 'gen_ai.request.messages';\n\n/**\n * The response text from OpenAI (stringified JSON array)\n * Only recorded when recordOutputs is enabled\n */\nconst GEN_AI_RESPONSE_TEXT_ATTRIBUTE = 'gen_ai.response.text';\n\n// =============================================================================\n// OPENAI-SPECIFIC ATTRIBUTES\n// =============================================================================\n\n/**\n * The response ID from OpenAI\n */\nconst OPENAI_RESPONSE_ID_ATTRIBUTE = 'openai.response.id';\n\n/**\n * The response model from OpenAI\n */\nconst OPENAI_RESPONSE_MODEL_ATTRIBUTE = 'openai.response.model';\n\n/**\n * The response timestamp from OpenAI (ISO string)\n */\nconst OPENAI_RESPONSE_TIMESTAMP_ATTRIBUTE = 'openai.response.timestamp';\n\n/**\n * The number of completion tokens used (OpenAI specific)\n */\nconst OPENAI_USAGE_COMPLETION_TOKENS_ATTRIBUTE = 'openai.usage.completion_tokens';\n\n/**\n * The number of prompt tokens used (OpenAI specific)\n */\nconst OPENAI_USAGE_PROMPT_TOKENS_ATTRIBUTE = 'openai.usage.prompt_tokens';\n\n// =============================================================================\n// OPENAI OPERATIONS\n// =============================================================================\n\n/**\n * OpenAI API operations\n */\nconst OPENAI_OPERATIONS = {\n  CHAT: 'chat',\n} ;\n\nexports.GEN_AI_OPERATION_NAME_ATTRIBUTE = GEN_AI_OPERATION_NAME_ATTRIBUTE;\nexports.GEN_AI_REQUEST_FREQUENCY_PENALTY_ATTRIBUTE = GEN_AI_REQUEST_FREQUENCY_PENALTY_ATTRIBUTE;\nexports.GEN_AI_REQUEST_MESSAGES_ATTRIBUTE = GEN_AI_REQUEST_MESSAGES_ATTRIBUTE;\nexports.GEN_AI_REQUEST_MODEL_ATTRIBUTE = GEN_AI_REQUEST_MODEL_ATTRIBUTE;\nexports.GEN_AI_REQUEST_PRESENCE_PENALTY_ATTRIBUTE = GEN_AI_REQUEST_PRESENCE_PENALTY_ATTRIBUTE;\nexports.GEN_AI_REQUEST_TEMPERATURE_ATTRIBUTE = GEN_AI_REQUEST_TEMPERATURE_ATTRIBUTE;\nexports.GEN_AI_REQUEST_TOP_P_ATTRIBUTE = GEN_AI_REQUEST_TOP_P_ATTRIBUTE;\nexports.GEN_AI_RESPONSE_FINISH_REASONS_ATTRIBUTE = GEN_AI_RESPONSE_FINISH_REASONS_ATTRIBUTE;\nexports.GEN_AI_RESPONSE_ID_ATTRIBUTE = GEN_AI_RESPONSE_ID_ATTRIBUTE;\nexports.GEN_AI_RESPONSE_MODEL_ATTRIBUTE = GEN_AI_RESPONSE_MODEL_ATTRIBUTE;\nexports.GEN_AI_RESPONSE_TEXT_ATTRIBUTE = GEN_AI_RESPONSE_TEXT_ATTRIBUTE;\nexports.GEN_AI_SYSTEM_ATTRIBUTE = GEN_AI_SYSTEM_ATTRIBUTE;\nexports.GEN_AI_USAGE_INPUT_TOKENS_ATTRIBUTE = GEN_AI_USAGE_INPUT_TOKENS_ATTRIBUTE;\nexports.GEN_AI_USAGE_OUTPUT_TOKENS_ATTRIBUTE = GEN_AI_USAGE_OUTPUT_TOKENS_ATTRIBUTE;\nexports.GEN_AI_USAGE_TOTAL_TOKENS_ATTRIBUTE = GEN_AI_USAGE_TOTAL_TOKENS_ATTRIBUTE;\nexports.OPENAI_OPERATIONS = OPENAI_OPERATIONS;\nexports.OPENAI_RESPONSE_ID_ATTRIBUTE = OPENAI_RESPONSE_ID_ATTRIBUTE;\nexports.OPENAI_RESPONSE_MODEL_ATTRIBUTE = OPENAI_RESPONSE_MODEL_ATTRIBUTE;\nexports.OPENAI_RESPONSE_TIMESTAMP_ATTRIBUTE = OPENAI_RESPONSE_TIMESTAMP_ATTRIBUTE;\nexports.OPENAI_USAGE_COMPLETION_TOKENS_ATTRIBUTE = OPENAI_USAGE_COMPLETION_TOKENS_ATTRIBUTE;\nexports.OPENAI_USAGE_PROMPT_TOKENS_ATTRIBUTE = OPENAI_USAGE_PROMPT_TOKENS_ATTRIBUTE;\n//# sourceMappingURL=gen-ai-attributes.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvZ2VuLWFpLWF0dHJpYnV0ZXMuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEU7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSx1Q0FBdUM7QUFDdkMsa0RBQWtEO0FBQ2xELHlDQUF5QztBQUN6QyxzQ0FBc0M7QUFDdEMsaURBQWlEO0FBQ2pELDRDQUE0QztBQUM1QyxzQ0FBc0M7QUFDdEMsZ0RBQWdEO0FBQ2hELG9DQUFvQztBQUNwQyx1Q0FBdUM7QUFDdkMsc0NBQXNDO0FBQ3RDLCtCQUErQjtBQUMvQiwyQ0FBMkM7QUFDM0MsNENBQTRDO0FBQzVDLDJDQUEyQztBQUMzQyx5QkFBeUI7QUFDekIsb0NBQW9DO0FBQ3BDLHVDQUF1QztBQUN2QywyQ0FBMkM7QUFDM0MsZ0RBQWdEO0FBQ2hELDRDQUE0QztBQUM1QyIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3V0aWxzL2dlbi1haS1hdHRyaWJ1dGVzLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG4vKipcbiAqIE9wZW5BSSBJbnRlZ3JhdGlvbiBUZWxlbWV0cnkgQXR0cmlidXRlc1xuICogQmFzZWQgb24gT3BlblRlbGVtZXRyeSBTZW1hbnRpYyBDb252ZW50aW9ucyBmb3IgR2VuZXJhdGl2ZSBBSVxuICogQHNlZSBodHRwczovL29wZW50ZWxlbWV0cnkuaW8vZG9jcy9zcGVjcy9zZW1jb252L2dlbi1haS9cbiAqL1xuXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuLy8gT1BFTlRFTEVNRVRSWSBTRU1BTlRJQyBDT05WRU5USU9OUyBGT1IgR0VOQUlcbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG5cbi8qKlxuICogVGhlIEdlbmVyYXRpdmUgQUkgc3lzdGVtIGJlaW5nIHVzZWRcbiAqIEZvciBPcGVuQUksIHRoaXMgc2hvdWxkIGFsd2F5cyBiZSBcIm9wZW5haVwiXG4gKi9cbmNvbnN0IEdFTl9BSV9TWVNURU1fQVRUUklCVVRFID0gJ2dlbl9haS5zeXN0ZW0nO1xuXG4vKipcbiAqIFRoZSBuYW1lIG9mIHRoZSBtb2RlbCBhcyByZXF1ZXN0ZWRcbiAqIEV4YW1wbGVzOiBcImdwdC00XCIsIFwiZ3B0LTMuNS10dXJib1wiXG4gKi9cbmNvbnN0IEdFTl9BSV9SRVFVRVNUX01PREVMX0FUVFJJQlVURSA9ICdnZW5fYWkucmVxdWVzdC5tb2RlbCc7XG5cbi8qKlxuICogVGhlIHRlbXBlcmF0dXJlIHNldHRpbmcgZm9yIHRoZSBtb2RlbCByZXF1ZXN0XG4gKi9cbmNvbnN0IEdFTl9BSV9SRVFVRVNUX1RFTVBFUkFUVVJFX0FUVFJJQlVURSA9ICdnZW5fYWkucmVxdWVzdC50ZW1wZXJhdHVyZSc7XG5cbi8qKlxuICogVGhlIGZyZXF1ZW5jeSBwZW5hbHR5IHNldHRpbmcgZm9yIHRoZSBtb2RlbCByZXF1ZXN0XG4gKi9cbmNvbnN0IEdFTl9BSV9SRVFVRVNUX0ZSRVFVRU5DWV9QRU5BTFRZX0FUVFJJQlVURSA9ICdnZW5fYWkucmVxdWVzdC5mcmVxdWVuY3lfcGVuYWx0eSc7XG5cbi8qKlxuICogVGhlIHByZXNlbmNlIHBlbmFsdHkgc2V0dGluZyBmb3IgdGhlIG1vZGVsIHJlcXVlc3RcbiAqL1xuY29uc3QgR0VOX0FJX1JFUVVFU1RfUFJFU0VOQ0VfUEVOQUxUWV9BVFRSSUJVVEUgPSAnZ2VuX2FpLnJlcXVlc3QucHJlc2VuY2VfcGVuYWx0eSc7XG5cbi8qKlxuICogVGhlIHRvcF9wIChudWNsZXVzIHNhbXBsaW5nKSBzZXR0aW5nIGZvciB0aGUgbW9kZWwgcmVxdWVzdFxuICovXG5jb25zdCBHRU5fQUlfUkVRVUVTVF9UT1BfUF9BVFRSSUJVVEUgPSAnZ2VuX2FpLnJlcXVlc3QudG9wX3AnO1xuXG4vKipcbiAqIEFycmF5IG9mIHJlYXNvbnMgd2h5IHRoZSBtb2RlbCBzdG9wcGVkIGdlbmVyYXRpbmcgdG9rZW5zXG4gKi9cbmNvbnN0IEdFTl9BSV9SRVNQT05TRV9GSU5JU0hfUkVBU09OU19BVFRSSUJVVEUgPSAnZ2VuX2FpLnJlc3BvbnNlLmZpbmlzaF9yZWFzb25zJztcblxuLyoqXG4gKiBUaGUgbmFtZSBvZiB0aGUgbW9kZWwgdGhhdCBnZW5lcmF0ZWQgdGhlIHJlc3BvbnNlXG4gKi9cbmNvbnN0IEdFTl9BSV9SRVNQT05TRV9NT0RFTF9BVFRSSUJVVEUgPSAnZ2VuX2FpLnJlc3BvbnNlLm1vZGVsJztcblxuLyoqXG4gKiBUaGUgdW5pcXVlIGlkZW50aWZpZXIgZm9yIHRoZSByZXNwb25zZVxuICovXG5jb25zdCBHRU5fQUlfUkVTUE9OU0VfSURfQVRUUklCVVRFID0gJ2dlbl9haS5yZXNwb25zZS5pZCc7XG5cbi8qKlxuICogVGhlIG51bWJlciBvZiB0b2tlbnMgdXNlZCBpbiB0aGUgcHJvbXB0XG4gKi9cbmNvbnN0IEdFTl9BSV9VU0FHRV9JTlBVVF9UT0tFTlNfQVRUUklCVVRFID0gJ2dlbl9haS51c2FnZS5pbnB1dF90b2tlbnMnO1xuXG4vKipcbiAqIFRoZSBudW1iZXIgb2YgdG9rZW5zIHVzZWQgaW4gdGhlIHJlc3BvbnNlXG4gKi9cbmNvbnN0IEdFTl9BSV9VU0FHRV9PVVRQVVRfVE9LRU5TX0FUVFJJQlVURSA9ICdnZW5fYWkudXNhZ2Uub3V0cHV0X3Rva2Vucyc7XG5cbi8qKlxuICogVGhlIHRvdGFsIG51bWJlciBvZiB0b2tlbnMgdXNlZCAoaW5wdXQgKyBvdXRwdXQpXG4gKi9cbmNvbnN0IEdFTl9BSV9VU0FHRV9UT1RBTF9UT0tFTlNfQVRUUklCVVRFID0gJ2dlbl9haS51c2FnZS50b3RhbF90b2tlbnMnO1xuXG4vKipcbiAqIFRoZSBvcGVyYXRpb24gbmFtZSBmb3IgT3BlbkFJIEFQSSBjYWxsc1xuICovXG5jb25zdCBHRU5fQUlfT1BFUkFUSU9OX05BTUVfQVRUUklCVVRFID0gJ2dlbl9haS5vcGVyYXRpb24ubmFtZSc7XG5cbi8qKlxuICogVGhlIHByb21wdCBtZXNzYWdlcyBzZW50IHRvIE9wZW5BSSAoc3RyaW5naWZpZWQgSlNPTilcbiAqIE9ubHkgcmVjb3JkZWQgd2hlbiByZWNvcmRJbnB1dHMgaXMgZW5hYmxlZFxuICovXG5jb25zdCBHRU5fQUlfUkVRVUVTVF9NRVNTQUdFU19BVFRSSUJVVEUgPSAnZ2VuX2FpLnJlcXVlc3QubWVzc2FnZXMnO1xuXG4vKipcbiAqIFRoZSByZXNwb25zZSB0ZXh0IGZyb20gT3BlbkFJIChzdHJpbmdpZmllZCBKU09OIGFycmF5KVxuICogT25seSByZWNvcmRlZCB3aGVuIHJlY29yZE91dHB1dHMgaXMgZW5hYmxlZFxuICovXG5jb25zdCBHRU5fQUlfUkVTUE9OU0VfVEVYVF9BVFRSSUJVVEUgPSAnZ2VuX2FpLnJlc3BvbnNlLnRleHQnO1xuXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuLy8gT1BFTkFJLVNQRUNJRklDIEFUVFJJQlVURVNcbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG5cbi8qKlxuICogVGhlIHJlc3BvbnNlIElEIGZyb20gT3BlbkFJXG4gKi9cbmNvbnN0IE9QRU5BSV9SRVNQT05TRV9JRF9BVFRSSUJVVEUgPSAnb3BlbmFpLnJlc3BvbnNlLmlkJztcblxuLyoqXG4gKiBUaGUgcmVzcG9uc2UgbW9kZWwgZnJvbSBPcGVuQUlcbiAqL1xuY29uc3QgT1BFTkFJX1JFU1BPTlNFX01PREVMX0FUVFJJQlVURSA9ICdvcGVuYWkucmVzcG9uc2UubW9kZWwnO1xuXG4vKipcbiAqIFRoZSByZXNwb25zZSB0aW1lc3RhbXAgZnJvbSBPcGVuQUkgKElTTyBzdHJpbmcpXG4gKi9cbmNvbnN0IE9QRU5BSV9SRVNQT05TRV9USU1FU1RBTVBfQVRUUklCVVRFID0gJ29wZW5haS5yZXNwb25zZS50aW1lc3RhbXAnO1xuXG4vKipcbiAqIFRoZSBudW1iZXIgb2YgY29tcGxldGlvbiB0b2tlbnMgdXNlZCAoT3BlbkFJIHNwZWNpZmljKVxuICovXG5jb25zdCBPUEVOQUlfVVNBR0VfQ09NUExFVElPTl9UT0tFTlNfQVRUUklCVVRFID0gJ29wZW5haS51c2FnZS5jb21wbGV0aW9uX3Rva2Vucyc7XG5cbi8qKlxuICogVGhlIG51bWJlciBvZiBwcm9tcHQgdG9rZW5zIHVzZWQgKE9wZW5BSSBzcGVjaWZpYylcbiAqL1xuY29uc3QgT1BFTkFJX1VTQUdFX1BST01QVF9UT0tFTlNfQVRUUklCVVRFID0gJ29wZW5haS51c2FnZS5wcm9tcHRfdG9rZW5zJztcblxuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cbi8vIE9QRU5BSSBPUEVSQVRJT05TXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuXG4vKipcbiAqIE9wZW5BSSBBUEkgb3BlcmF0aW9uc1xuICovXG5jb25zdCBPUEVOQUlfT1BFUkFUSU9OUyA9IHtcbiAgQ0hBVDogJ2NoYXQnLFxufSA7XG5cbmV4cG9ydHMuR0VOX0FJX09QRVJBVElPTl9OQU1FX0FUVFJJQlVURSA9IEdFTl9BSV9PUEVSQVRJT05fTkFNRV9BVFRSSUJVVEU7XG5leHBvcnRzLkdFTl9BSV9SRVFVRVNUX0ZSRVFVRU5DWV9QRU5BTFRZX0FUVFJJQlVURSA9IEdFTl9BSV9SRVFVRVNUX0ZSRVFVRU5DWV9QRU5BTFRZX0FUVFJJQlVURTtcbmV4cG9ydHMuR0VOX0FJX1JFUVVFU1RfTUVTU0FHRVNfQVRUUklCVVRFID0gR0VOX0FJX1JFUVVFU1RfTUVTU0FHRVNfQVRUUklCVVRFO1xuZXhwb3J0cy5HRU5fQUlfUkVRVUVTVF9NT0RFTF9BVFRSSUJVVEUgPSBHRU5fQUlfUkVRVUVTVF9NT0RFTF9BVFRSSUJVVEU7XG5leHBvcnRzLkdFTl9BSV9SRVFVRVNUX1BSRVNFTkNFX1BFTkFMVFlfQVRUUklCVVRFID0gR0VOX0FJX1JFUVVFU1RfUFJFU0VOQ0VfUEVOQUxUWV9BVFRSSUJVVEU7XG5leHBvcnRzLkdFTl9BSV9SRVFVRVNUX1RFTVBFUkFUVVJFX0FUVFJJQlVURSA9IEdFTl9BSV9SRVFVRVNUX1RFTVBFUkFUVVJFX0FUVFJJQlVURTtcbmV4cG9ydHMuR0VOX0FJX1JFUVVFU1RfVE9QX1BfQVRUUklCVVRFID0gR0VOX0FJX1JFUVVFU1RfVE9QX1BfQVRUUklCVVRFO1xuZXhwb3J0cy5HRU5fQUlfUkVTUE9OU0VfRklOSVNIX1JFQVNPTlNfQVRUUklCVVRFID0gR0VOX0FJX1JFU1BPTlNFX0ZJTklTSF9SRUFTT05TX0FUVFJJQlVURTtcbmV4cG9ydHMuR0VOX0FJX1JFU1BPTlNFX0lEX0FUVFJJQlVURSA9IEdFTl9BSV9SRVNQT05TRV9JRF9BVFRSSUJVVEU7XG5leHBvcnRzLkdFTl9BSV9SRVNQT05TRV9NT0RFTF9BVFRSSUJVVEUgPSBHRU5fQUlfUkVTUE9OU0VfTU9ERUxfQVRUUklCVVRFO1xuZXhwb3J0cy5HRU5fQUlfUkVTUE9OU0VfVEVYVF9BVFRSSUJVVEUgPSBHRU5fQUlfUkVTUE9OU0VfVEVYVF9BVFRSSUJVVEU7XG5leHBvcnRzLkdFTl9BSV9TWVNURU1fQVRUUklCVVRFID0gR0VOX0FJX1NZU1RFTV9BVFRSSUJVVEU7XG5leHBvcnRzLkdFTl9BSV9VU0FHRV9JTlBVVF9UT0tFTlNfQVRUUklCVVRFID0gR0VOX0FJX1VTQUdFX0lOUFVUX1RPS0VOU19BVFRSSUJVVEU7XG5leHBvcnRzLkdFTl9BSV9VU0FHRV9PVVRQVVRfVE9LRU5TX0FUVFJJQlVURSA9IEdFTl9BSV9VU0FHRV9PVVRQVVRfVE9LRU5TX0FUVFJJQlVURTtcbmV4cG9ydHMuR0VOX0FJX1VTQUdFX1RPVEFMX1RPS0VOU19BVFRSSUJVVEUgPSBHRU5fQUlfVVNBR0VfVE9UQUxfVE9LRU5TX0FUVFJJQlVURTtcbmV4cG9ydHMuT1BFTkFJX09QRVJBVElPTlMgPSBPUEVOQUlfT1BFUkFUSU9OUztcbmV4cG9ydHMuT1BFTkFJX1JFU1BPTlNFX0lEX0FUVFJJQlVURSA9IE9QRU5BSV9SRVNQT05TRV9JRF9BVFRSSUJVVEU7XG5leHBvcnRzLk9QRU5BSV9SRVNQT05TRV9NT0RFTF9BVFRSSUJVVEUgPSBPUEVOQUlfUkVTUE9OU0VfTU9ERUxfQVRUUklCVVRFO1xuZXhwb3J0cy5PUEVOQUlfUkVTUE9OU0VfVElNRVNUQU1QX0FUVFJJQlVURSA9IE9QRU5BSV9SRVNQT05TRV9USU1FU1RBTVBfQVRUUklCVVRFO1xuZXhwb3J0cy5PUEVOQUlfVVNBR0VfQ09NUExFVElPTl9UT0tFTlNfQVRUUklCVVRFID0gT1BFTkFJX1VTQUdFX0NPTVBMRVRJT05fVE9LRU5TX0FUVFJJQlVURTtcbmV4cG9ydHMuT1BFTkFJX1VTQUdFX1BST01QVF9UT0tFTlNfQVRUUklCVVRFID0gT1BFTkFJX1VTQUdFX1BST01QVF9UT0tFTlNfQVRUUklCVVRFO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9Z2VuLWFpLWF0dHJpYnV0ZXMuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/gen-ai-attributes.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/handleCallbackErrors.js":
/*!******************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/handleCallbackErrors.js ***!
  \******************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst is = __webpack_require__(/*! ./is.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js\");\n\n/**\n * Wrap a callback function with error handling.\n * If an error is thrown, it will be passed to the `onError` callback and re-thrown.\n *\n * If the return value of the function is a promise, it will be handled with `maybeHandlePromiseRejection`.\n *\n * If an `onFinally` callback is provided, this will be called when the callback has finished\n * - so if it returns a promise, once the promise resolved/rejected,\n * else once the callback has finished executing.\n * The `onFinally` callback will _always_ be called, no matter if an error was thrown or not.\n */\nfunction handleCallbackErrors\n\n(fn, onError, onFinally = () => {}) {\n  let maybePromiseResult;\n  try {\n    maybePromiseResult = fn();\n  } catch (e) {\n    onError(e);\n    onFinally();\n    throw e;\n  }\n\n  return maybeHandlePromiseRejection(maybePromiseResult, onError, onFinally);\n}\n\n/**\n * Maybe handle a promise rejection.\n * This expects to be given a value that _may_ be a promise, or any other value.\n * If it is a promise, and it rejects, it will call the `onError` callback.\n * Other than this, it will generally return the given value as-is.\n */\nfunction maybeHandlePromiseRejection(\n  value,\n  onError,\n  onFinally,\n) {\n  if (is.isThenable(value)) {\n    // @ts-expect-error - the isThenable check returns the \"wrong\" type here\n    return value.then(\n      res => {\n        onFinally();\n        return res;\n      },\n      e => {\n        onError(e);\n        onFinally();\n        throw e;\n      },\n    );\n  }\n\n  onFinally();\n  return value;\n}\n\nexports.handleCallbackErrors = handleCallbackErrors;\n//# sourceMappingURL=handleCallbackErrors.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvaGFuZGxlQ2FsbGJhY2tFcnJvcnMuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsV0FBVyxtQkFBTyxDQUFDLHNIQUFTOztBQUU1QjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsa0NBQWtDO0FBQ2xDO0FBQ0E7QUFDQTtBQUNBLElBQUk7QUFDSjtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxPQUFPO0FBQ1A7QUFDQTtBQUNBO0FBQ0E7QUFDQSxPQUFPO0FBQ1A7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUEsNEJBQTRCO0FBQzVCIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvaGFuZGxlQ2FsbGJhY2tFcnJvcnMuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGlzID0gcmVxdWlyZSgnLi9pcy5qcycpO1xuXG4vKipcbiAqIFdyYXAgYSBjYWxsYmFjayBmdW5jdGlvbiB3aXRoIGVycm9yIGhhbmRsaW5nLlxuICogSWYgYW4gZXJyb3IgaXMgdGhyb3duLCBpdCB3aWxsIGJlIHBhc3NlZCB0byB0aGUgYG9uRXJyb3JgIGNhbGxiYWNrIGFuZCByZS10aHJvd24uXG4gKlxuICogSWYgdGhlIHJldHVybiB2YWx1ZSBvZiB0aGUgZnVuY3Rpb24gaXMgYSBwcm9taXNlLCBpdCB3aWxsIGJlIGhhbmRsZWQgd2l0aCBgbWF5YmVIYW5kbGVQcm9taXNlUmVqZWN0aW9uYC5cbiAqXG4gKiBJZiBhbiBgb25GaW5hbGx5YCBjYWxsYmFjayBpcyBwcm92aWRlZCwgdGhpcyB3aWxsIGJlIGNhbGxlZCB3aGVuIHRoZSBjYWxsYmFjayBoYXMgZmluaXNoZWRcbiAqIC0gc28gaWYgaXQgcmV0dXJucyBhIHByb21pc2UsIG9uY2UgdGhlIHByb21pc2UgcmVzb2x2ZWQvcmVqZWN0ZWQsXG4gKiBlbHNlIG9uY2UgdGhlIGNhbGxiYWNrIGhhcyBmaW5pc2hlZCBleGVjdXRpbmcuXG4gKiBUaGUgYG9uRmluYWxseWAgY2FsbGJhY2sgd2lsbCBfYWx3YXlzXyBiZSBjYWxsZWQsIG5vIG1hdHRlciBpZiBhbiBlcnJvciB3YXMgdGhyb3duIG9yIG5vdC5cbiAqL1xuZnVuY3Rpb24gaGFuZGxlQ2FsbGJhY2tFcnJvcnNcblxuKGZuLCBvbkVycm9yLCBvbkZpbmFsbHkgPSAoKSA9PiB7fSkge1xuICBsZXQgbWF5YmVQcm9taXNlUmVzdWx0O1xuICB0cnkge1xuICAgIG1heWJlUHJvbWlzZVJlc3VsdCA9IGZuKCk7XG4gIH0gY2F0Y2ggKGUpIHtcbiAgICBvbkVycm9yKGUpO1xuICAgIG9uRmluYWxseSgpO1xuICAgIHRocm93IGU7XG4gIH1cblxuICByZXR1cm4gbWF5YmVIYW5kbGVQcm9taXNlUmVqZWN0aW9uKG1heWJlUHJvbWlzZVJlc3VsdCwgb25FcnJvciwgb25GaW5hbGx5KTtcbn1cblxuLyoqXG4gKiBNYXliZSBoYW5kbGUgYSBwcm9taXNlIHJlamVjdGlvbi5cbiAqIFRoaXMgZXhwZWN0cyB0byBiZSBnaXZlbiBhIHZhbHVlIHRoYXQgX21heV8gYmUgYSBwcm9taXNlLCBvciBhbnkgb3RoZXIgdmFsdWUuXG4gKiBJZiBpdCBpcyBhIHByb21pc2UsIGFuZCBpdCByZWplY3RzLCBpdCB3aWxsIGNhbGwgdGhlIGBvbkVycm9yYCBjYWxsYmFjay5cbiAqIE90aGVyIHRoYW4gdGhpcywgaXQgd2lsbCBnZW5lcmFsbHkgcmV0dXJuIHRoZSBnaXZlbiB2YWx1ZSBhcy1pcy5cbiAqL1xuZnVuY3Rpb24gbWF5YmVIYW5kbGVQcm9taXNlUmVqZWN0aW9uKFxuICB2YWx1ZSxcbiAgb25FcnJvcixcbiAgb25GaW5hbGx5LFxuKSB7XG4gIGlmIChpcy5pc1RoZW5hYmxlKHZhbHVlKSkge1xuICAgIC8vIEB0cy1leHBlY3QtZXJyb3IgLSB0aGUgaXNUaGVuYWJsZSBjaGVjayByZXR1cm5zIHRoZSBcIndyb25nXCIgdHlwZSBoZXJlXG4gICAgcmV0dXJuIHZhbHVlLnRoZW4oXG4gICAgICByZXMgPT4ge1xuICAgICAgICBvbkZpbmFsbHkoKTtcbiAgICAgICAgcmV0dXJuIHJlcztcbiAgICAgIH0sXG4gICAgICBlID0+IHtcbiAgICAgICAgb25FcnJvcihlKTtcbiAgICAgICAgb25GaW5hbGx5KCk7XG4gICAgICAgIHRocm93IGU7XG4gICAgICB9LFxuICAgICk7XG4gIH1cblxuICBvbkZpbmFsbHkoKTtcbiAgcmV0dXJuIHZhbHVlO1xufVxuXG5leHBvcnRzLmhhbmRsZUNhbGxiYWNrRXJyb3JzID0gaGFuZGxlQ2FsbGJhY2tFcnJvcnM7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1oYW5kbGVDYWxsYmFja0Vycm9ycy5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/handleCallbackErrors.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/hasSpansEnabled.js":
/*!*************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/hasSpansEnabled.js ***!
  \*************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst currentScopes = __webpack_require__(/*! ../currentScopes.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\n\n// Treeshakable guard to remove all code related to tracing\n\n/**\n * Determines if span recording is currently enabled.\n *\n * Spans are recorded when at least one of `tracesSampleRate` and `tracesSampler`\n * is defined in the SDK config. This function does not make any assumption about\n * sampling decisions, it only checks if the SDK is configured to record spans.\n *\n * Important: This function only determines if span recording is enabled. Trace\n * continuation and propagation is separately controlled and not covered by this function.\n * If this function returns `false`, traces can still be propagated (which is what\n * we refer to by \"Tracing without Performance\")\n * @see https://develop.sentry.dev/sdk/telemetry/traces/tracing-without-performance/\n *\n * @param maybeOptions An SDK options object to be passed to this function.\n * If this option is not provided, the function will use the current client's options.\n */\nfunction hasSpansEnabled(\n  maybeOptions,\n) {\n  if (typeof __SENTRY_TRACING__ === 'boolean' && !__SENTRY_TRACING__) {\n    return false;\n  }\n\n  const options = maybeOptions || currentScopes.getClient()?.getOptions();\n  return (\n    !!options &&\n    // Note: This check is `!= null`, meaning \"nullish\". `0` is not \"nullish\", `undefined` and `null` are. (This comment was brought to you by 15 minutes of questioning life)\n    (options.tracesSampleRate != null || !!options.tracesSampler)\n  );\n}\n\n/**\n * @see JSDoc of `hasSpansEnabled`\n * @deprecated Use `hasSpansEnabled` instead, which is a more accurately named version of this function.\n * This function will be removed in the next major version of the SDK.\n */\n// TODO(v10): Remove this export\nconst hasTracingEnabled = hasSpansEnabled;\n\nexports.hasSpansEnabled = hasSpansEnabled;\nexports.hasTracingEnabled = hasTracingEnabled;\n//# sourceMappingURL=hasSpansEnabled.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvaGFzU3BhbnNFbmFibGVkLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLHNCQUFzQixtQkFBTyxDQUFDLHVJQUFxQjs7QUFFbkQ7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsdUJBQXVCO0FBQ3ZCLHlCQUF5QjtBQUN6QiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3V0aWxzL2hhc1NwYW5zRW5hYmxlZC5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgY3VycmVudFNjb3BlcyA9IHJlcXVpcmUoJy4uL2N1cnJlbnRTY29wZXMuanMnKTtcblxuLy8gVHJlZXNoYWthYmxlIGd1YXJkIHRvIHJlbW92ZSBhbGwgY29kZSByZWxhdGVkIHRvIHRyYWNpbmdcblxuLyoqXG4gKiBEZXRlcm1pbmVzIGlmIHNwYW4gcmVjb3JkaW5nIGlzIGN1cnJlbnRseSBlbmFibGVkLlxuICpcbiAqIFNwYW5zIGFyZSByZWNvcmRlZCB3aGVuIGF0IGxlYXN0IG9uZSBvZiBgdHJhY2VzU2FtcGxlUmF0ZWAgYW5kIGB0cmFjZXNTYW1wbGVyYFxuICogaXMgZGVmaW5lZCBpbiB0aGUgU0RLIGNvbmZpZy4gVGhpcyBmdW5jdGlvbiBkb2VzIG5vdCBtYWtlIGFueSBhc3N1bXB0aW9uIGFib3V0XG4gKiBzYW1wbGluZyBkZWNpc2lvbnMsIGl0IG9ubHkgY2hlY2tzIGlmIHRoZSBTREsgaXMgY29uZmlndXJlZCB0byByZWNvcmQgc3BhbnMuXG4gKlxuICogSW1wb3J0YW50OiBUaGlzIGZ1bmN0aW9uIG9ubHkgZGV0ZXJtaW5lcyBpZiBzcGFuIHJlY29yZGluZyBpcyBlbmFibGVkLiBUcmFjZVxuICogY29udGludWF0aW9uIGFuZCBwcm9wYWdhdGlvbiBpcyBzZXBhcmF0ZWx5IGNvbnRyb2xsZWQgYW5kIG5vdCBjb3ZlcmVkIGJ5IHRoaXMgZnVuY3Rpb24uXG4gKiBJZiB0aGlzIGZ1bmN0aW9uIHJldHVybnMgYGZhbHNlYCwgdHJhY2VzIGNhbiBzdGlsbCBiZSBwcm9wYWdhdGVkICh3aGljaCBpcyB3aGF0XG4gKiB3ZSByZWZlciB0byBieSBcIlRyYWNpbmcgd2l0aG91dCBQZXJmb3JtYW5jZVwiKVxuICogQHNlZSBodHRwczovL2RldmVsb3Auc2VudHJ5LmRldi9zZGsvdGVsZW1ldHJ5L3RyYWNlcy90cmFjaW5nLXdpdGhvdXQtcGVyZm9ybWFuY2UvXG4gKlxuICogQHBhcmFtIG1heWJlT3B0aW9ucyBBbiBTREsgb3B0aW9ucyBvYmplY3QgdG8gYmUgcGFzc2VkIHRvIHRoaXMgZnVuY3Rpb24uXG4gKiBJZiB0aGlzIG9wdGlvbiBpcyBub3QgcHJvdmlkZWQsIHRoZSBmdW5jdGlvbiB3aWxsIHVzZSB0aGUgY3VycmVudCBjbGllbnQncyBvcHRpb25zLlxuICovXG5mdW5jdGlvbiBoYXNTcGFuc0VuYWJsZWQoXG4gIG1heWJlT3B0aW9ucyxcbikge1xuICBpZiAodHlwZW9mIF9fU0VOVFJZX1RSQUNJTkdfXyA9PT0gJ2Jvb2xlYW4nICYmICFfX1NFTlRSWV9UUkFDSU5HX18pIHtcbiAgICByZXR1cm4gZmFsc2U7XG4gIH1cblxuICBjb25zdCBvcHRpb25zID0gbWF5YmVPcHRpb25zIHx8IGN1cnJlbnRTY29wZXMuZ2V0Q2xpZW50KCk/LmdldE9wdGlvbnMoKTtcbiAgcmV0dXJuIChcbiAgICAhIW9wdGlvbnMgJiZcbiAgICAvLyBOb3RlOiBUaGlzIGNoZWNrIGlzIGAhPSBudWxsYCwgbWVhbmluZyBcIm51bGxpc2hcIi4gYDBgIGlzIG5vdCBcIm51bGxpc2hcIiwgYHVuZGVmaW5lZGAgYW5kIGBudWxsYCBhcmUuIChUaGlzIGNvbW1lbnQgd2FzIGJyb3VnaHQgdG8geW91IGJ5IDE1IG1pbnV0ZXMgb2YgcXVlc3Rpb25pbmcgbGlmZSlcbiAgICAob3B0aW9ucy50cmFjZXNTYW1wbGVSYXRlICE9IG51bGwgfHwgISFvcHRpb25zLnRyYWNlc1NhbXBsZXIpXG4gICk7XG59XG5cbi8qKlxuICogQHNlZSBKU0RvYyBvZiBgaGFzU3BhbnNFbmFibGVkYFxuICogQGRlcHJlY2F0ZWQgVXNlIGBoYXNTcGFuc0VuYWJsZWRgIGluc3RlYWQsIHdoaWNoIGlzIGEgbW9yZSBhY2N1cmF0ZWx5IG5hbWVkIHZlcnNpb24gb2YgdGhpcyBmdW5jdGlvbi5cbiAqIFRoaXMgZnVuY3Rpb24gd2lsbCBiZSByZW1vdmVkIGluIHRoZSBuZXh0IG1ham9yIHZlcnNpb24gb2YgdGhlIFNESy5cbiAqL1xuLy8gVE9ETyh2MTApOiBSZW1vdmUgdGhpcyBleHBvcnRcbmNvbnN0IGhhc1RyYWNpbmdFbmFibGVkID0gaGFzU3BhbnNFbmFibGVkO1xuXG5leHBvcnRzLmhhc1NwYW5zRW5hYmxlZCA9IGhhc1NwYW5zRW5hYmxlZDtcbmV4cG9ydHMuaGFzVHJhY2luZ0VuYWJsZWQgPSBoYXNUcmFjaW5nRW5hYmxlZDtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWhhc1NwYW5zRW5hYmxlZC5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/hasSpansEnabled.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/ipAddress.js":
/*!*******************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/ipAddress.js ***!
  \*******************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n// By default, we want to infer the IP address, unless this is explicitly set to `null`\n// We do this after all other processing is done\n// If `ip_address` is explicitly set to `null` or a value, we leave it as is\n\n/**\n * @internal\n */\nfunction addAutoIpAddressToUser(objWithMaybeUser) {\n  if (objWithMaybeUser.user?.ip_address === undefined) {\n    objWithMaybeUser.user = {\n      ...objWithMaybeUser.user,\n      ip_address: '{{auto}}',\n    };\n  }\n}\n\n/**\n * @internal\n */\nfunction addAutoIpAddressToSession(session) {\n  if ('aggregates' in session) {\n    if (session.attrs?.['ip_address'] === undefined) {\n      session.attrs = {\n        ...session.attrs,\n        ip_address: '{{auto}}',\n      };\n    }\n  } else {\n    if (session.ipAddress === undefined) {\n      session.ipAddress = '{{auto}}';\n    }\n  }\n}\n\nexports.addAutoIpAddressToSession = addAutoIpAddressToSession;\nexports.addAutoIpAddressToUser = addAutoIpAddressToUser;\n//# sourceMappingURL=ipAddress.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvaXBBZGRyZXNzLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLHFCQUFxQixNQUFNO0FBQzNCO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsdUJBQXVCLE1BQU07QUFDN0I7QUFDQTtBQUNBLElBQUk7QUFDSjtBQUNBLDZCQUE2QixNQUFNO0FBQ25DO0FBQ0E7QUFDQTs7QUFFQSxpQ0FBaUM7QUFDakMsOEJBQThCO0FBQzlCIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvaXBBZGRyZXNzLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG4vLyBCeSBkZWZhdWx0LCB3ZSB3YW50IHRvIGluZmVyIHRoZSBJUCBhZGRyZXNzLCB1bmxlc3MgdGhpcyBpcyBleHBsaWNpdGx5IHNldCB0byBgbnVsbGBcbi8vIFdlIGRvIHRoaXMgYWZ0ZXIgYWxsIG90aGVyIHByb2Nlc3NpbmcgaXMgZG9uZVxuLy8gSWYgYGlwX2FkZHJlc3NgIGlzIGV4cGxpY2l0bHkgc2V0IHRvIGBudWxsYCBvciBhIHZhbHVlLCB3ZSBsZWF2ZSBpdCBhcyBpc1xuXG4vKipcbiAqIEBpbnRlcm5hbFxuICovXG5mdW5jdGlvbiBhZGRBdXRvSXBBZGRyZXNzVG9Vc2VyKG9ialdpdGhNYXliZVVzZXIpIHtcbiAgaWYgKG9ialdpdGhNYXliZVVzZXIudXNlcj8uaXBfYWRkcmVzcyA9PT0gdW5kZWZpbmVkKSB7XG4gICAgb2JqV2l0aE1heWJlVXNlci51c2VyID0ge1xuICAgICAgLi4ub2JqV2l0aE1heWJlVXNlci51c2VyLFxuICAgICAgaXBfYWRkcmVzczogJ3t7YXV0b319JyxcbiAgICB9O1xuICB9XG59XG5cbi8qKlxuICogQGludGVybmFsXG4gKi9cbmZ1bmN0aW9uIGFkZEF1dG9JcEFkZHJlc3NUb1Nlc3Npb24oc2Vzc2lvbikge1xuICBpZiAoJ2FnZ3JlZ2F0ZXMnIGluIHNlc3Npb24pIHtcbiAgICBpZiAoc2Vzc2lvbi5hdHRycz8uWydpcF9hZGRyZXNzJ10gPT09IHVuZGVmaW5lZCkge1xuICAgICAgc2Vzc2lvbi5hdHRycyA9IHtcbiAgICAgICAgLi4uc2Vzc2lvbi5hdHRycyxcbiAgICAgICAgaXBfYWRkcmVzczogJ3t7YXV0b319JyxcbiAgICAgIH07XG4gICAgfVxuICB9IGVsc2Uge1xuICAgIGlmIChzZXNzaW9uLmlwQWRkcmVzcyA9PT0gdW5kZWZpbmVkKSB7XG4gICAgICBzZXNzaW9uLmlwQWRkcmVzcyA9ICd7e2F1dG99fSc7XG4gICAgfVxuICB9XG59XG5cbmV4cG9ydHMuYWRkQXV0b0lwQWRkcmVzc1RvU2Vzc2lvbiA9IGFkZEF1dG9JcEFkZHJlc3NUb1Nlc3Npb247XG5leHBvcnRzLmFkZEF1dG9JcEFkZHJlc3NUb1VzZXIgPSBhZGRBdXRvSXBBZGRyZXNzVG9Vc2VyO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9aXBBZGRyZXNzLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/ipAddress.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js":
/*!************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js ***!
  \************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n// eslint-disable-next-line @typescript-eslint/unbound-method\nconst objectToString = Object.prototype.toString;\n\n/**\n * Checks whether given value's type is one of a few Error or Error-like\n * {@link isError}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isError(wat) {\n  switch (objectToString.call(wat)) {\n    case '[object Error]':\n    case '[object Exception]':\n    case '[object DOMException]':\n    case '[object WebAssembly.Exception]':\n      return true;\n    default:\n      return isInstanceOf(wat, Error);\n  }\n}\n/**\n * Checks whether given value is an instance of the given built-in class.\n *\n * @param wat The value to be checked\n * @param className\n * @returns A boolean representing the result.\n */\nfunction isBuiltin(wat, className) {\n  return objectToString.call(wat) === `[object ${className}]`;\n}\n\n/**\n * Checks whether given value's type is ErrorEvent\n * {@link isErrorEvent}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isErrorEvent(wat) {\n  return isBuiltin(wat, 'ErrorEvent');\n}\n\n/**\n * Checks whether given value's type is DOMError\n * {@link isDOMError}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isDOMError(wat) {\n  return isBuiltin(wat, 'DOMError');\n}\n\n/**\n * Checks whether given value's type is DOMException\n * {@link isDOMException}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isDOMException(wat) {\n  return isBuiltin(wat, 'DOMException');\n}\n\n/**\n * Checks whether given value's type is a string\n * {@link isString}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isString(wat) {\n  return isBuiltin(wat, 'String');\n}\n\n/**\n * Checks whether given string is parameterized\n * {@link isParameterizedString}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isParameterizedString(wat) {\n  return (\n    typeof wat === 'object' &&\n    wat !== null &&\n    '__sentry_template_string__' in wat &&\n    '__sentry_template_values__' in wat\n  );\n}\n\n/**\n * Checks whether given value is a primitive (undefined, null, number, boolean, string, bigint, symbol)\n * {@link isPrimitive}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isPrimitive(wat) {\n  return wat === null || isParameterizedString(wat) || (typeof wat !== 'object' && typeof wat !== 'function');\n}\n\n/**\n * Checks whether given value's type is an object literal, or a class instance.\n * {@link isPlainObject}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isPlainObject(wat) {\n  return isBuiltin(wat, 'Object');\n}\n\n/**\n * Checks whether given value's type is an Event instance\n * {@link isEvent}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isEvent(wat) {\n  return typeof Event !== 'undefined' && isInstanceOf(wat, Event);\n}\n\n/**\n * Checks whether given value's type is an Element instance\n * {@link isElement}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isElement(wat) {\n  return typeof Element !== 'undefined' && isInstanceOf(wat, Element);\n}\n\n/**\n * Checks whether given value's type is an regexp\n * {@link isRegExp}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isRegExp(wat) {\n  return isBuiltin(wat, 'RegExp');\n}\n\n/**\n * Checks whether given value has a then function.\n * @param wat A value to be checked.\n */\nfunction isThenable(wat) {\n  // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n  return Boolean(wat?.then && typeof wat.then === 'function');\n}\n\n/**\n * Checks whether given value's type is a SyntheticEvent\n * {@link isSyntheticEvent}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isSyntheticEvent(wat) {\n  return isPlainObject(wat) && 'nativeEvent' in wat && 'preventDefault' in wat && 'stopPropagation' in wat;\n}\n\n/**\n * Checks whether given value's type is an instance of provided constructor.\n * {@link isInstanceOf}.\n *\n * @param wat A value to be checked.\n * @param base A constructor to be used in a check.\n * @returns A boolean representing the result.\n */\nfunction isInstanceOf(wat, base) {\n  try {\n    return wat instanceof base;\n  } catch {\n    return false;\n  }\n}\n\n/**\n * Checks whether given value's type is a Vue ViewModel.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isVueViewModel(wat) {\n  // Not using Object.prototype.toString because in Vue 3 it would read the instance's Symbol(Symbol.toStringTag) property.\n  return !!(typeof wat === 'object' && wat !== null && ((wat ).__isVue || (wat )._isVue));\n}\n\n/**\n * Checks whether the given parameter is a Standard Web API Request instance.\n *\n * Returns false if Request is not available in the current runtime.\n */\nfunction isRequest(request) {\n  return typeof Request !== 'undefined' && isInstanceOf(request, Request);\n}\n\nexports.isDOMError = isDOMError;\nexports.isDOMException = isDOMException;\nexports.isElement = isElement;\nexports.isError = isError;\nexports.isErrorEvent = isErrorEvent;\nexports.isEvent = isEvent;\nexports.isInstanceOf = isInstanceOf;\nexports.isParameterizedString = isParameterizedString;\nexports.isPlainObject = isPlainObject;\nexports.isPrimitive = isPrimitive;\nexports.isRegExp = isRegExp;\nexports.isRequest = isRequest;\nexports.isString = isString;\nexports.isSyntheticEvent = isSyntheticEvent;\nexports.isThenable = isThenable;\nexports.isVueViewModel = isVueViewModel;\n//# sourceMappingURL=is.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvaXMuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEU7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsSUFBSSxjQUFjO0FBQ2xCO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxpREFBaUQsVUFBVTtBQUMzRDs7QUFFQTtBQUNBO0FBQ0EsSUFBSSxtQkFBbUI7QUFDdkI7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLElBQUksaUJBQWlCO0FBQ3JCO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQSxJQUFJLHFCQUFxQjtBQUN6QjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsSUFBSSxlQUFlO0FBQ25CO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQSxJQUFJLDRCQUE0QjtBQUNoQztBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLElBQUksa0JBQWtCO0FBQ3RCO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQSxJQUFJLG9CQUFvQjtBQUN4QjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsSUFBSSxjQUFjO0FBQ2xCO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQSxJQUFJLGdCQUFnQjtBQUNwQjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsSUFBSSxlQUFlO0FBQ25CO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLElBQUksdUJBQXVCO0FBQzNCO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQSxJQUFJLG1CQUFtQjtBQUN2QjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsSUFBSTtBQUNKO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLGtCQUFrQjtBQUNsQixzQkFBc0I7QUFDdEIsaUJBQWlCO0FBQ2pCLGVBQWU7QUFDZixvQkFBb0I7QUFDcEIsZUFBZTtBQUNmLG9CQUFvQjtBQUNwQiw2QkFBNkI7QUFDN0IscUJBQXFCO0FBQ3JCLG1CQUFtQjtBQUNuQixnQkFBZ0I7QUFDaEIsaUJBQWlCO0FBQ2pCLGdCQUFnQjtBQUNoQix3QkFBd0I7QUFDeEIsa0JBQWtCO0FBQ2xCLHNCQUFzQjtBQUN0QiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3V0aWxzL2lzLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG4vLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L3VuYm91bmQtbWV0aG9kXG5jb25zdCBvYmplY3RUb1N0cmluZyA9IE9iamVjdC5wcm90b3R5cGUudG9TdHJpbmc7XG5cbi8qKlxuICogQ2hlY2tzIHdoZXRoZXIgZ2l2ZW4gdmFsdWUncyB0eXBlIGlzIG9uZSBvZiBhIGZldyBFcnJvciBvciBFcnJvci1saWtlXG4gKiB7QGxpbmsgaXNFcnJvcn0uXG4gKlxuICogQHBhcmFtIHdhdCBBIHZhbHVlIHRvIGJlIGNoZWNrZWQuXG4gKiBAcmV0dXJucyBBIGJvb2xlYW4gcmVwcmVzZW50aW5nIHRoZSByZXN1bHQuXG4gKi9cbmZ1bmN0aW9uIGlzRXJyb3Iod2F0KSB7XG4gIHN3aXRjaCAob2JqZWN0VG9TdHJpbmcuY2FsbCh3YXQpKSB7XG4gICAgY2FzZSAnW29iamVjdCBFcnJvcl0nOlxuICAgIGNhc2UgJ1tvYmplY3QgRXhjZXB0aW9uXSc6XG4gICAgY2FzZSAnW29iamVjdCBET01FeGNlcHRpb25dJzpcbiAgICBjYXNlICdbb2JqZWN0IFdlYkFzc2VtYmx5LkV4Y2VwdGlvbl0nOlxuICAgICAgcmV0dXJuIHRydWU7XG4gICAgZGVmYXVsdDpcbiAgICAgIHJldHVybiBpc0luc3RhbmNlT2Yod2F0LCBFcnJvcik7XG4gIH1cbn1cbi8qKlxuICogQ2hlY2tzIHdoZXRoZXIgZ2l2ZW4gdmFsdWUgaXMgYW4gaW5zdGFuY2Ugb2YgdGhlIGdpdmVuIGJ1aWx0LWluIGNsYXNzLlxuICpcbiAqIEBwYXJhbSB3YXQgVGhlIHZhbHVlIHRvIGJlIGNoZWNrZWRcbiAqIEBwYXJhbSBjbGFzc05hbWVcbiAqIEByZXR1cm5zIEEgYm9vbGVhbiByZXByZXNlbnRpbmcgdGhlIHJlc3VsdC5cbiAqL1xuZnVuY3Rpb24gaXNCdWlsdGluKHdhdCwgY2xhc3NOYW1lKSB7XG4gIHJldHVybiBvYmplY3RUb1N0cmluZy5jYWxsKHdhdCkgPT09IGBbb2JqZWN0ICR7Y2xhc3NOYW1lfV1gO1xufVxuXG4vKipcbiAqIENoZWNrcyB3aGV0aGVyIGdpdmVuIHZhbHVlJ3MgdHlwZSBpcyBFcnJvckV2ZW50XG4gKiB7QGxpbmsgaXNFcnJvckV2ZW50fS5cbiAqXG4gKiBAcGFyYW0gd2F0IEEgdmFsdWUgdG8gYmUgY2hlY2tlZC5cbiAqIEByZXR1cm5zIEEgYm9vbGVhbiByZXByZXNlbnRpbmcgdGhlIHJlc3VsdC5cbiAqL1xuZnVuY3Rpb24gaXNFcnJvckV2ZW50KHdhdCkge1xuICByZXR1cm4gaXNCdWlsdGluKHdhdCwgJ0Vycm9yRXZlbnQnKTtcbn1cblxuLyoqXG4gKiBDaGVja3Mgd2hldGhlciBnaXZlbiB2YWx1ZSdzIHR5cGUgaXMgRE9NRXJyb3JcbiAqIHtAbGluayBpc0RPTUVycm9yfS5cbiAqXG4gKiBAcGFyYW0gd2F0IEEgdmFsdWUgdG8gYmUgY2hlY2tlZC5cbiAqIEByZXR1cm5zIEEgYm9vbGVhbiByZXByZXNlbnRpbmcgdGhlIHJlc3VsdC5cbiAqL1xuZnVuY3Rpb24gaXNET01FcnJvcih3YXQpIHtcbiAgcmV0dXJuIGlzQnVpbHRpbih3YXQsICdET01FcnJvcicpO1xufVxuXG4vKipcbiAqIENoZWNrcyB3aGV0aGVyIGdpdmVuIHZhbHVlJ3MgdHlwZSBpcyBET01FeGNlcHRpb25cbiAqIHtAbGluayBpc0RPTUV4Y2VwdGlvbn0uXG4gKlxuICogQHBhcmFtIHdhdCBBIHZhbHVlIHRvIGJlIGNoZWNrZWQuXG4gKiBAcmV0dXJucyBBIGJvb2xlYW4gcmVwcmVzZW50aW5nIHRoZSByZXN1bHQuXG4gKi9cbmZ1bmN0aW9uIGlzRE9NRXhjZXB0aW9uKHdhdCkge1xuICByZXR1cm4gaXNCdWlsdGluKHdhdCwgJ0RPTUV4Y2VwdGlvbicpO1xufVxuXG4vKipcbiAqIENoZWNrcyB3aGV0aGVyIGdpdmVuIHZhbHVlJ3MgdHlwZSBpcyBhIHN0cmluZ1xuICoge0BsaW5rIGlzU3RyaW5nfS5cbiAqXG4gKiBAcGFyYW0gd2F0IEEgdmFsdWUgdG8gYmUgY2hlY2tlZC5cbiAqIEByZXR1cm5zIEEgYm9vbGVhbiByZXByZXNlbnRpbmcgdGhlIHJlc3VsdC5cbiAqL1xuZnVuY3Rpb24gaXNTdHJpbmcod2F0KSB7XG4gIHJldHVybiBpc0J1aWx0aW4od2F0LCAnU3RyaW5nJyk7XG59XG5cbi8qKlxuICogQ2hlY2tzIHdoZXRoZXIgZ2l2ZW4gc3RyaW5nIGlzIHBhcmFtZXRlcml6ZWRcbiAqIHtAbGluayBpc1BhcmFtZXRlcml6ZWRTdHJpbmd9LlxuICpcbiAqIEBwYXJhbSB3YXQgQSB2YWx1ZSB0byBiZSBjaGVja2VkLlxuICogQHJldHVybnMgQSBib29sZWFuIHJlcHJlc2VudGluZyB0aGUgcmVzdWx0LlxuICovXG5mdW5jdGlvbiBpc1BhcmFtZXRlcml6ZWRTdHJpbmcod2F0KSB7XG4gIHJldHVybiAoXG4gICAgdHlwZW9mIHdhdCA9PT0gJ29iamVjdCcgJiZcbiAgICB3YXQgIT09IG51bGwgJiZcbiAgICAnX19zZW50cnlfdGVtcGxhdGVfc3RyaW5nX18nIGluIHdhdCAmJlxuICAgICdfX3NlbnRyeV90ZW1wbGF0ZV92YWx1ZXNfXycgaW4gd2F0XG4gICk7XG59XG5cbi8qKlxuICogQ2hlY2tzIHdoZXRoZXIgZ2l2ZW4gdmFsdWUgaXMgYSBwcmltaXRpdmUgKHVuZGVmaW5lZCwgbnVsbCwgbnVtYmVyLCBib29sZWFuLCBzdHJpbmcsIGJpZ2ludCwgc3ltYm9sKVxuICoge0BsaW5rIGlzUHJpbWl0aXZlfS5cbiAqXG4gKiBAcGFyYW0gd2F0IEEgdmFsdWUgdG8gYmUgY2hlY2tlZC5cbiAqIEByZXR1cm5zIEEgYm9vbGVhbiByZXByZXNlbnRpbmcgdGhlIHJlc3VsdC5cbiAqL1xuZnVuY3Rpb24gaXNQcmltaXRpdmUod2F0KSB7XG4gIHJldHVybiB3YXQgPT09IG51bGwgfHwgaXNQYXJhbWV0ZXJpemVkU3RyaW5nKHdhdCkgfHwgKHR5cGVvZiB3YXQgIT09ICdvYmplY3QnICYmIHR5cGVvZiB3YXQgIT09ICdmdW5jdGlvbicpO1xufVxuXG4vKipcbiAqIENoZWNrcyB3aGV0aGVyIGdpdmVuIHZhbHVlJ3MgdHlwZSBpcyBhbiBvYmplY3QgbGl0ZXJhbCwgb3IgYSBjbGFzcyBpbnN0YW5jZS5cbiAqIHtAbGluayBpc1BsYWluT2JqZWN0fS5cbiAqXG4gKiBAcGFyYW0gd2F0IEEgdmFsdWUgdG8gYmUgY2hlY2tlZC5cbiAqIEByZXR1cm5zIEEgYm9vbGVhbiByZXByZXNlbnRpbmcgdGhlIHJlc3VsdC5cbiAqL1xuZnVuY3Rpb24gaXNQbGFpbk9iamVjdCh3YXQpIHtcbiAgcmV0dXJuIGlzQnVpbHRpbih3YXQsICdPYmplY3QnKTtcbn1cblxuLyoqXG4gKiBDaGVja3Mgd2hldGhlciBnaXZlbiB2YWx1ZSdzIHR5cGUgaXMgYW4gRXZlbnQgaW5zdGFuY2VcbiAqIHtAbGluayBpc0V2ZW50fS5cbiAqXG4gKiBAcGFyYW0gd2F0IEEgdmFsdWUgdG8gYmUgY2hlY2tlZC5cbiAqIEByZXR1cm5zIEEgYm9vbGVhbiByZXByZXNlbnRpbmcgdGhlIHJlc3VsdC5cbiAqL1xuZnVuY3Rpb24gaXNFdmVudCh3YXQpIHtcbiAgcmV0dXJuIHR5cGVvZiBFdmVudCAhPT0gJ3VuZGVmaW5lZCcgJiYgaXNJbnN0YW5jZU9mKHdhdCwgRXZlbnQpO1xufVxuXG4vKipcbiAqIENoZWNrcyB3aGV0aGVyIGdpdmVuIHZhbHVlJ3MgdHlwZSBpcyBhbiBFbGVtZW50IGluc3RhbmNlXG4gKiB7QGxpbmsgaXNFbGVtZW50fS5cbiAqXG4gKiBAcGFyYW0gd2F0IEEgdmFsdWUgdG8gYmUgY2hlY2tlZC5cbiAqIEByZXR1cm5zIEEgYm9vbGVhbiByZXByZXNlbnRpbmcgdGhlIHJlc3VsdC5cbiAqL1xuZnVuY3Rpb24gaXNFbGVtZW50KHdhdCkge1xuICByZXR1cm4gdHlwZW9mIEVsZW1lbnQgIT09ICd1bmRlZmluZWQnICYmIGlzSW5zdGFuY2VPZih3YXQsIEVsZW1lbnQpO1xufVxuXG4vKipcbiAqIENoZWNrcyB3aGV0aGVyIGdpdmVuIHZhbHVlJ3MgdHlwZSBpcyBhbiByZWdleHBcbiAqIHtAbGluayBpc1JlZ0V4cH0uXG4gKlxuICogQHBhcmFtIHdhdCBBIHZhbHVlIHRvIGJlIGNoZWNrZWQuXG4gKiBAcmV0dXJucyBBIGJvb2xlYW4gcmVwcmVzZW50aW5nIHRoZSByZXN1bHQuXG4gKi9cbmZ1bmN0aW9uIGlzUmVnRXhwKHdhdCkge1xuICByZXR1cm4gaXNCdWlsdGluKHdhdCwgJ1JlZ0V4cCcpO1xufVxuXG4vKipcbiAqIENoZWNrcyB3aGV0aGVyIGdpdmVuIHZhbHVlIGhhcyBhIHRoZW4gZnVuY3Rpb24uXG4gKiBAcGFyYW0gd2F0IEEgdmFsdWUgdG8gYmUgY2hlY2tlZC5cbiAqL1xuZnVuY3Rpb24gaXNUaGVuYWJsZSh3YXQpIHtcbiAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uby11bnNhZmUtbWVtYmVyLWFjY2Vzc1xuICByZXR1cm4gQm9vbGVhbih3YXQ/LnRoZW4gJiYgdHlwZW9mIHdhdC50aGVuID09PSAnZnVuY3Rpb24nKTtcbn1cblxuLyoqXG4gKiBDaGVja3Mgd2hldGhlciBnaXZlbiB2YWx1ZSdzIHR5cGUgaXMgYSBTeW50aGV0aWNFdmVudFxuICoge0BsaW5rIGlzU3ludGhldGljRXZlbnR9LlxuICpcbiAqIEBwYXJhbSB3YXQgQSB2YWx1ZSB0byBiZSBjaGVja2VkLlxuICogQHJldHVybnMgQSBib29sZWFuIHJlcHJlc2VudGluZyB0aGUgcmVzdWx0LlxuICovXG5mdW5jdGlvbiBpc1N5bnRoZXRpY0V2ZW50KHdhdCkge1xuICByZXR1cm4gaXNQbGFpbk9iamVjdCh3YXQpICYmICduYXRpdmVFdmVudCcgaW4gd2F0ICYmICdwcmV2ZW50RGVmYXVsdCcgaW4gd2F0ICYmICdzdG9wUHJvcGFnYXRpb24nIGluIHdhdDtcbn1cblxuLyoqXG4gKiBDaGVja3Mgd2hldGhlciBnaXZlbiB2YWx1ZSdzIHR5cGUgaXMgYW4gaW5zdGFuY2Ugb2YgcHJvdmlkZWQgY29uc3RydWN0b3IuXG4gKiB7QGxpbmsgaXNJbnN0YW5jZU9mfS5cbiAqXG4gKiBAcGFyYW0gd2F0IEEgdmFsdWUgdG8gYmUgY2hlY2tlZC5cbiAqIEBwYXJhbSBiYXNlIEEgY29uc3RydWN0b3IgdG8gYmUgdXNlZCBpbiBhIGNoZWNrLlxuICogQHJldHVybnMgQSBib29sZWFuIHJlcHJlc2VudGluZyB0aGUgcmVzdWx0LlxuICovXG5mdW5jdGlvbiBpc0luc3RhbmNlT2Yod2F0LCBiYXNlKSB7XG4gIHRyeSB7XG4gICAgcmV0dXJuIHdhdCBpbnN0YW5jZW9mIGJhc2U7XG4gIH0gY2F0Y2gge1xuICAgIHJldHVybiBmYWxzZTtcbiAgfVxufVxuXG4vKipcbiAqIENoZWNrcyB3aGV0aGVyIGdpdmVuIHZhbHVlJ3MgdHlwZSBpcyBhIFZ1ZSBWaWV3TW9kZWwuXG4gKlxuICogQHBhcmFtIHdhdCBBIHZhbHVlIHRvIGJlIGNoZWNrZWQuXG4gKiBAcmV0dXJucyBBIGJvb2xlYW4gcmVwcmVzZW50aW5nIHRoZSByZXN1bHQuXG4gKi9cbmZ1bmN0aW9uIGlzVnVlVmlld01vZGVsKHdhdCkge1xuICAvLyBOb3QgdXNpbmcgT2JqZWN0LnByb3RvdHlwZS50b1N0cmluZyBiZWNhdXNlIGluIFZ1ZSAzIGl0IHdvdWxkIHJlYWQgdGhlIGluc3RhbmNlJ3MgU3ltYm9sKFN5bWJvbC50b1N0cmluZ1RhZykgcHJvcGVydHkuXG4gIHJldHVybiAhISh0eXBlb2Ygd2F0ID09PSAnb2JqZWN0JyAmJiB3YXQgIT09IG51bGwgJiYgKCh3YXQgKS5fX2lzVnVlIHx8ICh3YXQgKS5faXNWdWUpKTtcbn1cblxuLyoqXG4gKiBDaGVja3Mgd2hldGhlciB0aGUgZ2l2ZW4gcGFyYW1ldGVyIGlzIGEgU3RhbmRhcmQgV2ViIEFQSSBSZXF1ZXN0IGluc3RhbmNlLlxuICpcbiAqIFJldHVybnMgZmFsc2UgaWYgUmVxdWVzdCBpcyBub3QgYXZhaWxhYmxlIGluIHRoZSBjdXJyZW50IHJ1bnRpbWUuXG4gKi9cbmZ1bmN0aW9uIGlzUmVxdWVzdChyZXF1ZXN0KSB7XG4gIHJldHVybiB0eXBlb2YgUmVxdWVzdCAhPT0gJ3VuZGVmaW5lZCcgJiYgaXNJbnN0YW5jZU9mKHJlcXVlc3QsIFJlcXVlc3QpO1xufVxuXG5leHBvcnRzLmlzRE9NRXJyb3IgPSBpc0RPTUVycm9yO1xuZXhwb3J0cy5pc0RPTUV4Y2VwdGlvbiA9IGlzRE9NRXhjZXB0aW9uO1xuZXhwb3J0cy5pc0VsZW1lbnQgPSBpc0VsZW1lbnQ7XG5leHBvcnRzLmlzRXJyb3IgPSBpc0Vycm9yO1xuZXhwb3J0cy5pc0Vycm9yRXZlbnQgPSBpc0Vycm9yRXZlbnQ7XG5leHBvcnRzLmlzRXZlbnQgPSBpc0V2ZW50O1xuZXhwb3J0cy5pc0luc3RhbmNlT2YgPSBpc0luc3RhbmNlT2Y7XG5leHBvcnRzLmlzUGFyYW1ldGVyaXplZFN0cmluZyA9IGlzUGFyYW1ldGVyaXplZFN0cmluZztcbmV4cG9ydHMuaXNQbGFpbk9iamVjdCA9IGlzUGxhaW5PYmplY3Q7XG5leHBvcnRzLmlzUHJpbWl0aXZlID0gaXNQcmltaXRpdmU7XG5leHBvcnRzLmlzUmVnRXhwID0gaXNSZWdFeHA7XG5leHBvcnRzLmlzUmVxdWVzdCA9IGlzUmVxdWVzdDtcbmV4cG9ydHMuaXNTdHJpbmcgPSBpc1N0cmluZztcbmV4cG9ydHMuaXNTeW50aGV0aWNFdmVudCA9IGlzU3ludGhldGljRXZlbnQ7XG5leHBvcnRzLmlzVGhlbmFibGUgPSBpc1RoZW5hYmxlO1xuZXhwb3J0cy5pc1Z1ZVZpZXdNb2RlbCA9IGlzVnVlVmlld01vZGVsO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9aXMuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/isBrowser.js":
/*!*******************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/isBrowser.js ***!
  \*******************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst node = __webpack_require__(/*! ./node.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/node.js\");\nconst worldwide = __webpack_require__(/*! ./worldwide.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/worldwide.js\");\n\n/**\n * Returns true if we are in the browser.\n */\nfunction isBrowser() {\n  // eslint-disable-next-line no-restricted-globals\n  return typeof window !== 'undefined' && (!node.isNodeEnv() || isElectronNodeRenderer());\n}\n\n// Electron renderers with nodeIntegration enabled are detected as Node.js so we specifically test for them\nfunction isElectronNodeRenderer() {\n  const process = (worldwide.GLOBAL_OBJ ).process;\n  return process?.type === 'renderer';\n}\n\nexports.isBrowser = isBrowser;\n//# sourceMappingURL=isBrowser.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvaXNCcm93c2VyLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLGFBQWEsbUJBQU8sQ0FBQywwSEFBVztBQUNoQyxrQkFBa0IsbUJBQU8sQ0FBQyxvSUFBZ0I7O0FBRTFDO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsaUJBQWlCO0FBQ2pCIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvaXNCcm93c2VyLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBub2RlID0gcmVxdWlyZSgnLi9ub2RlLmpzJyk7XG5jb25zdCB3b3JsZHdpZGUgPSByZXF1aXJlKCcuL3dvcmxkd2lkZS5qcycpO1xuXG4vKipcbiAqIFJldHVybnMgdHJ1ZSBpZiB3ZSBhcmUgaW4gdGhlIGJyb3dzZXIuXG4gKi9cbmZ1bmN0aW9uIGlzQnJvd3NlcigpIHtcbiAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIG5vLXJlc3RyaWN0ZWQtZ2xvYmFsc1xuICByZXR1cm4gdHlwZW9mIHdpbmRvdyAhPT0gJ3VuZGVmaW5lZCcgJiYgKCFub2RlLmlzTm9kZUVudigpIHx8IGlzRWxlY3Ryb25Ob2RlUmVuZGVyZXIoKSk7XG59XG5cbi8vIEVsZWN0cm9uIHJlbmRlcmVycyB3aXRoIG5vZGVJbnRlZ3JhdGlvbiBlbmFibGVkIGFyZSBkZXRlY3RlZCBhcyBOb2RlLmpzIHNvIHdlIHNwZWNpZmljYWxseSB0ZXN0IGZvciB0aGVtXG5mdW5jdGlvbiBpc0VsZWN0cm9uTm9kZVJlbmRlcmVyKCkge1xuICBjb25zdCBwcm9jZXNzID0gKHdvcmxkd2lkZS5HTE9CQUxfT0JKICkucHJvY2VzcztcbiAgcmV0dXJuIHByb2Nlc3M/LnR5cGUgPT09ICdyZW5kZXJlcic7XG59XG5cbmV4cG9ydHMuaXNCcm93c2VyID0gaXNCcm93c2VyO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9aXNCcm93c2VyLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/isBrowser.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/isSentryRequestUrl.js":
/*!****************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/isSentryRequestUrl.js ***!
  \****************************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n/**\n * Checks whether given url points to Sentry server\n *\n * @param url url to verify\n */\nfunction isSentryRequestUrl(url, client) {\n  const dsn = client?.getDsn();\n  const tunnel = client?.getOptions().tunnel;\n  return checkDsn(url, dsn) || checkTunnel(url, tunnel);\n}\n\nfunction checkTunnel(url, tunnel) {\n  if (!tunnel) {\n    return false;\n  }\n\n  return removeTrailingSlash(url) === removeTrailingSlash(tunnel);\n}\n\nfunction checkDsn(url, dsn) {\n  return dsn ? url.includes(dsn.host) : false;\n}\n\nfunction removeTrailingSlash(str) {\n  return str[str.length - 1] === '/' ? str.slice(0, -1) : str;\n}\n\nexports.isSentryRequestUrl = isSentryRequestUrl;\n//# sourceMappingURL=isSentryRequestUrl.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvaXNTZW50cnlSZXF1ZXN0VXJsLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQSwwQkFBMEI7QUFDMUIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9pc1NlbnRyeVJlcXVlc3RVcmwuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbi8qKlxuICogQ2hlY2tzIHdoZXRoZXIgZ2l2ZW4gdXJsIHBvaW50cyB0byBTZW50cnkgc2VydmVyXG4gKlxuICogQHBhcmFtIHVybCB1cmwgdG8gdmVyaWZ5XG4gKi9cbmZ1bmN0aW9uIGlzU2VudHJ5UmVxdWVzdFVybCh1cmwsIGNsaWVudCkge1xuICBjb25zdCBkc24gPSBjbGllbnQ/LmdldERzbigpO1xuICBjb25zdCB0dW5uZWwgPSBjbGllbnQ/LmdldE9wdGlvbnMoKS50dW5uZWw7XG4gIHJldHVybiBjaGVja0Rzbih1cmwsIGRzbikgfHwgY2hlY2tUdW5uZWwodXJsLCB0dW5uZWwpO1xufVxuXG5mdW5jdGlvbiBjaGVja1R1bm5lbCh1cmwsIHR1bm5lbCkge1xuICBpZiAoIXR1bm5lbCkge1xuICAgIHJldHVybiBmYWxzZTtcbiAgfVxuXG4gIHJldHVybiByZW1vdmVUcmFpbGluZ1NsYXNoKHVybCkgPT09IHJlbW92ZVRyYWlsaW5nU2xhc2godHVubmVsKTtcbn1cblxuZnVuY3Rpb24gY2hlY2tEc24odXJsLCBkc24pIHtcbiAgcmV0dXJuIGRzbiA/IHVybC5pbmNsdWRlcyhkc24uaG9zdCkgOiBmYWxzZTtcbn1cblxuZnVuY3Rpb24gcmVtb3ZlVHJhaWxpbmdTbGFzaChzdHIpIHtcbiAgcmV0dXJuIHN0cltzdHIubGVuZ3RoIC0gMV0gPT09ICcvJyA/IHN0ci5zbGljZSgwLCAtMSkgOiBzdHI7XG59XG5cbmV4cG9ydHMuaXNTZW50cnlSZXF1ZXN0VXJsID0gaXNTZW50cnlSZXF1ZXN0VXJsO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9aXNTZW50cnlSZXF1ZXN0VXJsLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/isSentryRequestUrl.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/lru.js":
/*!*************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/lru.js ***!
  \*************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n/** A simple Least Recently Used map */\nclass LRUMap {\n\n   constructor(  _maxSize) {this._maxSize = _maxSize;\n    this._cache = new Map();\n  }\n\n  /** Get the current size of the cache */\n   get size() {\n    return this._cache.size;\n  }\n\n  /** Get an entry or undefined if it was not in the cache. Re-inserts to update the recently used order */\n   get(key) {\n    const value = this._cache.get(key);\n    if (value === undefined) {\n      return undefined;\n    }\n    // Remove and re-insert to update the order\n    this._cache.delete(key);\n    this._cache.set(key, value);\n    return value;\n  }\n\n  /** Insert an entry and evict an older entry if we've reached maxSize */\n   set(key, value) {\n    if (this._cache.size >= this._maxSize) {\n      // keys() returns an iterator in insertion order so keys().next() gives us the oldest key\n      this._cache.delete(this._cache.keys().next().value);\n    }\n    this._cache.set(key, value);\n  }\n\n  /** Remove an entry and return the entry if it was in the cache */\n   remove(key) {\n    const value = this._cache.get(key);\n    if (value) {\n      this._cache.delete(key);\n    }\n    return value;\n  }\n\n  /** Clear all entries */\n   clear() {\n    this._cache.clear();\n  }\n\n  /** Get all the keys */\n   keys() {\n    return Array.from(this._cache.keys());\n  }\n\n  /** Get all the values */\n   values() {\n    const values = [];\n    this._cache.forEach(value => values.push(value));\n    return values;\n  }\n}\n\nexports.LRUMap = LRUMap;\n//# sourceMappingURL=lru.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvbHJ1LmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFO0FBQ0E7O0FBRUEsNEJBQTRCO0FBQzVCO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsY0FBYztBQUNkIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvbHJ1LmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG4vKiogQSBzaW1wbGUgTGVhc3QgUmVjZW50bHkgVXNlZCBtYXAgKi9cbmNsYXNzIExSVU1hcCB7XG5cbiAgIGNvbnN0cnVjdG9yKCAgX21heFNpemUpIHt0aGlzLl9tYXhTaXplID0gX21heFNpemU7XG4gICAgdGhpcy5fY2FjaGUgPSBuZXcgTWFwKCk7XG4gIH1cblxuICAvKiogR2V0IHRoZSBjdXJyZW50IHNpemUgb2YgdGhlIGNhY2hlICovXG4gICBnZXQgc2l6ZSgpIHtcbiAgICByZXR1cm4gdGhpcy5fY2FjaGUuc2l6ZTtcbiAgfVxuXG4gIC8qKiBHZXQgYW4gZW50cnkgb3IgdW5kZWZpbmVkIGlmIGl0IHdhcyBub3QgaW4gdGhlIGNhY2hlLiBSZS1pbnNlcnRzIHRvIHVwZGF0ZSB0aGUgcmVjZW50bHkgdXNlZCBvcmRlciAqL1xuICAgZ2V0KGtleSkge1xuICAgIGNvbnN0IHZhbHVlID0gdGhpcy5fY2FjaGUuZ2V0KGtleSk7XG4gICAgaWYgKHZhbHVlID09PSB1bmRlZmluZWQpIHtcbiAgICAgIHJldHVybiB1bmRlZmluZWQ7XG4gICAgfVxuICAgIC8vIFJlbW92ZSBhbmQgcmUtaW5zZXJ0IHRvIHVwZGF0ZSB0aGUgb3JkZXJcbiAgICB0aGlzLl9jYWNoZS5kZWxldGUoa2V5KTtcbiAgICB0aGlzLl9jYWNoZS5zZXQoa2V5LCB2YWx1ZSk7XG4gICAgcmV0dXJuIHZhbHVlO1xuICB9XG5cbiAgLyoqIEluc2VydCBhbiBlbnRyeSBhbmQgZXZpY3QgYW4gb2xkZXIgZW50cnkgaWYgd2UndmUgcmVhY2hlZCBtYXhTaXplICovXG4gICBzZXQoa2V5LCB2YWx1ZSkge1xuICAgIGlmICh0aGlzLl9jYWNoZS5zaXplID49IHRoaXMuX21heFNpemUpIHtcbiAgICAgIC8vIGtleXMoKSByZXR1cm5zIGFuIGl0ZXJhdG9yIGluIGluc2VydGlvbiBvcmRlciBzbyBrZXlzKCkubmV4dCgpIGdpdmVzIHVzIHRoZSBvbGRlc3Qga2V5XG4gICAgICB0aGlzLl9jYWNoZS5kZWxldGUodGhpcy5fY2FjaGUua2V5cygpLm5leHQoKS52YWx1ZSk7XG4gICAgfVxuICAgIHRoaXMuX2NhY2hlLnNldChrZXksIHZhbHVlKTtcbiAgfVxuXG4gIC8qKiBSZW1vdmUgYW4gZW50cnkgYW5kIHJldHVybiB0aGUgZW50cnkgaWYgaXQgd2FzIGluIHRoZSBjYWNoZSAqL1xuICAgcmVtb3ZlKGtleSkge1xuICAgIGNvbnN0IHZhbHVlID0gdGhpcy5fY2FjaGUuZ2V0KGtleSk7XG4gICAgaWYgKHZhbHVlKSB7XG4gICAgICB0aGlzLl9jYWNoZS5kZWxldGUoa2V5KTtcbiAgICB9XG4gICAgcmV0dXJuIHZhbHVlO1xuICB9XG5cbiAgLyoqIENsZWFyIGFsbCBlbnRyaWVzICovXG4gICBjbGVhcigpIHtcbiAgICB0aGlzLl9jYWNoZS5jbGVhcigpO1xuICB9XG5cbiAgLyoqIEdldCBhbGwgdGhlIGtleXMgKi9cbiAgIGtleXMoKSB7XG4gICAgcmV0dXJuIEFycmF5LmZyb20odGhpcy5fY2FjaGUua2V5cygpKTtcbiAgfVxuXG4gIC8qKiBHZXQgYWxsIHRoZSB2YWx1ZXMgKi9cbiAgIHZhbHVlcygpIHtcbiAgICBjb25zdCB2YWx1ZXMgPSBbXTtcbiAgICB0aGlzLl9jYWNoZS5mb3JFYWNoKHZhbHVlID0+IHZhbHVlcy5wdXNoKHZhbHVlKSk7XG4gICAgcmV0dXJuIHZhbHVlcztcbiAgfVxufVxuXG5leHBvcnRzLkxSVU1hcCA9IExSVU1hcDtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWxydS5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/lru.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/merge.js":
/*!***************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/merge.js ***!
  \***************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n/**\n * Shallow merge two objects.\n * Does not mutate the passed in objects.\n * Undefined/empty values in the merge object will overwrite existing values.\n *\n * By default, this merges 2 levels deep.\n */\nfunction merge(initialObj, mergeObj, levels = 2) {\n  // If the merge value is not an object, or we have no merge levels left,\n  // we just set the value to the merge value\n  if (!mergeObj || typeof mergeObj !== 'object' || levels <= 0) {\n    return mergeObj;\n  }\n\n  // If the merge object is an empty object, and the initial object is not undefined, we return the initial object\n  if (initialObj && Object.keys(mergeObj).length === 0) {\n    return initialObj;\n  }\n\n  // Clone object\n  const output = { ...initialObj };\n\n  // Merge values into output, resursively\n  for (const key in mergeObj) {\n    if (Object.prototype.hasOwnProperty.call(mergeObj, key)) {\n      output[key] = merge(output[key], mergeObj[key], levels - 1);\n    }\n  }\n\n  return output;\n}\n\nexports.merge = merge;\n//# sourceMappingURL=merge.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvbWVyZ2UuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEU7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQSxtQkFBbUI7O0FBRW5CO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBLGFBQWE7QUFDYiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3V0aWxzL21lcmdlLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG4vKipcbiAqIFNoYWxsb3cgbWVyZ2UgdHdvIG9iamVjdHMuXG4gKiBEb2VzIG5vdCBtdXRhdGUgdGhlIHBhc3NlZCBpbiBvYmplY3RzLlxuICogVW5kZWZpbmVkL2VtcHR5IHZhbHVlcyBpbiB0aGUgbWVyZ2Ugb2JqZWN0IHdpbGwgb3ZlcndyaXRlIGV4aXN0aW5nIHZhbHVlcy5cbiAqXG4gKiBCeSBkZWZhdWx0LCB0aGlzIG1lcmdlcyAyIGxldmVscyBkZWVwLlxuICovXG5mdW5jdGlvbiBtZXJnZShpbml0aWFsT2JqLCBtZXJnZU9iaiwgbGV2ZWxzID0gMikge1xuICAvLyBJZiB0aGUgbWVyZ2UgdmFsdWUgaXMgbm90IGFuIG9iamVjdCwgb3Igd2UgaGF2ZSBubyBtZXJnZSBsZXZlbHMgbGVmdCxcbiAgLy8gd2UganVzdCBzZXQgdGhlIHZhbHVlIHRvIHRoZSBtZXJnZSB2YWx1ZVxuICBpZiAoIW1lcmdlT2JqIHx8IHR5cGVvZiBtZXJnZU9iaiAhPT0gJ29iamVjdCcgfHwgbGV2ZWxzIDw9IDApIHtcbiAgICByZXR1cm4gbWVyZ2VPYmo7XG4gIH1cblxuICAvLyBJZiB0aGUgbWVyZ2Ugb2JqZWN0IGlzIGFuIGVtcHR5IG9iamVjdCwgYW5kIHRoZSBpbml0aWFsIG9iamVjdCBpcyBub3QgdW5kZWZpbmVkLCB3ZSByZXR1cm4gdGhlIGluaXRpYWwgb2JqZWN0XG4gIGlmIChpbml0aWFsT2JqICYmIE9iamVjdC5rZXlzKG1lcmdlT2JqKS5sZW5ndGggPT09IDApIHtcbiAgICByZXR1cm4gaW5pdGlhbE9iajtcbiAgfVxuXG4gIC8vIENsb25lIG9iamVjdFxuICBjb25zdCBvdXRwdXQgPSB7IC4uLmluaXRpYWxPYmogfTtcblxuICAvLyBNZXJnZSB2YWx1ZXMgaW50byBvdXRwdXQsIHJlc3Vyc2l2ZWx5XG4gIGZvciAoY29uc3Qga2V5IGluIG1lcmdlT2JqKSB7XG4gICAgaWYgKE9iamVjdC5wcm90b3R5cGUuaGFzT3duUHJvcGVydHkuY2FsbChtZXJnZU9iaiwga2V5KSkge1xuICAgICAgb3V0cHV0W2tleV0gPSBtZXJnZShvdXRwdXRba2V5XSwgbWVyZ2VPYmpba2V5XSwgbGV2ZWxzIC0gMSk7XG4gICAgfVxuICB9XG5cbiAgcmV0dXJuIG91dHB1dDtcbn1cblxuZXhwb3J0cy5tZXJnZSA9IG1lcmdlO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9bWVyZ2UuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/merge.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/meta.js":
/*!**************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/meta.js ***!
  \**************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst traceData = __webpack_require__(/*! ./traceData.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/traceData.js\");\n\n/**\n * Returns a string of meta tags that represent the current trace data.\n *\n * You can use this to propagate a trace from your server-side rendered Html to the browser.\n * This function returns up to two meta tags, `sentry-trace` and `baggage`, depending on the\n * current trace data state.\n *\n * @example\n * Usage example:\n *\n * ```js\n * function renderHtml() {\n *   return `\n *     <head>\n *       ${getTraceMetaTags()}\n *     </head>\n *   `;\n * }\n * ```\n *\n */\nfunction getTraceMetaTags(traceData$1) {\n  return Object.entries(traceData$1 || traceData.getTraceData())\n    .map(([key, value]) => `<meta name=\"${key}\" content=\"${value}\"/>`)\n    .join('\\n');\n}\n\nexports.getTraceMetaTags = getTraceMetaTags;\n//# sourceMappingURL=meta.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvbWV0YS5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxrQkFBa0IsbUJBQU8sQ0FBQyxvSUFBZ0I7O0FBRTFDO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxXQUFXO0FBQ1g7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLDBDQUEwQyxJQUFJLGFBQWEsTUFBTTtBQUNqRTtBQUNBOztBQUVBLHdCQUF3QjtBQUN4QiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3V0aWxzL21ldGEuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IHRyYWNlRGF0YSA9IHJlcXVpcmUoJy4vdHJhY2VEYXRhLmpzJyk7XG5cbi8qKlxuICogUmV0dXJucyBhIHN0cmluZyBvZiBtZXRhIHRhZ3MgdGhhdCByZXByZXNlbnQgdGhlIGN1cnJlbnQgdHJhY2UgZGF0YS5cbiAqXG4gKiBZb3UgY2FuIHVzZSB0aGlzIHRvIHByb3BhZ2F0ZSBhIHRyYWNlIGZyb20geW91ciBzZXJ2ZXItc2lkZSByZW5kZXJlZCBIdG1sIHRvIHRoZSBicm93c2VyLlxuICogVGhpcyBmdW5jdGlvbiByZXR1cm5zIHVwIHRvIHR3byBtZXRhIHRhZ3MsIGBzZW50cnktdHJhY2VgIGFuZCBgYmFnZ2FnZWAsIGRlcGVuZGluZyBvbiB0aGVcbiAqIGN1cnJlbnQgdHJhY2UgZGF0YSBzdGF0ZS5cbiAqXG4gKiBAZXhhbXBsZVxuICogVXNhZ2UgZXhhbXBsZTpcbiAqXG4gKiBgYGBqc1xuICogZnVuY3Rpb24gcmVuZGVySHRtbCgpIHtcbiAqICAgcmV0dXJuIGBcbiAqICAgICA8aGVhZD5cbiAqICAgICAgICR7Z2V0VHJhY2VNZXRhVGFncygpfVxuICogICAgIDwvaGVhZD5cbiAqICAgYDtcbiAqIH1cbiAqIGBgYFxuICpcbiAqL1xuZnVuY3Rpb24gZ2V0VHJhY2VNZXRhVGFncyh0cmFjZURhdGEkMSkge1xuICByZXR1cm4gT2JqZWN0LmVudHJpZXModHJhY2VEYXRhJDEgfHwgdHJhY2VEYXRhLmdldFRyYWNlRGF0YSgpKVxuICAgIC5tYXAoKFtrZXksIHZhbHVlXSkgPT4gYDxtZXRhIG5hbWU9XCIke2tleX1cIiBjb250ZW50PVwiJHt2YWx1ZX1cIi8+YClcbiAgICAuam9pbignXFxuJyk7XG59XG5cbmV4cG9ydHMuZ2V0VHJhY2VNZXRhVGFncyA9IGdldFRyYWNlTWV0YVRhZ3M7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1tZXRhLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/meta.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/misc.js":
/*!**************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/misc.js ***!
  \**************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst object = __webpack_require__(/*! ./object.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/object.js\");\nconst string = __webpack_require__(/*! ./string.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/string.js\");\nconst worldwide = __webpack_require__(/*! ./worldwide.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/worldwide.js\");\n\nfunction getCrypto() {\n  const gbl = worldwide.GLOBAL_OBJ ;\n  return gbl.crypto || gbl.msCrypto;\n}\n\n/**\n * UUID4 generator\n * @param crypto Object that provides the crypto API.\n * @returns string Generated UUID4.\n */\nfunction uuid4(crypto = getCrypto()) {\n  let getRandomByte = () => Math.random() * 16;\n  try {\n    if (crypto?.randomUUID) {\n      return crypto.randomUUID().replace(/-/g, '');\n    }\n    if (crypto?.getRandomValues) {\n      getRandomByte = () => {\n        // crypto.getRandomValues might return undefined instead of the typed array\n        // in old Chromium versions (e.g. 23.0.1235.0 (151422))\n        // However, `typedArray` is still filled in-place.\n        // @see https://developer.mozilla.org/en-US/docs/Web/API/Crypto/getRandomValues#typedarray\n        const typedArray = new Uint8Array(1);\n        crypto.getRandomValues(typedArray);\n        // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n        return typedArray[0];\n      };\n    }\n  } catch {\n    // some runtimes can crash invoking crypto\n    // https://github.com/getsentry/sentry-javascript/issues/8935\n  }\n\n  // http://stackoverflow.com/questions/105034/how-to-create-a-guid-uuid-in-javascript/2117523#2117523\n  // Concatenating the following numbers as strings results in '10000000100040008000100000000000'\n  return (([1e7] ) + 1e3 + 4e3 + 8e3 + 1e11).replace(/[018]/g, c =>\n    // eslint-disable-next-line no-bitwise\n    ((c ) ^ ((getRandomByte() & 15) >> ((c ) / 4))).toString(16),\n  );\n}\n\nfunction getFirstException(event) {\n  return event.exception?.values?.[0];\n}\n\n/**\n * Extracts either message or type+value from an event that can be used for user-facing logs\n * @returns event's description\n */\nfunction getEventDescription(event) {\n  const { message, event_id: eventId } = event;\n  if (message) {\n    return message;\n  }\n\n  const firstException = getFirstException(event);\n  if (firstException) {\n    if (firstException.type && firstException.value) {\n      return `${firstException.type}: ${firstException.value}`;\n    }\n    return firstException.type || firstException.value || eventId || '<unknown>';\n  }\n  return eventId || '<unknown>';\n}\n\n/**\n * Adds exception values, type and value to an synthetic Exception.\n * @param event The event to modify.\n * @param value Value of the exception.\n * @param type Type of the exception.\n * @hidden\n */\nfunction addExceptionTypeValue(event, value, type) {\n  const exception = (event.exception = event.exception || {});\n  const values = (exception.values = exception.values || []);\n  const firstException = (values[0] = values[0] || {});\n  if (!firstException.value) {\n    firstException.value = value || '';\n  }\n  if (!firstException.type) {\n    firstException.type = type || 'Error';\n  }\n}\n\n/**\n * Adds exception mechanism data to a given event. Uses defaults if the second parameter is not passed.\n *\n * @param event The event to modify.\n * @param newMechanism Mechanism data to add to the event.\n * @hidden\n */\nfunction addExceptionMechanism(event, newMechanism) {\n  const firstException = getFirstException(event);\n  if (!firstException) {\n    return;\n  }\n\n  const defaultMechanism = { type: 'generic', handled: true };\n  const currentMechanism = firstException.mechanism;\n  firstException.mechanism = { ...defaultMechanism, ...currentMechanism, ...newMechanism };\n\n  if (newMechanism && 'data' in newMechanism) {\n    const mergedData = { ...currentMechanism?.data, ...newMechanism.data };\n    firstException.mechanism.data = mergedData;\n  }\n}\n\n// https://semver.org/#is-there-a-suggested-regular-expression-regex-to-check-a-semver-string\nconst SEMVER_REGEXP =\n  /^(0|[1-9]\\d*)\\.(0|[1-9]\\d*)\\.(0|[1-9]\\d*)(?:-((?:0|[1-9]\\d*|\\d*[a-zA-Z-][0-9a-zA-Z-]*)(?:\\.(?:0|[1-9]\\d*|\\d*[a-zA-Z-][0-9a-zA-Z-]*))*))?(?:\\+([0-9a-zA-Z-]+(?:\\.[0-9a-zA-Z-]+)*))?$/;\n\n/**\n * Represents Semantic Versioning object\n */\n\nfunction _parseInt(input) {\n  return parseInt(input || '', 10);\n}\n\n/**\n * Parses input into a SemVer interface\n * @param input string representation of a semver version\n */\nfunction parseSemver(input) {\n  const match = input.match(SEMVER_REGEXP) || [];\n  const major = _parseInt(match[1]);\n  const minor = _parseInt(match[2]);\n  const patch = _parseInt(match[3]);\n  return {\n    buildmetadata: match[5],\n    major: isNaN(major) ? undefined : major,\n    minor: isNaN(minor) ? undefined : minor,\n    patch: isNaN(patch) ? undefined : patch,\n    prerelease: match[4],\n  };\n}\n\n/**\n * This function adds context (pre/post/line) lines to the provided frame\n *\n * @param lines string[] containing all lines\n * @param frame StackFrame that will be mutated\n * @param linesOfContext number of context lines we want to add pre/post\n */\nfunction addContextToFrame(lines, frame, linesOfContext = 5) {\n  // When there is no line number in the frame, attaching context is nonsensical and will even break grouping\n  if (frame.lineno === undefined) {\n    return;\n  }\n\n  const maxLines = lines.length;\n  const sourceLine = Math.max(Math.min(maxLines - 1, frame.lineno - 1), 0);\n\n  frame.pre_context = lines\n    .slice(Math.max(0, sourceLine - linesOfContext), sourceLine)\n    .map((line) => string.snipLine(line, 0));\n\n  // We guard here to ensure this is not larger than the existing number of lines\n  const lineIndex = Math.min(maxLines - 1, sourceLine);\n\n  // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n  frame.context_line = string.snipLine(lines[lineIndex], frame.colno || 0);\n\n  frame.post_context = lines\n    .slice(Math.min(sourceLine + 1, maxLines), sourceLine + 1 + linesOfContext)\n    .map((line) => string.snipLine(line, 0));\n}\n\n/**\n * Checks whether or not we've already captured the given exception (note: not an identical exception - the very object\n * in question), and marks it captured if not.\n *\n * This is useful because it's possible for an error to get captured by more than one mechanism. After we intercept and\n * record an error, we rethrow it (assuming we've intercepted it before it's reached the top-level global handlers), so\n * that we don't interfere with whatever effects the error might have had were the SDK not there. At that point, because\n * the error has been rethrown, it's possible for it to bubble up to some other code we've instrumented. If it's not\n * caught after that, it will bubble all the way up to the global handlers (which of course we also instrument). This\n * function helps us ensure that even if we encounter the same error more than once, we only record it the first time we\n * see it.\n *\n * Note: It will ignore primitives (always return `false` and not mark them as seen), as properties can't be set on\n * them. {@link: Object.objectify} can be used on exceptions to convert any that are primitives into their equivalent\n * object wrapper forms so that this check will always work. However, because we need to flag the exact object which\n * will get rethrown, and because that rethrowing happens outside of the event processing pipeline, the objectification\n * must be done before the exception captured.\n *\n * @param A thrown exception to check or flag as having been seen\n * @returns `true` if the exception has already been captured, `false` if not (with the side effect of marking it seen)\n */\nfunction checkOrSetAlreadyCaught(exception) {\n  if (isAlreadyCaptured(exception)) {\n    return true;\n  }\n\n  try {\n    // set it this way rather than by assignment so that it's not ennumerable and therefore isn't recorded by the\n    // `ExtraErrorData` integration\n    object.addNonEnumerableProperty(exception , '__sentry_captured__', true);\n  } catch {\n    // `exception` is a primitive, so we can't mark it seen\n  }\n\n  return false;\n}\n\nfunction isAlreadyCaptured(exception) {\n  try {\n    return (exception ).__sentry_captured__;\n  } catch {} // eslint-disable-line no-empty\n}\n\nexports.addContextToFrame = addContextToFrame;\nexports.addExceptionMechanism = addExceptionMechanism;\nexports.addExceptionTypeValue = addExceptionTypeValue;\nexports.checkOrSetAlreadyCaught = checkOrSetAlreadyCaught;\nexports.getEventDescription = getEventDescription;\nexports.parseSemver = parseSemver;\nexports.uuid4 = uuid4;\n//# sourceMappingURL=misc.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvbWlzYy5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxlQUFlLG1CQUFPLENBQUMsOEhBQWE7QUFDcEMsZUFBZSxtQkFBTyxDQUFDLDhIQUFhO0FBQ3BDLGtCQUFrQixtQkFBTyxDQUFDLG9JQUFnQjs7QUFFMUM7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLElBQUk7QUFDSjtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxVQUFVLDZCQUE2QjtBQUN2QztBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0EsZ0JBQWdCLG9CQUFvQixJQUFJLHFCQUFxQjtBQUM3RDtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSw0REFBNEQ7QUFDNUQ7QUFDQSxxREFBcUQ7QUFDckQ7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLDZCQUE2QjtBQUM3QjtBQUNBLCtCQUErQjs7QUFFL0I7QUFDQSx5QkFBeUI7QUFDekI7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFVBQVUseUJBQXlCO0FBQ25DO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQSxJQUFJO0FBQ0o7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBLElBQUksU0FBUztBQUNiOztBQUVBLHlCQUF5QjtBQUN6Qiw2QkFBNkI7QUFDN0IsNkJBQTZCO0FBQzdCLCtCQUErQjtBQUMvQiwyQkFBMkI7QUFDM0IsbUJBQW1CO0FBQ25CLGFBQWE7QUFDYiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3V0aWxzL21pc2MuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IG9iamVjdCA9IHJlcXVpcmUoJy4vb2JqZWN0LmpzJyk7XG5jb25zdCBzdHJpbmcgPSByZXF1aXJlKCcuL3N0cmluZy5qcycpO1xuY29uc3Qgd29ybGR3aWRlID0gcmVxdWlyZSgnLi93b3JsZHdpZGUuanMnKTtcblxuZnVuY3Rpb24gZ2V0Q3J5cHRvKCkge1xuICBjb25zdCBnYmwgPSB3b3JsZHdpZGUuR0xPQkFMX09CSiA7XG4gIHJldHVybiBnYmwuY3J5cHRvIHx8IGdibC5tc0NyeXB0bztcbn1cblxuLyoqXG4gKiBVVUlENCBnZW5lcmF0b3JcbiAqIEBwYXJhbSBjcnlwdG8gT2JqZWN0IHRoYXQgcHJvdmlkZXMgdGhlIGNyeXB0byBBUEkuXG4gKiBAcmV0dXJucyBzdHJpbmcgR2VuZXJhdGVkIFVVSUQ0LlxuICovXG5mdW5jdGlvbiB1dWlkNChjcnlwdG8gPSBnZXRDcnlwdG8oKSkge1xuICBsZXQgZ2V0UmFuZG9tQnl0ZSA9ICgpID0+IE1hdGgucmFuZG9tKCkgKiAxNjtcbiAgdHJ5IHtcbiAgICBpZiAoY3J5cHRvPy5yYW5kb21VVUlEKSB7XG4gICAgICByZXR1cm4gY3J5cHRvLnJhbmRvbVVVSUQoKS5yZXBsYWNlKC8tL2csICcnKTtcbiAgICB9XG4gICAgaWYgKGNyeXB0bz8uZ2V0UmFuZG9tVmFsdWVzKSB7XG4gICAgICBnZXRSYW5kb21CeXRlID0gKCkgPT4ge1xuICAgICAgICAvLyBjcnlwdG8uZ2V0UmFuZG9tVmFsdWVzIG1pZ2h0IHJldHVybiB1bmRlZmluZWQgaW5zdGVhZCBvZiB0aGUgdHlwZWQgYXJyYXlcbiAgICAgICAgLy8gaW4gb2xkIENocm9taXVtIHZlcnNpb25zIChlLmcuIDIzLjAuMTIzNS4wICgxNTE0MjIpKVxuICAgICAgICAvLyBIb3dldmVyLCBgdHlwZWRBcnJheWAgaXMgc3RpbGwgZmlsbGVkIGluLXBsYWNlLlxuICAgICAgICAvLyBAc2VlIGh0dHBzOi8vZGV2ZWxvcGVyLm1vemlsbGEub3JnL2VuLVVTL2RvY3MvV2ViL0FQSS9DcnlwdG8vZ2V0UmFuZG9tVmFsdWVzI3R5cGVkYXJyYXlcbiAgICAgICAgY29uc3QgdHlwZWRBcnJheSA9IG5ldyBVaW50OEFycmF5KDEpO1xuICAgICAgICBjcnlwdG8uZ2V0UmFuZG9tVmFsdWVzKHR5cGVkQXJyYXkpO1xuICAgICAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25vLW5vbi1udWxsLWFzc2VydGlvblxuICAgICAgICByZXR1cm4gdHlwZWRBcnJheVswXTtcbiAgICAgIH07XG4gICAgfVxuICB9IGNhdGNoIHtcbiAgICAvLyBzb21lIHJ1bnRpbWVzIGNhbiBjcmFzaCBpbnZva2luZyBjcnlwdG9cbiAgICAvLyBodHRwczovL2dpdGh1Yi5jb20vZ2V0c2VudHJ5L3NlbnRyeS1qYXZhc2NyaXB0L2lzc3Vlcy84OTM1XG4gIH1cblxuICAvLyBodHRwOi8vc3RhY2tvdmVyZmxvdy5jb20vcXVlc3Rpb25zLzEwNTAzNC9ob3ctdG8tY3JlYXRlLWEtZ3VpZC11dWlkLWluLWphdmFzY3JpcHQvMjExNzUyMyMyMTE3NTIzXG4gIC8vIENvbmNhdGVuYXRpbmcgdGhlIGZvbGxvd2luZyBudW1iZXJzIGFzIHN0cmluZ3MgcmVzdWx0cyBpbiAnMTAwMDAwMDAxMDAwNDAwMDgwMDAxMDAwMDAwMDAwMDAnXG4gIHJldHVybiAoKFsxZTddICkgKyAxZTMgKyA0ZTMgKyA4ZTMgKyAxZTExKS5yZXBsYWNlKC9bMDE4XS9nLCBjID0+XG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIG5vLWJpdHdpc2VcbiAgICAoKGMgKSBeICgoZ2V0UmFuZG9tQnl0ZSgpICYgMTUpID4+ICgoYyApIC8gNCkpKS50b1N0cmluZygxNiksXG4gICk7XG59XG5cbmZ1bmN0aW9uIGdldEZpcnN0RXhjZXB0aW9uKGV2ZW50KSB7XG4gIHJldHVybiBldmVudC5leGNlcHRpb24/LnZhbHVlcz8uWzBdO1xufVxuXG4vKipcbiAqIEV4dHJhY3RzIGVpdGhlciBtZXNzYWdlIG9yIHR5cGUrdmFsdWUgZnJvbSBhbiBldmVudCB0aGF0IGNhbiBiZSB1c2VkIGZvciB1c2VyLWZhY2luZyBsb2dzXG4gKiBAcmV0dXJucyBldmVudCdzIGRlc2NyaXB0aW9uXG4gKi9cbmZ1bmN0aW9uIGdldEV2ZW50RGVzY3JpcHRpb24oZXZlbnQpIHtcbiAgY29uc3QgeyBtZXNzYWdlLCBldmVudF9pZDogZXZlbnRJZCB9ID0gZXZlbnQ7XG4gIGlmIChtZXNzYWdlKSB7XG4gICAgcmV0dXJuIG1lc3NhZ2U7XG4gIH1cblxuICBjb25zdCBmaXJzdEV4Y2VwdGlvbiA9IGdldEZpcnN0RXhjZXB0aW9uKGV2ZW50KTtcbiAgaWYgKGZpcnN0RXhjZXB0aW9uKSB7XG4gICAgaWYgKGZpcnN0RXhjZXB0aW9uLnR5cGUgJiYgZmlyc3RFeGNlcHRpb24udmFsdWUpIHtcbiAgICAgIHJldHVybiBgJHtmaXJzdEV4Y2VwdGlvbi50eXBlfTogJHtmaXJzdEV4Y2VwdGlvbi52YWx1ZX1gO1xuICAgIH1cbiAgICByZXR1cm4gZmlyc3RFeGNlcHRpb24udHlwZSB8fCBmaXJzdEV4Y2VwdGlvbi52YWx1ZSB8fCBldmVudElkIHx8ICc8dW5rbm93bj4nO1xuICB9XG4gIHJldHVybiBldmVudElkIHx8ICc8dW5rbm93bj4nO1xufVxuXG4vKipcbiAqIEFkZHMgZXhjZXB0aW9uIHZhbHVlcywgdHlwZSBhbmQgdmFsdWUgdG8gYW4gc3ludGhldGljIEV4Y2VwdGlvbi5cbiAqIEBwYXJhbSBldmVudCBUaGUgZXZlbnQgdG8gbW9kaWZ5LlxuICogQHBhcmFtIHZhbHVlIFZhbHVlIG9mIHRoZSBleGNlcHRpb24uXG4gKiBAcGFyYW0gdHlwZSBUeXBlIG9mIHRoZSBleGNlcHRpb24uXG4gKiBAaGlkZGVuXG4gKi9cbmZ1bmN0aW9uIGFkZEV4Y2VwdGlvblR5cGVWYWx1ZShldmVudCwgdmFsdWUsIHR5cGUpIHtcbiAgY29uc3QgZXhjZXB0aW9uID0gKGV2ZW50LmV4Y2VwdGlvbiA9IGV2ZW50LmV4Y2VwdGlvbiB8fCB7fSk7XG4gIGNvbnN0IHZhbHVlcyA9IChleGNlcHRpb24udmFsdWVzID0gZXhjZXB0aW9uLnZhbHVlcyB8fCBbXSk7XG4gIGNvbnN0IGZpcnN0RXhjZXB0aW9uID0gKHZhbHVlc1swXSA9IHZhbHVlc1swXSB8fCB7fSk7XG4gIGlmICghZmlyc3RFeGNlcHRpb24udmFsdWUpIHtcbiAgICBmaXJzdEV4Y2VwdGlvbi52YWx1ZSA9IHZhbHVlIHx8ICcnO1xuICB9XG4gIGlmICghZmlyc3RFeGNlcHRpb24udHlwZSkge1xuICAgIGZpcnN0RXhjZXB0aW9uLnR5cGUgPSB0eXBlIHx8ICdFcnJvcic7XG4gIH1cbn1cblxuLyoqXG4gKiBBZGRzIGV4Y2VwdGlvbiBtZWNoYW5pc20gZGF0YSB0byBhIGdpdmVuIGV2ZW50LiBVc2VzIGRlZmF1bHRzIGlmIHRoZSBzZWNvbmQgcGFyYW1ldGVyIGlzIG5vdCBwYXNzZWQuXG4gKlxuICogQHBhcmFtIGV2ZW50IFRoZSBldmVudCB0byBtb2RpZnkuXG4gKiBAcGFyYW0gbmV3TWVjaGFuaXNtIE1lY2hhbmlzbSBkYXRhIHRvIGFkZCB0byB0aGUgZXZlbnQuXG4gKiBAaGlkZGVuXG4gKi9cbmZ1bmN0aW9uIGFkZEV4Y2VwdGlvbk1lY2hhbmlzbShldmVudCwgbmV3TWVjaGFuaXNtKSB7XG4gIGNvbnN0IGZpcnN0RXhjZXB0aW9uID0gZ2V0Rmlyc3RFeGNlcHRpb24oZXZlbnQpO1xuICBpZiAoIWZpcnN0RXhjZXB0aW9uKSB7XG4gICAgcmV0dXJuO1xuICB9XG5cbiAgY29uc3QgZGVmYXVsdE1lY2hhbmlzbSA9IHsgdHlwZTogJ2dlbmVyaWMnLCBoYW5kbGVkOiB0cnVlIH07XG4gIGNvbnN0IGN1cnJlbnRNZWNoYW5pc20gPSBmaXJzdEV4Y2VwdGlvbi5tZWNoYW5pc207XG4gIGZpcnN0RXhjZXB0aW9uLm1lY2hhbmlzbSA9IHsgLi4uZGVmYXVsdE1lY2hhbmlzbSwgLi4uY3VycmVudE1lY2hhbmlzbSwgLi4ubmV3TWVjaGFuaXNtIH07XG5cbiAgaWYgKG5ld01lY2hhbmlzbSAmJiAnZGF0YScgaW4gbmV3TWVjaGFuaXNtKSB7XG4gICAgY29uc3QgbWVyZ2VkRGF0YSA9IHsgLi4uY3VycmVudE1lY2hhbmlzbT8uZGF0YSwgLi4ubmV3TWVjaGFuaXNtLmRhdGEgfTtcbiAgICBmaXJzdEV4Y2VwdGlvbi5tZWNoYW5pc20uZGF0YSA9IG1lcmdlZERhdGE7XG4gIH1cbn1cblxuLy8gaHR0cHM6Ly9zZW12ZXIub3JnLyNpcy10aGVyZS1hLXN1Z2dlc3RlZC1yZWd1bGFyLWV4cHJlc3Npb24tcmVnZXgtdG8tY2hlY2stYS1zZW12ZXItc3RyaW5nXG5jb25zdCBTRU1WRVJfUkVHRVhQID1cbiAgL14oMHxbMS05XVxcZCopXFwuKDB8WzEtOV1cXGQqKVxcLigwfFsxLTldXFxkKikoPzotKCg/OjB8WzEtOV1cXGQqfFxcZCpbYS16QS1aLV1bMC05YS16QS1aLV0qKSg/OlxcLig/OjB8WzEtOV1cXGQqfFxcZCpbYS16QS1aLV1bMC05YS16QS1aLV0qKSkqKSk/KD86XFwrKFswLTlhLXpBLVotXSsoPzpcXC5bMC05YS16QS1aLV0rKSopKT8kLztcblxuLyoqXG4gKiBSZXByZXNlbnRzIFNlbWFudGljIFZlcnNpb25pbmcgb2JqZWN0XG4gKi9cblxuZnVuY3Rpb24gX3BhcnNlSW50KGlucHV0KSB7XG4gIHJldHVybiBwYXJzZUludChpbnB1dCB8fCAnJywgMTApO1xufVxuXG4vKipcbiAqIFBhcnNlcyBpbnB1dCBpbnRvIGEgU2VtVmVyIGludGVyZmFjZVxuICogQHBhcmFtIGlucHV0IHN0cmluZyByZXByZXNlbnRhdGlvbiBvZiBhIHNlbXZlciB2ZXJzaW9uXG4gKi9cbmZ1bmN0aW9uIHBhcnNlU2VtdmVyKGlucHV0KSB7XG4gIGNvbnN0IG1hdGNoID0gaW5wdXQubWF0Y2goU0VNVkVSX1JFR0VYUCkgfHwgW107XG4gIGNvbnN0IG1ham9yID0gX3BhcnNlSW50KG1hdGNoWzFdKTtcbiAgY29uc3QgbWlub3IgPSBfcGFyc2VJbnQobWF0Y2hbMl0pO1xuICBjb25zdCBwYXRjaCA9IF9wYXJzZUludChtYXRjaFszXSk7XG4gIHJldHVybiB7XG4gICAgYnVpbGRtZXRhZGF0YTogbWF0Y2hbNV0sXG4gICAgbWFqb3I6IGlzTmFOKG1ham9yKSA/IHVuZGVmaW5lZCA6IG1ham9yLFxuICAgIG1pbm9yOiBpc05hTihtaW5vcikgPyB1bmRlZmluZWQgOiBtaW5vcixcbiAgICBwYXRjaDogaXNOYU4ocGF0Y2gpID8gdW5kZWZpbmVkIDogcGF0Y2gsXG4gICAgcHJlcmVsZWFzZTogbWF0Y2hbNF0sXG4gIH07XG59XG5cbi8qKlxuICogVGhpcyBmdW5jdGlvbiBhZGRzIGNvbnRleHQgKHByZS9wb3N0L2xpbmUpIGxpbmVzIHRvIHRoZSBwcm92aWRlZCBmcmFtZVxuICpcbiAqIEBwYXJhbSBsaW5lcyBzdHJpbmdbXSBjb250YWluaW5nIGFsbCBsaW5lc1xuICogQHBhcmFtIGZyYW1lIFN0YWNrRnJhbWUgdGhhdCB3aWxsIGJlIG11dGF0ZWRcbiAqIEBwYXJhbSBsaW5lc09mQ29udGV4dCBudW1iZXIgb2YgY29udGV4dCBsaW5lcyB3ZSB3YW50IHRvIGFkZCBwcmUvcG9zdFxuICovXG5mdW5jdGlvbiBhZGRDb250ZXh0VG9GcmFtZShsaW5lcywgZnJhbWUsIGxpbmVzT2ZDb250ZXh0ID0gNSkge1xuICAvLyBXaGVuIHRoZXJlIGlzIG5vIGxpbmUgbnVtYmVyIGluIHRoZSBmcmFtZSwgYXR0YWNoaW5nIGNvbnRleHQgaXMgbm9uc2Vuc2ljYWwgYW5kIHdpbGwgZXZlbiBicmVhayBncm91cGluZ1xuICBpZiAoZnJhbWUubGluZW5vID09PSB1bmRlZmluZWQpIHtcbiAgICByZXR1cm47XG4gIH1cblxuICBjb25zdCBtYXhMaW5lcyA9IGxpbmVzLmxlbmd0aDtcbiAgY29uc3Qgc291cmNlTGluZSA9IE1hdGgubWF4KE1hdGgubWluKG1heExpbmVzIC0gMSwgZnJhbWUubGluZW5vIC0gMSksIDApO1xuXG4gIGZyYW1lLnByZV9jb250ZXh0ID0gbGluZXNcbiAgICAuc2xpY2UoTWF0aC5tYXgoMCwgc291cmNlTGluZSAtIGxpbmVzT2ZDb250ZXh0KSwgc291cmNlTGluZSlcbiAgICAubWFwKChsaW5lKSA9PiBzdHJpbmcuc25pcExpbmUobGluZSwgMCkpO1xuXG4gIC8vIFdlIGd1YXJkIGhlcmUgdG8gZW5zdXJlIHRoaXMgaXMgbm90IGxhcmdlciB0aGFuIHRoZSBleGlzdGluZyBudW1iZXIgb2YgbGluZXNcbiAgY29uc3QgbGluZUluZGV4ID0gTWF0aC5taW4obWF4TGluZXMgLSAxLCBzb3VyY2VMaW5lKTtcblxuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25vLW5vbi1udWxsLWFzc2VydGlvblxuICBmcmFtZS5jb250ZXh0X2xpbmUgPSBzdHJpbmcuc25pcExpbmUobGluZXNbbGluZUluZGV4XSwgZnJhbWUuY29sbm8gfHwgMCk7XG5cbiAgZnJhbWUucG9zdF9jb250ZXh0ID0gbGluZXNcbiAgICAuc2xpY2UoTWF0aC5taW4oc291cmNlTGluZSArIDEsIG1heExpbmVzKSwgc291cmNlTGluZSArIDEgKyBsaW5lc09mQ29udGV4dClcbiAgICAubWFwKChsaW5lKSA9PiBzdHJpbmcuc25pcExpbmUobGluZSwgMCkpO1xufVxuXG4vKipcbiAqIENoZWNrcyB3aGV0aGVyIG9yIG5vdCB3ZSd2ZSBhbHJlYWR5IGNhcHR1cmVkIHRoZSBnaXZlbiBleGNlcHRpb24gKG5vdGU6IG5vdCBhbiBpZGVudGljYWwgZXhjZXB0aW9uIC0gdGhlIHZlcnkgb2JqZWN0XG4gKiBpbiBxdWVzdGlvbiksIGFuZCBtYXJrcyBpdCBjYXB0dXJlZCBpZiBub3QuXG4gKlxuICogVGhpcyBpcyB1c2VmdWwgYmVjYXVzZSBpdCdzIHBvc3NpYmxlIGZvciBhbiBlcnJvciB0byBnZXQgY2FwdHVyZWQgYnkgbW9yZSB0aGFuIG9uZSBtZWNoYW5pc20uIEFmdGVyIHdlIGludGVyY2VwdCBhbmRcbiAqIHJlY29yZCBhbiBlcnJvciwgd2UgcmV0aHJvdyBpdCAoYXNzdW1pbmcgd2UndmUgaW50ZXJjZXB0ZWQgaXQgYmVmb3JlIGl0J3MgcmVhY2hlZCB0aGUgdG9wLWxldmVsIGdsb2JhbCBoYW5kbGVycyksIHNvXG4gKiB0aGF0IHdlIGRvbid0IGludGVyZmVyZSB3aXRoIHdoYXRldmVyIGVmZmVjdHMgdGhlIGVycm9yIG1pZ2h0IGhhdmUgaGFkIHdlcmUgdGhlIFNESyBub3QgdGhlcmUuIEF0IHRoYXQgcG9pbnQsIGJlY2F1c2VcbiAqIHRoZSBlcnJvciBoYXMgYmVlbiByZXRocm93biwgaXQncyBwb3NzaWJsZSBmb3IgaXQgdG8gYnViYmxlIHVwIHRvIHNvbWUgb3RoZXIgY29kZSB3ZSd2ZSBpbnN0cnVtZW50ZWQuIElmIGl0J3Mgbm90XG4gKiBjYXVnaHQgYWZ0ZXIgdGhhdCwgaXQgd2lsbCBidWJibGUgYWxsIHRoZSB3YXkgdXAgdG8gdGhlIGdsb2JhbCBoYW5kbGVycyAod2hpY2ggb2YgY291cnNlIHdlIGFsc28gaW5zdHJ1bWVudCkuIFRoaXNcbiAqIGZ1bmN0aW9uIGhlbHBzIHVzIGVuc3VyZSB0aGF0IGV2ZW4gaWYgd2UgZW5jb3VudGVyIHRoZSBzYW1lIGVycm9yIG1vcmUgdGhhbiBvbmNlLCB3ZSBvbmx5IHJlY29yZCBpdCB0aGUgZmlyc3QgdGltZSB3ZVxuICogc2VlIGl0LlxuICpcbiAqIE5vdGU6IEl0IHdpbGwgaWdub3JlIHByaW1pdGl2ZXMgKGFsd2F5cyByZXR1cm4gYGZhbHNlYCBhbmQgbm90IG1hcmsgdGhlbSBhcyBzZWVuKSwgYXMgcHJvcGVydGllcyBjYW4ndCBiZSBzZXQgb25cbiAqIHRoZW0uIHtAbGluazogT2JqZWN0Lm9iamVjdGlmeX0gY2FuIGJlIHVzZWQgb24gZXhjZXB0aW9ucyB0byBjb252ZXJ0IGFueSB0aGF0IGFyZSBwcmltaXRpdmVzIGludG8gdGhlaXIgZXF1aXZhbGVudFxuICogb2JqZWN0IHdyYXBwZXIgZm9ybXMgc28gdGhhdCB0aGlzIGNoZWNrIHdpbGwgYWx3YXlzIHdvcmsuIEhvd2V2ZXIsIGJlY2F1c2Ugd2UgbmVlZCB0byBmbGFnIHRoZSBleGFjdCBvYmplY3Qgd2hpY2hcbiAqIHdpbGwgZ2V0IHJldGhyb3duLCBhbmQgYmVjYXVzZSB0aGF0IHJldGhyb3dpbmcgaGFwcGVucyBvdXRzaWRlIG9mIHRoZSBldmVudCBwcm9jZXNzaW5nIHBpcGVsaW5lLCB0aGUgb2JqZWN0aWZpY2F0aW9uXG4gKiBtdXN0IGJlIGRvbmUgYmVmb3JlIHRoZSBleGNlcHRpb24gY2FwdHVyZWQuXG4gKlxuICogQHBhcmFtIEEgdGhyb3duIGV4Y2VwdGlvbiB0byBjaGVjayBvciBmbGFnIGFzIGhhdmluZyBiZWVuIHNlZW5cbiAqIEByZXR1cm5zIGB0cnVlYCBpZiB0aGUgZXhjZXB0aW9uIGhhcyBhbHJlYWR5IGJlZW4gY2FwdHVyZWQsIGBmYWxzZWAgaWYgbm90ICh3aXRoIHRoZSBzaWRlIGVmZmVjdCBvZiBtYXJraW5nIGl0IHNlZW4pXG4gKi9cbmZ1bmN0aW9uIGNoZWNrT3JTZXRBbHJlYWR5Q2F1Z2h0KGV4Y2VwdGlvbikge1xuICBpZiAoaXNBbHJlYWR5Q2FwdHVyZWQoZXhjZXB0aW9uKSkge1xuICAgIHJldHVybiB0cnVlO1xuICB9XG5cbiAgdHJ5IHtcbiAgICAvLyBzZXQgaXQgdGhpcyB3YXkgcmF0aGVyIHRoYW4gYnkgYXNzaWdubWVudCBzbyB0aGF0IGl0J3Mgbm90IGVubnVtZXJhYmxlIGFuZCB0aGVyZWZvcmUgaXNuJ3QgcmVjb3JkZWQgYnkgdGhlXG4gICAgLy8gYEV4dHJhRXJyb3JEYXRhYCBpbnRlZ3JhdGlvblxuICAgIG9iamVjdC5hZGROb25FbnVtZXJhYmxlUHJvcGVydHkoZXhjZXB0aW9uICwgJ19fc2VudHJ5X2NhcHR1cmVkX18nLCB0cnVlKTtcbiAgfSBjYXRjaCB7XG4gICAgLy8gYGV4Y2VwdGlvbmAgaXMgYSBwcmltaXRpdmUsIHNvIHdlIGNhbid0IG1hcmsgaXQgc2VlblxuICB9XG5cbiAgcmV0dXJuIGZhbHNlO1xufVxuXG5mdW5jdGlvbiBpc0FscmVhZHlDYXB0dXJlZChleGNlcHRpb24pIHtcbiAgdHJ5IHtcbiAgICByZXR1cm4gKGV4Y2VwdGlvbiApLl9fc2VudHJ5X2NhcHR1cmVkX187XG4gIH0gY2F0Y2gge30gLy8gZXNsaW50LWRpc2FibGUtbGluZSBuby1lbXB0eVxufVxuXG5leHBvcnRzLmFkZENvbnRleHRUb0ZyYW1lID0gYWRkQ29udGV4dFRvRnJhbWU7XG5leHBvcnRzLmFkZEV4Y2VwdGlvbk1lY2hhbmlzbSA9IGFkZEV4Y2VwdGlvbk1lY2hhbmlzbTtcbmV4cG9ydHMuYWRkRXhjZXB0aW9uVHlwZVZhbHVlID0gYWRkRXhjZXB0aW9uVHlwZVZhbHVlO1xuZXhwb3J0cy5jaGVja09yU2V0QWxyZWFkeUNhdWdodCA9IGNoZWNrT3JTZXRBbHJlYWR5Q2F1Z2h0O1xuZXhwb3J0cy5nZXRFdmVudERlc2NyaXB0aW9uID0gZ2V0RXZlbnREZXNjcmlwdGlvbjtcbmV4cG9ydHMucGFyc2VTZW12ZXIgPSBwYXJzZVNlbXZlcjtcbmV4cG9ydHMudXVpZDQgPSB1dWlkNDtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPW1pc2MuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/misc.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/node-stack-trace.js":
/*!**************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/node-stack-trace.js ***!
  \**************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst stacktrace = __webpack_require__(/*! ./stacktrace.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/stacktrace.js\");\n\n/**\n * Does this filename look like it's part of the app code?\n */\nfunction filenameIsInApp(filename, isNative = false) {\n  const isInternal =\n    isNative ||\n    (filename &&\n      // It's not internal if it's an absolute linux path\n      !filename.startsWith('/') &&\n      // It's not internal if it's an absolute windows path\n      !filename.match(/^[A-Z]:/) &&\n      // It's not internal if the path is starting with a dot\n      !filename.startsWith('.') &&\n      // It's not internal if the frame has a protocol. In node, this is usually the case if the file got pre-processed with a bundler like webpack\n      !filename.match(/^[a-zA-Z]([a-zA-Z0-9.\\-+])*:\\/\\//)); // Schema from: https://stackoverflow.com/a/3641782\n\n  // in_app is all that's not an internal Node function or a module within node_modules\n  // note that isNative appears to return true even for node core libraries\n  // see https://github.com/getsentry/raven-node/issues/176\n\n  return !isInternal && filename !== undefined && !filename.includes('node_modules/');\n}\n\n/** Node Stack line parser */\nfunction node(getModule) {\n  const FILENAME_MATCH = /^\\s*[-]{4,}$/;\n  const FULL_MATCH = /at (?:async )?(?:(.+?)\\s+\\()?(?:(.+):(\\d+):(\\d+)?|([^)]+))\\)?/;\n\n  // eslint-disable-next-line complexity\n  return (line) => {\n    const lineMatch = line.match(FULL_MATCH);\n\n    if (lineMatch) {\n      let object;\n      let method;\n      let functionName;\n      let typeName;\n      let methodName;\n\n      if (lineMatch[1]) {\n        functionName = lineMatch[1];\n\n        let methodStart = functionName.lastIndexOf('.');\n        if (functionName[methodStart - 1] === '.') {\n          methodStart--;\n        }\n\n        if (methodStart > 0) {\n          object = functionName.slice(0, methodStart);\n          method = functionName.slice(methodStart + 1);\n          const objectEnd = object.indexOf('.Module');\n          if (objectEnd > 0) {\n            functionName = functionName.slice(objectEnd + 1);\n            object = object.slice(0, objectEnd);\n          }\n        }\n        typeName = undefined;\n      }\n\n      if (method) {\n        typeName = object;\n        methodName = method;\n      }\n\n      if (method === '<anonymous>') {\n        methodName = undefined;\n        functionName = undefined;\n      }\n\n      if (functionName === undefined) {\n        methodName = methodName || stacktrace.UNKNOWN_FUNCTION;\n        functionName = typeName ? `${typeName}.${methodName}` : methodName;\n      }\n\n      let filename = lineMatch[2]?.startsWith('file://') ? lineMatch[2].slice(7) : lineMatch[2];\n      const isNative = lineMatch[5] === 'native';\n\n      // If it's a Windows path, trim the leading slash so that `/C:/foo` becomes `C:/foo`\n      if (filename?.match(/\\/[A-Z]:/)) {\n        filename = filename.slice(1);\n      }\n\n      if (!filename && lineMatch[5] && !isNative) {\n        filename = lineMatch[5];\n      }\n\n      return {\n        filename: filename ? decodeURI(filename) : undefined,\n        module: getModule ? getModule(filename) : undefined,\n        function: functionName,\n        lineno: _parseIntOrUndefined(lineMatch[3]),\n        colno: _parseIntOrUndefined(lineMatch[4]),\n        in_app: filenameIsInApp(filename || '', isNative),\n      };\n    }\n\n    if (line.match(FILENAME_MATCH)) {\n      return {\n        filename: line,\n      };\n    }\n\n    return undefined;\n  };\n}\n\n/**\n * Node.js stack line parser\n *\n * This is in @sentry/core so it can be used from the Electron SDK in the browser for when `nodeIntegration == true`.\n * This allows it to be used without referencing or importing any node specific code which causes bundlers to complain\n */\nfunction nodeStackLineParser(getModule) {\n  return [90, node(getModule)];\n}\n\nfunction _parseIntOrUndefined(input) {\n  return parseInt(input || '', 10) || undefined;\n}\n\nexports.filenameIsInApp = filenameIsInApp;\nexports.node = node;\nexports.nodeStackLineParser = nodeStackLineParser;\n//# sourceMappingURL=node-stack-trace.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvbm9kZS1zdGFjay10cmFjZS5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxtQkFBbUIsbUJBQU8sQ0FBQyxzSUFBaUI7O0FBRTVDO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSw0REFBNEQ7O0FBRTVEO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQSxrQ0FBa0MsR0FBRztBQUNyQzs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0EscUNBQXFDLFNBQVMsR0FBRyxXQUFXO0FBQzVEOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBLHVCQUF1QjtBQUN2QixZQUFZO0FBQ1osMkJBQTJCO0FBQzNCIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvbm9kZS1zdGFjay10cmFjZS5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3Qgc3RhY2t0cmFjZSA9IHJlcXVpcmUoJy4vc3RhY2t0cmFjZS5qcycpO1xuXG4vKipcbiAqIERvZXMgdGhpcyBmaWxlbmFtZSBsb29rIGxpa2UgaXQncyBwYXJ0IG9mIHRoZSBhcHAgY29kZT9cbiAqL1xuZnVuY3Rpb24gZmlsZW5hbWVJc0luQXBwKGZpbGVuYW1lLCBpc05hdGl2ZSA9IGZhbHNlKSB7XG4gIGNvbnN0IGlzSW50ZXJuYWwgPVxuICAgIGlzTmF0aXZlIHx8XG4gICAgKGZpbGVuYW1lICYmXG4gICAgICAvLyBJdCdzIG5vdCBpbnRlcm5hbCBpZiBpdCdzIGFuIGFic29sdXRlIGxpbnV4IHBhdGhcbiAgICAgICFmaWxlbmFtZS5zdGFydHNXaXRoKCcvJykgJiZcbiAgICAgIC8vIEl0J3Mgbm90IGludGVybmFsIGlmIGl0J3MgYW4gYWJzb2x1dGUgd2luZG93cyBwYXRoXG4gICAgICAhZmlsZW5hbWUubWF0Y2goL15bQS1aXTovKSAmJlxuICAgICAgLy8gSXQncyBub3QgaW50ZXJuYWwgaWYgdGhlIHBhdGggaXMgc3RhcnRpbmcgd2l0aCBhIGRvdFxuICAgICAgIWZpbGVuYW1lLnN0YXJ0c1dpdGgoJy4nKSAmJlxuICAgICAgLy8gSXQncyBub3QgaW50ZXJuYWwgaWYgdGhlIGZyYW1lIGhhcyBhIHByb3RvY29sLiBJbiBub2RlLCB0aGlzIGlzIHVzdWFsbHkgdGhlIGNhc2UgaWYgdGhlIGZpbGUgZ290IHByZS1wcm9jZXNzZWQgd2l0aCBhIGJ1bmRsZXIgbGlrZSB3ZWJwYWNrXG4gICAgICAhZmlsZW5hbWUubWF0Y2goL15bYS16QS1aXShbYS16QS1aMC05LlxcLStdKSo6XFwvXFwvLykpOyAvLyBTY2hlbWEgZnJvbTogaHR0cHM6Ly9zdGFja292ZXJmbG93LmNvbS9hLzM2NDE3ODJcblxuICAvLyBpbl9hcHAgaXMgYWxsIHRoYXQncyBub3QgYW4gaW50ZXJuYWwgTm9kZSBmdW5jdGlvbiBvciBhIG1vZHVsZSB3aXRoaW4gbm9kZV9tb2R1bGVzXG4gIC8vIG5vdGUgdGhhdCBpc05hdGl2ZSBhcHBlYXJzIHRvIHJldHVybiB0cnVlIGV2ZW4gZm9yIG5vZGUgY29yZSBsaWJyYXJpZXNcbiAgLy8gc2VlIGh0dHBzOi8vZ2l0aHViLmNvbS9nZXRzZW50cnkvcmF2ZW4tbm9kZS9pc3N1ZXMvMTc2XG5cbiAgcmV0dXJuICFpc0ludGVybmFsICYmIGZpbGVuYW1lICE9PSB1bmRlZmluZWQgJiYgIWZpbGVuYW1lLmluY2x1ZGVzKCdub2RlX21vZHVsZXMvJyk7XG59XG5cbi8qKiBOb2RlIFN0YWNrIGxpbmUgcGFyc2VyICovXG5mdW5jdGlvbiBub2RlKGdldE1vZHVsZSkge1xuICBjb25zdCBGSUxFTkFNRV9NQVRDSCA9IC9eXFxzKlstXXs0LH0kLztcbiAgY29uc3QgRlVMTF9NQVRDSCA9IC9hdCAoPzphc3luYyApPyg/OiguKz8pXFxzK1xcKCk/KD86KC4rKTooXFxkKyk6KFxcZCspP3woW14pXSspKVxcKT8vO1xuXG4gIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBjb21wbGV4aXR5XG4gIHJldHVybiAobGluZSkgPT4ge1xuICAgIGNvbnN0IGxpbmVNYXRjaCA9IGxpbmUubWF0Y2goRlVMTF9NQVRDSCk7XG5cbiAgICBpZiAobGluZU1hdGNoKSB7XG4gICAgICBsZXQgb2JqZWN0O1xuICAgICAgbGV0IG1ldGhvZDtcbiAgICAgIGxldCBmdW5jdGlvbk5hbWU7XG4gICAgICBsZXQgdHlwZU5hbWU7XG4gICAgICBsZXQgbWV0aG9kTmFtZTtcblxuICAgICAgaWYgKGxpbmVNYXRjaFsxXSkge1xuICAgICAgICBmdW5jdGlvbk5hbWUgPSBsaW5lTWF0Y2hbMV07XG5cbiAgICAgICAgbGV0IG1ldGhvZFN0YXJ0ID0gZnVuY3Rpb25OYW1lLmxhc3RJbmRleE9mKCcuJyk7XG4gICAgICAgIGlmIChmdW5jdGlvbk5hbWVbbWV0aG9kU3RhcnQgLSAxXSA9PT0gJy4nKSB7XG4gICAgICAgICAgbWV0aG9kU3RhcnQtLTtcbiAgICAgICAgfVxuXG4gICAgICAgIGlmIChtZXRob2RTdGFydCA+IDApIHtcbiAgICAgICAgICBvYmplY3QgPSBmdW5jdGlvbk5hbWUuc2xpY2UoMCwgbWV0aG9kU3RhcnQpO1xuICAgICAgICAgIG1ldGhvZCA9IGZ1bmN0aW9uTmFtZS5zbGljZShtZXRob2RTdGFydCArIDEpO1xuICAgICAgICAgIGNvbnN0IG9iamVjdEVuZCA9IG9iamVjdC5pbmRleE9mKCcuTW9kdWxlJyk7XG4gICAgICAgICAgaWYgKG9iamVjdEVuZCA+IDApIHtcbiAgICAgICAgICAgIGZ1bmN0aW9uTmFtZSA9IGZ1bmN0aW9uTmFtZS5zbGljZShvYmplY3RFbmQgKyAxKTtcbiAgICAgICAgICAgIG9iamVjdCA9IG9iamVjdC5zbGljZSgwLCBvYmplY3RFbmQpO1xuICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgICB0eXBlTmFtZSA9IHVuZGVmaW5lZDtcbiAgICAgIH1cblxuICAgICAgaWYgKG1ldGhvZCkge1xuICAgICAgICB0eXBlTmFtZSA9IG9iamVjdDtcbiAgICAgICAgbWV0aG9kTmFtZSA9IG1ldGhvZDtcbiAgICAgIH1cblxuICAgICAgaWYgKG1ldGhvZCA9PT0gJzxhbm9ueW1vdXM+Jykge1xuICAgICAgICBtZXRob2ROYW1lID0gdW5kZWZpbmVkO1xuICAgICAgICBmdW5jdGlvbk5hbWUgPSB1bmRlZmluZWQ7XG4gICAgICB9XG5cbiAgICAgIGlmIChmdW5jdGlvbk5hbWUgPT09IHVuZGVmaW5lZCkge1xuICAgICAgICBtZXRob2ROYW1lID0gbWV0aG9kTmFtZSB8fCBzdGFja3RyYWNlLlVOS05PV05fRlVOQ1RJT047XG4gICAgICAgIGZ1bmN0aW9uTmFtZSA9IHR5cGVOYW1lID8gYCR7dHlwZU5hbWV9LiR7bWV0aG9kTmFtZX1gIDogbWV0aG9kTmFtZTtcbiAgICAgIH1cblxuICAgICAgbGV0IGZpbGVuYW1lID0gbGluZU1hdGNoWzJdPy5zdGFydHNXaXRoKCdmaWxlOi8vJykgPyBsaW5lTWF0Y2hbMl0uc2xpY2UoNykgOiBsaW5lTWF0Y2hbMl07XG4gICAgICBjb25zdCBpc05hdGl2ZSA9IGxpbmVNYXRjaFs1XSA9PT0gJ25hdGl2ZSc7XG5cbiAgICAgIC8vIElmIGl0J3MgYSBXaW5kb3dzIHBhdGgsIHRyaW0gdGhlIGxlYWRpbmcgc2xhc2ggc28gdGhhdCBgL0M6L2Zvb2AgYmVjb21lcyBgQzovZm9vYFxuICAgICAgaWYgKGZpbGVuYW1lPy5tYXRjaCgvXFwvW0EtWl06LykpIHtcbiAgICAgICAgZmlsZW5hbWUgPSBmaWxlbmFtZS5zbGljZSgxKTtcbiAgICAgIH1cblxuICAgICAgaWYgKCFmaWxlbmFtZSAmJiBsaW5lTWF0Y2hbNV0gJiYgIWlzTmF0aXZlKSB7XG4gICAgICAgIGZpbGVuYW1lID0gbGluZU1hdGNoWzVdO1xuICAgICAgfVxuXG4gICAgICByZXR1cm4ge1xuICAgICAgICBmaWxlbmFtZTogZmlsZW5hbWUgPyBkZWNvZGVVUkkoZmlsZW5hbWUpIDogdW5kZWZpbmVkLFxuICAgICAgICBtb2R1bGU6IGdldE1vZHVsZSA/IGdldE1vZHVsZShmaWxlbmFtZSkgOiB1bmRlZmluZWQsXG4gICAgICAgIGZ1bmN0aW9uOiBmdW5jdGlvbk5hbWUsXG4gICAgICAgIGxpbmVubzogX3BhcnNlSW50T3JVbmRlZmluZWQobGluZU1hdGNoWzNdKSxcbiAgICAgICAgY29sbm86IF9wYXJzZUludE9yVW5kZWZpbmVkKGxpbmVNYXRjaFs0XSksXG4gICAgICAgIGluX2FwcDogZmlsZW5hbWVJc0luQXBwKGZpbGVuYW1lIHx8ICcnLCBpc05hdGl2ZSksXG4gICAgICB9O1xuICAgIH1cblxuICAgIGlmIChsaW5lLm1hdGNoKEZJTEVOQU1FX01BVENIKSkge1xuICAgICAgcmV0dXJuIHtcbiAgICAgICAgZmlsZW5hbWU6IGxpbmUsXG4gICAgICB9O1xuICAgIH1cblxuICAgIHJldHVybiB1bmRlZmluZWQ7XG4gIH07XG59XG5cbi8qKlxuICogTm9kZS5qcyBzdGFjayBsaW5lIHBhcnNlclxuICpcbiAqIFRoaXMgaXMgaW4gQHNlbnRyeS9jb3JlIHNvIGl0IGNhbiBiZSB1c2VkIGZyb20gdGhlIEVsZWN0cm9uIFNESyBpbiB0aGUgYnJvd3NlciBmb3Igd2hlbiBgbm9kZUludGVncmF0aW9uID09IHRydWVgLlxuICogVGhpcyBhbGxvd3MgaXQgdG8gYmUgdXNlZCB3aXRob3V0IHJlZmVyZW5jaW5nIG9yIGltcG9ydGluZyBhbnkgbm9kZSBzcGVjaWZpYyBjb2RlIHdoaWNoIGNhdXNlcyBidW5kbGVycyB0byBjb21wbGFpblxuICovXG5mdW5jdGlvbiBub2RlU3RhY2tMaW5lUGFyc2VyKGdldE1vZHVsZSkge1xuICByZXR1cm4gWzkwLCBub2RlKGdldE1vZHVsZSldO1xufVxuXG5mdW5jdGlvbiBfcGFyc2VJbnRPclVuZGVmaW5lZChpbnB1dCkge1xuICByZXR1cm4gcGFyc2VJbnQoaW5wdXQgfHwgJycsIDEwKSB8fCB1bmRlZmluZWQ7XG59XG5cbmV4cG9ydHMuZmlsZW5hbWVJc0luQXBwID0gZmlsZW5hbWVJc0luQXBwO1xuZXhwb3J0cy5ub2RlID0gbm9kZTtcbmV4cG9ydHMubm9kZVN0YWNrTGluZVBhcnNlciA9IG5vZGVTdGFja0xpbmVQYXJzZXI7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1ub2RlLXN0YWNrLXRyYWNlLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/node-stack-trace.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/node.js":
/*!**************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/node.js ***!
  \**************************************************************************************************/
/***/ ((module, exports, __webpack_require__) => {
 
eval("/* module decorator */ module = __webpack_require__.nmd(module);\nObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst env = __webpack_require__(/*! ./env.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/env.js\");\n\n/**\n * NOTE: In order to avoid circular dependencies, if you add a function to this module and it needs to print something,\n * you must either a) use `console.log` rather than the `debug` singleton, or b) put your function elsewhere.\n */\n\n\n/**\n * Checks whether we're in the Node.js or Browser environment\n *\n * @returns Answer to given question\n */\nfunction isNodeEnv() {\n  // explicitly check for browser bundles as those can be optimized statically\n  // by terser/rollup.\n  return (\n    !env.isBrowserBundle() &&\n    Object.prototype.toString.call(typeof process !== 'undefined' ? process : 0) === '[object process]'\n  );\n}\n\n/**\n * Requires a module which is protected against bundler minification.\n *\n * @param request The module path to resolve\n */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction dynamicRequire(mod, request) {\n  // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n  return mod.require(request);\n}\n\n/**\n * Helper for dynamically loading module that should work with linked dependencies.\n * The problem is that we _should_ be using `require(require.resolve(moduleName, { paths: [cwd()] }))`\n * However it's _not possible_ to do that with Webpack, as it has to know all the dependencies during\n * build time. `require.resolve` is also not available in any other way, so we cannot create,\n * a fake helper like we do with `dynamicRequire`.\n *\n * We always prefer to use local package, thus the value is not returned early from each `try/catch` block.\n * That is to mimic the behavior of `require.resolve` exactly.\n *\n * @param moduleName module name to require\n * @param existingModule module to use for requiring\n * @returns possibly required module\n */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction loadModule(moduleName, existingModule = module) {\n  let mod;\n\n  try {\n    mod = dynamicRequire(existingModule, moduleName);\n  } catch {\n    // no-empty\n  }\n\n  if (!mod) {\n    try {\n      const { cwd } = dynamicRequire(existingModule, 'process');\n      mod = dynamicRequire(existingModule, `${cwd()}/node_modules/${moduleName}`) ;\n    } catch {\n      // no-empty\n    }\n  }\n\n  return mod;\n}\n\nexports.isNodeEnv = isNodeEnv;\nexports.loadModule = loadModule;\n//# sourceMappingURL=node.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvbm9kZS5qcyIsIm1hcHBpbmdzIjoiO0FBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsWUFBWSxtQkFBTyxDQUFDLHdIQUFVOztBQUU5QjtBQUNBO0FBQ0E7QUFDQTs7O0FBR0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLG1GQUFtRixnQkFBZ0I7QUFDbkc7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsSUFBSTtBQUNKO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLGNBQWMsTUFBTTtBQUNwQiw4Q0FBOEMsTUFBTSxnQkFBZ0IsV0FBVztBQUMvRSxNQUFNO0FBQ047QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUEsaUJBQWlCO0FBQ2pCLGtCQUFrQjtBQUNsQiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3V0aWxzL25vZGUuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGVudiA9IHJlcXVpcmUoJy4vZW52LmpzJyk7XG5cbi8qKlxuICogTk9URTogSW4gb3JkZXIgdG8gYXZvaWQgY2lyY3VsYXIgZGVwZW5kZW5jaWVzLCBpZiB5b3UgYWRkIGEgZnVuY3Rpb24gdG8gdGhpcyBtb2R1bGUgYW5kIGl0IG5lZWRzIHRvIHByaW50IHNvbWV0aGluZyxcbiAqIHlvdSBtdXN0IGVpdGhlciBhKSB1c2UgYGNvbnNvbGUubG9nYCByYXRoZXIgdGhhbiB0aGUgYGRlYnVnYCBzaW5nbGV0b24sIG9yIGIpIHB1dCB5b3VyIGZ1bmN0aW9uIGVsc2V3aGVyZS5cbiAqL1xuXG5cbi8qKlxuICogQ2hlY2tzIHdoZXRoZXIgd2UncmUgaW4gdGhlIE5vZGUuanMgb3IgQnJvd3NlciBlbnZpcm9ubWVudFxuICpcbiAqIEByZXR1cm5zIEFuc3dlciB0byBnaXZlbiBxdWVzdGlvblxuICovXG5mdW5jdGlvbiBpc05vZGVFbnYoKSB7XG4gIC8vIGV4cGxpY2l0bHkgY2hlY2sgZm9yIGJyb3dzZXIgYnVuZGxlcyBhcyB0aG9zZSBjYW4gYmUgb3B0aW1pemVkIHN0YXRpY2FsbHlcbiAgLy8gYnkgdGVyc2VyL3JvbGx1cC5cbiAgcmV0dXJuIChcbiAgICAhZW52LmlzQnJvd3NlckJ1bmRsZSgpICYmXG4gICAgT2JqZWN0LnByb3RvdHlwZS50b1N0cmluZy5jYWxsKHR5cGVvZiBwcm9jZXNzICE9PSAndW5kZWZpbmVkJyA/IHByb2Nlc3MgOiAwKSA9PT0gJ1tvYmplY3QgcHJvY2Vzc10nXG4gICk7XG59XG5cbi8qKlxuICogUmVxdWlyZXMgYSBtb2R1bGUgd2hpY2ggaXMgcHJvdGVjdGVkIGFnYWluc3QgYnVuZGxlciBtaW5pZmljYXRpb24uXG4gKlxuICogQHBhcmFtIHJlcXVlc3QgVGhlIG1vZHVsZSBwYXRoIHRvIHJlc29sdmVcbiAqL1xuLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uby1leHBsaWNpdC1hbnlcbmZ1bmN0aW9uIGR5bmFtaWNSZXF1aXJlKG1vZCwgcmVxdWVzdCkge1xuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25vLXVuc2FmZS1tZW1iZXItYWNjZXNzXG4gIHJldHVybiBtb2QucmVxdWlyZShyZXF1ZXN0KTtcbn1cblxuLyoqXG4gKiBIZWxwZXIgZm9yIGR5bmFtaWNhbGx5IGxvYWRpbmcgbW9kdWxlIHRoYXQgc2hvdWxkIHdvcmsgd2l0aCBsaW5rZWQgZGVwZW5kZW5jaWVzLlxuICogVGhlIHByb2JsZW0gaXMgdGhhdCB3ZSBfc2hvdWxkXyBiZSB1c2luZyBgcmVxdWlyZShyZXF1aXJlLnJlc29sdmUobW9kdWxlTmFtZSwgeyBwYXRoczogW2N3ZCgpXSB9KSlgXG4gKiBIb3dldmVyIGl0J3MgX25vdCBwb3NzaWJsZV8gdG8gZG8gdGhhdCB3aXRoIFdlYnBhY2ssIGFzIGl0IGhhcyB0byBrbm93IGFsbCB0aGUgZGVwZW5kZW5jaWVzIGR1cmluZ1xuICogYnVpbGQgdGltZS4gYHJlcXVpcmUucmVzb2x2ZWAgaXMgYWxzbyBub3QgYXZhaWxhYmxlIGluIGFueSBvdGhlciB3YXksIHNvIHdlIGNhbm5vdCBjcmVhdGUsXG4gKiBhIGZha2UgaGVscGVyIGxpa2Ugd2UgZG8gd2l0aCBgZHluYW1pY1JlcXVpcmVgLlxuICpcbiAqIFdlIGFsd2F5cyBwcmVmZXIgdG8gdXNlIGxvY2FsIHBhY2thZ2UsIHRodXMgdGhlIHZhbHVlIGlzIG5vdCByZXR1cm5lZCBlYXJseSBmcm9tIGVhY2ggYHRyeS9jYXRjaGAgYmxvY2suXG4gKiBUaGF0IGlzIHRvIG1pbWljIHRoZSBiZWhhdmlvciBvZiBgcmVxdWlyZS5yZXNvbHZlYCBleGFjdGx5LlxuICpcbiAqIEBwYXJhbSBtb2R1bGVOYW1lIG1vZHVsZSBuYW1lIHRvIHJlcXVpcmVcbiAqIEBwYXJhbSBleGlzdGluZ01vZHVsZSBtb2R1bGUgdG8gdXNlIGZvciByZXF1aXJpbmdcbiAqIEByZXR1cm5zIHBvc3NpYmx5IHJlcXVpcmVkIG1vZHVsZVxuICovXG4vLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25vLWV4cGxpY2l0LWFueVxuZnVuY3Rpb24gbG9hZE1vZHVsZShtb2R1bGVOYW1lLCBleGlzdGluZ01vZHVsZSA9IG1vZHVsZSkge1xuICBsZXQgbW9kO1xuXG4gIHRyeSB7XG4gICAgbW9kID0gZHluYW1pY1JlcXVpcmUoZXhpc3RpbmdNb2R1bGUsIG1vZHVsZU5hbWUpO1xuICB9IGNhdGNoIHtcbiAgICAvLyBuby1lbXB0eVxuICB9XG5cbiAgaWYgKCFtb2QpIHtcbiAgICB0cnkge1xuICAgICAgY29uc3QgeyBjd2QgfSA9IGR5bmFtaWNSZXF1aXJlKGV4aXN0aW5nTW9kdWxlLCAncHJvY2VzcycpO1xuICAgICAgbW9kID0gZHluYW1pY1JlcXVpcmUoZXhpc3RpbmdNb2R1bGUsIGAke2N3ZCgpfS9ub2RlX21vZHVsZXMvJHttb2R1bGVOYW1lfWApIDtcbiAgICB9IGNhdGNoIHtcbiAgICAgIC8vIG5vLWVtcHR5XG4gICAgfVxuICB9XG5cbiAgcmV0dXJuIG1vZDtcbn1cblxuZXhwb3J0cy5pc05vZGVFbnYgPSBpc05vZGVFbnY7XG5leHBvcnRzLmxvYWRNb2R1bGUgPSBsb2FkTW9kdWxlO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9bm9kZS5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/node.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/normalize.js":
/*!*******************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/normalize.js ***!
  \*******************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst is = __webpack_require__(/*! ./is.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js\");\nconst object = __webpack_require__(/*! ./object.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/object.js\");\nconst stacktrace = __webpack_require__(/*! ./stacktrace.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/stacktrace.js\");\n\n/**\n * Recursively normalizes the given object.\n *\n * - Creates a copy to prevent original input mutation\n * - Skips non-enumerable properties\n * - When stringifying, calls `toJSON` if implemented\n * - Removes circular references\n * - Translates non-serializable values (`undefined`/`NaN`/functions) to serializable format\n * - Translates known global objects/classes to a string representations\n * - Takes care of `Error` object serialization\n * - Optionally limits depth of final output\n * - Optionally limits number of properties/elements included in any single object/array\n *\n * @param input The object to be normalized.\n * @param depth The max depth to which to normalize the object. (Anything deeper stringified whole.)\n * @param maxProperties The max number of elements or properties to be included in any single array or\n * object in the normalized output.\n * @returns A normalized version of the object, or `\"**non-serializable**\"` if any errors are thrown during normalization.\n */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction normalize(input, depth = 100, maxProperties = +Infinity) {\n  try {\n    // since we're at the outermost level, we don't provide a key\n    return visit('', input, depth, maxProperties);\n  } catch (err) {\n    return { ERROR: `**non-serializable** (${err})` };\n  }\n}\n\n/** JSDoc */\nfunction normalizeToSize(\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  object,\n  // Default Node.js REPL depth\n  depth = 3,\n  // 100kB, as 200kB is max payload size, so half sounds reasonable\n  maxSize = 100 * 1024,\n) {\n  const normalized = normalize(object, depth);\n\n  if (jsonSize(normalized) > maxSize) {\n    return normalizeToSize(object, depth - 1, maxSize);\n  }\n\n  return normalized ;\n}\n\n/**\n * Visits a node to perform normalization on it\n *\n * @param key The key corresponding to the given node\n * @param value The node to be visited\n * @param depth Optional number indicating the maximum recursion depth\n * @param maxProperties Optional maximum number of properties/elements included in any single object/array\n * @param memo Optional Memo class handling decycling\n */\nfunction visit(\n  key,\n  value,\n  depth = +Infinity,\n  maxProperties = +Infinity,\n  memo = memoBuilder(),\n) {\n  const [memoize, unmemoize] = memo;\n\n  // Get the simple cases out of the way first\n  if (\n    value == null || // this matches null and undefined -> eqeq not eqeqeq\n    ['boolean', 'string'].includes(typeof value) ||\n    (typeof value === 'number' && Number.isFinite(value))\n  ) {\n    return value ;\n  }\n\n  const stringified = stringifyValue(key, value);\n\n  // Anything we could potentially dig into more (objects or arrays) will have come back as `\"[object XXXX]\"`.\n  // Everything else will have already been serialized, so if we don't see that pattern, we're done.\n  if (!stringified.startsWith('[object ')) {\n    return stringified;\n  }\n\n  // From here on, we can assert that `value` is either an object or an array.\n\n  // Do not normalize objects that we know have already been normalized. As a general rule, the\n  // \"__sentry_skip_normalization__\" property should only be used sparingly and only should only be set on objects that\n  // have already been normalized.\n  if ((value )['__sentry_skip_normalization__']) {\n    return value ;\n  }\n\n  // We can set `__sentry_override_normalization_depth__` on an object to ensure that from there\n  // We keep a certain amount of depth.\n  // This should be used sparingly, e.g. we use it for the redux integration to ensure we get a certain amount of state.\n  const remainingDepth =\n    typeof (value )['__sentry_override_normalization_depth__'] === 'number'\n      ? ((value )['__sentry_override_normalization_depth__'] )\n      : depth;\n\n  // We're also done if we've reached the max depth\n  if (remainingDepth === 0) {\n    // At this point we know `serialized` is a string of the form `\"[object XXXX]\"`. Clean it up so it's just `\"[XXXX]\"`.\n    return stringified.replace('object ', '');\n  }\n\n  // If we've already visited this branch, bail out, as it's circular reference. If not, note that we're seeing it now.\n  if (memoize(value)) {\n    return '[Circular ~]';\n  }\n\n  // If the value has a `toJSON` method, we call it to extract more information\n  const valueWithToJSON = value ;\n  if (valueWithToJSON && typeof valueWithToJSON.toJSON === 'function') {\n    try {\n      const jsonValue = valueWithToJSON.toJSON();\n      // We need to normalize the return value of `.toJSON()` in case it has circular references\n      return visit('', jsonValue, remainingDepth - 1, maxProperties, memo);\n    } catch {\n      // pass (The built-in `toJSON` failed, but we can still try to do it ourselves)\n    }\n  }\n\n  // At this point we know we either have an object or an array, we haven't seen it before, and we're going to recurse\n  // because we haven't yet reached the max depth. Create an accumulator to hold the results of visiting each\n  // property/entry, and keep track of the number of items we add to it.\n  const normalized = (Array.isArray(value) ? [] : {}) ;\n  let numAdded = 0;\n\n  // Before we begin, convert`Error` and`Event` instances into plain objects, since some of each of their relevant\n  // properties are non-enumerable and otherwise would get missed.\n  const visitable = object.convertToPlainObject(value );\n\n  for (const visitKey in visitable) {\n    // Avoid iterating over fields in the prototype if they've somehow been exposed to enumeration.\n    if (!Object.prototype.hasOwnProperty.call(visitable, visitKey)) {\n      continue;\n    }\n\n    if (numAdded >= maxProperties) {\n      normalized[visitKey] = '[MaxProperties ~]';\n      break;\n    }\n\n    // Recursively visit all the child nodes\n    const visitValue = visitable[visitKey];\n    normalized[visitKey] = visit(visitKey, visitValue, remainingDepth - 1, maxProperties, memo);\n\n    numAdded++;\n  }\n\n  // Once we've visited all the branches, remove the parent from memo storage\n  unmemoize(value);\n\n  // Return accumulated values\n  return normalized;\n}\n\n/* eslint-disable complexity */\n/**\n * Stringify the given value. Handles various known special values and types.\n *\n * Not meant to be used on simple primitives which already have a string representation, as it will, for example, turn\n * the number 1231 into \"[Object Number]\", nor on `null`, as it will throw.\n *\n * @param value The value to stringify\n * @returns A stringified representation of the given value\n */\nfunction stringifyValue(\n  key,\n  // this type is a tiny bit of a cheat, since this function does handle NaN (which is technically a number), but for\n  // our internal use, it'll do\n  value,\n) {\n  try {\n    if (key === 'domain' && value && typeof value === 'object' && (value )._events) {\n      return '[Domain]';\n    }\n\n    if (key === 'domainEmitter') {\n      return '[DomainEmitter]';\n    }\n\n    // It's safe to use `global`, `window`, and `document` here in this manner, as we are asserting using `typeof` first\n    // which won't throw if they are not present.\n\n    if (typeof global !== 'undefined' && value === global) {\n      return '[Global]';\n    }\n\n    // eslint-disable-next-line no-restricted-globals\n    if (typeof window !== 'undefined' && value === window) {\n      return '[Window]';\n    }\n\n    // eslint-disable-next-line no-restricted-globals\n    if (typeof document !== 'undefined' && value === document) {\n      return '[Document]';\n    }\n\n    if (is.isVueViewModel(value)) {\n      return '[VueViewModel]';\n    }\n\n    // React's SyntheticEvent thingy\n    if (is.isSyntheticEvent(value)) {\n      return '[SyntheticEvent]';\n    }\n\n    if (typeof value === 'number' && !Number.isFinite(value)) {\n      return `[${value}]`;\n    }\n\n    if (typeof value === 'function') {\n      return `[Function: ${stacktrace.getFunctionName(value)}]`;\n    }\n\n    if (typeof value === 'symbol') {\n      return `[${String(value)}]`;\n    }\n\n    // stringified BigInts are indistinguishable from regular numbers, so we need to label them to avoid confusion\n    if (typeof value === 'bigint') {\n      return `[BigInt: ${String(value)}]`;\n    }\n\n    // Now that we've knocked out all the special cases and the primitives, all we have left are objects. Simply casting\n    // them to strings means that instances of classes which haven't defined their `toStringTag` will just come out as\n    // `\"[object Object]\"`. If we instead look at the constructor's name (which is the same as the name of the class),\n    // we can make sure that only plain objects come out that way.\n    const objName = getConstructorName(value);\n\n    // Handle HTML Elements\n    if (/^HTML(\\w*)Element$/.test(objName)) {\n      return `[HTMLElement: ${objName}]`;\n    }\n\n    return `[object ${objName}]`;\n  } catch (err) {\n    return `**non-serializable** (${err})`;\n  }\n}\n/* eslint-enable complexity */\n\nfunction getConstructorName(value) {\n  const prototype = Object.getPrototypeOf(value);\n\n  return prototype?.constructor ? prototype.constructor.name : 'null prototype';\n}\n\n/** Calculates bytes size of input string */\nfunction utf8Length(value) {\n  // eslint-disable-next-line no-bitwise\n  return ~-encodeURI(value).split(/%..|./).length;\n}\n\n/** Calculates bytes size of input object */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction jsonSize(value) {\n  return utf8Length(JSON.stringify(value));\n}\n\n/**\n * Normalizes URLs in exceptions and stacktraces to a base path so Sentry can fingerprint\n * across platforms and working directory.\n *\n * @param url The URL to be normalized.\n * @param basePath The application base path.\n * @returns The normalized URL.\n */\nfunction normalizeUrlToBase(url, basePath) {\n  const escapedBase = basePath\n    // Backslash to forward\n    .replace(/\\\\/g, '/')\n    // Escape RegExp special characters\n    .replace(/[|\\\\{}()[\\]^$+*?.]/g, '\\\\$&');\n\n  let newUrl = url;\n  try {\n    newUrl = decodeURI(url);\n  } catch {\n    // Sometime this breaks\n  }\n  return (\n    newUrl\n      .replace(/\\\\/g, '/')\n      .replace(/webpack:\\/?/g, '') // Remove intermediate base path\n      // eslint-disable-next-line @sentry-internal/sdk/no-regexp-constructor\n      .replace(new RegExp(`(file://)?/*${escapedBase}/*`, 'ig'), 'app:///')\n  );\n}\n\n/**\n * Helper to decycle json objects\n */\nfunction memoBuilder() {\n  const inner = new WeakSet();\n  function memoize(obj) {\n    if (inner.has(obj)) {\n      return true;\n    }\n    inner.add(obj);\n    return false;\n  }\n\n  function unmemoize(obj) {\n    inner.delete(obj);\n  }\n  return [memoize, unmemoize];\n}\n\nexports.normalize = normalize;\nexports.normalizeToSize = normalizeToSize;\nexports.normalizeUrlToBase = normalizeUrlToBase;\n//# sourceMappingURL=normalize.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvbm9ybWFsaXplLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLFdBQVcsbUJBQU8sQ0FBQyxzSEFBUztBQUM1QixlQUFlLG1CQUFPLENBQUMsOEhBQWE7QUFDcEMsbUJBQW1CLG1CQUFPLENBQUMsc0lBQWlCOztBQUU1QztBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxJQUFJO0FBQ0osYUFBYSxnQ0FBZ0MsSUFBSTtBQUNqRDtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsTUFBTTtBQUNOO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQSxvREFBb0Q7QUFDcEQ7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0EsaUJBQWlCLE1BQU07QUFDdkI7O0FBRUE7QUFDQSwyQkFBMkIsa0NBQWtDO0FBQzdEOztBQUVBO0FBQ0EsaUJBQWlCLGNBQWM7QUFDL0I7O0FBRUE7QUFDQTtBQUNBLHlCQUF5QixjQUFjO0FBQ3ZDOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLDhCQUE4QixRQUFRO0FBQ3RDOztBQUVBLHNCQUFzQixRQUFRO0FBQzlCLElBQUk7QUFDSixvQ0FBb0MsSUFBSTtBQUN4QztBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLG9CQUFvQjs7QUFFcEI7QUFDQTtBQUNBO0FBQ0EsSUFBSTtBQUNKO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EseUNBQXlDLFlBQVk7QUFDckQ7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSxpQkFBaUI7QUFDakIsdUJBQXVCO0FBQ3ZCLDBCQUEwQjtBQUMxQiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3V0aWxzL25vcm1hbGl6ZS5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgaXMgPSByZXF1aXJlKCcuL2lzLmpzJyk7XG5jb25zdCBvYmplY3QgPSByZXF1aXJlKCcuL29iamVjdC5qcycpO1xuY29uc3Qgc3RhY2t0cmFjZSA9IHJlcXVpcmUoJy4vc3RhY2t0cmFjZS5qcycpO1xuXG4vKipcbiAqIFJlY3Vyc2l2ZWx5IG5vcm1hbGl6ZXMgdGhlIGdpdmVuIG9iamVjdC5cbiAqXG4gKiAtIENyZWF0ZXMgYSBjb3B5IHRvIHByZXZlbnQgb3JpZ2luYWwgaW5wdXQgbXV0YXRpb25cbiAqIC0gU2tpcHMgbm9uLWVudW1lcmFibGUgcHJvcGVydGllc1xuICogLSBXaGVuIHN0cmluZ2lmeWluZywgY2FsbHMgYHRvSlNPTmAgaWYgaW1wbGVtZW50ZWRcbiAqIC0gUmVtb3ZlcyBjaXJjdWxhciByZWZlcmVuY2VzXG4gKiAtIFRyYW5zbGF0ZXMgbm9uLXNlcmlhbGl6YWJsZSB2YWx1ZXMgKGB1bmRlZmluZWRgL2BOYU5gL2Z1bmN0aW9ucykgdG8gc2VyaWFsaXphYmxlIGZvcm1hdFxuICogLSBUcmFuc2xhdGVzIGtub3duIGdsb2JhbCBvYmplY3RzL2NsYXNzZXMgdG8gYSBzdHJpbmcgcmVwcmVzZW50YXRpb25zXG4gKiAtIFRha2VzIGNhcmUgb2YgYEVycm9yYCBvYmplY3Qgc2VyaWFsaXphdGlvblxuICogLSBPcHRpb25hbGx5IGxpbWl0cyBkZXB0aCBvZiBmaW5hbCBvdXRwdXRcbiAqIC0gT3B0aW9uYWxseSBsaW1pdHMgbnVtYmVyIG9mIHByb3BlcnRpZXMvZWxlbWVudHMgaW5jbHVkZWQgaW4gYW55IHNpbmdsZSBvYmplY3QvYXJyYXlcbiAqXG4gKiBAcGFyYW0gaW5wdXQgVGhlIG9iamVjdCB0byBiZSBub3JtYWxpemVkLlxuICogQHBhcmFtIGRlcHRoIFRoZSBtYXggZGVwdGggdG8gd2hpY2ggdG8gbm9ybWFsaXplIHRoZSBvYmplY3QuIChBbnl0aGluZyBkZWVwZXIgc3RyaW5naWZpZWQgd2hvbGUuKVxuICogQHBhcmFtIG1heFByb3BlcnRpZXMgVGhlIG1heCBudW1iZXIgb2YgZWxlbWVudHMgb3IgcHJvcGVydGllcyB0byBiZSBpbmNsdWRlZCBpbiBhbnkgc2luZ2xlIGFycmF5IG9yXG4gKiBvYmplY3QgaW4gdGhlIG5vcm1hbGl6ZWQgb3V0cHV0LlxuICogQHJldHVybnMgQSBub3JtYWxpemVkIHZlcnNpb24gb2YgdGhlIG9iamVjdCwgb3IgYFwiKipub24tc2VyaWFsaXphYmxlKipcImAgaWYgYW55IGVycm9ycyBhcmUgdGhyb3duIGR1cmluZyBub3JtYWxpemF0aW9uLlxuICovXG4vLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25vLWV4cGxpY2l0LWFueVxuZnVuY3Rpb24gbm9ybWFsaXplKGlucHV0LCBkZXB0aCA9IDEwMCwgbWF4UHJvcGVydGllcyA9ICtJbmZpbml0eSkge1xuICB0cnkge1xuICAgIC8vIHNpbmNlIHdlJ3JlIGF0IHRoZSBvdXRlcm1vc3QgbGV2ZWwsIHdlIGRvbid0IHByb3ZpZGUgYSBrZXlcbiAgICByZXR1cm4gdmlzaXQoJycsIGlucHV0LCBkZXB0aCwgbWF4UHJvcGVydGllcyk7XG4gIH0gY2F0Y2ggKGVycikge1xuICAgIHJldHVybiB7IEVSUk9SOiBgKipub24tc2VyaWFsaXphYmxlKiogKCR7ZXJyfSlgIH07XG4gIH1cbn1cblxuLyoqIEpTRG9jICovXG5mdW5jdGlvbiBub3JtYWxpemVUb1NpemUoXG4gIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tZXhwbGljaXQtYW55XG4gIG9iamVjdCxcbiAgLy8gRGVmYXVsdCBOb2RlLmpzIFJFUEwgZGVwdGhcbiAgZGVwdGggPSAzLFxuICAvLyAxMDBrQiwgYXMgMjAwa0IgaXMgbWF4IHBheWxvYWQgc2l6ZSwgc28gaGFsZiBzb3VuZHMgcmVhc29uYWJsZVxuICBtYXhTaXplID0gMTAwICogMTAyNCxcbikge1xuICBjb25zdCBub3JtYWxpemVkID0gbm9ybWFsaXplKG9iamVjdCwgZGVwdGgpO1xuXG4gIGlmIChqc29uU2l6ZShub3JtYWxpemVkKSA+IG1heFNpemUpIHtcbiAgICByZXR1cm4gbm9ybWFsaXplVG9TaXplKG9iamVjdCwgZGVwdGggLSAxLCBtYXhTaXplKTtcbiAgfVxuXG4gIHJldHVybiBub3JtYWxpemVkIDtcbn1cblxuLyoqXG4gKiBWaXNpdHMgYSBub2RlIHRvIHBlcmZvcm0gbm9ybWFsaXphdGlvbiBvbiBpdFxuICpcbiAqIEBwYXJhbSBrZXkgVGhlIGtleSBjb3JyZXNwb25kaW5nIHRvIHRoZSBnaXZlbiBub2RlXG4gKiBAcGFyYW0gdmFsdWUgVGhlIG5vZGUgdG8gYmUgdmlzaXRlZFxuICogQHBhcmFtIGRlcHRoIE9wdGlvbmFsIG51bWJlciBpbmRpY2F0aW5nIHRoZSBtYXhpbXVtIHJlY3Vyc2lvbiBkZXB0aFxuICogQHBhcmFtIG1heFByb3BlcnRpZXMgT3B0aW9uYWwgbWF4aW11bSBudW1iZXIgb2YgcHJvcGVydGllcy9lbGVtZW50cyBpbmNsdWRlZCBpbiBhbnkgc2luZ2xlIG9iamVjdC9hcnJheVxuICogQHBhcmFtIG1lbW8gT3B0aW9uYWwgTWVtbyBjbGFzcyBoYW5kbGluZyBkZWN5Y2xpbmdcbiAqL1xuZnVuY3Rpb24gdmlzaXQoXG4gIGtleSxcbiAgdmFsdWUsXG4gIGRlcHRoID0gK0luZmluaXR5LFxuICBtYXhQcm9wZXJ0aWVzID0gK0luZmluaXR5LFxuICBtZW1vID0gbWVtb0J1aWxkZXIoKSxcbikge1xuICBjb25zdCBbbWVtb2l6ZSwgdW5tZW1vaXplXSA9IG1lbW87XG5cbiAgLy8gR2V0IHRoZSBzaW1wbGUgY2FzZXMgb3V0IG9mIHRoZSB3YXkgZmlyc3RcbiAgaWYgKFxuICAgIHZhbHVlID09IG51bGwgfHwgLy8gdGhpcyBtYXRjaGVzIG51bGwgYW5kIHVuZGVmaW5lZCAtPiBlcWVxIG5vdCBlcWVxZXFcbiAgICBbJ2Jvb2xlYW4nLCAnc3RyaW5nJ10uaW5jbHVkZXModHlwZW9mIHZhbHVlKSB8fFxuICAgICh0eXBlb2YgdmFsdWUgPT09ICdudW1iZXInICYmIE51bWJlci5pc0Zpbml0ZSh2YWx1ZSkpXG4gICkge1xuICAgIHJldHVybiB2YWx1ZSA7XG4gIH1cblxuICBjb25zdCBzdHJpbmdpZmllZCA9IHN0cmluZ2lmeVZhbHVlKGtleSwgdmFsdWUpO1xuXG4gIC8vIEFueXRoaW5nIHdlIGNvdWxkIHBvdGVudGlhbGx5IGRpZyBpbnRvIG1vcmUgKG9iamVjdHMgb3IgYXJyYXlzKSB3aWxsIGhhdmUgY29tZSBiYWNrIGFzIGBcIltvYmplY3QgWFhYWF1cImAuXG4gIC8vIEV2ZXJ5dGhpbmcgZWxzZSB3aWxsIGhhdmUgYWxyZWFkeSBiZWVuIHNlcmlhbGl6ZWQsIHNvIGlmIHdlIGRvbid0IHNlZSB0aGF0IHBhdHRlcm4sIHdlJ3JlIGRvbmUuXG4gIGlmICghc3RyaW5naWZpZWQuc3RhcnRzV2l0aCgnW29iamVjdCAnKSkge1xuICAgIHJldHVybiBzdHJpbmdpZmllZDtcbiAgfVxuXG4gIC8vIEZyb20gaGVyZSBvbiwgd2UgY2FuIGFzc2VydCB0aGF0IGB2YWx1ZWAgaXMgZWl0aGVyIGFuIG9iamVjdCBvciBhbiBhcnJheS5cblxuICAvLyBEbyBub3Qgbm9ybWFsaXplIG9iamVjdHMgdGhhdCB3ZSBrbm93IGhhdmUgYWxyZWFkeSBiZWVuIG5vcm1hbGl6ZWQuIEFzIGEgZ2VuZXJhbCBydWxlLCB0aGVcbiAgLy8gXCJfX3NlbnRyeV9za2lwX25vcm1hbGl6YXRpb25fX1wiIHByb3BlcnR5IHNob3VsZCBvbmx5IGJlIHVzZWQgc3BhcmluZ2x5IGFuZCBvbmx5IHNob3VsZCBvbmx5IGJlIHNldCBvbiBvYmplY3RzIHRoYXRcbiAgLy8gaGF2ZSBhbHJlYWR5IGJlZW4gbm9ybWFsaXplZC5cbiAgaWYgKCh2YWx1ZSApWydfX3NlbnRyeV9za2lwX25vcm1hbGl6YXRpb25fXyddKSB7XG4gICAgcmV0dXJuIHZhbHVlIDtcbiAgfVxuXG4gIC8vIFdlIGNhbiBzZXQgYF9fc2VudHJ5X292ZXJyaWRlX25vcm1hbGl6YXRpb25fZGVwdGhfX2Agb24gYW4gb2JqZWN0IHRvIGVuc3VyZSB0aGF0IGZyb20gdGhlcmVcbiAgLy8gV2Uga2VlcCBhIGNlcnRhaW4gYW1vdW50IG9mIGRlcHRoLlxuICAvLyBUaGlzIHNob3VsZCBiZSB1c2VkIHNwYXJpbmdseSwgZS5nLiB3ZSB1c2UgaXQgZm9yIHRoZSByZWR1eCBpbnRlZ3JhdGlvbiB0byBlbnN1cmUgd2UgZ2V0IGEgY2VydGFpbiBhbW91bnQgb2Ygc3RhdGUuXG4gIGNvbnN0IHJlbWFpbmluZ0RlcHRoID1cbiAgICB0eXBlb2YgKHZhbHVlIClbJ19fc2VudHJ5X292ZXJyaWRlX25vcm1hbGl6YXRpb25fZGVwdGhfXyddID09PSAnbnVtYmVyJ1xuICAgICAgPyAoKHZhbHVlIClbJ19fc2VudHJ5X292ZXJyaWRlX25vcm1hbGl6YXRpb25fZGVwdGhfXyddIClcbiAgICAgIDogZGVwdGg7XG5cbiAgLy8gV2UncmUgYWxzbyBkb25lIGlmIHdlJ3ZlIHJlYWNoZWQgdGhlIG1heCBkZXB0aFxuICBpZiAocmVtYWluaW5nRGVwdGggPT09IDApIHtcbiAgICAvLyBBdCB0aGlzIHBvaW50IHdlIGtub3cgYHNlcmlhbGl6ZWRgIGlzIGEgc3RyaW5nIG9mIHRoZSBmb3JtIGBcIltvYmplY3QgWFhYWF1cImAuIENsZWFuIGl0IHVwIHNvIGl0J3MganVzdCBgXCJbWFhYWF1cImAuXG4gICAgcmV0dXJuIHN0cmluZ2lmaWVkLnJlcGxhY2UoJ29iamVjdCAnLCAnJyk7XG4gIH1cblxuICAvLyBJZiB3ZSd2ZSBhbHJlYWR5IHZpc2l0ZWQgdGhpcyBicmFuY2gsIGJhaWwgb3V0LCBhcyBpdCdzIGNpcmN1bGFyIHJlZmVyZW5jZS4gSWYgbm90LCBub3RlIHRoYXQgd2UncmUgc2VlaW5nIGl0IG5vdy5cbiAgaWYgKG1lbW9pemUodmFsdWUpKSB7XG4gICAgcmV0dXJuICdbQ2lyY3VsYXIgfl0nO1xuICB9XG5cbiAgLy8gSWYgdGhlIHZhbHVlIGhhcyBhIGB0b0pTT05gIG1ldGhvZCwgd2UgY2FsbCBpdCB0byBleHRyYWN0IG1vcmUgaW5mb3JtYXRpb25cbiAgY29uc3QgdmFsdWVXaXRoVG9KU09OID0gdmFsdWUgO1xuICBpZiAodmFsdWVXaXRoVG9KU09OICYmIHR5cGVvZiB2YWx1ZVdpdGhUb0pTT04udG9KU09OID09PSAnZnVuY3Rpb24nKSB7XG4gICAgdHJ5IHtcbiAgICAgIGNvbnN0IGpzb25WYWx1ZSA9IHZhbHVlV2l0aFRvSlNPTi50b0pTT04oKTtcbiAgICAgIC8vIFdlIG5lZWQgdG8gbm9ybWFsaXplIHRoZSByZXR1cm4gdmFsdWUgb2YgYC50b0pTT04oKWAgaW4gY2FzZSBpdCBoYXMgY2lyY3VsYXIgcmVmZXJlbmNlc1xuICAgICAgcmV0dXJuIHZpc2l0KCcnLCBqc29uVmFsdWUsIHJlbWFpbmluZ0RlcHRoIC0gMSwgbWF4UHJvcGVydGllcywgbWVtbyk7XG4gICAgfSBjYXRjaCB7XG4gICAgICAvLyBwYXNzIChUaGUgYnVpbHQtaW4gYHRvSlNPTmAgZmFpbGVkLCBidXQgd2UgY2FuIHN0aWxsIHRyeSB0byBkbyBpdCBvdXJzZWx2ZXMpXG4gICAgfVxuICB9XG5cbiAgLy8gQXQgdGhpcyBwb2ludCB3ZSBrbm93IHdlIGVpdGhlciBoYXZlIGFuIG9iamVjdCBvciBhbiBhcnJheSwgd2UgaGF2ZW4ndCBzZWVuIGl0IGJlZm9yZSwgYW5kIHdlJ3JlIGdvaW5nIHRvIHJlY3Vyc2VcbiAgLy8gYmVjYXVzZSB3ZSBoYXZlbid0IHlldCByZWFjaGVkIHRoZSBtYXggZGVwdGguIENyZWF0ZSBhbiBhY2N1bXVsYXRvciB0byBob2xkIHRoZSByZXN1bHRzIG9mIHZpc2l0aW5nIGVhY2hcbiAgLy8gcHJvcGVydHkvZW50cnksIGFuZCBrZWVwIHRyYWNrIG9mIHRoZSBudW1iZXIgb2YgaXRlbXMgd2UgYWRkIHRvIGl0LlxuICBjb25zdCBub3JtYWxpemVkID0gKEFycmF5LmlzQXJyYXkodmFsdWUpID8gW10gOiB7fSkgO1xuICBsZXQgbnVtQWRkZWQgPSAwO1xuXG4gIC8vIEJlZm9yZSB3ZSBiZWdpbiwgY29udmVydGBFcnJvcmAgYW5kYEV2ZW50YCBpbnN0YW5jZXMgaW50byBwbGFpbiBvYmplY3RzLCBzaW5jZSBzb21lIG9mIGVhY2ggb2YgdGhlaXIgcmVsZXZhbnRcbiAgLy8gcHJvcGVydGllcyBhcmUgbm9uLWVudW1lcmFibGUgYW5kIG90aGVyd2lzZSB3b3VsZCBnZXQgbWlzc2VkLlxuICBjb25zdCB2aXNpdGFibGUgPSBvYmplY3QuY29udmVydFRvUGxhaW5PYmplY3QodmFsdWUgKTtcblxuICBmb3IgKGNvbnN0IHZpc2l0S2V5IGluIHZpc2l0YWJsZSkge1xuICAgIC8vIEF2b2lkIGl0ZXJhdGluZyBvdmVyIGZpZWxkcyBpbiB0aGUgcHJvdG90eXBlIGlmIHRoZXkndmUgc29tZWhvdyBiZWVuIGV4cG9zZWQgdG8gZW51bWVyYXRpb24uXG4gICAgaWYgKCFPYmplY3QucHJvdG90eXBlLmhhc093blByb3BlcnR5LmNhbGwodmlzaXRhYmxlLCB2aXNpdEtleSkpIHtcbiAgICAgIGNvbnRpbnVlO1xuICAgIH1cblxuICAgIGlmIChudW1BZGRlZCA+PSBtYXhQcm9wZXJ0aWVzKSB7XG4gICAgICBub3JtYWxpemVkW3Zpc2l0S2V5XSA9ICdbTWF4UHJvcGVydGllcyB+XSc7XG4gICAgICBicmVhaztcbiAgICB9XG5cbiAgICAvLyBSZWN1cnNpdmVseSB2aXNpdCBhbGwgdGhlIGNoaWxkIG5vZGVzXG4gICAgY29uc3QgdmlzaXRWYWx1ZSA9IHZpc2l0YWJsZVt2aXNpdEtleV07XG4gICAgbm9ybWFsaXplZFt2aXNpdEtleV0gPSB2aXNpdCh2aXNpdEtleSwgdmlzaXRWYWx1ZSwgcmVtYWluaW5nRGVwdGggLSAxLCBtYXhQcm9wZXJ0aWVzLCBtZW1vKTtcblxuICAgIG51bUFkZGVkKys7XG4gIH1cblxuICAvLyBPbmNlIHdlJ3ZlIHZpc2l0ZWQgYWxsIHRoZSBicmFuY2hlcywgcmVtb3ZlIHRoZSBwYXJlbnQgZnJvbSBtZW1vIHN0b3JhZ2VcbiAgdW5tZW1vaXplKHZhbHVlKTtcblxuICAvLyBSZXR1cm4gYWNjdW11bGF0ZWQgdmFsdWVzXG4gIHJldHVybiBub3JtYWxpemVkO1xufVxuXG4vKiBlc2xpbnQtZGlzYWJsZSBjb21wbGV4aXR5ICovXG4vKipcbiAqIFN0cmluZ2lmeSB0aGUgZ2l2ZW4gdmFsdWUuIEhhbmRsZXMgdmFyaW91cyBrbm93biBzcGVjaWFsIHZhbHVlcyBhbmQgdHlwZXMuXG4gKlxuICogTm90IG1lYW50IHRvIGJlIHVzZWQgb24gc2ltcGxlIHByaW1pdGl2ZXMgd2hpY2ggYWxyZWFkeSBoYXZlIGEgc3RyaW5nIHJlcHJlc2VudGF0aW9uLCBhcyBpdCB3aWxsLCBmb3IgZXhhbXBsZSwgdHVyblxuICogdGhlIG51bWJlciAxMjMxIGludG8gXCJbT2JqZWN0IE51bWJlcl1cIiwgbm9yIG9uIGBudWxsYCwgYXMgaXQgd2lsbCB0aHJvdy5cbiAqXG4gKiBAcGFyYW0gdmFsdWUgVGhlIHZhbHVlIHRvIHN0cmluZ2lmeVxuICogQHJldHVybnMgQSBzdHJpbmdpZmllZCByZXByZXNlbnRhdGlvbiBvZiB0aGUgZ2l2ZW4gdmFsdWVcbiAqL1xuZnVuY3Rpb24gc3RyaW5naWZ5VmFsdWUoXG4gIGtleSxcbiAgLy8gdGhpcyB0eXBlIGlzIGEgdGlueSBiaXQgb2YgYSBjaGVhdCwgc2luY2UgdGhpcyBmdW5jdGlvbiBkb2VzIGhhbmRsZSBOYU4gKHdoaWNoIGlzIHRlY2huaWNhbGx5IGEgbnVtYmVyKSwgYnV0IGZvclxuICAvLyBvdXIgaW50ZXJuYWwgdXNlLCBpdCdsbCBkb1xuICB2YWx1ZSxcbikge1xuICB0cnkge1xuICAgIGlmIChrZXkgPT09ICdkb21haW4nICYmIHZhbHVlICYmIHR5cGVvZiB2YWx1ZSA9PT0gJ29iamVjdCcgJiYgKHZhbHVlICkuX2V2ZW50cykge1xuICAgICAgcmV0dXJuICdbRG9tYWluXSc7XG4gICAgfVxuXG4gICAgaWYgKGtleSA9PT0gJ2RvbWFpbkVtaXR0ZXInKSB7XG4gICAgICByZXR1cm4gJ1tEb21haW5FbWl0dGVyXSc7XG4gICAgfVxuXG4gICAgLy8gSXQncyBzYWZlIHRvIHVzZSBgZ2xvYmFsYCwgYHdpbmRvd2AsIGFuZCBgZG9jdW1lbnRgIGhlcmUgaW4gdGhpcyBtYW5uZXIsIGFzIHdlIGFyZSBhc3NlcnRpbmcgdXNpbmcgYHR5cGVvZmAgZmlyc3RcbiAgICAvLyB3aGljaCB3b24ndCB0aHJvdyBpZiB0aGV5IGFyZSBub3QgcHJlc2VudC5cblxuICAgIGlmICh0eXBlb2YgZ2xvYmFsICE9PSAndW5kZWZpbmVkJyAmJiB2YWx1ZSA9PT0gZ2xvYmFsKSB7XG4gICAgICByZXR1cm4gJ1tHbG9iYWxdJztcbiAgICB9XG5cbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgbm8tcmVzdHJpY3RlZC1nbG9iYWxzXG4gICAgaWYgKHR5cGVvZiB3aW5kb3cgIT09ICd1bmRlZmluZWQnICYmIHZhbHVlID09PSB3aW5kb3cpIHtcbiAgICAgIHJldHVybiAnW1dpbmRvd10nO1xuICAgIH1cblxuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBuby1yZXN0cmljdGVkLWdsb2JhbHNcbiAgICBpZiAodHlwZW9mIGRvY3VtZW50ICE9PSAndW5kZWZpbmVkJyAmJiB2YWx1ZSA9PT0gZG9jdW1lbnQpIHtcbiAgICAgIHJldHVybiAnW0RvY3VtZW50XSc7XG4gICAgfVxuXG4gICAgaWYgKGlzLmlzVnVlVmlld01vZGVsKHZhbHVlKSkge1xuICAgICAgcmV0dXJuICdbVnVlVmlld01vZGVsXSc7XG4gICAgfVxuXG4gICAgLy8gUmVhY3QncyBTeW50aGV0aWNFdmVudCB0aGluZ3lcbiAgICBpZiAoaXMuaXNTeW50aGV0aWNFdmVudCh2YWx1ZSkpIHtcbiAgICAgIHJldHVybiAnW1N5bnRoZXRpY0V2ZW50XSc7XG4gICAgfVxuXG4gICAgaWYgKHR5cGVvZiB2YWx1ZSA9PT0gJ251bWJlcicgJiYgIU51bWJlci5pc0Zpbml0ZSh2YWx1ZSkpIHtcbiAgICAgIHJldHVybiBgWyR7dmFsdWV9XWA7XG4gICAgfVxuXG4gICAgaWYgKHR5cGVvZiB2YWx1ZSA9PT0gJ2Z1bmN0aW9uJykge1xuICAgICAgcmV0dXJuIGBbRnVuY3Rpb246ICR7c3RhY2t0cmFjZS5nZXRGdW5jdGlvbk5hbWUodmFsdWUpfV1gO1xuICAgIH1cblxuICAgIGlmICh0eXBlb2YgdmFsdWUgPT09ICdzeW1ib2wnKSB7XG4gICAgICByZXR1cm4gYFske1N0cmluZyh2YWx1ZSl9XWA7XG4gICAgfVxuXG4gICAgLy8gc3RyaW5naWZpZWQgQmlnSW50cyBhcmUgaW5kaXN0aW5ndWlzaGFibGUgZnJvbSByZWd1bGFyIG51bWJlcnMsIHNvIHdlIG5lZWQgdG8gbGFiZWwgdGhlbSB0byBhdm9pZCBjb25mdXNpb25cbiAgICBpZiAodHlwZW9mIHZhbHVlID09PSAnYmlnaW50Jykge1xuICAgICAgcmV0dXJuIGBbQmlnSW50OiAke1N0cmluZyh2YWx1ZSl9XWA7XG4gICAgfVxuXG4gICAgLy8gTm93IHRoYXQgd2UndmUga25vY2tlZCBvdXQgYWxsIHRoZSBzcGVjaWFsIGNhc2VzIGFuZCB0aGUgcHJpbWl0aXZlcywgYWxsIHdlIGhhdmUgbGVmdCBhcmUgb2JqZWN0cy4gU2ltcGx5IGNhc3RpbmdcbiAgICAvLyB0aGVtIHRvIHN0cmluZ3MgbWVhbnMgdGhhdCBpbnN0YW5jZXMgb2YgY2xhc3NlcyB3aGljaCBoYXZlbid0IGRlZmluZWQgdGhlaXIgYHRvU3RyaW5nVGFnYCB3aWxsIGp1c3QgY29tZSBvdXQgYXNcbiAgICAvLyBgXCJbb2JqZWN0IE9iamVjdF1cImAuIElmIHdlIGluc3RlYWQgbG9vayBhdCB0aGUgY29uc3RydWN0b3IncyBuYW1lICh3aGljaCBpcyB0aGUgc2FtZSBhcyB0aGUgbmFtZSBvZiB0aGUgY2xhc3MpLFxuICAgIC8vIHdlIGNhbiBtYWtlIHN1cmUgdGhhdCBvbmx5IHBsYWluIG9iamVjdHMgY29tZSBvdXQgdGhhdCB3YXkuXG4gICAgY29uc3Qgb2JqTmFtZSA9IGdldENvbnN0cnVjdG9yTmFtZSh2YWx1ZSk7XG5cbiAgICAvLyBIYW5kbGUgSFRNTCBFbGVtZW50c1xuICAgIGlmICgvXkhUTUwoXFx3KilFbGVtZW50JC8udGVzdChvYmpOYW1lKSkge1xuICAgICAgcmV0dXJuIGBbSFRNTEVsZW1lbnQ6ICR7b2JqTmFtZX1dYDtcbiAgICB9XG5cbiAgICByZXR1cm4gYFtvYmplY3QgJHtvYmpOYW1lfV1gO1xuICB9IGNhdGNoIChlcnIpIHtcbiAgICByZXR1cm4gYCoqbm9uLXNlcmlhbGl6YWJsZSoqICgke2Vycn0pYDtcbiAgfVxufVxuLyogZXNsaW50LWVuYWJsZSBjb21wbGV4aXR5ICovXG5cbmZ1bmN0aW9uIGdldENvbnN0cnVjdG9yTmFtZSh2YWx1ZSkge1xuICBjb25zdCBwcm90b3R5cGUgPSBPYmplY3QuZ2V0UHJvdG90eXBlT2YodmFsdWUpO1xuXG4gIHJldHVybiBwcm90b3R5cGU/LmNvbnN0cnVjdG9yID8gcHJvdG90eXBlLmNvbnN0cnVjdG9yLm5hbWUgOiAnbnVsbCBwcm90b3R5cGUnO1xufVxuXG4vKiogQ2FsY3VsYXRlcyBieXRlcyBzaXplIG9mIGlucHV0IHN0cmluZyAqL1xuZnVuY3Rpb24gdXRmOExlbmd0aCh2YWx1ZSkge1xuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgbm8tYml0d2lzZVxuICByZXR1cm4gfi1lbmNvZGVVUkkodmFsdWUpLnNwbGl0KC8lLi58Li8pLmxlbmd0aDtcbn1cblxuLyoqIENhbGN1bGF0ZXMgYnl0ZXMgc2l6ZSBvZiBpbnB1dCBvYmplY3QgKi9cbi8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tZXhwbGljaXQtYW55XG5mdW5jdGlvbiBqc29uU2l6ZSh2YWx1ZSkge1xuICByZXR1cm4gdXRmOExlbmd0aChKU09OLnN0cmluZ2lmeSh2YWx1ZSkpO1xufVxuXG4vKipcbiAqIE5vcm1hbGl6ZXMgVVJMcyBpbiBleGNlcHRpb25zIGFuZCBzdGFja3RyYWNlcyB0byBhIGJhc2UgcGF0aCBzbyBTZW50cnkgY2FuIGZpbmdlcnByaW50XG4gKiBhY3Jvc3MgcGxhdGZvcm1zIGFuZCB3b3JraW5nIGRpcmVjdG9yeS5cbiAqXG4gKiBAcGFyYW0gdXJsIFRoZSBVUkwgdG8gYmUgbm9ybWFsaXplZC5cbiAqIEBwYXJhbSBiYXNlUGF0aCBUaGUgYXBwbGljYXRpb24gYmFzZSBwYXRoLlxuICogQHJldHVybnMgVGhlIG5vcm1hbGl6ZWQgVVJMLlxuICovXG5mdW5jdGlvbiBub3JtYWxpemVVcmxUb0Jhc2UodXJsLCBiYXNlUGF0aCkge1xuICBjb25zdCBlc2NhcGVkQmFzZSA9IGJhc2VQYXRoXG4gICAgLy8gQmFja3NsYXNoIHRvIGZvcndhcmRcbiAgICAucmVwbGFjZSgvXFxcXC9nLCAnLycpXG4gICAgLy8gRXNjYXBlIFJlZ0V4cCBzcGVjaWFsIGNoYXJhY3RlcnNcbiAgICAucmVwbGFjZSgvW3xcXFxce30oKVtcXF1eJCsqPy5dL2csICdcXFxcJCYnKTtcblxuICBsZXQgbmV3VXJsID0gdXJsO1xuICB0cnkge1xuICAgIG5ld1VybCA9IGRlY29kZVVSSSh1cmwpO1xuICB9IGNhdGNoIHtcbiAgICAvLyBTb21ldGltZSB0aGlzIGJyZWFrc1xuICB9XG4gIHJldHVybiAoXG4gICAgbmV3VXJsXG4gICAgICAucmVwbGFjZSgvXFxcXC9nLCAnLycpXG4gICAgICAucmVwbGFjZSgvd2VicGFjazpcXC8/L2csICcnKSAvLyBSZW1vdmUgaW50ZXJtZWRpYXRlIGJhc2UgcGF0aFxuICAgICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEBzZW50cnktaW50ZXJuYWwvc2RrL25vLXJlZ2V4cC1jb25zdHJ1Y3RvclxuICAgICAgLnJlcGxhY2UobmV3IFJlZ0V4cChgKGZpbGU6Ly8pPy8qJHtlc2NhcGVkQmFzZX0vKmAsICdpZycpLCAnYXBwOi8vLycpXG4gICk7XG59XG5cbi8qKlxuICogSGVscGVyIHRvIGRlY3ljbGUganNvbiBvYmplY3RzXG4gKi9cbmZ1bmN0aW9uIG1lbW9CdWlsZGVyKCkge1xuICBjb25zdCBpbm5lciA9IG5ldyBXZWFrU2V0KCk7XG4gIGZ1bmN0aW9uIG1lbW9pemUob2JqKSB7XG4gICAgaWYgKGlubmVyLmhhcyhvYmopKSB7XG4gICAgICByZXR1cm4gdHJ1ZTtcbiAgICB9XG4gICAgaW5uZXIuYWRkKG9iaik7XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG5cbiAgZnVuY3Rpb24gdW5tZW1vaXplKG9iaikge1xuICAgIGlubmVyLmRlbGV0ZShvYmopO1xuICB9XG4gIHJldHVybiBbbWVtb2l6ZSwgdW5tZW1vaXplXTtcbn1cblxuZXhwb3J0cy5ub3JtYWxpemUgPSBub3JtYWxpemU7XG5leHBvcnRzLm5vcm1hbGl6ZVRvU2l6ZSA9IG5vcm1hbGl6ZVRvU2l6ZTtcbmV4cG9ydHMubm9ybWFsaXplVXJsVG9CYXNlID0gbm9ybWFsaXplVXJsVG9CYXNlO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9bm9ybWFsaXplLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/normalize.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/object.js":
/*!****************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/object.js ***!
  \****************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst debugBuild = __webpack_require__(/*! ../debug-build.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst browser = __webpack_require__(/*! ./browser.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/browser.js\");\nconst debugLogger = __webpack_require__(/*! ./debug-logger.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst is = __webpack_require__(/*! ./is.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js\");\nconst string = __webpack_require__(/*! ./string.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/string.js\");\n\n/* eslint-disable @typescript-eslint/no-explicit-any */\n\n/**\n * Replace a method in an object with a wrapped version of itself.\n *\n * If the method on the passed object is not a function, the wrapper will not be applied.\n *\n * @param source An object that contains a method to be wrapped.\n * @param name The name of the method to be wrapped.\n * @param replacementFactory A higher-order function that takes the original version of the given method and returns a\n * wrapped version. Note: The function returned by `replacementFactory` needs to be a non-arrow function, in order to\n * preserve the correct value of `this`, and the original method must be called using `origMethod.call(this, <other\n * args>)` or `origMethod.apply(this, [<other args>])` (rather than being called directly), again to preserve `this`.\n * @returns void\n */\nfunction fill(source, name, replacementFactory) {\n  if (!(name in source)) {\n    return;\n  }\n\n  // explicitly casting to unknown because we don't know the type of the method initially at all\n  const original = source[name] ;\n\n  if (typeof original !== 'function') {\n    return;\n  }\n\n  const wrapped = replacementFactory(original) ;\n\n  // Make sure it's a function first, as we need to attach an empty prototype for `defineProperties` to work\n  // otherwise it'll throw \"TypeError: Object.defineProperties called on non-object\"\n  if (typeof wrapped === 'function') {\n    markFunctionWrapped(wrapped, original);\n  }\n\n  try {\n    source[name] = wrapped;\n  } catch {\n    debugBuild.DEBUG_BUILD && debugLogger.debug.log(`Failed to replace method \"${name}\" in object`, source);\n  }\n}\n\n/**\n * Defines a non-enumerable property on the given object.\n *\n * @param obj The object on which to set the property\n * @param name The name of the property to be set\n * @param value The value to which to set the property\n */\nfunction addNonEnumerableProperty(obj, name, value) {\n  try {\n    Object.defineProperty(obj, name, {\n      // enumerable: false, // the default, so we can save on bundle size by not explicitly setting it\n      value: value,\n      writable: true,\n      configurable: true,\n    });\n  } catch {\n    debugBuild.DEBUG_BUILD && debugLogger.debug.log(`Failed to add non-enumerable property \"${name}\" to object`, obj);\n  }\n}\n\n/**\n * Remembers the original function on the wrapped function and\n * patches up the prototype.\n *\n * @param wrapped the wrapper function\n * @param original the original function that gets wrapped\n */\nfunction markFunctionWrapped(wrapped, original) {\n  try {\n    const proto = original.prototype || {};\n    wrapped.prototype = original.prototype = proto;\n    addNonEnumerableProperty(wrapped, '__sentry_original__', original);\n  } catch {} // eslint-disable-line no-empty\n}\n\n/**\n * This extracts the original function if available.  See\n * `markFunctionWrapped` for more information.\n *\n * @param func the function to unwrap\n * @returns the unwrapped version of the function if available.\n */\n// eslint-disable-next-line @typescript-eslint/ban-types\nfunction getOriginalFunction(func) {\n  return func.__sentry_original__;\n}\n\n/**\n * Transforms any `Error` or `Event` into a plain object with all of their enumerable properties, and some of their\n * non-enumerable properties attached.\n *\n * @param value Initial source that we have to transform in order for it to be usable by the serializer\n * @returns An Event or Error turned into an object - or the value argument itself, when value is neither an Event nor\n *  an Error.\n */\nfunction convertToPlainObject(value)\n\n {\n  if (is.isError(value)) {\n    return {\n      message: value.message,\n      name: value.name,\n      stack: value.stack,\n      ...getOwnProperties(value),\n    };\n  } else if (is.isEvent(value)) {\n    const newObj\n\n = {\n      type: value.type,\n      target: serializeEventTarget(value.target),\n      currentTarget: serializeEventTarget(value.currentTarget),\n      ...getOwnProperties(value),\n    };\n\n    if (typeof CustomEvent !== 'undefined' && is.isInstanceOf(value, CustomEvent)) {\n      newObj.detail = value.detail;\n    }\n\n    return newObj;\n  } else {\n    return value;\n  }\n}\n\n/** Creates a string representation of the target of an `Event` object */\nfunction serializeEventTarget(target) {\n  try {\n    return is.isElement(target) ? browser.htmlTreeAsString(target) : Object.prototype.toString.call(target);\n  } catch {\n    return '<unknown>';\n  }\n}\n\n/** Filters out all but an object's own properties */\nfunction getOwnProperties(obj) {\n  if (typeof obj === 'object' && obj !== null) {\n    const extractedProps = {};\n    for (const property in obj) {\n      if (Object.prototype.hasOwnProperty.call(obj, property)) {\n        extractedProps[property] = (obj )[property];\n      }\n    }\n    return extractedProps;\n  } else {\n    return {};\n  }\n}\n\n/**\n * Given any captured exception, extract its keys and create a sorted\n * and truncated list that will be used inside the event message.\n * eg. `Non-error exception captured with keys: foo, bar, baz`\n */\nfunction extractExceptionKeysForMessage(exception, maxLength = 40) {\n  const keys = Object.keys(convertToPlainObject(exception));\n  keys.sort();\n\n  const firstKey = keys[0];\n\n  if (!firstKey) {\n    return '[object has no keys]';\n  }\n\n  if (firstKey.length >= maxLength) {\n    return string.truncate(firstKey, maxLength);\n  }\n\n  for (let includedKeys = keys.length; includedKeys > 0; includedKeys--) {\n    const serialized = keys.slice(0, includedKeys).join(', ');\n    if (serialized.length > maxLength) {\n      continue;\n    }\n    if (includedKeys === keys.length) {\n      return serialized;\n    }\n    return string.truncate(serialized, maxLength);\n  }\n\n  return '';\n}\n\n/**\n * Given any object, return a new object having removed all fields whose value was `undefined`.\n * Works recursively on objects and arrays.\n *\n * Attention: This function keeps circular references in the returned object.\n *\n * @deprecated This function is no longer used by the SDK and will be removed in a future major version.\n */\nfunction dropUndefinedKeys(inputValue) {\n  // This map keeps track of what already visited nodes map to.\n  // Our Set - based memoBuilder doesn't work here because we want to the output object to have the same circular\n  // references as the input object.\n  const memoizationMap = new Map();\n\n  // This function just proxies `_dropUndefinedKeys` to keep the `memoBuilder` out of this function's API\n  return _dropUndefinedKeys(inputValue, memoizationMap);\n}\n\nfunction _dropUndefinedKeys(inputValue, memoizationMap) {\n  // Early return for primitive values\n  if (inputValue === null || typeof inputValue !== 'object') {\n    return inputValue;\n  }\n\n  // Check memo map first for all object types\n  const memoVal = memoizationMap.get(inputValue);\n  if (memoVal !== undefined) {\n    return memoVal ;\n  }\n\n  // handle arrays\n  if (Array.isArray(inputValue)) {\n    const returnValue = [];\n    // Store mapping to handle circular references\n    memoizationMap.set(inputValue, returnValue);\n\n    inputValue.forEach(value => {\n      returnValue.push(_dropUndefinedKeys(value, memoizationMap));\n    });\n\n    return returnValue ;\n  }\n\n  if (isPojo(inputValue)) {\n    const returnValue = {};\n    // Store mapping to handle circular references\n    memoizationMap.set(inputValue, returnValue);\n\n    const keys = Object.keys(inputValue);\n\n    keys.forEach(key => {\n      const val = inputValue[key];\n      if (val !== undefined) {\n        returnValue[key] = _dropUndefinedKeys(val, memoizationMap);\n      }\n    });\n\n    return returnValue ;\n  }\n\n  // For other object types, return as is\n  return inputValue;\n}\n\nfunction isPojo(input) {\n  // Plain objects have Object as constructor or no constructor\n  const constructor = (input ).constructor;\n  return constructor === Object || constructor === undefined;\n}\n\n/**\n * Ensure that something is an object.\n *\n * Turns `undefined` and `null` into `String`s and all other primitives into instances of their respective wrapper\n * classes (String, Boolean, Number, etc.). Acts as the identity function on non-primitives.\n *\n * @param wat The subject of the objectification\n * @returns A version of `wat` which can safely be used with `Object` class methods\n */\nfunction objectify(wat) {\n  let objectified;\n  switch (true) {\n    // this will catch both undefined and null\n    case wat == undefined:\n      objectified = new String(wat);\n      break;\n\n    // Though symbols and bigints do have wrapper classes (`Symbol` and `BigInt`, respectively), for whatever reason\n    // those classes don't have constructors which can be used with the `new` keyword. We therefore need to cast each as\n    // an object in order to wrap it.\n    case typeof wat === 'symbol' || typeof wat === 'bigint':\n      objectified = Object(wat);\n      break;\n\n    // this will catch the remaining primitives: `String`, `Number`, and `Boolean`\n    case is.isPrimitive(wat):\n      // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n      objectified = new (wat ).constructor(wat);\n      break;\n\n    // by process of elimination, at this point we know that `wat` must already be an object\n    default:\n      objectified = wat;\n      break;\n  }\n  return objectified;\n}\n\nexports.addNonEnumerableProperty = addNonEnumerableProperty;\nexports.convertToPlainObject = convertToPlainObject;\nexports.dropUndefinedKeys = dropUndefinedKeys;\nexports.extractExceptionKeysForMessage = extractExceptionKeysForMessage;\nexports.fill = fill;\nexports.getOriginalFunction = getOriginalFunction;\nexports.markFunctionWrapped = markFunctionWrapped;\nexports.objectify = objectify;\n//# sourceMappingURL=object.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvb2JqZWN0LmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLG1CQUFtQixtQkFBTyxDQUFDLG1JQUFtQjtBQUM5QyxnQkFBZ0IsbUJBQU8sQ0FBQyxnSUFBYztBQUN0QyxvQkFBb0IsbUJBQU8sQ0FBQywwSUFBbUI7QUFDL0MsV0FBVyxtQkFBTyxDQUFDLHNIQUFTO0FBQzVCLGVBQWUsbUJBQU8sQ0FBQyw4SEFBYTs7QUFFcEM7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQSxJQUFJO0FBQ0osaUZBQWlGLEtBQUs7QUFDdEY7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsS0FBSztBQUNMLElBQUk7QUFDSiw4RkFBOEYsS0FBSztBQUNuRztBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLElBQUksU0FBUztBQUNiOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxJQUFJO0FBQ0o7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBLElBQUk7QUFDSjtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQSxJQUFJO0FBQ0o7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsSUFBSTtBQUNKO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUEsdUNBQXVDLGtCQUFrQjtBQUN6RDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLEtBQUs7O0FBRUw7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsS0FBSzs7QUFFTDtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLGdDQUFnQztBQUNoQyw0QkFBNEI7QUFDNUIseUJBQXlCO0FBQ3pCLHNDQUFzQztBQUN0QyxZQUFZO0FBQ1osMkJBQTJCO0FBQzNCLDJCQUEyQjtBQUMzQixpQkFBaUI7QUFDakIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9vYmplY3QuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGRlYnVnQnVpbGQgPSByZXF1aXJlKCcuLi9kZWJ1Zy1idWlsZC5qcycpO1xuY29uc3QgYnJvd3NlciA9IHJlcXVpcmUoJy4vYnJvd3Nlci5qcycpO1xuY29uc3QgZGVidWdMb2dnZXIgPSByZXF1aXJlKCcuL2RlYnVnLWxvZ2dlci5qcycpO1xuY29uc3QgaXMgPSByZXF1aXJlKCcuL2lzLmpzJyk7XG5jb25zdCBzdHJpbmcgPSByZXF1aXJlKCcuL3N0cmluZy5qcycpO1xuXG4vKiBlc2xpbnQtZGlzYWJsZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tZXhwbGljaXQtYW55ICovXG5cbi8qKlxuICogUmVwbGFjZSBhIG1ldGhvZCBpbiBhbiBvYmplY3Qgd2l0aCBhIHdyYXBwZWQgdmVyc2lvbiBvZiBpdHNlbGYuXG4gKlxuICogSWYgdGhlIG1ldGhvZCBvbiB0aGUgcGFzc2VkIG9iamVjdCBpcyBub3QgYSBmdW5jdGlvbiwgdGhlIHdyYXBwZXIgd2lsbCBub3QgYmUgYXBwbGllZC5cbiAqXG4gKiBAcGFyYW0gc291cmNlIEFuIG9iamVjdCB0aGF0IGNvbnRhaW5zIGEgbWV0aG9kIHRvIGJlIHdyYXBwZWQuXG4gKiBAcGFyYW0gbmFtZSBUaGUgbmFtZSBvZiB0aGUgbWV0aG9kIHRvIGJlIHdyYXBwZWQuXG4gKiBAcGFyYW0gcmVwbGFjZW1lbnRGYWN0b3J5IEEgaGlnaGVyLW9yZGVyIGZ1bmN0aW9uIHRoYXQgdGFrZXMgdGhlIG9yaWdpbmFsIHZlcnNpb24gb2YgdGhlIGdpdmVuIG1ldGhvZCBhbmQgcmV0dXJucyBhXG4gKiB3cmFwcGVkIHZlcnNpb24uIE5vdGU6IFRoZSBmdW5jdGlvbiByZXR1cm5lZCBieSBgcmVwbGFjZW1lbnRGYWN0b3J5YCBuZWVkcyB0byBiZSBhIG5vbi1hcnJvdyBmdW5jdGlvbiwgaW4gb3JkZXIgdG9cbiAqIHByZXNlcnZlIHRoZSBjb3JyZWN0IHZhbHVlIG9mIGB0aGlzYCwgYW5kIHRoZSBvcmlnaW5hbCBtZXRob2QgbXVzdCBiZSBjYWxsZWQgdXNpbmcgYG9yaWdNZXRob2QuY2FsbCh0aGlzLCA8b3RoZXJcbiAqIGFyZ3M+KWAgb3IgYG9yaWdNZXRob2QuYXBwbHkodGhpcywgWzxvdGhlciBhcmdzPl0pYCAocmF0aGVyIHRoYW4gYmVpbmcgY2FsbGVkIGRpcmVjdGx5KSwgYWdhaW4gdG8gcHJlc2VydmUgYHRoaXNgLlxuICogQHJldHVybnMgdm9pZFxuICovXG5mdW5jdGlvbiBmaWxsKHNvdXJjZSwgbmFtZSwgcmVwbGFjZW1lbnRGYWN0b3J5KSB7XG4gIGlmICghKG5hbWUgaW4gc291cmNlKSkge1xuICAgIHJldHVybjtcbiAgfVxuXG4gIC8vIGV4cGxpY2l0bHkgY2FzdGluZyB0byB1bmtub3duIGJlY2F1c2Ugd2UgZG9uJ3Qga25vdyB0aGUgdHlwZSBvZiB0aGUgbWV0aG9kIGluaXRpYWxseSBhdCBhbGxcbiAgY29uc3Qgb3JpZ2luYWwgPSBzb3VyY2VbbmFtZV0gO1xuXG4gIGlmICh0eXBlb2Ygb3JpZ2luYWwgIT09ICdmdW5jdGlvbicpIHtcbiAgICByZXR1cm47XG4gIH1cblxuICBjb25zdCB3cmFwcGVkID0gcmVwbGFjZW1lbnRGYWN0b3J5KG9yaWdpbmFsKSA7XG5cbiAgLy8gTWFrZSBzdXJlIGl0J3MgYSBmdW5jdGlvbiBmaXJzdCwgYXMgd2UgbmVlZCB0byBhdHRhY2ggYW4gZW1wdHkgcHJvdG90eXBlIGZvciBgZGVmaW5lUHJvcGVydGllc2AgdG8gd29ya1xuICAvLyBvdGhlcndpc2UgaXQnbGwgdGhyb3cgXCJUeXBlRXJyb3I6IE9iamVjdC5kZWZpbmVQcm9wZXJ0aWVzIGNhbGxlZCBvbiBub24tb2JqZWN0XCJcbiAgaWYgKHR5cGVvZiB3cmFwcGVkID09PSAnZnVuY3Rpb24nKSB7XG4gICAgbWFya0Z1bmN0aW9uV3JhcHBlZCh3cmFwcGVkLCBvcmlnaW5hbCk7XG4gIH1cblxuICB0cnkge1xuICAgIHNvdXJjZVtuYW1lXSA9IHdyYXBwZWQ7XG4gIH0gY2F0Y2gge1xuICAgIGRlYnVnQnVpbGQuREVCVUdfQlVJTEQgJiYgZGVidWdMb2dnZXIuZGVidWcubG9nKGBGYWlsZWQgdG8gcmVwbGFjZSBtZXRob2QgXCIke25hbWV9XCIgaW4gb2JqZWN0YCwgc291cmNlKTtcbiAgfVxufVxuXG4vKipcbiAqIERlZmluZXMgYSBub24tZW51bWVyYWJsZSBwcm9wZXJ0eSBvbiB0aGUgZ2l2ZW4gb2JqZWN0LlxuICpcbiAqIEBwYXJhbSBvYmogVGhlIG9iamVjdCBvbiB3aGljaCB0byBzZXQgdGhlIHByb3BlcnR5XG4gKiBAcGFyYW0gbmFtZSBUaGUgbmFtZSBvZiB0aGUgcHJvcGVydHkgdG8gYmUgc2V0XG4gKiBAcGFyYW0gdmFsdWUgVGhlIHZhbHVlIHRvIHdoaWNoIHRvIHNldCB0aGUgcHJvcGVydHlcbiAqL1xuZnVuY3Rpb24gYWRkTm9uRW51bWVyYWJsZVByb3BlcnR5KG9iaiwgbmFtZSwgdmFsdWUpIHtcbiAgdHJ5IHtcbiAgICBPYmplY3QuZGVmaW5lUHJvcGVydHkob2JqLCBuYW1lLCB7XG4gICAgICAvLyBlbnVtZXJhYmxlOiBmYWxzZSwgLy8gdGhlIGRlZmF1bHQsIHNvIHdlIGNhbiBzYXZlIG9uIGJ1bmRsZSBzaXplIGJ5IG5vdCBleHBsaWNpdGx5IHNldHRpbmcgaXRcbiAgICAgIHZhbHVlOiB2YWx1ZSxcbiAgICAgIHdyaXRhYmxlOiB0cnVlLFxuICAgICAgY29uZmlndXJhYmxlOiB0cnVlLFxuICAgIH0pO1xuICB9IGNhdGNoIHtcbiAgICBkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEICYmIGRlYnVnTG9nZ2VyLmRlYnVnLmxvZyhgRmFpbGVkIHRvIGFkZCBub24tZW51bWVyYWJsZSBwcm9wZXJ0eSBcIiR7bmFtZX1cIiB0byBvYmplY3RgLCBvYmopO1xuICB9XG59XG5cbi8qKlxuICogUmVtZW1iZXJzIHRoZSBvcmlnaW5hbCBmdW5jdGlvbiBvbiB0aGUgd3JhcHBlZCBmdW5jdGlvbiBhbmRcbiAqIHBhdGNoZXMgdXAgdGhlIHByb3RvdHlwZS5cbiAqXG4gKiBAcGFyYW0gd3JhcHBlZCB0aGUgd3JhcHBlciBmdW5jdGlvblxuICogQHBhcmFtIG9yaWdpbmFsIHRoZSBvcmlnaW5hbCBmdW5jdGlvbiB0aGF0IGdldHMgd3JhcHBlZFxuICovXG5mdW5jdGlvbiBtYXJrRnVuY3Rpb25XcmFwcGVkKHdyYXBwZWQsIG9yaWdpbmFsKSB7XG4gIHRyeSB7XG4gICAgY29uc3QgcHJvdG8gPSBvcmlnaW5hbC5wcm90b3R5cGUgfHwge307XG4gICAgd3JhcHBlZC5wcm90b3R5cGUgPSBvcmlnaW5hbC5wcm90b3R5cGUgPSBwcm90bztcbiAgICBhZGROb25FbnVtZXJhYmxlUHJvcGVydHkod3JhcHBlZCwgJ19fc2VudHJ5X29yaWdpbmFsX18nLCBvcmlnaW5hbCk7XG4gIH0gY2F0Y2gge30gLy8gZXNsaW50LWRpc2FibGUtbGluZSBuby1lbXB0eVxufVxuXG4vKipcbiAqIFRoaXMgZXh0cmFjdHMgdGhlIG9yaWdpbmFsIGZ1bmN0aW9uIGlmIGF2YWlsYWJsZS4gIFNlZVxuICogYG1hcmtGdW5jdGlvbldyYXBwZWRgIGZvciBtb3JlIGluZm9ybWF0aW9uLlxuICpcbiAqIEBwYXJhbSBmdW5jIHRoZSBmdW5jdGlvbiB0byB1bndyYXBcbiAqIEByZXR1cm5zIHRoZSB1bndyYXBwZWQgdmVyc2lvbiBvZiB0aGUgZnVuY3Rpb24gaWYgYXZhaWxhYmxlLlxuICovXG4vLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L2Jhbi10eXBlc1xuZnVuY3Rpb24gZ2V0T3JpZ2luYWxGdW5jdGlvbihmdW5jKSB7XG4gIHJldHVybiBmdW5jLl9fc2VudHJ5X29yaWdpbmFsX187XG59XG5cbi8qKlxuICogVHJhbnNmb3JtcyBhbnkgYEVycm9yYCBvciBgRXZlbnRgIGludG8gYSBwbGFpbiBvYmplY3Qgd2l0aCBhbGwgb2YgdGhlaXIgZW51bWVyYWJsZSBwcm9wZXJ0aWVzLCBhbmQgc29tZSBvZiB0aGVpclxuICogbm9uLWVudW1lcmFibGUgcHJvcGVydGllcyBhdHRhY2hlZC5cbiAqXG4gKiBAcGFyYW0gdmFsdWUgSW5pdGlhbCBzb3VyY2UgdGhhdCB3ZSBoYXZlIHRvIHRyYW5zZm9ybSBpbiBvcmRlciBmb3IgaXQgdG8gYmUgdXNhYmxlIGJ5IHRoZSBzZXJpYWxpemVyXG4gKiBAcmV0dXJucyBBbiBFdmVudCBvciBFcnJvciB0dXJuZWQgaW50byBhbiBvYmplY3QgLSBvciB0aGUgdmFsdWUgYXJndW1lbnQgaXRzZWxmLCB3aGVuIHZhbHVlIGlzIG5laXRoZXIgYW4gRXZlbnQgbm9yXG4gKiAgYW4gRXJyb3IuXG4gKi9cbmZ1bmN0aW9uIGNvbnZlcnRUb1BsYWluT2JqZWN0KHZhbHVlKVxuXG4ge1xuICBpZiAoaXMuaXNFcnJvcih2YWx1ZSkpIHtcbiAgICByZXR1cm4ge1xuICAgICAgbWVzc2FnZTogdmFsdWUubWVzc2FnZSxcbiAgICAgIG5hbWU6IHZhbHVlLm5hbWUsXG4gICAgICBzdGFjazogdmFsdWUuc3RhY2ssXG4gICAgICAuLi5nZXRPd25Qcm9wZXJ0aWVzKHZhbHVlKSxcbiAgICB9O1xuICB9IGVsc2UgaWYgKGlzLmlzRXZlbnQodmFsdWUpKSB7XG4gICAgY29uc3QgbmV3T2JqXG5cbiA9IHtcbiAgICAgIHR5cGU6IHZhbHVlLnR5cGUsXG4gICAgICB0YXJnZXQ6IHNlcmlhbGl6ZUV2ZW50VGFyZ2V0KHZhbHVlLnRhcmdldCksXG4gICAgICBjdXJyZW50VGFyZ2V0OiBzZXJpYWxpemVFdmVudFRhcmdldCh2YWx1ZS5jdXJyZW50VGFyZ2V0KSxcbiAgICAgIC4uLmdldE93blByb3BlcnRpZXModmFsdWUpLFxuICAgIH07XG5cbiAgICBpZiAodHlwZW9mIEN1c3RvbUV2ZW50ICE9PSAndW5kZWZpbmVkJyAmJiBpcy5pc0luc3RhbmNlT2YodmFsdWUsIEN1c3RvbUV2ZW50KSkge1xuICAgICAgbmV3T2JqLmRldGFpbCA9IHZhbHVlLmRldGFpbDtcbiAgICB9XG5cbiAgICByZXR1cm4gbmV3T2JqO1xuICB9IGVsc2Uge1xuICAgIHJldHVybiB2YWx1ZTtcbiAgfVxufVxuXG4vKiogQ3JlYXRlcyBhIHN0cmluZyByZXByZXNlbnRhdGlvbiBvZiB0aGUgdGFyZ2V0IG9mIGFuIGBFdmVudGAgb2JqZWN0ICovXG5mdW5jdGlvbiBzZXJpYWxpemVFdmVudFRhcmdldCh0YXJnZXQpIHtcbiAgdHJ5IHtcbiAgICByZXR1cm4gaXMuaXNFbGVtZW50KHRhcmdldCkgPyBicm93c2VyLmh0bWxUcmVlQXNTdHJpbmcodGFyZ2V0KSA6IE9iamVjdC5wcm90b3R5cGUudG9TdHJpbmcuY2FsbCh0YXJnZXQpO1xuICB9IGNhdGNoIHtcbiAgICByZXR1cm4gJzx1bmtub3duPic7XG4gIH1cbn1cblxuLyoqIEZpbHRlcnMgb3V0IGFsbCBidXQgYW4gb2JqZWN0J3Mgb3duIHByb3BlcnRpZXMgKi9cbmZ1bmN0aW9uIGdldE93blByb3BlcnRpZXMob2JqKSB7XG4gIGlmICh0eXBlb2Ygb2JqID09PSAnb2JqZWN0JyAmJiBvYmogIT09IG51bGwpIHtcbiAgICBjb25zdCBleHRyYWN0ZWRQcm9wcyA9IHt9O1xuICAgIGZvciAoY29uc3QgcHJvcGVydHkgaW4gb2JqKSB7XG4gICAgICBpZiAoT2JqZWN0LnByb3RvdHlwZS5oYXNPd25Qcm9wZXJ0eS5jYWxsKG9iaiwgcHJvcGVydHkpKSB7XG4gICAgICAgIGV4dHJhY3RlZFByb3BzW3Byb3BlcnR5XSA9IChvYmogKVtwcm9wZXJ0eV07XG4gICAgICB9XG4gICAgfVxuICAgIHJldHVybiBleHRyYWN0ZWRQcm9wcztcbiAgfSBlbHNlIHtcbiAgICByZXR1cm4ge307XG4gIH1cbn1cblxuLyoqXG4gKiBHaXZlbiBhbnkgY2FwdHVyZWQgZXhjZXB0aW9uLCBleHRyYWN0IGl0cyBrZXlzIGFuZCBjcmVhdGUgYSBzb3J0ZWRcbiAqIGFuZCB0cnVuY2F0ZWQgbGlzdCB0aGF0IHdpbGwgYmUgdXNlZCBpbnNpZGUgdGhlIGV2ZW50IG1lc3NhZ2UuXG4gKiBlZy4gYE5vbi1lcnJvciBleGNlcHRpb24gY2FwdHVyZWQgd2l0aCBrZXlzOiBmb28sIGJhciwgYmF6YFxuICovXG5mdW5jdGlvbiBleHRyYWN0RXhjZXB0aW9uS2V5c0Zvck1lc3NhZ2UoZXhjZXB0aW9uLCBtYXhMZW5ndGggPSA0MCkge1xuICBjb25zdCBrZXlzID0gT2JqZWN0LmtleXMoY29udmVydFRvUGxhaW5PYmplY3QoZXhjZXB0aW9uKSk7XG4gIGtleXMuc29ydCgpO1xuXG4gIGNvbnN0IGZpcnN0S2V5ID0ga2V5c1swXTtcblxuICBpZiAoIWZpcnN0S2V5KSB7XG4gICAgcmV0dXJuICdbb2JqZWN0IGhhcyBubyBrZXlzXSc7XG4gIH1cblxuICBpZiAoZmlyc3RLZXkubGVuZ3RoID49IG1heExlbmd0aCkge1xuICAgIHJldHVybiBzdHJpbmcudHJ1bmNhdGUoZmlyc3RLZXksIG1heExlbmd0aCk7XG4gIH1cblxuICBmb3IgKGxldCBpbmNsdWRlZEtleXMgPSBrZXlzLmxlbmd0aDsgaW5jbHVkZWRLZXlzID4gMDsgaW5jbHVkZWRLZXlzLS0pIHtcbiAgICBjb25zdCBzZXJpYWxpemVkID0ga2V5cy5zbGljZSgwLCBpbmNsdWRlZEtleXMpLmpvaW4oJywgJyk7XG4gICAgaWYgKHNlcmlhbGl6ZWQubGVuZ3RoID4gbWF4TGVuZ3RoKSB7XG4gICAgICBjb250aW51ZTtcbiAgICB9XG4gICAgaWYgKGluY2x1ZGVkS2V5cyA9PT0ga2V5cy5sZW5ndGgpIHtcbiAgICAgIHJldHVybiBzZXJpYWxpemVkO1xuICAgIH1cbiAgICByZXR1cm4gc3RyaW5nLnRydW5jYXRlKHNlcmlhbGl6ZWQsIG1heExlbmd0aCk7XG4gIH1cblxuICByZXR1cm4gJyc7XG59XG5cbi8qKlxuICogR2l2ZW4gYW55IG9iamVjdCwgcmV0dXJuIGEgbmV3IG9iamVjdCBoYXZpbmcgcmVtb3ZlZCBhbGwgZmllbGRzIHdob3NlIHZhbHVlIHdhcyBgdW5kZWZpbmVkYC5cbiAqIFdvcmtzIHJlY3Vyc2l2ZWx5IG9uIG9iamVjdHMgYW5kIGFycmF5cy5cbiAqXG4gKiBBdHRlbnRpb246IFRoaXMgZnVuY3Rpb24ga2VlcHMgY2lyY3VsYXIgcmVmZXJlbmNlcyBpbiB0aGUgcmV0dXJuZWQgb2JqZWN0LlxuICpcbiAqIEBkZXByZWNhdGVkIFRoaXMgZnVuY3Rpb24gaXMgbm8gbG9uZ2VyIHVzZWQgYnkgdGhlIFNESyBhbmQgd2lsbCBiZSByZW1vdmVkIGluIGEgZnV0dXJlIG1ham9yIHZlcnNpb24uXG4gKi9cbmZ1bmN0aW9uIGRyb3BVbmRlZmluZWRLZXlzKGlucHV0VmFsdWUpIHtcbiAgLy8gVGhpcyBtYXAga2VlcHMgdHJhY2sgb2Ygd2hhdCBhbHJlYWR5IHZpc2l0ZWQgbm9kZXMgbWFwIHRvLlxuICAvLyBPdXIgU2V0IC0gYmFzZWQgbWVtb0J1aWxkZXIgZG9lc24ndCB3b3JrIGhlcmUgYmVjYXVzZSB3ZSB3YW50IHRvIHRoZSBvdXRwdXQgb2JqZWN0IHRvIGhhdmUgdGhlIHNhbWUgY2lyY3VsYXJcbiAgLy8gcmVmZXJlbmNlcyBhcyB0aGUgaW5wdXQgb2JqZWN0LlxuICBjb25zdCBtZW1vaXphdGlvbk1hcCA9IG5ldyBNYXAoKTtcblxuICAvLyBUaGlzIGZ1bmN0aW9uIGp1c3QgcHJveGllcyBgX2Ryb3BVbmRlZmluZWRLZXlzYCB0byBrZWVwIHRoZSBgbWVtb0J1aWxkZXJgIG91dCBvZiB0aGlzIGZ1bmN0aW9uJ3MgQVBJXG4gIHJldHVybiBfZHJvcFVuZGVmaW5lZEtleXMoaW5wdXRWYWx1ZSwgbWVtb2l6YXRpb25NYXApO1xufVxuXG5mdW5jdGlvbiBfZHJvcFVuZGVmaW5lZEtleXMoaW5wdXRWYWx1ZSwgbWVtb2l6YXRpb25NYXApIHtcbiAgLy8gRWFybHkgcmV0dXJuIGZvciBwcmltaXRpdmUgdmFsdWVzXG4gIGlmIChpbnB1dFZhbHVlID09PSBudWxsIHx8IHR5cGVvZiBpbnB1dFZhbHVlICE9PSAnb2JqZWN0Jykge1xuICAgIHJldHVybiBpbnB1dFZhbHVlO1xuICB9XG5cbiAgLy8gQ2hlY2sgbWVtbyBtYXAgZmlyc3QgZm9yIGFsbCBvYmplY3QgdHlwZXNcbiAgY29uc3QgbWVtb1ZhbCA9IG1lbW9pemF0aW9uTWFwLmdldChpbnB1dFZhbHVlKTtcbiAgaWYgKG1lbW9WYWwgIT09IHVuZGVmaW5lZCkge1xuICAgIHJldHVybiBtZW1vVmFsIDtcbiAgfVxuXG4gIC8vIGhhbmRsZSBhcnJheXNcbiAgaWYgKEFycmF5LmlzQXJyYXkoaW5wdXRWYWx1ZSkpIHtcbiAgICBjb25zdCByZXR1cm5WYWx1ZSA9IFtdO1xuICAgIC8vIFN0b3JlIG1hcHBpbmcgdG8gaGFuZGxlIGNpcmN1bGFyIHJlZmVyZW5jZXNcbiAgICBtZW1vaXphdGlvbk1hcC5zZXQoaW5wdXRWYWx1ZSwgcmV0dXJuVmFsdWUpO1xuXG4gICAgaW5wdXRWYWx1ZS5mb3JFYWNoKHZhbHVlID0+IHtcbiAgICAgIHJldHVyblZhbHVlLnB1c2goX2Ryb3BVbmRlZmluZWRLZXlzKHZhbHVlLCBtZW1vaXphdGlvbk1hcCkpO1xuICAgIH0pO1xuXG4gICAgcmV0dXJuIHJldHVyblZhbHVlIDtcbiAgfVxuXG4gIGlmIChpc1Bvam8oaW5wdXRWYWx1ZSkpIHtcbiAgICBjb25zdCByZXR1cm5WYWx1ZSA9IHt9O1xuICAgIC8vIFN0b3JlIG1hcHBpbmcgdG8gaGFuZGxlIGNpcmN1bGFyIHJlZmVyZW5jZXNcbiAgICBtZW1vaXphdGlvbk1hcC5zZXQoaW5wdXRWYWx1ZSwgcmV0dXJuVmFsdWUpO1xuXG4gICAgY29uc3Qga2V5cyA9IE9iamVjdC5rZXlzKGlucHV0VmFsdWUpO1xuXG4gICAga2V5cy5mb3JFYWNoKGtleSA9PiB7XG4gICAgICBjb25zdCB2YWwgPSBpbnB1dFZhbHVlW2tleV07XG4gICAgICBpZiAodmFsICE9PSB1bmRlZmluZWQpIHtcbiAgICAgICAgcmV0dXJuVmFsdWVba2V5XSA9IF9kcm9wVW5kZWZpbmVkS2V5cyh2YWwsIG1lbW9pemF0aW9uTWFwKTtcbiAgICAgIH1cbiAgICB9KTtcblxuICAgIHJldHVybiByZXR1cm5WYWx1ZSA7XG4gIH1cblxuICAvLyBGb3Igb3RoZXIgb2JqZWN0IHR5cGVzLCByZXR1cm4gYXMgaXNcbiAgcmV0dXJuIGlucHV0VmFsdWU7XG59XG5cbmZ1bmN0aW9uIGlzUG9qbyhpbnB1dCkge1xuICAvLyBQbGFpbiBvYmplY3RzIGhhdmUgT2JqZWN0IGFzIGNvbnN0cnVjdG9yIG9yIG5vIGNvbnN0cnVjdG9yXG4gIGNvbnN0IGNvbnN0cnVjdG9yID0gKGlucHV0ICkuY29uc3RydWN0b3I7XG4gIHJldHVybiBjb25zdHJ1Y3RvciA9PT0gT2JqZWN0IHx8IGNvbnN0cnVjdG9yID09PSB1bmRlZmluZWQ7XG59XG5cbi8qKlxuICogRW5zdXJlIHRoYXQgc29tZXRoaW5nIGlzIGFuIG9iamVjdC5cbiAqXG4gKiBUdXJucyBgdW5kZWZpbmVkYCBhbmQgYG51bGxgIGludG8gYFN0cmluZ2BzIGFuZCBhbGwgb3RoZXIgcHJpbWl0aXZlcyBpbnRvIGluc3RhbmNlcyBvZiB0aGVpciByZXNwZWN0aXZlIHdyYXBwZXJcbiAqIGNsYXNzZXMgKFN0cmluZywgQm9vbGVhbiwgTnVtYmVyLCBldGMuKS4gQWN0cyBhcyB0aGUgaWRlbnRpdHkgZnVuY3Rpb24gb24gbm9uLXByaW1pdGl2ZXMuXG4gKlxuICogQHBhcmFtIHdhdCBUaGUgc3ViamVjdCBvZiB0aGUgb2JqZWN0aWZpY2F0aW9uXG4gKiBAcmV0dXJucyBBIHZlcnNpb24gb2YgYHdhdGAgd2hpY2ggY2FuIHNhZmVseSBiZSB1c2VkIHdpdGggYE9iamVjdGAgY2xhc3MgbWV0aG9kc1xuICovXG5mdW5jdGlvbiBvYmplY3RpZnkod2F0KSB7XG4gIGxldCBvYmplY3RpZmllZDtcbiAgc3dpdGNoICh0cnVlKSB7XG4gICAgLy8gdGhpcyB3aWxsIGNhdGNoIGJvdGggdW5kZWZpbmVkIGFuZCBudWxsXG4gICAgY2FzZSB3YXQgPT0gdW5kZWZpbmVkOlxuICAgICAgb2JqZWN0aWZpZWQgPSBuZXcgU3RyaW5nKHdhdCk7XG4gICAgICBicmVhaztcblxuICAgIC8vIFRob3VnaCBzeW1ib2xzIGFuZCBiaWdpbnRzIGRvIGhhdmUgd3JhcHBlciBjbGFzc2VzIChgU3ltYm9sYCBhbmQgYEJpZ0ludGAsIHJlc3BlY3RpdmVseSksIGZvciB3aGF0ZXZlciByZWFzb25cbiAgICAvLyB0aG9zZSBjbGFzc2VzIGRvbid0IGhhdmUgY29uc3RydWN0b3JzIHdoaWNoIGNhbiBiZSB1c2VkIHdpdGggdGhlIGBuZXdgIGtleXdvcmQuIFdlIHRoZXJlZm9yZSBuZWVkIHRvIGNhc3QgZWFjaCBhc1xuICAgIC8vIGFuIG9iamVjdCBpbiBvcmRlciB0byB3cmFwIGl0LlxuICAgIGNhc2UgdHlwZW9mIHdhdCA9PT0gJ3N5bWJvbCcgfHwgdHlwZW9mIHdhdCA9PT0gJ2JpZ2ludCc6XG4gICAgICBvYmplY3RpZmllZCA9IE9iamVjdCh3YXQpO1xuICAgICAgYnJlYWs7XG5cbiAgICAvLyB0aGlzIHdpbGwgY2F0Y2ggdGhlIHJlbWFpbmluZyBwcmltaXRpdmVzOiBgU3RyaW5nYCwgYE51bWJlcmAsIGFuZCBgQm9vbGVhbmBcbiAgICBjYXNlIGlzLmlzUHJpbWl0aXZlKHdhdCk6XG4gICAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25vLXVuc2FmZS1tZW1iZXItYWNjZXNzXG4gICAgICBvYmplY3RpZmllZCA9IG5ldyAod2F0ICkuY29uc3RydWN0b3Iod2F0KTtcbiAgICAgIGJyZWFrO1xuXG4gICAgLy8gYnkgcHJvY2VzcyBvZiBlbGltaW5hdGlvbiwgYXQgdGhpcyBwb2ludCB3ZSBrbm93IHRoYXQgYHdhdGAgbXVzdCBhbHJlYWR5IGJlIGFuIG9iamVjdFxuICAgIGRlZmF1bHQ6XG4gICAgICBvYmplY3RpZmllZCA9IHdhdDtcbiAgICAgIGJyZWFrO1xuICB9XG4gIHJldHVybiBvYmplY3RpZmllZDtcbn1cblxuZXhwb3J0cy5hZGROb25FbnVtZXJhYmxlUHJvcGVydHkgPSBhZGROb25FbnVtZXJhYmxlUHJvcGVydHk7XG5leHBvcnRzLmNvbnZlcnRUb1BsYWluT2JqZWN0ID0gY29udmVydFRvUGxhaW5PYmplY3Q7XG5leHBvcnRzLmRyb3BVbmRlZmluZWRLZXlzID0gZHJvcFVuZGVmaW5lZEtleXM7XG5leHBvcnRzLmV4dHJhY3RFeGNlcHRpb25LZXlzRm9yTWVzc2FnZSA9IGV4dHJhY3RFeGNlcHRpb25LZXlzRm9yTWVzc2FnZTtcbmV4cG9ydHMuZmlsbCA9IGZpbGw7XG5leHBvcnRzLmdldE9yaWdpbmFsRnVuY3Rpb24gPSBnZXRPcmlnaW5hbEZ1bmN0aW9uO1xuZXhwb3J0cy5tYXJrRnVuY3Rpb25XcmFwcGVkID0gbWFya0Z1bmN0aW9uV3JhcHBlZDtcbmV4cG9ydHMub2JqZWN0aWZ5ID0gb2JqZWN0aWZ5O1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9b2JqZWN0LmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/object.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/openai/constants.js":
/*!**************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/openai/constants.js ***!
  \**************************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst OPENAI_INTEGRATION_NAME = 'OpenAI';\n\n// https://platform.openai.com/docs/quickstart?api-mode=responses\n// https://platform.openai.com/docs/quickstart?api-mode=chat\nconst INSTRUMENTED_METHODS = ['responses.create', 'chat.completions.create'] ;\n\nexports.INSTRUMENTED_METHODS = INSTRUMENTED_METHODS;\nexports.OPENAI_INTEGRATION_NAME = OPENAI_INTEGRATION_NAME;\n//# sourceMappingURL=constants.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvb3BlbmFpL2NvbnN0YW50cy5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUEsNEJBQTRCO0FBQzVCLCtCQUErQjtBQUMvQiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3V0aWxzL29wZW5haS9jb25zdGFudHMuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IE9QRU5BSV9JTlRFR1JBVElPTl9OQU1FID0gJ09wZW5BSSc7XG5cbi8vIGh0dHBzOi8vcGxhdGZvcm0ub3BlbmFpLmNvbS9kb2NzL3F1aWNrc3RhcnQ/YXBpLW1vZGU9cmVzcG9uc2VzXG4vLyBodHRwczovL3BsYXRmb3JtLm9wZW5haS5jb20vZG9jcy9xdWlja3N0YXJ0P2FwaS1tb2RlPWNoYXRcbmNvbnN0IElOU1RSVU1FTlRFRF9NRVRIT0RTID0gWydyZXNwb25zZXMuY3JlYXRlJywgJ2NoYXQuY29tcGxldGlvbnMuY3JlYXRlJ10gO1xuXG5leHBvcnRzLklOU1RSVU1FTlRFRF9NRVRIT0RTID0gSU5TVFJVTUVOVEVEX01FVEhPRFM7XG5leHBvcnRzLk9QRU5BSV9JTlRFR1JBVElPTl9OQU1FID0gT1BFTkFJX0lOVEVHUkFUSU9OX05BTUU7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1jb25zdGFudHMuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/openai/constants.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/openai/index.js":
/*!**********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/openai/index.js ***!
  \**********************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst currentScopes = __webpack_require__(/*! ../../currentScopes.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst exports$1 = __webpack_require__(/*! ../../exports.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/exports.js\");\nconst trace = __webpack_require__(/*! ../../tracing/trace.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/trace.js\");\nconst genAiAttributes = __webpack_require__(/*! ../gen-ai-attributes.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/gen-ai-attributes.js\");\nconst constants = __webpack_require__(/*! ./constants.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/openai/constants.js\");\nconst utils = __webpack_require__(/*! ./utils.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/openai/utils.js\");\n\n/**\n * Extract request attributes from method arguments\n */\nfunction extractRequestAttributes(args, methodPath) {\n  const attributes = {\n    [genAiAttributes.GEN_AI_SYSTEM_ATTRIBUTE]: 'openai',\n    [genAiAttributes.GEN_AI_OPERATION_NAME_ATTRIBUTE]: utils.getOperationName(methodPath),\n  };\n\n  if (args.length > 0 && typeof args[0] === 'object' && args[0] !== null) {\n    const params = args[0] ;\n\n    attributes[genAiAttributes.GEN_AI_REQUEST_MODEL_ATTRIBUTE] = params.model ?? 'unknown';\n    if ('temperature' in params) attributes[genAiAttributes.GEN_AI_REQUEST_TEMPERATURE_ATTRIBUTE] = params.temperature;\n    if ('top_p' in params) attributes[genAiAttributes.GEN_AI_REQUEST_TOP_P_ATTRIBUTE] = params.top_p;\n    if ('frequency_penalty' in params)\n      attributes[genAiAttributes.GEN_AI_REQUEST_FREQUENCY_PENALTY_ATTRIBUTE] = params.frequency_penalty;\n    if ('presence_penalty' in params) attributes[genAiAttributes.GEN_AI_REQUEST_PRESENCE_PENALTY_ATTRIBUTE] = params.presence_penalty;\n  } else {\n    attributes[genAiAttributes.GEN_AI_REQUEST_MODEL_ATTRIBUTE] = 'unknown';\n  }\n\n  return attributes;\n}\n\n/**\n * Helper function to set token usage attributes\n */\nfunction setTokenUsageAttributes(\n  span,\n  promptTokens,\n  completionTokens,\n  totalTokens,\n) {\n  if (promptTokens !== undefined) {\n    span.setAttributes({\n      [genAiAttributes.OPENAI_USAGE_PROMPT_TOKENS_ATTRIBUTE]: promptTokens,\n      [genAiAttributes.GEN_AI_USAGE_INPUT_TOKENS_ATTRIBUTE]: promptTokens,\n    });\n  }\n  if (completionTokens !== undefined) {\n    span.setAttributes({\n      [genAiAttributes.OPENAI_USAGE_COMPLETION_TOKENS_ATTRIBUTE]: completionTokens,\n      [genAiAttributes.GEN_AI_USAGE_OUTPUT_TOKENS_ATTRIBUTE]: completionTokens,\n    });\n  }\n  if (totalTokens !== undefined) {\n    span.setAttributes({\n      [genAiAttributes.GEN_AI_USAGE_TOTAL_TOKENS_ATTRIBUTE]: totalTokens,\n    });\n  }\n}\n\n/**\n * Helper function to set common response attributes (ID, model, timestamp)\n */\nfunction setCommonResponseAttributes(span, id, model, timestamp) {\n  if (id) {\n    span.setAttributes({\n      [genAiAttributes.OPENAI_RESPONSE_ID_ATTRIBUTE]: id,\n      [genAiAttributes.GEN_AI_RESPONSE_ID_ATTRIBUTE]: id,\n    });\n  }\n  if (model) {\n    span.setAttributes({\n      [genAiAttributes.OPENAI_RESPONSE_MODEL_ATTRIBUTE]: model,\n      [genAiAttributes.GEN_AI_RESPONSE_MODEL_ATTRIBUTE]: model,\n    });\n  }\n  if (timestamp) {\n    span.setAttributes({\n      [genAiAttributes.OPENAI_RESPONSE_TIMESTAMP_ATTRIBUTE]: new Date(timestamp * 1000).toISOString(),\n    });\n  }\n}\n\n/**\n * Add attributes for Chat Completion responses\n */\nfunction addChatCompletionAttributes(span, response) {\n  setCommonResponseAttributes(span, response.id, response.model, response.created);\n  if (response.usage) {\n    setTokenUsageAttributes(\n      span,\n      response.usage.prompt_tokens,\n      response.usage.completion_tokens,\n      response.usage.total_tokens,\n    );\n  }\n  if (Array.isArray(response.choices)) {\n    const finishReasons = response.choices\n      .map(choice => choice.finish_reason)\n      .filter((reason) => reason !== null);\n    if (finishReasons.length > 0) {\n      span.setAttributes({\n        [genAiAttributes.GEN_AI_RESPONSE_FINISH_REASONS_ATTRIBUTE]: JSON.stringify(finishReasons),\n      });\n    }\n  }\n}\n\n/**\n * Add attributes for Responses API responses\n */\nfunction addResponsesApiAttributes(span, response) {\n  setCommonResponseAttributes(span, response.id, response.model, response.created_at);\n  if (response.status) {\n    span.setAttributes({\n      [genAiAttributes.GEN_AI_RESPONSE_FINISH_REASONS_ATTRIBUTE]: JSON.stringify([response.status]),\n    });\n  }\n  if (response.usage) {\n    setTokenUsageAttributes(\n      span,\n      response.usage.input_tokens,\n      response.usage.output_tokens,\n      response.usage.total_tokens,\n    );\n  }\n}\n\n/**\n * Add response attributes to spans\n * This currently supports both Chat Completion and Responses API responses\n */\nfunction addResponseAttributes(span, result, recordOutputs) {\n  if (!result || typeof result !== 'object') return;\n\n  const response = result ;\n\n  if (utils.isChatCompletionResponse(response)) {\n    addChatCompletionAttributes(span, response);\n    if (recordOutputs && response.choices?.length) {\n      const responseTexts = response.choices.map(choice => choice.message?.content || '');\n      span.setAttributes({ [genAiAttributes.GEN_AI_RESPONSE_TEXT_ATTRIBUTE]: JSON.stringify(responseTexts) });\n    }\n  } else if (utils.isResponsesApiResponse(response)) {\n    addResponsesApiAttributes(span, response);\n    if (recordOutputs && response.output_text) {\n      span.setAttributes({ [genAiAttributes.GEN_AI_RESPONSE_TEXT_ATTRIBUTE]: response.output_text });\n    }\n  }\n}\n\n// Extract and record AI request inputs, if present. This is intentionally separate from response attributes.\nfunction addRequestAttributes(span, params) {\n  if ('messages' in params) {\n    span.setAttributes({ [genAiAttributes.GEN_AI_REQUEST_MESSAGES_ATTRIBUTE]: JSON.stringify(params.messages) });\n  }\n  if ('input' in params) {\n    span.setAttributes({ [genAiAttributes.GEN_AI_REQUEST_MESSAGES_ATTRIBUTE]: JSON.stringify(params.input) });\n  }\n}\n\nfunction getOptionsFromIntegration() {\n  const scope = currentScopes.getCurrentScope();\n  const client = scope.getClient();\n  const integration = client?.getIntegrationByName(constants.OPENAI_INTEGRATION_NAME) ;\n  const shouldRecordInputsAndOutputs = integration ? Boolean(client?.getOptions().sendDefaultPii) : false;\n\n  return {\n    recordInputs: integration?.options?.recordInputs ?? shouldRecordInputsAndOutputs,\n    recordOutputs: integration?.options?.recordOutputs ?? shouldRecordInputsAndOutputs,\n  };\n}\n\n/**\n * Instrument a method with Sentry spans\n * Following Sentry AI Agents Manual Instrumentation conventions\n * @see https://docs.sentry.io/platforms/javascript/guides/node/tracing/instrumentation/ai-agents-module/#manual-instrumentation\n */\nfunction instrumentMethod(\n  originalMethod,\n  methodPath,\n  context,\n  options,\n) {\n  return async function instrumentedMethod(...args) {\n    const finalOptions = options || getOptionsFromIntegration();\n    const requestAttributes = extractRequestAttributes(args, methodPath);\n    const model = (requestAttributes[genAiAttributes.GEN_AI_REQUEST_MODEL_ATTRIBUTE] ) || 'unknown';\n    const operationName = utils.getOperationName(methodPath);\n\n    return trace.startSpan(\n      {\n        name: `${operationName} ${model}`,\n        op: utils.getSpanOperation(methodPath),\n        attributes: requestAttributes ,\n      },\n      async (span) => {\n        try {\n          if (finalOptions.recordInputs && args[0] && typeof args[0] === 'object') {\n            addRequestAttributes(span, args[0] );\n          }\n\n          const result = await originalMethod.apply(context, args);\n          // TODO: Add streaming support\n          addResponseAttributes(span, result, finalOptions.recordOutputs);\n          return result;\n        } catch (error) {\n          exports$1.captureException(error);\n          throw error;\n        }\n      },\n    );\n  };\n}\n\n/**\n * Create a deep proxy for OpenAI client instrumentation\n */\nfunction createDeepProxy(target, currentPath = '', options) {\n  return new Proxy(target, {\n    get(obj, prop) {\n      const value = (obj )[prop];\n      const methodPath = utils.buildMethodPath(currentPath, String(prop));\n\n      if (typeof value === 'function' && utils.shouldInstrument(methodPath)) {\n        return instrumentMethod(value , methodPath, obj, options);\n      }\n\n      if (typeof value === 'function') {\n        // Bind non-instrumented functions to preserve the original `this` context,\n        // which is required for accessing private class fields (e.g. #baseURL) in OpenAI SDK v5.\n        return value.bind(obj);\n      }\n\n      if (value && typeof value === 'object') {\n        return createDeepProxy(value , methodPath, options);\n      }\n\n      return value;\n    },\n  });\n}\n\n/**\n * Instrument an OpenAI client with Sentry tracing\n * Can be used across Node.js, Cloudflare Workers, and Vercel Edge\n */\nfunction instrumentOpenAiClient(client, options) {\n  return createDeepProxy(client, '', options);\n}\n\nexports.instrumentOpenAiClient = instrumentOpenAiClient;\n//# sourceMappingURL=index.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvb3BlbmFpL2luZGV4LmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLHNCQUFzQixtQkFBTyxDQUFDLDBJQUF3QjtBQUN0RCxrQkFBa0IsbUJBQU8sQ0FBQyw4SEFBa0I7QUFDNUMsY0FBYyxtQkFBTyxDQUFDLDBJQUF3QjtBQUM5Qyx3QkFBd0IsbUJBQU8sQ0FBQyxxSkFBeUI7QUFDekQsa0JBQWtCLG1CQUFPLENBQUMsMklBQWdCO0FBQzFDLGNBQWMsbUJBQU8sQ0FBQyxtSUFBWTs7QUFFbEM7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLElBQUk7QUFDSjtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxLQUFLO0FBQ0w7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEtBQUs7QUFDTDtBQUNBO0FBQ0E7QUFDQTtBQUNBLEtBQUs7QUFDTDtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxLQUFLO0FBQ0w7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEtBQUs7QUFDTDtBQUNBO0FBQ0E7QUFDQTtBQUNBLEtBQUs7QUFDTDtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxPQUFPO0FBQ1A7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxLQUFLO0FBQ0w7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsMkJBQTJCLGlGQUFpRjtBQUM1RztBQUNBLElBQUk7QUFDSjtBQUNBO0FBQ0EsMkJBQTJCLHdFQUF3RTtBQUNuRztBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0EseUJBQXlCLHNGQUFzRjtBQUMvRztBQUNBO0FBQ0EseUJBQXlCLG1GQUFtRjtBQUM1RztBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsaUJBQWlCLGVBQWUsRUFBRSxNQUFNO0FBQ3hDO0FBQ0E7QUFDQSxPQUFPO0FBQ1A7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFVBQVU7QUFDVjtBQUNBO0FBQ0E7QUFDQSxPQUFPO0FBQ1A7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0EsS0FBSztBQUNMLEdBQUc7QUFDSDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSw4QkFBOEI7QUFDOUIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9vcGVuYWkvaW5kZXguanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGN1cnJlbnRTY29wZXMgPSByZXF1aXJlKCcuLi8uLi9jdXJyZW50U2NvcGVzLmpzJyk7XG5jb25zdCBleHBvcnRzJDEgPSByZXF1aXJlKCcuLi8uLi9leHBvcnRzLmpzJyk7XG5jb25zdCB0cmFjZSA9IHJlcXVpcmUoJy4uLy4uL3RyYWNpbmcvdHJhY2UuanMnKTtcbmNvbnN0IGdlbkFpQXR0cmlidXRlcyA9IHJlcXVpcmUoJy4uL2dlbi1haS1hdHRyaWJ1dGVzLmpzJyk7XG5jb25zdCBjb25zdGFudHMgPSByZXF1aXJlKCcuL2NvbnN0YW50cy5qcycpO1xuY29uc3QgdXRpbHMgPSByZXF1aXJlKCcuL3V0aWxzLmpzJyk7XG5cbi8qKlxuICogRXh0cmFjdCByZXF1ZXN0IGF0dHJpYnV0ZXMgZnJvbSBtZXRob2QgYXJndW1lbnRzXG4gKi9cbmZ1bmN0aW9uIGV4dHJhY3RSZXF1ZXN0QXR0cmlidXRlcyhhcmdzLCBtZXRob2RQYXRoKSB7XG4gIGNvbnN0IGF0dHJpYnV0ZXMgPSB7XG4gICAgW2dlbkFpQXR0cmlidXRlcy5HRU5fQUlfU1lTVEVNX0FUVFJJQlVURV06ICdvcGVuYWknLFxuICAgIFtnZW5BaUF0dHJpYnV0ZXMuR0VOX0FJX09QRVJBVElPTl9OQU1FX0FUVFJJQlVURV06IHV0aWxzLmdldE9wZXJhdGlvbk5hbWUobWV0aG9kUGF0aCksXG4gIH07XG5cbiAgaWYgKGFyZ3MubGVuZ3RoID4gMCAmJiB0eXBlb2YgYXJnc1swXSA9PT0gJ29iamVjdCcgJiYgYXJnc1swXSAhPT0gbnVsbCkge1xuICAgIGNvbnN0IHBhcmFtcyA9IGFyZ3NbMF0gO1xuXG4gICAgYXR0cmlidXRlc1tnZW5BaUF0dHJpYnV0ZXMuR0VOX0FJX1JFUVVFU1RfTU9ERUxfQVRUUklCVVRFXSA9IHBhcmFtcy5tb2RlbCA/PyAndW5rbm93bic7XG4gICAgaWYgKCd0ZW1wZXJhdHVyZScgaW4gcGFyYW1zKSBhdHRyaWJ1dGVzW2dlbkFpQXR0cmlidXRlcy5HRU5fQUlfUkVRVUVTVF9URU1QRVJBVFVSRV9BVFRSSUJVVEVdID0gcGFyYW1zLnRlbXBlcmF0dXJlO1xuICAgIGlmICgndG9wX3AnIGluIHBhcmFtcykgYXR0cmlidXRlc1tnZW5BaUF0dHJpYnV0ZXMuR0VOX0FJX1JFUVVFU1RfVE9QX1BfQVRUUklCVVRFXSA9IHBhcmFtcy50b3BfcDtcbiAgICBpZiAoJ2ZyZXF1ZW5jeV9wZW5hbHR5JyBpbiBwYXJhbXMpXG4gICAgICBhdHRyaWJ1dGVzW2dlbkFpQXR0cmlidXRlcy5HRU5fQUlfUkVRVUVTVF9GUkVRVUVOQ1lfUEVOQUxUWV9BVFRSSUJVVEVdID0gcGFyYW1zLmZyZXF1ZW5jeV9wZW5hbHR5O1xuICAgIGlmICgncHJlc2VuY2VfcGVuYWx0eScgaW4gcGFyYW1zKSBhdHRyaWJ1dGVzW2dlbkFpQXR0cmlidXRlcy5HRU5fQUlfUkVRVUVTVF9QUkVTRU5DRV9QRU5BTFRZX0FUVFJJQlVURV0gPSBwYXJhbXMucHJlc2VuY2VfcGVuYWx0eTtcbiAgfSBlbHNlIHtcbiAgICBhdHRyaWJ1dGVzW2dlbkFpQXR0cmlidXRlcy5HRU5fQUlfUkVRVUVTVF9NT0RFTF9BVFRSSUJVVEVdID0gJ3Vua25vd24nO1xuICB9XG5cbiAgcmV0dXJuIGF0dHJpYnV0ZXM7XG59XG5cbi8qKlxuICogSGVscGVyIGZ1bmN0aW9uIHRvIHNldCB0b2tlbiB1c2FnZSBhdHRyaWJ1dGVzXG4gKi9cbmZ1bmN0aW9uIHNldFRva2VuVXNhZ2VBdHRyaWJ1dGVzKFxuICBzcGFuLFxuICBwcm9tcHRUb2tlbnMsXG4gIGNvbXBsZXRpb25Ub2tlbnMsXG4gIHRvdGFsVG9rZW5zLFxuKSB7XG4gIGlmIChwcm9tcHRUb2tlbnMgIT09IHVuZGVmaW5lZCkge1xuICAgIHNwYW4uc2V0QXR0cmlidXRlcyh7XG4gICAgICBbZ2VuQWlBdHRyaWJ1dGVzLk9QRU5BSV9VU0FHRV9QUk9NUFRfVE9LRU5TX0FUVFJJQlVURV06IHByb21wdFRva2VucyxcbiAgICAgIFtnZW5BaUF0dHJpYnV0ZXMuR0VOX0FJX1VTQUdFX0lOUFVUX1RPS0VOU19BVFRSSUJVVEVdOiBwcm9tcHRUb2tlbnMsXG4gICAgfSk7XG4gIH1cbiAgaWYgKGNvbXBsZXRpb25Ub2tlbnMgIT09IHVuZGVmaW5lZCkge1xuICAgIHNwYW4uc2V0QXR0cmlidXRlcyh7XG4gICAgICBbZ2VuQWlBdHRyaWJ1dGVzLk9QRU5BSV9VU0FHRV9DT01QTEVUSU9OX1RPS0VOU19BVFRSSUJVVEVdOiBjb21wbGV0aW9uVG9rZW5zLFxuICAgICAgW2dlbkFpQXR0cmlidXRlcy5HRU5fQUlfVVNBR0VfT1VUUFVUX1RPS0VOU19BVFRSSUJVVEVdOiBjb21wbGV0aW9uVG9rZW5zLFxuICAgIH0pO1xuICB9XG4gIGlmICh0b3RhbFRva2VucyAhPT0gdW5kZWZpbmVkKSB7XG4gICAgc3Bhbi5zZXRBdHRyaWJ1dGVzKHtcbiAgICAgIFtnZW5BaUF0dHJpYnV0ZXMuR0VOX0FJX1VTQUdFX1RPVEFMX1RPS0VOU19BVFRSSUJVVEVdOiB0b3RhbFRva2VucyxcbiAgICB9KTtcbiAgfVxufVxuXG4vKipcbiAqIEhlbHBlciBmdW5jdGlvbiB0byBzZXQgY29tbW9uIHJlc3BvbnNlIGF0dHJpYnV0ZXMgKElELCBtb2RlbCwgdGltZXN0YW1wKVxuICovXG5mdW5jdGlvbiBzZXRDb21tb25SZXNwb25zZUF0dHJpYnV0ZXMoc3BhbiwgaWQsIG1vZGVsLCB0aW1lc3RhbXApIHtcbiAgaWYgKGlkKSB7XG4gICAgc3Bhbi5zZXRBdHRyaWJ1dGVzKHtcbiAgICAgIFtnZW5BaUF0dHJpYnV0ZXMuT1BFTkFJX1JFU1BPTlNFX0lEX0FUVFJJQlVURV06IGlkLFxuICAgICAgW2dlbkFpQXR0cmlidXRlcy5HRU5fQUlfUkVTUE9OU0VfSURfQVRUUklCVVRFXTogaWQsXG4gICAgfSk7XG4gIH1cbiAgaWYgKG1vZGVsKSB7XG4gICAgc3Bhbi5zZXRBdHRyaWJ1dGVzKHtcbiAgICAgIFtnZW5BaUF0dHJpYnV0ZXMuT1BFTkFJX1JFU1BPTlNFX01PREVMX0FUVFJJQlVURV06IG1vZGVsLFxuICAgICAgW2dlbkFpQXR0cmlidXRlcy5HRU5fQUlfUkVTUE9OU0VfTU9ERUxfQVRUUklCVVRFXTogbW9kZWwsXG4gICAgfSk7XG4gIH1cbiAgaWYgKHRpbWVzdGFtcCkge1xuICAgIHNwYW4uc2V0QXR0cmlidXRlcyh7XG4gICAgICBbZ2VuQWlBdHRyaWJ1dGVzLk9QRU5BSV9SRVNQT05TRV9USU1FU1RBTVBfQVRUUklCVVRFXTogbmV3IERhdGUodGltZXN0YW1wICogMTAwMCkudG9JU09TdHJpbmcoKSxcbiAgICB9KTtcbiAgfVxufVxuXG4vKipcbiAqIEFkZCBhdHRyaWJ1dGVzIGZvciBDaGF0IENvbXBsZXRpb24gcmVzcG9uc2VzXG4gKi9cbmZ1bmN0aW9uIGFkZENoYXRDb21wbGV0aW9uQXR0cmlidXRlcyhzcGFuLCByZXNwb25zZSkge1xuICBzZXRDb21tb25SZXNwb25zZUF0dHJpYnV0ZXMoc3BhbiwgcmVzcG9uc2UuaWQsIHJlc3BvbnNlLm1vZGVsLCByZXNwb25zZS5jcmVhdGVkKTtcbiAgaWYgKHJlc3BvbnNlLnVzYWdlKSB7XG4gICAgc2V0VG9rZW5Vc2FnZUF0dHJpYnV0ZXMoXG4gICAgICBzcGFuLFxuICAgICAgcmVzcG9uc2UudXNhZ2UucHJvbXB0X3Rva2VucyxcbiAgICAgIHJlc3BvbnNlLnVzYWdlLmNvbXBsZXRpb25fdG9rZW5zLFxuICAgICAgcmVzcG9uc2UudXNhZ2UudG90YWxfdG9rZW5zLFxuICAgICk7XG4gIH1cbiAgaWYgKEFycmF5LmlzQXJyYXkocmVzcG9uc2UuY2hvaWNlcykpIHtcbiAgICBjb25zdCBmaW5pc2hSZWFzb25zID0gcmVzcG9uc2UuY2hvaWNlc1xuICAgICAgLm1hcChjaG9pY2UgPT4gY2hvaWNlLmZpbmlzaF9yZWFzb24pXG4gICAgICAuZmlsdGVyKChyZWFzb24pID0+IHJlYXNvbiAhPT0gbnVsbCk7XG4gICAgaWYgKGZpbmlzaFJlYXNvbnMubGVuZ3RoID4gMCkge1xuICAgICAgc3Bhbi5zZXRBdHRyaWJ1dGVzKHtcbiAgICAgICAgW2dlbkFpQXR0cmlidXRlcy5HRU5fQUlfUkVTUE9OU0VfRklOSVNIX1JFQVNPTlNfQVRUUklCVVRFXTogSlNPTi5zdHJpbmdpZnkoZmluaXNoUmVhc29ucyksXG4gICAgICB9KTtcbiAgICB9XG4gIH1cbn1cblxuLyoqXG4gKiBBZGQgYXR0cmlidXRlcyBmb3IgUmVzcG9uc2VzIEFQSSByZXNwb25zZXNcbiAqL1xuZnVuY3Rpb24gYWRkUmVzcG9uc2VzQXBpQXR0cmlidXRlcyhzcGFuLCByZXNwb25zZSkge1xuICBzZXRDb21tb25SZXNwb25zZUF0dHJpYnV0ZXMoc3BhbiwgcmVzcG9uc2UuaWQsIHJlc3BvbnNlLm1vZGVsLCByZXNwb25zZS5jcmVhdGVkX2F0KTtcbiAgaWYgKHJlc3BvbnNlLnN0YXR1cykge1xuICAgIHNwYW4uc2V0QXR0cmlidXRlcyh7XG4gICAgICBbZ2VuQWlBdHRyaWJ1dGVzLkdFTl9BSV9SRVNQT05TRV9GSU5JU0hfUkVBU09OU19BVFRSSUJVVEVdOiBKU09OLnN0cmluZ2lmeShbcmVzcG9uc2Uuc3RhdHVzXSksXG4gICAgfSk7XG4gIH1cbiAgaWYgKHJlc3BvbnNlLnVzYWdlKSB7XG4gICAgc2V0VG9rZW5Vc2FnZUF0dHJpYnV0ZXMoXG4gICAgICBzcGFuLFxuICAgICAgcmVzcG9uc2UudXNhZ2UuaW5wdXRfdG9rZW5zLFxuICAgICAgcmVzcG9uc2UudXNhZ2Uub3V0cHV0X3Rva2VucyxcbiAgICAgIHJlc3BvbnNlLnVzYWdlLnRvdGFsX3Rva2VucyxcbiAgICApO1xuICB9XG59XG5cbi8qKlxuICogQWRkIHJlc3BvbnNlIGF0dHJpYnV0ZXMgdG8gc3BhbnNcbiAqIFRoaXMgY3VycmVudGx5IHN1cHBvcnRzIGJvdGggQ2hhdCBDb21wbGV0aW9uIGFuZCBSZXNwb25zZXMgQVBJIHJlc3BvbnNlc1xuICovXG5mdW5jdGlvbiBhZGRSZXNwb25zZUF0dHJpYnV0ZXMoc3BhbiwgcmVzdWx0LCByZWNvcmRPdXRwdXRzKSB7XG4gIGlmICghcmVzdWx0IHx8IHR5cGVvZiByZXN1bHQgIT09ICdvYmplY3QnKSByZXR1cm47XG5cbiAgY29uc3QgcmVzcG9uc2UgPSByZXN1bHQgO1xuXG4gIGlmICh1dGlscy5pc0NoYXRDb21wbGV0aW9uUmVzcG9uc2UocmVzcG9uc2UpKSB7XG4gICAgYWRkQ2hhdENvbXBsZXRpb25BdHRyaWJ1dGVzKHNwYW4sIHJlc3BvbnNlKTtcbiAgICBpZiAocmVjb3JkT3V0cHV0cyAmJiByZXNwb25zZS5jaG9pY2VzPy5sZW5ndGgpIHtcbiAgICAgIGNvbnN0IHJlc3BvbnNlVGV4dHMgPSByZXNwb25zZS5jaG9pY2VzLm1hcChjaG9pY2UgPT4gY2hvaWNlLm1lc3NhZ2U/LmNvbnRlbnQgfHwgJycpO1xuICAgICAgc3Bhbi5zZXRBdHRyaWJ1dGVzKHsgW2dlbkFpQXR0cmlidXRlcy5HRU5fQUlfUkVTUE9OU0VfVEVYVF9BVFRSSUJVVEVdOiBKU09OLnN0cmluZ2lmeShyZXNwb25zZVRleHRzKSB9KTtcbiAgICB9XG4gIH0gZWxzZSBpZiAodXRpbHMuaXNSZXNwb25zZXNBcGlSZXNwb25zZShyZXNwb25zZSkpIHtcbiAgICBhZGRSZXNwb25zZXNBcGlBdHRyaWJ1dGVzKHNwYW4sIHJlc3BvbnNlKTtcbiAgICBpZiAocmVjb3JkT3V0cHV0cyAmJiByZXNwb25zZS5vdXRwdXRfdGV4dCkge1xuICAgICAgc3Bhbi5zZXRBdHRyaWJ1dGVzKHsgW2dlbkFpQXR0cmlidXRlcy5HRU5fQUlfUkVTUE9OU0VfVEVYVF9BVFRSSUJVVEVdOiByZXNwb25zZS5vdXRwdXRfdGV4dCB9KTtcbiAgICB9XG4gIH1cbn1cblxuLy8gRXh0cmFjdCBhbmQgcmVjb3JkIEFJIHJlcXVlc3QgaW5wdXRzLCBpZiBwcmVzZW50LiBUaGlzIGlzIGludGVudGlvbmFsbHkgc2VwYXJhdGUgZnJvbSByZXNwb25zZSBhdHRyaWJ1dGVzLlxuZnVuY3Rpb24gYWRkUmVxdWVzdEF0dHJpYnV0ZXMoc3BhbiwgcGFyYW1zKSB7XG4gIGlmICgnbWVzc2FnZXMnIGluIHBhcmFtcykge1xuICAgIHNwYW4uc2V0QXR0cmlidXRlcyh7IFtnZW5BaUF0dHJpYnV0ZXMuR0VOX0FJX1JFUVVFU1RfTUVTU0FHRVNfQVRUUklCVVRFXTogSlNPTi5zdHJpbmdpZnkocGFyYW1zLm1lc3NhZ2VzKSB9KTtcbiAgfVxuICBpZiAoJ2lucHV0JyBpbiBwYXJhbXMpIHtcbiAgICBzcGFuLnNldEF0dHJpYnV0ZXMoeyBbZ2VuQWlBdHRyaWJ1dGVzLkdFTl9BSV9SRVFVRVNUX01FU1NBR0VTX0FUVFJJQlVURV06IEpTT04uc3RyaW5naWZ5KHBhcmFtcy5pbnB1dCkgfSk7XG4gIH1cbn1cblxuZnVuY3Rpb24gZ2V0T3B0aW9uc0Zyb21JbnRlZ3JhdGlvbigpIHtcbiAgY29uc3Qgc2NvcGUgPSBjdXJyZW50U2NvcGVzLmdldEN1cnJlbnRTY29wZSgpO1xuICBjb25zdCBjbGllbnQgPSBzY29wZS5nZXRDbGllbnQoKTtcbiAgY29uc3QgaW50ZWdyYXRpb24gPSBjbGllbnQ/LmdldEludGVncmF0aW9uQnlOYW1lKGNvbnN0YW50cy5PUEVOQUlfSU5URUdSQVRJT05fTkFNRSkgO1xuICBjb25zdCBzaG91bGRSZWNvcmRJbnB1dHNBbmRPdXRwdXRzID0gaW50ZWdyYXRpb24gPyBCb29sZWFuKGNsaWVudD8uZ2V0T3B0aW9ucygpLnNlbmREZWZhdWx0UGlpKSA6IGZhbHNlO1xuXG4gIHJldHVybiB7XG4gICAgcmVjb3JkSW5wdXRzOiBpbnRlZ3JhdGlvbj8ub3B0aW9ucz8ucmVjb3JkSW5wdXRzID8/IHNob3VsZFJlY29yZElucHV0c0FuZE91dHB1dHMsXG4gICAgcmVjb3JkT3V0cHV0czogaW50ZWdyYXRpb24/Lm9wdGlvbnM/LnJlY29yZE91dHB1dHMgPz8gc2hvdWxkUmVjb3JkSW5wdXRzQW5kT3V0cHV0cyxcbiAgfTtcbn1cblxuLyoqXG4gKiBJbnN0cnVtZW50IGEgbWV0aG9kIHdpdGggU2VudHJ5IHNwYW5zXG4gKiBGb2xsb3dpbmcgU2VudHJ5IEFJIEFnZW50cyBNYW51YWwgSW5zdHJ1bWVudGF0aW9uIGNvbnZlbnRpb25zXG4gKiBAc2VlIGh0dHBzOi8vZG9jcy5zZW50cnkuaW8vcGxhdGZvcm1zL2phdmFzY3JpcHQvZ3VpZGVzL25vZGUvdHJhY2luZy9pbnN0cnVtZW50YXRpb24vYWktYWdlbnRzLW1vZHVsZS8jbWFudWFsLWluc3RydW1lbnRhdGlvblxuICovXG5mdW5jdGlvbiBpbnN0cnVtZW50TWV0aG9kKFxuICBvcmlnaW5hbE1ldGhvZCxcbiAgbWV0aG9kUGF0aCxcbiAgY29udGV4dCxcbiAgb3B0aW9ucyxcbikge1xuICByZXR1cm4gYXN5bmMgZnVuY3Rpb24gaW5zdHJ1bWVudGVkTWV0aG9kKC4uLmFyZ3MpIHtcbiAgICBjb25zdCBmaW5hbE9wdGlvbnMgPSBvcHRpb25zIHx8IGdldE9wdGlvbnNGcm9tSW50ZWdyYXRpb24oKTtcbiAgICBjb25zdCByZXF1ZXN0QXR0cmlidXRlcyA9IGV4dHJhY3RSZXF1ZXN0QXR0cmlidXRlcyhhcmdzLCBtZXRob2RQYXRoKTtcbiAgICBjb25zdCBtb2RlbCA9IChyZXF1ZXN0QXR0cmlidXRlc1tnZW5BaUF0dHJpYnV0ZXMuR0VOX0FJX1JFUVVFU1RfTU9ERUxfQVRUUklCVVRFXSApIHx8ICd1bmtub3duJztcbiAgICBjb25zdCBvcGVyYXRpb25OYW1lID0gdXRpbHMuZ2V0T3BlcmF0aW9uTmFtZShtZXRob2RQYXRoKTtcblxuICAgIHJldHVybiB0cmFjZS5zdGFydFNwYW4oXG4gICAgICB7XG4gICAgICAgIG5hbWU6IGAke29wZXJhdGlvbk5hbWV9ICR7bW9kZWx9YCxcbiAgICAgICAgb3A6IHV0aWxzLmdldFNwYW5PcGVyYXRpb24obWV0aG9kUGF0aCksXG4gICAgICAgIGF0dHJpYnV0ZXM6IHJlcXVlc3RBdHRyaWJ1dGVzICxcbiAgICAgIH0sXG4gICAgICBhc3luYyAoc3BhbikgPT4ge1xuICAgICAgICB0cnkge1xuICAgICAgICAgIGlmIChmaW5hbE9wdGlvbnMucmVjb3JkSW5wdXRzICYmIGFyZ3NbMF0gJiYgdHlwZW9mIGFyZ3NbMF0gPT09ICdvYmplY3QnKSB7XG4gICAgICAgICAgICBhZGRSZXF1ZXN0QXR0cmlidXRlcyhzcGFuLCBhcmdzWzBdICk7XG4gICAgICAgICAgfVxuXG4gICAgICAgICAgY29uc3QgcmVzdWx0ID0gYXdhaXQgb3JpZ2luYWxNZXRob2QuYXBwbHkoY29udGV4dCwgYXJncyk7XG4gICAgICAgICAgLy8gVE9ETzogQWRkIHN0cmVhbWluZyBzdXBwb3J0XG4gICAgICAgICAgYWRkUmVzcG9uc2VBdHRyaWJ1dGVzKHNwYW4sIHJlc3VsdCwgZmluYWxPcHRpb25zLnJlY29yZE91dHB1dHMpO1xuICAgICAgICAgIHJldHVybiByZXN1bHQ7XG4gICAgICAgIH0gY2F0Y2ggKGVycm9yKSB7XG4gICAgICAgICAgZXhwb3J0cyQxLmNhcHR1cmVFeGNlcHRpb24oZXJyb3IpO1xuICAgICAgICAgIHRocm93IGVycm9yO1xuICAgICAgICB9XG4gICAgICB9LFxuICAgICk7XG4gIH07XG59XG5cbi8qKlxuICogQ3JlYXRlIGEgZGVlcCBwcm94eSBmb3IgT3BlbkFJIGNsaWVudCBpbnN0cnVtZW50YXRpb25cbiAqL1xuZnVuY3Rpb24gY3JlYXRlRGVlcFByb3h5KHRhcmdldCwgY3VycmVudFBhdGggPSAnJywgb3B0aW9ucykge1xuICByZXR1cm4gbmV3IFByb3h5KHRhcmdldCwge1xuICAgIGdldChvYmosIHByb3ApIHtcbiAgICAgIGNvbnN0IHZhbHVlID0gKG9iaiApW3Byb3BdO1xuICAgICAgY29uc3QgbWV0aG9kUGF0aCA9IHV0aWxzLmJ1aWxkTWV0aG9kUGF0aChjdXJyZW50UGF0aCwgU3RyaW5nKHByb3ApKTtcblxuICAgICAgaWYgKHR5cGVvZiB2YWx1ZSA9PT0gJ2Z1bmN0aW9uJyAmJiB1dGlscy5zaG91bGRJbnN0cnVtZW50KG1ldGhvZFBhdGgpKSB7XG4gICAgICAgIHJldHVybiBpbnN0cnVtZW50TWV0aG9kKHZhbHVlICwgbWV0aG9kUGF0aCwgb2JqLCBvcHRpb25zKTtcbiAgICAgIH1cblxuICAgICAgaWYgKHR5cGVvZiB2YWx1ZSA9PT0gJ2Z1bmN0aW9uJykge1xuICAgICAgICAvLyBCaW5kIG5vbi1pbnN0cnVtZW50ZWQgZnVuY3Rpb25zIHRvIHByZXNlcnZlIHRoZSBvcmlnaW5hbCBgdGhpc2AgY29udGV4dCxcbiAgICAgICAgLy8gd2hpY2ggaXMgcmVxdWlyZWQgZm9yIGFjY2Vzc2luZyBwcml2YXRlIGNsYXNzIGZpZWxkcyAoZS5nLiAjYmFzZVVSTCkgaW4gT3BlbkFJIFNESyB2NS5cbiAgICAgICAgcmV0dXJuIHZhbHVlLmJpbmQob2JqKTtcbiAgICAgIH1cblxuICAgICAgaWYgKHZhbHVlICYmIHR5cGVvZiB2YWx1ZSA9PT0gJ29iamVjdCcpIHtcbiAgICAgICAgcmV0dXJuIGNyZWF0ZURlZXBQcm94eSh2YWx1ZSAsIG1ldGhvZFBhdGgsIG9wdGlvbnMpO1xuICAgICAgfVxuXG4gICAgICByZXR1cm4gdmFsdWU7XG4gICAgfSxcbiAgfSk7XG59XG5cbi8qKlxuICogSW5zdHJ1bWVudCBhbiBPcGVuQUkgY2xpZW50IHdpdGggU2VudHJ5IHRyYWNpbmdcbiAqIENhbiBiZSB1c2VkIGFjcm9zcyBOb2RlLmpzLCBDbG91ZGZsYXJlIFdvcmtlcnMsIGFuZCBWZXJjZWwgRWRnZVxuICovXG5mdW5jdGlvbiBpbnN0cnVtZW50T3BlbkFpQ2xpZW50KGNsaWVudCwgb3B0aW9ucykge1xuICByZXR1cm4gY3JlYXRlRGVlcFByb3h5KGNsaWVudCwgJycsIG9wdGlvbnMpO1xufVxuXG5leHBvcnRzLmluc3RydW1lbnRPcGVuQWlDbGllbnQgPSBpbnN0cnVtZW50T3BlbkFpQ2xpZW50O1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9aW5kZXguanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/openai/index.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/openai/utils.js":
/*!**********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/openai/utils.js ***!
  \**********************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst genAiAttributes = __webpack_require__(/*! ../gen-ai-attributes.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/gen-ai-attributes.js\");\nconst constants = __webpack_require__(/*! ./constants.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/openai/constants.js\");\n\n/**\n * Maps OpenAI method paths to Sentry operation names\n */\nfunction getOperationName(methodPath) {\n  if (methodPath.includes('chat.completions')) {\n    return genAiAttributes.OPENAI_OPERATIONS.CHAT;\n  }\n  if (methodPath.includes('responses')) {\n    // The responses API is also a chat operation\n    return genAiAttributes.OPENAI_OPERATIONS.CHAT;\n  }\n  return methodPath.split('.').pop() || 'unknown';\n}\n\n/**\n * Get the span operation for OpenAI methods\n * Following Sentry's convention: \"gen_ai.{operation_name}\"\n */\nfunction getSpanOperation(methodPath) {\n  return `gen_ai.${getOperationName(methodPath)}`;\n}\n\n/**\n * Check if a method path should be instrumented\n */\nfunction shouldInstrument(methodPath) {\n  return constants.INSTRUMENTED_METHODS.includes(methodPath );\n}\n\n/**\n * Build method path from current traversal\n */\nfunction buildMethodPath(currentPath, prop) {\n  return currentPath ? `${currentPath}.${prop}` : prop;\n}\n\n/**\n * Check if response is a Chat Completion object\n */\nfunction isChatCompletionResponse(response) {\n  return (\n    response !== null &&\n    typeof response === 'object' &&\n    'object' in response &&\n    (response ).object === 'chat.completion'\n  );\n}\n\n/**\n * Check if response is a Responses API object\n */\nfunction isResponsesApiResponse(response) {\n  return (\n    response !== null &&\n    typeof response === 'object' &&\n    'object' in response &&\n    (response ).object === 'response'\n  );\n}\n\nexports.buildMethodPath = buildMethodPath;\nexports.getOperationName = getOperationName;\nexports.getSpanOperation = getSpanOperation;\nexports.isChatCompletionResponse = isChatCompletionResponse;\nexports.isResponsesApiResponse = isResponsesApiResponse;\nexports.shouldInstrument = shouldInstrument;\n//# sourceMappingURL=utils.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvb3BlbmFpL3V0aWxzLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLHdCQUF3QixtQkFBTyxDQUFDLHFKQUF5QjtBQUN6RCxrQkFBa0IsbUJBQU8sQ0FBQywySUFBZ0I7O0FBRTFDO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQSwyQ0FBMkMsZUFBZTtBQUMxRDtBQUNBO0FBQ0EsbUJBQW1CLDZCQUE2QjtBQUNoRDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQSwwQkFBMEIsWUFBWSxHQUFHLEtBQUs7QUFDOUM7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLHVCQUF1QjtBQUN2Qix3QkFBd0I7QUFDeEIsd0JBQXdCO0FBQ3hCLGdDQUFnQztBQUNoQyw4QkFBOEI7QUFDOUIsd0JBQXdCO0FBQ3hCIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvb3BlbmFpL3V0aWxzLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBnZW5BaUF0dHJpYnV0ZXMgPSByZXF1aXJlKCcuLi9nZW4tYWktYXR0cmlidXRlcy5qcycpO1xuY29uc3QgY29uc3RhbnRzID0gcmVxdWlyZSgnLi9jb25zdGFudHMuanMnKTtcblxuLyoqXG4gKiBNYXBzIE9wZW5BSSBtZXRob2QgcGF0aHMgdG8gU2VudHJ5IG9wZXJhdGlvbiBuYW1lc1xuICovXG5mdW5jdGlvbiBnZXRPcGVyYXRpb25OYW1lKG1ldGhvZFBhdGgpIHtcbiAgaWYgKG1ldGhvZFBhdGguaW5jbHVkZXMoJ2NoYXQuY29tcGxldGlvbnMnKSkge1xuICAgIHJldHVybiBnZW5BaUF0dHJpYnV0ZXMuT1BFTkFJX09QRVJBVElPTlMuQ0hBVDtcbiAgfVxuICBpZiAobWV0aG9kUGF0aC5pbmNsdWRlcygncmVzcG9uc2VzJykpIHtcbiAgICAvLyBUaGUgcmVzcG9uc2VzIEFQSSBpcyBhbHNvIGEgY2hhdCBvcGVyYXRpb25cbiAgICByZXR1cm4gZ2VuQWlBdHRyaWJ1dGVzLk9QRU5BSV9PUEVSQVRJT05TLkNIQVQ7XG4gIH1cbiAgcmV0dXJuIG1ldGhvZFBhdGguc3BsaXQoJy4nKS5wb3AoKSB8fCAndW5rbm93bic7XG59XG5cbi8qKlxuICogR2V0IHRoZSBzcGFuIG9wZXJhdGlvbiBmb3IgT3BlbkFJIG1ldGhvZHNcbiAqIEZvbGxvd2luZyBTZW50cnkncyBjb252ZW50aW9uOiBcImdlbl9haS57b3BlcmF0aW9uX25hbWV9XCJcbiAqL1xuZnVuY3Rpb24gZ2V0U3Bhbk9wZXJhdGlvbihtZXRob2RQYXRoKSB7XG4gIHJldHVybiBgZ2VuX2FpLiR7Z2V0T3BlcmF0aW9uTmFtZShtZXRob2RQYXRoKX1gO1xufVxuXG4vKipcbiAqIENoZWNrIGlmIGEgbWV0aG9kIHBhdGggc2hvdWxkIGJlIGluc3RydW1lbnRlZFxuICovXG5mdW5jdGlvbiBzaG91bGRJbnN0cnVtZW50KG1ldGhvZFBhdGgpIHtcbiAgcmV0dXJuIGNvbnN0YW50cy5JTlNUUlVNRU5URURfTUVUSE9EUy5pbmNsdWRlcyhtZXRob2RQYXRoICk7XG59XG5cbi8qKlxuICogQnVpbGQgbWV0aG9kIHBhdGggZnJvbSBjdXJyZW50IHRyYXZlcnNhbFxuICovXG5mdW5jdGlvbiBidWlsZE1ldGhvZFBhdGgoY3VycmVudFBhdGgsIHByb3ApIHtcbiAgcmV0dXJuIGN1cnJlbnRQYXRoID8gYCR7Y3VycmVudFBhdGh9LiR7cHJvcH1gIDogcHJvcDtcbn1cblxuLyoqXG4gKiBDaGVjayBpZiByZXNwb25zZSBpcyBhIENoYXQgQ29tcGxldGlvbiBvYmplY3RcbiAqL1xuZnVuY3Rpb24gaXNDaGF0Q29tcGxldGlvblJlc3BvbnNlKHJlc3BvbnNlKSB7XG4gIHJldHVybiAoXG4gICAgcmVzcG9uc2UgIT09IG51bGwgJiZcbiAgICB0eXBlb2YgcmVzcG9uc2UgPT09ICdvYmplY3QnICYmXG4gICAgJ29iamVjdCcgaW4gcmVzcG9uc2UgJiZcbiAgICAocmVzcG9uc2UgKS5vYmplY3QgPT09ICdjaGF0LmNvbXBsZXRpb24nXG4gICk7XG59XG5cbi8qKlxuICogQ2hlY2sgaWYgcmVzcG9uc2UgaXMgYSBSZXNwb25zZXMgQVBJIG9iamVjdFxuICovXG5mdW5jdGlvbiBpc1Jlc3BvbnNlc0FwaVJlc3BvbnNlKHJlc3BvbnNlKSB7XG4gIHJldHVybiAoXG4gICAgcmVzcG9uc2UgIT09IG51bGwgJiZcbiAgICB0eXBlb2YgcmVzcG9uc2UgPT09ICdvYmplY3QnICYmXG4gICAgJ29iamVjdCcgaW4gcmVzcG9uc2UgJiZcbiAgICAocmVzcG9uc2UgKS5vYmplY3QgPT09ICdyZXNwb25zZSdcbiAgKTtcbn1cblxuZXhwb3J0cy5idWlsZE1ldGhvZFBhdGggPSBidWlsZE1ldGhvZFBhdGg7XG5leHBvcnRzLmdldE9wZXJhdGlvbk5hbWUgPSBnZXRPcGVyYXRpb25OYW1lO1xuZXhwb3J0cy5nZXRTcGFuT3BlcmF0aW9uID0gZ2V0U3Bhbk9wZXJhdGlvbjtcbmV4cG9ydHMuaXNDaGF0Q29tcGxldGlvblJlc3BvbnNlID0gaXNDaGF0Q29tcGxldGlvblJlc3BvbnNlO1xuZXhwb3J0cy5pc1Jlc3BvbnNlc0FwaVJlc3BvbnNlID0gaXNSZXNwb25zZXNBcGlSZXNwb25zZTtcbmV4cG9ydHMuc2hvdWxkSW5zdHJ1bWVudCA9IHNob3VsZEluc3RydW1lbnQ7XG4vLyMgc291cmNlTWFwcGluZ1VSTD11dGlscy5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/openai/utils.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/parameterize.js":
/*!**********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/parameterize.js ***!
  \**********************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n/**\n * Tagged template function which returns parameterized representation of the message\n * For example: parameterize`This is a log statement with ${x} and ${y} params`, would return:\n * \"__sentry_template_string__\": 'This is a log statement with %s and %s params',\n * \"__sentry_template_values__\": ['first', 'second']\n *\n * @param strings An array of string values splitted between expressions\n * @param values Expressions extracted from template string\n *\n * @returns A `ParameterizedString` object that can be passed into `captureMessage` or Sentry.logger.X methods.\n */\nfunction parameterize(strings, ...values) {\n  const formatted = new String(String.raw(strings, ...values)) ;\n  formatted.__sentry_template_string__ = strings.join('\\x00').replace(/%/g, '%%').replace(/\\0/g, '%s');\n  formatted.__sentry_template_values__ = values;\n  return formatted;\n}\n\n/**\n * Tagged template function which returns parameterized representation of the message.\n *\n * @param strings An array of string values splitted between expressions\n * @param values Expressions extracted from template string\n * @returns A `ParameterizedString` object that can be passed into `captureMessage` or Sentry.logger.X methods.\n */\nconst fmt = parameterize;\n\nexports.fmt = fmt;\nexports.parameterize = parameterize;\n//# sourceMappingURL=parameterize.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvcGFyYW1ldGVyaXplLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFO0FBQ0E7QUFDQSw0REFBNEQsR0FBRyxNQUFNLEdBQUc7QUFDeEU7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLFdBQVc7QUFDWCxvQkFBb0I7QUFDcEIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9wYXJhbWV0ZXJpemUuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbi8qKlxuICogVGFnZ2VkIHRlbXBsYXRlIGZ1bmN0aW9uIHdoaWNoIHJldHVybnMgcGFyYW1ldGVyaXplZCByZXByZXNlbnRhdGlvbiBvZiB0aGUgbWVzc2FnZVxuICogRm9yIGV4YW1wbGU6IHBhcmFtZXRlcml6ZWBUaGlzIGlzIGEgbG9nIHN0YXRlbWVudCB3aXRoICR7eH0gYW5kICR7eX0gcGFyYW1zYCwgd291bGQgcmV0dXJuOlxuICogXCJfX3NlbnRyeV90ZW1wbGF0ZV9zdHJpbmdfX1wiOiAnVGhpcyBpcyBhIGxvZyBzdGF0ZW1lbnQgd2l0aCAlcyBhbmQgJXMgcGFyYW1zJyxcbiAqIFwiX19zZW50cnlfdGVtcGxhdGVfdmFsdWVzX19cIjogWydmaXJzdCcsICdzZWNvbmQnXVxuICpcbiAqIEBwYXJhbSBzdHJpbmdzIEFuIGFycmF5IG9mIHN0cmluZyB2YWx1ZXMgc3BsaXR0ZWQgYmV0d2VlbiBleHByZXNzaW9uc1xuICogQHBhcmFtIHZhbHVlcyBFeHByZXNzaW9ucyBleHRyYWN0ZWQgZnJvbSB0ZW1wbGF0ZSBzdHJpbmdcbiAqXG4gKiBAcmV0dXJucyBBIGBQYXJhbWV0ZXJpemVkU3RyaW5nYCBvYmplY3QgdGhhdCBjYW4gYmUgcGFzc2VkIGludG8gYGNhcHR1cmVNZXNzYWdlYCBvciBTZW50cnkubG9nZ2VyLlggbWV0aG9kcy5cbiAqL1xuZnVuY3Rpb24gcGFyYW1ldGVyaXplKHN0cmluZ3MsIC4uLnZhbHVlcykge1xuICBjb25zdCBmb3JtYXR0ZWQgPSBuZXcgU3RyaW5nKFN0cmluZy5yYXcoc3RyaW5ncywgLi4udmFsdWVzKSkgO1xuICBmb3JtYXR0ZWQuX19zZW50cnlfdGVtcGxhdGVfc3RyaW5nX18gPSBzdHJpbmdzLmpvaW4oJ1xceDAwJykucmVwbGFjZSgvJS9nLCAnJSUnKS5yZXBsYWNlKC9cXDAvZywgJyVzJyk7XG4gIGZvcm1hdHRlZC5fX3NlbnRyeV90ZW1wbGF0ZV92YWx1ZXNfXyA9IHZhbHVlcztcbiAgcmV0dXJuIGZvcm1hdHRlZDtcbn1cblxuLyoqXG4gKiBUYWdnZWQgdGVtcGxhdGUgZnVuY3Rpb24gd2hpY2ggcmV0dXJucyBwYXJhbWV0ZXJpemVkIHJlcHJlc2VudGF0aW9uIG9mIHRoZSBtZXNzYWdlLlxuICpcbiAqIEBwYXJhbSBzdHJpbmdzIEFuIGFycmF5IG9mIHN0cmluZyB2YWx1ZXMgc3BsaXR0ZWQgYmV0d2VlbiBleHByZXNzaW9uc1xuICogQHBhcmFtIHZhbHVlcyBFeHByZXNzaW9ucyBleHRyYWN0ZWQgZnJvbSB0ZW1wbGF0ZSBzdHJpbmdcbiAqIEByZXR1cm5zIEEgYFBhcmFtZXRlcml6ZWRTdHJpbmdgIG9iamVjdCB0aGF0IGNhbiBiZSBwYXNzZWQgaW50byBgY2FwdHVyZU1lc3NhZ2VgIG9yIFNlbnRyeS5sb2dnZXIuWCBtZXRob2RzLlxuICovXG5jb25zdCBmbXQgPSBwYXJhbWV0ZXJpemU7XG5cbmV4cG9ydHMuZm10ID0gZm10O1xuZXhwb3J0cy5wYXJhbWV0ZXJpemUgPSBwYXJhbWV0ZXJpemU7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1wYXJhbWV0ZXJpemUuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/parameterize.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/parseSampleRate.js":
/*!*************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/parseSampleRate.js ***!
  \*************************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n/**\n * Parse a sample rate from a given value.\n * This will either return a boolean or number sample rate, if the sample rate is valid (between 0 and 1).\n * If a string is passed, we try to convert it to a number.\n *\n * Any invalid sample rate will return `undefined`.\n */\nfunction parseSampleRate(sampleRate) {\n  if (typeof sampleRate === 'boolean') {\n    return Number(sampleRate);\n  }\n\n  const rate = typeof sampleRate === 'string' ? parseFloat(sampleRate) : sampleRate;\n  if (typeof rate !== 'number' || isNaN(rate) || rate < 0 || rate > 1) {\n    return undefined;\n  }\n\n  return rate;\n}\n\nexports.parseSampleRate = parseSampleRate;\n//# sourceMappingURL=parseSampleRate.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvcGFyc2VTYW1wbGVSYXRlLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQSx1QkFBdUI7QUFDdkIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9wYXJzZVNhbXBsZVJhdGUuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbi8qKlxuICogUGFyc2UgYSBzYW1wbGUgcmF0ZSBmcm9tIGEgZ2l2ZW4gdmFsdWUuXG4gKiBUaGlzIHdpbGwgZWl0aGVyIHJldHVybiBhIGJvb2xlYW4gb3IgbnVtYmVyIHNhbXBsZSByYXRlLCBpZiB0aGUgc2FtcGxlIHJhdGUgaXMgdmFsaWQgKGJldHdlZW4gMCBhbmQgMSkuXG4gKiBJZiBhIHN0cmluZyBpcyBwYXNzZWQsIHdlIHRyeSB0byBjb252ZXJ0IGl0IHRvIGEgbnVtYmVyLlxuICpcbiAqIEFueSBpbnZhbGlkIHNhbXBsZSByYXRlIHdpbGwgcmV0dXJuIGB1bmRlZmluZWRgLlxuICovXG5mdW5jdGlvbiBwYXJzZVNhbXBsZVJhdGUoc2FtcGxlUmF0ZSkge1xuICBpZiAodHlwZW9mIHNhbXBsZVJhdGUgPT09ICdib29sZWFuJykge1xuICAgIHJldHVybiBOdW1iZXIoc2FtcGxlUmF0ZSk7XG4gIH1cblxuICBjb25zdCByYXRlID0gdHlwZW9mIHNhbXBsZVJhdGUgPT09ICdzdHJpbmcnID8gcGFyc2VGbG9hdChzYW1wbGVSYXRlKSA6IHNhbXBsZVJhdGU7XG4gIGlmICh0eXBlb2YgcmF0ZSAhPT0gJ251bWJlcicgfHwgaXNOYU4ocmF0ZSkgfHwgcmF0ZSA8IDAgfHwgcmF0ZSA+IDEpIHtcbiAgICByZXR1cm4gdW5kZWZpbmVkO1xuICB9XG5cbiAgcmV0dXJuIHJhdGU7XG59XG5cbmV4cG9ydHMucGFyc2VTYW1wbGVSYXRlID0gcGFyc2VTYW1wbGVSYXRlO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9cGFyc2VTYW1wbGVSYXRlLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/parseSampleRate.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/path.js":
/*!**************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/path.js ***!
  \**************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n// Slightly modified (no IE8 support, ES6) and transcribed to TypeScript\n// https://github.com/calvinmetcalf/rollup-plugin-node-builtins/blob/63ab8aacd013767445ca299e468d9a60a95328d7/src/es6/path.js\n//\n// Copyright Joyent, Inc.and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n/** JSDoc */\nfunction normalizeArray(parts, allowAboveRoot) {\n  // if the path tries to go above the root, `up` ends up > 0\n  let up = 0;\n  for (let i = parts.length - 1; i >= 0; i--) {\n    const last = parts[i];\n    if (last === '.') {\n      parts.splice(i, 1);\n    } else if (last === '..') {\n      parts.splice(i, 1);\n      up++;\n    } else if (up) {\n      parts.splice(i, 1);\n      up--;\n    }\n  }\n\n  // if the path is allowed to go above the root, restore leading ..s\n  if (allowAboveRoot) {\n    for (; up--; up) {\n      parts.unshift('..');\n    }\n  }\n\n  return parts;\n}\n\n// Split a filename into [root, dir, basename, ext], unix version\n// 'root' is just a slash, or nothing.\nconst splitPathRe = /^(\\S+:\\\\|\\/?)([\\s\\S]*?)((?:\\.{1,2}|[^/\\\\]+?|)(\\.[^./\\\\]*|))(?:[/\\\\]*)$/;\n/** JSDoc */\nfunction splitPath(filename) {\n  // Truncate files names greater than 1024 characters to avoid regex dos\n  // https://github.com/getsentry/sentry-javascript/pull/8737#discussion_r1285719172\n  const truncated = filename.length > 1024 ? `<truncated>${filename.slice(-1024)}` : filename;\n  const parts = splitPathRe.exec(truncated);\n  return parts ? parts.slice(1) : [];\n}\n\n// path.resolve([from ...], to)\n// posix version\n/** JSDoc */\nfunction resolve(...args) {\n  let resolvedPath = '';\n  let resolvedAbsolute = false;\n\n  for (let i = args.length - 1; i >= -1 && !resolvedAbsolute; i--) {\n    const path = i >= 0 ? args[i] : '/';\n\n    // Skip empty entries\n    if (!path) {\n      continue;\n    }\n\n    resolvedPath = `${path}/${resolvedPath}`;\n    resolvedAbsolute = path.charAt(0) === '/';\n  }\n\n  // At this point the path should be resolved to a full absolute path, but\n  // handle relative paths to be safe (might happen when process.cwd() fails)\n\n  // Normalize the path\n  resolvedPath = normalizeArray(\n    resolvedPath.split('/').filter(p => !!p),\n    !resolvedAbsolute,\n  ).join('/');\n\n  return (resolvedAbsolute ? '/' : '') + resolvedPath || '.';\n}\n\n/** JSDoc */\nfunction trim(arr) {\n  let start = 0;\n  for (; start < arr.length; start++) {\n    if (arr[start] !== '') {\n      break;\n    }\n  }\n\n  let end = arr.length - 1;\n  for (; end >= 0; end--) {\n    if (arr[end] !== '') {\n      break;\n    }\n  }\n\n  if (start > end) {\n    return [];\n  }\n  return arr.slice(start, end - start + 1);\n}\n\n// path.relative(from, to)\n// posix version\n/** JSDoc */\nfunction relative(from, to) {\n  /* eslint-disable no-param-reassign */\n  from = resolve(from).slice(1);\n  to = resolve(to).slice(1);\n  /* eslint-enable no-param-reassign */\n\n  const fromParts = trim(from.split('/'));\n  const toParts = trim(to.split('/'));\n\n  const length = Math.min(fromParts.length, toParts.length);\n  let samePartsLength = length;\n  for (let i = 0; i < length; i++) {\n    if (fromParts[i] !== toParts[i]) {\n      samePartsLength = i;\n      break;\n    }\n  }\n\n  let outputParts = [];\n  for (let i = samePartsLength; i < fromParts.length; i++) {\n    outputParts.push('..');\n  }\n\n  outputParts = outputParts.concat(toParts.slice(samePartsLength));\n\n  return outputParts.join('/');\n}\n\n// path.normalize(path)\n// posix version\n/** JSDoc */\nfunction normalizePath(path) {\n  const isPathAbsolute = isAbsolute(path);\n  const trailingSlash = path.slice(-1) === '/';\n\n  // Normalize the path\n  let normalizedPath = normalizeArray(\n    path.split('/').filter(p => !!p),\n    !isPathAbsolute,\n  ).join('/');\n\n  if (!normalizedPath && !isPathAbsolute) {\n    normalizedPath = '.';\n  }\n  if (normalizedPath && trailingSlash) {\n    normalizedPath += '/';\n  }\n\n  return (isPathAbsolute ? '/' : '') + normalizedPath;\n}\n\n// posix version\n/** JSDoc */\nfunction isAbsolute(path) {\n  return path.charAt(0) === '/';\n}\n\n// posix version\n/** JSDoc */\nfunction join(...args) {\n  return normalizePath(args.join('/'));\n}\n\n/** JSDoc */\nfunction dirname(path) {\n  const result = splitPath(path);\n  const root = result[0] || '';\n  let dir = result[1];\n\n  if (!root && !dir) {\n    // No dirname whatsoever\n    return '.';\n  }\n\n  if (dir) {\n    // It has a dirname, strip trailing slash\n    dir = dir.slice(0, dir.length - 1);\n  }\n\n  return root + dir;\n}\n\n/** JSDoc */\nfunction basename(path, ext) {\n  let f = splitPath(path)[2] || '';\n  if (ext && f.slice(ext.length * -1) === ext) {\n    f = f.slice(0, f.length - ext.length);\n  }\n  return f;\n}\n\nexports.basename = basename;\nexports.dirname = dirname;\nexports.isAbsolute = isAbsolute;\nexports.join = join;\nexports.normalizePath = normalizePath;\nexports.relative = relative;\nexports.resolve = resolve;\n//# sourceMappingURL=path.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvcGF0aC5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsaUNBQWlDLFFBQVE7QUFDekM7QUFDQTtBQUNBO0FBQ0EsTUFBTTtBQUNOO0FBQ0E7QUFDQSxNQUFNO0FBQ047QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLFdBQVcsTUFBTTtBQUNqQjtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsbURBQW1ELElBQUk7QUFDdkQ7QUFDQTtBQUNBO0FBQ0E7QUFDQSwyREFBMkQsc0JBQXNCO0FBQ2pGO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsZ0NBQWdDLDhCQUE4QjtBQUM5RDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSxzQkFBc0IsS0FBSyxHQUFHLGFBQWE7QUFDM0M7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQSxTQUFTLG9CQUFvQjtBQUM3QjtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBLFNBQVMsVUFBVTtBQUNuQjtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0Esa0JBQWtCLFlBQVk7QUFDOUI7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBLGdDQUFnQyxzQkFBc0I7QUFDdEQ7QUFDQTs7QUFFQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSxnQkFBZ0I7QUFDaEIsZUFBZTtBQUNmLGtCQUFrQjtBQUNsQixZQUFZO0FBQ1oscUJBQXFCO0FBQ3JCLGdCQUFnQjtBQUNoQixlQUFlO0FBQ2YiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9wYXRoLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG4vLyBTbGlnaHRseSBtb2RpZmllZCAobm8gSUU4IHN1cHBvcnQsIEVTNikgYW5kIHRyYW5zY3JpYmVkIHRvIFR5cGVTY3JpcHRcbi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9jYWx2aW5tZXRjYWxmL3JvbGx1cC1wbHVnaW4tbm9kZS1idWlsdGlucy9ibG9iLzYzYWI4YWFjZDAxMzc2NzQ0NWNhMjk5ZTQ2OGQ5YTYwYTk1MzI4ZDcvc3JjL2VzNi9wYXRoLmpzXG4vL1xuLy8gQ29weXJpZ2h0IEpveWVudCwgSW5jLmFuZCBvdGhlciBOb2RlIGNvbnRyaWJ1dG9ycy5cbi8vXG4vLyBQZXJtaXNzaW9uIGlzIGhlcmVieSBncmFudGVkLCBmcmVlIG9mIGNoYXJnZSwgdG8gYW55IHBlcnNvbiBvYnRhaW5pbmcgYVxuLy8gY29weSBvZiB0aGlzIHNvZnR3YXJlIGFuZCBhc3NvY2lhdGVkIGRvY3VtZW50YXRpb24gZmlsZXMgKHRoZVxuLy8gXCJTb2Z0d2FyZVwiKSwgdG8gZGVhbCBpbiB0aGUgU29mdHdhcmUgd2l0aG91dCByZXN0cmljdGlvbiwgaW5jbHVkaW5nXG4vLyB3aXRob3V0IGxpbWl0YXRpb24gdGhlIHJpZ2h0cyB0byB1c2UsIGNvcHksIG1vZGlmeSwgbWVyZ2UsIHB1Ymxpc2gsXG4vLyBkaXN0cmlidXRlLCBzdWJsaWNlbnNlLCBhbmQvb3Igc2VsbCBjb3BpZXMgb2YgdGhlIFNvZnR3YXJlLCBhbmQgdG8gcGVybWl0XG4vLyBwZXJzb25zIHRvIHdob20gdGhlIFNvZnR3YXJlIGlzIGZ1cm5pc2hlZCB0byBkbyBzbywgc3ViamVjdCB0byB0aGVcbi8vIGZvbGxvd2luZyBjb25kaXRpb25zOlxuLy9cbi8vIFRoZSBhYm92ZSBjb3B5cmlnaHQgbm90aWNlIGFuZCB0aGlzIHBlcm1pc3Npb24gbm90aWNlIHNoYWxsIGJlIGluY2x1ZGVkXG4vLyBpbiBhbGwgY29waWVzIG9yIHN1YnN0YW50aWFsIHBvcnRpb25zIG9mIHRoZSBTb2Z0d2FyZS5cbi8vXG4vLyBUSEUgU09GVFdBUkUgSVMgUFJPVklERUQgXCJBUyBJU1wiLCBXSVRIT1VUIFdBUlJBTlRZIE9GIEFOWSBLSU5ELCBFWFBSRVNTXG4vLyBPUiBJTVBMSUVELCBJTkNMVURJTkcgQlVUIE5PVCBMSU1JVEVEIFRPIFRIRSBXQVJSQU5USUVTIE9GXG4vLyBNRVJDSEFOVEFCSUxJVFksIEZJVE5FU1MgRk9SIEEgUEFSVElDVUxBUiBQVVJQT1NFIEFORCBOT05JTkZSSU5HRU1FTlQuIElOXG4vLyBOTyBFVkVOVCBTSEFMTCBUSEUgQVVUSE9SUyBPUiBDT1BZUklHSFQgSE9MREVSUyBCRSBMSUFCTEUgRk9SIEFOWSBDTEFJTSxcbi8vIERBTUFHRVMgT1IgT1RIRVIgTElBQklMSVRZLCBXSEVUSEVSIElOIEFOIEFDVElPTiBPRiBDT05UUkFDVCwgVE9SVCBPUlxuLy8gT1RIRVJXSVNFLCBBUklTSU5HIEZST00sIE9VVCBPRiBPUiBJTiBDT05ORUNUSU9OIFdJVEggVEhFIFNPRlRXQVJFIE9SIFRIRVxuLy8gVVNFIE9SIE9USEVSIERFQUxJTkdTIElOIFRIRSBTT0ZUV0FSRS5cblxuLyoqIEpTRG9jICovXG5mdW5jdGlvbiBub3JtYWxpemVBcnJheShwYXJ0cywgYWxsb3dBYm92ZVJvb3QpIHtcbiAgLy8gaWYgdGhlIHBhdGggdHJpZXMgdG8gZ28gYWJvdmUgdGhlIHJvb3QsIGB1cGAgZW5kcyB1cCA+IDBcbiAgbGV0IHVwID0gMDtcbiAgZm9yIChsZXQgaSA9IHBhcnRzLmxlbmd0aCAtIDE7IGkgPj0gMDsgaS0tKSB7XG4gICAgY29uc3QgbGFzdCA9IHBhcnRzW2ldO1xuICAgIGlmIChsYXN0ID09PSAnLicpIHtcbiAgICAgIHBhcnRzLnNwbGljZShpLCAxKTtcbiAgICB9IGVsc2UgaWYgKGxhc3QgPT09ICcuLicpIHtcbiAgICAgIHBhcnRzLnNwbGljZShpLCAxKTtcbiAgICAgIHVwKys7XG4gICAgfSBlbHNlIGlmICh1cCkge1xuICAgICAgcGFydHMuc3BsaWNlKGksIDEpO1xuICAgICAgdXAtLTtcbiAgICB9XG4gIH1cblxuICAvLyBpZiB0aGUgcGF0aCBpcyBhbGxvd2VkIHRvIGdvIGFib3ZlIHRoZSByb290LCByZXN0b3JlIGxlYWRpbmcgLi5zXG4gIGlmIChhbGxvd0Fib3ZlUm9vdCkge1xuICAgIGZvciAoOyB1cC0tOyB1cCkge1xuICAgICAgcGFydHMudW5zaGlmdCgnLi4nKTtcbiAgICB9XG4gIH1cblxuICByZXR1cm4gcGFydHM7XG59XG5cbi8vIFNwbGl0IGEgZmlsZW5hbWUgaW50byBbcm9vdCwgZGlyLCBiYXNlbmFtZSwgZXh0XSwgdW5peCB2ZXJzaW9uXG4vLyAncm9vdCcgaXMganVzdCBhIHNsYXNoLCBvciBub3RoaW5nLlxuY29uc3Qgc3BsaXRQYXRoUmUgPSAvXihcXFMrOlxcXFx8XFwvPykoW1xcc1xcU10qPykoKD86XFwuezEsMn18W14vXFxcXF0rP3wpKFxcLlteLi9cXFxcXSp8KSkoPzpbL1xcXFxdKikkLztcbi8qKiBKU0RvYyAqL1xuZnVuY3Rpb24gc3BsaXRQYXRoKGZpbGVuYW1lKSB7XG4gIC8vIFRydW5jYXRlIGZpbGVzIG5hbWVzIGdyZWF0ZXIgdGhhbiAxMDI0IGNoYXJhY3RlcnMgdG8gYXZvaWQgcmVnZXggZG9zXG4gIC8vIGh0dHBzOi8vZ2l0aHViLmNvbS9nZXRzZW50cnkvc2VudHJ5LWphdmFzY3JpcHQvcHVsbC84NzM3I2Rpc2N1c3Npb25fcjEyODU3MTkxNzJcbiAgY29uc3QgdHJ1bmNhdGVkID0gZmlsZW5hbWUubGVuZ3RoID4gMTAyNCA/IGA8dHJ1bmNhdGVkPiR7ZmlsZW5hbWUuc2xpY2UoLTEwMjQpfWAgOiBmaWxlbmFtZTtcbiAgY29uc3QgcGFydHMgPSBzcGxpdFBhdGhSZS5leGVjKHRydW5jYXRlZCk7XG4gIHJldHVybiBwYXJ0cyA/IHBhcnRzLnNsaWNlKDEpIDogW107XG59XG5cbi8vIHBhdGgucmVzb2x2ZShbZnJvbSAuLi5dLCB0bylcbi8vIHBvc2l4IHZlcnNpb25cbi8qKiBKU0RvYyAqL1xuZnVuY3Rpb24gcmVzb2x2ZSguLi5hcmdzKSB7XG4gIGxldCByZXNvbHZlZFBhdGggPSAnJztcbiAgbGV0IHJlc29sdmVkQWJzb2x1dGUgPSBmYWxzZTtcblxuICBmb3IgKGxldCBpID0gYXJncy5sZW5ndGggLSAxOyBpID49IC0xICYmICFyZXNvbHZlZEFic29sdXRlOyBpLS0pIHtcbiAgICBjb25zdCBwYXRoID0gaSA+PSAwID8gYXJnc1tpXSA6ICcvJztcblxuICAgIC8vIFNraXAgZW1wdHkgZW50cmllc1xuICAgIGlmICghcGF0aCkge1xuICAgICAgY29udGludWU7XG4gICAgfVxuXG4gICAgcmVzb2x2ZWRQYXRoID0gYCR7cGF0aH0vJHtyZXNvbHZlZFBhdGh9YDtcbiAgICByZXNvbHZlZEFic29sdXRlID0gcGF0aC5jaGFyQXQoMCkgPT09ICcvJztcbiAgfVxuXG4gIC8vIEF0IHRoaXMgcG9pbnQgdGhlIHBhdGggc2hvdWxkIGJlIHJlc29sdmVkIHRvIGEgZnVsbCBhYnNvbHV0ZSBwYXRoLCBidXRcbiAgLy8gaGFuZGxlIHJlbGF0aXZlIHBhdGhzIHRvIGJlIHNhZmUgKG1pZ2h0IGhhcHBlbiB3aGVuIHByb2Nlc3MuY3dkKCkgZmFpbHMpXG5cbiAgLy8gTm9ybWFsaXplIHRoZSBwYXRoXG4gIHJlc29sdmVkUGF0aCA9IG5vcm1hbGl6ZUFycmF5KFxuICAgIHJlc29sdmVkUGF0aC5zcGxpdCgnLycpLmZpbHRlcihwID0+ICEhcCksXG4gICAgIXJlc29sdmVkQWJzb2x1dGUsXG4gICkuam9pbignLycpO1xuXG4gIHJldHVybiAocmVzb2x2ZWRBYnNvbHV0ZSA/ICcvJyA6ICcnKSArIHJlc29sdmVkUGF0aCB8fCAnLic7XG59XG5cbi8qKiBKU0RvYyAqL1xuZnVuY3Rpb24gdHJpbShhcnIpIHtcbiAgbGV0IHN0YXJ0ID0gMDtcbiAgZm9yICg7IHN0YXJ0IDwgYXJyLmxlbmd0aDsgc3RhcnQrKykge1xuICAgIGlmIChhcnJbc3RhcnRdICE9PSAnJykge1xuICAgICAgYnJlYWs7XG4gICAgfVxuICB9XG5cbiAgbGV0IGVuZCA9IGFyci5sZW5ndGggLSAxO1xuICBmb3IgKDsgZW5kID49IDA7IGVuZC0tKSB7XG4gICAgaWYgKGFycltlbmRdICE9PSAnJykge1xuICAgICAgYnJlYWs7XG4gICAgfVxuICB9XG5cbiAgaWYgKHN0YXJ0ID4gZW5kKSB7XG4gICAgcmV0dXJuIFtdO1xuICB9XG4gIHJldHVybiBhcnIuc2xpY2Uoc3RhcnQsIGVuZCAtIHN0YXJ0ICsgMSk7XG59XG5cbi8vIHBhdGgucmVsYXRpdmUoZnJvbSwgdG8pXG4vLyBwb3NpeCB2ZXJzaW9uXG4vKiogSlNEb2MgKi9cbmZ1bmN0aW9uIHJlbGF0aXZlKGZyb20sIHRvKSB7XG4gIC8qIGVzbGludC1kaXNhYmxlIG5vLXBhcmFtLXJlYXNzaWduICovXG4gIGZyb20gPSByZXNvbHZlKGZyb20pLnNsaWNlKDEpO1xuICB0byA9IHJlc29sdmUodG8pLnNsaWNlKDEpO1xuICAvKiBlc2xpbnQtZW5hYmxlIG5vLXBhcmFtLXJlYXNzaWduICovXG5cbiAgY29uc3QgZnJvbVBhcnRzID0gdHJpbShmcm9tLnNwbGl0KCcvJykpO1xuICBjb25zdCB0b1BhcnRzID0gdHJpbSh0by5zcGxpdCgnLycpKTtcblxuICBjb25zdCBsZW5ndGggPSBNYXRoLm1pbihmcm9tUGFydHMubGVuZ3RoLCB0b1BhcnRzLmxlbmd0aCk7XG4gIGxldCBzYW1lUGFydHNMZW5ndGggPSBsZW5ndGg7XG4gIGZvciAobGV0IGkgPSAwOyBpIDwgbGVuZ3RoOyBpKyspIHtcbiAgICBpZiAoZnJvbVBhcnRzW2ldICE9PSB0b1BhcnRzW2ldKSB7XG4gICAgICBzYW1lUGFydHNMZW5ndGggPSBpO1xuICAgICAgYnJlYWs7XG4gICAgfVxuICB9XG5cbiAgbGV0IG91dHB1dFBhcnRzID0gW107XG4gIGZvciAobGV0IGkgPSBzYW1lUGFydHNMZW5ndGg7IGkgPCBmcm9tUGFydHMubGVuZ3RoOyBpKyspIHtcbiAgICBvdXRwdXRQYXJ0cy5wdXNoKCcuLicpO1xuICB9XG5cbiAgb3V0cHV0UGFydHMgPSBvdXRwdXRQYXJ0cy5jb25jYXQodG9QYXJ0cy5zbGljZShzYW1lUGFydHNMZW5ndGgpKTtcblxuICByZXR1cm4gb3V0cHV0UGFydHMuam9pbignLycpO1xufVxuXG4vLyBwYXRoLm5vcm1hbGl6ZShwYXRoKVxuLy8gcG9zaXggdmVyc2lvblxuLyoqIEpTRG9jICovXG5mdW5jdGlvbiBub3JtYWxpemVQYXRoKHBhdGgpIHtcbiAgY29uc3QgaXNQYXRoQWJzb2x1dGUgPSBpc0Fic29sdXRlKHBhdGgpO1xuICBjb25zdCB0cmFpbGluZ1NsYXNoID0gcGF0aC5zbGljZSgtMSkgPT09ICcvJztcblxuICAvLyBOb3JtYWxpemUgdGhlIHBhdGhcbiAgbGV0IG5vcm1hbGl6ZWRQYXRoID0gbm9ybWFsaXplQXJyYXkoXG4gICAgcGF0aC5zcGxpdCgnLycpLmZpbHRlcihwID0+ICEhcCksXG4gICAgIWlzUGF0aEFic29sdXRlLFxuICApLmpvaW4oJy8nKTtcblxuICBpZiAoIW5vcm1hbGl6ZWRQYXRoICYmICFpc1BhdGhBYnNvbHV0ZSkge1xuICAgIG5vcm1hbGl6ZWRQYXRoID0gJy4nO1xuICB9XG4gIGlmIChub3JtYWxpemVkUGF0aCAmJiB0cmFpbGluZ1NsYXNoKSB7XG4gICAgbm9ybWFsaXplZFBhdGggKz0gJy8nO1xuICB9XG5cbiAgcmV0dXJuIChpc1BhdGhBYnNvbHV0ZSA/ICcvJyA6ICcnKSArIG5vcm1hbGl6ZWRQYXRoO1xufVxuXG4vLyBwb3NpeCB2ZXJzaW9uXG4vKiogSlNEb2MgKi9cbmZ1bmN0aW9uIGlzQWJzb2x1dGUocGF0aCkge1xuICByZXR1cm4gcGF0aC5jaGFyQXQoMCkgPT09ICcvJztcbn1cblxuLy8gcG9zaXggdmVyc2lvblxuLyoqIEpTRG9jICovXG5mdW5jdGlvbiBqb2luKC4uLmFyZ3MpIHtcbiAgcmV0dXJuIG5vcm1hbGl6ZVBhdGgoYXJncy5qb2luKCcvJykpO1xufVxuXG4vKiogSlNEb2MgKi9cbmZ1bmN0aW9uIGRpcm5hbWUocGF0aCkge1xuICBjb25zdCByZXN1bHQgPSBzcGxpdFBhdGgocGF0aCk7XG4gIGNvbnN0IHJvb3QgPSByZXN1bHRbMF0gfHwgJyc7XG4gIGxldCBkaXIgPSByZXN1bHRbMV07XG5cbiAgaWYgKCFyb290ICYmICFkaXIpIHtcbiAgICAvLyBObyBkaXJuYW1lIHdoYXRzb2V2ZXJcbiAgICByZXR1cm4gJy4nO1xuICB9XG5cbiAgaWYgKGRpcikge1xuICAgIC8vIEl0IGhhcyBhIGRpcm5hbWUsIHN0cmlwIHRyYWlsaW5nIHNsYXNoXG4gICAgZGlyID0gZGlyLnNsaWNlKDAsIGRpci5sZW5ndGggLSAxKTtcbiAgfVxuXG4gIHJldHVybiByb290ICsgZGlyO1xufVxuXG4vKiogSlNEb2MgKi9cbmZ1bmN0aW9uIGJhc2VuYW1lKHBhdGgsIGV4dCkge1xuICBsZXQgZiA9IHNwbGl0UGF0aChwYXRoKVsyXSB8fCAnJztcbiAgaWYgKGV4dCAmJiBmLnNsaWNlKGV4dC5sZW5ndGggKiAtMSkgPT09IGV4dCkge1xuICAgIGYgPSBmLnNsaWNlKDAsIGYubGVuZ3RoIC0gZXh0Lmxlbmd0aCk7XG4gIH1cbiAgcmV0dXJuIGY7XG59XG5cbmV4cG9ydHMuYmFzZW5hbWUgPSBiYXNlbmFtZTtcbmV4cG9ydHMuZGlybmFtZSA9IGRpcm5hbWU7XG5leHBvcnRzLmlzQWJzb2x1dGUgPSBpc0Fic29sdXRlO1xuZXhwb3J0cy5qb2luID0gam9pbjtcbmV4cG9ydHMubm9ybWFsaXplUGF0aCA9IG5vcm1hbGl6ZVBhdGg7XG5leHBvcnRzLnJlbGF0aXZlID0gcmVsYXRpdmU7XG5leHBvcnRzLnJlc29sdmUgPSByZXNvbHZlO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9cGF0aC5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/path.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/prepareEvent.js":
/*!**********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/prepareEvent.js ***!
  \**********************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst constants = __webpack_require__(/*! ../constants.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/constants.js\");\nconst currentScopes = __webpack_require__(/*! ../currentScopes.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst eventProcessors = __webpack_require__(/*! ../eventProcessors.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/eventProcessors.js\");\nconst scope = __webpack_require__(/*! ../scope.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/scope.js\");\nconst applyScopeDataToEvent = __webpack_require__(/*! ./applyScopeDataToEvent.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/applyScopeDataToEvent.js\");\nconst debugIds = __webpack_require__(/*! ./debug-ids.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-ids.js\");\nconst misc = __webpack_require__(/*! ./misc.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/misc.js\");\nconst normalize = __webpack_require__(/*! ./normalize.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/normalize.js\");\nconst string = __webpack_require__(/*! ./string.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/string.js\");\nconst time = __webpack_require__(/*! ./time.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/time.js\");\n\n/**\n * This type makes sure that we get either a CaptureContext, OR an EventHint.\n * It does not allow mixing them, which could lead to unexpected outcomes, e.g. this is disallowed:\n * { user: { id: '123' }, mechanism: { handled: false } }\n */\n\n/**\n * Adds common information to events.\n *\n * The information includes release and environment from `options`,\n * breadcrumbs and context (extra, tags and user) from the scope.\n *\n * Information that is already present in the event is never overwritten. For\n * nested objects, such as the context, keys are merged.\n *\n * @param event The original event.\n * @param hint May contain additional information about the original exception.\n * @param scope A scope containing event metadata.\n * @returns A new event with more information.\n * @hidden\n */\nfunction prepareEvent(\n  options,\n  event,\n  hint,\n  scope,\n  client,\n  isolationScope,\n) {\n  const { normalizeDepth = 3, normalizeMaxBreadth = 1000 } = options;\n  const prepared = {\n    ...event,\n    event_id: event.event_id || hint.event_id || misc.uuid4(),\n    timestamp: event.timestamp || time.dateTimestampInSeconds(),\n  };\n  const integrations = hint.integrations || options.integrations.map(i => i.name);\n\n  applyClientOptions(prepared, options);\n  applyIntegrationsMetadata(prepared, integrations);\n\n  if (client) {\n    client.emit('applyFrameMetadata', event);\n  }\n\n  // Only put debug IDs onto frames for error events.\n  if (event.type === undefined) {\n    applyDebugIds(prepared, options.stackParser);\n  }\n\n  // If we have scope given to us, use it as the base for further modifications.\n  // This allows us to prevent unnecessary copying of data if `captureContext` is not provided.\n  const finalScope = getFinalScope(scope, hint.captureContext);\n\n  if (hint.mechanism) {\n    misc.addExceptionMechanism(prepared, hint.mechanism);\n  }\n\n  const clientEventProcessors = client ? client.getEventProcessors() : [];\n\n  // This should be the last thing called, since we want that\n  // {@link Scope.addEventProcessor} gets the finished prepared event.\n  // Merge scope data together\n  const data = currentScopes.getGlobalScope().getScopeData();\n\n  if (isolationScope) {\n    const isolationData = isolationScope.getScopeData();\n    applyScopeDataToEvent.mergeScopeData(data, isolationData);\n  }\n\n  if (finalScope) {\n    const finalScopeData = finalScope.getScopeData();\n    applyScopeDataToEvent.mergeScopeData(data, finalScopeData);\n  }\n\n  const attachments = [...(hint.attachments || []), ...data.attachments];\n  if (attachments.length) {\n    hint.attachments = attachments;\n  }\n\n  applyScopeDataToEvent.applyScopeDataToEvent(prepared, data);\n\n  const eventProcessors$1 = [\n    ...clientEventProcessors,\n    // Run scope event processors _after_ all other processors\n    ...data.eventProcessors,\n  ];\n\n  const result = eventProcessors.notifyEventProcessors(eventProcessors$1, prepared, hint);\n\n  return result.then(evt => {\n    if (evt) {\n      // We apply the debug_meta field only after all event processors have ran, so that if any event processors modified\n      // file names (e.g.the RewriteFrames integration) the filename -> debug ID relationship isn't destroyed.\n      // This should not cause any PII issues, since we're only moving data that is already on the event and not adding\n      // any new data\n      applyDebugMeta(evt);\n    }\n\n    if (typeof normalizeDepth === 'number' && normalizeDepth > 0) {\n      return normalizeEvent(evt, normalizeDepth, normalizeMaxBreadth);\n    }\n    return evt;\n  });\n}\n\n/**\n * Enhances event using the client configuration.\n * It takes care of all \"static\" values like environment, release and `dist`,\n * as well as truncating overly long values.\n *\n * Only exported for tests.\n *\n * @param event event instance to be enhanced\n */\nfunction applyClientOptions(event, options) {\n  const { environment, release, dist, maxValueLength = 250 } = options;\n\n  // empty strings do not make sense for environment, release, and dist\n  // so we handle them the same as if they were not provided\n  event.environment = event.environment || environment || constants.DEFAULT_ENVIRONMENT;\n\n  if (!event.release && release) {\n    event.release = release;\n  }\n\n  if (!event.dist && dist) {\n    event.dist = dist;\n  }\n\n  const request = event.request;\n  if (request?.url) {\n    request.url = string.truncate(request.url, maxValueLength);\n  }\n}\n\n/**\n * Puts debug IDs into the stack frames of an error event.\n */\nfunction applyDebugIds(event, stackParser) {\n  // Build a map of filename -> debug_id\n  const filenameDebugIdMap = debugIds.getFilenameToDebugIdMap(stackParser);\n\n  event.exception?.values?.forEach(exception => {\n    exception.stacktrace?.frames?.forEach(frame => {\n      if (frame.filename) {\n        frame.debug_id = filenameDebugIdMap[frame.filename];\n      }\n    });\n  });\n}\n\n/**\n * Moves debug IDs from the stack frames of an error event into the debug_meta field.\n */\nfunction applyDebugMeta(event) {\n  // Extract debug IDs and filenames from the stack frames on the event.\n  const filenameDebugIdMap = {};\n  event.exception?.values?.forEach(exception => {\n    exception.stacktrace?.frames?.forEach(frame => {\n      if (frame.debug_id) {\n        if (frame.abs_path) {\n          filenameDebugIdMap[frame.abs_path] = frame.debug_id;\n        } else if (frame.filename) {\n          filenameDebugIdMap[frame.filename] = frame.debug_id;\n        }\n        delete frame.debug_id;\n      }\n    });\n  });\n\n  if (Object.keys(filenameDebugIdMap).length === 0) {\n    return;\n  }\n\n  // Fill debug_meta information\n  event.debug_meta = event.debug_meta || {};\n  event.debug_meta.images = event.debug_meta.images || [];\n  const images = event.debug_meta.images;\n  Object.entries(filenameDebugIdMap).forEach(([filename, debug_id]) => {\n    images.push({\n      type: 'sourcemap',\n      code_file: filename,\n      debug_id,\n    });\n  });\n}\n\n/**\n * This function adds all used integrations to the SDK info in the event.\n * @param event The event that will be filled with all integrations.\n */\nfunction applyIntegrationsMetadata(event, integrationNames) {\n  if (integrationNames.length > 0) {\n    event.sdk = event.sdk || {};\n    event.sdk.integrations = [...(event.sdk.integrations || []), ...integrationNames];\n  }\n}\n\n/**\n * Applies `normalize` function on necessary `Event` attributes to make them safe for serialization.\n * Normalized keys:\n * - `breadcrumbs.data`\n * - `user`\n * - `contexts`\n * - `extra`\n * @param event Event\n * @returns Normalized event\n */\nfunction normalizeEvent(event, depth, maxBreadth) {\n  if (!event) {\n    return null;\n  }\n\n  const normalized = {\n    ...event,\n    ...(event.breadcrumbs && {\n      breadcrumbs: event.breadcrumbs.map(b => ({\n        ...b,\n        ...(b.data && {\n          data: normalize.normalize(b.data, depth, maxBreadth),\n        }),\n      })),\n    }),\n    ...(event.user && {\n      user: normalize.normalize(event.user, depth, maxBreadth),\n    }),\n    ...(event.contexts && {\n      contexts: normalize.normalize(event.contexts, depth, maxBreadth),\n    }),\n    ...(event.extra && {\n      extra: normalize.normalize(event.extra, depth, maxBreadth),\n    }),\n  };\n\n  // event.contexts.trace stores information about a Transaction. Similarly,\n  // event.spans[] stores information about child Spans. Given that a\n  // Transaction is conceptually a Span, normalization should apply to both\n  // Transactions and Spans consistently.\n  // For now the decision is to skip normalization of Transactions and Spans,\n  // so this block overwrites the normalized event to add back the original\n  // Transaction information prior to normalization.\n  if (event.contexts?.trace && normalized.contexts) {\n    normalized.contexts.trace = event.contexts.trace;\n\n    // event.contexts.trace.data may contain circular/dangerous data so we need to normalize it\n    if (event.contexts.trace.data) {\n      normalized.contexts.trace.data = normalize.normalize(event.contexts.trace.data, depth, maxBreadth);\n    }\n  }\n\n  // event.spans[].data may contain circular/dangerous data so we need to normalize it\n  if (event.spans) {\n    normalized.spans = event.spans.map(span => {\n      return {\n        ...span,\n        ...(span.data && {\n          data: normalize.normalize(span.data, depth, maxBreadth),\n        }),\n      };\n    });\n  }\n\n  // event.contexts.flags (FeatureFlagContext) stores context for our feature\n  // flag integrations. It has a greater nesting depth than our other typed\n  // Contexts, so we re-normalize with a fixed depth of 3 here. We do not want\n  // to skip this in case of conflicting, user-provided context.\n  if (event.contexts?.flags && normalized.contexts) {\n    normalized.contexts.flags = normalize.normalize(event.contexts.flags, 3, maxBreadth);\n  }\n\n  return normalized;\n}\n\nfunction getFinalScope(scope$1, captureContext) {\n  if (!captureContext) {\n    return scope$1;\n  }\n\n  const finalScope = scope$1 ? scope$1.clone() : new scope.Scope();\n  finalScope.update(captureContext);\n  return finalScope;\n}\n\n/**\n * Parse either an `EventHint` directly, or convert a `CaptureContext` to an `EventHint`.\n * This is used to allow to update method signatures that used to accept a `CaptureContext` but should now accept an `EventHint`.\n */\nfunction parseEventHintOrCaptureContext(\n  hint,\n) {\n  if (!hint) {\n    return undefined;\n  }\n\n  // If you pass a Scope or `() => Scope` as CaptureContext, we just return this as captureContext\n  if (hintIsScopeOrFunction(hint)) {\n    return { captureContext: hint };\n  }\n\n  if (hintIsScopeContext(hint)) {\n    return {\n      captureContext: hint,\n    };\n  }\n\n  return hint;\n}\n\nfunction hintIsScopeOrFunction(hint) {\n  return hint instanceof scope.Scope || typeof hint === 'function';\n}\n\nconst captureContextKeys = [\n  'user',\n  'level',\n  'extra',\n  'contexts',\n  'tags',\n  'fingerprint',\n  'propagationContext',\n] ;\n\nfunction hintIsScopeContext(hint) {\n  return Object.keys(hint).some(key => captureContextKeys.includes(key ));\n}\n\nexports.applyClientOptions = applyClientOptions;\nexports.applyDebugIds = applyDebugIds;\nexports.applyDebugMeta = applyDebugMeta;\nexports.parseEventHintOrCaptureContext = parseEventHintOrCaptureContext;\nexports.prepareEvent = prepareEvent;\n//# sourceMappingURL=prepareEvent.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvcHJlcGFyZUV2ZW50LmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLGtCQUFrQixtQkFBTyxDQUFDLCtIQUFpQjtBQUMzQyxzQkFBc0IsbUJBQU8sQ0FBQyx1SUFBcUI7QUFDbkQsd0JBQXdCLG1CQUFPLENBQUMsMklBQXVCO0FBQ3ZELGNBQWMsbUJBQU8sQ0FBQyx1SEFBYTtBQUNuQyw4QkFBOEIsbUJBQU8sQ0FBQyw0SkFBNEI7QUFDbEUsaUJBQWlCLG1CQUFPLENBQUMsb0lBQWdCO0FBQ3pDLGFBQWEsbUJBQU8sQ0FBQywwSEFBVztBQUNoQyxrQkFBa0IsbUJBQU8sQ0FBQyxvSUFBZ0I7QUFDMUMsZUFBZSxtQkFBTyxDQUFDLDhIQUFhO0FBQ3BDLGFBQWEsbUJBQU8sQ0FBQywwSEFBVzs7QUFFaEM7QUFDQTtBQUNBO0FBQ0EsS0FBSyxRQUFRLFdBQVcsZUFBZTtBQUN2Qzs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsVUFBVSxpREFBaUQ7QUFDM0Q7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQSxNQUFNLCtCQUErQjtBQUNyQztBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEdBQUc7QUFDSDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFVBQVUsbURBQW1EOztBQUU3RDtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsS0FBSztBQUNMLEdBQUc7QUFDSDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsVUFBVTtBQUNWO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsS0FBSztBQUNMLEdBQUc7O0FBRUg7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEtBQUs7QUFDTCxHQUFHO0FBQ0g7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFNBQVM7QUFDVCxPQUFPO0FBQ1AsS0FBSztBQUNMO0FBQ0E7QUFDQSxLQUFLO0FBQ0w7QUFDQTtBQUNBLEtBQUs7QUFDTDtBQUNBO0FBQ0EsS0FBSztBQUNMOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsU0FBUztBQUNUO0FBQ0EsS0FBSztBQUNMOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLGFBQWE7QUFDYjs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUEsMEJBQTBCO0FBQzFCLHFCQUFxQjtBQUNyQixzQkFBc0I7QUFDdEIsc0NBQXNDO0FBQ3RDLG9CQUFvQjtBQUNwQiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3V0aWxzL3ByZXBhcmVFdmVudC5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgY29uc3RhbnRzID0gcmVxdWlyZSgnLi4vY29uc3RhbnRzLmpzJyk7XG5jb25zdCBjdXJyZW50U2NvcGVzID0gcmVxdWlyZSgnLi4vY3VycmVudFNjb3Blcy5qcycpO1xuY29uc3QgZXZlbnRQcm9jZXNzb3JzID0gcmVxdWlyZSgnLi4vZXZlbnRQcm9jZXNzb3JzLmpzJyk7XG5jb25zdCBzY29wZSA9IHJlcXVpcmUoJy4uL3Njb3BlLmpzJyk7XG5jb25zdCBhcHBseVNjb3BlRGF0YVRvRXZlbnQgPSByZXF1aXJlKCcuL2FwcGx5U2NvcGVEYXRhVG9FdmVudC5qcycpO1xuY29uc3QgZGVidWdJZHMgPSByZXF1aXJlKCcuL2RlYnVnLWlkcy5qcycpO1xuY29uc3QgbWlzYyA9IHJlcXVpcmUoJy4vbWlzYy5qcycpO1xuY29uc3Qgbm9ybWFsaXplID0gcmVxdWlyZSgnLi9ub3JtYWxpemUuanMnKTtcbmNvbnN0IHN0cmluZyA9IHJlcXVpcmUoJy4vc3RyaW5nLmpzJyk7XG5jb25zdCB0aW1lID0gcmVxdWlyZSgnLi90aW1lLmpzJyk7XG5cbi8qKlxuICogVGhpcyB0eXBlIG1ha2VzIHN1cmUgdGhhdCB3ZSBnZXQgZWl0aGVyIGEgQ2FwdHVyZUNvbnRleHQsIE9SIGFuIEV2ZW50SGludC5cbiAqIEl0IGRvZXMgbm90IGFsbG93IG1peGluZyB0aGVtLCB3aGljaCBjb3VsZCBsZWFkIHRvIHVuZXhwZWN0ZWQgb3V0Y29tZXMsIGUuZy4gdGhpcyBpcyBkaXNhbGxvd2VkOlxuICogeyB1c2VyOiB7IGlkOiAnMTIzJyB9LCBtZWNoYW5pc206IHsgaGFuZGxlZDogZmFsc2UgfSB9XG4gKi9cblxuLyoqXG4gKiBBZGRzIGNvbW1vbiBpbmZvcm1hdGlvbiB0byBldmVudHMuXG4gKlxuICogVGhlIGluZm9ybWF0aW9uIGluY2x1ZGVzIHJlbGVhc2UgYW5kIGVudmlyb25tZW50IGZyb20gYG9wdGlvbnNgLFxuICogYnJlYWRjcnVtYnMgYW5kIGNvbnRleHQgKGV4dHJhLCB0YWdzIGFuZCB1c2VyKSBmcm9tIHRoZSBzY29wZS5cbiAqXG4gKiBJbmZvcm1hdGlvbiB0aGF0IGlzIGFscmVhZHkgcHJlc2VudCBpbiB0aGUgZXZlbnQgaXMgbmV2ZXIgb3ZlcndyaXR0ZW4uIEZvclxuICogbmVzdGVkIG9iamVjdHMsIHN1Y2ggYXMgdGhlIGNvbnRleHQsIGtleXMgYXJlIG1lcmdlZC5cbiAqXG4gKiBAcGFyYW0gZXZlbnQgVGhlIG9yaWdpbmFsIGV2ZW50LlxuICogQHBhcmFtIGhpbnQgTWF5IGNvbnRhaW4gYWRkaXRpb25hbCBpbmZvcm1hdGlvbiBhYm91dCB0aGUgb3JpZ2luYWwgZXhjZXB0aW9uLlxuICogQHBhcmFtIHNjb3BlIEEgc2NvcGUgY29udGFpbmluZyBldmVudCBtZXRhZGF0YS5cbiAqIEByZXR1cm5zIEEgbmV3IGV2ZW50IHdpdGggbW9yZSBpbmZvcm1hdGlvbi5cbiAqIEBoaWRkZW5cbiAqL1xuZnVuY3Rpb24gcHJlcGFyZUV2ZW50KFxuICBvcHRpb25zLFxuICBldmVudCxcbiAgaGludCxcbiAgc2NvcGUsXG4gIGNsaWVudCxcbiAgaXNvbGF0aW9uU2NvcGUsXG4pIHtcbiAgY29uc3QgeyBub3JtYWxpemVEZXB0aCA9IDMsIG5vcm1hbGl6ZU1heEJyZWFkdGggPSAxMDAwIH0gPSBvcHRpb25zO1xuICBjb25zdCBwcmVwYXJlZCA9IHtcbiAgICAuLi5ldmVudCxcbiAgICBldmVudF9pZDogZXZlbnQuZXZlbnRfaWQgfHwgaGludC5ldmVudF9pZCB8fCBtaXNjLnV1aWQ0KCksXG4gICAgdGltZXN0YW1wOiBldmVudC50aW1lc3RhbXAgfHwgdGltZS5kYXRlVGltZXN0YW1wSW5TZWNvbmRzKCksXG4gIH07XG4gIGNvbnN0IGludGVncmF0aW9ucyA9IGhpbnQuaW50ZWdyYXRpb25zIHx8IG9wdGlvbnMuaW50ZWdyYXRpb25zLm1hcChpID0+IGkubmFtZSk7XG5cbiAgYXBwbHlDbGllbnRPcHRpb25zKHByZXBhcmVkLCBvcHRpb25zKTtcbiAgYXBwbHlJbnRlZ3JhdGlvbnNNZXRhZGF0YShwcmVwYXJlZCwgaW50ZWdyYXRpb25zKTtcblxuICBpZiAoY2xpZW50KSB7XG4gICAgY2xpZW50LmVtaXQoJ2FwcGx5RnJhbWVNZXRhZGF0YScsIGV2ZW50KTtcbiAgfVxuXG4gIC8vIE9ubHkgcHV0IGRlYnVnIElEcyBvbnRvIGZyYW1lcyBmb3IgZXJyb3IgZXZlbnRzLlxuICBpZiAoZXZlbnQudHlwZSA9PT0gdW5kZWZpbmVkKSB7XG4gICAgYXBwbHlEZWJ1Z0lkcyhwcmVwYXJlZCwgb3B0aW9ucy5zdGFja1BhcnNlcik7XG4gIH1cblxuICAvLyBJZiB3ZSBoYXZlIHNjb3BlIGdpdmVuIHRvIHVzLCB1c2UgaXQgYXMgdGhlIGJhc2UgZm9yIGZ1cnRoZXIgbW9kaWZpY2F0aW9ucy5cbiAgLy8gVGhpcyBhbGxvd3MgdXMgdG8gcHJldmVudCB1bm5lY2Vzc2FyeSBjb3B5aW5nIG9mIGRhdGEgaWYgYGNhcHR1cmVDb250ZXh0YCBpcyBub3QgcHJvdmlkZWQuXG4gIGNvbnN0IGZpbmFsU2NvcGUgPSBnZXRGaW5hbFNjb3BlKHNjb3BlLCBoaW50LmNhcHR1cmVDb250ZXh0KTtcblxuICBpZiAoaGludC5tZWNoYW5pc20pIHtcbiAgICBtaXNjLmFkZEV4Y2VwdGlvbk1lY2hhbmlzbShwcmVwYXJlZCwgaGludC5tZWNoYW5pc20pO1xuICB9XG5cbiAgY29uc3QgY2xpZW50RXZlbnRQcm9jZXNzb3JzID0gY2xpZW50ID8gY2xpZW50LmdldEV2ZW50UHJvY2Vzc29ycygpIDogW107XG5cbiAgLy8gVGhpcyBzaG91bGQgYmUgdGhlIGxhc3QgdGhpbmcgY2FsbGVkLCBzaW5jZSB3ZSB3YW50IHRoYXRcbiAgLy8ge0BsaW5rIFNjb3BlLmFkZEV2ZW50UHJvY2Vzc29yfSBnZXRzIHRoZSBmaW5pc2hlZCBwcmVwYXJlZCBldmVudC5cbiAgLy8gTWVyZ2Ugc2NvcGUgZGF0YSB0b2dldGhlclxuICBjb25zdCBkYXRhID0gY3VycmVudFNjb3Blcy5nZXRHbG9iYWxTY29wZSgpLmdldFNjb3BlRGF0YSgpO1xuXG4gIGlmIChpc29sYXRpb25TY29wZSkge1xuICAgIGNvbnN0IGlzb2xhdGlvbkRhdGEgPSBpc29sYXRpb25TY29wZS5nZXRTY29wZURhdGEoKTtcbiAgICBhcHBseVNjb3BlRGF0YVRvRXZlbnQubWVyZ2VTY29wZURhdGEoZGF0YSwgaXNvbGF0aW9uRGF0YSk7XG4gIH1cblxuICBpZiAoZmluYWxTY29wZSkge1xuICAgIGNvbnN0IGZpbmFsU2NvcGVEYXRhID0gZmluYWxTY29wZS5nZXRTY29wZURhdGEoKTtcbiAgICBhcHBseVNjb3BlRGF0YVRvRXZlbnQubWVyZ2VTY29wZURhdGEoZGF0YSwgZmluYWxTY29wZURhdGEpO1xuICB9XG5cbiAgY29uc3QgYXR0YWNobWVudHMgPSBbLi4uKGhpbnQuYXR0YWNobWVudHMgfHwgW10pLCAuLi5kYXRhLmF0dGFjaG1lbnRzXTtcbiAgaWYgKGF0dGFjaG1lbnRzLmxlbmd0aCkge1xuICAgIGhpbnQuYXR0YWNobWVudHMgPSBhdHRhY2htZW50cztcbiAgfVxuXG4gIGFwcGx5U2NvcGVEYXRhVG9FdmVudC5hcHBseVNjb3BlRGF0YVRvRXZlbnQocHJlcGFyZWQsIGRhdGEpO1xuXG4gIGNvbnN0IGV2ZW50UHJvY2Vzc29ycyQxID0gW1xuICAgIC4uLmNsaWVudEV2ZW50UHJvY2Vzc29ycyxcbiAgICAvLyBSdW4gc2NvcGUgZXZlbnQgcHJvY2Vzc29ycyBfYWZ0ZXJfIGFsbCBvdGhlciBwcm9jZXNzb3JzXG4gICAgLi4uZGF0YS5ldmVudFByb2Nlc3NvcnMsXG4gIF07XG5cbiAgY29uc3QgcmVzdWx0ID0gZXZlbnRQcm9jZXNzb3JzLm5vdGlmeUV2ZW50UHJvY2Vzc29ycyhldmVudFByb2Nlc3NvcnMkMSwgcHJlcGFyZWQsIGhpbnQpO1xuXG4gIHJldHVybiByZXN1bHQudGhlbihldnQgPT4ge1xuICAgIGlmIChldnQpIHtcbiAgICAgIC8vIFdlIGFwcGx5IHRoZSBkZWJ1Z19tZXRhIGZpZWxkIG9ubHkgYWZ0ZXIgYWxsIGV2ZW50IHByb2Nlc3NvcnMgaGF2ZSByYW4sIHNvIHRoYXQgaWYgYW55IGV2ZW50IHByb2Nlc3NvcnMgbW9kaWZpZWRcbiAgICAgIC8vIGZpbGUgbmFtZXMgKGUuZy50aGUgUmV3cml0ZUZyYW1lcyBpbnRlZ3JhdGlvbikgdGhlIGZpbGVuYW1lIC0+IGRlYnVnIElEIHJlbGF0aW9uc2hpcCBpc24ndCBkZXN0cm95ZWQuXG4gICAgICAvLyBUaGlzIHNob3VsZCBub3QgY2F1c2UgYW55IFBJSSBpc3N1ZXMsIHNpbmNlIHdlJ3JlIG9ubHkgbW92aW5nIGRhdGEgdGhhdCBpcyBhbHJlYWR5IG9uIHRoZSBldmVudCBhbmQgbm90IGFkZGluZ1xuICAgICAgLy8gYW55IG5ldyBkYXRhXG4gICAgICBhcHBseURlYnVnTWV0YShldnQpO1xuICAgIH1cblxuICAgIGlmICh0eXBlb2Ygbm9ybWFsaXplRGVwdGggPT09ICdudW1iZXInICYmIG5vcm1hbGl6ZURlcHRoID4gMCkge1xuICAgICAgcmV0dXJuIG5vcm1hbGl6ZUV2ZW50KGV2dCwgbm9ybWFsaXplRGVwdGgsIG5vcm1hbGl6ZU1heEJyZWFkdGgpO1xuICAgIH1cbiAgICByZXR1cm4gZXZ0O1xuICB9KTtcbn1cblxuLyoqXG4gKiBFbmhhbmNlcyBldmVudCB1c2luZyB0aGUgY2xpZW50IGNvbmZpZ3VyYXRpb24uXG4gKiBJdCB0YWtlcyBjYXJlIG9mIGFsbCBcInN0YXRpY1wiIHZhbHVlcyBsaWtlIGVudmlyb25tZW50LCByZWxlYXNlIGFuZCBgZGlzdGAsXG4gKiBhcyB3ZWxsIGFzIHRydW5jYXRpbmcgb3Zlcmx5IGxvbmcgdmFsdWVzLlxuICpcbiAqIE9ubHkgZXhwb3J0ZWQgZm9yIHRlc3RzLlxuICpcbiAqIEBwYXJhbSBldmVudCBldmVudCBpbnN0YW5jZSB0byBiZSBlbmhhbmNlZFxuICovXG5mdW5jdGlvbiBhcHBseUNsaWVudE9wdGlvbnMoZXZlbnQsIG9wdGlvbnMpIHtcbiAgY29uc3QgeyBlbnZpcm9ubWVudCwgcmVsZWFzZSwgZGlzdCwgbWF4VmFsdWVMZW5ndGggPSAyNTAgfSA9IG9wdGlvbnM7XG5cbiAgLy8gZW1wdHkgc3RyaW5ncyBkbyBub3QgbWFrZSBzZW5zZSBmb3IgZW52aXJvbm1lbnQsIHJlbGVhc2UsIGFuZCBkaXN0XG4gIC8vIHNvIHdlIGhhbmRsZSB0aGVtIHRoZSBzYW1lIGFzIGlmIHRoZXkgd2VyZSBub3QgcHJvdmlkZWRcbiAgZXZlbnQuZW52aXJvbm1lbnQgPSBldmVudC5lbnZpcm9ubWVudCB8fCBlbnZpcm9ubWVudCB8fCBjb25zdGFudHMuREVGQVVMVF9FTlZJUk9OTUVOVDtcblxuICBpZiAoIWV2ZW50LnJlbGVhc2UgJiYgcmVsZWFzZSkge1xuICAgIGV2ZW50LnJlbGVhc2UgPSByZWxlYXNlO1xuICB9XG5cbiAgaWYgKCFldmVudC5kaXN0ICYmIGRpc3QpIHtcbiAgICBldmVudC5kaXN0ID0gZGlzdDtcbiAgfVxuXG4gIGNvbnN0IHJlcXVlc3QgPSBldmVudC5yZXF1ZXN0O1xuICBpZiAocmVxdWVzdD8udXJsKSB7XG4gICAgcmVxdWVzdC51cmwgPSBzdHJpbmcudHJ1bmNhdGUocmVxdWVzdC51cmwsIG1heFZhbHVlTGVuZ3RoKTtcbiAgfVxufVxuXG4vKipcbiAqIFB1dHMgZGVidWcgSURzIGludG8gdGhlIHN0YWNrIGZyYW1lcyBvZiBhbiBlcnJvciBldmVudC5cbiAqL1xuZnVuY3Rpb24gYXBwbHlEZWJ1Z0lkcyhldmVudCwgc3RhY2tQYXJzZXIpIHtcbiAgLy8gQnVpbGQgYSBtYXAgb2YgZmlsZW5hbWUgLT4gZGVidWdfaWRcbiAgY29uc3QgZmlsZW5hbWVEZWJ1Z0lkTWFwID0gZGVidWdJZHMuZ2V0RmlsZW5hbWVUb0RlYnVnSWRNYXAoc3RhY2tQYXJzZXIpO1xuXG4gIGV2ZW50LmV4Y2VwdGlvbj8udmFsdWVzPy5mb3JFYWNoKGV4Y2VwdGlvbiA9PiB7XG4gICAgZXhjZXB0aW9uLnN0YWNrdHJhY2U/LmZyYW1lcz8uZm9yRWFjaChmcmFtZSA9PiB7XG4gICAgICBpZiAoZnJhbWUuZmlsZW5hbWUpIHtcbiAgICAgICAgZnJhbWUuZGVidWdfaWQgPSBmaWxlbmFtZURlYnVnSWRNYXBbZnJhbWUuZmlsZW5hbWVdO1xuICAgICAgfVxuICAgIH0pO1xuICB9KTtcbn1cblxuLyoqXG4gKiBNb3ZlcyBkZWJ1ZyBJRHMgZnJvbSB0aGUgc3RhY2sgZnJhbWVzIG9mIGFuIGVycm9yIGV2ZW50IGludG8gdGhlIGRlYnVnX21ldGEgZmllbGQuXG4gKi9cbmZ1bmN0aW9uIGFwcGx5RGVidWdNZXRhKGV2ZW50KSB7XG4gIC8vIEV4dHJhY3QgZGVidWcgSURzIGFuZCBmaWxlbmFtZXMgZnJvbSB0aGUgc3RhY2sgZnJhbWVzIG9uIHRoZSBldmVudC5cbiAgY29uc3QgZmlsZW5hbWVEZWJ1Z0lkTWFwID0ge307XG4gIGV2ZW50LmV4Y2VwdGlvbj8udmFsdWVzPy5mb3JFYWNoKGV4Y2VwdGlvbiA9PiB7XG4gICAgZXhjZXB0aW9uLnN0YWNrdHJhY2U/LmZyYW1lcz8uZm9yRWFjaChmcmFtZSA9PiB7XG4gICAgICBpZiAoZnJhbWUuZGVidWdfaWQpIHtcbiAgICAgICAgaWYgKGZyYW1lLmFic19wYXRoKSB7XG4gICAgICAgICAgZmlsZW5hbWVEZWJ1Z0lkTWFwW2ZyYW1lLmFic19wYXRoXSA9IGZyYW1lLmRlYnVnX2lkO1xuICAgICAgICB9IGVsc2UgaWYgKGZyYW1lLmZpbGVuYW1lKSB7XG4gICAgICAgICAgZmlsZW5hbWVEZWJ1Z0lkTWFwW2ZyYW1lLmZpbGVuYW1lXSA9IGZyYW1lLmRlYnVnX2lkO1xuICAgICAgICB9XG4gICAgICAgIGRlbGV0ZSBmcmFtZS5kZWJ1Z19pZDtcbiAgICAgIH1cbiAgICB9KTtcbiAgfSk7XG5cbiAgaWYgKE9iamVjdC5rZXlzKGZpbGVuYW1lRGVidWdJZE1hcCkubGVuZ3RoID09PSAwKSB7XG4gICAgcmV0dXJuO1xuICB9XG5cbiAgLy8gRmlsbCBkZWJ1Z19tZXRhIGluZm9ybWF0aW9uXG4gIGV2ZW50LmRlYnVnX21ldGEgPSBldmVudC5kZWJ1Z19tZXRhIHx8IHt9O1xuICBldmVudC5kZWJ1Z19tZXRhLmltYWdlcyA9IGV2ZW50LmRlYnVnX21ldGEuaW1hZ2VzIHx8IFtdO1xuICBjb25zdCBpbWFnZXMgPSBldmVudC5kZWJ1Z19tZXRhLmltYWdlcztcbiAgT2JqZWN0LmVudHJpZXMoZmlsZW5hbWVEZWJ1Z0lkTWFwKS5mb3JFYWNoKChbZmlsZW5hbWUsIGRlYnVnX2lkXSkgPT4ge1xuICAgIGltYWdlcy5wdXNoKHtcbiAgICAgIHR5cGU6ICdzb3VyY2VtYXAnLFxuICAgICAgY29kZV9maWxlOiBmaWxlbmFtZSxcbiAgICAgIGRlYnVnX2lkLFxuICAgIH0pO1xuICB9KTtcbn1cblxuLyoqXG4gKiBUaGlzIGZ1bmN0aW9uIGFkZHMgYWxsIHVzZWQgaW50ZWdyYXRpb25zIHRvIHRoZSBTREsgaW5mbyBpbiB0aGUgZXZlbnQuXG4gKiBAcGFyYW0gZXZlbnQgVGhlIGV2ZW50IHRoYXQgd2lsbCBiZSBmaWxsZWQgd2l0aCBhbGwgaW50ZWdyYXRpb25zLlxuICovXG5mdW5jdGlvbiBhcHBseUludGVncmF0aW9uc01ldGFkYXRhKGV2ZW50LCBpbnRlZ3JhdGlvbk5hbWVzKSB7XG4gIGlmIChpbnRlZ3JhdGlvbk5hbWVzLmxlbmd0aCA+IDApIHtcbiAgICBldmVudC5zZGsgPSBldmVudC5zZGsgfHwge307XG4gICAgZXZlbnQuc2RrLmludGVncmF0aW9ucyA9IFsuLi4oZXZlbnQuc2RrLmludGVncmF0aW9ucyB8fCBbXSksIC4uLmludGVncmF0aW9uTmFtZXNdO1xuICB9XG59XG5cbi8qKlxuICogQXBwbGllcyBgbm9ybWFsaXplYCBmdW5jdGlvbiBvbiBuZWNlc3NhcnkgYEV2ZW50YCBhdHRyaWJ1dGVzIHRvIG1ha2UgdGhlbSBzYWZlIGZvciBzZXJpYWxpemF0aW9uLlxuICogTm9ybWFsaXplZCBrZXlzOlxuICogLSBgYnJlYWRjcnVtYnMuZGF0YWBcbiAqIC0gYHVzZXJgXG4gKiAtIGBjb250ZXh0c2BcbiAqIC0gYGV4dHJhYFxuICogQHBhcmFtIGV2ZW50IEV2ZW50XG4gKiBAcmV0dXJucyBOb3JtYWxpemVkIGV2ZW50XG4gKi9cbmZ1bmN0aW9uIG5vcm1hbGl6ZUV2ZW50KGV2ZW50LCBkZXB0aCwgbWF4QnJlYWR0aCkge1xuICBpZiAoIWV2ZW50KSB7XG4gICAgcmV0dXJuIG51bGw7XG4gIH1cblxuICBjb25zdCBub3JtYWxpemVkID0ge1xuICAgIC4uLmV2ZW50LFxuICAgIC4uLihldmVudC5icmVhZGNydW1icyAmJiB7XG4gICAgICBicmVhZGNydW1iczogZXZlbnQuYnJlYWRjcnVtYnMubWFwKGIgPT4gKHtcbiAgICAgICAgLi4uYixcbiAgICAgICAgLi4uKGIuZGF0YSAmJiB7XG4gICAgICAgICAgZGF0YTogbm9ybWFsaXplLm5vcm1hbGl6ZShiLmRhdGEsIGRlcHRoLCBtYXhCcmVhZHRoKSxcbiAgICAgICAgfSksXG4gICAgICB9KSksXG4gICAgfSksXG4gICAgLi4uKGV2ZW50LnVzZXIgJiYge1xuICAgICAgdXNlcjogbm9ybWFsaXplLm5vcm1hbGl6ZShldmVudC51c2VyLCBkZXB0aCwgbWF4QnJlYWR0aCksXG4gICAgfSksXG4gICAgLi4uKGV2ZW50LmNvbnRleHRzICYmIHtcbiAgICAgIGNvbnRleHRzOiBub3JtYWxpemUubm9ybWFsaXplKGV2ZW50LmNvbnRleHRzLCBkZXB0aCwgbWF4QnJlYWR0aCksXG4gICAgfSksXG4gICAgLi4uKGV2ZW50LmV4dHJhICYmIHtcbiAgICAgIGV4dHJhOiBub3JtYWxpemUubm9ybWFsaXplKGV2ZW50LmV4dHJhLCBkZXB0aCwgbWF4QnJlYWR0aCksXG4gICAgfSksXG4gIH07XG5cbiAgLy8gZXZlbnQuY29udGV4dHMudHJhY2Ugc3RvcmVzIGluZm9ybWF0aW9uIGFib3V0IGEgVHJhbnNhY3Rpb24uIFNpbWlsYXJseSxcbiAgLy8gZXZlbnQuc3BhbnNbXSBzdG9yZXMgaW5mb3JtYXRpb24gYWJvdXQgY2hpbGQgU3BhbnMuIEdpdmVuIHRoYXQgYVxuICAvLyBUcmFuc2FjdGlvbiBpcyBjb25jZXB0dWFsbHkgYSBTcGFuLCBub3JtYWxpemF0aW9uIHNob3VsZCBhcHBseSB0byBib3RoXG4gIC8vIFRyYW5zYWN0aW9ucyBhbmQgU3BhbnMgY29uc2lzdGVudGx5LlxuICAvLyBGb3Igbm93IHRoZSBkZWNpc2lvbiBpcyB0byBza2lwIG5vcm1hbGl6YXRpb24gb2YgVHJhbnNhY3Rpb25zIGFuZCBTcGFucyxcbiAgLy8gc28gdGhpcyBibG9jayBvdmVyd3JpdGVzIHRoZSBub3JtYWxpemVkIGV2ZW50IHRvIGFkZCBiYWNrIHRoZSBvcmlnaW5hbFxuICAvLyBUcmFuc2FjdGlvbiBpbmZvcm1hdGlvbiBwcmlvciB0byBub3JtYWxpemF0aW9uLlxuICBpZiAoZXZlbnQuY29udGV4dHM/LnRyYWNlICYmIG5vcm1hbGl6ZWQuY29udGV4dHMpIHtcbiAgICBub3JtYWxpemVkLmNvbnRleHRzLnRyYWNlID0gZXZlbnQuY29udGV4dHMudHJhY2U7XG5cbiAgICAvLyBldmVudC5jb250ZXh0cy50cmFjZS5kYXRhIG1heSBjb250YWluIGNpcmN1bGFyL2Rhbmdlcm91cyBkYXRhIHNvIHdlIG5lZWQgdG8gbm9ybWFsaXplIGl0XG4gICAgaWYgKGV2ZW50LmNvbnRleHRzLnRyYWNlLmRhdGEpIHtcbiAgICAgIG5vcm1hbGl6ZWQuY29udGV4dHMudHJhY2UuZGF0YSA9IG5vcm1hbGl6ZS5ub3JtYWxpemUoZXZlbnQuY29udGV4dHMudHJhY2UuZGF0YSwgZGVwdGgsIG1heEJyZWFkdGgpO1xuICAgIH1cbiAgfVxuXG4gIC8vIGV2ZW50LnNwYW5zW10uZGF0YSBtYXkgY29udGFpbiBjaXJjdWxhci9kYW5nZXJvdXMgZGF0YSBzbyB3ZSBuZWVkIHRvIG5vcm1hbGl6ZSBpdFxuICBpZiAoZXZlbnQuc3BhbnMpIHtcbiAgICBub3JtYWxpemVkLnNwYW5zID0gZXZlbnQuc3BhbnMubWFwKHNwYW4gPT4ge1xuICAgICAgcmV0dXJuIHtcbiAgICAgICAgLi4uc3BhbixcbiAgICAgICAgLi4uKHNwYW4uZGF0YSAmJiB7XG4gICAgICAgICAgZGF0YTogbm9ybWFsaXplLm5vcm1hbGl6ZShzcGFuLmRhdGEsIGRlcHRoLCBtYXhCcmVhZHRoKSxcbiAgICAgICAgfSksXG4gICAgICB9O1xuICAgIH0pO1xuICB9XG5cbiAgLy8gZXZlbnQuY29udGV4dHMuZmxhZ3MgKEZlYXR1cmVGbGFnQ29udGV4dCkgc3RvcmVzIGNvbnRleHQgZm9yIG91ciBmZWF0dXJlXG4gIC8vIGZsYWcgaW50ZWdyYXRpb25zLiBJdCBoYXMgYSBncmVhdGVyIG5lc3RpbmcgZGVwdGggdGhhbiBvdXIgb3RoZXIgdHlwZWRcbiAgLy8gQ29udGV4dHMsIHNvIHdlIHJlLW5vcm1hbGl6ZSB3aXRoIGEgZml4ZWQgZGVwdGggb2YgMyBoZXJlLiBXZSBkbyBub3Qgd2FudFxuICAvLyB0byBza2lwIHRoaXMgaW4gY2FzZSBvZiBjb25mbGljdGluZywgdXNlci1wcm92aWRlZCBjb250ZXh0LlxuICBpZiAoZXZlbnQuY29udGV4dHM/LmZsYWdzICYmIG5vcm1hbGl6ZWQuY29udGV4dHMpIHtcbiAgICBub3JtYWxpemVkLmNvbnRleHRzLmZsYWdzID0gbm9ybWFsaXplLm5vcm1hbGl6ZShldmVudC5jb250ZXh0cy5mbGFncywgMywgbWF4QnJlYWR0aCk7XG4gIH1cblxuICByZXR1cm4gbm9ybWFsaXplZDtcbn1cblxuZnVuY3Rpb24gZ2V0RmluYWxTY29wZShzY29wZSQxLCBjYXB0dXJlQ29udGV4dCkge1xuICBpZiAoIWNhcHR1cmVDb250ZXh0KSB7XG4gICAgcmV0dXJuIHNjb3BlJDE7XG4gIH1cblxuICBjb25zdCBmaW5hbFNjb3BlID0gc2NvcGUkMSA/IHNjb3BlJDEuY2xvbmUoKSA6IG5ldyBzY29wZS5TY29wZSgpO1xuICBmaW5hbFNjb3BlLnVwZGF0ZShjYXB0dXJlQ29udGV4dCk7XG4gIHJldHVybiBmaW5hbFNjb3BlO1xufVxuXG4vKipcbiAqIFBhcnNlIGVpdGhlciBhbiBgRXZlbnRIaW50YCBkaXJlY3RseSwgb3IgY29udmVydCBhIGBDYXB0dXJlQ29udGV4dGAgdG8gYW4gYEV2ZW50SGludGAuXG4gKiBUaGlzIGlzIHVzZWQgdG8gYWxsb3cgdG8gdXBkYXRlIG1ldGhvZCBzaWduYXR1cmVzIHRoYXQgdXNlZCB0byBhY2NlcHQgYSBgQ2FwdHVyZUNvbnRleHRgIGJ1dCBzaG91bGQgbm93IGFjY2VwdCBhbiBgRXZlbnRIaW50YC5cbiAqL1xuZnVuY3Rpb24gcGFyc2VFdmVudEhpbnRPckNhcHR1cmVDb250ZXh0KFxuICBoaW50LFxuKSB7XG4gIGlmICghaGludCkge1xuICAgIHJldHVybiB1bmRlZmluZWQ7XG4gIH1cblxuICAvLyBJZiB5b3UgcGFzcyBhIFNjb3BlIG9yIGAoKSA9PiBTY29wZWAgYXMgQ2FwdHVyZUNvbnRleHQsIHdlIGp1c3QgcmV0dXJuIHRoaXMgYXMgY2FwdHVyZUNvbnRleHRcbiAgaWYgKGhpbnRJc1Njb3BlT3JGdW5jdGlvbihoaW50KSkge1xuICAgIHJldHVybiB7IGNhcHR1cmVDb250ZXh0OiBoaW50IH07XG4gIH1cblxuICBpZiAoaGludElzU2NvcGVDb250ZXh0KGhpbnQpKSB7XG4gICAgcmV0dXJuIHtcbiAgICAgIGNhcHR1cmVDb250ZXh0OiBoaW50LFxuICAgIH07XG4gIH1cblxuICByZXR1cm4gaGludDtcbn1cblxuZnVuY3Rpb24gaGludElzU2NvcGVPckZ1bmN0aW9uKGhpbnQpIHtcbiAgcmV0dXJuIGhpbnQgaW5zdGFuY2VvZiBzY29wZS5TY29wZSB8fCB0eXBlb2YgaGludCA9PT0gJ2Z1bmN0aW9uJztcbn1cblxuY29uc3QgY2FwdHVyZUNvbnRleHRLZXlzID0gW1xuICAndXNlcicsXG4gICdsZXZlbCcsXG4gICdleHRyYScsXG4gICdjb250ZXh0cycsXG4gICd0YWdzJyxcbiAgJ2ZpbmdlcnByaW50JyxcbiAgJ3Byb3BhZ2F0aW9uQ29udGV4dCcsXG5dIDtcblxuZnVuY3Rpb24gaGludElzU2NvcGVDb250ZXh0KGhpbnQpIHtcbiAgcmV0dXJuIE9iamVjdC5rZXlzKGhpbnQpLnNvbWUoa2V5ID0+IGNhcHR1cmVDb250ZXh0S2V5cy5pbmNsdWRlcyhrZXkgKSk7XG59XG5cbmV4cG9ydHMuYXBwbHlDbGllbnRPcHRpb25zID0gYXBwbHlDbGllbnRPcHRpb25zO1xuZXhwb3J0cy5hcHBseURlYnVnSWRzID0gYXBwbHlEZWJ1Z0lkcztcbmV4cG9ydHMuYXBwbHlEZWJ1Z01ldGEgPSBhcHBseURlYnVnTWV0YTtcbmV4cG9ydHMucGFyc2VFdmVudEhpbnRPckNhcHR1cmVDb250ZXh0ID0gcGFyc2VFdmVudEhpbnRPckNhcHR1cmVDb250ZXh0O1xuZXhwb3J0cy5wcmVwYXJlRXZlbnQgPSBwcmVwYXJlRXZlbnQ7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1wcmVwYXJlRXZlbnQuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/prepareEvent.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/promisebuffer.js":
/*!***********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/promisebuffer.js ***!
  \***********************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst syncpromise = __webpack_require__(/*! ./syncpromise.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/syncpromise.js\");\n\nconst SENTRY_BUFFER_FULL_ERROR = Symbol.for('SentryBufferFullError');\n\n/**\n * Creates an new PromiseBuffer object with the specified limit\n * @param limit max number of promises that can be stored in the buffer\n */\nfunction makePromiseBuffer(limit) {\n  const buffer = [];\n\n  function isReady() {\n    return limit === undefined || buffer.length < limit;\n  }\n\n  /**\n   * Remove a promise from the queue.\n   *\n   * @param task Can be any PromiseLike<T>\n   * @returns Removed promise.\n   */\n  function remove(task) {\n    return buffer.splice(buffer.indexOf(task), 1)[0] || Promise.resolve(undefined);\n  }\n\n  /**\n   * Add a promise (representing an in-flight action) to the queue, and set it to remove itself on fulfillment.\n   *\n   * @param taskProducer A function producing any PromiseLike<T>; In previous versions this used to be `task:\n   *        PromiseLike<T>`, but under that model, Promises were instantly created on the call-site and their executor\n   *        functions therefore ran immediately. Thus, even if the buffer was full, the action still happened. By\n   *        requiring the promise to be wrapped in a function, we can defer promise creation until after the buffer\n   *        limit check.\n   * @returns The original promise.\n   */\n  function add(taskProducer) {\n    if (!isReady()) {\n      return syncpromise.rejectedSyncPromise(SENTRY_BUFFER_FULL_ERROR);\n    }\n\n    // start the task and add its promise to the queue\n    const task = taskProducer();\n    if (buffer.indexOf(task) === -1) {\n      buffer.push(task);\n    }\n    void task\n      .then(() => remove(task))\n      // Use `then(null, rejectionHandler)` rather than `catch(rejectionHandler)` so that we can use `PromiseLike`\n      // rather than `Promise`. `PromiseLike` doesn't have a `.catch` method, making its polyfill smaller. (ES5 didn't\n      // have promises, so TS has to polyfill when down-compiling.)\n      .then(null, () =>\n        remove(task).then(null, () => {\n          // We have to add another catch here because `remove()` starts a new promise chain.\n        }),\n      );\n    return task;\n  }\n\n  /**\n   * Wait for all promises in the queue to resolve or for timeout to expire, whichever comes first.\n   *\n   * @param timeout The time, in ms, after which to resolve to `false` if the queue is still non-empty. Passing `0` (or\n   * not passing anything) will make the promise wait as long as it takes for the queue to drain before resolving to\n   * `true`.\n   * @returns A promise which will resolve to `true` if the queue is already empty or drains before the timeout, and\n   * `false` otherwise\n   */\n  function drain(timeout) {\n    return new syncpromise.SyncPromise((resolve, reject) => {\n      let counter = buffer.length;\n\n      if (!counter) {\n        return resolve(true);\n      }\n\n      // wait for `timeout` ms and then resolve to `false` (if not cancelled first)\n      const capturedSetTimeout = setTimeout(() => {\n        if (timeout && timeout > 0) {\n          resolve(false);\n        }\n      }, timeout);\n\n      // if all promises resolve in time, cancel the timer and resolve to `true`\n      buffer.forEach(item => {\n        void syncpromise.resolvedSyncPromise(item).then(() => {\n          if (!--counter) {\n            clearTimeout(capturedSetTimeout);\n            resolve(true);\n          }\n        }, reject);\n      });\n    });\n  }\n\n  return {\n    $: buffer,\n    add,\n    drain,\n  };\n}\n\nexports.SENTRY_BUFFER_FULL_ERROR = SENTRY_BUFFER_FULL_ERROR;\nexports.makePromiseBuffer = makePromiseBuffer;\n//# sourceMappingURL=promisebuffer.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvcHJvbWlzZWJ1ZmZlci5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxvQkFBb0IsbUJBQU8sQ0FBQyx3SUFBa0I7O0FBRTlDOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBLGtFQUFrRTtBQUNsRTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFNBQVM7QUFDVDtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsT0FBTzs7QUFFUDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFNBQVM7QUFDVCxPQUFPO0FBQ1AsS0FBSztBQUNMOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSxnQ0FBZ0M7QUFDaEMseUJBQXlCO0FBQ3pCIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvcHJvbWlzZWJ1ZmZlci5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3Qgc3luY3Byb21pc2UgPSByZXF1aXJlKCcuL3N5bmNwcm9taXNlLmpzJyk7XG5cbmNvbnN0IFNFTlRSWV9CVUZGRVJfRlVMTF9FUlJPUiA9IFN5bWJvbC5mb3IoJ1NlbnRyeUJ1ZmZlckZ1bGxFcnJvcicpO1xuXG4vKipcbiAqIENyZWF0ZXMgYW4gbmV3IFByb21pc2VCdWZmZXIgb2JqZWN0IHdpdGggdGhlIHNwZWNpZmllZCBsaW1pdFxuICogQHBhcmFtIGxpbWl0IG1heCBudW1iZXIgb2YgcHJvbWlzZXMgdGhhdCBjYW4gYmUgc3RvcmVkIGluIHRoZSBidWZmZXJcbiAqL1xuZnVuY3Rpb24gbWFrZVByb21pc2VCdWZmZXIobGltaXQpIHtcbiAgY29uc3QgYnVmZmVyID0gW107XG5cbiAgZnVuY3Rpb24gaXNSZWFkeSgpIHtcbiAgICByZXR1cm4gbGltaXQgPT09IHVuZGVmaW5lZCB8fCBidWZmZXIubGVuZ3RoIDwgbGltaXQ7XG4gIH1cblxuICAvKipcbiAgICogUmVtb3ZlIGEgcHJvbWlzZSBmcm9tIHRoZSBxdWV1ZS5cbiAgICpcbiAgICogQHBhcmFtIHRhc2sgQ2FuIGJlIGFueSBQcm9taXNlTGlrZTxUPlxuICAgKiBAcmV0dXJucyBSZW1vdmVkIHByb21pc2UuXG4gICAqL1xuICBmdW5jdGlvbiByZW1vdmUodGFzaykge1xuICAgIHJldHVybiBidWZmZXIuc3BsaWNlKGJ1ZmZlci5pbmRleE9mKHRhc2spLCAxKVswXSB8fCBQcm9taXNlLnJlc29sdmUodW5kZWZpbmVkKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBBZGQgYSBwcm9taXNlIChyZXByZXNlbnRpbmcgYW4gaW4tZmxpZ2h0IGFjdGlvbikgdG8gdGhlIHF1ZXVlLCBhbmQgc2V0IGl0IHRvIHJlbW92ZSBpdHNlbGYgb24gZnVsZmlsbG1lbnQuXG4gICAqXG4gICAqIEBwYXJhbSB0YXNrUHJvZHVjZXIgQSBmdW5jdGlvbiBwcm9kdWNpbmcgYW55IFByb21pc2VMaWtlPFQ+OyBJbiBwcmV2aW91cyB2ZXJzaW9ucyB0aGlzIHVzZWQgdG8gYmUgYHRhc2s6XG4gICAqICAgICAgICBQcm9taXNlTGlrZTxUPmAsIGJ1dCB1bmRlciB0aGF0IG1vZGVsLCBQcm9taXNlcyB3ZXJlIGluc3RhbnRseSBjcmVhdGVkIG9uIHRoZSBjYWxsLXNpdGUgYW5kIHRoZWlyIGV4ZWN1dG9yXG4gICAqICAgICAgICBmdW5jdGlvbnMgdGhlcmVmb3JlIHJhbiBpbW1lZGlhdGVseS4gVGh1cywgZXZlbiBpZiB0aGUgYnVmZmVyIHdhcyBmdWxsLCB0aGUgYWN0aW9uIHN0aWxsIGhhcHBlbmVkLiBCeVxuICAgKiAgICAgICAgcmVxdWlyaW5nIHRoZSBwcm9taXNlIHRvIGJlIHdyYXBwZWQgaW4gYSBmdW5jdGlvbiwgd2UgY2FuIGRlZmVyIHByb21pc2UgY3JlYXRpb24gdW50aWwgYWZ0ZXIgdGhlIGJ1ZmZlclxuICAgKiAgICAgICAgbGltaXQgY2hlY2suXG4gICAqIEByZXR1cm5zIFRoZSBvcmlnaW5hbCBwcm9taXNlLlxuICAgKi9cbiAgZnVuY3Rpb24gYWRkKHRhc2tQcm9kdWNlcikge1xuICAgIGlmICghaXNSZWFkeSgpKSB7XG4gICAgICByZXR1cm4gc3luY3Byb21pc2UucmVqZWN0ZWRTeW5jUHJvbWlzZShTRU5UUllfQlVGRkVSX0ZVTExfRVJST1IpO1xuICAgIH1cblxuICAgIC8vIHN0YXJ0IHRoZSB0YXNrIGFuZCBhZGQgaXRzIHByb21pc2UgdG8gdGhlIHF1ZXVlXG4gICAgY29uc3QgdGFzayA9IHRhc2tQcm9kdWNlcigpO1xuICAgIGlmIChidWZmZXIuaW5kZXhPZih0YXNrKSA9PT0gLTEpIHtcbiAgICAgIGJ1ZmZlci5wdXNoKHRhc2spO1xuICAgIH1cbiAgICB2b2lkIHRhc2tcbiAgICAgIC50aGVuKCgpID0+IHJlbW92ZSh0YXNrKSlcbiAgICAgIC8vIFVzZSBgdGhlbihudWxsLCByZWplY3Rpb25IYW5kbGVyKWAgcmF0aGVyIHRoYW4gYGNhdGNoKHJlamVjdGlvbkhhbmRsZXIpYCBzbyB0aGF0IHdlIGNhbiB1c2UgYFByb21pc2VMaWtlYFxuICAgICAgLy8gcmF0aGVyIHRoYW4gYFByb21pc2VgLiBgUHJvbWlzZUxpa2VgIGRvZXNuJ3QgaGF2ZSBhIGAuY2F0Y2hgIG1ldGhvZCwgbWFraW5nIGl0cyBwb2x5ZmlsbCBzbWFsbGVyLiAoRVM1IGRpZG4ndFxuICAgICAgLy8gaGF2ZSBwcm9taXNlcywgc28gVFMgaGFzIHRvIHBvbHlmaWxsIHdoZW4gZG93bi1jb21waWxpbmcuKVxuICAgICAgLnRoZW4obnVsbCwgKCkgPT5cbiAgICAgICAgcmVtb3ZlKHRhc2spLnRoZW4obnVsbCwgKCkgPT4ge1xuICAgICAgICAgIC8vIFdlIGhhdmUgdG8gYWRkIGFub3RoZXIgY2F0Y2ggaGVyZSBiZWNhdXNlIGByZW1vdmUoKWAgc3RhcnRzIGEgbmV3IHByb21pc2UgY2hhaW4uXG4gICAgICAgIH0pLFxuICAgICAgKTtcbiAgICByZXR1cm4gdGFzaztcbiAgfVxuXG4gIC8qKlxuICAgKiBXYWl0IGZvciBhbGwgcHJvbWlzZXMgaW4gdGhlIHF1ZXVlIHRvIHJlc29sdmUgb3IgZm9yIHRpbWVvdXQgdG8gZXhwaXJlLCB3aGljaGV2ZXIgY29tZXMgZmlyc3QuXG4gICAqXG4gICAqIEBwYXJhbSB0aW1lb3V0IFRoZSB0aW1lLCBpbiBtcywgYWZ0ZXIgd2hpY2ggdG8gcmVzb2x2ZSB0byBgZmFsc2VgIGlmIHRoZSBxdWV1ZSBpcyBzdGlsbCBub24tZW1wdHkuIFBhc3NpbmcgYDBgIChvclxuICAgKiBub3QgcGFzc2luZyBhbnl0aGluZykgd2lsbCBtYWtlIHRoZSBwcm9taXNlIHdhaXQgYXMgbG9uZyBhcyBpdCB0YWtlcyBmb3IgdGhlIHF1ZXVlIHRvIGRyYWluIGJlZm9yZSByZXNvbHZpbmcgdG9cbiAgICogYHRydWVgLlxuICAgKiBAcmV0dXJucyBBIHByb21pc2Ugd2hpY2ggd2lsbCByZXNvbHZlIHRvIGB0cnVlYCBpZiB0aGUgcXVldWUgaXMgYWxyZWFkeSBlbXB0eSBvciBkcmFpbnMgYmVmb3JlIHRoZSB0aW1lb3V0LCBhbmRcbiAgICogYGZhbHNlYCBvdGhlcndpc2VcbiAgICovXG4gIGZ1bmN0aW9uIGRyYWluKHRpbWVvdXQpIHtcbiAgICByZXR1cm4gbmV3IHN5bmNwcm9taXNlLlN5bmNQcm9taXNlKChyZXNvbHZlLCByZWplY3QpID0+IHtcbiAgICAgIGxldCBjb3VudGVyID0gYnVmZmVyLmxlbmd0aDtcblxuICAgICAgaWYgKCFjb3VudGVyKSB7XG4gICAgICAgIHJldHVybiByZXNvbHZlKHRydWUpO1xuICAgICAgfVxuXG4gICAgICAvLyB3YWl0IGZvciBgdGltZW91dGAgbXMgYW5kIHRoZW4gcmVzb2x2ZSB0byBgZmFsc2VgIChpZiBub3QgY2FuY2VsbGVkIGZpcnN0KVxuICAgICAgY29uc3QgY2FwdHVyZWRTZXRUaW1lb3V0ID0gc2V0VGltZW91dCgoKSA9PiB7XG4gICAgICAgIGlmICh0aW1lb3V0ICYmIHRpbWVvdXQgPiAwKSB7XG4gICAgICAgICAgcmVzb2x2ZShmYWxzZSk7XG4gICAgICAgIH1cbiAgICAgIH0sIHRpbWVvdXQpO1xuXG4gICAgICAvLyBpZiBhbGwgcHJvbWlzZXMgcmVzb2x2ZSBpbiB0aW1lLCBjYW5jZWwgdGhlIHRpbWVyIGFuZCByZXNvbHZlIHRvIGB0cnVlYFxuICAgICAgYnVmZmVyLmZvckVhY2goaXRlbSA9PiB7XG4gICAgICAgIHZvaWQgc3luY3Byb21pc2UucmVzb2x2ZWRTeW5jUHJvbWlzZShpdGVtKS50aGVuKCgpID0+IHtcbiAgICAgICAgICBpZiAoIS0tY291bnRlcikge1xuICAgICAgICAgICAgY2xlYXJUaW1lb3V0KGNhcHR1cmVkU2V0VGltZW91dCk7XG4gICAgICAgICAgICByZXNvbHZlKHRydWUpO1xuICAgICAgICAgIH1cbiAgICAgICAgfSwgcmVqZWN0KTtcbiAgICAgIH0pO1xuICAgIH0pO1xuICB9XG5cbiAgcmV0dXJuIHtcbiAgICAkOiBidWZmZXIsXG4gICAgYWRkLFxuICAgIGRyYWluLFxuICB9O1xufVxuXG5leHBvcnRzLlNFTlRSWV9CVUZGRVJfRlVMTF9FUlJPUiA9IFNFTlRSWV9CVUZGRVJfRlVMTF9FUlJPUjtcbmV4cG9ydHMubWFrZVByb21pc2VCdWZmZXIgPSBtYWtlUHJvbWlzZUJ1ZmZlcjtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPXByb21pc2VidWZmZXIuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/promisebuffer.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/propagationContext.js":
/*!****************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/propagationContext.js ***!
  \****************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst misc = __webpack_require__(/*! ./misc.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/misc.js\");\n\n/**\n * Generate a random, valid trace ID.\n */\nfunction generateTraceId() {\n  return misc.uuid4();\n}\n\n/**\n * Generate a random, valid span ID.\n */\nfunction generateSpanId() {\n  return misc.uuid4().substring(16);\n}\n\nexports.generateSpanId = generateSpanId;\nexports.generateTraceId = generateTraceId;\n//# sourceMappingURL=propagationContext.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvcHJvcGFnYXRpb25Db250ZXh0LmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLGFBQWEsbUJBQU8sQ0FBQywwSEFBVzs7QUFFaEM7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSxzQkFBc0I7QUFDdEIsdUJBQXVCO0FBQ3ZCIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvcHJvcGFnYXRpb25Db250ZXh0LmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBtaXNjID0gcmVxdWlyZSgnLi9taXNjLmpzJyk7XG5cbi8qKlxuICogR2VuZXJhdGUgYSByYW5kb20sIHZhbGlkIHRyYWNlIElELlxuICovXG5mdW5jdGlvbiBnZW5lcmF0ZVRyYWNlSWQoKSB7XG4gIHJldHVybiBtaXNjLnV1aWQ0KCk7XG59XG5cbi8qKlxuICogR2VuZXJhdGUgYSByYW5kb20sIHZhbGlkIHNwYW4gSUQuXG4gKi9cbmZ1bmN0aW9uIGdlbmVyYXRlU3BhbklkKCkge1xuICByZXR1cm4gbWlzYy51dWlkNCgpLnN1YnN0cmluZygxNik7XG59XG5cbmV4cG9ydHMuZ2VuZXJhdGVTcGFuSWQgPSBnZW5lcmF0ZVNwYW5JZDtcbmV4cG9ydHMuZ2VuZXJhdGVUcmFjZUlkID0gZ2VuZXJhdGVUcmFjZUlkO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9cHJvcGFnYXRpb25Db250ZXh0LmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/propagationContext.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/ratelimit.js":
/*!*******************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/ratelimit.js ***!
  \*******************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n// Intentionally keeping the key broad, as we don't know for sure what rate limit headers get returned from backend\n\nconst DEFAULT_RETRY_AFTER = 60 * 1000; // 60 seconds\n\n/**\n * Extracts Retry-After value from the request header or returns default value\n * @param header string representation of 'Retry-After' header\n * @param now current unix timestamp\n *\n */\nfunction parseRetryAfterHeader(header, now = Date.now()) {\n  const headerDelay = parseInt(`${header}`, 10);\n  if (!isNaN(headerDelay)) {\n    return headerDelay * 1000;\n  }\n\n  const headerDate = Date.parse(`${header}`);\n  if (!isNaN(headerDate)) {\n    return headerDate - now;\n  }\n\n  return DEFAULT_RETRY_AFTER;\n}\n\n/**\n * Gets the time that the given category is disabled until for rate limiting.\n * In case no category-specific limit is set but a general rate limit across all categories is active,\n * that time is returned.\n *\n * @return the time in ms that the category is disabled until or 0 if there's no active rate limit.\n */\nfunction disabledUntil(limits, dataCategory) {\n  return limits[dataCategory] || limits.all || 0;\n}\n\n/**\n * Checks if a category is rate limited\n */\nfunction isRateLimited(limits, dataCategory, now = Date.now()) {\n  return disabledUntil(limits, dataCategory) > now;\n}\n\n/**\n * Update ratelimits from incoming headers.\n *\n * @return the updated RateLimits object.\n */\nfunction updateRateLimits(\n  limits,\n  { statusCode, headers },\n  now = Date.now(),\n) {\n  const updatedRateLimits = {\n    ...limits,\n  };\n\n  // \"The name is case-insensitive.\"\n  // https://developer.mozilla.org/en-US/docs/Web/API/Headers/get\n  const rateLimitHeader = headers?.['x-sentry-rate-limits'];\n  const retryAfterHeader = headers?.['retry-after'];\n\n  if (rateLimitHeader) {\n    /**\n     * rate limit headers are of the form\n     *     <header>,<header>,..\n     * where each <header> is of the form\n     *     <retry_after>: <categories>: <scope>: <reason_code>: <namespaces>\n     * where\n     *     <retry_after> is a delay in seconds\n     *     <categories> is the event type(s) (error, transaction, etc) being rate limited and is of the form\n     *         <category>;<category>;...\n     *     <scope> is what's being limited (org, project, or key) - ignored by SDK\n     *     <reason_code> is an arbitrary string like \"org_quota\" - ignored by SDK\n     *     <namespaces> Semicolon-separated list of metric namespace identifiers. Defines which namespace(s) will be affected.\n     *         Only present if rate limit applies to the metric_bucket data category.\n     */\n    for (const limit of rateLimitHeader.trim().split(',')) {\n      const [retryAfter, categories, , , namespaces] = limit.split(':', 5) ;\n      const headerDelay = parseInt(retryAfter, 10);\n      const delay = (!isNaN(headerDelay) ? headerDelay : 60) * 1000; // 60sec default\n      if (!categories) {\n        updatedRateLimits.all = now + delay;\n      } else {\n        for (const category of categories.split(';')) {\n          if (category === 'metric_bucket') {\n            // namespaces will be present when category === 'metric_bucket'\n            if (!namespaces || namespaces.split(';').includes('custom')) {\n              updatedRateLimits[category] = now + delay;\n            }\n          } else {\n            updatedRateLimits[category] = now + delay;\n          }\n        }\n      }\n    }\n  } else if (retryAfterHeader) {\n    updatedRateLimits.all = now + parseRetryAfterHeader(retryAfterHeader, now);\n  } else if (statusCode === 429) {\n    updatedRateLimits.all = now + 60 * 1000;\n  }\n\n  return updatedRateLimits;\n}\n\nexports.DEFAULT_RETRY_AFTER = DEFAULT_RETRY_AFTER;\nexports.disabledUntil = disabledUntil;\nexports.isRateLimited = isRateLimited;\nexports.parseRetryAfterHeader = parseRetryAfterHeader;\nexports.updateRateLimits = updateRateLimits;\n//# sourceMappingURL=ratelimit.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvcmF0ZWxpbWl0LmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFOztBQUVBLHVDQUF1Qzs7QUFFdkM7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxrQ0FBa0MsT0FBTztBQUN6QztBQUNBO0FBQ0E7O0FBRUEsbUNBQW1DLE9BQU87QUFDMUM7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsSUFBSSxxQkFBcUI7QUFDekI7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSwwQkFBMEIsV0FBVztBQUNyQztBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EscUVBQXFFO0FBQ3JFO0FBQ0E7QUFDQSxRQUFRO0FBQ1Isa0RBQWtEO0FBQ2xEO0FBQ0E7QUFDQSxrREFBa0Q7QUFDbEQ7QUFDQTtBQUNBLFlBQVk7QUFDWjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsSUFBSTtBQUNKO0FBQ0EsSUFBSTtBQUNKO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQSwyQkFBMkI7QUFDM0IscUJBQXFCO0FBQ3JCLHFCQUFxQjtBQUNyQiw2QkFBNkI7QUFDN0Isd0JBQXdCO0FBQ3hCIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvcmF0ZWxpbWl0LmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG4vLyBJbnRlbnRpb25hbGx5IGtlZXBpbmcgdGhlIGtleSBicm9hZCwgYXMgd2UgZG9uJ3Qga25vdyBmb3Igc3VyZSB3aGF0IHJhdGUgbGltaXQgaGVhZGVycyBnZXQgcmV0dXJuZWQgZnJvbSBiYWNrZW5kXG5cbmNvbnN0IERFRkFVTFRfUkVUUllfQUZURVIgPSA2MCAqIDEwMDA7IC8vIDYwIHNlY29uZHNcblxuLyoqXG4gKiBFeHRyYWN0cyBSZXRyeS1BZnRlciB2YWx1ZSBmcm9tIHRoZSByZXF1ZXN0IGhlYWRlciBvciByZXR1cm5zIGRlZmF1bHQgdmFsdWVcbiAqIEBwYXJhbSBoZWFkZXIgc3RyaW5nIHJlcHJlc2VudGF0aW9uIG9mICdSZXRyeS1BZnRlcicgaGVhZGVyXG4gKiBAcGFyYW0gbm93IGN1cnJlbnQgdW5peCB0aW1lc3RhbXBcbiAqXG4gKi9cbmZ1bmN0aW9uIHBhcnNlUmV0cnlBZnRlckhlYWRlcihoZWFkZXIsIG5vdyA9IERhdGUubm93KCkpIHtcbiAgY29uc3QgaGVhZGVyRGVsYXkgPSBwYXJzZUludChgJHtoZWFkZXJ9YCwgMTApO1xuICBpZiAoIWlzTmFOKGhlYWRlckRlbGF5KSkge1xuICAgIHJldHVybiBoZWFkZXJEZWxheSAqIDEwMDA7XG4gIH1cblxuICBjb25zdCBoZWFkZXJEYXRlID0gRGF0ZS5wYXJzZShgJHtoZWFkZXJ9YCk7XG4gIGlmICghaXNOYU4oaGVhZGVyRGF0ZSkpIHtcbiAgICByZXR1cm4gaGVhZGVyRGF0ZSAtIG5vdztcbiAgfVxuXG4gIHJldHVybiBERUZBVUxUX1JFVFJZX0FGVEVSO1xufVxuXG4vKipcbiAqIEdldHMgdGhlIHRpbWUgdGhhdCB0aGUgZ2l2ZW4gY2F0ZWdvcnkgaXMgZGlzYWJsZWQgdW50aWwgZm9yIHJhdGUgbGltaXRpbmcuXG4gKiBJbiBjYXNlIG5vIGNhdGVnb3J5LXNwZWNpZmljIGxpbWl0IGlzIHNldCBidXQgYSBnZW5lcmFsIHJhdGUgbGltaXQgYWNyb3NzIGFsbCBjYXRlZ29yaWVzIGlzIGFjdGl2ZSxcbiAqIHRoYXQgdGltZSBpcyByZXR1cm5lZC5cbiAqXG4gKiBAcmV0dXJuIHRoZSB0aW1lIGluIG1zIHRoYXQgdGhlIGNhdGVnb3J5IGlzIGRpc2FibGVkIHVudGlsIG9yIDAgaWYgdGhlcmUncyBubyBhY3RpdmUgcmF0ZSBsaW1pdC5cbiAqL1xuZnVuY3Rpb24gZGlzYWJsZWRVbnRpbChsaW1pdHMsIGRhdGFDYXRlZ29yeSkge1xuICByZXR1cm4gbGltaXRzW2RhdGFDYXRlZ29yeV0gfHwgbGltaXRzLmFsbCB8fCAwO1xufVxuXG4vKipcbiAqIENoZWNrcyBpZiBhIGNhdGVnb3J5IGlzIHJhdGUgbGltaXRlZFxuICovXG5mdW5jdGlvbiBpc1JhdGVMaW1pdGVkKGxpbWl0cywgZGF0YUNhdGVnb3J5LCBub3cgPSBEYXRlLm5vdygpKSB7XG4gIHJldHVybiBkaXNhYmxlZFVudGlsKGxpbWl0cywgZGF0YUNhdGVnb3J5KSA+IG5vdztcbn1cblxuLyoqXG4gKiBVcGRhdGUgcmF0ZWxpbWl0cyBmcm9tIGluY29taW5nIGhlYWRlcnMuXG4gKlxuICogQHJldHVybiB0aGUgdXBkYXRlZCBSYXRlTGltaXRzIG9iamVjdC5cbiAqL1xuZnVuY3Rpb24gdXBkYXRlUmF0ZUxpbWl0cyhcbiAgbGltaXRzLFxuICB7IHN0YXR1c0NvZGUsIGhlYWRlcnMgfSxcbiAgbm93ID0gRGF0ZS5ub3coKSxcbikge1xuICBjb25zdCB1cGRhdGVkUmF0ZUxpbWl0cyA9IHtcbiAgICAuLi5saW1pdHMsXG4gIH07XG5cbiAgLy8gXCJUaGUgbmFtZSBpcyBjYXNlLWluc2Vuc2l0aXZlLlwiXG4gIC8vIGh0dHBzOi8vZGV2ZWxvcGVyLm1vemlsbGEub3JnL2VuLVVTL2RvY3MvV2ViL0FQSS9IZWFkZXJzL2dldFxuICBjb25zdCByYXRlTGltaXRIZWFkZXIgPSBoZWFkZXJzPy5bJ3gtc2VudHJ5LXJhdGUtbGltaXRzJ107XG4gIGNvbnN0IHJldHJ5QWZ0ZXJIZWFkZXIgPSBoZWFkZXJzPy5bJ3JldHJ5LWFmdGVyJ107XG5cbiAgaWYgKHJhdGVMaW1pdEhlYWRlcikge1xuICAgIC8qKlxuICAgICAqIHJhdGUgbGltaXQgaGVhZGVycyBhcmUgb2YgdGhlIGZvcm1cbiAgICAgKiAgICAgPGhlYWRlcj4sPGhlYWRlcj4sLi5cbiAgICAgKiB3aGVyZSBlYWNoIDxoZWFkZXI+IGlzIG9mIHRoZSBmb3JtXG4gICAgICogICAgIDxyZXRyeV9hZnRlcj46IDxjYXRlZ29yaWVzPjogPHNjb3BlPjogPHJlYXNvbl9jb2RlPjogPG5hbWVzcGFjZXM+XG4gICAgICogd2hlcmVcbiAgICAgKiAgICAgPHJldHJ5X2FmdGVyPiBpcyBhIGRlbGF5IGluIHNlY29uZHNcbiAgICAgKiAgICAgPGNhdGVnb3JpZXM+IGlzIHRoZSBldmVudCB0eXBlKHMpIChlcnJvciwgdHJhbnNhY3Rpb24sIGV0YykgYmVpbmcgcmF0ZSBsaW1pdGVkIGFuZCBpcyBvZiB0aGUgZm9ybVxuICAgICAqICAgICAgICAgPGNhdGVnb3J5Pjs8Y2F0ZWdvcnk+Oy4uLlxuICAgICAqICAgICA8c2NvcGU+IGlzIHdoYXQncyBiZWluZyBsaW1pdGVkIChvcmcsIHByb2plY3QsIG9yIGtleSkgLSBpZ25vcmVkIGJ5IFNES1xuICAgICAqICAgICA8cmVhc29uX2NvZGU+IGlzIGFuIGFyYml0cmFyeSBzdHJpbmcgbGlrZSBcIm9yZ19xdW90YVwiIC0gaWdub3JlZCBieSBTREtcbiAgICAgKiAgICAgPG5hbWVzcGFjZXM+IFNlbWljb2xvbi1zZXBhcmF0ZWQgbGlzdCBvZiBtZXRyaWMgbmFtZXNwYWNlIGlkZW50aWZpZXJzLiBEZWZpbmVzIHdoaWNoIG5hbWVzcGFjZShzKSB3aWxsIGJlIGFmZmVjdGVkLlxuICAgICAqICAgICAgICAgT25seSBwcmVzZW50IGlmIHJhdGUgbGltaXQgYXBwbGllcyB0byB0aGUgbWV0cmljX2J1Y2tldCBkYXRhIGNhdGVnb3J5LlxuICAgICAqL1xuICAgIGZvciAoY29uc3QgbGltaXQgb2YgcmF0ZUxpbWl0SGVhZGVyLnRyaW0oKS5zcGxpdCgnLCcpKSB7XG4gICAgICBjb25zdCBbcmV0cnlBZnRlciwgY2F0ZWdvcmllcywgLCAsIG5hbWVzcGFjZXNdID0gbGltaXQuc3BsaXQoJzonLCA1KSA7XG4gICAgICBjb25zdCBoZWFkZXJEZWxheSA9IHBhcnNlSW50KHJldHJ5QWZ0ZXIsIDEwKTtcbiAgICAgIGNvbnN0IGRlbGF5ID0gKCFpc05hTihoZWFkZXJEZWxheSkgPyBoZWFkZXJEZWxheSA6IDYwKSAqIDEwMDA7IC8vIDYwc2VjIGRlZmF1bHRcbiAgICAgIGlmICghY2F0ZWdvcmllcykge1xuICAgICAgICB1cGRhdGVkUmF0ZUxpbWl0cy5hbGwgPSBub3cgKyBkZWxheTtcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIGZvciAoY29uc3QgY2F0ZWdvcnkgb2YgY2F0ZWdvcmllcy5zcGxpdCgnOycpKSB7XG4gICAgICAgICAgaWYgKGNhdGVnb3J5ID09PSAnbWV0cmljX2J1Y2tldCcpIHtcbiAgICAgICAgICAgIC8vIG5hbWVzcGFjZXMgd2lsbCBiZSBwcmVzZW50IHdoZW4gY2F0ZWdvcnkgPT09ICdtZXRyaWNfYnVja2V0J1xuICAgICAgICAgICAgaWYgKCFuYW1lc3BhY2VzIHx8IG5hbWVzcGFjZXMuc3BsaXQoJzsnKS5pbmNsdWRlcygnY3VzdG9tJykpIHtcbiAgICAgICAgICAgICAgdXBkYXRlZFJhdGVMaW1pdHNbY2F0ZWdvcnldID0gbm93ICsgZGVsYXk7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgIHVwZGF0ZWRSYXRlTGltaXRzW2NhdGVnb3J5XSA9IG5vdyArIGRlbGF5O1xuICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgfVxuICAgIH1cbiAgfSBlbHNlIGlmIChyZXRyeUFmdGVySGVhZGVyKSB7XG4gICAgdXBkYXRlZFJhdGVMaW1pdHMuYWxsID0gbm93ICsgcGFyc2VSZXRyeUFmdGVySGVhZGVyKHJldHJ5QWZ0ZXJIZWFkZXIsIG5vdyk7XG4gIH0gZWxzZSBpZiAoc3RhdHVzQ29kZSA9PT0gNDI5KSB7XG4gICAgdXBkYXRlZFJhdGVMaW1pdHMuYWxsID0gbm93ICsgNjAgKiAxMDAwO1xuICB9XG5cbiAgcmV0dXJuIHVwZGF0ZWRSYXRlTGltaXRzO1xufVxuXG5leHBvcnRzLkRFRkFVTFRfUkVUUllfQUZURVIgPSBERUZBVUxUX1JFVFJZX0FGVEVSO1xuZXhwb3J0cy5kaXNhYmxlZFVudGlsID0gZGlzYWJsZWRVbnRpbDtcbmV4cG9ydHMuaXNSYXRlTGltaXRlZCA9IGlzUmF0ZUxpbWl0ZWQ7XG5leHBvcnRzLnBhcnNlUmV0cnlBZnRlckhlYWRlciA9IHBhcnNlUmV0cnlBZnRlckhlYWRlcjtcbmV4cG9ydHMudXBkYXRlUmF0ZUxpbWl0cyA9IHVwZGF0ZVJhdGVMaW1pdHM7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1yYXRlbGltaXQuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/ratelimit.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/request.js":
/*!*****************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/request.js ***!
  \*****************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n/**\n * Transforms a `Headers` object that implements the `Web Fetch API` (https://developer.mozilla.org/en-US/docs/Web/API/Headers) into a simple key-value dict.\n * The header keys will be lower case: e.g. A \"Content-Type\" header will be stored as \"content-type\".\n */\nfunction winterCGHeadersToDict(winterCGHeaders) {\n  const headers = {};\n  try {\n    winterCGHeaders.forEach((value, key) => {\n      if (typeof value === 'string') {\n        // We check that value is a string even though it might be redundant to make sure prototype pollution is not possible.\n        headers[key] = value;\n      }\n    });\n  } catch {\n    // just return the empty headers\n  }\n\n  return headers;\n}\n\n/**\n * Convert common request headers to a simple dictionary.\n */\nfunction headersToDict(reqHeaders) {\n  const headers = Object.create(null);\n\n  try {\n    Object.entries(reqHeaders).forEach(([key, value]) => {\n      if (typeof value === 'string') {\n        headers[key] = value;\n      }\n    });\n  } catch {\n    // just return the empty headers\n  }\n\n  return headers;\n}\n\n/**\n * Converts a `Request` object that implements the `Web Fetch API` (https://developer.mozilla.org/en-US/docs/Web/API/Headers) into the format that the `RequestData` integration understands.\n */\nfunction winterCGRequestToRequestData(req) {\n  const headers = winterCGHeadersToDict(req.headers);\n\n  return {\n    method: req.method,\n    url: req.url,\n    query_string: extractQueryParamsFromUrl(req.url),\n    headers,\n    // TODO: Can we extract body data from the request?\n  };\n}\n\n/**\n * Convert a HTTP request object to RequestEventData to be passed as normalizedRequest.\n * Instead of allowing `PolymorphicRequest` to be passed,\n * we want to be more specific and generally require a http.IncomingMessage-like object.\n */\nfunction httpRequestToRequestData(request\n\n) {\n  const headers = request.headers || {};\n\n  // Check for x-forwarded-host first, then fall back to host header\n  const forwardedHost = typeof headers['x-forwarded-host'] === 'string' ? headers['x-forwarded-host'] : undefined;\n  const host = forwardedHost || (typeof headers.host === 'string' ? headers.host : undefined);\n\n  // Check for x-forwarded-proto first, then fall back to existing protocol detection\n  const forwardedProto = typeof headers['x-forwarded-proto'] === 'string' ? headers['x-forwarded-proto'] : undefined;\n  const protocol = forwardedProto || request.protocol || (request.socket?.encrypted ? 'https' : 'http');\n\n  const url = request.url || '';\n\n  const absoluteUrl = getAbsoluteUrl({\n    url,\n    host,\n    protocol,\n  });\n\n  // This is non-standard, but may be sometimes set\n  // It may be overwritten later by our own body handling\n  const data = (request ).body || undefined;\n\n  // This is non-standard, but may be set on e.g. Next.js or Express requests\n  const cookies = (request ).cookies;\n\n  return {\n    url: absoluteUrl,\n    method: request.method,\n    query_string: extractQueryParamsFromUrl(url),\n    headers: headersToDict(headers),\n    cookies,\n    data,\n  };\n}\n\nfunction getAbsoluteUrl({\n  url,\n  protocol,\n  host,\n}\n\n) {\n  if (url?.startsWith('http')) {\n    return url;\n  }\n\n  if (url && host) {\n    return `${protocol}://${host}${url}`;\n  }\n\n  return undefined;\n}\n\n/** Extract the query params from an URL. */\nfunction extractQueryParamsFromUrl(url) {\n  // url is path and query string\n  if (!url) {\n    return;\n  }\n\n  try {\n    // The `URL` constructor can't handle internal URLs of the form `/some/path/here`, so stick a dummy protocol and\n    // hostname as the base. Since the point here is just to grab the query string, it doesn't matter what we use.\n    const queryParams = new URL(url, 'http://s.io').search.slice(1);\n    return queryParams.length ? queryParams : undefined;\n  } catch {\n    return undefined;\n  }\n}\n\nexports.extractQueryParamsFromUrl = extractQueryParamsFromUrl;\nexports.headersToDict = headersToDict;\nexports.httpRequestToRequestData = httpRequestToRequestData;\nexports.winterCGHeadersToDict = winterCGHeadersToDict;\nexports.winterCGRequestToRequestData = winterCGRequestToRequestData;\n//# sourceMappingURL=request.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvcmVxdWVzdC5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxLQUFLO0FBQ0wsSUFBSTtBQUNKO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxLQUFLO0FBQ0wsSUFBSTtBQUNKO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEdBQUc7O0FBRUg7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQSxjQUFjLFNBQVMsS0FBSyxLQUFLLEVBQUUsSUFBSTtBQUN2Qzs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsSUFBSTtBQUNKO0FBQ0E7QUFDQTs7QUFFQSxpQ0FBaUM7QUFDakMscUJBQXFCO0FBQ3JCLGdDQUFnQztBQUNoQyw2QkFBNkI7QUFDN0Isb0NBQW9DO0FBQ3BDIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvcmVxdWVzdC5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuLyoqXG4gKiBUcmFuc2Zvcm1zIGEgYEhlYWRlcnNgIG9iamVjdCB0aGF0IGltcGxlbWVudHMgdGhlIGBXZWIgRmV0Y2ggQVBJYCAoaHR0cHM6Ly9kZXZlbG9wZXIubW96aWxsYS5vcmcvZW4tVVMvZG9jcy9XZWIvQVBJL0hlYWRlcnMpIGludG8gYSBzaW1wbGUga2V5LXZhbHVlIGRpY3QuXG4gKiBUaGUgaGVhZGVyIGtleXMgd2lsbCBiZSBsb3dlciBjYXNlOiBlLmcuIEEgXCJDb250ZW50LVR5cGVcIiBoZWFkZXIgd2lsbCBiZSBzdG9yZWQgYXMgXCJjb250ZW50LXR5cGVcIi5cbiAqL1xuZnVuY3Rpb24gd2ludGVyQ0dIZWFkZXJzVG9EaWN0KHdpbnRlckNHSGVhZGVycykge1xuICBjb25zdCBoZWFkZXJzID0ge307XG4gIHRyeSB7XG4gICAgd2ludGVyQ0dIZWFkZXJzLmZvckVhY2goKHZhbHVlLCBrZXkpID0+IHtcbiAgICAgIGlmICh0eXBlb2YgdmFsdWUgPT09ICdzdHJpbmcnKSB7XG4gICAgICAgIC8vIFdlIGNoZWNrIHRoYXQgdmFsdWUgaXMgYSBzdHJpbmcgZXZlbiB0aG91Z2ggaXQgbWlnaHQgYmUgcmVkdW5kYW50IHRvIG1ha2Ugc3VyZSBwcm90b3R5cGUgcG9sbHV0aW9uIGlzIG5vdCBwb3NzaWJsZS5cbiAgICAgICAgaGVhZGVyc1trZXldID0gdmFsdWU7XG4gICAgICB9XG4gICAgfSk7XG4gIH0gY2F0Y2gge1xuICAgIC8vIGp1c3QgcmV0dXJuIHRoZSBlbXB0eSBoZWFkZXJzXG4gIH1cblxuICByZXR1cm4gaGVhZGVycztcbn1cblxuLyoqXG4gKiBDb252ZXJ0IGNvbW1vbiByZXF1ZXN0IGhlYWRlcnMgdG8gYSBzaW1wbGUgZGljdGlvbmFyeS5cbiAqL1xuZnVuY3Rpb24gaGVhZGVyc1RvRGljdChyZXFIZWFkZXJzKSB7XG4gIGNvbnN0IGhlYWRlcnMgPSBPYmplY3QuY3JlYXRlKG51bGwpO1xuXG4gIHRyeSB7XG4gICAgT2JqZWN0LmVudHJpZXMocmVxSGVhZGVycykuZm9yRWFjaCgoW2tleSwgdmFsdWVdKSA9PiB7XG4gICAgICBpZiAodHlwZW9mIHZhbHVlID09PSAnc3RyaW5nJykge1xuICAgICAgICBoZWFkZXJzW2tleV0gPSB2YWx1ZTtcbiAgICAgIH1cbiAgICB9KTtcbiAgfSBjYXRjaCB7XG4gICAgLy8ganVzdCByZXR1cm4gdGhlIGVtcHR5IGhlYWRlcnNcbiAgfVxuXG4gIHJldHVybiBoZWFkZXJzO1xufVxuXG4vKipcbiAqIENvbnZlcnRzIGEgYFJlcXVlc3RgIG9iamVjdCB0aGF0IGltcGxlbWVudHMgdGhlIGBXZWIgRmV0Y2ggQVBJYCAoaHR0cHM6Ly9kZXZlbG9wZXIubW96aWxsYS5vcmcvZW4tVVMvZG9jcy9XZWIvQVBJL0hlYWRlcnMpIGludG8gdGhlIGZvcm1hdCB0aGF0IHRoZSBgUmVxdWVzdERhdGFgIGludGVncmF0aW9uIHVuZGVyc3RhbmRzLlxuICovXG5mdW5jdGlvbiB3aW50ZXJDR1JlcXVlc3RUb1JlcXVlc3REYXRhKHJlcSkge1xuICBjb25zdCBoZWFkZXJzID0gd2ludGVyQ0dIZWFkZXJzVG9EaWN0KHJlcS5oZWFkZXJzKTtcblxuICByZXR1cm4ge1xuICAgIG1ldGhvZDogcmVxLm1ldGhvZCxcbiAgICB1cmw6IHJlcS51cmwsXG4gICAgcXVlcnlfc3RyaW5nOiBleHRyYWN0UXVlcnlQYXJhbXNGcm9tVXJsKHJlcS51cmwpLFxuICAgIGhlYWRlcnMsXG4gICAgLy8gVE9ETzogQ2FuIHdlIGV4dHJhY3QgYm9keSBkYXRhIGZyb20gdGhlIHJlcXVlc3Q/XG4gIH07XG59XG5cbi8qKlxuICogQ29udmVydCBhIEhUVFAgcmVxdWVzdCBvYmplY3QgdG8gUmVxdWVzdEV2ZW50RGF0YSB0byBiZSBwYXNzZWQgYXMgbm9ybWFsaXplZFJlcXVlc3QuXG4gKiBJbnN0ZWFkIG9mIGFsbG93aW5nIGBQb2x5bW9ycGhpY1JlcXVlc3RgIHRvIGJlIHBhc3NlZCxcbiAqIHdlIHdhbnQgdG8gYmUgbW9yZSBzcGVjaWZpYyBhbmQgZ2VuZXJhbGx5IHJlcXVpcmUgYSBodHRwLkluY29taW5nTWVzc2FnZS1saWtlIG9iamVjdC5cbiAqL1xuZnVuY3Rpb24gaHR0cFJlcXVlc3RUb1JlcXVlc3REYXRhKHJlcXVlc3RcblxuKSB7XG4gIGNvbnN0IGhlYWRlcnMgPSByZXF1ZXN0LmhlYWRlcnMgfHwge307XG5cbiAgLy8gQ2hlY2sgZm9yIHgtZm9yd2FyZGVkLWhvc3QgZmlyc3QsIHRoZW4gZmFsbCBiYWNrIHRvIGhvc3QgaGVhZGVyXG4gIGNvbnN0IGZvcndhcmRlZEhvc3QgPSB0eXBlb2YgaGVhZGVyc1sneC1mb3J3YXJkZWQtaG9zdCddID09PSAnc3RyaW5nJyA/IGhlYWRlcnNbJ3gtZm9yd2FyZGVkLWhvc3QnXSA6IHVuZGVmaW5lZDtcbiAgY29uc3QgaG9zdCA9IGZvcndhcmRlZEhvc3QgfHwgKHR5cGVvZiBoZWFkZXJzLmhvc3QgPT09ICdzdHJpbmcnID8gaGVhZGVycy5ob3N0IDogdW5kZWZpbmVkKTtcblxuICAvLyBDaGVjayBmb3IgeC1mb3J3YXJkZWQtcHJvdG8gZmlyc3QsIHRoZW4gZmFsbCBiYWNrIHRvIGV4aXN0aW5nIHByb3RvY29sIGRldGVjdGlvblxuICBjb25zdCBmb3J3YXJkZWRQcm90byA9IHR5cGVvZiBoZWFkZXJzWyd4LWZvcndhcmRlZC1wcm90byddID09PSAnc3RyaW5nJyA/IGhlYWRlcnNbJ3gtZm9yd2FyZGVkLXByb3RvJ10gOiB1bmRlZmluZWQ7XG4gIGNvbnN0IHByb3RvY29sID0gZm9yd2FyZGVkUHJvdG8gfHwgcmVxdWVzdC5wcm90b2NvbCB8fCAocmVxdWVzdC5zb2NrZXQ/LmVuY3J5cHRlZCA/ICdodHRwcycgOiAnaHR0cCcpO1xuXG4gIGNvbnN0IHVybCA9IHJlcXVlc3QudXJsIHx8ICcnO1xuXG4gIGNvbnN0IGFic29sdXRlVXJsID0gZ2V0QWJzb2x1dGVVcmwoe1xuICAgIHVybCxcbiAgICBob3N0LFxuICAgIHByb3RvY29sLFxuICB9KTtcblxuICAvLyBUaGlzIGlzIG5vbi1zdGFuZGFyZCwgYnV0IG1heSBiZSBzb21ldGltZXMgc2V0XG4gIC8vIEl0IG1heSBiZSBvdmVyd3JpdHRlbiBsYXRlciBieSBvdXIgb3duIGJvZHkgaGFuZGxpbmdcbiAgY29uc3QgZGF0YSA9IChyZXF1ZXN0ICkuYm9keSB8fCB1bmRlZmluZWQ7XG5cbiAgLy8gVGhpcyBpcyBub24tc3RhbmRhcmQsIGJ1dCBtYXkgYmUgc2V0IG9uIGUuZy4gTmV4dC5qcyBvciBFeHByZXNzIHJlcXVlc3RzXG4gIGNvbnN0IGNvb2tpZXMgPSAocmVxdWVzdCApLmNvb2tpZXM7XG5cbiAgcmV0dXJuIHtcbiAgICB1cmw6IGFic29sdXRlVXJsLFxuICAgIG1ldGhvZDogcmVxdWVzdC5tZXRob2QsXG4gICAgcXVlcnlfc3RyaW5nOiBleHRyYWN0UXVlcnlQYXJhbXNGcm9tVXJsKHVybCksXG4gICAgaGVhZGVyczogaGVhZGVyc1RvRGljdChoZWFkZXJzKSxcbiAgICBjb29raWVzLFxuICAgIGRhdGEsXG4gIH07XG59XG5cbmZ1bmN0aW9uIGdldEFic29sdXRlVXJsKHtcbiAgdXJsLFxuICBwcm90b2NvbCxcbiAgaG9zdCxcbn1cblxuKSB7XG4gIGlmICh1cmw/LnN0YXJ0c1dpdGgoJ2h0dHAnKSkge1xuICAgIHJldHVybiB1cmw7XG4gIH1cblxuICBpZiAodXJsICYmIGhvc3QpIHtcbiAgICByZXR1cm4gYCR7cHJvdG9jb2x9Oi8vJHtob3N0fSR7dXJsfWA7XG4gIH1cblxuICByZXR1cm4gdW5kZWZpbmVkO1xufVxuXG4vKiogRXh0cmFjdCB0aGUgcXVlcnkgcGFyYW1zIGZyb20gYW4gVVJMLiAqL1xuZnVuY3Rpb24gZXh0cmFjdFF1ZXJ5UGFyYW1zRnJvbVVybCh1cmwpIHtcbiAgLy8gdXJsIGlzIHBhdGggYW5kIHF1ZXJ5IHN0cmluZ1xuICBpZiAoIXVybCkge1xuICAgIHJldHVybjtcbiAgfVxuXG4gIHRyeSB7XG4gICAgLy8gVGhlIGBVUkxgIGNvbnN0cnVjdG9yIGNhbid0IGhhbmRsZSBpbnRlcm5hbCBVUkxzIG9mIHRoZSBmb3JtIGAvc29tZS9wYXRoL2hlcmVgLCBzbyBzdGljayBhIGR1bW15IHByb3RvY29sIGFuZFxuICAgIC8vIGhvc3RuYW1lIGFzIHRoZSBiYXNlLiBTaW5jZSB0aGUgcG9pbnQgaGVyZSBpcyBqdXN0IHRvIGdyYWIgdGhlIHF1ZXJ5IHN0cmluZywgaXQgZG9lc24ndCBtYXR0ZXIgd2hhdCB3ZSB1c2UuXG4gICAgY29uc3QgcXVlcnlQYXJhbXMgPSBuZXcgVVJMKHVybCwgJ2h0dHA6Ly9zLmlvJykuc2VhcmNoLnNsaWNlKDEpO1xuICAgIHJldHVybiBxdWVyeVBhcmFtcy5sZW5ndGggPyBxdWVyeVBhcmFtcyA6IHVuZGVmaW5lZDtcbiAgfSBjYXRjaCB7XG4gICAgcmV0dXJuIHVuZGVmaW5lZDtcbiAgfVxufVxuXG5leHBvcnRzLmV4dHJhY3RRdWVyeVBhcmFtc0Zyb21VcmwgPSBleHRyYWN0UXVlcnlQYXJhbXNGcm9tVXJsO1xuZXhwb3J0cy5oZWFkZXJzVG9EaWN0ID0gaGVhZGVyc1RvRGljdDtcbmV4cG9ydHMuaHR0cFJlcXVlc3RUb1JlcXVlc3REYXRhID0gaHR0cFJlcXVlc3RUb1JlcXVlc3REYXRhO1xuZXhwb3J0cy53aW50ZXJDR0hlYWRlcnNUb0RpY3QgPSB3aW50ZXJDR0hlYWRlcnNUb0RpY3Q7XG5leHBvcnRzLndpbnRlckNHUmVxdWVzdFRvUmVxdWVzdERhdGEgPSB3aW50ZXJDR1JlcXVlc3RUb1JlcXVlc3REYXRhO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9cmVxdWVzdC5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/request.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/sdkMetadata.js":
/*!*********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/sdkMetadata.js ***!
  \*********************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst version = __webpack_require__(/*! ./version.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/version.js\");\n\n/**\n * A builder for the SDK metadata in the options for the SDK initialization.\n *\n * Note: This function is identical to `buildMetadata` in Remix and NextJS and SvelteKit.\n * We don't extract it for bundle size reasons.\n * @see https://github.com/getsentry/sentry-javascript/pull/7404\n * @see https://github.com/getsentry/sentry-javascript/pull/4196\n *\n * If you make changes to this function consider updating the others as well.\n *\n * @param options SDK options object that gets mutated\n * @param names list of package names\n */\nfunction applySdkMetadata(options, name, names = [name], source = 'npm') {\n  const metadata = options._metadata || {};\n\n  if (!metadata.sdk) {\n    metadata.sdk = {\n      name: `sentry.javascript.${name}`,\n      packages: names.map(name => ({\n        name: `${source}:@sentry/${name}`,\n        version: version.SDK_VERSION,\n      })),\n      version: version.SDK_VERSION,\n    };\n  }\n\n  options._metadata = metadata;\n}\n\nexports.applySdkMetadata = applySdkMetadata;\n//# sourceMappingURL=sdkMetadata.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvc2RrTWV0YWRhdGEuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsZ0JBQWdCLG1CQUFPLENBQUMsZ0lBQWM7O0FBRXRDO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsaUNBQWlDLEtBQUs7QUFDdEM7QUFDQSxpQkFBaUIsT0FBTyxXQUFXLEtBQUs7QUFDeEM7QUFDQSxPQUFPO0FBQ1A7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUEsd0JBQXdCO0FBQ3hCIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvc2RrTWV0YWRhdGEuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IHZlcnNpb24gPSByZXF1aXJlKCcuL3ZlcnNpb24uanMnKTtcblxuLyoqXG4gKiBBIGJ1aWxkZXIgZm9yIHRoZSBTREsgbWV0YWRhdGEgaW4gdGhlIG9wdGlvbnMgZm9yIHRoZSBTREsgaW5pdGlhbGl6YXRpb24uXG4gKlxuICogTm90ZTogVGhpcyBmdW5jdGlvbiBpcyBpZGVudGljYWwgdG8gYGJ1aWxkTWV0YWRhdGFgIGluIFJlbWl4IGFuZCBOZXh0SlMgYW5kIFN2ZWx0ZUtpdC5cbiAqIFdlIGRvbid0IGV4dHJhY3QgaXQgZm9yIGJ1bmRsZSBzaXplIHJlYXNvbnMuXG4gKiBAc2VlIGh0dHBzOi8vZ2l0aHViLmNvbS9nZXRzZW50cnkvc2VudHJ5LWphdmFzY3JpcHQvcHVsbC83NDA0XG4gKiBAc2VlIGh0dHBzOi8vZ2l0aHViLmNvbS9nZXRzZW50cnkvc2VudHJ5LWphdmFzY3JpcHQvcHVsbC80MTk2XG4gKlxuICogSWYgeW91IG1ha2UgY2hhbmdlcyB0byB0aGlzIGZ1bmN0aW9uIGNvbnNpZGVyIHVwZGF0aW5nIHRoZSBvdGhlcnMgYXMgd2VsbC5cbiAqXG4gKiBAcGFyYW0gb3B0aW9ucyBTREsgb3B0aW9ucyBvYmplY3QgdGhhdCBnZXRzIG11dGF0ZWRcbiAqIEBwYXJhbSBuYW1lcyBsaXN0IG9mIHBhY2thZ2UgbmFtZXNcbiAqL1xuZnVuY3Rpb24gYXBwbHlTZGtNZXRhZGF0YShvcHRpb25zLCBuYW1lLCBuYW1lcyA9IFtuYW1lXSwgc291cmNlID0gJ25wbScpIHtcbiAgY29uc3QgbWV0YWRhdGEgPSBvcHRpb25zLl9tZXRhZGF0YSB8fCB7fTtcblxuICBpZiAoIW1ldGFkYXRhLnNkaykge1xuICAgIG1ldGFkYXRhLnNkayA9IHtcbiAgICAgIG5hbWU6IGBzZW50cnkuamF2YXNjcmlwdC4ke25hbWV9YCxcbiAgICAgIHBhY2thZ2VzOiBuYW1lcy5tYXAobmFtZSA9PiAoe1xuICAgICAgICBuYW1lOiBgJHtzb3VyY2V9OkBzZW50cnkvJHtuYW1lfWAsXG4gICAgICAgIHZlcnNpb246IHZlcnNpb24uU0RLX1ZFUlNJT04sXG4gICAgICB9KSksXG4gICAgICB2ZXJzaW9uOiB2ZXJzaW9uLlNES19WRVJTSU9OLFxuICAgIH07XG4gIH1cblxuICBvcHRpb25zLl9tZXRhZGF0YSA9IG1ldGFkYXRhO1xufVxuXG5leHBvcnRzLmFwcGx5U2RrTWV0YWRhdGEgPSBhcHBseVNka01ldGFkYXRhO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9c2RrTWV0YWRhdGEuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/sdkMetadata.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/severity.js":
/*!******************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/severity.js ***!
  \******************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n/**\n * Converts a string-based level into a `SeverityLevel`, normalizing it along the way.\n *\n * @param level String representation of desired `SeverityLevel`.\n * @returns The `SeverityLevel` corresponding to the given string, or 'log' if the string isn't a valid level.\n */\nfunction severityLevelFromString(level) {\n  return (\n    level === 'warn' ? 'warning' : ['fatal', 'error', 'warning', 'log', 'info', 'debug'].includes(level) ? level : 'log'\n  ) ;\n}\n\nexports.severityLevelFromString = severityLevelFromString;\n//# sourceMappingURL=severity.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvc2V2ZXJpdHkuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEU7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSwrQkFBK0I7QUFDL0IiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9zZXZlcml0eS5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuLyoqXG4gKiBDb252ZXJ0cyBhIHN0cmluZy1iYXNlZCBsZXZlbCBpbnRvIGEgYFNldmVyaXR5TGV2ZWxgLCBub3JtYWxpemluZyBpdCBhbG9uZyB0aGUgd2F5LlxuICpcbiAqIEBwYXJhbSBsZXZlbCBTdHJpbmcgcmVwcmVzZW50YXRpb24gb2YgZGVzaXJlZCBgU2V2ZXJpdHlMZXZlbGAuXG4gKiBAcmV0dXJucyBUaGUgYFNldmVyaXR5TGV2ZWxgIGNvcnJlc3BvbmRpbmcgdG8gdGhlIGdpdmVuIHN0cmluZywgb3IgJ2xvZycgaWYgdGhlIHN0cmluZyBpc24ndCBhIHZhbGlkIGxldmVsLlxuICovXG5mdW5jdGlvbiBzZXZlcml0eUxldmVsRnJvbVN0cmluZyhsZXZlbCkge1xuICByZXR1cm4gKFxuICAgIGxldmVsID09PSAnd2FybicgPyAnd2FybmluZycgOiBbJ2ZhdGFsJywgJ2Vycm9yJywgJ3dhcm5pbmcnLCAnbG9nJywgJ2luZm8nLCAnZGVidWcnXS5pbmNsdWRlcyhsZXZlbCkgPyBsZXZlbCA6ICdsb2cnXG4gICkgO1xufVxuXG5leHBvcnRzLnNldmVyaXR5TGV2ZWxGcm9tU3RyaW5nID0gc2V2ZXJpdHlMZXZlbEZyb21TdHJpbmc7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1zZXZlcml0eS5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/severity.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanOnScope.js":
/*!*********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanOnScope.js ***!
  \*********************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst object = __webpack_require__(/*! ./object.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/object.js\");\n\nconst SCOPE_SPAN_FIELD = '_sentrySpan';\n\n/**\n * Set the active span for a given scope.\n * NOTE: This should NOT be used directly, but is only used internally by the trace methods.\n */\nfunction _setSpanForScope(scope, span) {\n  if (span) {\n    object.addNonEnumerableProperty(scope , SCOPE_SPAN_FIELD, span);\n  } else {\n    // eslint-disable-next-line @typescript-eslint/no-dynamic-delete\n    delete (scope )[SCOPE_SPAN_FIELD];\n  }\n}\n\n/**\n * Get the active span for a given scope.\n * NOTE: This should NOT be used directly, but is only used internally by the trace methods.\n */\nfunction _getSpanForScope(scope) {\n  return scope[SCOPE_SPAN_FIELD];\n}\n\nexports._getSpanForScope = _getSpanForScope;\nexports._setSpanForScope = _setSpanForScope;\n//# sourceMappingURL=spanOnScope.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvc3Bhbk9uU2NvcGUuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsZUFBZSxtQkFBTyxDQUFDLDhIQUFhOztBQUVwQzs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLElBQUk7QUFDSjtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSx3QkFBd0I7QUFDeEIsd0JBQXdCO0FBQ3hCIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvc3Bhbk9uU2NvcGUuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IG9iamVjdCA9IHJlcXVpcmUoJy4vb2JqZWN0LmpzJyk7XG5cbmNvbnN0IFNDT1BFX1NQQU5fRklFTEQgPSAnX3NlbnRyeVNwYW4nO1xuXG4vKipcbiAqIFNldCB0aGUgYWN0aXZlIHNwYW4gZm9yIGEgZ2l2ZW4gc2NvcGUuXG4gKiBOT1RFOiBUaGlzIHNob3VsZCBOT1QgYmUgdXNlZCBkaXJlY3RseSwgYnV0IGlzIG9ubHkgdXNlZCBpbnRlcm5hbGx5IGJ5IHRoZSB0cmFjZSBtZXRob2RzLlxuICovXG5mdW5jdGlvbiBfc2V0U3BhbkZvclNjb3BlKHNjb3BlLCBzcGFuKSB7XG4gIGlmIChzcGFuKSB7XG4gICAgb2JqZWN0LmFkZE5vbkVudW1lcmFibGVQcm9wZXJ0eShzY29wZSAsIFNDT1BFX1NQQU5fRklFTEQsIHNwYW4pO1xuICB9IGVsc2Uge1xuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tZHluYW1pYy1kZWxldGVcbiAgICBkZWxldGUgKHNjb3BlIClbU0NPUEVfU1BBTl9GSUVMRF07XG4gIH1cbn1cblxuLyoqXG4gKiBHZXQgdGhlIGFjdGl2ZSBzcGFuIGZvciBhIGdpdmVuIHNjb3BlLlxuICogTk9URTogVGhpcyBzaG91bGQgTk9UIGJlIHVzZWQgZGlyZWN0bHksIGJ1dCBpcyBvbmx5IHVzZWQgaW50ZXJuYWxseSBieSB0aGUgdHJhY2UgbWV0aG9kcy5cbiAqL1xuZnVuY3Rpb24gX2dldFNwYW5Gb3JTY29wZShzY29wZSkge1xuICByZXR1cm4gc2NvcGVbU0NPUEVfU1BBTl9GSUVMRF07XG59XG5cbmV4cG9ydHMuX2dldFNwYW5Gb3JTY29wZSA9IF9nZXRTcGFuRm9yU2NvcGU7XG5leHBvcnRzLl9zZXRTcGFuRm9yU2NvcGUgPSBfc2V0U3BhbkZvclNjb3BlO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9c3Bhbk9uU2NvcGUuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanOnScope.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanUtils.js":
/*!*******************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanUtils.js ***!
  \*******************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst index = __webpack_require__(/*! ../asyncContext/index.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/asyncContext/index.js\");\nconst carrier = __webpack_require__(/*! ../carrier.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/carrier.js\");\nconst currentScopes = __webpack_require__(/*! ../currentScopes.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst semanticAttributes = __webpack_require__(/*! ../semanticAttributes.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/semanticAttributes.js\");\nconst spanstatus = __webpack_require__(/*! ../tracing/spanstatus.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/spanstatus.js\");\nconst utils = __webpack_require__(/*! ../tracing/utils.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/utils.js\");\nconst object = __webpack_require__(/*! ./object.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/object.js\");\nconst propagationContext = __webpack_require__(/*! ./propagationContext.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/propagationContext.js\");\nconst time = __webpack_require__(/*! ./time.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/time.js\");\nconst tracing = __webpack_require__(/*! ./tracing.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/tracing.js\");\nconst debugLogger = __webpack_require__(/*! ./debug-logger.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst spanOnScope = __webpack_require__(/*! ./spanOnScope.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanOnScope.js\");\n\n// These are aligned with OpenTelemetry trace flags\nconst TRACE_FLAG_NONE = 0x0;\nconst TRACE_FLAG_SAMPLED = 0x1;\n\nlet hasShownSpanDropWarning = false;\n\n/**\n * Convert a span to a trace context, which can be sent as the `trace` context in an event.\n * By default, this will only include trace_id, span_id & parent_span_id.\n * If `includeAllData` is true, it will also include data, op, status & origin.\n */\nfunction spanToTransactionTraceContext(span) {\n  const { spanId: span_id, traceId: trace_id } = span.spanContext();\n  const { data, op, parent_span_id, status, origin, links } = spanToJSON(span);\n\n  return {\n    parent_span_id,\n    span_id,\n    trace_id,\n    data,\n    op,\n    status,\n    origin,\n    links,\n  };\n}\n\n/**\n * Convert a span to a trace context, which can be sent as the `trace` context in a non-transaction event.\n */\nfunction spanToTraceContext(span) {\n  const { spanId, traceId: trace_id, isRemote } = span.spanContext();\n\n  // If the span is remote, we use a random/virtual span as span_id to the trace context,\n  // and the remote span as parent_span_id\n  const parent_span_id = isRemote ? spanId : spanToJSON(span).parent_span_id;\n  const scope = utils.getCapturedScopesOnSpan(span).scope;\n\n  const span_id = isRemote ? scope?.getPropagationContext().propagationSpanId || propagationContext.generateSpanId() : spanId;\n\n  return {\n    parent_span_id,\n    span_id,\n    trace_id,\n  };\n}\n\n/**\n * Convert a Span to a Sentry trace header.\n */\nfunction spanToTraceHeader(span) {\n  const { traceId, spanId } = span.spanContext();\n  const sampled = spanIsSampled(span);\n  return tracing.generateSentryTraceHeader(traceId, spanId, sampled);\n}\n\n/**\n *  Converts the span links array to a flattened version to be sent within an envelope.\n *\n *  If the links array is empty, it returns `undefined` so the empty value can be dropped before it's sent.\n */\nfunction convertSpanLinksForEnvelope(links) {\n  if (links && links.length > 0) {\n    return links.map(({ context: { spanId, traceId, traceFlags, ...restContext }, attributes }) => ({\n      span_id: spanId,\n      trace_id: traceId,\n      sampled: traceFlags === TRACE_FLAG_SAMPLED,\n      attributes,\n      ...restContext,\n    }));\n  } else {\n    return undefined;\n  }\n}\n\n/**\n * Convert a span time input into a timestamp in seconds.\n */\nfunction spanTimeInputToSeconds(input) {\n  if (typeof input === 'number') {\n    return ensureTimestampInSeconds(input);\n  }\n\n  if (Array.isArray(input)) {\n    // See {@link HrTime} for the array-based time format\n    return input[0] + input[1] / 1e9;\n  }\n\n  if (input instanceof Date) {\n    return ensureTimestampInSeconds(input.getTime());\n  }\n\n  return time.timestampInSeconds();\n}\n\n/**\n * Converts a timestamp to second, if it was in milliseconds, or keeps it as second.\n */\nfunction ensureTimestampInSeconds(timestamp) {\n  const isMs = timestamp > 9999999999;\n  return isMs ? timestamp / 1000 : timestamp;\n}\n\n/**\n * Convert a span to a JSON representation.\n */\n// Note: Because of this, we currently have a circular type dependency (which we opted out of in package.json).\n// This is not avoidable as we need `spanToJSON` in `spanUtils.ts`, which in turn is needed by `span.ts` for backwards compatibility.\n// And `spanToJSON` needs the Span class from `span.ts` to check here.\nfunction spanToJSON(span) {\n  if (spanIsSentrySpan(span)) {\n    return span.getSpanJSON();\n  }\n\n  const { spanId: span_id, traceId: trace_id } = span.spanContext();\n\n  // Handle a span from @opentelemetry/sdk-base-trace's `Span` class\n  if (spanIsOpenTelemetrySdkTraceBaseSpan(span)) {\n    const { attributes, startTime, name, endTime, status, links } = span;\n\n    // In preparation for the next major of OpenTelemetry, we want to support\n    // looking up the parent span id according to the new API\n    // In OTel v1, the parent span id is accessed as `parentSpanId`\n    // In OTel v2, the parent span id is accessed as `spanId` on the `parentSpanContext`\n    const parentSpanId =\n      'parentSpanId' in span\n        ? span.parentSpanId\n        : 'parentSpanContext' in span\n          ? (span.parentSpanContext )?.spanId\n          : undefined;\n\n    return {\n      span_id,\n      trace_id,\n      data: attributes,\n      description: name,\n      parent_span_id: parentSpanId,\n      start_timestamp: spanTimeInputToSeconds(startTime),\n      // This is [0,0] by default in OTEL, in which case we want to interpret this as no end time\n      timestamp: spanTimeInputToSeconds(endTime) || undefined,\n      status: getStatusMessage(status),\n      op: attributes[semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_OP],\n      origin: attributes[semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_ORIGIN] ,\n      links: convertSpanLinksForEnvelope(links),\n    };\n  }\n\n  // Finally, at least we have `spanContext()`....\n  // This should not actually happen in reality, but we need to handle it for type safety.\n  return {\n    span_id,\n    trace_id,\n    start_timestamp: 0,\n    data: {},\n  };\n}\n\nfunction spanIsOpenTelemetrySdkTraceBaseSpan(span) {\n  const castSpan = span ;\n  return !!castSpan.attributes && !!castSpan.startTime && !!castSpan.name && !!castSpan.endTime && !!castSpan.status;\n}\n\n/** Exported only for tests. */\n\n/**\n * Sadly, due to circular dependency checks we cannot actually import the Span class here and check for instanceof.\n * :( So instead we approximate this by checking if it has the `getSpanJSON` method.\n */\nfunction spanIsSentrySpan(span) {\n  return typeof (span ).getSpanJSON === 'function';\n}\n\n/**\n * Returns true if a span is sampled.\n * In most cases, you should just use `span.isRecording()` instead.\n * However, this has a slightly different semantic, as it also returns false if the span is finished.\n * So in the case where this distinction is important, use this method.\n */\nfunction spanIsSampled(span) {\n  // We align our trace flags with the ones OpenTelemetry use\n  // So we also check for sampled the same way they do.\n  const { traceFlags } = span.spanContext();\n  return traceFlags === TRACE_FLAG_SAMPLED;\n}\n\n/** Get the status message to use for a JSON representation of a span. */\nfunction getStatusMessage(status) {\n  if (!status || status.code === spanstatus.SPAN_STATUS_UNSET) {\n    return undefined;\n  }\n\n  if (status.code === spanstatus.SPAN_STATUS_OK) {\n    return 'ok';\n  }\n\n  return status.message || 'unknown_error';\n}\n\nconst CHILD_SPANS_FIELD = '_sentryChildSpans';\nconst ROOT_SPAN_FIELD = '_sentryRootSpan';\n\n/**\n * Adds an opaque child span reference to a span.\n */\nfunction addChildSpanToSpan(span, childSpan) {\n  // We store the root span reference on the child span\n  // We need this for `getRootSpan()` to work\n  const rootSpan = span[ROOT_SPAN_FIELD] || span;\n  object.addNonEnumerableProperty(childSpan , ROOT_SPAN_FIELD, rootSpan);\n\n  // We store a list of child spans on the parent span\n  // We need this for `getSpanDescendants()` to work\n  if (span[CHILD_SPANS_FIELD]) {\n    span[CHILD_SPANS_FIELD].add(childSpan);\n  } else {\n    object.addNonEnumerableProperty(span, CHILD_SPANS_FIELD, new Set([childSpan]));\n  }\n}\n\n/** This is only used internally by Idle Spans. */\nfunction removeChildSpanFromSpan(span, childSpan) {\n  if (span[CHILD_SPANS_FIELD]) {\n    span[CHILD_SPANS_FIELD].delete(childSpan);\n  }\n}\n\n/**\n * Returns an array of the given span and all of its descendants.\n */\nfunction getSpanDescendants(span) {\n  const resultSet = new Set();\n\n  function addSpanChildren(span) {\n    // This exit condition is required to not infinitely loop in case of a circular dependency.\n    if (resultSet.has(span)) {\n      return;\n      // We want to ignore unsampled spans (e.g. non recording spans)\n    } else if (spanIsSampled(span)) {\n      resultSet.add(span);\n      const childSpans = span[CHILD_SPANS_FIELD] ? Array.from(span[CHILD_SPANS_FIELD]) : [];\n      for (const childSpan of childSpans) {\n        addSpanChildren(childSpan);\n      }\n    }\n  }\n\n  addSpanChildren(span);\n\n  return Array.from(resultSet);\n}\n\n/**\n * Returns the root span of a given span.\n */\nfunction getRootSpan(span) {\n  return span[ROOT_SPAN_FIELD] || span;\n}\n\n/**\n * Returns the currently active span.\n */\nfunction getActiveSpan() {\n  const carrier$1 = carrier.getMainCarrier();\n  const acs = index.getAsyncContextStrategy(carrier$1);\n  if (acs.getActiveSpan) {\n    return acs.getActiveSpan();\n  }\n\n  return spanOnScope._getSpanForScope(currentScopes.getCurrentScope());\n}\n\n/**\n * Logs a warning once if `beforeSendSpan` is used to drop spans.\n */\nfunction showSpanDropWarning() {\n  if (!hasShownSpanDropWarning) {\n    debugLogger.consoleSandbox(() => {\n      // eslint-disable-next-line no-console\n      console.warn(\n        '[Sentry] Returning null from `beforeSendSpan` is disallowed. To drop certain spans, configure the respective integrations directly.',\n      );\n    });\n    hasShownSpanDropWarning = true;\n  }\n}\n\n/**\n * Updates the name of the given span and ensures that the span name is not\n * overwritten by the Sentry SDK.\n *\n * Use this function instead of `span.updateName()` if you want to make sure that\n * your name is kept. For some spans, for example root `http.server` spans the\n * Sentry SDK would otherwise overwrite the span name with a high-quality name\n * it infers when the span ends.\n *\n * Use this function in server code or when your span is started on the server\n * and on the client (browser). If you only update a span name on the client,\n * you can also use `span.updateName()` the SDK does not overwrite the name.\n *\n * @param span - The span to update the name of.\n * @param name - The name to set on the span.\n */\nfunction updateSpanName(span, name) {\n  span.updateName(name);\n  span.setAttributes({\n    [semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_SOURCE]: 'custom',\n    [semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_CUSTOM_SPAN_NAME]: name,\n  });\n}\n\nexports.TRACE_FLAG_NONE = TRACE_FLAG_NONE;\nexports.TRACE_FLAG_SAMPLED = TRACE_FLAG_SAMPLED;\nexports.addChildSpanToSpan = addChildSpanToSpan;\nexports.convertSpanLinksForEnvelope = convertSpanLinksForEnvelope;\nexports.getActiveSpan = getActiveSpan;\nexports.getRootSpan = getRootSpan;\nexports.getSpanDescendants = getSpanDescendants;\nexports.getStatusMessage = getStatusMessage;\nexports.removeChildSpanFromSpan = removeChildSpanFromSpan;\nexports.showSpanDropWarning = showSpanDropWarning;\nexports.spanIsSampled = spanIsSampled;\nexports.spanTimeInputToSeconds = spanTimeInputToSeconds;\nexports.spanToJSON = spanToJSON;\nexports.spanToTraceContext = spanToTraceContext;\nexports.spanToTraceHeader = spanToTraceHeader;\nexports.spanToTransactionTraceContext = spanToTransactionTraceContext;\nexports.updateSpanName = updateSpanName;\n//# sourceMappingURL=spanUtils.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvc3BhblV0aWxzLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLGNBQWMsbUJBQU8sQ0FBQyxpSkFBMEI7QUFDaEQsZ0JBQWdCLG1CQUFPLENBQUMsMkhBQWU7QUFDdkMsc0JBQXNCLG1CQUFPLENBQUMsdUlBQXFCO0FBQ25ELDJCQUEyQixtQkFBTyxDQUFDLGlKQUEwQjtBQUM3RCxtQkFBbUIsbUJBQU8sQ0FBQyxpSkFBMEI7QUFDckQsY0FBYyxtQkFBTyxDQUFDLHVJQUFxQjtBQUMzQyxlQUFlLG1CQUFPLENBQUMsOEhBQWE7QUFDcEMsMkJBQTJCLG1CQUFPLENBQUMsc0pBQXlCO0FBQzVELGFBQWEsbUJBQU8sQ0FBQywwSEFBVztBQUNoQyxnQkFBZ0IsbUJBQU8sQ0FBQyxnSUFBYztBQUN0QyxvQkFBb0IsbUJBQU8sQ0FBQywwSUFBbUI7QUFDL0Msb0JBQW9CLG1CQUFPLENBQUMsd0lBQWtCOztBQUU5QztBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsVUFBVSxxQ0FBcUM7QUFDL0MsVUFBVSxrREFBa0Q7O0FBRTVEO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQSxVQUFVLHNDQUFzQzs7QUFFaEQ7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsVUFBVSxrQkFBa0I7QUFDNUI7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0Esd0JBQXdCLFdBQVcsNkNBQTZDLGNBQWM7QUFDOUY7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEtBQUs7QUFDTCxJQUFJO0FBQ0o7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0EsWUFBWSxjQUFjO0FBQzFCO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsVUFBVSxxQ0FBcUM7O0FBRS9DO0FBQ0E7QUFDQSxZQUFZLHNEQUFzRDs7QUFFbEU7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFlBQVk7QUFDWjtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFVBQVUsYUFBYTtBQUN2QjtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsSUFBSTtBQUNKO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsTUFBTTtBQUNOO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsS0FBSztBQUNMO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxHQUFHO0FBQ0g7O0FBRUEsdUJBQXVCO0FBQ3ZCLDBCQUEwQjtBQUMxQiwwQkFBMEI7QUFDMUIsbUNBQW1DO0FBQ25DLHFCQUFxQjtBQUNyQixtQkFBbUI7QUFDbkIsMEJBQTBCO0FBQzFCLHdCQUF3QjtBQUN4QiwrQkFBK0I7QUFDL0IsMkJBQTJCO0FBQzNCLHFCQUFxQjtBQUNyQiw4QkFBOEI7QUFDOUIsa0JBQWtCO0FBQ2xCLDBCQUEwQjtBQUMxQix5QkFBeUI7QUFDekIscUNBQXFDO0FBQ3JDLHNCQUFzQjtBQUN0QiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3V0aWxzL3NwYW5VdGlscy5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgaW5kZXggPSByZXF1aXJlKCcuLi9hc3luY0NvbnRleHQvaW5kZXguanMnKTtcbmNvbnN0IGNhcnJpZXIgPSByZXF1aXJlKCcuLi9jYXJyaWVyLmpzJyk7XG5jb25zdCBjdXJyZW50U2NvcGVzID0gcmVxdWlyZSgnLi4vY3VycmVudFNjb3Blcy5qcycpO1xuY29uc3Qgc2VtYW50aWNBdHRyaWJ1dGVzID0gcmVxdWlyZSgnLi4vc2VtYW50aWNBdHRyaWJ1dGVzLmpzJyk7XG5jb25zdCBzcGFuc3RhdHVzID0gcmVxdWlyZSgnLi4vdHJhY2luZy9zcGFuc3RhdHVzLmpzJyk7XG5jb25zdCB1dGlscyA9IHJlcXVpcmUoJy4uL3RyYWNpbmcvdXRpbHMuanMnKTtcbmNvbnN0IG9iamVjdCA9IHJlcXVpcmUoJy4vb2JqZWN0LmpzJyk7XG5jb25zdCBwcm9wYWdhdGlvbkNvbnRleHQgPSByZXF1aXJlKCcuL3Byb3BhZ2F0aW9uQ29udGV4dC5qcycpO1xuY29uc3QgdGltZSA9IHJlcXVpcmUoJy4vdGltZS5qcycpO1xuY29uc3QgdHJhY2luZyA9IHJlcXVpcmUoJy4vdHJhY2luZy5qcycpO1xuY29uc3QgZGVidWdMb2dnZXIgPSByZXF1aXJlKCcuL2RlYnVnLWxvZ2dlci5qcycpO1xuY29uc3Qgc3Bhbk9uU2NvcGUgPSByZXF1aXJlKCcuL3NwYW5PblNjb3BlLmpzJyk7XG5cbi8vIFRoZXNlIGFyZSBhbGlnbmVkIHdpdGggT3BlblRlbGVtZXRyeSB0cmFjZSBmbGFnc1xuY29uc3QgVFJBQ0VfRkxBR19OT05FID0gMHgwO1xuY29uc3QgVFJBQ0VfRkxBR19TQU1QTEVEID0gMHgxO1xuXG5sZXQgaGFzU2hvd25TcGFuRHJvcFdhcm5pbmcgPSBmYWxzZTtcblxuLyoqXG4gKiBDb252ZXJ0IGEgc3BhbiB0byBhIHRyYWNlIGNvbnRleHQsIHdoaWNoIGNhbiBiZSBzZW50IGFzIHRoZSBgdHJhY2VgIGNvbnRleHQgaW4gYW4gZXZlbnQuXG4gKiBCeSBkZWZhdWx0LCB0aGlzIHdpbGwgb25seSBpbmNsdWRlIHRyYWNlX2lkLCBzcGFuX2lkICYgcGFyZW50X3NwYW5faWQuXG4gKiBJZiBgaW5jbHVkZUFsbERhdGFgIGlzIHRydWUsIGl0IHdpbGwgYWxzbyBpbmNsdWRlIGRhdGEsIG9wLCBzdGF0dXMgJiBvcmlnaW4uXG4gKi9cbmZ1bmN0aW9uIHNwYW5Ub1RyYW5zYWN0aW9uVHJhY2VDb250ZXh0KHNwYW4pIHtcbiAgY29uc3QgeyBzcGFuSWQ6IHNwYW5faWQsIHRyYWNlSWQ6IHRyYWNlX2lkIH0gPSBzcGFuLnNwYW5Db250ZXh0KCk7XG4gIGNvbnN0IHsgZGF0YSwgb3AsIHBhcmVudF9zcGFuX2lkLCBzdGF0dXMsIG9yaWdpbiwgbGlua3MgfSA9IHNwYW5Ub0pTT04oc3Bhbik7XG5cbiAgcmV0dXJuIHtcbiAgICBwYXJlbnRfc3Bhbl9pZCxcbiAgICBzcGFuX2lkLFxuICAgIHRyYWNlX2lkLFxuICAgIGRhdGEsXG4gICAgb3AsXG4gICAgc3RhdHVzLFxuICAgIG9yaWdpbixcbiAgICBsaW5rcyxcbiAgfTtcbn1cblxuLyoqXG4gKiBDb252ZXJ0IGEgc3BhbiB0byBhIHRyYWNlIGNvbnRleHQsIHdoaWNoIGNhbiBiZSBzZW50IGFzIHRoZSBgdHJhY2VgIGNvbnRleHQgaW4gYSBub24tdHJhbnNhY3Rpb24gZXZlbnQuXG4gKi9cbmZ1bmN0aW9uIHNwYW5Ub1RyYWNlQ29udGV4dChzcGFuKSB7XG4gIGNvbnN0IHsgc3BhbklkLCB0cmFjZUlkOiB0cmFjZV9pZCwgaXNSZW1vdGUgfSA9IHNwYW4uc3BhbkNvbnRleHQoKTtcblxuICAvLyBJZiB0aGUgc3BhbiBpcyByZW1vdGUsIHdlIHVzZSBhIHJhbmRvbS92aXJ0dWFsIHNwYW4gYXMgc3Bhbl9pZCB0byB0aGUgdHJhY2UgY29udGV4dCxcbiAgLy8gYW5kIHRoZSByZW1vdGUgc3BhbiBhcyBwYXJlbnRfc3Bhbl9pZFxuICBjb25zdCBwYXJlbnRfc3Bhbl9pZCA9IGlzUmVtb3RlID8gc3BhbklkIDogc3BhblRvSlNPTihzcGFuKS5wYXJlbnRfc3Bhbl9pZDtcbiAgY29uc3Qgc2NvcGUgPSB1dGlscy5nZXRDYXB0dXJlZFNjb3Blc09uU3BhbihzcGFuKS5zY29wZTtcblxuICBjb25zdCBzcGFuX2lkID0gaXNSZW1vdGUgPyBzY29wZT8uZ2V0UHJvcGFnYXRpb25Db250ZXh0KCkucHJvcGFnYXRpb25TcGFuSWQgfHwgcHJvcGFnYXRpb25Db250ZXh0LmdlbmVyYXRlU3BhbklkKCkgOiBzcGFuSWQ7XG5cbiAgcmV0dXJuIHtcbiAgICBwYXJlbnRfc3Bhbl9pZCxcbiAgICBzcGFuX2lkLFxuICAgIHRyYWNlX2lkLFxuICB9O1xufVxuXG4vKipcbiAqIENvbnZlcnQgYSBTcGFuIHRvIGEgU2VudHJ5IHRyYWNlIGhlYWRlci5cbiAqL1xuZnVuY3Rpb24gc3BhblRvVHJhY2VIZWFkZXIoc3Bhbikge1xuICBjb25zdCB7IHRyYWNlSWQsIHNwYW5JZCB9ID0gc3Bhbi5zcGFuQ29udGV4dCgpO1xuICBjb25zdCBzYW1wbGVkID0gc3BhbklzU2FtcGxlZChzcGFuKTtcbiAgcmV0dXJuIHRyYWNpbmcuZ2VuZXJhdGVTZW50cnlUcmFjZUhlYWRlcih0cmFjZUlkLCBzcGFuSWQsIHNhbXBsZWQpO1xufVxuXG4vKipcbiAqICBDb252ZXJ0cyB0aGUgc3BhbiBsaW5rcyBhcnJheSB0byBhIGZsYXR0ZW5lZCB2ZXJzaW9uIHRvIGJlIHNlbnQgd2l0aGluIGFuIGVudmVsb3BlLlxuICpcbiAqICBJZiB0aGUgbGlua3MgYXJyYXkgaXMgZW1wdHksIGl0IHJldHVybnMgYHVuZGVmaW5lZGAgc28gdGhlIGVtcHR5IHZhbHVlIGNhbiBiZSBkcm9wcGVkIGJlZm9yZSBpdCdzIHNlbnQuXG4gKi9cbmZ1bmN0aW9uIGNvbnZlcnRTcGFuTGlua3NGb3JFbnZlbG9wZShsaW5rcykge1xuICBpZiAobGlua3MgJiYgbGlua3MubGVuZ3RoID4gMCkge1xuICAgIHJldHVybiBsaW5rcy5tYXAoKHsgY29udGV4dDogeyBzcGFuSWQsIHRyYWNlSWQsIHRyYWNlRmxhZ3MsIC4uLnJlc3RDb250ZXh0IH0sIGF0dHJpYnV0ZXMgfSkgPT4gKHtcbiAgICAgIHNwYW5faWQ6IHNwYW5JZCxcbiAgICAgIHRyYWNlX2lkOiB0cmFjZUlkLFxuICAgICAgc2FtcGxlZDogdHJhY2VGbGFncyA9PT0gVFJBQ0VfRkxBR19TQU1QTEVELFxuICAgICAgYXR0cmlidXRlcyxcbiAgICAgIC4uLnJlc3RDb250ZXh0LFxuICAgIH0pKTtcbiAgfSBlbHNlIHtcbiAgICByZXR1cm4gdW5kZWZpbmVkO1xuICB9XG59XG5cbi8qKlxuICogQ29udmVydCBhIHNwYW4gdGltZSBpbnB1dCBpbnRvIGEgdGltZXN0YW1wIGluIHNlY29uZHMuXG4gKi9cbmZ1bmN0aW9uIHNwYW5UaW1lSW5wdXRUb1NlY29uZHMoaW5wdXQpIHtcbiAgaWYgKHR5cGVvZiBpbnB1dCA9PT0gJ251bWJlcicpIHtcbiAgICByZXR1cm4gZW5zdXJlVGltZXN0YW1wSW5TZWNvbmRzKGlucHV0KTtcbiAgfVxuXG4gIGlmIChBcnJheS5pc0FycmF5KGlucHV0KSkge1xuICAgIC8vIFNlZSB7QGxpbmsgSHJUaW1lfSBmb3IgdGhlIGFycmF5LWJhc2VkIHRpbWUgZm9ybWF0XG4gICAgcmV0dXJuIGlucHV0WzBdICsgaW5wdXRbMV0gLyAxZTk7XG4gIH1cblxuICBpZiAoaW5wdXQgaW5zdGFuY2VvZiBEYXRlKSB7XG4gICAgcmV0dXJuIGVuc3VyZVRpbWVzdGFtcEluU2Vjb25kcyhpbnB1dC5nZXRUaW1lKCkpO1xuICB9XG5cbiAgcmV0dXJuIHRpbWUudGltZXN0YW1wSW5TZWNvbmRzKCk7XG59XG5cbi8qKlxuICogQ29udmVydHMgYSB0aW1lc3RhbXAgdG8gc2Vjb25kLCBpZiBpdCB3YXMgaW4gbWlsbGlzZWNvbmRzLCBvciBrZWVwcyBpdCBhcyBzZWNvbmQuXG4gKi9cbmZ1bmN0aW9uIGVuc3VyZVRpbWVzdGFtcEluU2Vjb25kcyh0aW1lc3RhbXApIHtcbiAgY29uc3QgaXNNcyA9IHRpbWVzdGFtcCA+IDk5OTk5OTk5OTk7XG4gIHJldHVybiBpc01zID8gdGltZXN0YW1wIC8gMTAwMCA6IHRpbWVzdGFtcDtcbn1cblxuLyoqXG4gKiBDb252ZXJ0IGEgc3BhbiB0byBhIEpTT04gcmVwcmVzZW50YXRpb24uXG4gKi9cbi8vIE5vdGU6IEJlY2F1c2Ugb2YgdGhpcywgd2UgY3VycmVudGx5IGhhdmUgYSBjaXJjdWxhciB0eXBlIGRlcGVuZGVuY3kgKHdoaWNoIHdlIG9wdGVkIG91dCBvZiBpbiBwYWNrYWdlLmpzb24pLlxuLy8gVGhpcyBpcyBub3QgYXZvaWRhYmxlIGFzIHdlIG5lZWQgYHNwYW5Ub0pTT05gIGluIGBzcGFuVXRpbHMudHNgLCB3aGljaCBpbiB0dXJuIGlzIG5lZWRlZCBieSBgc3Bhbi50c2AgZm9yIGJhY2t3YXJkcyBjb21wYXRpYmlsaXR5LlxuLy8gQW5kIGBzcGFuVG9KU09OYCBuZWVkcyB0aGUgU3BhbiBjbGFzcyBmcm9tIGBzcGFuLnRzYCB0byBjaGVjayBoZXJlLlxuZnVuY3Rpb24gc3BhblRvSlNPTihzcGFuKSB7XG4gIGlmIChzcGFuSXNTZW50cnlTcGFuKHNwYW4pKSB7XG4gICAgcmV0dXJuIHNwYW4uZ2V0U3BhbkpTT04oKTtcbiAgfVxuXG4gIGNvbnN0IHsgc3BhbklkOiBzcGFuX2lkLCB0cmFjZUlkOiB0cmFjZV9pZCB9ID0gc3Bhbi5zcGFuQ29udGV4dCgpO1xuXG4gIC8vIEhhbmRsZSBhIHNwYW4gZnJvbSBAb3BlbnRlbGVtZXRyeS9zZGstYmFzZS10cmFjZSdzIGBTcGFuYCBjbGFzc1xuICBpZiAoc3BhbklzT3BlblRlbGVtZXRyeVNka1RyYWNlQmFzZVNwYW4oc3BhbikpIHtcbiAgICBjb25zdCB7IGF0dHJpYnV0ZXMsIHN0YXJ0VGltZSwgbmFtZSwgZW5kVGltZSwgc3RhdHVzLCBsaW5rcyB9ID0gc3BhbjtcblxuICAgIC8vIEluIHByZXBhcmF0aW9uIGZvciB0aGUgbmV4dCBtYWpvciBvZiBPcGVuVGVsZW1ldHJ5LCB3ZSB3YW50IHRvIHN1cHBvcnRcbiAgICAvLyBsb29raW5nIHVwIHRoZSBwYXJlbnQgc3BhbiBpZCBhY2NvcmRpbmcgdG8gdGhlIG5ldyBBUElcbiAgICAvLyBJbiBPVGVsIHYxLCB0aGUgcGFyZW50IHNwYW4gaWQgaXMgYWNjZXNzZWQgYXMgYHBhcmVudFNwYW5JZGBcbiAgICAvLyBJbiBPVGVsIHYyLCB0aGUgcGFyZW50IHNwYW4gaWQgaXMgYWNjZXNzZWQgYXMgYHNwYW5JZGAgb24gdGhlIGBwYXJlbnRTcGFuQ29udGV4dGBcbiAgICBjb25zdCBwYXJlbnRTcGFuSWQgPVxuICAgICAgJ3BhcmVudFNwYW5JZCcgaW4gc3BhblxuICAgICAgICA/IHNwYW4ucGFyZW50U3BhbklkXG4gICAgICAgIDogJ3BhcmVudFNwYW5Db250ZXh0JyBpbiBzcGFuXG4gICAgICAgICAgPyAoc3Bhbi5wYXJlbnRTcGFuQ29udGV4dCApPy5zcGFuSWRcbiAgICAgICAgICA6IHVuZGVmaW5lZDtcblxuICAgIHJldHVybiB7XG4gICAgICBzcGFuX2lkLFxuICAgICAgdHJhY2VfaWQsXG4gICAgICBkYXRhOiBhdHRyaWJ1dGVzLFxuICAgICAgZGVzY3JpcHRpb246IG5hbWUsXG4gICAgICBwYXJlbnRfc3Bhbl9pZDogcGFyZW50U3BhbklkLFxuICAgICAgc3RhcnRfdGltZXN0YW1wOiBzcGFuVGltZUlucHV0VG9TZWNvbmRzKHN0YXJ0VGltZSksXG4gICAgICAvLyBUaGlzIGlzIFswLDBdIGJ5IGRlZmF1bHQgaW4gT1RFTCwgaW4gd2hpY2ggY2FzZSB3ZSB3YW50IHRvIGludGVycHJldCB0aGlzIGFzIG5vIGVuZCB0aW1lXG4gICAgICB0aW1lc3RhbXA6IHNwYW5UaW1lSW5wdXRUb1NlY29uZHMoZW5kVGltZSkgfHwgdW5kZWZpbmVkLFxuICAgICAgc3RhdHVzOiBnZXRTdGF0dXNNZXNzYWdlKHN0YXR1cyksXG4gICAgICBvcDogYXR0cmlidXRlc1tzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9PUF0sXG4gICAgICBvcmlnaW46IGF0dHJpYnV0ZXNbc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfT1JJR0lOXSAsXG4gICAgICBsaW5rczogY29udmVydFNwYW5MaW5rc0ZvckVudmVsb3BlKGxpbmtzKSxcbiAgICB9O1xuICB9XG5cbiAgLy8gRmluYWxseSwgYXQgbGVhc3Qgd2UgaGF2ZSBgc3BhbkNvbnRleHQoKWAuLi4uXG4gIC8vIFRoaXMgc2hvdWxkIG5vdCBhY3R1YWxseSBoYXBwZW4gaW4gcmVhbGl0eSwgYnV0IHdlIG5lZWQgdG8gaGFuZGxlIGl0IGZvciB0eXBlIHNhZmV0eS5cbiAgcmV0dXJuIHtcbiAgICBzcGFuX2lkLFxuICAgIHRyYWNlX2lkLFxuICAgIHN0YXJ0X3RpbWVzdGFtcDogMCxcbiAgICBkYXRhOiB7fSxcbiAgfTtcbn1cblxuZnVuY3Rpb24gc3BhbklzT3BlblRlbGVtZXRyeVNka1RyYWNlQmFzZVNwYW4oc3Bhbikge1xuICBjb25zdCBjYXN0U3BhbiA9IHNwYW4gO1xuICByZXR1cm4gISFjYXN0U3Bhbi5hdHRyaWJ1dGVzICYmICEhY2FzdFNwYW4uc3RhcnRUaW1lICYmICEhY2FzdFNwYW4ubmFtZSAmJiAhIWNhc3RTcGFuLmVuZFRpbWUgJiYgISFjYXN0U3Bhbi5zdGF0dXM7XG59XG5cbi8qKiBFeHBvcnRlZCBvbmx5IGZvciB0ZXN0cy4gKi9cblxuLyoqXG4gKiBTYWRseSwgZHVlIHRvIGNpcmN1bGFyIGRlcGVuZGVuY3kgY2hlY2tzIHdlIGNhbm5vdCBhY3R1YWxseSBpbXBvcnQgdGhlIFNwYW4gY2xhc3MgaGVyZSBhbmQgY2hlY2sgZm9yIGluc3RhbmNlb2YuXG4gKiA6KCBTbyBpbnN0ZWFkIHdlIGFwcHJveGltYXRlIHRoaXMgYnkgY2hlY2tpbmcgaWYgaXQgaGFzIHRoZSBgZ2V0U3BhbkpTT05gIG1ldGhvZC5cbiAqL1xuZnVuY3Rpb24gc3BhbklzU2VudHJ5U3BhbihzcGFuKSB7XG4gIHJldHVybiB0eXBlb2YgKHNwYW4gKS5nZXRTcGFuSlNPTiA9PT0gJ2Z1bmN0aW9uJztcbn1cblxuLyoqXG4gKiBSZXR1cm5zIHRydWUgaWYgYSBzcGFuIGlzIHNhbXBsZWQuXG4gKiBJbiBtb3N0IGNhc2VzLCB5b3Ugc2hvdWxkIGp1c3QgdXNlIGBzcGFuLmlzUmVjb3JkaW5nKClgIGluc3RlYWQuXG4gKiBIb3dldmVyLCB0aGlzIGhhcyBhIHNsaWdodGx5IGRpZmZlcmVudCBzZW1hbnRpYywgYXMgaXQgYWxzbyByZXR1cm5zIGZhbHNlIGlmIHRoZSBzcGFuIGlzIGZpbmlzaGVkLlxuICogU28gaW4gdGhlIGNhc2Ugd2hlcmUgdGhpcyBkaXN0aW5jdGlvbiBpcyBpbXBvcnRhbnQsIHVzZSB0aGlzIG1ldGhvZC5cbiAqL1xuZnVuY3Rpb24gc3BhbklzU2FtcGxlZChzcGFuKSB7XG4gIC8vIFdlIGFsaWduIG91ciB0cmFjZSBmbGFncyB3aXRoIHRoZSBvbmVzIE9wZW5UZWxlbWV0cnkgdXNlXG4gIC8vIFNvIHdlIGFsc28gY2hlY2sgZm9yIHNhbXBsZWQgdGhlIHNhbWUgd2F5IHRoZXkgZG8uXG4gIGNvbnN0IHsgdHJhY2VGbGFncyB9ID0gc3Bhbi5zcGFuQ29udGV4dCgpO1xuICByZXR1cm4gdHJhY2VGbGFncyA9PT0gVFJBQ0VfRkxBR19TQU1QTEVEO1xufVxuXG4vKiogR2V0IHRoZSBzdGF0dXMgbWVzc2FnZSB0byB1c2UgZm9yIGEgSlNPTiByZXByZXNlbnRhdGlvbiBvZiBhIHNwYW4uICovXG5mdW5jdGlvbiBnZXRTdGF0dXNNZXNzYWdlKHN0YXR1cykge1xuICBpZiAoIXN0YXR1cyB8fCBzdGF0dXMuY29kZSA9PT0gc3BhbnN0YXR1cy5TUEFOX1NUQVRVU19VTlNFVCkge1xuICAgIHJldHVybiB1bmRlZmluZWQ7XG4gIH1cblxuICBpZiAoc3RhdHVzLmNvZGUgPT09IHNwYW5zdGF0dXMuU1BBTl9TVEFUVVNfT0spIHtcbiAgICByZXR1cm4gJ29rJztcbiAgfVxuXG4gIHJldHVybiBzdGF0dXMubWVzc2FnZSB8fCAndW5rbm93bl9lcnJvcic7XG59XG5cbmNvbnN0IENISUxEX1NQQU5TX0ZJRUxEID0gJ19zZW50cnlDaGlsZFNwYW5zJztcbmNvbnN0IFJPT1RfU1BBTl9GSUVMRCA9ICdfc2VudHJ5Um9vdFNwYW4nO1xuXG4vKipcbiAqIEFkZHMgYW4gb3BhcXVlIGNoaWxkIHNwYW4gcmVmZXJlbmNlIHRvIGEgc3Bhbi5cbiAqL1xuZnVuY3Rpb24gYWRkQ2hpbGRTcGFuVG9TcGFuKHNwYW4sIGNoaWxkU3Bhbikge1xuICAvLyBXZSBzdG9yZSB0aGUgcm9vdCBzcGFuIHJlZmVyZW5jZSBvbiB0aGUgY2hpbGQgc3BhblxuICAvLyBXZSBuZWVkIHRoaXMgZm9yIGBnZXRSb290U3BhbigpYCB0byB3b3JrXG4gIGNvbnN0IHJvb3RTcGFuID0gc3BhbltST09UX1NQQU5fRklFTERdIHx8IHNwYW47XG4gIG9iamVjdC5hZGROb25FbnVtZXJhYmxlUHJvcGVydHkoY2hpbGRTcGFuICwgUk9PVF9TUEFOX0ZJRUxELCByb290U3Bhbik7XG5cbiAgLy8gV2Ugc3RvcmUgYSBsaXN0IG9mIGNoaWxkIHNwYW5zIG9uIHRoZSBwYXJlbnQgc3BhblxuICAvLyBXZSBuZWVkIHRoaXMgZm9yIGBnZXRTcGFuRGVzY2VuZGFudHMoKWAgdG8gd29ya1xuICBpZiAoc3BhbltDSElMRF9TUEFOU19GSUVMRF0pIHtcbiAgICBzcGFuW0NISUxEX1NQQU5TX0ZJRUxEXS5hZGQoY2hpbGRTcGFuKTtcbiAgfSBlbHNlIHtcbiAgICBvYmplY3QuYWRkTm9uRW51bWVyYWJsZVByb3BlcnR5KHNwYW4sIENISUxEX1NQQU5TX0ZJRUxELCBuZXcgU2V0KFtjaGlsZFNwYW5dKSk7XG4gIH1cbn1cblxuLyoqIFRoaXMgaXMgb25seSB1c2VkIGludGVybmFsbHkgYnkgSWRsZSBTcGFucy4gKi9cbmZ1bmN0aW9uIHJlbW92ZUNoaWxkU3BhbkZyb21TcGFuKHNwYW4sIGNoaWxkU3Bhbikge1xuICBpZiAoc3BhbltDSElMRF9TUEFOU19GSUVMRF0pIHtcbiAgICBzcGFuW0NISUxEX1NQQU5TX0ZJRUxEXS5kZWxldGUoY2hpbGRTcGFuKTtcbiAgfVxufVxuXG4vKipcbiAqIFJldHVybnMgYW4gYXJyYXkgb2YgdGhlIGdpdmVuIHNwYW4gYW5kIGFsbCBvZiBpdHMgZGVzY2VuZGFudHMuXG4gKi9cbmZ1bmN0aW9uIGdldFNwYW5EZXNjZW5kYW50cyhzcGFuKSB7XG4gIGNvbnN0IHJlc3VsdFNldCA9IG5ldyBTZXQoKTtcblxuICBmdW5jdGlvbiBhZGRTcGFuQ2hpbGRyZW4oc3Bhbikge1xuICAgIC8vIFRoaXMgZXhpdCBjb25kaXRpb24gaXMgcmVxdWlyZWQgdG8gbm90IGluZmluaXRlbHkgbG9vcCBpbiBjYXNlIG9mIGEgY2lyY3VsYXIgZGVwZW5kZW5jeS5cbiAgICBpZiAocmVzdWx0U2V0LmhhcyhzcGFuKSkge1xuICAgICAgcmV0dXJuO1xuICAgICAgLy8gV2Ugd2FudCB0byBpZ25vcmUgdW5zYW1wbGVkIHNwYW5zIChlLmcuIG5vbiByZWNvcmRpbmcgc3BhbnMpXG4gICAgfSBlbHNlIGlmIChzcGFuSXNTYW1wbGVkKHNwYW4pKSB7XG4gICAgICByZXN1bHRTZXQuYWRkKHNwYW4pO1xuICAgICAgY29uc3QgY2hpbGRTcGFucyA9IHNwYW5bQ0hJTERfU1BBTlNfRklFTERdID8gQXJyYXkuZnJvbShzcGFuW0NISUxEX1NQQU5TX0ZJRUxEXSkgOiBbXTtcbiAgICAgIGZvciAoY29uc3QgY2hpbGRTcGFuIG9mIGNoaWxkU3BhbnMpIHtcbiAgICAgICAgYWRkU3BhbkNoaWxkcmVuKGNoaWxkU3Bhbik7XG4gICAgICB9XG4gICAgfVxuICB9XG5cbiAgYWRkU3BhbkNoaWxkcmVuKHNwYW4pO1xuXG4gIHJldHVybiBBcnJheS5mcm9tKHJlc3VsdFNldCk7XG59XG5cbi8qKlxuICogUmV0dXJucyB0aGUgcm9vdCBzcGFuIG9mIGEgZ2l2ZW4gc3Bhbi5cbiAqL1xuZnVuY3Rpb24gZ2V0Um9vdFNwYW4oc3Bhbikge1xuICByZXR1cm4gc3BhbltST09UX1NQQU5fRklFTERdIHx8IHNwYW47XG59XG5cbi8qKlxuICogUmV0dXJucyB0aGUgY3VycmVudGx5IGFjdGl2ZSBzcGFuLlxuICovXG5mdW5jdGlvbiBnZXRBY3RpdmVTcGFuKCkge1xuICBjb25zdCBjYXJyaWVyJDEgPSBjYXJyaWVyLmdldE1haW5DYXJyaWVyKCk7XG4gIGNvbnN0IGFjcyA9IGluZGV4LmdldEFzeW5jQ29udGV4dFN0cmF0ZWd5KGNhcnJpZXIkMSk7XG4gIGlmIChhY3MuZ2V0QWN0aXZlU3Bhbikge1xuICAgIHJldHVybiBhY3MuZ2V0QWN0aXZlU3BhbigpO1xuICB9XG5cbiAgcmV0dXJuIHNwYW5PblNjb3BlLl9nZXRTcGFuRm9yU2NvcGUoY3VycmVudFNjb3Blcy5nZXRDdXJyZW50U2NvcGUoKSk7XG59XG5cbi8qKlxuICogTG9ncyBhIHdhcm5pbmcgb25jZSBpZiBgYmVmb3JlU2VuZFNwYW5gIGlzIHVzZWQgdG8gZHJvcCBzcGFucy5cbiAqL1xuZnVuY3Rpb24gc2hvd1NwYW5Ecm9wV2FybmluZygpIHtcbiAgaWYgKCFoYXNTaG93blNwYW5Ecm9wV2FybmluZykge1xuICAgIGRlYnVnTG9nZ2VyLmNvbnNvbGVTYW5kYm94KCgpID0+IHtcbiAgICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBuby1jb25zb2xlXG4gICAgICBjb25zb2xlLndhcm4oXG4gICAgICAgICdbU2VudHJ5XSBSZXR1cm5pbmcgbnVsbCBmcm9tIGBiZWZvcmVTZW5kU3BhbmAgaXMgZGlzYWxsb3dlZC4gVG8gZHJvcCBjZXJ0YWluIHNwYW5zLCBjb25maWd1cmUgdGhlIHJlc3BlY3RpdmUgaW50ZWdyYXRpb25zIGRpcmVjdGx5LicsXG4gICAgICApO1xuICAgIH0pO1xuICAgIGhhc1Nob3duU3BhbkRyb3BXYXJuaW5nID0gdHJ1ZTtcbiAgfVxufVxuXG4vKipcbiAqIFVwZGF0ZXMgdGhlIG5hbWUgb2YgdGhlIGdpdmVuIHNwYW4gYW5kIGVuc3VyZXMgdGhhdCB0aGUgc3BhbiBuYW1lIGlzIG5vdFxuICogb3ZlcndyaXR0ZW4gYnkgdGhlIFNlbnRyeSBTREsuXG4gKlxuICogVXNlIHRoaXMgZnVuY3Rpb24gaW5zdGVhZCBvZiBgc3Bhbi51cGRhdGVOYW1lKClgIGlmIHlvdSB3YW50IHRvIG1ha2Ugc3VyZSB0aGF0XG4gKiB5b3VyIG5hbWUgaXMga2VwdC4gRm9yIHNvbWUgc3BhbnMsIGZvciBleGFtcGxlIHJvb3QgYGh0dHAuc2VydmVyYCBzcGFucyB0aGVcbiAqIFNlbnRyeSBTREsgd291bGQgb3RoZXJ3aXNlIG92ZXJ3cml0ZSB0aGUgc3BhbiBuYW1lIHdpdGggYSBoaWdoLXF1YWxpdHkgbmFtZVxuICogaXQgaW5mZXJzIHdoZW4gdGhlIHNwYW4gZW5kcy5cbiAqXG4gKiBVc2UgdGhpcyBmdW5jdGlvbiBpbiBzZXJ2ZXIgY29kZSBvciB3aGVuIHlvdXIgc3BhbiBpcyBzdGFydGVkIG9uIHRoZSBzZXJ2ZXJcbiAqIGFuZCBvbiB0aGUgY2xpZW50IChicm93c2VyKS4gSWYgeW91IG9ubHkgdXBkYXRlIGEgc3BhbiBuYW1lIG9uIHRoZSBjbGllbnQsXG4gKiB5b3UgY2FuIGFsc28gdXNlIGBzcGFuLnVwZGF0ZU5hbWUoKWAgdGhlIFNESyBkb2VzIG5vdCBvdmVyd3JpdGUgdGhlIG5hbWUuXG4gKlxuICogQHBhcmFtIHNwYW4gLSBUaGUgc3BhbiB0byB1cGRhdGUgdGhlIG5hbWUgb2YuXG4gKiBAcGFyYW0gbmFtZSAtIFRoZSBuYW1lIHRvIHNldCBvbiB0aGUgc3Bhbi5cbiAqL1xuZnVuY3Rpb24gdXBkYXRlU3Bhbk5hbWUoc3BhbiwgbmFtZSkge1xuICBzcGFuLnVwZGF0ZU5hbWUobmFtZSk7XG4gIHNwYW4uc2V0QXR0cmlidXRlcyh7XG4gICAgW3NlbWFudGljQXR0cmlidXRlcy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX1NPVVJDRV06ICdjdXN0b20nLFxuICAgIFtzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9DVVNUT01fU1BBTl9OQU1FXTogbmFtZSxcbiAgfSk7XG59XG5cbmV4cG9ydHMuVFJBQ0VfRkxBR19OT05FID0gVFJBQ0VfRkxBR19OT05FO1xuZXhwb3J0cy5UUkFDRV9GTEFHX1NBTVBMRUQgPSBUUkFDRV9GTEFHX1NBTVBMRUQ7XG5leHBvcnRzLmFkZENoaWxkU3BhblRvU3BhbiA9IGFkZENoaWxkU3BhblRvU3BhbjtcbmV4cG9ydHMuY29udmVydFNwYW5MaW5rc0ZvckVudmVsb3BlID0gY29udmVydFNwYW5MaW5rc0ZvckVudmVsb3BlO1xuZXhwb3J0cy5nZXRBY3RpdmVTcGFuID0gZ2V0QWN0aXZlU3BhbjtcbmV4cG9ydHMuZ2V0Um9vdFNwYW4gPSBnZXRSb290U3BhbjtcbmV4cG9ydHMuZ2V0U3BhbkRlc2NlbmRhbnRzID0gZ2V0U3BhbkRlc2NlbmRhbnRzO1xuZXhwb3J0cy5nZXRTdGF0dXNNZXNzYWdlID0gZ2V0U3RhdHVzTWVzc2FnZTtcbmV4cG9ydHMucmVtb3ZlQ2hpbGRTcGFuRnJvbVNwYW4gPSByZW1vdmVDaGlsZFNwYW5Gcm9tU3BhbjtcbmV4cG9ydHMuc2hvd1NwYW5Ecm9wV2FybmluZyA9IHNob3dTcGFuRHJvcFdhcm5pbmc7XG5leHBvcnRzLnNwYW5Jc1NhbXBsZWQgPSBzcGFuSXNTYW1wbGVkO1xuZXhwb3J0cy5zcGFuVGltZUlucHV0VG9TZWNvbmRzID0gc3BhblRpbWVJbnB1dFRvU2Vjb25kcztcbmV4cG9ydHMuc3BhblRvSlNPTiA9IHNwYW5Ub0pTT047XG5leHBvcnRzLnNwYW5Ub1RyYWNlQ29udGV4dCA9IHNwYW5Ub1RyYWNlQ29udGV4dDtcbmV4cG9ydHMuc3BhblRvVHJhY2VIZWFkZXIgPSBzcGFuVG9UcmFjZUhlYWRlcjtcbmV4cG9ydHMuc3BhblRvVHJhbnNhY3Rpb25UcmFjZUNvbnRleHQgPSBzcGFuVG9UcmFuc2FjdGlvblRyYWNlQ29udGV4dDtcbmV4cG9ydHMudXBkYXRlU3Bhbk5hbWUgPSB1cGRhdGVTcGFuTmFtZTtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPXNwYW5VdGlscy5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanUtils.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/stacktrace.js":
/*!********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/stacktrace.js ***!
  \********************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst STACKTRACE_FRAME_LIMIT = 50;\nconst UNKNOWN_FUNCTION = '?';\n// Used to sanitize webpack (error: *) wrapped stack errors\nconst WEBPACK_ERROR_REGEXP = /\\(error: (.*)\\)/;\nconst STRIP_FRAME_REGEXP = /captureMessage|captureException/;\n\n/**\n * Creates a stack parser with the supplied line parsers\n *\n * StackFrames are returned in the correct order for Sentry Exception\n * frames and with Sentry SDK internal frames removed from the top and bottom\n *\n */\nfunction createStackParser(...parsers) {\n  const sortedParsers = parsers.sort((a, b) => a[0] - b[0]).map(p => p[1]);\n\n  return (stack, skipFirstLines = 0, framesToPop = 0) => {\n    const frames = [];\n    const lines = stack.split('\\n');\n\n    for (let i = skipFirstLines; i < lines.length; i++) {\n      const line = lines[i] ;\n      // Ignore lines over 1kb as they are unlikely to be stack frames.\n      // Many of the regular expressions use backtracking which results in run time that increases exponentially with\n      // input size. Huge strings can result in hangs/Denial of Service:\n      // https://github.com/getsentry/sentry-javascript/issues/2286\n      if (line.length > 1024) {\n        continue;\n      }\n\n      // https://github.com/getsentry/sentry-javascript/issues/5459\n      // Remove webpack (error: *) wrappers\n      const cleanedLine = WEBPACK_ERROR_REGEXP.test(line) ? line.replace(WEBPACK_ERROR_REGEXP, '$1') : line;\n\n      // https://github.com/getsentry/sentry-javascript/issues/7813\n      // Skip Error: lines\n      if (cleanedLine.match(/\\S*Error: /)) {\n        continue;\n      }\n\n      for (const parser of sortedParsers) {\n        const frame = parser(cleanedLine);\n\n        if (frame) {\n          frames.push(frame);\n          break;\n        }\n      }\n\n      if (frames.length >= STACKTRACE_FRAME_LIMIT + framesToPop) {\n        break;\n      }\n    }\n\n    return stripSentryFramesAndReverse(frames.slice(framesToPop));\n  };\n}\n\n/**\n * Gets a stack parser implementation from Options.stackParser\n * @see Options\n *\n * If options contains an array of line parsers, it is converted into a parser\n */\nfunction stackParserFromStackParserOptions(stackParser) {\n  if (Array.isArray(stackParser)) {\n    return createStackParser(...stackParser);\n  }\n  return stackParser;\n}\n\n/**\n * Removes Sentry frames from the top and bottom of the stack if present and enforces a limit of max number of frames.\n * Assumes stack input is ordered from top to bottom and returns the reverse representation so call site of the\n * function that caused the crash is the last frame in the array.\n * @hidden\n */\nfunction stripSentryFramesAndReverse(stack) {\n  if (!stack.length) {\n    return [];\n  }\n\n  const localStack = Array.from(stack);\n\n  // If stack starts with one of our API calls, remove it (starts, meaning it's the top of the stack - aka last call)\n  if (/sentryWrapped/.test(getLastStackFrame(localStack).function || '')) {\n    localStack.pop();\n  }\n\n  // Reversing in the middle of the procedure allows us to just pop the values off the stack\n  localStack.reverse();\n\n  // If stack ends with one of our internal API calls, remove it (ends, meaning it's the bottom of the stack - aka top-most call)\n  if (STRIP_FRAME_REGEXP.test(getLastStackFrame(localStack).function || '')) {\n    localStack.pop();\n\n    // When using synthetic events, we will have a 2 levels deep stack, as `new Error('Sentry syntheticException')`\n    // is produced within the scope itself, making it:\n    //\n    //   Sentry.captureException()\n    //   scope.captureException()\n    //\n    // instead of just the top `Sentry` call itself.\n    // This forces us to possibly strip an additional frame in the exact same was as above.\n    if (STRIP_FRAME_REGEXP.test(getLastStackFrame(localStack).function || '')) {\n      localStack.pop();\n    }\n  }\n\n  return localStack.slice(0, STACKTRACE_FRAME_LIMIT).map(frame => ({\n    ...frame,\n    filename: frame.filename || getLastStackFrame(localStack).filename,\n    function: frame.function || UNKNOWN_FUNCTION,\n  }));\n}\n\nfunction getLastStackFrame(arr) {\n  return arr[arr.length - 1] || {};\n}\n\nconst defaultFunctionName = '<anonymous>';\n\n/**\n * Safely extract function name from itself\n */\nfunction getFunctionName(fn) {\n  try {\n    if (!fn || typeof fn !== 'function') {\n      return defaultFunctionName;\n    }\n    return fn.name || defaultFunctionName;\n  } catch {\n    // Just accessing custom props in some Selenium environments\n    // can cause a \"Permission denied\" exception (see raven-js#495).\n    return defaultFunctionName;\n  }\n}\n\n/**\n * Get's stack frames from an event without needing to check for undefined properties.\n */\nfunction getFramesFromEvent(event) {\n  const exception = event.exception;\n\n  if (exception) {\n    const frames = [];\n    try {\n      // @ts-expect-error Object could be undefined\n      exception.values.forEach(value => {\n        // @ts-expect-error Value could be undefined\n        if (value.stacktrace.frames) {\n          // @ts-expect-error Value could be undefined\n          frames.push(...value.stacktrace.frames);\n        }\n      });\n      return frames;\n    } catch {\n      return undefined;\n    }\n  }\n  return undefined;\n}\n\nexports.UNKNOWN_FUNCTION = UNKNOWN_FUNCTION;\nexports.createStackParser = createStackParser;\nexports.getFramesFromEvent = getFramesFromEvent;\nexports.getFunctionName = getFunctionName;\nexports.stackParserFromStackParserOptions = stackParserFromStackParserOptions;\nexports.stripSentryFramesAndReverse = stripSentryFramesAndReverse;\n//# sourceMappingURL=stacktrace.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvc3RhY2t0cmFjZS5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUEsaUNBQWlDLGtCQUFrQjtBQUNuRDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEdBQUc7QUFDSDs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsSUFBSTtBQUNKO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLE9BQU87QUFDUDtBQUNBLE1BQU07QUFDTjtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLHdCQUF3QjtBQUN4Qix5QkFBeUI7QUFDekIsMEJBQTBCO0FBQzFCLHVCQUF1QjtBQUN2Qix5Q0FBeUM7QUFDekMsbUNBQW1DO0FBQ25DIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvc3RhY2t0cmFjZS5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgU1RBQ0tUUkFDRV9GUkFNRV9MSU1JVCA9IDUwO1xuY29uc3QgVU5LTk9XTl9GVU5DVElPTiA9ICc/Jztcbi8vIFVzZWQgdG8gc2FuaXRpemUgd2VicGFjayAoZXJyb3I6ICopIHdyYXBwZWQgc3RhY2sgZXJyb3JzXG5jb25zdCBXRUJQQUNLX0VSUk9SX1JFR0VYUCA9IC9cXChlcnJvcjogKC4qKVxcKS87XG5jb25zdCBTVFJJUF9GUkFNRV9SRUdFWFAgPSAvY2FwdHVyZU1lc3NhZ2V8Y2FwdHVyZUV4Y2VwdGlvbi87XG5cbi8qKlxuICogQ3JlYXRlcyBhIHN0YWNrIHBhcnNlciB3aXRoIHRoZSBzdXBwbGllZCBsaW5lIHBhcnNlcnNcbiAqXG4gKiBTdGFja0ZyYW1lcyBhcmUgcmV0dXJuZWQgaW4gdGhlIGNvcnJlY3Qgb3JkZXIgZm9yIFNlbnRyeSBFeGNlcHRpb25cbiAqIGZyYW1lcyBhbmQgd2l0aCBTZW50cnkgU0RLIGludGVybmFsIGZyYW1lcyByZW1vdmVkIGZyb20gdGhlIHRvcCBhbmQgYm90dG9tXG4gKlxuICovXG5mdW5jdGlvbiBjcmVhdGVTdGFja1BhcnNlciguLi5wYXJzZXJzKSB7XG4gIGNvbnN0IHNvcnRlZFBhcnNlcnMgPSBwYXJzZXJzLnNvcnQoKGEsIGIpID0+IGFbMF0gLSBiWzBdKS5tYXAocCA9PiBwWzFdKTtcblxuICByZXR1cm4gKHN0YWNrLCBza2lwRmlyc3RMaW5lcyA9IDAsIGZyYW1lc1RvUG9wID0gMCkgPT4ge1xuICAgIGNvbnN0IGZyYW1lcyA9IFtdO1xuICAgIGNvbnN0IGxpbmVzID0gc3RhY2suc3BsaXQoJ1xcbicpO1xuXG4gICAgZm9yIChsZXQgaSA9IHNraXBGaXJzdExpbmVzOyBpIDwgbGluZXMubGVuZ3RoOyBpKyspIHtcbiAgICAgIGNvbnN0IGxpbmUgPSBsaW5lc1tpXSA7XG4gICAgICAvLyBJZ25vcmUgbGluZXMgb3ZlciAxa2IgYXMgdGhleSBhcmUgdW5saWtlbHkgdG8gYmUgc3RhY2sgZnJhbWVzLlxuICAgICAgLy8gTWFueSBvZiB0aGUgcmVndWxhciBleHByZXNzaW9ucyB1c2UgYmFja3RyYWNraW5nIHdoaWNoIHJlc3VsdHMgaW4gcnVuIHRpbWUgdGhhdCBpbmNyZWFzZXMgZXhwb25lbnRpYWxseSB3aXRoXG4gICAgICAvLyBpbnB1dCBzaXplLiBIdWdlIHN0cmluZ3MgY2FuIHJlc3VsdCBpbiBoYW5ncy9EZW5pYWwgb2YgU2VydmljZTpcbiAgICAgIC8vIGh0dHBzOi8vZ2l0aHViLmNvbS9nZXRzZW50cnkvc2VudHJ5LWphdmFzY3JpcHQvaXNzdWVzLzIyODZcbiAgICAgIGlmIChsaW5lLmxlbmd0aCA+IDEwMjQpIHtcbiAgICAgICAgY29udGludWU7XG4gICAgICB9XG5cbiAgICAgIC8vIGh0dHBzOi8vZ2l0aHViLmNvbS9nZXRzZW50cnkvc2VudHJ5LWphdmFzY3JpcHQvaXNzdWVzLzU0NTlcbiAgICAgIC8vIFJlbW92ZSB3ZWJwYWNrIChlcnJvcjogKikgd3JhcHBlcnNcbiAgICAgIGNvbnN0IGNsZWFuZWRMaW5lID0gV0VCUEFDS19FUlJPUl9SRUdFWFAudGVzdChsaW5lKSA/IGxpbmUucmVwbGFjZShXRUJQQUNLX0VSUk9SX1JFR0VYUCwgJyQxJykgOiBsaW5lO1xuXG4gICAgICAvLyBodHRwczovL2dpdGh1Yi5jb20vZ2V0c2VudHJ5L3NlbnRyeS1qYXZhc2NyaXB0L2lzc3Vlcy83ODEzXG4gICAgICAvLyBTa2lwIEVycm9yOiBsaW5lc1xuICAgICAgaWYgKGNsZWFuZWRMaW5lLm1hdGNoKC9cXFMqRXJyb3I6IC8pKSB7XG4gICAgICAgIGNvbnRpbnVlO1xuICAgICAgfVxuXG4gICAgICBmb3IgKGNvbnN0IHBhcnNlciBvZiBzb3J0ZWRQYXJzZXJzKSB7XG4gICAgICAgIGNvbnN0IGZyYW1lID0gcGFyc2VyKGNsZWFuZWRMaW5lKTtcblxuICAgICAgICBpZiAoZnJhbWUpIHtcbiAgICAgICAgICBmcmFtZXMucHVzaChmcmFtZSk7XG4gICAgICAgICAgYnJlYWs7XG4gICAgICAgIH1cbiAgICAgIH1cblxuICAgICAgaWYgKGZyYW1lcy5sZW5ndGggPj0gU1RBQ0tUUkFDRV9GUkFNRV9MSU1JVCArIGZyYW1lc1RvUG9wKSB7XG4gICAgICAgIGJyZWFrO1xuICAgICAgfVxuICAgIH1cblxuICAgIHJldHVybiBzdHJpcFNlbnRyeUZyYW1lc0FuZFJldmVyc2UoZnJhbWVzLnNsaWNlKGZyYW1lc1RvUG9wKSk7XG4gIH07XG59XG5cbi8qKlxuICogR2V0cyBhIHN0YWNrIHBhcnNlciBpbXBsZW1lbnRhdGlvbiBmcm9tIE9wdGlvbnMuc3RhY2tQYXJzZXJcbiAqIEBzZWUgT3B0aW9uc1xuICpcbiAqIElmIG9wdGlvbnMgY29udGFpbnMgYW4gYXJyYXkgb2YgbGluZSBwYXJzZXJzLCBpdCBpcyBjb252ZXJ0ZWQgaW50byBhIHBhcnNlclxuICovXG5mdW5jdGlvbiBzdGFja1BhcnNlckZyb21TdGFja1BhcnNlck9wdGlvbnMoc3RhY2tQYXJzZXIpIHtcbiAgaWYgKEFycmF5LmlzQXJyYXkoc3RhY2tQYXJzZXIpKSB7XG4gICAgcmV0dXJuIGNyZWF0ZVN0YWNrUGFyc2VyKC4uLnN0YWNrUGFyc2VyKTtcbiAgfVxuICByZXR1cm4gc3RhY2tQYXJzZXI7XG59XG5cbi8qKlxuICogUmVtb3ZlcyBTZW50cnkgZnJhbWVzIGZyb20gdGhlIHRvcCBhbmQgYm90dG9tIG9mIHRoZSBzdGFjayBpZiBwcmVzZW50IGFuZCBlbmZvcmNlcyBhIGxpbWl0IG9mIG1heCBudW1iZXIgb2YgZnJhbWVzLlxuICogQXNzdW1lcyBzdGFjayBpbnB1dCBpcyBvcmRlcmVkIGZyb20gdG9wIHRvIGJvdHRvbSBhbmQgcmV0dXJucyB0aGUgcmV2ZXJzZSByZXByZXNlbnRhdGlvbiBzbyBjYWxsIHNpdGUgb2YgdGhlXG4gKiBmdW5jdGlvbiB0aGF0IGNhdXNlZCB0aGUgY3Jhc2ggaXMgdGhlIGxhc3QgZnJhbWUgaW4gdGhlIGFycmF5LlxuICogQGhpZGRlblxuICovXG5mdW5jdGlvbiBzdHJpcFNlbnRyeUZyYW1lc0FuZFJldmVyc2Uoc3RhY2spIHtcbiAgaWYgKCFzdGFjay5sZW5ndGgpIHtcbiAgICByZXR1cm4gW107XG4gIH1cblxuICBjb25zdCBsb2NhbFN0YWNrID0gQXJyYXkuZnJvbShzdGFjayk7XG5cbiAgLy8gSWYgc3RhY2sgc3RhcnRzIHdpdGggb25lIG9mIG91ciBBUEkgY2FsbHMsIHJlbW92ZSBpdCAoc3RhcnRzLCBtZWFuaW5nIGl0J3MgdGhlIHRvcCBvZiB0aGUgc3RhY2sgLSBha2EgbGFzdCBjYWxsKVxuICBpZiAoL3NlbnRyeVdyYXBwZWQvLnRlc3QoZ2V0TGFzdFN0YWNrRnJhbWUobG9jYWxTdGFjaykuZnVuY3Rpb24gfHwgJycpKSB7XG4gICAgbG9jYWxTdGFjay5wb3AoKTtcbiAgfVxuXG4gIC8vIFJldmVyc2luZyBpbiB0aGUgbWlkZGxlIG9mIHRoZSBwcm9jZWR1cmUgYWxsb3dzIHVzIHRvIGp1c3QgcG9wIHRoZSB2YWx1ZXMgb2ZmIHRoZSBzdGFja1xuICBsb2NhbFN0YWNrLnJldmVyc2UoKTtcblxuICAvLyBJZiBzdGFjayBlbmRzIHdpdGggb25lIG9mIG91ciBpbnRlcm5hbCBBUEkgY2FsbHMsIHJlbW92ZSBpdCAoZW5kcywgbWVhbmluZyBpdCdzIHRoZSBib3R0b20gb2YgdGhlIHN0YWNrIC0gYWthIHRvcC1tb3N0IGNhbGwpXG4gIGlmIChTVFJJUF9GUkFNRV9SRUdFWFAudGVzdChnZXRMYXN0U3RhY2tGcmFtZShsb2NhbFN0YWNrKS5mdW5jdGlvbiB8fCAnJykpIHtcbiAgICBsb2NhbFN0YWNrLnBvcCgpO1xuXG4gICAgLy8gV2hlbiB1c2luZyBzeW50aGV0aWMgZXZlbnRzLCB3ZSB3aWxsIGhhdmUgYSAyIGxldmVscyBkZWVwIHN0YWNrLCBhcyBgbmV3IEVycm9yKCdTZW50cnkgc3ludGhldGljRXhjZXB0aW9uJylgXG4gICAgLy8gaXMgcHJvZHVjZWQgd2l0aGluIHRoZSBzY29wZSBpdHNlbGYsIG1ha2luZyBpdDpcbiAgICAvL1xuICAgIC8vICAgU2VudHJ5LmNhcHR1cmVFeGNlcHRpb24oKVxuICAgIC8vICAgc2NvcGUuY2FwdHVyZUV4Y2VwdGlvbigpXG4gICAgLy9cbiAgICAvLyBpbnN0ZWFkIG9mIGp1c3QgdGhlIHRvcCBgU2VudHJ5YCBjYWxsIGl0c2VsZi5cbiAgICAvLyBUaGlzIGZvcmNlcyB1cyB0byBwb3NzaWJseSBzdHJpcCBhbiBhZGRpdGlvbmFsIGZyYW1lIGluIHRoZSBleGFjdCBzYW1lIHdhcyBhcyBhYm92ZS5cbiAgICBpZiAoU1RSSVBfRlJBTUVfUkVHRVhQLnRlc3QoZ2V0TGFzdFN0YWNrRnJhbWUobG9jYWxTdGFjaykuZnVuY3Rpb24gfHwgJycpKSB7XG4gICAgICBsb2NhbFN0YWNrLnBvcCgpO1xuICAgIH1cbiAgfVxuXG4gIHJldHVybiBsb2NhbFN0YWNrLnNsaWNlKDAsIFNUQUNLVFJBQ0VfRlJBTUVfTElNSVQpLm1hcChmcmFtZSA9PiAoe1xuICAgIC4uLmZyYW1lLFxuICAgIGZpbGVuYW1lOiBmcmFtZS5maWxlbmFtZSB8fCBnZXRMYXN0U3RhY2tGcmFtZShsb2NhbFN0YWNrKS5maWxlbmFtZSxcbiAgICBmdW5jdGlvbjogZnJhbWUuZnVuY3Rpb24gfHwgVU5LTk9XTl9GVU5DVElPTixcbiAgfSkpO1xufVxuXG5mdW5jdGlvbiBnZXRMYXN0U3RhY2tGcmFtZShhcnIpIHtcbiAgcmV0dXJuIGFyclthcnIubGVuZ3RoIC0gMV0gfHwge307XG59XG5cbmNvbnN0IGRlZmF1bHRGdW5jdGlvbk5hbWUgPSAnPGFub255bW91cz4nO1xuXG4vKipcbiAqIFNhZmVseSBleHRyYWN0IGZ1bmN0aW9uIG5hbWUgZnJvbSBpdHNlbGZcbiAqL1xuZnVuY3Rpb24gZ2V0RnVuY3Rpb25OYW1lKGZuKSB7XG4gIHRyeSB7XG4gICAgaWYgKCFmbiB8fCB0eXBlb2YgZm4gIT09ICdmdW5jdGlvbicpIHtcbiAgICAgIHJldHVybiBkZWZhdWx0RnVuY3Rpb25OYW1lO1xuICAgIH1cbiAgICByZXR1cm4gZm4ubmFtZSB8fCBkZWZhdWx0RnVuY3Rpb25OYW1lO1xuICB9IGNhdGNoIHtcbiAgICAvLyBKdXN0IGFjY2Vzc2luZyBjdXN0b20gcHJvcHMgaW4gc29tZSBTZWxlbml1bSBlbnZpcm9ubWVudHNcbiAgICAvLyBjYW4gY2F1c2UgYSBcIlBlcm1pc3Npb24gZGVuaWVkXCIgZXhjZXB0aW9uIChzZWUgcmF2ZW4tanMjNDk1KS5cbiAgICByZXR1cm4gZGVmYXVsdEZ1bmN0aW9uTmFtZTtcbiAgfVxufVxuXG4vKipcbiAqIEdldCdzIHN0YWNrIGZyYW1lcyBmcm9tIGFuIGV2ZW50IHdpdGhvdXQgbmVlZGluZyB0byBjaGVjayBmb3IgdW5kZWZpbmVkIHByb3BlcnRpZXMuXG4gKi9cbmZ1bmN0aW9uIGdldEZyYW1lc0Zyb21FdmVudChldmVudCkge1xuICBjb25zdCBleGNlcHRpb24gPSBldmVudC5leGNlcHRpb247XG5cbiAgaWYgKGV4Y2VwdGlvbikge1xuICAgIGNvbnN0IGZyYW1lcyA9IFtdO1xuICAgIHRyeSB7XG4gICAgICAvLyBAdHMtZXhwZWN0LWVycm9yIE9iamVjdCBjb3VsZCBiZSB1bmRlZmluZWRcbiAgICAgIGV4Y2VwdGlvbi52YWx1ZXMuZm9yRWFjaCh2YWx1ZSA9PiB7XG4gICAgICAgIC8vIEB0cy1leHBlY3QtZXJyb3IgVmFsdWUgY291bGQgYmUgdW5kZWZpbmVkXG4gICAgICAgIGlmICh2YWx1ZS5zdGFja3RyYWNlLmZyYW1lcykge1xuICAgICAgICAgIC8vIEB0cy1leHBlY3QtZXJyb3IgVmFsdWUgY291bGQgYmUgdW5kZWZpbmVkXG4gICAgICAgICAgZnJhbWVzLnB1c2goLi4udmFsdWUuc3RhY2t0cmFjZS5mcmFtZXMpO1xuICAgICAgICB9XG4gICAgICB9KTtcbiAgICAgIHJldHVybiBmcmFtZXM7XG4gICAgfSBjYXRjaCB7XG4gICAgICByZXR1cm4gdW5kZWZpbmVkO1xuICAgIH1cbiAgfVxuICByZXR1cm4gdW5kZWZpbmVkO1xufVxuXG5leHBvcnRzLlVOS05PV05fRlVOQ1RJT04gPSBVTktOT1dOX0ZVTkNUSU9OO1xuZXhwb3J0cy5jcmVhdGVTdGFja1BhcnNlciA9IGNyZWF0ZVN0YWNrUGFyc2VyO1xuZXhwb3J0cy5nZXRGcmFtZXNGcm9tRXZlbnQgPSBnZXRGcmFtZXNGcm9tRXZlbnQ7XG5leHBvcnRzLmdldEZ1bmN0aW9uTmFtZSA9IGdldEZ1bmN0aW9uTmFtZTtcbmV4cG9ydHMuc3RhY2tQYXJzZXJGcm9tU3RhY2tQYXJzZXJPcHRpb25zID0gc3RhY2tQYXJzZXJGcm9tU3RhY2tQYXJzZXJPcHRpb25zO1xuZXhwb3J0cy5zdHJpcFNlbnRyeUZyYW1lc0FuZFJldmVyc2UgPSBzdHJpcFNlbnRyeUZyYW1lc0FuZFJldmVyc2U7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1zdGFja3RyYWNlLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/stacktrace.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/string.js":
/*!****************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/string.js ***!
  \****************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst is = __webpack_require__(/*! ./is.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js\");\n\n/**\n * Truncates given string to the maximum characters count\n *\n * @param str An object that contains serializable values\n * @param max Maximum number of characters in truncated string (0 = unlimited)\n * @returns string Encoded\n */\nfunction truncate(str, max = 0) {\n  if (typeof str !== 'string' || max === 0) {\n    return str;\n  }\n  return str.length <= max ? str : `${str.slice(0, max)}...`;\n}\n\n/**\n * This is basically just `trim_line` from\n * https://github.com/getsentry/sentry/blob/master/src/sentry/lang/javascript/processor.py#L67\n *\n * @param str An object that contains serializable values\n * @param max Maximum number of characters in truncated string\n * @returns string Encoded\n */\nfunction snipLine(line, colno) {\n  let newLine = line;\n  const lineLength = newLine.length;\n  if (lineLength <= 150) {\n    return newLine;\n  }\n  if (colno > lineLength) {\n    // eslint-disable-next-line no-param-reassign\n    colno = lineLength;\n  }\n\n  let start = Math.max(colno - 60, 0);\n  if (start < 5) {\n    start = 0;\n  }\n\n  let end = Math.min(start + 140, lineLength);\n  if (end > lineLength - 5) {\n    end = lineLength;\n  }\n  if (end === lineLength) {\n    start = Math.max(end - 140, 0);\n  }\n\n  newLine = newLine.slice(start, end);\n  if (start > 0) {\n    newLine = `'{snip} ${newLine}`;\n  }\n  if (end < lineLength) {\n    newLine += ' {snip}';\n  }\n\n  return newLine;\n}\n\n/**\n * Join values in array\n * @param input array of values to be joined together\n * @param delimiter string to be placed in-between values\n * @returns Joined values\n */\nfunction safeJoin(input, delimiter) {\n  if (!Array.isArray(input)) {\n    return '';\n  }\n\n  const output = [];\n  // eslint-disable-next-line @typescript-eslint/prefer-for-of\n  for (let i = 0; i < input.length; i++) {\n    const value = input[i];\n    try {\n      // This is a hack to fix a Vue3-specific bug that causes an infinite loop of\n      // console warnings. This happens when a Vue template is rendered with\n      // an undeclared variable, which we try to stringify, ultimately causing\n      // Vue to issue another warning which repeats indefinitely.\n      // see: https://github.com/getsentry/sentry-javascript/pull/8981\n      if (is.isVueViewModel(value)) {\n        output.push('[VueViewModel]');\n      } else {\n        output.push(String(value));\n      }\n    } catch {\n      output.push('[value cannot be serialized]');\n    }\n  }\n\n  return output.join(delimiter);\n}\n\n/**\n * Checks if the given value matches a regex or string\n *\n * @param value The string to test\n * @param pattern Either a regex or a string against which `value` will be matched\n * @param requireExactStringMatch If true, `value` must match `pattern` exactly. If false, `value` will match\n * `pattern` if it contains `pattern`. Only applies to string-type patterns.\n */\nfunction isMatchingPattern(\n  value,\n  pattern,\n  requireExactStringMatch = false,\n) {\n  if (!is.isString(value)) {\n    return false;\n  }\n\n  if (is.isRegExp(pattern)) {\n    return pattern.test(value);\n  }\n  if (is.isString(pattern)) {\n    return requireExactStringMatch ? value === pattern : value.includes(pattern);\n  }\n\n  return false;\n}\n\n/**\n * Test the given string against an array of strings and regexes. By default, string matching is done on a\n * substring-inclusion basis rather than a strict equality basis\n *\n * @param testString The string to test\n * @param patterns The patterns against which to test the string\n * @param requireExactStringMatch If true, `testString` must match one of the given string patterns exactly in order to\n * count. If false, `testString` will match a string pattern if it contains that pattern.\n * @returns\n */\nfunction stringMatchesSomePattern(\n  testString,\n  patterns = [],\n  requireExactStringMatch = false,\n) {\n  return patterns.some(pattern => isMatchingPattern(testString, pattern, requireExactStringMatch));\n}\n\nexports.isMatchingPattern = isMatchingPattern;\nexports.safeJoin = safeJoin;\nexports.snipLine = snipLine;\nexports.stringMatchesSomePattern = stringMatchesSomePattern;\nexports.truncate = truncate;\n//# sourceMappingURL=string.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvc3RyaW5nLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLFdBQVcsbUJBQU8sQ0FBQyxzSEFBUzs7QUFFNUI7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLHNDQUFzQyxrQkFBa0I7QUFDeEQ7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQSxpQkFBaUIsTUFBTSxFQUFFLFFBQVE7QUFDakM7QUFDQTtBQUNBLGtCQUFrQixLQUFLO0FBQ3ZCOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLGtCQUFrQixrQkFBa0I7QUFDcEM7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsUUFBUTtBQUNSO0FBQ0E7QUFDQSxNQUFNO0FBQ047QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSx5QkFBeUI7QUFDekIsZ0JBQWdCO0FBQ2hCLGdCQUFnQjtBQUNoQixnQ0FBZ0M7QUFDaEMsZ0JBQWdCO0FBQ2hCIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvc3RyaW5nLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBpcyA9IHJlcXVpcmUoJy4vaXMuanMnKTtcblxuLyoqXG4gKiBUcnVuY2F0ZXMgZ2l2ZW4gc3RyaW5nIHRvIHRoZSBtYXhpbXVtIGNoYXJhY3RlcnMgY291bnRcbiAqXG4gKiBAcGFyYW0gc3RyIEFuIG9iamVjdCB0aGF0IGNvbnRhaW5zIHNlcmlhbGl6YWJsZSB2YWx1ZXNcbiAqIEBwYXJhbSBtYXggTWF4aW11bSBudW1iZXIgb2YgY2hhcmFjdGVycyBpbiB0cnVuY2F0ZWQgc3RyaW5nICgwID0gdW5saW1pdGVkKVxuICogQHJldHVybnMgc3RyaW5nIEVuY29kZWRcbiAqL1xuZnVuY3Rpb24gdHJ1bmNhdGUoc3RyLCBtYXggPSAwKSB7XG4gIGlmICh0eXBlb2Ygc3RyICE9PSAnc3RyaW5nJyB8fCBtYXggPT09IDApIHtcbiAgICByZXR1cm4gc3RyO1xuICB9XG4gIHJldHVybiBzdHIubGVuZ3RoIDw9IG1heCA/IHN0ciA6IGAke3N0ci5zbGljZSgwLCBtYXgpfS4uLmA7XG59XG5cbi8qKlxuICogVGhpcyBpcyBiYXNpY2FsbHkganVzdCBgdHJpbV9saW5lYCBmcm9tXG4gKiBodHRwczovL2dpdGh1Yi5jb20vZ2V0c2VudHJ5L3NlbnRyeS9ibG9iL21hc3Rlci9zcmMvc2VudHJ5L2xhbmcvamF2YXNjcmlwdC9wcm9jZXNzb3IucHkjTDY3XG4gKlxuICogQHBhcmFtIHN0ciBBbiBvYmplY3QgdGhhdCBjb250YWlucyBzZXJpYWxpemFibGUgdmFsdWVzXG4gKiBAcGFyYW0gbWF4IE1heGltdW0gbnVtYmVyIG9mIGNoYXJhY3RlcnMgaW4gdHJ1bmNhdGVkIHN0cmluZ1xuICogQHJldHVybnMgc3RyaW5nIEVuY29kZWRcbiAqL1xuZnVuY3Rpb24gc25pcExpbmUobGluZSwgY29sbm8pIHtcbiAgbGV0IG5ld0xpbmUgPSBsaW5lO1xuICBjb25zdCBsaW5lTGVuZ3RoID0gbmV3TGluZS5sZW5ndGg7XG4gIGlmIChsaW5lTGVuZ3RoIDw9IDE1MCkge1xuICAgIHJldHVybiBuZXdMaW5lO1xuICB9XG4gIGlmIChjb2xubyA+IGxpbmVMZW5ndGgpIHtcbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgbm8tcGFyYW0tcmVhc3NpZ25cbiAgICBjb2xubyA9IGxpbmVMZW5ndGg7XG4gIH1cblxuICBsZXQgc3RhcnQgPSBNYXRoLm1heChjb2xubyAtIDYwLCAwKTtcbiAgaWYgKHN0YXJ0IDwgNSkge1xuICAgIHN0YXJ0ID0gMDtcbiAgfVxuXG4gIGxldCBlbmQgPSBNYXRoLm1pbihzdGFydCArIDE0MCwgbGluZUxlbmd0aCk7XG4gIGlmIChlbmQgPiBsaW5lTGVuZ3RoIC0gNSkge1xuICAgIGVuZCA9IGxpbmVMZW5ndGg7XG4gIH1cbiAgaWYgKGVuZCA9PT0gbGluZUxlbmd0aCkge1xuICAgIHN0YXJ0ID0gTWF0aC5tYXgoZW5kIC0gMTQwLCAwKTtcbiAgfVxuXG4gIG5ld0xpbmUgPSBuZXdMaW5lLnNsaWNlKHN0YXJ0LCBlbmQpO1xuICBpZiAoc3RhcnQgPiAwKSB7XG4gICAgbmV3TGluZSA9IGAne3NuaXB9ICR7bmV3TGluZX1gO1xuICB9XG4gIGlmIChlbmQgPCBsaW5lTGVuZ3RoKSB7XG4gICAgbmV3TGluZSArPSAnIHtzbmlwfSc7XG4gIH1cblxuICByZXR1cm4gbmV3TGluZTtcbn1cblxuLyoqXG4gKiBKb2luIHZhbHVlcyBpbiBhcnJheVxuICogQHBhcmFtIGlucHV0IGFycmF5IG9mIHZhbHVlcyB0byBiZSBqb2luZWQgdG9nZXRoZXJcbiAqIEBwYXJhbSBkZWxpbWl0ZXIgc3RyaW5nIHRvIGJlIHBsYWNlZCBpbi1iZXR3ZWVuIHZhbHVlc1xuICogQHJldHVybnMgSm9pbmVkIHZhbHVlc1xuICovXG5mdW5jdGlvbiBzYWZlSm9pbihpbnB1dCwgZGVsaW1pdGVyKSB7XG4gIGlmICghQXJyYXkuaXNBcnJheShpbnB1dCkpIHtcbiAgICByZXR1cm4gJyc7XG4gIH1cblxuICBjb25zdCBvdXRwdXQgPSBbXTtcbiAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9wcmVmZXItZm9yLW9mXG4gIGZvciAobGV0IGkgPSAwOyBpIDwgaW5wdXQubGVuZ3RoOyBpKyspIHtcbiAgICBjb25zdCB2YWx1ZSA9IGlucHV0W2ldO1xuICAgIHRyeSB7XG4gICAgICAvLyBUaGlzIGlzIGEgaGFjayB0byBmaXggYSBWdWUzLXNwZWNpZmljIGJ1ZyB0aGF0IGNhdXNlcyBhbiBpbmZpbml0ZSBsb29wIG9mXG4gICAgICAvLyBjb25zb2xlIHdhcm5pbmdzLiBUaGlzIGhhcHBlbnMgd2hlbiBhIFZ1ZSB0ZW1wbGF0ZSBpcyByZW5kZXJlZCB3aXRoXG4gICAgICAvLyBhbiB1bmRlY2xhcmVkIHZhcmlhYmxlLCB3aGljaCB3ZSB0cnkgdG8gc3RyaW5naWZ5LCB1bHRpbWF0ZWx5IGNhdXNpbmdcbiAgICAgIC8vIFZ1ZSB0byBpc3N1ZSBhbm90aGVyIHdhcm5pbmcgd2hpY2ggcmVwZWF0cyBpbmRlZmluaXRlbHkuXG4gICAgICAvLyBzZWU6IGh0dHBzOi8vZ2l0aHViLmNvbS9nZXRzZW50cnkvc2VudHJ5LWphdmFzY3JpcHQvcHVsbC84OTgxXG4gICAgICBpZiAoaXMuaXNWdWVWaWV3TW9kZWwodmFsdWUpKSB7XG4gICAgICAgIG91dHB1dC5wdXNoKCdbVnVlVmlld01vZGVsXScpO1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgb3V0cHV0LnB1c2goU3RyaW5nKHZhbHVlKSk7XG4gICAgICB9XG4gICAgfSBjYXRjaCB7XG4gICAgICBvdXRwdXQucHVzaCgnW3ZhbHVlIGNhbm5vdCBiZSBzZXJpYWxpemVkXScpO1xuICAgIH1cbiAgfVxuXG4gIHJldHVybiBvdXRwdXQuam9pbihkZWxpbWl0ZXIpO1xufVxuXG4vKipcbiAqIENoZWNrcyBpZiB0aGUgZ2l2ZW4gdmFsdWUgbWF0Y2hlcyBhIHJlZ2V4IG9yIHN0cmluZ1xuICpcbiAqIEBwYXJhbSB2YWx1ZSBUaGUgc3RyaW5nIHRvIHRlc3RcbiAqIEBwYXJhbSBwYXR0ZXJuIEVpdGhlciBhIHJlZ2V4IG9yIGEgc3RyaW5nIGFnYWluc3Qgd2hpY2ggYHZhbHVlYCB3aWxsIGJlIG1hdGNoZWRcbiAqIEBwYXJhbSByZXF1aXJlRXhhY3RTdHJpbmdNYXRjaCBJZiB0cnVlLCBgdmFsdWVgIG11c3QgbWF0Y2ggYHBhdHRlcm5gIGV4YWN0bHkuIElmIGZhbHNlLCBgdmFsdWVgIHdpbGwgbWF0Y2hcbiAqIGBwYXR0ZXJuYCBpZiBpdCBjb250YWlucyBgcGF0dGVybmAuIE9ubHkgYXBwbGllcyB0byBzdHJpbmctdHlwZSBwYXR0ZXJucy5cbiAqL1xuZnVuY3Rpb24gaXNNYXRjaGluZ1BhdHRlcm4oXG4gIHZhbHVlLFxuICBwYXR0ZXJuLFxuICByZXF1aXJlRXhhY3RTdHJpbmdNYXRjaCA9IGZhbHNlLFxuKSB7XG4gIGlmICghaXMuaXNTdHJpbmcodmFsdWUpKSB7XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG5cbiAgaWYgKGlzLmlzUmVnRXhwKHBhdHRlcm4pKSB7XG4gICAgcmV0dXJuIHBhdHRlcm4udGVzdCh2YWx1ZSk7XG4gIH1cbiAgaWYgKGlzLmlzU3RyaW5nKHBhdHRlcm4pKSB7XG4gICAgcmV0dXJuIHJlcXVpcmVFeGFjdFN0cmluZ01hdGNoID8gdmFsdWUgPT09IHBhdHRlcm4gOiB2YWx1ZS5pbmNsdWRlcyhwYXR0ZXJuKTtcbiAgfVxuXG4gIHJldHVybiBmYWxzZTtcbn1cblxuLyoqXG4gKiBUZXN0IHRoZSBnaXZlbiBzdHJpbmcgYWdhaW5zdCBhbiBhcnJheSBvZiBzdHJpbmdzIGFuZCByZWdleGVzLiBCeSBkZWZhdWx0LCBzdHJpbmcgbWF0Y2hpbmcgaXMgZG9uZSBvbiBhXG4gKiBzdWJzdHJpbmctaW5jbHVzaW9uIGJhc2lzIHJhdGhlciB0aGFuIGEgc3RyaWN0IGVxdWFsaXR5IGJhc2lzXG4gKlxuICogQHBhcmFtIHRlc3RTdHJpbmcgVGhlIHN0cmluZyB0byB0ZXN0XG4gKiBAcGFyYW0gcGF0dGVybnMgVGhlIHBhdHRlcm5zIGFnYWluc3Qgd2hpY2ggdG8gdGVzdCB0aGUgc3RyaW5nXG4gKiBAcGFyYW0gcmVxdWlyZUV4YWN0U3RyaW5nTWF0Y2ggSWYgdHJ1ZSwgYHRlc3RTdHJpbmdgIG11c3QgbWF0Y2ggb25lIG9mIHRoZSBnaXZlbiBzdHJpbmcgcGF0dGVybnMgZXhhY3RseSBpbiBvcmRlciB0b1xuICogY291bnQuIElmIGZhbHNlLCBgdGVzdFN0cmluZ2Agd2lsbCBtYXRjaCBhIHN0cmluZyBwYXR0ZXJuIGlmIGl0IGNvbnRhaW5zIHRoYXQgcGF0dGVybi5cbiAqIEByZXR1cm5zXG4gKi9cbmZ1bmN0aW9uIHN0cmluZ01hdGNoZXNTb21lUGF0dGVybihcbiAgdGVzdFN0cmluZyxcbiAgcGF0dGVybnMgPSBbXSxcbiAgcmVxdWlyZUV4YWN0U3RyaW5nTWF0Y2ggPSBmYWxzZSxcbikge1xuICByZXR1cm4gcGF0dGVybnMuc29tZShwYXR0ZXJuID0+IGlzTWF0Y2hpbmdQYXR0ZXJuKHRlc3RTdHJpbmcsIHBhdHRlcm4sIHJlcXVpcmVFeGFjdFN0cmluZ01hdGNoKSk7XG59XG5cbmV4cG9ydHMuaXNNYXRjaGluZ1BhdHRlcm4gPSBpc01hdGNoaW5nUGF0dGVybjtcbmV4cG9ydHMuc2FmZUpvaW4gPSBzYWZlSm9pbjtcbmV4cG9ydHMuc25pcExpbmUgPSBzbmlwTGluZTtcbmV4cG9ydHMuc3RyaW5nTWF0Y2hlc1NvbWVQYXR0ZXJuID0gc3RyaW5nTWF0Y2hlc1NvbWVQYXR0ZXJuO1xuZXhwb3J0cy50cnVuY2F0ZSA9IHRydW5jYXRlO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9c3RyaW5nLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/string.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/supports.js":
/*!******************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/supports.js ***!
  \******************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst debugBuild = __webpack_require__(/*! ../debug-build.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst debugLogger = __webpack_require__(/*! ./debug-logger.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst worldwide = __webpack_require__(/*! ./worldwide.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/worldwide.js\");\n\nconst WINDOW = worldwide.GLOBAL_OBJ ;\n\n/**\n * Tells whether current environment supports ErrorEvent objects\n * {@link supportsErrorEvent}.\n *\n * @returns Answer to the given question.\n */\nfunction supportsErrorEvent() {\n  try {\n    new ErrorEvent('');\n    return true;\n  } catch {\n    return false;\n  }\n}\n\n/**\n * Tells whether current environment supports DOMError objects\n * {@link supportsDOMError}.\n *\n * @returns Answer to the given question.\n */\nfunction supportsDOMError() {\n  try {\n    // Chrome: VM89:1 Uncaught TypeError: Failed to construct 'DOMError':\n    // 1 argument required, but only 0 present.\n    // @ts-expect-error It really needs 1 argument, not 0.\n    new DOMError('');\n    return true;\n  } catch {\n    return false;\n  }\n}\n\n/**\n * Tells whether current environment supports DOMException objects\n * {@link supportsDOMException}.\n *\n * @returns Answer to the given question.\n */\nfunction supportsDOMException() {\n  try {\n    new DOMException('');\n    return true;\n  } catch {\n    return false;\n  }\n}\n\n/**\n * Tells whether current environment supports History API\n * {@link supportsHistory}.\n *\n * @returns Answer to the given question.\n */\nfunction supportsHistory() {\n  return 'history' in WINDOW && !!WINDOW.history;\n}\n\n/**\n * Tells whether current environment supports Fetch API\n * {@link supportsFetch}.\n *\n * @returns Answer to the given question.\n * @deprecated This is no longer used and will be removed in a future major version.\n */\nconst supportsFetch = _isFetchSupported;\n\nfunction _isFetchSupported() {\n  if (!('fetch' in WINDOW)) {\n    return false;\n  }\n\n  try {\n    new Headers();\n    new Request('http://www.example.com');\n    new Response();\n    return true;\n  } catch {\n    return false;\n  }\n}\n\n/**\n * isNative checks if the given function is a native implementation\n */\n// eslint-disable-next-line @typescript-eslint/ban-types\nfunction isNativeFunction(func) {\n  return func && /^function\\s+\\w+\\(\\)\\s+\\{\\s+\\[native code\\]\\s+\\}$/.test(func.toString());\n}\n\n/**\n * Tells whether current environment supports Fetch API natively\n * {@link supportsNativeFetch}.\n *\n * @returns true if `window.fetch` is natively implemented, false otherwise\n */\nfunction supportsNativeFetch() {\n  if (typeof EdgeRuntime === 'string') {\n    return true;\n  }\n\n  if (!_isFetchSupported()) {\n    return false;\n  }\n\n  // Fast path to avoid DOM I/O\n  // eslint-disable-next-line @typescript-eslint/unbound-method\n  if (isNativeFunction(WINDOW.fetch)) {\n    return true;\n  }\n\n  // window.fetch is implemented, but is polyfilled or already wrapped (e.g: by a chrome extension)\n  // so create a \"pure\" iframe to see if that has native fetch\n  let result = false;\n  const doc = WINDOW.document;\n  // eslint-disable-next-line deprecation/deprecation\n  if (doc && typeof (doc.createElement ) === 'function') {\n    try {\n      const sandbox = doc.createElement('iframe');\n      sandbox.hidden = true;\n      doc.head.appendChild(sandbox);\n      if (sandbox.contentWindow?.fetch) {\n        // eslint-disable-next-line @typescript-eslint/unbound-method\n        result = isNativeFunction(sandbox.contentWindow.fetch);\n      }\n      doc.head.removeChild(sandbox);\n    } catch (err) {\n      debugBuild.DEBUG_BUILD && debugLogger.debug.warn('Could not create sandbox iframe for pure fetch check, bailing to window.fetch: ', err);\n    }\n  }\n\n  return result;\n}\n\n/**\n * Tells whether current environment supports ReportingObserver API\n * {@link supportsReportingObserver}.\n *\n * @returns Answer to the given question.\n */\nfunction supportsReportingObserver() {\n  return 'ReportingObserver' in WINDOW;\n}\n\n/**\n * Tells whether current environment supports Referrer Policy API\n * {@link supportsReferrerPolicy}.\n *\n * @returns Answer to the given question.\n * @deprecated This is no longer used and will be removed in a future major version.\n */\nfunction supportsReferrerPolicy() {\n  // Despite all stars in the sky saying that Edge supports old draft syntax, aka 'never', 'always', 'origin' and 'default'\n  // (see https://caniuse.com/#feat=referrer-policy),\n  // it doesn't. And it throws an exception instead of ignoring this parameter...\n  // REF: https://github.com/getsentry/raven-js/issues/1233\n\n  if (!_isFetchSupported()) {\n    return false;\n  }\n\n  try {\n    new Request('_', {\n      referrerPolicy: 'origin' ,\n    });\n    return true;\n  } catch {\n    return false;\n  }\n}\n\nexports.isNativeFunction = isNativeFunction;\nexports.supportsDOMError = supportsDOMError;\nexports.supportsDOMException = supportsDOMException;\nexports.supportsErrorEvent = supportsErrorEvent;\nexports.supportsFetch = supportsFetch;\nexports.supportsHistory = supportsHistory;\nexports.supportsNativeFetch = supportsNativeFetch;\nexports.supportsReferrerPolicy = supportsReferrerPolicy;\nexports.supportsReportingObserver = supportsReportingObserver;\n//# sourceMappingURL=supports.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvc3VwcG9ydHMuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsbUJBQW1CLG1CQUFPLENBQUMsbUlBQW1CO0FBQzlDLG9CQUFvQixtQkFBTyxDQUFDLDBJQUFtQjtBQUMvQyxrQkFBa0IsbUJBQU8sQ0FBQyxvSUFBZ0I7O0FBRTFDOztBQUVBO0FBQ0E7QUFDQSxJQUFJLHlCQUF5QjtBQUM3QjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLElBQUk7QUFDSjtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLElBQUksdUJBQXVCO0FBQzNCO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsSUFBSTtBQUNKO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsSUFBSSwyQkFBMkI7QUFDL0I7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxJQUFJO0FBQ0o7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQSxJQUFJLHNCQUFzQjtBQUMxQjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLElBQUksb0JBQW9CO0FBQ3hCO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLElBQUk7QUFDSjtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLDBDQUEwQyx1QkFBdUI7QUFDakU7O0FBRUE7QUFDQTtBQUNBLElBQUksMEJBQTBCO0FBQzlCO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLE1BQU07QUFDTjtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsSUFBSSxnQ0FBZ0M7QUFDcEM7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQSxJQUFJLDZCQUE2QjtBQUNqQztBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBLEtBQUs7QUFDTDtBQUNBLElBQUk7QUFDSjtBQUNBO0FBQ0E7O0FBRUEsd0JBQXdCO0FBQ3hCLHdCQUF3QjtBQUN4Qiw0QkFBNEI7QUFDNUIsMEJBQTBCO0FBQzFCLHFCQUFxQjtBQUNyQix1QkFBdUI7QUFDdkIsMkJBQTJCO0FBQzNCLDhCQUE4QjtBQUM5QixpQ0FBaUM7QUFDakMiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9zdXBwb3J0cy5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgZGVidWdCdWlsZCA9IHJlcXVpcmUoJy4uL2RlYnVnLWJ1aWxkLmpzJyk7XG5jb25zdCBkZWJ1Z0xvZ2dlciA9IHJlcXVpcmUoJy4vZGVidWctbG9nZ2VyLmpzJyk7XG5jb25zdCB3b3JsZHdpZGUgPSByZXF1aXJlKCcuL3dvcmxkd2lkZS5qcycpO1xuXG5jb25zdCBXSU5ET1cgPSB3b3JsZHdpZGUuR0xPQkFMX09CSiA7XG5cbi8qKlxuICogVGVsbHMgd2hldGhlciBjdXJyZW50IGVudmlyb25tZW50IHN1cHBvcnRzIEVycm9yRXZlbnQgb2JqZWN0c1xuICoge0BsaW5rIHN1cHBvcnRzRXJyb3JFdmVudH0uXG4gKlxuICogQHJldHVybnMgQW5zd2VyIHRvIHRoZSBnaXZlbiBxdWVzdGlvbi5cbiAqL1xuZnVuY3Rpb24gc3VwcG9ydHNFcnJvckV2ZW50KCkge1xuICB0cnkge1xuICAgIG5ldyBFcnJvckV2ZW50KCcnKTtcbiAgICByZXR1cm4gdHJ1ZTtcbiAgfSBjYXRjaCB7XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG59XG5cbi8qKlxuICogVGVsbHMgd2hldGhlciBjdXJyZW50IGVudmlyb25tZW50IHN1cHBvcnRzIERPTUVycm9yIG9iamVjdHNcbiAqIHtAbGluayBzdXBwb3J0c0RPTUVycm9yfS5cbiAqXG4gKiBAcmV0dXJucyBBbnN3ZXIgdG8gdGhlIGdpdmVuIHF1ZXN0aW9uLlxuICovXG5mdW5jdGlvbiBzdXBwb3J0c0RPTUVycm9yKCkge1xuICB0cnkge1xuICAgIC8vIENocm9tZTogVk04OToxIFVuY2F1Z2h0IFR5cGVFcnJvcjogRmFpbGVkIHRvIGNvbnN0cnVjdCAnRE9NRXJyb3InOlxuICAgIC8vIDEgYXJndW1lbnQgcmVxdWlyZWQsIGJ1dCBvbmx5IDAgcHJlc2VudC5cbiAgICAvLyBAdHMtZXhwZWN0LWVycm9yIEl0IHJlYWxseSBuZWVkcyAxIGFyZ3VtZW50LCBub3QgMC5cbiAgICBuZXcgRE9NRXJyb3IoJycpO1xuICAgIHJldHVybiB0cnVlO1xuICB9IGNhdGNoIHtcbiAgICByZXR1cm4gZmFsc2U7XG4gIH1cbn1cblxuLyoqXG4gKiBUZWxscyB3aGV0aGVyIGN1cnJlbnQgZW52aXJvbm1lbnQgc3VwcG9ydHMgRE9NRXhjZXB0aW9uIG9iamVjdHNcbiAqIHtAbGluayBzdXBwb3J0c0RPTUV4Y2VwdGlvbn0uXG4gKlxuICogQHJldHVybnMgQW5zd2VyIHRvIHRoZSBnaXZlbiBxdWVzdGlvbi5cbiAqL1xuZnVuY3Rpb24gc3VwcG9ydHNET01FeGNlcHRpb24oKSB7XG4gIHRyeSB7XG4gICAgbmV3IERPTUV4Y2VwdGlvbignJyk7XG4gICAgcmV0dXJuIHRydWU7XG4gIH0gY2F0Y2gge1xuICAgIHJldHVybiBmYWxzZTtcbiAgfVxufVxuXG4vKipcbiAqIFRlbGxzIHdoZXRoZXIgY3VycmVudCBlbnZpcm9ubWVudCBzdXBwb3J0cyBIaXN0b3J5IEFQSVxuICoge0BsaW5rIHN1cHBvcnRzSGlzdG9yeX0uXG4gKlxuICogQHJldHVybnMgQW5zd2VyIHRvIHRoZSBnaXZlbiBxdWVzdGlvbi5cbiAqL1xuZnVuY3Rpb24gc3VwcG9ydHNIaXN0b3J5KCkge1xuICByZXR1cm4gJ2hpc3RvcnknIGluIFdJTkRPVyAmJiAhIVdJTkRPVy5oaXN0b3J5O1xufVxuXG4vKipcbiAqIFRlbGxzIHdoZXRoZXIgY3VycmVudCBlbnZpcm9ubWVudCBzdXBwb3J0cyBGZXRjaCBBUElcbiAqIHtAbGluayBzdXBwb3J0c0ZldGNofS5cbiAqXG4gKiBAcmV0dXJucyBBbnN3ZXIgdG8gdGhlIGdpdmVuIHF1ZXN0aW9uLlxuICogQGRlcHJlY2F0ZWQgVGhpcyBpcyBubyBsb25nZXIgdXNlZCBhbmQgd2lsbCBiZSByZW1vdmVkIGluIGEgZnV0dXJlIG1ham9yIHZlcnNpb24uXG4gKi9cbmNvbnN0IHN1cHBvcnRzRmV0Y2ggPSBfaXNGZXRjaFN1cHBvcnRlZDtcblxuZnVuY3Rpb24gX2lzRmV0Y2hTdXBwb3J0ZWQoKSB7XG4gIGlmICghKCdmZXRjaCcgaW4gV0lORE9XKSkge1xuICAgIHJldHVybiBmYWxzZTtcbiAgfVxuXG4gIHRyeSB7XG4gICAgbmV3IEhlYWRlcnMoKTtcbiAgICBuZXcgUmVxdWVzdCgnaHR0cDovL3d3dy5leGFtcGxlLmNvbScpO1xuICAgIG5ldyBSZXNwb25zZSgpO1xuICAgIHJldHVybiB0cnVlO1xuICB9IGNhdGNoIHtcbiAgICByZXR1cm4gZmFsc2U7XG4gIH1cbn1cblxuLyoqXG4gKiBpc05hdGl2ZSBjaGVja3MgaWYgdGhlIGdpdmVuIGZ1bmN0aW9uIGlzIGEgbmF0aXZlIGltcGxlbWVudGF0aW9uXG4gKi9cbi8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvYmFuLXR5cGVzXG5mdW5jdGlvbiBpc05hdGl2ZUZ1bmN0aW9uKGZ1bmMpIHtcbiAgcmV0dXJuIGZ1bmMgJiYgL15mdW5jdGlvblxccytcXHcrXFwoXFwpXFxzK1xce1xccytcXFtuYXRpdmUgY29kZVxcXVxccytcXH0kLy50ZXN0KGZ1bmMudG9TdHJpbmcoKSk7XG59XG5cbi8qKlxuICogVGVsbHMgd2hldGhlciBjdXJyZW50IGVudmlyb25tZW50IHN1cHBvcnRzIEZldGNoIEFQSSBuYXRpdmVseVxuICoge0BsaW5rIHN1cHBvcnRzTmF0aXZlRmV0Y2h9LlxuICpcbiAqIEByZXR1cm5zIHRydWUgaWYgYHdpbmRvdy5mZXRjaGAgaXMgbmF0aXZlbHkgaW1wbGVtZW50ZWQsIGZhbHNlIG90aGVyd2lzZVxuICovXG5mdW5jdGlvbiBzdXBwb3J0c05hdGl2ZUZldGNoKCkge1xuICBpZiAodHlwZW9mIEVkZ2VSdW50aW1lID09PSAnc3RyaW5nJykge1xuICAgIHJldHVybiB0cnVlO1xuICB9XG5cbiAgaWYgKCFfaXNGZXRjaFN1cHBvcnRlZCgpKSB7XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG5cbiAgLy8gRmFzdCBwYXRoIHRvIGF2b2lkIERPTSBJL09cbiAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC91bmJvdW5kLW1ldGhvZFxuICBpZiAoaXNOYXRpdmVGdW5jdGlvbihXSU5ET1cuZmV0Y2gpKSB7XG4gICAgcmV0dXJuIHRydWU7XG4gIH1cblxuICAvLyB3aW5kb3cuZmV0Y2ggaXMgaW1wbGVtZW50ZWQsIGJ1dCBpcyBwb2x5ZmlsbGVkIG9yIGFscmVhZHkgd3JhcHBlZCAoZS5nOiBieSBhIGNocm9tZSBleHRlbnNpb24pXG4gIC8vIHNvIGNyZWF0ZSBhIFwicHVyZVwiIGlmcmFtZSB0byBzZWUgaWYgdGhhdCBoYXMgbmF0aXZlIGZldGNoXG4gIGxldCByZXN1bHQgPSBmYWxzZTtcbiAgY29uc3QgZG9jID0gV0lORE9XLmRvY3VtZW50O1xuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgZGVwcmVjYXRpb24vZGVwcmVjYXRpb25cbiAgaWYgKGRvYyAmJiB0eXBlb2YgKGRvYy5jcmVhdGVFbGVtZW50ICkgPT09ICdmdW5jdGlvbicpIHtcbiAgICB0cnkge1xuICAgICAgY29uc3Qgc2FuZGJveCA9IGRvYy5jcmVhdGVFbGVtZW50KCdpZnJhbWUnKTtcbiAgICAgIHNhbmRib3guaGlkZGVuID0gdHJ1ZTtcbiAgICAgIGRvYy5oZWFkLmFwcGVuZENoaWxkKHNhbmRib3gpO1xuICAgICAgaWYgKHNhbmRib3guY29udGVudFdpbmRvdz8uZmV0Y2gpIHtcbiAgICAgICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC91bmJvdW5kLW1ldGhvZFxuICAgICAgICByZXN1bHQgPSBpc05hdGl2ZUZ1bmN0aW9uKHNhbmRib3guY29udGVudFdpbmRvdy5mZXRjaCk7XG4gICAgICB9XG4gICAgICBkb2MuaGVhZC5yZW1vdmVDaGlsZChzYW5kYm94KTtcbiAgICB9IGNhdGNoIChlcnIpIHtcbiAgICAgIGRlYnVnQnVpbGQuREVCVUdfQlVJTEQgJiYgZGVidWdMb2dnZXIuZGVidWcud2FybignQ291bGQgbm90IGNyZWF0ZSBzYW5kYm94IGlmcmFtZSBmb3IgcHVyZSBmZXRjaCBjaGVjaywgYmFpbGluZyB0byB3aW5kb3cuZmV0Y2g6ICcsIGVycik7XG4gICAgfVxuICB9XG5cbiAgcmV0dXJuIHJlc3VsdDtcbn1cblxuLyoqXG4gKiBUZWxscyB3aGV0aGVyIGN1cnJlbnQgZW52aXJvbm1lbnQgc3VwcG9ydHMgUmVwb3J0aW5nT2JzZXJ2ZXIgQVBJXG4gKiB7QGxpbmsgc3VwcG9ydHNSZXBvcnRpbmdPYnNlcnZlcn0uXG4gKlxuICogQHJldHVybnMgQW5zd2VyIHRvIHRoZSBnaXZlbiBxdWVzdGlvbi5cbiAqL1xuZnVuY3Rpb24gc3VwcG9ydHNSZXBvcnRpbmdPYnNlcnZlcigpIHtcbiAgcmV0dXJuICdSZXBvcnRpbmdPYnNlcnZlcicgaW4gV0lORE9XO1xufVxuXG4vKipcbiAqIFRlbGxzIHdoZXRoZXIgY3VycmVudCBlbnZpcm9ubWVudCBzdXBwb3J0cyBSZWZlcnJlciBQb2xpY3kgQVBJXG4gKiB7QGxpbmsgc3VwcG9ydHNSZWZlcnJlclBvbGljeX0uXG4gKlxuICogQHJldHVybnMgQW5zd2VyIHRvIHRoZSBnaXZlbiBxdWVzdGlvbi5cbiAqIEBkZXByZWNhdGVkIFRoaXMgaXMgbm8gbG9uZ2VyIHVzZWQgYW5kIHdpbGwgYmUgcmVtb3ZlZCBpbiBhIGZ1dHVyZSBtYWpvciB2ZXJzaW9uLlxuICovXG5mdW5jdGlvbiBzdXBwb3J0c1JlZmVycmVyUG9saWN5KCkge1xuICAvLyBEZXNwaXRlIGFsbCBzdGFycyBpbiB0aGUgc2t5IHNheWluZyB0aGF0IEVkZ2Ugc3VwcG9ydHMgb2xkIGRyYWZ0IHN5bnRheCwgYWthICduZXZlcicsICdhbHdheXMnLCAnb3JpZ2luJyBhbmQgJ2RlZmF1bHQnXG4gIC8vIChzZWUgaHR0cHM6Ly9jYW5pdXNlLmNvbS8jZmVhdD1yZWZlcnJlci1wb2xpY3kpLFxuICAvLyBpdCBkb2Vzbid0LiBBbmQgaXQgdGhyb3dzIGFuIGV4Y2VwdGlvbiBpbnN0ZWFkIG9mIGlnbm9yaW5nIHRoaXMgcGFyYW1ldGVyLi4uXG4gIC8vIFJFRjogaHR0cHM6Ly9naXRodWIuY29tL2dldHNlbnRyeS9yYXZlbi1qcy9pc3N1ZXMvMTIzM1xuXG4gIGlmICghX2lzRmV0Y2hTdXBwb3J0ZWQoKSkge1xuICAgIHJldHVybiBmYWxzZTtcbiAgfVxuXG4gIHRyeSB7XG4gICAgbmV3IFJlcXVlc3QoJ18nLCB7XG4gICAgICByZWZlcnJlclBvbGljeTogJ29yaWdpbicgLFxuICAgIH0pO1xuICAgIHJldHVybiB0cnVlO1xuICB9IGNhdGNoIHtcbiAgICByZXR1cm4gZmFsc2U7XG4gIH1cbn1cblxuZXhwb3J0cy5pc05hdGl2ZUZ1bmN0aW9uID0gaXNOYXRpdmVGdW5jdGlvbjtcbmV4cG9ydHMuc3VwcG9ydHNET01FcnJvciA9IHN1cHBvcnRzRE9NRXJyb3I7XG5leHBvcnRzLnN1cHBvcnRzRE9NRXhjZXB0aW9uID0gc3VwcG9ydHNET01FeGNlcHRpb247XG5leHBvcnRzLnN1cHBvcnRzRXJyb3JFdmVudCA9IHN1cHBvcnRzRXJyb3JFdmVudDtcbmV4cG9ydHMuc3VwcG9ydHNGZXRjaCA9IHN1cHBvcnRzRmV0Y2g7XG5leHBvcnRzLnN1cHBvcnRzSGlzdG9yeSA9IHN1cHBvcnRzSGlzdG9yeTtcbmV4cG9ydHMuc3VwcG9ydHNOYXRpdmVGZXRjaCA9IHN1cHBvcnRzTmF0aXZlRmV0Y2g7XG5leHBvcnRzLnN1cHBvcnRzUmVmZXJyZXJQb2xpY3kgPSBzdXBwb3J0c1JlZmVycmVyUG9saWN5O1xuZXhwb3J0cy5zdXBwb3J0c1JlcG9ydGluZ09ic2VydmVyID0gc3VwcG9ydHNSZXBvcnRpbmdPYnNlcnZlcjtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPXN1cHBvcnRzLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/supports.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/syncpromise.js":
/*!*********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/syncpromise.js ***!
  \*********************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst is = __webpack_require__(/*! ./is.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js\");\n\n/* eslint-disable @typescript-eslint/no-explicit-any */\n\n/** SyncPromise internal states */\nconst STATE_PENDING = 0;\nconst STATE_RESOLVED = 1;\nconst STATE_REJECTED = 2;\n\n/**\n * Creates a resolved sync promise.\n *\n * @param value the value to resolve the promise with\n * @returns the resolved sync promise\n */\nfunction resolvedSyncPromise(value) {\n  return new SyncPromise(resolve => {\n    resolve(value);\n  });\n}\n\n/**\n * Creates a rejected sync promise.\n *\n * @param value the value to reject the promise with\n * @returns the rejected sync promise\n */\nfunction rejectedSyncPromise(reason) {\n  return new SyncPromise((_, reject) => {\n    reject(reason);\n  });\n}\n\n/**\n * Thenable class that behaves like a Promise and follows it's interface\n * but is not async internally\n */\nclass SyncPromise {\n\n   constructor(executor) {\n    this._state = STATE_PENDING;\n    this._handlers = [];\n\n    this._runExecutor(executor);\n  }\n\n  /** @inheritdoc */\n   then(\n    onfulfilled,\n    onrejected,\n  ) {\n    return new SyncPromise((resolve, reject) => {\n      this._handlers.push([\n        false,\n        result => {\n          if (!onfulfilled) {\n            // TODO: ¯\\_(ツ)_/¯\n            // TODO: FIXME\n            resolve(result );\n          } else {\n            try {\n              resolve(onfulfilled(result));\n            } catch (e) {\n              reject(e);\n            }\n          }\n        },\n        reason => {\n          if (!onrejected) {\n            reject(reason);\n          } else {\n            try {\n              resolve(onrejected(reason));\n            } catch (e) {\n              reject(e);\n            }\n          }\n        },\n      ]);\n      this._executeHandlers();\n    });\n  }\n\n  /** @inheritdoc */\n   catch(\n    onrejected,\n  ) {\n    return this.then(val => val, onrejected);\n  }\n\n  /** @inheritdoc */\n   finally(onfinally) {\n    return new SyncPromise((resolve, reject) => {\n      let val;\n      let isRejected;\n\n      return this.then(\n        value => {\n          isRejected = false;\n          val = value;\n          if (onfinally) {\n            onfinally();\n          }\n        },\n        reason => {\n          isRejected = true;\n          val = reason;\n          if (onfinally) {\n            onfinally();\n          }\n        },\n      ).then(() => {\n        if (isRejected) {\n          reject(val);\n          return;\n        }\n\n        resolve(val );\n      });\n    });\n  }\n\n  /** Excute the resolve/reject handlers. */\n   _executeHandlers() {\n    if (this._state === STATE_PENDING) {\n      return;\n    }\n\n    const cachedHandlers = this._handlers.slice();\n    this._handlers = [];\n\n    cachedHandlers.forEach(handler => {\n      if (handler[0]) {\n        return;\n      }\n\n      if (this._state === STATE_RESOLVED) {\n        handler[1](this._value );\n      }\n\n      if (this._state === STATE_REJECTED) {\n        handler[2](this._value);\n      }\n\n      handler[0] = true;\n    });\n  }\n\n  /** Run the executor for the SyncPromise. */\n   _runExecutor(executor) {\n    const setResult = (state, value) => {\n      if (this._state !== STATE_PENDING) {\n        return;\n      }\n\n      if (is.isThenable(value)) {\n        void (value ).then(resolve, reject);\n        return;\n      }\n\n      this._state = state;\n      this._value = value;\n\n      this._executeHandlers();\n    };\n\n    const resolve = (value) => {\n      setResult(STATE_RESOLVED, value);\n    };\n\n    const reject = (reason) => {\n      setResult(STATE_REJECTED, reason);\n    };\n\n    try {\n      executor(resolve, reject);\n    } catch (e) {\n      reject(e);\n    }\n  }\n}\n\nexports.SyncPromise = SyncPromise;\nexports.rejectedSyncPromise = rejectedSyncPromise;\nexports.resolvedSyncPromise = resolvedSyncPromise;\n//# sourceMappingURL=syncpromise.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvc3luY3Byb21pc2UuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsV0FBVyxtQkFBTyxDQUFDLHNIQUFTOztBQUU1Qjs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxHQUFHO0FBQ0g7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsR0FBRztBQUNIOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxZQUFZO0FBQ1o7QUFDQTtBQUNBLGNBQWM7QUFDZDtBQUNBO0FBQ0E7QUFDQSxTQUFTO0FBQ1Q7QUFDQTtBQUNBO0FBQ0EsWUFBWTtBQUNaO0FBQ0E7QUFDQSxjQUFjO0FBQ2Q7QUFDQTtBQUNBO0FBQ0EsU0FBUztBQUNUO0FBQ0E7QUFDQSxLQUFLO0FBQ0w7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxTQUFTO0FBQ1Q7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsU0FBUztBQUNUO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQSxPQUFPO0FBQ1AsS0FBSztBQUNMOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0EsS0FBSztBQUNMOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsTUFBTTtBQUNOO0FBQ0E7QUFDQTtBQUNBOztBQUVBLG1CQUFtQjtBQUNuQiwyQkFBMkI7QUFDM0IsMkJBQTJCO0FBQzNCIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvc3luY3Byb21pc2UuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGlzID0gcmVxdWlyZSgnLi9pcy5qcycpO1xuXG4vKiBlc2xpbnQtZGlzYWJsZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tZXhwbGljaXQtYW55ICovXG5cbi8qKiBTeW5jUHJvbWlzZSBpbnRlcm5hbCBzdGF0ZXMgKi9cbmNvbnN0IFNUQVRFX1BFTkRJTkcgPSAwO1xuY29uc3QgU1RBVEVfUkVTT0xWRUQgPSAxO1xuY29uc3QgU1RBVEVfUkVKRUNURUQgPSAyO1xuXG4vKipcbiAqIENyZWF0ZXMgYSByZXNvbHZlZCBzeW5jIHByb21pc2UuXG4gKlxuICogQHBhcmFtIHZhbHVlIHRoZSB2YWx1ZSB0byByZXNvbHZlIHRoZSBwcm9taXNlIHdpdGhcbiAqIEByZXR1cm5zIHRoZSByZXNvbHZlZCBzeW5jIHByb21pc2VcbiAqL1xuZnVuY3Rpb24gcmVzb2x2ZWRTeW5jUHJvbWlzZSh2YWx1ZSkge1xuICByZXR1cm4gbmV3IFN5bmNQcm9taXNlKHJlc29sdmUgPT4ge1xuICAgIHJlc29sdmUodmFsdWUpO1xuICB9KTtcbn1cblxuLyoqXG4gKiBDcmVhdGVzIGEgcmVqZWN0ZWQgc3luYyBwcm9taXNlLlxuICpcbiAqIEBwYXJhbSB2YWx1ZSB0aGUgdmFsdWUgdG8gcmVqZWN0IHRoZSBwcm9taXNlIHdpdGhcbiAqIEByZXR1cm5zIHRoZSByZWplY3RlZCBzeW5jIHByb21pc2VcbiAqL1xuZnVuY3Rpb24gcmVqZWN0ZWRTeW5jUHJvbWlzZShyZWFzb24pIHtcbiAgcmV0dXJuIG5ldyBTeW5jUHJvbWlzZSgoXywgcmVqZWN0KSA9PiB7XG4gICAgcmVqZWN0KHJlYXNvbik7XG4gIH0pO1xufVxuXG4vKipcbiAqIFRoZW5hYmxlIGNsYXNzIHRoYXQgYmVoYXZlcyBsaWtlIGEgUHJvbWlzZSBhbmQgZm9sbG93cyBpdCdzIGludGVyZmFjZVxuICogYnV0IGlzIG5vdCBhc3luYyBpbnRlcm5hbGx5XG4gKi9cbmNsYXNzIFN5bmNQcm9taXNlIHtcblxuICAgY29uc3RydWN0b3IoZXhlY3V0b3IpIHtcbiAgICB0aGlzLl9zdGF0ZSA9IFNUQVRFX1BFTkRJTkc7XG4gICAgdGhpcy5faGFuZGxlcnMgPSBbXTtcblxuICAgIHRoaXMuX3J1bkV4ZWN1dG9yKGV4ZWN1dG9yKTtcbiAgfVxuXG4gIC8qKiBAaW5oZXJpdGRvYyAqL1xuICAgdGhlbihcbiAgICBvbmZ1bGZpbGxlZCxcbiAgICBvbnJlamVjdGVkLFxuICApIHtcbiAgICByZXR1cm4gbmV3IFN5bmNQcm9taXNlKChyZXNvbHZlLCByZWplY3QpID0+IHtcbiAgICAgIHRoaXMuX2hhbmRsZXJzLnB1c2goW1xuICAgICAgICBmYWxzZSxcbiAgICAgICAgcmVzdWx0ID0+IHtcbiAgICAgICAgICBpZiAoIW9uZnVsZmlsbGVkKSB7XG4gICAgICAgICAgICAvLyBUT0RPOiDCr1xcXyjjg4QpXy/Cr1xuICAgICAgICAgICAgLy8gVE9ETzogRklYTUVcbiAgICAgICAgICAgIHJlc29sdmUocmVzdWx0ICk7XG4gICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgIHRyeSB7XG4gICAgICAgICAgICAgIHJlc29sdmUob25mdWxmaWxsZWQocmVzdWx0KSk7XG4gICAgICAgICAgICB9IGNhdGNoIChlKSB7XG4gICAgICAgICAgICAgIHJlamVjdChlKTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgICB9XG4gICAgICAgIH0sXG4gICAgICAgIHJlYXNvbiA9PiB7XG4gICAgICAgICAgaWYgKCFvbnJlamVjdGVkKSB7XG4gICAgICAgICAgICByZWplY3QocmVhc29uKTtcbiAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgdHJ5IHtcbiAgICAgICAgICAgICAgcmVzb2x2ZShvbnJlamVjdGVkKHJlYXNvbikpO1xuICAgICAgICAgICAgfSBjYXRjaCAoZSkge1xuICAgICAgICAgICAgICByZWplY3QoZSk7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgfVxuICAgICAgICB9LFxuICAgICAgXSk7XG4gICAgICB0aGlzLl9leGVjdXRlSGFuZGxlcnMoKTtcbiAgICB9KTtcbiAgfVxuXG4gIC8qKiBAaW5oZXJpdGRvYyAqL1xuICAgY2F0Y2goXG4gICAgb25yZWplY3RlZCxcbiAgKSB7XG4gICAgcmV0dXJuIHRoaXMudGhlbih2YWwgPT4gdmFsLCBvbnJlamVjdGVkKTtcbiAgfVxuXG4gIC8qKiBAaW5oZXJpdGRvYyAqL1xuICAgZmluYWxseShvbmZpbmFsbHkpIHtcbiAgICByZXR1cm4gbmV3IFN5bmNQcm9taXNlKChyZXNvbHZlLCByZWplY3QpID0+IHtcbiAgICAgIGxldCB2YWw7XG4gICAgICBsZXQgaXNSZWplY3RlZDtcblxuICAgICAgcmV0dXJuIHRoaXMudGhlbihcbiAgICAgICAgdmFsdWUgPT4ge1xuICAgICAgICAgIGlzUmVqZWN0ZWQgPSBmYWxzZTtcbiAgICAgICAgICB2YWwgPSB2YWx1ZTtcbiAgICAgICAgICBpZiAob25maW5hbGx5KSB7XG4gICAgICAgICAgICBvbmZpbmFsbHkoKTtcbiAgICAgICAgICB9XG4gICAgICAgIH0sXG4gICAgICAgIHJlYXNvbiA9PiB7XG4gICAgICAgICAgaXNSZWplY3RlZCA9IHRydWU7XG4gICAgICAgICAgdmFsID0gcmVhc29uO1xuICAgICAgICAgIGlmIChvbmZpbmFsbHkpIHtcbiAgICAgICAgICAgIG9uZmluYWxseSgpO1xuICAgICAgICAgIH1cbiAgICAgICAgfSxcbiAgICAgICkudGhlbigoKSA9PiB7XG4gICAgICAgIGlmIChpc1JlamVjdGVkKSB7XG4gICAgICAgICAgcmVqZWN0KHZhbCk7XG4gICAgICAgICAgcmV0dXJuO1xuICAgICAgICB9XG5cbiAgICAgICAgcmVzb2x2ZSh2YWwgKTtcbiAgICAgIH0pO1xuICAgIH0pO1xuICB9XG5cbiAgLyoqIEV4Y3V0ZSB0aGUgcmVzb2x2ZS9yZWplY3QgaGFuZGxlcnMuICovXG4gICBfZXhlY3V0ZUhhbmRsZXJzKCkge1xuICAgIGlmICh0aGlzLl9zdGF0ZSA9PT0gU1RBVEVfUEVORElORykge1xuICAgICAgcmV0dXJuO1xuICAgIH1cblxuICAgIGNvbnN0IGNhY2hlZEhhbmRsZXJzID0gdGhpcy5faGFuZGxlcnMuc2xpY2UoKTtcbiAgICB0aGlzLl9oYW5kbGVycyA9IFtdO1xuXG4gICAgY2FjaGVkSGFuZGxlcnMuZm9yRWFjaChoYW5kbGVyID0+IHtcbiAgICAgIGlmIChoYW5kbGVyWzBdKSB7XG4gICAgICAgIHJldHVybjtcbiAgICAgIH1cblxuICAgICAgaWYgKHRoaXMuX3N0YXRlID09PSBTVEFURV9SRVNPTFZFRCkge1xuICAgICAgICBoYW5kbGVyWzFdKHRoaXMuX3ZhbHVlICk7XG4gICAgICB9XG5cbiAgICAgIGlmICh0aGlzLl9zdGF0ZSA9PT0gU1RBVEVfUkVKRUNURUQpIHtcbiAgICAgICAgaGFuZGxlclsyXSh0aGlzLl92YWx1ZSk7XG4gICAgICB9XG5cbiAgICAgIGhhbmRsZXJbMF0gPSB0cnVlO1xuICAgIH0pO1xuICB9XG5cbiAgLyoqIFJ1biB0aGUgZXhlY3V0b3IgZm9yIHRoZSBTeW5jUHJvbWlzZS4gKi9cbiAgIF9ydW5FeGVjdXRvcihleGVjdXRvcikge1xuICAgIGNvbnN0IHNldFJlc3VsdCA9IChzdGF0ZSwgdmFsdWUpID0+IHtcbiAgICAgIGlmICh0aGlzLl9zdGF0ZSAhPT0gU1RBVEVfUEVORElORykge1xuICAgICAgICByZXR1cm47XG4gICAgICB9XG5cbiAgICAgIGlmIChpcy5pc1RoZW5hYmxlKHZhbHVlKSkge1xuICAgICAgICB2b2lkICh2YWx1ZSApLnRoZW4ocmVzb2x2ZSwgcmVqZWN0KTtcbiAgICAgICAgcmV0dXJuO1xuICAgICAgfVxuXG4gICAgICB0aGlzLl9zdGF0ZSA9IHN0YXRlO1xuICAgICAgdGhpcy5fdmFsdWUgPSB2YWx1ZTtcblxuICAgICAgdGhpcy5fZXhlY3V0ZUhhbmRsZXJzKCk7XG4gICAgfTtcblxuICAgIGNvbnN0IHJlc29sdmUgPSAodmFsdWUpID0+IHtcbiAgICAgIHNldFJlc3VsdChTVEFURV9SRVNPTFZFRCwgdmFsdWUpO1xuICAgIH07XG5cbiAgICBjb25zdCByZWplY3QgPSAocmVhc29uKSA9PiB7XG4gICAgICBzZXRSZXN1bHQoU1RBVEVfUkVKRUNURUQsIHJlYXNvbik7XG4gICAgfTtcblxuICAgIHRyeSB7XG4gICAgICBleGVjdXRvcihyZXNvbHZlLCByZWplY3QpO1xuICAgIH0gY2F0Y2ggKGUpIHtcbiAgICAgIHJlamVjdChlKTtcbiAgICB9XG4gIH1cbn1cblxuZXhwb3J0cy5TeW5jUHJvbWlzZSA9IFN5bmNQcm9taXNlO1xuZXhwb3J0cy5yZWplY3RlZFN5bmNQcm9taXNlID0gcmVqZWN0ZWRTeW5jUHJvbWlzZTtcbmV4cG9ydHMucmVzb2x2ZWRTeW5jUHJvbWlzZSA9IHJlc29sdmVkU3luY1Byb21pc2U7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1zeW5jcHJvbWlzZS5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/syncpromise.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/time.js":
/*!**************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/time.js ***!
  \**************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst worldwide = __webpack_require__(/*! ./worldwide.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/worldwide.js\");\n\nconst ONE_SECOND_IN_MS = 1000;\n\n/**\n * A partial definition of the [Performance Web API]{@link https://developer.mozilla.org/en-US/docs/Web/API/Performance}\n * for accessing a high-resolution monotonic clock.\n */\n\n/**\n * Returns a timestamp in seconds since the UNIX epoch using the Date API.\n */\nfunction dateTimestampInSeconds() {\n  return Date.now() / ONE_SECOND_IN_MS;\n}\n\n/**\n * Returns a wrapper around the native Performance API browser implementation, or undefined for browsers that do not\n * support the API.\n *\n * Wrapping the native API works around differences in behavior from different browsers.\n */\nfunction createUnixTimestampInSecondsFunc() {\n  const { performance } = worldwide.GLOBAL_OBJ ;\n  // Some browser and environments don't have a performance or timeOrigin, so we fallback to\n  // using Date.now() to compute the starting time.\n  if (!performance?.now || !performance.timeOrigin) {\n    return dateTimestampInSeconds;\n  }\n\n  const timeOrigin = performance.timeOrigin;\n\n  // performance.now() is a monotonic clock, which means it starts at 0 when the process begins. To get the current\n  // wall clock time (actual UNIX timestamp), we need to add the starting time origin and the current time elapsed.\n  //\n  // TODO: This does not account for the case where the monotonic clock that powers performance.now() drifts from the\n  // wall clock time, which causes the returned timestamp to be inaccurate. We should investigate how to detect and\n  // correct for this.\n  // See: https://github.com/getsentry/sentry-javascript/issues/2590\n  // See: https://github.com/mdn/content/issues/4713\n  // See: https://dev.to/noamr/when-a-millisecond-is-not-a-millisecond-3h6\n  return () => {\n    return (timeOrigin + performance.now()) / ONE_SECOND_IN_MS;\n  };\n}\n\nlet _cachedTimestampInSeconds;\n\n/**\n * Returns a timestamp in seconds since the UNIX epoch using either the Performance or Date APIs, depending on the\n * availability of the Performance API.\n *\n * BUG: Note that because of how browsers implement the Performance API, the clock might stop when the computer is\n * asleep. This creates a skew between `dateTimestampInSeconds` and `timestampInSeconds`. The\n * skew can grow to arbitrary amounts like days, weeks or months.\n * See https://github.com/getsentry/sentry-javascript/issues/2590.\n */\nfunction timestampInSeconds() {\n  // We store this in a closure so that we don't have to create a new function every time this is called.\n  const func = _cachedTimestampInSeconds ?? (_cachedTimestampInSeconds = createUnixTimestampInSecondsFunc());\n  return func();\n}\n\n/**\n * Cached result of getBrowserTimeOrigin.\n */\nlet cachedTimeOrigin;\n\n/**\n * Gets the time origin and the mode used to determine it.\n */\nfunction getBrowserTimeOrigin() {\n  // Unfortunately browsers may report an inaccurate time origin data, through either performance.timeOrigin or\n  // performance.timing.navigationStart, which results in poor results in performance data. We only treat time origin\n  // data as reliable if they are within a reasonable threshold of the current time.\n\n  const { performance } = worldwide.GLOBAL_OBJ ;\n  if (!performance?.now) {\n    return [undefined, 'none'];\n  }\n\n  const threshold = 3600 * 1000;\n  const performanceNow = performance.now();\n  const dateNow = Date.now();\n\n  // if timeOrigin isn't available set delta to threshold so it isn't used\n  const timeOriginDelta = performance.timeOrigin\n    ? Math.abs(performance.timeOrigin + performanceNow - dateNow)\n    : threshold;\n  const timeOriginIsReliable = timeOriginDelta < threshold;\n\n  // While performance.timing.navigationStart is deprecated in favor of performance.timeOrigin, performance.timeOrigin\n  // is not as widely supported. Namely, performance.timeOrigin is undefined in Safari as of writing.\n  // Also as of writing, performance.timing is not available in Web Workers in mainstream browsers, so it is not always\n  // a valid fallback. In the absence of an initial time provided by the browser, fallback to the current time from the\n  // Date API.\n  // eslint-disable-next-line deprecation/deprecation\n  const navigationStart = performance.timing?.navigationStart;\n  const hasNavigationStart = typeof navigationStart === 'number';\n  // if navigationStart isn't available set delta to threshold so it isn't used\n  const navigationStartDelta = hasNavigationStart ? Math.abs(navigationStart + performanceNow - dateNow) : threshold;\n  const navigationStartIsReliable = navigationStartDelta < threshold;\n\n  if (timeOriginIsReliable || navigationStartIsReliable) {\n    // Use the more reliable time origin\n    if (timeOriginDelta <= navigationStartDelta) {\n      return [performance.timeOrigin, 'timeOrigin'];\n    } else {\n      return [navigationStart, 'navigationStart'];\n    }\n  }\n\n  // Either both timeOrigin and navigationStart are skewed or neither is available, fallback to Date.\n  return [dateNow, 'dateNow'];\n}\n\n/**\n * The number of milliseconds since the UNIX epoch. This value is only usable in a browser, and only when the\n * performance API is available.\n */\nfunction browserPerformanceTimeOrigin() {\n  if (!cachedTimeOrigin) {\n    cachedTimeOrigin = getBrowserTimeOrigin();\n  }\n\n  return cachedTimeOrigin[0];\n}\n\nexports.browserPerformanceTimeOrigin = browserPerformanceTimeOrigin;\nexports.dateTimestampInSeconds = dateTimestampInSeconds;\nexports.timestampInSeconds = timestampInSeconds;\n//# sourceMappingURL=time.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvdGltZS5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxrQkFBa0IsbUJBQU8sQ0FBQyxvSUFBZ0I7O0FBRTFDOztBQUVBO0FBQ0EscURBQXFEO0FBQ3JEO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsVUFBVSxjQUFjO0FBQ3hCO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSxVQUFVLGNBQWM7QUFDeEI7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQSxNQUFNO0FBQ047QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUEsb0NBQW9DO0FBQ3BDLDhCQUE4QjtBQUM5QiwwQkFBMEI7QUFDMUIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy90aW1lLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCB3b3JsZHdpZGUgPSByZXF1aXJlKCcuL3dvcmxkd2lkZS5qcycpO1xuXG5jb25zdCBPTkVfU0VDT05EX0lOX01TID0gMTAwMDtcblxuLyoqXG4gKiBBIHBhcnRpYWwgZGVmaW5pdGlvbiBvZiB0aGUgW1BlcmZvcm1hbmNlIFdlYiBBUElde0BsaW5rIGh0dHBzOi8vZGV2ZWxvcGVyLm1vemlsbGEub3JnL2VuLVVTL2RvY3MvV2ViL0FQSS9QZXJmb3JtYW5jZX1cbiAqIGZvciBhY2Nlc3NpbmcgYSBoaWdoLXJlc29sdXRpb24gbW9ub3RvbmljIGNsb2NrLlxuICovXG5cbi8qKlxuICogUmV0dXJucyBhIHRpbWVzdGFtcCBpbiBzZWNvbmRzIHNpbmNlIHRoZSBVTklYIGVwb2NoIHVzaW5nIHRoZSBEYXRlIEFQSS5cbiAqL1xuZnVuY3Rpb24gZGF0ZVRpbWVzdGFtcEluU2Vjb25kcygpIHtcbiAgcmV0dXJuIERhdGUubm93KCkgLyBPTkVfU0VDT05EX0lOX01TO1xufVxuXG4vKipcbiAqIFJldHVybnMgYSB3cmFwcGVyIGFyb3VuZCB0aGUgbmF0aXZlIFBlcmZvcm1hbmNlIEFQSSBicm93c2VyIGltcGxlbWVudGF0aW9uLCBvciB1bmRlZmluZWQgZm9yIGJyb3dzZXJzIHRoYXQgZG8gbm90XG4gKiBzdXBwb3J0IHRoZSBBUEkuXG4gKlxuICogV3JhcHBpbmcgdGhlIG5hdGl2ZSBBUEkgd29ya3MgYXJvdW5kIGRpZmZlcmVuY2VzIGluIGJlaGF2aW9yIGZyb20gZGlmZmVyZW50IGJyb3dzZXJzLlxuICovXG5mdW5jdGlvbiBjcmVhdGVVbml4VGltZXN0YW1wSW5TZWNvbmRzRnVuYygpIHtcbiAgY29uc3QgeyBwZXJmb3JtYW5jZSB9ID0gd29ybGR3aWRlLkdMT0JBTF9PQkogO1xuICAvLyBTb21lIGJyb3dzZXIgYW5kIGVudmlyb25tZW50cyBkb24ndCBoYXZlIGEgcGVyZm9ybWFuY2Ugb3IgdGltZU9yaWdpbiwgc28gd2UgZmFsbGJhY2sgdG9cbiAgLy8gdXNpbmcgRGF0ZS5ub3coKSB0byBjb21wdXRlIHRoZSBzdGFydGluZyB0aW1lLlxuICBpZiAoIXBlcmZvcm1hbmNlPy5ub3cgfHwgIXBlcmZvcm1hbmNlLnRpbWVPcmlnaW4pIHtcbiAgICByZXR1cm4gZGF0ZVRpbWVzdGFtcEluU2Vjb25kcztcbiAgfVxuXG4gIGNvbnN0IHRpbWVPcmlnaW4gPSBwZXJmb3JtYW5jZS50aW1lT3JpZ2luO1xuXG4gIC8vIHBlcmZvcm1hbmNlLm5vdygpIGlzIGEgbW9ub3RvbmljIGNsb2NrLCB3aGljaCBtZWFucyBpdCBzdGFydHMgYXQgMCB3aGVuIHRoZSBwcm9jZXNzIGJlZ2lucy4gVG8gZ2V0IHRoZSBjdXJyZW50XG4gIC8vIHdhbGwgY2xvY2sgdGltZSAoYWN0dWFsIFVOSVggdGltZXN0YW1wKSwgd2UgbmVlZCB0byBhZGQgdGhlIHN0YXJ0aW5nIHRpbWUgb3JpZ2luIGFuZCB0aGUgY3VycmVudCB0aW1lIGVsYXBzZWQuXG4gIC8vXG4gIC8vIFRPRE86IFRoaXMgZG9lcyBub3QgYWNjb3VudCBmb3IgdGhlIGNhc2Ugd2hlcmUgdGhlIG1vbm90b25pYyBjbG9jayB0aGF0IHBvd2VycyBwZXJmb3JtYW5jZS5ub3coKSBkcmlmdHMgZnJvbSB0aGVcbiAgLy8gd2FsbCBjbG9jayB0aW1lLCB3aGljaCBjYXVzZXMgdGhlIHJldHVybmVkIHRpbWVzdGFtcCB0byBiZSBpbmFjY3VyYXRlLiBXZSBzaG91bGQgaW52ZXN0aWdhdGUgaG93IHRvIGRldGVjdCBhbmRcbiAgLy8gY29ycmVjdCBmb3IgdGhpcy5cbiAgLy8gU2VlOiBodHRwczovL2dpdGh1Yi5jb20vZ2V0c2VudHJ5L3NlbnRyeS1qYXZhc2NyaXB0L2lzc3Vlcy8yNTkwXG4gIC8vIFNlZTogaHR0cHM6Ly9naXRodWIuY29tL21kbi9jb250ZW50L2lzc3Vlcy80NzEzXG4gIC8vIFNlZTogaHR0cHM6Ly9kZXYudG8vbm9hbXIvd2hlbi1hLW1pbGxpc2Vjb25kLWlzLW5vdC1hLW1pbGxpc2Vjb25kLTNoNlxuICByZXR1cm4gKCkgPT4ge1xuICAgIHJldHVybiAodGltZU9yaWdpbiArIHBlcmZvcm1hbmNlLm5vdygpKSAvIE9ORV9TRUNPTkRfSU5fTVM7XG4gIH07XG59XG5cbmxldCBfY2FjaGVkVGltZXN0YW1wSW5TZWNvbmRzO1xuXG4vKipcbiAqIFJldHVybnMgYSB0aW1lc3RhbXAgaW4gc2Vjb25kcyBzaW5jZSB0aGUgVU5JWCBlcG9jaCB1c2luZyBlaXRoZXIgdGhlIFBlcmZvcm1hbmNlIG9yIERhdGUgQVBJcywgZGVwZW5kaW5nIG9uIHRoZVxuICogYXZhaWxhYmlsaXR5IG9mIHRoZSBQZXJmb3JtYW5jZSBBUEkuXG4gKlxuICogQlVHOiBOb3RlIHRoYXQgYmVjYXVzZSBvZiBob3cgYnJvd3NlcnMgaW1wbGVtZW50IHRoZSBQZXJmb3JtYW5jZSBBUEksIHRoZSBjbG9jayBtaWdodCBzdG9wIHdoZW4gdGhlIGNvbXB1dGVyIGlzXG4gKiBhc2xlZXAuIFRoaXMgY3JlYXRlcyBhIHNrZXcgYmV0d2VlbiBgZGF0ZVRpbWVzdGFtcEluU2Vjb25kc2AgYW5kIGB0aW1lc3RhbXBJblNlY29uZHNgLiBUaGVcbiAqIHNrZXcgY2FuIGdyb3cgdG8gYXJiaXRyYXJ5IGFtb3VudHMgbGlrZSBkYXlzLCB3ZWVrcyBvciBtb250aHMuXG4gKiBTZWUgaHR0cHM6Ly9naXRodWIuY29tL2dldHNlbnRyeS9zZW50cnktamF2YXNjcmlwdC9pc3N1ZXMvMjU5MC5cbiAqL1xuZnVuY3Rpb24gdGltZXN0YW1wSW5TZWNvbmRzKCkge1xuICAvLyBXZSBzdG9yZSB0aGlzIGluIGEgY2xvc3VyZSBzbyB0aGF0IHdlIGRvbid0IGhhdmUgdG8gY3JlYXRlIGEgbmV3IGZ1bmN0aW9uIGV2ZXJ5IHRpbWUgdGhpcyBpcyBjYWxsZWQuXG4gIGNvbnN0IGZ1bmMgPSBfY2FjaGVkVGltZXN0YW1wSW5TZWNvbmRzID8/IChfY2FjaGVkVGltZXN0YW1wSW5TZWNvbmRzID0gY3JlYXRlVW5peFRpbWVzdGFtcEluU2Vjb25kc0Z1bmMoKSk7XG4gIHJldHVybiBmdW5jKCk7XG59XG5cbi8qKlxuICogQ2FjaGVkIHJlc3VsdCBvZiBnZXRCcm93c2VyVGltZU9yaWdpbi5cbiAqL1xubGV0IGNhY2hlZFRpbWVPcmlnaW47XG5cbi8qKlxuICogR2V0cyB0aGUgdGltZSBvcmlnaW4gYW5kIHRoZSBtb2RlIHVzZWQgdG8gZGV0ZXJtaW5lIGl0LlxuICovXG5mdW5jdGlvbiBnZXRCcm93c2VyVGltZU9yaWdpbigpIHtcbiAgLy8gVW5mb3J0dW5hdGVseSBicm93c2VycyBtYXkgcmVwb3J0IGFuIGluYWNjdXJhdGUgdGltZSBvcmlnaW4gZGF0YSwgdGhyb3VnaCBlaXRoZXIgcGVyZm9ybWFuY2UudGltZU9yaWdpbiBvclxuICAvLyBwZXJmb3JtYW5jZS50aW1pbmcubmF2aWdhdGlvblN0YXJ0LCB3aGljaCByZXN1bHRzIGluIHBvb3IgcmVzdWx0cyBpbiBwZXJmb3JtYW5jZSBkYXRhLiBXZSBvbmx5IHRyZWF0IHRpbWUgb3JpZ2luXG4gIC8vIGRhdGEgYXMgcmVsaWFibGUgaWYgdGhleSBhcmUgd2l0aGluIGEgcmVhc29uYWJsZSB0aHJlc2hvbGQgb2YgdGhlIGN1cnJlbnQgdGltZS5cblxuICBjb25zdCB7IHBlcmZvcm1hbmNlIH0gPSB3b3JsZHdpZGUuR0xPQkFMX09CSiA7XG4gIGlmICghcGVyZm9ybWFuY2U/Lm5vdykge1xuICAgIHJldHVybiBbdW5kZWZpbmVkLCAnbm9uZSddO1xuICB9XG5cbiAgY29uc3QgdGhyZXNob2xkID0gMzYwMCAqIDEwMDA7XG4gIGNvbnN0IHBlcmZvcm1hbmNlTm93ID0gcGVyZm9ybWFuY2Uubm93KCk7XG4gIGNvbnN0IGRhdGVOb3cgPSBEYXRlLm5vdygpO1xuXG4gIC8vIGlmIHRpbWVPcmlnaW4gaXNuJ3QgYXZhaWxhYmxlIHNldCBkZWx0YSB0byB0aHJlc2hvbGQgc28gaXQgaXNuJ3QgdXNlZFxuICBjb25zdCB0aW1lT3JpZ2luRGVsdGEgPSBwZXJmb3JtYW5jZS50aW1lT3JpZ2luXG4gICAgPyBNYXRoLmFicyhwZXJmb3JtYW5jZS50aW1lT3JpZ2luICsgcGVyZm9ybWFuY2VOb3cgLSBkYXRlTm93KVxuICAgIDogdGhyZXNob2xkO1xuICBjb25zdCB0aW1lT3JpZ2luSXNSZWxpYWJsZSA9IHRpbWVPcmlnaW5EZWx0YSA8IHRocmVzaG9sZDtcblxuICAvLyBXaGlsZSBwZXJmb3JtYW5jZS50aW1pbmcubmF2aWdhdGlvblN0YXJ0IGlzIGRlcHJlY2F0ZWQgaW4gZmF2b3Igb2YgcGVyZm9ybWFuY2UudGltZU9yaWdpbiwgcGVyZm9ybWFuY2UudGltZU9yaWdpblxuICAvLyBpcyBub3QgYXMgd2lkZWx5IHN1cHBvcnRlZC4gTmFtZWx5LCBwZXJmb3JtYW5jZS50aW1lT3JpZ2luIGlzIHVuZGVmaW5lZCBpbiBTYWZhcmkgYXMgb2Ygd3JpdGluZy5cbiAgLy8gQWxzbyBhcyBvZiB3cml0aW5nLCBwZXJmb3JtYW5jZS50aW1pbmcgaXMgbm90IGF2YWlsYWJsZSBpbiBXZWIgV29ya2VycyBpbiBtYWluc3RyZWFtIGJyb3dzZXJzLCBzbyBpdCBpcyBub3QgYWx3YXlzXG4gIC8vIGEgdmFsaWQgZmFsbGJhY2suIEluIHRoZSBhYnNlbmNlIG9mIGFuIGluaXRpYWwgdGltZSBwcm92aWRlZCBieSB0aGUgYnJvd3NlciwgZmFsbGJhY2sgdG8gdGhlIGN1cnJlbnQgdGltZSBmcm9tIHRoZVxuICAvLyBEYXRlIEFQSS5cbiAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIGRlcHJlY2F0aW9uL2RlcHJlY2F0aW9uXG4gIGNvbnN0IG5hdmlnYXRpb25TdGFydCA9IHBlcmZvcm1hbmNlLnRpbWluZz8ubmF2aWdhdGlvblN0YXJ0O1xuICBjb25zdCBoYXNOYXZpZ2F0aW9uU3RhcnQgPSB0eXBlb2YgbmF2aWdhdGlvblN0YXJ0ID09PSAnbnVtYmVyJztcbiAgLy8gaWYgbmF2aWdhdGlvblN0YXJ0IGlzbid0IGF2YWlsYWJsZSBzZXQgZGVsdGEgdG8gdGhyZXNob2xkIHNvIGl0IGlzbid0IHVzZWRcbiAgY29uc3QgbmF2aWdhdGlvblN0YXJ0RGVsdGEgPSBoYXNOYXZpZ2F0aW9uU3RhcnQgPyBNYXRoLmFicyhuYXZpZ2F0aW9uU3RhcnQgKyBwZXJmb3JtYW5jZU5vdyAtIGRhdGVOb3cpIDogdGhyZXNob2xkO1xuICBjb25zdCBuYXZpZ2F0aW9uU3RhcnRJc1JlbGlhYmxlID0gbmF2aWdhdGlvblN0YXJ0RGVsdGEgPCB0aHJlc2hvbGQ7XG5cbiAgaWYgKHRpbWVPcmlnaW5Jc1JlbGlhYmxlIHx8IG5hdmlnYXRpb25TdGFydElzUmVsaWFibGUpIHtcbiAgICAvLyBVc2UgdGhlIG1vcmUgcmVsaWFibGUgdGltZSBvcmlnaW5cbiAgICBpZiAodGltZU9yaWdpbkRlbHRhIDw9IG5hdmlnYXRpb25TdGFydERlbHRhKSB7XG4gICAgICByZXR1cm4gW3BlcmZvcm1hbmNlLnRpbWVPcmlnaW4sICd0aW1lT3JpZ2luJ107XG4gICAgfSBlbHNlIHtcbiAgICAgIHJldHVybiBbbmF2aWdhdGlvblN0YXJ0LCAnbmF2aWdhdGlvblN0YXJ0J107XG4gICAgfVxuICB9XG5cbiAgLy8gRWl0aGVyIGJvdGggdGltZU9yaWdpbiBhbmQgbmF2aWdhdGlvblN0YXJ0IGFyZSBza2V3ZWQgb3IgbmVpdGhlciBpcyBhdmFpbGFibGUsIGZhbGxiYWNrIHRvIERhdGUuXG4gIHJldHVybiBbZGF0ZU5vdywgJ2RhdGVOb3cnXTtcbn1cblxuLyoqXG4gKiBUaGUgbnVtYmVyIG9mIG1pbGxpc2Vjb25kcyBzaW5jZSB0aGUgVU5JWCBlcG9jaC4gVGhpcyB2YWx1ZSBpcyBvbmx5IHVzYWJsZSBpbiBhIGJyb3dzZXIsIGFuZCBvbmx5IHdoZW4gdGhlXG4gKiBwZXJmb3JtYW5jZSBBUEkgaXMgYXZhaWxhYmxlLlxuICovXG5mdW5jdGlvbiBicm93c2VyUGVyZm9ybWFuY2VUaW1lT3JpZ2luKCkge1xuICBpZiAoIWNhY2hlZFRpbWVPcmlnaW4pIHtcbiAgICBjYWNoZWRUaW1lT3JpZ2luID0gZ2V0QnJvd3NlclRpbWVPcmlnaW4oKTtcbiAgfVxuXG4gIHJldHVybiBjYWNoZWRUaW1lT3JpZ2luWzBdO1xufVxuXG5leHBvcnRzLmJyb3dzZXJQZXJmb3JtYW5jZVRpbWVPcmlnaW4gPSBicm93c2VyUGVyZm9ybWFuY2VUaW1lT3JpZ2luO1xuZXhwb3J0cy5kYXRlVGltZXN0YW1wSW5TZWNvbmRzID0gZGF0ZVRpbWVzdGFtcEluU2Vjb25kcztcbmV4cG9ydHMudGltZXN0YW1wSW5TZWNvbmRzID0gdGltZXN0YW1wSW5TZWNvbmRzO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9dGltZS5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/time.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/traceData.js":
/*!*******************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/traceData.js ***!
  \*******************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst index = __webpack_require__(/*! ../asyncContext/index.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/asyncContext/index.js\");\nconst carrier = __webpack_require__(/*! ../carrier.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/carrier.js\");\nconst currentScopes = __webpack_require__(/*! ../currentScopes.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst exports$1 = __webpack_require__(/*! ../exports.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/exports.js\");\nconst debugLogger = __webpack_require__(/*! ./debug-logger.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst spanUtils = __webpack_require__(/*! ./spanUtils.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanUtils.js\");\nconst dynamicSamplingContext = __webpack_require__(/*! ../tracing/dynamicSamplingContext.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/dynamicSamplingContext.js\");\nconst tracing = __webpack_require__(/*! ./tracing.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/tracing.js\");\nconst baggage = __webpack_require__(/*! ./baggage.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/baggage.js\");\n\n/**\n * Extracts trace propagation data from the current span or from the client's scope (via transaction or propagation\n * context) and serializes it to `sentry-trace` and `baggage` values to strings. These values can be used to propagate\n * a trace via our tracing Http headers or Html `<meta>` tags.\n *\n * This function also applies some validation to the generated sentry-trace and baggage values to ensure that\n * only valid strings are returned.\n *\n * @returns an object with the tracing data values. The object keys are the name of the tracing key to be used as header\n * or meta tag name.\n */\nfunction getTraceData(options = {}) {\n  const client = options.client || currentScopes.getClient();\n  if (!exports$1.isEnabled() || !client) {\n    return {};\n  }\n\n  const carrier$1 = carrier.getMainCarrier();\n  const acs = index.getAsyncContextStrategy(carrier$1);\n  if (acs.getTraceData) {\n    return acs.getTraceData(options);\n  }\n\n  const scope = options.scope || currentScopes.getCurrentScope();\n  const span = options.span || spanUtils.getActiveSpan();\n  const sentryTrace = span ? spanUtils.spanToTraceHeader(span) : scopeToTraceHeader(scope);\n  const dsc = span ? dynamicSamplingContext.getDynamicSamplingContextFromSpan(span) : dynamicSamplingContext.getDynamicSamplingContextFromScope(client, scope);\n  const baggage$1 = baggage.dynamicSamplingContextToSentryBaggageHeader(dsc);\n\n  const isValidSentryTraceHeader = tracing.TRACEPARENT_REGEXP.test(sentryTrace);\n  if (!isValidSentryTraceHeader) {\n    debugLogger.debug.warn('Invalid sentry-trace data. Cannot generate trace data');\n    return {};\n  }\n\n  return {\n    'sentry-trace': sentryTrace,\n    baggage: baggage$1,\n  };\n}\n\n/**\n * Get a sentry-trace header value for the given scope.\n */\nfunction scopeToTraceHeader(scope) {\n  const { traceId, sampled, propagationSpanId } = scope.getPropagationContext();\n  return tracing.generateSentryTraceHeader(traceId, propagationSpanId, sampled);\n}\n\nexports.getTraceData = getTraceData;\n//# sourceMappingURL=traceData.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvdHJhY2VEYXRhLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLGNBQWMsbUJBQU8sQ0FBQyxpSkFBMEI7QUFDaEQsZ0JBQWdCLG1CQUFPLENBQUMsMkhBQWU7QUFDdkMsc0JBQXNCLG1CQUFPLENBQUMsdUlBQXFCO0FBQ25ELGtCQUFrQixtQkFBTyxDQUFDLDJIQUFlO0FBQ3pDLG9CQUFvQixtQkFBTyxDQUFDLDBJQUFtQjtBQUMvQyxrQkFBa0IsbUJBQU8sQ0FBQyxvSUFBZ0I7QUFDMUMsK0JBQStCLG1CQUFPLENBQUMseUtBQXNDO0FBQzdFLGdCQUFnQixtQkFBTyxDQUFDLGdJQUFjO0FBQ3RDLGdCQUFnQixtQkFBTyxDQUFDLGdJQUFjOztBQUV0QztBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0Esa0NBQWtDO0FBQ2xDO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQSxVQUFVLHNDQUFzQztBQUNoRDtBQUNBOztBQUVBLG9CQUFvQjtBQUNwQiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3V0aWxzL3RyYWNlRGF0YS5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgaW5kZXggPSByZXF1aXJlKCcuLi9hc3luY0NvbnRleHQvaW5kZXguanMnKTtcbmNvbnN0IGNhcnJpZXIgPSByZXF1aXJlKCcuLi9jYXJyaWVyLmpzJyk7XG5jb25zdCBjdXJyZW50U2NvcGVzID0gcmVxdWlyZSgnLi4vY3VycmVudFNjb3Blcy5qcycpO1xuY29uc3QgZXhwb3J0cyQxID0gcmVxdWlyZSgnLi4vZXhwb3J0cy5qcycpO1xuY29uc3QgZGVidWdMb2dnZXIgPSByZXF1aXJlKCcuL2RlYnVnLWxvZ2dlci5qcycpO1xuY29uc3Qgc3BhblV0aWxzID0gcmVxdWlyZSgnLi9zcGFuVXRpbHMuanMnKTtcbmNvbnN0IGR5bmFtaWNTYW1wbGluZ0NvbnRleHQgPSByZXF1aXJlKCcuLi90cmFjaW5nL2R5bmFtaWNTYW1wbGluZ0NvbnRleHQuanMnKTtcbmNvbnN0IHRyYWNpbmcgPSByZXF1aXJlKCcuL3RyYWNpbmcuanMnKTtcbmNvbnN0IGJhZ2dhZ2UgPSByZXF1aXJlKCcuL2JhZ2dhZ2UuanMnKTtcblxuLyoqXG4gKiBFeHRyYWN0cyB0cmFjZSBwcm9wYWdhdGlvbiBkYXRhIGZyb20gdGhlIGN1cnJlbnQgc3BhbiBvciBmcm9tIHRoZSBjbGllbnQncyBzY29wZSAodmlhIHRyYW5zYWN0aW9uIG9yIHByb3BhZ2F0aW9uXG4gKiBjb250ZXh0KSBhbmQgc2VyaWFsaXplcyBpdCB0byBgc2VudHJ5LXRyYWNlYCBhbmQgYGJhZ2dhZ2VgIHZhbHVlcyB0byBzdHJpbmdzLiBUaGVzZSB2YWx1ZXMgY2FuIGJlIHVzZWQgdG8gcHJvcGFnYXRlXG4gKiBhIHRyYWNlIHZpYSBvdXIgdHJhY2luZyBIdHRwIGhlYWRlcnMgb3IgSHRtbCBgPG1ldGE+YCB0YWdzLlxuICpcbiAqIFRoaXMgZnVuY3Rpb24gYWxzbyBhcHBsaWVzIHNvbWUgdmFsaWRhdGlvbiB0byB0aGUgZ2VuZXJhdGVkIHNlbnRyeS10cmFjZSBhbmQgYmFnZ2FnZSB2YWx1ZXMgdG8gZW5zdXJlIHRoYXRcbiAqIG9ubHkgdmFsaWQgc3RyaW5ncyBhcmUgcmV0dXJuZWQuXG4gKlxuICogQHJldHVybnMgYW4gb2JqZWN0IHdpdGggdGhlIHRyYWNpbmcgZGF0YSB2YWx1ZXMuIFRoZSBvYmplY3Qga2V5cyBhcmUgdGhlIG5hbWUgb2YgdGhlIHRyYWNpbmcga2V5IHRvIGJlIHVzZWQgYXMgaGVhZGVyXG4gKiBvciBtZXRhIHRhZyBuYW1lLlxuICovXG5mdW5jdGlvbiBnZXRUcmFjZURhdGEob3B0aW9ucyA9IHt9KSB7XG4gIGNvbnN0IGNsaWVudCA9IG9wdGlvbnMuY2xpZW50IHx8IGN1cnJlbnRTY29wZXMuZ2V0Q2xpZW50KCk7XG4gIGlmICghZXhwb3J0cyQxLmlzRW5hYmxlZCgpIHx8ICFjbGllbnQpIHtcbiAgICByZXR1cm4ge307XG4gIH1cblxuICBjb25zdCBjYXJyaWVyJDEgPSBjYXJyaWVyLmdldE1haW5DYXJyaWVyKCk7XG4gIGNvbnN0IGFjcyA9IGluZGV4LmdldEFzeW5jQ29udGV4dFN0cmF0ZWd5KGNhcnJpZXIkMSk7XG4gIGlmIChhY3MuZ2V0VHJhY2VEYXRhKSB7XG4gICAgcmV0dXJuIGFjcy5nZXRUcmFjZURhdGEob3B0aW9ucyk7XG4gIH1cblxuICBjb25zdCBzY29wZSA9IG9wdGlvbnMuc2NvcGUgfHwgY3VycmVudFNjb3Blcy5nZXRDdXJyZW50U2NvcGUoKTtcbiAgY29uc3Qgc3BhbiA9IG9wdGlvbnMuc3BhbiB8fCBzcGFuVXRpbHMuZ2V0QWN0aXZlU3BhbigpO1xuICBjb25zdCBzZW50cnlUcmFjZSA9IHNwYW4gPyBzcGFuVXRpbHMuc3BhblRvVHJhY2VIZWFkZXIoc3BhbikgOiBzY29wZVRvVHJhY2VIZWFkZXIoc2NvcGUpO1xuICBjb25zdCBkc2MgPSBzcGFuID8gZHluYW1pY1NhbXBsaW5nQ29udGV4dC5nZXREeW5hbWljU2FtcGxpbmdDb250ZXh0RnJvbVNwYW4oc3BhbikgOiBkeW5hbWljU2FtcGxpbmdDb250ZXh0LmdldER5bmFtaWNTYW1wbGluZ0NvbnRleHRGcm9tU2NvcGUoY2xpZW50LCBzY29wZSk7XG4gIGNvbnN0IGJhZ2dhZ2UkMSA9IGJhZ2dhZ2UuZHluYW1pY1NhbXBsaW5nQ29udGV4dFRvU2VudHJ5QmFnZ2FnZUhlYWRlcihkc2MpO1xuXG4gIGNvbnN0IGlzVmFsaWRTZW50cnlUcmFjZUhlYWRlciA9IHRyYWNpbmcuVFJBQ0VQQVJFTlRfUkVHRVhQLnRlc3Qoc2VudHJ5VHJhY2UpO1xuICBpZiAoIWlzVmFsaWRTZW50cnlUcmFjZUhlYWRlcikge1xuICAgIGRlYnVnTG9nZ2VyLmRlYnVnLndhcm4oJ0ludmFsaWQgc2VudHJ5LXRyYWNlIGRhdGEuIENhbm5vdCBnZW5lcmF0ZSB0cmFjZSBkYXRhJyk7XG4gICAgcmV0dXJuIHt9O1xuICB9XG5cbiAgcmV0dXJuIHtcbiAgICAnc2VudHJ5LXRyYWNlJzogc2VudHJ5VHJhY2UsXG4gICAgYmFnZ2FnZTogYmFnZ2FnZSQxLFxuICB9O1xufVxuXG4vKipcbiAqIEdldCBhIHNlbnRyeS10cmFjZSBoZWFkZXIgdmFsdWUgZm9yIHRoZSBnaXZlbiBzY29wZS5cbiAqL1xuZnVuY3Rpb24gc2NvcGVUb1RyYWNlSGVhZGVyKHNjb3BlKSB7XG4gIGNvbnN0IHsgdHJhY2VJZCwgc2FtcGxlZCwgcHJvcGFnYXRpb25TcGFuSWQgfSA9IHNjb3BlLmdldFByb3BhZ2F0aW9uQ29udGV4dCgpO1xuICByZXR1cm4gdHJhY2luZy5nZW5lcmF0ZVNlbnRyeVRyYWNlSGVhZGVyKHRyYWNlSWQsIHByb3BhZ2F0aW9uU3BhbklkLCBzYW1wbGVkKTtcbn1cblxuZXhwb3J0cy5nZXRUcmFjZURhdGEgPSBnZXRUcmFjZURhdGE7XG4vLyMgc291cmNlTWFwcGluZ1VSTD10cmFjZURhdGEuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/traceData.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/tracing.js":
/*!*****************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/tracing.js ***!
  \*****************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst baggage = __webpack_require__(/*! ./baggage.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/baggage.js\");\nconst parseSampleRate = __webpack_require__(/*! ./parseSampleRate.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/parseSampleRate.js\");\nconst propagationContext = __webpack_require__(/*! ./propagationContext.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/propagationContext.js\");\n\n// eslint-disable-next-line @sentry-internal/sdk/no-regexp-constructor -- RegExp is used for readability here\nconst TRACEPARENT_REGEXP = new RegExp(\n  '^[ \\\\t]*' + // whitespace\n    '([0-9a-f]{32})?' + // trace_id\n    '-?([0-9a-f]{16})?' + // span_id\n    '-?([01])?' + // sampled\n    '[ \\\\t]*$', // whitespace\n);\n\n/**\n * Extract transaction context data from a `sentry-trace` header.\n *\n * @param traceparent Traceparent string\n *\n * @returns Object containing data from the header, or undefined if traceparent string is malformed\n */\nfunction extractTraceparentData(traceparent) {\n  if (!traceparent) {\n    return undefined;\n  }\n\n  const matches = traceparent.match(TRACEPARENT_REGEXP);\n  if (!matches) {\n    return undefined;\n  }\n\n  let parentSampled;\n  if (matches[3] === '1') {\n    parentSampled = true;\n  } else if (matches[3] === '0') {\n    parentSampled = false;\n  }\n\n  return {\n    traceId: matches[1],\n    parentSampled,\n    parentSpanId: matches[2],\n  };\n}\n\n/**\n * Create a propagation context from incoming headers or\n * creates a minimal new one if the headers are undefined.\n */\nfunction propagationContextFromHeaders(\n  sentryTrace,\n  baggage$1,\n) {\n  const traceparentData = extractTraceparentData(sentryTrace);\n  const dynamicSamplingContext = baggage.baggageHeaderToDynamicSamplingContext(baggage$1);\n\n  if (!traceparentData?.traceId) {\n    return {\n      traceId: propagationContext.generateTraceId(),\n      sampleRand: Math.random(),\n    };\n  }\n\n  const sampleRand = getSampleRandFromTraceparentAndDsc(traceparentData, dynamicSamplingContext);\n\n  // The sample_rand on the DSC needs to be generated based on traceparent + baggage.\n  if (dynamicSamplingContext) {\n    dynamicSamplingContext.sample_rand = sampleRand.toString();\n  }\n\n  const { traceId, parentSpanId, parentSampled } = traceparentData;\n\n  return {\n    traceId,\n    parentSpanId,\n    sampled: parentSampled,\n    dsc: dynamicSamplingContext || {}, // If we have traceparent data but no DSC it means we are not head of trace and we must freeze it\n    sampleRand,\n  };\n}\n\n/**\n * Create sentry-trace header from span context values.\n */\nfunction generateSentryTraceHeader(\n  traceId = propagationContext.generateTraceId(),\n  spanId = propagationContext.generateSpanId(),\n  sampled,\n) {\n  let sampledString = '';\n  if (sampled !== undefined) {\n    sampledString = sampled ? '-1' : '-0';\n  }\n  return `${traceId}-${spanId}${sampledString}`;\n}\n\n/**\n * Given any combination of an incoming trace, generate a sample rand based on its defined semantics.\n *\n * Read more: https://develop.sentry.dev/sdk/telemetry/traces/#propagated-random-value\n */\nfunction getSampleRandFromTraceparentAndDsc(\n  traceparentData,\n  dsc,\n) {\n  // When there is an incoming sample rand use it.\n  const parsedSampleRand = parseSampleRate.parseSampleRate(dsc?.sample_rand);\n  if (parsedSampleRand !== undefined) {\n    return parsedSampleRand;\n  }\n\n  // Otherwise, if there is an incoming sampling decision + sample rate, generate a sample rand that would lead to the same sampling decision.\n  const parsedSampleRate = parseSampleRate.parseSampleRate(dsc?.sample_rate);\n  if (parsedSampleRate && traceparentData?.parentSampled !== undefined) {\n    return traceparentData.parentSampled\n      ? // Returns a sample rand with positive sampling decision [0, sampleRate)\n        Math.random() * parsedSampleRate\n      : // Returns a sample rand with negative sampling decision [sampleRate, 1)\n        parsedSampleRate + Math.random() * (1 - parsedSampleRate);\n  } else {\n    // If nothing applies, return a random sample rand.\n    return Math.random();\n  }\n}\n\nexports.TRACEPARENT_REGEXP = TRACEPARENT_REGEXP;\nexports.extractTraceparentData = extractTraceparentData;\nexports.generateSentryTraceHeader = generateSentryTraceHeader;\nexports.propagationContextFromHeaders = propagationContextFromHeaders;\n//# sourceMappingURL=tracing.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvdHJhY2luZy5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxnQkFBZ0IsbUJBQU8sQ0FBQyxnSUFBYztBQUN0Qyx3QkFBd0IsbUJBQU8sQ0FBQyxnSkFBc0I7QUFDdEQsMkJBQTJCLG1CQUFPLENBQUMsc0pBQXlCOztBQUU1RDtBQUNBO0FBQ0E7QUFDQSxlQUFlLEdBQUc7QUFDbEIsaUJBQWlCLEdBQUc7QUFDcEI7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0EsSUFBSTtBQUNKO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSxVQUFVLHVDQUF1Qzs7QUFFakQ7QUFDQTtBQUNBO0FBQ0E7QUFDQSxxQ0FBcUM7QUFDckM7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFlBQVksUUFBUSxHQUFHLE9BQU8sRUFBRSxjQUFjO0FBQzlDOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLElBQUk7QUFDSjtBQUNBO0FBQ0E7QUFDQTs7QUFFQSwwQkFBMEI7QUFDMUIsOEJBQThCO0FBQzlCLGlDQUFpQztBQUNqQyxxQ0FBcUM7QUFDckMiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy90cmFjaW5nLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBiYWdnYWdlID0gcmVxdWlyZSgnLi9iYWdnYWdlLmpzJyk7XG5jb25zdCBwYXJzZVNhbXBsZVJhdGUgPSByZXF1aXJlKCcuL3BhcnNlU2FtcGxlUmF0ZS5qcycpO1xuY29uc3QgcHJvcGFnYXRpb25Db250ZXh0ID0gcmVxdWlyZSgnLi9wcm9wYWdhdGlvbkNvbnRleHQuanMnKTtcblxuLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEBzZW50cnktaW50ZXJuYWwvc2RrL25vLXJlZ2V4cC1jb25zdHJ1Y3RvciAtLSBSZWdFeHAgaXMgdXNlZCBmb3IgcmVhZGFiaWxpdHkgaGVyZVxuY29uc3QgVFJBQ0VQQVJFTlRfUkVHRVhQID0gbmV3IFJlZ0V4cChcbiAgJ15bIFxcXFx0XSonICsgLy8gd2hpdGVzcGFjZVxuICAgICcoWzAtOWEtZl17MzJ9KT8nICsgLy8gdHJhY2VfaWRcbiAgICAnLT8oWzAtOWEtZl17MTZ9KT8nICsgLy8gc3Bhbl9pZFxuICAgICctPyhbMDFdKT8nICsgLy8gc2FtcGxlZFxuICAgICdbIFxcXFx0XSokJywgLy8gd2hpdGVzcGFjZVxuKTtcblxuLyoqXG4gKiBFeHRyYWN0IHRyYW5zYWN0aW9uIGNvbnRleHQgZGF0YSBmcm9tIGEgYHNlbnRyeS10cmFjZWAgaGVhZGVyLlxuICpcbiAqIEBwYXJhbSB0cmFjZXBhcmVudCBUcmFjZXBhcmVudCBzdHJpbmdcbiAqXG4gKiBAcmV0dXJucyBPYmplY3QgY29udGFpbmluZyBkYXRhIGZyb20gdGhlIGhlYWRlciwgb3IgdW5kZWZpbmVkIGlmIHRyYWNlcGFyZW50IHN0cmluZyBpcyBtYWxmb3JtZWRcbiAqL1xuZnVuY3Rpb24gZXh0cmFjdFRyYWNlcGFyZW50RGF0YSh0cmFjZXBhcmVudCkge1xuICBpZiAoIXRyYWNlcGFyZW50KSB7XG4gICAgcmV0dXJuIHVuZGVmaW5lZDtcbiAgfVxuXG4gIGNvbnN0IG1hdGNoZXMgPSB0cmFjZXBhcmVudC5tYXRjaChUUkFDRVBBUkVOVF9SRUdFWFApO1xuICBpZiAoIW1hdGNoZXMpIHtcbiAgICByZXR1cm4gdW5kZWZpbmVkO1xuICB9XG5cbiAgbGV0IHBhcmVudFNhbXBsZWQ7XG4gIGlmIChtYXRjaGVzWzNdID09PSAnMScpIHtcbiAgICBwYXJlbnRTYW1wbGVkID0gdHJ1ZTtcbiAgfSBlbHNlIGlmIChtYXRjaGVzWzNdID09PSAnMCcpIHtcbiAgICBwYXJlbnRTYW1wbGVkID0gZmFsc2U7XG4gIH1cblxuICByZXR1cm4ge1xuICAgIHRyYWNlSWQ6IG1hdGNoZXNbMV0sXG4gICAgcGFyZW50U2FtcGxlZCxcbiAgICBwYXJlbnRTcGFuSWQ6IG1hdGNoZXNbMl0sXG4gIH07XG59XG5cbi8qKlxuICogQ3JlYXRlIGEgcHJvcGFnYXRpb24gY29udGV4dCBmcm9tIGluY29taW5nIGhlYWRlcnMgb3JcbiAqIGNyZWF0ZXMgYSBtaW5pbWFsIG5ldyBvbmUgaWYgdGhlIGhlYWRlcnMgYXJlIHVuZGVmaW5lZC5cbiAqL1xuZnVuY3Rpb24gcHJvcGFnYXRpb25Db250ZXh0RnJvbUhlYWRlcnMoXG4gIHNlbnRyeVRyYWNlLFxuICBiYWdnYWdlJDEsXG4pIHtcbiAgY29uc3QgdHJhY2VwYXJlbnREYXRhID0gZXh0cmFjdFRyYWNlcGFyZW50RGF0YShzZW50cnlUcmFjZSk7XG4gIGNvbnN0IGR5bmFtaWNTYW1wbGluZ0NvbnRleHQgPSBiYWdnYWdlLmJhZ2dhZ2VIZWFkZXJUb0R5bmFtaWNTYW1wbGluZ0NvbnRleHQoYmFnZ2FnZSQxKTtcblxuICBpZiAoIXRyYWNlcGFyZW50RGF0YT8udHJhY2VJZCkge1xuICAgIHJldHVybiB7XG4gICAgICB0cmFjZUlkOiBwcm9wYWdhdGlvbkNvbnRleHQuZ2VuZXJhdGVUcmFjZUlkKCksXG4gICAgICBzYW1wbGVSYW5kOiBNYXRoLnJhbmRvbSgpLFxuICAgIH07XG4gIH1cblxuICBjb25zdCBzYW1wbGVSYW5kID0gZ2V0U2FtcGxlUmFuZEZyb21UcmFjZXBhcmVudEFuZERzYyh0cmFjZXBhcmVudERhdGEsIGR5bmFtaWNTYW1wbGluZ0NvbnRleHQpO1xuXG4gIC8vIFRoZSBzYW1wbGVfcmFuZCBvbiB0aGUgRFNDIG5lZWRzIHRvIGJlIGdlbmVyYXRlZCBiYXNlZCBvbiB0cmFjZXBhcmVudCArIGJhZ2dhZ2UuXG4gIGlmIChkeW5hbWljU2FtcGxpbmdDb250ZXh0KSB7XG4gICAgZHluYW1pY1NhbXBsaW5nQ29udGV4dC5zYW1wbGVfcmFuZCA9IHNhbXBsZVJhbmQudG9TdHJpbmcoKTtcbiAgfVxuXG4gIGNvbnN0IHsgdHJhY2VJZCwgcGFyZW50U3BhbklkLCBwYXJlbnRTYW1wbGVkIH0gPSB0cmFjZXBhcmVudERhdGE7XG5cbiAgcmV0dXJuIHtcbiAgICB0cmFjZUlkLFxuICAgIHBhcmVudFNwYW5JZCxcbiAgICBzYW1wbGVkOiBwYXJlbnRTYW1wbGVkLFxuICAgIGRzYzogZHluYW1pY1NhbXBsaW5nQ29udGV4dCB8fCB7fSwgLy8gSWYgd2UgaGF2ZSB0cmFjZXBhcmVudCBkYXRhIGJ1dCBubyBEU0MgaXQgbWVhbnMgd2UgYXJlIG5vdCBoZWFkIG9mIHRyYWNlIGFuZCB3ZSBtdXN0IGZyZWV6ZSBpdFxuICAgIHNhbXBsZVJhbmQsXG4gIH07XG59XG5cbi8qKlxuICogQ3JlYXRlIHNlbnRyeS10cmFjZSBoZWFkZXIgZnJvbSBzcGFuIGNvbnRleHQgdmFsdWVzLlxuICovXG5mdW5jdGlvbiBnZW5lcmF0ZVNlbnRyeVRyYWNlSGVhZGVyKFxuICB0cmFjZUlkID0gcHJvcGFnYXRpb25Db250ZXh0LmdlbmVyYXRlVHJhY2VJZCgpLFxuICBzcGFuSWQgPSBwcm9wYWdhdGlvbkNvbnRleHQuZ2VuZXJhdGVTcGFuSWQoKSxcbiAgc2FtcGxlZCxcbikge1xuICBsZXQgc2FtcGxlZFN0cmluZyA9ICcnO1xuICBpZiAoc2FtcGxlZCAhPT0gdW5kZWZpbmVkKSB7XG4gICAgc2FtcGxlZFN0cmluZyA9IHNhbXBsZWQgPyAnLTEnIDogJy0wJztcbiAgfVxuICByZXR1cm4gYCR7dHJhY2VJZH0tJHtzcGFuSWR9JHtzYW1wbGVkU3RyaW5nfWA7XG59XG5cbi8qKlxuICogR2l2ZW4gYW55IGNvbWJpbmF0aW9uIG9mIGFuIGluY29taW5nIHRyYWNlLCBnZW5lcmF0ZSBhIHNhbXBsZSByYW5kIGJhc2VkIG9uIGl0cyBkZWZpbmVkIHNlbWFudGljcy5cbiAqXG4gKiBSZWFkIG1vcmU6IGh0dHBzOi8vZGV2ZWxvcC5zZW50cnkuZGV2L3Nkay90ZWxlbWV0cnkvdHJhY2VzLyNwcm9wYWdhdGVkLXJhbmRvbS12YWx1ZVxuICovXG5mdW5jdGlvbiBnZXRTYW1wbGVSYW5kRnJvbVRyYWNlcGFyZW50QW5kRHNjKFxuICB0cmFjZXBhcmVudERhdGEsXG4gIGRzYyxcbikge1xuICAvLyBXaGVuIHRoZXJlIGlzIGFuIGluY29taW5nIHNhbXBsZSByYW5kIHVzZSBpdC5cbiAgY29uc3QgcGFyc2VkU2FtcGxlUmFuZCA9IHBhcnNlU2FtcGxlUmF0ZS5wYXJzZVNhbXBsZVJhdGUoZHNjPy5zYW1wbGVfcmFuZCk7XG4gIGlmIChwYXJzZWRTYW1wbGVSYW5kICE9PSB1bmRlZmluZWQpIHtcbiAgICByZXR1cm4gcGFyc2VkU2FtcGxlUmFuZDtcbiAgfVxuXG4gIC8vIE90aGVyd2lzZSwgaWYgdGhlcmUgaXMgYW4gaW5jb21pbmcgc2FtcGxpbmcgZGVjaXNpb24gKyBzYW1wbGUgcmF0ZSwgZ2VuZXJhdGUgYSBzYW1wbGUgcmFuZCB0aGF0IHdvdWxkIGxlYWQgdG8gdGhlIHNhbWUgc2FtcGxpbmcgZGVjaXNpb24uXG4gIGNvbnN0IHBhcnNlZFNhbXBsZVJhdGUgPSBwYXJzZVNhbXBsZVJhdGUucGFyc2VTYW1wbGVSYXRlKGRzYz8uc2FtcGxlX3JhdGUpO1xuICBpZiAocGFyc2VkU2FtcGxlUmF0ZSAmJiB0cmFjZXBhcmVudERhdGE/LnBhcmVudFNhbXBsZWQgIT09IHVuZGVmaW5lZCkge1xuICAgIHJldHVybiB0cmFjZXBhcmVudERhdGEucGFyZW50U2FtcGxlZFxuICAgICAgPyAvLyBSZXR1cm5zIGEgc2FtcGxlIHJhbmQgd2l0aCBwb3NpdGl2ZSBzYW1wbGluZyBkZWNpc2lvbiBbMCwgc2FtcGxlUmF0ZSlcbiAgICAgICAgTWF0aC5yYW5kb20oKSAqIHBhcnNlZFNhbXBsZVJhdGVcbiAgICAgIDogLy8gUmV0dXJucyBhIHNhbXBsZSByYW5kIHdpdGggbmVnYXRpdmUgc2FtcGxpbmcgZGVjaXNpb24gW3NhbXBsZVJhdGUsIDEpXG4gICAgICAgIHBhcnNlZFNhbXBsZVJhdGUgKyBNYXRoLnJhbmRvbSgpICogKDEgLSBwYXJzZWRTYW1wbGVSYXRlKTtcbiAgfSBlbHNlIHtcbiAgICAvLyBJZiBub3RoaW5nIGFwcGxpZXMsIHJldHVybiBhIHJhbmRvbSBzYW1wbGUgcmFuZC5cbiAgICByZXR1cm4gTWF0aC5yYW5kb20oKTtcbiAgfVxufVxuXG5leHBvcnRzLlRSQUNFUEFSRU5UX1JFR0VYUCA9IFRSQUNFUEFSRU5UX1JFR0VYUDtcbmV4cG9ydHMuZXh0cmFjdFRyYWNlcGFyZW50RGF0YSA9IGV4dHJhY3RUcmFjZXBhcmVudERhdGE7XG5leHBvcnRzLmdlbmVyYXRlU2VudHJ5VHJhY2VIZWFkZXIgPSBnZW5lcmF0ZVNlbnRyeVRyYWNlSGVhZGVyO1xuZXhwb3J0cy5wcm9wYWdhdGlvbkNvbnRleHRGcm9tSGVhZGVycyA9IHByb3BhZ2F0aW9uQ29udGV4dEZyb21IZWFkZXJzO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9dHJhY2luZy5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/tracing.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/transactionEvent.js":
/*!**************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/transactionEvent.js ***!
  \**************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst semanticAttributes = __webpack_require__(/*! ../semanticAttributes.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/semanticAttributes.js\");\n\n/**\n * Converts a transaction event to a span JSON object.\n */\nfunction convertTransactionEventToSpanJson(event) {\n  const { trace_id, parent_span_id, span_id, status, origin, data, op } = event.contexts?.trace ?? {};\n\n  return {\n    data: data ?? {},\n    description: event.transaction,\n    op,\n    parent_span_id,\n    span_id: span_id ?? '',\n    start_timestamp: event.start_timestamp ?? 0,\n    status,\n    timestamp: event.timestamp,\n    trace_id: trace_id ?? '',\n    origin,\n    profile_id: data?.[semanticAttributes.SEMANTIC_ATTRIBUTE_PROFILE_ID] ,\n    exclusive_time: data?.[semanticAttributes.SEMANTIC_ATTRIBUTE_EXCLUSIVE_TIME] ,\n    measurements: event.measurements,\n    is_segment: true,\n  };\n}\n\n/**\n * Converts a span JSON object to a transaction event.\n */\nfunction convertSpanJsonToTransactionEvent(span) {\n  return {\n    type: 'transaction',\n    timestamp: span.timestamp,\n    start_timestamp: span.start_timestamp,\n    transaction: span.description,\n    contexts: {\n      trace: {\n        trace_id: span.trace_id,\n        span_id: span.span_id,\n        parent_span_id: span.parent_span_id,\n        op: span.op,\n        status: span.status,\n        origin: span.origin,\n        data: {\n          ...span.data,\n          ...(span.profile_id && { [semanticAttributes.SEMANTIC_ATTRIBUTE_PROFILE_ID]: span.profile_id }),\n          ...(span.exclusive_time && { [semanticAttributes.SEMANTIC_ATTRIBUTE_EXCLUSIVE_TIME]: span.exclusive_time }),\n        },\n      },\n    },\n    measurements: span.measurements,\n  };\n}\n\nexports.convertSpanJsonToTransactionEvent = convertSpanJsonToTransactionEvent;\nexports.convertTransactionEventToSpanJson = convertTransactionEventToSpanJson;\n//# sourceMappingURL=transactionEvent.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvdHJhbnNhY3Rpb25FdmVudC5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSwyQkFBMkIsbUJBQU8sQ0FBQyxpSkFBMEI7O0FBRTdEO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsVUFBVSw4REFBOEQ7O0FBRXhFO0FBQ0Esb0JBQW9CO0FBQ3BCO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLG1DQUFtQyxxRUFBcUU7QUFDeEcsdUNBQXVDLDZFQUE2RTtBQUNwSCxTQUFTO0FBQ1QsT0FBTztBQUNQLEtBQUs7QUFDTDtBQUNBO0FBQ0E7O0FBRUEseUNBQXlDO0FBQ3pDLHlDQUF5QztBQUN6QyIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3V0aWxzL3RyYW5zYWN0aW9uRXZlbnQuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IHNlbWFudGljQXR0cmlidXRlcyA9IHJlcXVpcmUoJy4uL3NlbWFudGljQXR0cmlidXRlcy5qcycpO1xuXG4vKipcbiAqIENvbnZlcnRzIGEgdHJhbnNhY3Rpb24gZXZlbnQgdG8gYSBzcGFuIEpTT04gb2JqZWN0LlxuICovXG5mdW5jdGlvbiBjb252ZXJ0VHJhbnNhY3Rpb25FdmVudFRvU3Bhbkpzb24oZXZlbnQpIHtcbiAgY29uc3QgeyB0cmFjZV9pZCwgcGFyZW50X3NwYW5faWQsIHNwYW5faWQsIHN0YXR1cywgb3JpZ2luLCBkYXRhLCBvcCB9ID0gZXZlbnQuY29udGV4dHM/LnRyYWNlID8/IHt9O1xuXG4gIHJldHVybiB7XG4gICAgZGF0YTogZGF0YSA/PyB7fSxcbiAgICBkZXNjcmlwdGlvbjogZXZlbnQudHJhbnNhY3Rpb24sXG4gICAgb3AsXG4gICAgcGFyZW50X3NwYW5faWQsXG4gICAgc3Bhbl9pZDogc3Bhbl9pZCA/PyAnJyxcbiAgICBzdGFydF90aW1lc3RhbXA6IGV2ZW50LnN0YXJ0X3RpbWVzdGFtcCA/PyAwLFxuICAgIHN0YXR1cyxcbiAgICB0aW1lc3RhbXA6IGV2ZW50LnRpbWVzdGFtcCxcbiAgICB0cmFjZV9pZDogdHJhY2VfaWQgPz8gJycsXG4gICAgb3JpZ2luLFxuICAgIHByb2ZpbGVfaWQ6IGRhdGE/LltzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX1BST0ZJTEVfSURdICxcbiAgICBleGNsdXNpdmVfdGltZTogZGF0YT8uW3NlbWFudGljQXR0cmlidXRlcy5TRU1BTlRJQ19BVFRSSUJVVEVfRVhDTFVTSVZFX1RJTUVdICxcbiAgICBtZWFzdXJlbWVudHM6IGV2ZW50Lm1lYXN1cmVtZW50cyxcbiAgICBpc19zZWdtZW50OiB0cnVlLFxuICB9O1xufVxuXG4vKipcbiAqIENvbnZlcnRzIGEgc3BhbiBKU09OIG9iamVjdCB0byBhIHRyYW5zYWN0aW9uIGV2ZW50LlxuICovXG5mdW5jdGlvbiBjb252ZXJ0U3Bhbkpzb25Ub1RyYW5zYWN0aW9uRXZlbnQoc3Bhbikge1xuICByZXR1cm4ge1xuICAgIHR5cGU6ICd0cmFuc2FjdGlvbicsXG4gICAgdGltZXN0YW1wOiBzcGFuLnRpbWVzdGFtcCxcbiAgICBzdGFydF90aW1lc3RhbXA6IHNwYW4uc3RhcnRfdGltZXN0YW1wLFxuICAgIHRyYW5zYWN0aW9uOiBzcGFuLmRlc2NyaXB0aW9uLFxuICAgIGNvbnRleHRzOiB7XG4gICAgICB0cmFjZToge1xuICAgICAgICB0cmFjZV9pZDogc3Bhbi50cmFjZV9pZCxcbiAgICAgICAgc3Bhbl9pZDogc3Bhbi5zcGFuX2lkLFxuICAgICAgICBwYXJlbnRfc3Bhbl9pZDogc3Bhbi5wYXJlbnRfc3Bhbl9pZCxcbiAgICAgICAgb3A6IHNwYW4ub3AsXG4gICAgICAgIHN0YXR1czogc3Bhbi5zdGF0dXMsXG4gICAgICAgIG9yaWdpbjogc3Bhbi5vcmlnaW4sXG4gICAgICAgIGRhdGE6IHtcbiAgICAgICAgICAuLi5zcGFuLmRhdGEsXG4gICAgICAgICAgLi4uKHNwYW4ucHJvZmlsZV9pZCAmJiB7IFtzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX1BST0ZJTEVfSURdOiBzcGFuLnByb2ZpbGVfaWQgfSksXG4gICAgICAgICAgLi4uKHNwYW4uZXhjbHVzaXZlX3RpbWUgJiYgeyBbc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9FWENMVVNJVkVfVElNRV06IHNwYW4uZXhjbHVzaXZlX3RpbWUgfSksXG4gICAgICAgIH0sXG4gICAgICB9LFxuICAgIH0sXG4gICAgbWVhc3VyZW1lbnRzOiBzcGFuLm1lYXN1cmVtZW50cyxcbiAgfTtcbn1cblxuZXhwb3J0cy5jb252ZXJ0U3Bhbkpzb25Ub1RyYW5zYWN0aW9uRXZlbnQgPSBjb252ZXJ0U3Bhbkpzb25Ub1RyYW5zYWN0aW9uRXZlbnQ7XG5leHBvcnRzLmNvbnZlcnRUcmFuc2FjdGlvbkV2ZW50VG9TcGFuSnNvbiA9IGNvbnZlcnRUcmFuc2FjdGlvbkV2ZW50VG9TcGFuSnNvbjtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPXRyYW5zYWN0aW9uRXZlbnQuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/transactionEvent.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/url.js":
/*!*************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/url.js ***!
  \*************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst semanticAttributes = __webpack_require__(/*! ../semanticAttributes.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/semanticAttributes.js\");\n\n// Curious about `thismessage:/`? See: https://www.rfc-editor.org/rfc/rfc2557.html\n//  > When the methods above do not yield an absolute URI, a base URL\n//  > of \"thismessage:/\" MUST be employed. This base URL has been\n//  > defined for the sole purpose of resolving relative references\n//  > within a multipart/related structure when no other base URI is\n//  > specified.\n//\n// We need to provide a base URL to `parseStringToURLObject` because the fetch API gives us a\n// relative URL sometimes.\n//\n// This is the only case where we need to provide a base URL to `parseStringToURLObject`\n// because the relative URL is not valid on its own.\nconst DEFAULT_BASE_URL = 'thismessage:/';\n\n/**\n * Checks if the URL object is relative\n *\n * @param url - The URL object to check\n * @returns True if the URL object is relative, false otherwise\n */\nfunction isURLObjectRelative(url) {\n  return 'isRelative' in url;\n}\n\n/**\n * Parses string to a URL object\n *\n * @param url - The URL to parse\n * @returns The parsed URL object or undefined if the URL is invalid\n */\nfunction parseStringToURLObject(url, urlBase) {\n  const isRelative = url.indexOf('://') <= 0 && url.indexOf('//') !== 0;\n  const base = urlBase ?? (isRelative ? DEFAULT_BASE_URL : undefined);\n  try {\n    // Use `canParse` to short-circuit the URL constructor if it's not a valid URL\n    // This is faster than trying to construct the URL and catching the error\n    // Node 20+, Chrome 120+, Firefox 115+, Safari 17+\n    if ('canParse' in URL && !(URL ).canParse(url, base)) {\n      return undefined;\n    }\n\n    const fullUrlObject = new URL(url, base);\n    if (isRelative) {\n      // Because we used a fake base URL, we need to return a relative URL object.\n      // We cannot return anything about the origin, host, etc. because it will refer to the fake base URL.\n      return {\n        isRelative,\n        pathname: fullUrlObject.pathname,\n        search: fullUrlObject.search,\n        hash: fullUrlObject.hash,\n      };\n    }\n    return fullUrlObject;\n  } catch {\n    // empty body\n  }\n\n  return undefined;\n}\n\n/**\n * Takes a URL object and returns a sanitized string which is safe to use as span name\n * see: https://develop.sentry.dev/sdk/data-handling/#structuring-data\n */\nfunction getSanitizedUrlStringFromUrlObject(url) {\n  if (isURLObjectRelative(url)) {\n    return url.pathname;\n  }\n\n  const newUrl = new URL(url);\n  newUrl.search = '';\n  newUrl.hash = '';\n  if (['80', '443'].includes(newUrl.port)) {\n    newUrl.port = '';\n  }\n  if (newUrl.password) {\n    newUrl.password = '%filtered%';\n  }\n  if (newUrl.username) {\n    newUrl.username = '%filtered%';\n  }\n\n  return newUrl.toString();\n}\n\nfunction getHttpSpanNameFromUrlObject(\n  urlObject,\n  kind,\n  request,\n  routeName,\n) {\n  const method = request?.method?.toUpperCase() ?? 'GET';\n  const route = routeName\n    ? routeName\n    : urlObject\n      ? kind === 'client'\n        ? getSanitizedUrlStringFromUrlObject(urlObject)\n        : urlObject.pathname\n      : '/';\n\n  return `${method} ${route}`;\n}\n\n/**\n * Takes a parsed URL object and returns a set of attributes for the span\n * that represents the HTTP request for that url. This is used for both server\n * and client http spans.\n *\n * Follows https://opentelemetry.io/docs/specs/semconv/http/.\n *\n * @param urlObject - see {@link parseStringToURLObject}\n * @param kind - The type of HTTP operation (server or client)\n * @param spanOrigin - The origin of the span\n * @param request - The request object, see {@link PartialRequest}\n * @param routeName - The name of the route, must be low cardinality\n * @returns The span name and attributes for the HTTP operation\n */\nfunction getHttpSpanDetailsFromUrlObject(\n  urlObject,\n  kind,\n  spanOrigin,\n  request,\n  routeName,\n) {\n  const attributes = {\n    [semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_ORIGIN]: spanOrigin,\n    [semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_SOURCE]: 'url',\n  };\n\n  if (routeName) {\n    // This is based on https://opentelemetry.io/docs/specs/semconv/http/http-spans/#name\n    attributes[kind === 'server' ? 'http.route' : 'url.template'] = routeName;\n    attributes[semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_SOURCE] = 'route';\n  }\n\n  if (request?.method) {\n    attributes[semanticAttributes.SEMANTIC_ATTRIBUTE_HTTP_REQUEST_METHOD] = request.method.toUpperCase();\n  }\n\n  if (urlObject) {\n    if (urlObject.search) {\n      attributes['url.query'] = urlObject.search;\n    }\n    if (urlObject.hash) {\n      attributes['url.fragment'] = urlObject.hash;\n    }\n    if (urlObject.pathname) {\n      attributes['url.path'] = urlObject.pathname;\n      if (urlObject.pathname === '/') {\n        attributes[semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_SOURCE] = 'route';\n      }\n    }\n\n    if (!isURLObjectRelative(urlObject)) {\n      attributes[semanticAttributes.SEMANTIC_ATTRIBUTE_URL_FULL] = urlObject.href;\n      if (urlObject.port) {\n        attributes['url.port'] = urlObject.port;\n      }\n      if (urlObject.protocol) {\n        attributes['url.scheme'] = urlObject.protocol;\n      }\n      if (urlObject.hostname) {\n        attributes[kind === 'server' ? 'server.address' : 'url.domain'] = urlObject.hostname;\n      }\n    }\n  }\n\n  return [getHttpSpanNameFromUrlObject(urlObject, kind, request, routeName), attributes];\n}\n\n/**\n * Parses string form of URL into an object\n * // borrowed from https://tools.ietf.org/html/rfc3986#appendix-B\n * // intentionally using regex and not <a/> href parsing trick because React Native and other\n * // environments where DOM might not be available\n * @returns parsed URL object\n */\nfunction parseUrl(url) {\n  if (!url) {\n    return {};\n  }\n\n  const match = url.match(/^(([^:/?#]+):)?(\\/\\/([^/?#]*))?([^?#]*)(\\?([^#]*))?(#(.*))?$/);\n\n  if (!match) {\n    return {};\n  }\n\n  // coerce to undefined values to empty string so we don't get 'undefined'\n  const query = match[6] || '';\n  const fragment = match[8] || '';\n  return {\n    host: match[4],\n    path: match[5],\n    protocol: match[2],\n    search: query,\n    hash: fragment,\n    relative: match[5] + query + fragment, // everything minus origin\n  };\n}\n\n/**\n * Strip the query string and fragment off of a given URL or path (if present)\n *\n * @param urlPath Full URL or path, including possible query string and/or fragment\n * @returns URL or path without query string or fragment\n */\nfunction stripUrlQueryAndFragment(urlPath) {\n  return (urlPath.split(/[?#]/, 1) )[0];\n}\n\n/**\n * Takes a URL object and returns a sanitized string which is safe to use as span name\n * see: https://develop.sentry.dev/sdk/data-handling/#structuring-data\n */\nfunction getSanitizedUrlString(url) {\n  const { protocol, host, path } = url;\n\n  const filteredHost =\n    host\n      // Always filter out authority\n      ?.replace(/^.*@/, '[filtered]:[filtered]@')\n      // Don't show standard :80 (http) and :443 (https) ports to reduce the noise\n      // TODO: Use new URL global if it exists\n      .replace(/(:80)$/, '')\n      .replace(/(:443)$/, '') || '';\n\n  return `${protocol ? `${protocol}://` : ''}${filteredHost}${path}`;\n}\n\nexports.getHttpSpanDetailsFromUrlObject = getHttpSpanDetailsFromUrlObject;\nexports.getSanitizedUrlString = getSanitizedUrlString;\nexports.getSanitizedUrlStringFromUrlObject = getSanitizedUrlStringFromUrlObject;\nexports.isURLObjectRelative = isURLObjectRelative;\nexports.parseStringToURLObject = parseStringToURLObject;\nexports.parseUrl = parseUrl;\nexports.stripUrlQueryAndFragment = stripUrlQueryAndFragment;\n//# sourceMappingURL=url.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvdXJsLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLDJCQUEyQixtQkFBTyxDQUFDLGlKQUEwQjs7QUFFN0Q7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLElBQUk7QUFDSjtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLFlBQVksUUFBUSxFQUFFLE1BQU07QUFDNUI7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSwyQkFBMkI7QUFDM0I7QUFDQTtBQUNBLDZDQUE2QztBQUM3QztBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsVUFBVSx1QkFBdUI7O0FBRWpDO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsWUFBWSxjQUFjLFNBQVMsVUFBVSxFQUFFLGFBQWEsRUFBRSxLQUFLO0FBQ25FOztBQUVBLHVDQUF1QztBQUN2Qyw2QkFBNkI7QUFDN0IsMENBQTBDO0FBQzFDLDJCQUEyQjtBQUMzQiw4QkFBOEI7QUFDOUIsZ0JBQWdCO0FBQ2hCLGdDQUFnQztBQUNoQyIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3V0aWxzL3VybC5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3Qgc2VtYW50aWNBdHRyaWJ1dGVzID0gcmVxdWlyZSgnLi4vc2VtYW50aWNBdHRyaWJ1dGVzLmpzJyk7XG5cbi8vIEN1cmlvdXMgYWJvdXQgYHRoaXNtZXNzYWdlOi9gPyBTZWU6IGh0dHBzOi8vd3d3LnJmYy1lZGl0b3Iub3JnL3JmYy9yZmMyNTU3Lmh0bWxcbi8vICA+IFdoZW4gdGhlIG1ldGhvZHMgYWJvdmUgZG8gbm90IHlpZWxkIGFuIGFic29sdXRlIFVSSSwgYSBiYXNlIFVSTFxuLy8gID4gb2YgXCJ0aGlzbWVzc2FnZTovXCIgTVVTVCBiZSBlbXBsb3llZC4gVGhpcyBiYXNlIFVSTCBoYXMgYmVlblxuLy8gID4gZGVmaW5lZCBmb3IgdGhlIHNvbGUgcHVycG9zZSBvZiByZXNvbHZpbmcgcmVsYXRpdmUgcmVmZXJlbmNlc1xuLy8gID4gd2l0aGluIGEgbXVsdGlwYXJ0L3JlbGF0ZWQgc3RydWN0dXJlIHdoZW4gbm8gb3RoZXIgYmFzZSBVUkkgaXNcbi8vICA+IHNwZWNpZmllZC5cbi8vXG4vLyBXZSBuZWVkIHRvIHByb3ZpZGUgYSBiYXNlIFVSTCB0byBgcGFyc2VTdHJpbmdUb1VSTE9iamVjdGAgYmVjYXVzZSB0aGUgZmV0Y2ggQVBJIGdpdmVzIHVzIGFcbi8vIHJlbGF0aXZlIFVSTCBzb21ldGltZXMuXG4vL1xuLy8gVGhpcyBpcyB0aGUgb25seSBjYXNlIHdoZXJlIHdlIG5lZWQgdG8gcHJvdmlkZSBhIGJhc2UgVVJMIHRvIGBwYXJzZVN0cmluZ1RvVVJMT2JqZWN0YFxuLy8gYmVjYXVzZSB0aGUgcmVsYXRpdmUgVVJMIGlzIG5vdCB2YWxpZCBvbiBpdHMgb3duLlxuY29uc3QgREVGQVVMVF9CQVNFX1VSTCA9ICd0aGlzbWVzc2FnZTovJztcblxuLyoqXG4gKiBDaGVja3MgaWYgdGhlIFVSTCBvYmplY3QgaXMgcmVsYXRpdmVcbiAqXG4gKiBAcGFyYW0gdXJsIC0gVGhlIFVSTCBvYmplY3QgdG8gY2hlY2tcbiAqIEByZXR1cm5zIFRydWUgaWYgdGhlIFVSTCBvYmplY3QgaXMgcmVsYXRpdmUsIGZhbHNlIG90aGVyd2lzZVxuICovXG5mdW5jdGlvbiBpc1VSTE9iamVjdFJlbGF0aXZlKHVybCkge1xuICByZXR1cm4gJ2lzUmVsYXRpdmUnIGluIHVybDtcbn1cblxuLyoqXG4gKiBQYXJzZXMgc3RyaW5nIHRvIGEgVVJMIG9iamVjdFxuICpcbiAqIEBwYXJhbSB1cmwgLSBUaGUgVVJMIHRvIHBhcnNlXG4gKiBAcmV0dXJucyBUaGUgcGFyc2VkIFVSTCBvYmplY3Qgb3IgdW5kZWZpbmVkIGlmIHRoZSBVUkwgaXMgaW52YWxpZFxuICovXG5mdW5jdGlvbiBwYXJzZVN0cmluZ1RvVVJMT2JqZWN0KHVybCwgdXJsQmFzZSkge1xuICBjb25zdCBpc1JlbGF0aXZlID0gdXJsLmluZGV4T2YoJzovLycpIDw9IDAgJiYgdXJsLmluZGV4T2YoJy8vJykgIT09IDA7XG4gIGNvbnN0IGJhc2UgPSB1cmxCYXNlID8/IChpc1JlbGF0aXZlID8gREVGQVVMVF9CQVNFX1VSTCA6IHVuZGVmaW5lZCk7XG4gIHRyeSB7XG4gICAgLy8gVXNlIGBjYW5QYXJzZWAgdG8gc2hvcnQtY2lyY3VpdCB0aGUgVVJMIGNvbnN0cnVjdG9yIGlmIGl0J3Mgbm90IGEgdmFsaWQgVVJMXG4gICAgLy8gVGhpcyBpcyBmYXN0ZXIgdGhhbiB0cnlpbmcgdG8gY29uc3RydWN0IHRoZSBVUkwgYW5kIGNhdGNoaW5nIHRoZSBlcnJvclxuICAgIC8vIE5vZGUgMjArLCBDaHJvbWUgMTIwKywgRmlyZWZveCAxMTUrLCBTYWZhcmkgMTcrXG4gICAgaWYgKCdjYW5QYXJzZScgaW4gVVJMICYmICEoVVJMICkuY2FuUGFyc2UodXJsLCBiYXNlKSkge1xuICAgICAgcmV0dXJuIHVuZGVmaW5lZDtcbiAgICB9XG5cbiAgICBjb25zdCBmdWxsVXJsT2JqZWN0ID0gbmV3IFVSTCh1cmwsIGJhc2UpO1xuICAgIGlmIChpc1JlbGF0aXZlKSB7XG4gICAgICAvLyBCZWNhdXNlIHdlIHVzZWQgYSBmYWtlIGJhc2UgVVJMLCB3ZSBuZWVkIHRvIHJldHVybiBhIHJlbGF0aXZlIFVSTCBvYmplY3QuXG4gICAgICAvLyBXZSBjYW5ub3QgcmV0dXJuIGFueXRoaW5nIGFib3V0IHRoZSBvcmlnaW4sIGhvc3QsIGV0Yy4gYmVjYXVzZSBpdCB3aWxsIHJlZmVyIHRvIHRoZSBmYWtlIGJhc2UgVVJMLlxuICAgICAgcmV0dXJuIHtcbiAgICAgICAgaXNSZWxhdGl2ZSxcbiAgICAgICAgcGF0aG5hbWU6IGZ1bGxVcmxPYmplY3QucGF0aG5hbWUsXG4gICAgICAgIHNlYXJjaDogZnVsbFVybE9iamVjdC5zZWFyY2gsXG4gICAgICAgIGhhc2g6IGZ1bGxVcmxPYmplY3QuaGFzaCxcbiAgICAgIH07XG4gICAgfVxuICAgIHJldHVybiBmdWxsVXJsT2JqZWN0O1xuICB9IGNhdGNoIHtcbiAgICAvLyBlbXB0eSBib2R5XG4gIH1cblxuICByZXR1cm4gdW5kZWZpbmVkO1xufVxuXG4vKipcbiAqIFRha2VzIGEgVVJMIG9iamVjdCBhbmQgcmV0dXJucyBhIHNhbml0aXplZCBzdHJpbmcgd2hpY2ggaXMgc2FmZSB0byB1c2UgYXMgc3BhbiBuYW1lXG4gKiBzZWU6IGh0dHBzOi8vZGV2ZWxvcC5zZW50cnkuZGV2L3Nkay9kYXRhLWhhbmRsaW5nLyNzdHJ1Y3R1cmluZy1kYXRhXG4gKi9cbmZ1bmN0aW9uIGdldFNhbml0aXplZFVybFN0cmluZ0Zyb21VcmxPYmplY3QodXJsKSB7XG4gIGlmIChpc1VSTE9iamVjdFJlbGF0aXZlKHVybCkpIHtcbiAgICByZXR1cm4gdXJsLnBhdGhuYW1lO1xuICB9XG5cbiAgY29uc3QgbmV3VXJsID0gbmV3IFVSTCh1cmwpO1xuICBuZXdVcmwuc2VhcmNoID0gJyc7XG4gIG5ld1VybC5oYXNoID0gJyc7XG4gIGlmIChbJzgwJywgJzQ0MyddLmluY2x1ZGVzKG5ld1VybC5wb3J0KSkge1xuICAgIG5ld1VybC5wb3J0ID0gJyc7XG4gIH1cbiAgaWYgKG5ld1VybC5wYXNzd29yZCkge1xuICAgIG5ld1VybC5wYXNzd29yZCA9ICclZmlsdGVyZWQlJztcbiAgfVxuICBpZiAobmV3VXJsLnVzZXJuYW1lKSB7XG4gICAgbmV3VXJsLnVzZXJuYW1lID0gJyVmaWx0ZXJlZCUnO1xuICB9XG5cbiAgcmV0dXJuIG5ld1VybC50b1N0cmluZygpO1xufVxuXG5mdW5jdGlvbiBnZXRIdHRwU3Bhbk5hbWVGcm9tVXJsT2JqZWN0KFxuICB1cmxPYmplY3QsXG4gIGtpbmQsXG4gIHJlcXVlc3QsXG4gIHJvdXRlTmFtZSxcbikge1xuICBjb25zdCBtZXRob2QgPSByZXF1ZXN0Py5tZXRob2Q/LnRvVXBwZXJDYXNlKCkgPz8gJ0dFVCc7XG4gIGNvbnN0IHJvdXRlID0gcm91dGVOYW1lXG4gICAgPyByb3V0ZU5hbWVcbiAgICA6IHVybE9iamVjdFxuICAgICAgPyBraW5kID09PSAnY2xpZW50J1xuICAgICAgICA/IGdldFNhbml0aXplZFVybFN0cmluZ0Zyb21VcmxPYmplY3QodXJsT2JqZWN0KVxuICAgICAgICA6IHVybE9iamVjdC5wYXRobmFtZVxuICAgICAgOiAnLyc7XG5cbiAgcmV0dXJuIGAke21ldGhvZH0gJHtyb3V0ZX1gO1xufVxuXG4vKipcbiAqIFRha2VzIGEgcGFyc2VkIFVSTCBvYmplY3QgYW5kIHJldHVybnMgYSBzZXQgb2YgYXR0cmlidXRlcyBmb3IgdGhlIHNwYW5cbiAqIHRoYXQgcmVwcmVzZW50cyB0aGUgSFRUUCByZXF1ZXN0IGZvciB0aGF0IHVybC4gVGhpcyBpcyB1c2VkIGZvciBib3RoIHNlcnZlclxuICogYW5kIGNsaWVudCBodHRwIHNwYW5zLlxuICpcbiAqIEZvbGxvd3MgaHR0cHM6Ly9vcGVudGVsZW1ldHJ5LmlvL2RvY3Mvc3BlY3Mvc2VtY29udi9odHRwLy5cbiAqXG4gKiBAcGFyYW0gdXJsT2JqZWN0IC0gc2VlIHtAbGluayBwYXJzZVN0cmluZ1RvVVJMT2JqZWN0fVxuICogQHBhcmFtIGtpbmQgLSBUaGUgdHlwZSBvZiBIVFRQIG9wZXJhdGlvbiAoc2VydmVyIG9yIGNsaWVudClcbiAqIEBwYXJhbSBzcGFuT3JpZ2luIC0gVGhlIG9yaWdpbiBvZiB0aGUgc3BhblxuICogQHBhcmFtIHJlcXVlc3QgLSBUaGUgcmVxdWVzdCBvYmplY3QsIHNlZSB7QGxpbmsgUGFydGlhbFJlcXVlc3R9XG4gKiBAcGFyYW0gcm91dGVOYW1lIC0gVGhlIG5hbWUgb2YgdGhlIHJvdXRlLCBtdXN0IGJlIGxvdyBjYXJkaW5hbGl0eVxuICogQHJldHVybnMgVGhlIHNwYW4gbmFtZSBhbmQgYXR0cmlidXRlcyBmb3IgdGhlIEhUVFAgb3BlcmF0aW9uXG4gKi9cbmZ1bmN0aW9uIGdldEh0dHBTcGFuRGV0YWlsc0Zyb21VcmxPYmplY3QoXG4gIHVybE9iamVjdCxcbiAga2luZCxcbiAgc3Bhbk9yaWdpbixcbiAgcmVxdWVzdCxcbiAgcm91dGVOYW1lLFxuKSB7XG4gIGNvbnN0IGF0dHJpYnV0ZXMgPSB7XG4gICAgW3NlbWFudGljQXR0cmlidXRlcy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX09SSUdJTl06IHNwYW5PcmlnaW4sXG4gICAgW3NlbWFudGljQXR0cmlidXRlcy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX1NPVVJDRV06ICd1cmwnLFxuICB9O1xuXG4gIGlmIChyb3V0ZU5hbWUpIHtcbiAgICAvLyBUaGlzIGlzIGJhc2VkIG9uIGh0dHBzOi8vb3BlbnRlbGVtZXRyeS5pby9kb2NzL3NwZWNzL3NlbWNvbnYvaHR0cC9odHRwLXNwYW5zLyNuYW1lXG4gICAgYXR0cmlidXRlc1traW5kID09PSAnc2VydmVyJyA/ICdodHRwLnJvdXRlJyA6ICd1cmwudGVtcGxhdGUnXSA9IHJvdXRlTmFtZTtcbiAgICBhdHRyaWJ1dGVzW3NlbWFudGljQXR0cmlidXRlcy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX1NPVVJDRV0gPSAncm91dGUnO1xuICB9XG5cbiAgaWYgKHJlcXVlc3Q/Lm1ldGhvZCkge1xuICAgIGF0dHJpYnV0ZXNbc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9IVFRQX1JFUVVFU1RfTUVUSE9EXSA9IHJlcXVlc3QubWV0aG9kLnRvVXBwZXJDYXNlKCk7XG4gIH1cblxuICBpZiAodXJsT2JqZWN0KSB7XG4gICAgaWYgKHVybE9iamVjdC5zZWFyY2gpIHtcbiAgICAgIGF0dHJpYnV0ZXNbJ3VybC5xdWVyeSddID0gdXJsT2JqZWN0LnNlYXJjaDtcbiAgICB9XG4gICAgaWYgKHVybE9iamVjdC5oYXNoKSB7XG4gICAgICBhdHRyaWJ1dGVzWyd1cmwuZnJhZ21lbnQnXSA9IHVybE9iamVjdC5oYXNoO1xuICAgIH1cbiAgICBpZiAodXJsT2JqZWN0LnBhdGhuYW1lKSB7XG4gICAgICBhdHRyaWJ1dGVzWyd1cmwucGF0aCddID0gdXJsT2JqZWN0LnBhdGhuYW1lO1xuICAgICAgaWYgKHVybE9iamVjdC5wYXRobmFtZSA9PT0gJy8nKSB7XG4gICAgICAgIGF0dHJpYnV0ZXNbc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfU09VUkNFXSA9ICdyb3V0ZSc7XG4gICAgICB9XG4gICAgfVxuXG4gICAgaWYgKCFpc1VSTE9iamVjdFJlbGF0aXZlKHVybE9iamVjdCkpIHtcbiAgICAgIGF0dHJpYnV0ZXNbc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9VUkxfRlVMTF0gPSB1cmxPYmplY3QuaHJlZjtcbiAgICAgIGlmICh1cmxPYmplY3QucG9ydCkge1xuICAgICAgICBhdHRyaWJ1dGVzWyd1cmwucG9ydCddID0gdXJsT2JqZWN0LnBvcnQ7XG4gICAgICB9XG4gICAgICBpZiAodXJsT2JqZWN0LnByb3RvY29sKSB7XG4gICAgICAgIGF0dHJpYnV0ZXNbJ3VybC5zY2hlbWUnXSA9IHVybE9iamVjdC5wcm90b2NvbDtcbiAgICAgIH1cbiAgICAgIGlmICh1cmxPYmplY3QuaG9zdG5hbWUpIHtcbiAgICAgICAgYXR0cmlidXRlc1traW5kID09PSAnc2VydmVyJyA/ICdzZXJ2ZXIuYWRkcmVzcycgOiAndXJsLmRvbWFpbiddID0gdXJsT2JqZWN0Lmhvc3RuYW1lO1xuICAgICAgfVxuICAgIH1cbiAgfVxuXG4gIHJldHVybiBbZ2V0SHR0cFNwYW5OYW1lRnJvbVVybE9iamVjdCh1cmxPYmplY3QsIGtpbmQsIHJlcXVlc3QsIHJvdXRlTmFtZSksIGF0dHJpYnV0ZXNdO1xufVxuXG4vKipcbiAqIFBhcnNlcyBzdHJpbmcgZm9ybSBvZiBVUkwgaW50byBhbiBvYmplY3RcbiAqIC8vIGJvcnJvd2VkIGZyb20gaHR0cHM6Ly90b29scy5pZXRmLm9yZy9odG1sL3JmYzM5ODYjYXBwZW5kaXgtQlxuICogLy8gaW50ZW50aW9uYWxseSB1c2luZyByZWdleCBhbmQgbm90IDxhLz4gaHJlZiBwYXJzaW5nIHRyaWNrIGJlY2F1c2UgUmVhY3QgTmF0aXZlIGFuZCBvdGhlclxuICogLy8gZW52aXJvbm1lbnRzIHdoZXJlIERPTSBtaWdodCBub3QgYmUgYXZhaWxhYmxlXG4gKiBAcmV0dXJucyBwYXJzZWQgVVJMIG9iamVjdFxuICovXG5mdW5jdGlvbiBwYXJzZVVybCh1cmwpIHtcbiAgaWYgKCF1cmwpIHtcbiAgICByZXR1cm4ge307XG4gIH1cblxuICBjb25zdCBtYXRjaCA9IHVybC5tYXRjaCgvXigoW146Lz8jXSspOik/KFxcL1xcLyhbXi8/I10qKSk/KFtePyNdKikoXFw/KFteI10qKSk/KCMoLiopKT8kLyk7XG5cbiAgaWYgKCFtYXRjaCkge1xuICAgIHJldHVybiB7fTtcbiAgfVxuXG4gIC8vIGNvZXJjZSB0byB1bmRlZmluZWQgdmFsdWVzIHRvIGVtcHR5IHN0cmluZyBzbyB3ZSBkb24ndCBnZXQgJ3VuZGVmaW5lZCdcbiAgY29uc3QgcXVlcnkgPSBtYXRjaFs2XSB8fCAnJztcbiAgY29uc3QgZnJhZ21lbnQgPSBtYXRjaFs4XSB8fCAnJztcbiAgcmV0dXJuIHtcbiAgICBob3N0OiBtYXRjaFs0XSxcbiAgICBwYXRoOiBtYXRjaFs1XSxcbiAgICBwcm90b2NvbDogbWF0Y2hbMl0sXG4gICAgc2VhcmNoOiBxdWVyeSxcbiAgICBoYXNoOiBmcmFnbWVudCxcbiAgICByZWxhdGl2ZTogbWF0Y2hbNV0gKyBxdWVyeSArIGZyYWdtZW50LCAvLyBldmVyeXRoaW5nIG1pbnVzIG9yaWdpblxuICB9O1xufVxuXG4vKipcbiAqIFN0cmlwIHRoZSBxdWVyeSBzdHJpbmcgYW5kIGZyYWdtZW50IG9mZiBvZiBhIGdpdmVuIFVSTCBvciBwYXRoIChpZiBwcmVzZW50KVxuICpcbiAqIEBwYXJhbSB1cmxQYXRoIEZ1bGwgVVJMIG9yIHBhdGgsIGluY2x1ZGluZyBwb3NzaWJsZSBxdWVyeSBzdHJpbmcgYW5kL29yIGZyYWdtZW50XG4gKiBAcmV0dXJucyBVUkwgb3IgcGF0aCB3aXRob3V0IHF1ZXJ5IHN0cmluZyBvciBmcmFnbWVudFxuICovXG5mdW5jdGlvbiBzdHJpcFVybFF1ZXJ5QW5kRnJhZ21lbnQodXJsUGF0aCkge1xuICByZXR1cm4gKHVybFBhdGguc3BsaXQoL1s/I10vLCAxKSApWzBdO1xufVxuXG4vKipcbiAqIFRha2VzIGEgVVJMIG9iamVjdCBhbmQgcmV0dXJucyBhIHNhbml0aXplZCBzdHJpbmcgd2hpY2ggaXMgc2FmZSB0byB1c2UgYXMgc3BhbiBuYW1lXG4gKiBzZWU6IGh0dHBzOi8vZGV2ZWxvcC5zZW50cnkuZGV2L3Nkay9kYXRhLWhhbmRsaW5nLyNzdHJ1Y3R1cmluZy1kYXRhXG4gKi9cbmZ1bmN0aW9uIGdldFNhbml0aXplZFVybFN0cmluZyh1cmwpIHtcbiAgY29uc3QgeyBwcm90b2NvbCwgaG9zdCwgcGF0aCB9ID0gdXJsO1xuXG4gIGNvbnN0IGZpbHRlcmVkSG9zdCA9XG4gICAgaG9zdFxuICAgICAgLy8gQWx3YXlzIGZpbHRlciBvdXQgYXV0aG9yaXR5XG4gICAgICA/LnJlcGxhY2UoL14uKkAvLCAnW2ZpbHRlcmVkXTpbZmlsdGVyZWRdQCcpXG4gICAgICAvLyBEb24ndCBzaG93IHN0YW5kYXJkIDo4MCAoaHR0cCkgYW5kIDo0NDMgKGh0dHBzKSBwb3J0cyB0byByZWR1Y2UgdGhlIG5vaXNlXG4gICAgICAvLyBUT0RPOiBVc2UgbmV3IFVSTCBnbG9iYWwgaWYgaXQgZXhpc3RzXG4gICAgICAucmVwbGFjZSgvKDo4MCkkLywgJycpXG4gICAgICAucmVwbGFjZSgvKDo0NDMpJC8sICcnKSB8fCAnJztcblxuICByZXR1cm4gYCR7cHJvdG9jb2wgPyBgJHtwcm90b2NvbH06Ly9gIDogJyd9JHtmaWx0ZXJlZEhvc3R9JHtwYXRofWA7XG59XG5cbmV4cG9ydHMuZ2V0SHR0cFNwYW5EZXRhaWxzRnJvbVVybE9iamVjdCA9IGdldEh0dHBTcGFuRGV0YWlsc0Zyb21VcmxPYmplY3Q7XG5leHBvcnRzLmdldFNhbml0aXplZFVybFN0cmluZyA9IGdldFNhbml0aXplZFVybFN0cmluZztcbmV4cG9ydHMuZ2V0U2FuaXRpemVkVXJsU3RyaW5nRnJvbVVybE9iamVjdCA9IGdldFNhbml0aXplZFVybFN0cmluZ0Zyb21VcmxPYmplY3Q7XG5leHBvcnRzLmlzVVJMT2JqZWN0UmVsYXRpdmUgPSBpc1VSTE9iamVjdFJlbGF0aXZlO1xuZXhwb3J0cy5wYXJzZVN0cmluZ1RvVVJMT2JqZWN0ID0gcGFyc2VTdHJpbmdUb1VSTE9iamVjdDtcbmV4cG9ydHMucGFyc2VVcmwgPSBwYXJzZVVybDtcbmV4cG9ydHMuc3RyaXBVcmxRdWVyeUFuZEZyYWdtZW50ID0gc3RyaXBVcmxRdWVyeUFuZEZyYWdtZW50O1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9dXJsLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/url.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/vercel-ai-attributes.js":
/*!******************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/vercel-ai-attributes.js ***!
  \******************************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n/* eslint-disable max-lines */\n/**\n * AI SDK Telemetry Attributes\n * Based on https://ai-sdk.dev/docs/ai-sdk-core/telemetry#collected-data\n */\n\n\n// =============================================================================\n// SHARED ATTRIBUTES\n// =============================================================================\n\n/**\n * `generateText` function - `ai.generateText` span\n * `streamText` function - `ai.streamText` span\n *\n * The prompt that was used when calling the function\n * @see https://ai-sdk.dev/docs/ai-sdk-core/telemetry#generatetext-function\n * @see https://ai-sdk.dev/docs/ai-sdk-core/telemetry#streamtext-function\n */\nconst AI_PROMPT_ATTRIBUTE = 'ai.prompt';\n\n/**\n * `generateObject` function - `ai.generateObject` span\n * `streamObject` function - `ai.streamObject` span\n *\n * The object that was generated (stringified JSON)\n * @see https://ai-sdk.dev/docs/ai-sdk-core/telemetry#generateobject-function\n * @see https://ai-sdk.dev/docs/ai-sdk-core/telemetry#streamobject-function\n */\nconst AI_RESPONSE_OBJECT_ATTRIBUTE = 'ai.response.object';\n\n// =============================================================================\n// GENERATETEXT FUNCTION - UNIQUE ATTRIBUTES\n// =============================================================================\n\n/**\n * `generateText` function - `ai.generateText` span\n *\n * The text that was generated\n * @see https://ai-sdk.dev/docs/ai-sdk-core/telemetry#generatetext-function\n */\nconst AI_RESPONSE_TEXT_ATTRIBUTE = 'ai.response.text';\n\n/**\n * `generateText` function - `ai.generateText` span\n *\n * The tool calls that were made as part of the generation (stringified JSON)\n * @see https://ai-sdk.dev/docs/ai-sdk-core/telemetry#generatetext-function\n */\nconst AI_RESPONSE_TOOL_CALLS_ATTRIBUTE = 'ai.response.toolCalls';\n\n/**\n * `generateText` function - `ai.generateText.doGenerate` span\n *\n * The messages that were passed into the provider\n * @see https://ai-sdk.dev/docs/ai-sdk-core/telemetry#generatetext-function\n */\nconst AI_PROMPT_MESSAGES_ATTRIBUTE = 'ai.prompt.messages';\n\n/**\n * `generateText` function - `ai.generateText.doGenerate` span\n *\n * Array of stringified tool definitions\n * @see https://ai-sdk.dev/docs/ai-sdk-core/telemetry#generatetext-function\n */\nconst AI_PROMPT_TOOLS_ATTRIBUTE = 'ai.prompt.tools';\n\n/**\n * Basic LLM span information\n * Multiple spans\n *\n * The id of the model\n * @see https://ai-sdk.dev/docs/ai-sdk-core/telemetry#basic-llm-span-information\n */\nconst AI_MODEL_ID_ATTRIBUTE = 'ai.model.id';\n\n/**\n * Basic LLM span information\n * Multiple spans\n *\n * The provider of the model\n * @see https://ai-sdk.dev/docs/ai-sdk-core/telemetry#basic-llm-span-information\n */\nconst AI_MODEL_PROVIDER_ATTRIBUTE = 'ai.model.provider';\n\n/**\n * Basic LLM span information\n * Multiple spans\n *\n * Provider specific metadata returned with the generation response\n * @see https://ai-sdk.dev/docs/ai-sdk-core/telemetry#basic-llm-span-information\n */\nconst AI_RESPONSE_PROVIDER_METADATA_ATTRIBUTE = 'ai.response.providerMetadata';\n\n/**\n * Basic LLM span information\n * Multiple spans\n *\n * The functionId that was set through `telemetry.functionId`\n * @see https://ai-sdk.dev/docs/ai-sdk-core/telemetry#basic-llm-span-information\n */\nconst AI_TELEMETRY_FUNCTION_ID_ATTRIBUTE = 'ai.telemetry.functionId';\n\n/**\n * Basic LLM span information\n * Multiple spans\n *\n * The number of completion tokens that were used\n * @see https://ai-sdk.dev/docs/ai-sdk-core/telemetry#basic-llm-span-information\n */\nconst AI_USAGE_COMPLETION_TOKENS_ATTRIBUTE = 'ai.usage.completionTokens';\n\n/**\n * Basic LLM span information\n * Multiple spans\n *\n * The number of prompt tokens that were used\n * @see https://ai-sdk.dev/docs/ai-sdk-core/telemetry#basic-llm-span-information\n */\nconst AI_USAGE_PROMPT_TOKENS_ATTRIBUTE = 'ai.usage.promptTokens';\n\n/**\n * Semantic Conventions for GenAI operations\n * Individual LLM call spans\n *\n * The model that was used to generate the response\n * @see https://ai-sdk.dev/docs/ai-sdk-core/telemetry#call-llm-span-information\n */\nconst GEN_AI_RESPONSE_MODEL_ATTRIBUTE = 'gen_ai.response.model';\n\n/**\n * Semantic Conventions for GenAI operations\n * Individual LLM call spans\n *\n * The number of prompt tokens that were used\n * @see https://ai-sdk.dev/docs/ai-sdk-core/telemetry#call-llm-span-information\n */\nconst GEN_AI_USAGE_INPUT_TOKENS_ATTRIBUTE = 'gen_ai.usage.input_tokens';\n\n/**\n * Semantic Conventions for GenAI operations\n * Individual LLM call spans\n *\n * The number of completion tokens that were used\n * @see https://ai-sdk.dev/docs/ai-sdk-core/telemetry#call-llm-span-information\n */\nconst GEN_AI_USAGE_OUTPUT_TOKENS_ATTRIBUTE = 'gen_ai.usage.output_tokens';\n\n// =============================================================================\n// TOOL CALL SPANS\n// =============================================================================\n\n/**\n * Tool call spans\n * `ai.toolCall` span\n *\n * The name of the tool\n * @see https://ai-sdk.dev/docs/ai-sdk-core/telemetry#tool-call-spans\n */\nconst AI_TOOL_CALL_NAME_ATTRIBUTE = 'ai.toolCall.name';\n\n/**\n * Tool call spans\n * `ai.toolCall` span\n *\n * The id of the tool call\n * @see https://ai-sdk.dev/docs/ai-sdk-core/telemetry#tool-call-spans\n */\nconst AI_TOOL_CALL_ID_ATTRIBUTE = 'ai.toolCall.id';\n\n/**\n * Tool call spans\n * `ai.toolCall` span\n *\n * The parameters of the tool call\n * @see https://ai-sdk.dev/docs/ai-sdk-core/telemetry#tool-call-spans\n */\nconst AI_TOOL_CALL_ARGS_ATTRIBUTE = 'ai.toolCall.args';\n\n/**\n * Tool call spans\n * `ai.toolCall` span\n *\n * The result of the tool call\n * @see https://ai-sdk.dev/docs/ai-sdk-core/telemetry#tool-call-spans\n */\nconst AI_TOOL_CALL_RESULT_ATTRIBUTE = 'ai.toolCall.result';\n\n// =============================================================================\n// PROVIDER METADATA\n// =============================================================================\n\n/**\n * OpenAI Provider Metadata\n * @see https://ai-sdk.dev/providers/ai-sdk-providers/openai\n * @see https://github.com/vercel/ai/blob/65e042afde6aad4da9d7a62526ece839eb34f9a5/packages/openai/src/openai-chat-language-model.ts#L397-L416\n * @see https://github.com/vercel/ai/blob/65e042afde6aad4da9d7a62526ece839eb34f9a5/packages/openai/src/responses/openai-responses-language-model.ts#L377C7-L384\n */\n\nexports.AI_MODEL_ID_ATTRIBUTE = AI_MODEL_ID_ATTRIBUTE;\nexports.AI_MODEL_PROVIDER_ATTRIBUTE = AI_MODEL_PROVIDER_ATTRIBUTE;\nexports.AI_PROMPT_ATTRIBUTE = AI_PROMPT_ATTRIBUTE;\nexports.AI_PROMPT_MESSAGES_ATTRIBUTE = AI_PROMPT_MESSAGES_ATTRIBUTE;\nexports.AI_PROMPT_TOOLS_ATTRIBUTE = AI_PROMPT_TOOLS_ATTRIBUTE;\nexports.AI_RESPONSE_OBJECT_ATTRIBUTE = AI_RESPONSE_OBJECT_ATTRIBUTE;\nexports.AI_RESPONSE_PROVIDER_METADATA_ATTRIBUTE = AI_RESPONSE_PROVIDER_METADATA_ATTRIBUTE;\nexports.AI_RESPONSE_TEXT_ATTRIBUTE = AI_RESPONSE_TEXT_ATTRIBUTE;\nexports.AI_RESPONSE_TOOL_CALLS_ATTRIBUTE = AI_RESPONSE_TOOL_CALLS_ATTRIBUTE;\nexports.AI_TELEMETRY_FUNCTION_ID_ATTRIBUTE = AI_TELEMETRY_FUNCTION_ID_ATTRIBUTE;\nexports.AI_TOOL_CALL_ARGS_ATTRIBUTE = AI_TOOL_CALL_ARGS_ATTRIBUTE;\nexports.AI_TOOL_CALL_ID_ATTRIBUTE = AI_TOOL_CALL_ID_ATTRIBUTE;\nexports.AI_TOOL_CALL_NAME_ATTRIBUTE = AI_TOOL_CALL_NAME_ATTRIBUTE;\nexports.AI_TOOL_CALL_RESULT_ATTRIBUTE = AI_TOOL_CALL_RESULT_ATTRIBUTE;\nexports.AI_USAGE_COMPLETION_TOKENS_ATTRIBUTE = AI_USAGE_COMPLETION_TOKENS_ATTRIBUTE;\nexports.AI_USAGE_PROMPT_TOKENS_ATTRIBUTE = AI_USAGE_PROMPT_TOKENS_ATTRIBUTE;\nexports.GEN_AI_RESPONSE_MODEL_ATTRIBUTE = GEN_AI_RESPONSE_MODEL_ATTRIBUTE;\nexports.GEN_AI_USAGE_INPUT_TOKENS_ATTRIBUTE = GEN_AI_USAGE_INPUT_TOKENS_ATTRIBUTE;\nexports.GEN_AI_USAGE_OUTPUT_TOKENS_ATTRIBUTE = GEN_AI_USAGE_OUTPUT_TOKENS_ATTRIBUTE;\n//# sourceMappingURL=vercel-ai-attributes.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvdmVyY2VsLWFpLWF0dHJpYnV0ZXMuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEU7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7O0FBR0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsNkJBQTZCO0FBQzdCLG1DQUFtQztBQUNuQywyQkFBMkI7QUFDM0Isb0NBQW9DO0FBQ3BDLGlDQUFpQztBQUNqQyxvQ0FBb0M7QUFDcEMsK0NBQStDO0FBQy9DLGtDQUFrQztBQUNsQyx3Q0FBd0M7QUFDeEMsMENBQTBDO0FBQzFDLG1DQUFtQztBQUNuQyxpQ0FBaUM7QUFDakMsbUNBQW1DO0FBQ25DLHFDQUFxQztBQUNyQyw0Q0FBNEM7QUFDNUMsd0NBQXdDO0FBQ3hDLHVDQUF1QztBQUN2QywyQ0FBMkM7QUFDM0MsNENBQTRDO0FBQzVDIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvdmVyY2VsLWFpLWF0dHJpYnV0ZXMuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbi8qIGVzbGludC1kaXNhYmxlIG1heC1saW5lcyAqL1xuLyoqXG4gKiBBSSBTREsgVGVsZW1ldHJ5IEF0dHJpYnV0ZXNcbiAqIEJhc2VkIG9uIGh0dHBzOi8vYWktc2RrLmRldi9kb2NzL2FpLXNkay1jb3JlL3RlbGVtZXRyeSNjb2xsZWN0ZWQtZGF0YVxuICovXG5cblxuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cbi8vIFNIQVJFRCBBVFRSSUJVVEVTXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuXG4vKipcbiAqIGBnZW5lcmF0ZVRleHRgIGZ1bmN0aW9uIC0gYGFpLmdlbmVyYXRlVGV4dGAgc3BhblxuICogYHN0cmVhbVRleHRgIGZ1bmN0aW9uIC0gYGFpLnN0cmVhbVRleHRgIHNwYW5cbiAqXG4gKiBUaGUgcHJvbXB0IHRoYXQgd2FzIHVzZWQgd2hlbiBjYWxsaW5nIHRoZSBmdW5jdGlvblxuICogQHNlZSBodHRwczovL2FpLXNkay5kZXYvZG9jcy9haS1zZGstY29yZS90ZWxlbWV0cnkjZ2VuZXJhdGV0ZXh0LWZ1bmN0aW9uXG4gKiBAc2VlIGh0dHBzOi8vYWktc2RrLmRldi9kb2NzL2FpLXNkay1jb3JlL3RlbGVtZXRyeSNzdHJlYW10ZXh0LWZ1bmN0aW9uXG4gKi9cbmNvbnN0IEFJX1BST01QVF9BVFRSSUJVVEUgPSAnYWkucHJvbXB0JztcblxuLyoqXG4gKiBgZ2VuZXJhdGVPYmplY3RgIGZ1bmN0aW9uIC0gYGFpLmdlbmVyYXRlT2JqZWN0YCBzcGFuXG4gKiBgc3RyZWFtT2JqZWN0YCBmdW5jdGlvbiAtIGBhaS5zdHJlYW1PYmplY3RgIHNwYW5cbiAqXG4gKiBUaGUgb2JqZWN0IHRoYXQgd2FzIGdlbmVyYXRlZCAoc3RyaW5naWZpZWQgSlNPTilcbiAqIEBzZWUgaHR0cHM6Ly9haS1zZGsuZGV2L2RvY3MvYWktc2RrLWNvcmUvdGVsZW1ldHJ5I2dlbmVyYXRlb2JqZWN0LWZ1bmN0aW9uXG4gKiBAc2VlIGh0dHBzOi8vYWktc2RrLmRldi9kb2NzL2FpLXNkay1jb3JlL3RlbGVtZXRyeSNzdHJlYW1vYmplY3QtZnVuY3Rpb25cbiAqL1xuY29uc3QgQUlfUkVTUE9OU0VfT0JKRUNUX0FUVFJJQlVURSA9ICdhaS5yZXNwb25zZS5vYmplY3QnO1xuXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuLy8gR0VORVJBVEVURVhUIEZVTkNUSU9OIC0gVU5JUVVFIEFUVFJJQlVURVNcbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG5cbi8qKlxuICogYGdlbmVyYXRlVGV4dGAgZnVuY3Rpb24gLSBgYWkuZ2VuZXJhdGVUZXh0YCBzcGFuXG4gKlxuICogVGhlIHRleHQgdGhhdCB3YXMgZ2VuZXJhdGVkXG4gKiBAc2VlIGh0dHBzOi8vYWktc2RrLmRldi9kb2NzL2FpLXNkay1jb3JlL3RlbGVtZXRyeSNnZW5lcmF0ZXRleHQtZnVuY3Rpb25cbiAqL1xuY29uc3QgQUlfUkVTUE9OU0VfVEVYVF9BVFRSSUJVVEUgPSAnYWkucmVzcG9uc2UudGV4dCc7XG5cbi8qKlxuICogYGdlbmVyYXRlVGV4dGAgZnVuY3Rpb24gLSBgYWkuZ2VuZXJhdGVUZXh0YCBzcGFuXG4gKlxuICogVGhlIHRvb2wgY2FsbHMgdGhhdCB3ZXJlIG1hZGUgYXMgcGFydCBvZiB0aGUgZ2VuZXJhdGlvbiAoc3RyaW5naWZpZWQgSlNPTilcbiAqIEBzZWUgaHR0cHM6Ly9haS1zZGsuZGV2L2RvY3MvYWktc2RrLWNvcmUvdGVsZW1ldHJ5I2dlbmVyYXRldGV4dC1mdW5jdGlvblxuICovXG5jb25zdCBBSV9SRVNQT05TRV9UT09MX0NBTExTX0FUVFJJQlVURSA9ICdhaS5yZXNwb25zZS50b29sQ2FsbHMnO1xuXG4vKipcbiAqIGBnZW5lcmF0ZVRleHRgIGZ1bmN0aW9uIC0gYGFpLmdlbmVyYXRlVGV4dC5kb0dlbmVyYXRlYCBzcGFuXG4gKlxuICogVGhlIG1lc3NhZ2VzIHRoYXQgd2VyZSBwYXNzZWQgaW50byB0aGUgcHJvdmlkZXJcbiAqIEBzZWUgaHR0cHM6Ly9haS1zZGsuZGV2L2RvY3MvYWktc2RrLWNvcmUvdGVsZW1ldHJ5I2dlbmVyYXRldGV4dC1mdW5jdGlvblxuICovXG5jb25zdCBBSV9QUk9NUFRfTUVTU0FHRVNfQVRUUklCVVRFID0gJ2FpLnByb21wdC5tZXNzYWdlcyc7XG5cbi8qKlxuICogYGdlbmVyYXRlVGV4dGAgZnVuY3Rpb24gLSBgYWkuZ2VuZXJhdGVUZXh0LmRvR2VuZXJhdGVgIHNwYW5cbiAqXG4gKiBBcnJheSBvZiBzdHJpbmdpZmllZCB0b29sIGRlZmluaXRpb25zXG4gKiBAc2VlIGh0dHBzOi8vYWktc2RrLmRldi9kb2NzL2FpLXNkay1jb3JlL3RlbGVtZXRyeSNnZW5lcmF0ZXRleHQtZnVuY3Rpb25cbiAqL1xuY29uc3QgQUlfUFJPTVBUX1RPT0xTX0FUVFJJQlVURSA9ICdhaS5wcm9tcHQudG9vbHMnO1xuXG4vKipcbiAqIEJhc2ljIExMTSBzcGFuIGluZm9ybWF0aW9uXG4gKiBNdWx0aXBsZSBzcGFuc1xuICpcbiAqIFRoZSBpZCBvZiB0aGUgbW9kZWxcbiAqIEBzZWUgaHR0cHM6Ly9haS1zZGsuZGV2L2RvY3MvYWktc2RrLWNvcmUvdGVsZW1ldHJ5I2Jhc2ljLWxsbS1zcGFuLWluZm9ybWF0aW9uXG4gKi9cbmNvbnN0IEFJX01PREVMX0lEX0FUVFJJQlVURSA9ICdhaS5tb2RlbC5pZCc7XG5cbi8qKlxuICogQmFzaWMgTExNIHNwYW4gaW5mb3JtYXRpb25cbiAqIE11bHRpcGxlIHNwYW5zXG4gKlxuICogVGhlIHByb3ZpZGVyIG9mIHRoZSBtb2RlbFxuICogQHNlZSBodHRwczovL2FpLXNkay5kZXYvZG9jcy9haS1zZGstY29yZS90ZWxlbWV0cnkjYmFzaWMtbGxtLXNwYW4taW5mb3JtYXRpb25cbiAqL1xuY29uc3QgQUlfTU9ERUxfUFJPVklERVJfQVRUUklCVVRFID0gJ2FpLm1vZGVsLnByb3ZpZGVyJztcblxuLyoqXG4gKiBCYXNpYyBMTE0gc3BhbiBpbmZvcm1hdGlvblxuICogTXVsdGlwbGUgc3BhbnNcbiAqXG4gKiBQcm92aWRlciBzcGVjaWZpYyBtZXRhZGF0YSByZXR1cm5lZCB3aXRoIHRoZSBnZW5lcmF0aW9uIHJlc3BvbnNlXG4gKiBAc2VlIGh0dHBzOi8vYWktc2RrLmRldi9kb2NzL2FpLXNkay1jb3JlL3RlbGVtZXRyeSNiYXNpYy1sbG0tc3Bhbi1pbmZvcm1hdGlvblxuICovXG5jb25zdCBBSV9SRVNQT05TRV9QUk9WSURFUl9NRVRBREFUQV9BVFRSSUJVVEUgPSAnYWkucmVzcG9uc2UucHJvdmlkZXJNZXRhZGF0YSc7XG5cbi8qKlxuICogQmFzaWMgTExNIHNwYW4gaW5mb3JtYXRpb25cbiAqIE11bHRpcGxlIHNwYW5zXG4gKlxuICogVGhlIGZ1bmN0aW9uSWQgdGhhdCB3YXMgc2V0IHRocm91Z2ggYHRlbGVtZXRyeS5mdW5jdGlvbklkYFxuICogQHNlZSBodHRwczovL2FpLXNkay5kZXYvZG9jcy9haS1zZGstY29yZS90ZWxlbWV0cnkjYmFzaWMtbGxtLXNwYW4taW5mb3JtYXRpb25cbiAqL1xuY29uc3QgQUlfVEVMRU1FVFJZX0ZVTkNUSU9OX0lEX0FUVFJJQlVURSA9ICdhaS50ZWxlbWV0cnkuZnVuY3Rpb25JZCc7XG5cbi8qKlxuICogQmFzaWMgTExNIHNwYW4gaW5mb3JtYXRpb25cbiAqIE11bHRpcGxlIHNwYW5zXG4gKlxuICogVGhlIG51bWJlciBvZiBjb21wbGV0aW9uIHRva2VucyB0aGF0IHdlcmUgdXNlZFxuICogQHNlZSBodHRwczovL2FpLXNkay5kZXYvZG9jcy9haS1zZGstY29yZS90ZWxlbWV0cnkjYmFzaWMtbGxtLXNwYW4taW5mb3JtYXRpb25cbiAqL1xuY29uc3QgQUlfVVNBR0VfQ09NUExFVElPTl9UT0tFTlNfQVRUUklCVVRFID0gJ2FpLnVzYWdlLmNvbXBsZXRpb25Ub2tlbnMnO1xuXG4vKipcbiAqIEJhc2ljIExMTSBzcGFuIGluZm9ybWF0aW9uXG4gKiBNdWx0aXBsZSBzcGFuc1xuICpcbiAqIFRoZSBudW1iZXIgb2YgcHJvbXB0IHRva2VucyB0aGF0IHdlcmUgdXNlZFxuICogQHNlZSBodHRwczovL2FpLXNkay5kZXYvZG9jcy9haS1zZGstY29yZS90ZWxlbWV0cnkjYmFzaWMtbGxtLXNwYW4taW5mb3JtYXRpb25cbiAqL1xuY29uc3QgQUlfVVNBR0VfUFJPTVBUX1RPS0VOU19BVFRSSUJVVEUgPSAnYWkudXNhZ2UucHJvbXB0VG9rZW5zJztcblxuLyoqXG4gKiBTZW1hbnRpYyBDb252ZW50aW9ucyBmb3IgR2VuQUkgb3BlcmF0aW9uc1xuICogSW5kaXZpZHVhbCBMTE0gY2FsbCBzcGFuc1xuICpcbiAqIFRoZSBtb2RlbCB0aGF0IHdhcyB1c2VkIHRvIGdlbmVyYXRlIHRoZSByZXNwb25zZVxuICogQHNlZSBodHRwczovL2FpLXNkay5kZXYvZG9jcy9haS1zZGstY29yZS90ZWxlbWV0cnkjY2FsbC1sbG0tc3Bhbi1pbmZvcm1hdGlvblxuICovXG5jb25zdCBHRU5fQUlfUkVTUE9OU0VfTU9ERUxfQVRUUklCVVRFID0gJ2dlbl9haS5yZXNwb25zZS5tb2RlbCc7XG5cbi8qKlxuICogU2VtYW50aWMgQ29udmVudGlvbnMgZm9yIEdlbkFJIG9wZXJhdGlvbnNcbiAqIEluZGl2aWR1YWwgTExNIGNhbGwgc3BhbnNcbiAqXG4gKiBUaGUgbnVtYmVyIG9mIHByb21wdCB0b2tlbnMgdGhhdCB3ZXJlIHVzZWRcbiAqIEBzZWUgaHR0cHM6Ly9haS1zZGsuZGV2L2RvY3MvYWktc2RrLWNvcmUvdGVsZW1ldHJ5I2NhbGwtbGxtLXNwYW4taW5mb3JtYXRpb25cbiAqL1xuY29uc3QgR0VOX0FJX1VTQUdFX0lOUFVUX1RPS0VOU19BVFRSSUJVVEUgPSAnZ2VuX2FpLnVzYWdlLmlucHV0X3Rva2Vucyc7XG5cbi8qKlxuICogU2VtYW50aWMgQ29udmVudGlvbnMgZm9yIEdlbkFJIG9wZXJhdGlvbnNcbiAqIEluZGl2aWR1YWwgTExNIGNhbGwgc3BhbnNcbiAqXG4gKiBUaGUgbnVtYmVyIG9mIGNvbXBsZXRpb24gdG9rZW5zIHRoYXQgd2VyZSB1c2VkXG4gKiBAc2VlIGh0dHBzOi8vYWktc2RrLmRldi9kb2NzL2FpLXNkay1jb3JlL3RlbGVtZXRyeSNjYWxsLWxsbS1zcGFuLWluZm9ybWF0aW9uXG4gKi9cbmNvbnN0IEdFTl9BSV9VU0FHRV9PVVRQVVRfVE9LRU5TX0FUVFJJQlVURSA9ICdnZW5fYWkudXNhZ2Uub3V0cHV0X3Rva2Vucyc7XG5cbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG4vLyBUT09MIENBTEwgU1BBTlNcbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG5cbi8qKlxuICogVG9vbCBjYWxsIHNwYW5zXG4gKiBgYWkudG9vbENhbGxgIHNwYW5cbiAqXG4gKiBUaGUgbmFtZSBvZiB0aGUgdG9vbFxuICogQHNlZSBodHRwczovL2FpLXNkay5kZXYvZG9jcy9haS1zZGstY29yZS90ZWxlbWV0cnkjdG9vbC1jYWxsLXNwYW5zXG4gKi9cbmNvbnN0IEFJX1RPT0xfQ0FMTF9OQU1FX0FUVFJJQlVURSA9ICdhaS50b29sQ2FsbC5uYW1lJztcblxuLyoqXG4gKiBUb29sIGNhbGwgc3BhbnNcbiAqIGBhaS50b29sQ2FsbGAgc3BhblxuICpcbiAqIFRoZSBpZCBvZiB0aGUgdG9vbCBjYWxsXG4gKiBAc2VlIGh0dHBzOi8vYWktc2RrLmRldi9kb2NzL2FpLXNkay1jb3JlL3RlbGVtZXRyeSN0b29sLWNhbGwtc3BhbnNcbiAqL1xuY29uc3QgQUlfVE9PTF9DQUxMX0lEX0FUVFJJQlVURSA9ICdhaS50b29sQ2FsbC5pZCc7XG5cbi8qKlxuICogVG9vbCBjYWxsIHNwYW5zXG4gKiBgYWkudG9vbENhbGxgIHNwYW5cbiAqXG4gKiBUaGUgcGFyYW1ldGVycyBvZiB0aGUgdG9vbCBjYWxsXG4gKiBAc2VlIGh0dHBzOi8vYWktc2RrLmRldi9kb2NzL2FpLXNkay1jb3JlL3RlbGVtZXRyeSN0b29sLWNhbGwtc3BhbnNcbiAqL1xuY29uc3QgQUlfVE9PTF9DQUxMX0FSR1NfQVRUUklCVVRFID0gJ2FpLnRvb2xDYWxsLmFyZ3MnO1xuXG4vKipcbiAqIFRvb2wgY2FsbCBzcGFuc1xuICogYGFpLnRvb2xDYWxsYCBzcGFuXG4gKlxuICogVGhlIHJlc3VsdCBvZiB0aGUgdG9vbCBjYWxsXG4gKiBAc2VlIGh0dHBzOi8vYWktc2RrLmRldi9kb2NzL2FpLXNkay1jb3JlL3RlbGVtZXRyeSN0b29sLWNhbGwtc3BhbnNcbiAqL1xuY29uc3QgQUlfVE9PTF9DQUxMX1JFU1VMVF9BVFRSSUJVVEUgPSAnYWkudG9vbENhbGwucmVzdWx0JztcblxuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cbi8vIFBST1ZJREVSIE1FVEFEQVRBXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuXG4vKipcbiAqIE9wZW5BSSBQcm92aWRlciBNZXRhZGF0YVxuICogQHNlZSBodHRwczovL2FpLXNkay5kZXYvcHJvdmlkZXJzL2FpLXNkay1wcm92aWRlcnMvb3BlbmFpXG4gKiBAc2VlIGh0dHBzOi8vZ2l0aHViLmNvbS92ZXJjZWwvYWkvYmxvYi82NWUwNDJhZmRlNmFhZDRkYTlkN2E2MjUyNmVjZTgzOWViMzRmOWE1L3BhY2thZ2VzL29wZW5haS9zcmMvb3BlbmFpLWNoYXQtbGFuZ3VhZ2UtbW9kZWwudHMjTDM5Ny1MNDE2XG4gKiBAc2VlIGh0dHBzOi8vZ2l0aHViLmNvbS92ZXJjZWwvYWkvYmxvYi82NWUwNDJhZmRlNmFhZDRkYTlkN2E2MjUyNmVjZTgzOWViMzRmOWE1L3BhY2thZ2VzL29wZW5haS9zcmMvcmVzcG9uc2VzL29wZW5haS1yZXNwb25zZXMtbGFuZ3VhZ2UtbW9kZWwudHMjTDM3N0M3LUwzODRcbiAqL1xuXG5leHBvcnRzLkFJX01PREVMX0lEX0FUVFJJQlVURSA9IEFJX01PREVMX0lEX0FUVFJJQlVURTtcbmV4cG9ydHMuQUlfTU9ERUxfUFJPVklERVJfQVRUUklCVVRFID0gQUlfTU9ERUxfUFJPVklERVJfQVRUUklCVVRFO1xuZXhwb3J0cy5BSV9QUk9NUFRfQVRUUklCVVRFID0gQUlfUFJPTVBUX0FUVFJJQlVURTtcbmV4cG9ydHMuQUlfUFJPTVBUX01FU1NBR0VTX0FUVFJJQlVURSA9IEFJX1BST01QVF9NRVNTQUdFU19BVFRSSUJVVEU7XG5leHBvcnRzLkFJX1BST01QVF9UT09MU19BVFRSSUJVVEUgPSBBSV9QUk9NUFRfVE9PTFNfQVRUUklCVVRFO1xuZXhwb3J0cy5BSV9SRVNQT05TRV9PQkpFQ1RfQVRUUklCVVRFID0gQUlfUkVTUE9OU0VfT0JKRUNUX0FUVFJJQlVURTtcbmV4cG9ydHMuQUlfUkVTUE9OU0VfUFJPVklERVJfTUVUQURBVEFfQVRUUklCVVRFID0gQUlfUkVTUE9OU0VfUFJPVklERVJfTUVUQURBVEFfQVRUUklCVVRFO1xuZXhwb3J0cy5BSV9SRVNQT05TRV9URVhUX0FUVFJJQlVURSA9IEFJX1JFU1BPTlNFX1RFWFRfQVRUUklCVVRFO1xuZXhwb3J0cy5BSV9SRVNQT05TRV9UT09MX0NBTExTX0FUVFJJQlVURSA9IEFJX1JFU1BPTlNFX1RPT0xfQ0FMTFNfQVRUUklCVVRFO1xuZXhwb3J0cy5BSV9URUxFTUVUUllfRlVOQ1RJT05fSURfQVRUUklCVVRFID0gQUlfVEVMRU1FVFJZX0ZVTkNUSU9OX0lEX0FUVFJJQlVURTtcbmV4cG9ydHMuQUlfVE9PTF9DQUxMX0FSR1NfQVRUUklCVVRFID0gQUlfVE9PTF9DQUxMX0FSR1NfQVRUUklCVVRFO1xuZXhwb3J0cy5BSV9UT09MX0NBTExfSURfQVRUUklCVVRFID0gQUlfVE9PTF9DQUxMX0lEX0FUVFJJQlVURTtcbmV4cG9ydHMuQUlfVE9PTF9DQUxMX05BTUVfQVRUUklCVVRFID0gQUlfVE9PTF9DQUxMX05BTUVfQVRUUklCVVRFO1xuZXhwb3J0cy5BSV9UT09MX0NBTExfUkVTVUxUX0FUVFJJQlVURSA9IEFJX1RPT0xfQ0FMTF9SRVNVTFRfQVRUUklCVVRFO1xuZXhwb3J0cy5BSV9VU0FHRV9DT01QTEVUSU9OX1RPS0VOU19BVFRSSUJVVEUgPSBBSV9VU0FHRV9DT01QTEVUSU9OX1RPS0VOU19BVFRSSUJVVEU7XG5leHBvcnRzLkFJX1VTQUdFX1BST01QVF9UT0tFTlNfQVRUUklCVVRFID0gQUlfVVNBR0VfUFJPTVBUX1RPS0VOU19BVFRSSUJVVEU7XG5leHBvcnRzLkdFTl9BSV9SRVNQT05TRV9NT0RFTF9BVFRSSUJVVEUgPSBHRU5fQUlfUkVTUE9OU0VfTU9ERUxfQVRUUklCVVRFO1xuZXhwb3J0cy5HRU5fQUlfVVNBR0VfSU5QVVRfVE9LRU5TX0FUVFJJQlVURSA9IEdFTl9BSV9VU0FHRV9JTlBVVF9UT0tFTlNfQVRUUklCVVRFO1xuZXhwb3J0cy5HRU5fQUlfVVNBR0VfT1VUUFVUX1RPS0VOU19BVFRSSUJVVEUgPSBHRU5fQUlfVVNBR0VfT1VUUFVUX1RPS0VOU19BVFRSSUJVVEU7XG4vLyMgc291cmNlTWFwcGluZ1VSTD12ZXJjZWwtYWktYXR0cmlidXRlcy5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/vercel-ai-attributes.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/vercel-ai.js":
/*!*******************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/vercel-ai.js ***!
  \*******************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst semanticAttributes = __webpack_require__(/*! ../semanticAttributes.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/semanticAttributes.js\");\nconst spanUtils = __webpack_require__(/*! ./spanUtils.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanUtils.js\");\nconst vercelAiAttributes = __webpack_require__(/*! ./vercel-ai-attributes.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/vercel-ai-attributes.js\");\n\nfunction addOriginToSpan(span, origin) {\n  span.setAttribute(semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_ORIGIN, origin);\n}\n\n/**\n * Post-process spans emitted by the Vercel AI SDK.\n * This is supposed to be used in `client.on('spanStart', ...)\n */\nfunction onVercelAiSpanStart(span) {\n  const { data: attributes, description: name } = spanUtils.spanToJSON(span);\n\n  if (!name) {\n    return;\n  }\n\n  // Tool call spans\n  // https://ai-sdk.dev/docs/ai-sdk-core/telemetry#tool-call-spans\n  if (attributes[vercelAiAttributes.AI_TOOL_CALL_NAME_ATTRIBUTE] && attributes[vercelAiAttributes.AI_TOOL_CALL_ID_ATTRIBUTE] && name === 'ai.toolCall') {\n    processToolCallSpan(span, attributes);\n    return;\n  }\n\n  // The AI and Provider must be defined for generate, stream, and embed spans.\n  // The id of the model\n  const aiModelId = attributes[vercelAiAttributes.AI_MODEL_ID_ATTRIBUTE];\n  // the provider of the model\n  const aiModelProvider = attributes[vercelAiAttributes.AI_MODEL_PROVIDER_ATTRIBUTE];\n  if (typeof aiModelId !== 'string' || typeof aiModelProvider !== 'string' || !aiModelId || !aiModelProvider) {\n    return;\n  }\n\n  processGenerateSpan(span, name, attributes);\n}\n\nfunction vercelAiEventProcessor(event) {\n  if (event.type === 'transaction' && event.spans) {\n    for (const span of event.spans) {\n      // this mutates spans in-place\n      processEndedVercelAiSpan(span);\n    }\n  }\n  return event;\n}\n/**\n * Post-process spans emitted by the Vercel AI SDK.\n */\nfunction processEndedVercelAiSpan(span) {\n  const { data: attributes, origin } = span;\n\n  if (origin !== 'auto.vercelai.otel') {\n    return;\n  }\n\n  renameAttributeKey(attributes, vercelAiAttributes.AI_USAGE_COMPLETION_TOKENS_ATTRIBUTE, vercelAiAttributes.GEN_AI_USAGE_OUTPUT_TOKENS_ATTRIBUTE);\n  renameAttributeKey(attributes, vercelAiAttributes.AI_USAGE_PROMPT_TOKENS_ATTRIBUTE, vercelAiAttributes.GEN_AI_USAGE_INPUT_TOKENS_ATTRIBUTE);\n\n  if (\n    typeof attributes[vercelAiAttributes.GEN_AI_USAGE_OUTPUT_TOKENS_ATTRIBUTE] === 'number' &&\n    typeof attributes[vercelAiAttributes.GEN_AI_USAGE_INPUT_TOKENS_ATTRIBUTE] === 'number'\n  ) {\n    attributes['gen_ai.usage.total_tokens'] =\n      attributes[vercelAiAttributes.GEN_AI_USAGE_OUTPUT_TOKENS_ATTRIBUTE] + attributes[vercelAiAttributes.GEN_AI_USAGE_INPUT_TOKENS_ATTRIBUTE];\n  }\n\n  // Rename AI SDK attributes to standardized gen_ai attributes\n  renameAttributeKey(attributes, vercelAiAttributes.AI_PROMPT_MESSAGES_ATTRIBUTE, 'gen_ai.request.messages');\n  renameAttributeKey(attributes, vercelAiAttributes.AI_RESPONSE_TEXT_ATTRIBUTE, 'gen_ai.response.text');\n  renameAttributeKey(attributes, vercelAiAttributes.AI_RESPONSE_TOOL_CALLS_ATTRIBUTE, 'gen_ai.response.tool_calls');\n  renameAttributeKey(attributes, vercelAiAttributes.AI_RESPONSE_OBJECT_ATTRIBUTE, 'gen_ai.response.object');\n  renameAttributeKey(attributes, vercelAiAttributes.AI_PROMPT_TOOLS_ATTRIBUTE, 'gen_ai.request.available_tools');\n\n  renameAttributeKey(attributes, vercelAiAttributes.AI_TOOL_CALL_ARGS_ATTRIBUTE, 'gen_ai.tool.input');\n  renameAttributeKey(attributes, vercelAiAttributes.AI_TOOL_CALL_RESULT_ATTRIBUTE, 'gen_ai.tool.output');\n\n  addProviderMetadataToAttributes(attributes);\n\n  // Change attributes namespaced with `ai.X` to `vercel.ai.X`\n  for (const key of Object.keys(attributes)) {\n    if (key.startsWith('ai.')) {\n      renameAttributeKey(attributes, key, `vercel.${key}`);\n    }\n  }\n}\n\n/**\n * Renames an attribute key in the provided attributes object if the old key exists.\n * This function safely handles null and undefined values.\n */\nfunction renameAttributeKey(attributes, oldKey, newKey) {\n  if (attributes[oldKey] != null) {\n    attributes[newKey] = attributes[oldKey];\n    // eslint-disable-next-line @typescript-eslint/no-dynamic-delete\n    delete attributes[oldKey];\n  }\n}\n\nfunction processToolCallSpan(span, attributes) {\n  addOriginToSpan(span, 'auto.vercelai.otel');\n  span.setAttribute(semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_OP, 'gen_ai.execute_tool');\n  renameAttributeKey(attributes, vercelAiAttributes.AI_TOOL_CALL_NAME_ATTRIBUTE, 'gen_ai.tool.name');\n  renameAttributeKey(attributes, vercelAiAttributes.AI_TOOL_CALL_ID_ATTRIBUTE, 'gen_ai.tool.call.id');\n  // https://opentelemetry.io/docs/specs/semconv/registry/attributes/gen-ai/#gen-ai-tool-type\n  if (!attributes['gen_ai.tool.type']) {\n    span.setAttribute('gen_ai.tool.type', 'function');\n  }\n  const toolName = attributes['gen_ai.tool.name'];\n  if (toolName) {\n    span.updateName(`execute_tool ${toolName}`);\n  }\n}\n\nfunction processGenerateSpan(span, name, attributes) {\n  addOriginToSpan(span, 'auto.vercelai.otel');\n\n  const nameWthoutAi = name.replace('ai.', '');\n  span.setAttribute('ai.pipeline.name', nameWthoutAi);\n  span.updateName(nameWthoutAi);\n\n  // If a Telemetry name is set and it is a pipeline span, use that as the operation name\n  const functionId = attributes[vercelAiAttributes.AI_TELEMETRY_FUNCTION_ID_ATTRIBUTE];\n  if (functionId && typeof functionId === 'string' && name.split('.').length - 1 === 1) {\n    span.updateName(`${nameWthoutAi} ${functionId}`);\n    span.setAttribute('gen_ai.function_id', functionId);\n  }\n\n  if (attributes[vercelAiAttributes.AI_PROMPT_ATTRIBUTE]) {\n    span.setAttribute('gen_ai.prompt', attributes[vercelAiAttributes.AI_PROMPT_ATTRIBUTE]);\n  }\n  if (attributes[vercelAiAttributes.AI_MODEL_ID_ATTRIBUTE] && !attributes[vercelAiAttributes.GEN_AI_RESPONSE_MODEL_ATTRIBUTE]) {\n    span.setAttribute(vercelAiAttributes.GEN_AI_RESPONSE_MODEL_ATTRIBUTE, attributes[vercelAiAttributes.AI_MODEL_ID_ATTRIBUTE]);\n  }\n  span.setAttribute('ai.streaming', name.includes('stream'));\n\n  // Generate Spans\n  if (name === 'ai.generateText') {\n    span.setAttribute(semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_OP, 'gen_ai.invoke_agent');\n    return;\n  }\n\n  if (name === 'ai.generateText.doGenerate') {\n    span.setAttribute(semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_OP, 'gen_ai.generate_text');\n    span.updateName(`generate_text ${attributes[vercelAiAttributes.AI_MODEL_ID_ATTRIBUTE]}`);\n    return;\n  }\n\n  if (name === 'ai.streamText') {\n    span.setAttribute(semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_OP, 'gen_ai.invoke_agent');\n    return;\n  }\n\n  if (name === 'ai.streamText.doStream') {\n    span.setAttribute(semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_OP, 'gen_ai.stream_text');\n    span.updateName(`stream_text ${attributes[vercelAiAttributes.AI_MODEL_ID_ATTRIBUTE]}`);\n    return;\n  }\n\n  if (name === 'ai.generateObject') {\n    span.setAttribute(semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_OP, 'gen_ai.invoke_agent');\n    return;\n  }\n\n  if (name === 'ai.generateObject.doGenerate') {\n    span.setAttribute(semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_OP, 'gen_ai.generate_object');\n    span.updateName(`generate_object ${attributes[vercelAiAttributes.AI_MODEL_ID_ATTRIBUTE]}`);\n    return;\n  }\n\n  if (name === 'ai.streamObject') {\n    span.setAttribute(semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_OP, 'gen_ai.invoke_agent');\n    return;\n  }\n\n  if (name === 'ai.streamObject.doStream') {\n    span.setAttribute(semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_OP, 'gen_ai.stream_object');\n    span.updateName(`stream_object ${attributes[vercelAiAttributes.AI_MODEL_ID_ATTRIBUTE]}`);\n    return;\n  }\n\n  if (name === 'ai.embed') {\n    span.setAttribute(semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_OP, 'gen_ai.invoke_agent');\n    return;\n  }\n\n  if (name === 'ai.embed.doEmbed') {\n    span.setAttribute(semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_OP, 'gen_ai.embed');\n    span.updateName(`embed ${attributes[vercelAiAttributes.AI_MODEL_ID_ATTRIBUTE]}`);\n    return;\n  }\n\n  if (name === 'ai.embedMany') {\n    span.setAttribute(semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_OP, 'gen_ai.invoke_agent');\n    return;\n  }\n\n  if (name === 'ai.embedMany.doEmbed') {\n    span.setAttribute(semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_OP, 'gen_ai.embed_many');\n    span.updateName(`embed_many ${attributes[vercelAiAttributes.AI_MODEL_ID_ATTRIBUTE]}`);\n    return;\n  }\n\n  if (name.startsWith('ai.stream')) {\n    span.setAttribute(semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_OP, 'ai.run');\n    return;\n  }\n}\n\n/**\n * Add event processors to the given client to process Vercel AI spans.\n */\nfunction addVercelAiProcessors(client) {\n  client.on('spanStart', onVercelAiSpanStart);\n  // Note: We cannot do this on `spanEnd`, because the span cannot be mutated anymore at this point\n  client.addEventProcessor(Object.assign(vercelAiEventProcessor, { id: 'VercelAiEventProcessor' }));\n}\n\nfunction addProviderMetadataToAttributes(attributes) {\n  const providerMetadata = attributes[vercelAiAttributes.AI_RESPONSE_PROVIDER_METADATA_ATTRIBUTE] ;\n  if (providerMetadata) {\n    try {\n      const providerMetadataObject = JSON.parse(providerMetadata) ;\n      if (providerMetadataObject.openai) {\n        setAttributeIfDefined(\n          attributes,\n          'gen_ai.usage.input_tokens.cached',\n          providerMetadataObject.openai.cachedPromptTokens,\n        );\n        setAttributeIfDefined(\n          attributes,\n          'gen_ai.usage.output_tokens.reasoning',\n          providerMetadataObject.openai.reasoningTokens,\n        );\n        setAttributeIfDefined(\n          attributes,\n          'gen_ai.usage.output_tokens.prediction_accepted',\n          providerMetadataObject.openai.acceptedPredictionTokens,\n        );\n        setAttributeIfDefined(\n          attributes,\n          'gen_ai.usage.output_tokens.prediction_rejected',\n          providerMetadataObject.openai.rejectedPredictionTokens,\n        );\n        setAttributeIfDefined(attributes, 'gen_ai.conversation.id', providerMetadataObject.openai.responseId);\n      }\n\n      if (providerMetadataObject.anthropic) {\n        setAttributeIfDefined(\n          attributes,\n          'gen_ai.usage.input_tokens.cached',\n          providerMetadataObject.anthropic.cacheReadInputTokens,\n        );\n        setAttributeIfDefined(\n          attributes,\n          'gen_ai.usage.input_tokens.cache_write',\n          providerMetadataObject.anthropic.cacheCreationInputTokens,\n        );\n      }\n\n      if (providerMetadataObject.bedrock?.usage) {\n        setAttributeIfDefined(\n          attributes,\n          'gen_ai.usage.input_tokens.cached',\n          providerMetadataObject.bedrock.usage.cacheReadInputTokens,\n        );\n        setAttributeIfDefined(\n          attributes,\n          'gen_ai.usage.input_tokens.cache_write',\n          providerMetadataObject.bedrock.usage.cacheWriteInputTokens,\n        );\n      }\n\n      if (providerMetadataObject.deepseek) {\n        setAttributeIfDefined(\n          attributes,\n          'gen_ai.usage.input_tokens.cached',\n          providerMetadataObject.deepseek.promptCacheHitTokens,\n        );\n        setAttributeIfDefined(\n          attributes,\n          'gen_ai.usage.input_tokens.cache_miss',\n          providerMetadataObject.deepseek.promptCacheMissTokens,\n        );\n      }\n    } catch {\n      // Ignore\n    }\n  }\n}\n\n/**\n * Sets an attribute only if the value is not null or undefined.\n */\nfunction setAttributeIfDefined(attributes, key, value) {\n  if (value != null) {\n    attributes[key] = value;\n  }\n}\n\nexports.addVercelAiProcessors = addVercelAiProcessors;\n//# sourceMappingURL=vercel-ai.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvdmVyY2VsLWFpLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLDJCQUEyQixtQkFBTyxDQUFDLGlKQUEwQjtBQUM3RCxrQkFBa0IsbUJBQU8sQ0FBQyxvSUFBZ0I7QUFDMUMsMkJBQTJCLG1CQUFPLENBQUMsMEpBQTJCOztBQUU5RDtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFVBQVUsc0NBQXNDOztBQUVoRDtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFVBQVUsMkJBQTJCOztBQUVyQztBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQSxvREFBb0QsSUFBSTtBQUN4RDtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0Esb0NBQW9DLFNBQVM7QUFDN0M7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQSx1QkFBdUIsY0FBYyxFQUFFLFdBQVc7QUFDbEQ7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQSxxQ0FBcUMscURBQXFEO0FBQzFGO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLG1DQUFtQyxxREFBcUQ7QUFDeEY7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsdUNBQXVDLHFEQUFxRDtBQUM1RjtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQSxxQ0FBcUMscURBQXFEO0FBQzFGO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLDZCQUE2QixxREFBcUQ7QUFDbEY7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0Esa0NBQWtDLHFEQUFxRDtBQUN2RjtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsbUVBQW1FLDhCQUE4QjtBQUNqRzs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLE1BQU07QUFDTjtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLDZCQUE2QjtBQUM3QiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3V0aWxzL3ZlcmNlbC1haS5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3Qgc2VtYW50aWNBdHRyaWJ1dGVzID0gcmVxdWlyZSgnLi4vc2VtYW50aWNBdHRyaWJ1dGVzLmpzJyk7XG5jb25zdCBzcGFuVXRpbHMgPSByZXF1aXJlKCcuL3NwYW5VdGlscy5qcycpO1xuY29uc3QgdmVyY2VsQWlBdHRyaWJ1dGVzID0gcmVxdWlyZSgnLi92ZXJjZWwtYWktYXR0cmlidXRlcy5qcycpO1xuXG5mdW5jdGlvbiBhZGRPcmlnaW5Ub1NwYW4oc3Bhbiwgb3JpZ2luKSB7XG4gIHNwYW4uc2V0QXR0cmlidXRlKHNlbWFudGljQXR0cmlidXRlcy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX09SSUdJTiwgb3JpZ2luKTtcbn1cblxuLyoqXG4gKiBQb3N0LXByb2Nlc3Mgc3BhbnMgZW1pdHRlZCBieSB0aGUgVmVyY2VsIEFJIFNESy5cbiAqIFRoaXMgaXMgc3VwcG9zZWQgdG8gYmUgdXNlZCBpbiBgY2xpZW50Lm9uKCdzcGFuU3RhcnQnLCAuLi4pXG4gKi9cbmZ1bmN0aW9uIG9uVmVyY2VsQWlTcGFuU3RhcnQoc3Bhbikge1xuICBjb25zdCB7IGRhdGE6IGF0dHJpYnV0ZXMsIGRlc2NyaXB0aW9uOiBuYW1lIH0gPSBzcGFuVXRpbHMuc3BhblRvSlNPTihzcGFuKTtcblxuICBpZiAoIW5hbWUpIHtcbiAgICByZXR1cm47XG4gIH1cblxuICAvLyBUb29sIGNhbGwgc3BhbnNcbiAgLy8gaHR0cHM6Ly9haS1zZGsuZGV2L2RvY3MvYWktc2RrLWNvcmUvdGVsZW1ldHJ5I3Rvb2wtY2FsbC1zcGFuc1xuICBpZiAoYXR0cmlidXRlc1t2ZXJjZWxBaUF0dHJpYnV0ZXMuQUlfVE9PTF9DQUxMX05BTUVfQVRUUklCVVRFXSAmJiBhdHRyaWJ1dGVzW3ZlcmNlbEFpQXR0cmlidXRlcy5BSV9UT09MX0NBTExfSURfQVRUUklCVVRFXSAmJiBuYW1lID09PSAnYWkudG9vbENhbGwnKSB7XG4gICAgcHJvY2Vzc1Rvb2xDYWxsU3BhbihzcGFuLCBhdHRyaWJ1dGVzKTtcbiAgICByZXR1cm47XG4gIH1cblxuICAvLyBUaGUgQUkgYW5kIFByb3ZpZGVyIG11c3QgYmUgZGVmaW5lZCBmb3IgZ2VuZXJhdGUsIHN0cmVhbSwgYW5kIGVtYmVkIHNwYW5zLlxuICAvLyBUaGUgaWQgb2YgdGhlIG1vZGVsXG4gIGNvbnN0IGFpTW9kZWxJZCA9IGF0dHJpYnV0ZXNbdmVyY2VsQWlBdHRyaWJ1dGVzLkFJX01PREVMX0lEX0FUVFJJQlVURV07XG4gIC8vIHRoZSBwcm92aWRlciBvZiB0aGUgbW9kZWxcbiAgY29uc3QgYWlNb2RlbFByb3ZpZGVyID0gYXR0cmlidXRlc1t2ZXJjZWxBaUF0dHJpYnV0ZXMuQUlfTU9ERUxfUFJPVklERVJfQVRUUklCVVRFXTtcbiAgaWYgKHR5cGVvZiBhaU1vZGVsSWQgIT09ICdzdHJpbmcnIHx8IHR5cGVvZiBhaU1vZGVsUHJvdmlkZXIgIT09ICdzdHJpbmcnIHx8ICFhaU1vZGVsSWQgfHwgIWFpTW9kZWxQcm92aWRlcikge1xuICAgIHJldHVybjtcbiAgfVxuXG4gIHByb2Nlc3NHZW5lcmF0ZVNwYW4oc3BhbiwgbmFtZSwgYXR0cmlidXRlcyk7XG59XG5cbmZ1bmN0aW9uIHZlcmNlbEFpRXZlbnRQcm9jZXNzb3IoZXZlbnQpIHtcbiAgaWYgKGV2ZW50LnR5cGUgPT09ICd0cmFuc2FjdGlvbicgJiYgZXZlbnQuc3BhbnMpIHtcbiAgICBmb3IgKGNvbnN0IHNwYW4gb2YgZXZlbnQuc3BhbnMpIHtcbiAgICAgIC8vIHRoaXMgbXV0YXRlcyBzcGFucyBpbi1wbGFjZVxuICAgICAgcHJvY2Vzc0VuZGVkVmVyY2VsQWlTcGFuKHNwYW4pO1xuICAgIH1cbiAgfVxuICByZXR1cm4gZXZlbnQ7XG59XG4vKipcbiAqIFBvc3QtcHJvY2VzcyBzcGFucyBlbWl0dGVkIGJ5IHRoZSBWZXJjZWwgQUkgU0RLLlxuICovXG5mdW5jdGlvbiBwcm9jZXNzRW5kZWRWZXJjZWxBaVNwYW4oc3Bhbikge1xuICBjb25zdCB7IGRhdGE6IGF0dHJpYnV0ZXMsIG9yaWdpbiB9ID0gc3BhbjtcblxuICBpZiAob3JpZ2luICE9PSAnYXV0by52ZXJjZWxhaS5vdGVsJykge1xuICAgIHJldHVybjtcbiAgfVxuXG4gIHJlbmFtZUF0dHJpYnV0ZUtleShhdHRyaWJ1dGVzLCB2ZXJjZWxBaUF0dHJpYnV0ZXMuQUlfVVNBR0VfQ09NUExFVElPTl9UT0tFTlNfQVRUUklCVVRFLCB2ZXJjZWxBaUF0dHJpYnV0ZXMuR0VOX0FJX1VTQUdFX09VVFBVVF9UT0tFTlNfQVRUUklCVVRFKTtcbiAgcmVuYW1lQXR0cmlidXRlS2V5KGF0dHJpYnV0ZXMsIHZlcmNlbEFpQXR0cmlidXRlcy5BSV9VU0FHRV9QUk9NUFRfVE9LRU5TX0FUVFJJQlVURSwgdmVyY2VsQWlBdHRyaWJ1dGVzLkdFTl9BSV9VU0FHRV9JTlBVVF9UT0tFTlNfQVRUUklCVVRFKTtcblxuICBpZiAoXG4gICAgdHlwZW9mIGF0dHJpYnV0ZXNbdmVyY2VsQWlBdHRyaWJ1dGVzLkdFTl9BSV9VU0FHRV9PVVRQVVRfVE9LRU5TX0FUVFJJQlVURV0gPT09ICdudW1iZXInICYmXG4gICAgdHlwZW9mIGF0dHJpYnV0ZXNbdmVyY2VsQWlBdHRyaWJ1dGVzLkdFTl9BSV9VU0FHRV9JTlBVVF9UT0tFTlNfQVRUUklCVVRFXSA9PT0gJ251bWJlcidcbiAgKSB7XG4gICAgYXR0cmlidXRlc1snZ2VuX2FpLnVzYWdlLnRvdGFsX3Rva2VucyddID1cbiAgICAgIGF0dHJpYnV0ZXNbdmVyY2VsQWlBdHRyaWJ1dGVzLkdFTl9BSV9VU0FHRV9PVVRQVVRfVE9LRU5TX0FUVFJJQlVURV0gKyBhdHRyaWJ1dGVzW3ZlcmNlbEFpQXR0cmlidXRlcy5HRU5fQUlfVVNBR0VfSU5QVVRfVE9LRU5TX0FUVFJJQlVURV07XG4gIH1cblxuICAvLyBSZW5hbWUgQUkgU0RLIGF0dHJpYnV0ZXMgdG8gc3RhbmRhcmRpemVkIGdlbl9haSBhdHRyaWJ1dGVzXG4gIHJlbmFtZUF0dHJpYnV0ZUtleShhdHRyaWJ1dGVzLCB2ZXJjZWxBaUF0dHJpYnV0ZXMuQUlfUFJPTVBUX01FU1NBR0VTX0FUVFJJQlVURSwgJ2dlbl9haS5yZXF1ZXN0Lm1lc3NhZ2VzJyk7XG4gIHJlbmFtZUF0dHJpYnV0ZUtleShhdHRyaWJ1dGVzLCB2ZXJjZWxBaUF0dHJpYnV0ZXMuQUlfUkVTUE9OU0VfVEVYVF9BVFRSSUJVVEUsICdnZW5fYWkucmVzcG9uc2UudGV4dCcpO1xuICByZW5hbWVBdHRyaWJ1dGVLZXkoYXR0cmlidXRlcywgdmVyY2VsQWlBdHRyaWJ1dGVzLkFJX1JFU1BPTlNFX1RPT0xfQ0FMTFNfQVRUUklCVVRFLCAnZ2VuX2FpLnJlc3BvbnNlLnRvb2xfY2FsbHMnKTtcbiAgcmVuYW1lQXR0cmlidXRlS2V5KGF0dHJpYnV0ZXMsIHZlcmNlbEFpQXR0cmlidXRlcy5BSV9SRVNQT05TRV9PQkpFQ1RfQVRUUklCVVRFLCAnZ2VuX2FpLnJlc3BvbnNlLm9iamVjdCcpO1xuICByZW5hbWVBdHRyaWJ1dGVLZXkoYXR0cmlidXRlcywgdmVyY2VsQWlBdHRyaWJ1dGVzLkFJX1BST01QVF9UT09MU19BVFRSSUJVVEUsICdnZW5fYWkucmVxdWVzdC5hdmFpbGFibGVfdG9vbHMnKTtcblxuICByZW5hbWVBdHRyaWJ1dGVLZXkoYXR0cmlidXRlcywgdmVyY2VsQWlBdHRyaWJ1dGVzLkFJX1RPT0xfQ0FMTF9BUkdTX0FUVFJJQlVURSwgJ2dlbl9haS50b29sLmlucHV0Jyk7XG4gIHJlbmFtZUF0dHJpYnV0ZUtleShhdHRyaWJ1dGVzLCB2ZXJjZWxBaUF0dHJpYnV0ZXMuQUlfVE9PTF9DQUxMX1JFU1VMVF9BVFRSSUJVVEUsICdnZW5fYWkudG9vbC5vdXRwdXQnKTtcblxuICBhZGRQcm92aWRlck1ldGFkYXRhVG9BdHRyaWJ1dGVzKGF0dHJpYnV0ZXMpO1xuXG4gIC8vIENoYW5nZSBhdHRyaWJ1dGVzIG5hbWVzcGFjZWQgd2l0aCBgYWkuWGAgdG8gYHZlcmNlbC5haS5YYFxuICBmb3IgKGNvbnN0IGtleSBvZiBPYmplY3Qua2V5cyhhdHRyaWJ1dGVzKSkge1xuICAgIGlmIChrZXkuc3RhcnRzV2l0aCgnYWkuJykpIHtcbiAgICAgIHJlbmFtZUF0dHJpYnV0ZUtleShhdHRyaWJ1dGVzLCBrZXksIGB2ZXJjZWwuJHtrZXl9YCk7XG4gICAgfVxuICB9XG59XG5cbi8qKlxuICogUmVuYW1lcyBhbiBhdHRyaWJ1dGUga2V5IGluIHRoZSBwcm92aWRlZCBhdHRyaWJ1dGVzIG9iamVjdCBpZiB0aGUgb2xkIGtleSBleGlzdHMuXG4gKiBUaGlzIGZ1bmN0aW9uIHNhZmVseSBoYW5kbGVzIG51bGwgYW5kIHVuZGVmaW5lZCB2YWx1ZXMuXG4gKi9cbmZ1bmN0aW9uIHJlbmFtZUF0dHJpYnV0ZUtleShhdHRyaWJ1dGVzLCBvbGRLZXksIG5ld0tleSkge1xuICBpZiAoYXR0cmlidXRlc1tvbGRLZXldICE9IG51bGwpIHtcbiAgICBhdHRyaWJ1dGVzW25ld0tleV0gPSBhdHRyaWJ1dGVzW29sZEtleV07XG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uby1keW5hbWljLWRlbGV0ZVxuICAgIGRlbGV0ZSBhdHRyaWJ1dGVzW29sZEtleV07XG4gIH1cbn1cblxuZnVuY3Rpb24gcHJvY2Vzc1Rvb2xDYWxsU3BhbihzcGFuLCBhdHRyaWJ1dGVzKSB7XG4gIGFkZE9yaWdpblRvU3BhbihzcGFuLCAnYXV0by52ZXJjZWxhaS5vdGVsJyk7XG4gIHNwYW4uc2V0QXR0cmlidXRlKHNlbWFudGljQXR0cmlidXRlcy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX09QLCAnZ2VuX2FpLmV4ZWN1dGVfdG9vbCcpO1xuICByZW5hbWVBdHRyaWJ1dGVLZXkoYXR0cmlidXRlcywgdmVyY2VsQWlBdHRyaWJ1dGVzLkFJX1RPT0xfQ0FMTF9OQU1FX0FUVFJJQlVURSwgJ2dlbl9haS50b29sLm5hbWUnKTtcbiAgcmVuYW1lQXR0cmlidXRlS2V5KGF0dHJpYnV0ZXMsIHZlcmNlbEFpQXR0cmlidXRlcy5BSV9UT09MX0NBTExfSURfQVRUUklCVVRFLCAnZ2VuX2FpLnRvb2wuY2FsbC5pZCcpO1xuICAvLyBodHRwczovL29wZW50ZWxlbWV0cnkuaW8vZG9jcy9zcGVjcy9zZW1jb252L3JlZ2lzdHJ5L2F0dHJpYnV0ZXMvZ2VuLWFpLyNnZW4tYWktdG9vbC10eXBlXG4gIGlmICghYXR0cmlidXRlc1snZ2VuX2FpLnRvb2wudHlwZSddKSB7XG4gICAgc3Bhbi5zZXRBdHRyaWJ1dGUoJ2dlbl9haS50b29sLnR5cGUnLCAnZnVuY3Rpb24nKTtcbiAgfVxuICBjb25zdCB0b29sTmFtZSA9IGF0dHJpYnV0ZXNbJ2dlbl9haS50b29sLm5hbWUnXTtcbiAgaWYgKHRvb2xOYW1lKSB7XG4gICAgc3Bhbi51cGRhdGVOYW1lKGBleGVjdXRlX3Rvb2wgJHt0b29sTmFtZX1gKTtcbiAgfVxufVxuXG5mdW5jdGlvbiBwcm9jZXNzR2VuZXJhdGVTcGFuKHNwYW4sIG5hbWUsIGF0dHJpYnV0ZXMpIHtcbiAgYWRkT3JpZ2luVG9TcGFuKHNwYW4sICdhdXRvLnZlcmNlbGFpLm90ZWwnKTtcblxuICBjb25zdCBuYW1lV3Rob3V0QWkgPSBuYW1lLnJlcGxhY2UoJ2FpLicsICcnKTtcbiAgc3Bhbi5zZXRBdHRyaWJ1dGUoJ2FpLnBpcGVsaW5lLm5hbWUnLCBuYW1lV3Rob3V0QWkpO1xuICBzcGFuLnVwZGF0ZU5hbWUobmFtZVd0aG91dEFpKTtcblxuICAvLyBJZiBhIFRlbGVtZXRyeSBuYW1lIGlzIHNldCBhbmQgaXQgaXMgYSBwaXBlbGluZSBzcGFuLCB1c2UgdGhhdCBhcyB0aGUgb3BlcmF0aW9uIG5hbWVcbiAgY29uc3QgZnVuY3Rpb25JZCA9IGF0dHJpYnV0ZXNbdmVyY2VsQWlBdHRyaWJ1dGVzLkFJX1RFTEVNRVRSWV9GVU5DVElPTl9JRF9BVFRSSUJVVEVdO1xuICBpZiAoZnVuY3Rpb25JZCAmJiB0eXBlb2YgZnVuY3Rpb25JZCA9PT0gJ3N0cmluZycgJiYgbmFtZS5zcGxpdCgnLicpLmxlbmd0aCAtIDEgPT09IDEpIHtcbiAgICBzcGFuLnVwZGF0ZU5hbWUoYCR7bmFtZVd0aG91dEFpfSAke2Z1bmN0aW9uSWR9YCk7XG4gICAgc3Bhbi5zZXRBdHRyaWJ1dGUoJ2dlbl9haS5mdW5jdGlvbl9pZCcsIGZ1bmN0aW9uSWQpO1xuICB9XG5cbiAgaWYgKGF0dHJpYnV0ZXNbdmVyY2VsQWlBdHRyaWJ1dGVzLkFJX1BST01QVF9BVFRSSUJVVEVdKSB7XG4gICAgc3Bhbi5zZXRBdHRyaWJ1dGUoJ2dlbl9haS5wcm9tcHQnLCBhdHRyaWJ1dGVzW3ZlcmNlbEFpQXR0cmlidXRlcy5BSV9QUk9NUFRfQVRUUklCVVRFXSk7XG4gIH1cbiAgaWYgKGF0dHJpYnV0ZXNbdmVyY2VsQWlBdHRyaWJ1dGVzLkFJX01PREVMX0lEX0FUVFJJQlVURV0gJiYgIWF0dHJpYnV0ZXNbdmVyY2VsQWlBdHRyaWJ1dGVzLkdFTl9BSV9SRVNQT05TRV9NT0RFTF9BVFRSSUJVVEVdKSB7XG4gICAgc3Bhbi5zZXRBdHRyaWJ1dGUodmVyY2VsQWlBdHRyaWJ1dGVzLkdFTl9BSV9SRVNQT05TRV9NT0RFTF9BVFRSSUJVVEUsIGF0dHJpYnV0ZXNbdmVyY2VsQWlBdHRyaWJ1dGVzLkFJX01PREVMX0lEX0FUVFJJQlVURV0pO1xuICB9XG4gIHNwYW4uc2V0QXR0cmlidXRlKCdhaS5zdHJlYW1pbmcnLCBuYW1lLmluY2x1ZGVzKCdzdHJlYW0nKSk7XG5cbiAgLy8gR2VuZXJhdGUgU3BhbnNcbiAgaWYgKG5hbWUgPT09ICdhaS5nZW5lcmF0ZVRleHQnKSB7XG4gICAgc3Bhbi5zZXRBdHRyaWJ1dGUoc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfT1AsICdnZW5fYWkuaW52b2tlX2FnZW50Jyk7XG4gICAgcmV0dXJuO1xuICB9XG5cbiAgaWYgKG5hbWUgPT09ICdhaS5nZW5lcmF0ZVRleHQuZG9HZW5lcmF0ZScpIHtcbiAgICBzcGFuLnNldEF0dHJpYnV0ZShzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9PUCwgJ2dlbl9haS5nZW5lcmF0ZV90ZXh0Jyk7XG4gICAgc3Bhbi51cGRhdGVOYW1lKGBnZW5lcmF0ZV90ZXh0ICR7YXR0cmlidXRlc1t2ZXJjZWxBaUF0dHJpYnV0ZXMuQUlfTU9ERUxfSURfQVRUUklCVVRFXX1gKTtcbiAgICByZXR1cm47XG4gIH1cblxuICBpZiAobmFtZSA9PT0gJ2FpLnN0cmVhbVRleHQnKSB7XG4gICAgc3Bhbi5zZXRBdHRyaWJ1dGUoc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfT1AsICdnZW5fYWkuaW52b2tlX2FnZW50Jyk7XG4gICAgcmV0dXJuO1xuICB9XG5cbiAgaWYgKG5hbWUgPT09ICdhaS5zdHJlYW1UZXh0LmRvU3RyZWFtJykge1xuICAgIHNwYW4uc2V0QXR0cmlidXRlKHNlbWFudGljQXR0cmlidXRlcy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX09QLCAnZ2VuX2FpLnN0cmVhbV90ZXh0Jyk7XG4gICAgc3Bhbi51cGRhdGVOYW1lKGBzdHJlYW1fdGV4dCAke2F0dHJpYnV0ZXNbdmVyY2VsQWlBdHRyaWJ1dGVzLkFJX01PREVMX0lEX0FUVFJJQlVURV19YCk7XG4gICAgcmV0dXJuO1xuICB9XG5cbiAgaWYgKG5hbWUgPT09ICdhaS5nZW5lcmF0ZU9iamVjdCcpIHtcbiAgICBzcGFuLnNldEF0dHJpYnV0ZShzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9PUCwgJ2dlbl9haS5pbnZva2VfYWdlbnQnKTtcbiAgICByZXR1cm47XG4gIH1cblxuICBpZiAobmFtZSA9PT0gJ2FpLmdlbmVyYXRlT2JqZWN0LmRvR2VuZXJhdGUnKSB7XG4gICAgc3Bhbi5zZXRBdHRyaWJ1dGUoc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfT1AsICdnZW5fYWkuZ2VuZXJhdGVfb2JqZWN0Jyk7XG4gICAgc3Bhbi51cGRhdGVOYW1lKGBnZW5lcmF0ZV9vYmplY3QgJHthdHRyaWJ1dGVzW3ZlcmNlbEFpQXR0cmlidXRlcy5BSV9NT0RFTF9JRF9BVFRSSUJVVEVdfWApO1xuICAgIHJldHVybjtcbiAgfVxuXG4gIGlmIChuYW1lID09PSAnYWkuc3RyZWFtT2JqZWN0Jykge1xuICAgIHNwYW4uc2V0QXR0cmlidXRlKHNlbWFudGljQXR0cmlidXRlcy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX09QLCAnZ2VuX2FpLmludm9rZV9hZ2VudCcpO1xuICAgIHJldHVybjtcbiAgfVxuXG4gIGlmIChuYW1lID09PSAnYWkuc3RyZWFtT2JqZWN0LmRvU3RyZWFtJykge1xuICAgIHNwYW4uc2V0QXR0cmlidXRlKHNlbWFudGljQXR0cmlidXRlcy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX09QLCAnZ2VuX2FpLnN0cmVhbV9vYmplY3QnKTtcbiAgICBzcGFuLnVwZGF0ZU5hbWUoYHN0cmVhbV9vYmplY3QgJHthdHRyaWJ1dGVzW3ZlcmNlbEFpQXR0cmlidXRlcy5BSV9NT0RFTF9JRF9BVFRSSUJVVEVdfWApO1xuICAgIHJldHVybjtcbiAgfVxuXG4gIGlmIChuYW1lID09PSAnYWkuZW1iZWQnKSB7XG4gICAgc3Bhbi5zZXRBdHRyaWJ1dGUoc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfT1AsICdnZW5fYWkuaW52b2tlX2FnZW50Jyk7XG4gICAgcmV0dXJuO1xuICB9XG5cbiAgaWYgKG5hbWUgPT09ICdhaS5lbWJlZC5kb0VtYmVkJykge1xuICAgIHNwYW4uc2V0QXR0cmlidXRlKHNlbWFudGljQXR0cmlidXRlcy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX09QLCAnZ2VuX2FpLmVtYmVkJyk7XG4gICAgc3Bhbi51cGRhdGVOYW1lKGBlbWJlZCAke2F0dHJpYnV0ZXNbdmVyY2VsQWlBdHRyaWJ1dGVzLkFJX01PREVMX0lEX0FUVFJJQlVURV19YCk7XG4gICAgcmV0dXJuO1xuICB9XG5cbiAgaWYgKG5hbWUgPT09ICdhaS5lbWJlZE1hbnknKSB7XG4gICAgc3Bhbi5zZXRBdHRyaWJ1dGUoc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfT1AsICdnZW5fYWkuaW52b2tlX2FnZW50Jyk7XG4gICAgcmV0dXJuO1xuICB9XG5cbiAgaWYgKG5hbWUgPT09ICdhaS5lbWJlZE1hbnkuZG9FbWJlZCcpIHtcbiAgICBzcGFuLnNldEF0dHJpYnV0ZShzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9PUCwgJ2dlbl9haS5lbWJlZF9tYW55Jyk7XG4gICAgc3Bhbi51cGRhdGVOYW1lKGBlbWJlZF9tYW55ICR7YXR0cmlidXRlc1t2ZXJjZWxBaUF0dHJpYnV0ZXMuQUlfTU9ERUxfSURfQVRUUklCVVRFXX1gKTtcbiAgICByZXR1cm47XG4gIH1cblxuICBpZiAobmFtZS5zdGFydHNXaXRoKCdhaS5zdHJlYW0nKSkge1xuICAgIHNwYW4uc2V0QXR0cmlidXRlKHNlbWFudGljQXR0cmlidXRlcy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX09QLCAnYWkucnVuJyk7XG4gICAgcmV0dXJuO1xuICB9XG59XG5cbi8qKlxuICogQWRkIGV2ZW50IHByb2Nlc3NvcnMgdG8gdGhlIGdpdmVuIGNsaWVudCB0byBwcm9jZXNzIFZlcmNlbCBBSSBzcGFucy5cbiAqL1xuZnVuY3Rpb24gYWRkVmVyY2VsQWlQcm9jZXNzb3JzKGNsaWVudCkge1xuICBjbGllbnQub24oJ3NwYW5TdGFydCcsIG9uVmVyY2VsQWlTcGFuU3RhcnQpO1xuICAvLyBOb3RlOiBXZSBjYW5ub3QgZG8gdGhpcyBvbiBgc3BhbkVuZGAsIGJlY2F1c2UgdGhlIHNwYW4gY2Fubm90IGJlIG11dGF0ZWQgYW55bW9yZSBhdCB0aGlzIHBvaW50XG4gIGNsaWVudC5hZGRFdmVudFByb2Nlc3NvcihPYmplY3QuYXNzaWduKHZlcmNlbEFpRXZlbnRQcm9jZXNzb3IsIHsgaWQ6ICdWZXJjZWxBaUV2ZW50UHJvY2Vzc29yJyB9KSk7XG59XG5cbmZ1bmN0aW9uIGFkZFByb3ZpZGVyTWV0YWRhdGFUb0F0dHJpYnV0ZXMoYXR0cmlidXRlcykge1xuICBjb25zdCBwcm92aWRlck1ldGFkYXRhID0gYXR0cmlidXRlc1t2ZXJjZWxBaUF0dHJpYnV0ZXMuQUlfUkVTUE9OU0VfUFJPVklERVJfTUVUQURBVEFfQVRUUklCVVRFXSA7XG4gIGlmIChwcm92aWRlck1ldGFkYXRhKSB7XG4gICAgdHJ5IHtcbiAgICAgIGNvbnN0IHByb3ZpZGVyTWV0YWRhdGFPYmplY3QgPSBKU09OLnBhcnNlKHByb3ZpZGVyTWV0YWRhdGEpIDtcbiAgICAgIGlmIChwcm92aWRlck1ldGFkYXRhT2JqZWN0Lm9wZW5haSkge1xuICAgICAgICBzZXRBdHRyaWJ1dGVJZkRlZmluZWQoXG4gICAgICAgICAgYXR0cmlidXRlcyxcbiAgICAgICAgICAnZ2VuX2FpLnVzYWdlLmlucHV0X3Rva2Vucy5jYWNoZWQnLFxuICAgICAgICAgIHByb3ZpZGVyTWV0YWRhdGFPYmplY3Qub3BlbmFpLmNhY2hlZFByb21wdFRva2VucyxcbiAgICAgICAgKTtcbiAgICAgICAgc2V0QXR0cmlidXRlSWZEZWZpbmVkKFxuICAgICAgICAgIGF0dHJpYnV0ZXMsXG4gICAgICAgICAgJ2dlbl9haS51c2FnZS5vdXRwdXRfdG9rZW5zLnJlYXNvbmluZycsXG4gICAgICAgICAgcHJvdmlkZXJNZXRhZGF0YU9iamVjdC5vcGVuYWkucmVhc29uaW5nVG9rZW5zLFxuICAgICAgICApO1xuICAgICAgICBzZXRBdHRyaWJ1dGVJZkRlZmluZWQoXG4gICAgICAgICAgYXR0cmlidXRlcyxcbiAgICAgICAgICAnZ2VuX2FpLnVzYWdlLm91dHB1dF90b2tlbnMucHJlZGljdGlvbl9hY2NlcHRlZCcsXG4gICAgICAgICAgcHJvdmlkZXJNZXRhZGF0YU9iamVjdC5vcGVuYWkuYWNjZXB0ZWRQcmVkaWN0aW9uVG9rZW5zLFxuICAgICAgICApO1xuICAgICAgICBzZXRBdHRyaWJ1dGVJZkRlZmluZWQoXG4gICAgICAgICAgYXR0cmlidXRlcyxcbiAgICAgICAgICAnZ2VuX2FpLnVzYWdlLm91dHB1dF90b2tlbnMucHJlZGljdGlvbl9yZWplY3RlZCcsXG4gICAgICAgICAgcHJvdmlkZXJNZXRhZGF0YU9iamVjdC5vcGVuYWkucmVqZWN0ZWRQcmVkaWN0aW9uVG9rZW5zLFxuICAgICAgICApO1xuICAgICAgICBzZXRBdHRyaWJ1dGVJZkRlZmluZWQoYXR0cmlidXRlcywgJ2dlbl9haS5jb252ZXJzYXRpb24uaWQnLCBwcm92aWRlck1ldGFkYXRhT2JqZWN0Lm9wZW5haS5yZXNwb25zZUlkKTtcbiAgICAgIH1cblxuICAgICAgaWYgKHByb3ZpZGVyTWV0YWRhdGFPYmplY3QuYW50aHJvcGljKSB7XG4gICAgICAgIHNldEF0dHJpYnV0ZUlmRGVmaW5lZChcbiAgICAgICAgICBhdHRyaWJ1dGVzLFxuICAgICAgICAgICdnZW5fYWkudXNhZ2UuaW5wdXRfdG9rZW5zLmNhY2hlZCcsXG4gICAgICAgICAgcHJvdmlkZXJNZXRhZGF0YU9iamVjdC5hbnRocm9waWMuY2FjaGVSZWFkSW5wdXRUb2tlbnMsXG4gICAgICAgICk7XG4gICAgICAgIHNldEF0dHJpYnV0ZUlmRGVmaW5lZChcbiAgICAgICAgICBhdHRyaWJ1dGVzLFxuICAgICAgICAgICdnZW5fYWkudXNhZ2UuaW5wdXRfdG9rZW5zLmNhY2hlX3dyaXRlJyxcbiAgICAgICAgICBwcm92aWRlck1ldGFkYXRhT2JqZWN0LmFudGhyb3BpYy5jYWNoZUNyZWF0aW9uSW5wdXRUb2tlbnMsXG4gICAgICAgICk7XG4gICAgICB9XG5cbiAgICAgIGlmIChwcm92aWRlck1ldGFkYXRhT2JqZWN0LmJlZHJvY2s/LnVzYWdlKSB7XG4gICAgICAgIHNldEF0dHJpYnV0ZUlmRGVmaW5lZChcbiAgICAgICAgICBhdHRyaWJ1dGVzLFxuICAgICAgICAgICdnZW5fYWkudXNhZ2UuaW5wdXRfdG9rZW5zLmNhY2hlZCcsXG4gICAgICAgICAgcHJvdmlkZXJNZXRhZGF0YU9iamVjdC5iZWRyb2NrLnVzYWdlLmNhY2hlUmVhZElucHV0VG9rZW5zLFxuICAgICAgICApO1xuICAgICAgICBzZXRBdHRyaWJ1dGVJZkRlZmluZWQoXG4gICAgICAgICAgYXR0cmlidXRlcyxcbiAgICAgICAgICAnZ2VuX2FpLnVzYWdlLmlucHV0X3Rva2Vucy5jYWNoZV93cml0ZScsXG4gICAgICAgICAgcHJvdmlkZXJNZXRhZGF0YU9iamVjdC5iZWRyb2NrLnVzYWdlLmNhY2hlV3JpdGVJbnB1dFRva2VucyxcbiAgICAgICAgKTtcbiAgICAgIH1cblxuICAgICAgaWYgKHByb3ZpZGVyTWV0YWRhdGFPYmplY3QuZGVlcHNlZWspIHtcbiAgICAgICAgc2V0QXR0cmlidXRlSWZEZWZpbmVkKFxuICAgICAgICAgIGF0dHJpYnV0ZXMsXG4gICAgICAgICAgJ2dlbl9haS51c2FnZS5pbnB1dF90b2tlbnMuY2FjaGVkJyxcbiAgICAgICAgICBwcm92aWRlck1ldGFkYXRhT2JqZWN0LmRlZXBzZWVrLnByb21wdENhY2hlSGl0VG9rZW5zLFxuICAgICAgICApO1xuICAgICAgICBzZXRBdHRyaWJ1dGVJZkRlZmluZWQoXG4gICAgICAgICAgYXR0cmlidXRlcyxcbiAgICAgICAgICAnZ2VuX2FpLnVzYWdlLmlucHV0X3Rva2Vucy5jYWNoZV9taXNzJyxcbiAgICAgICAgICBwcm92aWRlck1ldGFkYXRhT2JqZWN0LmRlZXBzZWVrLnByb21wdENhY2hlTWlzc1Rva2VucyxcbiAgICAgICAgKTtcbiAgICAgIH1cbiAgICB9IGNhdGNoIHtcbiAgICAgIC8vIElnbm9yZVxuICAgIH1cbiAgfVxufVxuXG4vKipcbiAqIFNldHMgYW4gYXR0cmlidXRlIG9ubHkgaWYgdGhlIHZhbHVlIGlzIG5vdCBudWxsIG9yIHVuZGVmaW5lZC5cbiAqL1xuZnVuY3Rpb24gc2V0QXR0cmlidXRlSWZEZWZpbmVkKGF0dHJpYnV0ZXMsIGtleSwgdmFsdWUpIHtcbiAgaWYgKHZhbHVlICE9IG51bGwpIHtcbiAgICBhdHRyaWJ1dGVzW2tleV0gPSB2YWx1ZTtcbiAgfVxufVxuXG5leHBvcnRzLmFkZFZlcmNlbEFpUHJvY2Vzc29ycyA9IGFkZFZlcmNlbEFpUHJvY2Vzc29ycztcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPXZlcmNlbC1haS5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/vercel-ai.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/vercelWaitUntil.js":
/*!*************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/vercelWaitUntil.js ***!
  \*************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst worldwide = __webpack_require__(/*! ./worldwide.js */ \"(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/worldwide.js\");\n\n/**\n * Function that delays closing of a Vercel lambda until the provided promise is resolved.\n *\n * Vendored from https://www.npmjs.com/package/@vercel/functions\n */\nfunction vercelWaitUntil(task) {\n  const vercelRequestContextGlobal =\n    // @ts-expect-error This is not typed\n    worldwide.GLOBAL_OBJ[Symbol.for('@vercel/request-context')];\n\n  const ctx = vercelRequestContextGlobal?.get?.();\n\n  if (ctx?.waitUntil) {\n    ctx.waitUntil(task);\n  }\n}\n\nexports.vercelWaitUntil = vercelWaitUntil;\n//# sourceMappingURL=vercelWaitUntil.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvdmVyY2VsV2FpdFVudGlsLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLGtCQUFrQixtQkFBTyxDQUFDLG9JQUFnQjs7QUFFMUM7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLHVCQUF1QjtBQUN2QiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3V0aWxzL3ZlcmNlbFdhaXRVbnRpbC5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3Qgd29ybGR3aWRlID0gcmVxdWlyZSgnLi93b3JsZHdpZGUuanMnKTtcblxuLyoqXG4gKiBGdW5jdGlvbiB0aGF0IGRlbGF5cyBjbG9zaW5nIG9mIGEgVmVyY2VsIGxhbWJkYSB1bnRpbCB0aGUgcHJvdmlkZWQgcHJvbWlzZSBpcyByZXNvbHZlZC5cbiAqXG4gKiBWZW5kb3JlZCBmcm9tIGh0dHBzOi8vd3d3Lm5wbWpzLmNvbS9wYWNrYWdlL0B2ZXJjZWwvZnVuY3Rpb25zXG4gKi9cbmZ1bmN0aW9uIHZlcmNlbFdhaXRVbnRpbCh0YXNrKSB7XG4gIGNvbnN0IHZlcmNlbFJlcXVlc3RDb250ZXh0R2xvYmFsID1cbiAgICAvLyBAdHMtZXhwZWN0LWVycm9yIFRoaXMgaXMgbm90IHR5cGVkXG4gICAgd29ybGR3aWRlLkdMT0JBTF9PQkpbU3ltYm9sLmZvcignQHZlcmNlbC9yZXF1ZXN0LWNvbnRleHQnKV07XG5cbiAgY29uc3QgY3R4ID0gdmVyY2VsUmVxdWVzdENvbnRleHRHbG9iYWw/LmdldD8uKCk7XG5cbiAgaWYgKGN0eD8ud2FpdFVudGlsKSB7XG4gICAgY3R4LndhaXRVbnRpbCh0YXNrKTtcbiAgfVxufVxuXG5leHBvcnRzLnZlcmNlbFdhaXRVbnRpbCA9IHZlcmNlbFdhaXRVbnRpbDtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPXZlcmNlbFdhaXRVbnRpbC5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/vercelWaitUntil.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/version.js":
/*!*****************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/version.js ***!
  \*****************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n// This is a magic string replaced by rollup\n\nconst SDK_VERSION = \"9.46.0\" ;\n\nexports.SDK_VERSION = SDK_VERSION;\n//# sourceMappingURL=version.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvdmVyc2lvbi5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RTs7QUFFQTs7QUFFQSxtQkFBbUI7QUFDbkIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy92ZXJzaW9uLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG4vLyBUaGlzIGlzIGEgbWFnaWMgc3RyaW5nIHJlcGxhY2VkIGJ5IHJvbGx1cFxuXG5jb25zdCBTREtfVkVSU0lPTiA9IFwiOS40Ni4wXCIgO1xuXG5leHBvcnRzLlNES19WRVJTSU9OID0gU0RLX1ZFUlNJT047XG4vLyMgc291cmNlTWFwcGluZ1VSTD12ZXJzaW9uLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/version.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/worldwide.js":
/*!*******************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/worldwide.js ***!
  \*******************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n/** Internal global with common properties and Sentry extensions  */\n\n/** Get's the global object for the current JavaScript runtime */\nconst GLOBAL_OBJ = globalThis ;\n\nexports.GLOBAL_OBJ = GLOBAL_OBJ;\n//# sourceMappingURL=worldwide.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvd29ybGR3aWRlLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFOztBQUVBO0FBQ0E7O0FBRUEsa0JBQWtCO0FBQ2xCIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvd29ybGR3aWRlLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG4vKiogSW50ZXJuYWwgZ2xvYmFsIHdpdGggY29tbW9uIHByb3BlcnRpZXMgYW5kIFNlbnRyeSBleHRlbnNpb25zICAqL1xuXG4vKiogR2V0J3MgdGhlIGdsb2JhbCBvYmplY3QgZm9yIHRoZSBjdXJyZW50IEphdmFTY3JpcHQgcnVudGltZSAqL1xuY29uc3QgR0xPQkFMX09CSiA9IGdsb2JhbFRoaXMgO1xuXG5leHBvcnRzLkdMT0JBTF9PQkogPSBHTE9CQUxfT0JKO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9d29ybGR3aWRlLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/worldwide.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/vendor/escapeStringForRegex.js":
/*!*******************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/vendor/escapeStringForRegex.js ***!
  \*******************************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n// Based on https://github.com/sindresorhus/escape-string-regexp but with modifications to:\n//   a) reduce the size by skipping the runtime type - checking\n//   b) ensure it gets down - compiled for old versions of Node(the published package only supports Node 14+).\n//\n// MIT License\n//\n// Copyright (c) Sindre Sorhus <sindresorhus@gmail.com> (https://sindresorhus.com)\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated\n// documentation files(the \"Software\"), to deal in the Software without restriction, including without limitation\n// the rights to use, copy, modify, merge, publish, distribute, sublicense, and / or sell copies of the Software, and\n// to permit persons to whom the Software is furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in all copies or substantial portions of\n// the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO\n// THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,\n// TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS\n// IN THE SOFTWARE.\n\n/**\n * Given a string, escape characters which have meaning in the regex grammar, such that the result is safe to feed to\n * `new RegExp()`.\n *\n * @param regexString The string to escape\n * @returns An version of the string with all special regex characters escaped\n */\nfunction escapeStringForRegex(regexString) {\n  // escape the hyphen separately so we can also replace it with a unicode literal hyphen, to avoid the problems\n  // discussed in https://github.com/sindresorhus/escape-string-regexp/issues/20.\n  return regexString.replace(/[|\\\\{}()[\\]^$+*?.]/g, '\\\\$&').replace(/-/g, '\\\\x2d');\n}\n\nexports.escapeStringForRegex = escapeStringForRegex;\n//# sourceMappingURL=escapeStringForRegex.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdmVuZG9yL2VzY2FwZVN0cmluZ0ZvclJlZ2V4LmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLG9DQUFvQztBQUNwQzs7QUFFQSw0QkFBNEI7QUFDNUIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy92ZW5kb3IvZXNjYXBlU3RyaW5nRm9yUmVnZXguanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbi8vIEJhc2VkIG9uIGh0dHBzOi8vZ2l0aHViLmNvbS9zaW5kcmVzb3JodXMvZXNjYXBlLXN0cmluZy1yZWdleHAgYnV0IHdpdGggbW9kaWZpY2F0aW9ucyB0bzpcbi8vICAgYSkgcmVkdWNlIHRoZSBzaXplIGJ5IHNraXBwaW5nIHRoZSBydW50aW1lIHR5cGUgLSBjaGVja2luZ1xuLy8gICBiKSBlbnN1cmUgaXQgZ2V0cyBkb3duIC0gY29tcGlsZWQgZm9yIG9sZCB2ZXJzaW9ucyBvZiBOb2RlKHRoZSBwdWJsaXNoZWQgcGFja2FnZSBvbmx5IHN1cHBvcnRzIE5vZGUgMTQrKS5cbi8vXG4vLyBNSVQgTGljZW5zZVxuLy9cbi8vIENvcHlyaWdodCAoYykgU2luZHJlIFNvcmh1cyA8c2luZHJlc29yaHVzQGdtYWlsLmNvbT4gKGh0dHBzOi8vc2luZHJlc29yaHVzLmNvbSlcbi8vXG4vLyBQZXJtaXNzaW9uIGlzIGhlcmVieSBncmFudGVkLCBmcmVlIG9mIGNoYXJnZSwgdG8gYW55IHBlcnNvbiBvYnRhaW5pbmcgYSBjb3B5IG9mIHRoaXMgc29mdHdhcmUgYW5kIGFzc29jaWF0ZWRcbi8vIGRvY3VtZW50YXRpb24gZmlsZXModGhlIFwiU29mdHdhcmVcIiksIHRvIGRlYWwgaW4gdGhlIFNvZnR3YXJlIHdpdGhvdXQgcmVzdHJpY3Rpb24sIGluY2x1ZGluZyB3aXRob3V0IGxpbWl0YXRpb25cbi8vIHRoZSByaWdodHMgdG8gdXNlLCBjb3B5LCBtb2RpZnksIG1lcmdlLCBwdWJsaXNoLCBkaXN0cmlidXRlLCBzdWJsaWNlbnNlLCBhbmQgLyBvciBzZWxsIGNvcGllcyBvZiB0aGUgU29mdHdhcmUsIGFuZFxuLy8gdG8gcGVybWl0IHBlcnNvbnMgdG8gd2hvbSB0aGUgU29mdHdhcmUgaXMgZnVybmlzaGVkIHRvIGRvIHNvLCBzdWJqZWN0IHRvIHRoZSBmb2xsb3dpbmcgY29uZGl0aW9uczpcbi8vXG4vLyBUaGUgYWJvdmUgY29weXJpZ2h0IG5vdGljZSBhbmQgdGhpcyBwZXJtaXNzaW9uIG5vdGljZSBzaGFsbCBiZSBpbmNsdWRlZCBpbiBhbGwgY29waWVzIG9yIHN1YnN0YW50aWFsIHBvcnRpb25zIG9mXG4vLyB0aGUgU29mdHdhcmUuXG4vL1xuLy8gVEhFIFNPRlRXQVJFIElTIFBST1ZJREVEIFwiQVMgSVNcIiwgV0lUSE9VVCBXQVJSQU5UWSBPRiBBTlkgS0lORCwgRVhQUkVTUyBPUiBJTVBMSUVELCBJTkNMVURJTkcgQlVUIE5PVCBMSU1JVEVEIFRPXG4vLyBUSEUgV0FSUkFOVElFUyBPRiBNRVJDSEFOVEFCSUxJVFksIEZJVE5FU1MgRk9SIEEgUEFSVElDVUxBUiBQVVJQT1NFIEFORCBOT05JTkZSSU5HRU1FTlQuSU4gTk8gRVZFTlQgU0hBTEwgVEhFXG4vLyBBVVRIT1JTIE9SIENPUFlSSUdIVCBIT0xERVJTIEJFIExJQUJMRSBGT1IgQU5ZIENMQUlNLCBEQU1BR0VTIE9SIE9USEVSIExJQUJJTElUWSwgV0hFVEhFUiBJTiBBTiBBQ1RJT04gT0YgQ09OVFJBQ1QsXG4vLyBUT1JUIE9SIE9USEVSV0lTRSwgQVJJU0lORyBGUk9NLCBPVVQgT0YgT1IgSU4gQ09OTkVDVElPTiBXSVRIIFRIRSBTT0ZUV0FSRSBPUiBUSEUgVVNFIE9SIE9USEVSIERFQUxJTkdTXG4vLyBJTiBUSEUgU09GVFdBUkUuXG5cbi8qKlxuICogR2l2ZW4gYSBzdHJpbmcsIGVzY2FwZSBjaGFyYWN0ZXJzIHdoaWNoIGhhdmUgbWVhbmluZyBpbiB0aGUgcmVnZXggZ3JhbW1hciwgc3VjaCB0aGF0IHRoZSByZXN1bHQgaXMgc2FmZSB0byBmZWVkIHRvXG4gKiBgbmV3IFJlZ0V4cCgpYC5cbiAqXG4gKiBAcGFyYW0gcmVnZXhTdHJpbmcgVGhlIHN0cmluZyB0byBlc2NhcGVcbiAqIEByZXR1cm5zIEFuIHZlcnNpb24gb2YgdGhlIHN0cmluZyB3aXRoIGFsbCBzcGVjaWFsIHJlZ2V4IGNoYXJhY3RlcnMgZXNjYXBlZFxuICovXG5mdW5jdGlvbiBlc2NhcGVTdHJpbmdGb3JSZWdleChyZWdleFN0cmluZykge1xuICAvLyBlc2NhcGUgdGhlIGh5cGhlbiBzZXBhcmF0ZWx5IHNvIHdlIGNhbiBhbHNvIHJlcGxhY2UgaXQgd2l0aCBhIHVuaWNvZGUgbGl0ZXJhbCBoeXBoZW4sIHRvIGF2b2lkIHRoZSBwcm9ibGVtc1xuICAvLyBkaXNjdXNzZWQgaW4gaHR0cHM6Ly9naXRodWIuY29tL3NpbmRyZXNvcmh1cy9lc2NhcGUtc3RyaW5nLXJlZ2V4cC9pc3N1ZXMvMjAuXG4gIHJldHVybiByZWdleFN0cmluZy5yZXBsYWNlKC9bfFxcXFx7fSgpW1xcXV4kKyo/Ll0vZywgJ1xcXFwkJicpLnJlcGxhY2UoLy0vZywgJ1xcXFx4MmQnKTtcbn1cblxuZXhwb3J0cy5lc2NhcGVTdHJpbmdGb3JSZWdleCA9IGVzY2FwZVN0cmluZ0ZvclJlZ2V4O1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9ZXNjYXBlU3RyaW5nRm9yUmVnZXguanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/vendor/escapeStringForRegex.js\n");
 
/***/ }),
 
/***/ "(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/vendor/getIpAddress.js":
/*!***********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/vendor/getIpAddress.js ***!
  \***********************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n// Vendored / modified from @sergiodxa/remix-utils\n\n// https://github.com/sergiodxa/remix-utils/blob/02af80e12829a53696bfa8f3c2363975cf59f55e/src/server/get-client-ip-address.ts\n// MIT License\n\n// Copyright (c) 2021 Sergio Xalambrí\n\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the \"Software\"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n\n// The above copyright notice and this permission notice shall be included in all\n// copies or substantial portions of the Software.\n\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n// SOFTWARE.\n\n// The headers to check, in priority order\nconst ipHeaderNames = [\n  'X-Client-IP',\n  'X-Forwarded-For',\n  'Fly-Client-IP',\n  'CF-Connecting-IP',\n  'Fastly-Client-Ip',\n  'True-Client-Ip',\n  'X-Real-IP',\n  'X-Cluster-Client-IP',\n  'X-Forwarded',\n  'Forwarded-For',\n  'Forwarded',\n  'X-Vercel-Forwarded-For',\n];\n\n/**\n * Get the IP address of the client sending a request.\n *\n * It receives a Request headers object and use it to get the\n * IP address from one of the following headers in order.\n *\n * If the IP address is valid, it will be returned. Otherwise, null will be\n * returned.\n *\n * If the header values contains more than one IP address, the first valid one\n * will be returned.\n */\nfunction getClientIPAddress(headers) {\n  // This will end up being Array<string | string[] | undefined | null> because of the various possible values a header\n  // can take\n  const headerValues = ipHeaderNames.map((headerName) => {\n    const rawValue = headers[headerName];\n    const value = Array.isArray(rawValue) ? rawValue.join(';') : rawValue;\n\n    if (headerName === 'Forwarded') {\n      return parseForwardedHeader(value);\n    }\n\n    return value?.split(',').map((v) => v.trim());\n  });\n\n  // Flatten the array and filter out any falsy entries\n  const flattenedHeaderValues = headerValues.reduce((acc, val) => {\n    if (!val) {\n      return acc;\n    }\n\n    return acc.concat(val);\n  }, []);\n\n  // Find the first value which is a valid IP address, if any\n  const ipAddress = flattenedHeaderValues.find(ip => ip !== null && isIP(ip));\n\n  return ipAddress || null;\n}\n\nfunction parseForwardedHeader(value) {\n  if (!value) {\n    return null;\n  }\n\n  for (const part of value.split(';')) {\n    if (part.startsWith('for=')) {\n      return part.slice(4);\n    }\n  }\n\n  return null;\n}\n\n//\n/**\n * Custom method instead of importing this from `net` package, as this only exists in node\n * Accepts:\n * 127.0.0.1\n * 192.168.1.1\n * 192.168.1.255\n * 255.255.255.255\n * 10.1.1.1\n * 0.0.0.0\n * 2b01:cb19:8350:ed00:d0dd:fa5b:de31:8be5\n *\n * Rejects:\n * 1.1.1.01\n * 30.168.1.255.1\n * 127.1\n * 192.168.1.256\n * -1.2.3.4\n * 1.1.1.1.\n * 3...3\n * 192.168.1.099\n */\nfunction isIP(str) {\n  const regex =\n    /(?:^(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)(?:\\.(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)){3}$)|(?:^(?:(?:[a-fA-F\\d]{1,4}:){7}(?:[a-fA-F\\d]{1,4}|:)|(?:[a-fA-F\\d]{1,4}:){6}(?:(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)(?:\\\\.(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)){3}|:[a-fA-F\\d]{1,4}|:)|(?:[a-fA-F\\d]{1,4}:){5}(?::(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)(?:\\\\.(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)){3}|(?::[a-fA-F\\d]{1,4}){1,2}|:)|(?:[a-fA-F\\d]{1,4}:){4}(?:(?::[a-fA-F\\d]{1,4}){0,1}:(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)(?:\\\\.(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)){3}|(?::[a-fA-F\\d]{1,4}){1,3}|:)|(?:[a-fA-F\\d]{1,4}:){3}(?:(?::[a-fA-F\\d]{1,4}){0,2}:(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)(?:\\\\.(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)){3}|(?::[a-fA-F\\d]{1,4}){1,4}|:)|(?:[a-fA-F\\d]{1,4}:){2}(?:(?::[a-fA-F\\d]{1,4}){0,3}:(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)(?:\\\\.(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)){3}|(?::[a-fA-F\\d]{1,4}){1,5}|:)|(?:[a-fA-F\\d]{1,4}:){1}(?:(?::[a-fA-F\\d]{1,4}){0,4}:(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)(?:\\\\.(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)){3}|(?::[a-fA-F\\d]{1,4}){1,6}|:)|(?::(?:(?::[a-fA-F\\d]{1,4}){0,5}:(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)(?:\\\\.(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)){3}|(?::[a-fA-F\\d]{1,4}){1,7}|:)))(?:%[0-9a-zA-Z]{1,})?$)/;\n  return regex.test(str);\n}\n\nexports.getClientIPAddress = getClientIPAddress;\nexports.ipHeaderNames = ipHeaderNames;\n//# sourceMappingURL=getIpAddress.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKGluc3RydW1lbnQpLy4vbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdmVuZG9yL2dldElwQWRkcmVzcy5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RTs7QUFFQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsNERBQTREOztBQUU1RDtBQUNBO0FBQ0E7O0FBRUE7QUFDQSxHQUFHOztBQUVIO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQSxHQUFHOztBQUVIO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSxtQ0FBbUM7QUFDbkM7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSwwRkFBMEYsRUFBRSx3QkFBd0IsSUFBSSxHQUFHLEVBQUUsY0FBYyxJQUFJLGtCQUFrQixJQUFJLEdBQUcsRUFBRSxxRkFBcUYsRUFBRSxhQUFhLElBQUksa0JBQWtCLElBQUksR0FBRyxFQUFFLHNGQUFzRixFQUFFLGdCQUFnQixJQUFJLEVBQUUsSUFBSSxrQkFBa0IsSUFBSSxHQUFHLEVBQUUsa0JBQWtCLElBQUksRUFBRSxJQUFJLG1GQUFtRixFQUFFLGdCQUFnQixJQUFJLEVBQUUsSUFBSSxrQkFBa0IsSUFBSSxHQUFHLEVBQUUsa0JBQWtCLElBQUksRUFBRSxJQUFJLG1GQUFtRixFQUFFLGdCQUFnQixJQUFJLEVBQUUsSUFBSSxrQkFBa0IsSUFBSSxHQUFHLEVBQUUsa0JBQWtCLElBQUksRUFBRSxJQUFJLG1GQUFtRixFQUFFLGdCQUFnQixJQUFJLEVBQUUsSUFBSSxrQkFBa0IsSUFBSSxHQUFHLEVBQUUsa0JBQWtCLElBQUksRUFBRSxJQUFJLG1GQUFtRixFQUFFLGdCQUFnQixJQUFJLEVBQUUsSUFBSSwwQkFBMEIsSUFBSSxFQUFFLElBQUksbUZBQW1GLEVBQUUsZ0JBQWdCLElBQUksRUFBRSxJQUFJLHFCQUFxQixHQUFHO0FBQ2x1QztBQUNBOztBQUVBLDBCQUEwQjtBQUMxQixxQkFBcUI7QUFDckIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy92ZW5kb3IvZ2V0SXBBZGRyZXNzLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG4vLyBWZW5kb3JlZCAvIG1vZGlmaWVkIGZyb20gQHNlcmdpb2R4YS9yZW1peC11dGlsc1xuXG4vLyBodHRwczovL2dpdGh1Yi5jb20vc2VyZ2lvZHhhL3JlbWl4LXV0aWxzL2Jsb2IvMDJhZjgwZTEyODI5YTUzNjk2YmZhOGYzYzIzNjM5NzVjZjU5ZjU1ZS9zcmMvc2VydmVyL2dldC1jbGllbnQtaXAtYWRkcmVzcy50c1xuLy8gTUlUIExpY2Vuc2VcblxuLy8gQ29weXJpZ2h0IChjKSAyMDIxIFNlcmdpbyBYYWxhbWJyw61cblxuLy8gUGVybWlzc2lvbiBpcyBoZXJlYnkgZ3JhbnRlZCwgZnJlZSBvZiBjaGFyZ2UsIHRvIGFueSBwZXJzb24gb2J0YWluaW5nIGEgY29weVxuLy8gb2YgdGhpcyBzb2Z0d2FyZSBhbmQgYXNzb2NpYXRlZCBkb2N1bWVudGF0aW9uIGZpbGVzICh0aGUgXCJTb2Z0d2FyZVwiKSwgdG8gZGVhbFxuLy8gaW4gdGhlIFNvZnR3YXJlIHdpdGhvdXQgcmVzdHJpY3Rpb24sIGluY2x1ZGluZyB3aXRob3V0IGxpbWl0YXRpb24gdGhlIHJpZ2h0c1xuLy8gdG8gdXNlLCBjb3B5LCBtb2RpZnksIG1lcmdlLCBwdWJsaXNoLCBkaXN0cmlidXRlLCBzdWJsaWNlbnNlLCBhbmQvb3Igc2VsbFxuLy8gY29waWVzIG9mIHRoZSBTb2Z0d2FyZSwgYW5kIHRvIHBlcm1pdCBwZXJzb25zIHRvIHdob20gdGhlIFNvZnR3YXJlIGlzXG4vLyBmdXJuaXNoZWQgdG8gZG8gc28sIHN1YmplY3QgdG8gdGhlIGZvbGxvd2luZyBjb25kaXRpb25zOlxuXG4vLyBUaGUgYWJvdmUgY29weXJpZ2h0IG5vdGljZSBhbmQgdGhpcyBwZXJtaXNzaW9uIG5vdGljZSBzaGFsbCBiZSBpbmNsdWRlZCBpbiBhbGxcbi8vIGNvcGllcyBvciBzdWJzdGFudGlhbCBwb3J0aW9ucyBvZiB0aGUgU29mdHdhcmUuXG5cbi8vIFRIRSBTT0ZUV0FSRSBJUyBQUk9WSURFRCBcIkFTIElTXCIsIFdJVEhPVVQgV0FSUkFOVFkgT0YgQU5ZIEtJTkQsIEVYUFJFU1MgT1Jcbi8vIElNUExJRUQsIElOQ0xVRElORyBCVVQgTk9UIExJTUlURUQgVE8gVEhFIFdBUlJBTlRJRVMgT0YgTUVSQ0hBTlRBQklMSVRZLFxuLy8gRklUTkVTUyBGT1IgQSBQQVJUSUNVTEFSIFBVUlBPU0UgQU5EIE5PTklORlJJTkdFTUVOVC4gSU4gTk8gRVZFTlQgU0hBTEwgVEhFXG4vLyBBVVRIT1JTIE9SIENPUFlSSUdIVCBIT0xERVJTIEJFIExJQUJMRSBGT1IgQU5ZIENMQUlNLCBEQU1BR0VTIE9SIE9USEVSXG4vLyBMSUFCSUxJVFksIFdIRVRIRVIgSU4gQU4gQUNUSU9OIE9GIENPTlRSQUNULCBUT1JUIE9SIE9USEVSV0lTRSwgQVJJU0lORyBGUk9NLFxuLy8gT1VUIE9GIE9SIElOIENPTk5FQ1RJT04gV0lUSCBUSEUgU09GVFdBUkUgT1IgVEhFIFVTRSBPUiBPVEhFUiBERUFMSU5HUyBJTiBUSEVcbi8vIFNPRlRXQVJFLlxuXG4vLyBUaGUgaGVhZGVycyB0byBjaGVjaywgaW4gcHJpb3JpdHkgb3JkZXJcbmNvbnN0IGlwSGVhZGVyTmFtZXMgPSBbXG4gICdYLUNsaWVudC1JUCcsXG4gICdYLUZvcndhcmRlZC1Gb3InLFxuICAnRmx5LUNsaWVudC1JUCcsXG4gICdDRi1Db25uZWN0aW5nLUlQJyxcbiAgJ0Zhc3RseS1DbGllbnQtSXAnLFxuICAnVHJ1ZS1DbGllbnQtSXAnLFxuICAnWC1SZWFsLUlQJyxcbiAgJ1gtQ2x1c3Rlci1DbGllbnQtSVAnLFxuICAnWC1Gb3J3YXJkZWQnLFxuICAnRm9yd2FyZGVkLUZvcicsXG4gICdGb3J3YXJkZWQnLFxuICAnWC1WZXJjZWwtRm9yd2FyZGVkLUZvcicsXG5dO1xuXG4vKipcbiAqIEdldCB0aGUgSVAgYWRkcmVzcyBvZiB0aGUgY2xpZW50IHNlbmRpbmcgYSByZXF1ZXN0LlxuICpcbiAqIEl0IHJlY2VpdmVzIGEgUmVxdWVzdCBoZWFkZXJzIG9iamVjdCBhbmQgdXNlIGl0IHRvIGdldCB0aGVcbiAqIElQIGFkZHJlc3MgZnJvbSBvbmUgb2YgdGhlIGZvbGxvd2luZyBoZWFkZXJzIGluIG9yZGVyLlxuICpcbiAqIElmIHRoZSBJUCBhZGRyZXNzIGlzIHZhbGlkLCBpdCB3aWxsIGJlIHJldHVybmVkLiBPdGhlcndpc2UsIG51bGwgd2lsbCBiZVxuICogcmV0dXJuZWQuXG4gKlxuICogSWYgdGhlIGhlYWRlciB2YWx1ZXMgY29udGFpbnMgbW9yZSB0aGFuIG9uZSBJUCBhZGRyZXNzLCB0aGUgZmlyc3QgdmFsaWQgb25lXG4gKiB3aWxsIGJlIHJldHVybmVkLlxuICovXG5mdW5jdGlvbiBnZXRDbGllbnRJUEFkZHJlc3MoaGVhZGVycykge1xuICAvLyBUaGlzIHdpbGwgZW5kIHVwIGJlaW5nIEFycmF5PHN0cmluZyB8IHN0cmluZ1tdIHwgdW5kZWZpbmVkIHwgbnVsbD4gYmVjYXVzZSBvZiB0aGUgdmFyaW91cyBwb3NzaWJsZSB2YWx1ZXMgYSBoZWFkZXJcbiAgLy8gY2FuIHRha2VcbiAgY29uc3QgaGVhZGVyVmFsdWVzID0gaXBIZWFkZXJOYW1lcy5tYXAoKGhlYWRlck5hbWUpID0+IHtcbiAgICBjb25zdCByYXdWYWx1ZSA9IGhlYWRlcnNbaGVhZGVyTmFtZV07XG4gICAgY29uc3QgdmFsdWUgPSBBcnJheS5pc0FycmF5KHJhd1ZhbHVlKSA/IHJhd1ZhbHVlLmpvaW4oJzsnKSA6IHJhd1ZhbHVlO1xuXG4gICAgaWYgKGhlYWRlck5hbWUgPT09ICdGb3J3YXJkZWQnKSB7XG4gICAgICByZXR1cm4gcGFyc2VGb3J3YXJkZWRIZWFkZXIodmFsdWUpO1xuICAgIH1cblxuICAgIHJldHVybiB2YWx1ZT8uc3BsaXQoJywnKS5tYXAoKHYpID0+IHYudHJpbSgpKTtcbiAgfSk7XG5cbiAgLy8gRmxhdHRlbiB0aGUgYXJyYXkgYW5kIGZpbHRlciBvdXQgYW55IGZhbHN5IGVudHJpZXNcbiAgY29uc3QgZmxhdHRlbmVkSGVhZGVyVmFsdWVzID0gaGVhZGVyVmFsdWVzLnJlZHVjZSgoYWNjLCB2YWwpID0+IHtcbiAgICBpZiAoIXZhbCkge1xuICAgICAgcmV0dXJuIGFjYztcbiAgICB9XG5cbiAgICByZXR1cm4gYWNjLmNvbmNhdCh2YWwpO1xuICB9LCBbXSk7XG5cbiAgLy8gRmluZCB0aGUgZmlyc3QgdmFsdWUgd2hpY2ggaXMgYSB2YWxpZCBJUCBhZGRyZXNzLCBpZiBhbnlcbiAgY29uc3QgaXBBZGRyZXNzID0gZmxhdHRlbmVkSGVhZGVyVmFsdWVzLmZpbmQoaXAgPT4gaXAgIT09IG51bGwgJiYgaXNJUChpcCkpO1xuXG4gIHJldHVybiBpcEFkZHJlc3MgfHwgbnVsbDtcbn1cblxuZnVuY3Rpb24gcGFyc2VGb3J3YXJkZWRIZWFkZXIodmFsdWUpIHtcbiAgaWYgKCF2YWx1ZSkge1xuICAgIHJldHVybiBudWxsO1xuICB9XG5cbiAgZm9yIChjb25zdCBwYXJ0IG9mIHZhbHVlLnNwbGl0KCc7JykpIHtcbiAgICBpZiAocGFydC5zdGFydHNXaXRoKCdmb3I9JykpIHtcbiAgICAgIHJldHVybiBwYXJ0LnNsaWNlKDQpO1xuICAgIH1cbiAgfVxuXG4gIHJldHVybiBudWxsO1xufVxuXG4vL1xuLyoqXG4gKiBDdXN0b20gbWV0aG9kIGluc3RlYWQgb2YgaW1wb3J0aW5nIHRoaXMgZnJvbSBgbmV0YCBwYWNrYWdlLCBhcyB0aGlzIG9ubHkgZXhpc3RzIGluIG5vZGVcbiAqIEFjY2VwdHM6XG4gKiAxMjcuMC4wLjFcbiAqIDE5Mi4xNjguMS4xXG4gKiAxOTIuMTY4LjEuMjU1XG4gKiAyNTUuMjU1LjI1NS4yNTVcbiAqIDEwLjEuMS4xXG4gKiAwLjAuMC4wXG4gKiAyYjAxOmNiMTk6ODM1MDplZDAwOmQwZGQ6ZmE1YjpkZTMxOjhiZTVcbiAqXG4gKiBSZWplY3RzOlxuICogMS4xLjEuMDFcbiAqIDMwLjE2OC4xLjI1NS4xXG4gKiAxMjcuMVxuICogMTkyLjE2OC4xLjI1NlxuICogLTEuMi4zLjRcbiAqIDEuMS4xLjEuXG4gKiAzLi4uM1xuICogMTkyLjE2OC4xLjA5OVxuICovXG5mdW5jdGlvbiBpc0lQKHN0cikge1xuICBjb25zdCByZWdleCA9XG4gICAgLyg/Ol4oPzoyNVswLTVdfDJbMC00XVxcZHwxXFxkXFxkfFsxLTldXFxkfFxcZCkoPzpcXC4oPzoyNVswLTVdfDJbMC00XVxcZHwxXFxkXFxkfFsxLTldXFxkfFxcZCkpezN9JCl8KD86Xig/Oig/OlthLWZBLUZcXGRdezEsNH06KXs3fSg/OlthLWZBLUZcXGRdezEsNH18Oil8KD86W2EtZkEtRlxcZF17MSw0fTopezZ9KD86KD86MjVbMC01XXwyWzAtNF1cXGR8MVxcZFxcZHxbMS05XVxcZHxcXGQpKD86XFxcXC4oPzoyNVswLTVdfDJbMC00XVxcZHwxXFxkXFxkfFsxLTldXFxkfFxcZCkpezN9fDpbYS1mQS1GXFxkXXsxLDR9fDopfCg/OlthLWZBLUZcXGRdezEsNH06KXs1fSg/OjooPzoyNVswLTVdfDJbMC00XVxcZHwxXFxkXFxkfFsxLTldXFxkfFxcZCkoPzpcXFxcLig/OjI1WzAtNV18MlswLTRdXFxkfDFcXGRcXGR8WzEtOV1cXGR8XFxkKSl7M318KD86OlthLWZBLUZcXGRdezEsNH0pezEsMn18Oil8KD86W2EtZkEtRlxcZF17MSw0fTopezR9KD86KD86OlthLWZBLUZcXGRdezEsNH0pezAsMX06KD86MjVbMC01XXwyWzAtNF1cXGR8MVxcZFxcZHxbMS05XVxcZHxcXGQpKD86XFxcXC4oPzoyNVswLTVdfDJbMC00XVxcZHwxXFxkXFxkfFsxLTldXFxkfFxcZCkpezN9fCg/OjpbYS1mQS1GXFxkXXsxLDR9KXsxLDN9fDopfCg/OlthLWZBLUZcXGRdezEsNH06KXszfSg/Oig/OjpbYS1mQS1GXFxkXXsxLDR9KXswLDJ9Oig/OjI1WzAtNV18MlswLTRdXFxkfDFcXGRcXGR8WzEtOV1cXGR8XFxkKSg/OlxcXFwuKD86MjVbMC01XXwyWzAtNF1cXGR8MVxcZFxcZHxbMS05XVxcZHxcXGQpKXszfXwoPzo6W2EtZkEtRlxcZF17MSw0fSl7MSw0fXw6KXwoPzpbYS1mQS1GXFxkXXsxLDR9Oil7Mn0oPzooPzo6W2EtZkEtRlxcZF17MSw0fSl7MCwzfTooPzoyNVswLTVdfDJbMC00XVxcZHwxXFxkXFxkfFsxLTldXFxkfFxcZCkoPzpcXFxcLig/OjI1WzAtNV18MlswLTRdXFxkfDFcXGRcXGR8WzEtOV1cXGR8XFxkKSl7M318KD86OlthLWZBLUZcXGRdezEsNH0pezEsNX18Oil8KD86W2EtZkEtRlxcZF17MSw0fTopezF9KD86KD86OlthLWZBLUZcXGRdezEsNH0pezAsNH06KD86MjVbMC01XXwyWzAtNF1cXGR8MVxcZFxcZHxbMS05XVxcZHxcXGQpKD86XFxcXC4oPzoyNVswLTVdfDJbMC00XVxcZHwxXFxkXFxkfFsxLTldXFxkfFxcZCkpezN9fCg/OjpbYS1mQS1GXFxkXXsxLDR9KXsxLDZ9fDopfCg/OjooPzooPzo6W2EtZkEtRlxcZF17MSw0fSl7MCw1fTooPzoyNVswLTVdfDJbMC00XVxcZHwxXFxkXFxkfFsxLTldXFxkfFxcZCkoPzpcXFxcLig/OjI1WzAtNV18MlswLTRdXFxkfDFcXGRcXGR8WzEtOV1cXGR8XFxkKSl7M318KD86OlthLWZBLUZcXGRdezEsNH0pezEsN318OikpKSg/OiVbMC05YS16QS1aXXsxLH0pPyQpLztcbiAgcmV0dXJuIHJlZ2V4LnRlc3Qoc3RyKTtcbn1cblxuZXhwb3J0cy5nZXRDbGllbnRJUEFkZHJlc3MgPSBnZXRDbGllbnRJUEFkZHJlc3M7XG5leHBvcnRzLmlwSGVhZGVyTmFtZXMgPSBpcEhlYWRlck5hbWVzO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9Z2V0SXBBZGRyZXNzLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(instrument)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/vendor/getIpAddress.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/api.js":
/*!*******************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/api.js ***!
  \*******************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst dsn = __webpack_require__(/*! ./utils/dsn.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/dsn.js\");\n\nconst SENTRY_API_VERSION = '7';\n\n/** Returns the prefix to construct Sentry ingestion API endpoints. */\nfunction getBaseApiEndpoint(dsn) {\n  const protocol = dsn.protocol ? `${dsn.protocol}:` : '';\n  const port = dsn.port ? `:${dsn.port}` : '';\n  return `${protocol}//${dsn.host}${port}${dsn.path ? `/${dsn.path}` : ''}/api/`;\n}\n\n/** Returns the ingest API endpoint for target. */\nfunction _getIngestEndpoint(dsn) {\n  return `${getBaseApiEndpoint(dsn)}${dsn.projectId}/envelope/`;\n}\n\n/** Returns a URL-encoded string with auth config suitable for a query string. */\nfunction _encodedAuth(dsn, sdkInfo) {\n  const params = {\n    sentry_version: SENTRY_API_VERSION,\n  };\n\n  if (dsn.publicKey) {\n    // We send only the minimum set of required information. See\n    // https://github.com/getsentry/sentry-javascript/issues/2572.\n    params.sentry_key = dsn.publicKey;\n  }\n\n  if (sdkInfo) {\n    params.sentry_client = `${sdkInfo.name}/${sdkInfo.version}`;\n  }\n\n  return new URLSearchParams(params).toString();\n}\n\n/**\n * Returns the envelope endpoint URL with auth in the query string.\n *\n * Sending auth as part of the query string and not as custom HTTP headers avoids CORS preflight requests.\n */\nfunction getEnvelopeEndpointWithUrlEncodedAuth(dsn, tunnel, sdkInfo) {\n  return tunnel ? tunnel : `${_getIngestEndpoint(dsn)}?${_encodedAuth(dsn, sdkInfo)}`;\n}\n\n/** Returns the url to the report dialog endpoint. */\nfunction getReportDialogEndpoint(dsnLike, dialogOptions) {\n  const dsn$1 = dsn.makeDsn(dsnLike);\n  if (!dsn$1) {\n    return '';\n  }\n\n  const endpoint = `${getBaseApiEndpoint(dsn$1)}embed/error-page/`;\n\n  let encodedOptions = `dsn=${dsn.dsnToString(dsn$1)}`;\n  for (const key in dialogOptions) {\n    if (key === 'dsn') {\n      continue;\n    }\n\n    if (key === 'onClose') {\n      continue;\n    }\n\n    if (key === 'user') {\n      const user = dialogOptions.user;\n      if (!user) {\n        continue;\n      }\n      if (user.name) {\n        encodedOptions += `&name=${encodeURIComponent(user.name)}`;\n      }\n      if (user.email) {\n        encodedOptions += `&email=${encodeURIComponent(user.email)}`;\n      }\n    } else {\n      encodedOptions += `&${encodeURIComponent(key)}=${encodeURIComponent(dialogOptions[key] )}`;\n    }\n  }\n\n  return `${endpoint}?${encodedOptions}`;\n}\n\nexports.getEnvelopeEndpointWithUrlEncodedAuth = getEnvelopeEndpointWithUrlEncodedAuth;\nexports.getReportDialogEndpoint = getReportDialogEndpoint;\n//# sourceMappingURL=api.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9hcGkuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsWUFBWSxtQkFBTyxDQUFDLHVIQUFnQjs7QUFFcEM7O0FBRUE7QUFDQTtBQUNBLHFDQUFxQyxhQUFhO0FBQ2xELDhCQUE4QixTQUFTO0FBQ3ZDLFlBQVksU0FBUyxJQUFJLFNBQVMsRUFBRSxLQUFLLEVBQUUsZUFBZSxTQUFTLE9BQU87QUFDMUU7O0FBRUE7QUFDQTtBQUNBLFlBQVksd0JBQXdCLEVBQUUsY0FBYztBQUNwRDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQSw4QkFBOEIsYUFBYSxHQUFHLGdCQUFnQjtBQUM5RDs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLDhCQUE4Qix3QkFBd0IsR0FBRywyQkFBMkI7QUFDcEY7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLHNCQUFzQiwwQkFBMEI7O0FBRWhELDhCQUE4Qix1QkFBdUI7QUFDckQ7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLG1DQUFtQyw4QkFBOEI7QUFDakU7QUFDQTtBQUNBLG9DQUFvQywrQkFBK0I7QUFDbkU7QUFDQSxNQUFNO0FBQ04sNEJBQTRCLHdCQUF3QixHQUFHLHdDQUF3QztBQUMvRjtBQUNBOztBQUVBLFlBQVksU0FBUyxHQUFHLGVBQWU7QUFDdkM7O0FBRUEsNkNBQTZDO0FBQzdDLCtCQUErQjtBQUMvQiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL2FwaS5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgZHNuID0gcmVxdWlyZSgnLi91dGlscy9kc24uanMnKTtcblxuY29uc3QgU0VOVFJZX0FQSV9WRVJTSU9OID0gJzcnO1xuXG4vKiogUmV0dXJucyB0aGUgcHJlZml4IHRvIGNvbnN0cnVjdCBTZW50cnkgaW5nZXN0aW9uIEFQSSBlbmRwb2ludHMuICovXG5mdW5jdGlvbiBnZXRCYXNlQXBpRW5kcG9pbnQoZHNuKSB7XG4gIGNvbnN0IHByb3RvY29sID0gZHNuLnByb3RvY29sID8gYCR7ZHNuLnByb3RvY29sfTpgIDogJyc7XG4gIGNvbnN0IHBvcnQgPSBkc24ucG9ydCA/IGA6JHtkc24ucG9ydH1gIDogJyc7XG4gIHJldHVybiBgJHtwcm90b2NvbH0vLyR7ZHNuLmhvc3R9JHtwb3J0fSR7ZHNuLnBhdGggPyBgLyR7ZHNuLnBhdGh9YCA6ICcnfS9hcGkvYDtcbn1cblxuLyoqIFJldHVybnMgdGhlIGluZ2VzdCBBUEkgZW5kcG9pbnQgZm9yIHRhcmdldC4gKi9cbmZ1bmN0aW9uIF9nZXRJbmdlc3RFbmRwb2ludChkc24pIHtcbiAgcmV0dXJuIGAke2dldEJhc2VBcGlFbmRwb2ludChkc24pfSR7ZHNuLnByb2plY3RJZH0vZW52ZWxvcGUvYDtcbn1cblxuLyoqIFJldHVybnMgYSBVUkwtZW5jb2RlZCBzdHJpbmcgd2l0aCBhdXRoIGNvbmZpZyBzdWl0YWJsZSBmb3IgYSBxdWVyeSBzdHJpbmcuICovXG5mdW5jdGlvbiBfZW5jb2RlZEF1dGgoZHNuLCBzZGtJbmZvKSB7XG4gIGNvbnN0IHBhcmFtcyA9IHtcbiAgICBzZW50cnlfdmVyc2lvbjogU0VOVFJZX0FQSV9WRVJTSU9OLFxuICB9O1xuXG4gIGlmIChkc24ucHVibGljS2V5KSB7XG4gICAgLy8gV2Ugc2VuZCBvbmx5IHRoZSBtaW5pbXVtIHNldCBvZiByZXF1aXJlZCBpbmZvcm1hdGlvbi4gU2VlXG4gICAgLy8gaHR0cHM6Ly9naXRodWIuY29tL2dldHNlbnRyeS9zZW50cnktamF2YXNjcmlwdC9pc3N1ZXMvMjU3Mi5cbiAgICBwYXJhbXMuc2VudHJ5X2tleSA9IGRzbi5wdWJsaWNLZXk7XG4gIH1cblxuICBpZiAoc2RrSW5mbykge1xuICAgIHBhcmFtcy5zZW50cnlfY2xpZW50ID0gYCR7c2RrSW5mby5uYW1lfS8ke3Nka0luZm8udmVyc2lvbn1gO1xuICB9XG5cbiAgcmV0dXJuIG5ldyBVUkxTZWFyY2hQYXJhbXMocGFyYW1zKS50b1N0cmluZygpO1xufVxuXG4vKipcbiAqIFJldHVybnMgdGhlIGVudmVsb3BlIGVuZHBvaW50IFVSTCB3aXRoIGF1dGggaW4gdGhlIHF1ZXJ5IHN0cmluZy5cbiAqXG4gKiBTZW5kaW5nIGF1dGggYXMgcGFydCBvZiB0aGUgcXVlcnkgc3RyaW5nIGFuZCBub3QgYXMgY3VzdG9tIEhUVFAgaGVhZGVycyBhdm9pZHMgQ09SUyBwcmVmbGlnaHQgcmVxdWVzdHMuXG4gKi9cbmZ1bmN0aW9uIGdldEVudmVsb3BlRW5kcG9pbnRXaXRoVXJsRW5jb2RlZEF1dGgoZHNuLCB0dW5uZWwsIHNka0luZm8pIHtcbiAgcmV0dXJuIHR1bm5lbCA/IHR1bm5lbCA6IGAke19nZXRJbmdlc3RFbmRwb2ludChkc24pfT8ke19lbmNvZGVkQXV0aChkc24sIHNka0luZm8pfWA7XG59XG5cbi8qKiBSZXR1cm5zIHRoZSB1cmwgdG8gdGhlIHJlcG9ydCBkaWFsb2cgZW5kcG9pbnQuICovXG5mdW5jdGlvbiBnZXRSZXBvcnREaWFsb2dFbmRwb2ludChkc25MaWtlLCBkaWFsb2dPcHRpb25zKSB7XG4gIGNvbnN0IGRzbiQxID0gZHNuLm1ha2VEc24oZHNuTGlrZSk7XG4gIGlmICghZHNuJDEpIHtcbiAgICByZXR1cm4gJyc7XG4gIH1cblxuICBjb25zdCBlbmRwb2ludCA9IGAke2dldEJhc2VBcGlFbmRwb2ludChkc24kMSl9ZW1iZWQvZXJyb3ItcGFnZS9gO1xuXG4gIGxldCBlbmNvZGVkT3B0aW9ucyA9IGBkc249JHtkc24uZHNuVG9TdHJpbmcoZHNuJDEpfWA7XG4gIGZvciAoY29uc3Qga2V5IGluIGRpYWxvZ09wdGlvbnMpIHtcbiAgICBpZiAoa2V5ID09PSAnZHNuJykge1xuICAgICAgY29udGludWU7XG4gICAgfVxuXG4gICAgaWYgKGtleSA9PT0gJ29uQ2xvc2UnKSB7XG4gICAgICBjb250aW51ZTtcbiAgICB9XG5cbiAgICBpZiAoa2V5ID09PSAndXNlcicpIHtcbiAgICAgIGNvbnN0IHVzZXIgPSBkaWFsb2dPcHRpb25zLnVzZXI7XG4gICAgICBpZiAoIXVzZXIpIHtcbiAgICAgICAgY29udGludWU7XG4gICAgICB9XG4gICAgICBpZiAodXNlci5uYW1lKSB7XG4gICAgICAgIGVuY29kZWRPcHRpb25zICs9IGAmbmFtZT0ke2VuY29kZVVSSUNvbXBvbmVudCh1c2VyLm5hbWUpfWA7XG4gICAgICB9XG4gICAgICBpZiAodXNlci5lbWFpbCkge1xuICAgICAgICBlbmNvZGVkT3B0aW9ucyArPSBgJmVtYWlsPSR7ZW5jb2RlVVJJQ29tcG9uZW50KHVzZXIuZW1haWwpfWA7XG4gICAgICB9XG4gICAgfSBlbHNlIHtcbiAgICAgIGVuY29kZWRPcHRpb25zICs9IGAmJHtlbmNvZGVVUklDb21wb25lbnQoa2V5KX09JHtlbmNvZGVVUklDb21wb25lbnQoZGlhbG9nT3B0aW9uc1trZXldICl9YDtcbiAgICB9XG4gIH1cblxuICByZXR1cm4gYCR7ZW5kcG9pbnR9PyR7ZW5jb2RlZE9wdGlvbnN9YDtcbn1cblxuZXhwb3J0cy5nZXRFbnZlbG9wZUVuZHBvaW50V2l0aFVybEVuY29kZWRBdXRoID0gZ2V0RW52ZWxvcGVFbmRwb2ludFdpdGhVcmxFbmNvZGVkQXV0aDtcbmV4cG9ydHMuZ2V0UmVwb3J0RGlhbG9nRW5kcG9pbnQgPSBnZXRSZXBvcnREaWFsb2dFbmRwb2ludDtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWFwaS5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/api.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/asyncContext/index.js":
/*!**********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/asyncContext/index.js ***!
  \**********************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst carrier = __webpack_require__(/*! ../carrier.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/carrier.js\");\nconst stackStrategy = __webpack_require__(/*! ./stackStrategy.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/asyncContext/stackStrategy.js\");\n\n/**\n * @private Private API with no semver guarantees!\n *\n * Sets the global async context strategy\n */\nfunction setAsyncContextStrategy(strategy) {\n  // Get main carrier (global for every environment)\n  const registry = carrier.getMainCarrier();\n  const sentry = carrier.getSentryCarrier(registry);\n  sentry.acs = strategy;\n}\n\n/**\n * Get the current async context strategy.\n * If none has been setup, the default will be used.\n */\nfunction getAsyncContextStrategy(carrier$1) {\n  const sentry = carrier.getSentryCarrier(carrier$1);\n\n  if (sentry.acs) {\n    return sentry.acs;\n  }\n\n  // Otherwise, use the default one (stack)\n  return stackStrategy.getStackAsyncContextStrategy();\n}\n\nexports.getAsyncContextStrategy = getAsyncContextStrategy;\nexports.setAsyncContextStrategy = setAsyncContextStrategy;\n//# sourceMappingURL=index.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9hc3luY0NvbnRleHQvaW5kZXguanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsZ0JBQWdCLG1CQUFPLENBQUMsb0hBQWU7QUFDdkMsc0JBQXNCLG1CQUFPLENBQUMsNElBQW9COztBQUVsRDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBLCtCQUErQjtBQUMvQiwrQkFBK0I7QUFDL0IiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9hc3luY0NvbnRleHQvaW5kZXguanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGNhcnJpZXIgPSByZXF1aXJlKCcuLi9jYXJyaWVyLmpzJyk7XG5jb25zdCBzdGFja1N0cmF0ZWd5ID0gcmVxdWlyZSgnLi9zdGFja1N0cmF0ZWd5LmpzJyk7XG5cbi8qKlxuICogQHByaXZhdGUgUHJpdmF0ZSBBUEkgd2l0aCBubyBzZW12ZXIgZ3VhcmFudGVlcyFcbiAqXG4gKiBTZXRzIHRoZSBnbG9iYWwgYXN5bmMgY29udGV4dCBzdHJhdGVneVxuICovXG5mdW5jdGlvbiBzZXRBc3luY0NvbnRleHRTdHJhdGVneShzdHJhdGVneSkge1xuICAvLyBHZXQgbWFpbiBjYXJyaWVyIChnbG9iYWwgZm9yIGV2ZXJ5IGVudmlyb25tZW50KVxuICBjb25zdCByZWdpc3RyeSA9IGNhcnJpZXIuZ2V0TWFpbkNhcnJpZXIoKTtcbiAgY29uc3Qgc2VudHJ5ID0gY2Fycmllci5nZXRTZW50cnlDYXJyaWVyKHJlZ2lzdHJ5KTtcbiAgc2VudHJ5LmFjcyA9IHN0cmF0ZWd5O1xufVxuXG4vKipcbiAqIEdldCB0aGUgY3VycmVudCBhc3luYyBjb250ZXh0IHN0cmF0ZWd5LlxuICogSWYgbm9uZSBoYXMgYmVlbiBzZXR1cCwgdGhlIGRlZmF1bHQgd2lsbCBiZSB1c2VkLlxuICovXG5mdW5jdGlvbiBnZXRBc3luY0NvbnRleHRTdHJhdGVneShjYXJyaWVyJDEpIHtcbiAgY29uc3Qgc2VudHJ5ID0gY2Fycmllci5nZXRTZW50cnlDYXJyaWVyKGNhcnJpZXIkMSk7XG5cbiAgaWYgKHNlbnRyeS5hY3MpIHtcbiAgICByZXR1cm4gc2VudHJ5LmFjcztcbiAgfVxuXG4gIC8vIE90aGVyd2lzZSwgdXNlIHRoZSBkZWZhdWx0IG9uZSAoc3RhY2spXG4gIHJldHVybiBzdGFja1N0cmF0ZWd5LmdldFN0YWNrQXN5bmNDb250ZXh0U3RyYXRlZ3koKTtcbn1cblxuZXhwb3J0cy5nZXRBc3luY0NvbnRleHRTdHJhdGVneSA9IGdldEFzeW5jQ29udGV4dFN0cmF0ZWd5O1xuZXhwb3J0cy5zZXRBc3luY0NvbnRleHRTdHJhdGVneSA9IHNldEFzeW5jQ29udGV4dFN0cmF0ZWd5O1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9aW5kZXguanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/asyncContext/index.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/asyncContext/stackStrategy.js":
/*!******************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/asyncContext/stackStrategy.js ***!
  \******************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst defaultScopes = __webpack_require__(/*! ../defaultScopes.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/defaultScopes.js\");\nconst scope = __webpack_require__(/*! ../scope.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/scope.js\");\nconst is = __webpack_require__(/*! ../utils/is.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js\");\nconst carrier = __webpack_require__(/*! ../carrier.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/carrier.js\");\n\n/**\n * This is an object that holds a stack of scopes.\n */\nclass AsyncContextStack {\n\n   constructor(scope$1, isolationScope) {\n    let assignedScope;\n    if (!scope$1) {\n      assignedScope = new scope.Scope();\n    } else {\n      assignedScope = scope$1;\n    }\n\n    let assignedIsolationScope;\n    if (!isolationScope) {\n      assignedIsolationScope = new scope.Scope();\n    } else {\n      assignedIsolationScope = isolationScope;\n    }\n\n    // scope stack for domains or the process\n    this._stack = [{ scope: assignedScope }];\n    this._isolationScope = assignedIsolationScope;\n  }\n\n  /**\n   * Fork a scope for the stack.\n   */\n   withScope(callback) {\n    const scope = this._pushScope();\n\n    let maybePromiseResult;\n    try {\n      maybePromiseResult = callback(scope);\n    } catch (e) {\n      this._popScope();\n      throw e;\n    }\n\n    if (is.isThenable(maybePromiseResult)) {\n      // @ts-expect-error - isThenable returns the wrong type\n      return maybePromiseResult.then(\n        res => {\n          this._popScope();\n          return res;\n        },\n        e => {\n          this._popScope();\n          throw e;\n        },\n      );\n    }\n\n    this._popScope();\n    return maybePromiseResult;\n  }\n\n  /**\n   * Get the client of the stack.\n   */\n   getClient() {\n    return this.getStackTop().client ;\n  }\n\n  /**\n   * Returns the scope of the top stack.\n   */\n   getScope() {\n    return this.getStackTop().scope;\n  }\n\n  /**\n   * Get the isolation scope for the stack.\n   */\n   getIsolationScope() {\n    return this._isolationScope;\n  }\n\n  /**\n   * Returns the topmost scope layer in the order domain > local > process.\n   */\n   getStackTop() {\n    return this._stack[this._stack.length - 1] ;\n  }\n\n  /**\n   * Push a scope to the stack.\n   */\n   _pushScope() {\n    // We want to clone the content of prev scope\n    const scope = this.getScope().clone();\n    this._stack.push({\n      client: this.getClient(),\n      scope,\n    });\n    return scope;\n  }\n\n  /**\n   * Pop a scope from the stack.\n   */\n   _popScope() {\n    if (this._stack.length <= 1) return false;\n    return !!this._stack.pop();\n  }\n}\n\n/**\n * Get the global async context stack.\n * This will be removed during the v8 cycle and is only here to make migration easier.\n */\nfunction getAsyncContextStack() {\n  const registry = carrier.getMainCarrier();\n  const sentry = carrier.getSentryCarrier(registry);\n\n  return (sentry.stack = sentry.stack || new AsyncContextStack(defaultScopes.getDefaultCurrentScope(), defaultScopes.getDefaultIsolationScope()));\n}\n\nfunction withScope(callback) {\n  return getAsyncContextStack().withScope(callback);\n}\n\nfunction withSetScope(scope, callback) {\n  const stack = getAsyncContextStack() ;\n  return stack.withScope(() => {\n    stack.getStackTop().scope = scope;\n    return callback(scope);\n  });\n}\n\nfunction withIsolationScope(callback) {\n  return getAsyncContextStack().withScope(() => {\n    return callback(getAsyncContextStack().getIsolationScope());\n  });\n}\n\n/**\n * Get the stack-based async context strategy.\n */\nfunction getStackAsyncContextStrategy() {\n  return {\n    withIsolationScope,\n    withScope,\n    withSetScope,\n    withSetIsolationScope: (_isolationScope, callback) => {\n      return withIsolationScope(callback);\n    },\n    getCurrentScope: () => getAsyncContextStack().getScope(),\n    getIsolationScope: () => getAsyncContextStack().getIsolationScope(),\n  };\n}\n\nexports.AsyncContextStack = AsyncContextStack;\nexports.getStackAsyncContextStrategy = getStackAsyncContextStrategy;\n//# sourceMappingURL=stackStrategy.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9hc3luY0NvbnRleHQvc3RhY2tTdHJhdGVneS5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxzQkFBc0IsbUJBQU8sQ0FBQyxnSUFBcUI7QUFDbkQsY0FBYyxtQkFBTyxDQUFDLGdIQUFhO0FBQ25DLFdBQVcsbUJBQU8sQ0FBQyxzSEFBZ0I7QUFDbkMsZ0JBQWdCLG1CQUFPLENBQUMsb0hBQWU7O0FBRXZDO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsTUFBTTtBQUNOO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0EsTUFBTTtBQUNOO0FBQ0E7O0FBRUE7QUFDQSxxQkFBcUIsc0JBQXNCO0FBQzNDO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQSxNQUFNO0FBQ047QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFNBQVM7QUFDVDtBQUNBO0FBQ0E7QUFDQSxTQUFTO0FBQ1Q7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEtBQUs7QUFDTDtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEdBQUc7QUFDSDs7QUFFQTtBQUNBO0FBQ0E7QUFDQSxHQUFHO0FBQ0g7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxLQUFLO0FBQ0w7QUFDQTtBQUNBO0FBQ0E7O0FBRUEseUJBQXlCO0FBQ3pCLG9DQUFvQztBQUNwQyIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL2FzeW5jQ29udGV4dC9zdGFja1N0cmF0ZWd5LmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBkZWZhdWx0U2NvcGVzID0gcmVxdWlyZSgnLi4vZGVmYXVsdFNjb3Blcy5qcycpO1xuY29uc3Qgc2NvcGUgPSByZXF1aXJlKCcuLi9zY29wZS5qcycpO1xuY29uc3QgaXMgPSByZXF1aXJlKCcuLi91dGlscy9pcy5qcycpO1xuY29uc3QgY2FycmllciA9IHJlcXVpcmUoJy4uL2NhcnJpZXIuanMnKTtcblxuLyoqXG4gKiBUaGlzIGlzIGFuIG9iamVjdCB0aGF0IGhvbGRzIGEgc3RhY2sgb2Ygc2NvcGVzLlxuICovXG5jbGFzcyBBc3luY0NvbnRleHRTdGFjayB7XG5cbiAgIGNvbnN0cnVjdG9yKHNjb3BlJDEsIGlzb2xhdGlvblNjb3BlKSB7XG4gICAgbGV0IGFzc2lnbmVkU2NvcGU7XG4gICAgaWYgKCFzY29wZSQxKSB7XG4gICAgICBhc3NpZ25lZFNjb3BlID0gbmV3IHNjb3BlLlNjb3BlKCk7XG4gICAgfSBlbHNlIHtcbiAgICAgIGFzc2lnbmVkU2NvcGUgPSBzY29wZSQxO1xuICAgIH1cblxuICAgIGxldCBhc3NpZ25lZElzb2xhdGlvblNjb3BlO1xuICAgIGlmICghaXNvbGF0aW9uU2NvcGUpIHtcbiAgICAgIGFzc2lnbmVkSXNvbGF0aW9uU2NvcGUgPSBuZXcgc2NvcGUuU2NvcGUoKTtcbiAgICB9IGVsc2Uge1xuICAgICAgYXNzaWduZWRJc29sYXRpb25TY29wZSA9IGlzb2xhdGlvblNjb3BlO1xuICAgIH1cblxuICAgIC8vIHNjb3BlIHN0YWNrIGZvciBkb21haW5zIG9yIHRoZSBwcm9jZXNzXG4gICAgdGhpcy5fc3RhY2sgPSBbeyBzY29wZTogYXNzaWduZWRTY29wZSB9XTtcbiAgICB0aGlzLl9pc29sYXRpb25TY29wZSA9IGFzc2lnbmVkSXNvbGF0aW9uU2NvcGU7XG4gIH1cblxuICAvKipcbiAgICogRm9yayBhIHNjb3BlIGZvciB0aGUgc3RhY2suXG4gICAqL1xuICAgd2l0aFNjb3BlKGNhbGxiYWNrKSB7XG4gICAgY29uc3Qgc2NvcGUgPSB0aGlzLl9wdXNoU2NvcGUoKTtcblxuICAgIGxldCBtYXliZVByb21pc2VSZXN1bHQ7XG4gICAgdHJ5IHtcbiAgICAgIG1heWJlUHJvbWlzZVJlc3VsdCA9IGNhbGxiYWNrKHNjb3BlKTtcbiAgICB9IGNhdGNoIChlKSB7XG4gICAgICB0aGlzLl9wb3BTY29wZSgpO1xuICAgICAgdGhyb3cgZTtcbiAgICB9XG5cbiAgICBpZiAoaXMuaXNUaGVuYWJsZShtYXliZVByb21pc2VSZXN1bHQpKSB7XG4gICAgICAvLyBAdHMtZXhwZWN0LWVycm9yIC0gaXNUaGVuYWJsZSByZXR1cm5zIHRoZSB3cm9uZyB0eXBlXG4gICAgICByZXR1cm4gbWF5YmVQcm9taXNlUmVzdWx0LnRoZW4oXG4gICAgICAgIHJlcyA9PiB7XG4gICAgICAgICAgdGhpcy5fcG9wU2NvcGUoKTtcbiAgICAgICAgICByZXR1cm4gcmVzO1xuICAgICAgICB9LFxuICAgICAgICBlID0+IHtcbiAgICAgICAgICB0aGlzLl9wb3BTY29wZSgpO1xuICAgICAgICAgIHRocm93IGU7XG4gICAgICAgIH0sXG4gICAgICApO1xuICAgIH1cblxuICAgIHRoaXMuX3BvcFNjb3BlKCk7XG4gICAgcmV0dXJuIG1heWJlUHJvbWlzZVJlc3VsdDtcbiAgfVxuXG4gIC8qKlxuICAgKiBHZXQgdGhlIGNsaWVudCBvZiB0aGUgc3RhY2suXG4gICAqL1xuICAgZ2V0Q2xpZW50KCkge1xuICAgIHJldHVybiB0aGlzLmdldFN0YWNrVG9wKCkuY2xpZW50IDtcbiAgfVxuXG4gIC8qKlxuICAgKiBSZXR1cm5zIHRoZSBzY29wZSBvZiB0aGUgdG9wIHN0YWNrLlxuICAgKi9cbiAgIGdldFNjb3BlKCkge1xuICAgIHJldHVybiB0aGlzLmdldFN0YWNrVG9wKCkuc2NvcGU7XG4gIH1cblxuICAvKipcbiAgICogR2V0IHRoZSBpc29sYXRpb24gc2NvcGUgZm9yIHRoZSBzdGFjay5cbiAgICovXG4gICBnZXRJc29sYXRpb25TY29wZSgpIHtcbiAgICByZXR1cm4gdGhpcy5faXNvbGF0aW9uU2NvcGU7XG4gIH1cblxuICAvKipcbiAgICogUmV0dXJucyB0aGUgdG9wbW9zdCBzY29wZSBsYXllciBpbiB0aGUgb3JkZXIgZG9tYWluID4gbG9jYWwgPiBwcm9jZXNzLlxuICAgKi9cbiAgIGdldFN0YWNrVG9wKCkge1xuICAgIHJldHVybiB0aGlzLl9zdGFja1t0aGlzLl9zdGFjay5sZW5ndGggLSAxXSA7XG4gIH1cblxuICAvKipcbiAgICogUHVzaCBhIHNjb3BlIHRvIHRoZSBzdGFjay5cbiAgICovXG4gICBfcHVzaFNjb3BlKCkge1xuICAgIC8vIFdlIHdhbnQgdG8gY2xvbmUgdGhlIGNvbnRlbnQgb2YgcHJldiBzY29wZVxuICAgIGNvbnN0IHNjb3BlID0gdGhpcy5nZXRTY29wZSgpLmNsb25lKCk7XG4gICAgdGhpcy5fc3RhY2sucHVzaCh7XG4gICAgICBjbGllbnQ6IHRoaXMuZ2V0Q2xpZW50KCksXG4gICAgICBzY29wZSxcbiAgICB9KTtcbiAgICByZXR1cm4gc2NvcGU7XG4gIH1cblxuICAvKipcbiAgICogUG9wIGEgc2NvcGUgZnJvbSB0aGUgc3RhY2suXG4gICAqL1xuICAgX3BvcFNjb3BlKCkge1xuICAgIGlmICh0aGlzLl9zdGFjay5sZW5ndGggPD0gMSkgcmV0dXJuIGZhbHNlO1xuICAgIHJldHVybiAhIXRoaXMuX3N0YWNrLnBvcCgpO1xuICB9XG59XG5cbi8qKlxuICogR2V0IHRoZSBnbG9iYWwgYXN5bmMgY29udGV4dCBzdGFjay5cbiAqIFRoaXMgd2lsbCBiZSByZW1vdmVkIGR1cmluZyB0aGUgdjggY3ljbGUgYW5kIGlzIG9ubHkgaGVyZSB0byBtYWtlIG1pZ3JhdGlvbiBlYXNpZXIuXG4gKi9cbmZ1bmN0aW9uIGdldEFzeW5jQ29udGV4dFN0YWNrKCkge1xuICBjb25zdCByZWdpc3RyeSA9IGNhcnJpZXIuZ2V0TWFpbkNhcnJpZXIoKTtcbiAgY29uc3Qgc2VudHJ5ID0gY2Fycmllci5nZXRTZW50cnlDYXJyaWVyKHJlZ2lzdHJ5KTtcblxuICByZXR1cm4gKHNlbnRyeS5zdGFjayA9IHNlbnRyeS5zdGFjayB8fCBuZXcgQXN5bmNDb250ZXh0U3RhY2soZGVmYXVsdFNjb3Blcy5nZXREZWZhdWx0Q3VycmVudFNjb3BlKCksIGRlZmF1bHRTY29wZXMuZ2V0RGVmYXVsdElzb2xhdGlvblNjb3BlKCkpKTtcbn1cblxuZnVuY3Rpb24gd2l0aFNjb3BlKGNhbGxiYWNrKSB7XG4gIHJldHVybiBnZXRBc3luY0NvbnRleHRTdGFjaygpLndpdGhTY29wZShjYWxsYmFjayk7XG59XG5cbmZ1bmN0aW9uIHdpdGhTZXRTY29wZShzY29wZSwgY2FsbGJhY2spIHtcbiAgY29uc3Qgc3RhY2sgPSBnZXRBc3luY0NvbnRleHRTdGFjaygpIDtcbiAgcmV0dXJuIHN0YWNrLndpdGhTY29wZSgoKSA9PiB7XG4gICAgc3RhY2suZ2V0U3RhY2tUb3AoKS5zY29wZSA9IHNjb3BlO1xuICAgIHJldHVybiBjYWxsYmFjayhzY29wZSk7XG4gIH0pO1xufVxuXG5mdW5jdGlvbiB3aXRoSXNvbGF0aW9uU2NvcGUoY2FsbGJhY2spIHtcbiAgcmV0dXJuIGdldEFzeW5jQ29udGV4dFN0YWNrKCkud2l0aFNjb3BlKCgpID0+IHtcbiAgICByZXR1cm4gY2FsbGJhY2soZ2V0QXN5bmNDb250ZXh0U3RhY2soKS5nZXRJc29sYXRpb25TY29wZSgpKTtcbiAgfSk7XG59XG5cbi8qKlxuICogR2V0IHRoZSBzdGFjay1iYXNlZCBhc3luYyBjb250ZXh0IHN0cmF0ZWd5LlxuICovXG5mdW5jdGlvbiBnZXRTdGFja0FzeW5jQ29udGV4dFN0cmF0ZWd5KCkge1xuICByZXR1cm4ge1xuICAgIHdpdGhJc29sYXRpb25TY29wZSxcbiAgICB3aXRoU2NvcGUsXG4gICAgd2l0aFNldFNjb3BlLFxuICAgIHdpdGhTZXRJc29sYXRpb25TY29wZTogKF9pc29sYXRpb25TY29wZSwgY2FsbGJhY2spID0+IHtcbiAgICAgIHJldHVybiB3aXRoSXNvbGF0aW9uU2NvcGUoY2FsbGJhY2spO1xuICAgIH0sXG4gICAgZ2V0Q3VycmVudFNjb3BlOiAoKSA9PiBnZXRBc3luY0NvbnRleHRTdGFjaygpLmdldFNjb3BlKCksXG4gICAgZ2V0SXNvbGF0aW9uU2NvcGU6ICgpID0+IGdldEFzeW5jQ29udGV4dFN0YWNrKCkuZ2V0SXNvbGF0aW9uU2NvcGUoKSxcbiAgfTtcbn1cblxuZXhwb3J0cy5Bc3luY0NvbnRleHRTdGFjayA9IEFzeW5jQ29udGV4dFN0YWNrO1xuZXhwb3J0cy5nZXRTdGFja0FzeW5jQ29udGV4dFN0cmF0ZWd5ID0gZ2V0U3RhY2tBc3luY0NvbnRleHRTdHJhdGVneTtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPXN0YWNrU3RyYXRlZ3kuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/asyncContext/stackStrategy.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/breadcrumbs.js":
/*!***************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/breadcrumbs.js ***!
  \***************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst currentScopes = __webpack_require__(/*! ./currentScopes.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst debugLogger = __webpack_require__(/*! ./utils/debug-logger.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst time = __webpack_require__(/*! ./utils/time.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/time.js\");\n\n/**\n * Default maximum number of breadcrumbs added to an event. Can be overwritten\n * with {@link Options.maxBreadcrumbs}.\n */\nconst DEFAULT_BREADCRUMBS = 100;\n\n/**\n * Records a new breadcrumb which will be attached to future events.\n *\n * Breadcrumbs will be added to subsequent events to provide more context on\n * user's actions prior to an error or crash.\n */\nfunction addBreadcrumb(breadcrumb, hint) {\n  const client = currentScopes.getClient();\n  const isolationScope = currentScopes.getIsolationScope();\n\n  if (!client) return;\n\n  const { beforeBreadcrumb = null, maxBreadcrumbs = DEFAULT_BREADCRUMBS } = client.getOptions();\n\n  if (maxBreadcrumbs <= 0) return;\n\n  const timestamp = time.dateTimestampInSeconds();\n  const mergedBreadcrumb = { timestamp, ...breadcrumb };\n  const finalBreadcrumb = beforeBreadcrumb\n    ? (debugLogger.consoleSandbox(() => beforeBreadcrumb(mergedBreadcrumb, hint)) )\n    : mergedBreadcrumb;\n\n  if (finalBreadcrumb === null) return;\n\n  if (client.emit) {\n    client.emit('beforeAddBreadcrumb', finalBreadcrumb, hint);\n  }\n\n  isolationScope.addBreadcrumb(finalBreadcrumb, maxBreadcrumbs);\n}\n\nexports.addBreadcrumb = addBreadcrumb;\n//# sourceMappingURL=breadcrumbs.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9icmVhZGNydW1icy5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxzQkFBc0IsbUJBQU8sQ0FBQywrSEFBb0I7QUFDbEQsb0JBQW9CLG1CQUFPLENBQUMseUlBQXlCO0FBQ3JELGFBQWEsbUJBQU8sQ0FBQyx5SEFBaUI7O0FBRXRDO0FBQ0E7QUFDQSxTQUFTLDZCQUE2QjtBQUN0QztBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQSxVQUFVLGdFQUFnRTs7QUFFMUU7O0FBRUE7QUFDQSw2QkFBNkI7QUFDN0I7QUFDQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBLHFCQUFxQjtBQUNyQiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL2JyZWFkY3J1bWJzLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBjdXJyZW50U2NvcGVzID0gcmVxdWlyZSgnLi9jdXJyZW50U2NvcGVzLmpzJyk7XG5jb25zdCBkZWJ1Z0xvZ2dlciA9IHJlcXVpcmUoJy4vdXRpbHMvZGVidWctbG9nZ2VyLmpzJyk7XG5jb25zdCB0aW1lID0gcmVxdWlyZSgnLi91dGlscy90aW1lLmpzJyk7XG5cbi8qKlxuICogRGVmYXVsdCBtYXhpbXVtIG51bWJlciBvZiBicmVhZGNydW1icyBhZGRlZCB0byBhbiBldmVudC4gQ2FuIGJlIG92ZXJ3cml0dGVuXG4gKiB3aXRoIHtAbGluayBPcHRpb25zLm1heEJyZWFkY3J1bWJzfS5cbiAqL1xuY29uc3QgREVGQVVMVF9CUkVBRENSVU1CUyA9IDEwMDtcblxuLyoqXG4gKiBSZWNvcmRzIGEgbmV3IGJyZWFkY3J1bWIgd2hpY2ggd2lsbCBiZSBhdHRhY2hlZCB0byBmdXR1cmUgZXZlbnRzLlxuICpcbiAqIEJyZWFkY3J1bWJzIHdpbGwgYmUgYWRkZWQgdG8gc3Vic2VxdWVudCBldmVudHMgdG8gcHJvdmlkZSBtb3JlIGNvbnRleHQgb25cbiAqIHVzZXIncyBhY3Rpb25zIHByaW9yIHRvIGFuIGVycm9yIG9yIGNyYXNoLlxuICovXG5mdW5jdGlvbiBhZGRCcmVhZGNydW1iKGJyZWFkY3J1bWIsIGhpbnQpIHtcbiAgY29uc3QgY2xpZW50ID0gY3VycmVudFNjb3Blcy5nZXRDbGllbnQoKTtcbiAgY29uc3QgaXNvbGF0aW9uU2NvcGUgPSBjdXJyZW50U2NvcGVzLmdldElzb2xhdGlvblNjb3BlKCk7XG5cbiAgaWYgKCFjbGllbnQpIHJldHVybjtcblxuICBjb25zdCB7IGJlZm9yZUJyZWFkY3J1bWIgPSBudWxsLCBtYXhCcmVhZGNydW1icyA9IERFRkFVTFRfQlJFQURDUlVNQlMgfSA9IGNsaWVudC5nZXRPcHRpb25zKCk7XG5cbiAgaWYgKG1heEJyZWFkY3J1bWJzIDw9IDApIHJldHVybjtcblxuICBjb25zdCB0aW1lc3RhbXAgPSB0aW1lLmRhdGVUaW1lc3RhbXBJblNlY29uZHMoKTtcbiAgY29uc3QgbWVyZ2VkQnJlYWRjcnVtYiA9IHsgdGltZXN0YW1wLCAuLi5icmVhZGNydW1iIH07XG4gIGNvbnN0IGZpbmFsQnJlYWRjcnVtYiA9IGJlZm9yZUJyZWFkY3J1bWJcbiAgICA/IChkZWJ1Z0xvZ2dlci5jb25zb2xlU2FuZGJveCgoKSA9PiBiZWZvcmVCcmVhZGNydW1iKG1lcmdlZEJyZWFkY3J1bWIsIGhpbnQpKSApXG4gICAgOiBtZXJnZWRCcmVhZGNydW1iO1xuXG4gIGlmIChmaW5hbEJyZWFkY3J1bWIgPT09IG51bGwpIHJldHVybjtcblxuICBpZiAoY2xpZW50LmVtaXQpIHtcbiAgICBjbGllbnQuZW1pdCgnYmVmb3JlQWRkQnJlYWRjcnVtYicsIGZpbmFsQnJlYWRjcnVtYiwgaGludCk7XG4gIH1cblxuICBpc29sYXRpb25TY29wZS5hZGRCcmVhZGNydW1iKGZpbmFsQnJlYWRjcnVtYiwgbWF4QnJlYWRjcnVtYnMpO1xufVxuXG5leHBvcnRzLmFkZEJyZWFkY3J1bWIgPSBhZGRCcmVhZGNydW1iO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9YnJlYWRjcnVtYnMuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/breadcrumbs.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/carrier.js":
/*!***********************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/carrier.js ***!
  \***********************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst version = __webpack_require__(/*! ./utils/version.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/version.js\");\nconst worldwide = __webpack_require__(/*! ./utils/worldwide.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/worldwide.js\");\n\n/**\n * An object that contains globally accessible properties and maintains a scope stack.\n * @hidden\n */\n\n/**\n * Returns the global shim registry.\n *\n * FIXME: This function is problematic, because despite always returning a valid Carrier,\n * it has an optional `__SENTRY__` property, which then in turn requires us to always perform an unnecessary check\n * at the call-site. We always access the carrier through this function, so we can guarantee that `__SENTRY__` is there.\n **/\nfunction getMainCarrier() {\n  // This ensures a Sentry carrier exists\n  getSentryCarrier(worldwide.GLOBAL_OBJ);\n  return worldwide.GLOBAL_OBJ;\n}\n\n/** Will either get the existing sentry carrier, or create a new one. */\nfunction getSentryCarrier(carrier) {\n  const __SENTRY__ = (carrier.__SENTRY__ = carrier.__SENTRY__ || {});\n\n  // For now: First SDK that sets the .version property wins\n  __SENTRY__.version = __SENTRY__.version || version.SDK_VERSION;\n\n  // Intentionally populating and returning the version of \"this\" SDK instance\n  // rather than what's set in .version so that \"this\" SDK always gets its carrier\n  return (__SENTRY__[version.SDK_VERSION] = __SENTRY__[version.SDK_VERSION] || {});\n}\n\n/**\n * Returns a global singleton contained in the global `__SENTRY__[]` object.\n *\n * If the singleton doesn't already exist in `__SENTRY__`, it will be created using the given factory\n * function and added to the `__SENTRY__` object.\n *\n * @param name name of the global singleton on __SENTRY__\n * @param creator creator Factory function to create the singleton if it doesn't already exist on `__SENTRY__`\n * @param obj (Optional) The global object on which to look for `__SENTRY__`, if not `GLOBAL_OBJ`'s return value\n * @returns the singleton\n */\nfunction getGlobalSingleton(\n  name,\n  creator,\n  obj = worldwide.GLOBAL_OBJ,\n) {\n  const __SENTRY__ = (obj.__SENTRY__ = obj.__SENTRY__ || {});\n  const carrier = (__SENTRY__[version.SDK_VERSION] = __SENTRY__[version.SDK_VERSION] || {});\n  // Note: We do not want to set `carrier.version` here, as this may be called before any `init` is called, e.g. for the default scopes\n  return carrier[name] || (carrier[name] = creator());\n}\n\nexports.getGlobalSingleton = getGlobalSingleton;\nexports.getMainCarrier = getMainCarrier;\nexports.getSentryCarrier = getSentryCarrier;\n//# sourceMappingURL=carrier.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9jYXJyaWVyLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLGdCQUFnQixtQkFBTyxDQUFDLCtIQUFvQjtBQUM1QyxrQkFBa0IsbUJBQU8sQ0FBQyxtSUFBc0I7O0FBRWhEO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsbUVBQW1FOztBQUVuRTtBQUNBOztBQUVBO0FBQ0E7QUFDQSxpRkFBaUY7QUFDakY7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSwyREFBMkQ7QUFDM0QsMEZBQTBGO0FBQzFGO0FBQ0E7QUFDQTs7QUFFQSwwQkFBMEI7QUFDMUIsc0JBQXNCO0FBQ3RCLHdCQUF3QjtBQUN4QiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL2NhcnJpZXIuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IHZlcnNpb24gPSByZXF1aXJlKCcuL3V0aWxzL3ZlcnNpb24uanMnKTtcbmNvbnN0IHdvcmxkd2lkZSA9IHJlcXVpcmUoJy4vdXRpbHMvd29ybGR3aWRlLmpzJyk7XG5cbi8qKlxuICogQW4gb2JqZWN0IHRoYXQgY29udGFpbnMgZ2xvYmFsbHkgYWNjZXNzaWJsZSBwcm9wZXJ0aWVzIGFuZCBtYWludGFpbnMgYSBzY29wZSBzdGFjay5cbiAqIEBoaWRkZW5cbiAqL1xuXG4vKipcbiAqIFJldHVybnMgdGhlIGdsb2JhbCBzaGltIHJlZ2lzdHJ5LlxuICpcbiAqIEZJWE1FOiBUaGlzIGZ1bmN0aW9uIGlzIHByb2JsZW1hdGljLCBiZWNhdXNlIGRlc3BpdGUgYWx3YXlzIHJldHVybmluZyBhIHZhbGlkIENhcnJpZXIsXG4gKiBpdCBoYXMgYW4gb3B0aW9uYWwgYF9fU0VOVFJZX19gIHByb3BlcnR5LCB3aGljaCB0aGVuIGluIHR1cm4gcmVxdWlyZXMgdXMgdG8gYWx3YXlzIHBlcmZvcm0gYW4gdW5uZWNlc3NhcnkgY2hlY2tcbiAqIGF0IHRoZSBjYWxsLXNpdGUuIFdlIGFsd2F5cyBhY2Nlc3MgdGhlIGNhcnJpZXIgdGhyb3VnaCB0aGlzIGZ1bmN0aW9uLCBzbyB3ZSBjYW4gZ3VhcmFudGVlIHRoYXQgYF9fU0VOVFJZX19gIGlzIHRoZXJlLlxuICoqL1xuZnVuY3Rpb24gZ2V0TWFpbkNhcnJpZXIoKSB7XG4gIC8vIFRoaXMgZW5zdXJlcyBhIFNlbnRyeSBjYXJyaWVyIGV4aXN0c1xuICBnZXRTZW50cnlDYXJyaWVyKHdvcmxkd2lkZS5HTE9CQUxfT0JKKTtcbiAgcmV0dXJuIHdvcmxkd2lkZS5HTE9CQUxfT0JKO1xufVxuXG4vKiogV2lsbCBlaXRoZXIgZ2V0IHRoZSBleGlzdGluZyBzZW50cnkgY2Fycmllciwgb3IgY3JlYXRlIGEgbmV3IG9uZS4gKi9cbmZ1bmN0aW9uIGdldFNlbnRyeUNhcnJpZXIoY2Fycmllcikge1xuICBjb25zdCBfX1NFTlRSWV9fID0gKGNhcnJpZXIuX19TRU5UUllfXyA9IGNhcnJpZXIuX19TRU5UUllfXyB8fCB7fSk7XG5cbiAgLy8gRm9yIG5vdzogRmlyc3QgU0RLIHRoYXQgc2V0cyB0aGUgLnZlcnNpb24gcHJvcGVydHkgd2luc1xuICBfX1NFTlRSWV9fLnZlcnNpb24gPSBfX1NFTlRSWV9fLnZlcnNpb24gfHwgdmVyc2lvbi5TREtfVkVSU0lPTjtcblxuICAvLyBJbnRlbnRpb25hbGx5IHBvcHVsYXRpbmcgYW5kIHJldHVybmluZyB0aGUgdmVyc2lvbiBvZiBcInRoaXNcIiBTREsgaW5zdGFuY2VcbiAgLy8gcmF0aGVyIHRoYW4gd2hhdCdzIHNldCBpbiAudmVyc2lvbiBzbyB0aGF0IFwidGhpc1wiIFNESyBhbHdheXMgZ2V0cyBpdHMgY2FycmllclxuICByZXR1cm4gKF9fU0VOVFJZX19bdmVyc2lvbi5TREtfVkVSU0lPTl0gPSBfX1NFTlRSWV9fW3ZlcnNpb24uU0RLX1ZFUlNJT05dIHx8IHt9KTtcbn1cblxuLyoqXG4gKiBSZXR1cm5zIGEgZ2xvYmFsIHNpbmdsZXRvbiBjb250YWluZWQgaW4gdGhlIGdsb2JhbCBgX19TRU5UUllfX1tdYCBvYmplY3QuXG4gKlxuICogSWYgdGhlIHNpbmdsZXRvbiBkb2Vzbid0IGFscmVhZHkgZXhpc3QgaW4gYF9fU0VOVFJZX19gLCBpdCB3aWxsIGJlIGNyZWF0ZWQgdXNpbmcgdGhlIGdpdmVuIGZhY3RvcnlcbiAqIGZ1bmN0aW9uIGFuZCBhZGRlZCB0byB0aGUgYF9fU0VOVFJZX19gIG9iamVjdC5cbiAqXG4gKiBAcGFyYW0gbmFtZSBuYW1lIG9mIHRoZSBnbG9iYWwgc2luZ2xldG9uIG9uIF9fU0VOVFJZX19cbiAqIEBwYXJhbSBjcmVhdG9yIGNyZWF0b3IgRmFjdG9yeSBmdW5jdGlvbiB0byBjcmVhdGUgdGhlIHNpbmdsZXRvbiBpZiBpdCBkb2Vzbid0IGFscmVhZHkgZXhpc3Qgb24gYF9fU0VOVFJZX19gXG4gKiBAcGFyYW0gb2JqIChPcHRpb25hbCkgVGhlIGdsb2JhbCBvYmplY3Qgb24gd2hpY2ggdG8gbG9vayBmb3IgYF9fU0VOVFJZX19gLCBpZiBub3QgYEdMT0JBTF9PQkpgJ3MgcmV0dXJuIHZhbHVlXG4gKiBAcmV0dXJucyB0aGUgc2luZ2xldG9uXG4gKi9cbmZ1bmN0aW9uIGdldEdsb2JhbFNpbmdsZXRvbihcbiAgbmFtZSxcbiAgY3JlYXRvcixcbiAgb2JqID0gd29ybGR3aWRlLkdMT0JBTF9PQkosXG4pIHtcbiAgY29uc3QgX19TRU5UUllfXyA9IChvYmouX19TRU5UUllfXyA9IG9iai5fX1NFTlRSWV9fIHx8IHt9KTtcbiAgY29uc3QgY2FycmllciA9IChfX1NFTlRSWV9fW3ZlcnNpb24uU0RLX1ZFUlNJT05dID0gX19TRU5UUllfX1t2ZXJzaW9uLlNES19WRVJTSU9OXSB8fCB7fSk7XG4gIC8vIE5vdGU6IFdlIGRvIG5vdCB3YW50IHRvIHNldCBgY2Fycmllci52ZXJzaW9uYCBoZXJlLCBhcyB0aGlzIG1heSBiZSBjYWxsZWQgYmVmb3JlIGFueSBgaW5pdGAgaXMgY2FsbGVkLCBlLmcuIGZvciB0aGUgZGVmYXVsdCBzY29wZXNcbiAgcmV0dXJuIGNhcnJpZXJbbmFtZV0gfHwgKGNhcnJpZXJbbmFtZV0gPSBjcmVhdG9yKCkpO1xufVxuXG5leHBvcnRzLmdldEdsb2JhbFNpbmdsZXRvbiA9IGdldEdsb2JhbFNpbmdsZXRvbjtcbmV4cG9ydHMuZ2V0TWFpbkNhcnJpZXIgPSBnZXRNYWluQ2FycmllcjtcbmV4cG9ydHMuZ2V0U2VudHJ5Q2FycmllciA9IGdldFNlbnRyeUNhcnJpZXI7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1jYXJyaWVyLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/carrier.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/checkin.js":
/*!***********************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/checkin.js ***!
  \***********************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst dsn = __webpack_require__(/*! ./utils/dsn.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/dsn.js\");\nconst envelope = __webpack_require__(/*! ./utils/envelope.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/envelope.js\");\n\n/**\n * Create envelope from check in item.\n */\nfunction createCheckInEnvelope(\n  checkIn,\n  dynamicSamplingContext,\n  metadata,\n  tunnel,\n  dsn$1,\n) {\n  const headers = {\n    sent_at: new Date().toISOString(),\n  };\n\n  if (metadata?.sdk) {\n    headers.sdk = {\n      name: metadata.sdk.name,\n      version: metadata.sdk.version,\n    };\n  }\n\n  if (!!tunnel && !!dsn$1) {\n    headers.dsn = dsn.dsnToString(dsn$1);\n  }\n\n  if (dynamicSamplingContext) {\n    headers.trace = dynamicSamplingContext ;\n  }\n\n  const item = createCheckInEnvelopeItem(checkIn);\n  return envelope.createEnvelope(headers, [item]);\n}\n\nfunction createCheckInEnvelopeItem(checkIn) {\n  const checkInHeaders = {\n    type: 'check_in',\n  };\n  return [checkInHeaders, checkIn];\n}\n\nexports.createCheckInEnvelope = createCheckInEnvelope;\n//# sourceMappingURL=checkin.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9jaGVja2luLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLFlBQVksbUJBQU8sQ0FBQyx1SEFBZ0I7QUFDcEMsaUJBQWlCLG1CQUFPLENBQUMsaUlBQXFCOztBQUU5QztBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLDZCQUE2QjtBQUM3QiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL2NoZWNraW4uanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGRzbiA9IHJlcXVpcmUoJy4vdXRpbHMvZHNuLmpzJyk7XG5jb25zdCBlbnZlbG9wZSA9IHJlcXVpcmUoJy4vdXRpbHMvZW52ZWxvcGUuanMnKTtcblxuLyoqXG4gKiBDcmVhdGUgZW52ZWxvcGUgZnJvbSBjaGVjayBpbiBpdGVtLlxuICovXG5mdW5jdGlvbiBjcmVhdGVDaGVja0luRW52ZWxvcGUoXG4gIGNoZWNrSW4sXG4gIGR5bmFtaWNTYW1wbGluZ0NvbnRleHQsXG4gIG1ldGFkYXRhLFxuICB0dW5uZWwsXG4gIGRzbiQxLFxuKSB7XG4gIGNvbnN0IGhlYWRlcnMgPSB7XG4gICAgc2VudF9hdDogbmV3IERhdGUoKS50b0lTT1N0cmluZygpLFxuICB9O1xuXG4gIGlmIChtZXRhZGF0YT8uc2RrKSB7XG4gICAgaGVhZGVycy5zZGsgPSB7XG4gICAgICBuYW1lOiBtZXRhZGF0YS5zZGsubmFtZSxcbiAgICAgIHZlcnNpb246IG1ldGFkYXRhLnNkay52ZXJzaW9uLFxuICAgIH07XG4gIH1cblxuICBpZiAoISF0dW5uZWwgJiYgISFkc24kMSkge1xuICAgIGhlYWRlcnMuZHNuID0gZHNuLmRzblRvU3RyaW5nKGRzbiQxKTtcbiAgfVxuXG4gIGlmIChkeW5hbWljU2FtcGxpbmdDb250ZXh0KSB7XG4gICAgaGVhZGVycy50cmFjZSA9IGR5bmFtaWNTYW1wbGluZ0NvbnRleHQgO1xuICB9XG5cbiAgY29uc3QgaXRlbSA9IGNyZWF0ZUNoZWNrSW5FbnZlbG9wZUl0ZW0oY2hlY2tJbik7XG4gIHJldHVybiBlbnZlbG9wZS5jcmVhdGVFbnZlbG9wZShoZWFkZXJzLCBbaXRlbV0pO1xufVxuXG5mdW5jdGlvbiBjcmVhdGVDaGVja0luRW52ZWxvcGVJdGVtKGNoZWNrSW4pIHtcbiAgY29uc3QgY2hlY2tJbkhlYWRlcnMgPSB7XG4gICAgdHlwZTogJ2NoZWNrX2luJyxcbiAgfTtcbiAgcmV0dXJuIFtjaGVja0luSGVhZGVycywgY2hlY2tJbl07XG59XG5cbmV4cG9ydHMuY3JlYXRlQ2hlY2tJbkVudmVsb3BlID0gY3JlYXRlQ2hlY2tJbkVudmVsb3BlO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9Y2hlY2tpbi5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/checkin.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/client.js":
/*!**********************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/client.js ***!
  \**********************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst api = __webpack_require__(/*! ./api.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/api.js\");\nconst constants = __webpack_require__(/*! ./constants.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/constants.js\");\nconst currentScopes = __webpack_require__(/*! ./currentScopes.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst debugBuild = __webpack_require__(/*! ./debug-build.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst envelope = __webpack_require__(/*! ./envelope.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/envelope.js\");\nconst integration = __webpack_require__(/*! ./integration.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integration.js\");\nconst session = __webpack_require__(/*! ./session.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/session.js\");\nconst dynamicSamplingContext = __webpack_require__(/*! ./tracing/dynamicSamplingContext.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/dynamicSamplingContext.js\");\nconst clientreport = __webpack_require__(/*! ./utils/clientreport.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/clientreport.js\");\nconst debugLogger = __webpack_require__(/*! ./utils/debug-logger.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst dsn = __webpack_require__(/*! ./utils/dsn.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/dsn.js\");\nconst envelope$1 = __webpack_require__(/*! ./utils/envelope.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/envelope.js\");\nconst eventUtils = __webpack_require__(/*! ./utils/eventUtils.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/eventUtils.js\");\nconst is = __webpack_require__(/*! ./utils/is.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js\");\nconst merge = __webpack_require__(/*! ./utils/merge.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/merge.js\");\nconst misc = __webpack_require__(/*! ./utils/misc.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/misc.js\");\nconst parseSampleRate = __webpack_require__(/*! ./utils/parseSampleRate.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/parseSampleRate.js\");\nconst prepareEvent = __webpack_require__(/*! ./utils/prepareEvent.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/prepareEvent.js\");\nconst spanUtils = __webpack_require__(/*! ./utils/spanUtils.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanUtils.js\");\nconst syncpromise = __webpack_require__(/*! ./utils/syncpromise.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/syncpromise.js\");\nconst transactionEvent = __webpack_require__(/*! ./utils/transactionEvent.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/transactionEvent.js\");\n\n/* eslint-disable max-lines */\n\nconst ALREADY_SEEN_ERROR = \"Not capturing exception because it's already been captured.\";\nconst MISSING_RELEASE_FOR_SESSION_ERROR = 'Discarded session because of missing or non-string release';\n\nconst INTERNAL_ERROR_SYMBOL = Symbol.for('SentryInternalError');\nconst DO_NOT_SEND_EVENT_SYMBOL = Symbol.for('SentryDoNotSendEventError');\n\nfunction _makeInternalError(message) {\n  return {\n    message,\n    [INTERNAL_ERROR_SYMBOL]: true,\n  };\n}\n\nfunction _makeDoNotSendEventError(message) {\n  return {\n    message,\n    [DO_NOT_SEND_EVENT_SYMBOL]: true,\n  };\n}\n\nfunction _isInternalError(error) {\n  return !!error && typeof error === 'object' && INTERNAL_ERROR_SYMBOL in error;\n}\n\nfunction _isDoNotSendEventError(error) {\n  return !!error && typeof error === 'object' && DO_NOT_SEND_EVENT_SYMBOL in error;\n}\n\n/**\n * Base implementation for all JavaScript SDK clients.\n *\n * Call the constructor with the corresponding options\n * specific to the client subclass. To access these options later, use\n * {@link Client.getOptions}.\n *\n * If a Dsn is specified in the options, it will be parsed and stored. Use\n * {@link Client.getDsn} to retrieve the Dsn at any moment. In case the Dsn is\n * invalid, the constructor will throw a {@link SentryException}. Note that\n * without a valid Dsn, the SDK will not send any events to Sentry.\n *\n * Before sending an event, it is passed through\n * {@link Client._prepareEvent} to add SDK information and scope data\n * (breadcrumbs and context). To add more custom information, override this\n * method and extend the resulting prepared event.\n *\n * To issue automatically created events (e.g. via instrumentation), use\n * {@link Client.captureEvent}. It will prepare the event and pass it through\n * the callback lifecycle. To issue auto-breadcrumbs, use\n * {@link Client.addBreadcrumb}.\n *\n * @example\n * class NodeClient extends Client<NodeOptions> {\n *   public constructor(options: NodeOptions) {\n *     super(options);\n *   }\n *\n *   // ...\n * }\n */\nclass Client {\n  /** Options passed to the SDK. */\n\n  /** The client Dsn, if specified in options. Without this Dsn, the SDK will be disabled. */\n\n  /** Array of set up integrations. */\n\n  /** Number of calls being processed */\n\n  /** Holds flushable  */\n\n  // eslint-disable-next-line @typescript-eslint/ban-types\n\n  /**\n   * Initializes this client instance.\n   *\n   * @param options Options for the client.\n   */\n   constructor(options) {\n    this._options = options;\n    this._integrations = {};\n    this._numProcessing = 0;\n    this._outcomes = {};\n    this._hooks = {};\n    this._eventProcessors = [];\n\n    if (options.dsn) {\n      this._dsn = dsn.makeDsn(options.dsn);\n    } else {\n      debugBuild.DEBUG_BUILD && debugLogger.debug.warn('No DSN provided, client will not send events.');\n    }\n\n    if (this._dsn) {\n      const url = api.getEnvelopeEndpointWithUrlEncodedAuth(\n        this._dsn,\n        options.tunnel,\n        options._metadata ? options._metadata.sdk : undefined,\n      );\n      this._transport = options.transport({\n        tunnel: this._options.tunnel,\n        recordDroppedEvent: this.recordDroppedEvent.bind(this),\n        ...options.transportOptions,\n        url,\n      });\n    }\n  }\n\n  /**\n   * Captures an exception event and sends it to Sentry.\n   *\n   * Unlike `captureException` exported from every SDK, this method requires that you pass it the current scope.\n   */\n   captureException(exception, hint, scope) {\n    const eventId = misc.uuid4();\n\n    // ensure we haven't captured this very object before\n    if (misc.checkOrSetAlreadyCaught(exception)) {\n      debugBuild.DEBUG_BUILD && debugLogger.debug.log(ALREADY_SEEN_ERROR);\n      return eventId;\n    }\n\n    const hintWithEventId = {\n      event_id: eventId,\n      ...hint,\n    };\n\n    this._process(\n      this.eventFromException(exception, hintWithEventId).then(event =>\n        this._captureEvent(event, hintWithEventId, scope),\n      ),\n    );\n\n    return hintWithEventId.event_id;\n  }\n\n  /**\n   * Captures a message event and sends it to Sentry.\n   *\n   * Unlike `captureMessage` exported from every SDK, this method requires that you pass it the current scope.\n   */\n   captureMessage(\n    message,\n    level,\n    hint,\n    currentScope,\n  ) {\n    const hintWithEventId = {\n      event_id: misc.uuid4(),\n      ...hint,\n    };\n\n    const eventMessage = is.isParameterizedString(message) ? message : String(message);\n\n    const promisedEvent = is.isPrimitive(message)\n      ? this.eventFromMessage(eventMessage, level, hintWithEventId)\n      : this.eventFromException(message, hintWithEventId);\n\n    this._process(promisedEvent.then(event => this._captureEvent(event, hintWithEventId, currentScope)));\n\n    return hintWithEventId.event_id;\n  }\n\n  /**\n   * Captures a manually created event and sends it to Sentry.\n   *\n   * Unlike `captureEvent` exported from every SDK, this method requires that you pass it the current scope.\n   */\n   captureEvent(event, hint, currentScope) {\n    const eventId = misc.uuid4();\n\n    // ensure we haven't captured this very object before\n    if (hint?.originalException && misc.checkOrSetAlreadyCaught(hint.originalException)) {\n      debugBuild.DEBUG_BUILD && debugLogger.debug.log(ALREADY_SEEN_ERROR);\n      return eventId;\n    }\n\n    const hintWithEventId = {\n      event_id: eventId,\n      ...hint,\n    };\n\n    const sdkProcessingMetadata = event.sdkProcessingMetadata || {};\n    const capturedSpanScope = sdkProcessingMetadata.capturedSpanScope;\n    const capturedSpanIsolationScope = sdkProcessingMetadata.capturedSpanIsolationScope;\n\n    this._process(\n      this._captureEvent(event, hintWithEventId, capturedSpanScope || currentScope, capturedSpanIsolationScope),\n    );\n\n    return hintWithEventId.event_id;\n  }\n\n  /**\n   * Captures a session.\n   */\n   captureSession(session$1) {\n    this.sendSession(session$1);\n    // After sending, we set init false to indicate it's not the first occurrence\n    session.updateSession(session$1, { init: false });\n  }\n\n  /**\n   * Create a cron monitor check in and send it to Sentry. This method is not available on all clients.\n   *\n   * @param checkIn An object that describes a check in.\n   * @param upsertMonitorConfig An optional object that describes a monitor config. Use this if you want\n   * to create a monitor automatically when sending a check in.\n   * @param scope An optional scope containing event metadata.\n   * @returns A string representing the id of the check in.\n   */\n\n  /**\n   * Get the current Dsn.\n   */\n   getDsn() {\n    return this._dsn;\n  }\n\n  /**\n   * Get the current options.\n   */\n   getOptions() {\n    return this._options;\n  }\n\n  /**\n   * Get the SDK metadata.\n   * @see SdkMetadata\n   */\n   getSdkMetadata() {\n    return this._options._metadata;\n  }\n\n  /**\n   * Returns the transport that is used by the client.\n   * Please note that the transport gets lazy initialized so it will only be there once the first event has been sent.\n   */\n   getTransport() {\n    return this._transport;\n  }\n\n  /**\n   * Wait for all events to be sent or the timeout to expire, whichever comes first.\n   *\n   * @param timeout Maximum time in ms the client should wait for events to be flushed. Omitting this parameter will\n   *   cause the client to wait until all events are sent before resolving the promise.\n   * @returns A promise that will resolve with `true` if all events are sent before the timeout, or `false` if there are\n   * still events in the queue when the timeout is reached.\n   */\n   flush(timeout) {\n    const transport = this._transport;\n    if (transport) {\n      this.emit('flush');\n      return this._isClientDoneProcessing(timeout).then(clientFinished => {\n        return transport.flush(timeout).then(transportFlushed => clientFinished && transportFlushed);\n      });\n    } else {\n      return syncpromise.resolvedSyncPromise(true);\n    }\n  }\n\n  /**\n   * Flush the event queue and set the client to `enabled = false`. See {@link Client.flush}.\n   *\n   * @param {number} timeout Maximum time in ms the client should wait before shutting down. Omitting this parameter will cause\n   *   the client to wait until all events are sent before disabling itself.\n   * @returns {Promise<boolean>} A promise which resolves to `true` if the flush completes successfully before the timeout, or `false` if\n   * it doesn't.\n   */\n   close(timeout) {\n    return this.flush(timeout).then(result => {\n      this.getOptions().enabled = false;\n      this.emit('close');\n      return result;\n    });\n  }\n\n  /**\n   * Get all installed event processors.\n   */\n   getEventProcessors() {\n    return this._eventProcessors;\n  }\n\n  /**\n   * Adds an event processor that applies to any event processed by this client.\n   */\n   addEventProcessor(eventProcessor) {\n    this._eventProcessors.push(eventProcessor);\n  }\n\n  /**\n   * Initialize this client.\n   * Call this after the client was set on a scope.\n   */\n   init() {\n    if (\n      this._isEnabled() ||\n      // Force integrations to be setup even if no DSN was set when we have\n      // Spotlight enabled. This is particularly important for browser as we\n      // don't support the `spotlight` option there and rely on the users\n      // adding the `spotlightBrowserIntegration()` to their integrations which\n      // wouldn't get initialized with the check below when there's no DSN set.\n      this._options.integrations.some(({ name }) => name.startsWith('Spotlight'))\n    ) {\n      this._setupIntegrations();\n    }\n  }\n\n  /**\n   * Gets an installed integration by its name.\n   *\n   * @returns {Integration|undefined} The installed integration or `undefined` if no integration with that `name` was installed.\n   */\n   getIntegrationByName(integrationName) {\n    return this._integrations[integrationName] ;\n  }\n\n  /**\n   * Add an integration to the client.\n   * This can be used to e.g. lazy load integrations.\n   * In most cases, this should not be necessary,\n   * and you're better off just passing the integrations via `integrations: []` at initialization time.\n   * However, if you find the need to conditionally load & add an integration, you can use `addIntegration` to do so.\n   */\n   addIntegration(integration$1) {\n    const isAlreadyInstalled = this._integrations[integration$1.name];\n\n    // This hook takes care of only installing if not already installed\n    integration.setupIntegration(this, integration$1, this._integrations);\n    // Here we need to check manually to make sure to not run this multiple times\n    if (!isAlreadyInstalled) {\n      integration.afterSetupIntegrations(this, [integration$1]);\n    }\n  }\n\n  /**\n   * Send a fully prepared event to Sentry.\n   */\n   sendEvent(event, hint = {}) {\n    this.emit('beforeSendEvent', event, hint);\n\n    let env = envelope.createEventEnvelope(event, this._dsn, this._options._metadata, this._options.tunnel);\n\n    for (const attachment of hint.attachments || []) {\n      env = envelope$1.addItemToEnvelope(env, envelope$1.createAttachmentEnvelopeItem(attachment));\n    }\n\n    const promise = this.sendEnvelope(env);\n    if (promise) {\n      promise.then(sendResponse => this.emit('afterSendEvent', event, sendResponse), null);\n    }\n  }\n\n  /**\n   * Send a session or session aggregrates to Sentry.\n   */\n   sendSession(session) {\n    // Backfill release and environment on session\n    const { release: clientReleaseOption, environment: clientEnvironmentOption = constants.DEFAULT_ENVIRONMENT } = this._options;\n    if ('aggregates' in session) {\n      const sessionAttrs = session.attrs || {};\n      if (!sessionAttrs.release && !clientReleaseOption) {\n        debugBuild.DEBUG_BUILD && debugLogger.debug.warn(MISSING_RELEASE_FOR_SESSION_ERROR);\n        return;\n      }\n      sessionAttrs.release = sessionAttrs.release || clientReleaseOption;\n      sessionAttrs.environment = sessionAttrs.environment || clientEnvironmentOption;\n      session.attrs = sessionAttrs;\n    } else {\n      if (!session.release && !clientReleaseOption) {\n        debugBuild.DEBUG_BUILD && debugLogger.debug.warn(MISSING_RELEASE_FOR_SESSION_ERROR);\n        return;\n      }\n      session.release = session.release || clientReleaseOption;\n      session.environment = session.environment || clientEnvironmentOption;\n    }\n\n    this.emit('beforeSendSession', session);\n\n    const env = envelope.createSessionEnvelope(session, this._dsn, this._options._metadata, this._options.tunnel);\n\n    // sendEnvelope should not throw\n    // eslint-disable-next-line @typescript-eslint/no-floating-promises\n    this.sendEnvelope(env);\n  }\n\n  /**\n   * Record on the client that an event got dropped (ie, an event that will not be sent to Sentry).\n   */\n   recordDroppedEvent(reason, category, count = 1) {\n    if (this._options.sendClientReports) {\n      // We want to track each category (error, transaction, session, replay_event) separately\n      // but still keep the distinction between different type of outcomes.\n      // We could use nested maps, but it's much easier to read and type this way.\n      // A correct type for map-based implementation if we want to go that route\n      // would be `Partial<Record<SentryRequestType, Partial<Record<Outcome, number>>>>`\n      // With typescript 4.1 we could even use template literal types\n      const key = `${reason}:${category}`;\n      debugBuild.DEBUG_BUILD && debugLogger.debug.log(`Recording outcome: \"${key}\"${count > 1 ? ` (${count} times)` : ''}`);\n      this._outcomes[key] = (this._outcomes[key] || 0) + count;\n    }\n  }\n\n  /* eslint-disable @typescript-eslint/unified-signatures */\n  /**\n   * Register a callback for whenever a span is started.\n   * Receives the span as argument.\n   * @returns {() => void} A function that, when executed, removes the registered callback.\n   */\n\n  /**\n   * Register a hook on this client.\n   */\n   on(hook, callback) {\n    const hooks = (this._hooks[hook] = this._hooks[hook] || []);\n\n    // @ts-expect-error We assume the types are correct\n    hooks.push(callback);\n\n    // This function returns a callback execution handler that, when invoked,\n    // deregisters a callback. This is crucial for managing instances where callbacks\n    // need to be unregistered to prevent self-referencing in callback closures,\n    // ensuring proper garbage collection.\n    return () => {\n      // @ts-expect-error We assume the types are correct\n      const cbIndex = hooks.indexOf(callback);\n      if (cbIndex > -1) {\n        hooks.splice(cbIndex, 1);\n      }\n    };\n  }\n\n  /** Fire a hook whenever a span starts. */\n\n  /**\n   * Emit a hook that was previously registered via `on()`.\n   */\n   emit(hook, ...rest) {\n    const callbacks = this._hooks[hook];\n    if (callbacks) {\n      callbacks.forEach(callback => callback(...rest));\n    }\n  }\n\n  /**\n   * Send an envelope to Sentry.\n   */\n   sendEnvelope(envelope) {\n    this.emit('beforeEnvelope', envelope);\n\n    if (this._isEnabled() && this._transport) {\n      return this._transport.send(envelope).then(null, reason => {\n        debugBuild.DEBUG_BUILD && debugLogger.debug.error('Error while sending envelope:', reason);\n        return reason;\n      });\n    }\n\n    debugBuild.DEBUG_BUILD && debugLogger.debug.error('Transport disabled');\n\n    return syncpromise.resolvedSyncPromise({});\n  }\n\n  /* eslint-enable @typescript-eslint/unified-signatures */\n\n  /** Setup integrations for this client. */\n   _setupIntegrations() {\n    const { integrations } = this._options;\n    this._integrations = integration.setupIntegrations(this, integrations);\n    integration.afterSetupIntegrations(this, integrations);\n  }\n\n  /** Updates existing session based on the provided event */\n   _updateSessionFromEvent(session$1, event) {\n    let crashed = event.level === 'fatal';\n    let errored = false;\n    const exceptions = event.exception?.values;\n\n    if (exceptions) {\n      errored = true;\n\n      for (const ex of exceptions) {\n        const mechanism = ex.mechanism;\n        if (mechanism?.handled === false) {\n          crashed = true;\n          break;\n        }\n      }\n    }\n\n    // A session is updated and that session update is sent in only one of the two following scenarios:\n    // 1. Session with non terminal status and 0 errors + an error occurred -> Will set error count to 1 and send update\n    // 2. Session with non terminal status and 1 error + a crash occurred -> Will set status crashed and send update\n    const sessionNonTerminal = session$1.status === 'ok';\n    const shouldUpdateAndSend = (sessionNonTerminal && session$1.errors === 0) || (sessionNonTerminal && crashed);\n\n    if (shouldUpdateAndSend) {\n      session.updateSession(session$1, {\n        ...(crashed && { status: 'crashed' }),\n        errors: session$1.errors || Number(errored || crashed),\n      });\n      this.captureSession(session$1);\n    }\n  }\n\n  /**\n   * Determine if the client is finished processing. Returns a promise because it will wait `timeout` ms before saying\n   * \"no\" (resolving to `false`) in order to give the client a chance to potentially finish first.\n   *\n   * @param timeout The time, in ms, after which to resolve to `false` if the client is still busy. Passing `0` (or not\n   * passing anything) will make the promise wait as long as it takes for processing to finish before resolving to\n   * `true`.\n   * @returns A promise which will resolve to `true` if processing is already done or finishes before the timeout, and\n   * `false` otherwise\n   */\n   _isClientDoneProcessing(timeout) {\n    return new syncpromise.SyncPromise(resolve => {\n      let ticked = 0;\n      const tick = 1;\n\n      const interval = setInterval(() => {\n        if (this._numProcessing == 0) {\n          clearInterval(interval);\n          resolve(true);\n        } else {\n          ticked += tick;\n          if (timeout && ticked >= timeout) {\n            clearInterval(interval);\n            resolve(false);\n          }\n        }\n      }, tick);\n    });\n  }\n\n  /** Determines whether this SDK is enabled and a transport is present. */\n   _isEnabled() {\n    return this.getOptions().enabled !== false && this._transport !== undefined;\n  }\n\n  /**\n   * Adds common information to events.\n   *\n   * The information includes release and environment from `options`,\n   * breadcrumbs and context (extra, tags and user) from the scope.\n   *\n   * Information that is already present in the event is never overwritten. For\n   * nested objects, such as the context, keys are merged.\n   *\n   * @param event The original event.\n   * @param hint May contain additional information about the original exception.\n   * @param currentScope A scope containing event metadata.\n   * @returns A new event with more information.\n   */\n   _prepareEvent(\n    event,\n    hint,\n    currentScope,\n    isolationScope,\n  ) {\n    const options = this.getOptions();\n    const integrations = Object.keys(this._integrations);\n    if (!hint.integrations && integrations?.length) {\n      hint.integrations = integrations;\n    }\n\n    this.emit('preprocessEvent', event, hint);\n\n    if (!event.type) {\n      isolationScope.setLastEventId(event.event_id || hint.event_id);\n    }\n\n    return prepareEvent.prepareEvent(options, event, hint, currentScope, this, isolationScope).then(evt => {\n      if (evt === null) {\n        return evt;\n      }\n\n      this.emit('postprocessEvent', evt, hint);\n\n      evt.contexts = {\n        trace: currentScopes.getTraceContextFromScope(currentScope),\n        ...evt.contexts,\n      };\n\n      const dynamicSamplingContext$1 = dynamicSamplingContext.getDynamicSamplingContextFromScope(this, currentScope);\n\n      evt.sdkProcessingMetadata = {\n        dynamicSamplingContext: dynamicSamplingContext$1,\n        ...evt.sdkProcessingMetadata,\n      };\n\n      return evt;\n    });\n  }\n\n  /**\n   * Processes the event and logs an error in case of rejection\n   * @param event\n   * @param hint\n   * @param scope\n   */\n   _captureEvent(\n    event,\n    hint = {},\n    currentScope = currentScopes.getCurrentScope(),\n    isolationScope = currentScopes.getIsolationScope(),\n  ) {\n    if (debugBuild.DEBUG_BUILD && isErrorEvent(event)) {\n      debugLogger.debug.log(`Captured error event \\`${eventUtils.getPossibleEventMessages(event)[0] || '<unknown>'}\\``);\n    }\n\n    return this._processEvent(event, hint, currentScope, isolationScope).then(\n      finalEvent => {\n        return finalEvent.event_id;\n      },\n      reason => {\n        if (debugBuild.DEBUG_BUILD) {\n          if (_isDoNotSendEventError(reason)) {\n            debugLogger.debug.log(reason.message);\n          } else if (_isInternalError(reason)) {\n            debugLogger.debug.warn(reason.message);\n          } else {\n            debugLogger.debug.warn(reason);\n          }\n        }\n        return undefined;\n      },\n    );\n  }\n\n  /**\n   * Processes an event (either error or message) and sends it to Sentry.\n   *\n   * This also adds breadcrumbs and context information to the event. However,\n   * platform specific meta data (such as the User's IP address) must be added\n   * by the SDK implementor.\n   *\n   *\n   * @param event The event to send to Sentry.\n   * @param hint May contain additional information about the original exception.\n   * @param currentScope A scope containing event metadata.\n   * @returns A SyncPromise that resolves with the event or rejects in case event was/will not be send.\n   */\n   _processEvent(\n    event,\n    hint,\n    currentScope,\n    isolationScope,\n  ) {\n    const options = this.getOptions();\n    const { sampleRate } = options;\n\n    const isTransaction = isTransactionEvent(event);\n    const isError = isErrorEvent(event);\n    const eventType = event.type || 'error';\n    const beforeSendLabel = `before send for type \\`${eventType}\\``;\n\n    // 1.0 === 100% events are sent\n    // 0.0 === 0% events are sent\n    // Sampling for transaction happens somewhere else\n    const parsedSampleRate = typeof sampleRate === 'undefined' ? undefined : parseSampleRate.parseSampleRate(sampleRate);\n    if (isError && typeof parsedSampleRate === 'number' && Math.random() > parsedSampleRate) {\n      this.recordDroppedEvent('sample_rate', 'error');\n      return syncpromise.rejectedSyncPromise(\n        _makeDoNotSendEventError(\n          `Discarding event because it's not included in the random sample (sampling rate = ${sampleRate})`,\n        ),\n      );\n    }\n\n    const dataCategory = (eventType === 'replay_event' ? 'replay' : eventType) ;\n\n    return this._prepareEvent(event, hint, currentScope, isolationScope)\n      .then(prepared => {\n        if (prepared === null) {\n          this.recordDroppedEvent('event_processor', dataCategory);\n          throw _makeDoNotSendEventError('An event processor returned `null`, will not send event.');\n        }\n\n        const isInternalException = hint.data && (hint.data ).__sentry__ === true;\n        if (isInternalException) {\n          return prepared;\n        }\n\n        const result = processBeforeSend(this, options, prepared, hint);\n        return _validateBeforeSendResult(result, beforeSendLabel);\n      })\n      .then(processedEvent => {\n        if (processedEvent === null) {\n          this.recordDroppedEvent('before_send', dataCategory);\n          if (isTransaction) {\n            const spans = event.spans || [];\n            // the transaction itself counts as one span, plus all the child spans that are added\n            const spanCount = 1 + spans.length;\n            this.recordDroppedEvent('before_send', 'span', spanCount);\n          }\n          throw _makeDoNotSendEventError(`${beforeSendLabel} returned \\`null\\`, will not send event.`);\n        }\n\n        const session = currentScope.getSession() || isolationScope.getSession();\n        if (isError && session) {\n          this._updateSessionFromEvent(session, processedEvent);\n        }\n\n        if (isTransaction) {\n          const spanCountBefore = processedEvent.sdkProcessingMetadata?.spanCountBeforeProcessing || 0;\n          const spanCountAfter = processedEvent.spans ? processedEvent.spans.length : 0;\n\n          const droppedSpanCount = spanCountBefore - spanCountAfter;\n          if (droppedSpanCount > 0) {\n            this.recordDroppedEvent('before_send', 'span', droppedSpanCount);\n          }\n        }\n\n        // None of the Sentry built event processor will update transaction name,\n        // so if the transaction name has been changed by an event processor, we know\n        // it has to come from custom event processor added by a user\n        const transactionInfo = processedEvent.transaction_info;\n        if (isTransaction && transactionInfo && processedEvent.transaction !== event.transaction) {\n          const source = 'custom';\n          processedEvent.transaction_info = {\n            ...transactionInfo,\n            source,\n          };\n        }\n\n        this.sendEvent(processedEvent, hint);\n        return processedEvent;\n      })\n      .then(null, reason => {\n        if (_isDoNotSendEventError(reason) || _isInternalError(reason)) {\n          throw reason;\n        }\n\n        this.captureException(reason, {\n          data: {\n            __sentry__: true,\n          },\n          originalException: reason,\n        });\n        throw _makeInternalError(\n          `Event processing pipeline threw an error, original event will not be sent. Details have been sent as a new event.\\nReason: ${reason}`,\n        );\n      });\n  }\n\n  /**\n   * Occupies the client with processing and event\n   */\n   _process(promise) {\n    this._numProcessing++;\n    void promise.then(\n      value => {\n        this._numProcessing--;\n        return value;\n      },\n      reason => {\n        this._numProcessing--;\n        return reason;\n      },\n    );\n  }\n\n  /**\n   * Clears outcomes on this client and returns them.\n   */\n   _clearOutcomes() {\n    const outcomes = this._outcomes;\n    this._outcomes = {};\n    return Object.entries(outcomes).map(([key, quantity]) => {\n      const [reason, category] = key.split(':') ;\n      return {\n        reason,\n        category,\n        quantity,\n      };\n    });\n  }\n\n  /**\n   * Sends client reports as an envelope.\n   */\n   _flushOutcomes() {\n    debugBuild.DEBUG_BUILD && debugLogger.debug.log('Flushing outcomes...');\n\n    const outcomes = this._clearOutcomes();\n\n    if (outcomes.length === 0) {\n      debugBuild.DEBUG_BUILD && debugLogger.debug.log('No outcomes to send');\n      return;\n    }\n\n    // This is really the only place where we want to check for a DSN and only send outcomes then\n    if (!this._dsn) {\n      debugBuild.DEBUG_BUILD && debugLogger.debug.log('No dsn provided, will not send outcomes');\n      return;\n    }\n\n    debugBuild.DEBUG_BUILD && debugLogger.debug.log('Sending outcomes:', outcomes);\n\n    const envelope = clientreport.createClientReportEnvelope(outcomes, this._options.tunnel && dsn.dsnToString(this._dsn));\n\n    // sendEnvelope should not throw\n    // eslint-disable-next-line @typescript-eslint/no-floating-promises\n    this.sendEnvelope(envelope);\n  }\n\n  /**\n   * Creates an {@link Event} from all inputs to `captureException` and non-primitive inputs to `captureMessage`.\n   */\n\n}\n\n/**\n * @deprecated Use `Client` instead. This alias may be removed in a future major version.\n */\n// TODO(v10): Remove\n\n/**\n * @deprecated Use `Client` instead. This alias may be removed in a future major version.\n */\n// TODO(v10): Remove\nconst BaseClient = Client;\n\n/**\n * Verifies that return value of configured `beforeSend` or `beforeSendTransaction` is of expected type, and returns the value if so.\n */\nfunction _validateBeforeSendResult(\n  beforeSendResult,\n  beforeSendLabel,\n) {\n  const invalidValueError = `${beforeSendLabel} must return \\`null\\` or a valid event.`;\n  if (is.isThenable(beforeSendResult)) {\n    return beforeSendResult.then(\n      event => {\n        if (!is.isPlainObject(event) && event !== null) {\n          throw _makeInternalError(invalidValueError);\n        }\n        return event;\n      },\n      e => {\n        throw _makeInternalError(`${beforeSendLabel} rejected with ${e}`);\n      },\n    );\n  } else if (!is.isPlainObject(beforeSendResult) && beforeSendResult !== null) {\n    throw _makeInternalError(invalidValueError);\n  }\n  return beforeSendResult;\n}\n\n/**\n * Process the matching `beforeSendXXX` callback.\n */\nfunction processBeforeSend(\n  client,\n  options,\n  event,\n  hint,\n) {\n  const { beforeSend, beforeSendTransaction, beforeSendSpan } = options;\n  let processedEvent = event;\n\n  if (isErrorEvent(processedEvent) && beforeSend) {\n    return beforeSend(processedEvent, hint);\n  }\n\n  if (isTransactionEvent(processedEvent)) {\n    if (beforeSendSpan) {\n      // process root span\n      const processedRootSpanJson = beforeSendSpan(transactionEvent.convertTransactionEventToSpanJson(processedEvent));\n      if (!processedRootSpanJson) {\n        spanUtils.showSpanDropWarning();\n      } else {\n        // update event with processed root span values\n        processedEvent = merge.merge(event, transactionEvent.convertSpanJsonToTransactionEvent(processedRootSpanJson));\n      }\n\n      // process child spans\n      if (processedEvent.spans) {\n        const processedSpans = [];\n        for (const span of processedEvent.spans) {\n          const processedSpan = beforeSendSpan(span);\n          if (!processedSpan) {\n            spanUtils.showSpanDropWarning();\n            processedSpans.push(span);\n          } else {\n            processedSpans.push(processedSpan);\n          }\n        }\n        processedEvent.spans = processedSpans;\n      }\n    }\n\n    if (beforeSendTransaction) {\n      if (processedEvent.spans) {\n        // We store the # of spans before processing in SDK metadata,\n        // so we can compare it afterwards to determine how many spans were dropped\n        const spanCountBefore = processedEvent.spans.length;\n        processedEvent.sdkProcessingMetadata = {\n          ...event.sdkProcessingMetadata,\n          spanCountBeforeProcessing: spanCountBefore,\n        };\n      }\n      return beforeSendTransaction(processedEvent , hint);\n    }\n  }\n\n  return processedEvent;\n}\n\nfunction isErrorEvent(event) {\n  return event.type === undefined;\n}\n\nfunction isTransactionEvent(event) {\n  return event.type === 'transaction';\n}\n\n/** Extract trace information from scope */\nfunction _getTraceInfoFromScope(\n  client,\n  scope,\n) {\n  if (!scope) {\n    return [undefined, undefined];\n  }\n\n  return currentScopes.withScope(scope, () => {\n    const span = spanUtils.getActiveSpan();\n    const traceContext = span ? spanUtils.spanToTraceContext(span) : currentScopes.getTraceContextFromScope(scope);\n    const dynamicSamplingContext$1 = span\n      ? dynamicSamplingContext.getDynamicSamplingContextFromSpan(span)\n      : dynamicSamplingContext.getDynamicSamplingContextFromScope(client, scope);\n    return [dynamicSamplingContext$1, traceContext];\n  });\n}\n\nexports.BaseClient = BaseClient;\nexports.Client = Client;\nexports._getTraceInfoFromScope = _getTraceInfoFromScope;\n//# sourceMappingURL=client.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9jbGllbnQuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsWUFBWSxtQkFBTyxDQUFDLDJHQUFVO0FBQzlCLGtCQUFrQixtQkFBTyxDQUFDLHVIQUFnQjtBQUMxQyxzQkFBc0IsbUJBQU8sQ0FBQywrSEFBb0I7QUFDbEQsbUJBQW1CLG1CQUFPLENBQUMsMkhBQWtCO0FBQzdDLGlCQUFpQixtQkFBTyxDQUFDLHFIQUFlO0FBQ3hDLG9CQUFvQixtQkFBTyxDQUFDLDJIQUFrQjtBQUM5QyxnQkFBZ0IsbUJBQU8sQ0FBQyxtSEFBYztBQUN0QywrQkFBK0IsbUJBQU8sQ0FBQyxpS0FBcUM7QUFDNUUscUJBQXFCLG1CQUFPLENBQUMseUlBQXlCO0FBQ3RELG9CQUFvQixtQkFBTyxDQUFDLHlJQUF5QjtBQUNyRCxZQUFZLG1CQUFPLENBQUMsdUhBQWdCO0FBQ3BDLG1CQUFtQixtQkFBTyxDQUFDLGlJQUFxQjtBQUNoRCxtQkFBbUIsbUJBQU8sQ0FBQyxxSUFBdUI7QUFDbEQsV0FBVyxtQkFBTyxDQUFDLHFIQUFlO0FBQ2xDLGNBQWMsbUJBQU8sQ0FBQywySEFBa0I7QUFDeEMsYUFBYSxtQkFBTyxDQUFDLHlIQUFpQjtBQUN0Qyx3QkFBd0IsbUJBQU8sQ0FBQywrSUFBNEI7QUFDNUQscUJBQXFCLG1CQUFPLENBQUMseUlBQXlCO0FBQ3RELGtCQUFrQixtQkFBTyxDQUFDLG1JQUFzQjtBQUNoRCxvQkFBb0IsbUJBQU8sQ0FBQyx1SUFBd0I7QUFDcEQseUJBQXlCLG1CQUFPLENBQUMsaUpBQTZCOztBQUU5RDs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxJQUFJLHdCQUF3QjtBQUM1QjtBQUNBO0FBQ0EsSUFBSSxxQkFBcUI7QUFDekIsMENBQTBDLHNCQUFzQjtBQUNoRTtBQUNBO0FBQ0E7QUFDQSxJQUFJLDRCQUE0QjtBQUNoQztBQUNBO0FBQ0E7QUFDQTtBQUNBLElBQUksMEJBQTBCO0FBQzlCO0FBQ0EsSUFBSSwyQkFBMkI7QUFDL0I7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBOztBQUVBOztBQUVBOztBQUVBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsTUFBTTtBQUNOO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLE9BQU87QUFDUDtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSx1Q0FBdUMsYUFBYTtBQUNwRDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsT0FBTztBQUNQLE1BQU07QUFDTjtBQUNBO0FBQ0E7O0FBRUE7QUFDQSx5RUFBeUUsbUJBQW1CO0FBQzVGO0FBQ0EsYUFBYSxRQUFRO0FBQ3JCO0FBQ0EsZUFBZSxrQkFBa0I7QUFDakM7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxLQUFLO0FBQ0w7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSx5Q0FBeUMsTUFBTTtBQUMvQztBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQSxlQUFlLHVCQUF1QjtBQUN0QztBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0EsNkJBQTZCO0FBQzdCOztBQUVBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxZQUFZLHFHQUFxRztBQUNqSDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxNQUFNO0FBQ047QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLHFCQUFxQixPQUFPLEdBQUcsU0FBUztBQUN4Qyw2RUFBNkUsSUFBSSxHQUFHLGlCQUFpQixPQUFPLGFBQWE7QUFDekg7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsZUFBZSxZQUFZO0FBQzNCOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQSxPQUFPO0FBQ1A7O0FBRUE7O0FBRUEsNkNBQTZDO0FBQzdDOztBQUVBOztBQUVBO0FBQ0E7QUFDQSxZQUFZLGVBQWU7QUFDM0I7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLHlCQUF5QixtQkFBbUI7QUFDNUM7QUFDQSxPQUFPO0FBQ1A7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQSxVQUFVO0FBQ1Y7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsT0FBTztBQUNQLEtBQUs7QUFDTDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQSxLQUFLO0FBQ0w7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGFBQWE7QUFDYjtBQUNBO0FBQ0E7QUFDQTtBQUNBLHNEQUFzRCw2REFBNkQ7QUFDbkg7O0FBRUE7QUFDQTtBQUNBO0FBQ0EsT0FBTztBQUNQO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsWUFBWTtBQUNaO0FBQ0EsWUFBWTtBQUNaO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsT0FBTztBQUNQO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFlBQVksYUFBYTs7QUFFekI7QUFDQTtBQUNBO0FBQ0Esc0RBQXNELFVBQVU7O0FBRWhFO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSw4RkFBOEYsV0FBVztBQUN6RztBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQSxPQUFPO0FBQ1A7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsNENBQTRDLGlCQUFpQjtBQUM3RDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQSxPQUFPO0FBQ1A7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0EsV0FBVztBQUNYO0FBQ0EsU0FBUztBQUNUO0FBQ0Esd0lBQXdJLE9BQU87QUFDL0k7QUFDQSxPQUFPO0FBQ1A7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsT0FBTztBQUNQO0FBQ0E7QUFDQTtBQUNBLE9BQU87QUFDUDtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsS0FBSztBQUNMOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBLGlCQUFpQixhQUFhO0FBQzlCOztBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSwrQkFBK0IsaUJBQWlCO0FBQ2hEO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsT0FBTztBQUNQO0FBQ0Esb0NBQW9DLGlCQUFpQixnQkFBZ0IsRUFBRTtBQUN2RSxPQUFPO0FBQ1A7QUFDQSxJQUFJO0FBQ0o7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsVUFBVSxvREFBb0Q7QUFDOUQ7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFFBQVE7QUFDUjtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFlBQVk7QUFDWjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxHQUFHO0FBQ0g7O0FBRUEsa0JBQWtCO0FBQ2xCLGNBQWM7QUFDZCw4QkFBOEI7QUFDOUIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9jbGllbnQuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGFwaSA9IHJlcXVpcmUoJy4vYXBpLmpzJyk7XG5jb25zdCBjb25zdGFudHMgPSByZXF1aXJlKCcuL2NvbnN0YW50cy5qcycpO1xuY29uc3QgY3VycmVudFNjb3BlcyA9IHJlcXVpcmUoJy4vY3VycmVudFNjb3Blcy5qcycpO1xuY29uc3QgZGVidWdCdWlsZCA9IHJlcXVpcmUoJy4vZGVidWctYnVpbGQuanMnKTtcbmNvbnN0IGVudmVsb3BlID0gcmVxdWlyZSgnLi9lbnZlbG9wZS5qcycpO1xuY29uc3QgaW50ZWdyYXRpb24gPSByZXF1aXJlKCcuL2ludGVncmF0aW9uLmpzJyk7XG5jb25zdCBzZXNzaW9uID0gcmVxdWlyZSgnLi9zZXNzaW9uLmpzJyk7XG5jb25zdCBkeW5hbWljU2FtcGxpbmdDb250ZXh0ID0gcmVxdWlyZSgnLi90cmFjaW5nL2R5bmFtaWNTYW1wbGluZ0NvbnRleHQuanMnKTtcbmNvbnN0IGNsaWVudHJlcG9ydCA9IHJlcXVpcmUoJy4vdXRpbHMvY2xpZW50cmVwb3J0LmpzJyk7XG5jb25zdCBkZWJ1Z0xvZ2dlciA9IHJlcXVpcmUoJy4vdXRpbHMvZGVidWctbG9nZ2VyLmpzJyk7XG5jb25zdCBkc24gPSByZXF1aXJlKCcuL3V0aWxzL2Rzbi5qcycpO1xuY29uc3QgZW52ZWxvcGUkMSA9IHJlcXVpcmUoJy4vdXRpbHMvZW52ZWxvcGUuanMnKTtcbmNvbnN0IGV2ZW50VXRpbHMgPSByZXF1aXJlKCcuL3V0aWxzL2V2ZW50VXRpbHMuanMnKTtcbmNvbnN0IGlzID0gcmVxdWlyZSgnLi91dGlscy9pcy5qcycpO1xuY29uc3QgbWVyZ2UgPSByZXF1aXJlKCcuL3V0aWxzL21lcmdlLmpzJyk7XG5jb25zdCBtaXNjID0gcmVxdWlyZSgnLi91dGlscy9taXNjLmpzJyk7XG5jb25zdCBwYXJzZVNhbXBsZVJhdGUgPSByZXF1aXJlKCcuL3V0aWxzL3BhcnNlU2FtcGxlUmF0ZS5qcycpO1xuY29uc3QgcHJlcGFyZUV2ZW50ID0gcmVxdWlyZSgnLi91dGlscy9wcmVwYXJlRXZlbnQuanMnKTtcbmNvbnN0IHNwYW5VdGlscyA9IHJlcXVpcmUoJy4vdXRpbHMvc3BhblV0aWxzLmpzJyk7XG5jb25zdCBzeW5jcHJvbWlzZSA9IHJlcXVpcmUoJy4vdXRpbHMvc3luY3Byb21pc2UuanMnKTtcbmNvbnN0IHRyYW5zYWN0aW9uRXZlbnQgPSByZXF1aXJlKCcuL3V0aWxzL3RyYW5zYWN0aW9uRXZlbnQuanMnKTtcblxuLyogZXNsaW50LWRpc2FibGUgbWF4LWxpbmVzICovXG5cbmNvbnN0IEFMUkVBRFlfU0VFTl9FUlJPUiA9IFwiTm90IGNhcHR1cmluZyBleGNlcHRpb24gYmVjYXVzZSBpdCdzIGFscmVhZHkgYmVlbiBjYXB0dXJlZC5cIjtcbmNvbnN0IE1JU1NJTkdfUkVMRUFTRV9GT1JfU0VTU0lPTl9FUlJPUiA9ICdEaXNjYXJkZWQgc2Vzc2lvbiBiZWNhdXNlIG9mIG1pc3Npbmcgb3Igbm9uLXN0cmluZyByZWxlYXNlJztcblxuY29uc3QgSU5URVJOQUxfRVJST1JfU1lNQk9MID0gU3ltYm9sLmZvcignU2VudHJ5SW50ZXJuYWxFcnJvcicpO1xuY29uc3QgRE9fTk9UX1NFTkRfRVZFTlRfU1lNQk9MID0gU3ltYm9sLmZvcignU2VudHJ5RG9Ob3RTZW5kRXZlbnRFcnJvcicpO1xuXG5mdW5jdGlvbiBfbWFrZUludGVybmFsRXJyb3IobWVzc2FnZSkge1xuICByZXR1cm4ge1xuICAgIG1lc3NhZ2UsXG4gICAgW0lOVEVSTkFMX0VSUk9SX1NZTUJPTF06IHRydWUsXG4gIH07XG59XG5cbmZ1bmN0aW9uIF9tYWtlRG9Ob3RTZW5kRXZlbnRFcnJvcihtZXNzYWdlKSB7XG4gIHJldHVybiB7XG4gICAgbWVzc2FnZSxcbiAgICBbRE9fTk9UX1NFTkRfRVZFTlRfU1lNQk9MXTogdHJ1ZSxcbiAgfTtcbn1cblxuZnVuY3Rpb24gX2lzSW50ZXJuYWxFcnJvcihlcnJvcikge1xuICByZXR1cm4gISFlcnJvciAmJiB0eXBlb2YgZXJyb3IgPT09ICdvYmplY3QnICYmIElOVEVSTkFMX0VSUk9SX1NZTUJPTCBpbiBlcnJvcjtcbn1cblxuZnVuY3Rpb24gX2lzRG9Ob3RTZW5kRXZlbnRFcnJvcihlcnJvcikge1xuICByZXR1cm4gISFlcnJvciAmJiB0eXBlb2YgZXJyb3IgPT09ICdvYmplY3QnICYmIERPX05PVF9TRU5EX0VWRU5UX1NZTUJPTCBpbiBlcnJvcjtcbn1cblxuLyoqXG4gKiBCYXNlIGltcGxlbWVudGF0aW9uIGZvciBhbGwgSmF2YVNjcmlwdCBTREsgY2xpZW50cy5cbiAqXG4gKiBDYWxsIHRoZSBjb25zdHJ1Y3RvciB3aXRoIHRoZSBjb3JyZXNwb25kaW5nIG9wdGlvbnNcbiAqIHNwZWNpZmljIHRvIHRoZSBjbGllbnQgc3ViY2xhc3MuIFRvIGFjY2VzcyB0aGVzZSBvcHRpb25zIGxhdGVyLCB1c2VcbiAqIHtAbGluayBDbGllbnQuZ2V0T3B0aW9uc30uXG4gKlxuICogSWYgYSBEc24gaXMgc3BlY2lmaWVkIGluIHRoZSBvcHRpb25zLCBpdCB3aWxsIGJlIHBhcnNlZCBhbmQgc3RvcmVkLiBVc2VcbiAqIHtAbGluayBDbGllbnQuZ2V0RHNufSB0byByZXRyaWV2ZSB0aGUgRHNuIGF0IGFueSBtb21lbnQuIEluIGNhc2UgdGhlIERzbiBpc1xuICogaW52YWxpZCwgdGhlIGNvbnN0cnVjdG9yIHdpbGwgdGhyb3cgYSB7QGxpbmsgU2VudHJ5RXhjZXB0aW9ufS4gTm90ZSB0aGF0XG4gKiB3aXRob3V0IGEgdmFsaWQgRHNuLCB0aGUgU0RLIHdpbGwgbm90IHNlbmQgYW55IGV2ZW50cyB0byBTZW50cnkuXG4gKlxuICogQmVmb3JlIHNlbmRpbmcgYW4gZXZlbnQsIGl0IGlzIHBhc3NlZCB0aHJvdWdoXG4gKiB7QGxpbmsgQ2xpZW50Ll9wcmVwYXJlRXZlbnR9IHRvIGFkZCBTREsgaW5mb3JtYXRpb24gYW5kIHNjb3BlIGRhdGFcbiAqIChicmVhZGNydW1icyBhbmQgY29udGV4dCkuIFRvIGFkZCBtb3JlIGN1c3RvbSBpbmZvcm1hdGlvbiwgb3ZlcnJpZGUgdGhpc1xuICogbWV0aG9kIGFuZCBleHRlbmQgdGhlIHJlc3VsdGluZyBwcmVwYXJlZCBldmVudC5cbiAqXG4gKiBUbyBpc3N1ZSBhdXRvbWF0aWNhbGx5IGNyZWF0ZWQgZXZlbnRzIChlLmcuIHZpYSBpbnN0cnVtZW50YXRpb24pLCB1c2VcbiAqIHtAbGluayBDbGllbnQuY2FwdHVyZUV2ZW50fS4gSXQgd2lsbCBwcmVwYXJlIHRoZSBldmVudCBhbmQgcGFzcyBpdCB0aHJvdWdoXG4gKiB0aGUgY2FsbGJhY2sgbGlmZWN5Y2xlLiBUbyBpc3N1ZSBhdXRvLWJyZWFkY3J1bWJzLCB1c2VcbiAqIHtAbGluayBDbGllbnQuYWRkQnJlYWRjcnVtYn0uXG4gKlxuICogQGV4YW1wbGVcbiAqIGNsYXNzIE5vZGVDbGllbnQgZXh0ZW5kcyBDbGllbnQ8Tm9kZU9wdGlvbnM+IHtcbiAqICAgcHVibGljIGNvbnN0cnVjdG9yKG9wdGlvbnM6IE5vZGVPcHRpb25zKSB7XG4gKiAgICAgc3VwZXIob3B0aW9ucyk7XG4gKiAgIH1cbiAqXG4gKiAgIC8vIC4uLlxuICogfVxuICovXG5jbGFzcyBDbGllbnQge1xuICAvKiogT3B0aW9ucyBwYXNzZWQgdG8gdGhlIFNESy4gKi9cblxuICAvKiogVGhlIGNsaWVudCBEc24sIGlmIHNwZWNpZmllZCBpbiBvcHRpb25zLiBXaXRob3V0IHRoaXMgRHNuLCB0aGUgU0RLIHdpbGwgYmUgZGlzYWJsZWQuICovXG5cbiAgLyoqIEFycmF5IG9mIHNldCB1cCBpbnRlZ3JhdGlvbnMuICovXG5cbiAgLyoqIE51bWJlciBvZiBjYWxscyBiZWluZyBwcm9jZXNzZWQgKi9cblxuICAvKiogSG9sZHMgZmx1c2hhYmxlICAqL1xuXG4gIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvYmFuLXR5cGVzXG5cbiAgLyoqXG4gICAqIEluaXRpYWxpemVzIHRoaXMgY2xpZW50IGluc3RhbmNlLlxuICAgKlxuICAgKiBAcGFyYW0gb3B0aW9ucyBPcHRpb25zIGZvciB0aGUgY2xpZW50LlxuICAgKi9cbiAgIGNvbnN0cnVjdG9yKG9wdGlvbnMpIHtcbiAgICB0aGlzLl9vcHRpb25zID0gb3B0aW9ucztcbiAgICB0aGlzLl9pbnRlZ3JhdGlvbnMgPSB7fTtcbiAgICB0aGlzLl9udW1Qcm9jZXNzaW5nID0gMDtcbiAgICB0aGlzLl9vdXRjb21lcyA9IHt9O1xuICAgIHRoaXMuX2hvb2tzID0ge307XG4gICAgdGhpcy5fZXZlbnRQcm9jZXNzb3JzID0gW107XG5cbiAgICBpZiAob3B0aW9ucy5kc24pIHtcbiAgICAgIHRoaXMuX2RzbiA9IGRzbi5tYWtlRHNuKG9wdGlvbnMuZHNuKTtcbiAgICB9IGVsc2Uge1xuICAgICAgZGVidWdCdWlsZC5ERUJVR19CVUlMRCAmJiBkZWJ1Z0xvZ2dlci5kZWJ1Zy53YXJuKCdObyBEU04gcHJvdmlkZWQsIGNsaWVudCB3aWxsIG5vdCBzZW5kIGV2ZW50cy4nKTtcbiAgICB9XG5cbiAgICBpZiAodGhpcy5fZHNuKSB7XG4gICAgICBjb25zdCB1cmwgPSBhcGkuZ2V0RW52ZWxvcGVFbmRwb2ludFdpdGhVcmxFbmNvZGVkQXV0aChcbiAgICAgICAgdGhpcy5fZHNuLFxuICAgICAgICBvcHRpb25zLnR1bm5lbCxcbiAgICAgICAgb3B0aW9ucy5fbWV0YWRhdGEgPyBvcHRpb25zLl9tZXRhZGF0YS5zZGsgOiB1bmRlZmluZWQsXG4gICAgICApO1xuICAgICAgdGhpcy5fdHJhbnNwb3J0ID0gb3B0aW9ucy50cmFuc3BvcnQoe1xuICAgICAgICB0dW5uZWw6IHRoaXMuX29wdGlvbnMudHVubmVsLFxuICAgICAgICByZWNvcmREcm9wcGVkRXZlbnQ6IHRoaXMucmVjb3JkRHJvcHBlZEV2ZW50LmJpbmQodGhpcyksXG4gICAgICAgIC4uLm9wdGlvbnMudHJhbnNwb3J0T3B0aW9ucyxcbiAgICAgICAgdXJsLFxuICAgICAgfSk7XG4gICAgfVxuICB9XG5cbiAgLyoqXG4gICAqIENhcHR1cmVzIGFuIGV4Y2VwdGlvbiBldmVudCBhbmQgc2VuZHMgaXQgdG8gU2VudHJ5LlxuICAgKlxuICAgKiBVbmxpa2UgYGNhcHR1cmVFeGNlcHRpb25gIGV4cG9ydGVkIGZyb20gZXZlcnkgU0RLLCB0aGlzIG1ldGhvZCByZXF1aXJlcyB0aGF0IHlvdSBwYXNzIGl0IHRoZSBjdXJyZW50IHNjb3BlLlxuICAgKi9cbiAgIGNhcHR1cmVFeGNlcHRpb24oZXhjZXB0aW9uLCBoaW50LCBzY29wZSkge1xuICAgIGNvbnN0IGV2ZW50SWQgPSBtaXNjLnV1aWQ0KCk7XG5cbiAgICAvLyBlbnN1cmUgd2UgaGF2ZW4ndCBjYXB0dXJlZCB0aGlzIHZlcnkgb2JqZWN0IGJlZm9yZVxuICAgIGlmIChtaXNjLmNoZWNrT3JTZXRBbHJlYWR5Q2F1Z2h0KGV4Y2VwdGlvbikpIHtcbiAgICAgIGRlYnVnQnVpbGQuREVCVUdfQlVJTEQgJiYgZGVidWdMb2dnZXIuZGVidWcubG9nKEFMUkVBRFlfU0VFTl9FUlJPUik7XG4gICAgICByZXR1cm4gZXZlbnRJZDtcbiAgICB9XG5cbiAgICBjb25zdCBoaW50V2l0aEV2ZW50SWQgPSB7XG4gICAgICBldmVudF9pZDogZXZlbnRJZCxcbiAgICAgIC4uLmhpbnQsXG4gICAgfTtcblxuICAgIHRoaXMuX3Byb2Nlc3MoXG4gICAgICB0aGlzLmV2ZW50RnJvbUV4Y2VwdGlvbihleGNlcHRpb24sIGhpbnRXaXRoRXZlbnRJZCkudGhlbihldmVudCA9PlxuICAgICAgICB0aGlzLl9jYXB0dXJlRXZlbnQoZXZlbnQsIGhpbnRXaXRoRXZlbnRJZCwgc2NvcGUpLFxuICAgICAgKSxcbiAgICApO1xuXG4gICAgcmV0dXJuIGhpbnRXaXRoRXZlbnRJZC5ldmVudF9pZDtcbiAgfVxuXG4gIC8qKlxuICAgKiBDYXB0dXJlcyBhIG1lc3NhZ2UgZXZlbnQgYW5kIHNlbmRzIGl0IHRvIFNlbnRyeS5cbiAgICpcbiAgICogVW5saWtlIGBjYXB0dXJlTWVzc2FnZWAgZXhwb3J0ZWQgZnJvbSBldmVyeSBTREssIHRoaXMgbWV0aG9kIHJlcXVpcmVzIHRoYXQgeW91IHBhc3MgaXQgdGhlIGN1cnJlbnQgc2NvcGUuXG4gICAqL1xuICAgY2FwdHVyZU1lc3NhZ2UoXG4gICAgbWVzc2FnZSxcbiAgICBsZXZlbCxcbiAgICBoaW50LFxuICAgIGN1cnJlbnRTY29wZSxcbiAgKSB7XG4gICAgY29uc3QgaGludFdpdGhFdmVudElkID0ge1xuICAgICAgZXZlbnRfaWQ6IG1pc2MudXVpZDQoKSxcbiAgICAgIC4uLmhpbnQsXG4gICAgfTtcblxuICAgIGNvbnN0IGV2ZW50TWVzc2FnZSA9IGlzLmlzUGFyYW1ldGVyaXplZFN0cmluZyhtZXNzYWdlKSA/IG1lc3NhZ2UgOiBTdHJpbmcobWVzc2FnZSk7XG5cbiAgICBjb25zdCBwcm9taXNlZEV2ZW50ID0gaXMuaXNQcmltaXRpdmUobWVzc2FnZSlcbiAgICAgID8gdGhpcy5ldmVudEZyb21NZXNzYWdlKGV2ZW50TWVzc2FnZSwgbGV2ZWwsIGhpbnRXaXRoRXZlbnRJZClcbiAgICAgIDogdGhpcy5ldmVudEZyb21FeGNlcHRpb24obWVzc2FnZSwgaGludFdpdGhFdmVudElkKTtcblxuICAgIHRoaXMuX3Byb2Nlc3MocHJvbWlzZWRFdmVudC50aGVuKGV2ZW50ID0+IHRoaXMuX2NhcHR1cmVFdmVudChldmVudCwgaGludFdpdGhFdmVudElkLCBjdXJyZW50U2NvcGUpKSk7XG5cbiAgICByZXR1cm4gaGludFdpdGhFdmVudElkLmV2ZW50X2lkO1xuICB9XG5cbiAgLyoqXG4gICAqIENhcHR1cmVzIGEgbWFudWFsbHkgY3JlYXRlZCBldmVudCBhbmQgc2VuZHMgaXQgdG8gU2VudHJ5LlxuICAgKlxuICAgKiBVbmxpa2UgYGNhcHR1cmVFdmVudGAgZXhwb3J0ZWQgZnJvbSBldmVyeSBTREssIHRoaXMgbWV0aG9kIHJlcXVpcmVzIHRoYXQgeW91IHBhc3MgaXQgdGhlIGN1cnJlbnQgc2NvcGUuXG4gICAqL1xuICAgY2FwdHVyZUV2ZW50KGV2ZW50LCBoaW50LCBjdXJyZW50U2NvcGUpIHtcbiAgICBjb25zdCBldmVudElkID0gbWlzYy51dWlkNCgpO1xuXG4gICAgLy8gZW5zdXJlIHdlIGhhdmVuJ3QgY2FwdHVyZWQgdGhpcyB2ZXJ5IG9iamVjdCBiZWZvcmVcbiAgICBpZiAoaGludD8ub3JpZ2luYWxFeGNlcHRpb24gJiYgbWlzYy5jaGVja09yU2V0QWxyZWFkeUNhdWdodChoaW50Lm9yaWdpbmFsRXhjZXB0aW9uKSkge1xuICAgICAgZGVidWdCdWlsZC5ERUJVR19CVUlMRCAmJiBkZWJ1Z0xvZ2dlci5kZWJ1Zy5sb2coQUxSRUFEWV9TRUVOX0VSUk9SKTtcbiAgICAgIHJldHVybiBldmVudElkO1xuICAgIH1cblxuICAgIGNvbnN0IGhpbnRXaXRoRXZlbnRJZCA9IHtcbiAgICAgIGV2ZW50X2lkOiBldmVudElkLFxuICAgICAgLi4uaGludCxcbiAgICB9O1xuXG4gICAgY29uc3Qgc2RrUHJvY2Vzc2luZ01ldGFkYXRhID0gZXZlbnQuc2RrUHJvY2Vzc2luZ01ldGFkYXRhIHx8IHt9O1xuICAgIGNvbnN0IGNhcHR1cmVkU3BhblNjb3BlID0gc2RrUHJvY2Vzc2luZ01ldGFkYXRhLmNhcHR1cmVkU3BhblNjb3BlO1xuICAgIGNvbnN0IGNhcHR1cmVkU3Bhbklzb2xhdGlvblNjb3BlID0gc2RrUHJvY2Vzc2luZ01ldGFkYXRhLmNhcHR1cmVkU3Bhbklzb2xhdGlvblNjb3BlO1xuXG4gICAgdGhpcy5fcHJvY2VzcyhcbiAgICAgIHRoaXMuX2NhcHR1cmVFdmVudChldmVudCwgaGludFdpdGhFdmVudElkLCBjYXB0dXJlZFNwYW5TY29wZSB8fCBjdXJyZW50U2NvcGUsIGNhcHR1cmVkU3Bhbklzb2xhdGlvblNjb3BlKSxcbiAgICApO1xuXG4gICAgcmV0dXJuIGhpbnRXaXRoRXZlbnRJZC5ldmVudF9pZDtcbiAgfVxuXG4gIC8qKlxuICAgKiBDYXB0dXJlcyBhIHNlc3Npb24uXG4gICAqL1xuICAgY2FwdHVyZVNlc3Npb24oc2Vzc2lvbiQxKSB7XG4gICAgdGhpcy5zZW5kU2Vzc2lvbihzZXNzaW9uJDEpO1xuICAgIC8vIEFmdGVyIHNlbmRpbmcsIHdlIHNldCBpbml0IGZhbHNlIHRvIGluZGljYXRlIGl0J3Mgbm90IHRoZSBmaXJzdCBvY2N1cnJlbmNlXG4gICAgc2Vzc2lvbi51cGRhdGVTZXNzaW9uKHNlc3Npb24kMSwgeyBpbml0OiBmYWxzZSB9KTtcbiAgfVxuXG4gIC8qKlxuICAgKiBDcmVhdGUgYSBjcm9uIG1vbml0b3IgY2hlY2sgaW4gYW5kIHNlbmQgaXQgdG8gU2VudHJ5LiBUaGlzIG1ldGhvZCBpcyBub3QgYXZhaWxhYmxlIG9uIGFsbCBjbGllbnRzLlxuICAgKlxuICAgKiBAcGFyYW0gY2hlY2tJbiBBbiBvYmplY3QgdGhhdCBkZXNjcmliZXMgYSBjaGVjayBpbi5cbiAgICogQHBhcmFtIHVwc2VydE1vbml0b3JDb25maWcgQW4gb3B0aW9uYWwgb2JqZWN0IHRoYXQgZGVzY3JpYmVzIGEgbW9uaXRvciBjb25maWcuIFVzZSB0aGlzIGlmIHlvdSB3YW50XG4gICAqIHRvIGNyZWF0ZSBhIG1vbml0b3IgYXV0b21hdGljYWxseSB3aGVuIHNlbmRpbmcgYSBjaGVjayBpbi5cbiAgICogQHBhcmFtIHNjb3BlIEFuIG9wdGlvbmFsIHNjb3BlIGNvbnRhaW5pbmcgZXZlbnQgbWV0YWRhdGEuXG4gICAqIEByZXR1cm5zIEEgc3RyaW5nIHJlcHJlc2VudGluZyB0aGUgaWQgb2YgdGhlIGNoZWNrIGluLlxuICAgKi9cblxuICAvKipcbiAgICogR2V0IHRoZSBjdXJyZW50IERzbi5cbiAgICovXG4gICBnZXREc24oKSB7XG4gICAgcmV0dXJuIHRoaXMuX2RzbjtcbiAgfVxuXG4gIC8qKlxuICAgKiBHZXQgdGhlIGN1cnJlbnQgb3B0aW9ucy5cbiAgICovXG4gICBnZXRPcHRpb25zKCkge1xuICAgIHJldHVybiB0aGlzLl9vcHRpb25zO1xuICB9XG5cbiAgLyoqXG4gICAqIEdldCB0aGUgU0RLIG1ldGFkYXRhLlxuICAgKiBAc2VlIFNka01ldGFkYXRhXG4gICAqL1xuICAgZ2V0U2RrTWV0YWRhdGEoKSB7XG4gICAgcmV0dXJuIHRoaXMuX29wdGlvbnMuX21ldGFkYXRhO1xuICB9XG5cbiAgLyoqXG4gICAqIFJldHVybnMgdGhlIHRyYW5zcG9ydCB0aGF0IGlzIHVzZWQgYnkgdGhlIGNsaWVudC5cbiAgICogUGxlYXNlIG5vdGUgdGhhdCB0aGUgdHJhbnNwb3J0IGdldHMgbGF6eSBpbml0aWFsaXplZCBzbyBpdCB3aWxsIG9ubHkgYmUgdGhlcmUgb25jZSB0aGUgZmlyc3QgZXZlbnQgaGFzIGJlZW4gc2VudC5cbiAgICovXG4gICBnZXRUcmFuc3BvcnQoKSB7XG4gICAgcmV0dXJuIHRoaXMuX3RyYW5zcG9ydDtcbiAgfVxuXG4gIC8qKlxuICAgKiBXYWl0IGZvciBhbGwgZXZlbnRzIHRvIGJlIHNlbnQgb3IgdGhlIHRpbWVvdXQgdG8gZXhwaXJlLCB3aGljaGV2ZXIgY29tZXMgZmlyc3QuXG4gICAqXG4gICAqIEBwYXJhbSB0aW1lb3V0IE1heGltdW0gdGltZSBpbiBtcyB0aGUgY2xpZW50IHNob3VsZCB3YWl0IGZvciBldmVudHMgdG8gYmUgZmx1c2hlZC4gT21pdHRpbmcgdGhpcyBwYXJhbWV0ZXIgd2lsbFxuICAgKiAgIGNhdXNlIHRoZSBjbGllbnQgdG8gd2FpdCB1bnRpbCBhbGwgZXZlbnRzIGFyZSBzZW50IGJlZm9yZSByZXNvbHZpbmcgdGhlIHByb21pc2UuXG4gICAqIEByZXR1cm5zIEEgcHJvbWlzZSB0aGF0IHdpbGwgcmVzb2x2ZSB3aXRoIGB0cnVlYCBpZiBhbGwgZXZlbnRzIGFyZSBzZW50IGJlZm9yZSB0aGUgdGltZW91dCwgb3IgYGZhbHNlYCBpZiB0aGVyZSBhcmVcbiAgICogc3RpbGwgZXZlbnRzIGluIHRoZSBxdWV1ZSB3aGVuIHRoZSB0aW1lb3V0IGlzIHJlYWNoZWQuXG4gICAqL1xuICAgZmx1c2godGltZW91dCkge1xuICAgIGNvbnN0IHRyYW5zcG9ydCA9IHRoaXMuX3RyYW5zcG9ydDtcbiAgICBpZiAodHJhbnNwb3J0KSB7XG4gICAgICB0aGlzLmVtaXQoJ2ZsdXNoJyk7XG4gICAgICByZXR1cm4gdGhpcy5faXNDbGllbnREb25lUHJvY2Vzc2luZyh0aW1lb3V0KS50aGVuKGNsaWVudEZpbmlzaGVkID0+IHtcbiAgICAgICAgcmV0dXJuIHRyYW5zcG9ydC5mbHVzaCh0aW1lb3V0KS50aGVuKHRyYW5zcG9ydEZsdXNoZWQgPT4gY2xpZW50RmluaXNoZWQgJiYgdHJhbnNwb3J0Rmx1c2hlZCk7XG4gICAgICB9KTtcbiAgICB9IGVsc2Uge1xuICAgICAgcmV0dXJuIHN5bmNwcm9taXNlLnJlc29sdmVkU3luY1Byb21pc2UodHJ1ZSk7XG4gICAgfVxuICB9XG5cbiAgLyoqXG4gICAqIEZsdXNoIHRoZSBldmVudCBxdWV1ZSBhbmQgc2V0IHRoZSBjbGllbnQgdG8gYGVuYWJsZWQgPSBmYWxzZWAuIFNlZSB7QGxpbmsgQ2xpZW50LmZsdXNofS5cbiAgICpcbiAgICogQHBhcmFtIHtudW1iZXJ9IHRpbWVvdXQgTWF4aW11bSB0aW1lIGluIG1zIHRoZSBjbGllbnQgc2hvdWxkIHdhaXQgYmVmb3JlIHNodXR0aW5nIGRvd24uIE9taXR0aW5nIHRoaXMgcGFyYW1ldGVyIHdpbGwgY2F1c2VcbiAgICogICB0aGUgY2xpZW50IHRvIHdhaXQgdW50aWwgYWxsIGV2ZW50cyBhcmUgc2VudCBiZWZvcmUgZGlzYWJsaW5nIGl0c2VsZi5cbiAgICogQHJldHVybnMge1Byb21pc2U8Ym9vbGVhbj59IEEgcHJvbWlzZSB3aGljaCByZXNvbHZlcyB0byBgdHJ1ZWAgaWYgdGhlIGZsdXNoIGNvbXBsZXRlcyBzdWNjZXNzZnVsbHkgYmVmb3JlIHRoZSB0aW1lb3V0LCBvciBgZmFsc2VgIGlmXG4gICAqIGl0IGRvZXNuJ3QuXG4gICAqL1xuICAgY2xvc2UodGltZW91dCkge1xuICAgIHJldHVybiB0aGlzLmZsdXNoKHRpbWVvdXQpLnRoZW4ocmVzdWx0ID0+IHtcbiAgICAgIHRoaXMuZ2V0T3B0aW9ucygpLmVuYWJsZWQgPSBmYWxzZTtcbiAgICAgIHRoaXMuZW1pdCgnY2xvc2UnKTtcbiAgICAgIHJldHVybiByZXN1bHQ7XG4gICAgfSk7XG4gIH1cblxuICAvKipcbiAgICogR2V0IGFsbCBpbnN0YWxsZWQgZXZlbnQgcHJvY2Vzc29ycy5cbiAgICovXG4gICBnZXRFdmVudFByb2Nlc3NvcnMoKSB7XG4gICAgcmV0dXJuIHRoaXMuX2V2ZW50UHJvY2Vzc29ycztcbiAgfVxuXG4gIC8qKlxuICAgKiBBZGRzIGFuIGV2ZW50IHByb2Nlc3NvciB0aGF0IGFwcGxpZXMgdG8gYW55IGV2ZW50IHByb2Nlc3NlZCBieSB0aGlzIGNsaWVudC5cbiAgICovXG4gICBhZGRFdmVudFByb2Nlc3NvcihldmVudFByb2Nlc3Nvcikge1xuICAgIHRoaXMuX2V2ZW50UHJvY2Vzc29ycy5wdXNoKGV2ZW50UHJvY2Vzc29yKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBJbml0aWFsaXplIHRoaXMgY2xpZW50LlxuICAgKiBDYWxsIHRoaXMgYWZ0ZXIgdGhlIGNsaWVudCB3YXMgc2V0IG9uIGEgc2NvcGUuXG4gICAqL1xuICAgaW5pdCgpIHtcbiAgICBpZiAoXG4gICAgICB0aGlzLl9pc0VuYWJsZWQoKSB8fFxuICAgICAgLy8gRm9yY2UgaW50ZWdyYXRpb25zIHRvIGJlIHNldHVwIGV2ZW4gaWYgbm8gRFNOIHdhcyBzZXQgd2hlbiB3ZSBoYXZlXG4gICAgICAvLyBTcG90bGlnaHQgZW5hYmxlZC4gVGhpcyBpcyBwYXJ0aWN1bGFybHkgaW1wb3J0YW50IGZvciBicm93c2VyIGFzIHdlXG4gICAgICAvLyBkb24ndCBzdXBwb3J0IHRoZSBgc3BvdGxpZ2h0YCBvcHRpb24gdGhlcmUgYW5kIHJlbHkgb24gdGhlIHVzZXJzXG4gICAgICAvLyBhZGRpbmcgdGhlIGBzcG90bGlnaHRCcm93c2VySW50ZWdyYXRpb24oKWAgdG8gdGhlaXIgaW50ZWdyYXRpb25zIHdoaWNoXG4gICAgICAvLyB3b3VsZG4ndCBnZXQgaW5pdGlhbGl6ZWQgd2l0aCB0aGUgY2hlY2sgYmVsb3cgd2hlbiB0aGVyZSdzIG5vIERTTiBzZXQuXG4gICAgICB0aGlzLl9vcHRpb25zLmludGVncmF0aW9ucy5zb21lKCh7IG5hbWUgfSkgPT4gbmFtZS5zdGFydHNXaXRoKCdTcG90bGlnaHQnKSlcbiAgICApIHtcbiAgICAgIHRoaXMuX3NldHVwSW50ZWdyYXRpb25zKCk7XG4gICAgfVxuICB9XG5cbiAgLyoqXG4gICAqIEdldHMgYW4gaW5zdGFsbGVkIGludGVncmF0aW9uIGJ5IGl0cyBuYW1lLlxuICAgKlxuICAgKiBAcmV0dXJucyB7SW50ZWdyYXRpb258dW5kZWZpbmVkfSBUaGUgaW5zdGFsbGVkIGludGVncmF0aW9uIG9yIGB1bmRlZmluZWRgIGlmIG5vIGludGVncmF0aW9uIHdpdGggdGhhdCBgbmFtZWAgd2FzIGluc3RhbGxlZC5cbiAgICovXG4gICBnZXRJbnRlZ3JhdGlvbkJ5TmFtZShpbnRlZ3JhdGlvbk5hbWUpIHtcbiAgICByZXR1cm4gdGhpcy5faW50ZWdyYXRpb25zW2ludGVncmF0aW9uTmFtZV0gO1xuICB9XG5cbiAgLyoqXG4gICAqIEFkZCBhbiBpbnRlZ3JhdGlvbiB0byB0aGUgY2xpZW50LlxuICAgKiBUaGlzIGNhbiBiZSB1c2VkIHRvIGUuZy4gbGF6eSBsb2FkIGludGVncmF0aW9ucy5cbiAgICogSW4gbW9zdCBjYXNlcywgdGhpcyBzaG91bGQgbm90IGJlIG5lY2Vzc2FyeSxcbiAgICogYW5kIHlvdSdyZSBiZXR0ZXIgb2ZmIGp1c3QgcGFzc2luZyB0aGUgaW50ZWdyYXRpb25zIHZpYSBgaW50ZWdyYXRpb25zOiBbXWAgYXQgaW5pdGlhbGl6YXRpb24gdGltZS5cbiAgICogSG93ZXZlciwgaWYgeW91IGZpbmQgdGhlIG5lZWQgdG8gY29uZGl0aW9uYWxseSBsb2FkICYgYWRkIGFuIGludGVncmF0aW9uLCB5b3UgY2FuIHVzZSBgYWRkSW50ZWdyYXRpb25gIHRvIGRvIHNvLlxuICAgKi9cbiAgIGFkZEludGVncmF0aW9uKGludGVncmF0aW9uJDEpIHtcbiAgICBjb25zdCBpc0FscmVhZHlJbnN0YWxsZWQgPSB0aGlzLl9pbnRlZ3JhdGlvbnNbaW50ZWdyYXRpb24kMS5uYW1lXTtcblxuICAgIC8vIFRoaXMgaG9vayB0YWtlcyBjYXJlIG9mIG9ubHkgaW5zdGFsbGluZyBpZiBub3QgYWxyZWFkeSBpbnN0YWxsZWRcbiAgICBpbnRlZ3JhdGlvbi5zZXR1cEludGVncmF0aW9uKHRoaXMsIGludGVncmF0aW9uJDEsIHRoaXMuX2ludGVncmF0aW9ucyk7XG4gICAgLy8gSGVyZSB3ZSBuZWVkIHRvIGNoZWNrIG1hbnVhbGx5IHRvIG1ha2Ugc3VyZSB0byBub3QgcnVuIHRoaXMgbXVsdGlwbGUgdGltZXNcbiAgICBpZiAoIWlzQWxyZWFkeUluc3RhbGxlZCkge1xuICAgICAgaW50ZWdyYXRpb24uYWZ0ZXJTZXR1cEludGVncmF0aW9ucyh0aGlzLCBbaW50ZWdyYXRpb24kMV0pO1xuICAgIH1cbiAgfVxuXG4gIC8qKlxuICAgKiBTZW5kIGEgZnVsbHkgcHJlcGFyZWQgZXZlbnQgdG8gU2VudHJ5LlxuICAgKi9cbiAgIHNlbmRFdmVudChldmVudCwgaGludCA9IHt9KSB7XG4gICAgdGhpcy5lbWl0KCdiZWZvcmVTZW5kRXZlbnQnLCBldmVudCwgaGludCk7XG5cbiAgICBsZXQgZW52ID0gZW52ZWxvcGUuY3JlYXRlRXZlbnRFbnZlbG9wZShldmVudCwgdGhpcy5fZHNuLCB0aGlzLl9vcHRpb25zLl9tZXRhZGF0YSwgdGhpcy5fb3B0aW9ucy50dW5uZWwpO1xuXG4gICAgZm9yIChjb25zdCBhdHRhY2htZW50IG9mIGhpbnQuYXR0YWNobWVudHMgfHwgW10pIHtcbiAgICAgIGVudiA9IGVudmVsb3BlJDEuYWRkSXRlbVRvRW52ZWxvcGUoZW52LCBlbnZlbG9wZSQxLmNyZWF0ZUF0dGFjaG1lbnRFbnZlbG9wZUl0ZW0oYXR0YWNobWVudCkpO1xuICAgIH1cblxuICAgIGNvbnN0IHByb21pc2UgPSB0aGlzLnNlbmRFbnZlbG9wZShlbnYpO1xuICAgIGlmIChwcm9taXNlKSB7XG4gICAgICBwcm9taXNlLnRoZW4oc2VuZFJlc3BvbnNlID0+IHRoaXMuZW1pdCgnYWZ0ZXJTZW5kRXZlbnQnLCBldmVudCwgc2VuZFJlc3BvbnNlKSwgbnVsbCk7XG4gICAgfVxuICB9XG5cbiAgLyoqXG4gICAqIFNlbmQgYSBzZXNzaW9uIG9yIHNlc3Npb24gYWdncmVncmF0ZXMgdG8gU2VudHJ5LlxuICAgKi9cbiAgIHNlbmRTZXNzaW9uKHNlc3Npb24pIHtcbiAgICAvLyBCYWNrZmlsbCByZWxlYXNlIGFuZCBlbnZpcm9ubWVudCBvbiBzZXNzaW9uXG4gICAgY29uc3QgeyByZWxlYXNlOiBjbGllbnRSZWxlYXNlT3B0aW9uLCBlbnZpcm9ubWVudDogY2xpZW50RW52aXJvbm1lbnRPcHRpb24gPSBjb25zdGFudHMuREVGQVVMVF9FTlZJUk9OTUVOVCB9ID0gdGhpcy5fb3B0aW9ucztcbiAgICBpZiAoJ2FnZ3JlZ2F0ZXMnIGluIHNlc3Npb24pIHtcbiAgICAgIGNvbnN0IHNlc3Npb25BdHRycyA9IHNlc3Npb24uYXR0cnMgfHwge307XG4gICAgICBpZiAoIXNlc3Npb25BdHRycy5yZWxlYXNlICYmICFjbGllbnRSZWxlYXNlT3B0aW9uKSB7XG4gICAgICAgIGRlYnVnQnVpbGQuREVCVUdfQlVJTEQgJiYgZGVidWdMb2dnZXIuZGVidWcud2FybihNSVNTSU5HX1JFTEVBU0VfRk9SX1NFU1NJT05fRVJST1IpO1xuICAgICAgICByZXR1cm47XG4gICAgICB9XG4gICAgICBzZXNzaW9uQXR0cnMucmVsZWFzZSA9IHNlc3Npb25BdHRycy5yZWxlYXNlIHx8IGNsaWVudFJlbGVhc2VPcHRpb247XG4gICAgICBzZXNzaW9uQXR0cnMuZW52aXJvbm1lbnQgPSBzZXNzaW9uQXR0cnMuZW52aXJvbm1lbnQgfHwgY2xpZW50RW52aXJvbm1lbnRPcHRpb247XG4gICAgICBzZXNzaW9uLmF0dHJzID0gc2Vzc2lvbkF0dHJzO1xuICAgIH0gZWxzZSB7XG4gICAgICBpZiAoIXNlc3Npb24ucmVsZWFzZSAmJiAhY2xpZW50UmVsZWFzZU9wdGlvbikge1xuICAgICAgICBkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEICYmIGRlYnVnTG9nZ2VyLmRlYnVnLndhcm4oTUlTU0lOR19SRUxFQVNFX0ZPUl9TRVNTSU9OX0VSUk9SKTtcbiAgICAgICAgcmV0dXJuO1xuICAgICAgfVxuICAgICAgc2Vzc2lvbi5yZWxlYXNlID0gc2Vzc2lvbi5yZWxlYXNlIHx8IGNsaWVudFJlbGVhc2VPcHRpb247XG4gICAgICBzZXNzaW9uLmVudmlyb25tZW50ID0gc2Vzc2lvbi5lbnZpcm9ubWVudCB8fCBjbGllbnRFbnZpcm9ubWVudE9wdGlvbjtcbiAgICB9XG5cbiAgICB0aGlzLmVtaXQoJ2JlZm9yZVNlbmRTZXNzaW9uJywgc2Vzc2lvbik7XG5cbiAgICBjb25zdCBlbnYgPSBlbnZlbG9wZS5jcmVhdGVTZXNzaW9uRW52ZWxvcGUoc2Vzc2lvbiwgdGhpcy5fZHNuLCB0aGlzLl9vcHRpb25zLl9tZXRhZGF0YSwgdGhpcy5fb3B0aW9ucy50dW5uZWwpO1xuXG4gICAgLy8gc2VuZEVudmVsb3BlIHNob3VsZCBub3QgdGhyb3dcbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25vLWZsb2F0aW5nLXByb21pc2VzXG4gICAgdGhpcy5zZW5kRW52ZWxvcGUoZW52KTtcbiAgfVxuXG4gIC8qKlxuICAgKiBSZWNvcmQgb24gdGhlIGNsaWVudCB0aGF0IGFuIGV2ZW50IGdvdCBkcm9wcGVkIChpZSwgYW4gZXZlbnQgdGhhdCB3aWxsIG5vdCBiZSBzZW50IHRvIFNlbnRyeSkuXG4gICAqL1xuICAgcmVjb3JkRHJvcHBlZEV2ZW50KHJlYXNvbiwgY2F0ZWdvcnksIGNvdW50ID0gMSkge1xuICAgIGlmICh0aGlzLl9vcHRpb25zLnNlbmRDbGllbnRSZXBvcnRzKSB7XG4gICAgICAvLyBXZSB3YW50IHRvIHRyYWNrIGVhY2ggY2F0ZWdvcnkgKGVycm9yLCB0cmFuc2FjdGlvbiwgc2Vzc2lvbiwgcmVwbGF5X2V2ZW50KSBzZXBhcmF0ZWx5XG4gICAgICAvLyBidXQgc3RpbGwga2VlcCB0aGUgZGlzdGluY3Rpb24gYmV0d2VlbiBkaWZmZXJlbnQgdHlwZSBvZiBvdXRjb21lcy5cbiAgICAgIC8vIFdlIGNvdWxkIHVzZSBuZXN0ZWQgbWFwcywgYnV0IGl0J3MgbXVjaCBlYXNpZXIgdG8gcmVhZCBhbmQgdHlwZSB0aGlzIHdheS5cbiAgICAgIC8vIEEgY29ycmVjdCB0eXBlIGZvciBtYXAtYmFzZWQgaW1wbGVtZW50YXRpb24gaWYgd2Ugd2FudCB0byBnbyB0aGF0IHJvdXRlXG4gICAgICAvLyB3b3VsZCBiZSBgUGFydGlhbDxSZWNvcmQ8U2VudHJ5UmVxdWVzdFR5cGUsIFBhcnRpYWw8UmVjb3JkPE91dGNvbWUsIG51bWJlcj4+Pj5gXG4gICAgICAvLyBXaXRoIHR5cGVzY3JpcHQgNC4xIHdlIGNvdWxkIGV2ZW4gdXNlIHRlbXBsYXRlIGxpdGVyYWwgdHlwZXNcbiAgICAgIGNvbnN0IGtleSA9IGAke3JlYXNvbn06JHtjYXRlZ29yeX1gO1xuICAgICAgZGVidWdCdWlsZC5ERUJVR19CVUlMRCAmJiBkZWJ1Z0xvZ2dlci5kZWJ1Zy5sb2coYFJlY29yZGluZyBvdXRjb21lOiBcIiR7a2V5fVwiJHtjb3VudCA+IDEgPyBgICgke2NvdW50fSB0aW1lcylgIDogJyd9YCk7XG4gICAgICB0aGlzLl9vdXRjb21lc1trZXldID0gKHRoaXMuX291dGNvbWVzW2tleV0gfHwgMCkgKyBjb3VudDtcbiAgICB9XG4gIH1cblxuICAvKiBlc2xpbnQtZGlzYWJsZSBAdHlwZXNjcmlwdC1lc2xpbnQvdW5pZmllZC1zaWduYXR1cmVzICovXG4gIC8qKlxuICAgKiBSZWdpc3RlciBhIGNhbGxiYWNrIGZvciB3aGVuZXZlciBhIHNwYW4gaXMgc3RhcnRlZC5cbiAgICogUmVjZWl2ZXMgdGhlIHNwYW4gYXMgYXJndW1lbnQuXG4gICAqIEByZXR1cm5zIHsoKSA9PiB2b2lkfSBBIGZ1bmN0aW9uIHRoYXQsIHdoZW4gZXhlY3V0ZWQsIHJlbW92ZXMgdGhlIHJlZ2lzdGVyZWQgY2FsbGJhY2suXG4gICAqL1xuXG4gIC8qKlxuICAgKiBSZWdpc3RlciBhIGhvb2sgb24gdGhpcyBjbGllbnQuXG4gICAqL1xuICAgb24oaG9vaywgY2FsbGJhY2spIHtcbiAgICBjb25zdCBob29rcyA9ICh0aGlzLl9ob29rc1tob29rXSA9IHRoaXMuX2hvb2tzW2hvb2tdIHx8IFtdKTtcblxuICAgIC8vIEB0cy1leHBlY3QtZXJyb3IgV2UgYXNzdW1lIHRoZSB0eXBlcyBhcmUgY29ycmVjdFxuICAgIGhvb2tzLnB1c2goY2FsbGJhY2spO1xuXG4gICAgLy8gVGhpcyBmdW5jdGlvbiByZXR1cm5zIGEgY2FsbGJhY2sgZXhlY3V0aW9uIGhhbmRsZXIgdGhhdCwgd2hlbiBpbnZva2VkLFxuICAgIC8vIGRlcmVnaXN0ZXJzIGEgY2FsbGJhY2suIFRoaXMgaXMgY3J1Y2lhbCBmb3IgbWFuYWdpbmcgaW5zdGFuY2VzIHdoZXJlIGNhbGxiYWNrc1xuICAgIC8vIG5lZWQgdG8gYmUgdW5yZWdpc3RlcmVkIHRvIHByZXZlbnQgc2VsZi1yZWZlcmVuY2luZyBpbiBjYWxsYmFjayBjbG9zdXJlcyxcbiAgICAvLyBlbnN1cmluZyBwcm9wZXIgZ2FyYmFnZSBjb2xsZWN0aW9uLlxuICAgIHJldHVybiAoKSA9PiB7XG4gICAgICAvLyBAdHMtZXhwZWN0LWVycm9yIFdlIGFzc3VtZSB0aGUgdHlwZXMgYXJlIGNvcnJlY3RcbiAgICAgIGNvbnN0IGNiSW5kZXggPSBob29rcy5pbmRleE9mKGNhbGxiYWNrKTtcbiAgICAgIGlmIChjYkluZGV4ID4gLTEpIHtcbiAgICAgICAgaG9va3Muc3BsaWNlKGNiSW5kZXgsIDEpO1xuICAgICAgfVxuICAgIH07XG4gIH1cblxuICAvKiogRmlyZSBhIGhvb2sgd2hlbmV2ZXIgYSBzcGFuIHN0YXJ0cy4gKi9cblxuICAvKipcbiAgICogRW1pdCBhIGhvb2sgdGhhdCB3YXMgcHJldmlvdXNseSByZWdpc3RlcmVkIHZpYSBgb24oKWAuXG4gICAqL1xuICAgZW1pdChob29rLCAuLi5yZXN0KSB7XG4gICAgY29uc3QgY2FsbGJhY2tzID0gdGhpcy5faG9va3NbaG9va107XG4gICAgaWYgKGNhbGxiYWNrcykge1xuICAgICAgY2FsbGJhY2tzLmZvckVhY2goY2FsbGJhY2sgPT4gY2FsbGJhY2soLi4ucmVzdCkpO1xuICAgIH1cbiAgfVxuXG4gIC8qKlxuICAgKiBTZW5kIGFuIGVudmVsb3BlIHRvIFNlbnRyeS5cbiAgICovXG4gICBzZW5kRW52ZWxvcGUoZW52ZWxvcGUpIHtcbiAgICB0aGlzLmVtaXQoJ2JlZm9yZUVudmVsb3BlJywgZW52ZWxvcGUpO1xuXG4gICAgaWYgKHRoaXMuX2lzRW5hYmxlZCgpICYmIHRoaXMuX3RyYW5zcG9ydCkge1xuICAgICAgcmV0dXJuIHRoaXMuX3RyYW5zcG9ydC5zZW5kKGVudmVsb3BlKS50aGVuKG51bGwsIHJlYXNvbiA9PiB7XG4gICAgICAgIGRlYnVnQnVpbGQuREVCVUdfQlVJTEQgJiYgZGVidWdMb2dnZXIuZGVidWcuZXJyb3IoJ0Vycm9yIHdoaWxlIHNlbmRpbmcgZW52ZWxvcGU6JywgcmVhc29uKTtcbiAgICAgICAgcmV0dXJuIHJlYXNvbjtcbiAgICAgIH0pO1xuICAgIH1cblxuICAgIGRlYnVnQnVpbGQuREVCVUdfQlVJTEQgJiYgZGVidWdMb2dnZXIuZGVidWcuZXJyb3IoJ1RyYW5zcG9ydCBkaXNhYmxlZCcpO1xuXG4gICAgcmV0dXJuIHN5bmNwcm9taXNlLnJlc29sdmVkU3luY1Byb21pc2Uoe30pO1xuICB9XG5cbiAgLyogZXNsaW50LWVuYWJsZSBAdHlwZXNjcmlwdC1lc2xpbnQvdW5pZmllZC1zaWduYXR1cmVzICovXG5cbiAgLyoqIFNldHVwIGludGVncmF0aW9ucyBmb3IgdGhpcyBjbGllbnQuICovXG4gICBfc2V0dXBJbnRlZ3JhdGlvbnMoKSB7XG4gICAgY29uc3QgeyBpbnRlZ3JhdGlvbnMgfSA9IHRoaXMuX29wdGlvbnM7XG4gICAgdGhpcy5faW50ZWdyYXRpb25zID0gaW50ZWdyYXRpb24uc2V0dXBJbnRlZ3JhdGlvbnModGhpcywgaW50ZWdyYXRpb25zKTtcbiAgICBpbnRlZ3JhdGlvbi5hZnRlclNldHVwSW50ZWdyYXRpb25zKHRoaXMsIGludGVncmF0aW9ucyk7XG4gIH1cblxuICAvKiogVXBkYXRlcyBleGlzdGluZyBzZXNzaW9uIGJhc2VkIG9uIHRoZSBwcm92aWRlZCBldmVudCAqL1xuICAgX3VwZGF0ZVNlc3Npb25Gcm9tRXZlbnQoc2Vzc2lvbiQxLCBldmVudCkge1xuICAgIGxldCBjcmFzaGVkID0gZXZlbnQubGV2ZWwgPT09ICdmYXRhbCc7XG4gICAgbGV0IGVycm9yZWQgPSBmYWxzZTtcbiAgICBjb25zdCBleGNlcHRpb25zID0gZXZlbnQuZXhjZXB0aW9uPy52YWx1ZXM7XG5cbiAgICBpZiAoZXhjZXB0aW9ucykge1xuICAgICAgZXJyb3JlZCA9IHRydWU7XG5cbiAgICAgIGZvciAoY29uc3QgZXggb2YgZXhjZXB0aW9ucykge1xuICAgICAgICBjb25zdCBtZWNoYW5pc20gPSBleC5tZWNoYW5pc207XG4gICAgICAgIGlmIChtZWNoYW5pc20/LmhhbmRsZWQgPT09IGZhbHNlKSB7XG4gICAgICAgICAgY3Jhc2hlZCA9IHRydWU7XG4gICAgICAgICAgYnJlYWs7XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9XG5cbiAgICAvLyBBIHNlc3Npb24gaXMgdXBkYXRlZCBhbmQgdGhhdCBzZXNzaW9uIHVwZGF0ZSBpcyBzZW50IGluIG9ubHkgb25lIG9mIHRoZSB0d28gZm9sbG93aW5nIHNjZW5hcmlvczpcbiAgICAvLyAxLiBTZXNzaW9uIHdpdGggbm9uIHRlcm1pbmFsIHN0YXR1cyBhbmQgMCBlcnJvcnMgKyBhbiBlcnJvciBvY2N1cnJlZCAtPiBXaWxsIHNldCBlcnJvciBjb3VudCB0byAxIGFuZCBzZW5kIHVwZGF0ZVxuICAgIC8vIDIuIFNlc3Npb24gd2l0aCBub24gdGVybWluYWwgc3RhdHVzIGFuZCAxIGVycm9yICsgYSBjcmFzaCBvY2N1cnJlZCAtPiBXaWxsIHNldCBzdGF0dXMgY3Jhc2hlZCBhbmQgc2VuZCB1cGRhdGVcbiAgICBjb25zdCBzZXNzaW9uTm9uVGVybWluYWwgPSBzZXNzaW9uJDEuc3RhdHVzID09PSAnb2snO1xuICAgIGNvbnN0IHNob3VsZFVwZGF0ZUFuZFNlbmQgPSAoc2Vzc2lvbk5vblRlcm1pbmFsICYmIHNlc3Npb24kMS5lcnJvcnMgPT09IDApIHx8IChzZXNzaW9uTm9uVGVybWluYWwgJiYgY3Jhc2hlZCk7XG5cbiAgICBpZiAoc2hvdWxkVXBkYXRlQW5kU2VuZCkge1xuICAgICAgc2Vzc2lvbi51cGRhdGVTZXNzaW9uKHNlc3Npb24kMSwge1xuICAgICAgICAuLi4oY3Jhc2hlZCAmJiB7IHN0YXR1czogJ2NyYXNoZWQnIH0pLFxuICAgICAgICBlcnJvcnM6IHNlc3Npb24kMS5lcnJvcnMgfHwgTnVtYmVyKGVycm9yZWQgfHwgY3Jhc2hlZCksXG4gICAgICB9KTtcbiAgICAgIHRoaXMuY2FwdHVyZVNlc3Npb24oc2Vzc2lvbiQxKTtcbiAgICB9XG4gIH1cblxuICAvKipcbiAgICogRGV0ZXJtaW5lIGlmIHRoZSBjbGllbnQgaXMgZmluaXNoZWQgcHJvY2Vzc2luZy4gUmV0dXJucyBhIHByb21pc2UgYmVjYXVzZSBpdCB3aWxsIHdhaXQgYHRpbWVvdXRgIG1zIGJlZm9yZSBzYXlpbmdcbiAgICogXCJub1wiIChyZXNvbHZpbmcgdG8gYGZhbHNlYCkgaW4gb3JkZXIgdG8gZ2l2ZSB0aGUgY2xpZW50IGEgY2hhbmNlIHRvIHBvdGVudGlhbGx5IGZpbmlzaCBmaXJzdC5cbiAgICpcbiAgICogQHBhcmFtIHRpbWVvdXQgVGhlIHRpbWUsIGluIG1zLCBhZnRlciB3aGljaCB0byByZXNvbHZlIHRvIGBmYWxzZWAgaWYgdGhlIGNsaWVudCBpcyBzdGlsbCBidXN5LiBQYXNzaW5nIGAwYCAob3Igbm90XG4gICAqIHBhc3NpbmcgYW55dGhpbmcpIHdpbGwgbWFrZSB0aGUgcHJvbWlzZSB3YWl0IGFzIGxvbmcgYXMgaXQgdGFrZXMgZm9yIHByb2Nlc3NpbmcgdG8gZmluaXNoIGJlZm9yZSByZXNvbHZpbmcgdG9cbiAgICogYHRydWVgLlxuICAgKiBAcmV0dXJucyBBIHByb21pc2Ugd2hpY2ggd2lsbCByZXNvbHZlIHRvIGB0cnVlYCBpZiBwcm9jZXNzaW5nIGlzIGFscmVhZHkgZG9uZSBvciBmaW5pc2hlcyBiZWZvcmUgdGhlIHRpbWVvdXQsIGFuZFxuICAgKiBgZmFsc2VgIG90aGVyd2lzZVxuICAgKi9cbiAgIF9pc0NsaWVudERvbmVQcm9jZXNzaW5nKHRpbWVvdXQpIHtcbiAgICByZXR1cm4gbmV3IHN5bmNwcm9taXNlLlN5bmNQcm9taXNlKHJlc29sdmUgPT4ge1xuICAgICAgbGV0IHRpY2tlZCA9IDA7XG4gICAgICBjb25zdCB0aWNrID0gMTtcblxuICAgICAgY29uc3QgaW50ZXJ2YWwgPSBzZXRJbnRlcnZhbCgoKSA9PiB7XG4gICAgICAgIGlmICh0aGlzLl9udW1Qcm9jZXNzaW5nID09IDApIHtcbiAgICAgICAgICBjbGVhckludGVydmFsKGludGVydmFsKTtcbiAgICAgICAgICByZXNvbHZlKHRydWUpO1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgIHRpY2tlZCArPSB0aWNrO1xuICAgICAgICAgIGlmICh0aW1lb3V0ICYmIHRpY2tlZCA+PSB0aW1lb3V0KSB7XG4gICAgICAgICAgICBjbGVhckludGVydmFsKGludGVydmFsKTtcbiAgICAgICAgICAgIHJlc29sdmUoZmFsc2UpO1xuICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgfSwgdGljayk7XG4gICAgfSk7XG4gIH1cblxuICAvKiogRGV0ZXJtaW5lcyB3aGV0aGVyIHRoaXMgU0RLIGlzIGVuYWJsZWQgYW5kIGEgdHJhbnNwb3J0IGlzIHByZXNlbnQuICovXG4gICBfaXNFbmFibGVkKCkge1xuICAgIHJldHVybiB0aGlzLmdldE9wdGlvbnMoKS5lbmFibGVkICE9PSBmYWxzZSAmJiB0aGlzLl90cmFuc3BvcnQgIT09IHVuZGVmaW5lZDtcbiAgfVxuXG4gIC8qKlxuICAgKiBBZGRzIGNvbW1vbiBpbmZvcm1hdGlvbiB0byBldmVudHMuXG4gICAqXG4gICAqIFRoZSBpbmZvcm1hdGlvbiBpbmNsdWRlcyByZWxlYXNlIGFuZCBlbnZpcm9ubWVudCBmcm9tIGBvcHRpb25zYCxcbiAgICogYnJlYWRjcnVtYnMgYW5kIGNvbnRleHQgKGV4dHJhLCB0YWdzIGFuZCB1c2VyKSBmcm9tIHRoZSBzY29wZS5cbiAgICpcbiAgICogSW5mb3JtYXRpb24gdGhhdCBpcyBhbHJlYWR5IHByZXNlbnQgaW4gdGhlIGV2ZW50IGlzIG5ldmVyIG92ZXJ3cml0dGVuLiBGb3JcbiAgICogbmVzdGVkIG9iamVjdHMsIHN1Y2ggYXMgdGhlIGNvbnRleHQsIGtleXMgYXJlIG1lcmdlZC5cbiAgICpcbiAgICogQHBhcmFtIGV2ZW50IFRoZSBvcmlnaW5hbCBldmVudC5cbiAgICogQHBhcmFtIGhpbnQgTWF5IGNvbnRhaW4gYWRkaXRpb25hbCBpbmZvcm1hdGlvbiBhYm91dCB0aGUgb3JpZ2luYWwgZXhjZXB0aW9uLlxuICAgKiBAcGFyYW0gY3VycmVudFNjb3BlIEEgc2NvcGUgY29udGFpbmluZyBldmVudCBtZXRhZGF0YS5cbiAgICogQHJldHVybnMgQSBuZXcgZXZlbnQgd2l0aCBtb3JlIGluZm9ybWF0aW9uLlxuICAgKi9cbiAgIF9wcmVwYXJlRXZlbnQoXG4gICAgZXZlbnQsXG4gICAgaGludCxcbiAgICBjdXJyZW50U2NvcGUsXG4gICAgaXNvbGF0aW9uU2NvcGUsXG4gICkge1xuICAgIGNvbnN0IG9wdGlvbnMgPSB0aGlzLmdldE9wdGlvbnMoKTtcbiAgICBjb25zdCBpbnRlZ3JhdGlvbnMgPSBPYmplY3Qua2V5cyh0aGlzLl9pbnRlZ3JhdGlvbnMpO1xuICAgIGlmICghaGludC5pbnRlZ3JhdGlvbnMgJiYgaW50ZWdyYXRpb25zPy5sZW5ndGgpIHtcbiAgICAgIGhpbnQuaW50ZWdyYXRpb25zID0gaW50ZWdyYXRpb25zO1xuICAgIH1cblxuICAgIHRoaXMuZW1pdCgncHJlcHJvY2Vzc0V2ZW50JywgZXZlbnQsIGhpbnQpO1xuXG4gICAgaWYgKCFldmVudC50eXBlKSB7XG4gICAgICBpc29sYXRpb25TY29wZS5zZXRMYXN0RXZlbnRJZChldmVudC5ldmVudF9pZCB8fCBoaW50LmV2ZW50X2lkKTtcbiAgICB9XG5cbiAgICByZXR1cm4gcHJlcGFyZUV2ZW50LnByZXBhcmVFdmVudChvcHRpb25zLCBldmVudCwgaGludCwgY3VycmVudFNjb3BlLCB0aGlzLCBpc29sYXRpb25TY29wZSkudGhlbihldnQgPT4ge1xuICAgICAgaWYgKGV2dCA9PT0gbnVsbCkge1xuICAgICAgICByZXR1cm4gZXZ0O1xuICAgICAgfVxuXG4gICAgICB0aGlzLmVtaXQoJ3Bvc3Rwcm9jZXNzRXZlbnQnLCBldnQsIGhpbnQpO1xuXG4gICAgICBldnQuY29udGV4dHMgPSB7XG4gICAgICAgIHRyYWNlOiBjdXJyZW50U2NvcGVzLmdldFRyYWNlQ29udGV4dEZyb21TY29wZShjdXJyZW50U2NvcGUpLFxuICAgICAgICAuLi5ldnQuY29udGV4dHMsXG4gICAgICB9O1xuXG4gICAgICBjb25zdCBkeW5hbWljU2FtcGxpbmdDb250ZXh0JDEgPSBkeW5hbWljU2FtcGxpbmdDb250ZXh0LmdldER5bmFtaWNTYW1wbGluZ0NvbnRleHRGcm9tU2NvcGUodGhpcywgY3VycmVudFNjb3BlKTtcblxuICAgICAgZXZ0LnNka1Byb2Nlc3NpbmdNZXRhZGF0YSA9IHtcbiAgICAgICAgZHluYW1pY1NhbXBsaW5nQ29udGV4dDogZHluYW1pY1NhbXBsaW5nQ29udGV4dCQxLFxuICAgICAgICAuLi5ldnQuc2RrUHJvY2Vzc2luZ01ldGFkYXRhLFxuICAgICAgfTtcblxuICAgICAgcmV0dXJuIGV2dDtcbiAgICB9KTtcbiAgfVxuXG4gIC8qKlxuICAgKiBQcm9jZXNzZXMgdGhlIGV2ZW50IGFuZCBsb2dzIGFuIGVycm9yIGluIGNhc2Ugb2YgcmVqZWN0aW9uXG4gICAqIEBwYXJhbSBldmVudFxuICAgKiBAcGFyYW0gaGludFxuICAgKiBAcGFyYW0gc2NvcGVcbiAgICovXG4gICBfY2FwdHVyZUV2ZW50KFxuICAgIGV2ZW50LFxuICAgIGhpbnQgPSB7fSxcbiAgICBjdXJyZW50U2NvcGUgPSBjdXJyZW50U2NvcGVzLmdldEN1cnJlbnRTY29wZSgpLFxuICAgIGlzb2xhdGlvblNjb3BlID0gY3VycmVudFNjb3Blcy5nZXRJc29sYXRpb25TY29wZSgpLFxuICApIHtcbiAgICBpZiAoZGVidWdCdWlsZC5ERUJVR19CVUlMRCAmJiBpc0Vycm9yRXZlbnQoZXZlbnQpKSB7XG4gICAgICBkZWJ1Z0xvZ2dlci5kZWJ1Zy5sb2coYENhcHR1cmVkIGVycm9yIGV2ZW50IFxcYCR7ZXZlbnRVdGlscy5nZXRQb3NzaWJsZUV2ZW50TWVzc2FnZXMoZXZlbnQpWzBdIHx8ICc8dW5rbm93bj4nfVxcYGApO1xuICAgIH1cblxuICAgIHJldHVybiB0aGlzLl9wcm9jZXNzRXZlbnQoZXZlbnQsIGhpbnQsIGN1cnJlbnRTY29wZSwgaXNvbGF0aW9uU2NvcGUpLnRoZW4oXG4gICAgICBmaW5hbEV2ZW50ID0+IHtcbiAgICAgICAgcmV0dXJuIGZpbmFsRXZlbnQuZXZlbnRfaWQ7XG4gICAgICB9LFxuICAgICAgcmVhc29uID0+IHtcbiAgICAgICAgaWYgKGRlYnVnQnVpbGQuREVCVUdfQlVJTEQpIHtcbiAgICAgICAgICBpZiAoX2lzRG9Ob3RTZW5kRXZlbnRFcnJvcihyZWFzb24pKSB7XG4gICAgICAgICAgICBkZWJ1Z0xvZ2dlci5kZWJ1Zy5sb2cocmVhc29uLm1lc3NhZ2UpO1xuICAgICAgICAgIH0gZWxzZSBpZiAoX2lzSW50ZXJuYWxFcnJvcihyZWFzb24pKSB7XG4gICAgICAgICAgICBkZWJ1Z0xvZ2dlci5kZWJ1Zy53YXJuKHJlYXNvbi5tZXNzYWdlKTtcbiAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgZGVidWdMb2dnZXIuZGVidWcud2FybihyZWFzb24pO1xuICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gdW5kZWZpbmVkO1xuICAgICAgfSxcbiAgICApO1xuICB9XG5cbiAgLyoqXG4gICAqIFByb2Nlc3NlcyBhbiBldmVudCAoZWl0aGVyIGVycm9yIG9yIG1lc3NhZ2UpIGFuZCBzZW5kcyBpdCB0byBTZW50cnkuXG4gICAqXG4gICAqIFRoaXMgYWxzbyBhZGRzIGJyZWFkY3J1bWJzIGFuZCBjb250ZXh0IGluZm9ybWF0aW9uIHRvIHRoZSBldmVudC4gSG93ZXZlcixcbiAgICogcGxhdGZvcm0gc3BlY2lmaWMgbWV0YSBkYXRhIChzdWNoIGFzIHRoZSBVc2VyJ3MgSVAgYWRkcmVzcykgbXVzdCBiZSBhZGRlZFxuICAgKiBieSB0aGUgU0RLIGltcGxlbWVudG9yLlxuICAgKlxuICAgKlxuICAgKiBAcGFyYW0gZXZlbnQgVGhlIGV2ZW50IHRvIHNlbmQgdG8gU2VudHJ5LlxuICAgKiBAcGFyYW0gaGludCBNYXkgY29udGFpbiBhZGRpdGlvbmFsIGluZm9ybWF0aW9uIGFib3V0IHRoZSBvcmlnaW5hbCBleGNlcHRpb24uXG4gICAqIEBwYXJhbSBjdXJyZW50U2NvcGUgQSBzY29wZSBjb250YWluaW5nIGV2ZW50IG1ldGFkYXRhLlxuICAgKiBAcmV0dXJucyBBIFN5bmNQcm9taXNlIHRoYXQgcmVzb2x2ZXMgd2l0aCB0aGUgZXZlbnQgb3IgcmVqZWN0cyBpbiBjYXNlIGV2ZW50IHdhcy93aWxsIG5vdCBiZSBzZW5kLlxuICAgKi9cbiAgIF9wcm9jZXNzRXZlbnQoXG4gICAgZXZlbnQsXG4gICAgaGludCxcbiAgICBjdXJyZW50U2NvcGUsXG4gICAgaXNvbGF0aW9uU2NvcGUsXG4gICkge1xuICAgIGNvbnN0IG9wdGlvbnMgPSB0aGlzLmdldE9wdGlvbnMoKTtcbiAgICBjb25zdCB7IHNhbXBsZVJhdGUgfSA9IG9wdGlvbnM7XG5cbiAgICBjb25zdCBpc1RyYW5zYWN0aW9uID0gaXNUcmFuc2FjdGlvbkV2ZW50KGV2ZW50KTtcbiAgICBjb25zdCBpc0Vycm9yID0gaXNFcnJvckV2ZW50KGV2ZW50KTtcbiAgICBjb25zdCBldmVudFR5cGUgPSBldmVudC50eXBlIHx8ICdlcnJvcic7XG4gICAgY29uc3QgYmVmb3JlU2VuZExhYmVsID0gYGJlZm9yZSBzZW5kIGZvciB0eXBlIFxcYCR7ZXZlbnRUeXBlfVxcYGA7XG5cbiAgICAvLyAxLjAgPT09IDEwMCUgZXZlbnRzIGFyZSBzZW50XG4gICAgLy8gMC4wID09PSAwJSBldmVudHMgYXJlIHNlbnRcbiAgICAvLyBTYW1wbGluZyBmb3IgdHJhbnNhY3Rpb24gaGFwcGVucyBzb21ld2hlcmUgZWxzZVxuICAgIGNvbnN0IHBhcnNlZFNhbXBsZVJhdGUgPSB0eXBlb2Ygc2FtcGxlUmF0ZSA9PT0gJ3VuZGVmaW5lZCcgPyB1bmRlZmluZWQgOiBwYXJzZVNhbXBsZVJhdGUucGFyc2VTYW1wbGVSYXRlKHNhbXBsZVJhdGUpO1xuICAgIGlmIChpc0Vycm9yICYmIHR5cGVvZiBwYXJzZWRTYW1wbGVSYXRlID09PSAnbnVtYmVyJyAmJiBNYXRoLnJhbmRvbSgpID4gcGFyc2VkU2FtcGxlUmF0ZSkge1xuICAgICAgdGhpcy5yZWNvcmREcm9wcGVkRXZlbnQoJ3NhbXBsZV9yYXRlJywgJ2Vycm9yJyk7XG4gICAgICByZXR1cm4gc3luY3Byb21pc2UucmVqZWN0ZWRTeW5jUHJvbWlzZShcbiAgICAgICAgX21ha2VEb05vdFNlbmRFdmVudEVycm9yKFxuICAgICAgICAgIGBEaXNjYXJkaW5nIGV2ZW50IGJlY2F1c2UgaXQncyBub3QgaW5jbHVkZWQgaW4gdGhlIHJhbmRvbSBzYW1wbGUgKHNhbXBsaW5nIHJhdGUgPSAke3NhbXBsZVJhdGV9KWAsXG4gICAgICAgICksXG4gICAgICApO1xuICAgIH1cblxuICAgIGNvbnN0IGRhdGFDYXRlZ29yeSA9IChldmVudFR5cGUgPT09ICdyZXBsYXlfZXZlbnQnID8gJ3JlcGxheScgOiBldmVudFR5cGUpIDtcblxuICAgIHJldHVybiB0aGlzLl9wcmVwYXJlRXZlbnQoZXZlbnQsIGhpbnQsIGN1cnJlbnRTY29wZSwgaXNvbGF0aW9uU2NvcGUpXG4gICAgICAudGhlbihwcmVwYXJlZCA9PiB7XG4gICAgICAgIGlmIChwcmVwYXJlZCA9PT0gbnVsbCkge1xuICAgICAgICAgIHRoaXMucmVjb3JkRHJvcHBlZEV2ZW50KCdldmVudF9wcm9jZXNzb3InLCBkYXRhQ2F0ZWdvcnkpO1xuICAgICAgICAgIHRocm93IF9tYWtlRG9Ob3RTZW5kRXZlbnRFcnJvcignQW4gZXZlbnQgcHJvY2Vzc29yIHJldHVybmVkIGBudWxsYCwgd2lsbCBub3Qgc2VuZCBldmVudC4nKTtcbiAgICAgICAgfVxuXG4gICAgICAgIGNvbnN0IGlzSW50ZXJuYWxFeGNlcHRpb24gPSBoaW50LmRhdGEgJiYgKGhpbnQuZGF0YSApLl9fc2VudHJ5X18gPT09IHRydWU7XG4gICAgICAgIGlmIChpc0ludGVybmFsRXhjZXB0aW9uKSB7XG4gICAgICAgICAgcmV0dXJuIHByZXBhcmVkO1xuICAgICAgICB9XG5cbiAgICAgICAgY29uc3QgcmVzdWx0ID0gcHJvY2Vzc0JlZm9yZVNlbmQodGhpcywgb3B0aW9ucywgcHJlcGFyZWQsIGhpbnQpO1xuICAgICAgICByZXR1cm4gX3ZhbGlkYXRlQmVmb3JlU2VuZFJlc3VsdChyZXN1bHQsIGJlZm9yZVNlbmRMYWJlbCk7XG4gICAgICB9KVxuICAgICAgLnRoZW4ocHJvY2Vzc2VkRXZlbnQgPT4ge1xuICAgICAgICBpZiAocHJvY2Vzc2VkRXZlbnQgPT09IG51bGwpIHtcbiAgICAgICAgICB0aGlzLnJlY29yZERyb3BwZWRFdmVudCgnYmVmb3JlX3NlbmQnLCBkYXRhQ2F0ZWdvcnkpO1xuICAgICAgICAgIGlmIChpc1RyYW5zYWN0aW9uKSB7XG4gICAgICAgICAgICBjb25zdCBzcGFucyA9IGV2ZW50LnNwYW5zIHx8IFtdO1xuICAgICAgICAgICAgLy8gdGhlIHRyYW5zYWN0aW9uIGl0c2VsZiBjb3VudHMgYXMgb25lIHNwYW4sIHBsdXMgYWxsIHRoZSBjaGlsZCBzcGFucyB0aGF0IGFyZSBhZGRlZFxuICAgICAgICAgICAgY29uc3Qgc3BhbkNvdW50ID0gMSArIHNwYW5zLmxlbmd0aDtcbiAgICAgICAgICAgIHRoaXMucmVjb3JkRHJvcHBlZEV2ZW50KCdiZWZvcmVfc2VuZCcsICdzcGFuJywgc3BhbkNvdW50KTtcbiAgICAgICAgICB9XG4gICAgICAgICAgdGhyb3cgX21ha2VEb05vdFNlbmRFdmVudEVycm9yKGAke2JlZm9yZVNlbmRMYWJlbH0gcmV0dXJuZWQgXFxgbnVsbFxcYCwgd2lsbCBub3Qgc2VuZCBldmVudC5gKTtcbiAgICAgICAgfVxuXG4gICAgICAgIGNvbnN0IHNlc3Npb24gPSBjdXJyZW50U2NvcGUuZ2V0U2Vzc2lvbigpIHx8IGlzb2xhdGlvblNjb3BlLmdldFNlc3Npb24oKTtcbiAgICAgICAgaWYgKGlzRXJyb3IgJiYgc2Vzc2lvbikge1xuICAgICAgICAgIHRoaXMuX3VwZGF0ZVNlc3Npb25Gcm9tRXZlbnQoc2Vzc2lvbiwgcHJvY2Vzc2VkRXZlbnQpO1xuICAgICAgICB9XG5cbiAgICAgICAgaWYgKGlzVHJhbnNhY3Rpb24pIHtcbiAgICAgICAgICBjb25zdCBzcGFuQ291bnRCZWZvcmUgPSBwcm9jZXNzZWRFdmVudC5zZGtQcm9jZXNzaW5nTWV0YWRhdGE/LnNwYW5Db3VudEJlZm9yZVByb2Nlc3NpbmcgfHwgMDtcbiAgICAgICAgICBjb25zdCBzcGFuQ291bnRBZnRlciA9IHByb2Nlc3NlZEV2ZW50LnNwYW5zID8gcHJvY2Vzc2VkRXZlbnQuc3BhbnMubGVuZ3RoIDogMDtcblxuICAgICAgICAgIGNvbnN0IGRyb3BwZWRTcGFuQ291bnQgPSBzcGFuQ291bnRCZWZvcmUgLSBzcGFuQ291bnRBZnRlcjtcbiAgICAgICAgICBpZiAoZHJvcHBlZFNwYW5Db3VudCA+IDApIHtcbiAgICAgICAgICAgIHRoaXMucmVjb3JkRHJvcHBlZEV2ZW50KCdiZWZvcmVfc2VuZCcsICdzcGFuJywgZHJvcHBlZFNwYW5Db3VudCk7XG4gICAgICAgICAgfVxuICAgICAgICB9XG5cbiAgICAgICAgLy8gTm9uZSBvZiB0aGUgU2VudHJ5IGJ1aWx0IGV2ZW50IHByb2Nlc3NvciB3aWxsIHVwZGF0ZSB0cmFuc2FjdGlvbiBuYW1lLFxuICAgICAgICAvLyBzbyBpZiB0aGUgdHJhbnNhY3Rpb24gbmFtZSBoYXMgYmVlbiBjaGFuZ2VkIGJ5IGFuIGV2ZW50IHByb2Nlc3Nvciwgd2Uga25vd1xuICAgICAgICAvLyBpdCBoYXMgdG8gY29tZSBmcm9tIGN1c3RvbSBldmVudCBwcm9jZXNzb3IgYWRkZWQgYnkgYSB1c2VyXG4gICAgICAgIGNvbnN0IHRyYW5zYWN0aW9uSW5mbyA9IHByb2Nlc3NlZEV2ZW50LnRyYW5zYWN0aW9uX2luZm87XG4gICAgICAgIGlmIChpc1RyYW5zYWN0aW9uICYmIHRyYW5zYWN0aW9uSW5mbyAmJiBwcm9jZXNzZWRFdmVudC50cmFuc2FjdGlvbiAhPT0gZXZlbnQudHJhbnNhY3Rpb24pIHtcbiAgICAgICAgICBjb25zdCBzb3VyY2UgPSAnY3VzdG9tJztcbiAgICAgICAgICBwcm9jZXNzZWRFdmVudC50cmFuc2FjdGlvbl9pbmZvID0ge1xuICAgICAgICAgICAgLi4udHJhbnNhY3Rpb25JbmZvLFxuICAgICAgICAgICAgc291cmNlLFxuICAgICAgICAgIH07XG4gICAgICAgIH1cblxuICAgICAgICB0aGlzLnNlbmRFdmVudChwcm9jZXNzZWRFdmVudCwgaGludCk7XG4gICAgICAgIHJldHVybiBwcm9jZXNzZWRFdmVudDtcbiAgICAgIH0pXG4gICAgICAudGhlbihudWxsLCByZWFzb24gPT4ge1xuICAgICAgICBpZiAoX2lzRG9Ob3RTZW5kRXZlbnRFcnJvcihyZWFzb24pIHx8IF9pc0ludGVybmFsRXJyb3IocmVhc29uKSkge1xuICAgICAgICAgIHRocm93IHJlYXNvbjtcbiAgICAgICAgfVxuXG4gICAgICAgIHRoaXMuY2FwdHVyZUV4Y2VwdGlvbihyZWFzb24sIHtcbiAgICAgICAgICBkYXRhOiB7XG4gICAgICAgICAgICBfX3NlbnRyeV9fOiB0cnVlLFxuICAgICAgICAgIH0sXG4gICAgICAgICAgb3JpZ2luYWxFeGNlcHRpb246IHJlYXNvbixcbiAgICAgICAgfSk7XG4gICAgICAgIHRocm93IF9tYWtlSW50ZXJuYWxFcnJvcihcbiAgICAgICAgICBgRXZlbnQgcHJvY2Vzc2luZyBwaXBlbGluZSB0aHJldyBhbiBlcnJvciwgb3JpZ2luYWwgZXZlbnQgd2lsbCBub3QgYmUgc2VudC4gRGV0YWlscyBoYXZlIGJlZW4gc2VudCBhcyBhIG5ldyBldmVudC5cXG5SZWFzb246ICR7cmVhc29ufWAsXG4gICAgICAgICk7XG4gICAgICB9KTtcbiAgfVxuXG4gIC8qKlxuICAgKiBPY2N1cGllcyB0aGUgY2xpZW50IHdpdGggcHJvY2Vzc2luZyBhbmQgZXZlbnRcbiAgICovXG4gICBfcHJvY2Vzcyhwcm9taXNlKSB7XG4gICAgdGhpcy5fbnVtUHJvY2Vzc2luZysrO1xuICAgIHZvaWQgcHJvbWlzZS50aGVuKFxuICAgICAgdmFsdWUgPT4ge1xuICAgICAgICB0aGlzLl9udW1Qcm9jZXNzaW5nLS07XG4gICAgICAgIHJldHVybiB2YWx1ZTtcbiAgICAgIH0sXG4gICAgICByZWFzb24gPT4ge1xuICAgICAgICB0aGlzLl9udW1Qcm9jZXNzaW5nLS07XG4gICAgICAgIHJldHVybiByZWFzb247XG4gICAgICB9LFxuICAgICk7XG4gIH1cblxuICAvKipcbiAgICogQ2xlYXJzIG91dGNvbWVzIG9uIHRoaXMgY2xpZW50IGFuZCByZXR1cm5zIHRoZW0uXG4gICAqL1xuICAgX2NsZWFyT3V0Y29tZXMoKSB7XG4gICAgY29uc3Qgb3V0Y29tZXMgPSB0aGlzLl9vdXRjb21lcztcbiAgICB0aGlzLl9vdXRjb21lcyA9IHt9O1xuICAgIHJldHVybiBPYmplY3QuZW50cmllcyhvdXRjb21lcykubWFwKChba2V5LCBxdWFudGl0eV0pID0+IHtcbiAgICAgIGNvbnN0IFtyZWFzb24sIGNhdGVnb3J5XSA9IGtleS5zcGxpdCgnOicpIDtcbiAgICAgIHJldHVybiB7XG4gICAgICAgIHJlYXNvbixcbiAgICAgICAgY2F0ZWdvcnksXG4gICAgICAgIHF1YW50aXR5LFxuICAgICAgfTtcbiAgICB9KTtcbiAgfVxuXG4gIC8qKlxuICAgKiBTZW5kcyBjbGllbnQgcmVwb3J0cyBhcyBhbiBlbnZlbG9wZS5cbiAgICovXG4gICBfZmx1c2hPdXRjb21lcygpIHtcbiAgICBkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEICYmIGRlYnVnTG9nZ2VyLmRlYnVnLmxvZygnRmx1c2hpbmcgb3V0Y29tZXMuLi4nKTtcblxuICAgIGNvbnN0IG91dGNvbWVzID0gdGhpcy5fY2xlYXJPdXRjb21lcygpO1xuXG4gICAgaWYgKG91dGNvbWVzLmxlbmd0aCA9PT0gMCkge1xuICAgICAgZGVidWdCdWlsZC5ERUJVR19CVUlMRCAmJiBkZWJ1Z0xvZ2dlci5kZWJ1Zy5sb2coJ05vIG91dGNvbWVzIHRvIHNlbmQnKTtcbiAgICAgIHJldHVybjtcbiAgICB9XG5cbiAgICAvLyBUaGlzIGlzIHJlYWxseSB0aGUgb25seSBwbGFjZSB3aGVyZSB3ZSB3YW50IHRvIGNoZWNrIGZvciBhIERTTiBhbmQgb25seSBzZW5kIG91dGNvbWVzIHRoZW5cbiAgICBpZiAoIXRoaXMuX2Rzbikge1xuICAgICAgZGVidWdCdWlsZC5ERUJVR19CVUlMRCAmJiBkZWJ1Z0xvZ2dlci5kZWJ1Zy5sb2coJ05vIGRzbiBwcm92aWRlZCwgd2lsbCBub3Qgc2VuZCBvdXRjb21lcycpO1xuICAgICAgcmV0dXJuO1xuICAgIH1cblxuICAgIGRlYnVnQnVpbGQuREVCVUdfQlVJTEQgJiYgZGVidWdMb2dnZXIuZGVidWcubG9nKCdTZW5kaW5nIG91dGNvbWVzOicsIG91dGNvbWVzKTtcblxuICAgIGNvbnN0IGVudmVsb3BlID0gY2xpZW50cmVwb3J0LmNyZWF0ZUNsaWVudFJlcG9ydEVudmVsb3BlKG91dGNvbWVzLCB0aGlzLl9vcHRpb25zLnR1bm5lbCAmJiBkc24uZHNuVG9TdHJpbmcodGhpcy5fZHNuKSk7XG5cbiAgICAvLyBzZW5kRW52ZWxvcGUgc2hvdWxkIG5vdCB0aHJvd1xuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tZmxvYXRpbmctcHJvbWlzZXNcbiAgICB0aGlzLnNlbmRFbnZlbG9wZShlbnZlbG9wZSk7XG4gIH1cblxuICAvKipcbiAgICogQ3JlYXRlcyBhbiB7QGxpbmsgRXZlbnR9IGZyb20gYWxsIGlucHV0cyB0byBgY2FwdHVyZUV4Y2VwdGlvbmAgYW5kIG5vbi1wcmltaXRpdmUgaW5wdXRzIHRvIGBjYXB0dXJlTWVzc2FnZWAuXG4gICAqL1xuXG59XG5cbi8qKlxuICogQGRlcHJlY2F0ZWQgVXNlIGBDbGllbnRgIGluc3RlYWQuIFRoaXMgYWxpYXMgbWF5IGJlIHJlbW92ZWQgaW4gYSBmdXR1cmUgbWFqb3IgdmVyc2lvbi5cbiAqL1xuLy8gVE9ETyh2MTApOiBSZW1vdmVcblxuLyoqXG4gKiBAZGVwcmVjYXRlZCBVc2UgYENsaWVudGAgaW5zdGVhZC4gVGhpcyBhbGlhcyBtYXkgYmUgcmVtb3ZlZCBpbiBhIGZ1dHVyZSBtYWpvciB2ZXJzaW9uLlxuICovXG4vLyBUT0RPKHYxMCk6IFJlbW92ZVxuY29uc3QgQmFzZUNsaWVudCA9IENsaWVudDtcblxuLyoqXG4gKiBWZXJpZmllcyB0aGF0IHJldHVybiB2YWx1ZSBvZiBjb25maWd1cmVkIGBiZWZvcmVTZW5kYCBvciBgYmVmb3JlU2VuZFRyYW5zYWN0aW9uYCBpcyBvZiBleHBlY3RlZCB0eXBlLCBhbmQgcmV0dXJucyB0aGUgdmFsdWUgaWYgc28uXG4gKi9cbmZ1bmN0aW9uIF92YWxpZGF0ZUJlZm9yZVNlbmRSZXN1bHQoXG4gIGJlZm9yZVNlbmRSZXN1bHQsXG4gIGJlZm9yZVNlbmRMYWJlbCxcbikge1xuICBjb25zdCBpbnZhbGlkVmFsdWVFcnJvciA9IGAke2JlZm9yZVNlbmRMYWJlbH0gbXVzdCByZXR1cm4gXFxgbnVsbFxcYCBvciBhIHZhbGlkIGV2ZW50LmA7XG4gIGlmIChpcy5pc1RoZW5hYmxlKGJlZm9yZVNlbmRSZXN1bHQpKSB7XG4gICAgcmV0dXJuIGJlZm9yZVNlbmRSZXN1bHQudGhlbihcbiAgICAgIGV2ZW50ID0+IHtcbiAgICAgICAgaWYgKCFpcy5pc1BsYWluT2JqZWN0KGV2ZW50KSAmJiBldmVudCAhPT0gbnVsbCkge1xuICAgICAgICAgIHRocm93IF9tYWtlSW50ZXJuYWxFcnJvcihpbnZhbGlkVmFsdWVFcnJvcik7XG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuIGV2ZW50O1xuICAgICAgfSxcbiAgICAgIGUgPT4ge1xuICAgICAgICB0aHJvdyBfbWFrZUludGVybmFsRXJyb3IoYCR7YmVmb3JlU2VuZExhYmVsfSByZWplY3RlZCB3aXRoICR7ZX1gKTtcbiAgICAgIH0sXG4gICAgKTtcbiAgfSBlbHNlIGlmICghaXMuaXNQbGFpbk9iamVjdChiZWZvcmVTZW5kUmVzdWx0KSAmJiBiZWZvcmVTZW5kUmVzdWx0ICE9PSBudWxsKSB7XG4gICAgdGhyb3cgX21ha2VJbnRlcm5hbEVycm9yKGludmFsaWRWYWx1ZUVycm9yKTtcbiAgfVxuICByZXR1cm4gYmVmb3JlU2VuZFJlc3VsdDtcbn1cblxuLyoqXG4gKiBQcm9jZXNzIHRoZSBtYXRjaGluZyBgYmVmb3JlU2VuZFhYWGAgY2FsbGJhY2suXG4gKi9cbmZ1bmN0aW9uIHByb2Nlc3NCZWZvcmVTZW5kKFxuICBjbGllbnQsXG4gIG9wdGlvbnMsXG4gIGV2ZW50LFxuICBoaW50LFxuKSB7XG4gIGNvbnN0IHsgYmVmb3JlU2VuZCwgYmVmb3JlU2VuZFRyYW5zYWN0aW9uLCBiZWZvcmVTZW5kU3BhbiB9ID0gb3B0aW9ucztcbiAgbGV0IHByb2Nlc3NlZEV2ZW50ID0gZXZlbnQ7XG5cbiAgaWYgKGlzRXJyb3JFdmVudChwcm9jZXNzZWRFdmVudCkgJiYgYmVmb3JlU2VuZCkge1xuICAgIHJldHVybiBiZWZvcmVTZW5kKHByb2Nlc3NlZEV2ZW50LCBoaW50KTtcbiAgfVxuXG4gIGlmIChpc1RyYW5zYWN0aW9uRXZlbnQocHJvY2Vzc2VkRXZlbnQpKSB7XG4gICAgaWYgKGJlZm9yZVNlbmRTcGFuKSB7XG4gICAgICAvLyBwcm9jZXNzIHJvb3Qgc3BhblxuICAgICAgY29uc3QgcHJvY2Vzc2VkUm9vdFNwYW5Kc29uID0gYmVmb3JlU2VuZFNwYW4odHJhbnNhY3Rpb25FdmVudC5jb252ZXJ0VHJhbnNhY3Rpb25FdmVudFRvU3Bhbkpzb24ocHJvY2Vzc2VkRXZlbnQpKTtcbiAgICAgIGlmICghcHJvY2Vzc2VkUm9vdFNwYW5Kc29uKSB7XG4gICAgICAgIHNwYW5VdGlscy5zaG93U3BhbkRyb3BXYXJuaW5nKCk7XG4gICAgICB9IGVsc2Uge1xuICAgICAgICAvLyB1cGRhdGUgZXZlbnQgd2l0aCBwcm9jZXNzZWQgcm9vdCBzcGFuIHZhbHVlc1xuICAgICAgICBwcm9jZXNzZWRFdmVudCA9IG1lcmdlLm1lcmdlKGV2ZW50LCB0cmFuc2FjdGlvbkV2ZW50LmNvbnZlcnRTcGFuSnNvblRvVHJhbnNhY3Rpb25FdmVudChwcm9jZXNzZWRSb290U3Bhbkpzb24pKTtcbiAgICAgIH1cblxuICAgICAgLy8gcHJvY2VzcyBjaGlsZCBzcGFuc1xuICAgICAgaWYgKHByb2Nlc3NlZEV2ZW50LnNwYW5zKSB7XG4gICAgICAgIGNvbnN0IHByb2Nlc3NlZFNwYW5zID0gW107XG4gICAgICAgIGZvciAoY29uc3Qgc3BhbiBvZiBwcm9jZXNzZWRFdmVudC5zcGFucykge1xuICAgICAgICAgIGNvbnN0IHByb2Nlc3NlZFNwYW4gPSBiZWZvcmVTZW5kU3BhbihzcGFuKTtcbiAgICAgICAgICBpZiAoIXByb2Nlc3NlZFNwYW4pIHtcbiAgICAgICAgICAgIHNwYW5VdGlscy5zaG93U3BhbkRyb3BXYXJuaW5nKCk7XG4gICAgICAgICAgICBwcm9jZXNzZWRTcGFucy5wdXNoKHNwYW4pO1xuICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICBwcm9jZXNzZWRTcGFucy5wdXNoKHByb2Nlc3NlZFNwYW4pO1xuICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgICBwcm9jZXNzZWRFdmVudC5zcGFucyA9IHByb2Nlc3NlZFNwYW5zO1xuICAgICAgfVxuICAgIH1cblxuICAgIGlmIChiZWZvcmVTZW5kVHJhbnNhY3Rpb24pIHtcbiAgICAgIGlmIChwcm9jZXNzZWRFdmVudC5zcGFucykge1xuICAgICAgICAvLyBXZSBzdG9yZSB0aGUgIyBvZiBzcGFucyBiZWZvcmUgcHJvY2Vzc2luZyBpbiBTREsgbWV0YWRhdGEsXG4gICAgICAgIC8vIHNvIHdlIGNhbiBjb21wYXJlIGl0IGFmdGVyd2FyZHMgdG8gZGV0ZXJtaW5lIGhvdyBtYW55IHNwYW5zIHdlcmUgZHJvcHBlZFxuICAgICAgICBjb25zdCBzcGFuQ291bnRCZWZvcmUgPSBwcm9jZXNzZWRFdmVudC5zcGFucy5sZW5ndGg7XG4gICAgICAgIHByb2Nlc3NlZEV2ZW50LnNka1Byb2Nlc3NpbmdNZXRhZGF0YSA9IHtcbiAgICAgICAgICAuLi5ldmVudC5zZGtQcm9jZXNzaW5nTWV0YWRhdGEsXG4gICAgICAgICAgc3BhbkNvdW50QmVmb3JlUHJvY2Vzc2luZzogc3BhbkNvdW50QmVmb3JlLFxuICAgICAgICB9O1xuICAgICAgfVxuICAgICAgcmV0dXJuIGJlZm9yZVNlbmRUcmFuc2FjdGlvbihwcm9jZXNzZWRFdmVudCAsIGhpbnQpO1xuICAgIH1cbiAgfVxuXG4gIHJldHVybiBwcm9jZXNzZWRFdmVudDtcbn1cblxuZnVuY3Rpb24gaXNFcnJvckV2ZW50KGV2ZW50KSB7XG4gIHJldHVybiBldmVudC50eXBlID09PSB1bmRlZmluZWQ7XG59XG5cbmZ1bmN0aW9uIGlzVHJhbnNhY3Rpb25FdmVudChldmVudCkge1xuICByZXR1cm4gZXZlbnQudHlwZSA9PT0gJ3RyYW5zYWN0aW9uJztcbn1cblxuLyoqIEV4dHJhY3QgdHJhY2UgaW5mb3JtYXRpb24gZnJvbSBzY29wZSAqL1xuZnVuY3Rpb24gX2dldFRyYWNlSW5mb0Zyb21TY29wZShcbiAgY2xpZW50LFxuICBzY29wZSxcbikge1xuICBpZiAoIXNjb3BlKSB7XG4gICAgcmV0dXJuIFt1bmRlZmluZWQsIHVuZGVmaW5lZF07XG4gIH1cblxuICByZXR1cm4gY3VycmVudFNjb3Blcy53aXRoU2NvcGUoc2NvcGUsICgpID0+IHtcbiAgICBjb25zdCBzcGFuID0gc3BhblV0aWxzLmdldEFjdGl2ZVNwYW4oKTtcbiAgICBjb25zdCB0cmFjZUNvbnRleHQgPSBzcGFuID8gc3BhblV0aWxzLnNwYW5Ub1RyYWNlQ29udGV4dChzcGFuKSA6IGN1cnJlbnRTY29wZXMuZ2V0VHJhY2VDb250ZXh0RnJvbVNjb3BlKHNjb3BlKTtcbiAgICBjb25zdCBkeW5hbWljU2FtcGxpbmdDb250ZXh0JDEgPSBzcGFuXG4gICAgICA/IGR5bmFtaWNTYW1wbGluZ0NvbnRleHQuZ2V0RHluYW1pY1NhbXBsaW5nQ29udGV4dEZyb21TcGFuKHNwYW4pXG4gICAgICA6IGR5bmFtaWNTYW1wbGluZ0NvbnRleHQuZ2V0RHluYW1pY1NhbXBsaW5nQ29udGV4dEZyb21TY29wZShjbGllbnQsIHNjb3BlKTtcbiAgICByZXR1cm4gW2R5bmFtaWNTYW1wbGluZ0NvbnRleHQkMSwgdHJhY2VDb250ZXh0XTtcbiAgfSk7XG59XG5cbmV4cG9ydHMuQmFzZUNsaWVudCA9IEJhc2VDbGllbnQ7XG5leHBvcnRzLkNsaWVudCA9IENsaWVudDtcbmV4cG9ydHMuX2dldFRyYWNlSW5mb0Zyb21TY29wZSA9IF9nZXRUcmFjZUluZm9Gcm9tU2NvcGU7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1jbGllbnQuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/client.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/constants.js":
/*!*************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/constants.js ***!
  \*************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst DEFAULT_ENVIRONMENT = 'production';\n\nexports.DEFAULT_ENVIRONMENT = DEFAULT_ENVIRONMENT;\n//# sourceMappingURL=constants.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9jb25zdGFudHMuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEU7O0FBRUEsMkJBQTJCO0FBQzNCIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvY29uc3RhbnRzLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBERUZBVUxUX0VOVklST05NRU5UID0gJ3Byb2R1Y3Rpb24nO1xuXG5leHBvcnRzLkRFRkFVTFRfRU5WSVJPTk1FTlQgPSBERUZBVUxUX0VOVklST05NRU5UO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9Y29uc3RhbnRzLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/constants.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js":
/*!*****************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js ***!
  \*****************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst index = __webpack_require__(/*! ./asyncContext/index.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/asyncContext/index.js\");\nconst carrier = __webpack_require__(/*! ./carrier.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/carrier.js\");\nconst scope = __webpack_require__(/*! ./scope.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/scope.js\");\nconst propagationContext = __webpack_require__(/*! ./utils/propagationContext.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/propagationContext.js\");\n\n/**\n * Get the currently active scope.\n */\nfunction getCurrentScope() {\n  const carrier$1 = carrier.getMainCarrier();\n  const acs = index.getAsyncContextStrategy(carrier$1);\n  return acs.getCurrentScope();\n}\n\n/**\n * Get the currently active isolation scope.\n * The isolation scope is active for the current execution context.\n */\nfunction getIsolationScope() {\n  const carrier$1 = carrier.getMainCarrier();\n  const acs = index.getAsyncContextStrategy(carrier$1);\n  return acs.getIsolationScope();\n}\n\n/**\n * Get the global scope.\n * This scope is applied to _all_ events.\n */\nfunction getGlobalScope() {\n  return carrier.getGlobalSingleton('globalScope', () => new scope.Scope());\n}\n\n/**\n * Creates a new scope with and executes the given operation within.\n * The scope is automatically removed once the operation\n * finishes or throws.\n */\n\n/**\n * Either creates a new active scope, or sets the given scope as active scope in the given callback.\n */\nfunction withScope(\n  ...rest\n) {\n  const carrier$1 = carrier.getMainCarrier();\n  const acs = index.getAsyncContextStrategy(carrier$1);\n\n  // If a scope is defined, we want to make this the active scope instead of the default one\n  if (rest.length === 2) {\n    const [scope, callback] = rest;\n\n    if (!scope) {\n      return acs.withScope(callback);\n    }\n\n    return acs.withSetScope(scope, callback);\n  }\n\n  return acs.withScope(rest[0]);\n}\n\n/**\n * Attempts to fork the current isolation scope and the current scope based on the current async context strategy. If no\n * async context strategy is set, the isolation scope and the current scope will not be forked (this is currently the\n * case, for example, in the browser).\n *\n * Usage of this function in environments without async context strategy is discouraged and may lead to unexpected behaviour.\n *\n * This function is intended for Sentry SDK and SDK integration development. It is not recommended to be used in \"normal\"\n * applications directly because it comes with pitfalls. Use at your own risk!\n */\n\n/**\n * Either creates a new active isolation scope, or sets the given isolation scope as active scope in the given callback.\n */\nfunction withIsolationScope(\n  ...rest\n\n) {\n  const carrier$1 = carrier.getMainCarrier();\n  const acs = index.getAsyncContextStrategy(carrier$1);\n\n  // If a scope is defined, we want to make this the active scope instead of the default one\n  if (rest.length === 2) {\n    const [isolationScope, callback] = rest;\n\n    if (!isolationScope) {\n      return acs.withIsolationScope(callback);\n    }\n\n    return acs.withSetIsolationScope(isolationScope, callback);\n  }\n\n  return acs.withIsolationScope(rest[0]);\n}\n\n/**\n * Get the currently active client.\n */\nfunction getClient() {\n  return getCurrentScope().getClient();\n}\n\n/**\n * Get a trace context for the given scope.\n */\nfunction getTraceContextFromScope(scope) {\n  const propagationContext$1 = scope.getPropagationContext();\n\n  const { traceId, parentSpanId, propagationSpanId } = propagationContext$1;\n\n  const traceContext = {\n    trace_id: traceId,\n    span_id: propagationSpanId || propagationContext.generateSpanId(),\n  };\n\n  if (parentSpanId) {\n    traceContext.parent_span_id = parentSpanId;\n  }\n\n  return traceContext;\n}\n\nexports.getClient = getClient;\nexports.getCurrentScope = getCurrentScope;\nexports.getGlobalScope = getGlobalScope;\nexports.getIsolationScope = getIsolationScope;\nexports.getTraceContextFromScope = getTraceContextFromScope;\nexports.withIsolationScope = withIsolationScope;\nexports.withScope = withScope;\n//# sourceMappingURL=currentScopes.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9jdXJyZW50U2NvcGVzLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLGNBQWMsbUJBQU8sQ0FBQyx5SUFBeUI7QUFDL0MsZ0JBQWdCLG1CQUFPLENBQUMsbUhBQWM7QUFDdEMsY0FBYyxtQkFBTyxDQUFDLCtHQUFZO0FBQ2xDLDJCQUEyQixtQkFBTyxDQUFDLHFKQUErQjs7QUFFbEU7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLFVBQVUsMkNBQTJDOztBQUVyRDtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQSxpQkFBaUI7QUFDakIsdUJBQXVCO0FBQ3ZCLHNCQUFzQjtBQUN0Qix5QkFBeUI7QUFDekIsZ0NBQWdDO0FBQ2hDLDBCQUEwQjtBQUMxQixpQkFBaUI7QUFDakIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9jdXJyZW50U2NvcGVzLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBpbmRleCA9IHJlcXVpcmUoJy4vYXN5bmNDb250ZXh0L2luZGV4LmpzJyk7XG5jb25zdCBjYXJyaWVyID0gcmVxdWlyZSgnLi9jYXJyaWVyLmpzJyk7XG5jb25zdCBzY29wZSA9IHJlcXVpcmUoJy4vc2NvcGUuanMnKTtcbmNvbnN0IHByb3BhZ2F0aW9uQ29udGV4dCA9IHJlcXVpcmUoJy4vdXRpbHMvcHJvcGFnYXRpb25Db250ZXh0LmpzJyk7XG5cbi8qKlxuICogR2V0IHRoZSBjdXJyZW50bHkgYWN0aXZlIHNjb3BlLlxuICovXG5mdW5jdGlvbiBnZXRDdXJyZW50U2NvcGUoKSB7XG4gIGNvbnN0IGNhcnJpZXIkMSA9IGNhcnJpZXIuZ2V0TWFpbkNhcnJpZXIoKTtcbiAgY29uc3QgYWNzID0gaW5kZXguZ2V0QXN5bmNDb250ZXh0U3RyYXRlZ3koY2FycmllciQxKTtcbiAgcmV0dXJuIGFjcy5nZXRDdXJyZW50U2NvcGUoKTtcbn1cblxuLyoqXG4gKiBHZXQgdGhlIGN1cnJlbnRseSBhY3RpdmUgaXNvbGF0aW9uIHNjb3BlLlxuICogVGhlIGlzb2xhdGlvbiBzY29wZSBpcyBhY3RpdmUgZm9yIHRoZSBjdXJyZW50IGV4ZWN1dGlvbiBjb250ZXh0LlxuICovXG5mdW5jdGlvbiBnZXRJc29sYXRpb25TY29wZSgpIHtcbiAgY29uc3QgY2FycmllciQxID0gY2Fycmllci5nZXRNYWluQ2FycmllcigpO1xuICBjb25zdCBhY3MgPSBpbmRleC5nZXRBc3luY0NvbnRleHRTdHJhdGVneShjYXJyaWVyJDEpO1xuICByZXR1cm4gYWNzLmdldElzb2xhdGlvblNjb3BlKCk7XG59XG5cbi8qKlxuICogR2V0IHRoZSBnbG9iYWwgc2NvcGUuXG4gKiBUaGlzIHNjb3BlIGlzIGFwcGxpZWQgdG8gX2FsbF8gZXZlbnRzLlxuICovXG5mdW5jdGlvbiBnZXRHbG9iYWxTY29wZSgpIHtcbiAgcmV0dXJuIGNhcnJpZXIuZ2V0R2xvYmFsU2luZ2xldG9uKCdnbG9iYWxTY29wZScsICgpID0+IG5ldyBzY29wZS5TY29wZSgpKTtcbn1cblxuLyoqXG4gKiBDcmVhdGVzIGEgbmV3IHNjb3BlIHdpdGggYW5kIGV4ZWN1dGVzIHRoZSBnaXZlbiBvcGVyYXRpb24gd2l0aGluLlxuICogVGhlIHNjb3BlIGlzIGF1dG9tYXRpY2FsbHkgcmVtb3ZlZCBvbmNlIHRoZSBvcGVyYXRpb25cbiAqIGZpbmlzaGVzIG9yIHRocm93cy5cbiAqL1xuXG4vKipcbiAqIEVpdGhlciBjcmVhdGVzIGEgbmV3IGFjdGl2ZSBzY29wZSwgb3Igc2V0cyB0aGUgZ2l2ZW4gc2NvcGUgYXMgYWN0aXZlIHNjb3BlIGluIHRoZSBnaXZlbiBjYWxsYmFjay5cbiAqL1xuZnVuY3Rpb24gd2l0aFNjb3BlKFxuICAuLi5yZXN0XG4pIHtcbiAgY29uc3QgY2FycmllciQxID0gY2Fycmllci5nZXRNYWluQ2FycmllcigpO1xuICBjb25zdCBhY3MgPSBpbmRleC5nZXRBc3luY0NvbnRleHRTdHJhdGVneShjYXJyaWVyJDEpO1xuXG4gIC8vIElmIGEgc2NvcGUgaXMgZGVmaW5lZCwgd2Ugd2FudCB0byBtYWtlIHRoaXMgdGhlIGFjdGl2ZSBzY29wZSBpbnN0ZWFkIG9mIHRoZSBkZWZhdWx0IG9uZVxuICBpZiAocmVzdC5sZW5ndGggPT09IDIpIHtcbiAgICBjb25zdCBbc2NvcGUsIGNhbGxiYWNrXSA9IHJlc3Q7XG5cbiAgICBpZiAoIXNjb3BlKSB7XG4gICAgICByZXR1cm4gYWNzLndpdGhTY29wZShjYWxsYmFjayk7XG4gICAgfVxuXG4gICAgcmV0dXJuIGFjcy53aXRoU2V0U2NvcGUoc2NvcGUsIGNhbGxiYWNrKTtcbiAgfVxuXG4gIHJldHVybiBhY3Mud2l0aFNjb3BlKHJlc3RbMF0pO1xufVxuXG4vKipcbiAqIEF0dGVtcHRzIHRvIGZvcmsgdGhlIGN1cnJlbnQgaXNvbGF0aW9uIHNjb3BlIGFuZCB0aGUgY3VycmVudCBzY29wZSBiYXNlZCBvbiB0aGUgY3VycmVudCBhc3luYyBjb250ZXh0IHN0cmF0ZWd5LiBJZiBub1xuICogYXN5bmMgY29udGV4dCBzdHJhdGVneSBpcyBzZXQsIHRoZSBpc29sYXRpb24gc2NvcGUgYW5kIHRoZSBjdXJyZW50IHNjb3BlIHdpbGwgbm90IGJlIGZvcmtlZCAodGhpcyBpcyBjdXJyZW50bHkgdGhlXG4gKiBjYXNlLCBmb3IgZXhhbXBsZSwgaW4gdGhlIGJyb3dzZXIpLlxuICpcbiAqIFVzYWdlIG9mIHRoaXMgZnVuY3Rpb24gaW4gZW52aXJvbm1lbnRzIHdpdGhvdXQgYXN5bmMgY29udGV4dCBzdHJhdGVneSBpcyBkaXNjb3VyYWdlZCBhbmQgbWF5IGxlYWQgdG8gdW5leHBlY3RlZCBiZWhhdmlvdXIuXG4gKlxuICogVGhpcyBmdW5jdGlvbiBpcyBpbnRlbmRlZCBmb3IgU2VudHJ5IFNESyBhbmQgU0RLIGludGVncmF0aW9uIGRldmVsb3BtZW50LiBJdCBpcyBub3QgcmVjb21tZW5kZWQgdG8gYmUgdXNlZCBpbiBcIm5vcm1hbFwiXG4gKiBhcHBsaWNhdGlvbnMgZGlyZWN0bHkgYmVjYXVzZSBpdCBjb21lcyB3aXRoIHBpdGZhbGxzLiBVc2UgYXQgeW91ciBvd24gcmlzayFcbiAqL1xuXG4vKipcbiAqIEVpdGhlciBjcmVhdGVzIGEgbmV3IGFjdGl2ZSBpc29sYXRpb24gc2NvcGUsIG9yIHNldHMgdGhlIGdpdmVuIGlzb2xhdGlvbiBzY29wZSBhcyBhY3RpdmUgc2NvcGUgaW4gdGhlIGdpdmVuIGNhbGxiYWNrLlxuICovXG5mdW5jdGlvbiB3aXRoSXNvbGF0aW9uU2NvcGUoXG4gIC4uLnJlc3RcblxuKSB7XG4gIGNvbnN0IGNhcnJpZXIkMSA9IGNhcnJpZXIuZ2V0TWFpbkNhcnJpZXIoKTtcbiAgY29uc3QgYWNzID0gaW5kZXguZ2V0QXN5bmNDb250ZXh0U3RyYXRlZ3koY2FycmllciQxKTtcblxuICAvLyBJZiBhIHNjb3BlIGlzIGRlZmluZWQsIHdlIHdhbnQgdG8gbWFrZSB0aGlzIHRoZSBhY3RpdmUgc2NvcGUgaW5zdGVhZCBvZiB0aGUgZGVmYXVsdCBvbmVcbiAgaWYgKHJlc3QubGVuZ3RoID09PSAyKSB7XG4gICAgY29uc3QgW2lzb2xhdGlvblNjb3BlLCBjYWxsYmFja10gPSByZXN0O1xuXG4gICAgaWYgKCFpc29sYXRpb25TY29wZSkge1xuICAgICAgcmV0dXJuIGFjcy53aXRoSXNvbGF0aW9uU2NvcGUoY2FsbGJhY2spO1xuICAgIH1cblxuICAgIHJldHVybiBhY3Mud2l0aFNldElzb2xhdGlvblNjb3BlKGlzb2xhdGlvblNjb3BlLCBjYWxsYmFjayk7XG4gIH1cblxuICByZXR1cm4gYWNzLndpdGhJc29sYXRpb25TY29wZShyZXN0WzBdKTtcbn1cblxuLyoqXG4gKiBHZXQgdGhlIGN1cnJlbnRseSBhY3RpdmUgY2xpZW50LlxuICovXG5mdW5jdGlvbiBnZXRDbGllbnQoKSB7XG4gIHJldHVybiBnZXRDdXJyZW50U2NvcGUoKS5nZXRDbGllbnQoKTtcbn1cblxuLyoqXG4gKiBHZXQgYSB0cmFjZSBjb250ZXh0IGZvciB0aGUgZ2l2ZW4gc2NvcGUuXG4gKi9cbmZ1bmN0aW9uIGdldFRyYWNlQ29udGV4dEZyb21TY29wZShzY29wZSkge1xuICBjb25zdCBwcm9wYWdhdGlvbkNvbnRleHQkMSA9IHNjb3BlLmdldFByb3BhZ2F0aW9uQ29udGV4dCgpO1xuXG4gIGNvbnN0IHsgdHJhY2VJZCwgcGFyZW50U3BhbklkLCBwcm9wYWdhdGlvblNwYW5JZCB9ID0gcHJvcGFnYXRpb25Db250ZXh0JDE7XG5cbiAgY29uc3QgdHJhY2VDb250ZXh0ID0ge1xuICAgIHRyYWNlX2lkOiB0cmFjZUlkLFxuICAgIHNwYW5faWQ6IHByb3BhZ2F0aW9uU3BhbklkIHx8IHByb3BhZ2F0aW9uQ29udGV4dC5nZW5lcmF0ZVNwYW5JZCgpLFxuICB9O1xuXG4gIGlmIChwYXJlbnRTcGFuSWQpIHtcbiAgICB0cmFjZUNvbnRleHQucGFyZW50X3NwYW5faWQgPSBwYXJlbnRTcGFuSWQ7XG4gIH1cblxuICByZXR1cm4gdHJhY2VDb250ZXh0O1xufVxuXG5leHBvcnRzLmdldENsaWVudCA9IGdldENsaWVudDtcbmV4cG9ydHMuZ2V0Q3VycmVudFNjb3BlID0gZ2V0Q3VycmVudFNjb3BlO1xuZXhwb3J0cy5nZXRHbG9iYWxTY29wZSA9IGdldEdsb2JhbFNjb3BlO1xuZXhwb3J0cy5nZXRJc29sYXRpb25TY29wZSA9IGdldElzb2xhdGlvblNjb3BlO1xuZXhwb3J0cy5nZXRUcmFjZUNvbnRleHRGcm9tU2NvcGUgPSBnZXRUcmFjZUNvbnRleHRGcm9tU2NvcGU7XG5leHBvcnRzLndpdGhJc29sYXRpb25TY29wZSA9IHdpdGhJc29sYXRpb25TY29wZTtcbmV4cG9ydHMud2l0aFNjb3BlID0gd2l0aFNjb3BlO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9Y3VycmVudFNjb3Blcy5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js":
/*!***************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js ***!
  \***************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n/**\n * This serves as a build time flag that will be true by default, but false in non-debug builds or if users replace `__SENTRY_DEBUG__` in their generated code.\n *\n * ATTENTION: This constant must never cross package boundaries (i.e. be exported) to guarantee that it can be used for tree shaking.\n */\nconst DEBUG_BUILD = ( false || false);\n\nexports.DEBUG_BUILD = DEBUG_BUILD;\n//# sourceMappingURL=debug-build.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9kZWJ1Zy1idWlsZC5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EscUJBQXFCLE1BQXVDLElBQUksS0FBZ0I7O0FBRWhGLG1CQUFtQjtBQUNuQiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL2RlYnVnLWJ1aWxkLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG4vKipcbiAqIFRoaXMgc2VydmVzIGFzIGEgYnVpbGQgdGltZSBmbGFnIHRoYXQgd2lsbCBiZSB0cnVlIGJ5IGRlZmF1bHQsIGJ1dCBmYWxzZSBpbiBub24tZGVidWcgYnVpbGRzIG9yIGlmIHVzZXJzIHJlcGxhY2UgYF9fU0VOVFJZX0RFQlVHX19gIGluIHRoZWlyIGdlbmVyYXRlZCBjb2RlLlxuICpcbiAqIEFUVEVOVElPTjogVGhpcyBjb25zdGFudCBtdXN0IG5ldmVyIGNyb3NzIHBhY2thZ2UgYm91bmRhcmllcyAoaS5lLiBiZSBleHBvcnRlZCkgdG8gZ3VhcmFudGVlIHRoYXQgaXQgY2FuIGJlIHVzZWQgZm9yIHRyZWUgc2hha2luZy5cbiAqL1xuY29uc3QgREVCVUdfQlVJTEQgPSAodHlwZW9mIF9fU0VOVFJZX0RFQlVHX18gPT09ICd1bmRlZmluZWQnIHx8IF9fU0VOVFJZX0RFQlVHX18pO1xuXG5leHBvcnRzLkRFQlVHX0JVSUxEID0gREVCVUdfQlVJTEQ7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1kZWJ1Zy1idWlsZC5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/defaultScopes.js":
/*!*****************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/defaultScopes.js ***!
  \*****************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst carrier = __webpack_require__(/*! ./carrier.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/carrier.js\");\nconst scope = __webpack_require__(/*! ./scope.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/scope.js\");\n\n/** Get the default current scope. */\nfunction getDefaultCurrentScope() {\n  return carrier.getGlobalSingleton('defaultCurrentScope', () => new scope.Scope());\n}\n\n/** Get the default isolation scope. */\nfunction getDefaultIsolationScope() {\n  return carrier.getGlobalSingleton('defaultIsolationScope', () => new scope.Scope());\n}\n\nexports.getDefaultCurrentScope = getDefaultCurrentScope;\nexports.getDefaultIsolationScope = getDefaultIsolationScope;\n//# sourceMappingURL=defaultScopes.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9kZWZhdWx0U2NvcGVzLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLGdCQUFnQixtQkFBTyxDQUFDLG1IQUFjO0FBQ3RDLGNBQWMsbUJBQU8sQ0FBQywrR0FBWTs7QUFFbEM7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsOEJBQThCO0FBQzlCLGdDQUFnQztBQUNoQyIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL2RlZmF1bHRTY29wZXMuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGNhcnJpZXIgPSByZXF1aXJlKCcuL2NhcnJpZXIuanMnKTtcbmNvbnN0IHNjb3BlID0gcmVxdWlyZSgnLi9zY29wZS5qcycpO1xuXG4vKiogR2V0IHRoZSBkZWZhdWx0IGN1cnJlbnQgc2NvcGUuICovXG5mdW5jdGlvbiBnZXREZWZhdWx0Q3VycmVudFNjb3BlKCkge1xuICByZXR1cm4gY2Fycmllci5nZXRHbG9iYWxTaW5nbGV0b24oJ2RlZmF1bHRDdXJyZW50U2NvcGUnLCAoKSA9PiBuZXcgc2NvcGUuU2NvcGUoKSk7XG59XG5cbi8qKiBHZXQgdGhlIGRlZmF1bHQgaXNvbGF0aW9uIHNjb3BlLiAqL1xuZnVuY3Rpb24gZ2V0RGVmYXVsdElzb2xhdGlvblNjb3BlKCkge1xuICByZXR1cm4gY2Fycmllci5nZXRHbG9iYWxTaW5nbGV0b24oJ2RlZmF1bHRJc29sYXRpb25TY29wZScsICgpID0+IG5ldyBzY29wZS5TY29wZSgpKTtcbn1cblxuZXhwb3J0cy5nZXREZWZhdWx0Q3VycmVudFNjb3BlID0gZ2V0RGVmYXVsdEN1cnJlbnRTY29wZTtcbmV4cG9ydHMuZ2V0RGVmYXVsdElzb2xhdGlvblNjb3BlID0gZ2V0RGVmYXVsdElzb2xhdGlvblNjb3BlO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9ZGVmYXVsdFNjb3Blcy5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/defaultScopes.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/envelope.js":
/*!************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/envelope.js ***!
  \************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst dynamicSamplingContext = __webpack_require__(/*! ./tracing/dynamicSamplingContext.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/dynamicSamplingContext.js\");\nconst dsn = __webpack_require__(/*! ./utils/dsn.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/dsn.js\");\nconst envelope = __webpack_require__(/*! ./utils/envelope.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/envelope.js\");\nconst spanUtils = __webpack_require__(/*! ./utils/spanUtils.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanUtils.js\");\n\n/**\n * Apply SdkInfo (name, version, packages, integrations) to the corresponding event key.\n * Merge with existing data if any.\n **/\nfunction enhanceEventWithSdkInfo(event, sdkInfo) {\n  if (!sdkInfo) {\n    return event;\n  }\n  event.sdk = event.sdk || {};\n  event.sdk.name = event.sdk.name || sdkInfo.name;\n  event.sdk.version = event.sdk.version || sdkInfo.version;\n  event.sdk.integrations = [...(event.sdk.integrations || []), ...(sdkInfo.integrations || [])];\n  event.sdk.packages = [...(event.sdk.packages || []), ...(sdkInfo.packages || [])];\n  return event;\n}\n\n/** Creates an envelope from a Session */\nfunction createSessionEnvelope(\n  session,\n  dsn$1,\n  metadata,\n  tunnel,\n) {\n  const sdkInfo = envelope.getSdkMetadataForEnvelopeHeader(metadata);\n  const envelopeHeaders = {\n    sent_at: new Date().toISOString(),\n    ...(sdkInfo && { sdk: sdkInfo }),\n    ...(!!tunnel && dsn$1 && { dsn: dsn.dsnToString(dsn$1) }),\n  };\n\n  const envelopeItem =\n    'aggregates' in session ? [{ type: 'sessions' }, session] : [{ type: 'session' }, session.toJSON()];\n\n  return envelope.createEnvelope(envelopeHeaders, [envelopeItem]);\n}\n\n/**\n * Create an Envelope from an event.\n */\nfunction createEventEnvelope(\n  event,\n  dsn,\n  metadata,\n  tunnel,\n) {\n  const sdkInfo = envelope.getSdkMetadataForEnvelopeHeader(metadata);\n\n  /*\n    Note: Due to TS, event.type may be `replay_event`, theoretically.\n    In practice, we never call `createEventEnvelope` with `replay_event` type,\n    and we'd have to adjust a looot of types to make this work properly.\n    We want to avoid casting this around, as that could lead to bugs (e.g. when we add another type)\n    So the safe choice is to really guard against the replay_event type here.\n  */\n  const eventType = event.type && event.type !== 'replay_event' ? event.type : 'event';\n\n  enhanceEventWithSdkInfo(event, metadata?.sdk);\n\n  const envelopeHeaders = envelope.createEventEnvelopeHeaders(event, sdkInfo, tunnel, dsn);\n\n  // Prevent this data (which, if it exists, was used in earlier steps in the processing pipeline) from being sent to\n  // sentry. (Note: Our use of this property comes and goes with whatever we might be debugging, whatever hacks we may\n  // have temporarily added, etc. Even if we don't happen to be using it at some point in the future, let's not get rid\n  // of this `delete`, lest we miss putting it back in the next time the property is in use.)\n  delete event.sdkProcessingMetadata;\n\n  const eventItem = [{ type: eventType }, event];\n  return envelope.createEnvelope(envelopeHeaders, [eventItem]);\n}\n\n/**\n * Create envelope from Span item.\n *\n * Takes an optional client and runs spans through `beforeSendSpan` if available.\n */\nfunction createSpanEnvelope(spans, client) {\n  function dscHasRequiredProps(dsc) {\n    return !!dsc.trace_id && !!dsc.public_key;\n  }\n\n  // For the moment we'll obtain the DSC from the first span in the array\n  // This might need to be changed if we permit sending multiple spans from\n  // different segments in one envelope\n  const dsc = dynamicSamplingContext.getDynamicSamplingContextFromSpan(spans[0]);\n\n  const dsn$1 = client?.getDsn();\n  const tunnel = client?.getOptions().tunnel;\n\n  const headers = {\n    sent_at: new Date().toISOString(),\n    ...(dscHasRequiredProps(dsc) && { trace: dsc }),\n    ...(!!tunnel && dsn$1 && { dsn: dsn.dsnToString(dsn$1) }),\n  };\n\n  const beforeSendSpan = client?.getOptions().beforeSendSpan;\n  const convertToSpanJSON = beforeSendSpan\n    ? (span) => {\n        const spanJson = spanUtils.spanToJSON(span);\n        const processedSpan = beforeSendSpan(spanJson);\n\n        if (!processedSpan) {\n          spanUtils.showSpanDropWarning();\n          return spanJson;\n        }\n\n        return processedSpan;\n      }\n    : spanUtils.spanToJSON;\n\n  const items = [];\n  for (const span of spans) {\n    const spanJson = convertToSpanJSON(span);\n    if (spanJson) {\n      items.push(envelope.createSpanEnvelopeItem(spanJson));\n    }\n  }\n\n  return envelope.createEnvelope(headers, items);\n}\n\nexports.createEventEnvelope = createEventEnvelope;\nexports.createSessionEnvelope = createSessionEnvelope;\nexports.createSpanEnvelope = createSpanEnvelope;\n//# sourceMappingURL=envelope.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9lbnZlbG9wZS5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSwrQkFBK0IsbUJBQU8sQ0FBQyxpS0FBcUM7QUFDNUUsWUFBWSxtQkFBTyxDQUFDLHVIQUFnQjtBQUNwQyxpQkFBaUIsbUJBQU8sQ0FBQyxpSUFBcUI7QUFDOUMsa0JBQWtCLG1CQUFPLENBQUMsbUlBQXNCOztBQUVoRDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxxQkFBcUIsY0FBYztBQUNuQywrQkFBK0IsNkJBQTZCO0FBQzVEOztBQUVBO0FBQ0EsaUNBQWlDLGtCQUFrQixnQkFBZ0IsaUJBQWlCOztBQUVwRjtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSx1QkFBdUIsaUJBQWlCO0FBQ3hDO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLHNDQUFzQyxZQUFZO0FBQ2xELCtCQUErQiw2QkFBNkI7QUFDNUQ7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQSwyQkFBMkI7QUFDM0IsNkJBQTZCO0FBQzdCLDBCQUEwQjtBQUMxQiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL2VudmVsb3BlLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBkeW5hbWljU2FtcGxpbmdDb250ZXh0ID0gcmVxdWlyZSgnLi90cmFjaW5nL2R5bmFtaWNTYW1wbGluZ0NvbnRleHQuanMnKTtcbmNvbnN0IGRzbiA9IHJlcXVpcmUoJy4vdXRpbHMvZHNuLmpzJyk7XG5jb25zdCBlbnZlbG9wZSA9IHJlcXVpcmUoJy4vdXRpbHMvZW52ZWxvcGUuanMnKTtcbmNvbnN0IHNwYW5VdGlscyA9IHJlcXVpcmUoJy4vdXRpbHMvc3BhblV0aWxzLmpzJyk7XG5cbi8qKlxuICogQXBwbHkgU2RrSW5mbyAobmFtZSwgdmVyc2lvbiwgcGFja2FnZXMsIGludGVncmF0aW9ucykgdG8gdGhlIGNvcnJlc3BvbmRpbmcgZXZlbnQga2V5LlxuICogTWVyZ2Ugd2l0aCBleGlzdGluZyBkYXRhIGlmIGFueS5cbiAqKi9cbmZ1bmN0aW9uIGVuaGFuY2VFdmVudFdpdGhTZGtJbmZvKGV2ZW50LCBzZGtJbmZvKSB7XG4gIGlmICghc2RrSW5mbykge1xuICAgIHJldHVybiBldmVudDtcbiAgfVxuICBldmVudC5zZGsgPSBldmVudC5zZGsgfHwge307XG4gIGV2ZW50LnNkay5uYW1lID0gZXZlbnQuc2RrLm5hbWUgfHwgc2RrSW5mby5uYW1lO1xuICBldmVudC5zZGsudmVyc2lvbiA9IGV2ZW50LnNkay52ZXJzaW9uIHx8IHNka0luZm8udmVyc2lvbjtcbiAgZXZlbnQuc2RrLmludGVncmF0aW9ucyA9IFsuLi4oZXZlbnQuc2RrLmludGVncmF0aW9ucyB8fCBbXSksIC4uLihzZGtJbmZvLmludGVncmF0aW9ucyB8fCBbXSldO1xuICBldmVudC5zZGsucGFja2FnZXMgPSBbLi4uKGV2ZW50LnNkay5wYWNrYWdlcyB8fCBbXSksIC4uLihzZGtJbmZvLnBhY2thZ2VzIHx8IFtdKV07XG4gIHJldHVybiBldmVudDtcbn1cblxuLyoqIENyZWF0ZXMgYW4gZW52ZWxvcGUgZnJvbSBhIFNlc3Npb24gKi9cbmZ1bmN0aW9uIGNyZWF0ZVNlc3Npb25FbnZlbG9wZShcbiAgc2Vzc2lvbixcbiAgZHNuJDEsXG4gIG1ldGFkYXRhLFxuICB0dW5uZWwsXG4pIHtcbiAgY29uc3Qgc2RrSW5mbyA9IGVudmVsb3BlLmdldFNka01ldGFkYXRhRm9yRW52ZWxvcGVIZWFkZXIobWV0YWRhdGEpO1xuICBjb25zdCBlbnZlbG9wZUhlYWRlcnMgPSB7XG4gICAgc2VudF9hdDogbmV3IERhdGUoKS50b0lTT1N0cmluZygpLFxuICAgIC4uLihzZGtJbmZvICYmIHsgc2RrOiBzZGtJbmZvIH0pLFxuICAgIC4uLighIXR1bm5lbCAmJiBkc24kMSAmJiB7IGRzbjogZHNuLmRzblRvU3RyaW5nKGRzbiQxKSB9KSxcbiAgfTtcblxuICBjb25zdCBlbnZlbG9wZUl0ZW0gPVxuICAgICdhZ2dyZWdhdGVzJyBpbiBzZXNzaW9uID8gW3sgdHlwZTogJ3Nlc3Npb25zJyB9LCBzZXNzaW9uXSA6IFt7IHR5cGU6ICdzZXNzaW9uJyB9LCBzZXNzaW9uLnRvSlNPTigpXTtcblxuICByZXR1cm4gZW52ZWxvcGUuY3JlYXRlRW52ZWxvcGUoZW52ZWxvcGVIZWFkZXJzLCBbZW52ZWxvcGVJdGVtXSk7XG59XG5cbi8qKlxuICogQ3JlYXRlIGFuIEVudmVsb3BlIGZyb20gYW4gZXZlbnQuXG4gKi9cbmZ1bmN0aW9uIGNyZWF0ZUV2ZW50RW52ZWxvcGUoXG4gIGV2ZW50LFxuICBkc24sXG4gIG1ldGFkYXRhLFxuICB0dW5uZWwsXG4pIHtcbiAgY29uc3Qgc2RrSW5mbyA9IGVudmVsb3BlLmdldFNka01ldGFkYXRhRm9yRW52ZWxvcGVIZWFkZXIobWV0YWRhdGEpO1xuXG4gIC8qXG4gICAgTm90ZTogRHVlIHRvIFRTLCBldmVudC50eXBlIG1heSBiZSBgcmVwbGF5X2V2ZW50YCwgdGhlb3JldGljYWxseS5cbiAgICBJbiBwcmFjdGljZSwgd2UgbmV2ZXIgY2FsbCBgY3JlYXRlRXZlbnRFbnZlbG9wZWAgd2l0aCBgcmVwbGF5X2V2ZW50YCB0eXBlLFxuICAgIGFuZCB3ZSdkIGhhdmUgdG8gYWRqdXN0IGEgbG9vb3Qgb2YgdHlwZXMgdG8gbWFrZSB0aGlzIHdvcmsgcHJvcGVybHkuXG4gICAgV2Ugd2FudCB0byBhdm9pZCBjYXN0aW5nIHRoaXMgYXJvdW5kLCBhcyB0aGF0IGNvdWxkIGxlYWQgdG8gYnVncyAoZS5nLiB3aGVuIHdlIGFkZCBhbm90aGVyIHR5cGUpXG4gICAgU28gdGhlIHNhZmUgY2hvaWNlIGlzIHRvIHJlYWxseSBndWFyZCBhZ2FpbnN0IHRoZSByZXBsYXlfZXZlbnQgdHlwZSBoZXJlLlxuICAqL1xuICBjb25zdCBldmVudFR5cGUgPSBldmVudC50eXBlICYmIGV2ZW50LnR5cGUgIT09ICdyZXBsYXlfZXZlbnQnID8gZXZlbnQudHlwZSA6ICdldmVudCc7XG5cbiAgZW5oYW5jZUV2ZW50V2l0aFNka0luZm8oZXZlbnQsIG1ldGFkYXRhPy5zZGspO1xuXG4gIGNvbnN0IGVudmVsb3BlSGVhZGVycyA9IGVudmVsb3BlLmNyZWF0ZUV2ZW50RW52ZWxvcGVIZWFkZXJzKGV2ZW50LCBzZGtJbmZvLCB0dW5uZWwsIGRzbik7XG5cbiAgLy8gUHJldmVudCB0aGlzIGRhdGEgKHdoaWNoLCBpZiBpdCBleGlzdHMsIHdhcyB1c2VkIGluIGVhcmxpZXIgc3RlcHMgaW4gdGhlIHByb2Nlc3NpbmcgcGlwZWxpbmUpIGZyb20gYmVpbmcgc2VudCB0b1xuICAvLyBzZW50cnkuIChOb3RlOiBPdXIgdXNlIG9mIHRoaXMgcHJvcGVydHkgY29tZXMgYW5kIGdvZXMgd2l0aCB3aGF0ZXZlciB3ZSBtaWdodCBiZSBkZWJ1Z2dpbmcsIHdoYXRldmVyIGhhY2tzIHdlIG1heVxuICAvLyBoYXZlIHRlbXBvcmFyaWx5IGFkZGVkLCBldGMuIEV2ZW4gaWYgd2UgZG9uJ3QgaGFwcGVuIHRvIGJlIHVzaW5nIGl0IGF0IHNvbWUgcG9pbnQgaW4gdGhlIGZ1dHVyZSwgbGV0J3Mgbm90IGdldCByaWRcbiAgLy8gb2YgdGhpcyBgZGVsZXRlYCwgbGVzdCB3ZSBtaXNzIHB1dHRpbmcgaXQgYmFjayBpbiB0aGUgbmV4dCB0aW1lIHRoZSBwcm9wZXJ0eSBpcyBpbiB1c2UuKVxuICBkZWxldGUgZXZlbnQuc2RrUHJvY2Vzc2luZ01ldGFkYXRhO1xuXG4gIGNvbnN0IGV2ZW50SXRlbSA9IFt7IHR5cGU6IGV2ZW50VHlwZSB9LCBldmVudF07XG4gIHJldHVybiBlbnZlbG9wZS5jcmVhdGVFbnZlbG9wZShlbnZlbG9wZUhlYWRlcnMsIFtldmVudEl0ZW1dKTtcbn1cblxuLyoqXG4gKiBDcmVhdGUgZW52ZWxvcGUgZnJvbSBTcGFuIGl0ZW0uXG4gKlxuICogVGFrZXMgYW4gb3B0aW9uYWwgY2xpZW50IGFuZCBydW5zIHNwYW5zIHRocm91Z2ggYGJlZm9yZVNlbmRTcGFuYCBpZiBhdmFpbGFibGUuXG4gKi9cbmZ1bmN0aW9uIGNyZWF0ZVNwYW5FbnZlbG9wZShzcGFucywgY2xpZW50KSB7XG4gIGZ1bmN0aW9uIGRzY0hhc1JlcXVpcmVkUHJvcHMoZHNjKSB7XG4gICAgcmV0dXJuICEhZHNjLnRyYWNlX2lkICYmICEhZHNjLnB1YmxpY19rZXk7XG4gIH1cblxuICAvLyBGb3IgdGhlIG1vbWVudCB3ZSdsbCBvYnRhaW4gdGhlIERTQyBmcm9tIHRoZSBmaXJzdCBzcGFuIGluIHRoZSBhcnJheVxuICAvLyBUaGlzIG1pZ2h0IG5lZWQgdG8gYmUgY2hhbmdlZCBpZiB3ZSBwZXJtaXQgc2VuZGluZyBtdWx0aXBsZSBzcGFucyBmcm9tXG4gIC8vIGRpZmZlcmVudCBzZWdtZW50cyBpbiBvbmUgZW52ZWxvcGVcbiAgY29uc3QgZHNjID0gZHluYW1pY1NhbXBsaW5nQ29udGV4dC5nZXREeW5hbWljU2FtcGxpbmdDb250ZXh0RnJvbVNwYW4oc3BhbnNbMF0pO1xuXG4gIGNvbnN0IGRzbiQxID0gY2xpZW50Py5nZXREc24oKTtcbiAgY29uc3QgdHVubmVsID0gY2xpZW50Py5nZXRPcHRpb25zKCkudHVubmVsO1xuXG4gIGNvbnN0IGhlYWRlcnMgPSB7XG4gICAgc2VudF9hdDogbmV3IERhdGUoKS50b0lTT1N0cmluZygpLFxuICAgIC4uLihkc2NIYXNSZXF1aXJlZFByb3BzKGRzYykgJiYgeyB0cmFjZTogZHNjIH0pLFxuICAgIC4uLighIXR1bm5lbCAmJiBkc24kMSAmJiB7IGRzbjogZHNuLmRzblRvU3RyaW5nKGRzbiQxKSB9KSxcbiAgfTtcblxuICBjb25zdCBiZWZvcmVTZW5kU3BhbiA9IGNsaWVudD8uZ2V0T3B0aW9ucygpLmJlZm9yZVNlbmRTcGFuO1xuICBjb25zdCBjb252ZXJ0VG9TcGFuSlNPTiA9IGJlZm9yZVNlbmRTcGFuXG4gICAgPyAoc3BhbikgPT4ge1xuICAgICAgICBjb25zdCBzcGFuSnNvbiA9IHNwYW5VdGlscy5zcGFuVG9KU09OKHNwYW4pO1xuICAgICAgICBjb25zdCBwcm9jZXNzZWRTcGFuID0gYmVmb3JlU2VuZFNwYW4oc3Bhbkpzb24pO1xuXG4gICAgICAgIGlmICghcHJvY2Vzc2VkU3Bhbikge1xuICAgICAgICAgIHNwYW5VdGlscy5zaG93U3BhbkRyb3BXYXJuaW5nKCk7XG4gICAgICAgICAgcmV0dXJuIHNwYW5Kc29uO1xuICAgICAgICB9XG5cbiAgICAgICAgcmV0dXJuIHByb2Nlc3NlZFNwYW47XG4gICAgICB9XG4gICAgOiBzcGFuVXRpbHMuc3BhblRvSlNPTjtcblxuICBjb25zdCBpdGVtcyA9IFtdO1xuICBmb3IgKGNvbnN0IHNwYW4gb2Ygc3BhbnMpIHtcbiAgICBjb25zdCBzcGFuSnNvbiA9IGNvbnZlcnRUb1NwYW5KU09OKHNwYW4pO1xuICAgIGlmIChzcGFuSnNvbikge1xuICAgICAgaXRlbXMucHVzaChlbnZlbG9wZS5jcmVhdGVTcGFuRW52ZWxvcGVJdGVtKHNwYW5Kc29uKSk7XG4gICAgfVxuICB9XG5cbiAgcmV0dXJuIGVudmVsb3BlLmNyZWF0ZUVudmVsb3BlKGhlYWRlcnMsIGl0ZW1zKTtcbn1cblxuZXhwb3J0cy5jcmVhdGVFdmVudEVudmVsb3BlID0gY3JlYXRlRXZlbnRFbnZlbG9wZTtcbmV4cG9ydHMuY3JlYXRlU2Vzc2lvbkVudmVsb3BlID0gY3JlYXRlU2Vzc2lvbkVudmVsb3BlO1xuZXhwb3J0cy5jcmVhdGVTcGFuRW52ZWxvcGUgPSBjcmVhdGVTcGFuRW52ZWxvcGU7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1lbnZlbG9wZS5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/envelope.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/eventProcessors.js":
/*!*******************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/eventProcessors.js ***!
  \*******************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst debugBuild = __webpack_require__(/*! ./debug-build.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst debugLogger = __webpack_require__(/*! ./utils/debug-logger.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst is = __webpack_require__(/*! ./utils/is.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js\");\nconst syncpromise = __webpack_require__(/*! ./utils/syncpromise.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/syncpromise.js\");\n\n/**\n * Process an array of event processors, returning the processed event (or `null` if the event was dropped).\n */\nfunction notifyEventProcessors(\n  processors,\n  event,\n  hint,\n  index = 0,\n) {\n  return new syncpromise.SyncPromise((resolve, reject) => {\n    const processor = processors[index];\n    if (event === null || typeof processor !== 'function') {\n      resolve(event);\n    } else {\n      const result = processor({ ...event }, hint) ;\n\n      debugBuild.DEBUG_BUILD && processor.id && result === null && debugLogger.debug.log(`Event processor \"${processor.id}\" dropped event`);\n\n      if (is.isThenable(result)) {\n        void result\n          .then(final => notifyEventProcessors(processors, final, hint, index + 1).then(resolve))\n          .then(null, reject);\n      } else {\n        void notifyEventProcessors(processors, result, hint, index + 1)\n          .then(resolve)\n          .then(null, reject);\n      }\n    }\n  });\n}\n\nexports.notifyEventProcessors = notifyEventProcessors;\n//# sourceMappingURL=eventProcessors.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9ldmVudFByb2Nlc3NvcnMuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsbUJBQW1CLG1CQUFPLENBQUMsMkhBQWtCO0FBQzdDLG9CQUFvQixtQkFBTyxDQUFDLHlJQUF5QjtBQUNyRCxXQUFXLG1CQUFPLENBQUMscUhBQWU7QUFDbEMsb0JBQW9CLG1CQUFPLENBQUMsdUlBQXdCOztBQUVwRDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLE1BQU07QUFDTixpQ0FBaUMsVUFBVTs7QUFFM0MsNkdBQTZHLGFBQWE7O0FBRTFIO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsUUFBUTtBQUNSO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxHQUFHO0FBQ0g7O0FBRUEsNkJBQTZCO0FBQzdCIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvZXZlbnRQcm9jZXNzb3JzLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBkZWJ1Z0J1aWxkID0gcmVxdWlyZSgnLi9kZWJ1Zy1idWlsZC5qcycpO1xuY29uc3QgZGVidWdMb2dnZXIgPSByZXF1aXJlKCcuL3V0aWxzL2RlYnVnLWxvZ2dlci5qcycpO1xuY29uc3QgaXMgPSByZXF1aXJlKCcuL3V0aWxzL2lzLmpzJyk7XG5jb25zdCBzeW5jcHJvbWlzZSA9IHJlcXVpcmUoJy4vdXRpbHMvc3luY3Byb21pc2UuanMnKTtcblxuLyoqXG4gKiBQcm9jZXNzIGFuIGFycmF5IG9mIGV2ZW50IHByb2Nlc3NvcnMsIHJldHVybmluZyB0aGUgcHJvY2Vzc2VkIGV2ZW50IChvciBgbnVsbGAgaWYgdGhlIGV2ZW50IHdhcyBkcm9wcGVkKS5cbiAqL1xuZnVuY3Rpb24gbm90aWZ5RXZlbnRQcm9jZXNzb3JzKFxuICBwcm9jZXNzb3JzLFxuICBldmVudCxcbiAgaGludCxcbiAgaW5kZXggPSAwLFxuKSB7XG4gIHJldHVybiBuZXcgc3luY3Byb21pc2UuU3luY1Byb21pc2UoKHJlc29sdmUsIHJlamVjdCkgPT4ge1xuICAgIGNvbnN0IHByb2Nlc3NvciA9IHByb2Nlc3NvcnNbaW5kZXhdO1xuICAgIGlmIChldmVudCA9PT0gbnVsbCB8fCB0eXBlb2YgcHJvY2Vzc29yICE9PSAnZnVuY3Rpb24nKSB7XG4gICAgICByZXNvbHZlKGV2ZW50KTtcbiAgICB9IGVsc2Uge1xuICAgICAgY29uc3QgcmVzdWx0ID0gcHJvY2Vzc29yKHsgLi4uZXZlbnQgfSwgaGludCkgO1xuXG4gICAgICBkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEICYmIHByb2Nlc3Nvci5pZCAmJiByZXN1bHQgPT09IG51bGwgJiYgZGVidWdMb2dnZXIuZGVidWcubG9nKGBFdmVudCBwcm9jZXNzb3IgXCIke3Byb2Nlc3Nvci5pZH1cIiBkcm9wcGVkIGV2ZW50YCk7XG5cbiAgICAgIGlmIChpcy5pc1RoZW5hYmxlKHJlc3VsdCkpIHtcbiAgICAgICAgdm9pZCByZXN1bHRcbiAgICAgICAgICAudGhlbihmaW5hbCA9PiBub3RpZnlFdmVudFByb2Nlc3NvcnMocHJvY2Vzc29ycywgZmluYWwsIGhpbnQsIGluZGV4ICsgMSkudGhlbihyZXNvbHZlKSlcbiAgICAgICAgICAudGhlbihudWxsLCByZWplY3QpO1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgdm9pZCBub3RpZnlFdmVudFByb2Nlc3NvcnMocHJvY2Vzc29ycywgcmVzdWx0LCBoaW50LCBpbmRleCArIDEpXG4gICAgICAgICAgLnRoZW4ocmVzb2x2ZSlcbiAgICAgICAgICAudGhlbihudWxsLCByZWplY3QpO1xuICAgICAgfVxuICAgIH1cbiAgfSk7XG59XG5cbmV4cG9ydHMubm90aWZ5RXZlbnRQcm9jZXNzb3JzID0gbm90aWZ5RXZlbnRQcm9jZXNzb3JzO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9ZXZlbnRQcm9jZXNzb3JzLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/eventProcessors.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/exports.js":
/*!***********************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/exports.js ***!
  \***********************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst currentScopes = __webpack_require__(/*! ./currentScopes.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst debugBuild = __webpack_require__(/*! ./debug-build.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst session = __webpack_require__(/*! ./session.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/session.js\");\nconst debugLogger = __webpack_require__(/*! ./utils/debug-logger.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst is = __webpack_require__(/*! ./utils/is.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js\");\nconst misc = __webpack_require__(/*! ./utils/misc.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/misc.js\");\nconst prepareEvent = __webpack_require__(/*! ./utils/prepareEvent.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/prepareEvent.js\");\nconst time = __webpack_require__(/*! ./utils/time.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/time.js\");\nconst worldwide = __webpack_require__(/*! ./utils/worldwide.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/worldwide.js\");\n\n/**\n * Captures an exception event and sends it to Sentry.\n *\n * @param exception The exception to capture.\n * @param hint Optional additional data to attach to the Sentry event.\n * @returns the id of the captured Sentry event.\n */\nfunction captureException(exception, hint) {\n  return currentScopes.getCurrentScope().captureException(exception, prepareEvent.parseEventHintOrCaptureContext(hint));\n}\n\n/**\n * Captures a message event and sends it to Sentry.\n *\n * @param message The message to send to Sentry.\n * @param captureContext Define the level of the message or pass in additional data to attach to the message.\n * @returns the id of the captured message.\n */\nfunction captureMessage(message, captureContext) {\n  // This is necessary to provide explicit scopes upgrade, without changing the original\n  // arity of the `captureMessage(message, level)` method.\n  const level = typeof captureContext === 'string' ? captureContext : undefined;\n  const context = typeof captureContext !== 'string' ? { captureContext } : undefined;\n  return currentScopes.getCurrentScope().captureMessage(message, level, context);\n}\n\n/**\n * Captures a manually created event and sends it to Sentry.\n *\n * @param event The event to send to Sentry.\n * @param hint Optional additional data to attach to the Sentry event.\n * @returns the id of the captured event.\n */\nfunction captureEvent(event, hint) {\n  return currentScopes.getCurrentScope().captureEvent(event, hint);\n}\n\n/**\n * Sets context data with the given name.\n * @param name of the context\n * @param context Any kind of data. This data will be normalized.\n */\nfunction setContext(name, context) {\n  currentScopes.getIsolationScope().setContext(name, context);\n}\n\n/**\n * Set an object that will be merged sent as extra data with the event.\n * @param extras Extras object to merge into current context.\n */\nfunction setExtras(extras) {\n  currentScopes.getIsolationScope().setExtras(extras);\n}\n\n/**\n * Set key:value that will be sent as extra data with the event.\n * @param key String of extra\n * @param extra Any kind of data. This data will be normalized.\n */\nfunction setExtra(key, extra) {\n  currentScopes.getIsolationScope().setExtra(key, extra);\n}\n\n/**\n * Set an object that will be merged sent as tags data with the event.\n * @param tags Tags context object to merge into current context.\n */\nfunction setTags(tags) {\n  currentScopes.getIsolationScope().setTags(tags);\n}\n\n/**\n * Set key:value that will be sent as tags data with the event.\n *\n * Can also be used to unset a tag, by passing `undefined`.\n *\n * @param key String key of tag\n * @param value Value of tag\n */\nfunction setTag(key, value) {\n  currentScopes.getIsolationScope().setTag(key, value);\n}\n\n/**\n * Updates user context information for future events.\n *\n * @param user User context object to be set in the current context. Pass `null` to unset the user.\n */\nfunction setUser(user) {\n  currentScopes.getIsolationScope().setUser(user);\n}\n\n/**\n * The last error event id of the isolation scope.\n *\n * Warning: This function really returns the last recorded error event id on the current\n * isolation scope. If you call this function after handling a certain error and another error\n * is captured in between, the last one is returned instead of the one you might expect.\n * Also, ids of events that were never sent to Sentry (for example because\n * they were dropped in `beforeSend`) could be returned.\n *\n * @returns The last event id of the isolation scope.\n */\nfunction lastEventId() {\n  return currentScopes.getIsolationScope().lastEventId();\n}\n\n/**\n * Create a cron monitor check in and send it to Sentry.\n *\n * @param checkIn An object that describes a check in.\n * @param upsertMonitorConfig An optional object that describes a monitor config. Use this if you want\n * to create a monitor automatically when sending a check in.\n */\nfunction captureCheckIn(checkIn, upsertMonitorConfig) {\n  const scope = currentScopes.getCurrentScope();\n  const client = currentScopes.getClient();\n  if (!client) {\n    debugBuild.DEBUG_BUILD && debugLogger.debug.warn('Cannot capture check-in. No client defined.');\n  } else if (!client.captureCheckIn) {\n    debugBuild.DEBUG_BUILD && debugLogger.debug.warn('Cannot capture check-in. Client does not support sending check-ins.');\n  } else {\n    return client.captureCheckIn(checkIn, upsertMonitorConfig, scope);\n  }\n\n  return misc.uuid4();\n}\n\n/**\n * Wraps a callback with a cron monitor check in. The check in will be sent to Sentry when the callback finishes.\n *\n * @param monitorSlug The distinct slug of the monitor.\n * @param callback Callback to be monitored\n * @param upsertMonitorConfig An optional object that describes a monitor config. Use this if you want\n * to create a monitor automatically when sending a check in.\n */\nfunction withMonitor(\n  monitorSlug,\n  callback,\n  upsertMonitorConfig,\n) {\n  const checkInId = captureCheckIn({ monitorSlug, status: 'in_progress' }, upsertMonitorConfig);\n  const now = time.timestampInSeconds();\n\n  function finishCheckIn(status) {\n    captureCheckIn({ monitorSlug, status, checkInId, duration: time.timestampInSeconds() - now });\n  }\n\n  return currentScopes.withIsolationScope(() => {\n    let maybePromiseResult;\n    try {\n      maybePromiseResult = callback();\n    } catch (e) {\n      finishCheckIn('error');\n      throw e;\n    }\n\n    if (is.isThenable(maybePromiseResult)) {\n      return maybePromiseResult.then(\n        r => {\n          finishCheckIn('ok');\n          return r;\n        },\n        e => {\n          finishCheckIn('error');\n          throw e;\n        },\n      ) ;\n    }\n    finishCheckIn('ok');\n\n    return maybePromiseResult;\n  });\n}\n\n/**\n * Call `flush()` on the current client, if there is one. See {@link Client.flush}.\n *\n * @param timeout Maximum time in ms the client should wait to flush its event queue. Omitting this parameter will cause\n * the client to wait until all events are sent before resolving the promise.\n * @returns A promise which resolves to `true` if the queue successfully drains before the timeout, or `false` if it\n * doesn't (or if there's no client defined).\n */\nasync function flush(timeout) {\n  const client = currentScopes.getClient();\n  if (client) {\n    return client.flush(timeout);\n  }\n  debugBuild.DEBUG_BUILD && debugLogger.debug.warn('Cannot flush events. No client defined.');\n  return Promise.resolve(false);\n}\n\n/**\n * Call `close()` on the current client, if there is one. See {@link Client.close}.\n *\n * @param timeout Maximum time in ms the client should wait to flush its event queue before shutting down. Omitting this\n * parameter will cause the client to wait until all events are sent before disabling itself.\n * @returns A promise which resolves to `true` if the queue successfully drains before the timeout, or `false` if it\n * doesn't (or if there's no client defined).\n */\nasync function close(timeout) {\n  const client = currentScopes.getClient();\n  if (client) {\n    return client.close(timeout);\n  }\n  debugBuild.DEBUG_BUILD && debugLogger.debug.warn('Cannot flush events and disable SDK. No client defined.');\n  return Promise.resolve(false);\n}\n\n/**\n * Returns true if Sentry has been properly initialized.\n */\nfunction isInitialized() {\n  return !!currentScopes.getClient();\n}\n\n/** If the SDK is initialized & enabled. */\nfunction isEnabled() {\n  const client = currentScopes.getClient();\n  return client?.getOptions().enabled !== false && !!client?.getTransport();\n}\n\n/**\n * Add an event processor.\n * This will be added to the current isolation scope, ensuring any event that is processed in the current execution\n * context will have the processor applied.\n */\nfunction addEventProcessor(callback) {\n  currentScopes.getIsolationScope().addEventProcessor(callback);\n}\n\n/**\n * Start a session on the current isolation scope.\n *\n * @param context (optional) additional properties to be applied to the returned session object\n *\n * @returns the new active session\n */\nfunction startSession(context) {\n  const isolationScope = currentScopes.getIsolationScope();\n  const currentScope = currentScopes.getCurrentScope();\n\n  // Will fetch userAgent if called from browser sdk\n  const { userAgent } = worldwide.GLOBAL_OBJ.navigator || {};\n\n  const session$1 = session.makeSession({\n    user: currentScope.getUser() || isolationScope.getUser(),\n    ...(userAgent && { userAgent }),\n    ...context,\n  });\n\n  // End existing session if there's one\n  const currentSession = isolationScope.getSession();\n  if (currentSession?.status === 'ok') {\n    session.updateSession(currentSession, { status: 'exited' });\n  }\n\n  endSession();\n\n  // Afterwards we set the new session on the scope\n  isolationScope.setSession(session$1);\n\n  return session$1;\n}\n\n/**\n * End the session on the current isolation scope.\n */\nfunction endSession() {\n  const isolationScope = currentScopes.getIsolationScope();\n  const currentScope = currentScopes.getCurrentScope();\n\n  const session$1 = currentScope.getSession() || isolationScope.getSession();\n  if (session$1) {\n    session.closeSession(session$1);\n  }\n  _sendSessionUpdate();\n\n  // the session is over; take it off of the scope\n  isolationScope.setSession();\n}\n\n/**\n * Sends the current Session on the scope\n */\nfunction _sendSessionUpdate() {\n  const isolationScope = currentScopes.getIsolationScope();\n  const client = currentScopes.getClient();\n  const session = isolationScope.getSession();\n  if (session && client) {\n    client.captureSession(session);\n  }\n}\n\n/**\n * Sends the current session on the scope to Sentry\n *\n * @param end If set the session will be marked as exited and removed from the scope.\n *            Defaults to `false`.\n */\nfunction captureSession(end = false) {\n  // both send the update and pull the session from the scope\n  if (end) {\n    endSession();\n    return;\n  }\n\n  // only send the update\n  _sendSessionUpdate();\n}\n\nexports.addEventProcessor = addEventProcessor;\nexports.captureCheckIn = captureCheckIn;\nexports.captureEvent = captureEvent;\nexports.captureException = captureException;\nexports.captureMessage = captureMessage;\nexports.captureSession = captureSession;\nexports.close = close;\nexports.endSession = endSession;\nexports.flush = flush;\nexports.isEnabled = isEnabled;\nexports.isInitialized = isInitialized;\nexports.lastEventId = lastEventId;\nexports.setContext = setContext;\nexports.setExtra = setExtra;\nexports.setExtras = setExtras;\nexports.setTag = setTag;\nexports.setTags = setTags;\nexports.setUser = setUser;\nexports.startSession = startSession;\nexports.withMonitor = withMonitor;\n//# sourceMappingURL=exports.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9leHBvcnRzLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLHNCQUFzQixtQkFBTyxDQUFDLCtIQUFvQjtBQUNsRCxtQkFBbUIsbUJBQU8sQ0FBQywySEFBa0I7QUFDN0MsZ0JBQWdCLG1CQUFPLENBQUMsbUhBQWM7QUFDdEMsb0JBQW9CLG1CQUFPLENBQUMseUlBQXlCO0FBQ3JELFdBQVcsbUJBQU8sQ0FBQyxxSEFBZTtBQUNsQyxhQUFhLG1CQUFPLENBQUMseUhBQWlCO0FBQ3RDLHFCQUFxQixtQkFBTyxDQUFDLHlJQUF5QjtBQUN0RCxhQUFhLG1CQUFPLENBQUMseUhBQWlCO0FBQ3RDLGtCQUFrQixtQkFBTyxDQUFDLG1JQUFzQjs7QUFFaEQ7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLHlEQUF5RCxpQkFBaUI7QUFDMUU7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsSUFBSTtBQUNKO0FBQ0EsSUFBSTtBQUNKO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLHFDQUFxQyxvQ0FBb0M7QUFDekU7O0FBRUE7QUFDQSxxQkFBcUIsMkVBQTJFO0FBQ2hHOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsTUFBTTtBQUNOO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsU0FBUztBQUNUO0FBQ0E7QUFDQTtBQUNBLFNBQVM7QUFDVDtBQUNBO0FBQ0E7O0FBRUE7QUFDQSxHQUFHO0FBQ0g7O0FBRUE7QUFDQSwrREFBK0QsbUJBQW1CO0FBQ2xGO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQSwrREFBK0QsbUJBQW1CO0FBQ2xGO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBLFVBQVUsWUFBWTs7QUFFdEI7QUFDQTtBQUNBLHVCQUF1QixXQUFXO0FBQ2xDO0FBQ0EsR0FBRzs7QUFFSDtBQUNBO0FBQ0E7QUFDQSw0Q0FBNEMsa0JBQWtCO0FBQzlEOztBQUVBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSwwQkFBMEI7QUFDMUI7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUEseUJBQXlCO0FBQ3pCLHNCQUFzQjtBQUN0QixvQkFBb0I7QUFDcEIsd0JBQXdCO0FBQ3hCLHNCQUFzQjtBQUN0QixzQkFBc0I7QUFDdEIsYUFBYTtBQUNiLGtCQUFrQjtBQUNsQixhQUFhO0FBQ2IsaUJBQWlCO0FBQ2pCLHFCQUFxQjtBQUNyQixtQkFBbUI7QUFDbkIsa0JBQWtCO0FBQ2xCLGdCQUFnQjtBQUNoQixpQkFBaUI7QUFDakIsY0FBYztBQUNkLGVBQWU7QUFDZixlQUFlO0FBQ2Ysb0JBQW9CO0FBQ3BCLG1CQUFtQjtBQUNuQiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL2V4cG9ydHMuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGN1cnJlbnRTY29wZXMgPSByZXF1aXJlKCcuL2N1cnJlbnRTY29wZXMuanMnKTtcbmNvbnN0IGRlYnVnQnVpbGQgPSByZXF1aXJlKCcuL2RlYnVnLWJ1aWxkLmpzJyk7XG5jb25zdCBzZXNzaW9uID0gcmVxdWlyZSgnLi9zZXNzaW9uLmpzJyk7XG5jb25zdCBkZWJ1Z0xvZ2dlciA9IHJlcXVpcmUoJy4vdXRpbHMvZGVidWctbG9nZ2VyLmpzJyk7XG5jb25zdCBpcyA9IHJlcXVpcmUoJy4vdXRpbHMvaXMuanMnKTtcbmNvbnN0IG1pc2MgPSByZXF1aXJlKCcuL3V0aWxzL21pc2MuanMnKTtcbmNvbnN0IHByZXBhcmVFdmVudCA9IHJlcXVpcmUoJy4vdXRpbHMvcHJlcGFyZUV2ZW50LmpzJyk7XG5jb25zdCB0aW1lID0gcmVxdWlyZSgnLi91dGlscy90aW1lLmpzJyk7XG5jb25zdCB3b3JsZHdpZGUgPSByZXF1aXJlKCcuL3V0aWxzL3dvcmxkd2lkZS5qcycpO1xuXG4vKipcbiAqIENhcHR1cmVzIGFuIGV4Y2VwdGlvbiBldmVudCBhbmQgc2VuZHMgaXQgdG8gU2VudHJ5LlxuICpcbiAqIEBwYXJhbSBleGNlcHRpb24gVGhlIGV4Y2VwdGlvbiB0byBjYXB0dXJlLlxuICogQHBhcmFtIGhpbnQgT3B0aW9uYWwgYWRkaXRpb25hbCBkYXRhIHRvIGF0dGFjaCB0byB0aGUgU2VudHJ5IGV2ZW50LlxuICogQHJldHVybnMgdGhlIGlkIG9mIHRoZSBjYXB0dXJlZCBTZW50cnkgZXZlbnQuXG4gKi9cbmZ1bmN0aW9uIGNhcHR1cmVFeGNlcHRpb24oZXhjZXB0aW9uLCBoaW50KSB7XG4gIHJldHVybiBjdXJyZW50U2NvcGVzLmdldEN1cnJlbnRTY29wZSgpLmNhcHR1cmVFeGNlcHRpb24oZXhjZXB0aW9uLCBwcmVwYXJlRXZlbnQucGFyc2VFdmVudEhpbnRPckNhcHR1cmVDb250ZXh0KGhpbnQpKTtcbn1cblxuLyoqXG4gKiBDYXB0dXJlcyBhIG1lc3NhZ2UgZXZlbnQgYW5kIHNlbmRzIGl0IHRvIFNlbnRyeS5cbiAqXG4gKiBAcGFyYW0gbWVzc2FnZSBUaGUgbWVzc2FnZSB0byBzZW5kIHRvIFNlbnRyeS5cbiAqIEBwYXJhbSBjYXB0dXJlQ29udGV4dCBEZWZpbmUgdGhlIGxldmVsIG9mIHRoZSBtZXNzYWdlIG9yIHBhc3MgaW4gYWRkaXRpb25hbCBkYXRhIHRvIGF0dGFjaCB0byB0aGUgbWVzc2FnZS5cbiAqIEByZXR1cm5zIHRoZSBpZCBvZiB0aGUgY2FwdHVyZWQgbWVzc2FnZS5cbiAqL1xuZnVuY3Rpb24gY2FwdHVyZU1lc3NhZ2UobWVzc2FnZSwgY2FwdHVyZUNvbnRleHQpIHtcbiAgLy8gVGhpcyBpcyBuZWNlc3NhcnkgdG8gcHJvdmlkZSBleHBsaWNpdCBzY29wZXMgdXBncmFkZSwgd2l0aG91dCBjaGFuZ2luZyB0aGUgb3JpZ2luYWxcbiAgLy8gYXJpdHkgb2YgdGhlIGBjYXB0dXJlTWVzc2FnZShtZXNzYWdlLCBsZXZlbClgIG1ldGhvZC5cbiAgY29uc3QgbGV2ZWwgPSB0eXBlb2YgY2FwdHVyZUNvbnRleHQgPT09ICdzdHJpbmcnID8gY2FwdHVyZUNvbnRleHQgOiB1bmRlZmluZWQ7XG4gIGNvbnN0IGNvbnRleHQgPSB0eXBlb2YgY2FwdHVyZUNvbnRleHQgIT09ICdzdHJpbmcnID8geyBjYXB0dXJlQ29udGV4dCB9IDogdW5kZWZpbmVkO1xuICByZXR1cm4gY3VycmVudFNjb3Blcy5nZXRDdXJyZW50U2NvcGUoKS5jYXB0dXJlTWVzc2FnZShtZXNzYWdlLCBsZXZlbCwgY29udGV4dCk7XG59XG5cbi8qKlxuICogQ2FwdHVyZXMgYSBtYW51YWxseSBjcmVhdGVkIGV2ZW50IGFuZCBzZW5kcyBpdCB0byBTZW50cnkuXG4gKlxuICogQHBhcmFtIGV2ZW50IFRoZSBldmVudCB0byBzZW5kIHRvIFNlbnRyeS5cbiAqIEBwYXJhbSBoaW50IE9wdGlvbmFsIGFkZGl0aW9uYWwgZGF0YSB0byBhdHRhY2ggdG8gdGhlIFNlbnRyeSBldmVudC5cbiAqIEByZXR1cm5zIHRoZSBpZCBvZiB0aGUgY2FwdHVyZWQgZXZlbnQuXG4gKi9cbmZ1bmN0aW9uIGNhcHR1cmVFdmVudChldmVudCwgaGludCkge1xuICByZXR1cm4gY3VycmVudFNjb3Blcy5nZXRDdXJyZW50U2NvcGUoKS5jYXB0dXJlRXZlbnQoZXZlbnQsIGhpbnQpO1xufVxuXG4vKipcbiAqIFNldHMgY29udGV4dCBkYXRhIHdpdGggdGhlIGdpdmVuIG5hbWUuXG4gKiBAcGFyYW0gbmFtZSBvZiB0aGUgY29udGV4dFxuICogQHBhcmFtIGNvbnRleHQgQW55IGtpbmQgb2YgZGF0YS4gVGhpcyBkYXRhIHdpbGwgYmUgbm9ybWFsaXplZC5cbiAqL1xuZnVuY3Rpb24gc2V0Q29udGV4dChuYW1lLCBjb250ZXh0KSB7XG4gIGN1cnJlbnRTY29wZXMuZ2V0SXNvbGF0aW9uU2NvcGUoKS5zZXRDb250ZXh0KG5hbWUsIGNvbnRleHQpO1xufVxuXG4vKipcbiAqIFNldCBhbiBvYmplY3QgdGhhdCB3aWxsIGJlIG1lcmdlZCBzZW50IGFzIGV4dHJhIGRhdGEgd2l0aCB0aGUgZXZlbnQuXG4gKiBAcGFyYW0gZXh0cmFzIEV4dHJhcyBvYmplY3QgdG8gbWVyZ2UgaW50byBjdXJyZW50IGNvbnRleHQuXG4gKi9cbmZ1bmN0aW9uIHNldEV4dHJhcyhleHRyYXMpIHtcbiAgY3VycmVudFNjb3Blcy5nZXRJc29sYXRpb25TY29wZSgpLnNldEV4dHJhcyhleHRyYXMpO1xufVxuXG4vKipcbiAqIFNldCBrZXk6dmFsdWUgdGhhdCB3aWxsIGJlIHNlbnQgYXMgZXh0cmEgZGF0YSB3aXRoIHRoZSBldmVudC5cbiAqIEBwYXJhbSBrZXkgU3RyaW5nIG9mIGV4dHJhXG4gKiBAcGFyYW0gZXh0cmEgQW55IGtpbmQgb2YgZGF0YS4gVGhpcyBkYXRhIHdpbGwgYmUgbm9ybWFsaXplZC5cbiAqL1xuZnVuY3Rpb24gc2V0RXh0cmEoa2V5LCBleHRyYSkge1xuICBjdXJyZW50U2NvcGVzLmdldElzb2xhdGlvblNjb3BlKCkuc2V0RXh0cmEoa2V5LCBleHRyYSk7XG59XG5cbi8qKlxuICogU2V0IGFuIG9iamVjdCB0aGF0IHdpbGwgYmUgbWVyZ2VkIHNlbnQgYXMgdGFncyBkYXRhIHdpdGggdGhlIGV2ZW50LlxuICogQHBhcmFtIHRhZ3MgVGFncyBjb250ZXh0IG9iamVjdCB0byBtZXJnZSBpbnRvIGN1cnJlbnQgY29udGV4dC5cbiAqL1xuZnVuY3Rpb24gc2V0VGFncyh0YWdzKSB7XG4gIGN1cnJlbnRTY29wZXMuZ2V0SXNvbGF0aW9uU2NvcGUoKS5zZXRUYWdzKHRhZ3MpO1xufVxuXG4vKipcbiAqIFNldCBrZXk6dmFsdWUgdGhhdCB3aWxsIGJlIHNlbnQgYXMgdGFncyBkYXRhIHdpdGggdGhlIGV2ZW50LlxuICpcbiAqIENhbiBhbHNvIGJlIHVzZWQgdG8gdW5zZXQgYSB0YWcsIGJ5IHBhc3NpbmcgYHVuZGVmaW5lZGAuXG4gKlxuICogQHBhcmFtIGtleSBTdHJpbmcga2V5IG9mIHRhZ1xuICogQHBhcmFtIHZhbHVlIFZhbHVlIG9mIHRhZ1xuICovXG5mdW5jdGlvbiBzZXRUYWcoa2V5LCB2YWx1ZSkge1xuICBjdXJyZW50U2NvcGVzLmdldElzb2xhdGlvblNjb3BlKCkuc2V0VGFnKGtleSwgdmFsdWUpO1xufVxuXG4vKipcbiAqIFVwZGF0ZXMgdXNlciBjb250ZXh0IGluZm9ybWF0aW9uIGZvciBmdXR1cmUgZXZlbnRzLlxuICpcbiAqIEBwYXJhbSB1c2VyIFVzZXIgY29udGV4dCBvYmplY3QgdG8gYmUgc2V0IGluIHRoZSBjdXJyZW50IGNvbnRleHQuIFBhc3MgYG51bGxgIHRvIHVuc2V0IHRoZSB1c2VyLlxuICovXG5mdW5jdGlvbiBzZXRVc2VyKHVzZXIpIHtcbiAgY3VycmVudFNjb3Blcy5nZXRJc29sYXRpb25TY29wZSgpLnNldFVzZXIodXNlcik7XG59XG5cbi8qKlxuICogVGhlIGxhc3QgZXJyb3IgZXZlbnQgaWQgb2YgdGhlIGlzb2xhdGlvbiBzY29wZS5cbiAqXG4gKiBXYXJuaW5nOiBUaGlzIGZ1bmN0aW9uIHJlYWxseSByZXR1cm5zIHRoZSBsYXN0IHJlY29yZGVkIGVycm9yIGV2ZW50IGlkIG9uIHRoZSBjdXJyZW50XG4gKiBpc29sYXRpb24gc2NvcGUuIElmIHlvdSBjYWxsIHRoaXMgZnVuY3Rpb24gYWZ0ZXIgaGFuZGxpbmcgYSBjZXJ0YWluIGVycm9yIGFuZCBhbm90aGVyIGVycm9yXG4gKiBpcyBjYXB0dXJlZCBpbiBiZXR3ZWVuLCB0aGUgbGFzdCBvbmUgaXMgcmV0dXJuZWQgaW5zdGVhZCBvZiB0aGUgb25lIHlvdSBtaWdodCBleHBlY3QuXG4gKiBBbHNvLCBpZHMgb2YgZXZlbnRzIHRoYXQgd2VyZSBuZXZlciBzZW50IHRvIFNlbnRyeSAoZm9yIGV4YW1wbGUgYmVjYXVzZVxuICogdGhleSB3ZXJlIGRyb3BwZWQgaW4gYGJlZm9yZVNlbmRgKSBjb3VsZCBiZSByZXR1cm5lZC5cbiAqXG4gKiBAcmV0dXJucyBUaGUgbGFzdCBldmVudCBpZCBvZiB0aGUgaXNvbGF0aW9uIHNjb3BlLlxuICovXG5mdW5jdGlvbiBsYXN0RXZlbnRJZCgpIHtcbiAgcmV0dXJuIGN1cnJlbnRTY29wZXMuZ2V0SXNvbGF0aW9uU2NvcGUoKS5sYXN0RXZlbnRJZCgpO1xufVxuXG4vKipcbiAqIENyZWF0ZSBhIGNyb24gbW9uaXRvciBjaGVjayBpbiBhbmQgc2VuZCBpdCB0byBTZW50cnkuXG4gKlxuICogQHBhcmFtIGNoZWNrSW4gQW4gb2JqZWN0IHRoYXQgZGVzY3JpYmVzIGEgY2hlY2sgaW4uXG4gKiBAcGFyYW0gdXBzZXJ0TW9uaXRvckNvbmZpZyBBbiBvcHRpb25hbCBvYmplY3QgdGhhdCBkZXNjcmliZXMgYSBtb25pdG9yIGNvbmZpZy4gVXNlIHRoaXMgaWYgeW91IHdhbnRcbiAqIHRvIGNyZWF0ZSBhIG1vbml0b3IgYXV0b21hdGljYWxseSB3aGVuIHNlbmRpbmcgYSBjaGVjayBpbi5cbiAqL1xuZnVuY3Rpb24gY2FwdHVyZUNoZWNrSW4oY2hlY2tJbiwgdXBzZXJ0TW9uaXRvckNvbmZpZykge1xuICBjb25zdCBzY29wZSA9IGN1cnJlbnRTY29wZXMuZ2V0Q3VycmVudFNjb3BlKCk7XG4gIGNvbnN0IGNsaWVudCA9IGN1cnJlbnRTY29wZXMuZ2V0Q2xpZW50KCk7XG4gIGlmICghY2xpZW50KSB7XG4gICAgZGVidWdCdWlsZC5ERUJVR19CVUlMRCAmJiBkZWJ1Z0xvZ2dlci5kZWJ1Zy53YXJuKCdDYW5ub3QgY2FwdHVyZSBjaGVjay1pbi4gTm8gY2xpZW50IGRlZmluZWQuJyk7XG4gIH0gZWxzZSBpZiAoIWNsaWVudC5jYXB0dXJlQ2hlY2tJbikge1xuICAgIGRlYnVnQnVpbGQuREVCVUdfQlVJTEQgJiYgZGVidWdMb2dnZXIuZGVidWcud2FybignQ2Fubm90IGNhcHR1cmUgY2hlY2staW4uIENsaWVudCBkb2VzIG5vdCBzdXBwb3J0IHNlbmRpbmcgY2hlY2staW5zLicpO1xuICB9IGVsc2Uge1xuICAgIHJldHVybiBjbGllbnQuY2FwdHVyZUNoZWNrSW4oY2hlY2tJbiwgdXBzZXJ0TW9uaXRvckNvbmZpZywgc2NvcGUpO1xuICB9XG5cbiAgcmV0dXJuIG1pc2MudXVpZDQoKTtcbn1cblxuLyoqXG4gKiBXcmFwcyBhIGNhbGxiYWNrIHdpdGggYSBjcm9uIG1vbml0b3IgY2hlY2sgaW4uIFRoZSBjaGVjayBpbiB3aWxsIGJlIHNlbnQgdG8gU2VudHJ5IHdoZW4gdGhlIGNhbGxiYWNrIGZpbmlzaGVzLlxuICpcbiAqIEBwYXJhbSBtb25pdG9yU2x1ZyBUaGUgZGlzdGluY3Qgc2x1ZyBvZiB0aGUgbW9uaXRvci5cbiAqIEBwYXJhbSBjYWxsYmFjayBDYWxsYmFjayB0byBiZSBtb25pdG9yZWRcbiAqIEBwYXJhbSB1cHNlcnRNb25pdG9yQ29uZmlnIEFuIG9wdGlvbmFsIG9iamVjdCB0aGF0IGRlc2NyaWJlcyBhIG1vbml0b3IgY29uZmlnLiBVc2UgdGhpcyBpZiB5b3Ugd2FudFxuICogdG8gY3JlYXRlIGEgbW9uaXRvciBhdXRvbWF0aWNhbGx5IHdoZW4gc2VuZGluZyBhIGNoZWNrIGluLlxuICovXG5mdW5jdGlvbiB3aXRoTW9uaXRvcihcbiAgbW9uaXRvclNsdWcsXG4gIGNhbGxiYWNrLFxuICB1cHNlcnRNb25pdG9yQ29uZmlnLFxuKSB7XG4gIGNvbnN0IGNoZWNrSW5JZCA9IGNhcHR1cmVDaGVja0luKHsgbW9uaXRvclNsdWcsIHN0YXR1czogJ2luX3Byb2dyZXNzJyB9LCB1cHNlcnRNb25pdG9yQ29uZmlnKTtcbiAgY29uc3Qgbm93ID0gdGltZS50aW1lc3RhbXBJblNlY29uZHMoKTtcblxuICBmdW5jdGlvbiBmaW5pc2hDaGVja0luKHN0YXR1cykge1xuICAgIGNhcHR1cmVDaGVja0luKHsgbW9uaXRvclNsdWcsIHN0YXR1cywgY2hlY2tJbklkLCBkdXJhdGlvbjogdGltZS50aW1lc3RhbXBJblNlY29uZHMoKSAtIG5vdyB9KTtcbiAgfVxuXG4gIHJldHVybiBjdXJyZW50U2NvcGVzLndpdGhJc29sYXRpb25TY29wZSgoKSA9PiB7XG4gICAgbGV0IG1heWJlUHJvbWlzZVJlc3VsdDtcbiAgICB0cnkge1xuICAgICAgbWF5YmVQcm9taXNlUmVzdWx0ID0gY2FsbGJhY2soKTtcbiAgICB9IGNhdGNoIChlKSB7XG4gICAgICBmaW5pc2hDaGVja0luKCdlcnJvcicpO1xuICAgICAgdGhyb3cgZTtcbiAgICB9XG5cbiAgICBpZiAoaXMuaXNUaGVuYWJsZShtYXliZVByb21pc2VSZXN1bHQpKSB7XG4gICAgICByZXR1cm4gbWF5YmVQcm9taXNlUmVzdWx0LnRoZW4oXG4gICAgICAgIHIgPT4ge1xuICAgICAgICAgIGZpbmlzaENoZWNrSW4oJ29rJyk7XG4gICAgICAgICAgcmV0dXJuIHI7XG4gICAgICAgIH0sXG4gICAgICAgIGUgPT4ge1xuICAgICAgICAgIGZpbmlzaENoZWNrSW4oJ2Vycm9yJyk7XG4gICAgICAgICAgdGhyb3cgZTtcbiAgICAgICAgfSxcbiAgICAgICkgO1xuICAgIH1cbiAgICBmaW5pc2hDaGVja0luKCdvaycpO1xuXG4gICAgcmV0dXJuIG1heWJlUHJvbWlzZVJlc3VsdDtcbiAgfSk7XG59XG5cbi8qKlxuICogQ2FsbCBgZmx1c2goKWAgb24gdGhlIGN1cnJlbnQgY2xpZW50LCBpZiB0aGVyZSBpcyBvbmUuIFNlZSB7QGxpbmsgQ2xpZW50LmZsdXNofS5cbiAqXG4gKiBAcGFyYW0gdGltZW91dCBNYXhpbXVtIHRpbWUgaW4gbXMgdGhlIGNsaWVudCBzaG91bGQgd2FpdCB0byBmbHVzaCBpdHMgZXZlbnQgcXVldWUuIE9taXR0aW5nIHRoaXMgcGFyYW1ldGVyIHdpbGwgY2F1c2VcbiAqIHRoZSBjbGllbnQgdG8gd2FpdCB1bnRpbCBhbGwgZXZlbnRzIGFyZSBzZW50IGJlZm9yZSByZXNvbHZpbmcgdGhlIHByb21pc2UuXG4gKiBAcmV0dXJucyBBIHByb21pc2Ugd2hpY2ggcmVzb2x2ZXMgdG8gYHRydWVgIGlmIHRoZSBxdWV1ZSBzdWNjZXNzZnVsbHkgZHJhaW5zIGJlZm9yZSB0aGUgdGltZW91dCwgb3IgYGZhbHNlYCBpZiBpdFxuICogZG9lc24ndCAob3IgaWYgdGhlcmUncyBubyBjbGllbnQgZGVmaW5lZCkuXG4gKi9cbmFzeW5jIGZ1bmN0aW9uIGZsdXNoKHRpbWVvdXQpIHtcbiAgY29uc3QgY2xpZW50ID0gY3VycmVudFNjb3Blcy5nZXRDbGllbnQoKTtcbiAgaWYgKGNsaWVudCkge1xuICAgIHJldHVybiBjbGllbnQuZmx1c2godGltZW91dCk7XG4gIH1cbiAgZGVidWdCdWlsZC5ERUJVR19CVUlMRCAmJiBkZWJ1Z0xvZ2dlci5kZWJ1Zy53YXJuKCdDYW5ub3QgZmx1c2ggZXZlbnRzLiBObyBjbGllbnQgZGVmaW5lZC4nKTtcbiAgcmV0dXJuIFByb21pc2UucmVzb2x2ZShmYWxzZSk7XG59XG5cbi8qKlxuICogQ2FsbCBgY2xvc2UoKWAgb24gdGhlIGN1cnJlbnQgY2xpZW50LCBpZiB0aGVyZSBpcyBvbmUuIFNlZSB7QGxpbmsgQ2xpZW50LmNsb3NlfS5cbiAqXG4gKiBAcGFyYW0gdGltZW91dCBNYXhpbXVtIHRpbWUgaW4gbXMgdGhlIGNsaWVudCBzaG91bGQgd2FpdCB0byBmbHVzaCBpdHMgZXZlbnQgcXVldWUgYmVmb3JlIHNodXR0aW5nIGRvd24uIE9taXR0aW5nIHRoaXNcbiAqIHBhcmFtZXRlciB3aWxsIGNhdXNlIHRoZSBjbGllbnQgdG8gd2FpdCB1bnRpbCBhbGwgZXZlbnRzIGFyZSBzZW50IGJlZm9yZSBkaXNhYmxpbmcgaXRzZWxmLlxuICogQHJldHVybnMgQSBwcm9taXNlIHdoaWNoIHJlc29sdmVzIHRvIGB0cnVlYCBpZiB0aGUgcXVldWUgc3VjY2Vzc2Z1bGx5IGRyYWlucyBiZWZvcmUgdGhlIHRpbWVvdXQsIG9yIGBmYWxzZWAgaWYgaXRcbiAqIGRvZXNuJ3QgKG9yIGlmIHRoZXJlJ3Mgbm8gY2xpZW50IGRlZmluZWQpLlxuICovXG5hc3luYyBmdW5jdGlvbiBjbG9zZSh0aW1lb3V0KSB7XG4gIGNvbnN0IGNsaWVudCA9IGN1cnJlbnRTY29wZXMuZ2V0Q2xpZW50KCk7XG4gIGlmIChjbGllbnQpIHtcbiAgICByZXR1cm4gY2xpZW50LmNsb3NlKHRpbWVvdXQpO1xuICB9XG4gIGRlYnVnQnVpbGQuREVCVUdfQlVJTEQgJiYgZGVidWdMb2dnZXIuZGVidWcud2FybignQ2Fubm90IGZsdXNoIGV2ZW50cyBhbmQgZGlzYWJsZSBTREsuIE5vIGNsaWVudCBkZWZpbmVkLicpO1xuICByZXR1cm4gUHJvbWlzZS5yZXNvbHZlKGZhbHNlKTtcbn1cblxuLyoqXG4gKiBSZXR1cm5zIHRydWUgaWYgU2VudHJ5IGhhcyBiZWVuIHByb3Blcmx5IGluaXRpYWxpemVkLlxuICovXG5mdW5jdGlvbiBpc0luaXRpYWxpemVkKCkge1xuICByZXR1cm4gISFjdXJyZW50U2NvcGVzLmdldENsaWVudCgpO1xufVxuXG4vKiogSWYgdGhlIFNESyBpcyBpbml0aWFsaXplZCAmIGVuYWJsZWQuICovXG5mdW5jdGlvbiBpc0VuYWJsZWQoKSB7XG4gIGNvbnN0IGNsaWVudCA9IGN1cnJlbnRTY29wZXMuZ2V0Q2xpZW50KCk7XG4gIHJldHVybiBjbGllbnQ/LmdldE9wdGlvbnMoKS5lbmFibGVkICE9PSBmYWxzZSAmJiAhIWNsaWVudD8uZ2V0VHJhbnNwb3J0KCk7XG59XG5cbi8qKlxuICogQWRkIGFuIGV2ZW50IHByb2Nlc3Nvci5cbiAqIFRoaXMgd2lsbCBiZSBhZGRlZCB0byB0aGUgY3VycmVudCBpc29sYXRpb24gc2NvcGUsIGVuc3VyaW5nIGFueSBldmVudCB0aGF0IGlzIHByb2Nlc3NlZCBpbiB0aGUgY3VycmVudCBleGVjdXRpb25cbiAqIGNvbnRleHQgd2lsbCBoYXZlIHRoZSBwcm9jZXNzb3IgYXBwbGllZC5cbiAqL1xuZnVuY3Rpb24gYWRkRXZlbnRQcm9jZXNzb3IoY2FsbGJhY2spIHtcbiAgY3VycmVudFNjb3Blcy5nZXRJc29sYXRpb25TY29wZSgpLmFkZEV2ZW50UHJvY2Vzc29yKGNhbGxiYWNrKTtcbn1cblxuLyoqXG4gKiBTdGFydCBhIHNlc3Npb24gb24gdGhlIGN1cnJlbnQgaXNvbGF0aW9uIHNjb3BlLlxuICpcbiAqIEBwYXJhbSBjb250ZXh0IChvcHRpb25hbCkgYWRkaXRpb25hbCBwcm9wZXJ0aWVzIHRvIGJlIGFwcGxpZWQgdG8gdGhlIHJldHVybmVkIHNlc3Npb24gb2JqZWN0XG4gKlxuICogQHJldHVybnMgdGhlIG5ldyBhY3RpdmUgc2Vzc2lvblxuICovXG5mdW5jdGlvbiBzdGFydFNlc3Npb24oY29udGV4dCkge1xuICBjb25zdCBpc29sYXRpb25TY29wZSA9IGN1cnJlbnRTY29wZXMuZ2V0SXNvbGF0aW9uU2NvcGUoKTtcbiAgY29uc3QgY3VycmVudFNjb3BlID0gY3VycmVudFNjb3Blcy5nZXRDdXJyZW50U2NvcGUoKTtcblxuICAvLyBXaWxsIGZldGNoIHVzZXJBZ2VudCBpZiBjYWxsZWQgZnJvbSBicm93c2VyIHNka1xuICBjb25zdCB7IHVzZXJBZ2VudCB9ID0gd29ybGR3aWRlLkdMT0JBTF9PQkoubmF2aWdhdG9yIHx8IHt9O1xuXG4gIGNvbnN0IHNlc3Npb24kMSA9IHNlc3Npb24ubWFrZVNlc3Npb24oe1xuICAgIHVzZXI6IGN1cnJlbnRTY29wZS5nZXRVc2VyKCkgfHwgaXNvbGF0aW9uU2NvcGUuZ2V0VXNlcigpLFxuICAgIC4uLih1c2VyQWdlbnQgJiYgeyB1c2VyQWdlbnQgfSksXG4gICAgLi4uY29udGV4dCxcbiAgfSk7XG5cbiAgLy8gRW5kIGV4aXN0aW5nIHNlc3Npb24gaWYgdGhlcmUncyBvbmVcbiAgY29uc3QgY3VycmVudFNlc3Npb24gPSBpc29sYXRpb25TY29wZS5nZXRTZXNzaW9uKCk7XG4gIGlmIChjdXJyZW50U2Vzc2lvbj8uc3RhdHVzID09PSAnb2snKSB7XG4gICAgc2Vzc2lvbi51cGRhdGVTZXNzaW9uKGN1cnJlbnRTZXNzaW9uLCB7IHN0YXR1czogJ2V4aXRlZCcgfSk7XG4gIH1cblxuICBlbmRTZXNzaW9uKCk7XG5cbiAgLy8gQWZ0ZXJ3YXJkcyB3ZSBzZXQgdGhlIG5ldyBzZXNzaW9uIG9uIHRoZSBzY29wZVxuICBpc29sYXRpb25TY29wZS5zZXRTZXNzaW9uKHNlc3Npb24kMSk7XG5cbiAgcmV0dXJuIHNlc3Npb24kMTtcbn1cblxuLyoqXG4gKiBFbmQgdGhlIHNlc3Npb24gb24gdGhlIGN1cnJlbnQgaXNvbGF0aW9uIHNjb3BlLlxuICovXG5mdW5jdGlvbiBlbmRTZXNzaW9uKCkge1xuICBjb25zdCBpc29sYXRpb25TY29wZSA9IGN1cnJlbnRTY29wZXMuZ2V0SXNvbGF0aW9uU2NvcGUoKTtcbiAgY29uc3QgY3VycmVudFNjb3BlID0gY3VycmVudFNjb3Blcy5nZXRDdXJyZW50U2NvcGUoKTtcblxuICBjb25zdCBzZXNzaW9uJDEgPSBjdXJyZW50U2NvcGUuZ2V0U2Vzc2lvbigpIHx8IGlzb2xhdGlvblNjb3BlLmdldFNlc3Npb24oKTtcbiAgaWYgKHNlc3Npb24kMSkge1xuICAgIHNlc3Npb24uY2xvc2VTZXNzaW9uKHNlc3Npb24kMSk7XG4gIH1cbiAgX3NlbmRTZXNzaW9uVXBkYXRlKCk7XG5cbiAgLy8gdGhlIHNlc3Npb24gaXMgb3ZlcjsgdGFrZSBpdCBvZmYgb2YgdGhlIHNjb3BlXG4gIGlzb2xhdGlvblNjb3BlLnNldFNlc3Npb24oKTtcbn1cblxuLyoqXG4gKiBTZW5kcyB0aGUgY3VycmVudCBTZXNzaW9uIG9uIHRoZSBzY29wZVxuICovXG5mdW5jdGlvbiBfc2VuZFNlc3Npb25VcGRhdGUoKSB7XG4gIGNvbnN0IGlzb2xhdGlvblNjb3BlID0gY3VycmVudFNjb3Blcy5nZXRJc29sYXRpb25TY29wZSgpO1xuICBjb25zdCBjbGllbnQgPSBjdXJyZW50U2NvcGVzLmdldENsaWVudCgpO1xuICBjb25zdCBzZXNzaW9uID0gaXNvbGF0aW9uU2NvcGUuZ2V0U2Vzc2lvbigpO1xuICBpZiAoc2Vzc2lvbiAmJiBjbGllbnQpIHtcbiAgICBjbGllbnQuY2FwdHVyZVNlc3Npb24oc2Vzc2lvbik7XG4gIH1cbn1cblxuLyoqXG4gKiBTZW5kcyB0aGUgY3VycmVudCBzZXNzaW9uIG9uIHRoZSBzY29wZSB0byBTZW50cnlcbiAqXG4gKiBAcGFyYW0gZW5kIElmIHNldCB0aGUgc2Vzc2lvbiB3aWxsIGJlIG1hcmtlZCBhcyBleGl0ZWQgYW5kIHJlbW92ZWQgZnJvbSB0aGUgc2NvcGUuXG4gKiAgICAgICAgICAgIERlZmF1bHRzIHRvIGBmYWxzZWAuXG4gKi9cbmZ1bmN0aW9uIGNhcHR1cmVTZXNzaW9uKGVuZCA9IGZhbHNlKSB7XG4gIC8vIGJvdGggc2VuZCB0aGUgdXBkYXRlIGFuZCBwdWxsIHRoZSBzZXNzaW9uIGZyb20gdGhlIHNjb3BlXG4gIGlmIChlbmQpIHtcbiAgICBlbmRTZXNzaW9uKCk7XG4gICAgcmV0dXJuO1xuICB9XG5cbiAgLy8gb25seSBzZW5kIHRoZSB1cGRhdGVcbiAgX3NlbmRTZXNzaW9uVXBkYXRlKCk7XG59XG5cbmV4cG9ydHMuYWRkRXZlbnRQcm9jZXNzb3IgPSBhZGRFdmVudFByb2Nlc3NvcjtcbmV4cG9ydHMuY2FwdHVyZUNoZWNrSW4gPSBjYXB0dXJlQ2hlY2tJbjtcbmV4cG9ydHMuY2FwdHVyZUV2ZW50ID0gY2FwdHVyZUV2ZW50O1xuZXhwb3J0cy5jYXB0dXJlRXhjZXB0aW9uID0gY2FwdHVyZUV4Y2VwdGlvbjtcbmV4cG9ydHMuY2FwdHVyZU1lc3NhZ2UgPSBjYXB0dXJlTWVzc2FnZTtcbmV4cG9ydHMuY2FwdHVyZVNlc3Npb24gPSBjYXB0dXJlU2Vzc2lvbjtcbmV4cG9ydHMuY2xvc2UgPSBjbG9zZTtcbmV4cG9ydHMuZW5kU2Vzc2lvbiA9IGVuZFNlc3Npb247XG5leHBvcnRzLmZsdXNoID0gZmx1c2g7XG5leHBvcnRzLmlzRW5hYmxlZCA9IGlzRW5hYmxlZDtcbmV4cG9ydHMuaXNJbml0aWFsaXplZCA9IGlzSW5pdGlhbGl6ZWQ7XG5leHBvcnRzLmxhc3RFdmVudElkID0gbGFzdEV2ZW50SWQ7XG5leHBvcnRzLnNldENvbnRleHQgPSBzZXRDb250ZXh0O1xuZXhwb3J0cy5zZXRFeHRyYSA9IHNldEV4dHJhO1xuZXhwb3J0cy5zZXRFeHRyYXMgPSBzZXRFeHRyYXM7XG5leHBvcnRzLnNldFRhZyA9IHNldFRhZztcbmV4cG9ydHMuc2V0VGFncyA9IHNldFRhZ3M7XG5leHBvcnRzLnNldFVzZXIgPSBzZXRVc2VyO1xuZXhwb3J0cy5zdGFydFNlc3Npb24gPSBzdGFydFNlc3Npb247XG5leHBvcnRzLndpdGhNb25pdG9yID0gd2l0aE1vbml0b3I7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1leHBvcnRzLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/exports.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/feedback.js":
/*!************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/feedback.js ***!
  \************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst currentScopes = __webpack_require__(/*! ./currentScopes.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\n\n/**\n * Send user feedback to Sentry.\n */\nfunction captureFeedback(\n  params,\n  hint = {},\n  scope = currentScopes.getCurrentScope(),\n) {\n  const { message, name, email, url, source, associatedEventId, tags } = params;\n\n  const feedbackEvent = {\n    contexts: {\n      feedback: {\n        contact_email: email,\n        name,\n        message,\n        url,\n        source,\n        associated_event_id: associatedEventId,\n      },\n    },\n    type: 'feedback',\n    level: 'info',\n    tags,\n  };\n\n  const client = scope?.getClient() || currentScopes.getClient();\n\n  if (client) {\n    client.emit('beforeSendFeedback', feedbackEvent, hint);\n  }\n\n  const eventId = scope.captureEvent(feedbackEvent, hint);\n\n  return eventId;\n}\n\nexports.captureFeedback = captureFeedback;\n//# sourceMappingURL=feedback.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9mZWVkYmFjay5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxzQkFBc0IsbUJBQU8sQ0FBQywrSEFBb0I7O0FBRWxEO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxXQUFXO0FBQ1g7QUFDQTtBQUNBLFVBQVUsNkRBQTZEOztBQUV2RTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxPQUFPO0FBQ1AsS0FBSztBQUNMO0FBQ0E7QUFDQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBOztBQUVBLHVCQUF1QjtBQUN2QiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL2ZlZWRiYWNrLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBjdXJyZW50U2NvcGVzID0gcmVxdWlyZSgnLi9jdXJyZW50U2NvcGVzLmpzJyk7XG5cbi8qKlxuICogU2VuZCB1c2VyIGZlZWRiYWNrIHRvIFNlbnRyeS5cbiAqL1xuZnVuY3Rpb24gY2FwdHVyZUZlZWRiYWNrKFxuICBwYXJhbXMsXG4gIGhpbnQgPSB7fSxcbiAgc2NvcGUgPSBjdXJyZW50U2NvcGVzLmdldEN1cnJlbnRTY29wZSgpLFxuKSB7XG4gIGNvbnN0IHsgbWVzc2FnZSwgbmFtZSwgZW1haWwsIHVybCwgc291cmNlLCBhc3NvY2lhdGVkRXZlbnRJZCwgdGFncyB9ID0gcGFyYW1zO1xuXG4gIGNvbnN0IGZlZWRiYWNrRXZlbnQgPSB7XG4gICAgY29udGV4dHM6IHtcbiAgICAgIGZlZWRiYWNrOiB7XG4gICAgICAgIGNvbnRhY3RfZW1haWw6IGVtYWlsLFxuICAgICAgICBuYW1lLFxuICAgICAgICBtZXNzYWdlLFxuICAgICAgICB1cmwsXG4gICAgICAgIHNvdXJjZSxcbiAgICAgICAgYXNzb2NpYXRlZF9ldmVudF9pZDogYXNzb2NpYXRlZEV2ZW50SWQsXG4gICAgICB9LFxuICAgIH0sXG4gICAgdHlwZTogJ2ZlZWRiYWNrJyxcbiAgICBsZXZlbDogJ2luZm8nLFxuICAgIHRhZ3MsXG4gIH07XG5cbiAgY29uc3QgY2xpZW50ID0gc2NvcGU/LmdldENsaWVudCgpIHx8IGN1cnJlbnRTY29wZXMuZ2V0Q2xpZW50KCk7XG5cbiAgaWYgKGNsaWVudCkge1xuICAgIGNsaWVudC5lbWl0KCdiZWZvcmVTZW5kRmVlZGJhY2snLCBmZWVkYmFja0V2ZW50LCBoaW50KTtcbiAgfVxuXG4gIGNvbnN0IGV2ZW50SWQgPSBzY29wZS5jYXB0dXJlRXZlbnQoZmVlZGJhY2tFdmVudCwgaGludCk7XG5cbiAgcmV0dXJuIGV2ZW50SWQ7XG59XG5cbmV4cG9ydHMuY2FwdHVyZUZlZWRiYWNrID0gY2FwdHVyZUZlZWRiYWNrO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9ZmVlZGJhY2suanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/feedback.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/fetch.js":
/*!*********************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/fetch.js ***!
  \*********************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst currentScopes = __webpack_require__(/*! ./currentScopes.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst semanticAttributes = __webpack_require__(/*! ./semanticAttributes.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/semanticAttributes.js\");\nconst spanUtils = __webpack_require__(/*! ./utils/spanUtils.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanUtils.js\");\nconst spanstatus = __webpack_require__(/*! ./tracing/spanstatus.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/spanstatus.js\");\nconst is = __webpack_require__(/*! ./utils/is.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js\");\nconst hasSpansEnabled = __webpack_require__(/*! ./utils/hasSpansEnabled.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/hasSpansEnabled.js\");\nconst baggage = __webpack_require__(/*! ./utils/baggage.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/baggage.js\");\nconst sentryNonRecordingSpan = __webpack_require__(/*! ./tracing/sentryNonRecordingSpan.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/sentryNonRecordingSpan.js\");\nconst trace = __webpack_require__(/*! ./tracing/trace.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/trace.js\");\nconst traceData = __webpack_require__(/*! ./utils/traceData.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/traceData.js\");\nconst url = __webpack_require__(/*! ./utils/url.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/url.js\");\n\n/**\n * Create and track fetch request spans for usage in combination with `addFetchInstrumentationHandler`.\n *\n * @returns Span if a span was created, otherwise void.\n */\nfunction instrumentFetchRequest(\n  handlerData,\n  shouldCreateSpan,\n  shouldAttachHeaders,\n  spans,\n  spanOrigin = 'auto.http.browser',\n) {\n  if (!handlerData.fetchData) {\n    return undefined;\n  }\n\n  const { method, url } = handlerData.fetchData;\n\n  const shouldCreateSpanResult = hasSpansEnabled.hasSpansEnabled() && shouldCreateSpan(url);\n\n  if (handlerData.endTimestamp && shouldCreateSpanResult) {\n    const spanId = handlerData.fetchData.__span;\n    if (!spanId) return;\n\n    const span = spans[spanId];\n    if (span) {\n      endSpan(span, handlerData);\n\n      // eslint-disable-next-line @typescript-eslint/no-dynamic-delete\n      delete spans[spanId];\n    }\n    return undefined;\n  }\n\n  const hasParent = !!spanUtils.getActiveSpan();\n\n  const span =\n    shouldCreateSpanResult && hasParent\n      ? trace.startInactiveSpan(getSpanStartOptions(url, method, spanOrigin))\n      : new sentryNonRecordingSpan.SentryNonRecordingSpan();\n\n  handlerData.fetchData.__span = span.spanContext().spanId;\n  spans[span.spanContext().spanId] = span;\n\n  if (shouldAttachHeaders(handlerData.fetchData.url)) {\n    const request = handlerData.args[0];\n\n    const options = handlerData.args[1] || {};\n\n    const headers = _addTracingHeadersToFetchRequest(\n      request,\n      options,\n      // If performance is disabled (TWP) or there's no active root span (pageload/navigation/interaction),\n      // we do not want to use the span as base for the trace headers,\n      // which means that the headers will be generated from the scope and the sampling decision is deferred\n      hasSpansEnabled.hasSpansEnabled() && hasParent ? span : undefined,\n    );\n    if (headers) {\n      // Ensure this is actually set, if no options have been passed previously\n      handlerData.args[1] = options;\n      options.headers = headers;\n    }\n  }\n\n  const client = currentScopes.getClient();\n\n  if (client) {\n    const fetchHint = {\n      input: handlerData.args,\n      response: handlerData.response,\n      startTimestamp: handlerData.startTimestamp,\n      endTimestamp: handlerData.endTimestamp,\n    } ;\n\n    client.emit('beforeOutgoingRequestSpan', span, fetchHint);\n  }\n\n  return span;\n}\n\n/**\n * Adds sentry-trace and baggage headers to the various forms of fetch headers.\n * exported only for testing purposes\n *\n * When we determine if we should add a baggage header, there are 3 cases:\n * 1. No previous baggage header -> add baggage\n * 2. Previous baggage header has no sentry baggage values -> add our baggage\n * 3. Previous baggage header has sentry baggage values -> do nothing (might have been added manually by users)\n */\n// eslint-disable-next-line complexity -- yup it's this complicated :(\nfunction _addTracingHeadersToFetchRequest(\n  request,\n  fetchOptionsObj\n\n,\n  span,\n) {\n  const traceHeaders = traceData.getTraceData({ span });\n  const sentryTrace = traceHeaders['sentry-trace'];\n  const baggage = traceHeaders.baggage;\n\n  // Nothing to do, when we return undefined here, the original headers will be used\n  if (!sentryTrace) {\n    return undefined;\n  }\n\n  const originalHeaders = fetchOptionsObj.headers || (is.isRequest(request) ? request.headers : undefined);\n\n  if (!originalHeaders) {\n    return { ...traceHeaders };\n  } else if (isHeaders(originalHeaders)) {\n    const newHeaders = new Headers(originalHeaders);\n\n    // We don't want to override manually added sentry headers\n    if (!newHeaders.get('sentry-trace')) {\n      newHeaders.set('sentry-trace', sentryTrace);\n    }\n\n    if (baggage) {\n      const prevBaggageHeader = newHeaders.get('baggage');\n\n      if (!prevBaggageHeader) {\n        newHeaders.set('baggage', baggage);\n      } else if (!baggageHeaderHasSentryBaggageValues(prevBaggageHeader)) {\n        newHeaders.set('baggage', `${prevBaggageHeader},${baggage}`);\n      }\n    }\n\n    return newHeaders;\n  } else if (Array.isArray(originalHeaders)) {\n    const newHeaders = [...originalHeaders];\n\n    if (!originalHeaders.find(header => header[0] === 'sentry-trace')) {\n      newHeaders.push(['sentry-trace', sentryTrace]);\n    }\n\n    const prevBaggageHeaderWithSentryValues = originalHeaders.find(\n      header => header[0] === 'baggage' && baggageHeaderHasSentryBaggageValues(header[1]),\n    );\n\n    if (baggage && !prevBaggageHeaderWithSentryValues) {\n      // If there are multiple entries with the same key, the browser will merge the values into a single request header.\n      // Its therefore safe to simply push a \"baggage\" entry, even though there might already be another baggage header.\n      newHeaders.push(['baggage', baggage]);\n    }\n\n    return newHeaders ;\n  } else {\n    const existingSentryTraceHeader = 'sentry-trace' in originalHeaders ? originalHeaders['sentry-trace'] : undefined;\n\n    const existingBaggageHeader = 'baggage' in originalHeaders ? originalHeaders.baggage : undefined;\n    const newBaggageHeaders = existingBaggageHeader\n      ? Array.isArray(existingBaggageHeader)\n        ? [...existingBaggageHeader]\n        : [existingBaggageHeader]\n      : [];\n\n    const prevBaggageHeaderWithSentryValues =\n      existingBaggageHeader &&\n      (Array.isArray(existingBaggageHeader)\n        ? existingBaggageHeader.find(headerItem => baggageHeaderHasSentryBaggageValues(headerItem))\n        : baggageHeaderHasSentryBaggageValues(existingBaggageHeader));\n\n    if (baggage && !prevBaggageHeaderWithSentryValues) {\n      newBaggageHeaders.push(baggage);\n    }\n\n    return {\n      ...(originalHeaders ),\n      'sentry-trace': (existingSentryTraceHeader ) ?? sentryTrace,\n      baggage: newBaggageHeaders.length > 0 ? newBaggageHeaders.join(',') : undefined,\n    };\n  }\n}\n\nfunction endSpan(span, handlerData) {\n  if (handlerData.response) {\n    spanstatus.setHttpStatus(span, handlerData.response.status);\n\n    const contentLength = handlerData.response?.headers?.get('content-length');\n\n    if (contentLength) {\n      const contentLengthNum = parseInt(contentLength);\n      if (contentLengthNum > 0) {\n        span.setAttribute('http.response_content_length', contentLengthNum);\n      }\n    }\n  } else if (handlerData.error) {\n    span.setStatus({ code: spanstatus.SPAN_STATUS_ERROR, message: 'internal_error' });\n  }\n  span.end();\n}\n\nfunction baggageHeaderHasSentryBaggageValues(baggageHeader) {\n  return baggageHeader.split(',').some(baggageEntry => baggageEntry.trim().startsWith(baggage.SENTRY_BAGGAGE_KEY_PREFIX));\n}\n\nfunction isHeaders(headers) {\n  return typeof Headers !== 'undefined' && is.isInstanceOf(headers, Headers);\n}\n\nfunction getSpanStartOptions(\n  url$1,\n  method,\n  spanOrigin,\n) {\n  const parsedUrl = url.parseStringToURLObject(url$1);\n  return {\n    name: parsedUrl ? `${method} ${url.getSanitizedUrlStringFromUrlObject(parsedUrl)}` : method,\n    attributes: getFetchSpanAttributes(url$1, parsedUrl, method, spanOrigin),\n  };\n}\n\nfunction getFetchSpanAttributes(\n  url$1,\n  parsedUrl,\n  method,\n  spanOrigin,\n) {\n  const attributes = {\n    url: url$1,\n    type: 'fetch',\n    'http.method': method,\n    [semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_ORIGIN]: spanOrigin,\n    [semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_OP]: 'http.client',\n  };\n  if (parsedUrl) {\n    if (!url.isURLObjectRelative(parsedUrl)) {\n      attributes['http.url'] = parsedUrl.href;\n      attributes['server.address'] = parsedUrl.host;\n    }\n    if (parsedUrl.search) {\n      attributes['http.query'] = parsedUrl.search;\n    }\n    if (parsedUrl.hash) {\n      attributes['http.fragment'] = parsedUrl.hash;\n    }\n  }\n  return attributes;\n}\n\nexports._addTracingHeadersToFetchRequest = _addTracingHeadersToFetchRequest;\nexports.instrumentFetchRequest = instrumentFetchRequest;\n//# sourceMappingURL=fetch.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9mZXRjaC5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxzQkFBc0IsbUJBQU8sQ0FBQywrSEFBb0I7QUFDbEQsMkJBQTJCLG1CQUFPLENBQUMseUlBQXlCO0FBQzVELGtCQUFrQixtQkFBTyxDQUFDLG1JQUFzQjtBQUNoRCxtQkFBbUIsbUJBQU8sQ0FBQyx5SUFBeUI7QUFDcEQsV0FBVyxtQkFBTyxDQUFDLHFIQUFlO0FBQ2xDLHdCQUF3QixtQkFBTyxDQUFDLCtJQUE0QjtBQUM1RCxnQkFBZ0IsbUJBQU8sQ0FBQywrSEFBb0I7QUFDNUMsK0JBQStCLG1CQUFPLENBQUMsaUtBQXFDO0FBQzVFLGNBQWMsbUJBQU8sQ0FBQywrSEFBb0I7QUFDMUMsa0JBQWtCLG1CQUFPLENBQUMsbUlBQXNCO0FBQ2hELFlBQVksbUJBQU8sQ0FBQyx1SEFBZ0I7O0FBRXBDO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSxVQUFVLGNBQWM7O0FBRXhCOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0EsZ0RBQWdELE1BQU07QUFDdEQ7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBLGFBQWE7QUFDYixJQUFJO0FBQ0o7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsUUFBUTtBQUNSLHFDQUFxQyxrQkFBa0IsR0FBRyxRQUFRO0FBQ2xFO0FBQ0E7O0FBRUE7QUFDQSxJQUFJO0FBQ0o7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0EsSUFBSTtBQUNKOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsSUFBSTtBQUNKLHFCQUFxQiwrREFBK0Q7QUFDcEY7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSx5QkFBeUIsUUFBUSxFQUFFLGtEQUFrRDtBQUNyRjtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLHdDQUF3QztBQUN4Qyw4QkFBOEI7QUFDOUIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9mZXRjaC5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgY3VycmVudFNjb3BlcyA9IHJlcXVpcmUoJy4vY3VycmVudFNjb3Blcy5qcycpO1xuY29uc3Qgc2VtYW50aWNBdHRyaWJ1dGVzID0gcmVxdWlyZSgnLi9zZW1hbnRpY0F0dHJpYnV0ZXMuanMnKTtcbmNvbnN0IHNwYW5VdGlscyA9IHJlcXVpcmUoJy4vdXRpbHMvc3BhblV0aWxzLmpzJyk7XG5jb25zdCBzcGFuc3RhdHVzID0gcmVxdWlyZSgnLi90cmFjaW5nL3NwYW5zdGF0dXMuanMnKTtcbmNvbnN0IGlzID0gcmVxdWlyZSgnLi91dGlscy9pcy5qcycpO1xuY29uc3QgaGFzU3BhbnNFbmFibGVkID0gcmVxdWlyZSgnLi91dGlscy9oYXNTcGFuc0VuYWJsZWQuanMnKTtcbmNvbnN0IGJhZ2dhZ2UgPSByZXF1aXJlKCcuL3V0aWxzL2JhZ2dhZ2UuanMnKTtcbmNvbnN0IHNlbnRyeU5vblJlY29yZGluZ1NwYW4gPSByZXF1aXJlKCcuL3RyYWNpbmcvc2VudHJ5Tm9uUmVjb3JkaW5nU3Bhbi5qcycpO1xuY29uc3QgdHJhY2UgPSByZXF1aXJlKCcuL3RyYWNpbmcvdHJhY2UuanMnKTtcbmNvbnN0IHRyYWNlRGF0YSA9IHJlcXVpcmUoJy4vdXRpbHMvdHJhY2VEYXRhLmpzJyk7XG5jb25zdCB1cmwgPSByZXF1aXJlKCcuL3V0aWxzL3VybC5qcycpO1xuXG4vKipcbiAqIENyZWF0ZSBhbmQgdHJhY2sgZmV0Y2ggcmVxdWVzdCBzcGFucyBmb3IgdXNhZ2UgaW4gY29tYmluYXRpb24gd2l0aCBgYWRkRmV0Y2hJbnN0cnVtZW50YXRpb25IYW5kbGVyYC5cbiAqXG4gKiBAcmV0dXJucyBTcGFuIGlmIGEgc3BhbiB3YXMgY3JlYXRlZCwgb3RoZXJ3aXNlIHZvaWQuXG4gKi9cbmZ1bmN0aW9uIGluc3RydW1lbnRGZXRjaFJlcXVlc3QoXG4gIGhhbmRsZXJEYXRhLFxuICBzaG91bGRDcmVhdGVTcGFuLFxuICBzaG91bGRBdHRhY2hIZWFkZXJzLFxuICBzcGFucyxcbiAgc3Bhbk9yaWdpbiA9ICdhdXRvLmh0dHAuYnJvd3NlcicsXG4pIHtcbiAgaWYgKCFoYW5kbGVyRGF0YS5mZXRjaERhdGEpIHtcbiAgICByZXR1cm4gdW5kZWZpbmVkO1xuICB9XG5cbiAgY29uc3QgeyBtZXRob2QsIHVybCB9ID0gaGFuZGxlckRhdGEuZmV0Y2hEYXRhO1xuXG4gIGNvbnN0IHNob3VsZENyZWF0ZVNwYW5SZXN1bHQgPSBoYXNTcGFuc0VuYWJsZWQuaGFzU3BhbnNFbmFibGVkKCkgJiYgc2hvdWxkQ3JlYXRlU3Bhbih1cmwpO1xuXG4gIGlmIChoYW5kbGVyRGF0YS5lbmRUaW1lc3RhbXAgJiYgc2hvdWxkQ3JlYXRlU3BhblJlc3VsdCkge1xuICAgIGNvbnN0IHNwYW5JZCA9IGhhbmRsZXJEYXRhLmZldGNoRGF0YS5fX3NwYW47XG4gICAgaWYgKCFzcGFuSWQpIHJldHVybjtcblxuICAgIGNvbnN0IHNwYW4gPSBzcGFuc1tzcGFuSWRdO1xuICAgIGlmIChzcGFuKSB7XG4gICAgICBlbmRTcGFuKHNwYW4sIGhhbmRsZXJEYXRhKTtcblxuICAgICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uby1keW5hbWljLWRlbGV0ZVxuICAgICAgZGVsZXRlIHNwYW5zW3NwYW5JZF07XG4gICAgfVxuICAgIHJldHVybiB1bmRlZmluZWQ7XG4gIH1cblxuICBjb25zdCBoYXNQYXJlbnQgPSAhIXNwYW5VdGlscy5nZXRBY3RpdmVTcGFuKCk7XG5cbiAgY29uc3Qgc3BhbiA9XG4gICAgc2hvdWxkQ3JlYXRlU3BhblJlc3VsdCAmJiBoYXNQYXJlbnRcbiAgICAgID8gdHJhY2Uuc3RhcnRJbmFjdGl2ZVNwYW4oZ2V0U3BhblN0YXJ0T3B0aW9ucyh1cmwsIG1ldGhvZCwgc3Bhbk9yaWdpbikpXG4gICAgICA6IG5ldyBzZW50cnlOb25SZWNvcmRpbmdTcGFuLlNlbnRyeU5vblJlY29yZGluZ1NwYW4oKTtcblxuICBoYW5kbGVyRGF0YS5mZXRjaERhdGEuX19zcGFuID0gc3Bhbi5zcGFuQ29udGV4dCgpLnNwYW5JZDtcbiAgc3BhbnNbc3Bhbi5zcGFuQ29udGV4dCgpLnNwYW5JZF0gPSBzcGFuO1xuXG4gIGlmIChzaG91bGRBdHRhY2hIZWFkZXJzKGhhbmRsZXJEYXRhLmZldGNoRGF0YS51cmwpKSB7XG4gICAgY29uc3QgcmVxdWVzdCA9IGhhbmRsZXJEYXRhLmFyZ3NbMF07XG5cbiAgICBjb25zdCBvcHRpb25zID0gaGFuZGxlckRhdGEuYXJnc1sxXSB8fCB7fTtcblxuICAgIGNvbnN0IGhlYWRlcnMgPSBfYWRkVHJhY2luZ0hlYWRlcnNUb0ZldGNoUmVxdWVzdChcbiAgICAgIHJlcXVlc3QsXG4gICAgICBvcHRpb25zLFxuICAgICAgLy8gSWYgcGVyZm9ybWFuY2UgaXMgZGlzYWJsZWQgKFRXUCkgb3IgdGhlcmUncyBubyBhY3RpdmUgcm9vdCBzcGFuIChwYWdlbG9hZC9uYXZpZ2F0aW9uL2ludGVyYWN0aW9uKSxcbiAgICAgIC8vIHdlIGRvIG5vdCB3YW50IHRvIHVzZSB0aGUgc3BhbiBhcyBiYXNlIGZvciB0aGUgdHJhY2UgaGVhZGVycyxcbiAgICAgIC8vIHdoaWNoIG1lYW5zIHRoYXQgdGhlIGhlYWRlcnMgd2lsbCBiZSBnZW5lcmF0ZWQgZnJvbSB0aGUgc2NvcGUgYW5kIHRoZSBzYW1wbGluZyBkZWNpc2lvbiBpcyBkZWZlcnJlZFxuICAgICAgaGFzU3BhbnNFbmFibGVkLmhhc1NwYW5zRW5hYmxlZCgpICYmIGhhc1BhcmVudCA/IHNwYW4gOiB1bmRlZmluZWQsXG4gICAgKTtcbiAgICBpZiAoaGVhZGVycykge1xuICAgICAgLy8gRW5zdXJlIHRoaXMgaXMgYWN0dWFsbHkgc2V0LCBpZiBubyBvcHRpb25zIGhhdmUgYmVlbiBwYXNzZWQgcHJldmlvdXNseVxuICAgICAgaGFuZGxlckRhdGEuYXJnc1sxXSA9IG9wdGlvbnM7XG4gICAgICBvcHRpb25zLmhlYWRlcnMgPSBoZWFkZXJzO1xuICAgIH1cbiAgfVxuXG4gIGNvbnN0IGNsaWVudCA9IGN1cnJlbnRTY29wZXMuZ2V0Q2xpZW50KCk7XG5cbiAgaWYgKGNsaWVudCkge1xuICAgIGNvbnN0IGZldGNoSGludCA9IHtcbiAgICAgIGlucHV0OiBoYW5kbGVyRGF0YS5hcmdzLFxuICAgICAgcmVzcG9uc2U6IGhhbmRsZXJEYXRhLnJlc3BvbnNlLFxuICAgICAgc3RhcnRUaW1lc3RhbXA6IGhhbmRsZXJEYXRhLnN0YXJ0VGltZXN0YW1wLFxuICAgICAgZW5kVGltZXN0YW1wOiBoYW5kbGVyRGF0YS5lbmRUaW1lc3RhbXAsXG4gICAgfSA7XG5cbiAgICBjbGllbnQuZW1pdCgnYmVmb3JlT3V0Z29pbmdSZXF1ZXN0U3BhbicsIHNwYW4sIGZldGNoSGludCk7XG4gIH1cblxuICByZXR1cm4gc3Bhbjtcbn1cblxuLyoqXG4gKiBBZGRzIHNlbnRyeS10cmFjZSBhbmQgYmFnZ2FnZSBoZWFkZXJzIHRvIHRoZSB2YXJpb3VzIGZvcm1zIG9mIGZldGNoIGhlYWRlcnMuXG4gKiBleHBvcnRlZCBvbmx5IGZvciB0ZXN0aW5nIHB1cnBvc2VzXG4gKlxuICogV2hlbiB3ZSBkZXRlcm1pbmUgaWYgd2Ugc2hvdWxkIGFkZCBhIGJhZ2dhZ2UgaGVhZGVyLCB0aGVyZSBhcmUgMyBjYXNlczpcbiAqIDEuIE5vIHByZXZpb3VzIGJhZ2dhZ2UgaGVhZGVyIC0+IGFkZCBiYWdnYWdlXG4gKiAyLiBQcmV2aW91cyBiYWdnYWdlIGhlYWRlciBoYXMgbm8gc2VudHJ5IGJhZ2dhZ2UgdmFsdWVzIC0+IGFkZCBvdXIgYmFnZ2FnZVxuICogMy4gUHJldmlvdXMgYmFnZ2FnZSBoZWFkZXIgaGFzIHNlbnRyeSBiYWdnYWdlIHZhbHVlcyAtPiBkbyBub3RoaW5nIChtaWdodCBoYXZlIGJlZW4gYWRkZWQgbWFudWFsbHkgYnkgdXNlcnMpXG4gKi9cbi8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBjb21wbGV4aXR5IC0tIHl1cCBpdCdzIHRoaXMgY29tcGxpY2F0ZWQgOihcbmZ1bmN0aW9uIF9hZGRUcmFjaW5nSGVhZGVyc1RvRmV0Y2hSZXF1ZXN0KFxuICByZXF1ZXN0LFxuICBmZXRjaE9wdGlvbnNPYmpcblxuLFxuICBzcGFuLFxuKSB7XG4gIGNvbnN0IHRyYWNlSGVhZGVycyA9IHRyYWNlRGF0YS5nZXRUcmFjZURhdGEoeyBzcGFuIH0pO1xuICBjb25zdCBzZW50cnlUcmFjZSA9IHRyYWNlSGVhZGVyc1snc2VudHJ5LXRyYWNlJ107XG4gIGNvbnN0IGJhZ2dhZ2UgPSB0cmFjZUhlYWRlcnMuYmFnZ2FnZTtcblxuICAvLyBOb3RoaW5nIHRvIGRvLCB3aGVuIHdlIHJldHVybiB1bmRlZmluZWQgaGVyZSwgdGhlIG9yaWdpbmFsIGhlYWRlcnMgd2lsbCBiZSB1c2VkXG4gIGlmICghc2VudHJ5VHJhY2UpIHtcbiAgICByZXR1cm4gdW5kZWZpbmVkO1xuICB9XG5cbiAgY29uc3Qgb3JpZ2luYWxIZWFkZXJzID0gZmV0Y2hPcHRpb25zT2JqLmhlYWRlcnMgfHwgKGlzLmlzUmVxdWVzdChyZXF1ZXN0KSA/IHJlcXVlc3QuaGVhZGVycyA6IHVuZGVmaW5lZCk7XG5cbiAgaWYgKCFvcmlnaW5hbEhlYWRlcnMpIHtcbiAgICByZXR1cm4geyAuLi50cmFjZUhlYWRlcnMgfTtcbiAgfSBlbHNlIGlmIChpc0hlYWRlcnMob3JpZ2luYWxIZWFkZXJzKSkge1xuICAgIGNvbnN0IG5ld0hlYWRlcnMgPSBuZXcgSGVhZGVycyhvcmlnaW5hbEhlYWRlcnMpO1xuXG4gICAgLy8gV2UgZG9uJ3Qgd2FudCB0byBvdmVycmlkZSBtYW51YWxseSBhZGRlZCBzZW50cnkgaGVhZGVyc1xuICAgIGlmICghbmV3SGVhZGVycy5nZXQoJ3NlbnRyeS10cmFjZScpKSB7XG4gICAgICBuZXdIZWFkZXJzLnNldCgnc2VudHJ5LXRyYWNlJywgc2VudHJ5VHJhY2UpO1xuICAgIH1cblxuICAgIGlmIChiYWdnYWdlKSB7XG4gICAgICBjb25zdCBwcmV2QmFnZ2FnZUhlYWRlciA9IG5ld0hlYWRlcnMuZ2V0KCdiYWdnYWdlJyk7XG5cbiAgICAgIGlmICghcHJldkJhZ2dhZ2VIZWFkZXIpIHtcbiAgICAgICAgbmV3SGVhZGVycy5zZXQoJ2JhZ2dhZ2UnLCBiYWdnYWdlKTtcbiAgICAgIH0gZWxzZSBpZiAoIWJhZ2dhZ2VIZWFkZXJIYXNTZW50cnlCYWdnYWdlVmFsdWVzKHByZXZCYWdnYWdlSGVhZGVyKSkge1xuICAgICAgICBuZXdIZWFkZXJzLnNldCgnYmFnZ2FnZScsIGAke3ByZXZCYWdnYWdlSGVhZGVyfSwke2JhZ2dhZ2V9YCk7XG4gICAgICB9XG4gICAgfVxuXG4gICAgcmV0dXJuIG5ld0hlYWRlcnM7XG4gIH0gZWxzZSBpZiAoQXJyYXkuaXNBcnJheShvcmlnaW5hbEhlYWRlcnMpKSB7XG4gICAgY29uc3QgbmV3SGVhZGVycyA9IFsuLi5vcmlnaW5hbEhlYWRlcnNdO1xuXG4gICAgaWYgKCFvcmlnaW5hbEhlYWRlcnMuZmluZChoZWFkZXIgPT4gaGVhZGVyWzBdID09PSAnc2VudHJ5LXRyYWNlJykpIHtcbiAgICAgIG5ld0hlYWRlcnMucHVzaChbJ3NlbnRyeS10cmFjZScsIHNlbnRyeVRyYWNlXSk7XG4gICAgfVxuXG4gICAgY29uc3QgcHJldkJhZ2dhZ2VIZWFkZXJXaXRoU2VudHJ5VmFsdWVzID0gb3JpZ2luYWxIZWFkZXJzLmZpbmQoXG4gICAgICBoZWFkZXIgPT4gaGVhZGVyWzBdID09PSAnYmFnZ2FnZScgJiYgYmFnZ2FnZUhlYWRlckhhc1NlbnRyeUJhZ2dhZ2VWYWx1ZXMoaGVhZGVyWzFdKSxcbiAgICApO1xuXG4gICAgaWYgKGJhZ2dhZ2UgJiYgIXByZXZCYWdnYWdlSGVhZGVyV2l0aFNlbnRyeVZhbHVlcykge1xuICAgICAgLy8gSWYgdGhlcmUgYXJlIG11bHRpcGxlIGVudHJpZXMgd2l0aCB0aGUgc2FtZSBrZXksIHRoZSBicm93c2VyIHdpbGwgbWVyZ2UgdGhlIHZhbHVlcyBpbnRvIGEgc2luZ2xlIHJlcXVlc3QgaGVhZGVyLlxuICAgICAgLy8gSXRzIHRoZXJlZm9yZSBzYWZlIHRvIHNpbXBseSBwdXNoIGEgXCJiYWdnYWdlXCIgZW50cnksIGV2ZW4gdGhvdWdoIHRoZXJlIG1pZ2h0IGFscmVhZHkgYmUgYW5vdGhlciBiYWdnYWdlIGhlYWRlci5cbiAgICAgIG5ld0hlYWRlcnMucHVzaChbJ2JhZ2dhZ2UnLCBiYWdnYWdlXSk7XG4gICAgfVxuXG4gICAgcmV0dXJuIG5ld0hlYWRlcnMgO1xuICB9IGVsc2Uge1xuICAgIGNvbnN0IGV4aXN0aW5nU2VudHJ5VHJhY2VIZWFkZXIgPSAnc2VudHJ5LXRyYWNlJyBpbiBvcmlnaW5hbEhlYWRlcnMgPyBvcmlnaW5hbEhlYWRlcnNbJ3NlbnRyeS10cmFjZSddIDogdW5kZWZpbmVkO1xuXG4gICAgY29uc3QgZXhpc3RpbmdCYWdnYWdlSGVhZGVyID0gJ2JhZ2dhZ2UnIGluIG9yaWdpbmFsSGVhZGVycyA/IG9yaWdpbmFsSGVhZGVycy5iYWdnYWdlIDogdW5kZWZpbmVkO1xuICAgIGNvbnN0IG5ld0JhZ2dhZ2VIZWFkZXJzID0gZXhpc3RpbmdCYWdnYWdlSGVhZGVyXG4gICAgICA/IEFycmF5LmlzQXJyYXkoZXhpc3RpbmdCYWdnYWdlSGVhZGVyKVxuICAgICAgICA/IFsuLi5leGlzdGluZ0JhZ2dhZ2VIZWFkZXJdXG4gICAgICAgIDogW2V4aXN0aW5nQmFnZ2FnZUhlYWRlcl1cbiAgICAgIDogW107XG5cbiAgICBjb25zdCBwcmV2QmFnZ2FnZUhlYWRlcldpdGhTZW50cnlWYWx1ZXMgPVxuICAgICAgZXhpc3RpbmdCYWdnYWdlSGVhZGVyICYmXG4gICAgICAoQXJyYXkuaXNBcnJheShleGlzdGluZ0JhZ2dhZ2VIZWFkZXIpXG4gICAgICAgID8gZXhpc3RpbmdCYWdnYWdlSGVhZGVyLmZpbmQoaGVhZGVySXRlbSA9PiBiYWdnYWdlSGVhZGVySGFzU2VudHJ5QmFnZ2FnZVZhbHVlcyhoZWFkZXJJdGVtKSlcbiAgICAgICAgOiBiYWdnYWdlSGVhZGVySGFzU2VudHJ5QmFnZ2FnZVZhbHVlcyhleGlzdGluZ0JhZ2dhZ2VIZWFkZXIpKTtcblxuICAgIGlmIChiYWdnYWdlICYmICFwcmV2QmFnZ2FnZUhlYWRlcldpdGhTZW50cnlWYWx1ZXMpIHtcbiAgICAgIG5ld0JhZ2dhZ2VIZWFkZXJzLnB1c2goYmFnZ2FnZSk7XG4gICAgfVxuXG4gICAgcmV0dXJuIHtcbiAgICAgIC4uLihvcmlnaW5hbEhlYWRlcnMgKSxcbiAgICAgICdzZW50cnktdHJhY2UnOiAoZXhpc3RpbmdTZW50cnlUcmFjZUhlYWRlciApID8/IHNlbnRyeVRyYWNlLFxuICAgICAgYmFnZ2FnZTogbmV3QmFnZ2FnZUhlYWRlcnMubGVuZ3RoID4gMCA/IG5ld0JhZ2dhZ2VIZWFkZXJzLmpvaW4oJywnKSA6IHVuZGVmaW5lZCxcbiAgICB9O1xuICB9XG59XG5cbmZ1bmN0aW9uIGVuZFNwYW4oc3BhbiwgaGFuZGxlckRhdGEpIHtcbiAgaWYgKGhhbmRsZXJEYXRhLnJlc3BvbnNlKSB7XG4gICAgc3BhbnN0YXR1cy5zZXRIdHRwU3RhdHVzKHNwYW4sIGhhbmRsZXJEYXRhLnJlc3BvbnNlLnN0YXR1cyk7XG5cbiAgICBjb25zdCBjb250ZW50TGVuZ3RoID0gaGFuZGxlckRhdGEucmVzcG9uc2U/LmhlYWRlcnM/LmdldCgnY29udGVudC1sZW5ndGgnKTtcblxuICAgIGlmIChjb250ZW50TGVuZ3RoKSB7XG4gICAgICBjb25zdCBjb250ZW50TGVuZ3RoTnVtID0gcGFyc2VJbnQoY29udGVudExlbmd0aCk7XG4gICAgICBpZiAoY29udGVudExlbmd0aE51bSA+IDApIHtcbiAgICAgICAgc3Bhbi5zZXRBdHRyaWJ1dGUoJ2h0dHAucmVzcG9uc2VfY29udGVudF9sZW5ndGgnLCBjb250ZW50TGVuZ3RoTnVtKTtcbiAgICAgIH1cbiAgICB9XG4gIH0gZWxzZSBpZiAoaGFuZGxlckRhdGEuZXJyb3IpIHtcbiAgICBzcGFuLnNldFN0YXR1cyh7IGNvZGU6IHNwYW5zdGF0dXMuU1BBTl9TVEFUVVNfRVJST1IsIG1lc3NhZ2U6ICdpbnRlcm5hbF9lcnJvcicgfSk7XG4gIH1cbiAgc3Bhbi5lbmQoKTtcbn1cblxuZnVuY3Rpb24gYmFnZ2FnZUhlYWRlckhhc1NlbnRyeUJhZ2dhZ2VWYWx1ZXMoYmFnZ2FnZUhlYWRlcikge1xuICByZXR1cm4gYmFnZ2FnZUhlYWRlci5zcGxpdCgnLCcpLnNvbWUoYmFnZ2FnZUVudHJ5ID0+IGJhZ2dhZ2VFbnRyeS50cmltKCkuc3RhcnRzV2l0aChiYWdnYWdlLlNFTlRSWV9CQUdHQUdFX0tFWV9QUkVGSVgpKTtcbn1cblxuZnVuY3Rpb24gaXNIZWFkZXJzKGhlYWRlcnMpIHtcbiAgcmV0dXJuIHR5cGVvZiBIZWFkZXJzICE9PSAndW5kZWZpbmVkJyAmJiBpcy5pc0luc3RhbmNlT2YoaGVhZGVycywgSGVhZGVycyk7XG59XG5cbmZ1bmN0aW9uIGdldFNwYW5TdGFydE9wdGlvbnMoXG4gIHVybCQxLFxuICBtZXRob2QsXG4gIHNwYW5PcmlnaW4sXG4pIHtcbiAgY29uc3QgcGFyc2VkVXJsID0gdXJsLnBhcnNlU3RyaW5nVG9VUkxPYmplY3QodXJsJDEpO1xuICByZXR1cm4ge1xuICAgIG5hbWU6IHBhcnNlZFVybCA/IGAke21ldGhvZH0gJHt1cmwuZ2V0U2FuaXRpemVkVXJsU3RyaW5nRnJvbVVybE9iamVjdChwYXJzZWRVcmwpfWAgOiBtZXRob2QsXG4gICAgYXR0cmlidXRlczogZ2V0RmV0Y2hTcGFuQXR0cmlidXRlcyh1cmwkMSwgcGFyc2VkVXJsLCBtZXRob2QsIHNwYW5PcmlnaW4pLFxuICB9O1xufVxuXG5mdW5jdGlvbiBnZXRGZXRjaFNwYW5BdHRyaWJ1dGVzKFxuICB1cmwkMSxcbiAgcGFyc2VkVXJsLFxuICBtZXRob2QsXG4gIHNwYW5PcmlnaW4sXG4pIHtcbiAgY29uc3QgYXR0cmlidXRlcyA9IHtcbiAgICB1cmw6IHVybCQxLFxuICAgIHR5cGU6ICdmZXRjaCcsXG4gICAgJ2h0dHAubWV0aG9kJzogbWV0aG9kLFxuICAgIFtzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9PUklHSU5dOiBzcGFuT3JpZ2luLFxuICAgIFtzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9PUF06ICdodHRwLmNsaWVudCcsXG4gIH07XG4gIGlmIChwYXJzZWRVcmwpIHtcbiAgICBpZiAoIXVybC5pc1VSTE9iamVjdFJlbGF0aXZlKHBhcnNlZFVybCkpIHtcbiAgICAgIGF0dHJpYnV0ZXNbJ2h0dHAudXJsJ10gPSBwYXJzZWRVcmwuaHJlZjtcbiAgICAgIGF0dHJpYnV0ZXNbJ3NlcnZlci5hZGRyZXNzJ10gPSBwYXJzZWRVcmwuaG9zdDtcbiAgICB9XG4gICAgaWYgKHBhcnNlZFVybC5zZWFyY2gpIHtcbiAgICAgIGF0dHJpYnV0ZXNbJ2h0dHAucXVlcnknXSA9IHBhcnNlZFVybC5zZWFyY2g7XG4gICAgfVxuICAgIGlmIChwYXJzZWRVcmwuaGFzaCkge1xuICAgICAgYXR0cmlidXRlc1snaHR0cC5mcmFnbWVudCddID0gcGFyc2VkVXJsLmhhc2g7XG4gICAgfVxuICB9XG4gIHJldHVybiBhdHRyaWJ1dGVzO1xufVxuXG5leHBvcnRzLl9hZGRUcmFjaW5nSGVhZGVyc1RvRmV0Y2hSZXF1ZXN0ID0gX2FkZFRyYWNpbmdIZWFkZXJzVG9GZXRjaFJlcXVlc3Q7XG5leHBvcnRzLmluc3RydW1lbnRGZXRjaFJlcXVlc3QgPSBpbnN0cnVtZW50RmV0Y2hSZXF1ZXN0O1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9ZmV0Y2guanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/fetch.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/index.js":
/*!*********************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/index.js ***!
  \*********************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst errors = __webpack_require__(/*! ./tracing/errors.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/errors.js\");\nconst utils = __webpack_require__(/*! ./tracing/utils.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/utils.js\");\nconst idleSpan = __webpack_require__(/*! ./tracing/idleSpan.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/idleSpan.js\");\nconst sentrySpan = __webpack_require__(/*! ./tracing/sentrySpan.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/sentrySpan.js\");\nconst sentryNonRecordingSpan = __webpack_require__(/*! ./tracing/sentryNonRecordingSpan.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/sentryNonRecordingSpan.js\");\nconst spanstatus = __webpack_require__(/*! ./tracing/spanstatus.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/spanstatus.js\");\nconst trace = __webpack_require__(/*! ./tracing/trace.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/trace.js\");\nconst dynamicSamplingContext = __webpack_require__(/*! ./tracing/dynamicSamplingContext.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/dynamicSamplingContext.js\");\nconst measurement = __webpack_require__(/*! ./tracing/measurement.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/measurement.js\");\nconst sampling = __webpack_require__(/*! ./tracing/sampling.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/sampling.js\");\nconst logSpans = __webpack_require__(/*! ./tracing/logSpans.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/logSpans.js\");\nconst semanticAttributes = __webpack_require__(/*! ./semanticAttributes.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/semanticAttributes.js\");\nconst envelope = __webpack_require__(/*! ./envelope.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/envelope.js\");\nconst exports$1 = __webpack_require__(/*! ./exports.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/exports.js\");\nconst currentScopes = __webpack_require__(/*! ./currentScopes.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst defaultScopes = __webpack_require__(/*! ./defaultScopes.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/defaultScopes.js\");\nconst index = __webpack_require__(/*! ./asyncContext/index.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/asyncContext/index.js\");\nconst carrier = __webpack_require__(/*! ./carrier.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/carrier.js\");\nconst session = __webpack_require__(/*! ./session.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/session.js\");\nconst scope = __webpack_require__(/*! ./scope.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/scope.js\");\nconst eventProcessors = __webpack_require__(/*! ./eventProcessors.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/eventProcessors.js\");\nconst api = __webpack_require__(/*! ./api.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/api.js\");\nconst client = __webpack_require__(/*! ./client.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/client.js\");\nconst serverRuntimeClient = __webpack_require__(/*! ./server-runtime-client.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/server-runtime-client.js\");\nconst sdk = __webpack_require__(/*! ./sdk.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/sdk.js\");\nconst base = __webpack_require__(/*! ./transports/base.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/transports/base.js\");\nconst offline = __webpack_require__(/*! ./transports/offline.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/transports/offline.js\");\nconst multiplexed = __webpack_require__(/*! ./transports/multiplexed.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/transports/multiplexed.js\");\nconst integration = __webpack_require__(/*! ./integration.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integration.js\");\nconst applyScopeDataToEvent = __webpack_require__(/*! ./utils/applyScopeDataToEvent.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/applyScopeDataToEvent.js\");\nconst prepareEvent = __webpack_require__(/*! ./utils/prepareEvent.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/prepareEvent.js\");\nconst checkin = __webpack_require__(/*! ./checkin.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/checkin.js\");\nconst hasSpansEnabled = __webpack_require__(/*! ./utils/hasSpansEnabled.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/hasSpansEnabled.js\");\nconst isSentryRequestUrl = __webpack_require__(/*! ./utils/isSentryRequestUrl.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/isSentryRequestUrl.js\");\nconst handleCallbackErrors = __webpack_require__(/*! ./utils/handleCallbackErrors.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/handleCallbackErrors.js\");\nconst parameterize = __webpack_require__(/*! ./utils/parameterize.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/parameterize.js\");\nconst ipAddress = __webpack_require__(/*! ./utils/ipAddress.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/ipAddress.js\");\nconst spanUtils = __webpack_require__(/*! ./utils/spanUtils.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanUtils.js\");\nconst parseSampleRate = __webpack_require__(/*! ./utils/parseSampleRate.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/parseSampleRate.js\");\nconst sdkMetadata = __webpack_require__(/*! ./utils/sdkMetadata.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/sdkMetadata.js\");\nconst traceData = __webpack_require__(/*! ./utils/traceData.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/traceData.js\");\nconst meta = __webpack_require__(/*! ./utils/meta.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/meta.js\");\nconst debounce = __webpack_require__(/*! ./utils/debounce.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debounce.js\");\nconst request = __webpack_require__(/*! ./utils/request.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/request.js\");\nconst constants = __webpack_require__(/*! ./constants.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/constants.js\");\nconst breadcrumbs = __webpack_require__(/*! ./breadcrumbs.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/breadcrumbs.js\");\nconst functiontostring = __webpack_require__(/*! ./integrations/functiontostring.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/functiontostring.js\");\nconst eventFilters = __webpack_require__(/*! ./integrations/eventFilters.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/eventFilters.js\");\nconst linkederrors = __webpack_require__(/*! ./integrations/linkederrors.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/linkederrors.js\");\nconst metadata = __webpack_require__(/*! ./integrations/metadata.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/metadata.js\");\nconst requestdata = __webpack_require__(/*! ./integrations/requestdata.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/requestdata.js\");\nconst captureconsole = __webpack_require__(/*! ./integrations/captureconsole.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/captureconsole.js\");\nconst dedupe = __webpack_require__(/*! ./integrations/dedupe.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/dedupe.js\");\nconst extraerrordata = __webpack_require__(/*! ./integrations/extraerrordata.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/extraerrordata.js\");\nconst rewriteframes = __webpack_require__(/*! ./integrations/rewriteframes.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/rewriteframes.js\");\nconst supabase = __webpack_require__(/*! ./integrations/supabase.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/supabase.js\");\nconst zoderrors = __webpack_require__(/*! ./integrations/zoderrors.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/zoderrors.js\");\nconst thirdPartyErrorsFilter = __webpack_require__(/*! ./integrations/third-party-errors-filter.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/third-party-errors-filter.js\");\nconst console = __webpack_require__(/*! ./integrations/console.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/console.js\");\nconst featureFlagsIntegration = __webpack_require__(/*! ./integrations/featureFlags/featureFlagsIntegration.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/featureFlags/featureFlagsIntegration.js\");\nconst profiling = __webpack_require__(/*! ./profiling.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/profiling.js\");\nconst fetch = __webpack_require__(/*! ./fetch.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/fetch.js\");\nconst trpc = __webpack_require__(/*! ./trpc.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/trpc.js\");\nconst index$1 = __webpack_require__(/*! ./integrations/mcp-server/index.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/index.js\");\nconst feedback = __webpack_require__(/*! ./feedback.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/feedback.js\");\nconst exports$2 = __webpack_require__(/*! ./logs/exports.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/logs/exports.js\");\nconst consoleIntegration = __webpack_require__(/*! ./logs/console-integration.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/logs/console-integration.js\");\nconst vercelAi = __webpack_require__(/*! ./utils/vercel-ai.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/vercel-ai.js\");\nconst index$2 = __webpack_require__(/*! ./utils/openai/index.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/openai/index.js\");\nconst constants$1 = __webpack_require__(/*! ./utils/openai/constants.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/openai/constants.js\");\nconst featureFlags = __webpack_require__(/*! ./utils/featureFlags.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/featureFlags.js\");\nconst aggregateErrors = __webpack_require__(/*! ./utils/aggregate-errors.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/aggregate-errors.js\");\nconst breadcrumbLogLevel = __webpack_require__(/*! ./utils/breadcrumb-log-level.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/breadcrumb-log-level.js\");\nconst browser = __webpack_require__(/*! ./utils/browser.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/browser.js\");\nconst dsn = __webpack_require__(/*! ./utils/dsn.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/dsn.js\");\nconst error = __webpack_require__(/*! ./utils/error.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/error.js\");\nconst worldwide = __webpack_require__(/*! ./utils/worldwide.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/worldwide.js\");\nconst console$1 = __webpack_require__(/*! ./instrument/console.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/console.js\");\nconst fetch$1 = __webpack_require__(/*! ./instrument/fetch.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/fetch.js\");\nconst globalError = __webpack_require__(/*! ./instrument/globalError.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/globalError.js\");\nconst globalUnhandledRejection = __webpack_require__(/*! ./instrument/globalUnhandledRejection.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/globalUnhandledRejection.js\");\nconst handlers = __webpack_require__(/*! ./instrument/handlers.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/handlers.js\");\nconst is = __webpack_require__(/*! ./utils/is.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js\");\nconst isBrowser = __webpack_require__(/*! ./utils/isBrowser.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/isBrowser.js\");\nconst debugLogger = __webpack_require__(/*! ./utils/debug-logger.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst misc = __webpack_require__(/*! ./utils/misc.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/misc.js\");\nconst node = __webpack_require__(/*! ./utils/node.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/node.js\");\nconst normalize = __webpack_require__(/*! ./utils/normalize.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/normalize.js\");\nconst object = __webpack_require__(/*! ./utils/object.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/object.js\");\nconst path = __webpack_require__(/*! ./utils/path.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/path.js\");\nconst promisebuffer = __webpack_require__(/*! ./utils/promisebuffer.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/promisebuffer.js\");\nconst severity = __webpack_require__(/*! ./utils/severity.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/severity.js\");\nconst stacktrace = __webpack_require__(/*! ./utils/stacktrace.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/stacktrace.js\");\nconst nodeStackTrace = __webpack_require__(/*! ./utils/node-stack-trace.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/node-stack-trace.js\");\nconst string = __webpack_require__(/*! ./utils/string.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/string.js\");\nconst supports = __webpack_require__(/*! ./utils/supports.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/supports.js\");\nconst syncpromise = __webpack_require__(/*! ./utils/syncpromise.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/syncpromise.js\");\nconst time = __webpack_require__(/*! ./utils/time.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/time.js\");\nconst tracing = __webpack_require__(/*! ./utils/tracing.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/tracing.js\");\nconst env = __webpack_require__(/*! ./utils/env.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/env.js\");\nconst envelope$1 = __webpack_require__(/*! ./utils/envelope.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/envelope.js\");\nconst clientreport = __webpack_require__(/*! ./utils/clientreport.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/clientreport.js\");\nconst ratelimit = __webpack_require__(/*! ./utils/ratelimit.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/ratelimit.js\");\nconst baggage = __webpack_require__(/*! ./utils/baggage.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/baggage.js\");\nconst url = __webpack_require__(/*! ./utils/url.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/url.js\");\nconst eventbuilder = __webpack_require__(/*! ./utils/eventbuilder.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/eventbuilder.js\");\nconst anr = __webpack_require__(/*! ./utils/anr.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/anr.js\");\nconst lru = __webpack_require__(/*! ./utils/lru.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/lru.js\");\nconst propagationContext = __webpack_require__(/*! ./utils/propagationContext.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/propagationContext.js\");\nconst vercelWaitUntil = __webpack_require__(/*! ./utils/vercelWaitUntil.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/vercelWaitUntil.js\");\nconst flushIfServerless = __webpack_require__(/*! ./utils/flushIfServerless.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/flushIfServerless.js\");\nconst version = __webpack_require__(/*! ./utils/version.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/version.js\");\nconst debugIds = __webpack_require__(/*! ./utils/debug-ids.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-ids.js\");\nconst escapeStringForRegex = __webpack_require__(/*! ./vendor/escapeStringForRegex.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/vendor/escapeStringForRegex.js\");\n\n\n\nexports.registerSpanErrorInstrumentation = errors.registerSpanErrorInstrumentation;\nexports.getCapturedScopesOnSpan = utils.getCapturedScopesOnSpan;\nexports.setCapturedScopesOnSpan = utils.setCapturedScopesOnSpan;\nexports.TRACING_DEFAULTS = idleSpan.TRACING_DEFAULTS;\nexports.startIdleSpan = idleSpan.startIdleSpan;\nexports.SentrySpan = sentrySpan.SentrySpan;\nexports.SentryNonRecordingSpan = sentryNonRecordingSpan.SentryNonRecordingSpan;\nexports.SPAN_STATUS_ERROR = spanstatus.SPAN_STATUS_ERROR;\nexports.SPAN_STATUS_OK = spanstatus.SPAN_STATUS_OK;\nexports.SPAN_STATUS_UNSET = spanstatus.SPAN_STATUS_UNSET;\nexports.getSpanStatusFromHttpCode = spanstatus.getSpanStatusFromHttpCode;\nexports.setHttpStatus = spanstatus.setHttpStatus;\nexports.continueTrace = trace.continueTrace;\nexports.startInactiveSpan = trace.startInactiveSpan;\nexports.startNewTrace = trace.startNewTrace;\nexports.startSpan = trace.startSpan;\nexports.startSpanManual = trace.startSpanManual;\nexports.suppressTracing = trace.suppressTracing;\nexports.withActiveSpan = trace.withActiveSpan;\nexports.getDynamicSamplingContextFromClient = dynamicSamplingContext.getDynamicSamplingContextFromClient;\nexports.getDynamicSamplingContextFromScope = dynamicSamplingContext.getDynamicSamplingContextFromScope;\nexports.getDynamicSamplingContextFromSpan = dynamicSamplingContext.getDynamicSamplingContextFromSpan;\nexports.spanToBaggageHeader = dynamicSamplingContext.spanToBaggageHeader;\nexports.setMeasurement = measurement.setMeasurement;\nexports.timedEventsToMeasurements = measurement.timedEventsToMeasurements;\nexports.sampleSpan = sampling.sampleSpan;\nexports.logSpanEnd = logSpans.logSpanEnd;\nexports.logSpanStart = logSpans.logSpanStart;\nexports.SEMANTIC_ATTRIBUTE_CACHE_HIT = semanticAttributes.SEMANTIC_ATTRIBUTE_CACHE_HIT;\nexports.SEMANTIC_ATTRIBUTE_CACHE_ITEM_SIZE = semanticAttributes.SEMANTIC_ATTRIBUTE_CACHE_ITEM_SIZE;\nexports.SEMANTIC_ATTRIBUTE_CACHE_KEY = semanticAttributes.SEMANTIC_ATTRIBUTE_CACHE_KEY;\nexports.SEMANTIC_ATTRIBUTE_EXCLUSIVE_TIME = semanticAttributes.SEMANTIC_ATTRIBUTE_EXCLUSIVE_TIME;\nexports.SEMANTIC_ATTRIBUTE_HTTP_REQUEST_METHOD = semanticAttributes.SEMANTIC_ATTRIBUTE_HTTP_REQUEST_METHOD;\nexports.SEMANTIC_ATTRIBUTE_PROFILE_ID = semanticAttributes.SEMANTIC_ATTRIBUTE_PROFILE_ID;\nexports.SEMANTIC_ATTRIBUTE_SENTRY_CUSTOM_SPAN_NAME = semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_CUSTOM_SPAN_NAME;\nexports.SEMANTIC_ATTRIBUTE_SENTRY_IDLE_SPAN_FINISH_REASON = semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_IDLE_SPAN_FINISH_REASON;\nexports.SEMANTIC_ATTRIBUTE_SENTRY_MEASUREMENT_UNIT = semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_MEASUREMENT_UNIT;\nexports.SEMANTIC_ATTRIBUTE_SENTRY_MEASUREMENT_VALUE = semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_MEASUREMENT_VALUE;\nexports.SEMANTIC_ATTRIBUTE_SENTRY_OP = semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_OP;\nexports.SEMANTIC_ATTRIBUTE_SENTRY_ORIGIN = semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_ORIGIN;\nexports.SEMANTIC_ATTRIBUTE_SENTRY_PREVIOUS_TRACE_SAMPLE_RATE = semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_PREVIOUS_TRACE_SAMPLE_RATE;\nexports.SEMANTIC_ATTRIBUTE_SENTRY_SAMPLE_RATE = semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_SAMPLE_RATE;\nexports.SEMANTIC_ATTRIBUTE_SENTRY_SOURCE = semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_SOURCE;\nexports.SEMANTIC_ATTRIBUTE_URL_FULL = semanticAttributes.SEMANTIC_ATTRIBUTE_URL_FULL;\nexports.SEMANTIC_LINK_ATTRIBUTE_LINK_TYPE = semanticAttributes.SEMANTIC_LINK_ATTRIBUTE_LINK_TYPE;\nexports.createEventEnvelope = envelope.createEventEnvelope;\nexports.createSessionEnvelope = envelope.createSessionEnvelope;\nexports.createSpanEnvelope = envelope.createSpanEnvelope;\nexports.addEventProcessor = exports$1.addEventProcessor;\nexports.captureCheckIn = exports$1.captureCheckIn;\nexports.captureEvent = exports$1.captureEvent;\nexports.captureException = exports$1.captureException;\nexports.captureMessage = exports$1.captureMessage;\nexports.captureSession = exports$1.captureSession;\nexports.close = exports$1.close;\nexports.endSession = exports$1.endSession;\nexports.flush = exports$1.flush;\nexports.isEnabled = exports$1.isEnabled;\nexports.isInitialized = exports$1.isInitialized;\nexports.lastEventId = exports$1.lastEventId;\nexports.setContext = exports$1.setContext;\nexports.setExtra = exports$1.setExtra;\nexports.setExtras = exports$1.setExtras;\nexports.setTag = exports$1.setTag;\nexports.setTags = exports$1.setTags;\nexports.setUser = exports$1.setUser;\nexports.startSession = exports$1.startSession;\nexports.withMonitor = exports$1.withMonitor;\nexports.getClient = currentScopes.getClient;\nexports.getCurrentScope = currentScopes.getCurrentScope;\nexports.getGlobalScope = currentScopes.getGlobalScope;\nexports.getIsolationScope = currentScopes.getIsolationScope;\nexports.getTraceContextFromScope = currentScopes.getTraceContextFromScope;\nexports.withIsolationScope = currentScopes.withIsolationScope;\nexports.withScope = currentScopes.withScope;\nexports.getDefaultCurrentScope = defaultScopes.getDefaultCurrentScope;\nexports.getDefaultIsolationScope = defaultScopes.getDefaultIsolationScope;\nexports.setAsyncContextStrategy = index.setAsyncContextStrategy;\nexports.getGlobalSingleton = carrier.getGlobalSingleton;\nexports.getMainCarrier = carrier.getMainCarrier;\nexports.closeSession = session.closeSession;\nexports.makeSession = session.makeSession;\nexports.updateSession = session.updateSession;\nexports.Scope = scope.Scope;\nexports.notifyEventProcessors = eventProcessors.notifyEventProcessors;\nexports.getEnvelopeEndpointWithUrlEncodedAuth = api.getEnvelopeEndpointWithUrlEncodedAuth;\nexports.getReportDialogEndpoint = api.getReportDialogEndpoint;\nexports.BaseClient = client.BaseClient;\nexports.Client = client.Client;\nexports.ServerRuntimeClient = serverRuntimeClient.ServerRuntimeClient;\nexports.initAndBind = sdk.initAndBind;\nexports.setCurrentClient = sdk.setCurrentClient;\nexports.createTransport = base.createTransport;\nexports.makeOfflineTransport = offline.makeOfflineTransport;\nexports.makeMultiplexedTransport = multiplexed.makeMultiplexedTransport;\nexports.addIntegration = integration.addIntegration;\nexports.defineIntegration = integration.defineIntegration;\nexports.getIntegrationsToSetup = integration.getIntegrationsToSetup;\nexports.applyScopeDataToEvent = applyScopeDataToEvent.applyScopeDataToEvent;\nexports.mergeScopeData = applyScopeDataToEvent.mergeScopeData;\nexports.prepareEvent = prepareEvent.prepareEvent;\nexports.createCheckInEnvelope = checkin.createCheckInEnvelope;\nexports.hasSpansEnabled = hasSpansEnabled.hasSpansEnabled;\nexports.hasTracingEnabled = hasSpansEnabled.hasTracingEnabled;\nexports.isSentryRequestUrl = isSentryRequestUrl.isSentryRequestUrl;\nexports.handleCallbackErrors = handleCallbackErrors.handleCallbackErrors;\nexports.fmt = parameterize.fmt;\nexports.parameterize = parameterize.parameterize;\nexports.addAutoIpAddressToSession = ipAddress.addAutoIpAddressToSession;\nexports.addAutoIpAddressToUser = ipAddress.addAutoIpAddressToUser;\nexports.addChildSpanToSpan = spanUtils.addChildSpanToSpan;\nexports.convertSpanLinksForEnvelope = spanUtils.convertSpanLinksForEnvelope;\nexports.getActiveSpan = spanUtils.getActiveSpan;\nexports.getRootSpan = spanUtils.getRootSpan;\nexports.getSpanDescendants = spanUtils.getSpanDescendants;\nexports.getStatusMessage = spanUtils.getStatusMessage;\nexports.spanIsSampled = spanUtils.spanIsSampled;\nexports.spanTimeInputToSeconds = spanUtils.spanTimeInputToSeconds;\nexports.spanToJSON = spanUtils.spanToJSON;\nexports.spanToTraceContext = spanUtils.spanToTraceContext;\nexports.spanToTraceHeader = spanUtils.spanToTraceHeader;\nexports.updateSpanName = spanUtils.updateSpanName;\nexports.parseSampleRate = parseSampleRate.parseSampleRate;\nexports.applySdkMetadata = sdkMetadata.applySdkMetadata;\nexports.getTraceData = traceData.getTraceData;\nexports.getTraceMetaTags = meta.getTraceMetaTags;\nexports.debounce = debounce.debounce;\nexports.extractQueryParamsFromUrl = request.extractQueryParamsFromUrl;\nexports.headersToDict = request.headersToDict;\nexports.httpRequestToRequestData = request.httpRequestToRequestData;\nexports.winterCGHeadersToDict = request.winterCGHeadersToDict;\nexports.winterCGRequestToRequestData = request.winterCGRequestToRequestData;\nexports.DEFAULT_ENVIRONMENT = constants.DEFAULT_ENVIRONMENT;\nexports.addBreadcrumb = breadcrumbs.addBreadcrumb;\nexports.functionToStringIntegration = functiontostring.functionToStringIntegration;\nexports.eventFiltersIntegration = eventFilters.eventFiltersIntegration;\nexports.inboundFiltersIntegration = eventFilters.inboundFiltersIntegration;\nexports.linkedErrorsIntegration = linkederrors.linkedErrorsIntegration;\nexports.moduleMetadataIntegration = metadata.moduleMetadataIntegration;\nexports.requestDataIntegration = requestdata.requestDataIntegration;\nexports.captureConsoleIntegration = captureconsole.captureConsoleIntegration;\nexports.dedupeIntegration = dedupe.dedupeIntegration;\nexports.extraErrorDataIntegration = extraerrordata.extraErrorDataIntegration;\nexports.rewriteFramesIntegration = rewriteframes.rewriteFramesIntegration;\nexports.instrumentSupabaseClient = supabase.instrumentSupabaseClient;\nexports.supabaseIntegration = supabase.supabaseIntegration;\nexports.zodErrorsIntegration = zoderrors.zodErrorsIntegration;\nexports.thirdPartyErrorFilterIntegration = thirdPartyErrorsFilter.thirdPartyErrorFilterIntegration;\nexports.consoleIntegration = console.consoleIntegration;\nexports.featureFlagsIntegration = featureFlagsIntegration.featureFlagsIntegration;\nexports.profiler = profiling.profiler;\nexports.instrumentFetchRequest = fetch.instrumentFetchRequest;\nexports.trpcMiddleware = trpc.trpcMiddleware;\nexports.wrapMcpServerWithSentry = index$1.wrapMcpServerWithSentry;\nexports.captureFeedback = feedback.captureFeedback;\nexports._INTERNAL_captureLog = exports$2._INTERNAL_captureLog;\nexports._INTERNAL_captureSerializedLog = exports$2._INTERNAL_captureSerializedLog;\nexports._INTERNAL_flushLogsBuffer = exports$2._INTERNAL_flushLogsBuffer;\nexports.consoleLoggingIntegration = consoleIntegration.consoleLoggingIntegration;\nexports.addVercelAiProcessors = vercelAi.addVercelAiProcessors;\nexports.instrumentOpenAiClient = index$2.instrumentOpenAiClient;\nexports.OPENAI_INTEGRATION_NAME = constants$1.OPENAI_INTEGRATION_NAME;\nexports._INTERNAL_FLAG_BUFFER_SIZE = featureFlags._INTERNAL_FLAG_BUFFER_SIZE;\nexports._INTERNAL_MAX_FLAGS_PER_SPAN = featureFlags._INTERNAL_MAX_FLAGS_PER_SPAN;\nexports._INTERNAL_addFeatureFlagToActiveSpan = featureFlags._INTERNAL_addFeatureFlagToActiveSpan;\nexports._INTERNAL_copyFlagsFromScopeToEvent = featureFlags._INTERNAL_copyFlagsFromScopeToEvent;\nexports._INTERNAL_insertFlagToScope = featureFlags._INTERNAL_insertFlagToScope;\nexports.applyAggregateErrorsToEvent = aggregateErrors.applyAggregateErrorsToEvent;\nexports.getBreadcrumbLogLevelFromHttpStatusCode = breadcrumbLogLevel.getBreadcrumbLogLevelFromHttpStatusCode;\nexports.getComponentName = browser.getComponentName;\nexports.getLocationHref = browser.getLocationHref;\nexports.htmlTreeAsString = browser.htmlTreeAsString;\nexports.dsnFromString = dsn.dsnFromString;\nexports.dsnToString = dsn.dsnToString;\nexports.makeDsn = dsn.makeDsn;\nexports.SentryError = error.SentryError;\nexports.GLOBAL_OBJ = worldwide.GLOBAL_OBJ;\nexports.addConsoleInstrumentationHandler = console$1.addConsoleInstrumentationHandler;\nexports.addFetchEndInstrumentationHandler = fetch$1.addFetchEndInstrumentationHandler;\nexports.addFetchInstrumentationHandler = fetch$1.addFetchInstrumentationHandler;\nexports.addGlobalErrorInstrumentationHandler = globalError.addGlobalErrorInstrumentationHandler;\nexports.addGlobalUnhandledRejectionInstrumentationHandler = globalUnhandledRejection.addGlobalUnhandledRejectionInstrumentationHandler;\nexports.addHandler = handlers.addHandler;\nexports.maybeInstrument = handlers.maybeInstrument;\nexports.resetInstrumentationHandlers = handlers.resetInstrumentationHandlers;\nexports.triggerHandlers = handlers.triggerHandlers;\nexports.isDOMError = is.isDOMError;\nexports.isDOMException = is.isDOMException;\nexports.isElement = is.isElement;\nexports.isError = is.isError;\nexports.isErrorEvent = is.isErrorEvent;\nexports.isEvent = is.isEvent;\nexports.isInstanceOf = is.isInstanceOf;\nexports.isParameterizedString = is.isParameterizedString;\nexports.isPlainObject = is.isPlainObject;\nexports.isPrimitive = is.isPrimitive;\nexports.isRegExp = is.isRegExp;\nexports.isString = is.isString;\nexports.isSyntheticEvent = is.isSyntheticEvent;\nexports.isThenable = is.isThenable;\nexports.isVueViewModel = is.isVueViewModel;\nexports.isBrowser = isBrowser.isBrowser;\nexports.CONSOLE_LEVELS = debugLogger.CONSOLE_LEVELS;\nexports.consoleSandbox = debugLogger.consoleSandbox;\nexports.debug = debugLogger.debug;\nexports.logger = debugLogger.logger;\nexports.originalConsoleMethods = debugLogger.originalConsoleMethods;\nexports.addContextToFrame = misc.addContextToFrame;\nexports.addExceptionMechanism = misc.addExceptionMechanism;\nexports.addExceptionTypeValue = misc.addExceptionTypeValue;\nexports.checkOrSetAlreadyCaught = misc.checkOrSetAlreadyCaught;\nexports.getEventDescription = misc.getEventDescription;\nexports.parseSemver = misc.parseSemver;\nexports.uuid4 = misc.uuid4;\nexports.isNodeEnv = node.isNodeEnv;\nexports.loadModule = node.loadModule;\nexports.normalize = normalize.normalize;\nexports.normalizeToSize = normalize.normalizeToSize;\nexports.normalizeUrlToBase = normalize.normalizeUrlToBase;\nexports.addNonEnumerableProperty = object.addNonEnumerableProperty;\nexports.convertToPlainObject = object.convertToPlainObject;\nexports.dropUndefinedKeys = object.dropUndefinedKeys;\nexports.extractExceptionKeysForMessage = object.extractExceptionKeysForMessage;\nexports.fill = object.fill;\nexports.getOriginalFunction = object.getOriginalFunction;\nexports.markFunctionWrapped = object.markFunctionWrapped;\nexports.objectify = object.objectify;\nexports.basename = path.basename;\nexports.dirname = path.dirname;\nexports.isAbsolute = path.isAbsolute;\nexports.join = path.join;\nexports.normalizePath = path.normalizePath;\nexports.relative = path.relative;\nexports.resolve = path.resolve;\nexports.SENTRY_BUFFER_FULL_ERROR = promisebuffer.SENTRY_BUFFER_FULL_ERROR;\nexports.makePromiseBuffer = promisebuffer.makePromiseBuffer;\nexports.severityLevelFromString = severity.severityLevelFromString;\nexports.UNKNOWN_FUNCTION = stacktrace.UNKNOWN_FUNCTION;\nexports.createStackParser = stacktrace.createStackParser;\nexports.getFramesFromEvent = stacktrace.getFramesFromEvent;\nexports.getFunctionName = stacktrace.getFunctionName;\nexports.stackParserFromStackParserOptions = stacktrace.stackParserFromStackParserOptions;\nexports.stripSentryFramesAndReverse = stacktrace.stripSentryFramesAndReverse;\nexports.filenameIsInApp = nodeStackTrace.filenameIsInApp;\nexports.node = nodeStackTrace.node;\nexports.nodeStackLineParser = nodeStackTrace.nodeStackLineParser;\nexports.isMatchingPattern = string.isMatchingPattern;\nexports.safeJoin = string.safeJoin;\nexports.snipLine = string.snipLine;\nexports.stringMatchesSomePattern = string.stringMatchesSomePattern;\nexports.truncate = string.truncate;\nexports.isNativeFunction = supports.isNativeFunction;\nexports.supportsDOMError = supports.supportsDOMError;\nexports.supportsDOMException = supports.supportsDOMException;\nexports.supportsErrorEvent = supports.supportsErrorEvent;\nexports.supportsFetch = supports.supportsFetch;\nexports.supportsHistory = supports.supportsHistory;\nexports.supportsNativeFetch = supports.supportsNativeFetch;\nexports.supportsReferrerPolicy = supports.supportsReferrerPolicy;\nexports.supportsReportingObserver = supports.supportsReportingObserver;\nexports.SyncPromise = syncpromise.SyncPromise;\nexports.rejectedSyncPromise = syncpromise.rejectedSyncPromise;\nexports.resolvedSyncPromise = syncpromise.resolvedSyncPromise;\nexports.browserPerformanceTimeOrigin = time.browserPerformanceTimeOrigin;\nexports.dateTimestampInSeconds = time.dateTimestampInSeconds;\nexports.timestampInSeconds = time.timestampInSeconds;\nexports.TRACEPARENT_REGEXP = tracing.TRACEPARENT_REGEXP;\nexports.extractTraceparentData = tracing.extractTraceparentData;\nexports.generateSentryTraceHeader = tracing.generateSentryTraceHeader;\nexports.propagationContextFromHeaders = tracing.propagationContextFromHeaders;\nexports.getSDKSource = env.getSDKSource;\nexports.isBrowserBundle = env.isBrowserBundle;\nexports.addItemToEnvelope = envelope$1.addItemToEnvelope;\nexports.createAttachmentEnvelopeItem = envelope$1.createAttachmentEnvelopeItem;\nexports.createEnvelope = envelope$1.createEnvelope;\nexports.createEventEnvelopeHeaders = envelope$1.createEventEnvelopeHeaders;\nexports.createSpanEnvelopeItem = envelope$1.createSpanEnvelopeItem;\nexports.envelopeContainsItemType = envelope$1.envelopeContainsItemType;\nexports.envelopeItemTypeToDataCategory = envelope$1.envelopeItemTypeToDataCategory;\nexports.forEachEnvelopeItem = envelope$1.forEachEnvelopeItem;\nexports.getSdkMetadataForEnvelopeHeader = envelope$1.getSdkMetadataForEnvelopeHeader;\nexports.parseEnvelope = envelope$1.parseEnvelope;\nexports.serializeEnvelope = envelope$1.serializeEnvelope;\nexports.createClientReportEnvelope = clientreport.createClientReportEnvelope;\nexports.DEFAULT_RETRY_AFTER = ratelimit.DEFAULT_RETRY_AFTER;\nexports.disabledUntil = ratelimit.disabledUntil;\nexports.isRateLimited = ratelimit.isRateLimited;\nexports.parseRetryAfterHeader = ratelimit.parseRetryAfterHeader;\nexports.updateRateLimits = ratelimit.updateRateLimits;\nexports.MAX_BAGGAGE_STRING_LENGTH = baggage.MAX_BAGGAGE_STRING_LENGTH;\nexports.SENTRY_BAGGAGE_KEY_PREFIX = baggage.SENTRY_BAGGAGE_KEY_PREFIX;\nexports.SENTRY_BAGGAGE_KEY_PREFIX_REGEX = baggage.SENTRY_BAGGAGE_KEY_PREFIX_REGEX;\nexports.baggageHeaderToDynamicSamplingContext = baggage.baggageHeaderToDynamicSamplingContext;\nexports.dynamicSamplingContextToSentryBaggageHeader = baggage.dynamicSamplingContextToSentryBaggageHeader;\nexports.objectToBaggageHeader = baggage.objectToBaggageHeader;\nexports.parseBaggageHeader = baggage.parseBaggageHeader;\nexports.getHttpSpanDetailsFromUrlObject = url.getHttpSpanDetailsFromUrlObject;\nexports.getSanitizedUrlString = url.getSanitizedUrlString;\nexports.getSanitizedUrlStringFromUrlObject = url.getSanitizedUrlStringFromUrlObject;\nexports.isURLObjectRelative = url.isURLObjectRelative;\nexports.parseStringToURLObject = url.parseStringToURLObject;\nexports.parseUrl = url.parseUrl;\nexports.stripUrlQueryAndFragment = url.stripUrlQueryAndFragment;\nexports.eventFromMessage = eventbuilder.eventFromMessage;\nexports.eventFromUnknownInput = eventbuilder.eventFromUnknownInput;\nexports.exceptionFromError = eventbuilder.exceptionFromError;\nexports.parseStackFrames = eventbuilder.parseStackFrames;\nexports.callFrameToStackFrame = anr.callFrameToStackFrame;\nexports.watchdogTimer = anr.watchdogTimer;\nexports.LRUMap = lru.LRUMap;\nexports.generateSpanId = propagationContext.generateSpanId;\nexports.generateTraceId = propagationContext.generateTraceId;\nexports.vercelWaitUntil = vercelWaitUntil.vercelWaitUntil;\nexports.flushIfServerless = flushIfServerless.flushIfServerless;\nexports.SDK_VERSION = version.SDK_VERSION;\nexports.getDebugImagesForResources = debugIds.getDebugImagesForResources;\nexports.getFilenameToDebugIdMap = debugIds.getFilenameToDebugIdMap;\nexports.escapeStringForRegex = escapeStringForRegex.escapeStringForRegex;\n//# sourceMappingURL=index.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbmRleC5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxlQUFlLG1CQUFPLENBQUMsaUlBQXFCO0FBQzVDLGNBQWMsbUJBQU8sQ0FBQywrSEFBb0I7QUFDMUMsaUJBQWlCLG1CQUFPLENBQUMscUlBQXVCO0FBQ2hELG1CQUFtQixtQkFBTyxDQUFDLHlJQUF5QjtBQUNwRCwrQkFBK0IsbUJBQU8sQ0FBQyxpS0FBcUM7QUFDNUUsbUJBQW1CLG1CQUFPLENBQUMseUlBQXlCO0FBQ3BELGNBQWMsbUJBQU8sQ0FBQywrSEFBb0I7QUFDMUMsK0JBQStCLG1CQUFPLENBQUMsaUtBQXFDO0FBQzVFLG9CQUFvQixtQkFBTyxDQUFDLDJJQUEwQjtBQUN0RCxpQkFBaUIsbUJBQU8sQ0FBQyxxSUFBdUI7QUFDaEQsaUJBQWlCLG1CQUFPLENBQUMscUlBQXVCO0FBQ2hELDJCQUEyQixtQkFBTyxDQUFDLHlJQUF5QjtBQUM1RCxpQkFBaUIsbUJBQU8sQ0FBQyxxSEFBZTtBQUN4QyxrQkFBa0IsbUJBQU8sQ0FBQyxtSEFBYztBQUN4QyxzQkFBc0IsbUJBQU8sQ0FBQywrSEFBb0I7QUFDbEQsc0JBQXNCLG1CQUFPLENBQUMsK0hBQW9CO0FBQ2xELGNBQWMsbUJBQU8sQ0FBQyx5SUFBeUI7QUFDL0MsZ0JBQWdCLG1CQUFPLENBQUMsbUhBQWM7QUFDdEMsZ0JBQWdCLG1CQUFPLENBQUMsbUhBQWM7QUFDdEMsY0FBYyxtQkFBTyxDQUFDLCtHQUFZO0FBQ2xDLHdCQUF3QixtQkFBTyxDQUFDLG1JQUFzQjtBQUN0RCxZQUFZLG1CQUFPLENBQUMsMkdBQVU7QUFDOUIsZUFBZSxtQkFBTyxDQUFDLGlIQUFhO0FBQ3BDLDRCQUE0QixtQkFBTyxDQUFDLCtJQUE0QjtBQUNoRSxZQUFZLG1CQUFPLENBQUMsMkdBQVU7QUFDOUIsYUFBYSxtQkFBTyxDQUFDLG1JQUFzQjtBQUMzQyxnQkFBZ0IsbUJBQU8sQ0FBQyx5SUFBeUI7QUFDakQsb0JBQW9CLG1CQUFPLENBQUMsaUpBQTZCO0FBQ3pELG9CQUFvQixtQkFBTyxDQUFDLDJIQUFrQjtBQUM5Qyw4QkFBOEIsbUJBQU8sQ0FBQywySkFBa0M7QUFDeEUscUJBQXFCLG1CQUFPLENBQUMseUlBQXlCO0FBQ3RELGdCQUFnQixtQkFBTyxDQUFDLG1IQUFjO0FBQ3RDLHdCQUF3QixtQkFBTyxDQUFDLCtJQUE0QjtBQUM1RCwyQkFBMkIsbUJBQU8sQ0FBQyxxSkFBK0I7QUFDbEUsNkJBQTZCLG1CQUFPLENBQUMseUpBQWlDO0FBQ3RFLHFCQUFxQixtQkFBTyxDQUFDLHlJQUF5QjtBQUN0RCxrQkFBa0IsbUJBQU8sQ0FBQyxtSUFBc0I7QUFDaEQsa0JBQWtCLG1CQUFPLENBQUMsbUlBQXNCO0FBQ2hELHdCQUF3QixtQkFBTyxDQUFDLCtJQUE0QjtBQUM1RCxvQkFBb0IsbUJBQU8sQ0FBQyx1SUFBd0I7QUFDcEQsa0JBQWtCLG1CQUFPLENBQUMsbUlBQXNCO0FBQ2hELGFBQWEsbUJBQU8sQ0FBQyx5SEFBaUI7QUFDdEMsaUJBQWlCLG1CQUFPLENBQUMsaUlBQXFCO0FBQzlDLGdCQUFnQixtQkFBTyxDQUFDLCtIQUFvQjtBQUM1QyxrQkFBa0IsbUJBQU8sQ0FBQyx1SEFBZ0I7QUFDMUMsb0JBQW9CLG1CQUFPLENBQUMsMkhBQWtCO0FBQzlDLHlCQUF5QixtQkFBTyxDQUFDLCtKQUFvQztBQUNyRSxxQkFBcUIsbUJBQU8sQ0FBQyx1SkFBZ0M7QUFDN0QscUJBQXFCLG1CQUFPLENBQUMsdUpBQWdDO0FBQzdELGlCQUFpQixtQkFBTyxDQUFDLCtJQUE0QjtBQUNyRCxvQkFBb0IsbUJBQU8sQ0FBQyxxSkFBK0I7QUFDM0QsdUJBQXVCLG1CQUFPLENBQUMsMkpBQWtDO0FBQ2pFLGVBQWUsbUJBQU8sQ0FBQywySUFBMEI7QUFDakQsdUJBQXVCLG1CQUFPLENBQUMsMkpBQWtDO0FBQ2pFLHNCQUFzQixtQkFBTyxDQUFDLHlKQUFpQztBQUMvRCxpQkFBaUIsbUJBQU8sQ0FBQywrSUFBNEI7QUFDckQsa0JBQWtCLG1CQUFPLENBQUMsaUpBQTZCO0FBQ3ZELCtCQUErQixtQkFBTyxDQUFDLGlMQUE2QztBQUNwRixnQkFBZ0IsbUJBQU8sQ0FBQyw2SUFBMkI7QUFDbkQsZ0NBQWdDLG1CQUFPLENBQUMsdU1BQXdEO0FBQ2hHLGtCQUFrQixtQkFBTyxDQUFDLHVIQUFnQjtBQUMxQyxjQUFjLG1CQUFPLENBQUMsK0dBQVk7QUFDbEMsYUFBYSxtQkFBTyxDQUFDLDZHQUFXO0FBQ2hDLGdCQUFnQixtQkFBTyxDQUFDLCtKQUFvQztBQUM1RCxpQkFBaUIsbUJBQU8sQ0FBQyxxSEFBZTtBQUN4QyxrQkFBa0IsbUJBQU8sQ0FBQyw2SEFBbUI7QUFDN0MsMkJBQTJCLG1CQUFPLENBQUMscUpBQStCO0FBQ2xFLGlCQUFpQixtQkFBTyxDQUFDLG1JQUFzQjtBQUMvQyxnQkFBZ0IsbUJBQU8sQ0FBQyx5SUFBeUI7QUFDakQsb0JBQW9CLG1CQUFPLENBQUMsaUpBQTZCO0FBQ3pELHFCQUFxQixtQkFBTyxDQUFDLHlJQUF5QjtBQUN0RCx3QkFBd0IsbUJBQU8sQ0FBQyxpSkFBNkI7QUFDN0QsMkJBQTJCLG1CQUFPLENBQUMseUpBQWlDO0FBQ3BFLGdCQUFnQixtQkFBTyxDQUFDLCtIQUFvQjtBQUM1QyxZQUFZLG1CQUFPLENBQUMsdUhBQWdCO0FBQ3BDLGNBQWMsbUJBQU8sQ0FBQywySEFBa0I7QUFDeEMsa0JBQWtCLG1CQUFPLENBQUMsbUlBQXNCO0FBQ2hELGtCQUFrQixtQkFBTyxDQUFDLHlJQUF5QjtBQUNuRCxnQkFBZ0IsbUJBQU8sQ0FBQyxxSUFBdUI7QUFDL0Msb0JBQW9CLG1CQUFPLENBQUMsaUpBQTZCO0FBQ3pELGlDQUFpQyxtQkFBTyxDQUFDLDJLQUEwQztBQUNuRixpQkFBaUIsbUJBQU8sQ0FBQywySUFBMEI7QUFDbkQsV0FBVyxtQkFBTyxDQUFDLHFIQUFlO0FBQ2xDLGtCQUFrQixtQkFBTyxDQUFDLG1JQUFzQjtBQUNoRCxvQkFBb0IsbUJBQU8sQ0FBQyx5SUFBeUI7QUFDckQsYUFBYSxtQkFBTyxDQUFDLHlIQUFpQjtBQUN0QyxhQUFhLG1CQUFPLENBQUMseUhBQWlCO0FBQ3RDLGtCQUFrQixtQkFBTyxDQUFDLG1JQUFzQjtBQUNoRCxlQUFlLG1CQUFPLENBQUMsNkhBQW1CO0FBQzFDLGFBQWEsbUJBQU8sQ0FBQyx5SEFBaUI7QUFDdEMsc0JBQXNCLG1CQUFPLENBQUMsMklBQTBCO0FBQ3hELGlCQUFpQixtQkFBTyxDQUFDLGlJQUFxQjtBQUM5QyxtQkFBbUIsbUJBQU8sQ0FBQyxxSUFBdUI7QUFDbEQsdUJBQXVCLG1CQUFPLENBQUMsaUpBQTZCO0FBQzVELGVBQWUsbUJBQU8sQ0FBQyw2SEFBbUI7QUFDMUMsaUJBQWlCLG1CQUFPLENBQUMsaUlBQXFCO0FBQzlDLG9CQUFvQixtQkFBTyxDQUFDLHVJQUF3QjtBQUNwRCxhQUFhLG1CQUFPLENBQUMseUhBQWlCO0FBQ3RDLGdCQUFnQixtQkFBTyxDQUFDLCtIQUFvQjtBQUM1QyxZQUFZLG1CQUFPLENBQUMsdUhBQWdCO0FBQ3BDLG1CQUFtQixtQkFBTyxDQUFDLGlJQUFxQjtBQUNoRCxxQkFBcUIsbUJBQU8sQ0FBQyx5SUFBeUI7QUFDdEQsa0JBQWtCLG1CQUFPLENBQUMsbUlBQXNCO0FBQ2hELGdCQUFnQixtQkFBTyxDQUFDLCtIQUFvQjtBQUM1QyxZQUFZLG1CQUFPLENBQUMsdUhBQWdCO0FBQ3BDLHFCQUFxQixtQkFBTyxDQUFDLHlJQUF5QjtBQUN0RCxZQUFZLG1CQUFPLENBQUMsdUhBQWdCO0FBQ3BDLFlBQVksbUJBQU8sQ0FBQyx1SEFBZ0I7QUFDcEMsMkJBQTJCLG1CQUFPLENBQUMscUpBQStCO0FBQ2xFLHdCQUF3QixtQkFBTyxDQUFDLCtJQUE0QjtBQUM1RCwwQkFBMEIsbUJBQU8sQ0FBQyxtSkFBOEI7QUFDaEUsZ0JBQWdCLG1CQUFPLENBQUMsK0hBQW9CO0FBQzVDLGlCQUFpQixtQkFBTyxDQUFDLG1JQUFzQjtBQUMvQyw2QkFBNkIsbUJBQU8sQ0FBQywySkFBa0M7Ozs7QUFJdkUsd0NBQXdDO0FBQ3hDLCtCQUErQjtBQUMvQiwrQkFBK0I7QUFDL0Isd0JBQXdCO0FBQ3hCLHFCQUFxQjtBQUNyQixrQkFBa0I7QUFDbEIsOEJBQThCO0FBQzlCLHlCQUF5QjtBQUN6QixzQkFBc0I7QUFDdEIseUJBQXlCO0FBQ3pCLGlDQUFpQztBQUNqQyxxQkFBcUI7QUFDckIscUJBQXFCO0FBQ3JCLHlCQUF5QjtBQUN6QixxQkFBcUI7QUFDckIsaUJBQWlCO0FBQ2pCLHVCQUF1QjtBQUN2Qix1QkFBdUI7QUFDdkIsc0JBQXNCO0FBQ3RCLDJDQUEyQztBQUMzQywwQ0FBMEM7QUFDMUMseUNBQXlDO0FBQ3pDLDJCQUEyQjtBQUMzQixzQkFBc0I7QUFDdEIsaUNBQWlDO0FBQ2pDLGtCQUFrQjtBQUNsQixrQkFBa0I7QUFDbEIsb0JBQW9CO0FBQ3BCLG9DQUFvQztBQUNwQywwQ0FBMEM7QUFDMUMsb0NBQW9DO0FBQ3BDLHlDQUF5QztBQUN6Qyw4Q0FBOEM7QUFDOUMscUNBQXFDO0FBQ3JDLGtEQUFrRDtBQUNsRCx5REFBeUQ7QUFDekQsa0RBQWtEO0FBQ2xELG1EQUFtRDtBQUNuRCxvQ0FBb0M7QUFDcEMsd0NBQXdDO0FBQ3hDLDREQUE0RDtBQUM1RCw2Q0FBNkM7QUFDN0Msd0NBQXdDO0FBQ3hDLG1DQUFtQztBQUNuQyx5Q0FBeUM7QUFDekMsMkJBQTJCO0FBQzNCLDZCQUE2QjtBQUM3QiwwQkFBMEI7QUFDMUIseUJBQXlCO0FBQ3pCLHNCQUFzQjtBQUN0QixvQkFBb0I7QUFDcEIsd0JBQXdCO0FBQ3hCLHNCQUFzQjtBQUN0QixzQkFBc0I7QUFDdEIsYUFBYTtBQUNiLGtCQUFrQjtBQUNsQixhQUFhO0FBQ2IsaUJBQWlCO0FBQ2pCLHFCQUFxQjtBQUNyQixtQkFBbUI7QUFDbkIsa0JBQWtCO0FBQ2xCLGdCQUFnQjtBQUNoQixpQkFBaUI7QUFDakIsY0FBYztBQUNkLGVBQWU7QUFDZixlQUFlO0FBQ2Ysb0JBQW9CO0FBQ3BCLG1CQUFtQjtBQUNuQixpQkFBaUI7QUFDakIsdUJBQXVCO0FBQ3ZCLHNCQUFzQjtBQUN0Qix5QkFBeUI7QUFDekIsZ0NBQWdDO0FBQ2hDLDBCQUEwQjtBQUMxQixpQkFBaUI7QUFDakIsOEJBQThCO0FBQzlCLGdDQUFnQztBQUNoQywrQkFBK0I7QUFDL0IsMEJBQTBCO0FBQzFCLHNCQUFzQjtBQUN0QixvQkFBb0I7QUFDcEIsbUJBQW1CO0FBQ25CLHFCQUFxQjtBQUNyQixhQUFhO0FBQ2IsNkJBQTZCO0FBQzdCLDZDQUE2QztBQUM3QywrQkFBK0I7QUFDL0Isa0JBQWtCO0FBQ2xCLGNBQWM7QUFDZCwyQkFBMkI7QUFDM0IsbUJBQW1CO0FBQ25CLHdCQUF3QjtBQUN4Qix1QkFBdUI7QUFDdkIsNEJBQTRCO0FBQzVCLGdDQUFnQztBQUNoQyxzQkFBc0I7QUFDdEIseUJBQXlCO0FBQ3pCLDhCQUE4QjtBQUM5Qiw2QkFBNkI7QUFDN0Isc0JBQXNCO0FBQ3RCLG9CQUFvQjtBQUNwQiw2QkFBNkI7QUFDN0IsdUJBQXVCO0FBQ3ZCLHlCQUF5QjtBQUN6QiwwQkFBMEI7QUFDMUIsNEJBQTRCO0FBQzVCLFdBQVc7QUFDWCxvQkFBb0I7QUFDcEIsaUNBQWlDO0FBQ2pDLDhCQUE4QjtBQUM5QiwwQkFBMEI7QUFDMUIsbUNBQW1DO0FBQ25DLHFCQUFxQjtBQUNyQixtQkFBbUI7QUFDbkIsMEJBQTBCO0FBQzFCLHdCQUF3QjtBQUN4QixxQkFBcUI7QUFDckIsOEJBQThCO0FBQzlCLGtCQUFrQjtBQUNsQiwwQkFBMEI7QUFDMUIseUJBQXlCO0FBQ3pCLHNCQUFzQjtBQUN0Qix1QkFBdUI7QUFDdkIsd0JBQXdCO0FBQ3hCLG9CQUFvQjtBQUNwQix3QkFBd0I7QUFDeEIsZ0JBQWdCO0FBQ2hCLGlDQUFpQztBQUNqQyxxQkFBcUI7QUFDckIsZ0NBQWdDO0FBQ2hDLDZCQUE2QjtBQUM3QixvQ0FBb0M7QUFDcEMsMkJBQTJCO0FBQzNCLHFCQUFxQjtBQUNyQixtQ0FBbUM7QUFDbkMsK0JBQStCO0FBQy9CLGlDQUFpQztBQUNqQywrQkFBK0I7QUFDL0IsaUNBQWlDO0FBQ2pDLDhCQUE4QjtBQUM5QixpQ0FBaUM7QUFDakMseUJBQXlCO0FBQ3pCLGlDQUFpQztBQUNqQyxnQ0FBZ0M7QUFDaEMsZ0NBQWdDO0FBQ2hDLDJCQUEyQjtBQUMzQiw0QkFBNEI7QUFDNUIsd0NBQXdDO0FBQ3hDLDBCQUEwQjtBQUMxQiwrQkFBK0I7QUFDL0IsZ0JBQWdCO0FBQ2hCLDhCQUE4QjtBQUM5QixzQkFBc0I7QUFDdEIsK0JBQStCO0FBQy9CLHVCQUF1QjtBQUN2Qiw0QkFBNEI7QUFDNUIsc0NBQXNDO0FBQ3RDLGlDQUFpQztBQUNqQyxpQ0FBaUM7QUFDakMsNkJBQTZCO0FBQzdCLDhCQUE4QjtBQUM5QiwrQkFBK0I7QUFDL0Isa0NBQWtDO0FBQ2xDLG9DQUFvQztBQUNwQyw0Q0FBNEM7QUFDNUMsMkNBQTJDO0FBQzNDLG1DQUFtQztBQUNuQyxtQ0FBbUM7QUFDbkMsK0NBQStDO0FBQy9DLHdCQUF3QjtBQUN4Qix1QkFBdUI7QUFDdkIsd0JBQXdCO0FBQ3hCLHFCQUFxQjtBQUNyQixtQkFBbUI7QUFDbkIsZUFBZTtBQUNmLG1CQUFtQjtBQUNuQixrQkFBa0I7QUFDbEIsd0NBQXdDO0FBQ3hDLHlDQUF5QztBQUN6QyxzQ0FBc0M7QUFDdEMsNENBQTRDO0FBQzVDLHlEQUF5RDtBQUN6RCxrQkFBa0I7QUFDbEIsdUJBQXVCO0FBQ3ZCLG9DQUFvQztBQUNwQyx1QkFBdUI7QUFDdkIsa0JBQWtCO0FBQ2xCLHNCQUFzQjtBQUN0QixpQkFBaUI7QUFDakIsZUFBZTtBQUNmLG9CQUFvQjtBQUNwQixlQUFlO0FBQ2Ysb0JBQW9CO0FBQ3BCLDZCQUE2QjtBQUM3QixxQkFBcUI7QUFDckIsbUJBQW1CO0FBQ25CLGdCQUFnQjtBQUNoQixnQkFBZ0I7QUFDaEIsd0JBQXdCO0FBQ3hCLGtCQUFrQjtBQUNsQixzQkFBc0I7QUFDdEIsaUJBQWlCO0FBQ2pCLHNCQUFzQjtBQUN0QixzQkFBc0I7QUFDdEIsYUFBYTtBQUNiLGNBQWM7QUFDZCw4QkFBOEI7QUFDOUIseUJBQXlCO0FBQ3pCLDZCQUE2QjtBQUM3Qiw2QkFBNkI7QUFDN0IsK0JBQStCO0FBQy9CLDJCQUEyQjtBQUMzQixtQkFBbUI7QUFDbkIsYUFBYTtBQUNiLGlCQUFpQjtBQUNqQixrQkFBa0I7QUFDbEIsaUJBQWlCO0FBQ2pCLHVCQUF1QjtBQUN2QiwwQkFBMEI7QUFDMUIsZ0NBQWdDO0FBQ2hDLDRCQUE0QjtBQUM1Qix5QkFBeUI7QUFDekIsc0NBQXNDO0FBQ3RDLFlBQVk7QUFDWiwyQkFBMkI7QUFDM0IsMkJBQTJCO0FBQzNCLGlCQUFpQjtBQUNqQixnQkFBZ0I7QUFDaEIsZUFBZTtBQUNmLGtCQUFrQjtBQUNsQixZQUFZO0FBQ1oscUJBQXFCO0FBQ3JCLGdCQUFnQjtBQUNoQixlQUFlO0FBQ2YsZ0NBQWdDO0FBQ2hDLHlCQUF5QjtBQUN6QiwrQkFBK0I7QUFDL0Isd0JBQXdCO0FBQ3hCLHlCQUF5QjtBQUN6QiwwQkFBMEI7QUFDMUIsdUJBQXVCO0FBQ3ZCLHlDQUF5QztBQUN6QyxtQ0FBbUM7QUFDbkMsdUJBQXVCO0FBQ3ZCLFlBQVk7QUFDWiwyQkFBMkI7QUFDM0IseUJBQXlCO0FBQ3pCLGdCQUFnQjtBQUNoQixnQkFBZ0I7QUFDaEIsZ0NBQWdDO0FBQ2hDLGdCQUFnQjtBQUNoQix3QkFBd0I7QUFDeEIsd0JBQXdCO0FBQ3hCLDRCQUE0QjtBQUM1QiwwQkFBMEI7QUFDMUIscUJBQXFCO0FBQ3JCLHVCQUF1QjtBQUN2QiwyQkFBMkI7QUFDM0IsOEJBQThCO0FBQzlCLGlDQUFpQztBQUNqQyxtQkFBbUI7QUFDbkIsMkJBQTJCO0FBQzNCLDJCQUEyQjtBQUMzQixvQ0FBb0M7QUFDcEMsOEJBQThCO0FBQzlCLDBCQUEwQjtBQUMxQiwwQkFBMEI7QUFDMUIsOEJBQThCO0FBQzlCLGlDQUFpQztBQUNqQyxxQ0FBcUM7QUFDckMsb0JBQW9CO0FBQ3BCLHVCQUF1QjtBQUN2Qix5QkFBeUI7QUFDekIsb0NBQW9DO0FBQ3BDLHNCQUFzQjtBQUN0QixrQ0FBa0M7QUFDbEMsOEJBQThCO0FBQzlCLGdDQUFnQztBQUNoQyxzQ0FBc0M7QUFDdEMsMkJBQTJCO0FBQzNCLHVDQUF1QztBQUN2QyxxQkFBcUI7QUFDckIseUJBQXlCO0FBQ3pCLGtDQUFrQztBQUNsQywyQkFBMkI7QUFDM0IscUJBQXFCO0FBQ3JCLHFCQUFxQjtBQUNyQiw2QkFBNkI7QUFDN0Isd0JBQXdCO0FBQ3hCLGlDQUFpQztBQUNqQyxpQ0FBaUM7QUFDakMsdUNBQXVDO0FBQ3ZDLDZDQUE2QztBQUM3QyxtREFBbUQ7QUFDbkQsNkJBQTZCO0FBQzdCLDBCQUEwQjtBQUMxQix1Q0FBdUM7QUFDdkMsNkJBQTZCO0FBQzdCLDBDQUEwQztBQUMxQywyQkFBMkI7QUFDM0IsOEJBQThCO0FBQzlCLGdCQUFnQjtBQUNoQixnQ0FBZ0M7QUFDaEMsd0JBQXdCO0FBQ3hCLDZCQUE2QjtBQUM3QiwwQkFBMEI7QUFDMUIsd0JBQXdCO0FBQ3hCLDZCQUE2QjtBQUM3QixxQkFBcUI7QUFDckIsY0FBYztBQUNkLHNCQUFzQjtBQUN0Qix1QkFBdUI7QUFDdkIsdUJBQXVCO0FBQ3ZCLHlCQUF5QjtBQUN6QixtQkFBbUI7QUFDbkIsa0NBQWtDO0FBQ2xDLCtCQUErQjtBQUMvQiw0QkFBNEI7QUFDNUIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbmRleC5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgZXJyb3JzID0gcmVxdWlyZSgnLi90cmFjaW5nL2Vycm9ycy5qcycpO1xuY29uc3QgdXRpbHMgPSByZXF1aXJlKCcuL3RyYWNpbmcvdXRpbHMuanMnKTtcbmNvbnN0IGlkbGVTcGFuID0gcmVxdWlyZSgnLi90cmFjaW5nL2lkbGVTcGFuLmpzJyk7XG5jb25zdCBzZW50cnlTcGFuID0gcmVxdWlyZSgnLi90cmFjaW5nL3NlbnRyeVNwYW4uanMnKTtcbmNvbnN0IHNlbnRyeU5vblJlY29yZGluZ1NwYW4gPSByZXF1aXJlKCcuL3RyYWNpbmcvc2VudHJ5Tm9uUmVjb3JkaW5nU3Bhbi5qcycpO1xuY29uc3Qgc3BhbnN0YXR1cyA9IHJlcXVpcmUoJy4vdHJhY2luZy9zcGFuc3RhdHVzLmpzJyk7XG5jb25zdCB0cmFjZSA9IHJlcXVpcmUoJy4vdHJhY2luZy90cmFjZS5qcycpO1xuY29uc3QgZHluYW1pY1NhbXBsaW5nQ29udGV4dCA9IHJlcXVpcmUoJy4vdHJhY2luZy9keW5hbWljU2FtcGxpbmdDb250ZXh0LmpzJyk7XG5jb25zdCBtZWFzdXJlbWVudCA9IHJlcXVpcmUoJy4vdHJhY2luZy9tZWFzdXJlbWVudC5qcycpO1xuY29uc3Qgc2FtcGxpbmcgPSByZXF1aXJlKCcuL3RyYWNpbmcvc2FtcGxpbmcuanMnKTtcbmNvbnN0IGxvZ1NwYW5zID0gcmVxdWlyZSgnLi90cmFjaW5nL2xvZ1NwYW5zLmpzJyk7XG5jb25zdCBzZW1hbnRpY0F0dHJpYnV0ZXMgPSByZXF1aXJlKCcuL3NlbWFudGljQXR0cmlidXRlcy5qcycpO1xuY29uc3QgZW52ZWxvcGUgPSByZXF1aXJlKCcuL2VudmVsb3BlLmpzJyk7XG5jb25zdCBleHBvcnRzJDEgPSByZXF1aXJlKCcuL2V4cG9ydHMuanMnKTtcbmNvbnN0IGN1cnJlbnRTY29wZXMgPSByZXF1aXJlKCcuL2N1cnJlbnRTY29wZXMuanMnKTtcbmNvbnN0IGRlZmF1bHRTY29wZXMgPSByZXF1aXJlKCcuL2RlZmF1bHRTY29wZXMuanMnKTtcbmNvbnN0IGluZGV4ID0gcmVxdWlyZSgnLi9hc3luY0NvbnRleHQvaW5kZXguanMnKTtcbmNvbnN0IGNhcnJpZXIgPSByZXF1aXJlKCcuL2NhcnJpZXIuanMnKTtcbmNvbnN0IHNlc3Npb24gPSByZXF1aXJlKCcuL3Nlc3Npb24uanMnKTtcbmNvbnN0IHNjb3BlID0gcmVxdWlyZSgnLi9zY29wZS5qcycpO1xuY29uc3QgZXZlbnRQcm9jZXNzb3JzID0gcmVxdWlyZSgnLi9ldmVudFByb2Nlc3NvcnMuanMnKTtcbmNvbnN0IGFwaSA9IHJlcXVpcmUoJy4vYXBpLmpzJyk7XG5jb25zdCBjbGllbnQgPSByZXF1aXJlKCcuL2NsaWVudC5qcycpO1xuY29uc3Qgc2VydmVyUnVudGltZUNsaWVudCA9IHJlcXVpcmUoJy4vc2VydmVyLXJ1bnRpbWUtY2xpZW50LmpzJyk7XG5jb25zdCBzZGsgPSByZXF1aXJlKCcuL3Nkay5qcycpO1xuY29uc3QgYmFzZSA9IHJlcXVpcmUoJy4vdHJhbnNwb3J0cy9iYXNlLmpzJyk7XG5jb25zdCBvZmZsaW5lID0gcmVxdWlyZSgnLi90cmFuc3BvcnRzL29mZmxpbmUuanMnKTtcbmNvbnN0IG11bHRpcGxleGVkID0gcmVxdWlyZSgnLi90cmFuc3BvcnRzL211bHRpcGxleGVkLmpzJyk7XG5jb25zdCBpbnRlZ3JhdGlvbiA9IHJlcXVpcmUoJy4vaW50ZWdyYXRpb24uanMnKTtcbmNvbnN0IGFwcGx5U2NvcGVEYXRhVG9FdmVudCA9IHJlcXVpcmUoJy4vdXRpbHMvYXBwbHlTY29wZURhdGFUb0V2ZW50LmpzJyk7XG5jb25zdCBwcmVwYXJlRXZlbnQgPSByZXF1aXJlKCcuL3V0aWxzL3ByZXBhcmVFdmVudC5qcycpO1xuY29uc3QgY2hlY2tpbiA9IHJlcXVpcmUoJy4vY2hlY2tpbi5qcycpO1xuY29uc3QgaGFzU3BhbnNFbmFibGVkID0gcmVxdWlyZSgnLi91dGlscy9oYXNTcGFuc0VuYWJsZWQuanMnKTtcbmNvbnN0IGlzU2VudHJ5UmVxdWVzdFVybCA9IHJlcXVpcmUoJy4vdXRpbHMvaXNTZW50cnlSZXF1ZXN0VXJsLmpzJyk7XG5jb25zdCBoYW5kbGVDYWxsYmFja0Vycm9ycyA9IHJlcXVpcmUoJy4vdXRpbHMvaGFuZGxlQ2FsbGJhY2tFcnJvcnMuanMnKTtcbmNvbnN0IHBhcmFtZXRlcml6ZSA9IHJlcXVpcmUoJy4vdXRpbHMvcGFyYW1ldGVyaXplLmpzJyk7XG5jb25zdCBpcEFkZHJlc3MgPSByZXF1aXJlKCcuL3V0aWxzL2lwQWRkcmVzcy5qcycpO1xuY29uc3Qgc3BhblV0aWxzID0gcmVxdWlyZSgnLi91dGlscy9zcGFuVXRpbHMuanMnKTtcbmNvbnN0IHBhcnNlU2FtcGxlUmF0ZSA9IHJlcXVpcmUoJy4vdXRpbHMvcGFyc2VTYW1wbGVSYXRlLmpzJyk7XG5jb25zdCBzZGtNZXRhZGF0YSA9IHJlcXVpcmUoJy4vdXRpbHMvc2RrTWV0YWRhdGEuanMnKTtcbmNvbnN0IHRyYWNlRGF0YSA9IHJlcXVpcmUoJy4vdXRpbHMvdHJhY2VEYXRhLmpzJyk7XG5jb25zdCBtZXRhID0gcmVxdWlyZSgnLi91dGlscy9tZXRhLmpzJyk7XG5jb25zdCBkZWJvdW5jZSA9IHJlcXVpcmUoJy4vdXRpbHMvZGVib3VuY2UuanMnKTtcbmNvbnN0IHJlcXVlc3QgPSByZXF1aXJlKCcuL3V0aWxzL3JlcXVlc3QuanMnKTtcbmNvbnN0IGNvbnN0YW50cyA9IHJlcXVpcmUoJy4vY29uc3RhbnRzLmpzJyk7XG5jb25zdCBicmVhZGNydW1icyA9IHJlcXVpcmUoJy4vYnJlYWRjcnVtYnMuanMnKTtcbmNvbnN0IGZ1bmN0aW9udG9zdHJpbmcgPSByZXF1aXJlKCcuL2ludGVncmF0aW9ucy9mdW5jdGlvbnRvc3RyaW5nLmpzJyk7XG5jb25zdCBldmVudEZpbHRlcnMgPSByZXF1aXJlKCcuL2ludGVncmF0aW9ucy9ldmVudEZpbHRlcnMuanMnKTtcbmNvbnN0IGxpbmtlZGVycm9ycyA9IHJlcXVpcmUoJy4vaW50ZWdyYXRpb25zL2xpbmtlZGVycm9ycy5qcycpO1xuY29uc3QgbWV0YWRhdGEgPSByZXF1aXJlKCcuL2ludGVncmF0aW9ucy9tZXRhZGF0YS5qcycpO1xuY29uc3QgcmVxdWVzdGRhdGEgPSByZXF1aXJlKCcuL2ludGVncmF0aW9ucy9yZXF1ZXN0ZGF0YS5qcycpO1xuY29uc3QgY2FwdHVyZWNvbnNvbGUgPSByZXF1aXJlKCcuL2ludGVncmF0aW9ucy9jYXB0dXJlY29uc29sZS5qcycpO1xuY29uc3QgZGVkdXBlID0gcmVxdWlyZSgnLi9pbnRlZ3JhdGlvbnMvZGVkdXBlLmpzJyk7XG5jb25zdCBleHRyYWVycm9yZGF0YSA9IHJlcXVpcmUoJy4vaW50ZWdyYXRpb25zL2V4dHJhZXJyb3JkYXRhLmpzJyk7XG5jb25zdCByZXdyaXRlZnJhbWVzID0gcmVxdWlyZSgnLi9pbnRlZ3JhdGlvbnMvcmV3cml0ZWZyYW1lcy5qcycpO1xuY29uc3Qgc3VwYWJhc2UgPSByZXF1aXJlKCcuL2ludGVncmF0aW9ucy9zdXBhYmFzZS5qcycpO1xuY29uc3Qgem9kZXJyb3JzID0gcmVxdWlyZSgnLi9pbnRlZ3JhdGlvbnMvem9kZXJyb3JzLmpzJyk7XG5jb25zdCB0aGlyZFBhcnR5RXJyb3JzRmlsdGVyID0gcmVxdWlyZSgnLi9pbnRlZ3JhdGlvbnMvdGhpcmQtcGFydHktZXJyb3JzLWZpbHRlci5qcycpO1xuY29uc3QgY29uc29sZSA9IHJlcXVpcmUoJy4vaW50ZWdyYXRpb25zL2NvbnNvbGUuanMnKTtcbmNvbnN0IGZlYXR1cmVGbGFnc0ludGVncmF0aW9uID0gcmVxdWlyZSgnLi9pbnRlZ3JhdGlvbnMvZmVhdHVyZUZsYWdzL2ZlYXR1cmVGbGFnc0ludGVncmF0aW9uLmpzJyk7XG5jb25zdCBwcm9maWxpbmcgPSByZXF1aXJlKCcuL3Byb2ZpbGluZy5qcycpO1xuY29uc3QgZmV0Y2ggPSByZXF1aXJlKCcuL2ZldGNoLmpzJyk7XG5jb25zdCB0cnBjID0gcmVxdWlyZSgnLi90cnBjLmpzJyk7XG5jb25zdCBpbmRleCQxID0gcmVxdWlyZSgnLi9pbnRlZ3JhdGlvbnMvbWNwLXNlcnZlci9pbmRleC5qcycpO1xuY29uc3QgZmVlZGJhY2sgPSByZXF1aXJlKCcuL2ZlZWRiYWNrLmpzJyk7XG5jb25zdCBleHBvcnRzJDIgPSByZXF1aXJlKCcuL2xvZ3MvZXhwb3J0cy5qcycpO1xuY29uc3QgY29uc29sZUludGVncmF0aW9uID0gcmVxdWlyZSgnLi9sb2dzL2NvbnNvbGUtaW50ZWdyYXRpb24uanMnKTtcbmNvbnN0IHZlcmNlbEFpID0gcmVxdWlyZSgnLi91dGlscy92ZXJjZWwtYWkuanMnKTtcbmNvbnN0IGluZGV4JDIgPSByZXF1aXJlKCcuL3V0aWxzL29wZW5haS9pbmRleC5qcycpO1xuY29uc3QgY29uc3RhbnRzJDEgPSByZXF1aXJlKCcuL3V0aWxzL29wZW5haS9jb25zdGFudHMuanMnKTtcbmNvbnN0IGZlYXR1cmVGbGFncyA9IHJlcXVpcmUoJy4vdXRpbHMvZmVhdHVyZUZsYWdzLmpzJyk7XG5jb25zdCBhZ2dyZWdhdGVFcnJvcnMgPSByZXF1aXJlKCcuL3V0aWxzL2FnZ3JlZ2F0ZS1lcnJvcnMuanMnKTtcbmNvbnN0IGJyZWFkY3J1bWJMb2dMZXZlbCA9IHJlcXVpcmUoJy4vdXRpbHMvYnJlYWRjcnVtYi1sb2ctbGV2ZWwuanMnKTtcbmNvbnN0IGJyb3dzZXIgPSByZXF1aXJlKCcuL3V0aWxzL2Jyb3dzZXIuanMnKTtcbmNvbnN0IGRzbiA9IHJlcXVpcmUoJy4vdXRpbHMvZHNuLmpzJyk7XG5jb25zdCBlcnJvciA9IHJlcXVpcmUoJy4vdXRpbHMvZXJyb3IuanMnKTtcbmNvbnN0IHdvcmxkd2lkZSA9IHJlcXVpcmUoJy4vdXRpbHMvd29ybGR3aWRlLmpzJyk7XG5jb25zdCBjb25zb2xlJDEgPSByZXF1aXJlKCcuL2luc3RydW1lbnQvY29uc29sZS5qcycpO1xuY29uc3QgZmV0Y2gkMSA9IHJlcXVpcmUoJy4vaW5zdHJ1bWVudC9mZXRjaC5qcycpO1xuY29uc3QgZ2xvYmFsRXJyb3IgPSByZXF1aXJlKCcuL2luc3RydW1lbnQvZ2xvYmFsRXJyb3IuanMnKTtcbmNvbnN0IGdsb2JhbFVuaGFuZGxlZFJlamVjdGlvbiA9IHJlcXVpcmUoJy4vaW5zdHJ1bWVudC9nbG9iYWxVbmhhbmRsZWRSZWplY3Rpb24uanMnKTtcbmNvbnN0IGhhbmRsZXJzID0gcmVxdWlyZSgnLi9pbnN0cnVtZW50L2hhbmRsZXJzLmpzJyk7XG5jb25zdCBpcyA9IHJlcXVpcmUoJy4vdXRpbHMvaXMuanMnKTtcbmNvbnN0IGlzQnJvd3NlciA9IHJlcXVpcmUoJy4vdXRpbHMvaXNCcm93c2VyLmpzJyk7XG5jb25zdCBkZWJ1Z0xvZ2dlciA9IHJlcXVpcmUoJy4vdXRpbHMvZGVidWctbG9nZ2VyLmpzJyk7XG5jb25zdCBtaXNjID0gcmVxdWlyZSgnLi91dGlscy9taXNjLmpzJyk7XG5jb25zdCBub2RlID0gcmVxdWlyZSgnLi91dGlscy9ub2RlLmpzJyk7XG5jb25zdCBub3JtYWxpemUgPSByZXF1aXJlKCcuL3V0aWxzL25vcm1hbGl6ZS5qcycpO1xuY29uc3Qgb2JqZWN0ID0gcmVxdWlyZSgnLi91dGlscy9vYmplY3QuanMnKTtcbmNvbnN0IHBhdGggPSByZXF1aXJlKCcuL3V0aWxzL3BhdGguanMnKTtcbmNvbnN0IHByb21pc2VidWZmZXIgPSByZXF1aXJlKCcuL3V0aWxzL3Byb21pc2VidWZmZXIuanMnKTtcbmNvbnN0IHNldmVyaXR5ID0gcmVxdWlyZSgnLi91dGlscy9zZXZlcml0eS5qcycpO1xuY29uc3Qgc3RhY2t0cmFjZSA9IHJlcXVpcmUoJy4vdXRpbHMvc3RhY2t0cmFjZS5qcycpO1xuY29uc3Qgbm9kZVN0YWNrVHJhY2UgPSByZXF1aXJlKCcuL3V0aWxzL25vZGUtc3RhY2stdHJhY2UuanMnKTtcbmNvbnN0IHN0cmluZyA9IHJlcXVpcmUoJy4vdXRpbHMvc3RyaW5nLmpzJyk7XG5jb25zdCBzdXBwb3J0cyA9IHJlcXVpcmUoJy4vdXRpbHMvc3VwcG9ydHMuanMnKTtcbmNvbnN0IHN5bmNwcm9taXNlID0gcmVxdWlyZSgnLi91dGlscy9zeW5jcHJvbWlzZS5qcycpO1xuY29uc3QgdGltZSA9IHJlcXVpcmUoJy4vdXRpbHMvdGltZS5qcycpO1xuY29uc3QgdHJhY2luZyA9IHJlcXVpcmUoJy4vdXRpbHMvdHJhY2luZy5qcycpO1xuY29uc3QgZW52ID0gcmVxdWlyZSgnLi91dGlscy9lbnYuanMnKTtcbmNvbnN0IGVudmVsb3BlJDEgPSByZXF1aXJlKCcuL3V0aWxzL2VudmVsb3BlLmpzJyk7XG5jb25zdCBjbGllbnRyZXBvcnQgPSByZXF1aXJlKCcuL3V0aWxzL2NsaWVudHJlcG9ydC5qcycpO1xuY29uc3QgcmF0ZWxpbWl0ID0gcmVxdWlyZSgnLi91dGlscy9yYXRlbGltaXQuanMnKTtcbmNvbnN0IGJhZ2dhZ2UgPSByZXF1aXJlKCcuL3V0aWxzL2JhZ2dhZ2UuanMnKTtcbmNvbnN0IHVybCA9IHJlcXVpcmUoJy4vdXRpbHMvdXJsLmpzJyk7XG5jb25zdCBldmVudGJ1aWxkZXIgPSByZXF1aXJlKCcuL3V0aWxzL2V2ZW50YnVpbGRlci5qcycpO1xuY29uc3QgYW5yID0gcmVxdWlyZSgnLi91dGlscy9hbnIuanMnKTtcbmNvbnN0IGxydSA9IHJlcXVpcmUoJy4vdXRpbHMvbHJ1LmpzJyk7XG5jb25zdCBwcm9wYWdhdGlvbkNvbnRleHQgPSByZXF1aXJlKCcuL3V0aWxzL3Byb3BhZ2F0aW9uQ29udGV4dC5qcycpO1xuY29uc3QgdmVyY2VsV2FpdFVudGlsID0gcmVxdWlyZSgnLi91dGlscy92ZXJjZWxXYWl0VW50aWwuanMnKTtcbmNvbnN0IGZsdXNoSWZTZXJ2ZXJsZXNzID0gcmVxdWlyZSgnLi91dGlscy9mbHVzaElmU2VydmVybGVzcy5qcycpO1xuY29uc3QgdmVyc2lvbiA9IHJlcXVpcmUoJy4vdXRpbHMvdmVyc2lvbi5qcycpO1xuY29uc3QgZGVidWdJZHMgPSByZXF1aXJlKCcuL3V0aWxzL2RlYnVnLWlkcy5qcycpO1xuY29uc3QgZXNjYXBlU3RyaW5nRm9yUmVnZXggPSByZXF1aXJlKCcuL3ZlbmRvci9lc2NhcGVTdHJpbmdGb3JSZWdleC5qcycpO1xuXG5cblxuZXhwb3J0cy5yZWdpc3RlclNwYW5FcnJvckluc3RydW1lbnRhdGlvbiA9IGVycm9ycy5yZWdpc3RlclNwYW5FcnJvckluc3RydW1lbnRhdGlvbjtcbmV4cG9ydHMuZ2V0Q2FwdHVyZWRTY29wZXNPblNwYW4gPSB1dGlscy5nZXRDYXB0dXJlZFNjb3Blc09uU3BhbjtcbmV4cG9ydHMuc2V0Q2FwdHVyZWRTY29wZXNPblNwYW4gPSB1dGlscy5zZXRDYXB0dXJlZFNjb3Blc09uU3BhbjtcbmV4cG9ydHMuVFJBQ0lOR19ERUZBVUxUUyA9IGlkbGVTcGFuLlRSQUNJTkdfREVGQVVMVFM7XG5leHBvcnRzLnN0YXJ0SWRsZVNwYW4gPSBpZGxlU3Bhbi5zdGFydElkbGVTcGFuO1xuZXhwb3J0cy5TZW50cnlTcGFuID0gc2VudHJ5U3Bhbi5TZW50cnlTcGFuO1xuZXhwb3J0cy5TZW50cnlOb25SZWNvcmRpbmdTcGFuID0gc2VudHJ5Tm9uUmVjb3JkaW5nU3Bhbi5TZW50cnlOb25SZWNvcmRpbmdTcGFuO1xuZXhwb3J0cy5TUEFOX1NUQVRVU19FUlJPUiA9IHNwYW5zdGF0dXMuU1BBTl9TVEFUVVNfRVJST1I7XG5leHBvcnRzLlNQQU5fU1RBVFVTX09LID0gc3BhbnN0YXR1cy5TUEFOX1NUQVRVU19PSztcbmV4cG9ydHMuU1BBTl9TVEFUVVNfVU5TRVQgPSBzcGFuc3RhdHVzLlNQQU5fU1RBVFVTX1VOU0VUO1xuZXhwb3J0cy5nZXRTcGFuU3RhdHVzRnJvbUh0dHBDb2RlID0gc3BhbnN0YXR1cy5nZXRTcGFuU3RhdHVzRnJvbUh0dHBDb2RlO1xuZXhwb3J0cy5zZXRIdHRwU3RhdHVzID0gc3BhbnN0YXR1cy5zZXRIdHRwU3RhdHVzO1xuZXhwb3J0cy5jb250aW51ZVRyYWNlID0gdHJhY2UuY29udGludWVUcmFjZTtcbmV4cG9ydHMuc3RhcnRJbmFjdGl2ZVNwYW4gPSB0cmFjZS5zdGFydEluYWN0aXZlU3BhbjtcbmV4cG9ydHMuc3RhcnROZXdUcmFjZSA9IHRyYWNlLnN0YXJ0TmV3VHJhY2U7XG5leHBvcnRzLnN0YXJ0U3BhbiA9IHRyYWNlLnN0YXJ0U3BhbjtcbmV4cG9ydHMuc3RhcnRTcGFuTWFudWFsID0gdHJhY2Uuc3RhcnRTcGFuTWFudWFsO1xuZXhwb3J0cy5zdXBwcmVzc1RyYWNpbmcgPSB0cmFjZS5zdXBwcmVzc1RyYWNpbmc7XG5leHBvcnRzLndpdGhBY3RpdmVTcGFuID0gdHJhY2Uud2l0aEFjdGl2ZVNwYW47XG5leHBvcnRzLmdldER5bmFtaWNTYW1wbGluZ0NvbnRleHRGcm9tQ2xpZW50ID0gZHluYW1pY1NhbXBsaW5nQ29udGV4dC5nZXREeW5hbWljU2FtcGxpbmdDb250ZXh0RnJvbUNsaWVudDtcbmV4cG9ydHMuZ2V0RHluYW1pY1NhbXBsaW5nQ29udGV4dEZyb21TY29wZSA9IGR5bmFtaWNTYW1wbGluZ0NvbnRleHQuZ2V0RHluYW1pY1NhbXBsaW5nQ29udGV4dEZyb21TY29wZTtcbmV4cG9ydHMuZ2V0RHluYW1pY1NhbXBsaW5nQ29udGV4dEZyb21TcGFuID0gZHluYW1pY1NhbXBsaW5nQ29udGV4dC5nZXREeW5hbWljU2FtcGxpbmdDb250ZXh0RnJvbVNwYW47XG5leHBvcnRzLnNwYW5Ub0JhZ2dhZ2VIZWFkZXIgPSBkeW5hbWljU2FtcGxpbmdDb250ZXh0LnNwYW5Ub0JhZ2dhZ2VIZWFkZXI7XG5leHBvcnRzLnNldE1lYXN1cmVtZW50ID0gbWVhc3VyZW1lbnQuc2V0TWVhc3VyZW1lbnQ7XG5leHBvcnRzLnRpbWVkRXZlbnRzVG9NZWFzdXJlbWVudHMgPSBtZWFzdXJlbWVudC50aW1lZEV2ZW50c1RvTWVhc3VyZW1lbnRzO1xuZXhwb3J0cy5zYW1wbGVTcGFuID0gc2FtcGxpbmcuc2FtcGxlU3BhbjtcbmV4cG9ydHMubG9nU3BhbkVuZCA9IGxvZ1NwYW5zLmxvZ1NwYW5FbmQ7XG5leHBvcnRzLmxvZ1NwYW5TdGFydCA9IGxvZ1NwYW5zLmxvZ1NwYW5TdGFydDtcbmV4cG9ydHMuU0VNQU5USUNfQVRUUklCVVRFX0NBQ0hFX0hJVCA9IHNlbWFudGljQXR0cmlidXRlcy5TRU1BTlRJQ19BVFRSSUJVVEVfQ0FDSEVfSElUO1xuZXhwb3J0cy5TRU1BTlRJQ19BVFRSSUJVVEVfQ0FDSEVfSVRFTV9TSVpFID0gc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9DQUNIRV9JVEVNX1NJWkU7XG5leHBvcnRzLlNFTUFOVElDX0FUVFJJQlVURV9DQUNIRV9LRVkgPSBzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX0NBQ0hFX0tFWTtcbmV4cG9ydHMuU0VNQU5USUNfQVRUUklCVVRFX0VYQ0xVU0lWRV9USU1FID0gc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9FWENMVVNJVkVfVElNRTtcbmV4cG9ydHMuU0VNQU5USUNfQVRUUklCVVRFX0hUVFBfUkVRVUVTVF9NRVRIT0QgPSBzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX0hUVFBfUkVRVUVTVF9NRVRIT0Q7XG5leHBvcnRzLlNFTUFOVElDX0FUVFJJQlVURV9QUk9GSUxFX0lEID0gc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9QUk9GSUxFX0lEO1xuZXhwb3J0cy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX0NVU1RPTV9TUEFOX05BTUUgPSBzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9DVVNUT01fU1BBTl9OQU1FO1xuZXhwb3J0cy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX0lETEVfU1BBTl9GSU5JU0hfUkVBU09OID0gc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfSURMRV9TUEFOX0ZJTklTSF9SRUFTT047XG5leHBvcnRzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfTUVBU1VSRU1FTlRfVU5JVCA9IHNlbWFudGljQXR0cmlidXRlcy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX01FQVNVUkVNRU5UX1VOSVQ7XG5leHBvcnRzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfTUVBU1VSRU1FTlRfVkFMVUUgPSBzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9NRUFTVVJFTUVOVF9WQUxVRTtcbmV4cG9ydHMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9PUCA9IHNlbWFudGljQXR0cmlidXRlcy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX09QO1xuZXhwb3J0cy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX09SSUdJTiA9IHNlbWFudGljQXR0cmlidXRlcy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX09SSUdJTjtcbmV4cG9ydHMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9QUkVWSU9VU19UUkFDRV9TQU1QTEVfUkFURSA9IHNlbWFudGljQXR0cmlidXRlcy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX1BSRVZJT1VTX1RSQUNFX1NBTVBMRV9SQVRFO1xuZXhwb3J0cy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX1NBTVBMRV9SQVRFID0gc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfU0FNUExFX1JBVEU7XG5leHBvcnRzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfU09VUkNFID0gc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfU09VUkNFO1xuZXhwb3J0cy5TRU1BTlRJQ19BVFRSSUJVVEVfVVJMX0ZVTEwgPSBzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX1VSTF9GVUxMO1xuZXhwb3J0cy5TRU1BTlRJQ19MSU5LX0FUVFJJQlVURV9MSU5LX1RZUEUgPSBzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfTElOS19BVFRSSUJVVEVfTElOS19UWVBFO1xuZXhwb3J0cy5jcmVhdGVFdmVudEVudmVsb3BlID0gZW52ZWxvcGUuY3JlYXRlRXZlbnRFbnZlbG9wZTtcbmV4cG9ydHMuY3JlYXRlU2Vzc2lvbkVudmVsb3BlID0gZW52ZWxvcGUuY3JlYXRlU2Vzc2lvbkVudmVsb3BlO1xuZXhwb3J0cy5jcmVhdGVTcGFuRW52ZWxvcGUgPSBlbnZlbG9wZS5jcmVhdGVTcGFuRW52ZWxvcGU7XG5leHBvcnRzLmFkZEV2ZW50UHJvY2Vzc29yID0gZXhwb3J0cyQxLmFkZEV2ZW50UHJvY2Vzc29yO1xuZXhwb3J0cy5jYXB0dXJlQ2hlY2tJbiA9IGV4cG9ydHMkMS5jYXB0dXJlQ2hlY2tJbjtcbmV4cG9ydHMuY2FwdHVyZUV2ZW50ID0gZXhwb3J0cyQxLmNhcHR1cmVFdmVudDtcbmV4cG9ydHMuY2FwdHVyZUV4Y2VwdGlvbiA9IGV4cG9ydHMkMS5jYXB0dXJlRXhjZXB0aW9uO1xuZXhwb3J0cy5jYXB0dXJlTWVzc2FnZSA9IGV4cG9ydHMkMS5jYXB0dXJlTWVzc2FnZTtcbmV4cG9ydHMuY2FwdHVyZVNlc3Npb24gPSBleHBvcnRzJDEuY2FwdHVyZVNlc3Npb247XG5leHBvcnRzLmNsb3NlID0gZXhwb3J0cyQxLmNsb3NlO1xuZXhwb3J0cy5lbmRTZXNzaW9uID0gZXhwb3J0cyQxLmVuZFNlc3Npb247XG5leHBvcnRzLmZsdXNoID0gZXhwb3J0cyQxLmZsdXNoO1xuZXhwb3J0cy5pc0VuYWJsZWQgPSBleHBvcnRzJDEuaXNFbmFibGVkO1xuZXhwb3J0cy5pc0luaXRpYWxpemVkID0gZXhwb3J0cyQxLmlzSW5pdGlhbGl6ZWQ7XG5leHBvcnRzLmxhc3RFdmVudElkID0gZXhwb3J0cyQxLmxhc3RFdmVudElkO1xuZXhwb3J0cy5zZXRDb250ZXh0ID0gZXhwb3J0cyQxLnNldENvbnRleHQ7XG5leHBvcnRzLnNldEV4dHJhID0gZXhwb3J0cyQxLnNldEV4dHJhO1xuZXhwb3J0cy5zZXRFeHRyYXMgPSBleHBvcnRzJDEuc2V0RXh0cmFzO1xuZXhwb3J0cy5zZXRUYWcgPSBleHBvcnRzJDEuc2V0VGFnO1xuZXhwb3J0cy5zZXRUYWdzID0gZXhwb3J0cyQxLnNldFRhZ3M7XG5leHBvcnRzLnNldFVzZXIgPSBleHBvcnRzJDEuc2V0VXNlcjtcbmV4cG9ydHMuc3RhcnRTZXNzaW9uID0gZXhwb3J0cyQxLnN0YXJ0U2Vzc2lvbjtcbmV4cG9ydHMud2l0aE1vbml0b3IgPSBleHBvcnRzJDEud2l0aE1vbml0b3I7XG5leHBvcnRzLmdldENsaWVudCA9IGN1cnJlbnRTY29wZXMuZ2V0Q2xpZW50O1xuZXhwb3J0cy5nZXRDdXJyZW50U2NvcGUgPSBjdXJyZW50U2NvcGVzLmdldEN1cnJlbnRTY29wZTtcbmV4cG9ydHMuZ2V0R2xvYmFsU2NvcGUgPSBjdXJyZW50U2NvcGVzLmdldEdsb2JhbFNjb3BlO1xuZXhwb3J0cy5nZXRJc29sYXRpb25TY29wZSA9IGN1cnJlbnRTY29wZXMuZ2V0SXNvbGF0aW9uU2NvcGU7XG5leHBvcnRzLmdldFRyYWNlQ29udGV4dEZyb21TY29wZSA9IGN1cnJlbnRTY29wZXMuZ2V0VHJhY2VDb250ZXh0RnJvbVNjb3BlO1xuZXhwb3J0cy53aXRoSXNvbGF0aW9uU2NvcGUgPSBjdXJyZW50U2NvcGVzLndpdGhJc29sYXRpb25TY29wZTtcbmV4cG9ydHMud2l0aFNjb3BlID0gY3VycmVudFNjb3Blcy53aXRoU2NvcGU7XG5leHBvcnRzLmdldERlZmF1bHRDdXJyZW50U2NvcGUgPSBkZWZhdWx0U2NvcGVzLmdldERlZmF1bHRDdXJyZW50U2NvcGU7XG5leHBvcnRzLmdldERlZmF1bHRJc29sYXRpb25TY29wZSA9IGRlZmF1bHRTY29wZXMuZ2V0RGVmYXVsdElzb2xhdGlvblNjb3BlO1xuZXhwb3J0cy5zZXRBc3luY0NvbnRleHRTdHJhdGVneSA9IGluZGV4LnNldEFzeW5jQ29udGV4dFN0cmF0ZWd5O1xuZXhwb3J0cy5nZXRHbG9iYWxTaW5nbGV0b24gPSBjYXJyaWVyLmdldEdsb2JhbFNpbmdsZXRvbjtcbmV4cG9ydHMuZ2V0TWFpbkNhcnJpZXIgPSBjYXJyaWVyLmdldE1haW5DYXJyaWVyO1xuZXhwb3J0cy5jbG9zZVNlc3Npb24gPSBzZXNzaW9uLmNsb3NlU2Vzc2lvbjtcbmV4cG9ydHMubWFrZVNlc3Npb24gPSBzZXNzaW9uLm1ha2VTZXNzaW9uO1xuZXhwb3J0cy51cGRhdGVTZXNzaW9uID0gc2Vzc2lvbi51cGRhdGVTZXNzaW9uO1xuZXhwb3J0cy5TY29wZSA9IHNjb3BlLlNjb3BlO1xuZXhwb3J0cy5ub3RpZnlFdmVudFByb2Nlc3NvcnMgPSBldmVudFByb2Nlc3NvcnMubm90aWZ5RXZlbnRQcm9jZXNzb3JzO1xuZXhwb3J0cy5nZXRFbnZlbG9wZUVuZHBvaW50V2l0aFVybEVuY29kZWRBdXRoID0gYXBpLmdldEVudmVsb3BlRW5kcG9pbnRXaXRoVXJsRW5jb2RlZEF1dGg7XG5leHBvcnRzLmdldFJlcG9ydERpYWxvZ0VuZHBvaW50ID0gYXBpLmdldFJlcG9ydERpYWxvZ0VuZHBvaW50O1xuZXhwb3J0cy5CYXNlQ2xpZW50ID0gY2xpZW50LkJhc2VDbGllbnQ7XG5leHBvcnRzLkNsaWVudCA9IGNsaWVudC5DbGllbnQ7XG5leHBvcnRzLlNlcnZlclJ1bnRpbWVDbGllbnQgPSBzZXJ2ZXJSdW50aW1lQ2xpZW50LlNlcnZlclJ1bnRpbWVDbGllbnQ7XG5leHBvcnRzLmluaXRBbmRCaW5kID0gc2RrLmluaXRBbmRCaW5kO1xuZXhwb3J0cy5zZXRDdXJyZW50Q2xpZW50ID0gc2RrLnNldEN1cnJlbnRDbGllbnQ7XG5leHBvcnRzLmNyZWF0ZVRyYW5zcG9ydCA9IGJhc2UuY3JlYXRlVHJhbnNwb3J0O1xuZXhwb3J0cy5tYWtlT2ZmbGluZVRyYW5zcG9ydCA9IG9mZmxpbmUubWFrZU9mZmxpbmVUcmFuc3BvcnQ7XG5leHBvcnRzLm1ha2VNdWx0aXBsZXhlZFRyYW5zcG9ydCA9IG11bHRpcGxleGVkLm1ha2VNdWx0aXBsZXhlZFRyYW5zcG9ydDtcbmV4cG9ydHMuYWRkSW50ZWdyYXRpb24gPSBpbnRlZ3JhdGlvbi5hZGRJbnRlZ3JhdGlvbjtcbmV4cG9ydHMuZGVmaW5lSW50ZWdyYXRpb24gPSBpbnRlZ3JhdGlvbi5kZWZpbmVJbnRlZ3JhdGlvbjtcbmV4cG9ydHMuZ2V0SW50ZWdyYXRpb25zVG9TZXR1cCA9IGludGVncmF0aW9uLmdldEludGVncmF0aW9uc1RvU2V0dXA7XG5leHBvcnRzLmFwcGx5U2NvcGVEYXRhVG9FdmVudCA9IGFwcGx5U2NvcGVEYXRhVG9FdmVudC5hcHBseVNjb3BlRGF0YVRvRXZlbnQ7XG5leHBvcnRzLm1lcmdlU2NvcGVEYXRhID0gYXBwbHlTY29wZURhdGFUb0V2ZW50Lm1lcmdlU2NvcGVEYXRhO1xuZXhwb3J0cy5wcmVwYXJlRXZlbnQgPSBwcmVwYXJlRXZlbnQucHJlcGFyZUV2ZW50O1xuZXhwb3J0cy5jcmVhdGVDaGVja0luRW52ZWxvcGUgPSBjaGVja2luLmNyZWF0ZUNoZWNrSW5FbnZlbG9wZTtcbmV4cG9ydHMuaGFzU3BhbnNFbmFibGVkID0gaGFzU3BhbnNFbmFibGVkLmhhc1NwYW5zRW5hYmxlZDtcbmV4cG9ydHMuaGFzVHJhY2luZ0VuYWJsZWQgPSBoYXNTcGFuc0VuYWJsZWQuaGFzVHJhY2luZ0VuYWJsZWQ7XG5leHBvcnRzLmlzU2VudHJ5UmVxdWVzdFVybCA9IGlzU2VudHJ5UmVxdWVzdFVybC5pc1NlbnRyeVJlcXVlc3RVcmw7XG5leHBvcnRzLmhhbmRsZUNhbGxiYWNrRXJyb3JzID0gaGFuZGxlQ2FsbGJhY2tFcnJvcnMuaGFuZGxlQ2FsbGJhY2tFcnJvcnM7XG5leHBvcnRzLmZtdCA9IHBhcmFtZXRlcml6ZS5mbXQ7XG5leHBvcnRzLnBhcmFtZXRlcml6ZSA9IHBhcmFtZXRlcml6ZS5wYXJhbWV0ZXJpemU7XG5leHBvcnRzLmFkZEF1dG9JcEFkZHJlc3NUb1Nlc3Npb24gPSBpcEFkZHJlc3MuYWRkQXV0b0lwQWRkcmVzc1RvU2Vzc2lvbjtcbmV4cG9ydHMuYWRkQXV0b0lwQWRkcmVzc1RvVXNlciA9IGlwQWRkcmVzcy5hZGRBdXRvSXBBZGRyZXNzVG9Vc2VyO1xuZXhwb3J0cy5hZGRDaGlsZFNwYW5Ub1NwYW4gPSBzcGFuVXRpbHMuYWRkQ2hpbGRTcGFuVG9TcGFuO1xuZXhwb3J0cy5jb252ZXJ0U3BhbkxpbmtzRm9yRW52ZWxvcGUgPSBzcGFuVXRpbHMuY29udmVydFNwYW5MaW5rc0ZvckVudmVsb3BlO1xuZXhwb3J0cy5nZXRBY3RpdmVTcGFuID0gc3BhblV0aWxzLmdldEFjdGl2ZVNwYW47XG5leHBvcnRzLmdldFJvb3RTcGFuID0gc3BhblV0aWxzLmdldFJvb3RTcGFuO1xuZXhwb3J0cy5nZXRTcGFuRGVzY2VuZGFudHMgPSBzcGFuVXRpbHMuZ2V0U3BhbkRlc2NlbmRhbnRzO1xuZXhwb3J0cy5nZXRTdGF0dXNNZXNzYWdlID0gc3BhblV0aWxzLmdldFN0YXR1c01lc3NhZ2U7XG5leHBvcnRzLnNwYW5Jc1NhbXBsZWQgPSBzcGFuVXRpbHMuc3BhbklzU2FtcGxlZDtcbmV4cG9ydHMuc3BhblRpbWVJbnB1dFRvU2Vjb25kcyA9IHNwYW5VdGlscy5zcGFuVGltZUlucHV0VG9TZWNvbmRzO1xuZXhwb3J0cy5zcGFuVG9KU09OID0gc3BhblV0aWxzLnNwYW5Ub0pTT047XG5leHBvcnRzLnNwYW5Ub1RyYWNlQ29udGV4dCA9IHNwYW5VdGlscy5zcGFuVG9UcmFjZUNvbnRleHQ7XG5leHBvcnRzLnNwYW5Ub1RyYWNlSGVhZGVyID0gc3BhblV0aWxzLnNwYW5Ub1RyYWNlSGVhZGVyO1xuZXhwb3J0cy51cGRhdGVTcGFuTmFtZSA9IHNwYW5VdGlscy51cGRhdGVTcGFuTmFtZTtcbmV4cG9ydHMucGFyc2VTYW1wbGVSYXRlID0gcGFyc2VTYW1wbGVSYXRlLnBhcnNlU2FtcGxlUmF0ZTtcbmV4cG9ydHMuYXBwbHlTZGtNZXRhZGF0YSA9IHNka01ldGFkYXRhLmFwcGx5U2RrTWV0YWRhdGE7XG5leHBvcnRzLmdldFRyYWNlRGF0YSA9IHRyYWNlRGF0YS5nZXRUcmFjZURhdGE7XG5leHBvcnRzLmdldFRyYWNlTWV0YVRhZ3MgPSBtZXRhLmdldFRyYWNlTWV0YVRhZ3M7XG5leHBvcnRzLmRlYm91bmNlID0gZGVib3VuY2UuZGVib3VuY2U7XG5leHBvcnRzLmV4dHJhY3RRdWVyeVBhcmFtc0Zyb21VcmwgPSByZXF1ZXN0LmV4dHJhY3RRdWVyeVBhcmFtc0Zyb21Vcmw7XG5leHBvcnRzLmhlYWRlcnNUb0RpY3QgPSByZXF1ZXN0LmhlYWRlcnNUb0RpY3Q7XG5leHBvcnRzLmh0dHBSZXF1ZXN0VG9SZXF1ZXN0RGF0YSA9IHJlcXVlc3QuaHR0cFJlcXVlc3RUb1JlcXVlc3REYXRhO1xuZXhwb3J0cy53aW50ZXJDR0hlYWRlcnNUb0RpY3QgPSByZXF1ZXN0LndpbnRlckNHSGVhZGVyc1RvRGljdDtcbmV4cG9ydHMud2ludGVyQ0dSZXF1ZXN0VG9SZXF1ZXN0RGF0YSA9IHJlcXVlc3Qud2ludGVyQ0dSZXF1ZXN0VG9SZXF1ZXN0RGF0YTtcbmV4cG9ydHMuREVGQVVMVF9FTlZJUk9OTUVOVCA9IGNvbnN0YW50cy5ERUZBVUxUX0VOVklST05NRU5UO1xuZXhwb3J0cy5hZGRCcmVhZGNydW1iID0gYnJlYWRjcnVtYnMuYWRkQnJlYWRjcnVtYjtcbmV4cG9ydHMuZnVuY3Rpb25Ub1N0cmluZ0ludGVncmF0aW9uID0gZnVuY3Rpb250b3N0cmluZy5mdW5jdGlvblRvU3RyaW5nSW50ZWdyYXRpb247XG5leHBvcnRzLmV2ZW50RmlsdGVyc0ludGVncmF0aW9uID0gZXZlbnRGaWx0ZXJzLmV2ZW50RmlsdGVyc0ludGVncmF0aW9uO1xuZXhwb3J0cy5pbmJvdW5kRmlsdGVyc0ludGVncmF0aW9uID0gZXZlbnRGaWx0ZXJzLmluYm91bmRGaWx0ZXJzSW50ZWdyYXRpb247XG5leHBvcnRzLmxpbmtlZEVycm9yc0ludGVncmF0aW9uID0gbGlua2VkZXJyb3JzLmxpbmtlZEVycm9yc0ludGVncmF0aW9uO1xuZXhwb3J0cy5tb2R1bGVNZXRhZGF0YUludGVncmF0aW9uID0gbWV0YWRhdGEubW9kdWxlTWV0YWRhdGFJbnRlZ3JhdGlvbjtcbmV4cG9ydHMucmVxdWVzdERhdGFJbnRlZ3JhdGlvbiA9IHJlcXVlc3RkYXRhLnJlcXVlc3REYXRhSW50ZWdyYXRpb247XG5leHBvcnRzLmNhcHR1cmVDb25zb2xlSW50ZWdyYXRpb24gPSBjYXB0dXJlY29uc29sZS5jYXB0dXJlQ29uc29sZUludGVncmF0aW9uO1xuZXhwb3J0cy5kZWR1cGVJbnRlZ3JhdGlvbiA9IGRlZHVwZS5kZWR1cGVJbnRlZ3JhdGlvbjtcbmV4cG9ydHMuZXh0cmFFcnJvckRhdGFJbnRlZ3JhdGlvbiA9IGV4dHJhZXJyb3JkYXRhLmV4dHJhRXJyb3JEYXRhSW50ZWdyYXRpb247XG5leHBvcnRzLnJld3JpdGVGcmFtZXNJbnRlZ3JhdGlvbiA9IHJld3JpdGVmcmFtZXMucmV3cml0ZUZyYW1lc0ludGVncmF0aW9uO1xuZXhwb3J0cy5pbnN0cnVtZW50U3VwYWJhc2VDbGllbnQgPSBzdXBhYmFzZS5pbnN0cnVtZW50U3VwYWJhc2VDbGllbnQ7XG5leHBvcnRzLnN1cGFiYXNlSW50ZWdyYXRpb24gPSBzdXBhYmFzZS5zdXBhYmFzZUludGVncmF0aW9uO1xuZXhwb3J0cy56b2RFcnJvcnNJbnRlZ3JhdGlvbiA9IHpvZGVycm9ycy56b2RFcnJvcnNJbnRlZ3JhdGlvbjtcbmV4cG9ydHMudGhpcmRQYXJ0eUVycm9yRmlsdGVySW50ZWdyYXRpb24gPSB0aGlyZFBhcnR5RXJyb3JzRmlsdGVyLnRoaXJkUGFydHlFcnJvckZpbHRlckludGVncmF0aW9uO1xuZXhwb3J0cy5jb25zb2xlSW50ZWdyYXRpb24gPSBjb25zb2xlLmNvbnNvbGVJbnRlZ3JhdGlvbjtcbmV4cG9ydHMuZmVhdHVyZUZsYWdzSW50ZWdyYXRpb24gPSBmZWF0dXJlRmxhZ3NJbnRlZ3JhdGlvbi5mZWF0dXJlRmxhZ3NJbnRlZ3JhdGlvbjtcbmV4cG9ydHMucHJvZmlsZXIgPSBwcm9maWxpbmcucHJvZmlsZXI7XG5leHBvcnRzLmluc3RydW1lbnRGZXRjaFJlcXVlc3QgPSBmZXRjaC5pbnN0cnVtZW50RmV0Y2hSZXF1ZXN0O1xuZXhwb3J0cy50cnBjTWlkZGxld2FyZSA9IHRycGMudHJwY01pZGRsZXdhcmU7XG5leHBvcnRzLndyYXBNY3BTZXJ2ZXJXaXRoU2VudHJ5ID0gaW5kZXgkMS53cmFwTWNwU2VydmVyV2l0aFNlbnRyeTtcbmV4cG9ydHMuY2FwdHVyZUZlZWRiYWNrID0gZmVlZGJhY2suY2FwdHVyZUZlZWRiYWNrO1xuZXhwb3J0cy5fSU5URVJOQUxfY2FwdHVyZUxvZyA9IGV4cG9ydHMkMi5fSU5URVJOQUxfY2FwdHVyZUxvZztcbmV4cG9ydHMuX0lOVEVSTkFMX2NhcHR1cmVTZXJpYWxpemVkTG9nID0gZXhwb3J0cyQyLl9JTlRFUk5BTF9jYXB0dXJlU2VyaWFsaXplZExvZztcbmV4cG9ydHMuX0lOVEVSTkFMX2ZsdXNoTG9nc0J1ZmZlciA9IGV4cG9ydHMkMi5fSU5URVJOQUxfZmx1c2hMb2dzQnVmZmVyO1xuZXhwb3J0cy5jb25zb2xlTG9nZ2luZ0ludGVncmF0aW9uID0gY29uc29sZUludGVncmF0aW9uLmNvbnNvbGVMb2dnaW5nSW50ZWdyYXRpb247XG5leHBvcnRzLmFkZFZlcmNlbEFpUHJvY2Vzc29ycyA9IHZlcmNlbEFpLmFkZFZlcmNlbEFpUHJvY2Vzc29ycztcbmV4cG9ydHMuaW5zdHJ1bWVudE9wZW5BaUNsaWVudCA9IGluZGV4JDIuaW5zdHJ1bWVudE9wZW5BaUNsaWVudDtcbmV4cG9ydHMuT1BFTkFJX0lOVEVHUkFUSU9OX05BTUUgPSBjb25zdGFudHMkMS5PUEVOQUlfSU5URUdSQVRJT05fTkFNRTtcbmV4cG9ydHMuX0lOVEVSTkFMX0ZMQUdfQlVGRkVSX1NJWkUgPSBmZWF0dXJlRmxhZ3MuX0lOVEVSTkFMX0ZMQUdfQlVGRkVSX1NJWkU7XG5leHBvcnRzLl9JTlRFUk5BTF9NQVhfRkxBR1NfUEVSX1NQQU4gPSBmZWF0dXJlRmxhZ3MuX0lOVEVSTkFMX01BWF9GTEFHU19QRVJfU1BBTjtcbmV4cG9ydHMuX0lOVEVSTkFMX2FkZEZlYXR1cmVGbGFnVG9BY3RpdmVTcGFuID0gZmVhdHVyZUZsYWdzLl9JTlRFUk5BTF9hZGRGZWF0dXJlRmxhZ1RvQWN0aXZlU3BhbjtcbmV4cG9ydHMuX0lOVEVSTkFMX2NvcHlGbGFnc0Zyb21TY29wZVRvRXZlbnQgPSBmZWF0dXJlRmxhZ3MuX0lOVEVSTkFMX2NvcHlGbGFnc0Zyb21TY29wZVRvRXZlbnQ7XG5leHBvcnRzLl9JTlRFUk5BTF9pbnNlcnRGbGFnVG9TY29wZSA9IGZlYXR1cmVGbGFncy5fSU5URVJOQUxfaW5zZXJ0RmxhZ1RvU2NvcGU7XG5leHBvcnRzLmFwcGx5QWdncmVnYXRlRXJyb3JzVG9FdmVudCA9IGFnZ3JlZ2F0ZUVycm9ycy5hcHBseUFnZ3JlZ2F0ZUVycm9yc1RvRXZlbnQ7XG5leHBvcnRzLmdldEJyZWFkY3J1bWJMb2dMZXZlbEZyb21IdHRwU3RhdHVzQ29kZSA9IGJyZWFkY3J1bWJMb2dMZXZlbC5nZXRCcmVhZGNydW1iTG9nTGV2ZWxGcm9tSHR0cFN0YXR1c0NvZGU7XG5leHBvcnRzLmdldENvbXBvbmVudE5hbWUgPSBicm93c2VyLmdldENvbXBvbmVudE5hbWU7XG5leHBvcnRzLmdldExvY2F0aW9uSHJlZiA9IGJyb3dzZXIuZ2V0TG9jYXRpb25IcmVmO1xuZXhwb3J0cy5odG1sVHJlZUFzU3RyaW5nID0gYnJvd3Nlci5odG1sVHJlZUFzU3RyaW5nO1xuZXhwb3J0cy5kc25Gcm9tU3RyaW5nID0gZHNuLmRzbkZyb21TdHJpbmc7XG5leHBvcnRzLmRzblRvU3RyaW5nID0gZHNuLmRzblRvU3RyaW5nO1xuZXhwb3J0cy5tYWtlRHNuID0gZHNuLm1ha2VEc247XG5leHBvcnRzLlNlbnRyeUVycm9yID0gZXJyb3IuU2VudHJ5RXJyb3I7XG5leHBvcnRzLkdMT0JBTF9PQkogPSB3b3JsZHdpZGUuR0xPQkFMX09CSjtcbmV4cG9ydHMuYWRkQ29uc29sZUluc3RydW1lbnRhdGlvbkhhbmRsZXIgPSBjb25zb2xlJDEuYWRkQ29uc29sZUluc3RydW1lbnRhdGlvbkhhbmRsZXI7XG5leHBvcnRzLmFkZEZldGNoRW5kSW5zdHJ1bWVudGF0aW9uSGFuZGxlciA9IGZldGNoJDEuYWRkRmV0Y2hFbmRJbnN0cnVtZW50YXRpb25IYW5kbGVyO1xuZXhwb3J0cy5hZGRGZXRjaEluc3RydW1lbnRhdGlvbkhhbmRsZXIgPSBmZXRjaCQxLmFkZEZldGNoSW5zdHJ1bWVudGF0aW9uSGFuZGxlcjtcbmV4cG9ydHMuYWRkR2xvYmFsRXJyb3JJbnN0cnVtZW50YXRpb25IYW5kbGVyID0gZ2xvYmFsRXJyb3IuYWRkR2xvYmFsRXJyb3JJbnN0cnVtZW50YXRpb25IYW5kbGVyO1xuZXhwb3J0cy5hZGRHbG9iYWxVbmhhbmRsZWRSZWplY3Rpb25JbnN0cnVtZW50YXRpb25IYW5kbGVyID0gZ2xvYmFsVW5oYW5kbGVkUmVqZWN0aW9uLmFkZEdsb2JhbFVuaGFuZGxlZFJlamVjdGlvbkluc3RydW1lbnRhdGlvbkhhbmRsZXI7XG5leHBvcnRzLmFkZEhhbmRsZXIgPSBoYW5kbGVycy5hZGRIYW5kbGVyO1xuZXhwb3J0cy5tYXliZUluc3RydW1lbnQgPSBoYW5kbGVycy5tYXliZUluc3RydW1lbnQ7XG5leHBvcnRzLnJlc2V0SW5zdHJ1bWVudGF0aW9uSGFuZGxlcnMgPSBoYW5kbGVycy5yZXNldEluc3RydW1lbnRhdGlvbkhhbmRsZXJzO1xuZXhwb3J0cy50cmlnZ2VySGFuZGxlcnMgPSBoYW5kbGVycy50cmlnZ2VySGFuZGxlcnM7XG5leHBvcnRzLmlzRE9NRXJyb3IgPSBpcy5pc0RPTUVycm9yO1xuZXhwb3J0cy5pc0RPTUV4Y2VwdGlvbiA9IGlzLmlzRE9NRXhjZXB0aW9uO1xuZXhwb3J0cy5pc0VsZW1lbnQgPSBpcy5pc0VsZW1lbnQ7XG5leHBvcnRzLmlzRXJyb3IgPSBpcy5pc0Vycm9yO1xuZXhwb3J0cy5pc0Vycm9yRXZlbnQgPSBpcy5pc0Vycm9yRXZlbnQ7XG5leHBvcnRzLmlzRXZlbnQgPSBpcy5pc0V2ZW50O1xuZXhwb3J0cy5pc0luc3RhbmNlT2YgPSBpcy5pc0luc3RhbmNlT2Y7XG5leHBvcnRzLmlzUGFyYW1ldGVyaXplZFN0cmluZyA9IGlzLmlzUGFyYW1ldGVyaXplZFN0cmluZztcbmV4cG9ydHMuaXNQbGFpbk9iamVjdCA9IGlzLmlzUGxhaW5PYmplY3Q7XG5leHBvcnRzLmlzUHJpbWl0aXZlID0gaXMuaXNQcmltaXRpdmU7XG5leHBvcnRzLmlzUmVnRXhwID0gaXMuaXNSZWdFeHA7XG5leHBvcnRzLmlzU3RyaW5nID0gaXMuaXNTdHJpbmc7XG5leHBvcnRzLmlzU3ludGhldGljRXZlbnQgPSBpcy5pc1N5bnRoZXRpY0V2ZW50O1xuZXhwb3J0cy5pc1RoZW5hYmxlID0gaXMuaXNUaGVuYWJsZTtcbmV4cG9ydHMuaXNWdWVWaWV3TW9kZWwgPSBpcy5pc1Z1ZVZpZXdNb2RlbDtcbmV4cG9ydHMuaXNCcm93c2VyID0gaXNCcm93c2VyLmlzQnJvd3NlcjtcbmV4cG9ydHMuQ09OU09MRV9MRVZFTFMgPSBkZWJ1Z0xvZ2dlci5DT05TT0xFX0xFVkVMUztcbmV4cG9ydHMuY29uc29sZVNhbmRib3ggPSBkZWJ1Z0xvZ2dlci5jb25zb2xlU2FuZGJveDtcbmV4cG9ydHMuZGVidWcgPSBkZWJ1Z0xvZ2dlci5kZWJ1ZztcbmV4cG9ydHMubG9nZ2VyID0gZGVidWdMb2dnZXIubG9nZ2VyO1xuZXhwb3J0cy5vcmlnaW5hbENvbnNvbGVNZXRob2RzID0gZGVidWdMb2dnZXIub3JpZ2luYWxDb25zb2xlTWV0aG9kcztcbmV4cG9ydHMuYWRkQ29udGV4dFRvRnJhbWUgPSBtaXNjLmFkZENvbnRleHRUb0ZyYW1lO1xuZXhwb3J0cy5hZGRFeGNlcHRpb25NZWNoYW5pc20gPSBtaXNjLmFkZEV4Y2VwdGlvbk1lY2hhbmlzbTtcbmV4cG9ydHMuYWRkRXhjZXB0aW9uVHlwZVZhbHVlID0gbWlzYy5hZGRFeGNlcHRpb25UeXBlVmFsdWU7XG5leHBvcnRzLmNoZWNrT3JTZXRBbHJlYWR5Q2F1Z2h0ID0gbWlzYy5jaGVja09yU2V0QWxyZWFkeUNhdWdodDtcbmV4cG9ydHMuZ2V0RXZlbnREZXNjcmlwdGlvbiA9IG1pc2MuZ2V0RXZlbnREZXNjcmlwdGlvbjtcbmV4cG9ydHMucGFyc2VTZW12ZXIgPSBtaXNjLnBhcnNlU2VtdmVyO1xuZXhwb3J0cy51dWlkNCA9IG1pc2MudXVpZDQ7XG5leHBvcnRzLmlzTm9kZUVudiA9IG5vZGUuaXNOb2RlRW52O1xuZXhwb3J0cy5sb2FkTW9kdWxlID0gbm9kZS5sb2FkTW9kdWxlO1xuZXhwb3J0cy5ub3JtYWxpemUgPSBub3JtYWxpemUubm9ybWFsaXplO1xuZXhwb3J0cy5ub3JtYWxpemVUb1NpemUgPSBub3JtYWxpemUubm9ybWFsaXplVG9TaXplO1xuZXhwb3J0cy5ub3JtYWxpemVVcmxUb0Jhc2UgPSBub3JtYWxpemUubm9ybWFsaXplVXJsVG9CYXNlO1xuZXhwb3J0cy5hZGROb25FbnVtZXJhYmxlUHJvcGVydHkgPSBvYmplY3QuYWRkTm9uRW51bWVyYWJsZVByb3BlcnR5O1xuZXhwb3J0cy5jb252ZXJ0VG9QbGFpbk9iamVjdCA9IG9iamVjdC5jb252ZXJ0VG9QbGFpbk9iamVjdDtcbmV4cG9ydHMuZHJvcFVuZGVmaW5lZEtleXMgPSBvYmplY3QuZHJvcFVuZGVmaW5lZEtleXM7XG5leHBvcnRzLmV4dHJhY3RFeGNlcHRpb25LZXlzRm9yTWVzc2FnZSA9IG9iamVjdC5leHRyYWN0RXhjZXB0aW9uS2V5c0Zvck1lc3NhZ2U7XG5leHBvcnRzLmZpbGwgPSBvYmplY3QuZmlsbDtcbmV4cG9ydHMuZ2V0T3JpZ2luYWxGdW5jdGlvbiA9IG9iamVjdC5nZXRPcmlnaW5hbEZ1bmN0aW9uO1xuZXhwb3J0cy5tYXJrRnVuY3Rpb25XcmFwcGVkID0gb2JqZWN0Lm1hcmtGdW5jdGlvbldyYXBwZWQ7XG5leHBvcnRzLm9iamVjdGlmeSA9IG9iamVjdC5vYmplY3RpZnk7XG5leHBvcnRzLmJhc2VuYW1lID0gcGF0aC5iYXNlbmFtZTtcbmV4cG9ydHMuZGlybmFtZSA9IHBhdGguZGlybmFtZTtcbmV4cG9ydHMuaXNBYnNvbHV0ZSA9IHBhdGguaXNBYnNvbHV0ZTtcbmV4cG9ydHMuam9pbiA9IHBhdGguam9pbjtcbmV4cG9ydHMubm9ybWFsaXplUGF0aCA9IHBhdGgubm9ybWFsaXplUGF0aDtcbmV4cG9ydHMucmVsYXRpdmUgPSBwYXRoLnJlbGF0aXZlO1xuZXhwb3J0cy5yZXNvbHZlID0gcGF0aC5yZXNvbHZlO1xuZXhwb3J0cy5TRU5UUllfQlVGRkVSX0ZVTExfRVJST1IgPSBwcm9taXNlYnVmZmVyLlNFTlRSWV9CVUZGRVJfRlVMTF9FUlJPUjtcbmV4cG9ydHMubWFrZVByb21pc2VCdWZmZXIgPSBwcm9taXNlYnVmZmVyLm1ha2VQcm9taXNlQnVmZmVyO1xuZXhwb3J0cy5zZXZlcml0eUxldmVsRnJvbVN0cmluZyA9IHNldmVyaXR5LnNldmVyaXR5TGV2ZWxGcm9tU3RyaW5nO1xuZXhwb3J0cy5VTktOT1dOX0ZVTkNUSU9OID0gc3RhY2t0cmFjZS5VTktOT1dOX0ZVTkNUSU9OO1xuZXhwb3J0cy5jcmVhdGVTdGFja1BhcnNlciA9IHN0YWNrdHJhY2UuY3JlYXRlU3RhY2tQYXJzZXI7XG5leHBvcnRzLmdldEZyYW1lc0Zyb21FdmVudCA9IHN0YWNrdHJhY2UuZ2V0RnJhbWVzRnJvbUV2ZW50O1xuZXhwb3J0cy5nZXRGdW5jdGlvbk5hbWUgPSBzdGFja3RyYWNlLmdldEZ1bmN0aW9uTmFtZTtcbmV4cG9ydHMuc3RhY2tQYXJzZXJGcm9tU3RhY2tQYXJzZXJPcHRpb25zID0gc3RhY2t0cmFjZS5zdGFja1BhcnNlckZyb21TdGFja1BhcnNlck9wdGlvbnM7XG5leHBvcnRzLnN0cmlwU2VudHJ5RnJhbWVzQW5kUmV2ZXJzZSA9IHN0YWNrdHJhY2Uuc3RyaXBTZW50cnlGcmFtZXNBbmRSZXZlcnNlO1xuZXhwb3J0cy5maWxlbmFtZUlzSW5BcHAgPSBub2RlU3RhY2tUcmFjZS5maWxlbmFtZUlzSW5BcHA7XG5leHBvcnRzLm5vZGUgPSBub2RlU3RhY2tUcmFjZS5ub2RlO1xuZXhwb3J0cy5ub2RlU3RhY2tMaW5lUGFyc2VyID0gbm9kZVN0YWNrVHJhY2Uubm9kZVN0YWNrTGluZVBhcnNlcjtcbmV4cG9ydHMuaXNNYXRjaGluZ1BhdHRlcm4gPSBzdHJpbmcuaXNNYXRjaGluZ1BhdHRlcm47XG5leHBvcnRzLnNhZmVKb2luID0gc3RyaW5nLnNhZmVKb2luO1xuZXhwb3J0cy5zbmlwTGluZSA9IHN0cmluZy5zbmlwTGluZTtcbmV4cG9ydHMuc3RyaW5nTWF0Y2hlc1NvbWVQYXR0ZXJuID0gc3RyaW5nLnN0cmluZ01hdGNoZXNTb21lUGF0dGVybjtcbmV4cG9ydHMudHJ1bmNhdGUgPSBzdHJpbmcudHJ1bmNhdGU7XG5leHBvcnRzLmlzTmF0aXZlRnVuY3Rpb24gPSBzdXBwb3J0cy5pc05hdGl2ZUZ1bmN0aW9uO1xuZXhwb3J0cy5zdXBwb3J0c0RPTUVycm9yID0gc3VwcG9ydHMuc3VwcG9ydHNET01FcnJvcjtcbmV4cG9ydHMuc3VwcG9ydHNET01FeGNlcHRpb24gPSBzdXBwb3J0cy5zdXBwb3J0c0RPTUV4Y2VwdGlvbjtcbmV4cG9ydHMuc3VwcG9ydHNFcnJvckV2ZW50ID0gc3VwcG9ydHMuc3VwcG9ydHNFcnJvckV2ZW50O1xuZXhwb3J0cy5zdXBwb3J0c0ZldGNoID0gc3VwcG9ydHMuc3VwcG9ydHNGZXRjaDtcbmV4cG9ydHMuc3VwcG9ydHNIaXN0b3J5ID0gc3VwcG9ydHMuc3VwcG9ydHNIaXN0b3J5O1xuZXhwb3J0cy5zdXBwb3J0c05hdGl2ZUZldGNoID0gc3VwcG9ydHMuc3VwcG9ydHNOYXRpdmVGZXRjaDtcbmV4cG9ydHMuc3VwcG9ydHNSZWZlcnJlclBvbGljeSA9IHN1cHBvcnRzLnN1cHBvcnRzUmVmZXJyZXJQb2xpY3k7XG5leHBvcnRzLnN1cHBvcnRzUmVwb3J0aW5nT2JzZXJ2ZXIgPSBzdXBwb3J0cy5zdXBwb3J0c1JlcG9ydGluZ09ic2VydmVyO1xuZXhwb3J0cy5TeW5jUHJvbWlzZSA9IHN5bmNwcm9taXNlLlN5bmNQcm9taXNlO1xuZXhwb3J0cy5yZWplY3RlZFN5bmNQcm9taXNlID0gc3luY3Byb21pc2UucmVqZWN0ZWRTeW5jUHJvbWlzZTtcbmV4cG9ydHMucmVzb2x2ZWRTeW5jUHJvbWlzZSA9IHN5bmNwcm9taXNlLnJlc29sdmVkU3luY1Byb21pc2U7XG5leHBvcnRzLmJyb3dzZXJQZXJmb3JtYW5jZVRpbWVPcmlnaW4gPSB0aW1lLmJyb3dzZXJQZXJmb3JtYW5jZVRpbWVPcmlnaW47XG5leHBvcnRzLmRhdGVUaW1lc3RhbXBJblNlY29uZHMgPSB0aW1lLmRhdGVUaW1lc3RhbXBJblNlY29uZHM7XG5leHBvcnRzLnRpbWVzdGFtcEluU2Vjb25kcyA9IHRpbWUudGltZXN0YW1wSW5TZWNvbmRzO1xuZXhwb3J0cy5UUkFDRVBBUkVOVF9SRUdFWFAgPSB0cmFjaW5nLlRSQUNFUEFSRU5UX1JFR0VYUDtcbmV4cG9ydHMuZXh0cmFjdFRyYWNlcGFyZW50RGF0YSA9IHRyYWNpbmcuZXh0cmFjdFRyYWNlcGFyZW50RGF0YTtcbmV4cG9ydHMuZ2VuZXJhdGVTZW50cnlUcmFjZUhlYWRlciA9IHRyYWNpbmcuZ2VuZXJhdGVTZW50cnlUcmFjZUhlYWRlcjtcbmV4cG9ydHMucHJvcGFnYXRpb25Db250ZXh0RnJvbUhlYWRlcnMgPSB0cmFjaW5nLnByb3BhZ2F0aW9uQ29udGV4dEZyb21IZWFkZXJzO1xuZXhwb3J0cy5nZXRTREtTb3VyY2UgPSBlbnYuZ2V0U0RLU291cmNlO1xuZXhwb3J0cy5pc0Jyb3dzZXJCdW5kbGUgPSBlbnYuaXNCcm93c2VyQnVuZGxlO1xuZXhwb3J0cy5hZGRJdGVtVG9FbnZlbG9wZSA9IGVudmVsb3BlJDEuYWRkSXRlbVRvRW52ZWxvcGU7XG5leHBvcnRzLmNyZWF0ZUF0dGFjaG1lbnRFbnZlbG9wZUl0ZW0gPSBlbnZlbG9wZSQxLmNyZWF0ZUF0dGFjaG1lbnRFbnZlbG9wZUl0ZW07XG5leHBvcnRzLmNyZWF0ZUVudmVsb3BlID0gZW52ZWxvcGUkMS5jcmVhdGVFbnZlbG9wZTtcbmV4cG9ydHMuY3JlYXRlRXZlbnRFbnZlbG9wZUhlYWRlcnMgPSBlbnZlbG9wZSQxLmNyZWF0ZUV2ZW50RW52ZWxvcGVIZWFkZXJzO1xuZXhwb3J0cy5jcmVhdGVTcGFuRW52ZWxvcGVJdGVtID0gZW52ZWxvcGUkMS5jcmVhdGVTcGFuRW52ZWxvcGVJdGVtO1xuZXhwb3J0cy5lbnZlbG9wZUNvbnRhaW5zSXRlbVR5cGUgPSBlbnZlbG9wZSQxLmVudmVsb3BlQ29udGFpbnNJdGVtVHlwZTtcbmV4cG9ydHMuZW52ZWxvcGVJdGVtVHlwZVRvRGF0YUNhdGVnb3J5ID0gZW52ZWxvcGUkMS5lbnZlbG9wZUl0ZW1UeXBlVG9EYXRhQ2F0ZWdvcnk7XG5leHBvcnRzLmZvckVhY2hFbnZlbG9wZUl0ZW0gPSBlbnZlbG9wZSQxLmZvckVhY2hFbnZlbG9wZUl0ZW07XG5leHBvcnRzLmdldFNka01ldGFkYXRhRm9yRW52ZWxvcGVIZWFkZXIgPSBlbnZlbG9wZSQxLmdldFNka01ldGFkYXRhRm9yRW52ZWxvcGVIZWFkZXI7XG5leHBvcnRzLnBhcnNlRW52ZWxvcGUgPSBlbnZlbG9wZSQxLnBhcnNlRW52ZWxvcGU7XG5leHBvcnRzLnNlcmlhbGl6ZUVudmVsb3BlID0gZW52ZWxvcGUkMS5zZXJpYWxpemVFbnZlbG9wZTtcbmV4cG9ydHMuY3JlYXRlQ2xpZW50UmVwb3J0RW52ZWxvcGUgPSBjbGllbnRyZXBvcnQuY3JlYXRlQ2xpZW50UmVwb3J0RW52ZWxvcGU7XG5leHBvcnRzLkRFRkFVTFRfUkVUUllfQUZURVIgPSByYXRlbGltaXQuREVGQVVMVF9SRVRSWV9BRlRFUjtcbmV4cG9ydHMuZGlzYWJsZWRVbnRpbCA9IHJhdGVsaW1pdC5kaXNhYmxlZFVudGlsO1xuZXhwb3J0cy5pc1JhdGVMaW1pdGVkID0gcmF0ZWxpbWl0LmlzUmF0ZUxpbWl0ZWQ7XG5leHBvcnRzLnBhcnNlUmV0cnlBZnRlckhlYWRlciA9IHJhdGVsaW1pdC5wYXJzZVJldHJ5QWZ0ZXJIZWFkZXI7XG5leHBvcnRzLnVwZGF0ZVJhdGVMaW1pdHMgPSByYXRlbGltaXQudXBkYXRlUmF0ZUxpbWl0cztcbmV4cG9ydHMuTUFYX0JBR0dBR0VfU1RSSU5HX0xFTkdUSCA9IGJhZ2dhZ2UuTUFYX0JBR0dBR0VfU1RSSU5HX0xFTkdUSDtcbmV4cG9ydHMuU0VOVFJZX0JBR0dBR0VfS0VZX1BSRUZJWCA9IGJhZ2dhZ2UuU0VOVFJZX0JBR0dBR0VfS0VZX1BSRUZJWDtcbmV4cG9ydHMuU0VOVFJZX0JBR0dBR0VfS0VZX1BSRUZJWF9SRUdFWCA9IGJhZ2dhZ2UuU0VOVFJZX0JBR0dBR0VfS0VZX1BSRUZJWF9SRUdFWDtcbmV4cG9ydHMuYmFnZ2FnZUhlYWRlclRvRHluYW1pY1NhbXBsaW5nQ29udGV4dCA9IGJhZ2dhZ2UuYmFnZ2FnZUhlYWRlclRvRHluYW1pY1NhbXBsaW5nQ29udGV4dDtcbmV4cG9ydHMuZHluYW1pY1NhbXBsaW5nQ29udGV4dFRvU2VudHJ5QmFnZ2FnZUhlYWRlciA9IGJhZ2dhZ2UuZHluYW1pY1NhbXBsaW5nQ29udGV4dFRvU2VudHJ5QmFnZ2FnZUhlYWRlcjtcbmV4cG9ydHMub2JqZWN0VG9CYWdnYWdlSGVhZGVyID0gYmFnZ2FnZS5vYmplY3RUb0JhZ2dhZ2VIZWFkZXI7XG5leHBvcnRzLnBhcnNlQmFnZ2FnZUhlYWRlciA9IGJhZ2dhZ2UucGFyc2VCYWdnYWdlSGVhZGVyO1xuZXhwb3J0cy5nZXRIdHRwU3BhbkRldGFpbHNGcm9tVXJsT2JqZWN0ID0gdXJsLmdldEh0dHBTcGFuRGV0YWlsc0Zyb21VcmxPYmplY3Q7XG5leHBvcnRzLmdldFNhbml0aXplZFVybFN0cmluZyA9IHVybC5nZXRTYW5pdGl6ZWRVcmxTdHJpbmc7XG5leHBvcnRzLmdldFNhbml0aXplZFVybFN0cmluZ0Zyb21VcmxPYmplY3QgPSB1cmwuZ2V0U2FuaXRpemVkVXJsU3RyaW5nRnJvbVVybE9iamVjdDtcbmV4cG9ydHMuaXNVUkxPYmplY3RSZWxhdGl2ZSA9IHVybC5pc1VSTE9iamVjdFJlbGF0aXZlO1xuZXhwb3J0cy5wYXJzZVN0cmluZ1RvVVJMT2JqZWN0ID0gdXJsLnBhcnNlU3RyaW5nVG9VUkxPYmplY3Q7XG5leHBvcnRzLnBhcnNlVXJsID0gdXJsLnBhcnNlVXJsO1xuZXhwb3J0cy5zdHJpcFVybFF1ZXJ5QW5kRnJhZ21lbnQgPSB1cmwuc3RyaXBVcmxRdWVyeUFuZEZyYWdtZW50O1xuZXhwb3J0cy5ldmVudEZyb21NZXNzYWdlID0gZXZlbnRidWlsZGVyLmV2ZW50RnJvbU1lc3NhZ2U7XG5leHBvcnRzLmV2ZW50RnJvbVVua25vd25JbnB1dCA9IGV2ZW50YnVpbGRlci5ldmVudEZyb21Vbmtub3duSW5wdXQ7XG5leHBvcnRzLmV4Y2VwdGlvbkZyb21FcnJvciA9IGV2ZW50YnVpbGRlci5leGNlcHRpb25Gcm9tRXJyb3I7XG5leHBvcnRzLnBhcnNlU3RhY2tGcmFtZXMgPSBldmVudGJ1aWxkZXIucGFyc2VTdGFja0ZyYW1lcztcbmV4cG9ydHMuY2FsbEZyYW1lVG9TdGFja0ZyYW1lID0gYW5yLmNhbGxGcmFtZVRvU3RhY2tGcmFtZTtcbmV4cG9ydHMud2F0Y2hkb2dUaW1lciA9IGFuci53YXRjaGRvZ1RpbWVyO1xuZXhwb3J0cy5MUlVNYXAgPSBscnUuTFJVTWFwO1xuZXhwb3J0cy5nZW5lcmF0ZVNwYW5JZCA9IHByb3BhZ2F0aW9uQ29udGV4dC5nZW5lcmF0ZVNwYW5JZDtcbmV4cG9ydHMuZ2VuZXJhdGVUcmFjZUlkID0gcHJvcGFnYXRpb25Db250ZXh0LmdlbmVyYXRlVHJhY2VJZDtcbmV4cG9ydHMudmVyY2VsV2FpdFVudGlsID0gdmVyY2VsV2FpdFVudGlsLnZlcmNlbFdhaXRVbnRpbDtcbmV4cG9ydHMuZmx1c2hJZlNlcnZlcmxlc3MgPSBmbHVzaElmU2VydmVybGVzcy5mbHVzaElmU2VydmVybGVzcztcbmV4cG9ydHMuU0RLX1ZFUlNJT04gPSB2ZXJzaW9uLlNES19WRVJTSU9OO1xuZXhwb3J0cy5nZXREZWJ1Z0ltYWdlc0ZvclJlc291cmNlcyA9IGRlYnVnSWRzLmdldERlYnVnSW1hZ2VzRm9yUmVzb3VyY2VzO1xuZXhwb3J0cy5nZXRGaWxlbmFtZVRvRGVidWdJZE1hcCA9IGRlYnVnSWRzLmdldEZpbGVuYW1lVG9EZWJ1Z0lkTWFwO1xuZXhwb3J0cy5lc2NhcGVTdHJpbmdGb3JSZWdleCA9IGVzY2FwZVN0cmluZ0ZvclJlZ2V4LmVzY2FwZVN0cmluZ0ZvclJlZ2V4O1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9aW5kZXguanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/index.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/console.js":
/*!**********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/console.js ***!
  \**********************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst debugLogger = __webpack_require__(/*! ../utils/debug-logger.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst object = __webpack_require__(/*! ../utils/object.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/object.js\");\nconst worldwide = __webpack_require__(/*! ../utils/worldwide.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/worldwide.js\");\nconst handlers = __webpack_require__(/*! ./handlers.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/handlers.js\");\n\n/**\n * Add an instrumentation handler for when a console.xxx method is called.\n *\n * Use at your own risk, this might break without changelog notice, only used internally.\n * @hidden\n */\nfunction addConsoleInstrumentationHandler(handler) {\n  const type = 'console';\n  handlers.addHandler(type, handler);\n  handlers.maybeInstrument(type, instrumentConsole);\n}\n\nfunction instrumentConsole() {\n  if (!('console' in worldwide.GLOBAL_OBJ)) {\n    return;\n  }\n\n  debugLogger.CONSOLE_LEVELS.forEach(function (level) {\n    if (!(level in worldwide.GLOBAL_OBJ.console)) {\n      return;\n    }\n\n    object.fill(worldwide.GLOBAL_OBJ.console, level, function (originalConsoleMethod) {\n      debugLogger.originalConsoleMethods[level] = originalConsoleMethod;\n\n      return function (...args) {\n        const handlerData = { args, level };\n        handlers.triggerHandlers('console', handlerData);\n\n        const log = debugLogger.originalConsoleMethods[level];\n        log?.apply(worldwide.GLOBAL_OBJ.console, args);\n      };\n    });\n  });\n}\n\nexports.addConsoleInstrumentationHandler = addConsoleInstrumentationHandler;\n//# sourceMappingURL=console.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnN0cnVtZW50L2NvbnNvbGUuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsb0JBQW9CLG1CQUFPLENBQUMsMElBQTBCO0FBQ3RELGVBQWUsbUJBQU8sQ0FBQyw4SEFBb0I7QUFDM0Msa0JBQWtCLG1CQUFPLENBQUMsb0lBQXVCO0FBQ2pELGlCQUFpQixtQkFBTyxDQUFDLGdJQUFlOztBQUV4QztBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQSw4QkFBOEI7QUFDOUI7O0FBRUE7QUFDQTtBQUNBO0FBQ0EsS0FBSztBQUNMLEdBQUc7QUFDSDs7QUFFQSx3Q0FBd0M7QUFDeEMiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnN0cnVtZW50L2NvbnNvbGUuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGRlYnVnTG9nZ2VyID0gcmVxdWlyZSgnLi4vdXRpbHMvZGVidWctbG9nZ2VyLmpzJyk7XG5jb25zdCBvYmplY3QgPSByZXF1aXJlKCcuLi91dGlscy9vYmplY3QuanMnKTtcbmNvbnN0IHdvcmxkd2lkZSA9IHJlcXVpcmUoJy4uL3V0aWxzL3dvcmxkd2lkZS5qcycpO1xuY29uc3QgaGFuZGxlcnMgPSByZXF1aXJlKCcuL2hhbmRsZXJzLmpzJyk7XG5cbi8qKlxuICogQWRkIGFuIGluc3RydW1lbnRhdGlvbiBoYW5kbGVyIGZvciB3aGVuIGEgY29uc29sZS54eHggbWV0aG9kIGlzIGNhbGxlZC5cbiAqXG4gKiBVc2UgYXQgeW91ciBvd24gcmlzaywgdGhpcyBtaWdodCBicmVhayB3aXRob3V0IGNoYW5nZWxvZyBub3RpY2UsIG9ubHkgdXNlZCBpbnRlcm5hbGx5LlxuICogQGhpZGRlblxuICovXG5mdW5jdGlvbiBhZGRDb25zb2xlSW5zdHJ1bWVudGF0aW9uSGFuZGxlcihoYW5kbGVyKSB7XG4gIGNvbnN0IHR5cGUgPSAnY29uc29sZSc7XG4gIGhhbmRsZXJzLmFkZEhhbmRsZXIodHlwZSwgaGFuZGxlcik7XG4gIGhhbmRsZXJzLm1heWJlSW5zdHJ1bWVudCh0eXBlLCBpbnN0cnVtZW50Q29uc29sZSk7XG59XG5cbmZ1bmN0aW9uIGluc3RydW1lbnRDb25zb2xlKCkge1xuICBpZiAoISgnY29uc29sZScgaW4gd29ybGR3aWRlLkdMT0JBTF9PQkopKSB7XG4gICAgcmV0dXJuO1xuICB9XG5cbiAgZGVidWdMb2dnZXIuQ09OU09MRV9MRVZFTFMuZm9yRWFjaChmdW5jdGlvbiAobGV2ZWwpIHtcbiAgICBpZiAoIShsZXZlbCBpbiB3b3JsZHdpZGUuR0xPQkFMX09CSi5jb25zb2xlKSkge1xuICAgICAgcmV0dXJuO1xuICAgIH1cblxuICAgIG9iamVjdC5maWxsKHdvcmxkd2lkZS5HTE9CQUxfT0JKLmNvbnNvbGUsIGxldmVsLCBmdW5jdGlvbiAob3JpZ2luYWxDb25zb2xlTWV0aG9kKSB7XG4gICAgICBkZWJ1Z0xvZ2dlci5vcmlnaW5hbENvbnNvbGVNZXRob2RzW2xldmVsXSA9IG9yaWdpbmFsQ29uc29sZU1ldGhvZDtcblxuICAgICAgcmV0dXJuIGZ1bmN0aW9uICguLi5hcmdzKSB7XG4gICAgICAgIGNvbnN0IGhhbmRsZXJEYXRhID0geyBhcmdzLCBsZXZlbCB9O1xuICAgICAgICBoYW5kbGVycy50cmlnZ2VySGFuZGxlcnMoJ2NvbnNvbGUnLCBoYW5kbGVyRGF0YSk7XG5cbiAgICAgICAgY29uc3QgbG9nID0gZGVidWdMb2dnZXIub3JpZ2luYWxDb25zb2xlTWV0aG9kc1tsZXZlbF07XG4gICAgICAgIGxvZz8uYXBwbHkod29ybGR3aWRlLkdMT0JBTF9PQkouY29uc29sZSwgYXJncyk7XG4gICAgICB9O1xuICAgIH0pO1xuICB9KTtcbn1cblxuZXhwb3J0cy5hZGRDb25zb2xlSW5zdHJ1bWVudGF0aW9uSGFuZGxlciA9IGFkZENvbnNvbGVJbnN0cnVtZW50YXRpb25IYW5kbGVyO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9Y29uc29sZS5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/console.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/fetch.js":
/*!********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/fetch.js ***!
  \********************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst is = __webpack_require__(/*! ../utils/is.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js\");\nconst object = __webpack_require__(/*! ../utils/object.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/object.js\");\nconst supports = __webpack_require__(/*! ../utils/supports.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/supports.js\");\nconst time = __webpack_require__(/*! ../utils/time.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/time.js\");\nconst worldwide = __webpack_require__(/*! ../utils/worldwide.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/worldwide.js\");\nconst handlers = __webpack_require__(/*! ./handlers.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/handlers.js\");\n\n/**\n * Add an instrumentation handler for when a fetch request happens.\n * The handler function is called once when the request starts and once when it ends,\n * which can be identified by checking if it has an `endTimestamp`.\n *\n * Use at your own risk, this might break without changelog notice, only used internally.\n * @hidden\n */\nfunction addFetchInstrumentationHandler(\n  handler,\n  skipNativeFetchCheck,\n) {\n  const type = 'fetch';\n  handlers.addHandler(type, handler);\n  handlers.maybeInstrument(type, () => instrumentFetch(undefined, skipNativeFetchCheck));\n}\n\n/**\n * Add an instrumentation handler for long-lived fetch requests, like consuming server-sent events (SSE) via fetch.\n * The handler will resolve the request body and emit the actual `endTimestamp`, so that the\n * span can be updated accordingly.\n *\n * Only used internally\n * @hidden\n */\nfunction addFetchEndInstrumentationHandler(handler) {\n  const type = 'fetch-body-resolved';\n  handlers.addHandler(type, handler);\n  handlers.maybeInstrument(type, () => instrumentFetch(streamHandler));\n}\n\nfunction instrumentFetch(onFetchResolved, skipNativeFetchCheck = false) {\n  if (skipNativeFetchCheck && !supports.supportsNativeFetch()) {\n    return;\n  }\n\n  object.fill(worldwide.GLOBAL_OBJ, 'fetch', function (originalFetch) {\n    return function (...args) {\n      // We capture the error right here and not in the Promise error callback because Safari (and probably other\n      // browsers too) will wipe the stack trace up to this point, only leaving us with this file which is useless.\n\n      // NOTE: If you are a Sentry user, and you are seeing this stack frame,\n      //       it means the error, that was caused by your fetch call did not\n      //       have a stack trace, so the SDK backfilled the stack trace so\n      //       you can see which fetch call failed.\n      const virtualError = new Error();\n\n      const { method, url } = parseFetchArgs(args);\n      const handlerData = {\n        args,\n        fetchData: {\n          method,\n          url,\n        },\n        startTimestamp: time.timestampInSeconds() * 1000,\n        // // Adding the error to be able to fingerprint the failed fetch event in HttpClient instrumentation\n        virtualError,\n        headers: getHeadersFromFetchArgs(args),\n      };\n\n      // if there is no callback, fetch is instrumented directly\n      if (!onFetchResolved) {\n        handlers.triggerHandlers('fetch', {\n          ...handlerData,\n        });\n      }\n\n      // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n      return originalFetch.apply(worldwide.GLOBAL_OBJ, args).then(\n        async (response) => {\n          if (onFetchResolved) {\n            onFetchResolved(response);\n          } else {\n            handlers.triggerHandlers('fetch', {\n              ...handlerData,\n              endTimestamp: time.timestampInSeconds() * 1000,\n              response,\n            });\n          }\n\n          return response;\n        },\n        (error) => {\n          handlers.triggerHandlers('fetch', {\n            ...handlerData,\n            endTimestamp: time.timestampInSeconds() * 1000,\n            error,\n          });\n\n          if (is.isError(error) && error.stack === undefined) {\n            // NOTE: If you are a Sentry user, and you are seeing this stack frame,\n            //       it means the error, that was caused by your fetch call did not\n            //       have a stack trace, so the SDK backfilled the stack trace so\n            //       you can see which fetch call failed.\n            error.stack = virtualError.stack;\n            object.addNonEnumerableProperty(error, 'framesToPop', 1);\n          }\n\n          // We enhance the not-so-helpful \"Failed to fetch\" error messages with the host\n          // Possible messages we handle here:\n          // * \"Failed to fetch\" (chromium)\n          // * \"Load failed\" (webkit)\n          // * \"NetworkError when attempting to fetch resource.\" (firefox)\n          if (\n            error instanceof TypeError &&\n            (error.message === 'Failed to fetch' ||\n              error.message === 'Load failed' ||\n              error.message === 'NetworkError when attempting to fetch resource.')\n          ) {\n            try {\n              const url = new URL(handlerData.fetchData.url);\n              error.message = `${error.message} (${url.host})`;\n            } catch {\n              // ignore it if errors happen here\n            }\n          }\n\n          // NOTE: If you are a Sentry user, and you are seeing this stack frame,\n          //       it means the sentry.javascript SDK caught an error invoking your application code.\n          //       This is expected behavior and NOT indicative of a bug with sentry.javascript.\n          throw error;\n        },\n      );\n    };\n  });\n}\n\nasync function resolveResponse(res, onFinishedResolving) {\n  if (res?.body) {\n    const body = res.body;\n    const responseReader = body.getReader();\n\n    // Define a maximum duration after which we just cancel\n    const maxFetchDurationTimeout = setTimeout(\n      () => {\n        body.cancel().then(null, () => {\n          // noop\n        });\n      },\n      90 * 1000, // 90s\n    );\n\n    let readingActive = true;\n    while (readingActive) {\n      let chunkTimeout;\n      try {\n        // abort reading if read op takes more than 5s\n        chunkTimeout = setTimeout(() => {\n          body.cancel().then(null, () => {\n            // noop on error\n          });\n        }, 5000);\n\n        // This .read() call will reject/throw when we abort due to timeouts through `body.cancel()`\n        const { done } = await responseReader.read();\n\n        clearTimeout(chunkTimeout);\n\n        if (done) {\n          onFinishedResolving();\n          readingActive = false;\n        }\n      } catch {\n        readingActive = false;\n      } finally {\n        clearTimeout(chunkTimeout);\n      }\n    }\n\n    clearTimeout(maxFetchDurationTimeout);\n\n    responseReader.releaseLock();\n    body.cancel().then(null, () => {\n      // noop on error\n    });\n  }\n}\n\nfunction streamHandler(response) {\n  // clone response for awaiting stream\n  let clonedResponseForResolving;\n  try {\n    clonedResponseForResolving = response.clone();\n  } catch {\n    return;\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-floating-promises\n  resolveResponse(clonedResponseForResolving, () => {\n    handlers.triggerHandlers('fetch-body-resolved', {\n      endTimestamp: time.timestampInSeconds() * 1000,\n      response,\n    });\n  });\n}\n\nfunction hasProp(obj, prop) {\n  return !!obj && typeof obj === 'object' && !!(obj )[prop];\n}\n\nfunction getUrlFromResource(resource) {\n  if (typeof resource === 'string') {\n    return resource;\n  }\n\n  if (!resource) {\n    return '';\n  }\n\n  if (hasProp(resource, 'url')) {\n    return resource.url;\n  }\n\n  if (resource.toString) {\n    return resource.toString();\n  }\n\n  return '';\n}\n\n/**\n * Parses the fetch arguments to find the used Http method and the url of the request.\n * Exported for tests only.\n */\nfunction parseFetchArgs(fetchArgs) {\n  if (fetchArgs.length === 0) {\n    return { method: 'GET', url: '' };\n  }\n\n  if (fetchArgs.length === 2) {\n    const [url, options] = fetchArgs ;\n\n    return {\n      url: getUrlFromResource(url),\n      method: hasProp(options, 'method') ? String(options.method).toUpperCase() : 'GET',\n    };\n  }\n\n  const arg = fetchArgs[0];\n  return {\n    url: getUrlFromResource(arg ),\n    method: hasProp(arg, 'method') ? String(arg.method).toUpperCase() : 'GET',\n  };\n}\n\nfunction getHeadersFromFetchArgs(fetchArgs) {\n  const [requestArgument, optionsArgument] = fetchArgs;\n\n  try {\n    if (\n      typeof optionsArgument === 'object' &&\n      optionsArgument !== null &&\n      'headers' in optionsArgument &&\n      optionsArgument.headers\n    ) {\n      return new Headers(optionsArgument.headers );\n    }\n\n    if (is.isRequest(requestArgument)) {\n      return new Headers(requestArgument.headers);\n    }\n  } catch {\n    // noop\n  }\n\n  return;\n}\n\nexports.addFetchEndInstrumentationHandler = addFetchEndInstrumentationHandler;\nexports.addFetchInstrumentationHandler = addFetchInstrumentationHandler;\nexports.parseFetchArgs = parseFetchArgs;\n//# sourceMappingURL=fetch.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnN0cnVtZW50L2ZldGNoLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLFdBQVcsbUJBQU8sQ0FBQyxzSEFBZ0I7QUFDbkMsZUFBZSxtQkFBTyxDQUFDLDhIQUFvQjtBQUMzQyxpQkFBaUIsbUJBQU8sQ0FBQyxrSUFBc0I7QUFDL0MsYUFBYSxtQkFBTyxDQUFDLDBIQUFrQjtBQUN2QyxrQkFBa0IsbUJBQU8sQ0FBQyxvSUFBdUI7QUFDakQsaUJBQWlCLG1CQUFPLENBQUMsZ0lBQWU7O0FBRXhDO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsY0FBYyxjQUFjO0FBQzVCO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxTQUFTO0FBQ1Q7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFNBQVM7QUFDVDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsWUFBWTtBQUNaO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsYUFBYTtBQUNiOztBQUVBO0FBQ0EsU0FBUztBQUNUO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxXQUFXOztBQUVYO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxpQ0FBaUMsZUFBZSxHQUFHLFNBQVM7QUFDNUQsY0FBYztBQUNkO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFNBQVM7QUFDVDtBQUNBO0FBQ0EsR0FBRztBQUNIOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxTQUFTO0FBQ1QsT0FBTztBQUNQO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFdBQVc7QUFDWCxTQUFTOztBQUVUO0FBQ0EsZ0JBQWdCLE9BQU87O0FBRXZCOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsUUFBUTtBQUNSO0FBQ0EsUUFBUTtBQUNSO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQSxLQUFLO0FBQ0w7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsSUFBSTtBQUNKO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEtBQUs7QUFDTCxHQUFHO0FBQ0g7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsYUFBYTtBQUNiOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0EsSUFBSTtBQUNKO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQSx5Q0FBeUM7QUFDekMsc0NBQXNDO0FBQ3RDLHNCQUFzQjtBQUN0QiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL2luc3RydW1lbnQvZmV0Y2guanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGlzID0gcmVxdWlyZSgnLi4vdXRpbHMvaXMuanMnKTtcbmNvbnN0IG9iamVjdCA9IHJlcXVpcmUoJy4uL3V0aWxzL29iamVjdC5qcycpO1xuY29uc3Qgc3VwcG9ydHMgPSByZXF1aXJlKCcuLi91dGlscy9zdXBwb3J0cy5qcycpO1xuY29uc3QgdGltZSA9IHJlcXVpcmUoJy4uL3V0aWxzL3RpbWUuanMnKTtcbmNvbnN0IHdvcmxkd2lkZSA9IHJlcXVpcmUoJy4uL3V0aWxzL3dvcmxkd2lkZS5qcycpO1xuY29uc3QgaGFuZGxlcnMgPSByZXF1aXJlKCcuL2hhbmRsZXJzLmpzJyk7XG5cbi8qKlxuICogQWRkIGFuIGluc3RydW1lbnRhdGlvbiBoYW5kbGVyIGZvciB3aGVuIGEgZmV0Y2ggcmVxdWVzdCBoYXBwZW5zLlxuICogVGhlIGhhbmRsZXIgZnVuY3Rpb24gaXMgY2FsbGVkIG9uY2Ugd2hlbiB0aGUgcmVxdWVzdCBzdGFydHMgYW5kIG9uY2Ugd2hlbiBpdCBlbmRzLFxuICogd2hpY2ggY2FuIGJlIGlkZW50aWZpZWQgYnkgY2hlY2tpbmcgaWYgaXQgaGFzIGFuIGBlbmRUaW1lc3RhbXBgLlxuICpcbiAqIFVzZSBhdCB5b3VyIG93biByaXNrLCB0aGlzIG1pZ2h0IGJyZWFrIHdpdGhvdXQgY2hhbmdlbG9nIG5vdGljZSwgb25seSB1c2VkIGludGVybmFsbHkuXG4gKiBAaGlkZGVuXG4gKi9cbmZ1bmN0aW9uIGFkZEZldGNoSW5zdHJ1bWVudGF0aW9uSGFuZGxlcihcbiAgaGFuZGxlcixcbiAgc2tpcE5hdGl2ZUZldGNoQ2hlY2ssXG4pIHtcbiAgY29uc3QgdHlwZSA9ICdmZXRjaCc7XG4gIGhhbmRsZXJzLmFkZEhhbmRsZXIodHlwZSwgaGFuZGxlcik7XG4gIGhhbmRsZXJzLm1heWJlSW5zdHJ1bWVudCh0eXBlLCAoKSA9PiBpbnN0cnVtZW50RmV0Y2godW5kZWZpbmVkLCBza2lwTmF0aXZlRmV0Y2hDaGVjaykpO1xufVxuXG4vKipcbiAqIEFkZCBhbiBpbnN0cnVtZW50YXRpb24gaGFuZGxlciBmb3IgbG9uZy1saXZlZCBmZXRjaCByZXF1ZXN0cywgbGlrZSBjb25zdW1pbmcgc2VydmVyLXNlbnQgZXZlbnRzIChTU0UpIHZpYSBmZXRjaC5cbiAqIFRoZSBoYW5kbGVyIHdpbGwgcmVzb2x2ZSB0aGUgcmVxdWVzdCBib2R5IGFuZCBlbWl0IHRoZSBhY3R1YWwgYGVuZFRpbWVzdGFtcGAsIHNvIHRoYXQgdGhlXG4gKiBzcGFuIGNhbiBiZSB1cGRhdGVkIGFjY29yZGluZ2x5LlxuICpcbiAqIE9ubHkgdXNlZCBpbnRlcm5hbGx5XG4gKiBAaGlkZGVuXG4gKi9cbmZ1bmN0aW9uIGFkZEZldGNoRW5kSW5zdHJ1bWVudGF0aW9uSGFuZGxlcihoYW5kbGVyKSB7XG4gIGNvbnN0IHR5cGUgPSAnZmV0Y2gtYm9keS1yZXNvbHZlZCc7XG4gIGhhbmRsZXJzLmFkZEhhbmRsZXIodHlwZSwgaGFuZGxlcik7XG4gIGhhbmRsZXJzLm1heWJlSW5zdHJ1bWVudCh0eXBlLCAoKSA9PiBpbnN0cnVtZW50RmV0Y2goc3RyZWFtSGFuZGxlcikpO1xufVxuXG5mdW5jdGlvbiBpbnN0cnVtZW50RmV0Y2gob25GZXRjaFJlc29sdmVkLCBza2lwTmF0aXZlRmV0Y2hDaGVjayA9IGZhbHNlKSB7XG4gIGlmIChza2lwTmF0aXZlRmV0Y2hDaGVjayAmJiAhc3VwcG9ydHMuc3VwcG9ydHNOYXRpdmVGZXRjaCgpKSB7XG4gICAgcmV0dXJuO1xuICB9XG5cbiAgb2JqZWN0LmZpbGwod29ybGR3aWRlLkdMT0JBTF9PQkosICdmZXRjaCcsIGZ1bmN0aW9uIChvcmlnaW5hbEZldGNoKSB7XG4gICAgcmV0dXJuIGZ1bmN0aW9uICguLi5hcmdzKSB7XG4gICAgICAvLyBXZSBjYXB0dXJlIHRoZSBlcnJvciByaWdodCBoZXJlIGFuZCBub3QgaW4gdGhlIFByb21pc2UgZXJyb3IgY2FsbGJhY2sgYmVjYXVzZSBTYWZhcmkgKGFuZCBwcm9iYWJseSBvdGhlclxuICAgICAgLy8gYnJvd3NlcnMgdG9vKSB3aWxsIHdpcGUgdGhlIHN0YWNrIHRyYWNlIHVwIHRvIHRoaXMgcG9pbnQsIG9ubHkgbGVhdmluZyB1cyB3aXRoIHRoaXMgZmlsZSB3aGljaCBpcyB1c2VsZXNzLlxuXG4gICAgICAvLyBOT1RFOiBJZiB5b3UgYXJlIGEgU2VudHJ5IHVzZXIsIGFuZCB5b3UgYXJlIHNlZWluZyB0aGlzIHN0YWNrIGZyYW1lLFxuICAgICAgLy8gICAgICAgaXQgbWVhbnMgdGhlIGVycm9yLCB0aGF0IHdhcyBjYXVzZWQgYnkgeW91ciBmZXRjaCBjYWxsIGRpZCBub3RcbiAgICAgIC8vICAgICAgIGhhdmUgYSBzdGFjayB0cmFjZSwgc28gdGhlIFNESyBiYWNrZmlsbGVkIHRoZSBzdGFjayB0cmFjZSBzb1xuICAgICAgLy8gICAgICAgeW91IGNhbiBzZWUgd2hpY2ggZmV0Y2ggY2FsbCBmYWlsZWQuXG4gICAgICBjb25zdCB2aXJ0dWFsRXJyb3IgPSBuZXcgRXJyb3IoKTtcblxuICAgICAgY29uc3QgeyBtZXRob2QsIHVybCB9ID0gcGFyc2VGZXRjaEFyZ3MoYXJncyk7XG4gICAgICBjb25zdCBoYW5kbGVyRGF0YSA9IHtcbiAgICAgICAgYXJncyxcbiAgICAgICAgZmV0Y2hEYXRhOiB7XG4gICAgICAgICAgbWV0aG9kLFxuICAgICAgICAgIHVybCxcbiAgICAgICAgfSxcbiAgICAgICAgc3RhcnRUaW1lc3RhbXA6IHRpbWUudGltZXN0YW1wSW5TZWNvbmRzKCkgKiAxMDAwLFxuICAgICAgICAvLyAvLyBBZGRpbmcgdGhlIGVycm9yIHRvIGJlIGFibGUgdG8gZmluZ2VycHJpbnQgdGhlIGZhaWxlZCBmZXRjaCBldmVudCBpbiBIdHRwQ2xpZW50IGluc3RydW1lbnRhdGlvblxuICAgICAgICB2aXJ0dWFsRXJyb3IsXG4gICAgICAgIGhlYWRlcnM6IGdldEhlYWRlcnNGcm9tRmV0Y2hBcmdzKGFyZ3MpLFxuICAgICAgfTtcblxuICAgICAgLy8gaWYgdGhlcmUgaXMgbm8gY2FsbGJhY2ssIGZldGNoIGlzIGluc3RydW1lbnRlZCBkaXJlY3RseVxuICAgICAgaWYgKCFvbkZldGNoUmVzb2x2ZWQpIHtcbiAgICAgICAgaGFuZGxlcnMudHJpZ2dlckhhbmRsZXJzKCdmZXRjaCcsIHtcbiAgICAgICAgICAuLi5oYW5kbGVyRGF0YSxcbiAgICAgICAgfSk7XG4gICAgICB9XG5cbiAgICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tdW5zYWZlLW1lbWJlci1hY2Nlc3NcbiAgICAgIHJldHVybiBvcmlnaW5hbEZldGNoLmFwcGx5KHdvcmxkd2lkZS5HTE9CQUxfT0JKLCBhcmdzKS50aGVuKFxuICAgICAgICBhc3luYyAocmVzcG9uc2UpID0+IHtcbiAgICAgICAgICBpZiAob25GZXRjaFJlc29sdmVkKSB7XG4gICAgICAgICAgICBvbkZldGNoUmVzb2x2ZWQocmVzcG9uc2UpO1xuICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICBoYW5kbGVycy50cmlnZ2VySGFuZGxlcnMoJ2ZldGNoJywge1xuICAgICAgICAgICAgICAuLi5oYW5kbGVyRGF0YSxcbiAgICAgICAgICAgICAgZW5kVGltZXN0YW1wOiB0aW1lLnRpbWVzdGFtcEluU2Vjb25kcygpICogMTAwMCxcbiAgICAgICAgICAgICAgcmVzcG9uc2UsXG4gICAgICAgICAgICB9KTtcbiAgICAgICAgICB9XG5cbiAgICAgICAgICByZXR1cm4gcmVzcG9uc2U7XG4gICAgICAgIH0sXG4gICAgICAgIChlcnJvcikgPT4ge1xuICAgICAgICAgIGhhbmRsZXJzLnRyaWdnZXJIYW5kbGVycygnZmV0Y2gnLCB7XG4gICAgICAgICAgICAuLi5oYW5kbGVyRGF0YSxcbiAgICAgICAgICAgIGVuZFRpbWVzdGFtcDogdGltZS50aW1lc3RhbXBJblNlY29uZHMoKSAqIDEwMDAsXG4gICAgICAgICAgICBlcnJvcixcbiAgICAgICAgICB9KTtcblxuICAgICAgICAgIGlmIChpcy5pc0Vycm9yKGVycm9yKSAmJiBlcnJvci5zdGFjayA9PT0gdW5kZWZpbmVkKSB7XG4gICAgICAgICAgICAvLyBOT1RFOiBJZiB5b3UgYXJlIGEgU2VudHJ5IHVzZXIsIGFuZCB5b3UgYXJlIHNlZWluZyB0aGlzIHN0YWNrIGZyYW1lLFxuICAgICAgICAgICAgLy8gICAgICAgaXQgbWVhbnMgdGhlIGVycm9yLCB0aGF0IHdhcyBjYXVzZWQgYnkgeW91ciBmZXRjaCBjYWxsIGRpZCBub3RcbiAgICAgICAgICAgIC8vICAgICAgIGhhdmUgYSBzdGFjayB0cmFjZSwgc28gdGhlIFNESyBiYWNrZmlsbGVkIHRoZSBzdGFjayB0cmFjZSBzb1xuICAgICAgICAgICAgLy8gICAgICAgeW91IGNhbiBzZWUgd2hpY2ggZmV0Y2ggY2FsbCBmYWlsZWQuXG4gICAgICAgICAgICBlcnJvci5zdGFjayA9IHZpcnR1YWxFcnJvci5zdGFjaztcbiAgICAgICAgICAgIG9iamVjdC5hZGROb25FbnVtZXJhYmxlUHJvcGVydHkoZXJyb3IsICdmcmFtZXNUb1BvcCcsIDEpO1xuICAgICAgICAgIH1cblxuICAgICAgICAgIC8vIFdlIGVuaGFuY2UgdGhlIG5vdC1zby1oZWxwZnVsIFwiRmFpbGVkIHRvIGZldGNoXCIgZXJyb3IgbWVzc2FnZXMgd2l0aCB0aGUgaG9zdFxuICAgICAgICAgIC8vIFBvc3NpYmxlIG1lc3NhZ2VzIHdlIGhhbmRsZSBoZXJlOlxuICAgICAgICAgIC8vICogXCJGYWlsZWQgdG8gZmV0Y2hcIiAoY2hyb21pdW0pXG4gICAgICAgICAgLy8gKiBcIkxvYWQgZmFpbGVkXCIgKHdlYmtpdClcbiAgICAgICAgICAvLyAqIFwiTmV0d29ya0Vycm9yIHdoZW4gYXR0ZW1wdGluZyB0byBmZXRjaCByZXNvdXJjZS5cIiAoZmlyZWZveClcbiAgICAgICAgICBpZiAoXG4gICAgICAgICAgICBlcnJvciBpbnN0YW5jZW9mIFR5cGVFcnJvciAmJlxuICAgICAgICAgICAgKGVycm9yLm1lc3NhZ2UgPT09ICdGYWlsZWQgdG8gZmV0Y2gnIHx8XG4gICAgICAgICAgICAgIGVycm9yLm1lc3NhZ2UgPT09ICdMb2FkIGZhaWxlZCcgfHxcbiAgICAgICAgICAgICAgZXJyb3IubWVzc2FnZSA9PT0gJ05ldHdvcmtFcnJvciB3aGVuIGF0dGVtcHRpbmcgdG8gZmV0Y2ggcmVzb3VyY2UuJylcbiAgICAgICAgICApIHtcbiAgICAgICAgICAgIHRyeSB7XG4gICAgICAgICAgICAgIGNvbnN0IHVybCA9IG5ldyBVUkwoaGFuZGxlckRhdGEuZmV0Y2hEYXRhLnVybCk7XG4gICAgICAgICAgICAgIGVycm9yLm1lc3NhZ2UgPSBgJHtlcnJvci5tZXNzYWdlfSAoJHt1cmwuaG9zdH0pYDtcbiAgICAgICAgICAgIH0gY2F0Y2gge1xuICAgICAgICAgICAgICAvLyBpZ25vcmUgaXQgaWYgZXJyb3JzIGhhcHBlbiBoZXJlXG4gICAgICAgICAgICB9XG4gICAgICAgICAgfVxuXG4gICAgICAgICAgLy8gTk9URTogSWYgeW91IGFyZSBhIFNlbnRyeSB1c2VyLCBhbmQgeW91IGFyZSBzZWVpbmcgdGhpcyBzdGFjayBmcmFtZSxcbiAgICAgICAgICAvLyAgICAgICBpdCBtZWFucyB0aGUgc2VudHJ5LmphdmFzY3JpcHQgU0RLIGNhdWdodCBhbiBlcnJvciBpbnZva2luZyB5b3VyIGFwcGxpY2F0aW9uIGNvZGUuXG4gICAgICAgICAgLy8gICAgICAgVGhpcyBpcyBleHBlY3RlZCBiZWhhdmlvciBhbmQgTk9UIGluZGljYXRpdmUgb2YgYSBidWcgd2l0aCBzZW50cnkuamF2YXNjcmlwdC5cbiAgICAgICAgICB0aHJvdyBlcnJvcjtcbiAgICAgICAgfSxcbiAgICAgICk7XG4gICAgfTtcbiAgfSk7XG59XG5cbmFzeW5jIGZ1bmN0aW9uIHJlc29sdmVSZXNwb25zZShyZXMsIG9uRmluaXNoZWRSZXNvbHZpbmcpIHtcbiAgaWYgKHJlcz8uYm9keSkge1xuICAgIGNvbnN0IGJvZHkgPSByZXMuYm9keTtcbiAgICBjb25zdCByZXNwb25zZVJlYWRlciA9IGJvZHkuZ2V0UmVhZGVyKCk7XG5cbiAgICAvLyBEZWZpbmUgYSBtYXhpbXVtIGR1cmF0aW9uIGFmdGVyIHdoaWNoIHdlIGp1c3QgY2FuY2VsXG4gICAgY29uc3QgbWF4RmV0Y2hEdXJhdGlvblRpbWVvdXQgPSBzZXRUaW1lb3V0KFxuICAgICAgKCkgPT4ge1xuICAgICAgICBib2R5LmNhbmNlbCgpLnRoZW4obnVsbCwgKCkgPT4ge1xuICAgICAgICAgIC8vIG5vb3BcbiAgICAgICAgfSk7XG4gICAgICB9LFxuICAgICAgOTAgKiAxMDAwLCAvLyA5MHNcbiAgICApO1xuXG4gICAgbGV0IHJlYWRpbmdBY3RpdmUgPSB0cnVlO1xuICAgIHdoaWxlIChyZWFkaW5nQWN0aXZlKSB7XG4gICAgICBsZXQgY2h1bmtUaW1lb3V0O1xuICAgICAgdHJ5IHtcbiAgICAgICAgLy8gYWJvcnQgcmVhZGluZyBpZiByZWFkIG9wIHRha2VzIG1vcmUgdGhhbiA1c1xuICAgICAgICBjaHVua1RpbWVvdXQgPSBzZXRUaW1lb3V0KCgpID0+IHtcbiAgICAgICAgICBib2R5LmNhbmNlbCgpLnRoZW4obnVsbCwgKCkgPT4ge1xuICAgICAgICAgICAgLy8gbm9vcCBvbiBlcnJvclxuICAgICAgICAgIH0pO1xuICAgICAgICB9LCA1MDAwKTtcblxuICAgICAgICAvLyBUaGlzIC5yZWFkKCkgY2FsbCB3aWxsIHJlamVjdC90aHJvdyB3aGVuIHdlIGFib3J0IGR1ZSB0byB0aW1lb3V0cyB0aHJvdWdoIGBib2R5LmNhbmNlbCgpYFxuICAgICAgICBjb25zdCB7IGRvbmUgfSA9IGF3YWl0IHJlc3BvbnNlUmVhZGVyLnJlYWQoKTtcblxuICAgICAgICBjbGVhclRpbWVvdXQoY2h1bmtUaW1lb3V0KTtcblxuICAgICAgICBpZiAoZG9uZSkge1xuICAgICAgICAgIG9uRmluaXNoZWRSZXNvbHZpbmcoKTtcbiAgICAgICAgICByZWFkaW5nQWN0aXZlID0gZmFsc2U7XG4gICAgICAgIH1cbiAgICAgIH0gY2F0Y2gge1xuICAgICAgICByZWFkaW5nQWN0aXZlID0gZmFsc2U7XG4gICAgICB9IGZpbmFsbHkge1xuICAgICAgICBjbGVhclRpbWVvdXQoY2h1bmtUaW1lb3V0KTtcbiAgICAgIH1cbiAgICB9XG5cbiAgICBjbGVhclRpbWVvdXQobWF4RmV0Y2hEdXJhdGlvblRpbWVvdXQpO1xuXG4gICAgcmVzcG9uc2VSZWFkZXIucmVsZWFzZUxvY2soKTtcbiAgICBib2R5LmNhbmNlbCgpLnRoZW4obnVsbCwgKCkgPT4ge1xuICAgICAgLy8gbm9vcCBvbiBlcnJvclxuICAgIH0pO1xuICB9XG59XG5cbmZ1bmN0aW9uIHN0cmVhbUhhbmRsZXIocmVzcG9uc2UpIHtcbiAgLy8gY2xvbmUgcmVzcG9uc2UgZm9yIGF3YWl0aW5nIHN0cmVhbVxuICBsZXQgY2xvbmVkUmVzcG9uc2VGb3JSZXNvbHZpbmc7XG4gIHRyeSB7XG4gICAgY2xvbmVkUmVzcG9uc2VGb3JSZXNvbHZpbmcgPSByZXNwb25zZS5jbG9uZSgpO1xuICB9IGNhdGNoIHtcbiAgICByZXR1cm47XG4gIH1cblxuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25vLWZsb2F0aW5nLXByb21pc2VzXG4gIHJlc29sdmVSZXNwb25zZShjbG9uZWRSZXNwb25zZUZvclJlc29sdmluZywgKCkgPT4ge1xuICAgIGhhbmRsZXJzLnRyaWdnZXJIYW5kbGVycygnZmV0Y2gtYm9keS1yZXNvbHZlZCcsIHtcbiAgICAgIGVuZFRpbWVzdGFtcDogdGltZS50aW1lc3RhbXBJblNlY29uZHMoKSAqIDEwMDAsXG4gICAgICByZXNwb25zZSxcbiAgICB9KTtcbiAgfSk7XG59XG5cbmZ1bmN0aW9uIGhhc1Byb3Aob2JqLCBwcm9wKSB7XG4gIHJldHVybiAhIW9iaiAmJiB0eXBlb2Ygb2JqID09PSAnb2JqZWN0JyAmJiAhIShvYmogKVtwcm9wXTtcbn1cblxuZnVuY3Rpb24gZ2V0VXJsRnJvbVJlc291cmNlKHJlc291cmNlKSB7XG4gIGlmICh0eXBlb2YgcmVzb3VyY2UgPT09ICdzdHJpbmcnKSB7XG4gICAgcmV0dXJuIHJlc291cmNlO1xuICB9XG5cbiAgaWYgKCFyZXNvdXJjZSkge1xuICAgIHJldHVybiAnJztcbiAgfVxuXG4gIGlmIChoYXNQcm9wKHJlc291cmNlLCAndXJsJykpIHtcbiAgICByZXR1cm4gcmVzb3VyY2UudXJsO1xuICB9XG5cbiAgaWYgKHJlc291cmNlLnRvU3RyaW5nKSB7XG4gICAgcmV0dXJuIHJlc291cmNlLnRvU3RyaW5nKCk7XG4gIH1cblxuICByZXR1cm4gJyc7XG59XG5cbi8qKlxuICogUGFyc2VzIHRoZSBmZXRjaCBhcmd1bWVudHMgdG8gZmluZCB0aGUgdXNlZCBIdHRwIG1ldGhvZCBhbmQgdGhlIHVybCBvZiB0aGUgcmVxdWVzdC5cbiAqIEV4cG9ydGVkIGZvciB0ZXN0cyBvbmx5LlxuICovXG5mdW5jdGlvbiBwYXJzZUZldGNoQXJncyhmZXRjaEFyZ3MpIHtcbiAgaWYgKGZldGNoQXJncy5sZW5ndGggPT09IDApIHtcbiAgICByZXR1cm4geyBtZXRob2Q6ICdHRVQnLCB1cmw6ICcnIH07XG4gIH1cblxuICBpZiAoZmV0Y2hBcmdzLmxlbmd0aCA9PT0gMikge1xuICAgIGNvbnN0IFt1cmwsIG9wdGlvbnNdID0gZmV0Y2hBcmdzIDtcblxuICAgIHJldHVybiB7XG4gICAgICB1cmw6IGdldFVybEZyb21SZXNvdXJjZSh1cmwpLFxuICAgICAgbWV0aG9kOiBoYXNQcm9wKG9wdGlvbnMsICdtZXRob2QnKSA/IFN0cmluZyhvcHRpb25zLm1ldGhvZCkudG9VcHBlckNhc2UoKSA6ICdHRVQnLFxuICAgIH07XG4gIH1cblxuICBjb25zdCBhcmcgPSBmZXRjaEFyZ3NbMF07XG4gIHJldHVybiB7XG4gICAgdXJsOiBnZXRVcmxGcm9tUmVzb3VyY2UoYXJnICksXG4gICAgbWV0aG9kOiBoYXNQcm9wKGFyZywgJ21ldGhvZCcpID8gU3RyaW5nKGFyZy5tZXRob2QpLnRvVXBwZXJDYXNlKCkgOiAnR0VUJyxcbiAgfTtcbn1cblxuZnVuY3Rpb24gZ2V0SGVhZGVyc0Zyb21GZXRjaEFyZ3MoZmV0Y2hBcmdzKSB7XG4gIGNvbnN0IFtyZXF1ZXN0QXJndW1lbnQsIG9wdGlvbnNBcmd1bWVudF0gPSBmZXRjaEFyZ3M7XG5cbiAgdHJ5IHtcbiAgICBpZiAoXG4gICAgICB0eXBlb2Ygb3B0aW9uc0FyZ3VtZW50ID09PSAnb2JqZWN0JyAmJlxuICAgICAgb3B0aW9uc0FyZ3VtZW50ICE9PSBudWxsICYmXG4gICAgICAnaGVhZGVycycgaW4gb3B0aW9uc0FyZ3VtZW50ICYmXG4gICAgICBvcHRpb25zQXJndW1lbnQuaGVhZGVyc1xuICAgICkge1xuICAgICAgcmV0dXJuIG5ldyBIZWFkZXJzKG9wdGlvbnNBcmd1bWVudC5oZWFkZXJzICk7XG4gICAgfVxuXG4gICAgaWYgKGlzLmlzUmVxdWVzdChyZXF1ZXN0QXJndW1lbnQpKSB7XG4gICAgICByZXR1cm4gbmV3IEhlYWRlcnMocmVxdWVzdEFyZ3VtZW50LmhlYWRlcnMpO1xuICAgIH1cbiAgfSBjYXRjaCB7XG4gICAgLy8gbm9vcFxuICB9XG5cbiAgcmV0dXJuO1xufVxuXG5leHBvcnRzLmFkZEZldGNoRW5kSW5zdHJ1bWVudGF0aW9uSGFuZGxlciA9IGFkZEZldGNoRW5kSW5zdHJ1bWVudGF0aW9uSGFuZGxlcjtcbmV4cG9ydHMuYWRkRmV0Y2hJbnN0cnVtZW50YXRpb25IYW5kbGVyID0gYWRkRmV0Y2hJbnN0cnVtZW50YXRpb25IYW5kbGVyO1xuZXhwb3J0cy5wYXJzZUZldGNoQXJncyA9IHBhcnNlRmV0Y2hBcmdzO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9ZmV0Y2guanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/fetch.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/globalError.js":
/*!**************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/globalError.js ***!
  \**************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst worldwide = __webpack_require__(/*! ../utils/worldwide.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/worldwide.js\");\nconst handlers = __webpack_require__(/*! ./handlers.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/handlers.js\");\n\nlet _oldOnErrorHandler = null;\n\n/**\n * Add an instrumentation handler for when an error is captured by the global error handler.\n *\n * Use at your own risk, this might break without changelog notice, only used internally.\n * @hidden\n */\nfunction addGlobalErrorInstrumentationHandler(handler) {\n  const type = 'error';\n  handlers.addHandler(type, handler);\n  handlers.maybeInstrument(type, instrumentError);\n}\n\nfunction instrumentError() {\n  _oldOnErrorHandler = worldwide.GLOBAL_OBJ.onerror;\n\n  // Note: The reason we are doing window.onerror instead of window.addEventListener('error')\n  // is that we are using this handler in the Loader Script, to handle buffered errors consistently\n  worldwide.GLOBAL_OBJ.onerror = function (\n    msg,\n    url,\n    line,\n    column,\n    error,\n  ) {\n    const handlerData = {\n      column,\n      error,\n      line,\n      msg,\n      url,\n    };\n    handlers.triggerHandlers('error', handlerData);\n\n    if (_oldOnErrorHandler) {\n      // eslint-disable-next-line prefer-rest-params\n      return _oldOnErrorHandler.apply(this, arguments);\n    }\n\n    return false;\n  };\n\n  worldwide.GLOBAL_OBJ.onerror.__SENTRY_INSTRUMENTED__ = true;\n}\n\nexports.addGlobalErrorInstrumentationHandler = addGlobalErrorInstrumentationHandler;\n//# sourceMappingURL=globalError.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnN0cnVtZW50L2dsb2JhbEVycm9yLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLGtCQUFrQixtQkFBTyxDQUFDLG9JQUF1QjtBQUNqRCxpQkFBaUIsbUJBQU8sQ0FBQyxnSUFBZTs7QUFFeEM7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBOztBQUVBLDRDQUE0QztBQUM1QyIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL2luc3RydW1lbnQvZ2xvYmFsRXJyb3IuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IHdvcmxkd2lkZSA9IHJlcXVpcmUoJy4uL3V0aWxzL3dvcmxkd2lkZS5qcycpO1xuY29uc3QgaGFuZGxlcnMgPSByZXF1aXJlKCcuL2hhbmRsZXJzLmpzJyk7XG5cbmxldCBfb2xkT25FcnJvckhhbmRsZXIgPSBudWxsO1xuXG4vKipcbiAqIEFkZCBhbiBpbnN0cnVtZW50YXRpb24gaGFuZGxlciBmb3Igd2hlbiBhbiBlcnJvciBpcyBjYXB0dXJlZCBieSB0aGUgZ2xvYmFsIGVycm9yIGhhbmRsZXIuXG4gKlxuICogVXNlIGF0IHlvdXIgb3duIHJpc2ssIHRoaXMgbWlnaHQgYnJlYWsgd2l0aG91dCBjaGFuZ2Vsb2cgbm90aWNlLCBvbmx5IHVzZWQgaW50ZXJuYWxseS5cbiAqIEBoaWRkZW5cbiAqL1xuZnVuY3Rpb24gYWRkR2xvYmFsRXJyb3JJbnN0cnVtZW50YXRpb25IYW5kbGVyKGhhbmRsZXIpIHtcbiAgY29uc3QgdHlwZSA9ICdlcnJvcic7XG4gIGhhbmRsZXJzLmFkZEhhbmRsZXIodHlwZSwgaGFuZGxlcik7XG4gIGhhbmRsZXJzLm1heWJlSW5zdHJ1bWVudCh0eXBlLCBpbnN0cnVtZW50RXJyb3IpO1xufVxuXG5mdW5jdGlvbiBpbnN0cnVtZW50RXJyb3IoKSB7XG4gIF9vbGRPbkVycm9ySGFuZGxlciA9IHdvcmxkd2lkZS5HTE9CQUxfT0JKLm9uZXJyb3I7XG5cbiAgLy8gTm90ZTogVGhlIHJlYXNvbiB3ZSBhcmUgZG9pbmcgd2luZG93Lm9uZXJyb3IgaW5zdGVhZCBvZiB3aW5kb3cuYWRkRXZlbnRMaXN0ZW5lcignZXJyb3InKVxuICAvLyBpcyB0aGF0IHdlIGFyZSB1c2luZyB0aGlzIGhhbmRsZXIgaW4gdGhlIExvYWRlciBTY3JpcHQsIHRvIGhhbmRsZSBidWZmZXJlZCBlcnJvcnMgY29uc2lzdGVudGx5XG4gIHdvcmxkd2lkZS5HTE9CQUxfT0JKLm9uZXJyb3IgPSBmdW5jdGlvbiAoXG4gICAgbXNnLFxuICAgIHVybCxcbiAgICBsaW5lLFxuICAgIGNvbHVtbixcbiAgICBlcnJvcixcbiAgKSB7XG4gICAgY29uc3QgaGFuZGxlckRhdGEgPSB7XG4gICAgICBjb2x1bW4sXG4gICAgICBlcnJvcixcbiAgICAgIGxpbmUsXG4gICAgICBtc2csXG4gICAgICB1cmwsXG4gICAgfTtcbiAgICBoYW5kbGVycy50cmlnZ2VySGFuZGxlcnMoJ2Vycm9yJywgaGFuZGxlckRhdGEpO1xuXG4gICAgaWYgKF9vbGRPbkVycm9ySGFuZGxlcikge1xuICAgICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIHByZWZlci1yZXN0LXBhcmFtc1xuICAgICAgcmV0dXJuIF9vbGRPbkVycm9ySGFuZGxlci5hcHBseSh0aGlzLCBhcmd1bWVudHMpO1xuICAgIH1cblxuICAgIHJldHVybiBmYWxzZTtcbiAgfTtcblxuICB3b3JsZHdpZGUuR0xPQkFMX09CSi5vbmVycm9yLl9fU0VOVFJZX0lOU1RSVU1FTlRFRF9fID0gdHJ1ZTtcbn1cblxuZXhwb3J0cy5hZGRHbG9iYWxFcnJvckluc3RydW1lbnRhdGlvbkhhbmRsZXIgPSBhZGRHbG9iYWxFcnJvckluc3RydW1lbnRhdGlvbkhhbmRsZXI7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1nbG9iYWxFcnJvci5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/globalError.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/globalUnhandledRejection.js":
/*!***************************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/globalUnhandledRejection.js ***!
  \***************************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst worldwide = __webpack_require__(/*! ../utils/worldwide.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/worldwide.js\");\nconst handlers = __webpack_require__(/*! ./handlers.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/handlers.js\");\n\nlet _oldOnUnhandledRejectionHandler = null;\n\n/**\n * Add an instrumentation handler for when an unhandled promise rejection is captured.\n *\n * Use at your own risk, this might break without changelog notice, only used internally.\n * @hidden\n */\nfunction addGlobalUnhandledRejectionInstrumentationHandler(\n  handler,\n) {\n  const type = 'unhandledrejection';\n  handlers.addHandler(type, handler);\n  handlers.maybeInstrument(type, instrumentUnhandledRejection);\n}\n\nfunction instrumentUnhandledRejection() {\n  _oldOnUnhandledRejectionHandler = worldwide.GLOBAL_OBJ.onunhandledrejection;\n\n  // Note: The reason we are doing window.onunhandledrejection instead of window.addEventListener('unhandledrejection')\n  // is that we are using this handler in the Loader Script, to handle buffered rejections consistently\n  worldwide.GLOBAL_OBJ.onunhandledrejection = function (e) {\n    const handlerData = e;\n    handlers.triggerHandlers('unhandledrejection', handlerData);\n\n    if (_oldOnUnhandledRejectionHandler) {\n      // eslint-disable-next-line prefer-rest-params\n      return _oldOnUnhandledRejectionHandler.apply(this, arguments);\n    }\n\n    return true;\n  };\n\n  worldwide.GLOBAL_OBJ.onunhandledrejection.__SENTRY_INSTRUMENTED__ = true;\n}\n\nexports.addGlobalUnhandledRejectionInstrumentationHandler = addGlobalUnhandledRejectionInstrumentationHandler;\n//# sourceMappingURL=globalUnhandledRejection.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnN0cnVtZW50L2dsb2JhbFVuaGFuZGxlZFJlamVjdGlvbi5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxrQkFBa0IsbUJBQU8sQ0FBQyxvSUFBdUI7QUFDakQsaUJBQWlCLG1CQUFPLENBQUMsZ0lBQWU7O0FBRXhDOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUEseURBQXlEO0FBQ3pEIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvaW5zdHJ1bWVudC9nbG9iYWxVbmhhbmRsZWRSZWplY3Rpb24uanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IHdvcmxkd2lkZSA9IHJlcXVpcmUoJy4uL3V0aWxzL3dvcmxkd2lkZS5qcycpO1xuY29uc3QgaGFuZGxlcnMgPSByZXF1aXJlKCcuL2hhbmRsZXJzLmpzJyk7XG5cbmxldCBfb2xkT25VbmhhbmRsZWRSZWplY3Rpb25IYW5kbGVyID0gbnVsbDtcblxuLyoqXG4gKiBBZGQgYW4gaW5zdHJ1bWVudGF0aW9uIGhhbmRsZXIgZm9yIHdoZW4gYW4gdW5oYW5kbGVkIHByb21pc2UgcmVqZWN0aW9uIGlzIGNhcHR1cmVkLlxuICpcbiAqIFVzZSBhdCB5b3VyIG93biByaXNrLCB0aGlzIG1pZ2h0IGJyZWFrIHdpdGhvdXQgY2hhbmdlbG9nIG5vdGljZSwgb25seSB1c2VkIGludGVybmFsbHkuXG4gKiBAaGlkZGVuXG4gKi9cbmZ1bmN0aW9uIGFkZEdsb2JhbFVuaGFuZGxlZFJlamVjdGlvbkluc3RydW1lbnRhdGlvbkhhbmRsZXIoXG4gIGhhbmRsZXIsXG4pIHtcbiAgY29uc3QgdHlwZSA9ICd1bmhhbmRsZWRyZWplY3Rpb24nO1xuICBoYW5kbGVycy5hZGRIYW5kbGVyKHR5cGUsIGhhbmRsZXIpO1xuICBoYW5kbGVycy5tYXliZUluc3RydW1lbnQodHlwZSwgaW5zdHJ1bWVudFVuaGFuZGxlZFJlamVjdGlvbik7XG59XG5cbmZ1bmN0aW9uIGluc3RydW1lbnRVbmhhbmRsZWRSZWplY3Rpb24oKSB7XG4gIF9vbGRPblVuaGFuZGxlZFJlamVjdGlvbkhhbmRsZXIgPSB3b3JsZHdpZGUuR0xPQkFMX09CSi5vbnVuaGFuZGxlZHJlamVjdGlvbjtcblxuICAvLyBOb3RlOiBUaGUgcmVhc29uIHdlIGFyZSBkb2luZyB3aW5kb3cub251bmhhbmRsZWRyZWplY3Rpb24gaW5zdGVhZCBvZiB3aW5kb3cuYWRkRXZlbnRMaXN0ZW5lcigndW5oYW5kbGVkcmVqZWN0aW9uJylcbiAgLy8gaXMgdGhhdCB3ZSBhcmUgdXNpbmcgdGhpcyBoYW5kbGVyIGluIHRoZSBMb2FkZXIgU2NyaXB0LCB0byBoYW5kbGUgYnVmZmVyZWQgcmVqZWN0aW9ucyBjb25zaXN0ZW50bHlcbiAgd29ybGR3aWRlLkdMT0JBTF9PQkoub251bmhhbmRsZWRyZWplY3Rpb24gPSBmdW5jdGlvbiAoZSkge1xuICAgIGNvbnN0IGhhbmRsZXJEYXRhID0gZTtcbiAgICBoYW5kbGVycy50cmlnZ2VySGFuZGxlcnMoJ3VuaGFuZGxlZHJlamVjdGlvbicsIGhhbmRsZXJEYXRhKTtcblxuICAgIGlmIChfb2xkT25VbmhhbmRsZWRSZWplY3Rpb25IYW5kbGVyKSB7XG4gICAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgcHJlZmVyLXJlc3QtcGFyYW1zXG4gICAgICByZXR1cm4gX29sZE9uVW5oYW5kbGVkUmVqZWN0aW9uSGFuZGxlci5hcHBseSh0aGlzLCBhcmd1bWVudHMpO1xuICAgIH1cblxuICAgIHJldHVybiB0cnVlO1xuICB9O1xuXG4gIHdvcmxkd2lkZS5HTE9CQUxfT0JKLm9udW5oYW5kbGVkcmVqZWN0aW9uLl9fU0VOVFJZX0lOU1RSVU1FTlRFRF9fID0gdHJ1ZTtcbn1cblxuZXhwb3J0cy5hZGRHbG9iYWxVbmhhbmRsZWRSZWplY3Rpb25JbnN0cnVtZW50YXRpb25IYW5kbGVyID0gYWRkR2xvYmFsVW5oYW5kbGVkUmVqZWN0aW9uSW5zdHJ1bWVudGF0aW9uSGFuZGxlcjtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWdsb2JhbFVuaGFuZGxlZFJlamVjdGlvbi5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/globalUnhandledRejection.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/handlers.js":
/*!***********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/handlers.js ***!
  \***********************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst debugBuild = __webpack_require__(/*! ../debug-build.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst debugLogger = __webpack_require__(/*! ../utils/debug-logger.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst stacktrace = __webpack_require__(/*! ../utils/stacktrace.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/stacktrace.js\");\n\n// We keep the handlers globally\nconst handlers = {};\nconst instrumented = {};\n\n/** Add a handler function. */\nfunction addHandler(type, handler) {\n  handlers[type] = handlers[type] || [];\n  (handlers[type] ).push(handler);\n}\n\n/**\n * Reset all instrumentation handlers.\n * This can be used by tests to ensure we have a clean slate of instrumentation handlers.\n */\nfunction resetInstrumentationHandlers() {\n  Object.keys(handlers).forEach(key => {\n    handlers[key ] = undefined;\n  });\n}\n\n/** Maybe run an instrumentation function, unless it was already called. */\nfunction maybeInstrument(type, instrumentFn) {\n  if (!instrumented[type]) {\n    instrumented[type] = true;\n    try {\n      instrumentFn();\n    } catch (e) {\n      debugBuild.DEBUG_BUILD && debugLogger.debug.error(`Error while instrumenting ${type}`, e);\n    }\n  }\n}\n\n/** Trigger handlers for a given instrumentation type. */\nfunction triggerHandlers(type, data) {\n  const typeHandlers = type && handlers[type];\n  if (!typeHandlers) {\n    return;\n  }\n\n  for (const handler of typeHandlers) {\n    try {\n      handler(data);\n    } catch (e) {\n      debugBuild.DEBUG_BUILD &&\n        debugLogger.debug.error(\n          `Error while triggering instrumentation handler.\\nType: ${type}\\nName: ${stacktrace.getFunctionName(handler)}\\nError:`,\n          e,\n        );\n    }\n  }\n}\n\nexports.addHandler = addHandler;\nexports.maybeInstrument = maybeInstrument;\nexports.resetInstrumentationHandlers = resetInstrumentationHandlers;\nexports.triggerHandlers = triggerHandlers;\n//# sourceMappingURL=handlers.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnN0cnVtZW50L2hhbmRsZXJzLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLG1CQUFtQixtQkFBTyxDQUFDLDRIQUFtQjtBQUM5QyxvQkFBb0IsbUJBQU8sQ0FBQywwSUFBMEI7QUFDdEQsbUJBQW1CLG1CQUFPLENBQUMsc0lBQXdCOztBQUVuRDtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEdBQUc7QUFDSDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxNQUFNO0FBQ04scUZBQXFGLEtBQUs7QUFDMUY7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQSxNQUFNO0FBQ047QUFDQTtBQUNBLG9FQUFvRSxLQUFLLFVBQVUsb0NBQW9DO0FBQ3ZIO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsa0JBQWtCO0FBQ2xCLHVCQUF1QjtBQUN2QixvQ0FBb0M7QUFDcEMsdUJBQXVCO0FBQ3ZCIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvaW5zdHJ1bWVudC9oYW5kbGVycy5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgZGVidWdCdWlsZCA9IHJlcXVpcmUoJy4uL2RlYnVnLWJ1aWxkLmpzJyk7XG5jb25zdCBkZWJ1Z0xvZ2dlciA9IHJlcXVpcmUoJy4uL3V0aWxzL2RlYnVnLWxvZ2dlci5qcycpO1xuY29uc3Qgc3RhY2t0cmFjZSA9IHJlcXVpcmUoJy4uL3V0aWxzL3N0YWNrdHJhY2UuanMnKTtcblxuLy8gV2Uga2VlcCB0aGUgaGFuZGxlcnMgZ2xvYmFsbHlcbmNvbnN0IGhhbmRsZXJzID0ge307XG5jb25zdCBpbnN0cnVtZW50ZWQgPSB7fTtcblxuLyoqIEFkZCBhIGhhbmRsZXIgZnVuY3Rpb24uICovXG5mdW5jdGlvbiBhZGRIYW5kbGVyKHR5cGUsIGhhbmRsZXIpIHtcbiAgaGFuZGxlcnNbdHlwZV0gPSBoYW5kbGVyc1t0eXBlXSB8fCBbXTtcbiAgKGhhbmRsZXJzW3R5cGVdICkucHVzaChoYW5kbGVyKTtcbn1cblxuLyoqXG4gKiBSZXNldCBhbGwgaW5zdHJ1bWVudGF0aW9uIGhhbmRsZXJzLlxuICogVGhpcyBjYW4gYmUgdXNlZCBieSB0ZXN0cyB0byBlbnN1cmUgd2UgaGF2ZSBhIGNsZWFuIHNsYXRlIG9mIGluc3RydW1lbnRhdGlvbiBoYW5kbGVycy5cbiAqL1xuZnVuY3Rpb24gcmVzZXRJbnN0cnVtZW50YXRpb25IYW5kbGVycygpIHtcbiAgT2JqZWN0LmtleXMoaGFuZGxlcnMpLmZvckVhY2goa2V5ID0+IHtcbiAgICBoYW5kbGVyc1trZXkgXSA9IHVuZGVmaW5lZDtcbiAgfSk7XG59XG5cbi8qKiBNYXliZSBydW4gYW4gaW5zdHJ1bWVudGF0aW9uIGZ1bmN0aW9uLCB1bmxlc3MgaXQgd2FzIGFscmVhZHkgY2FsbGVkLiAqL1xuZnVuY3Rpb24gbWF5YmVJbnN0cnVtZW50KHR5cGUsIGluc3RydW1lbnRGbikge1xuICBpZiAoIWluc3RydW1lbnRlZFt0eXBlXSkge1xuICAgIGluc3RydW1lbnRlZFt0eXBlXSA9IHRydWU7XG4gICAgdHJ5IHtcbiAgICAgIGluc3RydW1lbnRGbigpO1xuICAgIH0gY2F0Y2ggKGUpIHtcbiAgICAgIGRlYnVnQnVpbGQuREVCVUdfQlVJTEQgJiYgZGVidWdMb2dnZXIuZGVidWcuZXJyb3IoYEVycm9yIHdoaWxlIGluc3RydW1lbnRpbmcgJHt0eXBlfWAsIGUpO1xuICAgIH1cbiAgfVxufVxuXG4vKiogVHJpZ2dlciBoYW5kbGVycyBmb3IgYSBnaXZlbiBpbnN0cnVtZW50YXRpb24gdHlwZS4gKi9cbmZ1bmN0aW9uIHRyaWdnZXJIYW5kbGVycyh0eXBlLCBkYXRhKSB7XG4gIGNvbnN0IHR5cGVIYW5kbGVycyA9IHR5cGUgJiYgaGFuZGxlcnNbdHlwZV07XG4gIGlmICghdHlwZUhhbmRsZXJzKSB7XG4gICAgcmV0dXJuO1xuICB9XG5cbiAgZm9yIChjb25zdCBoYW5kbGVyIG9mIHR5cGVIYW5kbGVycykge1xuICAgIHRyeSB7XG4gICAgICBoYW5kbGVyKGRhdGEpO1xuICAgIH0gY2F0Y2ggKGUpIHtcbiAgICAgIGRlYnVnQnVpbGQuREVCVUdfQlVJTEQgJiZcbiAgICAgICAgZGVidWdMb2dnZXIuZGVidWcuZXJyb3IoXG4gICAgICAgICAgYEVycm9yIHdoaWxlIHRyaWdnZXJpbmcgaW5zdHJ1bWVudGF0aW9uIGhhbmRsZXIuXFxuVHlwZTogJHt0eXBlfVxcbk5hbWU6ICR7c3RhY2t0cmFjZS5nZXRGdW5jdGlvbk5hbWUoaGFuZGxlcil9XFxuRXJyb3I6YCxcbiAgICAgICAgICBlLFxuICAgICAgICApO1xuICAgIH1cbiAgfVxufVxuXG5leHBvcnRzLmFkZEhhbmRsZXIgPSBhZGRIYW5kbGVyO1xuZXhwb3J0cy5tYXliZUluc3RydW1lbnQgPSBtYXliZUluc3RydW1lbnQ7XG5leHBvcnRzLnJlc2V0SW5zdHJ1bWVudGF0aW9uSGFuZGxlcnMgPSByZXNldEluc3RydW1lbnRhdGlvbkhhbmRsZXJzO1xuZXhwb3J0cy50cmlnZ2VySGFuZGxlcnMgPSB0cmlnZ2VySGFuZGxlcnM7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1oYW5kbGVycy5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/handlers.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integration.js":
/*!***************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integration.js ***!
  \***************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst currentScopes = __webpack_require__(/*! ./currentScopes.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst debugBuild = __webpack_require__(/*! ./debug-build.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst debugLogger = __webpack_require__(/*! ./utils/debug-logger.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\n\nconst installedIntegrations = [];\n\n/** Map of integrations assigned to a client */\n\n/**\n * Remove duplicates from the given array, preferring the last instance of any duplicate. Not guaranteed to\n * preserve the order of integrations in the array.\n *\n * @private\n */\nfunction filterDuplicates(integrations) {\n  const integrationsByName = {};\n\n  integrations.forEach((currentInstance) => {\n    const { name } = currentInstance;\n\n    const existingInstance = integrationsByName[name];\n\n    // We want integrations later in the array to overwrite earlier ones of the same type, except that we never want a\n    // default instance to overwrite an existing user instance\n    if (existingInstance && !existingInstance.isDefaultInstance && currentInstance.isDefaultInstance) {\n      return;\n    }\n\n    integrationsByName[name] = currentInstance;\n  });\n\n  return Object.values(integrationsByName);\n}\n\n/** Gets integrations to install */\nfunction getIntegrationsToSetup(options) {\n  const defaultIntegrations = options.defaultIntegrations || [];\n  const userIntegrations = options.integrations;\n\n  // We flag default instances, so that later we can tell them apart from any user-created instances of the same class\n  defaultIntegrations.forEach((integration) => {\n    integration.isDefaultInstance = true;\n  });\n\n  let integrations;\n\n  if (Array.isArray(userIntegrations)) {\n    integrations = [...defaultIntegrations, ...userIntegrations];\n  } else if (typeof userIntegrations === 'function') {\n    const resolvedUserIntegrations = userIntegrations(defaultIntegrations);\n    integrations = Array.isArray(resolvedUserIntegrations) ? resolvedUserIntegrations : [resolvedUserIntegrations];\n  } else {\n    integrations = defaultIntegrations;\n  }\n\n  return filterDuplicates(integrations);\n}\n\n/**\n * Given a list of integration instances this installs them all. When `withDefaults` is set to `true` then all default\n * integrations are added unless they were already provided before.\n * @param integrations array of integration instances\n * @param withDefault should enable default integrations\n */\nfunction setupIntegrations(client, integrations) {\n  const integrationIndex = {};\n\n  integrations.forEach((integration) => {\n    // guard against empty provided integrations\n    if (integration) {\n      setupIntegration(client, integration, integrationIndex);\n    }\n  });\n\n  return integrationIndex;\n}\n\n/**\n * Execute the `afterAllSetup` hooks of the given integrations.\n */\nfunction afterSetupIntegrations(client, integrations) {\n  for (const integration of integrations) {\n    // guard against empty provided integrations\n    if (integration?.afterAllSetup) {\n      integration.afterAllSetup(client);\n    }\n  }\n}\n\n/** Setup a single integration.  */\nfunction setupIntegration(client, integration, integrationIndex) {\n  if (integrationIndex[integration.name]) {\n    debugBuild.DEBUG_BUILD && debugLogger.debug.log(`Integration skipped because it was already installed: ${integration.name}`);\n    return;\n  }\n  integrationIndex[integration.name] = integration;\n\n  // `setupOnce` is only called the first time\n  if (installedIntegrations.indexOf(integration.name) === -1 && typeof integration.setupOnce === 'function') {\n    integration.setupOnce();\n    installedIntegrations.push(integration.name);\n  }\n\n  // `setup` is run for each client\n  if (integration.setup && typeof integration.setup === 'function') {\n    integration.setup(client);\n  }\n\n  if (typeof integration.preprocessEvent === 'function') {\n    const callback = integration.preprocessEvent.bind(integration) ;\n    client.on('preprocessEvent', (event, hint) => callback(event, hint, client));\n  }\n\n  if (typeof integration.processEvent === 'function') {\n    const callback = integration.processEvent.bind(integration) ;\n\n    const processor = Object.assign((event, hint) => callback(event, hint, client), {\n      id: integration.name,\n    });\n\n    client.addEventProcessor(processor);\n  }\n\n  debugBuild.DEBUG_BUILD && debugLogger.debug.log(`Integration installed: ${integration.name}`);\n}\n\n/** Add an integration to the current scope's client. */\nfunction addIntegration(integration) {\n  const client = currentScopes.getClient();\n\n  if (!client) {\n    debugBuild.DEBUG_BUILD && debugLogger.debug.warn(`Cannot add integration \"${integration.name}\" because no SDK Client is available.`);\n    return;\n  }\n\n  client.addIntegration(integration);\n}\n\n/**\n * Define an integration function that can be used to create an integration instance.\n * Note that this by design hides the implementation details of the integration, as they are considered internal.\n */\nfunction defineIntegration(fn) {\n  return fn;\n}\n\nexports.addIntegration = addIntegration;\nexports.afterSetupIntegrations = afterSetupIntegrations;\nexports.defineIntegration = defineIntegration;\nexports.getIntegrationsToSetup = getIntegrationsToSetup;\nexports.installedIntegrations = installedIntegrations;\nexports.setupIntegration = setupIntegration;\nexports.setupIntegrations = setupIntegrations;\n//# sourceMappingURL=integration.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbi5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxzQkFBc0IsbUJBQU8sQ0FBQywrSEFBb0I7QUFDbEQsbUJBQW1CLG1CQUFPLENBQUMsMkhBQWtCO0FBQzdDLG9CQUFvQixtQkFBTyxDQUFDLHlJQUF5Qjs7QUFFckQ7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBLFlBQVksT0FBTzs7QUFFbkI7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBLEdBQUc7O0FBRUg7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQSxHQUFHOztBQUVIOztBQUVBO0FBQ0E7QUFDQSxJQUFJO0FBQ0o7QUFDQTtBQUNBLElBQUk7QUFDSjtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsR0FBRzs7QUFFSDtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0EsNkdBQTZHLGlCQUFpQjtBQUM5SDtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQSxLQUFLOztBQUVMO0FBQ0E7O0FBRUEsNEVBQTRFLGlCQUFpQjtBQUM3Rjs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQSxnRkFBZ0YsaUJBQWlCO0FBQ2pHO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSxzQkFBc0I7QUFDdEIsOEJBQThCO0FBQzlCLHlCQUF5QjtBQUN6Qiw4QkFBOEI7QUFDOUIsNkJBQTZCO0FBQzdCLHdCQUF3QjtBQUN4Qix5QkFBeUI7QUFDekIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbi5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgY3VycmVudFNjb3BlcyA9IHJlcXVpcmUoJy4vY3VycmVudFNjb3Blcy5qcycpO1xuY29uc3QgZGVidWdCdWlsZCA9IHJlcXVpcmUoJy4vZGVidWctYnVpbGQuanMnKTtcbmNvbnN0IGRlYnVnTG9nZ2VyID0gcmVxdWlyZSgnLi91dGlscy9kZWJ1Zy1sb2dnZXIuanMnKTtcblxuY29uc3QgaW5zdGFsbGVkSW50ZWdyYXRpb25zID0gW107XG5cbi8qKiBNYXAgb2YgaW50ZWdyYXRpb25zIGFzc2lnbmVkIHRvIGEgY2xpZW50ICovXG5cbi8qKlxuICogUmVtb3ZlIGR1cGxpY2F0ZXMgZnJvbSB0aGUgZ2l2ZW4gYXJyYXksIHByZWZlcnJpbmcgdGhlIGxhc3QgaW5zdGFuY2Ugb2YgYW55IGR1cGxpY2F0ZS4gTm90IGd1YXJhbnRlZWQgdG9cbiAqIHByZXNlcnZlIHRoZSBvcmRlciBvZiBpbnRlZ3JhdGlvbnMgaW4gdGhlIGFycmF5LlxuICpcbiAqIEBwcml2YXRlXG4gKi9cbmZ1bmN0aW9uIGZpbHRlckR1cGxpY2F0ZXMoaW50ZWdyYXRpb25zKSB7XG4gIGNvbnN0IGludGVncmF0aW9uc0J5TmFtZSA9IHt9O1xuXG4gIGludGVncmF0aW9ucy5mb3JFYWNoKChjdXJyZW50SW5zdGFuY2UpID0+IHtcbiAgICBjb25zdCB7IG5hbWUgfSA9IGN1cnJlbnRJbnN0YW5jZTtcblxuICAgIGNvbnN0IGV4aXN0aW5nSW5zdGFuY2UgPSBpbnRlZ3JhdGlvbnNCeU5hbWVbbmFtZV07XG5cbiAgICAvLyBXZSB3YW50IGludGVncmF0aW9ucyBsYXRlciBpbiB0aGUgYXJyYXkgdG8gb3ZlcndyaXRlIGVhcmxpZXIgb25lcyBvZiB0aGUgc2FtZSB0eXBlLCBleGNlcHQgdGhhdCB3ZSBuZXZlciB3YW50IGFcbiAgICAvLyBkZWZhdWx0IGluc3RhbmNlIHRvIG92ZXJ3cml0ZSBhbiBleGlzdGluZyB1c2VyIGluc3RhbmNlXG4gICAgaWYgKGV4aXN0aW5nSW5zdGFuY2UgJiYgIWV4aXN0aW5nSW5zdGFuY2UuaXNEZWZhdWx0SW5zdGFuY2UgJiYgY3VycmVudEluc3RhbmNlLmlzRGVmYXVsdEluc3RhbmNlKSB7XG4gICAgICByZXR1cm47XG4gICAgfVxuXG4gICAgaW50ZWdyYXRpb25zQnlOYW1lW25hbWVdID0gY3VycmVudEluc3RhbmNlO1xuICB9KTtcblxuICByZXR1cm4gT2JqZWN0LnZhbHVlcyhpbnRlZ3JhdGlvbnNCeU5hbWUpO1xufVxuXG4vKiogR2V0cyBpbnRlZ3JhdGlvbnMgdG8gaW5zdGFsbCAqL1xuZnVuY3Rpb24gZ2V0SW50ZWdyYXRpb25zVG9TZXR1cChvcHRpb25zKSB7XG4gIGNvbnN0IGRlZmF1bHRJbnRlZ3JhdGlvbnMgPSBvcHRpb25zLmRlZmF1bHRJbnRlZ3JhdGlvbnMgfHwgW107XG4gIGNvbnN0IHVzZXJJbnRlZ3JhdGlvbnMgPSBvcHRpb25zLmludGVncmF0aW9ucztcblxuICAvLyBXZSBmbGFnIGRlZmF1bHQgaW5zdGFuY2VzLCBzbyB0aGF0IGxhdGVyIHdlIGNhbiB0ZWxsIHRoZW0gYXBhcnQgZnJvbSBhbnkgdXNlci1jcmVhdGVkIGluc3RhbmNlcyBvZiB0aGUgc2FtZSBjbGFzc1xuICBkZWZhdWx0SW50ZWdyYXRpb25zLmZvckVhY2goKGludGVncmF0aW9uKSA9PiB7XG4gICAgaW50ZWdyYXRpb24uaXNEZWZhdWx0SW5zdGFuY2UgPSB0cnVlO1xuICB9KTtcblxuICBsZXQgaW50ZWdyYXRpb25zO1xuXG4gIGlmIChBcnJheS5pc0FycmF5KHVzZXJJbnRlZ3JhdGlvbnMpKSB7XG4gICAgaW50ZWdyYXRpb25zID0gWy4uLmRlZmF1bHRJbnRlZ3JhdGlvbnMsIC4uLnVzZXJJbnRlZ3JhdGlvbnNdO1xuICB9IGVsc2UgaWYgKHR5cGVvZiB1c2VySW50ZWdyYXRpb25zID09PSAnZnVuY3Rpb24nKSB7XG4gICAgY29uc3QgcmVzb2x2ZWRVc2VySW50ZWdyYXRpb25zID0gdXNlckludGVncmF0aW9ucyhkZWZhdWx0SW50ZWdyYXRpb25zKTtcbiAgICBpbnRlZ3JhdGlvbnMgPSBBcnJheS5pc0FycmF5KHJlc29sdmVkVXNlckludGVncmF0aW9ucykgPyByZXNvbHZlZFVzZXJJbnRlZ3JhdGlvbnMgOiBbcmVzb2x2ZWRVc2VySW50ZWdyYXRpb25zXTtcbiAgfSBlbHNlIHtcbiAgICBpbnRlZ3JhdGlvbnMgPSBkZWZhdWx0SW50ZWdyYXRpb25zO1xuICB9XG5cbiAgcmV0dXJuIGZpbHRlckR1cGxpY2F0ZXMoaW50ZWdyYXRpb25zKTtcbn1cblxuLyoqXG4gKiBHaXZlbiBhIGxpc3Qgb2YgaW50ZWdyYXRpb24gaW5zdGFuY2VzIHRoaXMgaW5zdGFsbHMgdGhlbSBhbGwuIFdoZW4gYHdpdGhEZWZhdWx0c2AgaXMgc2V0IHRvIGB0cnVlYCB0aGVuIGFsbCBkZWZhdWx0XG4gKiBpbnRlZ3JhdGlvbnMgYXJlIGFkZGVkIHVubGVzcyB0aGV5IHdlcmUgYWxyZWFkeSBwcm92aWRlZCBiZWZvcmUuXG4gKiBAcGFyYW0gaW50ZWdyYXRpb25zIGFycmF5IG9mIGludGVncmF0aW9uIGluc3RhbmNlc1xuICogQHBhcmFtIHdpdGhEZWZhdWx0IHNob3VsZCBlbmFibGUgZGVmYXVsdCBpbnRlZ3JhdGlvbnNcbiAqL1xuZnVuY3Rpb24gc2V0dXBJbnRlZ3JhdGlvbnMoY2xpZW50LCBpbnRlZ3JhdGlvbnMpIHtcbiAgY29uc3QgaW50ZWdyYXRpb25JbmRleCA9IHt9O1xuXG4gIGludGVncmF0aW9ucy5mb3JFYWNoKChpbnRlZ3JhdGlvbikgPT4ge1xuICAgIC8vIGd1YXJkIGFnYWluc3QgZW1wdHkgcHJvdmlkZWQgaW50ZWdyYXRpb25zXG4gICAgaWYgKGludGVncmF0aW9uKSB7XG4gICAgICBzZXR1cEludGVncmF0aW9uKGNsaWVudCwgaW50ZWdyYXRpb24sIGludGVncmF0aW9uSW5kZXgpO1xuICAgIH1cbiAgfSk7XG5cbiAgcmV0dXJuIGludGVncmF0aW9uSW5kZXg7XG59XG5cbi8qKlxuICogRXhlY3V0ZSB0aGUgYGFmdGVyQWxsU2V0dXBgIGhvb2tzIG9mIHRoZSBnaXZlbiBpbnRlZ3JhdGlvbnMuXG4gKi9cbmZ1bmN0aW9uIGFmdGVyU2V0dXBJbnRlZ3JhdGlvbnMoY2xpZW50LCBpbnRlZ3JhdGlvbnMpIHtcbiAgZm9yIChjb25zdCBpbnRlZ3JhdGlvbiBvZiBpbnRlZ3JhdGlvbnMpIHtcbiAgICAvLyBndWFyZCBhZ2FpbnN0IGVtcHR5IHByb3ZpZGVkIGludGVncmF0aW9uc1xuICAgIGlmIChpbnRlZ3JhdGlvbj8uYWZ0ZXJBbGxTZXR1cCkge1xuICAgICAgaW50ZWdyYXRpb24uYWZ0ZXJBbGxTZXR1cChjbGllbnQpO1xuICAgIH1cbiAgfVxufVxuXG4vKiogU2V0dXAgYSBzaW5nbGUgaW50ZWdyYXRpb24uICAqL1xuZnVuY3Rpb24gc2V0dXBJbnRlZ3JhdGlvbihjbGllbnQsIGludGVncmF0aW9uLCBpbnRlZ3JhdGlvbkluZGV4KSB7XG4gIGlmIChpbnRlZ3JhdGlvbkluZGV4W2ludGVncmF0aW9uLm5hbWVdKSB7XG4gICAgZGVidWdCdWlsZC5ERUJVR19CVUlMRCAmJiBkZWJ1Z0xvZ2dlci5kZWJ1Zy5sb2coYEludGVncmF0aW9uIHNraXBwZWQgYmVjYXVzZSBpdCB3YXMgYWxyZWFkeSBpbnN0YWxsZWQ6ICR7aW50ZWdyYXRpb24ubmFtZX1gKTtcbiAgICByZXR1cm47XG4gIH1cbiAgaW50ZWdyYXRpb25JbmRleFtpbnRlZ3JhdGlvbi5uYW1lXSA9IGludGVncmF0aW9uO1xuXG4gIC8vIGBzZXR1cE9uY2VgIGlzIG9ubHkgY2FsbGVkIHRoZSBmaXJzdCB0aW1lXG4gIGlmIChpbnN0YWxsZWRJbnRlZ3JhdGlvbnMuaW5kZXhPZihpbnRlZ3JhdGlvbi5uYW1lKSA9PT0gLTEgJiYgdHlwZW9mIGludGVncmF0aW9uLnNldHVwT25jZSA9PT0gJ2Z1bmN0aW9uJykge1xuICAgIGludGVncmF0aW9uLnNldHVwT25jZSgpO1xuICAgIGluc3RhbGxlZEludGVncmF0aW9ucy5wdXNoKGludGVncmF0aW9uLm5hbWUpO1xuICB9XG5cbiAgLy8gYHNldHVwYCBpcyBydW4gZm9yIGVhY2ggY2xpZW50XG4gIGlmIChpbnRlZ3JhdGlvbi5zZXR1cCAmJiB0eXBlb2YgaW50ZWdyYXRpb24uc2V0dXAgPT09ICdmdW5jdGlvbicpIHtcbiAgICBpbnRlZ3JhdGlvbi5zZXR1cChjbGllbnQpO1xuICB9XG5cbiAgaWYgKHR5cGVvZiBpbnRlZ3JhdGlvbi5wcmVwcm9jZXNzRXZlbnQgPT09ICdmdW5jdGlvbicpIHtcbiAgICBjb25zdCBjYWxsYmFjayA9IGludGVncmF0aW9uLnByZXByb2Nlc3NFdmVudC5iaW5kKGludGVncmF0aW9uKSA7XG4gICAgY2xpZW50Lm9uKCdwcmVwcm9jZXNzRXZlbnQnLCAoZXZlbnQsIGhpbnQpID0+IGNhbGxiYWNrKGV2ZW50LCBoaW50LCBjbGllbnQpKTtcbiAgfVxuXG4gIGlmICh0eXBlb2YgaW50ZWdyYXRpb24ucHJvY2Vzc0V2ZW50ID09PSAnZnVuY3Rpb24nKSB7XG4gICAgY29uc3QgY2FsbGJhY2sgPSBpbnRlZ3JhdGlvbi5wcm9jZXNzRXZlbnQuYmluZChpbnRlZ3JhdGlvbikgO1xuXG4gICAgY29uc3QgcHJvY2Vzc29yID0gT2JqZWN0LmFzc2lnbigoZXZlbnQsIGhpbnQpID0+IGNhbGxiYWNrKGV2ZW50LCBoaW50LCBjbGllbnQpLCB7XG4gICAgICBpZDogaW50ZWdyYXRpb24ubmFtZSxcbiAgICB9KTtcblxuICAgIGNsaWVudC5hZGRFdmVudFByb2Nlc3Nvcihwcm9jZXNzb3IpO1xuICB9XG5cbiAgZGVidWdCdWlsZC5ERUJVR19CVUlMRCAmJiBkZWJ1Z0xvZ2dlci5kZWJ1Zy5sb2coYEludGVncmF0aW9uIGluc3RhbGxlZDogJHtpbnRlZ3JhdGlvbi5uYW1lfWApO1xufVxuXG4vKiogQWRkIGFuIGludGVncmF0aW9uIHRvIHRoZSBjdXJyZW50IHNjb3BlJ3MgY2xpZW50LiAqL1xuZnVuY3Rpb24gYWRkSW50ZWdyYXRpb24oaW50ZWdyYXRpb24pIHtcbiAgY29uc3QgY2xpZW50ID0gY3VycmVudFNjb3Blcy5nZXRDbGllbnQoKTtcblxuICBpZiAoIWNsaWVudCkge1xuICAgIGRlYnVnQnVpbGQuREVCVUdfQlVJTEQgJiYgZGVidWdMb2dnZXIuZGVidWcud2FybihgQ2Fubm90IGFkZCBpbnRlZ3JhdGlvbiBcIiR7aW50ZWdyYXRpb24ubmFtZX1cIiBiZWNhdXNlIG5vIFNESyBDbGllbnQgaXMgYXZhaWxhYmxlLmApO1xuICAgIHJldHVybjtcbiAgfVxuXG4gIGNsaWVudC5hZGRJbnRlZ3JhdGlvbihpbnRlZ3JhdGlvbik7XG59XG5cbi8qKlxuICogRGVmaW5lIGFuIGludGVncmF0aW9uIGZ1bmN0aW9uIHRoYXQgY2FuIGJlIHVzZWQgdG8gY3JlYXRlIGFuIGludGVncmF0aW9uIGluc3RhbmNlLlxuICogTm90ZSB0aGF0IHRoaXMgYnkgZGVzaWduIGhpZGVzIHRoZSBpbXBsZW1lbnRhdGlvbiBkZXRhaWxzIG9mIHRoZSBpbnRlZ3JhdGlvbiwgYXMgdGhleSBhcmUgY29uc2lkZXJlZCBpbnRlcm5hbC5cbiAqL1xuZnVuY3Rpb24gZGVmaW5lSW50ZWdyYXRpb24oZm4pIHtcbiAgcmV0dXJuIGZuO1xufVxuXG5leHBvcnRzLmFkZEludGVncmF0aW9uID0gYWRkSW50ZWdyYXRpb247XG5leHBvcnRzLmFmdGVyU2V0dXBJbnRlZ3JhdGlvbnMgPSBhZnRlclNldHVwSW50ZWdyYXRpb25zO1xuZXhwb3J0cy5kZWZpbmVJbnRlZ3JhdGlvbiA9IGRlZmluZUludGVncmF0aW9uO1xuZXhwb3J0cy5nZXRJbnRlZ3JhdGlvbnNUb1NldHVwID0gZ2V0SW50ZWdyYXRpb25zVG9TZXR1cDtcbmV4cG9ydHMuaW5zdGFsbGVkSW50ZWdyYXRpb25zID0gaW5zdGFsbGVkSW50ZWdyYXRpb25zO1xuZXhwb3J0cy5zZXR1cEludGVncmF0aW9uID0gc2V0dXBJbnRlZ3JhdGlvbjtcbmV4cG9ydHMuc2V0dXBJbnRlZ3JhdGlvbnMgPSBzZXR1cEludGVncmF0aW9ucztcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWludGVncmF0aW9uLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integration.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/captureconsole.js":
/*!*******************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/captureconsole.js ***!
  \*******************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst currentScopes = __webpack_require__(/*! ../currentScopes.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst exports$1 = __webpack_require__(/*! ../exports.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/exports.js\");\nconst console = __webpack_require__(/*! ../instrument/console.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/console.js\");\nconst integration = __webpack_require__(/*! ../integration.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integration.js\");\nconst debugLogger = __webpack_require__(/*! ../utils/debug-logger.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst misc = __webpack_require__(/*! ../utils/misc.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/misc.js\");\nconst severity = __webpack_require__(/*! ../utils/severity.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/severity.js\");\nconst string = __webpack_require__(/*! ../utils/string.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/string.js\");\nconst worldwide = __webpack_require__(/*! ../utils/worldwide.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/worldwide.js\");\n\nconst INTEGRATION_NAME = 'CaptureConsole';\n\nconst _captureConsoleIntegration = ((options = {}) => {\n  const levels = options.levels || debugLogger.CONSOLE_LEVELS;\n  const handled = options.handled ?? true;\n\n  return {\n    name: INTEGRATION_NAME,\n    setup(client) {\n      if (!('console' in worldwide.GLOBAL_OBJ)) {\n        return;\n      }\n\n      console.addConsoleInstrumentationHandler(({ args, level }) => {\n        if (currentScopes.getClient() !== client || !levels.includes(level)) {\n          return;\n        }\n\n        consoleHandler(args, level, handled);\n      });\n    },\n  };\n}) ;\n\n/**\n * Send Console API calls as Sentry Events.\n */\nconst captureConsoleIntegration = integration.defineIntegration(_captureConsoleIntegration);\n\nfunction consoleHandler(args, level, handled) {\n  const captureContext = {\n    level: severity.severityLevelFromString(level),\n    extra: {\n      arguments: args,\n    },\n  };\n\n  currentScopes.withScope(scope => {\n    scope.addEventProcessor(event => {\n      event.logger = 'console';\n\n      misc.addExceptionMechanism(event, {\n        handled,\n        type: 'console',\n      });\n\n      return event;\n    });\n\n    if (level === 'assert') {\n      if (!args[0]) {\n        const message = `Assertion failed: ${string.safeJoin(args.slice(1), ' ') || 'console.assert'}`;\n        scope.setExtra('arguments', args.slice(1));\n        exports$1.captureMessage(message, captureContext);\n      }\n      return;\n    }\n\n    const error = args.find(arg => arg instanceof Error);\n    if (error) {\n      exports$1.captureException(error, captureContext);\n      return;\n    }\n\n    const message = string.safeJoin(args, ' ');\n    exports$1.captureMessage(message, captureContext);\n  });\n}\n\nexports.captureConsoleIntegration = captureConsoleIntegration;\n//# sourceMappingURL=captureconsole.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvY2FwdHVyZWNvbnNvbGUuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsc0JBQXNCLG1CQUFPLENBQUMsZ0lBQXFCO0FBQ25ELGtCQUFrQixtQkFBTyxDQUFDLG9IQUFlO0FBQ3pDLGdCQUFnQixtQkFBTyxDQUFDLDBJQUEwQjtBQUNsRCxvQkFBb0IsbUJBQU8sQ0FBQyw0SEFBbUI7QUFDL0Msb0JBQW9CLG1CQUFPLENBQUMsMElBQTBCO0FBQ3RELGFBQWEsbUJBQU8sQ0FBQywwSEFBa0I7QUFDdkMsaUJBQWlCLG1CQUFPLENBQUMsa0lBQXNCO0FBQy9DLGVBQWUsbUJBQU8sQ0FBQyw4SEFBb0I7QUFDM0Msa0JBQWtCLG1CQUFPLENBQUMsb0lBQXVCOztBQUVqRDs7QUFFQSxpREFBaUQ7QUFDakQ7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsa0RBQWtELGFBQWE7QUFDL0Q7QUFDQTtBQUNBOztBQUVBO0FBQ0EsT0FBTztBQUNQLEtBQUs7QUFDTDtBQUNBLENBQUM7O0FBRUQ7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEtBQUs7QUFDTDs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0EsT0FBTzs7QUFFUDtBQUNBLEtBQUs7O0FBRUw7QUFDQTtBQUNBLDZDQUE2Qyx3REFBd0Q7QUFDckc7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQSxHQUFHO0FBQ0g7O0FBRUEsaUNBQWlDO0FBQ2pDIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvaW50ZWdyYXRpb25zL2NhcHR1cmVjb25zb2xlLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBjdXJyZW50U2NvcGVzID0gcmVxdWlyZSgnLi4vY3VycmVudFNjb3Blcy5qcycpO1xuY29uc3QgZXhwb3J0cyQxID0gcmVxdWlyZSgnLi4vZXhwb3J0cy5qcycpO1xuY29uc3QgY29uc29sZSA9IHJlcXVpcmUoJy4uL2luc3RydW1lbnQvY29uc29sZS5qcycpO1xuY29uc3QgaW50ZWdyYXRpb24gPSByZXF1aXJlKCcuLi9pbnRlZ3JhdGlvbi5qcycpO1xuY29uc3QgZGVidWdMb2dnZXIgPSByZXF1aXJlKCcuLi91dGlscy9kZWJ1Zy1sb2dnZXIuanMnKTtcbmNvbnN0IG1pc2MgPSByZXF1aXJlKCcuLi91dGlscy9taXNjLmpzJyk7XG5jb25zdCBzZXZlcml0eSA9IHJlcXVpcmUoJy4uL3V0aWxzL3NldmVyaXR5LmpzJyk7XG5jb25zdCBzdHJpbmcgPSByZXF1aXJlKCcuLi91dGlscy9zdHJpbmcuanMnKTtcbmNvbnN0IHdvcmxkd2lkZSA9IHJlcXVpcmUoJy4uL3V0aWxzL3dvcmxkd2lkZS5qcycpO1xuXG5jb25zdCBJTlRFR1JBVElPTl9OQU1FID0gJ0NhcHR1cmVDb25zb2xlJztcblxuY29uc3QgX2NhcHR1cmVDb25zb2xlSW50ZWdyYXRpb24gPSAoKG9wdGlvbnMgPSB7fSkgPT4ge1xuICBjb25zdCBsZXZlbHMgPSBvcHRpb25zLmxldmVscyB8fCBkZWJ1Z0xvZ2dlci5DT05TT0xFX0xFVkVMUztcbiAgY29uc3QgaGFuZGxlZCA9IG9wdGlvbnMuaGFuZGxlZCA/PyB0cnVlO1xuXG4gIHJldHVybiB7XG4gICAgbmFtZTogSU5URUdSQVRJT05fTkFNRSxcbiAgICBzZXR1cChjbGllbnQpIHtcbiAgICAgIGlmICghKCdjb25zb2xlJyBpbiB3b3JsZHdpZGUuR0xPQkFMX09CSikpIHtcbiAgICAgICAgcmV0dXJuO1xuICAgICAgfVxuXG4gICAgICBjb25zb2xlLmFkZENvbnNvbGVJbnN0cnVtZW50YXRpb25IYW5kbGVyKCh7IGFyZ3MsIGxldmVsIH0pID0+IHtcbiAgICAgICAgaWYgKGN1cnJlbnRTY29wZXMuZ2V0Q2xpZW50KCkgIT09IGNsaWVudCB8fCAhbGV2ZWxzLmluY2x1ZGVzKGxldmVsKSkge1xuICAgICAgICAgIHJldHVybjtcbiAgICAgICAgfVxuXG4gICAgICAgIGNvbnNvbGVIYW5kbGVyKGFyZ3MsIGxldmVsLCBoYW5kbGVkKTtcbiAgICAgIH0pO1xuICAgIH0sXG4gIH07XG59KSA7XG5cbi8qKlxuICogU2VuZCBDb25zb2xlIEFQSSBjYWxscyBhcyBTZW50cnkgRXZlbnRzLlxuICovXG5jb25zdCBjYXB0dXJlQ29uc29sZUludGVncmF0aW9uID0gaW50ZWdyYXRpb24uZGVmaW5lSW50ZWdyYXRpb24oX2NhcHR1cmVDb25zb2xlSW50ZWdyYXRpb24pO1xuXG5mdW5jdGlvbiBjb25zb2xlSGFuZGxlcihhcmdzLCBsZXZlbCwgaGFuZGxlZCkge1xuICBjb25zdCBjYXB0dXJlQ29udGV4dCA9IHtcbiAgICBsZXZlbDogc2V2ZXJpdHkuc2V2ZXJpdHlMZXZlbEZyb21TdHJpbmcobGV2ZWwpLFxuICAgIGV4dHJhOiB7XG4gICAgICBhcmd1bWVudHM6IGFyZ3MsXG4gICAgfSxcbiAgfTtcblxuICBjdXJyZW50U2NvcGVzLndpdGhTY29wZShzY29wZSA9PiB7XG4gICAgc2NvcGUuYWRkRXZlbnRQcm9jZXNzb3IoZXZlbnQgPT4ge1xuICAgICAgZXZlbnQubG9nZ2VyID0gJ2NvbnNvbGUnO1xuXG4gICAgICBtaXNjLmFkZEV4Y2VwdGlvbk1lY2hhbmlzbShldmVudCwge1xuICAgICAgICBoYW5kbGVkLFxuICAgICAgICB0eXBlOiAnY29uc29sZScsXG4gICAgICB9KTtcblxuICAgICAgcmV0dXJuIGV2ZW50O1xuICAgIH0pO1xuXG4gICAgaWYgKGxldmVsID09PSAnYXNzZXJ0Jykge1xuICAgICAgaWYgKCFhcmdzWzBdKSB7XG4gICAgICAgIGNvbnN0IG1lc3NhZ2UgPSBgQXNzZXJ0aW9uIGZhaWxlZDogJHtzdHJpbmcuc2FmZUpvaW4oYXJncy5zbGljZSgxKSwgJyAnKSB8fCAnY29uc29sZS5hc3NlcnQnfWA7XG4gICAgICAgIHNjb3BlLnNldEV4dHJhKCdhcmd1bWVudHMnLCBhcmdzLnNsaWNlKDEpKTtcbiAgICAgICAgZXhwb3J0cyQxLmNhcHR1cmVNZXNzYWdlKG1lc3NhZ2UsIGNhcHR1cmVDb250ZXh0KTtcbiAgICAgIH1cbiAgICAgIHJldHVybjtcbiAgICB9XG5cbiAgICBjb25zdCBlcnJvciA9IGFyZ3MuZmluZChhcmcgPT4gYXJnIGluc3RhbmNlb2YgRXJyb3IpO1xuICAgIGlmIChlcnJvcikge1xuICAgICAgZXhwb3J0cyQxLmNhcHR1cmVFeGNlcHRpb24oZXJyb3IsIGNhcHR1cmVDb250ZXh0KTtcbiAgICAgIHJldHVybjtcbiAgICB9XG5cbiAgICBjb25zdCBtZXNzYWdlID0gc3RyaW5nLnNhZmVKb2luKGFyZ3MsICcgJyk7XG4gICAgZXhwb3J0cyQxLmNhcHR1cmVNZXNzYWdlKG1lc3NhZ2UsIGNhcHR1cmVDb250ZXh0KTtcbiAgfSk7XG59XG5cbmV4cG9ydHMuY2FwdHVyZUNvbnNvbGVJbnRlZ3JhdGlvbiA9IGNhcHR1cmVDb25zb2xlSW50ZWdyYXRpb247XG4vLyMgc291cmNlTWFwcGluZ1VSTD1jYXB0dXJlY29uc29sZS5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/captureconsole.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/console.js":
/*!************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/console.js ***!
  \************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst breadcrumbs = __webpack_require__(/*! ../breadcrumbs.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/breadcrumbs.js\");\nconst currentScopes = __webpack_require__(/*! ../currentScopes.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst console = __webpack_require__(/*! ../instrument/console.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/console.js\");\nconst integration = __webpack_require__(/*! ../integration.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integration.js\");\nconst debugLogger = __webpack_require__(/*! ../utils/debug-logger.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst severity = __webpack_require__(/*! ../utils/severity.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/severity.js\");\nconst string = __webpack_require__(/*! ../utils/string.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/string.js\");\nconst worldwide = __webpack_require__(/*! ../utils/worldwide.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/worldwide.js\");\n\nconst INTEGRATION_NAME = 'Console';\n\n/**\n * Captures calls to the `console` API as breadcrumbs in Sentry.\n *\n * By default the integration instruments `console.debug`, `console.info`, `console.warn`, `console.error`,\n * `console.log`, `console.trace`, and `console.assert`. You can use the `levels` option to customize which\n * levels are captured.\n *\n * @example\n *\n * ```js\n * Sentry.init({\n *   integrations: [Sentry.consoleIntegration({ levels: ['error', 'warn'] })],\n * });\n * ```\n */\nconst consoleIntegration = integration.defineIntegration((options = {}) => {\n  const levels = new Set(options.levels || debugLogger.CONSOLE_LEVELS);\n\n  return {\n    name: INTEGRATION_NAME,\n    setup(client) {\n      console.addConsoleInstrumentationHandler(({ args, level }) => {\n        if (currentScopes.getClient() !== client || !levels.has(level)) {\n          return;\n        }\n\n        addConsoleBreadcrumb(level, args);\n      });\n    },\n  };\n});\n\n/**\n * Capture a console breadcrumb.\n *\n * Exported just for tests.\n */\nfunction addConsoleBreadcrumb(level, args) {\n  const breadcrumb = {\n    category: 'console',\n    data: {\n      arguments: args,\n      logger: 'console',\n    },\n    level: severity.severityLevelFromString(level),\n    message: formatConsoleArgs(args),\n  };\n\n  if (level === 'assert') {\n    if (args[0] === false) {\n      const assertionArgs = args.slice(1);\n      breadcrumb.message =\n        assertionArgs.length > 0 ? `Assertion failed: ${formatConsoleArgs(assertionArgs)}` : 'Assertion failed';\n      breadcrumb.data.arguments = assertionArgs;\n    } else {\n      // Don't capture a breadcrumb for passed assertions\n      return;\n    }\n  }\n\n  breadcrumbs.addBreadcrumb(breadcrumb, {\n    input: args,\n    level,\n  });\n}\n\nfunction formatConsoleArgs(values) {\n  return 'util' in worldwide.GLOBAL_OBJ && typeof (worldwide.GLOBAL_OBJ ).util.format === 'function'\n    ? (worldwide.GLOBAL_OBJ ).util.format(...values)\n    : string.safeJoin(values, ' ');\n}\n\nexports.addConsoleBreadcrumb = addConsoleBreadcrumb;\nexports.consoleIntegration = consoleIntegration;\n//# sourceMappingURL=console.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvY29uc29sZS5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxvQkFBb0IsbUJBQU8sQ0FBQyw0SEFBbUI7QUFDL0Msc0JBQXNCLG1CQUFPLENBQUMsZ0lBQXFCO0FBQ25ELGdCQUFnQixtQkFBTyxDQUFDLDBJQUEwQjtBQUNsRCxvQkFBb0IsbUJBQU8sQ0FBQyw0SEFBbUI7QUFDL0Msb0JBQW9CLG1CQUFPLENBQUMsMElBQTBCO0FBQ3RELGlCQUFpQixtQkFBTyxDQUFDLGtJQUFzQjtBQUMvQyxlQUFlLG1CQUFPLENBQUMsOEhBQW9CO0FBQzNDLGtCQUFrQixtQkFBTyxDQUFDLG9JQUF1Qjs7QUFFakQ7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGdEQUFnRCwyQkFBMkI7QUFDM0UsSUFBSTtBQUNKO0FBQ0E7QUFDQSxzRUFBc0U7QUFDdEU7O0FBRUE7QUFDQTtBQUNBO0FBQ0Esa0RBQWtELGFBQWE7QUFDL0Q7QUFDQTtBQUNBOztBQUVBO0FBQ0EsT0FBTztBQUNQLEtBQUs7QUFDTDtBQUNBLENBQUM7O0FBRUQ7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEtBQUs7QUFDTDtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQSx3REFBd0QsaUNBQWlDO0FBQ3pGO0FBQ0EsTUFBTTtBQUNOO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBLEdBQUc7QUFDSDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLDRCQUE0QjtBQUM1QiwwQkFBMEI7QUFDMUIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvY29uc29sZS5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgYnJlYWRjcnVtYnMgPSByZXF1aXJlKCcuLi9icmVhZGNydW1icy5qcycpO1xuY29uc3QgY3VycmVudFNjb3BlcyA9IHJlcXVpcmUoJy4uL2N1cnJlbnRTY29wZXMuanMnKTtcbmNvbnN0IGNvbnNvbGUgPSByZXF1aXJlKCcuLi9pbnN0cnVtZW50L2NvbnNvbGUuanMnKTtcbmNvbnN0IGludGVncmF0aW9uID0gcmVxdWlyZSgnLi4vaW50ZWdyYXRpb24uanMnKTtcbmNvbnN0IGRlYnVnTG9nZ2VyID0gcmVxdWlyZSgnLi4vdXRpbHMvZGVidWctbG9nZ2VyLmpzJyk7XG5jb25zdCBzZXZlcml0eSA9IHJlcXVpcmUoJy4uL3V0aWxzL3NldmVyaXR5LmpzJyk7XG5jb25zdCBzdHJpbmcgPSByZXF1aXJlKCcuLi91dGlscy9zdHJpbmcuanMnKTtcbmNvbnN0IHdvcmxkd2lkZSA9IHJlcXVpcmUoJy4uL3V0aWxzL3dvcmxkd2lkZS5qcycpO1xuXG5jb25zdCBJTlRFR1JBVElPTl9OQU1FID0gJ0NvbnNvbGUnO1xuXG4vKipcbiAqIENhcHR1cmVzIGNhbGxzIHRvIHRoZSBgY29uc29sZWAgQVBJIGFzIGJyZWFkY3J1bWJzIGluIFNlbnRyeS5cbiAqXG4gKiBCeSBkZWZhdWx0IHRoZSBpbnRlZ3JhdGlvbiBpbnN0cnVtZW50cyBgY29uc29sZS5kZWJ1Z2AsIGBjb25zb2xlLmluZm9gLCBgY29uc29sZS53YXJuYCwgYGNvbnNvbGUuZXJyb3JgLFxuICogYGNvbnNvbGUubG9nYCwgYGNvbnNvbGUudHJhY2VgLCBhbmQgYGNvbnNvbGUuYXNzZXJ0YC4gWW91IGNhbiB1c2UgdGhlIGBsZXZlbHNgIG9wdGlvbiB0byBjdXN0b21pemUgd2hpY2hcbiAqIGxldmVscyBhcmUgY2FwdHVyZWQuXG4gKlxuICogQGV4YW1wbGVcbiAqXG4gKiBgYGBqc1xuICogU2VudHJ5LmluaXQoe1xuICogICBpbnRlZ3JhdGlvbnM6IFtTZW50cnkuY29uc29sZUludGVncmF0aW9uKHsgbGV2ZWxzOiBbJ2Vycm9yJywgJ3dhcm4nXSB9KV0sXG4gKiB9KTtcbiAqIGBgYFxuICovXG5jb25zdCBjb25zb2xlSW50ZWdyYXRpb24gPSBpbnRlZ3JhdGlvbi5kZWZpbmVJbnRlZ3JhdGlvbigob3B0aW9ucyA9IHt9KSA9PiB7XG4gIGNvbnN0IGxldmVscyA9IG5ldyBTZXQob3B0aW9ucy5sZXZlbHMgfHwgZGVidWdMb2dnZXIuQ09OU09MRV9MRVZFTFMpO1xuXG4gIHJldHVybiB7XG4gICAgbmFtZTogSU5URUdSQVRJT05fTkFNRSxcbiAgICBzZXR1cChjbGllbnQpIHtcbiAgICAgIGNvbnNvbGUuYWRkQ29uc29sZUluc3RydW1lbnRhdGlvbkhhbmRsZXIoKHsgYXJncywgbGV2ZWwgfSkgPT4ge1xuICAgICAgICBpZiAoY3VycmVudFNjb3Blcy5nZXRDbGllbnQoKSAhPT0gY2xpZW50IHx8ICFsZXZlbHMuaGFzKGxldmVsKSkge1xuICAgICAgICAgIHJldHVybjtcbiAgICAgICAgfVxuXG4gICAgICAgIGFkZENvbnNvbGVCcmVhZGNydW1iKGxldmVsLCBhcmdzKTtcbiAgICAgIH0pO1xuICAgIH0sXG4gIH07XG59KTtcblxuLyoqXG4gKiBDYXB0dXJlIGEgY29uc29sZSBicmVhZGNydW1iLlxuICpcbiAqIEV4cG9ydGVkIGp1c3QgZm9yIHRlc3RzLlxuICovXG5mdW5jdGlvbiBhZGRDb25zb2xlQnJlYWRjcnVtYihsZXZlbCwgYXJncykge1xuICBjb25zdCBicmVhZGNydW1iID0ge1xuICAgIGNhdGVnb3J5OiAnY29uc29sZScsXG4gICAgZGF0YToge1xuICAgICAgYXJndW1lbnRzOiBhcmdzLFxuICAgICAgbG9nZ2VyOiAnY29uc29sZScsXG4gICAgfSxcbiAgICBsZXZlbDogc2V2ZXJpdHkuc2V2ZXJpdHlMZXZlbEZyb21TdHJpbmcobGV2ZWwpLFxuICAgIG1lc3NhZ2U6IGZvcm1hdENvbnNvbGVBcmdzKGFyZ3MpLFxuICB9O1xuXG4gIGlmIChsZXZlbCA9PT0gJ2Fzc2VydCcpIHtcbiAgICBpZiAoYXJnc1swXSA9PT0gZmFsc2UpIHtcbiAgICAgIGNvbnN0IGFzc2VydGlvbkFyZ3MgPSBhcmdzLnNsaWNlKDEpO1xuICAgICAgYnJlYWRjcnVtYi5tZXNzYWdlID1cbiAgICAgICAgYXNzZXJ0aW9uQXJncy5sZW5ndGggPiAwID8gYEFzc2VydGlvbiBmYWlsZWQ6ICR7Zm9ybWF0Q29uc29sZUFyZ3MoYXNzZXJ0aW9uQXJncyl9YCA6ICdBc3NlcnRpb24gZmFpbGVkJztcbiAgICAgIGJyZWFkY3J1bWIuZGF0YS5hcmd1bWVudHMgPSBhc3NlcnRpb25BcmdzO1xuICAgIH0gZWxzZSB7XG4gICAgICAvLyBEb24ndCBjYXB0dXJlIGEgYnJlYWRjcnVtYiBmb3IgcGFzc2VkIGFzc2VydGlvbnNcbiAgICAgIHJldHVybjtcbiAgICB9XG4gIH1cblxuICBicmVhZGNydW1icy5hZGRCcmVhZGNydW1iKGJyZWFkY3J1bWIsIHtcbiAgICBpbnB1dDogYXJncyxcbiAgICBsZXZlbCxcbiAgfSk7XG59XG5cbmZ1bmN0aW9uIGZvcm1hdENvbnNvbGVBcmdzKHZhbHVlcykge1xuICByZXR1cm4gJ3V0aWwnIGluIHdvcmxkd2lkZS5HTE9CQUxfT0JKICYmIHR5cGVvZiAod29ybGR3aWRlLkdMT0JBTF9PQkogKS51dGlsLmZvcm1hdCA9PT0gJ2Z1bmN0aW9uJ1xuICAgID8gKHdvcmxkd2lkZS5HTE9CQUxfT0JKICkudXRpbC5mb3JtYXQoLi4udmFsdWVzKVxuICAgIDogc3RyaW5nLnNhZmVKb2luKHZhbHVlcywgJyAnKTtcbn1cblxuZXhwb3J0cy5hZGRDb25zb2xlQnJlYWRjcnVtYiA9IGFkZENvbnNvbGVCcmVhZGNydW1iO1xuZXhwb3J0cy5jb25zb2xlSW50ZWdyYXRpb24gPSBjb25zb2xlSW50ZWdyYXRpb247XG4vLyMgc291cmNlTWFwcGluZ1VSTD1jb25zb2xlLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/console.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/dedupe.js":
/*!***********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/dedupe.js ***!
  \***********************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst debugBuild = __webpack_require__(/*! ../debug-build.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst integration = __webpack_require__(/*! ../integration.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integration.js\");\nconst debugLogger = __webpack_require__(/*! ../utils/debug-logger.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst stacktrace = __webpack_require__(/*! ../utils/stacktrace.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/stacktrace.js\");\n\nconst INTEGRATION_NAME = 'Dedupe';\n\nconst _dedupeIntegration = (() => {\n  let previousEvent;\n\n  return {\n    name: INTEGRATION_NAME,\n    processEvent(currentEvent) {\n      // We want to ignore any non-error type events, e.g. transactions or replays\n      // These should never be deduped, and also not be compared against as _previousEvent.\n      if (currentEvent.type) {\n        return currentEvent;\n      }\n\n      // Juuust in case something goes wrong\n      try {\n        if (_shouldDropEvent(currentEvent, previousEvent)) {\n          debugBuild.DEBUG_BUILD && debugLogger.debug.warn('Event dropped due to being a duplicate of previously captured event.');\n          return null;\n        }\n      } catch {} // eslint-disable-line no-empty\n\n      return (previousEvent = currentEvent);\n    },\n  };\n}) ;\n\n/**\n * Deduplication filter.\n */\nconst dedupeIntegration = integration.defineIntegration(_dedupeIntegration);\n\n/** only exported for tests. */\nfunction _shouldDropEvent(currentEvent, previousEvent) {\n  if (!previousEvent) {\n    return false;\n  }\n\n  if (_isSameMessageEvent(currentEvent, previousEvent)) {\n    return true;\n  }\n\n  if (_isSameExceptionEvent(currentEvent, previousEvent)) {\n    return true;\n  }\n\n  return false;\n}\n\nfunction _isSameMessageEvent(currentEvent, previousEvent) {\n  const currentMessage = currentEvent.message;\n  const previousMessage = previousEvent.message;\n\n  // If neither event has a message property, they were both exceptions, so bail out\n  if (!currentMessage && !previousMessage) {\n    return false;\n  }\n\n  // If only one event has a stacktrace, but not the other one, they are not the same\n  if ((currentMessage && !previousMessage) || (!currentMessage && previousMessage)) {\n    return false;\n  }\n\n  if (currentMessage !== previousMessage) {\n    return false;\n  }\n\n  if (!_isSameFingerprint(currentEvent, previousEvent)) {\n    return false;\n  }\n\n  if (!_isSameStacktrace(currentEvent, previousEvent)) {\n    return false;\n  }\n\n  return true;\n}\n\nfunction _isSameExceptionEvent(currentEvent, previousEvent) {\n  const previousException = _getExceptionFromEvent(previousEvent);\n  const currentException = _getExceptionFromEvent(currentEvent);\n\n  if (!previousException || !currentException) {\n    return false;\n  }\n\n  if (previousException.type !== currentException.type || previousException.value !== currentException.value) {\n    return false;\n  }\n\n  if (!_isSameFingerprint(currentEvent, previousEvent)) {\n    return false;\n  }\n\n  if (!_isSameStacktrace(currentEvent, previousEvent)) {\n    return false;\n  }\n\n  return true;\n}\n\nfunction _isSameStacktrace(currentEvent, previousEvent) {\n  let currentFrames = stacktrace.getFramesFromEvent(currentEvent);\n  let previousFrames = stacktrace.getFramesFromEvent(previousEvent);\n\n  // If neither event has a stacktrace, they are assumed to be the same\n  if (!currentFrames && !previousFrames) {\n    return true;\n  }\n\n  // If only one event has a stacktrace, but not the other one, they are not the same\n  if ((currentFrames && !previousFrames) || (!currentFrames && previousFrames)) {\n    return false;\n  }\n\n  currentFrames = currentFrames ;\n  previousFrames = previousFrames ;\n\n  // If number of frames differ, they are not the same\n  if (previousFrames.length !== currentFrames.length) {\n    return false;\n  }\n\n  // Otherwise, compare the two\n  for (let i = 0; i < previousFrames.length; i++) {\n    // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n    const frameA = previousFrames[i];\n    // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n    const frameB = currentFrames[i];\n\n    if (\n      frameA.filename !== frameB.filename ||\n      frameA.lineno !== frameB.lineno ||\n      frameA.colno !== frameB.colno ||\n      frameA.function !== frameB.function\n    ) {\n      return false;\n    }\n  }\n\n  return true;\n}\n\nfunction _isSameFingerprint(currentEvent, previousEvent) {\n  let currentFingerprint = currentEvent.fingerprint;\n  let previousFingerprint = previousEvent.fingerprint;\n\n  // If neither event has a fingerprint, they are assumed to be the same\n  if (!currentFingerprint && !previousFingerprint) {\n    return true;\n  }\n\n  // If only one event has a fingerprint, but not the other one, they are not the same\n  if ((currentFingerprint && !previousFingerprint) || (!currentFingerprint && previousFingerprint)) {\n    return false;\n  }\n\n  currentFingerprint = currentFingerprint ;\n  previousFingerprint = previousFingerprint ;\n\n  // Otherwise, compare the two\n  try {\n    return !!(currentFingerprint.join('') === previousFingerprint.join(''));\n  } catch {\n    return false;\n  }\n}\n\nfunction _getExceptionFromEvent(event) {\n  return event.exception?.values?.[0];\n}\n\nexports._shouldDropEvent = _shouldDropEvent;\nexports.dedupeIntegration = dedupeIntegration;\n//# sourceMappingURL=dedupe.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvZGVkdXBlLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLG1CQUFtQixtQkFBTyxDQUFDLDRIQUFtQjtBQUM5QyxvQkFBb0IsbUJBQU8sQ0FBQyw0SEFBbUI7QUFDL0Msb0JBQW9CLG1CQUFPLENBQUMsMElBQTBCO0FBQ3RELG1CQUFtQixtQkFBTyxDQUFDLHNJQUF3Qjs7QUFFbkQ7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFFBQVEsU0FBUzs7QUFFakI7QUFDQSxLQUFLO0FBQ0w7QUFDQSxDQUFDOztBQUVEO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBLGtCQUFrQiwyQkFBMkI7QUFDN0M7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0EsSUFBSTtBQUNKO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUEsd0JBQXdCO0FBQ3hCLHlCQUF5QjtBQUN6QiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL2ludGVncmF0aW9ucy9kZWR1cGUuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGRlYnVnQnVpbGQgPSByZXF1aXJlKCcuLi9kZWJ1Zy1idWlsZC5qcycpO1xuY29uc3QgaW50ZWdyYXRpb24gPSByZXF1aXJlKCcuLi9pbnRlZ3JhdGlvbi5qcycpO1xuY29uc3QgZGVidWdMb2dnZXIgPSByZXF1aXJlKCcuLi91dGlscy9kZWJ1Zy1sb2dnZXIuanMnKTtcbmNvbnN0IHN0YWNrdHJhY2UgPSByZXF1aXJlKCcuLi91dGlscy9zdGFja3RyYWNlLmpzJyk7XG5cbmNvbnN0IElOVEVHUkFUSU9OX05BTUUgPSAnRGVkdXBlJztcblxuY29uc3QgX2RlZHVwZUludGVncmF0aW9uID0gKCgpID0+IHtcbiAgbGV0IHByZXZpb3VzRXZlbnQ7XG5cbiAgcmV0dXJuIHtcbiAgICBuYW1lOiBJTlRFR1JBVElPTl9OQU1FLFxuICAgIHByb2Nlc3NFdmVudChjdXJyZW50RXZlbnQpIHtcbiAgICAgIC8vIFdlIHdhbnQgdG8gaWdub3JlIGFueSBub24tZXJyb3IgdHlwZSBldmVudHMsIGUuZy4gdHJhbnNhY3Rpb25zIG9yIHJlcGxheXNcbiAgICAgIC8vIFRoZXNlIHNob3VsZCBuZXZlciBiZSBkZWR1cGVkLCBhbmQgYWxzbyBub3QgYmUgY29tcGFyZWQgYWdhaW5zdCBhcyBfcHJldmlvdXNFdmVudC5cbiAgICAgIGlmIChjdXJyZW50RXZlbnQudHlwZSkge1xuICAgICAgICByZXR1cm4gY3VycmVudEV2ZW50O1xuICAgICAgfVxuXG4gICAgICAvLyBKdXV1c3QgaW4gY2FzZSBzb21ldGhpbmcgZ29lcyB3cm9uZ1xuICAgICAgdHJ5IHtcbiAgICAgICAgaWYgKF9zaG91bGREcm9wRXZlbnQoY3VycmVudEV2ZW50LCBwcmV2aW91c0V2ZW50KSkge1xuICAgICAgICAgIGRlYnVnQnVpbGQuREVCVUdfQlVJTEQgJiYgZGVidWdMb2dnZXIuZGVidWcud2FybignRXZlbnQgZHJvcHBlZCBkdWUgdG8gYmVpbmcgYSBkdXBsaWNhdGUgb2YgcHJldmlvdXNseSBjYXB0dXJlZCBldmVudC4nKTtcbiAgICAgICAgICByZXR1cm4gbnVsbDtcbiAgICAgICAgfVxuICAgICAgfSBjYXRjaCB7fSAvLyBlc2xpbnQtZGlzYWJsZS1saW5lIG5vLWVtcHR5XG5cbiAgICAgIHJldHVybiAocHJldmlvdXNFdmVudCA9IGN1cnJlbnRFdmVudCk7XG4gICAgfSxcbiAgfTtcbn0pIDtcblxuLyoqXG4gKiBEZWR1cGxpY2F0aW9uIGZpbHRlci5cbiAqL1xuY29uc3QgZGVkdXBlSW50ZWdyYXRpb24gPSBpbnRlZ3JhdGlvbi5kZWZpbmVJbnRlZ3JhdGlvbihfZGVkdXBlSW50ZWdyYXRpb24pO1xuXG4vKiogb25seSBleHBvcnRlZCBmb3IgdGVzdHMuICovXG5mdW5jdGlvbiBfc2hvdWxkRHJvcEV2ZW50KGN1cnJlbnRFdmVudCwgcHJldmlvdXNFdmVudCkge1xuICBpZiAoIXByZXZpb3VzRXZlbnQpIHtcbiAgICByZXR1cm4gZmFsc2U7XG4gIH1cblxuICBpZiAoX2lzU2FtZU1lc3NhZ2VFdmVudChjdXJyZW50RXZlbnQsIHByZXZpb3VzRXZlbnQpKSB7XG4gICAgcmV0dXJuIHRydWU7XG4gIH1cblxuICBpZiAoX2lzU2FtZUV4Y2VwdGlvbkV2ZW50KGN1cnJlbnRFdmVudCwgcHJldmlvdXNFdmVudCkpIHtcbiAgICByZXR1cm4gdHJ1ZTtcbiAgfVxuXG4gIHJldHVybiBmYWxzZTtcbn1cblxuZnVuY3Rpb24gX2lzU2FtZU1lc3NhZ2VFdmVudChjdXJyZW50RXZlbnQsIHByZXZpb3VzRXZlbnQpIHtcbiAgY29uc3QgY3VycmVudE1lc3NhZ2UgPSBjdXJyZW50RXZlbnQubWVzc2FnZTtcbiAgY29uc3QgcHJldmlvdXNNZXNzYWdlID0gcHJldmlvdXNFdmVudC5tZXNzYWdlO1xuXG4gIC8vIElmIG5laXRoZXIgZXZlbnQgaGFzIGEgbWVzc2FnZSBwcm9wZXJ0eSwgdGhleSB3ZXJlIGJvdGggZXhjZXB0aW9ucywgc28gYmFpbCBvdXRcbiAgaWYgKCFjdXJyZW50TWVzc2FnZSAmJiAhcHJldmlvdXNNZXNzYWdlKSB7XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG5cbiAgLy8gSWYgb25seSBvbmUgZXZlbnQgaGFzIGEgc3RhY2t0cmFjZSwgYnV0IG5vdCB0aGUgb3RoZXIgb25lLCB0aGV5IGFyZSBub3QgdGhlIHNhbWVcbiAgaWYgKChjdXJyZW50TWVzc2FnZSAmJiAhcHJldmlvdXNNZXNzYWdlKSB8fCAoIWN1cnJlbnRNZXNzYWdlICYmIHByZXZpb3VzTWVzc2FnZSkpIHtcbiAgICByZXR1cm4gZmFsc2U7XG4gIH1cblxuICBpZiAoY3VycmVudE1lc3NhZ2UgIT09IHByZXZpb3VzTWVzc2FnZSkge1xuICAgIHJldHVybiBmYWxzZTtcbiAgfVxuXG4gIGlmICghX2lzU2FtZUZpbmdlcnByaW50KGN1cnJlbnRFdmVudCwgcHJldmlvdXNFdmVudCkpIHtcbiAgICByZXR1cm4gZmFsc2U7XG4gIH1cblxuICBpZiAoIV9pc1NhbWVTdGFja3RyYWNlKGN1cnJlbnRFdmVudCwgcHJldmlvdXNFdmVudCkpIHtcbiAgICByZXR1cm4gZmFsc2U7XG4gIH1cblxuICByZXR1cm4gdHJ1ZTtcbn1cblxuZnVuY3Rpb24gX2lzU2FtZUV4Y2VwdGlvbkV2ZW50KGN1cnJlbnRFdmVudCwgcHJldmlvdXNFdmVudCkge1xuICBjb25zdCBwcmV2aW91c0V4Y2VwdGlvbiA9IF9nZXRFeGNlcHRpb25Gcm9tRXZlbnQocHJldmlvdXNFdmVudCk7XG4gIGNvbnN0IGN1cnJlbnRFeGNlcHRpb24gPSBfZ2V0RXhjZXB0aW9uRnJvbUV2ZW50KGN1cnJlbnRFdmVudCk7XG5cbiAgaWYgKCFwcmV2aW91c0V4Y2VwdGlvbiB8fCAhY3VycmVudEV4Y2VwdGlvbikge1xuICAgIHJldHVybiBmYWxzZTtcbiAgfVxuXG4gIGlmIChwcmV2aW91c0V4Y2VwdGlvbi50eXBlICE9PSBjdXJyZW50RXhjZXB0aW9uLnR5cGUgfHwgcHJldmlvdXNFeGNlcHRpb24udmFsdWUgIT09IGN1cnJlbnRFeGNlcHRpb24udmFsdWUpIHtcbiAgICByZXR1cm4gZmFsc2U7XG4gIH1cblxuICBpZiAoIV9pc1NhbWVGaW5nZXJwcmludChjdXJyZW50RXZlbnQsIHByZXZpb3VzRXZlbnQpKSB7XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG5cbiAgaWYgKCFfaXNTYW1lU3RhY2t0cmFjZShjdXJyZW50RXZlbnQsIHByZXZpb3VzRXZlbnQpKSB7XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG5cbiAgcmV0dXJuIHRydWU7XG59XG5cbmZ1bmN0aW9uIF9pc1NhbWVTdGFja3RyYWNlKGN1cnJlbnRFdmVudCwgcHJldmlvdXNFdmVudCkge1xuICBsZXQgY3VycmVudEZyYW1lcyA9IHN0YWNrdHJhY2UuZ2V0RnJhbWVzRnJvbUV2ZW50KGN1cnJlbnRFdmVudCk7XG4gIGxldCBwcmV2aW91c0ZyYW1lcyA9IHN0YWNrdHJhY2UuZ2V0RnJhbWVzRnJvbUV2ZW50KHByZXZpb3VzRXZlbnQpO1xuXG4gIC8vIElmIG5laXRoZXIgZXZlbnQgaGFzIGEgc3RhY2t0cmFjZSwgdGhleSBhcmUgYXNzdW1lZCB0byBiZSB0aGUgc2FtZVxuICBpZiAoIWN1cnJlbnRGcmFtZXMgJiYgIXByZXZpb3VzRnJhbWVzKSB7XG4gICAgcmV0dXJuIHRydWU7XG4gIH1cblxuICAvLyBJZiBvbmx5IG9uZSBldmVudCBoYXMgYSBzdGFja3RyYWNlLCBidXQgbm90IHRoZSBvdGhlciBvbmUsIHRoZXkgYXJlIG5vdCB0aGUgc2FtZVxuICBpZiAoKGN1cnJlbnRGcmFtZXMgJiYgIXByZXZpb3VzRnJhbWVzKSB8fCAoIWN1cnJlbnRGcmFtZXMgJiYgcHJldmlvdXNGcmFtZXMpKSB7XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG5cbiAgY3VycmVudEZyYW1lcyA9IGN1cnJlbnRGcmFtZXMgO1xuICBwcmV2aW91c0ZyYW1lcyA9IHByZXZpb3VzRnJhbWVzIDtcblxuICAvLyBJZiBudW1iZXIgb2YgZnJhbWVzIGRpZmZlciwgdGhleSBhcmUgbm90IHRoZSBzYW1lXG4gIGlmIChwcmV2aW91c0ZyYW1lcy5sZW5ndGggIT09IGN1cnJlbnRGcmFtZXMubGVuZ3RoKSB7XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG5cbiAgLy8gT3RoZXJ3aXNlLCBjb21wYXJlIHRoZSB0d29cbiAgZm9yIChsZXQgaSA9IDA7IGkgPCBwcmV2aW91c0ZyYW1lcy5sZW5ndGg7IGkrKykge1xuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tbm9uLW51bGwtYXNzZXJ0aW9uXG4gICAgY29uc3QgZnJhbWVBID0gcHJldmlvdXNGcmFtZXNbaV07XG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uby1ub24tbnVsbC1hc3NlcnRpb25cbiAgICBjb25zdCBmcmFtZUIgPSBjdXJyZW50RnJhbWVzW2ldO1xuXG4gICAgaWYgKFxuICAgICAgZnJhbWVBLmZpbGVuYW1lICE9PSBmcmFtZUIuZmlsZW5hbWUgfHxcbiAgICAgIGZyYW1lQS5saW5lbm8gIT09IGZyYW1lQi5saW5lbm8gfHxcbiAgICAgIGZyYW1lQS5jb2xubyAhPT0gZnJhbWVCLmNvbG5vIHx8XG4gICAgICBmcmFtZUEuZnVuY3Rpb24gIT09IGZyYW1lQi5mdW5jdGlvblxuICAgICkge1xuICAgICAgcmV0dXJuIGZhbHNlO1xuICAgIH1cbiAgfVxuXG4gIHJldHVybiB0cnVlO1xufVxuXG5mdW5jdGlvbiBfaXNTYW1lRmluZ2VycHJpbnQoY3VycmVudEV2ZW50LCBwcmV2aW91c0V2ZW50KSB7XG4gIGxldCBjdXJyZW50RmluZ2VycHJpbnQgPSBjdXJyZW50RXZlbnQuZmluZ2VycHJpbnQ7XG4gIGxldCBwcmV2aW91c0ZpbmdlcnByaW50ID0gcHJldmlvdXNFdmVudC5maW5nZXJwcmludDtcblxuICAvLyBJZiBuZWl0aGVyIGV2ZW50IGhhcyBhIGZpbmdlcnByaW50LCB0aGV5IGFyZSBhc3N1bWVkIHRvIGJlIHRoZSBzYW1lXG4gIGlmICghY3VycmVudEZpbmdlcnByaW50ICYmICFwcmV2aW91c0ZpbmdlcnByaW50KSB7XG4gICAgcmV0dXJuIHRydWU7XG4gIH1cblxuICAvLyBJZiBvbmx5IG9uZSBldmVudCBoYXMgYSBmaW5nZXJwcmludCwgYnV0IG5vdCB0aGUgb3RoZXIgb25lLCB0aGV5IGFyZSBub3QgdGhlIHNhbWVcbiAgaWYgKChjdXJyZW50RmluZ2VycHJpbnQgJiYgIXByZXZpb3VzRmluZ2VycHJpbnQpIHx8ICghY3VycmVudEZpbmdlcnByaW50ICYmIHByZXZpb3VzRmluZ2VycHJpbnQpKSB7XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG5cbiAgY3VycmVudEZpbmdlcnByaW50ID0gY3VycmVudEZpbmdlcnByaW50IDtcbiAgcHJldmlvdXNGaW5nZXJwcmludCA9IHByZXZpb3VzRmluZ2VycHJpbnQgO1xuXG4gIC8vIE90aGVyd2lzZSwgY29tcGFyZSB0aGUgdHdvXG4gIHRyeSB7XG4gICAgcmV0dXJuICEhKGN1cnJlbnRGaW5nZXJwcmludC5qb2luKCcnKSA9PT0gcHJldmlvdXNGaW5nZXJwcmludC5qb2luKCcnKSk7XG4gIH0gY2F0Y2gge1xuICAgIHJldHVybiBmYWxzZTtcbiAgfVxufVxuXG5mdW5jdGlvbiBfZ2V0RXhjZXB0aW9uRnJvbUV2ZW50KGV2ZW50KSB7XG4gIHJldHVybiBldmVudC5leGNlcHRpb24/LnZhbHVlcz8uWzBdO1xufVxuXG5leHBvcnRzLl9zaG91bGREcm9wRXZlbnQgPSBfc2hvdWxkRHJvcEV2ZW50O1xuZXhwb3J0cy5kZWR1cGVJbnRlZ3JhdGlvbiA9IGRlZHVwZUludGVncmF0aW9uO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9ZGVkdXBlLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/dedupe.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/eventFilters.js":
/*!*****************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/eventFilters.js ***!
  \*****************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst debugBuild = __webpack_require__(/*! ../debug-build.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst integration = __webpack_require__(/*! ../integration.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integration.js\");\nconst debugLogger = __webpack_require__(/*! ../utils/debug-logger.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst eventUtils = __webpack_require__(/*! ../utils/eventUtils.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/eventUtils.js\");\nconst misc = __webpack_require__(/*! ../utils/misc.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/misc.js\");\nconst string = __webpack_require__(/*! ../utils/string.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/string.js\");\n\n// \"Script error.\" is hard coded into browsers for errors that it can't read.\n// this is the result of a script being pulled in from an external domain and CORS.\nconst DEFAULT_IGNORE_ERRORS = [\n  /^Script error\\.?$/,\n  /^Javascript error: Script error\\.? on line 0$/,\n  /^ResizeObserver loop completed with undelivered notifications.$/, // The browser logs this when a ResizeObserver handler takes a bit longer. Usually this is not an actual issue though. It indicates slowness.\n  /^Cannot redefine property: googletag$/, // This is thrown when google tag manager is used in combination with an ad blocker\n  /^Can't find variable: gmo$/, // Error from Google Search App https://issuetracker.google.com/issues/396043331\n  /^undefined is not an object \\(evaluating 'a\\.[A-Z]'\\)$/, // Random error that happens but not actionable or noticeable to end-users.\n  'can\\'t redefine non-configurable property \"solana\"', // Probably a browser extension or custom browser (Brave) throwing this error\n  \"vv().getRestrictions is not a function. (In 'vv().getRestrictions(1,a)', 'vv().getRestrictions' is undefined)\", // Error thrown by GTM, seemingly not affecting end-users\n  \"Can't find variable: _AutofillCallbackHandler\", // Unactionable error in instagram webview https://developers.facebook.com/community/threads/320013549791141/\n  /^Non-Error promise rejection captured with value: Object Not Found Matching Id:\\d+, MethodName:simulateEvent, ParamCount:\\d+$/, // unactionable error from CEFSharp, a .NET library that embeds chromium in .NET apps\n  /^Java exception was raised during method invocation$/, // error from Facebook Mobile browser (https://github.com/getsentry/sentry-javascript/issues/15065)\n];\n\n/** Options for the EventFilters integration */\n\nconst INTEGRATION_NAME = 'EventFilters';\n\n/**\n * An integration that filters out events (errors and transactions) based on:\n *\n * - (Errors) A curated list of known low-value or irrelevant errors (see {@link DEFAULT_IGNORE_ERRORS})\n * - (Errors) A list of error messages or urls/filenames passed in via\n *   - Top level Sentry.init options (`ignoreErrors`, `denyUrls`, `allowUrls`)\n *   - The same options passed to the integration directly via @param options\n * - (Transactions/Spans) A list of root span (transaction) names passed in via\n *   - Top level Sentry.init option (`ignoreTransactions`)\n *   - The same option passed to the integration directly via @param options\n *\n * Events filtered by this integration will not be sent to Sentry.\n */\nconst eventFiltersIntegration = integration.defineIntegration((options = {}) => {\n  let mergedOptions;\n  return {\n    name: INTEGRATION_NAME,\n    setup(client) {\n      const clientOptions = client.getOptions();\n      mergedOptions = _mergeOptions(options, clientOptions);\n    },\n    processEvent(event, _hint, client) {\n      if (!mergedOptions) {\n        const clientOptions = client.getOptions();\n        mergedOptions = _mergeOptions(options, clientOptions);\n      }\n      return _shouldDropEvent(event, mergedOptions) ? null : event;\n    },\n  };\n});\n\n/**\n * An integration that filters out events (errors and transactions) based on:\n *\n * - (Errors) A curated list of known low-value or irrelevant errors (see {@link DEFAULT_IGNORE_ERRORS})\n * - (Errors) A list of error messages or urls/filenames passed in via\n *   - Top level Sentry.init options (`ignoreErrors`, `denyUrls`, `allowUrls`)\n *   - The same options passed to the integration directly via @param options\n * - (Transactions/Spans) A list of root span (transaction) names passed in via\n *   - Top level Sentry.init option (`ignoreTransactions`)\n *   - The same option passed to the integration directly via @param options\n *\n * Events filtered by this integration will not be sent to Sentry.\n *\n * @deprecated this integration was renamed and will be removed in a future major version.\n * Use `eventFiltersIntegration` instead.\n */\nconst inboundFiltersIntegration = integration.defineIntegration(((options = {}) => {\n  return {\n    ...eventFiltersIntegration(options),\n    name: 'InboundFilters',\n  };\n}) );\n\nfunction _mergeOptions(\n  internalOptions = {},\n  clientOptions = {},\n) {\n  return {\n    allowUrls: [...(internalOptions.allowUrls || []), ...(clientOptions.allowUrls || [])],\n    denyUrls: [...(internalOptions.denyUrls || []), ...(clientOptions.denyUrls || [])],\n    ignoreErrors: [\n      ...(internalOptions.ignoreErrors || []),\n      ...(clientOptions.ignoreErrors || []),\n      ...(internalOptions.disableErrorDefaults ? [] : DEFAULT_IGNORE_ERRORS),\n    ],\n    ignoreTransactions: [...(internalOptions.ignoreTransactions || []), ...(clientOptions.ignoreTransactions || [])],\n  };\n}\n\nfunction _shouldDropEvent(event, options) {\n  if (!event.type) {\n    // Filter errors\n    if (_isIgnoredError(event, options.ignoreErrors)) {\n      debugBuild.DEBUG_BUILD &&\n        debugLogger.debug.warn(\n          `Event dropped due to being matched by \\`ignoreErrors\\` option.\\nEvent: ${misc.getEventDescription(event)}`,\n        );\n      return true;\n    }\n    if (_isUselessError(event)) {\n      debugBuild.DEBUG_BUILD &&\n        debugLogger.debug.warn(\n          `Event dropped due to not having an error message, error type or stacktrace.\\nEvent: ${misc.getEventDescription(\n            event,\n          )}`,\n        );\n      return true;\n    }\n    if (_isDeniedUrl(event, options.denyUrls)) {\n      debugBuild.DEBUG_BUILD &&\n        debugLogger.debug.warn(\n          `Event dropped due to being matched by \\`denyUrls\\` option.\\nEvent: ${misc.getEventDescription(\n            event,\n          )}.\\nUrl: ${_getEventFilterUrl(event)}`,\n        );\n      return true;\n    }\n    if (!_isAllowedUrl(event, options.allowUrls)) {\n      debugBuild.DEBUG_BUILD &&\n        debugLogger.debug.warn(\n          `Event dropped due to not being matched by \\`allowUrls\\` option.\\nEvent: ${misc.getEventDescription(\n            event,\n          )}.\\nUrl: ${_getEventFilterUrl(event)}`,\n        );\n      return true;\n    }\n  } else if (event.type === 'transaction') {\n    // Filter transactions\n\n    if (_isIgnoredTransaction(event, options.ignoreTransactions)) {\n      debugBuild.DEBUG_BUILD &&\n        debugLogger.debug.warn(\n          `Event dropped due to being matched by \\`ignoreTransactions\\` option.\\nEvent: ${misc.getEventDescription(event)}`,\n        );\n      return true;\n    }\n  }\n  return false;\n}\n\nfunction _isIgnoredError(event, ignoreErrors) {\n  if (!ignoreErrors?.length) {\n    return false;\n  }\n\n  return eventUtils.getPossibleEventMessages(event).some(message => string.stringMatchesSomePattern(message, ignoreErrors));\n}\n\nfunction _isIgnoredTransaction(event, ignoreTransactions) {\n  if (!ignoreTransactions?.length) {\n    return false;\n  }\n\n  const name = event.transaction;\n  return name ? string.stringMatchesSomePattern(name, ignoreTransactions) : false;\n}\n\nfunction _isDeniedUrl(event, denyUrls) {\n  if (!denyUrls?.length) {\n    return false;\n  }\n  const url = _getEventFilterUrl(event);\n  return !url ? false : string.stringMatchesSomePattern(url, denyUrls);\n}\n\nfunction _isAllowedUrl(event, allowUrls) {\n  if (!allowUrls?.length) {\n    return true;\n  }\n  const url = _getEventFilterUrl(event);\n  return !url ? true : string.stringMatchesSomePattern(url, allowUrls);\n}\n\nfunction _getLastValidUrl(frames = []) {\n  for (let i = frames.length - 1; i >= 0; i--) {\n    const frame = frames[i];\n\n    if (frame && frame.filename !== '<anonymous>' && frame.filename !== '[native code]') {\n      return frame.filename || null;\n    }\n  }\n\n  return null;\n}\n\nfunction _getEventFilterUrl(event) {\n  try {\n    // If there are linked exceptions or exception aggregates we only want to match against the top frame of the \"root\" (the main exception)\n    // The root always comes last in linked exceptions\n    const rootException = [...(event.exception?.values ?? [])]\n      .reverse()\n      .find(value => value.mechanism?.parent_id === undefined && value.stacktrace?.frames?.length);\n    const frames = rootException?.stacktrace?.frames;\n    return frames ? _getLastValidUrl(frames) : null;\n  } catch {\n    debugBuild.DEBUG_BUILD && debugLogger.debug.error(`Cannot extract url for event ${misc.getEventDescription(event)}`);\n    return null;\n  }\n}\n\nfunction _isUselessError(event) {\n  // We only want to consider events for dropping that actually have recorded exception values.\n  if (!event.exception?.values?.length) {\n    return false;\n  }\n\n  return (\n    // No top-level message\n    !event.message &&\n    // There are no exception values that have a stacktrace, a non-generic-Error type or value\n    !event.exception.values.some(value => value.stacktrace || (value.type && value.type !== 'Error') || value.value)\n  );\n}\n\nexports.eventFiltersIntegration = eventFiltersIntegration;\nexports.inboundFiltersIntegration = inboundFiltersIntegration;\n//# sourceMappingURL=eventFilters.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvZXZlbnRGaWx0ZXJzLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLG1CQUFtQixtQkFBTyxDQUFDLDRIQUFtQjtBQUM5QyxvQkFBb0IsbUJBQU8sQ0FBQyw0SEFBbUI7QUFDL0Msb0JBQW9CLG1CQUFPLENBQUMsMElBQTBCO0FBQ3RELG1CQUFtQixtQkFBTyxDQUFDLHNJQUF3QjtBQUNuRCxhQUFhLG1CQUFPLENBQUMsMEhBQWtCO0FBQ3ZDLGVBQWUsbUJBQU8sQ0FBQyw4SEFBb0I7O0FBRTNDO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQSwyRUFBMkUsNEJBQTRCO0FBQ3ZHO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLDJFQUEyRTtBQUMzRTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxLQUFLO0FBQ0w7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsS0FBSztBQUNMO0FBQ0EsQ0FBQzs7QUFFRDtBQUNBO0FBQ0E7QUFDQSwyRUFBMkUsNEJBQTRCO0FBQ3ZHO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLDhFQUE4RTtBQUM5RTtBQUNBO0FBQ0E7QUFDQTtBQUNBLENBQUM7O0FBRUQ7QUFDQSxzQkFBc0I7QUFDdEIsb0JBQW9CO0FBQ3BCO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxvRkFBb0YsZ0NBQWdDO0FBQ3BIO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGlHQUFpRztBQUNqRztBQUNBLFlBQVk7QUFDWjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxnRkFBZ0Y7QUFDaEY7QUFDQSxZQUFZLFVBQVUsMEJBQTBCO0FBQ2hEO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLHFGQUFxRjtBQUNyRjtBQUNBLFlBQVksVUFBVSwwQkFBMEI7QUFDaEQ7QUFDQTtBQUNBO0FBQ0EsSUFBSTtBQUNKOztBQUVBO0FBQ0E7QUFDQTtBQUNBLDBGQUEwRixnQ0FBZ0M7QUFDMUg7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0Esa0NBQWtDLFFBQVE7QUFDMUM7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxJQUFJO0FBQ0osc0ZBQXNGLGdDQUFnQztBQUN0SDtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSwrQkFBK0I7QUFDL0IsaUNBQWlDO0FBQ2pDIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvaW50ZWdyYXRpb25zL2V2ZW50RmlsdGVycy5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgZGVidWdCdWlsZCA9IHJlcXVpcmUoJy4uL2RlYnVnLWJ1aWxkLmpzJyk7XG5jb25zdCBpbnRlZ3JhdGlvbiA9IHJlcXVpcmUoJy4uL2ludGVncmF0aW9uLmpzJyk7XG5jb25zdCBkZWJ1Z0xvZ2dlciA9IHJlcXVpcmUoJy4uL3V0aWxzL2RlYnVnLWxvZ2dlci5qcycpO1xuY29uc3QgZXZlbnRVdGlscyA9IHJlcXVpcmUoJy4uL3V0aWxzL2V2ZW50VXRpbHMuanMnKTtcbmNvbnN0IG1pc2MgPSByZXF1aXJlKCcuLi91dGlscy9taXNjLmpzJyk7XG5jb25zdCBzdHJpbmcgPSByZXF1aXJlKCcuLi91dGlscy9zdHJpbmcuanMnKTtcblxuLy8gXCJTY3JpcHQgZXJyb3IuXCIgaXMgaGFyZCBjb2RlZCBpbnRvIGJyb3dzZXJzIGZvciBlcnJvcnMgdGhhdCBpdCBjYW4ndCByZWFkLlxuLy8gdGhpcyBpcyB0aGUgcmVzdWx0IG9mIGEgc2NyaXB0IGJlaW5nIHB1bGxlZCBpbiBmcm9tIGFuIGV4dGVybmFsIGRvbWFpbiBhbmQgQ09SUy5cbmNvbnN0IERFRkFVTFRfSUdOT1JFX0VSUk9SUyA9IFtcbiAgL15TY3JpcHQgZXJyb3JcXC4/JC8sXG4gIC9eSmF2YXNjcmlwdCBlcnJvcjogU2NyaXB0IGVycm9yXFwuPyBvbiBsaW5lIDAkLyxcbiAgL15SZXNpemVPYnNlcnZlciBsb29wIGNvbXBsZXRlZCB3aXRoIHVuZGVsaXZlcmVkIG5vdGlmaWNhdGlvbnMuJC8sIC8vIFRoZSBicm93c2VyIGxvZ3MgdGhpcyB3aGVuIGEgUmVzaXplT2JzZXJ2ZXIgaGFuZGxlciB0YWtlcyBhIGJpdCBsb25nZXIuIFVzdWFsbHkgdGhpcyBpcyBub3QgYW4gYWN0dWFsIGlzc3VlIHRob3VnaC4gSXQgaW5kaWNhdGVzIHNsb3duZXNzLlxuICAvXkNhbm5vdCByZWRlZmluZSBwcm9wZXJ0eTogZ29vZ2xldGFnJC8sIC8vIFRoaXMgaXMgdGhyb3duIHdoZW4gZ29vZ2xlIHRhZyBtYW5hZ2VyIGlzIHVzZWQgaW4gY29tYmluYXRpb24gd2l0aCBhbiBhZCBibG9ja2VyXG4gIC9eQ2FuJ3QgZmluZCB2YXJpYWJsZTogZ21vJC8sIC8vIEVycm9yIGZyb20gR29vZ2xlIFNlYXJjaCBBcHAgaHR0cHM6Ly9pc3N1ZXRyYWNrZXIuZ29vZ2xlLmNvbS9pc3N1ZXMvMzk2MDQzMzMxXG4gIC9edW5kZWZpbmVkIGlzIG5vdCBhbiBvYmplY3QgXFwoZXZhbHVhdGluZyAnYVxcLltBLVpdJ1xcKSQvLCAvLyBSYW5kb20gZXJyb3IgdGhhdCBoYXBwZW5zIGJ1dCBub3QgYWN0aW9uYWJsZSBvciBub3RpY2VhYmxlIHRvIGVuZC11c2Vycy5cbiAgJ2NhblxcJ3QgcmVkZWZpbmUgbm9uLWNvbmZpZ3VyYWJsZSBwcm9wZXJ0eSBcInNvbGFuYVwiJywgLy8gUHJvYmFibHkgYSBicm93c2VyIGV4dGVuc2lvbiBvciBjdXN0b20gYnJvd3NlciAoQnJhdmUpIHRocm93aW5nIHRoaXMgZXJyb3JcbiAgXCJ2digpLmdldFJlc3RyaWN0aW9ucyBpcyBub3QgYSBmdW5jdGlvbi4gKEluICd2digpLmdldFJlc3RyaWN0aW9ucygxLGEpJywgJ3Z2KCkuZ2V0UmVzdHJpY3Rpb25zJyBpcyB1bmRlZmluZWQpXCIsIC8vIEVycm9yIHRocm93biBieSBHVE0sIHNlZW1pbmdseSBub3QgYWZmZWN0aW5nIGVuZC11c2Vyc1xuICBcIkNhbid0IGZpbmQgdmFyaWFibGU6IF9BdXRvZmlsbENhbGxiYWNrSGFuZGxlclwiLCAvLyBVbmFjdGlvbmFibGUgZXJyb3IgaW4gaW5zdGFncmFtIHdlYnZpZXcgaHR0cHM6Ly9kZXZlbG9wZXJzLmZhY2Vib29rLmNvbS9jb21tdW5pdHkvdGhyZWFkcy8zMjAwMTM1NDk3OTExNDEvXG4gIC9eTm9uLUVycm9yIHByb21pc2UgcmVqZWN0aW9uIGNhcHR1cmVkIHdpdGggdmFsdWU6IE9iamVjdCBOb3QgRm91bmQgTWF0Y2hpbmcgSWQ6XFxkKywgTWV0aG9kTmFtZTpzaW11bGF0ZUV2ZW50LCBQYXJhbUNvdW50OlxcZCskLywgLy8gdW5hY3Rpb25hYmxlIGVycm9yIGZyb20gQ0VGU2hhcnAsIGEgLk5FVCBsaWJyYXJ5IHRoYXQgZW1iZWRzIGNocm9taXVtIGluIC5ORVQgYXBwc1xuICAvXkphdmEgZXhjZXB0aW9uIHdhcyByYWlzZWQgZHVyaW5nIG1ldGhvZCBpbnZvY2F0aW9uJC8sIC8vIGVycm9yIGZyb20gRmFjZWJvb2sgTW9iaWxlIGJyb3dzZXIgKGh0dHBzOi8vZ2l0aHViLmNvbS9nZXRzZW50cnkvc2VudHJ5LWphdmFzY3JpcHQvaXNzdWVzLzE1MDY1KVxuXTtcblxuLyoqIE9wdGlvbnMgZm9yIHRoZSBFdmVudEZpbHRlcnMgaW50ZWdyYXRpb24gKi9cblxuY29uc3QgSU5URUdSQVRJT05fTkFNRSA9ICdFdmVudEZpbHRlcnMnO1xuXG4vKipcbiAqIEFuIGludGVncmF0aW9uIHRoYXQgZmlsdGVycyBvdXQgZXZlbnRzIChlcnJvcnMgYW5kIHRyYW5zYWN0aW9ucykgYmFzZWQgb246XG4gKlxuICogLSAoRXJyb3JzKSBBIGN1cmF0ZWQgbGlzdCBvZiBrbm93biBsb3ctdmFsdWUgb3IgaXJyZWxldmFudCBlcnJvcnMgKHNlZSB7QGxpbmsgREVGQVVMVF9JR05PUkVfRVJST1JTfSlcbiAqIC0gKEVycm9ycykgQSBsaXN0IG9mIGVycm9yIG1lc3NhZ2VzIG9yIHVybHMvZmlsZW5hbWVzIHBhc3NlZCBpbiB2aWFcbiAqICAgLSBUb3AgbGV2ZWwgU2VudHJ5LmluaXQgb3B0aW9ucyAoYGlnbm9yZUVycm9yc2AsIGBkZW55VXJsc2AsIGBhbGxvd1VybHNgKVxuICogICAtIFRoZSBzYW1lIG9wdGlvbnMgcGFzc2VkIHRvIHRoZSBpbnRlZ3JhdGlvbiBkaXJlY3RseSB2aWEgQHBhcmFtIG9wdGlvbnNcbiAqIC0gKFRyYW5zYWN0aW9ucy9TcGFucykgQSBsaXN0IG9mIHJvb3Qgc3BhbiAodHJhbnNhY3Rpb24pIG5hbWVzIHBhc3NlZCBpbiB2aWFcbiAqICAgLSBUb3AgbGV2ZWwgU2VudHJ5LmluaXQgb3B0aW9uIChgaWdub3JlVHJhbnNhY3Rpb25zYClcbiAqICAgLSBUaGUgc2FtZSBvcHRpb24gcGFzc2VkIHRvIHRoZSBpbnRlZ3JhdGlvbiBkaXJlY3RseSB2aWEgQHBhcmFtIG9wdGlvbnNcbiAqXG4gKiBFdmVudHMgZmlsdGVyZWQgYnkgdGhpcyBpbnRlZ3JhdGlvbiB3aWxsIG5vdCBiZSBzZW50IHRvIFNlbnRyeS5cbiAqL1xuY29uc3QgZXZlbnRGaWx0ZXJzSW50ZWdyYXRpb24gPSBpbnRlZ3JhdGlvbi5kZWZpbmVJbnRlZ3JhdGlvbigob3B0aW9ucyA9IHt9KSA9PiB7XG4gIGxldCBtZXJnZWRPcHRpb25zO1xuICByZXR1cm4ge1xuICAgIG5hbWU6IElOVEVHUkFUSU9OX05BTUUsXG4gICAgc2V0dXAoY2xpZW50KSB7XG4gICAgICBjb25zdCBjbGllbnRPcHRpb25zID0gY2xpZW50LmdldE9wdGlvbnMoKTtcbiAgICAgIG1lcmdlZE9wdGlvbnMgPSBfbWVyZ2VPcHRpb25zKG9wdGlvbnMsIGNsaWVudE9wdGlvbnMpO1xuICAgIH0sXG4gICAgcHJvY2Vzc0V2ZW50KGV2ZW50LCBfaGludCwgY2xpZW50KSB7XG4gICAgICBpZiAoIW1lcmdlZE9wdGlvbnMpIHtcbiAgICAgICAgY29uc3QgY2xpZW50T3B0aW9ucyA9IGNsaWVudC5nZXRPcHRpb25zKCk7XG4gICAgICAgIG1lcmdlZE9wdGlvbnMgPSBfbWVyZ2VPcHRpb25zKG9wdGlvbnMsIGNsaWVudE9wdGlvbnMpO1xuICAgICAgfVxuICAgICAgcmV0dXJuIF9zaG91bGREcm9wRXZlbnQoZXZlbnQsIG1lcmdlZE9wdGlvbnMpID8gbnVsbCA6IGV2ZW50O1xuICAgIH0sXG4gIH07XG59KTtcblxuLyoqXG4gKiBBbiBpbnRlZ3JhdGlvbiB0aGF0IGZpbHRlcnMgb3V0IGV2ZW50cyAoZXJyb3JzIGFuZCB0cmFuc2FjdGlvbnMpIGJhc2VkIG9uOlxuICpcbiAqIC0gKEVycm9ycykgQSBjdXJhdGVkIGxpc3Qgb2Yga25vd24gbG93LXZhbHVlIG9yIGlycmVsZXZhbnQgZXJyb3JzIChzZWUge0BsaW5rIERFRkFVTFRfSUdOT1JFX0VSUk9SU30pXG4gKiAtIChFcnJvcnMpIEEgbGlzdCBvZiBlcnJvciBtZXNzYWdlcyBvciB1cmxzL2ZpbGVuYW1lcyBwYXNzZWQgaW4gdmlhXG4gKiAgIC0gVG9wIGxldmVsIFNlbnRyeS5pbml0IG9wdGlvbnMgKGBpZ25vcmVFcnJvcnNgLCBgZGVueVVybHNgLCBgYWxsb3dVcmxzYClcbiAqICAgLSBUaGUgc2FtZSBvcHRpb25zIHBhc3NlZCB0byB0aGUgaW50ZWdyYXRpb24gZGlyZWN0bHkgdmlhIEBwYXJhbSBvcHRpb25zXG4gKiAtIChUcmFuc2FjdGlvbnMvU3BhbnMpIEEgbGlzdCBvZiByb290IHNwYW4gKHRyYW5zYWN0aW9uKSBuYW1lcyBwYXNzZWQgaW4gdmlhXG4gKiAgIC0gVG9wIGxldmVsIFNlbnRyeS5pbml0IG9wdGlvbiAoYGlnbm9yZVRyYW5zYWN0aW9uc2ApXG4gKiAgIC0gVGhlIHNhbWUgb3B0aW9uIHBhc3NlZCB0byB0aGUgaW50ZWdyYXRpb24gZGlyZWN0bHkgdmlhIEBwYXJhbSBvcHRpb25zXG4gKlxuICogRXZlbnRzIGZpbHRlcmVkIGJ5IHRoaXMgaW50ZWdyYXRpb24gd2lsbCBub3QgYmUgc2VudCB0byBTZW50cnkuXG4gKlxuICogQGRlcHJlY2F0ZWQgdGhpcyBpbnRlZ3JhdGlvbiB3YXMgcmVuYW1lZCBhbmQgd2lsbCBiZSByZW1vdmVkIGluIGEgZnV0dXJlIG1ham9yIHZlcnNpb24uXG4gKiBVc2UgYGV2ZW50RmlsdGVyc0ludGVncmF0aW9uYCBpbnN0ZWFkLlxuICovXG5jb25zdCBpbmJvdW5kRmlsdGVyc0ludGVncmF0aW9uID0gaW50ZWdyYXRpb24uZGVmaW5lSW50ZWdyYXRpb24oKChvcHRpb25zID0ge30pID0+IHtcbiAgcmV0dXJuIHtcbiAgICAuLi5ldmVudEZpbHRlcnNJbnRlZ3JhdGlvbihvcHRpb25zKSxcbiAgICBuYW1lOiAnSW5ib3VuZEZpbHRlcnMnLFxuICB9O1xufSkgKTtcblxuZnVuY3Rpb24gX21lcmdlT3B0aW9ucyhcbiAgaW50ZXJuYWxPcHRpb25zID0ge30sXG4gIGNsaWVudE9wdGlvbnMgPSB7fSxcbikge1xuICByZXR1cm4ge1xuICAgIGFsbG93VXJsczogWy4uLihpbnRlcm5hbE9wdGlvbnMuYWxsb3dVcmxzIHx8IFtdKSwgLi4uKGNsaWVudE9wdGlvbnMuYWxsb3dVcmxzIHx8IFtdKV0sXG4gICAgZGVueVVybHM6IFsuLi4oaW50ZXJuYWxPcHRpb25zLmRlbnlVcmxzIHx8IFtdKSwgLi4uKGNsaWVudE9wdGlvbnMuZGVueVVybHMgfHwgW10pXSxcbiAgICBpZ25vcmVFcnJvcnM6IFtcbiAgICAgIC4uLihpbnRlcm5hbE9wdGlvbnMuaWdub3JlRXJyb3JzIHx8IFtdKSxcbiAgICAgIC4uLihjbGllbnRPcHRpb25zLmlnbm9yZUVycm9ycyB8fCBbXSksXG4gICAgICAuLi4oaW50ZXJuYWxPcHRpb25zLmRpc2FibGVFcnJvckRlZmF1bHRzID8gW10gOiBERUZBVUxUX0lHTk9SRV9FUlJPUlMpLFxuICAgIF0sXG4gICAgaWdub3JlVHJhbnNhY3Rpb25zOiBbLi4uKGludGVybmFsT3B0aW9ucy5pZ25vcmVUcmFuc2FjdGlvbnMgfHwgW10pLCAuLi4oY2xpZW50T3B0aW9ucy5pZ25vcmVUcmFuc2FjdGlvbnMgfHwgW10pXSxcbiAgfTtcbn1cblxuZnVuY3Rpb24gX3Nob3VsZERyb3BFdmVudChldmVudCwgb3B0aW9ucykge1xuICBpZiAoIWV2ZW50LnR5cGUpIHtcbiAgICAvLyBGaWx0ZXIgZXJyb3JzXG4gICAgaWYgKF9pc0lnbm9yZWRFcnJvcihldmVudCwgb3B0aW9ucy5pZ25vcmVFcnJvcnMpKSB7XG4gICAgICBkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEICYmXG4gICAgICAgIGRlYnVnTG9nZ2VyLmRlYnVnLndhcm4oXG4gICAgICAgICAgYEV2ZW50IGRyb3BwZWQgZHVlIHRvIGJlaW5nIG1hdGNoZWQgYnkgXFxgaWdub3JlRXJyb3JzXFxgIG9wdGlvbi5cXG5FdmVudDogJHttaXNjLmdldEV2ZW50RGVzY3JpcHRpb24oZXZlbnQpfWAsXG4gICAgICAgICk7XG4gICAgICByZXR1cm4gdHJ1ZTtcbiAgICB9XG4gICAgaWYgKF9pc1VzZWxlc3NFcnJvcihldmVudCkpIHtcbiAgICAgIGRlYnVnQnVpbGQuREVCVUdfQlVJTEQgJiZcbiAgICAgICAgZGVidWdMb2dnZXIuZGVidWcud2FybihcbiAgICAgICAgICBgRXZlbnQgZHJvcHBlZCBkdWUgdG8gbm90IGhhdmluZyBhbiBlcnJvciBtZXNzYWdlLCBlcnJvciB0eXBlIG9yIHN0YWNrdHJhY2UuXFxuRXZlbnQ6ICR7bWlzYy5nZXRFdmVudERlc2NyaXB0aW9uKFxuICAgICAgICAgICAgZXZlbnQsXG4gICAgICAgICAgKX1gLFxuICAgICAgICApO1xuICAgICAgcmV0dXJuIHRydWU7XG4gICAgfVxuICAgIGlmIChfaXNEZW5pZWRVcmwoZXZlbnQsIG9wdGlvbnMuZGVueVVybHMpKSB7XG4gICAgICBkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEICYmXG4gICAgICAgIGRlYnVnTG9nZ2VyLmRlYnVnLndhcm4oXG4gICAgICAgICAgYEV2ZW50IGRyb3BwZWQgZHVlIHRvIGJlaW5nIG1hdGNoZWQgYnkgXFxgZGVueVVybHNcXGAgb3B0aW9uLlxcbkV2ZW50OiAke21pc2MuZ2V0RXZlbnREZXNjcmlwdGlvbihcbiAgICAgICAgICAgIGV2ZW50LFxuICAgICAgICAgICl9LlxcblVybDogJHtfZ2V0RXZlbnRGaWx0ZXJVcmwoZXZlbnQpfWAsXG4gICAgICAgICk7XG4gICAgICByZXR1cm4gdHJ1ZTtcbiAgICB9XG4gICAgaWYgKCFfaXNBbGxvd2VkVXJsKGV2ZW50LCBvcHRpb25zLmFsbG93VXJscykpIHtcbiAgICAgIGRlYnVnQnVpbGQuREVCVUdfQlVJTEQgJiZcbiAgICAgICAgZGVidWdMb2dnZXIuZGVidWcud2FybihcbiAgICAgICAgICBgRXZlbnQgZHJvcHBlZCBkdWUgdG8gbm90IGJlaW5nIG1hdGNoZWQgYnkgXFxgYWxsb3dVcmxzXFxgIG9wdGlvbi5cXG5FdmVudDogJHttaXNjLmdldEV2ZW50RGVzY3JpcHRpb24oXG4gICAgICAgICAgICBldmVudCxcbiAgICAgICAgICApfS5cXG5Vcmw6ICR7X2dldEV2ZW50RmlsdGVyVXJsKGV2ZW50KX1gLFxuICAgICAgICApO1xuICAgICAgcmV0dXJuIHRydWU7XG4gICAgfVxuICB9IGVsc2UgaWYgKGV2ZW50LnR5cGUgPT09ICd0cmFuc2FjdGlvbicpIHtcbiAgICAvLyBGaWx0ZXIgdHJhbnNhY3Rpb25zXG5cbiAgICBpZiAoX2lzSWdub3JlZFRyYW5zYWN0aW9uKGV2ZW50LCBvcHRpb25zLmlnbm9yZVRyYW5zYWN0aW9ucykpIHtcbiAgICAgIGRlYnVnQnVpbGQuREVCVUdfQlVJTEQgJiZcbiAgICAgICAgZGVidWdMb2dnZXIuZGVidWcud2FybihcbiAgICAgICAgICBgRXZlbnQgZHJvcHBlZCBkdWUgdG8gYmVpbmcgbWF0Y2hlZCBieSBcXGBpZ25vcmVUcmFuc2FjdGlvbnNcXGAgb3B0aW9uLlxcbkV2ZW50OiAke21pc2MuZ2V0RXZlbnREZXNjcmlwdGlvbihldmVudCl9YCxcbiAgICAgICAgKTtcbiAgICAgIHJldHVybiB0cnVlO1xuICAgIH1cbiAgfVxuICByZXR1cm4gZmFsc2U7XG59XG5cbmZ1bmN0aW9uIF9pc0lnbm9yZWRFcnJvcihldmVudCwgaWdub3JlRXJyb3JzKSB7XG4gIGlmICghaWdub3JlRXJyb3JzPy5sZW5ndGgpIHtcbiAgICByZXR1cm4gZmFsc2U7XG4gIH1cblxuICByZXR1cm4gZXZlbnRVdGlscy5nZXRQb3NzaWJsZUV2ZW50TWVzc2FnZXMoZXZlbnQpLnNvbWUobWVzc2FnZSA9PiBzdHJpbmcuc3RyaW5nTWF0Y2hlc1NvbWVQYXR0ZXJuKG1lc3NhZ2UsIGlnbm9yZUVycm9ycykpO1xufVxuXG5mdW5jdGlvbiBfaXNJZ25vcmVkVHJhbnNhY3Rpb24oZXZlbnQsIGlnbm9yZVRyYW5zYWN0aW9ucykge1xuICBpZiAoIWlnbm9yZVRyYW5zYWN0aW9ucz8ubGVuZ3RoKSB7XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG5cbiAgY29uc3QgbmFtZSA9IGV2ZW50LnRyYW5zYWN0aW9uO1xuICByZXR1cm4gbmFtZSA/IHN0cmluZy5zdHJpbmdNYXRjaGVzU29tZVBhdHRlcm4obmFtZSwgaWdub3JlVHJhbnNhY3Rpb25zKSA6IGZhbHNlO1xufVxuXG5mdW5jdGlvbiBfaXNEZW5pZWRVcmwoZXZlbnQsIGRlbnlVcmxzKSB7XG4gIGlmICghZGVueVVybHM/Lmxlbmd0aCkge1xuICAgIHJldHVybiBmYWxzZTtcbiAgfVxuICBjb25zdCB1cmwgPSBfZ2V0RXZlbnRGaWx0ZXJVcmwoZXZlbnQpO1xuICByZXR1cm4gIXVybCA/IGZhbHNlIDogc3RyaW5nLnN0cmluZ01hdGNoZXNTb21lUGF0dGVybih1cmwsIGRlbnlVcmxzKTtcbn1cblxuZnVuY3Rpb24gX2lzQWxsb3dlZFVybChldmVudCwgYWxsb3dVcmxzKSB7XG4gIGlmICghYWxsb3dVcmxzPy5sZW5ndGgpIHtcbiAgICByZXR1cm4gdHJ1ZTtcbiAgfVxuICBjb25zdCB1cmwgPSBfZ2V0RXZlbnRGaWx0ZXJVcmwoZXZlbnQpO1xuICByZXR1cm4gIXVybCA/IHRydWUgOiBzdHJpbmcuc3RyaW5nTWF0Y2hlc1NvbWVQYXR0ZXJuKHVybCwgYWxsb3dVcmxzKTtcbn1cblxuZnVuY3Rpb24gX2dldExhc3RWYWxpZFVybChmcmFtZXMgPSBbXSkge1xuICBmb3IgKGxldCBpID0gZnJhbWVzLmxlbmd0aCAtIDE7IGkgPj0gMDsgaS0tKSB7XG4gICAgY29uc3QgZnJhbWUgPSBmcmFtZXNbaV07XG5cbiAgICBpZiAoZnJhbWUgJiYgZnJhbWUuZmlsZW5hbWUgIT09ICc8YW5vbnltb3VzPicgJiYgZnJhbWUuZmlsZW5hbWUgIT09ICdbbmF0aXZlIGNvZGVdJykge1xuICAgICAgcmV0dXJuIGZyYW1lLmZpbGVuYW1lIHx8IG51bGw7XG4gICAgfVxuICB9XG5cbiAgcmV0dXJuIG51bGw7XG59XG5cbmZ1bmN0aW9uIF9nZXRFdmVudEZpbHRlclVybChldmVudCkge1xuICB0cnkge1xuICAgIC8vIElmIHRoZXJlIGFyZSBsaW5rZWQgZXhjZXB0aW9ucyBvciBleGNlcHRpb24gYWdncmVnYXRlcyB3ZSBvbmx5IHdhbnQgdG8gbWF0Y2ggYWdhaW5zdCB0aGUgdG9wIGZyYW1lIG9mIHRoZSBcInJvb3RcIiAodGhlIG1haW4gZXhjZXB0aW9uKVxuICAgIC8vIFRoZSByb290IGFsd2F5cyBjb21lcyBsYXN0IGluIGxpbmtlZCBleGNlcHRpb25zXG4gICAgY29uc3Qgcm9vdEV4Y2VwdGlvbiA9IFsuLi4oZXZlbnQuZXhjZXB0aW9uPy52YWx1ZXMgPz8gW10pXVxuICAgICAgLnJldmVyc2UoKVxuICAgICAgLmZpbmQodmFsdWUgPT4gdmFsdWUubWVjaGFuaXNtPy5wYXJlbnRfaWQgPT09IHVuZGVmaW5lZCAmJiB2YWx1ZS5zdGFja3RyYWNlPy5mcmFtZXM/Lmxlbmd0aCk7XG4gICAgY29uc3QgZnJhbWVzID0gcm9vdEV4Y2VwdGlvbj8uc3RhY2t0cmFjZT8uZnJhbWVzO1xuICAgIHJldHVybiBmcmFtZXMgPyBfZ2V0TGFzdFZhbGlkVXJsKGZyYW1lcykgOiBudWxsO1xuICB9IGNhdGNoIHtcbiAgICBkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEICYmIGRlYnVnTG9nZ2VyLmRlYnVnLmVycm9yKGBDYW5ub3QgZXh0cmFjdCB1cmwgZm9yIGV2ZW50ICR7bWlzYy5nZXRFdmVudERlc2NyaXB0aW9uKGV2ZW50KX1gKTtcbiAgICByZXR1cm4gbnVsbDtcbiAgfVxufVxuXG5mdW5jdGlvbiBfaXNVc2VsZXNzRXJyb3IoZXZlbnQpIHtcbiAgLy8gV2Ugb25seSB3YW50IHRvIGNvbnNpZGVyIGV2ZW50cyBmb3IgZHJvcHBpbmcgdGhhdCBhY3R1YWxseSBoYXZlIHJlY29yZGVkIGV4Y2VwdGlvbiB2YWx1ZXMuXG4gIGlmICghZXZlbnQuZXhjZXB0aW9uPy52YWx1ZXM/Lmxlbmd0aCkge1xuICAgIHJldHVybiBmYWxzZTtcbiAgfVxuXG4gIHJldHVybiAoXG4gICAgLy8gTm8gdG9wLWxldmVsIG1lc3NhZ2VcbiAgICAhZXZlbnQubWVzc2FnZSAmJlxuICAgIC8vIFRoZXJlIGFyZSBubyBleGNlcHRpb24gdmFsdWVzIHRoYXQgaGF2ZSBhIHN0YWNrdHJhY2UsIGEgbm9uLWdlbmVyaWMtRXJyb3IgdHlwZSBvciB2YWx1ZVxuICAgICFldmVudC5leGNlcHRpb24udmFsdWVzLnNvbWUodmFsdWUgPT4gdmFsdWUuc3RhY2t0cmFjZSB8fCAodmFsdWUudHlwZSAmJiB2YWx1ZS50eXBlICE9PSAnRXJyb3InKSB8fCB2YWx1ZS52YWx1ZSlcbiAgKTtcbn1cblxuZXhwb3J0cy5ldmVudEZpbHRlcnNJbnRlZ3JhdGlvbiA9IGV2ZW50RmlsdGVyc0ludGVncmF0aW9uO1xuZXhwb3J0cy5pbmJvdW5kRmlsdGVyc0ludGVncmF0aW9uID0gaW5ib3VuZEZpbHRlcnNJbnRlZ3JhdGlvbjtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWV2ZW50RmlsdGVycy5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/eventFilters.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/extraerrordata.js":
/*!*******************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/extraerrordata.js ***!
  \*******************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst debugBuild = __webpack_require__(/*! ../debug-build.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst integration = __webpack_require__(/*! ../integration.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integration.js\");\nconst debugLogger = __webpack_require__(/*! ../utils/debug-logger.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst is = __webpack_require__(/*! ../utils/is.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js\");\nconst normalize = __webpack_require__(/*! ../utils/normalize.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/normalize.js\");\nconst object = __webpack_require__(/*! ../utils/object.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/object.js\");\nconst string = __webpack_require__(/*! ../utils/string.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/string.js\");\n\nconst INTEGRATION_NAME = 'ExtraErrorData';\n\n/**\n * Extract additional data for from original exceptions.\n */\nconst _extraErrorDataIntegration = ((options = {}) => {\n  const { depth = 3, captureErrorCause = true } = options;\n  return {\n    name: INTEGRATION_NAME,\n    processEvent(event, hint, client) {\n      const { maxValueLength = 250 } = client.getOptions();\n      return _enhanceEventWithErrorData(event, hint, depth, captureErrorCause, maxValueLength);\n    },\n  };\n}) ;\n\nconst extraErrorDataIntegration = integration.defineIntegration(_extraErrorDataIntegration);\n\nfunction _enhanceEventWithErrorData(\n  event,\n  hint = {},\n  depth,\n  captureErrorCause,\n  maxValueLength,\n) {\n  if (!hint.originalException || !is.isError(hint.originalException)) {\n    return event;\n  }\n  const exceptionName = (hint.originalException ).name || hint.originalException.constructor.name;\n\n  const errorData = _extractErrorData(hint.originalException , captureErrorCause, maxValueLength);\n\n  if (errorData) {\n    const contexts = {\n      ...event.contexts,\n    };\n\n    const normalizedErrorData = normalize.normalize(errorData, depth);\n\n    if (is.isPlainObject(normalizedErrorData)) {\n      // We mark the error data as \"already normalized\" here, because we don't want other normalization procedures to\n      // potentially truncate the data we just already normalized, with a certain depth setting.\n      object.addNonEnumerableProperty(normalizedErrorData, '__sentry_skip_normalization__', true);\n      contexts[exceptionName] = normalizedErrorData;\n    }\n\n    return {\n      ...event,\n      contexts,\n    };\n  }\n\n  return event;\n}\n\n/**\n * Extract extra information from the Error object\n */\nfunction _extractErrorData(\n  error,\n  captureErrorCause,\n  maxValueLength,\n) {\n  // We are trying to enhance already existing event, so no harm done if it won't succeed\n  try {\n    const nativeKeys = [\n      'name',\n      'message',\n      'stack',\n      'line',\n      'column',\n      'fileName',\n      'lineNumber',\n      'columnNumber',\n      'toJSON',\n    ];\n\n    const extraErrorInfo = {};\n\n    // We want only enumerable properties, thus `getOwnPropertyNames` is redundant here, as we filter keys anyway.\n    for (const key of Object.keys(error)) {\n      if (nativeKeys.indexOf(key) !== -1) {\n        continue;\n      }\n      const value = error[key];\n      extraErrorInfo[key] = is.isError(value) || typeof value === 'string' ? string.truncate(`${value}`, maxValueLength) : value;\n    }\n\n    // Error.cause is a standard property that is non enumerable, we therefore need to access it separately.\n    // https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Error/cause\n    if (captureErrorCause && error.cause !== undefined) {\n      extraErrorInfo.cause = is.isError(error.cause) ? error.cause.toString() : error.cause;\n    }\n\n    // Check if someone attached `toJSON` method to grab even more properties (eg. axios is doing that)\n    if (typeof error.toJSON === 'function') {\n      const serializedError = error.toJSON() ;\n\n      for (const key of Object.keys(serializedError)) {\n        const value = serializedError[key];\n        extraErrorInfo[key] = is.isError(value) ? value.toString() : value;\n      }\n    }\n\n    return extraErrorInfo;\n  } catch (oO) {\n    debugBuild.DEBUG_BUILD && debugLogger.debug.error('Unable to extract extra data from the Error object:', oO);\n  }\n\n  return null;\n}\n\nexports.extraErrorDataIntegration = extraErrorDataIntegration;\n//# sourceMappingURL=extraerrordata.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvZXh0cmFlcnJvcmRhdGEuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsbUJBQW1CLG1CQUFPLENBQUMsNEhBQW1CO0FBQzlDLG9CQUFvQixtQkFBTyxDQUFDLDRIQUFtQjtBQUMvQyxvQkFBb0IsbUJBQU8sQ0FBQywwSUFBMEI7QUFDdEQsV0FBVyxtQkFBTyxDQUFDLHNIQUFnQjtBQUNuQyxrQkFBa0IsbUJBQU8sQ0FBQyxvSUFBdUI7QUFDakQsZUFBZSxtQkFBTyxDQUFDLDhIQUFvQjtBQUMzQyxlQUFlLG1CQUFPLENBQUMsOEhBQW9COztBQUUzQzs7QUFFQTtBQUNBO0FBQ0E7QUFDQSxpREFBaUQ7QUFDakQsVUFBVSxzQ0FBc0M7QUFDaEQ7QUFDQTtBQUNBO0FBQ0EsY0FBYyx1QkFBdUI7QUFDckM7QUFDQSxLQUFLO0FBQ0w7QUFDQSxDQUFDOztBQUVEOztBQUVBO0FBQ0E7QUFDQSxXQUFXO0FBQ1g7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxnR0FBZ0csTUFBTTtBQUN0Rzs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0EsSUFBSTtBQUNKO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQSxpQ0FBaUM7QUFDakMiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvZXh0cmFlcnJvcmRhdGEuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGRlYnVnQnVpbGQgPSByZXF1aXJlKCcuLi9kZWJ1Zy1idWlsZC5qcycpO1xuY29uc3QgaW50ZWdyYXRpb24gPSByZXF1aXJlKCcuLi9pbnRlZ3JhdGlvbi5qcycpO1xuY29uc3QgZGVidWdMb2dnZXIgPSByZXF1aXJlKCcuLi91dGlscy9kZWJ1Zy1sb2dnZXIuanMnKTtcbmNvbnN0IGlzID0gcmVxdWlyZSgnLi4vdXRpbHMvaXMuanMnKTtcbmNvbnN0IG5vcm1hbGl6ZSA9IHJlcXVpcmUoJy4uL3V0aWxzL25vcm1hbGl6ZS5qcycpO1xuY29uc3Qgb2JqZWN0ID0gcmVxdWlyZSgnLi4vdXRpbHMvb2JqZWN0LmpzJyk7XG5jb25zdCBzdHJpbmcgPSByZXF1aXJlKCcuLi91dGlscy9zdHJpbmcuanMnKTtcblxuY29uc3QgSU5URUdSQVRJT05fTkFNRSA9ICdFeHRyYUVycm9yRGF0YSc7XG5cbi8qKlxuICogRXh0cmFjdCBhZGRpdGlvbmFsIGRhdGEgZm9yIGZyb20gb3JpZ2luYWwgZXhjZXB0aW9ucy5cbiAqL1xuY29uc3QgX2V4dHJhRXJyb3JEYXRhSW50ZWdyYXRpb24gPSAoKG9wdGlvbnMgPSB7fSkgPT4ge1xuICBjb25zdCB7IGRlcHRoID0gMywgY2FwdHVyZUVycm9yQ2F1c2UgPSB0cnVlIH0gPSBvcHRpb25zO1xuICByZXR1cm4ge1xuICAgIG5hbWU6IElOVEVHUkFUSU9OX05BTUUsXG4gICAgcHJvY2Vzc0V2ZW50KGV2ZW50LCBoaW50LCBjbGllbnQpIHtcbiAgICAgIGNvbnN0IHsgbWF4VmFsdWVMZW5ndGggPSAyNTAgfSA9IGNsaWVudC5nZXRPcHRpb25zKCk7XG4gICAgICByZXR1cm4gX2VuaGFuY2VFdmVudFdpdGhFcnJvckRhdGEoZXZlbnQsIGhpbnQsIGRlcHRoLCBjYXB0dXJlRXJyb3JDYXVzZSwgbWF4VmFsdWVMZW5ndGgpO1xuICAgIH0sXG4gIH07XG59KSA7XG5cbmNvbnN0IGV4dHJhRXJyb3JEYXRhSW50ZWdyYXRpb24gPSBpbnRlZ3JhdGlvbi5kZWZpbmVJbnRlZ3JhdGlvbihfZXh0cmFFcnJvckRhdGFJbnRlZ3JhdGlvbik7XG5cbmZ1bmN0aW9uIF9lbmhhbmNlRXZlbnRXaXRoRXJyb3JEYXRhKFxuICBldmVudCxcbiAgaGludCA9IHt9LFxuICBkZXB0aCxcbiAgY2FwdHVyZUVycm9yQ2F1c2UsXG4gIG1heFZhbHVlTGVuZ3RoLFxuKSB7XG4gIGlmICghaGludC5vcmlnaW5hbEV4Y2VwdGlvbiB8fCAhaXMuaXNFcnJvcihoaW50Lm9yaWdpbmFsRXhjZXB0aW9uKSkge1xuICAgIHJldHVybiBldmVudDtcbiAgfVxuICBjb25zdCBleGNlcHRpb25OYW1lID0gKGhpbnQub3JpZ2luYWxFeGNlcHRpb24gKS5uYW1lIHx8IGhpbnQub3JpZ2luYWxFeGNlcHRpb24uY29uc3RydWN0b3IubmFtZTtcblxuICBjb25zdCBlcnJvckRhdGEgPSBfZXh0cmFjdEVycm9yRGF0YShoaW50Lm9yaWdpbmFsRXhjZXB0aW9uICwgY2FwdHVyZUVycm9yQ2F1c2UsIG1heFZhbHVlTGVuZ3RoKTtcblxuICBpZiAoZXJyb3JEYXRhKSB7XG4gICAgY29uc3QgY29udGV4dHMgPSB7XG4gICAgICAuLi5ldmVudC5jb250ZXh0cyxcbiAgICB9O1xuXG4gICAgY29uc3Qgbm9ybWFsaXplZEVycm9yRGF0YSA9IG5vcm1hbGl6ZS5ub3JtYWxpemUoZXJyb3JEYXRhLCBkZXB0aCk7XG5cbiAgICBpZiAoaXMuaXNQbGFpbk9iamVjdChub3JtYWxpemVkRXJyb3JEYXRhKSkge1xuICAgICAgLy8gV2UgbWFyayB0aGUgZXJyb3IgZGF0YSBhcyBcImFscmVhZHkgbm9ybWFsaXplZFwiIGhlcmUsIGJlY2F1c2Ugd2UgZG9uJ3Qgd2FudCBvdGhlciBub3JtYWxpemF0aW9uIHByb2NlZHVyZXMgdG9cbiAgICAgIC8vIHBvdGVudGlhbGx5IHRydW5jYXRlIHRoZSBkYXRhIHdlIGp1c3QgYWxyZWFkeSBub3JtYWxpemVkLCB3aXRoIGEgY2VydGFpbiBkZXB0aCBzZXR0aW5nLlxuICAgICAgb2JqZWN0LmFkZE5vbkVudW1lcmFibGVQcm9wZXJ0eShub3JtYWxpemVkRXJyb3JEYXRhLCAnX19zZW50cnlfc2tpcF9ub3JtYWxpemF0aW9uX18nLCB0cnVlKTtcbiAgICAgIGNvbnRleHRzW2V4Y2VwdGlvbk5hbWVdID0gbm9ybWFsaXplZEVycm9yRGF0YTtcbiAgICB9XG5cbiAgICByZXR1cm4ge1xuICAgICAgLi4uZXZlbnQsXG4gICAgICBjb250ZXh0cyxcbiAgICB9O1xuICB9XG5cbiAgcmV0dXJuIGV2ZW50O1xufVxuXG4vKipcbiAqIEV4dHJhY3QgZXh0cmEgaW5mb3JtYXRpb24gZnJvbSB0aGUgRXJyb3Igb2JqZWN0XG4gKi9cbmZ1bmN0aW9uIF9leHRyYWN0RXJyb3JEYXRhKFxuICBlcnJvcixcbiAgY2FwdHVyZUVycm9yQ2F1c2UsXG4gIG1heFZhbHVlTGVuZ3RoLFxuKSB7XG4gIC8vIFdlIGFyZSB0cnlpbmcgdG8gZW5oYW5jZSBhbHJlYWR5IGV4aXN0aW5nIGV2ZW50LCBzbyBubyBoYXJtIGRvbmUgaWYgaXQgd29uJ3Qgc3VjY2VlZFxuICB0cnkge1xuICAgIGNvbnN0IG5hdGl2ZUtleXMgPSBbXG4gICAgICAnbmFtZScsXG4gICAgICAnbWVzc2FnZScsXG4gICAgICAnc3RhY2snLFxuICAgICAgJ2xpbmUnLFxuICAgICAgJ2NvbHVtbicsXG4gICAgICAnZmlsZU5hbWUnLFxuICAgICAgJ2xpbmVOdW1iZXInLFxuICAgICAgJ2NvbHVtbk51bWJlcicsXG4gICAgICAndG9KU09OJyxcbiAgICBdO1xuXG4gICAgY29uc3QgZXh0cmFFcnJvckluZm8gPSB7fTtcblxuICAgIC8vIFdlIHdhbnQgb25seSBlbnVtZXJhYmxlIHByb3BlcnRpZXMsIHRodXMgYGdldE93blByb3BlcnR5TmFtZXNgIGlzIHJlZHVuZGFudCBoZXJlLCBhcyB3ZSBmaWx0ZXIga2V5cyBhbnl3YXkuXG4gICAgZm9yIChjb25zdCBrZXkgb2YgT2JqZWN0LmtleXMoZXJyb3IpKSB7XG4gICAgICBpZiAobmF0aXZlS2V5cy5pbmRleE9mKGtleSkgIT09IC0xKSB7XG4gICAgICAgIGNvbnRpbnVlO1xuICAgICAgfVxuICAgICAgY29uc3QgdmFsdWUgPSBlcnJvcltrZXldO1xuICAgICAgZXh0cmFFcnJvckluZm9ba2V5XSA9IGlzLmlzRXJyb3IodmFsdWUpIHx8IHR5cGVvZiB2YWx1ZSA9PT0gJ3N0cmluZycgPyBzdHJpbmcudHJ1bmNhdGUoYCR7dmFsdWV9YCwgbWF4VmFsdWVMZW5ndGgpIDogdmFsdWU7XG4gICAgfVxuXG4gICAgLy8gRXJyb3IuY2F1c2UgaXMgYSBzdGFuZGFyZCBwcm9wZXJ0eSB0aGF0IGlzIG5vbiBlbnVtZXJhYmxlLCB3ZSB0aGVyZWZvcmUgbmVlZCB0byBhY2Nlc3MgaXQgc2VwYXJhdGVseS5cbiAgICAvLyBodHRwczovL2RldmVsb3Blci5tb3ppbGxhLm9yZy9lbi1VUy9kb2NzL1dlYi9KYXZhU2NyaXB0L1JlZmVyZW5jZS9HbG9iYWxfT2JqZWN0cy9FcnJvci9jYXVzZVxuICAgIGlmIChjYXB0dXJlRXJyb3JDYXVzZSAmJiBlcnJvci5jYXVzZSAhPT0gdW5kZWZpbmVkKSB7XG4gICAgICBleHRyYUVycm9ySW5mby5jYXVzZSA9IGlzLmlzRXJyb3IoZXJyb3IuY2F1c2UpID8gZXJyb3IuY2F1c2UudG9TdHJpbmcoKSA6IGVycm9yLmNhdXNlO1xuICAgIH1cblxuICAgIC8vIENoZWNrIGlmIHNvbWVvbmUgYXR0YWNoZWQgYHRvSlNPTmAgbWV0aG9kIHRvIGdyYWIgZXZlbiBtb3JlIHByb3BlcnRpZXMgKGVnLiBheGlvcyBpcyBkb2luZyB0aGF0KVxuICAgIGlmICh0eXBlb2YgZXJyb3IudG9KU09OID09PSAnZnVuY3Rpb24nKSB7XG4gICAgICBjb25zdCBzZXJpYWxpemVkRXJyb3IgPSBlcnJvci50b0pTT04oKSA7XG5cbiAgICAgIGZvciAoY29uc3Qga2V5IG9mIE9iamVjdC5rZXlzKHNlcmlhbGl6ZWRFcnJvcikpIHtcbiAgICAgICAgY29uc3QgdmFsdWUgPSBzZXJpYWxpemVkRXJyb3Jba2V5XTtcbiAgICAgICAgZXh0cmFFcnJvckluZm9ba2V5XSA9IGlzLmlzRXJyb3IodmFsdWUpID8gdmFsdWUudG9TdHJpbmcoKSA6IHZhbHVlO1xuICAgICAgfVxuICAgIH1cblxuICAgIHJldHVybiBleHRyYUVycm9ySW5mbztcbiAgfSBjYXRjaCAob08pIHtcbiAgICBkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEICYmIGRlYnVnTG9nZ2VyLmRlYnVnLmVycm9yKCdVbmFibGUgdG8gZXh0cmFjdCBleHRyYSBkYXRhIGZyb20gdGhlIEVycm9yIG9iamVjdDonLCBvTyk7XG4gIH1cblxuICByZXR1cm4gbnVsbDtcbn1cblxuZXhwb3J0cy5leHRyYUVycm9yRGF0YUludGVncmF0aW9uID0gZXh0cmFFcnJvckRhdGFJbnRlZ3JhdGlvbjtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWV4dHJhZXJyb3JkYXRhLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/extraerrordata.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/featureFlags/featureFlagsIntegration.js":
/*!*****************************************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/featureFlags/featureFlagsIntegration.js ***!
  \*****************************************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst integration = __webpack_require__(/*! ../../integration.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integration.js\");\nconst featureFlags = __webpack_require__(/*! ../../utils/featureFlags.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/featureFlags.js\");\n\n/**\n * Sentry integration for buffering feature flag evaluations manually with an API, and\n * capturing them on error events and spans.\n *\n * See the [feature flag documentation](https://develop.sentry.dev/sdk/expected-features/#feature-flags) for more information.\n *\n * @example\n * ```\n * import * as Sentry from '@sentry/browser';\n * import { type FeatureFlagsIntegration } from '@sentry/browser';\n *\n * // Setup\n * Sentry.init(..., integrations: [Sentry.featureFlagsIntegration()])\n *\n * // Verify\n * const flagsIntegration = Sentry.getClient()?.getIntegrationByName<FeatureFlagsIntegration>('FeatureFlags');\n * if (flagsIntegration) {\n *   flagsIntegration.addFeatureFlag('my-flag', true);\n * } else {\n *   // check your setup\n * }\n * Sentry.captureException(Exception('broke')); // 'my-flag' should be captured to this Sentry event.\n * ```\n */\nconst featureFlagsIntegration = integration.defineIntegration(() => {\n  return {\n    name: 'FeatureFlags',\n\n    processEvent(event, _hint, _client) {\n      return featureFlags._INTERNAL_copyFlagsFromScopeToEvent(event);\n    },\n\n    addFeatureFlag(name, value) {\n      featureFlags._INTERNAL_insertFlagToScope(name, value);\n      featureFlags._INTERNAL_addFeatureFlagToActiveSpan(name, value);\n    },\n  };\n}) ;\n\nexports.featureFlagsIntegration = featureFlagsIntegration;\n//# sourceMappingURL=featureFlagsIntegration.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvZmVhdHVyZUZsYWdzL2ZlYXR1cmVGbGFnc0ludGVncmF0aW9uLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLG9CQUFvQixtQkFBTyxDQUFDLCtIQUFzQjtBQUNsRCxxQkFBcUIsbUJBQU8sQ0FBQyw2SUFBNkI7O0FBRTFEO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFlBQVksK0JBQStCO0FBQzNDO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxLQUFLO0FBQ0w7QUFDQTtBQUNBLGdEQUFnRDtBQUNoRDtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQSxLQUFLOztBQUVMO0FBQ0E7QUFDQTtBQUNBLEtBQUs7QUFDTDtBQUNBLENBQUM7O0FBRUQsK0JBQStCO0FBQy9CIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvaW50ZWdyYXRpb25zL2ZlYXR1cmVGbGFncy9mZWF0dXJlRmxhZ3NJbnRlZ3JhdGlvbi5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgaW50ZWdyYXRpb24gPSByZXF1aXJlKCcuLi8uLi9pbnRlZ3JhdGlvbi5qcycpO1xuY29uc3QgZmVhdHVyZUZsYWdzID0gcmVxdWlyZSgnLi4vLi4vdXRpbHMvZmVhdHVyZUZsYWdzLmpzJyk7XG5cbi8qKlxuICogU2VudHJ5IGludGVncmF0aW9uIGZvciBidWZmZXJpbmcgZmVhdHVyZSBmbGFnIGV2YWx1YXRpb25zIG1hbnVhbGx5IHdpdGggYW4gQVBJLCBhbmRcbiAqIGNhcHR1cmluZyB0aGVtIG9uIGVycm9yIGV2ZW50cyBhbmQgc3BhbnMuXG4gKlxuICogU2VlIHRoZSBbZmVhdHVyZSBmbGFnIGRvY3VtZW50YXRpb25dKGh0dHBzOi8vZGV2ZWxvcC5zZW50cnkuZGV2L3Nkay9leHBlY3RlZC1mZWF0dXJlcy8jZmVhdHVyZS1mbGFncykgZm9yIG1vcmUgaW5mb3JtYXRpb24uXG4gKlxuICogQGV4YW1wbGVcbiAqIGBgYFxuICogaW1wb3J0ICogYXMgU2VudHJ5IGZyb20gJ0BzZW50cnkvYnJvd3Nlcic7XG4gKiBpbXBvcnQgeyB0eXBlIEZlYXR1cmVGbGFnc0ludGVncmF0aW9uIH0gZnJvbSAnQHNlbnRyeS9icm93c2VyJztcbiAqXG4gKiAvLyBTZXR1cFxuICogU2VudHJ5LmluaXQoLi4uLCBpbnRlZ3JhdGlvbnM6IFtTZW50cnkuZmVhdHVyZUZsYWdzSW50ZWdyYXRpb24oKV0pXG4gKlxuICogLy8gVmVyaWZ5XG4gKiBjb25zdCBmbGFnc0ludGVncmF0aW9uID0gU2VudHJ5LmdldENsaWVudCgpPy5nZXRJbnRlZ3JhdGlvbkJ5TmFtZTxGZWF0dXJlRmxhZ3NJbnRlZ3JhdGlvbj4oJ0ZlYXR1cmVGbGFncycpO1xuICogaWYgKGZsYWdzSW50ZWdyYXRpb24pIHtcbiAqICAgZmxhZ3NJbnRlZ3JhdGlvbi5hZGRGZWF0dXJlRmxhZygnbXktZmxhZycsIHRydWUpO1xuICogfSBlbHNlIHtcbiAqICAgLy8gY2hlY2sgeW91ciBzZXR1cFxuICogfVxuICogU2VudHJ5LmNhcHR1cmVFeGNlcHRpb24oRXhjZXB0aW9uKCdicm9rZScpKTsgLy8gJ215LWZsYWcnIHNob3VsZCBiZSBjYXB0dXJlZCB0byB0aGlzIFNlbnRyeSBldmVudC5cbiAqIGBgYFxuICovXG5jb25zdCBmZWF0dXJlRmxhZ3NJbnRlZ3JhdGlvbiA9IGludGVncmF0aW9uLmRlZmluZUludGVncmF0aW9uKCgpID0+IHtcbiAgcmV0dXJuIHtcbiAgICBuYW1lOiAnRmVhdHVyZUZsYWdzJyxcblxuICAgIHByb2Nlc3NFdmVudChldmVudCwgX2hpbnQsIF9jbGllbnQpIHtcbiAgICAgIHJldHVybiBmZWF0dXJlRmxhZ3MuX0lOVEVSTkFMX2NvcHlGbGFnc0Zyb21TY29wZVRvRXZlbnQoZXZlbnQpO1xuICAgIH0sXG5cbiAgICBhZGRGZWF0dXJlRmxhZyhuYW1lLCB2YWx1ZSkge1xuICAgICAgZmVhdHVyZUZsYWdzLl9JTlRFUk5BTF9pbnNlcnRGbGFnVG9TY29wZShuYW1lLCB2YWx1ZSk7XG4gICAgICBmZWF0dXJlRmxhZ3MuX0lOVEVSTkFMX2FkZEZlYXR1cmVGbGFnVG9BY3RpdmVTcGFuKG5hbWUsIHZhbHVlKTtcbiAgICB9LFxuICB9O1xufSkgO1xuXG5leHBvcnRzLmZlYXR1cmVGbGFnc0ludGVncmF0aW9uID0gZmVhdHVyZUZsYWdzSW50ZWdyYXRpb247XG4vLyMgc291cmNlTWFwcGluZ1VSTD1mZWF0dXJlRmxhZ3NJbnRlZ3JhdGlvbi5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/featureFlags/featureFlagsIntegration.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/functiontostring.js":
/*!*********************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/functiontostring.js ***!
  \*********************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst currentScopes = __webpack_require__(/*! ../currentScopes.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst integration = __webpack_require__(/*! ../integration.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integration.js\");\nconst object = __webpack_require__(/*! ../utils/object.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/object.js\");\n\nlet originalFunctionToString;\n\nconst INTEGRATION_NAME = 'FunctionToString';\n\nconst SETUP_CLIENTS = new WeakMap();\n\nconst _functionToStringIntegration = (() => {\n  return {\n    name: INTEGRATION_NAME,\n    setupOnce() {\n      // eslint-disable-next-line @typescript-eslint/unbound-method\n      originalFunctionToString = Function.prototype.toString;\n\n      // intrinsics (like Function.prototype) might be immutable in some environments\n      // e.g. Node with --frozen-intrinsics, XS (an embedded JavaScript engine) or SES (a JavaScript proposal)\n      try {\n        Function.prototype.toString = function ( ...args) {\n          const originalFunction = object.getOriginalFunction(this);\n          const context =\n            SETUP_CLIENTS.has(currentScopes.getClient() ) && originalFunction !== undefined ? originalFunction : this;\n          return originalFunctionToString.apply(context, args);\n        };\n      } catch {\n        // ignore errors here, just don't patch this\n      }\n    },\n    setup(client) {\n      SETUP_CLIENTS.set(client, true);\n    },\n  };\n}) ;\n\n/**\n * Patch toString calls to return proper name for wrapped functions.\n *\n * ```js\n * Sentry.init({\n *   integrations: [\n *     functionToStringIntegration(),\n *   ],\n * });\n * ```\n */\nconst functionToStringIntegration = integration.defineIntegration(_functionToStringIntegration);\n\nexports.functionToStringIntegration = functionToStringIntegration;\n//# sourceMappingURL=functiontostring.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvZnVuY3Rpb250b3N0cmluZy5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxzQkFBc0IsbUJBQU8sQ0FBQyxnSUFBcUI7QUFDbkQsb0JBQW9CLG1CQUFPLENBQUMsNEhBQW1CO0FBQy9DLGVBQWUsbUJBQU8sQ0FBQyw4SEFBb0I7O0FBRTNDOztBQUVBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxRQUFRO0FBQ1I7QUFDQTtBQUNBLEtBQUs7QUFDTDtBQUNBO0FBQ0EsS0FBSztBQUNMO0FBQ0EsQ0FBQzs7QUFFRDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsSUFBSTtBQUNKO0FBQ0E7QUFDQTs7QUFFQSxtQ0FBbUM7QUFDbkMiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvZnVuY3Rpb250b3N0cmluZy5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgY3VycmVudFNjb3BlcyA9IHJlcXVpcmUoJy4uL2N1cnJlbnRTY29wZXMuanMnKTtcbmNvbnN0IGludGVncmF0aW9uID0gcmVxdWlyZSgnLi4vaW50ZWdyYXRpb24uanMnKTtcbmNvbnN0IG9iamVjdCA9IHJlcXVpcmUoJy4uL3V0aWxzL29iamVjdC5qcycpO1xuXG5sZXQgb3JpZ2luYWxGdW5jdGlvblRvU3RyaW5nO1xuXG5jb25zdCBJTlRFR1JBVElPTl9OQU1FID0gJ0Z1bmN0aW9uVG9TdHJpbmcnO1xuXG5jb25zdCBTRVRVUF9DTElFTlRTID0gbmV3IFdlYWtNYXAoKTtcblxuY29uc3QgX2Z1bmN0aW9uVG9TdHJpbmdJbnRlZ3JhdGlvbiA9ICgoKSA9PiB7XG4gIHJldHVybiB7XG4gICAgbmFtZTogSU5URUdSQVRJT05fTkFNRSxcbiAgICBzZXR1cE9uY2UoKSB7XG4gICAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L3VuYm91bmQtbWV0aG9kXG4gICAgICBvcmlnaW5hbEZ1bmN0aW9uVG9TdHJpbmcgPSBGdW5jdGlvbi5wcm90b3R5cGUudG9TdHJpbmc7XG5cbiAgICAgIC8vIGludHJpbnNpY3MgKGxpa2UgRnVuY3Rpb24ucHJvdG90eXBlKSBtaWdodCBiZSBpbW11dGFibGUgaW4gc29tZSBlbnZpcm9ubWVudHNcbiAgICAgIC8vIGUuZy4gTm9kZSB3aXRoIC0tZnJvemVuLWludHJpbnNpY3MsIFhTIChhbiBlbWJlZGRlZCBKYXZhU2NyaXB0IGVuZ2luZSkgb3IgU0VTIChhIEphdmFTY3JpcHQgcHJvcG9zYWwpXG4gICAgICB0cnkge1xuICAgICAgICBGdW5jdGlvbi5wcm90b3R5cGUudG9TdHJpbmcgPSBmdW5jdGlvbiAoIC4uLmFyZ3MpIHtcbiAgICAgICAgICBjb25zdCBvcmlnaW5hbEZ1bmN0aW9uID0gb2JqZWN0LmdldE9yaWdpbmFsRnVuY3Rpb24odGhpcyk7XG4gICAgICAgICAgY29uc3QgY29udGV4dCA9XG4gICAgICAgICAgICBTRVRVUF9DTElFTlRTLmhhcyhjdXJyZW50U2NvcGVzLmdldENsaWVudCgpICkgJiYgb3JpZ2luYWxGdW5jdGlvbiAhPT0gdW5kZWZpbmVkID8gb3JpZ2luYWxGdW5jdGlvbiA6IHRoaXM7XG4gICAgICAgICAgcmV0dXJuIG9yaWdpbmFsRnVuY3Rpb25Ub1N0cmluZy5hcHBseShjb250ZXh0LCBhcmdzKTtcbiAgICAgICAgfTtcbiAgICAgIH0gY2F0Y2gge1xuICAgICAgICAvLyBpZ25vcmUgZXJyb3JzIGhlcmUsIGp1c3QgZG9uJ3QgcGF0Y2ggdGhpc1xuICAgICAgfVxuICAgIH0sXG4gICAgc2V0dXAoY2xpZW50KSB7XG4gICAgICBTRVRVUF9DTElFTlRTLnNldChjbGllbnQsIHRydWUpO1xuICAgIH0sXG4gIH07XG59KSA7XG5cbi8qKlxuICogUGF0Y2ggdG9TdHJpbmcgY2FsbHMgdG8gcmV0dXJuIHByb3BlciBuYW1lIGZvciB3cmFwcGVkIGZ1bmN0aW9ucy5cbiAqXG4gKiBgYGBqc1xuICogU2VudHJ5LmluaXQoe1xuICogICBpbnRlZ3JhdGlvbnM6IFtcbiAqICAgICBmdW5jdGlvblRvU3RyaW5nSW50ZWdyYXRpb24oKSxcbiAqICAgXSxcbiAqIH0pO1xuICogYGBgXG4gKi9cbmNvbnN0IGZ1bmN0aW9uVG9TdHJpbmdJbnRlZ3JhdGlvbiA9IGludGVncmF0aW9uLmRlZmluZUludGVncmF0aW9uKF9mdW5jdGlvblRvU3RyaW5nSW50ZWdyYXRpb24pO1xuXG5leHBvcnRzLmZ1bmN0aW9uVG9TdHJpbmdJbnRlZ3JhdGlvbiA9IGZ1bmN0aW9uVG9TdHJpbmdJbnRlZ3JhdGlvbjtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWZ1bmN0aW9udG9zdHJpbmcuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/functiontostring.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/linkederrors.js":
/*!*****************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/linkederrors.js ***!
  \*****************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst integration = __webpack_require__(/*! ../integration.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integration.js\");\nconst aggregateErrors = __webpack_require__(/*! ../utils/aggregate-errors.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/aggregate-errors.js\");\nconst eventbuilder = __webpack_require__(/*! ../utils/eventbuilder.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/eventbuilder.js\");\n\nconst DEFAULT_KEY = 'cause';\nconst DEFAULT_LIMIT = 5;\n\nconst INTEGRATION_NAME = 'LinkedErrors';\n\nconst _linkedErrorsIntegration = ((options = {}) => {\n  const limit = options.limit || DEFAULT_LIMIT;\n  const key = options.key || DEFAULT_KEY;\n\n  return {\n    name: INTEGRATION_NAME,\n    preprocessEvent(event, hint, client) {\n      const options = client.getOptions();\n\n      aggregateErrors.applyAggregateErrorsToEvent(eventbuilder.exceptionFromError, options.stackParser, key, limit, event, hint);\n    },\n  };\n}) ;\n\nconst linkedErrorsIntegration = integration.defineIntegration(_linkedErrorsIntegration);\n\nexports.linkedErrorsIntegration = linkedErrorsIntegration;\n//# sourceMappingURL=linkederrors.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvbGlua2VkZXJyb3JzLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLG9CQUFvQixtQkFBTyxDQUFDLDRIQUFtQjtBQUMvQyx3QkFBd0IsbUJBQU8sQ0FBQyxrSkFBOEI7QUFDOUQscUJBQXFCLG1CQUFPLENBQUMsMElBQTBCOztBQUV2RDtBQUNBOztBQUVBOztBQUVBLCtDQUErQztBQUMvQztBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0EsS0FBSztBQUNMO0FBQ0EsQ0FBQzs7QUFFRDs7QUFFQSwrQkFBK0I7QUFDL0IiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvbGlua2VkZXJyb3JzLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBpbnRlZ3JhdGlvbiA9IHJlcXVpcmUoJy4uL2ludGVncmF0aW9uLmpzJyk7XG5jb25zdCBhZ2dyZWdhdGVFcnJvcnMgPSByZXF1aXJlKCcuLi91dGlscy9hZ2dyZWdhdGUtZXJyb3JzLmpzJyk7XG5jb25zdCBldmVudGJ1aWxkZXIgPSByZXF1aXJlKCcuLi91dGlscy9ldmVudGJ1aWxkZXIuanMnKTtcblxuY29uc3QgREVGQVVMVF9LRVkgPSAnY2F1c2UnO1xuY29uc3QgREVGQVVMVF9MSU1JVCA9IDU7XG5cbmNvbnN0IElOVEVHUkFUSU9OX05BTUUgPSAnTGlua2VkRXJyb3JzJztcblxuY29uc3QgX2xpbmtlZEVycm9yc0ludGVncmF0aW9uID0gKChvcHRpb25zID0ge30pID0+IHtcbiAgY29uc3QgbGltaXQgPSBvcHRpb25zLmxpbWl0IHx8IERFRkFVTFRfTElNSVQ7XG4gIGNvbnN0IGtleSA9IG9wdGlvbnMua2V5IHx8IERFRkFVTFRfS0VZO1xuXG4gIHJldHVybiB7XG4gICAgbmFtZTogSU5URUdSQVRJT05fTkFNRSxcbiAgICBwcmVwcm9jZXNzRXZlbnQoZXZlbnQsIGhpbnQsIGNsaWVudCkge1xuICAgICAgY29uc3Qgb3B0aW9ucyA9IGNsaWVudC5nZXRPcHRpb25zKCk7XG5cbiAgICAgIGFnZ3JlZ2F0ZUVycm9ycy5hcHBseUFnZ3JlZ2F0ZUVycm9yc1RvRXZlbnQoZXZlbnRidWlsZGVyLmV4Y2VwdGlvbkZyb21FcnJvciwgb3B0aW9ucy5zdGFja1BhcnNlciwga2V5LCBsaW1pdCwgZXZlbnQsIGhpbnQpO1xuICAgIH0sXG4gIH07XG59KSA7XG5cbmNvbnN0IGxpbmtlZEVycm9yc0ludGVncmF0aW9uID0gaW50ZWdyYXRpb24uZGVmaW5lSW50ZWdyYXRpb24oX2xpbmtlZEVycm9yc0ludGVncmF0aW9uKTtcblxuZXhwb3J0cy5saW5rZWRFcnJvcnNJbnRlZ3JhdGlvbiA9IGxpbmtlZEVycm9yc0ludGVncmF0aW9uO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9bGlua2VkZXJyb3JzLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/linkederrors.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/attributeExtraction.js":
/*!***********************************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/attributeExtraction.js ***!
  \***********************************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst url = __webpack_require__(/*! ../../utils/url.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/url.js\");\nconst attributes = __webpack_require__(/*! ./attributes.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/attributes.js\");\nconst methodConfig = __webpack_require__(/*! ./methodConfig.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/methodConfig.js\");\n\n/**\n * Core attribute extraction and building functions for MCP server instrumentation\n */\n\n\n/**\n * Extracts additional attributes for specific notification types\n * @param method - Notification method name\n * @param params - Notification parameters\n * @returns Method-specific attributes for span instrumentation\n */\nfunction getNotificationAttributes(\n  method,\n  params,\n) {\n  const attributes$1 = {};\n\n  switch (method) {\n    case 'notifications/cancelled':\n      if (params?.requestId) {\n        attributes$1['mcp.cancelled.request_id'] = String(params.requestId);\n      }\n      if (params?.reason) {\n        attributes$1['mcp.cancelled.reason'] = String(params.reason);\n      }\n      break;\n\n    case 'notifications/message':\n      if (params?.level) {\n        attributes$1[attributes.MCP_LOGGING_LEVEL_ATTRIBUTE] = String(params.level);\n      }\n      if (params?.logger) {\n        attributes$1[attributes.MCP_LOGGING_LOGGER_ATTRIBUTE] = String(params.logger);\n      }\n      if (params?.data !== undefined) {\n        attributes$1[attributes.MCP_LOGGING_DATA_TYPE_ATTRIBUTE] = typeof params.data;\n        if (typeof params.data === 'string') {\n          attributes$1[attributes.MCP_LOGGING_MESSAGE_ATTRIBUTE] = params.data;\n        } else {\n          attributes$1[attributes.MCP_LOGGING_MESSAGE_ATTRIBUTE] = JSON.stringify(params.data);\n        }\n      }\n      break;\n\n    case 'notifications/progress':\n      if (params?.progressToken) {\n        attributes$1['mcp.progress.token'] = String(params.progressToken);\n      }\n      if (typeof params?.progress === 'number') {\n        attributes$1['mcp.progress.current'] = params.progress;\n      }\n      if (typeof params?.total === 'number') {\n        attributes$1['mcp.progress.total'] = params.total;\n        if (typeof params?.progress === 'number') {\n          attributes$1['mcp.progress.percentage'] = (params.progress / params.total) * 100;\n        }\n      }\n      if (params?.message) {\n        attributes$1['mcp.progress.message'] = String(params.message);\n      }\n      break;\n\n    case 'notifications/resources/updated':\n      if (params?.uri) {\n        attributes$1[attributes.MCP_RESOURCE_URI_ATTRIBUTE] = String(params.uri);\n        const urlObject = url.parseStringToURLObject(String(params.uri));\n        if (urlObject && !url.isURLObjectRelative(urlObject)) {\n          attributes$1['mcp.resource.protocol'] = urlObject.protocol.replace(':', '');\n        }\n      }\n      break;\n\n    case 'notifications/initialized':\n      attributes$1['mcp.lifecycle.phase'] = 'initialization_complete';\n      attributes$1['mcp.protocol.ready'] = 1;\n      break;\n  }\n\n  return attributes$1;\n}\n\n/**\n * Build type-specific attributes based on message type\n * @param type - Span type (request or notification)\n * @param message - JSON-RPC message\n * @param params - Optional parameters for attribute extraction\n * @returns Type-specific attributes for span instrumentation\n */\nfunction buildTypeSpecificAttributes(\n  type,\n  message,\n  params,\n) {\n  if (type === 'request') {\n    const request = message ;\n    const targetInfo = methodConfig.extractTargetInfo(request.method, params || {});\n\n    return {\n      ...(request.id !== undefined && { [attributes.MCP_REQUEST_ID_ATTRIBUTE]: String(request.id) }),\n      ...targetInfo.attributes,\n      ...methodConfig.getRequestArguments(request.method, params || {}),\n    };\n  }\n\n  return getNotificationAttributes(message.method, params || {});\n}\n\nexports.buildTypeSpecificAttributes = buildTypeSpecificAttributes;\nexports.getNotificationAttributes = getNotificationAttributes;\n//# sourceMappingURL=attributeExtraction.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvbWNwLXNlcnZlci9hdHRyaWJ1dGVFeHRyYWN0aW9uLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLFlBQVksbUJBQU8sQ0FBQywySEFBb0I7QUFDeEMsbUJBQW1CLG1CQUFPLENBQUMsaUpBQWlCO0FBQzVDLHFCQUFxQixtQkFBTyxDQUFDLHFKQUFtQjs7QUFFaEQ7QUFDQTtBQUNBOzs7QUFHQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsVUFBVTtBQUNWO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0Esa0ZBQWtGOztBQUVsRjtBQUNBLHdDQUF3QywyREFBMkQ7QUFDbkc7QUFDQSxzRUFBc0U7QUFDdEU7QUFDQTs7QUFFQSwrREFBK0Q7QUFDL0Q7O0FBRUEsbUNBQW1DO0FBQ25DLGlDQUFpQztBQUNqQyIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL2ludGVncmF0aW9ucy9tY3Atc2VydmVyL2F0dHJpYnV0ZUV4dHJhY3Rpb24uanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IHVybCA9IHJlcXVpcmUoJy4uLy4uL3V0aWxzL3VybC5qcycpO1xuY29uc3QgYXR0cmlidXRlcyA9IHJlcXVpcmUoJy4vYXR0cmlidXRlcy5qcycpO1xuY29uc3QgbWV0aG9kQ29uZmlnID0gcmVxdWlyZSgnLi9tZXRob2RDb25maWcuanMnKTtcblxuLyoqXG4gKiBDb3JlIGF0dHJpYnV0ZSBleHRyYWN0aW9uIGFuZCBidWlsZGluZyBmdW5jdGlvbnMgZm9yIE1DUCBzZXJ2ZXIgaW5zdHJ1bWVudGF0aW9uXG4gKi9cblxuXG4vKipcbiAqIEV4dHJhY3RzIGFkZGl0aW9uYWwgYXR0cmlidXRlcyBmb3Igc3BlY2lmaWMgbm90aWZpY2F0aW9uIHR5cGVzXG4gKiBAcGFyYW0gbWV0aG9kIC0gTm90aWZpY2F0aW9uIG1ldGhvZCBuYW1lXG4gKiBAcGFyYW0gcGFyYW1zIC0gTm90aWZpY2F0aW9uIHBhcmFtZXRlcnNcbiAqIEByZXR1cm5zIE1ldGhvZC1zcGVjaWZpYyBhdHRyaWJ1dGVzIGZvciBzcGFuIGluc3RydW1lbnRhdGlvblxuICovXG5mdW5jdGlvbiBnZXROb3RpZmljYXRpb25BdHRyaWJ1dGVzKFxuICBtZXRob2QsXG4gIHBhcmFtcyxcbikge1xuICBjb25zdCBhdHRyaWJ1dGVzJDEgPSB7fTtcblxuICBzd2l0Y2ggKG1ldGhvZCkge1xuICAgIGNhc2UgJ25vdGlmaWNhdGlvbnMvY2FuY2VsbGVkJzpcbiAgICAgIGlmIChwYXJhbXM/LnJlcXVlc3RJZCkge1xuICAgICAgICBhdHRyaWJ1dGVzJDFbJ21jcC5jYW5jZWxsZWQucmVxdWVzdF9pZCddID0gU3RyaW5nKHBhcmFtcy5yZXF1ZXN0SWQpO1xuICAgICAgfVxuICAgICAgaWYgKHBhcmFtcz8ucmVhc29uKSB7XG4gICAgICAgIGF0dHJpYnV0ZXMkMVsnbWNwLmNhbmNlbGxlZC5yZWFzb24nXSA9IFN0cmluZyhwYXJhbXMucmVhc29uKTtcbiAgICAgIH1cbiAgICAgIGJyZWFrO1xuXG4gICAgY2FzZSAnbm90aWZpY2F0aW9ucy9tZXNzYWdlJzpcbiAgICAgIGlmIChwYXJhbXM/LmxldmVsKSB7XG4gICAgICAgIGF0dHJpYnV0ZXMkMVthdHRyaWJ1dGVzLk1DUF9MT0dHSU5HX0xFVkVMX0FUVFJJQlVURV0gPSBTdHJpbmcocGFyYW1zLmxldmVsKTtcbiAgICAgIH1cbiAgICAgIGlmIChwYXJhbXM/LmxvZ2dlcikge1xuICAgICAgICBhdHRyaWJ1dGVzJDFbYXR0cmlidXRlcy5NQ1BfTE9HR0lOR19MT0dHRVJfQVRUUklCVVRFXSA9IFN0cmluZyhwYXJhbXMubG9nZ2VyKTtcbiAgICAgIH1cbiAgICAgIGlmIChwYXJhbXM/LmRhdGEgIT09IHVuZGVmaW5lZCkge1xuICAgICAgICBhdHRyaWJ1dGVzJDFbYXR0cmlidXRlcy5NQ1BfTE9HR0lOR19EQVRBX1RZUEVfQVRUUklCVVRFXSA9IHR5cGVvZiBwYXJhbXMuZGF0YTtcbiAgICAgICAgaWYgKHR5cGVvZiBwYXJhbXMuZGF0YSA9PT0gJ3N0cmluZycpIHtcbiAgICAgICAgICBhdHRyaWJ1dGVzJDFbYXR0cmlidXRlcy5NQ1BfTE9HR0lOR19NRVNTQUdFX0FUVFJJQlVURV0gPSBwYXJhbXMuZGF0YTtcbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICBhdHRyaWJ1dGVzJDFbYXR0cmlidXRlcy5NQ1BfTE9HR0lOR19NRVNTQUdFX0FUVFJJQlVURV0gPSBKU09OLnN0cmluZ2lmeShwYXJhbXMuZGF0YSk7XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICAgIGJyZWFrO1xuXG4gICAgY2FzZSAnbm90aWZpY2F0aW9ucy9wcm9ncmVzcyc6XG4gICAgICBpZiAocGFyYW1zPy5wcm9ncmVzc1Rva2VuKSB7XG4gICAgICAgIGF0dHJpYnV0ZXMkMVsnbWNwLnByb2dyZXNzLnRva2VuJ10gPSBTdHJpbmcocGFyYW1zLnByb2dyZXNzVG9rZW4pO1xuICAgICAgfVxuICAgICAgaWYgKHR5cGVvZiBwYXJhbXM/LnByb2dyZXNzID09PSAnbnVtYmVyJykge1xuICAgICAgICBhdHRyaWJ1dGVzJDFbJ21jcC5wcm9ncmVzcy5jdXJyZW50J10gPSBwYXJhbXMucHJvZ3Jlc3M7XG4gICAgICB9XG4gICAgICBpZiAodHlwZW9mIHBhcmFtcz8udG90YWwgPT09ICdudW1iZXInKSB7XG4gICAgICAgIGF0dHJpYnV0ZXMkMVsnbWNwLnByb2dyZXNzLnRvdGFsJ10gPSBwYXJhbXMudG90YWw7XG4gICAgICAgIGlmICh0eXBlb2YgcGFyYW1zPy5wcm9ncmVzcyA9PT0gJ251bWJlcicpIHtcbiAgICAgICAgICBhdHRyaWJ1dGVzJDFbJ21jcC5wcm9ncmVzcy5wZXJjZW50YWdlJ10gPSAocGFyYW1zLnByb2dyZXNzIC8gcGFyYW1zLnRvdGFsKSAqIDEwMDtcbiAgICAgICAgfVxuICAgICAgfVxuICAgICAgaWYgKHBhcmFtcz8ubWVzc2FnZSkge1xuICAgICAgICBhdHRyaWJ1dGVzJDFbJ21jcC5wcm9ncmVzcy5tZXNzYWdlJ10gPSBTdHJpbmcocGFyYW1zLm1lc3NhZ2UpO1xuICAgICAgfVxuICAgICAgYnJlYWs7XG5cbiAgICBjYXNlICdub3RpZmljYXRpb25zL3Jlc291cmNlcy91cGRhdGVkJzpcbiAgICAgIGlmIChwYXJhbXM/LnVyaSkge1xuICAgICAgICBhdHRyaWJ1dGVzJDFbYXR0cmlidXRlcy5NQ1BfUkVTT1VSQ0VfVVJJX0FUVFJJQlVURV0gPSBTdHJpbmcocGFyYW1zLnVyaSk7XG4gICAgICAgIGNvbnN0IHVybE9iamVjdCA9IHVybC5wYXJzZVN0cmluZ1RvVVJMT2JqZWN0KFN0cmluZyhwYXJhbXMudXJpKSk7XG4gICAgICAgIGlmICh1cmxPYmplY3QgJiYgIXVybC5pc1VSTE9iamVjdFJlbGF0aXZlKHVybE9iamVjdCkpIHtcbiAgICAgICAgICBhdHRyaWJ1dGVzJDFbJ21jcC5yZXNvdXJjZS5wcm90b2NvbCddID0gdXJsT2JqZWN0LnByb3RvY29sLnJlcGxhY2UoJzonLCAnJyk7XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICAgIGJyZWFrO1xuXG4gICAgY2FzZSAnbm90aWZpY2F0aW9ucy9pbml0aWFsaXplZCc6XG4gICAgICBhdHRyaWJ1dGVzJDFbJ21jcC5saWZlY3ljbGUucGhhc2UnXSA9ICdpbml0aWFsaXphdGlvbl9jb21wbGV0ZSc7XG4gICAgICBhdHRyaWJ1dGVzJDFbJ21jcC5wcm90b2NvbC5yZWFkeSddID0gMTtcbiAgICAgIGJyZWFrO1xuICB9XG5cbiAgcmV0dXJuIGF0dHJpYnV0ZXMkMTtcbn1cblxuLyoqXG4gKiBCdWlsZCB0eXBlLXNwZWNpZmljIGF0dHJpYnV0ZXMgYmFzZWQgb24gbWVzc2FnZSB0eXBlXG4gKiBAcGFyYW0gdHlwZSAtIFNwYW4gdHlwZSAocmVxdWVzdCBvciBub3RpZmljYXRpb24pXG4gKiBAcGFyYW0gbWVzc2FnZSAtIEpTT04tUlBDIG1lc3NhZ2VcbiAqIEBwYXJhbSBwYXJhbXMgLSBPcHRpb25hbCBwYXJhbWV0ZXJzIGZvciBhdHRyaWJ1dGUgZXh0cmFjdGlvblxuICogQHJldHVybnMgVHlwZS1zcGVjaWZpYyBhdHRyaWJ1dGVzIGZvciBzcGFuIGluc3RydW1lbnRhdGlvblxuICovXG5mdW5jdGlvbiBidWlsZFR5cGVTcGVjaWZpY0F0dHJpYnV0ZXMoXG4gIHR5cGUsXG4gIG1lc3NhZ2UsXG4gIHBhcmFtcyxcbikge1xuICBpZiAodHlwZSA9PT0gJ3JlcXVlc3QnKSB7XG4gICAgY29uc3QgcmVxdWVzdCA9IG1lc3NhZ2UgO1xuICAgIGNvbnN0IHRhcmdldEluZm8gPSBtZXRob2RDb25maWcuZXh0cmFjdFRhcmdldEluZm8ocmVxdWVzdC5tZXRob2QsIHBhcmFtcyB8fCB7fSk7XG5cbiAgICByZXR1cm4ge1xuICAgICAgLi4uKHJlcXVlc3QuaWQgIT09IHVuZGVmaW5lZCAmJiB7IFthdHRyaWJ1dGVzLk1DUF9SRVFVRVNUX0lEX0FUVFJJQlVURV06IFN0cmluZyhyZXF1ZXN0LmlkKSB9KSxcbiAgICAgIC4uLnRhcmdldEluZm8uYXR0cmlidXRlcyxcbiAgICAgIC4uLm1ldGhvZENvbmZpZy5nZXRSZXF1ZXN0QXJndW1lbnRzKHJlcXVlc3QubWV0aG9kLCBwYXJhbXMgfHwge30pLFxuICAgIH07XG4gIH1cblxuICByZXR1cm4gZ2V0Tm90aWZpY2F0aW9uQXR0cmlidXRlcyhtZXNzYWdlLm1ldGhvZCwgcGFyYW1zIHx8IHt9KTtcbn1cblxuZXhwb3J0cy5idWlsZFR5cGVTcGVjaWZpY0F0dHJpYnV0ZXMgPSBidWlsZFR5cGVTcGVjaWZpY0F0dHJpYnV0ZXM7XG5leHBvcnRzLmdldE5vdGlmaWNhdGlvbkF0dHJpYnV0ZXMgPSBnZXROb3RpZmljYXRpb25BdHRyaWJ1dGVzO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9YXR0cmlidXRlRXh0cmFjdGlvbi5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/attributeExtraction.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/attributes.js":
/*!**************************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/attributes.js ***!
  \**************************************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n/**\n * Essential MCP attribute constants for Sentry instrumentation\n *\n * Based on OpenTelemetry MCP semantic conventions\n * @see https://github.com/open-telemetry/semantic-conventions/blob/3097fb0af5b9492b0e3f55dc5f6c21a3dc2be8df/docs/gen-ai/mcp.md\n */\n\n// =============================================================================\n// CORE MCP ATTRIBUTES\n// =============================================================================\n\n/** The name of the request or notification method */\nconst MCP_METHOD_NAME_ATTRIBUTE = 'mcp.method.name';\n\n/** JSON-RPC request identifier for the request. Unique within the MCP session. */\nconst MCP_REQUEST_ID_ATTRIBUTE = 'mcp.request.id';\n\n/** Identifies the MCP session */\nconst MCP_SESSION_ID_ATTRIBUTE = 'mcp.session.id';\n\n/** Transport method used for MCP communication */\nconst MCP_TRANSPORT_ATTRIBUTE = 'mcp.transport';\n\n// =============================================================================\n// SERVER ATTRIBUTES\n// =============================================================================\n\n/** Name of the MCP server application */\nconst MCP_SERVER_NAME_ATTRIBUTE = 'mcp.server.name';\n\n/** Display title of the MCP server application */\nconst MCP_SERVER_TITLE_ATTRIBUTE = 'mcp.server.title';\n\n/** Version of the MCP server application */\nconst MCP_SERVER_VERSION_ATTRIBUTE = 'mcp.server.version';\n\n/** MCP protocol version used in the session */\nconst MCP_PROTOCOL_VERSION_ATTRIBUTE = 'mcp.protocol.version';\n\n// =============================================================================\n// METHOD-SPECIFIC ATTRIBUTES\n// =============================================================================\n\n/** Name of the tool being called */\nconst MCP_TOOL_NAME_ATTRIBUTE = 'mcp.tool.name';\n\n/** The resource URI being accessed */\nconst MCP_RESOURCE_URI_ATTRIBUTE = 'mcp.resource.uri';\n\n/** Name of the prompt template */\nconst MCP_PROMPT_NAME_ATTRIBUTE = 'mcp.prompt.name';\n\n// =============================================================================\n// TOOL RESULT ATTRIBUTES\n// =============================================================================\n\n/** Whether a tool execution resulted in an error */\nconst MCP_TOOL_RESULT_IS_ERROR_ATTRIBUTE = 'mcp.tool.result.is_error';\n\n/** Number of content items in the tool result */\nconst MCP_TOOL_RESULT_CONTENT_COUNT_ATTRIBUTE = 'mcp.tool.result.content_count';\n\n/** Serialized content of the tool result */\nconst MCP_TOOL_RESULT_CONTENT_ATTRIBUTE = 'mcp.tool.result.content';\n\n/** Prefix for tool result attributes that contain sensitive content */\nconst MCP_TOOL_RESULT_PREFIX = 'mcp.tool.result';\n\n// =============================================================================\n// PROMPT RESULT ATTRIBUTES\n// =============================================================================\n\n/** Description of the prompt result */\nconst MCP_PROMPT_RESULT_DESCRIPTION_ATTRIBUTE = 'mcp.prompt.result.description';\n\n/** Number of messages in the prompt result */\nconst MCP_PROMPT_RESULT_MESSAGE_COUNT_ATTRIBUTE = 'mcp.prompt.result.message_count';\n\n/** Content of the message in the prompt result (for single message results) */\nconst MCP_PROMPT_RESULT_MESSAGE_CONTENT_ATTRIBUTE = 'mcp.prompt.result.message_content';\n\n/** Prefix for prompt result attributes that contain sensitive content */\nconst MCP_PROMPT_RESULT_PREFIX = 'mcp.prompt.result';\n\n// =============================================================================\n// REQUEST ARGUMENT ATTRIBUTES\n// =============================================================================\n\n/** Prefix for MCP request argument prefix for each argument */\nconst MCP_REQUEST_ARGUMENT = 'mcp.request.argument';\n\n// =============================================================================\n// LOGGING ATTRIBUTES\n// =============================================================================\n\n/** Log level for MCP logging operations */\nconst MCP_LOGGING_LEVEL_ATTRIBUTE = 'mcp.logging.level';\n\n/** Logger name for MCP logging operations */\nconst MCP_LOGGING_LOGGER_ATTRIBUTE = 'mcp.logging.logger';\n\n/** Data type of the logged message */\nconst MCP_LOGGING_DATA_TYPE_ATTRIBUTE = 'mcp.logging.data_type';\n\n/** Log message content */\nconst MCP_LOGGING_MESSAGE_ATTRIBUTE = 'mcp.logging.message';\n\n// =============================================================================\n// NETWORK ATTRIBUTES (OpenTelemetry Standard)\n// =============================================================================\n\n/** OSI transport layer protocol */\nconst NETWORK_TRANSPORT_ATTRIBUTE = 'network.transport';\n\n/** The version of JSON RPC protocol used */\nconst NETWORK_PROTOCOL_VERSION_ATTRIBUTE = 'network.protocol.version';\n\n/** Client address - domain name if available without reverse DNS lookup; otherwise, IP address or Unix domain socket name */\nconst CLIENT_ADDRESS_ATTRIBUTE = 'client.address';\n\n/** Client port number */\nconst CLIENT_PORT_ATTRIBUTE = 'client.port';\n\n// =============================================================================\n// SENTRY-SPECIFIC MCP ATTRIBUTE VALUES\n// =============================================================================\n\n/** Sentry operation value for MCP server spans */\nconst MCP_SERVER_OP_VALUE = 'mcp.server';\n\n/**\n * Sentry operation value for client-to-server notifications\n * Following OpenTelemetry MCP semantic conventions\n */\nconst MCP_NOTIFICATION_CLIENT_TO_SERVER_OP_VALUE = 'mcp.notification.client_to_server';\n\n/**\n * Sentry operation value for server-to-client notifications\n * Following OpenTelemetry MCP semantic conventions\n */\nconst MCP_NOTIFICATION_SERVER_TO_CLIENT_OP_VALUE = 'mcp.notification.server_to_client';\n\n/** Sentry origin value for MCP function spans */\nconst MCP_FUNCTION_ORIGIN_VALUE = 'auto.function.mcp_server';\n\n/** Sentry origin value for MCP notification spans */\nconst MCP_NOTIFICATION_ORIGIN_VALUE = 'auto.mcp.notification';\n\n/** Sentry source value for MCP route spans */\nconst MCP_ROUTE_SOURCE_VALUE = 'route';\n\nexports.CLIENT_ADDRESS_ATTRIBUTE = CLIENT_ADDRESS_ATTRIBUTE;\nexports.CLIENT_PORT_ATTRIBUTE = CLIENT_PORT_ATTRIBUTE;\nexports.MCP_FUNCTION_ORIGIN_VALUE = MCP_FUNCTION_ORIGIN_VALUE;\nexports.MCP_LOGGING_DATA_TYPE_ATTRIBUTE = MCP_LOGGING_DATA_TYPE_ATTRIBUTE;\nexports.MCP_LOGGING_LEVEL_ATTRIBUTE = MCP_LOGGING_LEVEL_ATTRIBUTE;\nexports.MCP_LOGGING_LOGGER_ATTRIBUTE = MCP_LOGGING_LOGGER_ATTRIBUTE;\nexports.MCP_LOGGING_MESSAGE_ATTRIBUTE = MCP_LOGGING_MESSAGE_ATTRIBUTE;\nexports.MCP_METHOD_NAME_ATTRIBUTE = MCP_METHOD_NAME_ATTRIBUTE;\nexports.MCP_NOTIFICATION_CLIENT_TO_SERVER_OP_VALUE = MCP_NOTIFICATION_CLIENT_TO_SERVER_OP_VALUE;\nexports.MCP_NOTIFICATION_ORIGIN_VALUE = MCP_NOTIFICATION_ORIGIN_VALUE;\nexports.MCP_NOTIFICATION_SERVER_TO_CLIENT_OP_VALUE = MCP_NOTIFICATION_SERVER_TO_CLIENT_OP_VALUE;\nexports.MCP_PROMPT_NAME_ATTRIBUTE = MCP_PROMPT_NAME_ATTRIBUTE;\nexports.MCP_PROMPT_RESULT_DESCRIPTION_ATTRIBUTE = MCP_PROMPT_RESULT_DESCRIPTION_ATTRIBUTE;\nexports.MCP_PROMPT_RESULT_MESSAGE_CONTENT_ATTRIBUTE = MCP_PROMPT_RESULT_MESSAGE_CONTENT_ATTRIBUTE;\nexports.MCP_PROMPT_RESULT_MESSAGE_COUNT_ATTRIBUTE = MCP_PROMPT_RESULT_MESSAGE_COUNT_ATTRIBUTE;\nexports.MCP_PROMPT_RESULT_PREFIX = MCP_PROMPT_RESULT_PREFIX;\nexports.MCP_PROTOCOL_VERSION_ATTRIBUTE = MCP_PROTOCOL_VERSION_ATTRIBUTE;\nexports.MCP_REQUEST_ARGUMENT = MCP_REQUEST_ARGUMENT;\nexports.MCP_REQUEST_ID_ATTRIBUTE = MCP_REQUEST_ID_ATTRIBUTE;\nexports.MCP_RESOURCE_URI_ATTRIBUTE = MCP_RESOURCE_URI_ATTRIBUTE;\nexports.MCP_ROUTE_SOURCE_VALUE = MCP_ROUTE_SOURCE_VALUE;\nexports.MCP_SERVER_NAME_ATTRIBUTE = MCP_SERVER_NAME_ATTRIBUTE;\nexports.MCP_SERVER_OP_VALUE = MCP_SERVER_OP_VALUE;\nexports.MCP_SERVER_TITLE_ATTRIBUTE = MCP_SERVER_TITLE_ATTRIBUTE;\nexports.MCP_SERVER_VERSION_ATTRIBUTE = MCP_SERVER_VERSION_ATTRIBUTE;\nexports.MCP_SESSION_ID_ATTRIBUTE = MCP_SESSION_ID_ATTRIBUTE;\nexports.MCP_TOOL_NAME_ATTRIBUTE = MCP_TOOL_NAME_ATTRIBUTE;\nexports.MCP_TOOL_RESULT_CONTENT_ATTRIBUTE = MCP_TOOL_RESULT_CONTENT_ATTRIBUTE;\nexports.MCP_TOOL_RESULT_CONTENT_COUNT_ATTRIBUTE = MCP_TOOL_RESULT_CONTENT_COUNT_ATTRIBUTE;\nexports.MCP_TOOL_RESULT_IS_ERROR_ATTRIBUTE = MCP_TOOL_RESULT_IS_ERROR_ATTRIBUTE;\nexports.MCP_TOOL_RESULT_PREFIX = MCP_TOOL_RESULT_PREFIX;\nexports.MCP_TRANSPORT_ATTRIBUTE = MCP_TRANSPORT_ATTRIBUTE;\nexports.NETWORK_PROTOCOL_VERSION_ATTRIBUTE = NETWORK_PROTOCOL_VERSION_ATTRIBUTE;\nexports.NETWORK_TRANSPORT_ATTRIBUTE = NETWORK_TRANSPORT_ATTRIBUTE;\n//# sourceMappingURL=attributes.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvbWNwLXNlcnZlci9hdHRyaWJ1dGVzLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQSwwRUFBMEU7QUFDMUU7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUEsZ0NBQWdDO0FBQ2hDLDZCQUE2QjtBQUM3QixpQ0FBaUM7QUFDakMsdUNBQXVDO0FBQ3ZDLG1DQUFtQztBQUNuQyxvQ0FBb0M7QUFDcEMscUNBQXFDO0FBQ3JDLGlDQUFpQztBQUNqQyxrREFBa0Q7QUFDbEQscUNBQXFDO0FBQ3JDLGtEQUFrRDtBQUNsRCxpQ0FBaUM7QUFDakMsK0NBQStDO0FBQy9DLG1EQUFtRDtBQUNuRCxpREFBaUQ7QUFDakQsZ0NBQWdDO0FBQ2hDLHNDQUFzQztBQUN0Qyw0QkFBNEI7QUFDNUIsZ0NBQWdDO0FBQ2hDLGtDQUFrQztBQUNsQyw4QkFBOEI7QUFDOUIsaUNBQWlDO0FBQ2pDLDJCQUEyQjtBQUMzQixrQ0FBa0M7QUFDbEMsb0NBQW9DO0FBQ3BDLGdDQUFnQztBQUNoQywrQkFBK0I7QUFDL0IseUNBQXlDO0FBQ3pDLCtDQUErQztBQUMvQywwQ0FBMEM7QUFDMUMsOEJBQThCO0FBQzlCLCtCQUErQjtBQUMvQiwwQ0FBMEM7QUFDMUMsbUNBQW1DO0FBQ25DIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvaW50ZWdyYXRpb25zL21jcC1zZXJ2ZXIvYXR0cmlidXRlcy5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuLyoqXG4gKiBFc3NlbnRpYWwgTUNQIGF0dHJpYnV0ZSBjb25zdGFudHMgZm9yIFNlbnRyeSBpbnN0cnVtZW50YXRpb25cbiAqXG4gKiBCYXNlZCBvbiBPcGVuVGVsZW1ldHJ5IE1DUCBzZW1hbnRpYyBjb252ZW50aW9uc1xuICogQHNlZSBodHRwczovL2dpdGh1Yi5jb20vb3Blbi10ZWxlbWV0cnkvc2VtYW50aWMtY29udmVudGlvbnMvYmxvYi8zMDk3ZmIwYWY1Yjk0OTJiMGUzZjU1ZGM1ZjZjMjFhM2RjMmJlOGRmL2RvY3MvZ2VuLWFpL21jcC5tZFxuICovXG5cbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG4vLyBDT1JFIE1DUCBBVFRSSUJVVEVTXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuXG4vKiogVGhlIG5hbWUgb2YgdGhlIHJlcXVlc3Qgb3Igbm90aWZpY2F0aW9uIG1ldGhvZCAqL1xuY29uc3QgTUNQX01FVEhPRF9OQU1FX0FUVFJJQlVURSA9ICdtY3AubWV0aG9kLm5hbWUnO1xuXG4vKiogSlNPTi1SUEMgcmVxdWVzdCBpZGVudGlmaWVyIGZvciB0aGUgcmVxdWVzdC4gVW5pcXVlIHdpdGhpbiB0aGUgTUNQIHNlc3Npb24uICovXG5jb25zdCBNQ1BfUkVRVUVTVF9JRF9BVFRSSUJVVEUgPSAnbWNwLnJlcXVlc3QuaWQnO1xuXG4vKiogSWRlbnRpZmllcyB0aGUgTUNQIHNlc3Npb24gKi9cbmNvbnN0IE1DUF9TRVNTSU9OX0lEX0FUVFJJQlVURSA9ICdtY3Auc2Vzc2lvbi5pZCc7XG5cbi8qKiBUcmFuc3BvcnQgbWV0aG9kIHVzZWQgZm9yIE1DUCBjb21tdW5pY2F0aW9uICovXG5jb25zdCBNQ1BfVFJBTlNQT1JUX0FUVFJJQlVURSA9ICdtY3AudHJhbnNwb3J0JztcblxuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cbi8vIFNFUlZFUiBBVFRSSUJVVEVTXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuXG4vKiogTmFtZSBvZiB0aGUgTUNQIHNlcnZlciBhcHBsaWNhdGlvbiAqL1xuY29uc3QgTUNQX1NFUlZFUl9OQU1FX0FUVFJJQlVURSA9ICdtY3Auc2VydmVyLm5hbWUnO1xuXG4vKiogRGlzcGxheSB0aXRsZSBvZiB0aGUgTUNQIHNlcnZlciBhcHBsaWNhdGlvbiAqL1xuY29uc3QgTUNQX1NFUlZFUl9USVRMRV9BVFRSSUJVVEUgPSAnbWNwLnNlcnZlci50aXRsZSc7XG5cbi8qKiBWZXJzaW9uIG9mIHRoZSBNQ1Agc2VydmVyIGFwcGxpY2F0aW9uICovXG5jb25zdCBNQ1BfU0VSVkVSX1ZFUlNJT05fQVRUUklCVVRFID0gJ21jcC5zZXJ2ZXIudmVyc2lvbic7XG5cbi8qKiBNQ1AgcHJvdG9jb2wgdmVyc2lvbiB1c2VkIGluIHRoZSBzZXNzaW9uICovXG5jb25zdCBNQ1BfUFJPVE9DT0xfVkVSU0lPTl9BVFRSSUJVVEUgPSAnbWNwLnByb3RvY29sLnZlcnNpb24nO1xuXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuLy8gTUVUSE9ELVNQRUNJRklDIEFUVFJJQlVURVNcbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG5cbi8qKiBOYW1lIG9mIHRoZSB0b29sIGJlaW5nIGNhbGxlZCAqL1xuY29uc3QgTUNQX1RPT0xfTkFNRV9BVFRSSUJVVEUgPSAnbWNwLnRvb2wubmFtZSc7XG5cbi8qKiBUaGUgcmVzb3VyY2UgVVJJIGJlaW5nIGFjY2Vzc2VkICovXG5jb25zdCBNQ1BfUkVTT1VSQ0VfVVJJX0FUVFJJQlVURSA9ICdtY3AucmVzb3VyY2UudXJpJztcblxuLyoqIE5hbWUgb2YgdGhlIHByb21wdCB0ZW1wbGF0ZSAqL1xuY29uc3QgTUNQX1BST01QVF9OQU1FX0FUVFJJQlVURSA9ICdtY3AucHJvbXB0Lm5hbWUnO1xuXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuLy8gVE9PTCBSRVNVTFQgQVRUUklCVVRFU1xuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cblxuLyoqIFdoZXRoZXIgYSB0b29sIGV4ZWN1dGlvbiByZXN1bHRlZCBpbiBhbiBlcnJvciAqL1xuY29uc3QgTUNQX1RPT0xfUkVTVUxUX0lTX0VSUk9SX0FUVFJJQlVURSA9ICdtY3AudG9vbC5yZXN1bHQuaXNfZXJyb3InO1xuXG4vKiogTnVtYmVyIG9mIGNvbnRlbnQgaXRlbXMgaW4gdGhlIHRvb2wgcmVzdWx0ICovXG5jb25zdCBNQ1BfVE9PTF9SRVNVTFRfQ09OVEVOVF9DT1VOVF9BVFRSSUJVVEUgPSAnbWNwLnRvb2wucmVzdWx0LmNvbnRlbnRfY291bnQnO1xuXG4vKiogU2VyaWFsaXplZCBjb250ZW50IG9mIHRoZSB0b29sIHJlc3VsdCAqL1xuY29uc3QgTUNQX1RPT0xfUkVTVUxUX0NPTlRFTlRfQVRUUklCVVRFID0gJ21jcC50b29sLnJlc3VsdC5jb250ZW50JztcblxuLyoqIFByZWZpeCBmb3IgdG9vbCByZXN1bHQgYXR0cmlidXRlcyB0aGF0IGNvbnRhaW4gc2Vuc2l0aXZlIGNvbnRlbnQgKi9cbmNvbnN0IE1DUF9UT09MX1JFU1VMVF9QUkVGSVggPSAnbWNwLnRvb2wucmVzdWx0JztcblxuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cbi8vIFBST01QVCBSRVNVTFQgQVRUUklCVVRFU1xuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cblxuLyoqIERlc2NyaXB0aW9uIG9mIHRoZSBwcm9tcHQgcmVzdWx0ICovXG5jb25zdCBNQ1BfUFJPTVBUX1JFU1VMVF9ERVNDUklQVElPTl9BVFRSSUJVVEUgPSAnbWNwLnByb21wdC5yZXN1bHQuZGVzY3JpcHRpb24nO1xuXG4vKiogTnVtYmVyIG9mIG1lc3NhZ2VzIGluIHRoZSBwcm9tcHQgcmVzdWx0ICovXG5jb25zdCBNQ1BfUFJPTVBUX1JFU1VMVF9NRVNTQUdFX0NPVU5UX0FUVFJJQlVURSA9ICdtY3AucHJvbXB0LnJlc3VsdC5tZXNzYWdlX2NvdW50JztcblxuLyoqIENvbnRlbnQgb2YgdGhlIG1lc3NhZ2UgaW4gdGhlIHByb21wdCByZXN1bHQgKGZvciBzaW5nbGUgbWVzc2FnZSByZXN1bHRzKSAqL1xuY29uc3QgTUNQX1BST01QVF9SRVNVTFRfTUVTU0FHRV9DT05URU5UX0FUVFJJQlVURSA9ICdtY3AucHJvbXB0LnJlc3VsdC5tZXNzYWdlX2NvbnRlbnQnO1xuXG4vKiogUHJlZml4IGZvciBwcm9tcHQgcmVzdWx0IGF0dHJpYnV0ZXMgdGhhdCBjb250YWluIHNlbnNpdGl2ZSBjb250ZW50ICovXG5jb25zdCBNQ1BfUFJPTVBUX1JFU1VMVF9QUkVGSVggPSAnbWNwLnByb21wdC5yZXN1bHQnO1xuXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuLy8gUkVRVUVTVCBBUkdVTUVOVCBBVFRSSUJVVEVTXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuXG4vKiogUHJlZml4IGZvciBNQ1AgcmVxdWVzdCBhcmd1bWVudCBwcmVmaXggZm9yIGVhY2ggYXJndW1lbnQgKi9cbmNvbnN0IE1DUF9SRVFVRVNUX0FSR1VNRU5UID0gJ21jcC5yZXF1ZXN0LmFyZ3VtZW50JztcblxuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cbi8vIExPR0dJTkcgQVRUUklCVVRFU1xuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cblxuLyoqIExvZyBsZXZlbCBmb3IgTUNQIGxvZ2dpbmcgb3BlcmF0aW9ucyAqL1xuY29uc3QgTUNQX0xPR0dJTkdfTEVWRUxfQVRUUklCVVRFID0gJ21jcC5sb2dnaW5nLmxldmVsJztcblxuLyoqIExvZ2dlciBuYW1lIGZvciBNQ1AgbG9nZ2luZyBvcGVyYXRpb25zICovXG5jb25zdCBNQ1BfTE9HR0lOR19MT0dHRVJfQVRUUklCVVRFID0gJ21jcC5sb2dnaW5nLmxvZ2dlcic7XG5cbi8qKiBEYXRhIHR5cGUgb2YgdGhlIGxvZ2dlZCBtZXNzYWdlICovXG5jb25zdCBNQ1BfTE9HR0lOR19EQVRBX1RZUEVfQVRUUklCVVRFID0gJ21jcC5sb2dnaW5nLmRhdGFfdHlwZSc7XG5cbi8qKiBMb2cgbWVzc2FnZSBjb250ZW50ICovXG5jb25zdCBNQ1BfTE9HR0lOR19NRVNTQUdFX0FUVFJJQlVURSA9ICdtY3AubG9nZ2luZy5tZXNzYWdlJztcblxuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cbi8vIE5FVFdPUksgQVRUUklCVVRFUyAoT3BlblRlbGVtZXRyeSBTdGFuZGFyZClcbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG5cbi8qKiBPU0kgdHJhbnNwb3J0IGxheWVyIHByb3RvY29sICovXG5jb25zdCBORVRXT1JLX1RSQU5TUE9SVF9BVFRSSUJVVEUgPSAnbmV0d29yay50cmFuc3BvcnQnO1xuXG4vKiogVGhlIHZlcnNpb24gb2YgSlNPTiBSUEMgcHJvdG9jb2wgdXNlZCAqL1xuY29uc3QgTkVUV09SS19QUk9UT0NPTF9WRVJTSU9OX0FUVFJJQlVURSA9ICduZXR3b3JrLnByb3RvY29sLnZlcnNpb24nO1xuXG4vKiogQ2xpZW50IGFkZHJlc3MgLSBkb21haW4gbmFtZSBpZiBhdmFpbGFibGUgd2l0aG91dCByZXZlcnNlIEROUyBsb29rdXA7IG90aGVyd2lzZSwgSVAgYWRkcmVzcyBvciBVbml4IGRvbWFpbiBzb2NrZXQgbmFtZSAqL1xuY29uc3QgQ0xJRU5UX0FERFJFU1NfQVRUUklCVVRFID0gJ2NsaWVudC5hZGRyZXNzJztcblxuLyoqIENsaWVudCBwb3J0IG51bWJlciAqL1xuY29uc3QgQ0xJRU5UX1BPUlRfQVRUUklCVVRFID0gJ2NsaWVudC5wb3J0JztcblxuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cbi8vIFNFTlRSWS1TUEVDSUZJQyBNQ1AgQVRUUklCVVRFIFZBTFVFU1xuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cblxuLyoqIFNlbnRyeSBvcGVyYXRpb24gdmFsdWUgZm9yIE1DUCBzZXJ2ZXIgc3BhbnMgKi9cbmNvbnN0IE1DUF9TRVJWRVJfT1BfVkFMVUUgPSAnbWNwLnNlcnZlcic7XG5cbi8qKlxuICogU2VudHJ5IG9wZXJhdGlvbiB2YWx1ZSBmb3IgY2xpZW50LXRvLXNlcnZlciBub3RpZmljYXRpb25zXG4gKiBGb2xsb3dpbmcgT3BlblRlbGVtZXRyeSBNQ1Agc2VtYW50aWMgY29udmVudGlvbnNcbiAqL1xuY29uc3QgTUNQX05PVElGSUNBVElPTl9DTElFTlRfVE9fU0VSVkVSX09QX1ZBTFVFID0gJ21jcC5ub3RpZmljYXRpb24uY2xpZW50X3RvX3NlcnZlcic7XG5cbi8qKlxuICogU2VudHJ5IG9wZXJhdGlvbiB2YWx1ZSBmb3Igc2VydmVyLXRvLWNsaWVudCBub3RpZmljYXRpb25zXG4gKiBGb2xsb3dpbmcgT3BlblRlbGVtZXRyeSBNQ1Agc2VtYW50aWMgY29udmVudGlvbnNcbiAqL1xuY29uc3QgTUNQX05PVElGSUNBVElPTl9TRVJWRVJfVE9fQ0xJRU5UX09QX1ZBTFVFID0gJ21jcC5ub3RpZmljYXRpb24uc2VydmVyX3RvX2NsaWVudCc7XG5cbi8qKiBTZW50cnkgb3JpZ2luIHZhbHVlIGZvciBNQ1AgZnVuY3Rpb24gc3BhbnMgKi9cbmNvbnN0IE1DUF9GVU5DVElPTl9PUklHSU5fVkFMVUUgPSAnYXV0by5mdW5jdGlvbi5tY3Bfc2VydmVyJztcblxuLyoqIFNlbnRyeSBvcmlnaW4gdmFsdWUgZm9yIE1DUCBub3RpZmljYXRpb24gc3BhbnMgKi9cbmNvbnN0IE1DUF9OT1RJRklDQVRJT05fT1JJR0lOX1ZBTFVFID0gJ2F1dG8ubWNwLm5vdGlmaWNhdGlvbic7XG5cbi8qKiBTZW50cnkgc291cmNlIHZhbHVlIGZvciBNQ1Agcm91dGUgc3BhbnMgKi9cbmNvbnN0IE1DUF9ST1VURV9TT1VSQ0VfVkFMVUUgPSAncm91dGUnO1xuXG5leHBvcnRzLkNMSUVOVF9BRERSRVNTX0FUVFJJQlVURSA9IENMSUVOVF9BRERSRVNTX0FUVFJJQlVURTtcbmV4cG9ydHMuQ0xJRU5UX1BPUlRfQVRUUklCVVRFID0gQ0xJRU5UX1BPUlRfQVRUUklCVVRFO1xuZXhwb3J0cy5NQ1BfRlVOQ1RJT05fT1JJR0lOX1ZBTFVFID0gTUNQX0ZVTkNUSU9OX09SSUdJTl9WQUxVRTtcbmV4cG9ydHMuTUNQX0xPR0dJTkdfREFUQV9UWVBFX0FUVFJJQlVURSA9IE1DUF9MT0dHSU5HX0RBVEFfVFlQRV9BVFRSSUJVVEU7XG5leHBvcnRzLk1DUF9MT0dHSU5HX0xFVkVMX0FUVFJJQlVURSA9IE1DUF9MT0dHSU5HX0xFVkVMX0FUVFJJQlVURTtcbmV4cG9ydHMuTUNQX0xPR0dJTkdfTE9HR0VSX0FUVFJJQlVURSA9IE1DUF9MT0dHSU5HX0xPR0dFUl9BVFRSSUJVVEU7XG5leHBvcnRzLk1DUF9MT0dHSU5HX01FU1NBR0VfQVRUUklCVVRFID0gTUNQX0xPR0dJTkdfTUVTU0FHRV9BVFRSSUJVVEU7XG5leHBvcnRzLk1DUF9NRVRIT0RfTkFNRV9BVFRSSUJVVEUgPSBNQ1BfTUVUSE9EX05BTUVfQVRUUklCVVRFO1xuZXhwb3J0cy5NQ1BfTk9USUZJQ0FUSU9OX0NMSUVOVF9UT19TRVJWRVJfT1BfVkFMVUUgPSBNQ1BfTk9USUZJQ0FUSU9OX0NMSUVOVF9UT19TRVJWRVJfT1BfVkFMVUU7XG5leHBvcnRzLk1DUF9OT1RJRklDQVRJT05fT1JJR0lOX1ZBTFVFID0gTUNQX05PVElGSUNBVElPTl9PUklHSU5fVkFMVUU7XG5leHBvcnRzLk1DUF9OT1RJRklDQVRJT05fU0VSVkVSX1RPX0NMSUVOVF9PUF9WQUxVRSA9IE1DUF9OT1RJRklDQVRJT05fU0VSVkVSX1RPX0NMSUVOVF9PUF9WQUxVRTtcbmV4cG9ydHMuTUNQX1BST01QVF9OQU1FX0FUVFJJQlVURSA9IE1DUF9QUk9NUFRfTkFNRV9BVFRSSUJVVEU7XG5leHBvcnRzLk1DUF9QUk9NUFRfUkVTVUxUX0RFU0NSSVBUSU9OX0FUVFJJQlVURSA9IE1DUF9QUk9NUFRfUkVTVUxUX0RFU0NSSVBUSU9OX0FUVFJJQlVURTtcbmV4cG9ydHMuTUNQX1BST01QVF9SRVNVTFRfTUVTU0FHRV9DT05URU5UX0FUVFJJQlVURSA9IE1DUF9QUk9NUFRfUkVTVUxUX01FU1NBR0VfQ09OVEVOVF9BVFRSSUJVVEU7XG5leHBvcnRzLk1DUF9QUk9NUFRfUkVTVUxUX01FU1NBR0VfQ09VTlRfQVRUUklCVVRFID0gTUNQX1BST01QVF9SRVNVTFRfTUVTU0FHRV9DT1VOVF9BVFRSSUJVVEU7XG5leHBvcnRzLk1DUF9QUk9NUFRfUkVTVUxUX1BSRUZJWCA9IE1DUF9QUk9NUFRfUkVTVUxUX1BSRUZJWDtcbmV4cG9ydHMuTUNQX1BST1RPQ09MX1ZFUlNJT05fQVRUUklCVVRFID0gTUNQX1BST1RPQ09MX1ZFUlNJT05fQVRUUklCVVRFO1xuZXhwb3J0cy5NQ1BfUkVRVUVTVF9BUkdVTUVOVCA9IE1DUF9SRVFVRVNUX0FSR1VNRU5UO1xuZXhwb3J0cy5NQ1BfUkVRVUVTVF9JRF9BVFRSSUJVVEUgPSBNQ1BfUkVRVUVTVF9JRF9BVFRSSUJVVEU7XG5leHBvcnRzLk1DUF9SRVNPVVJDRV9VUklfQVRUUklCVVRFID0gTUNQX1JFU09VUkNFX1VSSV9BVFRSSUJVVEU7XG5leHBvcnRzLk1DUF9ST1VURV9TT1VSQ0VfVkFMVUUgPSBNQ1BfUk9VVEVfU09VUkNFX1ZBTFVFO1xuZXhwb3J0cy5NQ1BfU0VSVkVSX05BTUVfQVRUUklCVVRFID0gTUNQX1NFUlZFUl9OQU1FX0FUVFJJQlVURTtcbmV4cG9ydHMuTUNQX1NFUlZFUl9PUF9WQUxVRSA9IE1DUF9TRVJWRVJfT1BfVkFMVUU7XG5leHBvcnRzLk1DUF9TRVJWRVJfVElUTEVfQVRUUklCVVRFID0gTUNQX1NFUlZFUl9USVRMRV9BVFRSSUJVVEU7XG5leHBvcnRzLk1DUF9TRVJWRVJfVkVSU0lPTl9BVFRSSUJVVEUgPSBNQ1BfU0VSVkVSX1ZFUlNJT05fQVRUUklCVVRFO1xuZXhwb3J0cy5NQ1BfU0VTU0lPTl9JRF9BVFRSSUJVVEUgPSBNQ1BfU0VTU0lPTl9JRF9BVFRSSUJVVEU7XG5leHBvcnRzLk1DUF9UT09MX05BTUVfQVRUUklCVVRFID0gTUNQX1RPT0xfTkFNRV9BVFRSSUJVVEU7XG5leHBvcnRzLk1DUF9UT09MX1JFU1VMVF9DT05URU5UX0FUVFJJQlVURSA9IE1DUF9UT09MX1JFU1VMVF9DT05URU5UX0FUVFJJQlVURTtcbmV4cG9ydHMuTUNQX1RPT0xfUkVTVUxUX0NPTlRFTlRfQ09VTlRfQVRUUklCVVRFID0gTUNQX1RPT0xfUkVTVUxUX0NPTlRFTlRfQ09VTlRfQVRUUklCVVRFO1xuZXhwb3J0cy5NQ1BfVE9PTF9SRVNVTFRfSVNfRVJST1JfQVRUUklCVVRFID0gTUNQX1RPT0xfUkVTVUxUX0lTX0VSUk9SX0FUVFJJQlVURTtcbmV4cG9ydHMuTUNQX1RPT0xfUkVTVUxUX1BSRUZJWCA9IE1DUF9UT09MX1JFU1VMVF9QUkVGSVg7XG5leHBvcnRzLk1DUF9UUkFOU1BPUlRfQVRUUklCVVRFID0gTUNQX1RSQU5TUE9SVF9BVFRSSUJVVEU7XG5leHBvcnRzLk5FVFdPUktfUFJPVE9DT0xfVkVSU0lPTl9BVFRSSUJVVEUgPSBORVRXT1JLX1BST1RPQ09MX1ZFUlNJT05fQVRUUklCVVRFO1xuZXhwb3J0cy5ORVRXT1JLX1RSQU5TUE9SVF9BVFRSSUJVVEUgPSBORVRXT1JLX1RSQU5TUE9SVF9BVFRSSUJVVEU7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1hdHRyaWJ1dGVzLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/attributes.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/correlation.js":
/*!***************************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/correlation.js ***!
  \***************************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst currentScopes = __webpack_require__(/*! ../../currentScopes.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst spanstatus = __webpack_require__(/*! ../../tracing/spanstatus.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/spanstatus.js\");\nconst piiFiltering = __webpack_require__(/*! ./piiFiltering.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/piiFiltering.js\");\nconst resultExtraction = __webpack_require__(/*! ./resultExtraction.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/resultExtraction.js\");\n\n/**\n * Request-span correlation system for MCP server instrumentation\n *\n * Handles mapping requestId to span data for correlation with handler execution.\n * Uses WeakMap to scope correlation maps per transport instance, preventing\n * request ID collisions between different MCP sessions.\n */\n\n\n/**\n * Transport-scoped correlation system that prevents collisions between different MCP sessions\n * @internal Each transport instance gets its own correlation map, eliminating request ID conflicts\n */\nconst transportToSpanMap = new WeakMap();\n\n/**\n * Gets or creates the span map for a specific transport instance\n * @internal\n * @param transport - MCP transport instance\n * @returns Span map for the transport\n */\nfunction getOrCreateSpanMap(transport) {\n  let spanMap = transportToSpanMap.get(transport);\n  if (!spanMap) {\n    spanMap = new Map();\n    transportToSpanMap.set(transport, spanMap);\n  }\n  return spanMap;\n}\n\n/**\n * Stores span context for later correlation with handler execution\n * @param transport - MCP transport instance\n * @param requestId - Request identifier\n * @param span - Active span to correlate\n * @param method - MCP method name\n */\nfunction storeSpanForRequest(transport, requestId, span, method) {\n  const spanMap = getOrCreateSpanMap(transport);\n  spanMap.set(requestId, {\n    span,\n    method,\n    startTime: Date.now(),\n  });\n}\n\n/**\n * Completes span with tool results and cleans up correlation\n * @param transport - MCP transport instance\n * @param requestId - Request identifier\n * @param result - Tool execution result for attribute extraction\n */\nfunction completeSpanWithResults(transport, requestId, result) {\n  const spanMap = getOrCreateSpanMap(transport);\n  const spanData = spanMap.get(requestId);\n  if (spanData) {\n    const { span, method } = spanData;\n\n    if (method === 'tools/call') {\n      const rawToolAttributes = resultExtraction.extractToolResultAttributes(result);\n      const client = currentScopes.getClient();\n      const sendDefaultPii = Boolean(client?.getOptions().sendDefaultPii);\n      const toolAttributes = piiFiltering.filterMcpPiiFromSpanData(rawToolAttributes, sendDefaultPii);\n\n      span.setAttributes(toolAttributes);\n    } else if (method === 'prompts/get') {\n      const rawPromptAttributes = resultExtraction.extractPromptResultAttributes(result);\n      const client = currentScopes.getClient();\n      const sendDefaultPii = Boolean(client?.getOptions().sendDefaultPii);\n      const promptAttributes = piiFiltering.filterMcpPiiFromSpanData(rawPromptAttributes, sendDefaultPii);\n\n      span.setAttributes(promptAttributes);\n    }\n\n    span.end();\n    spanMap.delete(requestId);\n  }\n}\n\n/**\n * Cleans up pending spans for a specific transport (when that transport closes)\n * @param transport - MCP transport instance\n * @returns Number of pending spans that were cleaned up\n */\nfunction cleanupPendingSpansForTransport(transport) {\n  const spanMap = transportToSpanMap.get(transport);\n  if (!spanMap) {\n    return 0;\n  }\n\n  const pendingCount = spanMap.size;\n\n  for (const [, spanData] of spanMap) {\n    spanData.span.setStatus({\n      code: spanstatus.SPAN_STATUS_ERROR,\n      message: 'cancelled',\n    });\n    spanData.span.end();\n  }\n\n  spanMap.clear();\n  return pendingCount;\n}\n\nexports.cleanupPendingSpansForTransport = cleanupPendingSpansForTransport;\nexports.completeSpanWithResults = completeSpanWithResults;\nexports.storeSpanForRequest = storeSpanForRequest;\n//# sourceMappingURL=correlation.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvbWNwLXNlcnZlci9jb3JyZWxhdGlvbi5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxzQkFBc0IsbUJBQU8sQ0FBQyxtSUFBd0I7QUFDdEQsbUJBQW1CLG1CQUFPLENBQUMsNklBQTZCO0FBQ3hELHFCQUFxQixtQkFBTyxDQUFDLHFKQUFtQjtBQUNoRCx5QkFBeUIsbUJBQU8sQ0FBQyw2SkFBdUI7O0FBRXhEO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOzs7QUFHQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxHQUFHO0FBQ0g7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxZQUFZLGVBQWU7O0FBRTNCO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQSxNQUFNO0FBQ047QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEtBQUs7QUFDTDtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQSx1Q0FBdUM7QUFDdkMsK0JBQStCO0FBQy9CLDJCQUEyQjtBQUMzQiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL2ludGVncmF0aW9ucy9tY3Atc2VydmVyL2NvcnJlbGF0aW9uLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBjdXJyZW50U2NvcGVzID0gcmVxdWlyZSgnLi4vLi4vY3VycmVudFNjb3Blcy5qcycpO1xuY29uc3Qgc3BhbnN0YXR1cyA9IHJlcXVpcmUoJy4uLy4uL3RyYWNpbmcvc3BhbnN0YXR1cy5qcycpO1xuY29uc3QgcGlpRmlsdGVyaW5nID0gcmVxdWlyZSgnLi9waWlGaWx0ZXJpbmcuanMnKTtcbmNvbnN0IHJlc3VsdEV4dHJhY3Rpb24gPSByZXF1aXJlKCcuL3Jlc3VsdEV4dHJhY3Rpb24uanMnKTtcblxuLyoqXG4gKiBSZXF1ZXN0LXNwYW4gY29ycmVsYXRpb24gc3lzdGVtIGZvciBNQ1Agc2VydmVyIGluc3RydW1lbnRhdGlvblxuICpcbiAqIEhhbmRsZXMgbWFwcGluZyByZXF1ZXN0SWQgdG8gc3BhbiBkYXRhIGZvciBjb3JyZWxhdGlvbiB3aXRoIGhhbmRsZXIgZXhlY3V0aW9uLlxuICogVXNlcyBXZWFrTWFwIHRvIHNjb3BlIGNvcnJlbGF0aW9uIG1hcHMgcGVyIHRyYW5zcG9ydCBpbnN0YW5jZSwgcHJldmVudGluZ1xuICogcmVxdWVzdCBJRCBjb2xsaXNpb25zIGJldHdlZW4gZGlmZmVyZW50IE1DUCBzZXNzaW9ucy5cbiAqL1xuXG5cbi8qKlxuICogVHJhbnNwb3J0LXNjb3BlZCBjb3JyZWxhdGlvbiBzeXN0ZW0gdGhhdCBwcmV2ZW50cyBjb2xsaXNpb25zIGJldHdlZW4gZGlmZmVyZW50IE1DUCBzZXNzaW9uc1xuICogQGludGVybmFsIEVhY2ggdHJhbnNwb3J0IGluc3RhbmNlIGdldHMgaXRzIG93biBjb3JyZWxhdGlvbiBtYXAsIGVsaW1pbmF0aW5nIHJlcXVlc3QgSUQgY29uZmxpY3RzXG4gKi9cbmNvbnN0IHRyYW5zcG9ydFRvU3Bhbk1hcCA9IG5ldyBXZWFrTWFwKCk7XG5cbi8qKlxuICogR2V0cyBvciBjcmVhdGVzIHRoZSBzcGFuIG1hcCBmb3IgYSBzcGVjaWZpYyB0cmFuc3BvcnQgaW5zdGFuY2VcbiAqIEBpbnRlcm5hbFxuICogQHBhcmFtIHRyYW5zcG9ydCAtIE1DUCB0cmFuc3BvcnQgaW5zdGFuY2VcbiAqIEByZXR1cm5zIFNwYW4gbWFwIGZvciB0aGUgdHJhbnNwb3J0XG4gKi9cbmZ1bmN0aW9uIGdldE9yQ3JlYXRlU3Bhbk1hcCh0cmFuc3BvcnQpIHtcbiAgbGV0IHNwYW5NYXAgPSB0cmFuc3BvcnRUb1NwYW5NYXAuZ2V0KHRyYW5zcG9ydCk7XG4gIGlmICghc3Bhbk1hcCkge1xuICAgIHNwYW5NYXAgPSBuZXcgTWFwKCk7XG4gICAgdHJhbnNwb3J0VG9TcGFuTWFwLnNldCh0cmFuc3BvcnQsIHNwYW5NYXApO1xuICB9XG4gIHJldHVybiBzcGFuTWFwO1xufVxuXG4vKipcbiAqIFN0b3JlcyBzcGFuIGNvbnRleHQgZm9yIGxhdGVyIGNvcnJlbGF0aW9uIHdpdGggaGFuZGxlciBleGVjdXRpb25cbiAqIEBwYXJhbSB0cmFuc3BvcnQgLSBNQ1AgdHJhbnNwb3J0IGluc3RhbmNlXG4gKiBAcGFyYW0gcmVxdWVzdElkIC0gUmVxdWVzdCBpZGVudGlmaWVyXG4gKiBAcGFyYW0gc3BhbiAtIEFjdGl2ZSBzcGFuIHRvIGNvcnJlbGF0ZVxuICogQHBhcmFtIG1ldGhvZCAtIE1DUCBtZXRob2QgbmFtZVxuICovXG5mdW5jdGlvbiBzdG9yZVNwYW5Gb3JSZXF1ZXN0KHRyYW5zcG9ydCwgcmVxdWVzdElkLCBzcGFuLCBtZXRob2QpIHtcbiAgY29uc3Qgc3Bhbk1hcCA9IGdldE9yQ3JlYXRlU3Bhbk1hcCh0cmFuc3BvcnQpO1xuICBzcGFuTWFwLnNldChyZXF1ZXN0SWQsIHtcbiAgICBzcGFuLFxuICAgIG1ldGhvZCxcbiAgICBzdGFydFRpbWU6IERhdGUubm93KCksXG4gIH0pO1xufVxuXG4vKipcbiAqIENvbXBsZXRlcyBzcGFuIHdpdGggdG9vbCByZXN1bHRzIGFuZCBjbGVhbnMgdXAgY29ycmVsYXRpb25cbiAqIEBwYXJhbSB0cmFuc3BvcnQgLSBNQ1AgdHJhbnNwb3J0IGluc3RhbmNlXG4gKiBAcGFyYW0gcmVxdWVzdElkIC0gUmVxdWVzdCBpZGVudGlmaWVyXG4gKiBAcGFyYW0gcmVzdWx0IC0gVG9vbCBleGVjdXRpb24gcmVzdWx0IGZvciBhdHRyaWJ1dGUgZXh0cmFjdGlvblxuICovXG5mdW5jdGlvbiBjb21wbGV0ZVNwYW5XaXRoUmVzdWx0cyh0cmFuc3BvcnQsIHJlcXVlc3RJZCwgcmVzdWx0KSB7XG4gIGNvbnN0IHNwYW5NYXAgPSBnZXRPckNyZWF0ZVNwYW5NYXAodHJhbnNwb3J0KTtcbiAgY29uc3Qgc3BhbkRhdGEgPSBzcGFuTWFwLmdldChyZXF1ZXN0SWQpO1xuICBpZiAoc3BhbkRhdGEpIHtcbiAgICBjb25zdCB7IHNwYW4sIG1ldGhvZCB9ID0gc3BhbkRhdGE7XG5cbiAgICBpZiAobWV0aG9kID09PSAndG9vbHMvY2FsbCcpIHtcbiAgICAgIGNvbnN0IHJhd1Rvb2xBdHRyaWJ1dGVzID0gcmVzdWx0RXh0cmFjdGlvbi5leHRyYWN0VG9vbFJlc3VsdEF0dHJpYnV0ZXMocmVzdWx0KTtcbiAgICAgIGNvbnN0IGNsaWVudCA9IGN1cnJlbnRTY29wZXMuZ2V0Q2xpZW50KCk7XG4gICAgICBjb25zdCBzZW5kRGVmYXVsdFBpaSA9IEJvb2xlYW4oY2xpZW50Py5nZXRPcHRpb25zKCkuc2VuZERlZmF1bHRQaWkpO1xuICAgICAgY29uc3QgdG9vbEF0dHJpYnV0ZXMgPSBwaWlGaWx0ZXJpbmcuZmlsdGVyTWNwUGlpRnJvbVNwYW5EYXRhKHJhd1Rvb2xBdHRyaWJ1dGVzLCBzZW5kRGVmYXVsdFBpaSk7XG5cbiAgICAgIHNwYW4uc2V0QXR0cmlidXRlcyh0b29sQXR0cmlidXRlcyk7XG4gICAgfSBlbHNlIGlmIChtZXRob2QgPT09ICdwcm9tcHRzL2dldCcpIHtcbiAgICAgIGNvbnN0IHJhd1Byb21wdEF0dHJpYnV0ZXMgPSByZXN1bHRFeHRyYWN0aW9uLmV4dHJhY3RQcm9tcHRSZXN1bHRBdHRyaWJ1dGVzKHJlc3VsdCk7XG4gICAgICBjb25zdCBjbGllbnQgPSBjdXJyZW50U2NvcGVzLmdldENsaWVudCgpO1xuICAgICAgY29uc3Qgc2VuZERlZmF1bHRQaWkgPSBCb29sZWFuKGNsaWVudD8uZ2V0T3B0aW9ucygpLnNlbmREZWZhdWx0UGlpKTtcbiAgICAgIGNvbnN0IHByb21wdEF0dHJpYnV0ZXMgPSBwaWlGaWx0ZXJpbmcuZmlsdGVyTWNwUGlpRnJvbVNwYW5EYXRhKHJhd1Byb21wdEF0dHJpYnV0ZXMsIHNlbmREZWZhdWx0UGlpKTtcblxuICAgICAgc3Bhbi5zZXRBdHRyaWJ1dGVzKHByb21wdEF0dHJpYnV0ZXMpO1xuICAgIH1cblxuICAgIHNwYW4uZW5kKCk7XG4gICAgc3Bhbk1hcC5kZWxldGUocmVxdWVzdElkKTtcbiAgfVxufVxuXG4vKipcbiAqIENsZWFucyB1cCBwZW5kaW5nIHNwYW5zIGZvciBhIHNwZWNpZmljIHRyYW5zcG9ydCAod2hlbiB0aGF0IHRyYW5zcG9ydCBjbG9zZXMpXG4gKiBAcGFyYW0gdHJhbnNwb3J0IC0gTUNQIHRyYW5zcG9ydCBpbnN0YW5jZVxuICogQHJldHVybnMgTnVtYmVyIG9mIHBlbmRpbmcgc3BhbnMgdGhhdCB3ZXJlIGNsZWFuZWQgdXBcbiAqL1xuZnVuY3Rpb24gY2xlYW51cFBlbmRpbmdTcGFuc0ZvclRyYW5zcG9ydCh0cmFuc3BvcnQpIHtcbiAgY29uc3Qgc3Bhbk1hcCA9IHRyYW5zcG9ydFRvU3Bhbk1hcC5nZXQodHJhbnNwb3J0KTtcbiAgaWYgKCFzcGFuTWFwKSB7XG4gICAgcmV0dXJuIDA7XG4gIH1cblxuICBjb25zdCBwZW5kaW5nQ291bnQgPSBzcGFuTWFwLnNpemU7XG5cbiAgZm9yIChjb25zdCBbLCBzcGFuRGF0YV0gb2Ygc3Bhbk1hcCkge1xuICAgIHNwYW5EYXRhLnNwYW4uc2V0U3RhdHVzKHtcbiAgICAgIGNvZGU6IHNwYW5zdGF0dXMuU1BBTl9TVEFUVVNfRVJST1IsXG4gICAgICBtZXNzYWdlOiAnY2FuY2VsbGVkJyxcbiAgICB9KTtcbiAgICBzcGFuRGF0YS5zcGFuLmVuZCgpO1xuICB9XG5cbiAgc3Bhbk1hcC5jbGVhcigpO1xuICByZXR1cm4gcGVuZGluZ0NvdW50O1xufVxuXG5leHBvcnRzLmNsZWFudXBQZW5kaW5nU3BhbnNGb3JUcmFuc3BvcnQgPSBjbGVhbnVwUGVuZGluZ1NwYW5zRm9yVHJhbnNwb3J0O1xuZXhwb3J0cy5jb21wbGV0ZVNwYW5XaXRoUmVzdWx0cyA9IGNvbXBsZXRlU3BhbldpdGhSZXN1bHRzO1xuZXhwb3J0cy5zdG9yZVNwYW5Gb3JSZXF1ZXN0ID0gc3RvcmVTcGFuRm9yUmVxdWVzdDtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWNvcnJlbGF0aW9uLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/correlation.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/errorCapture.js":
/*!****************************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/errorCapture.js ***!
  \****************************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst currentScopes = __webpack_require__(/*! ../../currentScopes.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst exports$1 = __webpack_require__(/*! ../../exports.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/exports.js\");\nconst spanUtils = __webpack_require__(/*! ../../utils/spanUtils.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanUtils.js\");\nconst spanstatus = __webpack_require__(/*! ../../tracing/spanstatus.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/spanstatus.js\");\n\n/**\n * Safe error capture utilities for MCP server instrumentation\n *\n * Ensures error reporting never interferes with MCP server operation.\n * All capture operations are wrapped in try-catch to prevent side effects.\n */\n\n\n/**\n * Captures an error without affecting MCP server operation.\n *\n * The active span already contains all MCP context (method, tool, arguments, etc.)\n * @param error - Error to capture\n * @param errorType - Classification of error type for filtering\n * @param extraData - Additional context data to include\n */\nfunction captureError(error, errorType, extraData) {\n  try {\n    const client = currentScopes.getClient();\n    if (!client) {\n      return;\n    }\n\n    const activeSpan = spanUtils.getActiveSpan();\n    if (activeSpan?.isRecording()) {\n      activeSpan.setStatus({\n        code: spanstatus.SPAN_STATUS_ERROR,\n        message: 'internal_error',\n      });\n    }\n\n    exports$1.captureException(error, {\n      mechanism: {\n        type: 'mcp_server',\n        handled: false,\n        data: {\n          error_type: errorType || 'handler_execution',\n          ...extraData,\n        },\n      },\n    });\n  } catch {\n    // noop\n  }\n}\n\nexports.captureError = captureError;\n//# sourceMappingURL=errorCapture.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvbWNwLXNlcnZlci9lcnJvckNhcHR1cmUuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsc0JBQXNCLG1CQUFPLENBQUMsbUlBQXdCO0FBQ3RELGtCQUFrQixtQkFBTyxDQUFDLHVIQUFrQjtBQUM1QyxrQkFBa0IsbUJBQU8sQ0FBQyx1SUFBMEI7QUFDcEQsbUJBQW1CLG1CQUFPLENBQUMsNklBQTZCOztBQUV4RDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7OztBQUdBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLE9BQU87QUFDUDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFNBQVM7QUFDVCxPQUFPO0FBQ1AsS0FBSztBQUNMLElBQUk7QUFDSjtBQUNBO0FBQ0E7O0FBRUEsb0JBQW9CO0FBQ3BCIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvaW50ZWdyYXRpb25zL21jcC1zZXJ2ZXIvZXJyb3JDYXB0dXJlLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBjdXJyZW50U2NvcGVzID0gcmVxdWlyZSgnLi4vLi4vY3VycmVudFNjb3Blcy5qcycpO1xuY29uc3QgZXhwb3J0cyQxID0gcmVxdWlyZSgnLi4vLi4vZXhwb3J0cy5qcycpO1xuY29uc3Qgc3BhblV0aWxzID0gcmVxdWlyZSgnLi4vLi4vdXRpbHMvc3BhblV0aWxzLmpzJyk7XG5jb25zdCBzcGFuc3RhdHVzID0gcmVxdWlyZSgnLi4vLi4vdHJhY2luZy9zcGFuc3RhdHVzLmpzJyk7XG5cbi8qKlxuICogU2FmZSBlcnJvciBjYXB0dXJlIHV0aWxpdGllcyBmb3IgTUNQIHNlcnZlciBpbnN0cnVtZW50YXRpb25cbiAqXG4gKiBFbnN1cmVzIGVycm9yIHJlcG9ydGluZyBuZXZlciBpbnRlcmZlcmVzIHdpdGggTUNQIHNlcnZlciBvcGVyYXRpb24uXG4gKiBBbGwgY2FwdHVyZSBvcGVyYXRpb25zIGFyZSB3cmFwcGVkIGluIHRyeS1jYXRjaCB0byBwcmV2ZW50IHNpZGUgZWZmZWN0cy5cbiAqL1xuXG5cbi8qKlxuICogQ2FwdHVyZXMgYW4gZXJyb3Igd2l0aG91dCBhZmZlY3RpbmcgTUNQIHNlcnZlciBvcGVyYXRpb24uXG4gKlxuICogVGhlIGFjdGl2ZSBzcGFuIGFscmVhZHkgY29udGFpbnMgYWxsIE1DUCBjb250ZXh0IChtZXRob2QsIHRvb2wsIGFyZ3VtZW50cywgZXRjLilcbiAqIEBwYXJhbSBlcnJvciAtIEVycm9yIHRvIGNhcHR1cmVcbiAqIEBwYXJhbSBlcnJvclR5cGUgLSBDbGFzc2lmaWNhdGlvbiBvZiBlcnJvciB0eXBlIGZvciBmaWx0ZXJpbmdcbiAqIEBwYXJhbSBleHRyYURhdGEgLSBBZGRpdGlvbmFsIGNvbnRleHQgZGF0YSB0byBpbmNsdWRlXG4gKi9cbmZ1bmN0aW9uIGNhcHR1cmVFcnJvcihlcnJvciwgZXJyb3JUeXBlLCBleHRyYURhdGEpIHtcbiAgdHJ5IHtcbiAgICBjb25zdCBjbGllbnQgPSBjdXJyZW50U2NvcGVzLmdldENsaWVudCgpO1xuICAgIGlmICghY2xpZW50KSB7XG4gICAgICByZXR1cm47XG4gICAgfVxuXG4gICAgY29uc3QgYWN0aXZlU3BhbiA9IHNwYW5VdGlscy5nZXRBY3RpdmVTcGFuKCk7XG4gICAgaWYgKGFjdGl2ZVNwYW4/LmlzUmVjb3JkaW5nKCkpIHtcbiAgICAgIGFjdGl2ZVNwYW4uc2V0U3RhdHVzKHtcbiAgICAgICAgY29kZTogc3BhbnN0YXR1cy5TUEFOX1NUQVRVU19FUlJPUixcbiAgICAgICAgbWVzc2FnZTogJ2ludGVybmFsX2Vycm9yJyxcbiAgICAgIH0pO1xuICAgIH1cblxuICAgIGV4cG9ydHMkMS5jYXB0dXJlRXhjZXB0aW9uKGVycm9yLCB7XG4gICAgICBtZWNoYW5pc206IHtcbiAgICAgICAgdHlwZTogJ21jcF9zZXJ2ZXInLFxuICAgICAgICBoYW5kbGVkOiBmYWxzZSxcbiAgICAgICAgZGF0YToge1xuICAgICAgICAgIGVycm9yX3R5cGU6IGVycm9yVHlwZSB8fCAnaGFuZGxlcl9leGVjdXRpb24nLFxuICAgICAgICAgIC4uLmV4dHJhRGF0YSxcbiAgICAgICAgfSxcbiAgICAgIH0sXG4gICAgfSk7XG4gIH0gY2F0Y2gge1xuICAgIC8vIG5vb3BcbiAgfVxufVxuXG5leHBvcnRzLmNhcHR1cmVFcnJvciA9IGNhcHR1cmVFcnJvcjtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWVycm9yQ2FwdHVyZS5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/errorCapture.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/handlers.js":
/*!************************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/handlers.js ***!
  \************************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst debugBuild = __webpack_require__(/*! ../../debug-build.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst debugLogger = __webpack_require__(/*! ../../utils/debug-logger.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst object = __webpack_require__(/*! ../../utils/object.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/object.js\");\nconst errorCapture = __webpack_require__(/*! ./errorCapture.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/errorCapture.js\");\n\n/**\n * Handler method wrapping for MCP server instrumentation\n *\n * Provides automatic error capture and span correlation for tool, resource,\n * and prompt handlers.\n */\n\n\n/**\n * Generic function to wrap MCP server method handlers\n * @internal\n * @param serverInstance - MCP server instance\n * @param methodName - Method name to wrap (tool, resource, prompt)\n */\nfunction wrapMethodHandler(serverInstance, methodName) {\n  object.fill(serverInstance, methodName, originalMethod => {\n    return function ( name, ...args) {\n      const handler = args[args.length - 1];\n\n      if (typeof handler !== 'function') {\n        return (originalMethod ).call(this, name, ...args);\n      }\n\n      const wrappedHandler = createWrappedHandler(handler , methodName, name);\n      return (originalMethod ).call(this, name, ...args.slice(0, -1), wrappedHandler);\n    };\n  });\n}\n\n/**\n * Creates a wrapped handler with span correlation and error capture\n * @internal\n * @param originalHandler - Original handler function\n * @param methodName - MCP method name\n * @param handlerName - Handler identifier\n * @returns Wrapped handler function\n */\nfunction createWrappedHandler(originalHandler, methodName, handlerName) {\n  return function ( ...handlerArgs) {\n    try {\n      return createErrorCapturingHandler.call(this, originalHandler, methodName, handlerName, handlerArgs);\n    } catch (error) {\n      debugBuild.DEBUG_BUILD && debugLogger.debug.warn('MCP handler wrapping failed:', error);\n      return originalHandler.apply(this, handlerArgs);\n    }\n  };\n}\n\n/**\n * Creates an error-capturing wrapper for handler execution\n * @internal\n * @param originalHandler - Original handler function\n * @param methodName - MCP method name\n * @param handlerName - Handler identifier\n * @param handlerArgs - Handler arguments\n * @param extraHandlerData - Additional handler context\n * @returns Handler execution result\n */\nfunction createErrorCapturingHandler(\n\n  originalHandler,\n  methodName,\n  handlerName,\n  handlerArgs,\n) {\n  try {\n    const result = originalHandler.apply(this, handlerArgs);\n\n    if (result && typeof result === 'object' && typeof (result ).then === 'function') {\n      return Promise.resolve(result).catch(error => {\n        captureHandlerError(error, methodName, handlerName);\n        throw error;\n      });\n    }\n\n    return result;\n  } catch (error) {\n    captureHandlerError(error , methodName, handlerName);\n    throw error;\n  }\n}\n\n/**\n * Captures handler execution errors based on handler type\n * @internal\n * @param error - Error to capture\n * @param methodName - MCP method name\n * @param handlerName - Handler identifier\n */\nfunction captureHandlerError(error, methodName, handlerName) {\n  try {\n    const extraData = {};\n\n    if (methodName === 'tool') {\n      extraData.tool_name = handlerName;\n\n      if (\n        error.name === 'ProtocolValidationError' ||\n        error.message.includes('validation') ||\n        error.message.includes('protocol')\n      ) {\n        errorCapture.captureError(error, 'validation', extraData);\n      } else if (\n        error.name === 'ServerTimeoutError' ||\n        error.message.includes('timed out') ||\n        error.message.includes('timeout')\n      ) {\n        errorCapture.captureError(error, 'timeout', extraData);\n      } else {\n        errorCapture.captureError(error, 'tool_execution', extraData);\n      }\n    } else if (methodName === 'resource') {\n      extraData.resource_uri = handlerName;\n      errorCapture.captureError(error, 'resource_execution', extraData);\n    } else if (methodName === 'prompt') {\n      extraData.prompt_name = handlerName;\n      errorCapture.captureError(error, 'prompt_execution', extraData);\n    }\n  } catch (captureErr) {\n    // noop\n  }\n}\n\n/**\n * Wraps tool handlers to associate them with request spans\n * @param serverInstance - MCP server instance\n */\nfunction wrapToolHandlers(serverInstance) {\n  wrapMethodHandler(serverInstance, 'tool');\n}\n\n/**\n * Wraps resource handlers to associate them with request spans\n * @param serverInstance - MCP server instance\n */\nfunction wrapResourceHandlers(serverInstance) {\n  wrapMethodHandler(serverInstance, 'resource');\n}\n\n/**\n * Wraps prompt handlers to associate them with request spans\n * @param serverInstance - MCP server instance\n */\nfunction wrapPromptHandlers(serverInstance) {\n  wrapMethodHandler(serverInstance, 'prompt');\n}\n\n/**\n * Wraps all MCP handler types (tool, resource, prompt) for span correlation\n * @param serverInstance - MCP server instance\n */\nfunction wrapAllMCPHandlers(serverInstance) {\n  wrapToolHandlers(serverInstance);\n  wrapResourceHandlers(serverInstance);\n  wrapPromptHandlers(serverInstance);\n}\n\nexports.wrapAllMCPHandlers = wrapAllMCPHandlers;\nexports.wrapPromptHandlers = wrapPromptHandlers;\nexports.wrapResourceHandlers = wrapResourceHandlers;\nexports.wrapToolHandlers = wrapToolHandlers;\n//# sourceMappingURL=handlers.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvbWNwLXNlcnZlci9oYW5kbGVycy5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxtQkFBbUIsbUJBQU8sQ0FBQywrSEFBc0I7QUFDakQsb0JBQW9CLG1CQUFPLENBQUMsNklBQTZCO0FBQ3pELGVBQWUsbUJBQU8sQ0FBQyxpSUFBdUI7QUFDOUMscUJBQXFCLG1CQUFPLENBQUMscUpBQW1COztBQUVoRDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7OztBQUdBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQSxHQUFHO0FBQ0g7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsTUFBTTtBQUNOO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLE9BQU87QUFDUDs7QUFFQTtBQUNBLElBQUk7QUFDSjtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFFBQVE7QUFDUjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsUUFBUTtBQUNSO0FBQ0E7QUFDQSxNQUFNO0FBQ047QUFDQTtBQUNBLE1BQU07QUFDTjtBQUNBO0FBQ0E7QUFDQSxJQUFJO0FBQ0o7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSwwQkFBMEI7QUFDMUIsMEJBQTBCO0FBQzFCLDRCQUE0QjtBQUM1Qix3QkFBd0I7QUFDeEIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvbWNwLXNlcnZlci9oYW5kbGVycy5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgZGVidWdCdWlsZCA9IHJlcXVpcmUoJy4uLy4uL2RlYnVnLWJ1aWxkLmpzJyk7XG5jb25zdCBkZWJ1Z0xvZ2dlciA9IHJlcXVpcmUoJy4uLy4uL3V0aWxzL2RlYnVnLWxvZ2dlci5qcycpO1xuY29uc3Qgb2JqZWN0ID0gcmVxdWlyZSgnLi4vLi4vdXRpbHMvb2JqZWN0LmpzJyk7XG5jb25zdCBlcnJvckNhcHR1cmUgPSByZXF1aXJlKCcuL2Vycm9yQ2FwdHVyZS5qcycpO1xuXG4vKipcbiAqIEhhbmRsZXIgbWV0aG9kIHdyYXBwaW5nIGZvciBNQ1Agc2VydmVyIGluc3RydW1lbnRhdGlvblxuICpcbiAqIFByb3ZpZGVzIGF1dG9tYXRpYyBlcnJvciBjYXB0dXJlIGFuZCBzcGFuIGNvcnJlbGF0aW9uIGZvciB0b29sLCByZXNvdXJjZSxcbiAqIGFuZCBwcm9tcHQgaGFuZGxlcnMuXG4gKi9cblxuXG4vKipcbiAqIEdlbmVyaWMgZnVuY3Rpb24gdG8gd3JhcCBNQ1Agc2VydmVyIG1ldGhvZCBoYW5kbGVyc1xuICogQGludGVybmFsXG4gKiBAcGFyYW0gc2VydmVySW5zdGFuY2UgLSBNQ1Agc2VydmVyIGluc3RhbmNlXG4gKiBAcGFyYW0gbWV0aG9kTmFtZSAtIE1ldGhvZCBuYW1lIHRvIHdyYXAgKHRvb2wsIHJlc291cmNlLCBwcm9tcHQpXG4gKi9cbmZ1bmN0aW9uIHdyYXBNZXRob2RIYW5kbGVyKHNlcnZlckluc3RhbmNlLCBtZXRob2ROYW1lKSB7XG4gIG9iamVjdC5maWxsKHNlcnZlckluc3RhbmNlLCBtZXRob2ROYW1lLCBvcmlnaW5hbE1ldGhvZCA9PiB7XG4gICAgcmV0dXJuIGZ1bmN0aW9uICggbmFtZSwgLi4uYXJncykge1xuICAgICAgY29uc3QgaGFuZGxlciA9IGFyZ3NbYXJncy5sZW5ndGggLSAxXTtcblxuICAgICAgaWYgKHR5cGVvZiBoYW5kbGVyICE9PSAnZnVuY3Rpb24nKSB7XG4gICAgICAgIHJldHVybiAob3JpZ2luYWxNZXRob2QgKS5jYWxsKHRoaXMsIG5hbWUsIC4uLmFyZ3MpO1xuICAgICAgfVxuXG4gICAgICBjb25zdCB3cmFwcGVkSGFuZGxlciA9IGNyZWF0ZVdyYXBwZWRIYW5kbGVyKGhhbmRsZXIgLCBtZXRob2ROYW1lLCBuYW1lKTtcbiAgICAgIHJldHVybiAob3JpZ2luYWxNZXRob2QgKS5jYWxsKHRoaXMsIG5hbWUsIC4uLmFyZ3Muc2xpY2UoMCwgLTEpLCB3cmFwcGVkSGFuZGxlcik7XG4gICAgfTtcbiAgfSk7XG59XG5cbi8qKlxuICogQ3JlYXRlcyBhIHdyYXBwZWQgaGFuZGxlciB3aXRoIHNwYW4gY29ycmVsYXRpb24gYW5kIGVycm9yIGNhcHR1cmVcbiAqIEBpbnRlcm5hbFxuICogQHBhcmFtIG9yaWdpbmFsSGFuZGxlciAtIE9yaWdpbmFsIGhhbmRsZXIgZnVuY3Rpb25cbiAqIEBwYXJhbSBtZXRob2ROYW1lIC0gTUNQIG1ldGhvZCBuYW1lXG4gKiBAcGFyYW0gaGFuZGxlck5hbWUgLSBIYW5kbGVyIGlkZW50aWZpZXJcbiAqIEByZXR1cm5zIFdyYXBwZWQgaGFuZGxlciBmdW5jdGlvblxuICovXG5mdW5jdGlvbiBjcmVhdGVXcmFwcGVkSGFuZGxlcihvcmlnaW5hbEhhbmRsZXIsIG1ldGhvZE5hbWUsIGhhbmRsZXJOYW1lKSB7XG4gIHJldHVybiBmdW5jdGlvbiAoIC4uLmhhbmRsZXJBcmdzKSB7XG4gICAgdHJ5IHtcbiAgICAgIHJldHVybiBjcmVhdGVFcnJvckNhcHR1cmluZ0hhbmRsZXIuY2FsbCh0aGlzLCBvcmlnaW5hbEhhbmRsZXIsIG1ldGhvZE5hbWUsIGhhbmRsZXJOYW1lLCBoYW5kbGVyQXJncyk7XG4gICAgfSBjYXRjaCAoZXJyb3IpIHtcbiAgICAgIGRlYnVnQnVpbGQuREVCVUdfQlVJTEQgJiYgZGVidWdMb2dnZXIuZGVidWcud2FybignTUNQIGhhbmRsZXIgd3JhcHBpbmcgZmFpbGVkOicsIGVycm9yKTtcbiAgICAgIHJldHVybiBvcmlnaW5hbEhhbmRsZXIuYXBwbHkodGhpcywgaGFuZGxlckFyZ3MpO1xuICAgIH1cbiAgfTtcbn1cblxuLyoqXG4gKiBDcmVhdGVzIGFuIGVycm9yLWNhcHR1cmluZyB3cmFwcGVyIGZvciBoYW5kbGVyIGV4ZWN1dGlvblxuICogQGludGVybmFsXG4gKiBAcGFyYW0gb3JpZ2luYWxIYW5kbGVyIC0gT3JpZ2luYWwgaGFuZGxlciBmdW5jdGlvblxuICogQHBhcmFtIG1ldGhvZE5hbWUgLSBNQ1AgbWV0aG9kIG5hbWVcbiAqIEBwYXJhbSBoYW5kbGVyTmFtZSAtIEhhbmRsZXIgaWRlbnRpZmllclxuICogQHBhcmFtIGhhbmRsZXJBcmdzIC0gSGFuZGxlciBhcmd1bWVudHNcbiAqIEBwYXJhbSBleHRyYUhhbmRsZXJEYXRhIC0gQWRkaXRpb25hbCBoYW5kbGVyIGNvbnRleHRcbiAqIEByZXR1cm5zIEhhbmRsZXIgZXhlY3V0aW9uIHJlc3VsdFxuICovXG5mdW5jdGlvbiBjcmVhdGVFcnJvckNhcHR1cmluZ0hhbmRsZXIoXG5cbiAgb3JpZ2luYWxIYW5kbGVyLFxuICBtZXRob2ROYW1lLFxuICBoYW5kbGVyTmFtZSxcbiAgaGFuZGxlckFyZ3MsXG4pIHtcbiAgdHJ5IHtcbiAgICBjb25zdCByZXN1bHQgPSBvcmlnaW5hbEhhbmRsZXIuYXBwbHkodGhpcywgaGFuZGxlckFyZ3MpO1xuXG4gICAgaWYgKHJlc3VsdCAmJiB0eXBlb2YgcmVzdWx0ID09PSAnb2JqZWN0JyAmJiB0eXBlb2YgKHJlc3VsdCApLnRoZW4gPT09ICdmdW5jdGlvbicpIHtcbiAgICAgIHJldHVybiBQcm9taXNlLnJlc29sdmUocmVzdWx0KS5jYXRjaChlcnJvciA9PiB7XG4gICAgICAgIGNhcHR1cmVIYW5kbGVyRXJyb3IoZXJyb3IsIG1ldGhvZE5hbWUsIGhhbmRsZXJOYW1lKTtcbiAgICAgICAgdGhyb3cgZXJyb3I7XG4gICAgICB9KTtcbiAgICB9XG5cbiAgICByZXR1cm4gcmVzdWx0O1xuICB9IGNhdGNoIChlcnJvcikge1xuICAgIGNhcHR1cmVIYW5kbGVyRXJyb3IoZXJyb3IgLCBtZXRob2ROYW1lLCBoYW5kbGVyTmFtZSk7XG4gICAgdGhyb3cgZXJyb3I7XG4gIH1cbn1cblxuLyoqXG4gKiBDYXB0dXJlcyBoYW5kbGVyIGV4ZWN1dGlvbiBlcnJvcnMgYmFzZWQgb24gaGFuZGxlciB0eXBlXG4gKiBAaW50ZXJuYWxcbiAqIEBwYXJhbSBlcnJvciAtIEVycm9yIHRvIGNhcHR1cmVcbiAqIEBwYXJhbSBtZXRob2ROYW1lIC0gTUNQIG1ldGhvZCBuYW1lXG4gKiBAcGFyYW0gaGFuZGxlck5hbWUgLSBIYW5kbGVyIGlkZW50aWZpZXJcbiAqL1xuZnVuY3Rpb24gY2FwdHVyZUhhbmRsZXJFcnJvcihlcnJvciwgbWV0aG9kTmFtZSwgaGFuZGxlck5hbWUpIHtcbiAgdHJ5IHtcbiAgICBjb25zdCBleHRyYURhdGEgPSB7fTtcblxuICAgIGlmIChtZXRob2ROYW1lID09PSAndG9vbCcpIHtcbiAgICAgIGV4dHJhRGF0YS50b29sX25hbWUgPSBoYW5kbGVyTmFtZTtcblxuICAgICAgaWYgKFxuICAgICAgICBlcnJvci5uYW1lID09PSAnUHJvdG9jb2xWYWxpZGF0aW9uRXJyb3InIHx8XG4gICAgICAgIGVycm9yLm1lc3NhZ2UuaW5jbHVkZXMoJ3ZhbGlkYXRpb24nKSB8fFxuICAgICAgICBlcnJvci5tZXNzYWdlLmluY2x1ZGVzKCdwcm90b2NvbCcpXG4gICAgICApIHtcbiAgICAgICAgZXJyb3JDYXB0dXJlLmNhcHR1cmVFcnJvcihlcnJvciwgJ3ZhbGlkYXRpb24nLCBleHRyYURhdGEpO1xuICAgICAgfSBlbHNlIGlmIChcbiAgICAgICAgZXJyb3IubmFtZSA9PT0gJ1NlcnZlclRpbWVvdXRFcnJvcicgfHxcbiAgICAgICAgZXJyb3IubWVzc2FnZS5pbmNsdWRlcygndGltZWQgb3V0JykgfHxcbiAgICAgICAgZXJyb3IubWVzc2FnZS5pbmNsdWRlcygndGltZW91dCcpXG4gICAgICApIHtcbiAgICAgICAgZXJyb3JDYXB0dXJlLmNhcHR1cmVFcnJvcihlcnJvciwgJ3RpbWVvdXQnLCBleHRyYURhdGEpO1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgZXJyb3JDYXB0dXJlLmNhcHR1cmVFcnJvcihlcnJvciwgJ3Rvb2xfZXhlY3V0aW9uJywgZXh0cmFEYXRhKTtcbiAgICAgIH1cbiAgICB9IGVsc2UgaWYgKG1ldGhvZE5hbWUgPT09ICdyZXNvdXJjZScpIHtcbiAgICAgIGV4dHJhRGF0YS5yZXNvdXJjZV91cmkgPSBoYW5kbGVyTmFtZTtcbiAgICAgIGVycm9yQ2FwdHVyZS5jYXB0dXJlRXJyb3IoZXJyb3IsICdyZXNvdXJjZV9leGVjdXRpb24nLCBleHRyYURhdGEpO1xuICAgIH0gZWxzZSBpZiAobWV0aG9kTmFtZSA9PT0gJ3Byb21wdCcpIHtcbiAgICAgIGV4dHJhRGF0YS5wcm9tcHRfbmFtZSA9IGhhbmRsZXJOYW1lO1xuICAgICAgZXJyb3JDYXB0dXJlLmNhcHR1cmVFcnJvcihlcnJvciwgJ3Byb21wdF9leGVjdXRpb24nLCBleHRyYURhdGEpO1xuICAgIH1cbiAgfSBjYXRjaCAoY2FwdHVyZUVycikge1xuICAgIC8vIG5vb3BcbiAgfVxufVxuXG4vKipcbiAqIFdyYXBzIHRvb2wgaGFuZGxlcnMgdG8gYXNzb2NpYXRlIHRoZW0gd2l0aCByZXF1ZXN0IHNwYW5zXG4gKiBAcGFyYW0gc2VydmVySW5zdGFuY2UgLSBNQ1Agc2VydmVyIGluc3RhbmNlXG4gKi9cbmZ1bmN0aW9uIHdyYXBUb29sSGFuZGxlcnMoc2VydmVySW5zdGFuY2UpIHtcbiAgd3JhcE1ldGhvZEhhbmRsZXIoc2VydmVySW5zdGFuY2UsICd0b29sJyk7XG59XG5cbi8qKlxuICogV3JhcHMgcmVzb3VyY2UgaGFuZGxlcnMgdG8gYXNzb2NpYXRlIHRoZW0gd2l0aCByZXF1ZXN0IHNwYW5zXG4gKiBAcGFyYW0gc2VydmVySW5zdGFuY2UgLSBNQ1Agc2VydmVyIGluc3RhbmNlXG4gKi9cbmZ1bmN0aW9uIHdyYXBSZXNvdXJjZUhhbmRsZXJzKHNlcnZlckluc3RhbmNlKSB7XG4gIHdyYXBNZXRob2RIYW5kbGVyKHNlcnZlckluc3RhbmNlLCAncmVzb3VyY2UnKTtcbn1cblxuLyoqXG4gKiBXcmFwcyBwcm9tcHQgaGFuZGxlcnMgdG8gYXNzb2NpYXRlIHRoZW0gd2l0aCByZXF1ZXN0IHNwYW5zXG4gKiBAcGFyYW0gc2VydmVySW5zdGFuY2UgLSBNQ1Agc2VydmVyIGluc3RhbmNlXG4gKi9cbmZ1bmN0aW9uIHdyYXBQcm9tcHRIYW5kbGVycyhzZXJ2ZXJJbnN0YW5jZSkge1xuICB3cmFwTWV0aG9kSGFuZGxlcihzZXJ2ZXJJbnN0YW5jZSwgJ3Byb21wdCcpO1xufVxuXG4vKipcbiAqIFdyYXBzIGFsbCBNQ1AgaGFuZGxlciB0eXBlcyAodG9vbCwgcmVzb3VyY2UsIHByb21wdCkgZm9yIHNwYW4gY29ycmVsYXRpb25cbiAqIEBwYXJhbSBzZXJ2ZXJJbnN0YW5jZSAtIE1DUCBzZXJ2ZXIgaW5zdGFuY2VcbiAqL1xuZnVuY3Rpb24gd3JhcEFsbE1DUEhhbmRsZXJzKHNlcnZlckluc3RhbmNlKSB7XG4gIHdyYXBUb29sSGFuZGxlcnMoc2VydmVySW5zdGFuY2UpO1xuICB3cmFwUmVzb3VyY2VIYW5kbGVycyhzZXJ2ZXJJbnN0YW5jZSk7XG4gIHdyYXBQcm9tcHRIYW5kbGVycyhzZXJ2ZXJJbnN0YW5jZSk7XG59XG5cbmV4cG9ydHMud3JhcEFsbE1DUEhhbmRsZXJzID0gd3JhcEFsbE1DUEhhbmRsZXJzO1xuZXhwb3J0cy53cmFwUHJvbXB0SGFuZGxlcnMgPSB3cmFwUHJvbXB0SGFuZGxlcnM7XG5leHBvcnRzLndyYXBSZXNvdXJjZUhhbmRsZXJzID0gd3JhcFJlc291cmNlSGFuZGxlcnM7XG5leHBvcnRzLndyYXBUb29sSGFuZGxlcnMgPSB3cmFwVG9vbEhhbmRsZXJzO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9aGFuZGxlcnMuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/handlers.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/index.js":
/*!*********************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/index.js ***!
  \*********************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst object = __webpack_require__(/*! ../../utils/object.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/object.js\");\nconst handlers = __webpack_require__(/*! ./handlers.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/handlers.js\");\nconst transport = __webpack_require__(/*! ./transport.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/transport.js\");\nconst validation = __webpack_require__(/*! ./validation.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/validation.js\");\n\n/**\n * Tracks wrapped MCP server instances to prevent double-wrapping\n * @internal\n */\nconst wrappedMcpServerInstances = new WeakSet();\n\n/**\n * Wraps a MCP Server instance from the `@modelcontextprotocol/sdk` package with Sentry instrumentation.\n *\n * Compatible with versions `^1.9.0` of the `@modelcontextprotocol/sdk` package.\n * Automatically instruments transport methods and handler functions for comprehensive monitoring.\n *\n * @example\n * ```typescript\n * import * as Sentry from '@sentry/core';\n * import { McpServer } from '@modelcontextprotocol/sdk/server/mcp.js';\n * import { StreamableHTTPServerTransport } from '@modelcontextprotocol/sdk/server/streamableHttp.js';\n *\n * const server = Sentry.wrapMcpServerWithSentry(\n *   new McpServer({ name: \"my-server\", version: \"1.0.0\" })\n * );\n *\n * const transport = new StreamableHTTPServerTransport();\n * await server.connect(transport);\n * ```\n *\n * @param mcpServerInstance - MCP server instance to instrument\n * @returns Instrumented server instance (same reference)\n */\nfunction wrapMcpServerWithSentry(mcpServerInstance) {\n  if (wrappedMcpServerInstances.has(mcpServerInstance)) {\n    return mcpServerInstance;\n  }\n\n  if (!validation.validateMcpServerInstance(mcpServerInstance)) {\n    return mcpServerInstance;\n  }\n\n  const serverInstance = mcpServerInstance ;\n\n  object.fill(serverInstance, 'connect', originalConnect => {\n    return async function ( transport$1, ...restArgs) {\n      const result = await (originalConnect ).call(\n        this,\n        transport$1,\n        ...restArgs,\n      );\n\n      transport.wrapTransportOnMessage(transport$1);\n      transport.wrapTransportSend(transport$1);\n      transport.wrapTransportOnClose(transport$1);\n      transport.wrapTransportError(transport$1);\n\n      return result;\n    };\n  });\n\n  handlers.wrapAllMCPHandlers(serverInstance);\n\n  wrappedMcpServerInstances.add(mcpServerInstance);\n  return mcpServerInstance ;\n}\n\nexports.wrapMcpServerWithSentry = wrapMcpServerWithSentry;\n//# sourceMappingURL=index.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvbWNwLXNlcnZlci9pbmRleC5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxlQUFlLG1CQUFPLENBQUMsaUlBQXVCO0FBQzlDLGlCQUFpQixtQkFBTyxDQUFDLDZJQUFlO0FBQ3hDLGtCQUFrQixtQkFBTyxDQUFDLCtJQUFnQjtBQUMxQyxtQkFBbUIsbUJBQU8sQ0FBQyxpSkFBaUI7O0FBRTVDO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsWUFBWSxZQUFZO0FBQ3hCLFlBQVksZ0NBQWdDO0FBQzVDO0FBQ0E7QUFDQSxxQkFBcUIscUNBQXFDO0FBQzFEO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsR0FBRzs7QUFFSDs7QUFFQTtBQUNBO0FBQ0E7O0FBRUEsK0JBQStCO0FBQy9CIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvaW50ZWdyYXRpb25zL21jcC1zZXJ2ZXIvaW5kZXguanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IG9iamVjdCA9IHJlcXVpcmUoJy4uLy4uL3V0aWxzL29iamVjdC5qcycpO1xuY29uc3QgaGFuZGxlcnMgPSByZXF1aXJlKCcuL2hhbmRsZXJzLmpzJyk7XG5jb25zdCB0cmFuc3BvcnQgPSByZXF1aXJlKCcuL3RyYW5zcG9ydC5qcycpO1xuY29uc3QgdmFsaWRhdGlvbiA9IHJlcXVpcmUoJy4vdmFsaWRhdGlvbi5qcycpO1xuXG4vKipcbiAqIFRyYWNrcyB3cmFwcGVkIE1DUCBzZXJ2ZXIgaW5zdGFuY2VzIHRvIHByZXZlbnQgZG91YmxlLXdyYXBwaW5nXG4gKiBAaW50ZXJuYWxcbiAqL1xuY29uc3Qgd3JhcHBlZE1jcFNlcnZlckluc3RhbmNlcyA9IG5ldyBXZWFrU2V0KCk7XG5cbi8qKlxuICogV3JhcHMgYSBNQ1AgU2VydmVyIGluc3RhbmNlIGZyb20gdGhlIGBAbW9kZWxjb250ZXh0cHJvdG9jb2wvc2RrYCBwYWNrYWdlIHdpdGggU2VudHJ5IGluc3RydW1lbnRhdGlvbi5cbiAqXG4gKiBDb21wYXRpYmxlIHdpdGggdmVyc2lvbnMgYF4xLjkuMGAgb2YgdGhlIGBAbW9kZWxjb250ZXh0cHJvdG9jb2wvc2RrYCBwYWNrYWdlLlxuICogQXV0b21hdGljYWxseSBpbnN0cnVtZW50cyB0cmFuc3BvcnQgbWV0aG9kcyBhbmQgaGFuZGxlciBmdW5jdGlvbnMgZm9yIGNvbXByZWhlbnNpdmUgbW9uaXRvcmluZy5cbiAqXG4gKiBAZXhhbXBsZVxuICogYGBgdHlwZXNjcmlwdFxuICogaW1wb3J0ICogYXMgU2VudHJ5IGZyb20gJ0BzZW50cnkvY29yZSc7XG4gKiBpbXBvcnQgeyBNY3BTZXJ2ZXIgfSBmcm9tICdAbW9kZWxjb250ZXh0cHJvdG9jb2wvc2RrL3NlcnZlci9tY3AuanMnO1xuICogaW1wb3J0IHsgU3RyZWFtYWJsZUhUVFBTZXJ2ZXJUcmFuc3BvcnQgfSBmcm9tICdAbW9kZWxjb250ZXh0cHJvdG9jb2wvc2RrL3NlcnZlci9zdHJlYW1hYmxlSHR0cC5qcyc7XG4gKlxuICogY29uc3Qgc2VydmVyID0gU2VudHJ5LndyYXBNY3BTZXJ2ZXJXaXRoU2VudHJ5KFxuICogICBuZXcgTWNwU2VydmVyKHsgbmFtZTogXCJteS1zZXJ2ZXJcIiwgdmVyc2lvbjogXCIxLjAuMFwiIH0pXG4gKiApO1xuICpcbiAqIGNvbnN0IHRyYW5zcG9ydCA9IG5ldyBTdHJlYW1hYmxlSFRUUFNlcnZlclRyYW5zcG9ydCgpO1xuICogYXdhaXQgc2VydmVyLmNvbm5lY3QodHJhbnNwb3J0KTtcbiAqIGBgYFxuICpcbiAqIEBwYXJhbSBtY3BTZXJ2ZXJJbnN0YW5jZSAtIE1DUCBzZXJ2ZXIgaW5zdGFuY2UgdG8gaW5zdHJ1bWVudFxuICogQHJldHVybnMgSW5zdHJ1bWVudGVkIHNlcnZlciBpbnN0YW5jZSAoc2FtZSByZWZlcmVuY2UpXG4gKi9cbmZ1bmN0aW9uIHdyYXBNY3BTZXJ2ZXJXaXRoU2VudHJ5KG1jcFNlcnZlckluc3RhbmNlKSB7XG4gIGlmICh3cmFwcGVkTWNwU2VydmVySW5zdGFuY2VzLmhhcyhtY3BTZXJ2ZXJJbnN0YW5jZSkpIHtcbiAgICByZXR1cm4gbWNwU2VydmVySW5zdGFuY2U7XG4gIH1cblxuICBpZiAoIXZhbGlkYXRpb24udmFsaWRhdGVNY3BTZXJ2ZXJJbnN0YW5jZShtY3BTZXJ2ZXJJbnN0YW5jZSkpIHtcbiAgICByZXR1cm4gbWNwU2VydmVySW5zdGFuY2U7XG4gIH1cblxuICBjb25zdCBzZXJ2ZXJJbnN0YW5jZSA9IG1jcFNlcnZlckluc3RhbmNlIDtcblxuICBvYmplY3QuZmlsbChzZXJ2ZXJJbnN0YW5jZSwgJ2Nvbm5lY3QnLCBvcmlnaW5hbENvbm5lY3QgPT4ge1xuICAgIHJldHVybiBhc3luYyBmdW5jdGlvbiAoIHRyYW5zcG9ydCQxLCAuLi5yZXN0QXJncykge1xuICAgICAgY29uc3QgcmVzdWx0ID0gYXdhaXQgKG9yaWdpbmFsQ29ubmVjdCApLmNhbGwoXG4gICAgICAgIHRoaXMsXG4gICAgICAgIHRyYW5zcG9ydCQxLFxuICAgICAgICAuLi5yZXN0QXJncyxcbiAgICAgICk7XG5cbiAgICAgIHRyYW5zcG9ydC53cmFwVHJhbnNwb3J0T25NZXNzYWdlKHRyYW5zcG9ydCQxKTtcbiAgICAgIHRyYW5zcG9ydC53cmFwVHJhbnNwb3J0U2VuZCh0cmFuc3BvcnQkMSk7XG4gICAgICB0cmFuc3BvcnQud3JhcFRyYW5zcG9ydE9uQ2xvc2UodHJhbnNwb3J0JDEpO1xuICAgICAgdHJhbnNwb3J0LndyYXBUcmFuc3BvcnRFcnJvcih0cmFuc3BvcnQkMSk7XG5cbiAgICAgIHJldHVybiByZXN1bHQ7XG4gICAgfTtcbiAgfSk7XG5cbiAgaGFuZGxlcnMud3JhcEFsbE1DUEhhbmRsZXJzKHNlcnZlckluc3RhbmNlKTtcblxuICB3cmFwcGVkTWNwU2VydmVySW5zdGFuY2VzLmFkZChtY3BTZXJ2ZXJJbnN0YW5jZSk7XG4gIHJldHVybiBtY3BTZXJ2ZXJJbnN0YW5jZSA7XG59XG5cbmV4cG9ydHMud3JhcE1jcFNlcnZlcldpdGhTZW50cnkgPSB3cmFwTWNwU2VydmVyV2l0aFNlbnRyeTtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWluZGV4LmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/index.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/methodConfig.js":
/*!****************************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/methodConfig.js ***!
  \****************************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst attributes = __webpack_require__(/*! ./attributes.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/attributes.js\");\n\n/**\n * Method configuration and request processing for MCP server instrumentation\n */\n\n\n/**\n * Configuration for MCP methods to extract targets and arguments\n * @internal Maps method names to their extraction configuration\n */\nconst METHOD_CONFIGS = {\n  'tools/call': {\n    targetField: 'name',\n    targetAttribute: attributes.MCP_TOOL_NAME_ATTRIBUTE,\n    captureArguments: true,\n    argumentsField: 'arguments',\n  },\n  'resources/read': {\n    targetField: 'uri',\n    targetAttribute: attributes.MCP_RESOURCE_URI_ATTRIBUTE,\n    captureUri: true,\n  },\n  'resources/subscribe': {\n    targetField: 'uri',\n    targetAttribute: attributes.MCP_RESOURCE_URI_ATTRIBUTE,\n  },\n  'resources/unsubscribe': {\n    targetField: 'uri',\n    targetAttribute: attributes.MCP_RESOURCE_URI_ATTRIBUTE,\n  },\n  'prompts/get': {\n    targetField: 'name',\n    targetAttribute: attributes.MCP_PROMPT_NAME_ATTRIBUTE,\n    captureName: true,\n    captureArguments: true,\n    argumentsField: 'arguments',\n  },\n};\n\n/**\n * Extracts target info from method and params based on method type\n * @param method - MCP method name\n * @param params - Method parameters\n * @returns Target name and attributes for span instrumentation\n */\nfunction extractTargetInfo(\n  method,\n  params,\n)\n\n {\n  const config = METHOD_CONFIGS[method ];\n  if (!config) {\n    return { attributes: {} };\n  }\n\n  const target =\n    config.targetField && typeof params?.[config.targetField] === 'string'\n      ? (params[config.targetField] )\n      : undefined;\n\n  return {\n    target,\n    attributes: target && config.targetAttribute ? { [config.targetAttribute]: target } : {},\n  };\n}\n\n/**\n * Extracts request arguments based on method type\n * @param method - MCP method name\n * @param params - Method parameters\n * @returns Arguments as span attributes with mcp.request.argument prefix\n */\nfunction getRequestArguments(method, params) {\n  const args = {};\n  const config = METHOD_CONFIGS[method ];\n\n  if (!config) {\n    return args;\n  }\n\n  if (config.captureArguments && config.argumentsField && params?.[config.argumentsField]) {\n    const argumentsObj = params[config.argumentsField];\n    if (typeof argumentsObj === 'object' && argumentsObj !== null) {\n      for (const [key, value] of Object.entries(argumentsObj )) {\n        args[`${attributes.MCP_REQUEST_ARGUMENT}.${key.toLowerCase()}`] = JSON.stringify(value);\n      }\n    }\n  }\n\n  if (config.captureUri && params?.uri) {\n    args[`${attributes.MCP_REQUEST_ARGUMENT}.uri`] = JSON.stringify(params.uri);\n  }\n\n  if (config.captureName && params?.name) {\n    args[`${attributes.MCP_REQUEST_ARGUMENT}.name`] = JSON.stringify(params.name);\n  }\n\n  return args;\n}\n\nexports.extractTargetInfo = extractTargetInfo;\nexports.getRequestArguments = getRequestArguments;\n//# sourceMappingURL=methodConfig.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvbWNwLXNlcnZlci9tZXRob2RDb25maWcuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsbUJBQW1CLG1CQUFPLENBQUMsaUpBQWlCOztBQUU1QztBQUNBO0FBQ0E7OztBQUdBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsR0FBRztBQUNIO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsR0FBRztBQUNIO0FBQ0E7QUFDQTtBQUNBLEdBQUc7QUFDSDtBQUNBO0FBQ0E7QUFDQSxHQUFHO0FBQ0g7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsR0FBRztBQUNIOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBLGFBQWE7QUFDYjs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0EscURBQXFELG1DQUFtQyxJQUFJO0FBQzVGO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGdCQUFnQixnQ0FBZ0MsR0FBRyxrQkFBa0I7QUFDckU7QUFDQTtBQUNBOztBQUVBO0FBQ0EsWUFBWSxnQ0FBZ0M7QUFDNUM7O0FBRUE7QUFDQSxZQUFZLGdDQUFnQztBQUM1Qzs7QUFFQTtBQUNBOztBQUVBLHlCQUF5QjtBQUN6QiwyQkFBMkI7QUFDM0IiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvbWNwLXNlcnZlci9tZXRob2RDb25maWcuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGF0dHJpYnV0ZXMgPSByZXF1aXJlKCcuL2F0dHJpYnV0ZXMuanMnKTtcblxuLyoqXG4gKiBNZXRob2QgY29uZmlndXJhdGlvbiBhbmQgcmVxdWVzdCBwcm9jZXNzaW5nIGZvciBNQ1Agc2VydmVyIGluc3RydW1lbnRhdGlvblxuICovXG5cblxuLyoqXG4gKiBDb25maWd1cmF0aW9uIGZvciBNQ1AgbWV0aG9kcyB0byBleHRyYWN0IHRhcmdldHMgYW5kIGFyZ3VtZW50c1xuICogQGludGVybmFsIE1hcHMgbWV0aG9kIG5hbWVzIHRvIHRoZWlyIGV4dHJhY3Rpb24gY29uZmlndXJhdGlvblxuICovXG5jb25zdCBNRVRIT0RfQ09ORklHUyA9IHtcbiAgJ3Rvb2xzL2NhbGwnOiB7XG4gICAgdGFyZ2V0RmllbGQ6ICduYW1lJyxcbiAgICB0YXJnZXRBdHRyaWJ1dGU6IGF0dHJpYnV0ZXMuTUNQX1RPT0xfTkFNRV9BVFRSSUJVVEUsXG4gICAgY2FwdHVyZUFyZ3VtZW50czogdHJ1ZSxcbiAgICBhcmd1bWVudHNGaWVsZDogJ2FyZ3VtZW50cycsXG4gIH0sXG4gICdyZXNvdXJjZXMvcmVhZCc6IHtcbiAgICB0YXJnZXRGaWVsZDogJ3VyaScsXG4gICAgdGFyZ2V0QXR0cmlidXRlOiBhdHRyaWJ1dGVzLk1DUF9SRVNPVVJDRV9VUklfQVRUUklCVVRFLFxuICAgIGNhcHR1cmVVcmk6IHRydWUsXG4gIH0sXG4gICdyZXNvdXJjZXMvc3Vic2NyaWJlJzoge1xuICAgIHRhcmdldEZpZWxkOiAndXJpJyxcbiAgICB0YXJnZXRBdHRyaWJ1dGU6IGF0dHJpYnV0ZXMuTUNQX1JFU09VUkNFX1VSSV9BVFRSSUJVVEUsXG4gIH0sXG4gICdyZXNvdXJjZXMvdW5zdWJzY3JpYmUnOiB7XG4gICAgdGFyZ2V0RmllbGQ6ICd1cmknLFxuICAgIHRhcmdldEF0dHJpYnV0ZTogYXR0cmlidXRlcy5NQ1BfUkVTT1VSQ0VfVVJJX0FUVFJJQlVURSxcbiAgfSxcbiAgJ3Byb21wdHMvZ2V0Jzoge1xuICAgIHRhcmdldEZpZWxkOiAnbmFtZScsXG4gICAgdGFyZ2V0QXR0cmlidXRlOiBhdHRyaWJ1dGVzLk1DUF9QUk9NUFRfTkFNRV9BVFRSSUJVVEUsXG4gICAgY2FwdHVyZU5hbWU6IHRydWUsXG4gICAgY2FwdHVyZUFyZ3VtZW50czogdHJ1ZSxcbiAgICBhcmd1bWVudHNGaWVsZDogJ2FyZ3VtZW50cycsXG4gIH0sXG59O1xuXG4vKipcbiAqIEV4dHJhY3RzIHRhcmdldCBpbmZvIGZyb20gbWV0aG9kIGFuZCBwYXJhbXMgYmFzZWQgb24gbWV0aG9kIHR5cGVcbiAqIEBwYXJhbSBtZXRob2QgLSBNQ1AgbWV0aG9kIG5hbWVcbiAqIEBwYXJhbSBwYXJhbXMgLSBNZXRob2QgcGFyYW1ldGVyc1xuICogQHJldHVybnMgVGFyZ2V0IG5hbWUgYW5kIGF0dHJpYnV0ZXMgZm9yIHNwYW4gaW5zdHJ1bWVudGF0aW9uXG4gKi9cbmZ1bmN0aW9uIGV4dHJhY3RUYXJnZXRJbmZvKFxuICBtZXRob2QsXG4gIHBhcmFtcyxcbilcblxuIHtcbiAgY29uc3QgY29uZmlnID0gTUVUSE9EX0NPTkZJR1NbbWV0aG9kIF07XG4gIGlmICghY29uZmlnKSB7XG4gICAgcmV0dXJuIHsgYXR0cmlidXRlczoge30gfTtcbiAgfVxuXG4gIGNvbnN0IHRhcmdldCA9XG4gICAgY29uZmlnLnRhcmdldEZpZWxkICYmIHR5cGVvZiBwYXJhbXM/Lltjb25maWcudGFyZ2V0RmllbGRdID09PSAnc3RyaW5nJ1xuICAgICAgPyAocGFyYW1zW2NvbmZpZy50YXJnZXRGaWVsZF0gKVxuICAgICAgOiB1bmRlZmluZWQ7XG5cbiAgcmV0dXJuIHtcbiAgICB0YXJnZXQsXG4gICAgYXR0cmlidXRlczogdGFyZ2V0ICYmIGNvbmZpZy50YXJnZXRBdHRyaWJ1dGUgPyB7IFtjb25maWcudGFyZ2V0QXR0cmlidXRlXTogdGFyZ2V0IH0gOiB7fSxcbiAgfTtcbn1cblxuLyoqXG4gKiBFeHRyYWN0cyByZXF1ZXN0IGFyZ3VtZW50cyBiYXNlZCBvbiBtZXRob2QgdHlwZVxuICogQHBhcmFtIG1ldGhvZCAtIE1DUCBtZXRob2QgbmFtZVxuICogQHBhcmFtIHBhcmFtcyAtIE1ldGhvZCBwYXJhbWV0ZXJzXG4gKiBAcmV0dXJucyBBcmd1bWVudHMgYXMgc3BhbiBhdHRyaWJ1dGVzIHdpdGggbWNwLnJlcXVlc3QuYXJndW1lbnQgcHJlZml4XG4gKi9cbmZ1bmN0aW9uIGdldFJlcXVlc3RBcmd1bWVudHMobWV0aG9kLCBwYXJhbXMpIHtcbiAgY29uc3QgYXJncyA9IHt9O1xuICBjb25zdCBjb25maWcgPSBNRVRIT0RfQ09ORklHU1ttZXRob2QgXTtcblxuICBpZiAoIWNvbmZpZykge1xuICAgIHJldHVybiBhcmdzO1xuICB9XG5cbiAgaWYgKGNvbmZpZy5jYXB0dXJlQXJndW1lbnRzICYmIGNvbmZpZy5hcmd1bWVudHNGaWVsZCAmJiBwYXJhbXM/Lltjb25maWcuYXJndW1lbnRzRmllbGRdKSB7XG4gICAgY29uc3QgYXJndW1lbnRzT2JqID0gcGFyYW1zW2NvbmZpZy5hcmd1bWVudHNGaWVsZF07XG4gICAgaWYgKHR5cGVvZiBhcmd1bWVudHNPYmogPT09ICdvYmplY3QnICYmIGFyZ3VtZW50c09iaiAhPT0gbnVsbCkge1xuICAgICAgZm9yIChjb25zdCBba2V5LCB2YWx1ZV0gb2YgT2JqZWN0LmVudHJpZXMoYXJndW1lbnRzT2JqICkpIHtcbiAgICAgICAgYXJnc1tgJHthdHRyaWJ1dGVzLk1DUF9SRVFVRVNUX0FSR1VNRU5UfS4ke2tleS50b0xvd2VyQ2FzZSgpfWBdID0gSlNPTi5zdHJpbmdpZnkodmFsdWUpO1xuICAgICAgfVxuICAgIH1cbiAgfVxuXG4gIGlmIChjb25maWcuY2FwdHVyZVVyaSAmJiBwYXJhbXM/LnVyaSkge1xuICAgIGFyZ3NbYCR7YXR0cmlidXRlcy5NQ1BfUkVRVUVTVF9BUkdVTUVOVH0udXJpYF0gPSBKU09OLnN0cmluZ2lmeShwYXJhbXMudXJpKTtcbiAgfVxuXG4gIGlmIChjb25maWcuY2FwdHVyZU5hbWUgJiYgcGFyYW1zPy5uYW1lKSB7XG4gICAgYXJnc1tgJHthdHRyaWJ1dGVzLk1DUF9SRVFVRVNUX0FSR1VNRU5UfS5uYW1lYF0gPSBKU09OLnN0cmluZ2lmeShwYXJhbXMubmFtZSk7XG4gIH1cblxuICByZXR1cm4gYXJncztcbn1cblxuZXhwb3J0cy5leHRyYWN0VGFyZ2V0SW5mbyA9IGV4dHJhY3RUYXJnZXRJbmZvO1xuZXhwb3J0cy5nZXRSZXF1ZXN0QXJndW1lbnRzID0gZ2V0UmVxdWVzdEFyZ3VtZW50cztcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPW1ldGhvZENvbmZpZy5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/methodConfig.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/piiFiltering.js":
/*!****************************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/piiFiltering.js ***!
  \****************************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst attributes = __webpack_require__(/*! ./attributes.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/attributes.js\");\n\n/**\n * PII attributes that should be removed when sendDefaultPii is false\n * @internal\n */\nconst PII_ATTRIBUTES = new Set([\n  attributes.CLIENT_ADDRESS_ATTRIBUTE,\n  attributes.CLIENT_PORT_ATTRIBUTE,\n  attributes.MCP_LOGGING_MESSAGE_ATTRIBUTE,\n  attributes.MCP_PROMPT_RESULT_DESCRIPTION_ATTRIBUTE,\n  attributes.MCP_PROMPT_RESULT_MESSAGE_CONTENT_ATTRIBUTE,\n  attributes.MCP_RESOURCE_URI_ATTRIBUTE,\n  attributes.MCP_TOOL_RESULT_CONTENT_ATTRIBUTE,\n]);\n\n/**\n * Checks if an attribute key should be considered PII.\n *\n * Returns true for:\n * - Explicit PII attributes (client.address, client.port, mcp.logging.message, etc.)\n * - All request arguments (mcp.request.argument.*)\n * - Tool and prompt result content (mcp.tool.result.*, mcp.prompt.result.*) except metadata\n *\n * Preserves metadata attributes ending with _count, _error, or .is_error as they don't contain sensitive data.\n *\n * @param key - Attribute key to evaluate\n * @returns true if the attribute should be filtered out (is PII), false if it should be preserved\n * @internal\n */\nfunction isPiiAttribute(key) {\n  if (PII_ATTRIBUTES.has(key)) {\n    return true;\n  }\n\n  if (key.startsWith(`${attributes.MCP_REQUEST_ARGUMENT}.`)) {\n    return true;\n  }\n\n  if (key.startsWith(`${attributes.MCP_TOOL_RESULT_PREFIX}.`) || key.startsWith(`${attributes.MCP_PROMPT_RESULT_PREFIX}.`)) {\n    if (!key.endsWith('_count') && !key.endsWith('_error') && !key.endsWith('.is_error')) {\n      return true;\n    }\n  }\n\n  return false;\n}\n\n/**\n * Removes PII attributes from span data when sendDefaultPii is false\n * @param spanData - Raw span attributes\n * @param sendDefaultPii - Whether to include PII data\n * @returns Filtered span attributes\n */\nfunction filterMcpPiiFromSpanData(\n  spanData,\n  sendDefaultPii,\n) {\n  if (sendDefaultPii) {\n    return spanData ;\n  }\n\n  return Object.entries(spanData).reduce(\n    (acc, [key, value]) => {\n      if (!isPiiAttribute(key)) {\n        acc[key] = value ;\n      }\n      return acc;\n    },\n    {} ,\n  );\n}\n\nexports.filterMcpPiiFromSpanData = filterMcpPiiFromSpanData;\n//# sourceMappingURL=piiFiltering.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvbWNwLXNlcnZlci9waWlGaWx0ZXJpbmcuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsbUJBQW1CLG1CQUFPLENBQUMsaUpBQWlCOztBQUU1QztBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsd0JBQXdCLGdDQUFnQztBQUN4RDtBQUNBOztBQUVBLHdCQUF3QixrQ0FBa0MseUJBQXlCLG9DQUFvQztBQUN2SDtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEtBQUs7QUFDTCxPQUFPO0FBQ1A7QUFDQTs7QUFFQSxnQ0FBZ0M7QUFDaEMiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvbWNwLXNlcnZlci9waWlGaWx0ZXJpbmcuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGF0dHJpYnV0ZXMgPSByZXF1aXJlKCcuL2F0dHJpYnV0ZXMuanMnKTtcblxuLyoqXG4gKiBQSUkgYXR0cmlidXRlcyB0aGF0IHNob3VsZCBiZSByZW1vdmVkIHdoZW4gc2VuZERlZmF1bHRQaWkgaXMgZmFsc2VcbiAqIEBpbnRlcm5hbFxuICovXG5jb25zdCBQSUlfQVRUUklCVVRFUyA9IG5ldyBTZXQoW1xuICBhdHRyaWJ1dGVzLkNMSUVOVF9BRERSRVNTX0FUVFJJQlVURSxcbiAgYXR0cmlidXRlcy5DTElFTlRfUE9SVF9BVFRSSUJVVEUsXG4gIGF0dHJpYnV0ZXMuTUNQX0xPR0dJTkdfTUVTU0FHRV9BVFRSSUJVVEUsXG4gIGF0dHJpYnV0ZXMuTUNQX1BST01QVF9SRVNVTFRfREVTQ1JJUFRJT05fQVRUUklCVVRFLFxuICBhdHRyaWJ1dGVzLk1DUF9QUk9NUFRfUkVTVUxUX01FU1NBR0VfQ09OVEVOVF9BVFRSSUJVVEUsXG4gIGF0dHJpYnV0ZXMuTUNQX1JFU09VUkNFX1VSSV9BVFRSSUJVVEUsXG4gIGF0dHJpYnV0ZXMuTUNQX1RPT0xfUkVTVUxUX0NPTlRFTlRfQVRUUklCVVRFLFxuXSk7XG5cbi8qKlxuICogQ2hlY2tzIGlmIGFuIGF0dHJpYnV0ZSBrZXkgc2hvdWxkIGJlIGNvbnNpZGVyZWQgUElJLlxuICpcbiAqIFJldHVybnMgdHJ1ZSBmb3I6XG4gKiAtIEV4cGxpY2l0IFBJSSBhdHRyaWJ1dGVzIChjbGllbnQuYWRkcmVzcywgY2xpZW50LnBvcnQsIG1jcC5sb2dnaW5nLm1lc3NhZ2UsIGV0Yy4pXG4gKiAtIEFsbCByZXF1ZXN0IGFyZ3VtZW50cyAobWNwLnJlcXVlc3QuYXJndW1lbnQuKilcbiAqIC0gVG9vbCBhbmQgcHJvbXB0IHJlc3VsdCBjb250ZW50IChtY3AudG9vbC5yZXN1bHQuKiwgbWNwLnByb21wdC5yZXN1bHQuKikgZXhjZXB0IG1ldGFkYXRhXG4gKlxuICogUHJlc2VydmVzIG1ldGFkYXRhIGF0dHJpYnV0ZXMgZW5kaW5nIHdpdGggX2NvdW50LCBfZXJyb3IsIG9yIC5pc19lcnJvciBhcyB0aGV5IGRvbid0IGNvbnRhaW4gc2Vuc2l0aXZlIGRhdGEuXG4gKlxuICogQHBhcmFtIGtleSAtIEF0dHJpYnV0ZSBrZXkgdG8gZXZhbHVhdGVcbiAqIEByZXR1cm5zIHRydWUgaWYgdGhlIGF0dHJpYnV0ZSBzaG91bGQgYmUgZmlsdGVyZWQgb3V0IChpcyBQSUkpLCBmYWxzZSBpZiBpdCBzaG91bGQgYmUgcHJlc2VydmVkXG4gKiBAaW50ZXJuYWxcbiAqL1xuZnVuY3Rpb24gaXNQaWlBdHRyaWJ1dGUoa2V5KSB7XG4gIGlmIChQSUlfQVRUUklCVVRFUy5oYXMoa2V5KSkge1xuICAgIHJldHVybiB0cnVlO1xuICB9XG5cbiAgaWYgKGtleS5zdGFydHNXaXRoKGAke2F0dHJpYnV0ZXMuTUNQX1JFUVVFU1RfQVJHVU1FTlR9LmApKSB7XG4gICAgcmV0dXJuIHRydWU7XG4gIH1cblxuICBpZiAoa2V5LnN0YXJ0c1dpdGgoYCR7YXR0cmlidXRlcy5NQ1BfVE9PTF9SRVNVTFRfUFJFRklYfS5gKSB8fCBrZXkuc3RhcnRzV2l0aChgJHthdHRyaWJ1dGVzLk1DUF9QUk9NUFRfUkVTVUxUX1BSRUZJWH0uYCkpIHtcbiAgICBpZiAoIWtleS5lbmRzV2l0aCgnX2NvdW50JykgJiYgIWtleS5lbmRzV2l0aCgnX2Vycm9yJykgJiYgIWtleS5lbmRzV2l0aCgnLmlzX2Vycm9yJykpIHtcbiAgICAgIHJldHVybiB0cnVlO1xuICAgIH1cbiAgfVxuXG4gIHJldHVybiBmYWxzZTtcbn1cblxuLyoqXG4gKiBSZW1vdmVzIFBJSSBhdHRyaWJ1dGVzIGZyb20gc3BhbiBkYXRhIHdoZW4gc2VuZERlZmF1bHRQaWkgaXMgZmFsc2VcbiAqIEBwYXJhbSBzcGFuRGF0YSAtIFJhdyBzcGFuIGF0dHJpYnV0ZXNcbiAqIEBwYXJhbSBzZW5kRGVmYXVsdFBpaSAtIFdoZXRoZXIgdG8gaW5jbHVkZSBQSUkgZGF0YVxuICogQHJldHVybnMgRmlsdGVyZWQgc3BhbiBhdHRyaWJ1dGVzXG4gKi9cbmZ1bmN0aW9uIGZpbHRlck1jcFBpaUZyb21TcGFuRGF0YShcbiAgc3BhbkRhdGEsXG4gIHNlbmREZWZhdWx0UGlpLFxuKSB7XG4gIGlmIChzZW5kRGVmYXVsdFBpaSkge1xuICAgIHJldHVybiBzcGFuRGF0YSA7XG4gIH1cblxuICByZXR1cm4gT2JqZWN0LmVudHJpZXMoc3BhbkRhdGEpLnJlZHVjZShcbiAgICAoYWNjLCBba2V5LCB2YWx1ZV0pID0+IHtcbiAgICAgIGlmICghaXNQaWlBdHRyaWJ1dGUoa2V5KSkge1xuICAgICAgICBhY2Nba2V5XSA9IHZhbHVlIDtcbiAgICAgIH1cbiAgICAgIHJldHVybiBhY2M7XG4gICAgfSxcbiAgICB7fSAsXG4gICk7XG59XG5cbmV4cG9ydHMuZmlsdGVyTWNwUGlpRnJvbVNwYW5EYXRhID0gZmlsdGVyTWNwUGlpRnJvbVNwYW5EYXRhO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9cGlpRmlsdGVyaW5nLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/piiFiltering.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/resultExtraction.js":
/*!********************************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/resultExtraction.js ***!
  \********************************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst attributes = __webpack_require__(/*! ./attributes.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/attributes.js\");\nconst validation = __webpack_require__(/*! ./validation.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/validation.js\");\n\n/**\n * Result extraction functions for MCP server instrumentation\n *\n * Handles extraction of attributes from tool and prompt execution results.\n */\n\n\n/**\n * Build attributes for tool result content items\n * @param content - Array of content items from tool result\n * @returns Attributes extracted from each content item including type, text, mime type, URI, and resource info\n */\nfunction buildAllContentItemAttributes(content) {\n  const attributes$1 = {\n    [attributes.MCP_TOOL_RESULT_CONTENT_COUNT_ATTRIBUTE]: content.length,\n  };\n\n  for (const [i, item] of content.entries()) {\n    if (!validation.isValidContentItem(item)) {\n      continue;\n    }\n\n    const prefix = content.length === 1 ? 'mcp.tool.result' : `mcp.tool.result.${i}`;\n\n    const safeSet = (key, value) => {\n      if (typeof value === 'string') {\n        attributes$1[`${prefix}.${key}`] = value;\n      }\n    };\n\n    safeSet('content_type', item.type);\n    safeSet('mime_type', item.mimeType);\n    safeSet('uri', item.uri);\n    safeSet('name', item.name);\n\n    if (typeof item.text === 'string') {\n      attributes$1[`${prefix}.content`] = item.text;\n    }\n\n    if (typeof item.data === 'string') {\n      attributes$1[`${prefix}.data_size`] = item.data.length;\n    }\n\n    const resource = item.resource;\n    if (validation.isValidContentItem(resource)) {\n      safeSet('resource_uri', resource.uri);\n      safeSet('resource_mime_type', resource.mimeType);\n    }\n  }\n\n  return attributes$1;\n}\n\n/**\n * Extract tool result attributes for span instrumentation\n * @param result - Tool execution result\n * @returns Attributes extracted from tool result content\n */\nfunction extractToolResultAttributes(result) {\n  if (!validation.isValidContentItem(result)) {\n    return {};\n  }\n\n  const attributes$1 = Array.isArray(result.content) ? buildAllContentItemAttributes(result.content) : {};\n\n  if (typeof result.isError === 'boolean') {\n    attributes$1[attributes.MCP_TOOL_RESULT_IS_ERROR_ATTRIBUTE] = result.isError;\n  }\n\n  return attributes$1;\n}\n\n/**\n * Extract prompt result attributes for span instrumentation\n * @param result - Prompt execution result\n * @returns Attributes extracted from prompt result\n */\nfunction extractPromptResultAttributes(result) {\n  const attributes$1 = {};\n  if (!validation.isValidContentItem(result)) {\n    return attributes$1;\n  }\n\n  if (typeof result.description === 'string') {\n    attributes$1[attributes.MCP_PROMPT_RESULT_DESCRIPTION_ATTRIBUTE] = result.description;\n  }\n\n  if (Array.isArray(result.messages)) {\n    attributes$1[attributes.MCP_PROMPT_RESULT_MESSAGE_COUNT_ATTRIBUTE] = result.messages.length;\n\n    const messages = result.messages;\n    for (const [i, message] of messages.entries()) {\n      if (!validation.isValidContentItem(message)) {\n        continue;\n      }\n\n      const prefix = messages.length === 1 ? 'mcp.prompt.result' : `mcp.prompt.result.${i}`;\n\n      const safeSet = (key, value) => {\n        if (typeof value === 'string') {\n          const attrName = messages.length === 1 ? `${prefix}.message_${key}` : `${prefix}.${key}`;\n          attributes$1[attrName] = value;\n        }\n      };\n\n      safeSet('role', message.role);\n\n      if (validation.isValidContentItem(message.content)) {\n        const content = message.content;\n        if (typeof content.text === 'string') {\n          const attrName = messages.length === 1 ? `${prefix}.message_content` : `${prefix}.content`;\n          attributes$1[attrName] = content.text;\n        }\n      }\n    }\n  }\n\n  return attributes$1;\n}\n\nexports.extractPromptResultAttributes = extractPromptResultAttributes;\nexports.extractToolResultAttributes = extractToolResultAttributes;\n//# sourceMappingURL=resultExtraction.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvbWNwLXNlcnZlci9yZXN1bHRFeHRyYWN0aW9uLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLG1CQUFtQixtQkFBTyxDQUFDLGlKQUFpQjtBQUM1QyxtQkFBbUIsbUJBQU8sQ0FBQyxpSkFBaUI7O0FBRTVDO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7OztBQUdBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSxpRkFBaUYsRUFBRTs7QUFFbkY7QUFDQTtBQUNBLHdCQUF3QixPQUFPLEdBQUcsSUFBSTtBQUN0QztBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0Esc0JBQXNCLE9BQU87QUFDN0I7O0FBRUE7QUFDQSxzQkFBc0IsT0FBTztBQUM3Qjs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSx3RkFBd0YsRUFBRTs7QUFFMUY7QUFDQTtBQUNBLHNEQUFzRCxPQUFPLFdBQVcsSUFBSSxPQUFPLE9BQU8sR0FBRyxJQUFJO0FBQ2pHO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQSxzREFBc0QsT0FBTyx1QkFBdUIsT0FBTztBQUMzRjtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUEscUNBQXFDO0FBQ3JDLG1DQUFtQztBQUNuQyIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL2ludGVncmF0aW9ucy9tY3Atc2VydmVyL3Jlc3VsdEV4dHJhY3Rpb24uanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGF0dHJpYnV0ZXMgPSByZXF1aXJlKCcuL2F0dHJpYnV0ZXMuanMnKTtcbmNvbnN0IHZhbGlkYXRpb24gPSByZXF1aXJlKCcuL3ZhbGlkYXRpb24uanMnKTtcblxuLyoqXG4gKiBSZXN1bHQgZXh0cmFjdGlvbiBmdW5jdGlvbnMgZm9yIE1DUCBzZXJ2ZXIgaW5zdHJ1bWVudGF0aW9uXG4gKlxuICogSGFuZGxlcyBleHRyYWN0aW9uIG9mIGF0dHJpYnV0ZXMgZnJvbSB0b29sIGFuZCBwcm9tcHQgZXhlY3V0aW9uIHJlc3VsdHMuXG4gKi9cblxuXG4vKipcbiAqIEJ1aWxkIGF0dHJpYnV0ZXMgZm9yIHRvb2wgcmVzdWx0IGNvbnRlbnQgaXRlbXNcbiAqIEBwYXJhbSBjb250ZW50IC0gQXJyYXkgb2YgY29udGVudCBpdGVtcyBmcm9tIHRvb2wgcmVzdWx0XG4gKiBAcmV0dXJucyBBdHRyaWJ1dGVzIGV4dHJhY3RlZCBmcm9tIGVhY2ggY29udGVudCBpdGVtIGluY2x1ZGluZyB0eXBlLCB0ZXh0LCBtaW1lIHR5cGUsIFVSSSwgYW5kIHJlc291cmNlIGluZm9cbiAqL1xuZnVuY3Rpb24gYnVpbGRBbGxDb250ZW50SXRlbUF0dHJpYnV0ZXMoY29udGVudCkge1xuICBjb25zdCBhdHRyaWJ1dGVzJDEgPSB7XG4gICAgW2F0dHJpYnV0ZXMuTUNQX1RPT0xfUkVTVUxUX0NPTlRFTlRfQ09VTlRfQVRUUklCVVRFXTogY29udGVudC5sZW5ndGgsXG4gIH07XG5cbiAgZm9yIChjb25zdCBbaSwgaXRlbV0gb2YgY29udGVudC5lbnRyaWVzKCkpIHtcbiAgICBpZiAoIXZhbGlkYXRpb24uaXNWYWxpZENvbnRlbnRJdGVtKGl0ZW0pKSB7XG4gICAgICBjb250aW51ZTtcbiAgICB9XG5cbiAgICBjb25zdCBwcmVmaXggPSBjb250ZW50Lmxlbmd0aCA9PT0gMSA/ICdtY3AudG9vbC5yZXN1bHQnIDogYG1jcC50b29sLnJlc3VsdC4ke2l9YDtcblxuICAgIGNvbnN0IHNhZmVTZXQgPSAoa2V5LCB2YWx1ZSkgPT4ge1xuICAgICAgaWYgKHR5cGVvZiB2YWx1ZSA9PT0gJ3N0cmluZycpIHtcbiAgICAgICAgYXR0cmlidXRlcyQxW2Ake3ByZWZpeH0uJHtrZXl9YF0gPSB2YWx1ZTtcbiAgICAgIH1cbiAgICB9O1xuXG4gICAgc2FmZVNldCgnY29udGVudF90eXBlJywgaXRlbS50eXBlKTtcbiAgICBzYWZlU2V0KCdtaW1lX3R5cGUnLCBpdGVtLm1pbWVUeXBlKTtcbiAgICBzYWZlU2V0KCd1cmknLCBpdGVtLnVyaSk7XG4gICAgc2FmZVNldCgnbmFtZScsIGl0ZW0ubmFtZSk7XG5cbiAgICBpZiAodHlwZW9mIGl0ZW0udGV4dCA9PT0gJ3N0cmluZycpIHtcbiAgICAgIGF0dHJpYnV0ZXMkMVtgJHtwcmVmaXh9LmNvbnRlbnRgXSA9IGl0ZW0udGV4dDtcbiAgICB9XG5cbiAgICBpZiAodHlwZW9mIGl0ZW0uZGF0YSA9PT0gJ3N0cmluZycpIHtcbiAgICAgIGF0dHJpYnV0ZXMkMVtgJHtwcmVmaXh9LmRhdGFfc2l6ZWBdID0gaXRlbS5kYXRhLmxlbmd0aDtcbiAgICB9XG5cbiAgICBjb25zdCByZXNvdXJjZSA9IGl0ZW0ucmVzb3VyY2U7XG4gICAgaWYgKHZhbGlkYXRpb24uaXNWYWxpZENvbnRlbnRJdGVtKHJlc291cmNlKSkge1xuICAgICAgc2FmZVNldCgncmVzb3VyY2VfdXJpJywgcmVzb3VyY2UudXJpKTtcbiAgICAgIHNhZmVTZXQoJ3Jlc291cmNlX21pbWVfdHlwZScsIHJlc291cmNlLm1pbWVUeXBlKTtcbiAgICB9XG4gIH1cblxuICByZXR1cm4gYXR0cmlidXRlcyQxO1xufVxuXG4vKipcbiAqIEV4dHJhY3QgdG9vbCByZXN1bHQgYXR0cmlidXRlcyBmb3Igc3BhbiBpbnN0cnVtZW50YXRpb25cbiAqIEBwYXJhbSByZXN1bHQgLSBUb29sIGV4ZWN1dGlvbiByZXN1bHRcbiAqIEByZXR1cm5zIEF0dHJpYnV0ZXMgZXh0cmFjdGVkIGZyb20gdG9vbCByZXN1bHQgY29udGVudFxuICovXG5mdW5jdGlvbiBleHRyYWN0VG9vbFJlc3VsdEF0dHJpYnV0ZXMocmVzdWx0KSB7XG4gIGlmICghdmFsaWRhdGlvbi5pc1ZhbGlkQ29udGVudEl0ZW0ocmVzdWx0KSkge1xuICAgIHJldHVybiB7fTtcbiAgfVxuXG4gIGNvbnN0IGF0dHJpYnV0ZXMkMSA9IEFycmF5LmlzQXJyYXkocmVzdWx0LmNvbnRlbnQpID8gYnVpbGRBbGxDb250ZW50SXRlbUF0dHJpYnV0ZXMocmVzdWx0LmNvbnRlbnQpIDoge307XG5cbiAgaWYgKHR5cGVvZiByZXN1bHQuaXNFcnJvciA9PT0gJ2Jvb2xlYW4nKSB7XG4gICAgYXR0cmlidXRlcyQxW2F0dHJpYnV0ZXMuTUNQX1RPT0xfUkVTVUxUX0lTX0VSUk9SX0FUVFJJQlVURV0gPSByZXN1bHQuaXNFcnJvcjtcbiAgfVxuXG4gIHJldHVybiBhdHRyaWJ1dGVzJDE7XG59XG5cbi8qKlxuICogRXh0cmFjdCBwcm9tcHQgcmVzdWx0IGF0dHJpYnV0ZXMgZm9yIHNwYW4gaW5zdHJ1bWVudGF0aW9uXG4gKiBAcGFyYW0gcmVzdWx0IC0gUHJvbXB0IGV4ZWN1dGlvbiByZXN1bHRcbiAqIEByZXR1cm5zIEF0dHJpYnV0ZXMgZXh0cmFjdGVkIGZyb20gcHJvbXB0IHJlc3VsdFxuICovXG5mdW5jdGlvbiBleHRyYWN0UHJvbXB0UmVzdWx0QXR0cmlidXRlcyhyZXN1bHQpIHtcbiAgY29uc3QgYXR0cmlidXRlcyQxID0ge307XG4gIGlmICghdmFsaWRhdGlvbi5pc1ZhbGlkQ29udGVudEl0ZW0ocmVzdWx0KSkge1xuICAgIHJldHVybiBhdHRyaWJ1dGVzJDE7XG4gIH1cblxuICBpZiAodHlwZW9mIHJlc3VsdC5kZXNjcmlwdGlvbiA9PT0gJ3N0cmluZycpIHtcbiAgICBhdHRyaWJ1dGVzJDFbYXR0cmlidXRlcy5NQ1BfUFJPTVBUX1JFU1VMVF9ERVNDUklQVElPTl9BVFRSSUJVVEVdID0gcmVzdWx0LmRlc2NyaXB0aW9uO1xuICB9XG5cbiAgaWYgKEFycmF5LmlzQXJyYXkocmVzdWx0Lm1lc3NhZ2VzKSkge1xuICAgIGF0dHJpYnV0ZXMkMVthdHRyaWJ1dGVzLk1DUF9QUk9NUFRfUkVTVUxUX01FU1NBR0VfQ09VTlRfQVRUUklCVVRFXSA9IHJlc3VsdC5tZXNzYWdlcy5sZW5ndGg7XG5cbiAgICBjb25zdCBtZXNzYWdlcyA9IHJlc3VsdC5tZXNzYWdlcztcbiAgICBmb3IgKGNvbnN0IFtpLCBtZXNzYWdlXSBvZiBtZXNzYWdlcy5lbnRyaWVzKCkpIHtcbiAgICAgIGlmICghdmFsaWRhdGlvbi5pc1ZhbGlkQ29udGVudEl0ZW0obWVzc2FnZSkpIHtcbiAgICAgICAgY29udGludWU7XG4gICAgICB9XG5cbiAgICAgIGNvbnN0IHByZWZpeCA9IG1lc3NhZ2VzLmxlbmd0aCA9PT0gMSA/ICdtY3AucHJvbXB0LnJlc3VsdCcgOiBgbWNwLnByb21wdC5yZXN1bHQuJHtpfWA7XG5cbiAgICAgIGNvbnN0IHNhZmVTZXQgPSAoa2V5LCB2YWx1ZSkgPT4ge1xuICAgICAgICBpZiAodHlwZW9mIHZhbHVlID09PSAnc3RyaW5nJykge1xuICAgICAgICAgIGNvbnN0IGF0dHJOYW1lID0gbWVzc2FnZXMubGVuZ3RoID09PSAxID8gYCR7cHJlZml4fS5tZXNzYWdlXyR7a2V5fWAgOiBgJHtwcmVmaXh9LiR7a2V5fWA7XG4gICAgICAgICAgYXR0cmlidXRlcyQxW2F0dHJOYW1lXSA9IHZhbHVlO1xuICAgICAgICB9XG4gICAgICB9O1xuXG4gICAgICBzYWZlU2V0KCdyb2xlJywgbWVzc2FnZS5yb2xlKTtcblxuICAgICAgaWYgKHZhbGlkYXRpb24uaXNWYWxpZENvbnRlbnRJdGVtKG1lc3NhZ2UuY29udGVudCkpIHtcbiAgICAgICAgY29uc3QgY29udGVudCA9IG1lc3NhZ2UuY29udGVudDtcbiAgICAgICAgaWYgKHR5cGVvZiBjb250ZW50LnRleHQgPT09ICdzdHJpbmcnKSB7XG4gICAgICAgICAgY29uc3QgYXR0ck5hbWUgPSBtZXNzYWdlcy5sZW5ndGggPT09IDEgPyBgJHtwcmVmaXh9Lm1lc3NhZ2VfY29udGVudGAgOiBgJHtwcmVmaXh9LmNvbnRlbnRgO1xuICAgICAgICAgIGF0dHJpYnV0ZXMkMVthdHRyTmFtZV0gPSBjb250ZW50LnRleHQ7XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9XG4gIH1cblxuICByZXR1cm4gYXR0cmlidXRlcyQxO1xufVxuXG5leHBvcnRzLmV4dHJhY3RQcm9tcHRSZXN1bHRBdHRyaWJ1dGVzID0gZXh0cmFjdFByb21wdFJlc3VsdEF0dHJpYnV0ZXM7XG5leHBvcnRzLmV4dHJhY3RUb29sUmVzdWx0QXR0cmlidXRlcyA9IGV4dHJhY3RUb29sUmVzdWx0QXR0cmlidXRlcztcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPXJlc3VsdEV4dHJhY3Rpb24uanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/resultExtraction.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/sessionExtraction.js":
/*!*********************************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/sessionExtraction.js ***!
  \*********************************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst attributes = __webpack_require__(/*! ./attributes.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/attributes.js\");\nconst sessionManagement = __webpack_require__(/*! ./sessionManagement.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/sessionManagement.js\");\nconst validation = __webpack_require__(/*! ./validation.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/validation.js\");\n\n/**\n * Session and party info extraction functions for MCP server instrumentation\n *\n * Handles extraction of client/server info and session data from MCP messages.\n */\n\n\n/**\n * Extracts and validates PartyInfo from an unknown object\n * @param obj - Unknown object that might contain party info\n * @returns Validated PartyInfo object with only string properties\n */\nfunction extractPartyInfo(obj) {\n  const partyInfo = {};\n\n  if (validation.isValidContentItem(obj)) {\n    if (typeof obj.name === 'string') {\n      partyInfo.name = obj.name;\n    }\n    if (typeof obj.title === 'string') {\n      partyInfo.title = obj.title;\n    }\n    if (typeof obj.version === 'string') {\n      partyInfo.version = obj.version;\n    }\n  }\n\n  return partyInfo;\n}\n\n/**\n * Extracts session data from \"initialize\" requests\n * @param request - JSON-RPC \"initialize\" request containing client info and protocol version\n * @returns Session data extracted from request parameters including protocol version and client info\n */\nfunction extractSessionDataFromInitializeRequest(request) {\n  const sessionData = {};\n  if (validation.isValidContentItem(request.params)) {\n    if (typeof request.params.protocolVersion === 'string') {\n      sessionData.protocolVersion = request.params.protocolVersion;\n    }\n    if (request.params.clientInfo) {\n      sessionData.clientInfo = extractPartyInfo(request.params.clientInfo);\n    }\n  }\n  return sessionData;\n}\n\n/**\n * Extracts session data from \"initialize\" response\n * @param result - \"initialize\" response result containing server info and protocol version\n * @returns Partial session data extracted from response including protocol version and server info\n */\nfunction extractSessionDataFromInitializeResponse(result) {\n  const sessionData = {};\n  if (validation.isValidContentItem(result)) {\n    if (typeof result.protocolVersion === 'string') {\n      sessionData.protocolVersion = result.protocolVersion;\n    }\n    if (result.serverInfo) {\n      sessionData.serverInfo = extractPartyInfo(result.serverInfo);\n    }\n  }\n  return sessionData;\n}\n\n/**\n * Build client attributes from stored client info\n * @param transport - MCP transport instance\n * @returns Client attributes for span instrumentation\n */\nfunction getClientAttributes(transport) {\n  const clientInfo = sessionManagement.getClientInfoForTransport(transport);\n  const attributes = {};\n\n  if (clientInfo?.name) {\n    attributes['mcp.client.name'] = clientInfo.name;\n  }\n  if (clientInfo?.title) {\n    attributes['mcp.client.title'] = clientInfo.title;\n  }\n  if (clientInfo?.version) {\n    attributes['mcp.client.version'] = clientInfo.version;\n  }\n\n  return attributes;\n}\n\n/**\n * Build server attributes from stored server info\n * @param transport - MCP transport instance\n * @returns Server attributes for span instrumentation\n */\nfunction getServerAttributes(transport) {\n  const serverInfo = sessionManagement.getSessionDataForTransport(transport)?.serverInfo;\n  const attributes$1 = {};\n\n  if (serverInfo?.name) {\n    attributes$1[attributes.MCP_SERVER_NAME_ATTRIBUTE] = serverInfo.name;\n  }\n  if (serverInfo?.title) {\n    attributes$1[attributes.MCP_SERVER_TITLE_ATTRIBUTE] = serverInfo.title;\n  }\n  if (serverInfo?.version) {\n    attributes$1[attributes.MCP_SERVER_VERSION_ATTRIBUTE] = serverInfo.version;\n  }\n\n  return attributes$1;\n}\n\n/**\n * Extracts client connection info from extra handler data\n * @param extra - Extra handler data containing connection info\n * @returns Client address and port information\n */\nfunction extractClientInfo(extra)\n\n {\n  return {\n    address:\n      extra?.requestInfo?.remoteAddress ||\n      extra?.clientAddress ||\n      extra?.request?.ip ||\n      extra?.request?.connection?.remoteAddress,\n    port: extra?.requestInfo?.remotePort || extra?.clientPort || extra?.request?.connection?.remotePort,\n  };\n}\n\n/**\n * Extracts transport types based on transport constructor name\n * @param transport - MCP transport instance\n * @returns Transport type mapping for span attributes\n */\nfunction getTransportTypes(transport) {\n  const transportName = transport.constructor?.name?.toLowerCase() || '';\n\n  if (transportName.includes('stdio')) {\n    return { mcpTransport: 'stdio', networkTransport: 'pipe' };\n  }\n\n  if (transportName.includes('streamablehttp') || transportName.includes('streamable')) {\n    return { mcpTransport: 'http', networkTransport: 'tcp' };\n  }\n\n  if (transportName.includes('sse')) {\n    return { mcpTransport: 'sse', networkTransport: 'tcp' };\n  }\n\n  return { mcpTransport: 'unknown', networkTransport: 'unknown' };\n}\n\n/**\n * Build transport and network attributes\n * @param transport - MCP transport instance\n * @param extra - Optional extra handler data\n * @returns Transport attributes for span instrumentation\n */\nfunction buildTransportAttributes(\n  transport,\n  extra,\n) {\n  const sessionId = transport.sessionId;\n  const clientInfo = extra ? extractClientInfo(extra) : {};\n  const { mcpTransport, networkTransport } = getTransportTypes(transport);\n  const clientAttributes = getClientAttributes(transport);\n  const serverAttributes = getServerAttributes(transport);\n  const protocolVersion = sessionManagement.getProtocolVersionForTransport(transport);\n\n  const attributes$1 = {\n    ...(sessionId && { [attributes.MCP_SESSION_ID_ATTRIBUTE]: sessionId }),\n    ...(clientInfo.address && { [attributes.CLIENT_ADDRESS_ATTRIBUTE]: clientInfo.address }),\n    ...(clientInfo.port && { [attributes.CLIENT_PORT_ATTRIBUTE]: clientInfo.port }),\n    [attributes.MCP_TRANSPORT_ATTRIBUTE]: mcpTransport,\n    [attributes.NETWORK_TRANSPORT_ATTRIBUTE]: networkTransport,\n    [attributes.NETWORK_PROTOCOL_VERSION_ATTRIBUTE]: '2.0',\n    ...(protocolVersion && { [attributes.MCP_PROTOCOL_VERSION_ATTRIBUTE]: protocolVersion }),\n    ...clientAttributes,\n    ...serverAttributes,\n  };\n\n  return attributes$1;\n}\n\nexports.buildTransportAttributes = buildTransportAttributes;\nexports.extractClientInfo = extractClientInfo;\nexports.extractSessionDataFromInitializeRequest = extractSessionDataFromInitializeRequest;\nexports.extractSessionDataFromInitializeResponse = extractSessionDataFromInitializeResponse;\nexports.getClientAttributes = getClientAttributes;\nexports.getServerAttributes = getServerAttributes;\nexports.getTransportTypes = getTransportTypes;\n//# sourceMappingURL=sessionExtraction.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvbWNwLXNlcnZlci9zZXNzaW9uRXh0cmFjdGlvbi5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxtQkFBbUIsbUJBQU8sQ0FBQyxpSkFBaUI7QUFDNUMsMEJBQTBCLG1CQUFPLENBQUMsK0pBQXdCO0FBQzFELG1CQUFtQixtQkFBTyxDQUFDLGlKQUFpQjs7QUFFNUM7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7O0FBR0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0EsYUFBYTtBQUNiOztBQUVBO0FBQ0EsYUFBYTtBQUNiOztBQUVBO0FBQ0EsYUFBYTtBQUNiOztBQUVBLFdBQVc7QUFDWDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxVQUFVLGlDQUFpQztBQUMzQztBQUNBO0FBQ0E7O0FBRUE7QUFDQSx1QkFBdUIsa0RBQWtEO0FBQ3pFLGdDQUFnQywyREFBMkQ7QUFDM0YsNkJBQTZCLHFEQUFxRDtBQUNsRjtBQUNBO0FBQ0E7QUFDQSw2QkFBNkIsOERBQThEO0FBQzNGO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBLGdDQUFnQztBQUNoQyx5QkFBeUI7QUFDekIsK0NBQStDO0FBQy9DLGdEQUFnRDtBQUNoRCwyQkFBMkI7QUFDM0IsMkJBQTJCO0FBQzNCLHlCQUF5QjtBQUN6QiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL2ludGVncmF0aW9ucy9tY3Atc2VydmVyL3Nlc3Npb25FeHRyYWN0aW9uLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBhdHRyaWJ1dGVzID0gcmVxdWlyZSgnLi9hdHRyaWJ1dGVzLmpzJyk7XG5jb25zdCBzZXNzaW9uTWFuYWdlbWVudCA9IHJlcXVpcmUoJy4vc2Vzc2lvbk1hbmFnZW1lbnQuanMnKTtcbmNvbnN0IHZhbGlkYXRpb24gPSByZXF1aXJlKCcuL3ZhbGlkYXRpb24uanMnKTtcblxuLyoqXG4gKiBTZXNzaW9uIGFuZCBwYXJ0eSBpbmZvIGV4dHJhY3Rpb24gZnVuY3Rpb25zIGZvciBNQ1Agc2VydmVyIGluc3RydW1lbnRhdGlvblxuICpcbiAqIEhhbmRsZXMgZXh0cmFjdGlvbiBvZiBjbGllbnQvc2VydmVyIGluZm8gYW5kIHNlc3Npb24gZGF0YSBmcm9tIE1DUCBtZXNzYWdlcy5cbiAqL1xuXG5cbi8qKlxuICogRXh0cmFjdHMgYW5kIHZhbGlkYXRlcyBQYXJ0eUluZm8gZnJvbSBhbiB1bmtub3duIG9iamVjdFxuICogQHBhcmFtIG9iaiAtIFVua25vd24gb2JqZWN0IHRoYXQgbWlnaHQgY29udGFpbiBwYXJ0eSBpbmZvXG4gKiBAcmV0dXJucyBWYWxpZGF0ZWQgUGFydHlJbmZvIG9iamVjdCB3aXRoIG9ubHkgc3RyaW5nIHByb3BlcnRpZXNcbiAqL1xuZnVuY3Rpb24gZXh0cmFjdFBhcnR5SW5mbyhvYmopIHtcbiAgY29uc3QgcGFydHlJbmZvID0ge307XG5cbiAgaWYgKHZhbGlkYXRpb24uaXNWYWxpZENvbnRlbnRJdGVtKG9iaikpIHtcbiAgICBpZiAodHlwZW9mIG9iai5uYW1lID09PSAnc3RyaW5nJykge1xuICAgICAgcGFydHlJbmZvLm5hbWUgPSBvYmoubmFtZTtcbiAgICB9XG4gICAgaWYgKHR5cGVvZiBvYmoudGl0bGUgPT09ICdzdHJpbmcnKSB7XG4gICAgICBwYXJ0eUluZm8udGl0bGUgPSBvYmoudGl0bGU7XG4gICAgfVxuICAgIGlmICh0eXBlb2Ygb2JqLnZlcnNpb24gPT09ICdzdHJpbmcnKSB7XG4gICAgICBwYXJ0eUluZm8udmVyc2lvbiA9IG9iai52ZXJzaW9uO1xuICAgIH1cbiAgfVxuXG4gIHJldHVybiBwYXJ0eUluZm87XG59XG5cbi8qKlxuICogRXh0cmFjdHMgc2Vzc2lvbiBkYXRhIGZyb20gXCJpbml0aWFsaXplXCIgcmVxdWVzdHNcbiAqIEBwYXJhbSByZXF1ZXN0IC0gSlNPTi1SUEMgXCJpbml0aWFsaXplXCIgcmVxdWVzdCBjb250YWluaW5nIGNsaWVudCBpbmZvIGFuZCBwcm90b2NvbCB2ZXJzaW9uXG4gKiBAcmV0dXJucyBTZXNzaW9uIGRhdGEgZXh0cmFjdGVkIGZyb20gcmVxdWVzdCBwYXJhbWV0ZXJzIGluY2x1ZGluZyBwcm90b2NvbCB2ZXJzaW9uIGFuZCBjbGllbnQgaW5mb1xuICovXG5mdW5jdGlvbiBleHRyYWN0U2Vzc2lvbkRhdGFGcm9tSW5pdGlhbGl6ZVJlcXVlc3QocmVxdWVzdCkge1xuICBjb25zdCBzZXNzaW9uRGF0YSA9IHt9O1xuICBpZiAodmFsaWRhdGlvbi5pc1ZhbGlkQ29udGVudEl0ZW0ocmVxdWVzdC5wYXJhbXMpKSB7XG4gICAgaWYgKHR5cGVvZiByZXF1ZXN0LnBhcmFtcy5wcm90b2NvbFZlcnNpb24gPT09ICdzdHJpbmcnKSB7XG4gICAgICBzZXNzaW9uRGF0YS5wcm90b2NvbFZlcnNpb24gPSByZXF1ZXN0LnBhcmFtcy5wcm90b2NvbFZlcnNpb247XG4gICAgfVxuICAgIGlmIChyZXF1ZXN0LnBhcmFtcy5jbGllbnRJbmZvKSB7XG4gICAgICBzZXNzaW9uRGF0YS5jbGllbnRJbmZvID0gZXh0cmFjdFBhcnR5SW5mbyhyZXF1ZXN0LnBhcmFtcy5jbGllbnRJbmZvKTtcbiAgICB9XG4gIH1cbiAgcmV0dXJuIHNlc3Npb25EYXRhO1xufVxuXG4vKipcbiAqIEV4dHJhY3RzIHNlc3Npb24gZGF0YSBmcm9tIFwiaW5pdGlhbGl6ZVwiIHJlc3BvbnNlXG4gKiBAcGFyYW0gcmVzdWx0IC0gXCJpbml0aWFsaXplXCIgcmVzcG9uc2UgcmVzdWx0IGNvbnRhaW5pbmcgc2VydmVyIGluZm8gYW5kIHByb3RvY29sIHZlcnNpb25cbiAqIEByZXR1cm5zIFBhcnRpYWwgc2Vzc2lvbiBkYXRhIGV4dHJhY3RlZCBmcm9tIHJlc3BvbnNlIGluY2x1ZGluZyBwcm90b2NvbCB2ZXJzaW9uIGFuZCBzZXJ2ZXIgaW5mb1xuICovXG5mdW5jdGlvbiBleHRyYWN0U2Vzc2lvbkRhdGFGcm9tSW5pdGlhbGl6ZVJlc3BvbnNlKHJlc3VsdCkge1xuICBjb25zdCBzZXNzaW9uRGF0YSA9IHt9O1xuICBpZiAodmFsaWRhdGlvbi5pc1ZhbGlkQ29udGVudEl0ZW0ocmVzdWx0KSkge1xuICAgIGlmICh0eXBlb2YgcmVzdWx0LnByb3RvY29sVmVyc2lvbiA9PT0gJ3N0cmluZycpIHtcbiAgICAgIHNlc3Npb25EYXRhLnByb3RvY29sVmVyc2lvbiA9IHJlc3VsdC5wcm90b2NvbFZlcnNpb247XG4gICAgfVxuICAgIGlmIChyZXN1bHQuc2VydmVySW5mbykge1xuICAgICAgc2Vzc2lvbkRhdGEuc2VydmVySW5mbyA9IGV4dHJhY3RQYXJ0eUluZm8ocmVzdWx0LnNlcnZlckluZm8pO1xuICAgIH1cbiAgfVxuICByZXR1cm4gc2Vzc2lvbkRhdGE7XG59XG5cbi8qKlxuICogQnVpbGQgY2xpZW50IGF0dHJpYnV0ZXMgZnJvbSBzdG9yZWQgY2xpZW50IGluZm9cbiAqIEBwYXJhbSB0cmFuc3BvcnQgLSBNQ1AgdHJhbnNwb3J0IGluc3RhbmNlXG4gKiBAcmV0dXJucyBDbGllbnQgYXR0cmlidXRlcyBmb3Igc3BhbiBpbnN0cnVtZW50YXRpb25cbiAqL1xuZnVuY3Rpb24gZ2V0Q2xpZW50QXR0cmlidXRlcyh0cmFuc3BvcnQpIHtcbiAgY29uc3QgY2xpZW50SW5mbyA9IHNlc3Npb25NYW5hZ2VtZW50LmdldENsaWVudEluZm9Gb3JUcmFuc3BvcnQodHJhbnNwb3J0KTtcbiAgY29uc3QgYXR0cmlidXRlcyA9IHt9O1xuXG4gIGlmIChjbGllbnRJbmZvPy5uYW1lKSB7XG4gICAgYXR0cmlidXRlc1snbWNwLmNsaWVudC5uYW1lJ10gPSBjbGllbnRJbmZvLm5hbWU7XG4gIH1cbiAgaWYgKGNsaWVudEluZm8/LnRpdGxlKSB7XG4gICAgYXR0cmlidXRlc1snbWNwLmNsaWVudC50aXRsZSddID0gY2xpZW50SW5mby50aXRsZTtcbiAgfVxuICBpZiAoY2xpZW50SW5mbz8udmVyc2lvbikge1xuICAgIGF0dHJpYnV0ZXNbJ21jcC5jbGllbnQudmVyc2lvbiddID0gY2xpZW50SW5mby52ZXJzaW9uO1xuICB9XG5cbiAgcmV0dXJuIGF0dHJpYnV0ZXM7XG59XG5cbi8qKlxuICogQnVpbGQgc2VydmVyIGF0dHJpYnV0ZXMgZnJvbSBzdG9yZWQgc2VydmVyIGluZm9cbiAqIEBwYXJhbSB0cmFuc3BvcnQgLSBNQ1AgdHJhbnNwb3J0IGluc3RhbmNlXG4gKiBAcmV0dXJucyBTZXJ2ZXIgYXR0cmlidXRlcyBmb3Igc3BhbiBpbnN0cnVtZW50YXRpb25cbiAqL1xuZnVuY3Rpb24gZ2V0U2VydmVyQXR0cmlidXRlcyh0cmFuc3BvcnQpIHtcbiAgY29uc3Qgc2VydmVySW5mbyA9IHNlc3Npb25NYW5hZ2VtZW50LmdldFNlc3Npb25EYXRhRm9yVHJhbnNwb3J0KHRyYW5zcG9ydCk/LnNlcnZlckluZm87XG4gIGNvbnN0IGF0dHJpYnV0ZXMkMSA9IHt9O1xuXG4gIGlmIChzZXJ2ZXJJbmZvPy5uYW1lKSB7XG4gICAgYXR0cmlidXRlcyQxW2F0dHJpYnV0ZXMuTUNQX1NFUlZFUl9OQU1FX0FUVFJJQlVURV0gPSBzZXJ2ZXJJbmZvLm5hbWU7XG4gIH1cbiAgaWYgKHNlcnZlckluZm8/LnRpdGxlKSB7XG4gICAgYXR0cmlidXRlcyQxW2F0dHJpYnV0ZXMuTUNQX1NFUlZFUl9USVRMRV9BVFRSSUJVVEVdID0gc2VydmVySW5mby50aXRsZTtcbiAgfVxuICBpZiAoc2VydmVySW5mbz8udmVyc2lvbikge1xuICAgIGF0dHJpYnV0ZXMkMVthdHRyaWJ1dGVzLk1DUF9TRVJWRVJfVkVSU0lPTl9BVFRSSUJVVEVdID0gc2VydmVySW5mby52ZXJzaW9uO1xuICB9XG5cbiAgcmV0dXJuIGF0dHJpYnV0ZXMkMTtcbn1cblxuLyoqXG4gKiBFeHRyYWN0cyBjbGllbnQgY29ubmVjdGlvbiBpbmZvIGZyb20gZXh0cmEgaGFuZGxlciBkYXRhXG4gKiBAcGFyYW0gZXh0cmEgLSBFeHRyYSBoYW5kbGVyIGRhdGEgY29udGFpbmluZyBjb25uZWN0aW9uIGluZm9cbiAqIEByZXR1cm5zIENsaWVudCBhZGRyZXNzIGFuZCBwb3J0IGluZm9ybWF0aW9uXG4gKi9cbmZ1bmN0aW9uIGV4dHJhY3RDbGllbnRJbmZvKGV4dHJhKVxuXG4ge1xuICByZXR1cm4ge1xuICAgIGFkZHJlc3M6XG4gICAgICBleHRyYT8ucmVxdWVzdEluZm8/LnJlbW90ZUFkZHJlc3MgfHxcbiAgICAgIGV4dHJhPy5jbGllbnRBZGRyZXNzIHx8XG4gICAgICBleHRyYT8ucmVxdWVzdD8uaXAgfHxcbiAgICAgIGV4dHJhPy5yZXF1ZXN0Py5jb25uZWN0aW9uPy5yZW1vdGVBZGRyZXNzLFxuICAgIHBvcnQ6IGV4dHJhPy5yZXF1ZXN0SW5mbz8ucmVtb3RlUG9ydCB8fCBleHRyYT8uY2xpZW50UG9ydCB8fCBleHRyYT8ucmVxdWVzdD8uY29ubmVjdGlvbj8ucmVtb3RlUG9ydCxcbiAgfTtcbn1cblxuLyoqXG4gKiBFeHRyYWN0cyB0cmFuc3BvcnQgdHlwZXMgYmFzZWQgb24gdHJhbnNwb3J0IGNvbnN0cnVjdG9yIG5hbWVcbiAqIEBwYXJhbSB0cmFuc3BvcnQgLSBNQ1AgdHJhbnNwb3J0IGluc3RhbmNlXG4gKiBAcmV0dXJucyBUcmFuc3BvcnQgdHlwZSBtYXBwaW5nIGZvciBzcGFuIGF0dHJpYnV0ZXNcbiAqL1xuZnVuY3Rpb24gZ2V0VHJhbnNwb3J0VHlwZXModHJhbnNwb3J0KSB7XG4gIGNvbnN0IHRyYW5zcG9ydE5hbWUgPSB0cmFuc3BvcnQuY29uc3RydWN0b3I/Lm5hbWU/LnRvTG93ZXJDYXNlKCkgfHwgJyc7XG5cbiAgaWYgKHRyYW5zcG9ydE5hbWUuaW5jbHVkZXMoJ3N0ZGlvJykpIHtcbiAgICByZXR1cm4geyBtY3BUcmFuc3BvcnQ6ICdzdGRpbycsIG5ldHdvcmtUcmFuc3BvcnQ6ICdwaXBlJyB9O1xuICB9XG5cbiAgaWYgKHRyYW5zcG9ydE5hbWUuaW5jbHVkZXMoJ3N0cmVhbWFibGVodHRwJykgfHwgdHJhbnNwb3J0TmFtZS5pbmNsdWRlcygnc3RyZWFtYWJsZScpKSB7XG4gICAgcmV0dXJuIHsgbWNwVHJhbnNwb3J0OiAnaHR0cCcsIG5ldHdvcmtUcmFuc3BvcnQ6ICd0Y3AnIH07XG4gIH1cblxuICBpZiAodHJhbnNwb3J0TmFtZS5pbmNsdWRlcygnc3NlJykpIHtcbiAgICByZXR1cm4geyBtY3BUcmFuc3BvcnQ6ICdzc2UnLCBuZXR3b3JrVHJhbnNwb3J0OiAndGNwJyB9O1xuICB9XG5cbiAgcmV0dXJuIHsgbWNwVHJhbnNwb3J0OiAndW5rbm93bicsIG5ldHdvcmtUcmFuc3BvcnQ6ICd1bmtub3duJyB9O1xufVxuXG4vKipcbiAqIEJ1aWxkIHRyYW5zcG9ydCBhbmQgbmV0d29yayBhdHRyaWJ1dGVzXG4gKiBAcGFyYW0gdHJhbnNwb3J0IC0gTUNQIHRyYW5zcG9ydCBpbnN0YW5jZVxuICogQHBhcmFtIGV4dHJhIC0gT3B0aW9uYWwgZXh0cmEgaGFuZGxlciBkYXRhXG4gKiBAcmV0dXJucyBUcmFuc3BvcnQgYXR0cmlidXRlcyBmb3Igc3BhbiBpbnN0cnVtZW50YXRpb25cbiAqL1xuZnVuY3Rpb24gYnVpbGRUcmFuc3BvcnRBdHRyaWJ1dGVzKFxuICB0cmFuc3BvcnQsXG4gIGV4dHJhLFxuKSB7XG4gIGNvbnN0IHNlc3Npb25JZCA9IHRyYW5zcG9ydC5zZXNzaW9uSWQ7XG4gIGNvbnN0IGNsaWVudEluZm8gPSBleHRyYSA/IGV4dHJhY3RDbGllbnRJbmZvKGV4dHJhKSA6IHt9O1xuICBjb25zdCB7IG1jcFRyYW5zcG9ydCwgbmV0d29ya1RyYW5zcG9ydCB9ID0gZ2V0VHJhbnNwb3J0VHlwZXModHJhbnNwb3J0KTtcbiAgY29uc3QgY2xpZW50QXR0cmlidXRlcyA9IGdldENsaWVudEF0dHJpYnV0ZXModHJhbnNwb3J0KTtcbiAgY29uc3Qgc2VydmVyQXR0cmlidXRlcyA9IGdldFNlcnZlckF0dHJpYnV0ZXModHJhbnNwb3J0KTtcbiAgY29uc3QgcHJvdG9jb2xWZXJzaW9uID0gc2Vzc2lvbk1hbmFnZW1lbnQuZ2V0UHJvdG9jb2xWZXJzaW9uRm9yVHJhbnNwb3J0KHRyYW5zcG9ydCk7XG5cbiAgY29uc3QgYXR0cmlidXRlcyQxID0ge1xuICAgIC4uLihzZXNzaW9uSWQgJiYgeyBbYXR0cmlidXRlcy5NQ1BfU0VTU0lPTl9JRF9BVFRSSUJVVEVdOiBzZXNzaW9uSWQgfSksXG4gICAgLi4uKGNsaWVudEluZm8uYWRkcmVzcyAmJiB7IFthdHRyaWJ1dGVzLkNMSUVOVF9BRERSRVNTX0FUVFJJQlVURV06IGNsaWVudEluZm8uYWRkcmVzcyB9KSxcbiAgICAuLi4oY2xpZW50SW5mby5wb3J0ICYmIHsgW2F0dHJpYnV0ZXMuQ0xJRU5UX1BPUlRfQVRUUklCVVRFXTogY2xpZW50SW5mby5wb3J0IH0pLFxuICAgIFthdHRyaWJ1dGVzLk1DUF9UUkFOU1BPUlRfQVRUUklCVVRFXTogbWNwVHJhbnNwb3J0LFxuICAgIFthdHRyaWJ1dGVzLk5FVFdPUktfVFJBTlNQT1JUX0FUVFJJQlVURV06IG5ldHdvcmtUcmFuc3BvcnQsXG4gICAgW2F0dHJpYnV0ZXMuTkVUV09SS19QUk9UT0NPTF9WRVJTSU9OX0FUVFJJQlVURV06ICcyLjAnLFxuICAgIC4uLihwcm90b2NvbFZlcnNpb24gJiYgeyBbYXR0cmlidXRlcy5NQ1BfUFJPVE9DT0xfVkVSU0lPTl9BVFRSSUJVVEVdOiBwcm90b2NvbFZlcnNpb24gfSksXG4gICAgLi4uY2xpZW50QXR0cmlidXRlcyxcbiAgICAuLi5zZXJ2ZXJBdHRyaWJ1dGVzLFxuICB9O1xuXG4gIHJldHVybiBhdHRyaWJ1dGVzJDE7XG59XG5cbmV4cG9ydHMuYnVpbGRUcmFuc3BvcnRBdHRyaWJ1dGVzID0gYnVpbGRUcmFuc3BvcnRBdHRyaWJ1dGVzO1xuZXhwb3J0cy5leHRyYWN0Q2xpZW50SW5mbyA9IGV4dHJhY3RDbGllbnRJbmZvO1xuZXhwb3J0cy5leHRyYWN0U2Vzc2lvbkRhdGFGcm9tSW5pdGlhbGl6ZVJlcXVlc3QgPSBleHRyYWN0U2Vzc2lvbkRhdGFGcm9tSW5pdGlhbGl6ZVJlcXVlc3Q7XG5leHBvcnRzLmV4dHJhY3RTZXNzaW9uRGF0YUZyb21Jbml0aWFsaXplUmVzcG9uc2UgPSBleHRyYWN0U2Vzc2lvbkRhdGFGcm9tSW5pdGlhbGl6ZVJlc3BvbnNlO1xuZXhwb3J0cy5nZXRDbGllbnRBdHRyaWJ1dGVzID0gZ2V0Q2xpZW50QXR0cmlidXRlcztcbmV4cG9ydHMuZ2V0U2VydmVyQXR0cmlidXRlcyA9IGdldFNlcnZlckF0dHJpYnV0ZXM7XG5leHBvcnRzLmdldFRyYW5zcG9ydFR5cGVzID0gZ2V0VHJhbnNwb3J0VHlwZXM7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1zZXNzaW9uRXh0cmFjdGlvbi5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/sessionExtraction.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/sessionManagement.js":
/*!*********************************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/sessionManagement.js ***!
  \*********************************************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n/**\n * Transport-scoped session data storage (only for transports with sessionId)\n * @internal Maps transport instances to session-level data\n */\nconst transportToSessionData = new WeakMap();\n\n/**\n * Stores session data for a transport with sessionId\n * @param transport - MCP transport instance\n * @param sessionData - Session data to store\n */\nfunction storeSessionDataForTransport(transport, sessionData) {\n  if (transport.sessionId) {\n    transportToSessionData.set(transport, sessionData);\n  }\n}\n\n/**\n * Updates session data for a transport with sessionId (merges with existing data)\n * @param transport - MCP transport instance\n * @param partialSessionData - Partial session data to merge with existing data\n */\nfunction updateSessionDataForTransport(transport, partialSessionData) {\n  if (transport.sessionId) {\n    const existingData = transportToSessionData.get(transport) || {};\n    transportToSessionData.set(transport, { ...existingData, ...partialSessionData });\n  }\n}\n\n/**\n * Retrieves client information for a transport\n * @param transport - MCP transport instance\n * @returns Client information if available\n */\nfunction getClientInfoForTransport(transport) {\n  return transportToSessionData.get(transport)?.clientInfo;\n}\n\n/**\n * Retrieves protocol version for a transport\n * @param transport - MCP transport instance\n * @returns Protocol version if available\n */\nfunction getProtocolVersionForTransport(transport) {\n  return transportToSessionData.get(transport)?.protocolVersion;\n}\n\n/**\n * Retrieves full session data for a transport\n * @param transport - MCP transport instance\n * @returns Complete session data if available\n */\nfunction getSessionDataForTransport(transport) {\n  return transportToSessionData.get(transport);\n}\n\n/**\n * Cleans up session data for a specific transport (when that transport closes)\n * @param transport - MCP transport instance\n */\nfunction cleanupSessionDataForTransport(transport) {\n  transportToSessionData.delete(transport);\n}\n\nexports.cleanupSessionDataForTransport = cleanupSessionDataForTransport;\nexports.getClientInfoForTransport = getClientInfoForTransport;\nexports.getProtocolVersionForTransport = getProtocolVersionForTransport;\nexports.getSessionDataForTransport = getSessionDataForTransport;\nexports.storeSessionDataForTransport = storeSessionDataForTransport;\nexports.updateSessionDataForTransport = updateSessionDataForTransport;\n//# sourceMappingURL=sessionManagement.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvbWNwLXNlcnZlci9zZXNzaW9uTWFuYWdlbWVudC5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSw0Q0FBNEMsd0NBQXdDO0FBQ3BGO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsc0NBQXNDO0FBQ3RDLGlDQUFpQztBQUNqQyxzQ0FBc0M7QUFDdEMsa0NBQWtDO0FBQ2xDLG9DQUFvQztBQUNwQyxxQ0FBcUM7QUFDckMiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvbWNwLXNlcnZlci9zZXNzaW9uTWFuYWdlbWVudC5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuLyoqXG4gKiBUcmFuc3BvcnQtc2NvcGVkIHNlc3Npb24gZGF0YSBzdG9yYWdlIChvbmx5IGZvciB0cmFuc3BvcnRzIHdpdGggc2Vzc2lvbklkKVxuICogQGludGVybmFsIE1hcHMgdHJhbnNwb3J0IGluc3RhbmNlcyB0byBzZXNzaW9uLWxldmVsIGRhdGFcbiAqL1xuY29uc3QgdHJhbnNwb3J0VG9TZXNzaW9uRGF0YSA9IG5ldyBXZWFrTWFwKCk7XG5cbi8qKlxuICogU3RvcmVzIHNlc3Npb24gZGF0YSBmb3IgYSB0cmFuc3BvcnQgd2l0aCBzZXNzaW9uSWRcbiAqIEBwYXJhbSB0cmFuc3BvcnQgLSBNQ1AgdHJhbnNwb3J0IGluc3RhbmNlXG4gKiBAcGFyYW0gc2Vzc2lvbkRhdGEgLSBTZXNzaW9uIGRhdGEgdG8gc3RvcmVcbiAqL1xuZnVuY3Rpb24gc3RvcmVTZXNzaW9uRGF0YUZvclRyYW5zcG9ydCh0cmFuc3BvcnQsIHNlc3Npb25EYXRhKSB7XG4gIGlmICh0cmFuc3BvcnQuc2Vzc2lvbklkKSB7XG4gICAgdHJhbnNwb3J0VG9TZXNzaW9uRGF0YS5zZXQodHJhbnNwb3J0LCBzZXNzaW9uRGF0YSk7XG4gIH1cbn1cblxuLyoqXG4gKiBVcGRhdGVzIHNlc3Npb24gZGF0YSBmb3IgYSB0cmFuc3BvcnQgd2l0aCBzZXNzaW9uSWQgKG1lcmdlcyB3aXRoIGV4aXN0aW5nIGRhdGEpXG4gKiBAcGFyYW0gdHJhbnNwb3J0IC0gTUNQIHRyYW5zcG9ydCBpbnN0YW5jZVxuICogQHBhcmFtIHBhcnRpYWxTZXNzaW9uRGF0YSAtIFBhcnRpYWwgc2Vzc2lvbiBkYXRhIHRvIG1lcmdlIHdpdGggZXhpc3RpbmcgZGF0YVxuICovXG5mdW5jdGlvbiB1cGRhdGVTZXNzaW9uRGF0YUZvclRyYW5zcG9ydCh0cmFuc3BvcnQsIHBhcnRpYWxTZXNzaW9uRGF0YSkge1xuICBpZiAodHJhbnNwb3J0LnNlc3Npb25JZCkge1xuICAgIGNvbnN0IGV4aXN0aW5nRGF0YSA9IHRyYW5zcG9ydFRvU2Vzc2lvbkRhdGEuZ2V0KHRyYW5zcG9ydCkgfHwge307XG4gICAgdHJhbnNwb3J0VG9TZXNzaW9uRGF0YS5zZXQodHJhbnNwb3J0LCB7IC4uLmV4aXN0aW5nRGF0YSwgLi4ucGFydGlhbFNlc3Npb25EYXRhIH0pO1xuICB9XG59XG5cbi8qKlxuICogUmV0cmlldmVzIGNsaWVudCBpbmZvcm1hdGlvbiBmb3IgYSB0cmFuc3BvcnRcbiAqIEBwYXJhbSB0cmFuc3BvcnQgLSBNQ1AgdHJhbnNwb3J0IGluc3RhbmNlXG4gKiBAcmV0dXJucyBDbGllbnQgaW5mb3JtYXRpb24gaWYgYXZhaWxhYmxlXG4gKi9cbmZ1bmN0aW9uIGdldENsaWVudEluZm9Gb3JUcmFuc3BvcnQodHJhbnNwb3J0KSB7XG4gIHJldHVybiB0cmFuc3BvcnRUb1Nlc3Npb25EYXRhLmdldCh0cmFuc3BvcnQpPy5jbGllbnRJbmZvO1xufVxuXG4vKipcbiAqIFJldHJpZXZlcyBwcm90b2NvbCB2ZXJzaW9uIGZvciBhIHRyYW5zcG9ydFxuICogQHBhcmFtIHRyYW5zcG9ydCAtIE1DUCB0cmFuc3BvcnQgaW5zdGFuY2VcbiAqIEByZXR1cm5zIFByb3RvY29sIHZlcnNpb24gaWYgYXZhaWxhYmxlXG4gKi9cbmZ1bmN0aW9uIGdldFByb3RvY29sVmVyc2lvbkZvclRyYW5zcG9ydCh0cmFuc3BvcnQpIHtcbiAgcmV0dXJuIHRyYW5zcG9ydFRvU2Vzc2lvbkRhdGEuZ2V0KHRyYW5zcG9ydCk/LnByb3RvY29sVmVyc2lvbjtcbn1cblxuLyoqXG4gKiBSZXRyaWV2ZXMgZnVsbCBzZXNzaW9uIGRhdGEgZm9yIGEgdHJhbnNwb3J0XG4gKiBAcGFyYW0gdHJhbnNwb3J0IC0gTUNQIHRyYW5zcG9ydCBpbnN0YW5jZVxuICogQHJldHVybnMgQ29tcGxldGUgc2Vzc2lvbiBkYXRhIGlmIGF2YWlsYWJsZVxuICovXG5mdW5jdGlvbiBnZXRTZXNzaW9uRGF0YUZvclRyYW5zcG9ydCh0cmFuc3BvcnQpIHtcbiAgcmV0dXJuIHRyYW5zcG9ydFRvU2Vzc2lvbkRhdGEuZ2V0KHRyYW5zcG9ydCk7XG59XG5cbi8qKlxuICogQ2xlYW5zIHVwIHNlc3Npb24gZGF0YSBmb3IgYSBzcGVjaWZpYyB0cmFuc3BvcnQgKHdoZW4gdGhhdCB0cmFuc3BvcnQgY2xvc2VzKVxuICogQHBhcmFtIHRyYW5zcG9ydCAtIE1DUCB0cmFuc3BvcnQgaW5zdGFuY2VcbiAqL1xuZnVuY3Rpb24gY2xlYW51cFNlc3Npb25EYXRhRm9yVHJhbnNwb3J0KHRyYW5zcG9ydCkge1xuICB0cmFuc3BvcnRUb1Nlc3Npb25EYXRhLmRlbGV0ZSh0cmFuc3BvcnQpO1xufVxuXG5leHBvcnRzLmNsZWFudXBTZXNzaW9uRGF0YUZvclRyYW5zcG9ydCA9IGNsZWFudXBTZXNzaW9uRGF0YUZvclRyYW5zcG9ydDtcbmV4cG9ydHMuZ2V0Q2xpZW50SW5mb0ZvclRyYW5zcG9ydCA9IGdldENsaWVudEluZm9Gb3JUcmFuc3BvcnQ7XG5leHBvcnRzLmdldFByb3RvY29sVmVyc2lvbkZvclRyYW5zcG9ydCA9IGdldFByb3RvY29sVmVyc2lvbkZvclRyYW5zcG9ydDtcbmV4cG9ydHMuZ2V0U2Vzc2lvbkRhdGFGb3JUcmFuc3BvcnQgPSBnZXRTZXNzaW9uRGF0YUZvclRyYW5zcG9ydDtcbmV4cG9ydHMuc3RvcmVTZXNzaW9uRGF0YUZvclRyYW5zcG9ydCA9IHN0b3JlU2Vzc2lvbkRhdGFGb3JUcmFuc3BvcnQ7XG5leHBvcnRzLnVwZGF0ZVNlc3Npb25EYXRhRm9yVHJhbnNwb3J0ID0gdXBkYXRlU2Vzc2lvbkRhdGFGb3JUcmFuc3BvcnQ7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1zZXNzaW9uTWFuYWdlbWVudC5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/sessionManagement.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/spans.js":
/*!*********************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/spans.js ***!
  \*********************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst currentScopes = __webpack_require__(/*! ../../currentScopes.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst semanticAttributes = __webpack_require__(/*! ../../semanticAttributes.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/semanticAttributes.js\");\nconst trace = __webpack_require__(/*! ../../tracing/trace.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/trace.js\");\nconst attributeExtraction = __webpack_require__(/*! ./attributeExtraction.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/attributeExtraction.js\");\nconst attributes = __webpack_require__(/*! ./attributes.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/attributes.js\");\nconst methodConfig = __webpack_require__(/*! ./methodConfig.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/methodConfig.js\");\nconst piiFiltering = __webpack_require__(/*! ./piiFiltering.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/piiFiltering.js\");\nconst sessionExtraction = __webpack_require__(/*! ./sessionExtraction.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/sessionExtraction.js\");\n\n/**\n * Span creation and management functions for MCP server instrumentation\n *\n * Provides unified span creation following OpenTelemetry MCP semantic conventions and our opinitionated take on MCP.\n * Handles both request and notification spans with attribute extraction.\n */\n\n\n/**\n * Creates a span name based on the method and target\n * @internal\n * @param method - MCP method name\n * @param target - Optional target identifier\n * @returns Formatted span name\n */\nfunction createSpanName(method, target) {\n  return target ? `${method} ${target}` : method;\n}\n\n/**\n * Build Sentry-specific attributes based on span type\n * @internal\n * @param type - Span type configuration\n * @returns Sentry-specific attributes\n */\nfunction buildSentryAttributes(type) {\n  let op;\n  let origin;\n\n  switch (type) {\n    case 'request':\n      op = attributes.MCP_SERVER_OP_VALUE;\n      origin = attributes.MCP_FUNCTION_ORIGIN_VALUE;\n      break;\n    case 'notification-incoming':\n      op = attributes.MCP_NOTIFICATION_CLIENT_TO_SERVER_OP_VALUE;\n      origin = attributes.MCP_NOTIFICATION_ORIGIN_VALUE;\n      break;\n    case 'notification-outgoing':\n      op = attributes.MCP_NOTIFICATION_SERVER_TO_CLIENT_OP_VALUE;\n      origin = attributes.MCP_NOTIFICATION_ORIGIN_VALUE;\n      break;\n  }\n\n  return {\n    [semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_OP]: op,\n    [semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_ORIGIN]: origin,\n    [semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_SOURCE]: attributes.MCP_ROUTE_SOURCE_VALUE,\n  };\n}\n\n/**\n * Unified builder for creating MCP spans\n * @internal\n * @param config - Span configuration\n * @returns Created span\n */\nfunction createMcpSpan(config) {\n  const { type, message, transport, extra, callback } = config;\n  const { method } = message;\n  const params = message.params ;\n\n  // Determine span name based on type and OTEL conventions\n  let spanName;\n  if (type === 'request') {\n    const targetInfo = methodConfig.extractTargetInfo(method, params || {});\n    spanName = createSpanName(method, targetInfo.target);\n  } else {\n    // For notifications, use method name directly per OpenTelemetry conventions\n    spanName = method;\n  }\n\n  const rawAttributes = {\n    ...sessionExtraction.buildTransportAttributes(transport, extra),\n    [attributes.MCP_METHOD_NAME_ATTRIBUTE]: method,\n    ...attributeExtraction.buildTypeSpecificAttributes(type, message, params),\n    ...buildSentryAttributes(type),\n  };\n\n  const client = currentScopes.getClient();\n  const sendDefaultPii = Boolean(client?.getOptions().sendDefaultPii);\n  const attributes$1 = piiFiltering.filterMcpPiiFromSpanData(rawAttributes, sendDefaultPii) ;\n\n  return trace.startSpan(\n    {\n      name: spanName,\n      forceTransaction: true,\n      attributes: attributes$1,\n    },\n    callback,\n  );\n}\n\n/**\n * Creates a span for incoming MCP notifications\n * @param jsonRpcMessage - Notification message\n * @param transport - MCP transport instance\n * @param extra - Extra handler data\n * @param callback - Span execution callback\n * @returns Span execution result\n */\nfunction createMcpNotificationSpan(\n  jsonRpcMessage,\n  transport,\n  extra,\n  callback,\n) {\n  return createMcpSpan({\n    type: 'notification-incoming',\n    message: jsonRpcMessage,\n    transport,\n    extra,\n    callback,\n  });\n}\n\n/**\n * Creates a span for outgoing MCP notifications\n * @param jsonRpcMessage - Notification message\n * @param transport - MCP transport instance\n * @param callback - Span execution callback\n * @returns Span execution result\n */\nfunction createMcpOutgoingNotificationSpan(\n  jsonRpcMessage,\n  transport,\n  callback,\n) {\n  return createMcpSpan({\n    type: 'notification-outgoing',\n    message: jsonRpcMessage,\n    transport,\n    callback,\n  });\n}\n\n/**\n * Builds span configuration for MCP server requests\n * @param jsonRpcMessage - Request message\n * @param transport - MCP transport instance\n * @param extra - Optional extra handler data\n * @returns Span configuration object\n */\nfunction buildMcpServerSpanConfig(\n  jsonRpcMessage,\n  transport,\n  extra,\n)\n\n {\n  const { method } = jsonRpcMessage;\n  const params = jsonRpcMessage.params ;\n\n  const targetInfo = methodConfig.extractTargetInfo(method, params || {});\n  const spanName = createSpanName(method, targetInfo.target);\n\n  const rawAttributes = {\n    ...sessionExtraction.buildTransportAttributes(transport, extra),\n    [attributes.MCP_METHOD_NAME_ATTRIBUTE]: method,\n    ...attributeExtraction.buildTypeSpecificAttributes('request', jsonRpcMessage, params),\n    ...buildSentryAttributes('request'),\n  };\n\n  const client = currentScopes.getClient();\n  const sendDefaultPii = Boolean(client?.getOptions().sendDefaultPii);\n  const attributes$1 = piiFiltering.filterMcpPiiFromSpanData(rawAttributes, sendDefaultPii) ;\n\n  return {\n    name: spanName,\n    op: attributes.MCP_SERVER_OP_VALUE,\n    forceTransaction: true,\n    attributes: attributes$1,\n  };\n}\n\nexports.buildMcpServerSpanConfig = buildMcpServerSpanConfig;\nexports.createMcpNotificationSpan = createMcpNotificationSpan;\nexports.createMcpOutgoingNotificationSpan = createMcpOutgoingNotificationSpan;\n//# sourceMappingURL=spans.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvbWNwLXNlcnZlci9zcGFucy5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxzQkFBc0IsbUJBQU8sQ0FBQyxtSUFBd0I7QUFDdEQsMkJBQTJCLG1CQUFPLENBQUMsNklBQTZCO0FBQ2hFLGNBQWMsbUJBQU8sQ0FBQyxtSUFBd0I7QUFDOUMsNEJBQTRCLG1CQUFPLENBQUMsbUtBQTBCO0FBQzlELG1CQUFtQixtQkFBTyxDQUFDLGlKQUFpQjtBQUM1QyxxQkFBcUIsbUJBQU8sQ0FBQyxxSkFBbUI7QUFDaEQscUJBQXFCLG1CQUFPLENBQUMscUpBQW1CO0FBQ2hELDBCQUEwQixtQkFBTyxDQUFDLCtKQUF3Qjs7QUFFMUQ7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOzs7QUFHQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EscUJBQXFCLFFBQVEsRUFBRSxPQUFPO0FBQ3RDOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFVBQVUsNENBQTRDO0FBQ3RELFVBQVUsU0FBUztBQUNuQjs7QUFFQTtBQUNBO0FBQ0E7QUFDQSwwRUFBMEU7QUFDMUU7QUFDQSxJQUFJO0FBQ0o7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEtBQUs7QUFDTDtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEdBQUc7QUFDSDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsR0FBRztBQUNIOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBLFVBQVUsU0FBUztBQUNuQjs7QUFFQSx3RUFBd0U7QUFDeEU7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSxnQ0FBZ0M7QUFDaEMsaUNBQWlDO0FBQ2pDLHlDQUF5QztBQUN6QyIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL2ludGVncmF0aW9ucy9tY3Atc2VydmVyL3NwYW5zLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBjdXJyZW50U2NvcGVzID0gcmVxdWlyZSgnLi4vLi4vY3VycmVudFNjb3Blcy5qcycpO1xuY29uc3Qgc2VtYW50aWNBdHRyaWJ1dGVzID0gcmVxdWlyZSgnLi4vLi4vc2VtYW50aWNBdHRyaWJ1dGVzLmpzJyk7XG5jb25zdCB0cmFjZSA9IHJlcXVpcmUoJy4uLy4uL3RyYWNpbmcvdHJhY2UuanMnKTtcbmNvbnN0IGF0dHJpYnV0ZUV4dHJhY3Rpb24gPSByZXF1aXJlKCcuL2F0dHJpYnV0ZUV4dHJhY3Rpb24uanMnKTtcbmNvbnN0IGF0dHJpYnV0ZXMgPSByZXF1aXJlKCcuL2F0dHJpYnV0ZXMuanMnKTtcbmNvbnN0IG1ldGhvZENvbmZpZyA9IHJlcXVpcmUoJy4vbWV0aG9kQ29uZmlnLmpzJyk7XG5jb25zdCBwaWlGaWx0ZXJpbmcgPSByZXF1aXJlKCcuL3BpaUZpbHRlcmluZy5qcycpO1xuY29uc3Qgc2Vzc2lvbkV4dHJhY3Rpb24gPSByZXF1aXJlKCcuL3Nlc3Npb25FeHRyYWN0aW9uLmpzJyk7XG5cbi8qKlxuICogU3BhbiBjcmVhdGlvbiBhbmQgbWFuYWdlbWVudCBmdW5jdGlvbnMgZm9yIE1DUCBzZXJ2ZXIgaW5zdHJ1bWVudGF0aW9uXG4gKlxuICogUHJvdmlkZXMgdW5pZmllZCBzcGFuIGNyZWF0aW9uIGZvbGxvd2luZyBPcGVuVGVsZW1ldHJ5IE1DUCBzZW1hbnRpYyBjb252ZW50aW9ucyBhbmQgb3VyIG9waW5pdGlvbmF0ZWQgdGFrZSBvbiBNQ1AuXG4gKiBIYW5kbGVzIGJvdGggcmVxdWVzdCBhbmQgbm90aWZpY2F0aW9uIHNwYW5zIHdpdGggYXR0cmlidXRlIGV4dHJhY3Rpb24uXG4gKi9cblxuXG4vKipcbiAqIENyZWF0ZXMgYSBzcGFuIG5hbWUgYmFzZWQgb24gdGhlIG1ldGhvZCBhbmQgdGFyZ2V0XG4gKiBAaW50ZXJuYWxcbiAqIEBwYXJhbSBtZXRob2QgLSBNQ1AgbWV0aG9kIG5hbWVcbiAqIEBwYXJhbSB0YXJnZXQgLSBPcHRpb25hbCB0YXJnZXQgaWRlbnRpZmllclxuICogQHJldHVybnMgRm9ybWF0dGVkIHNwYW4gbmFtZVxuICovXG5mdW5jdGlvbiBjcmVhdGVTcGFuTmFtZShtZXRob2QsIHRhcmdldCkge1xuICByZXR1cm4gdGFyZ2V0ID8gYCR7bWV0aG9kfSAke3RhcmdldH1gIDogbWV0aG9kO1xufVxuXG4vKipcbiAqIEJ1aWxkIFNlbnRyeS1zcGVjaWZpYyBhdHRyaWJ1dGVzIGJhc2VkIG9uIHNwYW4gdHlwZVxuICogQGludGVybmFsXG4gKiBAcGFyYW0gdHlwZSAtIFNwYW4gdHlwZSBjb25maWd1cmF0aW9uXG4gKiBAcmV0dXJucyBTZW50cnktc3BlY2lmaWMgYXR0cmlidXRlc1xuICovXG5mdW5jdGlvbiBidWlsZFNlbnRyeUF0dHJpYnV0ZXModHlwZSkge1xuICBsZXQgb3A7XG4gIGxldCBvcmlnaW47XG5cbiAgc3dpdGNoICh0eXBlKSB7XG4gICAgY2FzZSAncmVxdWVzdCc6XG4gICAgICBvcCA9IGF0dHJpYnV0ZXMuTUNQX1NFUlZFUl9PUF9WQUxVRTtcbiAgICAgIG9yaWdpbiA9IGF0dHJpYnV0ZXMuTUNQX0ZVTkNUSU9OX09SSUdJTl9WQUxVRTtcbiAgICAgIGJyZWFrO1xuICAgIGNhc2UgJ25vdGlmaWNhdGlvbi1pbmNvbWluZyc6XG4gICAgICBvcCA9IGF0dHJpYnV0ZXMuTUNQX05PVElGSUNBVElPTl9DTElFTlRfVE9fU0VSVkVSX09QX1ZBTFVFO1xuICAgICAgb3JpZ2luID0gYXR0cmlidXRlcy5NQ1BfTk9USUZJQ0FUSU9OX09SSUdJTl9WQUxVRTtcbiAgICAgIGJyZWFrO1xuICAgIGNhc2UgJ25vdGlmaWNhdGlvbi1vdXRnb2luZyc6XG4gICAgICBvcCA9IGF0dHJpYnV0ZXMuTUNQX05PVElGSUNBVElPTl9TRVJWRVJfVE9fQ0xJRU5UX09QX1ZBTFVFO1xuICAgICAgb3JpZ2luID0gYXR0cmlidXRlcy5NQ1BfTk9USUZJQ0FUSU9OX09SSUdJTl9WQUxVRTtcbiAgICAgIGJyZWFrO1xuICB9XG5cbiAgcmV0dXJuIHtcbiAgICBbc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfT1BdOiBvcCxcbiAgICBbc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfT1JJR0lOXTogb3JpZ2luLFxuICAgIFtzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9TT1VSQ0VdOiBhdHRyaWJ1dGVzLk1DUF9ST1VURV9TT1VSQ0VfVkFMVUUsXG4gIH07XG59XG5cbi8qKlxuICogVW5pZmllZCBidWlsZGVyIGZvciBjcmVhdGluZyBNQ1Agc3BhbnNcbiAqIEBpbnRlcm5hbFxuICogQHBhcmFtIGNvbmZpZyAtIFNwYW4gY29uZmlndXJhdGlvblxuICogQHJldHVybnMgQ3JlYXRlZCBzcGFuXG4gKi9cbmZ1bmN0aW9uIGNyZWF0ZU1jcFNwYW4oY29uZmlnKSB7XG4gIGNvbnN0IHsgdHlwZSwgbWVzc2FnZSwgdHJhbnNwb3J0LCBleHRyYSwgY2FsbGJhY2sgfSA9IGNvbmZpZztcbiAgY29uc3QgeyBtZXRob2QgfSA9IG1lc3NhZ2U7XG4gIGNvbnN0IHBhcmFtcyA9IG1lc3NhZ2UucGFyYW1zIDtcblxuICAvLyBEZXRlcm1pbmUgc3BhbiBuYW1lIGJhc2VkIG9uIHR5cGUgYW5kIE9URUwgY29udmVudGlvbnNcbiAgbGV0IHNwYW5OYW1lO1xuICBpZiAodHlwZSA9PT0gJ3JlcXVlc3QnKSB7XG4gICAgY29uc3QgdGFyZ2V0SW5mbyA9IG1ldGhvZENvbmZpZy5leHRyYWN0VGFyZ2V0SW5mbyhtZXRob2QsIHBhcmFtcyB8fCB7fSk7XG4gICAgc3Bhbk5hbWUgPSBjcmVhdGVTcGFuTmFtZShtZXRob2QsIHRhcmdldEluZm8udGFyZ2V0KTtcbiAgfSBlbHNlIHtcbiAgICAvLyBGb3Igbm90aWZpY2F0aW9ucywgdXNlIG1ldGhvZCBuYW1lIGRpcmVjdGx5IHBlciBPcGVuVGVsZW1ldHJ5IGNvbnZlbnRpb25zXG4gICAgc3Bhbk5hbWUgPSBtZXRob2Q7XG4gIH1cblxuICBjb25zdCByYXdBdHRyaWJ1dGVzID0ge1xuICAgIC4uLnNlc3Npb25FeHRyYWN0aW9uLmJ1aWxkVHJhbnNwb3J0QXR0cmlidXRlcyh0cmFuc3BvcnQsIGV4dHJhKSxcbiAgICBbYXR0cmlidXRlcy5NQ1BfTUVUSE9EX05BTUVfQVRUUklCVVRFXTogbWV0aG9kLFxuICAgIC4uLmF0dHJpYnV0ZUV4dHJhY3Rpb24uYnVpbGRUeXBlU3BlY2lmaWNBdHRyaWJ1dGVzKHR5cGUsIG1lc3NhZ2UsIHBhcmFtcyksXG4gICAgLi4uYnVpbGRTZW50cnlBdHRyaWJ1dGVzKHR5cGUpLFxuICB9O1xuXG4gIGNvbnN0IGNsaWVudCA9IGN1cnJlbnRTY29wZXMuZ2V0Q2xpZW50KCk7XG4gIGNvbnN0IHNlbmREZWZhdWx0UGlpID0gQm9vbGVhbihjbGllbnQ/LmdldE9wdGlvbnMoKS5zZW5kRGVmYXVsdFBpaSk7XG4gIGNvbnN0IGF0dHJpYnV0ZXMkMSA9IHBpaUZpbHRlcmluZy5maWx0ZXJNY3BQaWlGcm9tU3BhbkRhdGEocmF3QXR0cmlidXRlcywgc2VuZERlZmF1bHRQaWkpIDtcblxuICByZXR1cm4gdHJhY2Uuc3RhcnRTcGFuKFxuICAgIHtcbiAgICAgIG5hbWU6IHNwYW5OYW1lLFxuICAgICAgZm9yY2VUcmFuc2FjdGlvbjogdHJ1ZSxcbiAgICAgIGF0dHJpYnV0ZXM6IGF0dHJpYnV0ZXMkMSxcbiAgICB9LFxuICAgIGNhbGxiYWNrLFxuICApO1xufVxuXG4vKipcbiAqIENyZWF0ZXMgYSBzcGFuIGZvciBpbmNvbWluZyBNQ1Agbm90aWZpY2F0aW9uc1xuICogQHBhcmFtIGpzb25ScGNNZXNzYWdlIC0gTm90aWZpY2F0aW9uIG1lc3NhZ2VcbiAqIEBwYXJhbSB0cmFuc3BvcnQgLSBNQ1AgdHJhbnNwb3J0IGluc3RhbmNlXG4gKiBAcGFyYW0gZXh0cmEgLSBFeHRyYSBoYW5kbGVyIGRhdGFcbiAqIEBwYXJhbSBjYWxsYmFjayAtIFNwYW4gZXhlY3V0aW9uIGNhbGxiYWNrXG4gKiBAcmV0dXJucyBTcGFuIGV4ZWN1dGlvbiByZXN1bHRcbiAqL1xuZnVuY3Rpb24gY3JlYXRlTWNwTm90aWZpY2F0aW9uU3BhbihcbiAganNvblJwY01lc3NhZ2UsXG4gIHRyYW5zcG9ydCxcbiAgZXh0cmEsXG4gIGNhbGxiYWNrLFxuKSB7XG4gIHJldHVybiBjcmVhdGVNY3BTcGFuKHtcbiAgICB0eXBlOiAnbm90aWZpY2F0aW9uLWluY29taW5nJyxcbiAgICBtZXNzYWdlOiBqc29uUnBjTWVzc2FnZSxcbiAgICB0cmFuc3BvcnQsXG4gICAgZXh0cmEsXG4gICAgY2FsbGJhY2ssXG4gIH0pO1xufVxuXG4vKipcbiAqIENyZWF0ZXMgYSBzcGFuIGZvciBvdXRnb2luZyBNQ1Agbm90aWZpY2F0aW9uc1xuICogQHBhcmFtIGpzb25ScGNNZXNzYWdlIC0gTm90aWZpY2F0aW9uIG1lc3NhZ2VcbiAqIEBwYXJhbSB0cmFuc3BvcnQgLSBNQ1AgdHJhbnNwb3J0IGluc3RhbmNlXG4gKiBAcGFyYW0gY2FsbGJhY2sgLSBTcGFuIGV4ZWN1dGlvbiBjYWxsYmFja1xuICogQHJldHVybnMgU3BhbiBleGVjdXRpb24gcmVzdWx0XG4gKi9cbmZ1bmN0aW9uIGNyZWF0ZU1jcE91dGdvaW5nTm90aWZpY2F0aW9uU3BhbihcbiAganNvblJwY01lc3NhZ2UsXG4gIHRyYW5zcG9ydCxcbiAgY2FsbGJhY2ssXG4pIHtcbiAgcmV0dXJuIGNyZWF0ZU1jcFNwYW4oe1xuICAgIHR5cGU6ICdub3RpZmljYXRpb24tb3V0Z29pbmcnLFxuICAgIG1lc3NhZ2U6IGpzb25ScGNNZXNzYWdlLFxuICAgIHRyYW5zcG9ydCxcbiAgICBjYWxsYmFjayxcbiAgfSk7XG59XG5cbi8qKlxuICogQnVpbGRzIHNwYW4gY29uZmlndXJhdGlvbiBmb3IgTUNQIHNlcnZlciByZXF1ZXN0c1xuICogQHBhcmFtIGpzb25ScGNNZXNzYWdlIC0gUmVxdWVzdCBtZXNzYWdlXG4gKiBAcGFyYW0gdHJhbnNwb3J0IC0gTUNQIHRyYW5zcG9ydCBpbnN0YW5jZVxuICogQHBhcmFtIGV4dHJhIC0gT3B0aW9uYWwgZXh0cmEgaGFuZGxlciBkYXRhXG4gKiBAcmV0dXJucyBTcGFuIGNvbmZpZ3VyYXRpb24gb2JqZWN0XG4gKi9cbmZ1bmN0aW9uIGJ1aWxkTWNwU2VydmVyU3BhbkNvbmZpZyhcbiAganNvblJwY01lc3NhZ2UsXG4gIHRyYW5zcG9ydCxcbiAgZXh0cmEsXG4pXG5cbiB7XG4gIGNvbnN0IHsgbWV0aG9kIH0gPSBqc29uUnBjTWVzc2FnZTtcbiAgY29uc3QgcGFyYW1zID0ganNvblJwY01lc3NhZ2UucGFyYW1zIDtcblxuICBjb25zdCB0YXJnZXRJbmZvID0gbWV0aG9kQ29uZmlnLmV4dHJhY3RUYXJnZXRJbmZvKG1ldGhvZCwgcGFyYW1zIHx8IHt9KTtcbiAgY29uc3Qgc3Bhbk5hbWUgPSBjcmVhdGVTcGFuTmFtZShtZXRob2QsIHRhcmdldEluZm8udGFyZ2V0KTtcblxuICBjb25zdCByYXdBdHRyaWJ1dGVzID0ge1xuICAgIC4uLnNlc3Npb25FeHRyYWN0aW9uLmJ1aWxkVHJhbnNwb3J0QXR0cmlidXRlcyh0cmFuc3BvcnQsIGV4dHJhKSxcbiAgICBbYXR0cmlidXRlcy5NQ1BfTUVUSE9EX05BTUVfQVRUUklCVVRFXTogbWV0aG9kLFxuICAgIC4uLmF0dHJpYnV0ZUV4dHJhY3Rpb24uYnVpbGRUeXBlU3BlY2lmaWNBdHRyaWJ1dGVzKCdyZXF1ZXN0JywganNvblJwY01lc3NhZ2UsIHBhcmFtcyksXG4gICAgLi4uYnVpbGRTZW50cnlBdHRyaWJ1dGVzKCdyZXF1ZXN0JyksXG4gIH07XG5cbiAgY29uc3QgY2xpZW50ID0gY3VycmVudFNjb3Blcy5nZXRDbGllbnQoKTtcbiAgY29uc3Qgc2VuZERlZmF1bHRQaWkgPSBCb29sZWFuKGNsaWVudD8uZ2V0T3B0aW9ucygpLnNlbmREZWZhdWx0UGlpKTtcbiAgY29uc3QgYXR0cmlidXRlcyQxID0gcGlpRmlsdGVyaW5nLmZpbHRlck1jcFBpaUZyb21TcGFuRGF0YShyYXdBdHRyaWJ1dGVzLCBzZW5kRGVmYXVsdFBpaSkgO1xuXG4gIHJldHVybiB7XG4gICAgbmFtZTogc3Bhbk5hbWUsXG4gICAgb3A6IGF0dHJpYnV0ZXMuTUNQX1NFUlZFUl9PUF9WQUxVRSxcbiAgICBmb3JjZVRyYW5zYWN0aW9uOiB0cnVlLFxuICAgIGF0dHJpYnV0ZXM6IGF0dHJpYnV0ZXMkMSxcbiAgfTtcbn1cblxuZXhwb3J0cy5idWlsZE1jcFNlcnZlclNwYW5Db25maWcgPSBidWlsZE1jcFNlcnZlclNwYW5Db25maWc7XG5leHBvcnRzLmNyZWF0ZU1jcE5vdGlmaWNhdGlvblNwYW4gPSBjcmVhdGVNY3BOb3RpZmljYXRpb25TcGFuO1xuZXhwb3J0cy5jcmVhdGVNY3BPdXRnb2luZ05vdGlmaWNhdGlvblNwYW4gPSBjcmVhdGVNY3BPdXRnb2luZ05vdGlmaWNhdGlvblNwYW47XG4vLyMgc291cmNlTWFwcGluZ1VSTD1zcGFucy5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/spans.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/transport.js":
/*!*************************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/transport.js ***!
  \*************************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst currentScopes = __webpack_require__(/*! ../../currentScopes.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst object = __webpack_require__(/*! ../../utils/object.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/object.js\");\nconst trace = __webpack_require__(/*! ../../tracing/trace.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/trace.js\");\nconst correlation = __webpack_require__(/*! ./correlation.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/correlation.js\");\nconst errorCapture = __webpack_require__(/*! ./errorCapture.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/errorCapture.js\");\nconst sessionExtraction = __webpack_require__(/*! ./sessionExtraction.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/sessionExtraction.js\");\nconst sessionManagement = __webpack_require__(/*! ./sessionManagement.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/sessionManagement.js\");\nconst spans = __webpack_require__(/*! ./spans.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/spans.js\");\nconst validation = __webpack_require__(/*! ./validation.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/validation.js\");\n\n/**\n * Transport layer instrumentation for MCP server\n *\n * Handles message interception and response correlation.\n * @see https://modelcontextprotocol.io/specification/2025-06-18/basic/transports\n */\n\n\n/**\n * Wraps transport.onmessage to create spans for incoming messages.\n * For \"initialize\" requests, extracts and stores client info and protocol version\n * in the session data for the transport.\n * @param transport - MCP transport instance to wrap\n */\nfunction wrapTransportOnMessage(transport) {\n  if (transport.onmessage) {\n    object.fill(transport, 'onmessage', originalOnMessage => {\n      return function ( message, extra) {\n        if (validation.isJsonRpcRequest(message)) {\n          if (message.method === 'initialize') {\n            try {\n              const sessionData = sessionExtraction.extractSessionDataFromInitializeRequest(message);\n              sessionManagement.storeSessionDataForTransport(this, sessionData);\n            } catch {\n              // noop\n            }\n          }\n\n          const isolationScope = currentScopes.getIsolationScope().clone();\n\n          return currentScopes.withIsolationScope(isolationScope, () => {\n            const spanConfig = spans.buildMcpServerSpanConfig(message, this, extra );\n            const span = trace.startInactiveSpan(spanConfig);\n\n            correlation.storeSpanForRequest(this, message.id, span, message.method);\n\n            return trace.withActiveSpan(span, () => {\n              return (originalOnMessage ).call(this, message, extra);\n            });\n          });\n        }\n\n        if (validation.isJsonRpcNotification(message)) {\n          return spans.createMcpNotificationSpan(message, this, extra , () => {\n            return (originalOnMessage ).call(this, message, extra);\n          });\n        }\n\n        return (originalOnMessage ).call(this, message, extra);\n      };\n    });\n  }\n}\n\n/**\n * Wraps transport.send to handle outgoing messages and response correlation.\n * For \"initialize\" responses, extracts and stores protocol version and server info\n * in the session data for the transport.\n * @param transport - MCP transport instance to wrap\n */\nfunction wrapTransportSend(transport) {\n  if (transport.send) {\n    object.fill(transport, 'send', originalSend => {\n      return async function ( ...args) {\n        const [message] = args;\n\n        if (validation.isJsonRpcNotification(message)) {\n          return spans.createMcpOutgoingNotificationSpan(message, this, () => {\n            return (originalSend ).call(this, ...args);\n          });\n        }\n\n        if (validation.isJsonRpcResponse(message)) {\n          if (message.id !== null && message.id !== undefined) {\n            if (message.error) {\n              captureJsonRpcErrorResponse(message.error);\n            }\n\n            if (validation.isValidContentItem(message.result)) {\n              if (message.result.protocolVersion || message.result.serverInfo) {\n                try {\n                  const serverData = sessionExtraction.extractSessionDataFromInitializeResponse(message.result);\n                  sessionManagement.updateSessionDataForTransport(this, serverData);\n                } catch {\n                  // noop\n                }\n              }\n            }\n\n            correlation.completeSpanWithResults(this, message.id, message.result);\n          }\n        }\n\n        return (originalSend ).call(this, ...args);\n      };\n    });\n  }\n}\n\n/**\n * Wraps transport.onclose to clean up pending spans for this transport only\n * @param transport - MCP transport instance to wrap\n */\nfunction wrapTransportOnClose(transport) {\n  if (transport.onclose) {\n    object.fill(transport, 'onclose', originalOnClose => {\n      return function ( ...args) {\n        correlation.cleanupPendingSpansForTransport(this);\n        sessionManagement.cleanupSessionDataForTransport(this);\n        return (originalOnClose ).call(this, ...args);\n      };\n    });\n  }\n}\n\n/**\n * Wraps transport error handlers to capture connection errors\n * @param transport - MCP transport instance to wrap\n */\nfunction wrapTransportError(transport) {\n  if (transport.onerror) {\n    object.fill(transport, 'onerror', (originalOnError) => {\n      return function ( error) {\n        captureTransportError(error);\n        return originalOnError.call(this, error);\n      };\n    });\n  }\n}\n\n/**\n * Captures JSON-RPC error responses for server-side errors.\n * @see https://www.jsonrpc.org/specification#error_object\n * @internal\n * @param errorResponse - JSON-RPC error response\n */\nfunction captureJsonRpcErrorResponse(errorResponse) {\n  try {\n    if (errorResponse && typeof errorResponse === 'object' && 'code' in errorResponse && 'message' in errorResponse) {\n      const jsonRpcError = errorResponse ;\n\n      const isServerError =\n        jsonRpcError.code === -32603 || (jsonRpcError.code >= -32099 && jsonRpcError.code <= -32000);\n\n      if (isServerError) {\n        const error = new Error(jsonRpcError.message);\n        error.name = `JsonRpcError_${jsonRpcError.code}`;\n\n        errorCapture.captureError(error, 'protocol');\n      }\n    }\n  } catch {\n    // noop\n  }\n}\n\n/**\n * Captures transport connection errors\n * @internal\n * @param error - Transport error\n */\nfunction captureTransportError(error) {\n  try {\n    errorCapture.captureError(error, 'transport');\n  } catch {\n    // noop\n  }\n}\n\nexports.wrapTransportError = wrapTransportError;\nexports.wrapTransportOnClose = wrapTransportOnClose;\nexports.wrapTransportOnMessage = wrapTransportOnMessage;\nexports.wrapTransportSend = wrapTransportSend;\n//# sourceMappingURL=transport.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvbWNwLXNlcnZlci90cmFuc3BvcnQuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsc0JBQXNCLG1CQUFPLENBQUMsbUlBQXdCO0FBQ3RELGVBQWUsbUJBQU8sQ0FBQyxpSUFBdUI7QUFDOUMsY0FBYyxtQkFBTyxDQUFDLG1JQUF3QjtBQUM5QyxvQkFBb0IsbUJBQU8sQ0FBQyxtSkFBa0I7QUFDOUMscUJBQXFCLG1CQUFPLENBQUMscUpBQW1CO0FBQ2hELDBCQUEwQixtQkFBTyxDQUFDLCtKQUF3QjtBQUMxRCwwQkFBMEIsbUJBQU8sQ0FBQywrSkFBd0I7QUFDMUQsY0FBYyxtQkFBTyxDQUFDLHVJQUFZO0FBQ2xDLG1CQUFtQixtQkFBTyxDQUFDLGlKQUFpQjs7QUFFNUM7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOzs7QUFHQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxjQUFjO0FBQ2Q7QUFDQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0EsYUFBYTtBQUNiLFdBQVc7QUFDWDs7QUFFQTtBQUNBO0FBQ0E7QUFDQSxXQUFXO0FBQ1g7O0FBRUE7QUFDQTtBQUNBLEtBQUs7QUFDTDtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0EsV0FBVztBQUNYOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGtCQUFrQjtBQUNsQjtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLEtBQUs7QUFDTDtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEtBQUs7QUFDTDtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxLQUFLO0FBQ0w7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQSxxQ0FBcUMsa0JBQWtCOztBQUV2RDtBQUNBO0FBQ0E7QUFDQSxJQUFJO0FBQ0o7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxJQUFJO0FBQ0o7QUFDQTtBQUNBOztBQUVBLDBCQUEwQjtBQUMxQiw0QkFBNEI7QUFDNUIsOEJBQThCO0FBQzlCLHlCQUF5QjtBQUN6QiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL2ludGVncmF0aW9ucy9tY3Atc2VydmVyL3RyYW5zcG9ydC5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgY3VycmVudFNjb3BlcyA9IHJlcXVpcmUoJy4uLy4uL2N1cnJlbnRTY29wZXMuanMnKTtcbmNvbnN0IG9iamVjdCA9IHJlcXVpcmUoJy4uLy4uL3V0aWxzL29iamVjdC5qcycpO1xuY29uc3QgdHJhY2UgPSByZXF1aXJlKCcuLi8uLi90cmFjaW5nL3RyYWNlLmpzJyk7XG5jb25zdCBjb3JyZWxhdGlvbiA9IHJlcXVpcmUoJy4vY29ycmVsYXRpb24uanMnKTtcbmNvbnN0IGVycm9yQ2FwdHVyZSA9IHJlcXVpcmUoJy4vZXJyb3JDYXB0dXJlLmpzJyk7XG5jb25zdCBzZXNzaW9uRXh0cmFjdGlvbiA9IHJlcXVpcmUoJy4vc2Vzc2lvbkV4dHJhY3Rpb24uanMnKTtcbmNvbnN0IHNlc3Npb25NYW5hZ2VtZW50ID0gcmVxdWlyZSgnLi9zZXNzaW9uTWFuYWdlbWVudC5qcycpO1xuY29uc3Qgc3BhbnMgPSByZXF1aXJlKCcuL3NwYW5zLmpzJyk7XG5jb25zdCB2YWxpZGF0aW9uID0gcmVxdWlyZSgnLi92YWxpZGF0aW9uLmpzJyk7XG5cbi8qKlxuICogVHJhbnNwb3J0IGxheWVyIGluc3RydW1lbnRhdGlvbiBmb3IgTUNQIHNlcnZlclxuICpcbiAqIEhhbmRsZXMgbWVzc2FnZSBpbnRlcmNlcHRpb24gYW5kIHJlc3BvbnNlIGNvcnJlbGF0aW9uLlxuICogQHNlZSBodHRwczovL21vZGVsY29udGV4dHByb3RvY29sLmlvL3NwZWNpZmljYXRpb24vMjAyNS0wNi0xOC9iYXNpYy90cmFuc3BvcnRzXG4gKi9cblxuXG4vKipcbiAqIFdyYXBzIHRyYW5zcG9ydC5vbm1lc3NhZ2UgdG8gY3JlYXRlIHNwYW5zIGZvciBpbmNvbWluZyBtZXNzYWdlcy5cbiAqIEZvciBcImluaXRpYWxpemVcIiByZXF1ZXN0cywgZXh0cmFjdHMgYW5kIHN0b3JlcyBjbGllbnQgaW5mbyBhbmQgcHJvdG9jb2wgdmVyc2lvblxuICogaW4gdGhlIHNlc3Npb24gZGF0YSBmb3IgdGhlIHRyYW5zcG9ydC5cbiAqIEBwYXJhbSB0cmFuc3BvcnQgLSBNQ1AgdHJhbnNwb3J0IGluc3RhbmNlIHRvIHdyYXBcbiAqL1xuZnVuY3Rpb24gd3JhcFRyYW5zcG9ydE9uTWVzc2FnZSh0cmFuc3BvcnQpIHtcbiAgaWYgKHRyYW5zcG9ydC5vbm1lc3NhZ2UpIHtcbiAgICBvYmplY3QuZmlsbCh0cmFuc3BvcnQsICdvbm1lc3NhZ2UnLCBvcmlnaW5hbE9uTWVzc2FnZSA9PiB7XG4gICAgICByZXR1cm4gZnVuY3Rpb24gKCBtZXNzYWdlLCBleHRyYSkge1xuICAgICAgICBpZiAodmFsaWRhdGlvbi5pc0pzb25ScGNSZXF1ZXN0KG1lc3NhZ2UpKSB7XG4gICAgICAgICAgaWYgKG1lc3NhZ2UubWV0aG9kID09PSAnaW5pdGlhbGl6ZScpIHtcbiAgICAgICAgICAgIHRyeSB7XG4gICAgICAgICAgICAgIGNvbnN0IHNlc3Npb25EYXRhID0gc2Vzc2lvbkV4dHJhY3Rpb24uZXh0cmFjdFNlc3Npb25EYXRhRnJvbUluaXRpYWxpemVSZXF1ZXN0KG1lc3NhZ2UpO1xuICAgICAgICAgICAgICBzZXNzaW9uTWFuYWdlbWVudC5zdG9yZVNlc3Npb25EYXRhRm9yVHJhbnNwb3J0KHRoaXMsIHNlc3Npb25EYXRhKTtcbiAgICAgICAgICAgIH0gY2F0Y2gge1xuICAgICAgICAgICAgICAvLyBub29wXG4gICAgICAgICAgICB9XG4gICAgICAgICAgfVxuXG4gICAgICAgICAgY29uc3QgaXNvbGF0aW9uU2NvcGUgPSBjdXJyZW50U2NvcGVzLmdldElzb2xhdGlvblNjb3BlKCkuY2xvbmUoKTtcblxuICAgICAgICAgIHJldHVybiBjdXJyZW50U2NvcGVzLndpdGhJc29sYXRpb25TY29wZShpc29sYXRpb25TY29wZSwgKCkgPT4ge1xuICAgICAgICAgICAgY29uc3Qgc3BhbkNvbmZpZyA9IHNwYW5zLmJ1aWxkTWNwU2VydmVyU3BhbkNvbmZpZyhtZXNzYWdlLCB0aGlzLCBleHRyYSApO1xuICAgICAgICAgICAgY29uc3Qgc3BhbiA9IHRyYWNlLnN0YXJ0SW5hY3RpdmVTcGFuKHNwYW5Db25maWcpO1xuXG4gICAgICAgICAgICBjb3JyZWxhdGlvbi5zdG9yZVNwYW5Gb3JSZXF1ZXN0KHRoaXMsIG1lc3NhZ2UuaWQsIHNwYW4sIG1lc3NhZ2UubWV0aG9kKTtcblxuICAgICAgICAgICAgcmV0dXJuIHRyYWNlLndpdGhBY3RpdmVTcGFuKHNwYW4sICgpID0+IHtcbiAgICAgICAgICAgICAgcmV0dXJuIChvcmlnaW5hbE9uTWVzc2FnZSApLmNhbGwodGhpcywgbWVzc2FnZSwgZXh0cmEpO1xuICAgICAgICAgICAgfSk7XG4gICAgICAgICAgfSk7XG4gICAgICAgIH1cblxuICAgICAgICBpZiAodmFsaWRhdGlvbi5pc0pzb25ScGNOb3RpZmljYXRpb24obWVzc2FnZSkpIHtcbiAgICAgICAgICByZXR1cm4gc3BhbnMuY3JlYXRlTWNwTm90aWZpY2F0aW9uU3BhbihtZXNzYWdlLCB0aGlzLCBleHRyYSAsICgpID0+IHtcbiAgICAgICAgICAgIHJldHVybiAob3JpZ2luYWxPbk1lc3NhZ2UgKS5jYWxsKHRoaXMsIG1lc3NhZ2UsIGV4dHJhKTtcbiAgICAgICAgICB9KTtcbiAgICAgICAgfVxuXG4gICAgICAgIHJldHVybiAob3JpZ2luYWxPbk1lc3NhZ2UgKS5jYWxsKHRoaXMsIG1lc3NhZ2UsIGV4dHJhKTtcbiAgICAgIH07XG4gICAgfSk7XG4gIH1cbn1cblxuLyoqXG4gKiBXcmFwcyB0cmFuc3BvcnQuc2VuZCB0byBoYW5kbGUgb3V0Z29pbmcgbWVzc2FnZXMgYW5kIHJlc3BvbnNlIGNvcnJlbGF0aW9uLlxuICogRm9yIFwiaW5pdGlhbGl6ZVwiIHJlc3BvbnNlcywgZXh0cmFjdHMgYW5kIHN0b3JlcyBwcm90b2NvbCB2ZXJzaW9uIGFuZCBzZXJ2ZXIgaW5mb1xuICogaW4gdGhlIHNlc3Npb24gZGF0YSBmb3IgdGhlIHRyYW5zcG9ydC5cbiAqIEBwYXJhbSB0cmFuc3BvcnQgLSBNQ1AgdHJhbnNwb3J0IGluc3RhbmNlIHRvIHdyYXBcbiAqL1xuZnVuY3Rpb24gd3JhcFRyYW5zcG9ydFNlbmQodHJhbnNwb3J0KSB7XG4gIGlmICh0cmFuc3BvcnQuc2VuZCkge1xuICAgIG9iamVjdC5maWxsKHRyYW5zcG9ydCwgJ3NlbmQnLCBvcmlnaW5hbFNlbmQgPT4ge1xuICAgICAgcmV0dXJuIGFzeW5jIGZ1bmN0aW9uICggLi4uYXJncykge1xuICAgICAgICBjb25zdCBbbWVzc2FnZV0gPSBhcmdzO1xuXG4gICAgICAgIGlmICh2YWxpZGF0aW9uLmlzSnNvblJwY05vdGlmaWNhdGlvbihtZXNzYWdlKSkge1xuICAgICAgICAgIHJldHVybiBzcGFucy5jcmVhdGVNY3BPdXRnb2luZ05vdGlmaWNhdGlvblNwYW4obWVzc2FnZSwgdGhpcywgKCkgPT4ge1xuICAgICAgICAgICAgcmV0dXJuIChvcmlnaW5hbFNlbmQgKS5jYWxsKHRoaXMsIC4uLmFyZ3MpO1xuICAgICAgICAgIH0pO1xuICAgICAgICB9XG5cbiAgICAgICAgaWYgKHZhbGlkYXRpb24uaXNKc29uUnBjUmVzcG9uc2UobWVzc2FnZSkpIHtcbiAgICAgICAgICBpZiAobWVzc2FnZS5pZCAhPT0gbnVsbCAmJiBtZXNzYWdlLmlkICE9PSB1bmRlZmluZWQpIHtcbiAgICAgICAgICAgIGlmIChtZXNzYWdlLmVycm9yKSB7XG4gICAgICAgICAgICAgIGNhcHR1cmVKc29uUnBjRXJyb3JSZXNwb25zZShtZXNzYWdlLmVycm9yKTtcbiAgICAgICAgICAgIH1cblxuICAgICAgICAgICAgaWYgKHZhbGlkYXRpb24uaXNWYWxpZENvbnRlbnRJdGVtKG1lc3NhZ2UucmVzdWx0KSkge1xuICAgICAgICAgICAgICBpZiAobWVzc2FnZS5yZXN1bHQucHJvdG9jb2xWZXJzaW9uIHx8IG1lc3NhZ2UucmVzdWx0LnNlcnZlckluZm8pIHtcbiAgICAgICAgICAgICAgICB0cnkge1xuICAgICAgICAgICAgICAgICAgY29uc3Qgc2VydmVyRGF0YSA9IHNlc3Npb25FeHRyYWN0aW9uLmV4dHJhY3RTZXNzaW9uRGF0YUZyb21Jbml0aWFsaXplUmVzcG9uc2UobWVzc2FnZS5yZXN1bHQpO1xuICAgICAgICAgICAgICAgICAgc2Vzc2lvbk1hbmFnZW1lbnQudXBkYXRlU2Vzc2lvbkRhdGFGb3JUcmFuc3BvcnQodGhpcywgc2VydmVyRGF0YSk7XG4gICAgICAgICAgICAgICAgfSBjYXRjaCB7XG4gICAgICAgICAgICAgICAgICAvLyBub29wXG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICB9XG4gICAgICAgICAgICB9XG5cbiAgICAgICAgICAgIGNvcnJlbGF0aW9uLmNvbXBsZXRlU3BhbldpdGhSZXN1bHRzKHRoaXMsIG1lc3NhZ2UuaWQsIG1lc3NhZ2UucmVzdWx0KTtcbiAgICAgICAgICB9XG4gICAgICAgIH1cblxuICAgICAgICByZXR1cm4gKG9yaWdpbmFsU2VuZCApLmNhbGwodGhpcywgLi4uYXJncyk7XG4gICAgICB9O1xuICAgIH0pO1xuICB9XG59XG5cbi8qKlxuICogV3JhcHMgdHJhbnNwb3J0Lm9uY2xvc2UgdG8gY2xlYW4gdXAgcGVuZGluZyBzcGFucyBmb3IgdGhpcyB0cmFuc3BvcnQgb25seVxuICogQHBhcmFtIHRyYW5zcG9ydCAtIE1DUCB0cmFuc3BvcnQgaW5zdGFuY2UgdG8gd3JhcFxuICovXG5mdW5jdGlvbiB3cmFwVHJhbnNwb3J0T25DbG9zZSh0cmFuc3BvcnQpIHtcbiAgaWYgKHRyYW5zcG9ydC5vbmNsb3NlKSB7XG4gICAgb2JqZWN0LmZpbGwodHJhbnNwb3J0LCAnb25jbG9zZScsIG9yaWdpbmFsT25DbG9zZSA9PiB7XG4gICAgICByZXR1cm4gZnVuY3Rpb24gKCAuLi5hcmdzKSB7XG4gICAgICAgIGNvcnJlbGF0aW9uLmNsZWFudXBQZW5kaW5nU3BhbnNGb3JUcmFuc3BvcnQodGhpcyk7XG4gICAgICAgIHNlc3Npb25NYW5hZ2VtZW50LmNsZWFudXBTZXNzaW9uRGF0YUZvclRyYW5zcG9ydCh0aGlzKTtcbiAgICAgICAgcmV0dXJuIChvcmlnaW5hbE9uQ2xvc2UgKS5jYWxsKHRoaXMsIC4uLmFyZ3MpO1xuICAgICAgfTtcbiAgICB9KTtcbiAgfVxufVxuXG4vKipcbiAqIFdyYXBzIHRyYW5zcG9ydCBlcnJvciBoYW5kbGVycyB0byBjYXB0dXJlIGNvbm5lY3Rpb24gZXJyb3JzXG4gKiBAcGFyYW0gdHJhbnNwb3J0IC0gTUNQIHRyYW5zcG9ydCBpbnN0YW5jZSB0byB3cmFwXG4gKi9cbmZ1bmN0aW9uIHdyYXBUcmFuc3BvcnRFcnJvcih0cmFuc3BvcnQpIHtcbiAgaWYgKHRyYW5zcG9ydC5vbmVycm9yKSB7XG4gICAgb2JqZWN0LmZpbGwodHJhbnNwb3J0LCAnb25lcnJvcicsIChvcmlnaW5hbE9uRXJyb3IpID0+IHtcbiAgICAgIHJldHVybiBmdW5jdGlvbiAoIGVycm9yKSB7XG4gICAgICAgIGNhcHR1cmVUcmFuc3BvcnRFcnJvcihlcnJvcik7XG4gICAgICAgIHJldHVybiBvcmlnaW5hbE9uRXJyb3IuY2FsbCh0aGlzLCBlcnJvcik7XG4gICAgICB9O1xuICAgIH0pO1xuICB9XG59XG5cbi8qKlxuICogQ2FwdHVyZXMgSlNPTi1SUEMgZXJyb3IgcmVzcG9uc2VzIGZvciBzZXJ2ZXItc2lkZSBlcnJvcnMuXG4gKiBAc2VlIGh0dHBzOi8vd3d3Lmpzb25ycGMub3JnL3NwZWNpZmljYXRpb24jZXJyb3Jfb2JqZWN0XG4gKiBAaW50ZXJuYWxcbiAqIEBwYXJhbSBlcnJvclJlc3BvbnNlIC0gSlNPTi1SUEMgZXJyb3IgcmVzcG9uc2VcbiAqL1xuZnVuY3Rpb24gY2FwdHVyZUpzb25ScGNFcnJvclJlc3BvbnNlKGVycm9yUmVzcG9uc2UpIHtcbiAgdHJ5IHtcbiAgICBpZiAoZXJyb3JSZXNwb25zZSAmJiB0eXBlb2YgZXJyb3JSZXNwb25zZSA9PT0gJ29iamVjdCcgJiYgJ2NvZGUnIGluIGVycm9yUmVzcG9uc2UgJiYgJ21lc3NhZ2UnIGluIGVycm9yUmVzcG9uc2UpIHtcbiAgICAgIGNvbnN0IGpzb25ScGNFcnJvciA9IGVycm9yUmVzcG9uc2UgO1xuXG4gICAgICBjb25zdCBpc1NlcnZlckVycm9yID1cbiAgICAgICAganNvblJwY0Vycm9yLmNvZGUgPT09IC0zMjYwMyB8fCAoanNvblJwY0Vycm9yLmNvZGUgPj0gLTMyMDk5ICYmIGpzb25ScGNFcnJvci5jb2RlIDw9IC0zMjAwMCk7XG5cbiAgICAgIGlmIChpc1NlcnZlckVycm9yKSB7XG4gICAgICAgIGNvbnN0IGVycm9yID0gbmV3IEVycm9yKGpzb25ScGNFcnJvci5tZXNzYWdlKTtcbiAgICAgICAgZXJyb3IubmFtZSA9IGBKc29uUnBjRXJyb3JfJHtqc29uUnBjRXJyb3IuY29kZX1gO1xuXG4gICAgICAgIGVycm9yQ2FwdHVyZS5jYXB0dXJlRXJyb3IoZXJyb3IsICdwcm90b2NvbCcpO1xuICAgICAgfVxuICAgIH1cbiAgfSBjYXRjaCB7XG4gICAgLy8gbm9vcFxuICB9XG59XG5cbi8qKlxuICogQ2FwdHVyZXMgdHJhbnNwb3J0IGNvbm5lY3Rpb24gZXJyb3JzXG4gKiBAaW50ZXJuYWxcbiAqIEBwYXJhbSBlcnJvciAtIFRyYW5zcG9ydCBlcnJvclxuICovXG5mdW5jdGlvbiBjYXB0dXJlVHJhbnNwb3J0RXJyb3IoZXJyb3IpIHtcbiAgdHJ5IHtcbiAgICBlcnJvckNhcHR1cmUuY2FwdHVyZUVycm9yKGVycm9yLCAndHJhbnNwb3J0Jyk7XG4gIH0gY2F0Y2gge1xuICAgIC8vIG5vb3BcbiAgfVxufVxuXG5leHBvcnRzLndyYXBUcmFuc3BvcnRFcnJvciA9IHdyYXBUcmFuc3BvcnRFcnJvcjtcbmV4cG9ydHMud3JhcFRyYW5zcG9ydE9uQ2xvc2UgPSB3cmFwVHJhbnNwb3J0T25DbG9zZTtcbmV4cG9ydHMud3JhcFRyYW5zcG9ydE9uTWVzc2FnZSA9IHdyYXBUcmFuc3BvcnRPbk1lc3NhZ2U7XG5leHBvcnRzLndyYXBUcmFuc3BvcnRTZW5kID0gd3JhcFRyYW5zcG9ydFNlbmQ7XG4vLyMgc291cmNlTWFwcGluZ1VSTD10cmFuc3BvcnQuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/transport.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/validation.js":
/*!**************************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/validation.js ***!
  \**************************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst debugBuild = __webpack_require__(/*! ../../debug-build.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst debugLogger = __webpack_require__(/*! ../../utils/debug-logger.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\n\n/**\n * Message validation functions for MCP server instrumentation\n *\n * Provides JSON-RPC 2.0 message type validation and MCP server instance validation.\n */\n\n\n/**\n * Validates if a message is a JSON-RPC request\n * @param message - Message to validate\n * @returns True if message is a JSON-RPC request\n */\nfunction isJsonRpcRequest(message) {\n  return (\n    typeof message === 'object' &&\n    message !== null &&\n    'jsonrpc' in message &&\n    (message ).jsonrpc === '2.0' &&\n    'method' in message &&\n    'id' in message\n  );\n}\n\n/**\n * Validates if a message is a JSON-RPC notification\n * @param message - Message to validate\n * @returns True if message is a JSON-RPC notification\n */\nfunction isJsonRpcNotification(message) {\n  return (\n    typeof message === 'object' &&\n    message !== null &&\n    'jsonrpc' in message &&\n    (message ).jsonrpc === '2.0' &&\n    'method' in message &&\n    !('id' in message)\n  );\n}\n\n/**\n * Validates if a message is a JSON-RPC response\n * @param message - Message to validate\n * @returns True if message is a JSON-RPC response\n */\nfunction isJsonRpcResponse(message) {\n  return (\n    typeof message === 'object' &&\n    message !== null &&\n    'jsonrpc' in message &&\n    (message ).jsonrpc === '2.0' &&\n    'id' in message &&\n    ('result' in message || 'error' in message)\n  );\n}\n\n/**\n * Validates MCP server instance with type checking\n * @param instance - Object to validate as MCP server instance\n * @returns True if instance has required MCP server methods\n */\nfunction validateMcpServerInstance(instance) {\n  if (\n    typeof instance === 'object' &&\n    instance !== null &&\n    'resource' in instance &&\n    'tool' in instance &&\n    'prompt' in instance &&\n    'connect' in instance\n  ) {\n    return true;\n  }\n  debugBuild.DEBUG_BUILD && debugLogger.debug.warn('Did not patch MCP server. Interface is incompatible.');\n  return false;\n}\n\n/**\n * Check if the item is a valid content item\n * @param item - The item to check\n * @returns True if the item is a valid content item, false otherwise\n */\nfunction isValidContentItem(item) {\n  return item != null && typeof item === 'object';\n}\n\nexports.isJsonRpcNotification = isJsonRpcNotification;\nexports.isJsonRpcRequest = isJsonRpcRequest;\nexports.isJsonRpcResponse = isJsonRpcResponse;\nexports.isValidContentItem = isValidContentItem;\nexports.validateMcpServerInstance = validateMcpServerInstance;\n//# sourceMappingURL=validation.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvbWNwLXNlcnZlci92YWxpZGF0aW9uLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLG1CQUFtQixtQkFBTyxDQUFDLCtIQUFzQjtBQUNqRCxvQkFBb0IsbUJBQU8sQ0FBQyw2SUFBNkI7O0FBRXpEO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7OztBQUdBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsNkJBQTZCO0FBQzdCLHdCQUF3QjtBQUN4Qix5QkFBeUI7QUFDekIsMEJBQTBCO0FBQzFCLGlDQUFpQztBQUNqQyIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL2ludGVncmF0aW9ucy9tY3Atc2VydmVyL3ZhbGlkYXRpb24uanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGRlYnVnQnVpbGQgPSByZXF1aXJlKCcuLi8uLi9kZWJ1Zy1idWlsZC5qcycpO1xuY29uc3QgZGVidWdMb2dnZXIgPSByZXF1aXJlKCcuLi8uLi91dGlscy9kZWJ1Zy1sb2dnZXIuanMnKTtcblxuLyoqXG4gKiBNZXNzYWdlIHZhbGlkYXRpb24gZnVuY3Rpb25zIGZvciBNQ1Agc2VydmVyIGluc3RydW1lbnRhdGlvblxuICpcbiAqIFByb3ZpZGVzIEpTT04tUlBDIDIuMCBtZXNzYWdlIHR5cGUgdmFsaWRhdGlvbiBhbmQgTUNQIHNlcnZlciBpbnN0YW5jZSB2YWxpZGF0aW9uLlxuICovXG5cblxuLyoqXG4gKiBWYWxpZGF0ZXMgaWYgYSBtZXNzYWdlIGlzIGEgSlNPTi1SUEMgcmVxdWVzdFxuICogQHBhcmFtIG1lc3NhZ2UgLSBNZXNzYWdlIHRvIHZhbGlkYXRlXG4gKiBAcmV0dXJucyBUcnVlIGlmIG1lc3NhZ2UgaXMgYSBKU09OLVJQQyByZXF1ZXN0XG4gKi9cbmZ1bmN0aW9uIGlzSnNvblJwY1JlcXVlc3QobWVzc2FnZSkge1xuICByZXR1cm4gKFxuICAgIHR5cGVvZiBtZXNzYWdlID09PSAnb2JqZWN0JyAmJlxuICAgIG1lc3NhZ2UgIT09IG51bGwgJiZcbiAgICAnanNvbnJwYycgaW4gbWVzc2FnZSAmJlxuICAgIChtZXNzYWdlICkuanNvbnJwYyA9PT0gJzIuMCcgJiZcbiAgICAnbWV0aG9kJyBpbiBtZXNzYWdlICYmXG4gICAgJ2lkJyBpbiBtZXNzYWdlXG4gICk7XG59XG5cbi8qKlxuICogVmFsaWRhdGVzIGlmIGEgbWVzc2FnZSBpcyBhIEpTT04tUlBDIG5vdGlmaWNhdGlvblxuICogQHBhcmFtIG1lc3NhZ2UgLSBNZXNzYWdlIHRvIHZhbGlkYXRlXG4gKiBAcmV0dXJucyBUcnVlIGlmIG1lc3NhZ2UgaXMgYSBKU09OLVJQQyBub3RpZmljYXRpb25cbiAqL1xuZnVuY3Rpb24gaXNKc29uUnBjTm90aWZpY2F0aW9uKG1lc3NhZ2UpIHtcbiAgcmV0dXJuIChcbiAgICB0eXBlb2YgbWVzc2FnZSA9PT0gJ29iamVjdCcgJiZcbiAgICBtZXNzYWdlICE9PSBudWxsICYmXG4gICAgJ2pzb25ycGMnIGluIG1lc3NhZ2UgJiZcbiAgICAobWVzc2FnZSApLmpzb25ycGMgPT09ICcyLjAnICYmXG4gICAgJ21ldGhvZCcgaW4gbWVzc2FnZSAmJlxuICAgICEoJ2lkJyBpbiBtZXNzYWdlKVxuICApO1xufVxuXG4vKipcbiAqIFZhbGlkYXRlcyBpZiBhIG1lc3NhZ2UgaXMgYSBKU09OLVJQQyByZXNwb25zZVxuICogQHBhcmFtIG1lc3NhZ2UgLSBNZXNzYWdlIHRvIHZhbGlkYXRlXG4gKiBAcmV0dXJucyBUcnVlIGlmIG1lc3NhZ2UgaXMgYSBKU09OLVJQQyByZXNwb25zZVxuICovXG5mdW5jdGlvbiBpc0pzb25ScGNSZXNwb25zZShtZXNzYWdlKSB7XG4gIHJldHVybiAoXG4gICAgdHlwZW9mIG1lc3NhZ2UgPT09ICdvYmplY3QnICYmXG4gICAgbWVzc2FnZSAhPT0gbnVsbCAmJlxuICAgICdqc29ucnBjJyBpbiBtZXNzYWdlICYmXG4gICAgKG1lc3NhZ2UgKS5qc29ucnBjID09PSAnMi4wJyAmJlxuICAgICdpZCcgaW4gbWVzc2FnZSAmJlxuICAgICgncmVzdWx0JyBpbiBtZXNzYWdlIHx8ICdlcnJvcicgaW4gbWVzc2FnZSlcbiAgKTtcbn1cblxuLyoqXG4gKiBWYWxpZGF0ZXMgTUNQIHNlcnZlciBpbnN0YW5jZSB3aXRoIHR5cGUgY2hlY2tpbmdcbiAqIEBwYXJhbSBpbnN0YW5jZSAtIE9iamVjdCB0byB2YWxpZGF0ZSBhcyBNQ1Agc2VydmVyIGluc3RhbmNlXG4gKiBAcmV0dXJucyBUcnVlIGlmIGluc3RhbmNlIGhhcyByZXF1aXJlZCBNQ1Agc2VydmVyIG1ldGhvZHNcbiAqL1xuZnVuY3Rpb24gdmFsaWRhdGVNY3BTZXJ2ZXJJbnN0YW5jZShpbnN0YW5jZSkge1xuICBpZiAoXG4gICAgdHlwZW9mIGluc3RhbmNlID09PSAnb2JqZWN0JyAmJlxuICAgIGluc3RhbmNlICE9PSBudWxsICYmXG4gICAgJ3Jlc291cmNlJyBpbiBpbnN0YW5jZSAmJlxuICAgICd0b29sJyBpbiBpbnN0YW5jZSAmJlxuICAgICdwcm9tcHQnIGluIGluc3RhbmNlICYmXG4gICAgJ2Nvbm5lY3QnIGluIGluc3RhbmNlXG4gICkge1xuICAgIHJldHVybiB0cnVlO1xuICB9XG4gIGRlYnVnQnVpbGQuREVCVUdfQlVJTEQgJiYgZGVidWdMb2dnZXIuZGVidWcud2FybignRGlkIG5vdCBwYXRjaCBNQ1Agc2VydmVyLiBJbnRlcmZhY2UgaXMgaW5jb21wYXRpYmxlLicpO1xuICByZXR1cm4gZmFsc2U7XG59XG5cbi8qKlxuICogQ2hlY2sgaWYgdGhlIGl0ZW0gaXMgYSB2YWxpZCBjb250ZW50IGl0ZW1cbiAqIEBwYXJhbSBpdGVtIC0gVGhlIGl0ZW0gdG8gY2hlY2tcbiAqIEByZXR1cm5zIFRydWUgaWYgdGhlIGl0ZW0gaXMgYSB2YWxpZCBjb250ZW50IGl0ZW0sIGZhbHNlIG90aGVyd2lzZVxuICovXG5mdW5jdGlvbiBpc1ZhbGlkQ29udGVudEl0ZW0oaXRlbSkge1xuICByZXR1cm4gaXRlbSAhPSBudWxsICYmIHR5cGVvZiBpdGVtID09PSAnb2JqZWN0Jztcbn1cblxuZXhwb3J0cy5pc0pzb25ScGNOb3RpZmljYXRpb24gPSBpc0pzb25ScGNOb3RpZmljYXRpb247XG5leHBvcnRzLmlzSnNvblJwY1JlcXVlc3QgPSBpc0pzb25ScGNSZXF1ZXN0O1xuZXhwb3J0cy5pc0pzb25ScGNSZXNwb25zZSA9IGlzSnNvblJwY1Jlc3BvbnNlO1xuZXhwb3J0cy5pc1ZhbGlkQ29udGVudEl0ZW0gPSBpc1ZhbGlkQ29udGVudEl0ZW07XG5leHBvcnRzLnZhbGlkYXRlTWNwU2VydmVySW5zdGFuY2UgPSB2YWxpZGF0ZU1jcFNlcnZlckluc3RhbmNlO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9dmFsaWRhdGlvbi5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/validation.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/metadata.js":
/*!*************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/metadata.js ***!
  \*************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst integration = __webpack_require__(/*! ../integration.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integration.js\");\nconst metadata = __webpack_require__(/*! ../metadata.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/metadata.js\");\nconst envelope = __webpack_require__(/*! ../utils/envelope.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/envelope.js\");\n\n/**\n * Adds module metadata to stack frames.\n *\n * Metadata can be injected by the Sentry bundler plugins using the `moduleMetadata` config option.\n *\n * When this integration is added, the metadata passed to the bundler plugin is added to the stack frames of all events\n * under the `module_metadata` property. This can be used to help in tagging or routing of events from different teams\n * our sources\n */\nconst moduleMetadataIntegration = integration.defineIntegration(() => {\n  return {\n    name: 'ModuleMetadata',\n    setup(client) {\n      // We need to strip metadata from stack frames before sending them to Sentry since these are client side only.\n      client.on('beforeEnvelope', envelope$1 => {\n        envelope.forEachEnvelopeItem(envelope$1, (item, type) => {\n          if (type === 'event') {\n            const event = Array.isArray(item) ? (item )[1] : undefined;\n\n            if (event) {\n              metadata.stripMetadataFromStackFrames(event);\n              item[1] = event;\n            }\n          }\n        });\n      });\n\n      client.on('applyFrameMetadata', event => {\n        // Only apply stack frame metadata to error events\n        if (event.type) {\n          return;\n        }\n\n        const stackParser = client.getOptions().stackParser;\n        metadata.addMetadataToStackFrames(stackParser, event);\n      });\n    },\n  };\n});\n\nexports.moduleMetadataIntegration = moduleMetadataIntegration;\n//# sourceMappingURL=metadata.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvbWV0YWRhdGEuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsb0JBQW9CLG1CQUFPLENBQUMsNEhBQW1CO0FBQy9DLGlCQUFpQixtQkFBTyxDQUFDLHNIQUFnQjtBQUN6QyxpQkFBaUIsbUJBQU8sQ0FBQyxrSUFBc0I7O0FBRS9DO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsU0FBUztBQUNULE9BQU87O0FBRVA7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsT0FBTztBQUNQLEtBQUs7QUFDTDtBQUNBLENBQUM7O0FBRUQsaUNBQWlDO0FBQ2pDIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvaW50ZWdyYXRpb25zL21ldGFkYXRhLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBpbnRlZ3JhdGlvbiA9IHJlcXVpcmUoJy4uL2ludGVncmF0aW9uLmpzJyk7XG5jb25zdCBtZXRhZGF0YSA9IHJlcXVpcmUoJy4uL21ldGFkYXRhLmpzJyk7XG5jb25zdCBlbnZlbG9wZSA9IHJlcXVpcmUoJy4uL3V0aWxzL2VudmVsb3BlLmpzJyk7XG5cbi8qKlxuICogQWRkcyBtb2R1bGUgbWV0YWRhdGEgdG8gc3RhY2sgZnJhbWVzLlxuICpcbiAqIE1ldGFkYXRhIGNhbiBiZSBpbmplY3RlZCBieSB0aGUgU2VudHJ5IGJ1bmRsZXIgcGx1Z2lucyB1c2luZyB0aGUgYG1vZHVsZU1ldGFkYXRhYCBjb25maWcgb3B0aW9uLlxuICpcbiAqIFdoZW4gdGhpcyBpbnRlZ3JhdGlvbiBpcyBhZGRlZCwgdGhlIG1ldGFkYXRhIHBhc3NlZCB0byB0aGUgYnVuZGxlciBwbHVnaW4gaXMgYWRkZWQgdG8gdGhlIHN0YWNrIGZyYW1lcyBvZiBhbGwgZXZlbnRzXG4gKiB1bmRlciB0aGUgYG1vZHVsZV9tZXRhZGF0YWAgcHJvcGVydHkuIFRoaXMgY2FuIGJlIHVzZWQgdG8gaGVscCBpbiB0YWdnaW5nIG9yIHJvdXRpbmcgb2YgZXZlbnRzIGZyb20gZGlmZmVyZW50IHRlYW1zXG4gKiBvdXIgc291cmNlc1xuICovXG5jb25zdCBtb2R1bGVNZXRhZGF0YUludGVncmF0aW9uID0gaW50ZWdyYXRpb24uZGVmaW5lSW50ZWdyYXRpb24oKCkgPT4ge1xuICByZXR1cm4ge1xuICAgIG5hbWU6ICdNb2R1bGVNZXRhZGF0YScsXG4gICAgc2V0dXAoY2xpZW50KSB7XG4gICAgICAvLyBXZSBuZWVkIHRvIHN0cmlwIG1ldGFkYXRhIGZyb20gc3RhY2sgZnJhbWVzIGJlZm9yZSBzZW5kaW5nIHRoZW0gdG8gU2VudHJ5IHNpbmNlIHRoZXNlIGFyZSBjbGllbnQgc2lkZSBvbmx5LlxuICAgICAgY2xpZW50Lm9uKCdiZWZvcmVFbnZlbG9wZScsIGVudmVsb3BlJDEgPT4ge1xuICAgICAgICBlbnZlbG9wZS5mb3JFYWNoRW52ZWxvcGVJdGVtKGVudmVsb3BlJDEsIChpdGVtLCB0eXBlKSA9PiB7XG4gICAgICAgICAgaWYgKHR5cGUgPT09ICdldmVudCcpIHtcbiAgICAgICAgICAgIGNvbnN0IGV2ZW50ID0gQXJyYXkuaXNBcnJheShpdGVtKSA/IChpdGVtIClbMV0gOiB1bmRlZmluZWQ7XG5cbiAgICAgICAgICAgIGlmIChldmVudCkge1xuICAgICAgICAgICAgICBtZXRhZGF0YS5zdHJpcE1ldGFkYXRhRnJvbVN0YWNrRnJhbWVzKGV2ZW50KTtcbiAgICAgICAgICAgICAgaXRlbVsxXSA9IGV2ZW50O1xuICAgICAgICAgICAgfVxuICAgICAgICAgIH1cbiAgICAgICAgfSk7XG4gICAgICB9KTtcblxuICAgICAgY2xpZW50Lm9uKCdhcHBseUZyYW1lTWV0YWRhdGEnLCBldmVudCA9PiB7XG4gICAgICAgIC8vIE9ubHkgYXBwbHkgc3RhY2sgZnJhbWUgbWV0YWRhdGEgdG8gZXJyb3IgZXZlbnRzXG4gICAgICAgIGlmIChldmVudC50eXBlKSB7XG4gICAgICAgICAgcmV0dXJuO1xuICAgICAgICB9XG5cbiAgICAgICAgY29uc3Qgc3RhY2tQYXJzZXIgPSBjbGllbnQuZ2V0T3B0aW9ucygpLnN0YWNrUGFyc2VyO1xuICAgICAgICBtZXRhZGF0YS5hZGRNZXRhZGF0YVRvU3RhY2tGcmFtZXMoc3RhY2tQYXJzZXIsIGV2ZW50KTtcbiAgICAgIH0pO1xuICAgIH0sXG4gIH07XG59KTtcblxuZXhwb3J0cy5tb2R1bGVNZXRhZGF0YUludGVncmF0aW9uID0gbW9kdWxlTWV0YWRhdGFJbnRlZ3JhdGlvbjtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPW1ldGFkYXRhLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/metadata.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/requestdata.js":
/*!****************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/requestdata.js ***!
  \****************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst integration = __webpack_require__(/*! ../integration.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integration.js\");\nconst cookie = __webpack_require__(/*! ../utils/cookie.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/cookie.js\");\nconst getIpAddress = __webpack_require__(/*! ../vendor/getIpAddress.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/vendor/getIpAddress.js\");\n\n// TODO(v10): Change defaults based on `sendDefaultPii`\nconst DEFAULT_INCLUDE = {\n  cookies: true,\n  data: true,\n  headers: true,\n  query_string: true,\n  url: true,\n};\n\nconst INTEGRATION_NAME = 'RequestData';\n\nconst _requestDataIntegration = ((options = {}) => {\n  const include = {\n    ...DEFAULT_INCLUDE,\n    ...options.include,\n  };\n\n  return {\n    name: INTEGRATION_NAME,\n    processEvent(event, _hint, client) {\n      const { sdkProcessingMetadata = {} } = event;\n      const { normalizedRequest, ipAddress } = sdkProcessingMetadata;\n\n      const includeWithDefaultPiiApplied = {\n        ...include,\n        ip: include.ip ?? client.getOptions().sendDefaultPii,\n      };\n\n      if (normalizedRequest) {\n        addNormalizedRequestDataToEvent(event, normalizedRequest, { ipAddress }, includeWithDefaultPiiApplied);\n      }\n\n      return event;\n    },\n  };\n}) ;\n\n/**\n * Add data about a request to an event. Primarily for use in Node-based SDKs, but included in `@sentry/core`\n * so it can be used in cross-platform SDKs like `@sentry/nextjs`.\n */\nconst requestDataIntegration = integration.defineIntegration(_requestDataIntegration);\n\n/**\n * Add already normalized request data to an event.\n * This mutates the passed in event.\n */\nfunction addNormalizedRequestDataToEvent(\n  event,\n  req,\n  // Data that should not go into `event.request` but is somehow related to requests\n  additionalData,\n  include,\n) {\n  event.request = {\n    ...event.request,\n    ...extractNormalizedRequestData(req, include),\n  };\n\n  if (include.ip) {\n    const ip = (req.headers && getIpAddress.getClientIPAddress(req.headers)) || additionalData.ipAddress;\n    if (ip) {\n      event.user = {\n        ...event.user,\n        ip_address: ip,\n      };\n    }\n  }\n}\n\nfunction extractNormalizedRequestData(\n  normalizedRequest,\n  include,\n) {\n  const requestData = {};\n  const headers = { ...normalizedRequest.headers };\n\n  if (include.headers) {\n    requestData.headers = headers;\n\n    // Remove the Cookie header in case cookie data should not be included in the event\n    if (!include.cookies) {\n      delete (headers ).cookie;\n    }\n\n    // Remove IP headers in case IP data should not be included in the event\n    if (!include.ip) {\n      getIpAddress.ipHeaderNames.forEach(ipHeaderName => {\n        // eslint-disable-next-line @typescript-eslint/no-dynamic-delete\n        delete (headers )[ipHeaderName];\n      });\n    }\n  }\n\n  requestData.method = normalizedRequest.method;\n\n  if (include.url) {\n    requestData.url = normalizedRequest.url;\n  }\n\n  if (include.cookies) {\n    const cookies = normalizedRequest.cookies || (headers?.cookie ? cookie.parseCookie(headers.cookie) : undefined);\n    requestData.cookies = cookies || {};\n  }\n\n  if (include.query_string) {\n    requestData.query_string = normalizedRequest.query_string;\n  }\n\n  if (include.data) {\n    requestData.data = normalizedRequest.data;\n  }\n\n  return requestData;\n}\n\nexports.requestDataIntegration = requestDataIntegration;\n//# sourceMappingURL=requestdata.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvcmVxdWVzdGRhdGEuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsb0JBQW9CLG1CQUFPLENBQUMsNEhBQW1CO0FBQy9DLGVBQWUsbUJBQU8sQ0FBQyw4SEFBb0I7QUFDM0MscUJBQXFCLG1CQUFPLENBQUMsNElBQTJCOztBQUV4RDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBOztBQUVBLDhDQUE4QztBQUM5QztBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQSxjQUFjLDZCQUE2QjtBQUMzQyxjQUFjLCtCQUErQjs7QUFFN0M7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQSxvRUFBb0UsV0FBVztBQUMvRTs7QUFFQTtBQUNBLEtBQUs7QUFDTDtBQUNBLENBQUM7O0FBRUQ7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLG9CQUFvQjs7QUFFcEI7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsT0FBTztBQUNQO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQSw4QkFBOEI7QUFDOUIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvcmVxdWVzdGRhdGEuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGludGVncmF0aW9uID0gcmVxdWlyZSgnLi4vaW50ZWdyYXRpb24uanMnKTtcbmNvbnN0IGNvb2tpZSA9IHJlcXVpcmUoJy4uL3V0aWxzL2Nvb2tpZS5qcycpO1xuY29uc3QgZ2V0SXBBZGRyZXNzID0gcmVxdWlyZSgnLi4vdmVuZG9yL2dldElwQWRkcmVzcy5qcycpO1xuXG4vLyBUT0RPKHYxMCk6IENoYW5nZSBkZWZhdWx0cyBiYXNlZCBvbiBgc2VuZERlZmF1bHRQaWlgXG5jb25zdCBERUZBVUxUX0lOQ0xVREUgPSB7XG4gIGNvb2tpZXM6IHRydWUsXG4gIGRhdGE6IHRydWUsXG4gIGhlYWRlcnM6IHRydWUsXG4gIHF1ZXJ5X3N0cmluZzogdHJ1ZSxcbiAgdXJsOiB0cnVlLFxufTtcblxuY29uc3QgSU5URUdSQVRJT05fTkFNRSA9ICdSZXF1ZXN0RGF0YSc7XG5cbmNvbnN0IF9yZXF1ZXN0RGF0YUludGVncmF0aW9uID0gKChvcHRpb25zID0ge30pID0+IHtcbiAgY29uc3QgaW5jbHVkZSA9IHtcbiAgICAuLi5ERUZBVUxUX0lOQ0xVREUsXG4gICAgLi4ub3B0aW9ucy5pbmNsdWRlLFxuICB9O1xuXG4gIHJldHVybiB7XG4gICAgbmFtZTogSU5URUdSQVRJT05fTkFNRSxcbiAgICBwcm9jZXNzRXZlbnQoZXZlbnQsIF9oaW50LCBjbGllbnQpIHtcbiAgICAgIGNvbnN0IHsgc2RrUHJvY2Vzc2luZ01ldGFkYXRhID0ge30gfSA9IGV2ZW50O1xuICAgICAgY29uc3QgeyBub3JtYWxpemVkUmVxdWVzdCwgaXBBZGRyZXNzIH0gPSBzZGtQcm9jZXNzaW5nTWV0YWRhdGE7XG5cbiAgICAgIGNvbnN0IGluY2x1ZGVXaXRoRGVmYXVsdFBpaUFwcGxpZWQgPSB7XG4gICAgICAgIC4uLmluY2x1ZGUsXG4gICAgICAgIGlwOiBpbmNsdWRlLmlwID8/IGNsaWVudC5nZXRPcHRpb25zKCkuc2VuZERlZmF1bHRQaWksXG4gICAgICB9O1xuXG4gICAgICBpZiAobm9ybWFsaXplZFJlcXVlc3QpIHtcbiAgICAgICAgYWRkTm9ybWFsaXplZFJlcXVlc3REYXRhVG9FdmVudChldmVudCwgbm9ybWFsaXplZFJlcXVlc3QsIHsgaXBBZGRyZXNzIH0sIGluY2x1ZGVXaXRoRGVmYXVsdFBpaUFwcGxpZWQpO1xuICAgICAgfVxuXG4gICAgICByZXR1cm4gZXZlbnQ7XG4gICAgfSxcbiAgfTtcbn0pIDtcblxuLyoqXG4gKiBBZGQgZGF0YSBhYm91dCBhIHJlcXVlc3QgdG8gYW4gZXZlbnQuIFByaW1hcmlseSBmb3IgdXNlIGluIE5vZGUtYmFzZWQgU0RLcywgYnV0IGluY2x1ZGVkIGluIGBAc2VudHJ5L2NvcmVgXG4gKiBzbyBpdCBjYW4gYmUgdXNlZCBpbiBjcm9zcy1wbGF0Zm9ybSBTREtzIGxpa2UgYEBzZW50cnkvbmV4dGpzYC5cbiAqL1xuY29uc3QgcmVxdWVzdERhdGFJbnRlZ3JhdGlvbiA9IGludGVncmF0aW9uLmRlZmluZUludGVncmF0aW9uKF9yZXF1ZXN0RGF0YUludGVncmF0aW9uKTtcblxuLyoqXG4gKiBBZGQgYWxyZWFkeSBub3JtYWxpemVkIHJlcXVlc3QgZGF0YSB0byBhbiBldmVudC5cbiAqIFRoaXMgbXV0YXRlcyB0aGUgcGFzc2VkIGluIGV2ZW50LlxuICovXG5mdW5jdGlvbiBhZGROb3JtYWxpemVkUmVxdWVzdERhdGFUb0V2ZW50KFxuICBldmVudCxcbiAgcmVxLFxuICAvLyBEYXRhIHRoYXQgc2hvdWxkIG5vdCBnbyBpbnRvIGBldmVudC5yZXF1ZXN0YCBidXQgaXMgc29tZWhvdyByZWxhdGVkIHRvIHJlcXVlc3RzXG4gIGFkZGl0aW9uYWxEYXRhLFxuICBpbmNsdWRlLFxuKSB7XG4gIGV2ZW50LnJlcXVlc3QgPSB7XG4gICAgLi4uZXZlbnQucmVxdWVzdCxcbiAgICAuLi5leHRyYWN0Tm9ybWFsaXplZFJlcXVlc3REYXRhKHJlcSwgaW5jbHVkZSksXG4gIH07XG5cbiAgaWYgKGluY2x1ZGUuaXApIHtcbiAgICBjb25zdCBpcCA9IChyZXEuaGVhZGVycyAmJiBnZXRJcEFkZHJlc3MuZ2V0Q2xpZW50SVBBZGRyZXNzKHJlcS5oZWFkZXJzKSkgfHwgYWRkaXRpb25hbERhdGEuaXBBZGRyZXNzO1xuICAgIGlmIChpcCkge1xuICAgICAgZXZlbnQudXNlciA9IHtcbiAgICAgICAgLi4uZXZlbnQudXNlcixcbiAgICAgICAgaXBfYWRkcmVzczogaXAsXG4gICAgICB9O1xuICAgIH1cbiAgfVxufVxuXG5mdW5jdGlvbiBleHRyYWN0Tm9ybWFsaXplZFJlcXVlc3REYXRhKFxuICBub3JtYWxpemVkUmVxdWVzdCxcbiAgaW5jbHVkZSxcbikge1xuICBjb25zdCByZXF1ZXN0RGF0YSA9IHt9O1xuICBjb25zdCBoZWFkZXJzID0geyAuLi5ub3JtYWxpemVkUmVxdWVzdC5oZWFkZXJzIH07XG5cbiAgaWYgKGluY2x1ZGUuaGVhZGVycykge1xuICAgIHJlcXVlc3REYXRhLmhlYWRlcnMgPSBoZWFkZXJzO1xuXG4gICAgLy8gUmVtb3ZlIHRoZSBDb29raWUgaGVhZGVyIGluIGNhc2UgY29va2llIGRhdGEgc2hvdWxkIG5vdCBiZSBpbmNsdWRlZCBpbiB0aGUgZXZlbnRcbiAgICBpZiAoIWluY2x1ZGUuY29va2llcykge1xuICAgICAgZGVsZXRlIChoZWFkZXJzICkuY29va2llO1xuICAgIH1cblxuICAgIC8vIFJlbW92ZSBJUCBoZWFkZXJzIGluIGNhc2UgSVAgZGF0YSBzaG91bGQgbm90IGJlIGluY2x1ZGVkIGluIHRoZSBldmVudFxuICAgIGlmICghaW5jbHVkZS5pcCkge1xuICAgICAgZ2V0SXBBZGRyZXNzLmlwSGVhZGVyTmFtZXMuZm9yRWFjaChpcEhlYWRlck5hbWUgPT4ge1xuICAgICAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25vLWR5bmFtaWMtZGVsZXRlXG4gICAgICAgIGRlbGV0ZSAoaGVhZGVycyApW2lwSGVhZGVyTmFtZV07XG4gICAgICB9KTtcbiAgICB9XG4gIH1cblxuICByZXF1ZXN0RGF0YS5tZXRob2QgPSBub3JtYWxpemVkUmVxdWVzdC5tZXRob2Q7XG5cbiAgaWYgKGluY2x1ZGUudXJsKSB7XG4gICAgcmVxdWVzdERhdGEudXJsID0gbm9ybWFsaXplZFJlcXVlc3QudXJsO1xuICB9XG5cbiAgaWYgKGluY2x1ZGUuY29va2llcykge1xuICAgIGNvbnN0IGNvb2tpZXMgPSBub3JtYWxpemVkUmVxdWVzdC5jb29raWVzIHx8IChoZWFkZXJzPy5jb29raWUgPyBjb29raWUucGFyc2VDb29raWUoaGVhZGVycy5jb29raWUpIDogdW5kZWZpbmVkKTtcbiAgICByZXF1ZXN0RGF0YS5jb29raWVzID0gY29va2llcyB8fCB7fTtcbiAgfVxuXG4gIGlmIChpbmNsdWRlLnF1ZXJ5X3N0cmluZykge1xuICAgIHJlcXVlc3REYXRhLnF1ZXJ5X3N0cmluZyA9IG5vcm1hbGl6ZWRSZXF1ZXN0LnF1ZXJ5X3N0cmluZztcbiAgfVxuXG4gIGlmIChpbmNsdWRlLmRhdGEpIHtcbiAgICByZXF1ZXN0RGF0YS5kYXRhID0gbm9ybWFsaXplZFJlcXVlc3QuZGF0YTtcbiAgfVxuXG4gIHJldHVybiByZXF1ZXN0RGF0YTtcbn1cblxuZXhwb3J0cy5yZXF1ZXN0RGF0YUludGVncmF0aW9uID0gcmVxdWVzdERhdGFJbnRlZ3JhdGlvbjtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPXJlcXVlc3RkYXRhLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/requestdata.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/rewriteframes.js":
/*!******************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/rewriteframes.js ***!
  \******************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst integration = __webpack_require__(/*! ../integration.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integration.js\");\nconst path = __webpack_require__(/*! ../utils/path.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/path.js\");\nconst worldwide = __webpack_require__(/*! ../utils/worldwide.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/worldwide.js\");\n\nconst INTEGRATION_NAME = 'RewriteFrames';\n\n/**\n * Rewrite event frames paths.\n */\nconst rewriteFramesIntegration = integration.defineIntegration((options = {}) => {\n  const root = options.root;\n  const prefix = options.prefix || 'app:///';\n\n  const isBrowser = 'window' in worldwide.GLOBAL_OBJ && !!worldwide.GLOBAL_OBJ.window;\n\n  const iteratee = options.iteratee || generateIteratee({ isBrowser, root, prefix });\n\n  /** Process an exception event. */\n  function _processExceptionsEvent(event) {\n    try {\n      return {\n        ...event,\n        exception: {\n          ...event.exception,\n          // The check for this is performed inside `process` call itself, safe to skip here\n          // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n          values: event.exception.values.map(value => ({\n            ...value,\n            ...(value.stacktrace && { stacktrace: _processStacktrace(value.stacktrace) }),\n          })),\n        },\n      };\n    } catch {\n      return event;\n    }\n  }\n\n  /** Process a stack trace. */\n  function _processStacktrace(stacktrace) {\n    return {\n      ...stacktrace,\n      frames: stacktrace?.frames?.map(f => iteratee(f)),\n    };\n  }\n\n  return {\n    name: INTEGRATION_NAME,\n    processEvent(originalEvent) {\n      let processedEvent = originalEvent;\n\n      if (originalEvent.exception && Array.isArray(originalEvent.exception.values)) {\n        processedEvent = _processExceptionsEvent(processedEvent);\n      }\n\n      return processedEvent;\n    },\n  };\n});\n\n/**\n * Exported only for tests.\n */\nfunction generateIteratee({\n  isBrowser,\n  root,\n  prefix,\n}\n\n) {\n  return (frame) => {\n    if (!frame.filename) {\n      return frame;\n    }\n\n    // Determine if this is a Windows frame by checking for a Windows-style prefix such as `C:\\`\n    const isWindowsFrame =\n      /^[a-zA-Z]:\\\\/.test(frame.filename) ||\n      // or the presence of a backslash without a forward slash (which are not allowed on Windows)\n      (frame.filename.includes('\\\\') && !frame.filename.includes('/'));\n\n    // Check if the frame filename begins with `/`\n    const startsWithSlash = /^\\//.test(frame.filename);\n\n    if (isBrowser) {\n      if (root) {\n        const oldFilename = frame.filename;\n        if (oldFilename.indexOf(root) === 0) {\n          frame.filename = oldFilename.replace(root, prefix);\n        }\n      }\n    } else {\n      if (isWindowsFrame || startsWithSlash) {\n        const filename = isWindowsFrame\n          ? frame.filename\n              .replace(/^[a-zA-Z]:/, '') // remove Windows-style prefix\n              .replace(/\\\\/g, '/') // replace all `\\\\` instances with `/`\n          : frame.filename;\n        const base = root ? path.relative(root, filename) : path.basename(filename);\n        frame.filename = `${prefix}${base}`;\n      }\n    }\n\n    return frame;\n  };\n}\n\nexports.generateIteratee = generateIteratee;\nexports.rewriteFramesIntegration = rewriteFramesIntegration;\n//# sourceMappingURL=rewriteframes.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvcmV3cml0ZWZyYW1lcy5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxvQkFBb0IsbUJBQU8sQ0FBQyw0SEFBbUI7QUFDL0MsYUFBYSxtQkFBTyxDQUFDLDBIQUFrQjtBQUN2QyxrQkFBa0IsbUJBQU8sQ0FBQyxvSUFBdUI7O0FBRWpEOztBQUVBO0FBQ0E7QUFDQTtBQUNBLDRFQUE0RTtBQUM1RTtBQUNBOztBQUVBOztBQUVBLDBEQUEwRCx5QkFBeUI7O0FBRW5GO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxzQ0FBc0Msa0RBQWtEO0FBQ3hGLFdBQVc7QUFDWCxTQUFTO0FBQ1Q7QUFDQSxNQUFNO0FBQ047QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBLEtBQUs7QUFDTDtBQUNBLENBQUM7O0FBRUQ7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLE1BQU07QUFDTjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLDRCQUE0QixPQUFPLEVBQUUsS0FBSztBQUMxQztBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQSx3QkFBd0I7QUFDeEIsZ0NBQWdDO0FBQ2hDIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvaW50ZWdyYXRpb25zL3Jld3JpdGVmcmFtZXMuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGludGVncmF0aW9uID0gcmVxdWlyZSgnLi4vaW50ZWdyYXRpb24uanMnKTtcbmNvbnN0IHBhdGggPSByZXF1aXJlKCcuLi91dGlscy9wYXRoLmpzJyk7XG5jb25zdCB3b3JsZHdpZGUgPSByZXF1aXJlKCcuLi91dGlscy93b3JsZHdpZGUuanMnKTtcblxuY29uc3QgSU5URUdSQVRJT05fTkFNRSA9ICdSZXdyaXRlRnJhbWVzJztcblxuLyoqXG4gKiBSZXdyaXRlIGV2ZW50IGZyYW1lcyBwYXRocy5cbiAqL1xuY29uc3QgcmV3cml0ZUZyYW1lc0ludGVncmF0aW9uID0gaW50ZWdyYXRpb24uZGVmaW5lSW50ZWdyYXRpb24oKG9wdGlvbnMgPSB7fSkgPT4ge1xuICBjb25zdCByb290ID0gb3B0aW9ucy5yb290O1xuICBjb25zdCBwcmVmaXggPSBvcHRpb25zLnByZWZpeCB8fCAnYXBwOi8vLyc7XG5cbiAgY29uc3QgaXNCcm93c2VyID0gJ3dpbmRvdycgaW4gd29ybGR3aWRlLkdMT0JBTF9PQkogJiYgISF3b3JsZHdpZGUuR0xPQkFMX09CSi53aW5kb3c7XG5cbiAgY29uc3QgaXRlcmF0ZWUgPSBvcHRpb25zLml0ZXJhdGVlIHx8IGdlbmVyYXRlSXRlcmF0ZWUoeyBpc0Jyb3dzZXIsIHJvb3QsIHByZWZpeCB9KTtcblxuICAvKiogUHJvY2VzcyBhbiBleGNlcHRpb24gZXZlbnQuICovXG4gIGZ1bmN0aW9uIF9wcm9jZXNzRXhjZXB0aW9uc0V2ZW50KGV2ZW50KSB7XG4gICAgdHJ5IHtcbiAgICAgIHJldHVybiB7XG4gICAgICAgIC4uLmV2ZW50LFxuICAgICAgICBleGNlcHRpb246IHtcbiAgICAgICAgICAuLi5ldmVudC5leGNlcHRpb24sXG4gICAgICAgICAgLy8gVGhlIGNoZWNrIGZvciB0aGlzIGlzIHBlcmZvcm1lZCBpbnNpZGUgYHByb2Nlc3NgIGNhbGwgaXRzZWxmLCBzYWZlIHRvIHNraXAgaGVyZVxuICAgICAgICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tbm9uLW51bGwtYXNzZXJ0aW9uXG4gICAgICAgICAgdmFsdWVzOiBldmVudC5leGNlcHRpb24udmFsdWVzLm1hcCh2YWx1ZSA9PiAoe1xuICAgICAgICAgICAgLi4udmFsdWUsXG4gICAgICAgICAgICAuLi4odmFsdWUuc3RhY2t0cmFjZSAmJiB7IHN0YWNrdHJhY2U6IF9wcm9jZXNzU3RhY2t0cmFjZSh2YWx1ZS5zdGFja3RyYWNlKSB9KSxcbiAgICAgICAgICB9KSksXG4gICAgICAgIH0sXG4gICAgICB9O1xuICAgIH0gY2F0Y2gge1xuICAgICAgcmV0dXJuIGV2ZW50O1xuICAgIH1cbiAgfVxuXG4gIC8qKiBQcm9jZXNzIGEgc3RhY2sgdHJhY2UuICovXG4gIGZ1bmN0aW9uIF9wcm9jZXNzU3RhY2t0cmFjZShzdGFja3RyYWNlKSB7XG4gICAgcmV0dXJuIHtcbiAgICAgIC4uLnN0YWNrdHJhY2UsXG4gICAgICBmcmFtZXM6IHN0YWNrdHJhY2U/LmZyYW1lcz8ubWFwKGYgPT4gaXRlcmF0ZWUoZikpLFxuICAgIH07XG4gIH1cblxuICByZXR1cm4ge1xuICAgIG5hbWU6IElOVEVHUkFUSU9OX05BTUUsXG4gICAgcHJvY2Vzc0V2ZW50KG9yaWdpbmFsRXZlbnQpIHtcbiAgICAgIGxldCBwcm9jZXNzZWRFdmVudCA9IG9yaWdpbmFsRXZlbnQ7XG5cbiAgICAgIGlmIChvcmlnaW5hbEV2ZW50LmV4Y2VwdGlvbiAmJiBBcnJheS5pc0FycmF5KG9yaWdpbmFsRXZlbnQuZXhjZXB0aW9uLnZhbHVlcykpIHtcbiAgICAgICAgcHJvY2Vzc2VkRXZlbnQgPSBfcHJvY2Vzc0V4Y2VwdGlvbnNFdmVudChwcm9jZXNzZWRFdmVudCk7XG4gICAgICB9XG5cbiAgICAgIHJldHVybiBwcm9jZXNzZWRFdmVudDtcbiAgICB9LFxuICB9O1xufSk7XG5cbi8qKlxuICogRXhwb3J0ZWQgb25seSBmb3IgdGVzdHMuXG4gKi9cbmZ1bmN0aW9uIGdlbmVyYXRlSXRlcmF0ZWUoe1xuICBpc0Jyb3dzZXIsXG4gIHJvb3QsXG4gIHByZWZpeCxcbn1cblxuKSB7XG4gIHJldHVybiAoZnJhbWUpID0+IHtcbiAgICBpZiAoIWZyYW1lLmZpbGVuYW1lKSB7XG4gICAgICByZXR1cm4gZnJhbWU7XG4gICAgfVxuXG4gICAgLy8gRGV0ZXJtaW5lIGlmIHRoaXMgaXMgYSBXaW5kb3dzIGZyYW1lIGJ5IGNoZWNraW5nIGZvciBhIFdpbmRvd3Mtc3R5bGUgcHJlZml4IHN1Y2ggYXMgYEM6XFxgXG4gICAgY29uc3QgaXNXaW5kb3dzRnJhbWUgPVxuICAgICAgL15bYS16QS1aXTpcXFxcLy50ZXN0KGZyYW1lLmZpbGVuYW1lKSB8fFxuICAgICAgLy8gb3IgdGhlIHByZXNlbmNlIG9mIGEgYmFja3NsYXNoIHdpdGhvdXQgYSBmb3J3YXJkIHNsYXNoICh3aGljaCBhcmUgbm90IGFsbG93ZWQgb24gV2luZG93cylcbiAgICAgIChmcmFtZS5maWxlbmFtZS5pbmNsdWRlcygnXFxcXCcpICYmICFmcmFtZS5maWxlbmFtZS5pbmNsdWRlcygnLycpKTtcblxuICAgIC8vIENoZWNrIGlmIHRoZSBmcmFtZSBmaWxlbmFtZSBiZWdpbnMgd2l0aCBgL2BcbiAgICBjb25zdCBzdGFydHNXaXRoU2xhc2ggPSAvXlxcLy8udGVzdChmcmFtZS5maWxlbmFtZSk7XG5cbiAgICBpZiAoaXNCcm93c2VyKSB7XG4gICAgICBpZiAocm9vdCkge1xuICAgICAgICBjb25zdCBvbGRGaWxlbmFtZSA9IGZyYW1lLmZpbGVuYW1lO1xuICAgICAgICBpZiAob2xkRmlsZW5hbWUuaW5kZXhPZihyb290KSA9PT0gMCkge1xuICAgICAgICAgIGZyYW1lLmZpbGVuYW1lID0gb2xkRmlsZW5hbWUucmVwbGFjZShyb290LCBwcmVmaXgpO1xuICAgICAgICB9XG4gICAgICB9XG4gICAgfSBlbHNlIHtcbiAgICAgIGlmIChpc1dpbmRvd3NGcmFtZSB8fCBzdGFydHNXaXRoU2xhc2gpIHtcbiAgICAgICAgY29uc3QgZmlsZW5hbWUgPSBpc1dpbmRvd3NGcmFtZVxuICAgICAgICAgID8gZnJhbWUuZmlsZW5hbWVcbiAgICAgICAgICAgICAgLnJlcGxhY2UoL15bYS16QS1aXTovLCAnJykgLy8gcmVtb3ZlIFdpbmRvd3Mtc3R5bGUgcHJlZml4XG4gICAgICAgICAgICAgIC5yZXBsYWNlKC9cXFxcL2csICcvJykgLy8gcmVwbGFjZSBhbGwgYFxcXFxgIGluc3RhbmNlcyB3aXRoIGAvYFxuICAgICAgICAgIDogZnJhbWUuZmlsZW5hbWU7XG4gICAgICAgIGNvbnN0IGJhc2UgPSByb290ID8gcGF0aC5yZWxhdGl2ZShyb290LCBmaWxlbmFtZSkgOiBwYXRoLmJhc2VuYW1lKGZpbGVuYW1lKTtcbiAgICAgICAgZnJhbWUuZmlsZW5hbWUgPSBgJHtwcmVmaXh9JHtiYXNlfWA7XG4gICAgICB9XG4gICAgfVxuXG4gICAgcmV0dXJuIGZyYW1lO1xuICB9O1xufVxuXG5leHBvcnRzLmdlbmVyYXRlSXRlcmF0ZWUgPSBnZW5lcmF0ZUl0ZXJhdGVlO1xuZXhwb3J0cy5yZXdyaXRlRnJhbWVzSW50ZWdyYXRpb24gPSByZXdyaXRlRnJhbWVzSW50ZWdyYXRpb247XG4vLyMgc291cmNlTWFwcGluZ1VSTD1yZXdyaXRlZnJhbWVzLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/rewriteframes.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/supabase.js":
/*!*************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/supabase.js ***!
  \*************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst breadcrumbs = __webpack_require__(/*! ../breadcrumbs.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/breadcrumbs.js\");\nconst debugBuild = __webpack_require__(/*! ../debug-build.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst exports$1 = __webpack_require__(/*! ../exports.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/exports.js\");\nconst integration = __webpack_require__(/*! ../integration.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integration.js\");\nconst semanticAttributes = __webpack_require__(/*! ../semanticAttributes.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/semanticAttributes.js\");\nconst debugLogger = __webpack_require__(/*! ../utils/debug-logger.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst is = __webpack_require__(/*! ../utils/is.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js\");\nconst spanstatus = __webpack_require__(/*! ../tracing/spanstatus.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/spanstatus.js\");\nconst trace = __webpack_require__(/*! ../tracing/trace.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/trace.js\");\n\n// Based on Kamil Ogórek's work on:\n// https://github.com/supabase-community/sentry-integration-js\n\n\nconst AUTH_OPERATIONS_TO_INSTRUMENT = [\n  'reauthenticate',\n  'signInAnonymously',\n  'signInWithOAuth',\n  'signInWithIdToken',\n  'signInWithOtp',\n  'signInWithPassword',\n  'signInWithSSO',\n  'signOut',\n  'signUp',\n  'verifyOtp',\n];\n\nconst AUTH_ADMIN_OPERATIONS_TO_INSTRUMENT = [\n  'createUser',\n  'deleteUser',\n  'listUsers',\n  'getUserById',\n  'updateUserById',\n  'inviteUserByEmail',\n];\n\nconst FILTER_MAPPINGS = {\n  eq: 'eq',\n  neq: 'neq',\n  gt: 'gt',\n  gte: 'gte',\n  lt: 'lt',\n  lte: 'lte',\n  like: 'like',\n  'like(all)': 'likeAllOf',\n  'like(any)': 'likeAnyOf',\n  ilike: 'ilike',\n  'ilike(all)': 'ilikeAllOf',\n  'ilike(any)': 'ilikeAnyOf',\n  is: 'is',\n  in: 'in',\n  cs: 'contains',\n  cd: 'containedBy',\n  sr: 'rangeGt',\n  nxl: 'rangeGte',\n  sl: 'rangeLt',\n  nxr: 'rangeLte',\n  adj: 'rangeAdjacent',\n  ov: 'overlaps',\n  fts: '',\n  plfts: 'plain',\n  phfts: 'phrase',\n  wfts: 'websearch',\n  not: 'not',\n};\n\nconst DB_OPERATIONS_TO_INSTRUMENT = ['select', 'insert', 'upsert', 'update', 'delete'];\n\nfunction markAsInstrumented(fn) {\n  try {\n    (fn ).__SENTRY_INSTRUMENTED__ = true;\n  } catch {\n    // ignore errors here\n  }\n}\n\nfunction isInstrumented(fn) {\n  try {\n    return (fn ).__SENTRY_INSTRUMENTED__;\n  } catch {\n    return false;\n  }\n}\n\n/**\n * Extracts the database operation type from the HTTP method and headers\n * @param method - The HTTP method of the request\n * @param headers - The request headers\n * @returns The database operation type ('select', 'insert', 'upsert', 'update', or 'delete')\n */\nfunction extractOperation(method, headers = {}) {\n  switch (method) {\n    case 'GET': {\n      return 'select';\n    }\n    case 'POST': {\n      if (headers['Prefer']?.includes('resolution=')) {\n        return 'upsert';\n      } else {\n        return 'insert';\n      }\n    }\n    case 'PATCH': {\n      return 'update';\n    }\n    case 'DELETE': {\n      return 'delete';\n    }\n    default: {\n      return '<unknown-op>';\n    }\n  }\n}\n\n/**\n * Translates Supabase filter parameters into readable method names for tracing\n * @param key - The filter key from the URL search parameters\n * @param query - The filter value from the URL search parameters\n * @returns A string representation of the filter as a method call\n */\nfunction translateFiltersIntoMethods(key, query) {\n  if (query === '' || query === '*') {\n    return 'select(*)';\n  }\n\n  if (key === 'select') {\n    return `select(${query})`;\n  }\n\n  if (key === 'or' || key.endsWith('.or')) {\n    return `${key}${query}`;\n  }\n\n  const [filter, ...value] = query.split('.');\n\n  let method;\n  // Handle optional `configPart` of the filter\n  if (filter?.startsWith('fts')) {\n    method = 'textSearch';\n  } else if (filter?.startsWith('plfts')) {\n    method = 'textSearch[plain]';\n  } else if (filter?.startsWith('phfts')) {\n    method = 'textSearch[phrase]';\n  } else if (filter?.startsWith('wfts')) {\n    method = 'textSearch[websearch]';\n  } else {\n    method = (filter && FILTER_MAPPINGS[filter ]) || 'filter';\n  }\n\n  return `${method}(${key}, ${value.join('.')})`;\n}\n\nfunction instrumentAuthOperation(operation, isAdmin = false) {\n  return new Proxy(operation, {\n    apply(target, thisArg, argumentsList) {\n      return trace.startSpan(\n        {\n          name: `auth ${isAdmin ? '(admin) ' : ''}${operation.name}`,\n          attributes: {\n            [semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_ORIGIN]: 'auto.db.supabase',\n            [semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_OP]: 'db',\n            'db.system': 'postgresql',\n            'db.operation': `auth.${isAdmin ? 'admin.' : ''}${operation.name}`,\n          },\n        },\n        span => {\n          return Reflect.apply(target, thisArg, argumentsList)\n            .then((res) => {\n              if (res && typeof res === 'object' && 'error' in res && res.error) {\n                span.setStatus({ code: spanstatus.SPAN_STATUS_ERROR });\n\n                exports$1.captureException(res.error, {\n                  mechanism: {\n                    handled: false,\n                  },\n                });\n              } else {\n                span.setStatus({ code: spanstatus.SPAN_STATUS_OK });\n              }\n\n              span.end();\n              return res;\n            })\n            .catch((err) => {\n              span.setStatus({ code: spanstatus.SPAN_STATUS_ERROR });\n              span.end();\n\n              exports$1.captureException(err, {\n                mechanism: {\n                  handled: false,\n                },\n              });\n\n              throw err;\n            })\n            .then(...argumentsList);\n        },\n      );\n    },\n  });\n}\n\nfunction instrumentSupabaseAuthClient(supabaseClientInstance) {\n  const auth = supabaseClientInstance.auth;\n\n  if (!auth || isInstrumented(supabaseClientInstance.auth)) {\n    return;\n  }\n\n  for (const operation of AUTH_OPERATIONS_TO_INSTRUMENT) {\n    const authOperation = auth[operation];\n\n    if (!authOperation) {\n      continue;\n    }\n\n    if (typeof supabaseClientInstance.auth[operation] === 'function') {\n      supabaseClientInstance.auth[operation] = instrumentAuthOperation(authOperation);\n    }\n  }\n\n  for (const operation of AUTH_ADMIN_OPERATIONS_TO_INSTRUMENT) {\n    const authOperation = auth.admin[operation];\n\n    if (!authOperation) {\n      continue;\n    }\n\n    if (typeof supabaseClientInstance.auth.admin[operation] === 'function') {\n      supabaseClientInstance.auth.admin[operation] = instrumentAuthOperation(authOperation, true);\n    }\n  }\n\n  markAsInstrumented(supabaseClientInstance.auth);\n}\n\nfunction instrumentSupabaseClientConstructor(SupabaseClient) {\n  if (isInstrumented((SupabaseClient ).prototype.from)) {\n    return;\n  }\n\n  (SupabaseClient ).prototype.from = new Proxy(\n    (SupabaseClient ).prototype.from,\n    {\n      apply(target, thisArg, argumentsList) {\n        const rv = Reflect.apply(target, thisArg, argumentsList);\n        const PostgRESTQueryBuilder = (rv ).constructor;\n\n        instrumentPostgRESTQueryBuilder(PostgRESTQueryBuilder );\n\n        return rv;\n      },\n    },\n  );\n\n  markAsInstrumented((SupabaseClient ).prototype.from);\n}\n\nfunction instrumentPostgRESTFilterBuilder(PostgRESTFilterBuilder) {\n  if (isInstrumented((PostgRESTFilterBuilder.prototype ).then)) {\n    return;\n  }\n\n  (PostgRESTFilterBuilder.prototype ).then = new Proxy(\n    (PostgRESTFilterBuilder.prototype ).then,\n    {\n      apply(target, thisArg, argumentsList) {\n        const operations = DB_OPERATIONS_TO_INSTRUMENT;\n        const typedThis = thisArg ;\n        const operation = extractOperation(typedThis.method, typedThis.headers);\n\n        if (!operations.includes(operation)) {\n          return Reflect.apply(target, thisArg, argumentsList);\n        }\n\n        if (!typedThis?.url?.pathname || typeof typedThis.url.pathname !== 'string') {\n          return Reflect.apply(target, thisArg, argumentsList);\n        }\n\n        const pathParts = typedThis.url.pathname.split('/');\n        const table = pathParts.length > 0 ? pathParts[pathParts.length - 1] : '';\n\n        const queryItems = [];\n        for (const [key, value] of typedThis.url.searchParams.entries()) {\n          // It's possible to have multiple entries for the same key, eg. `id=eq.7&id=eq.3`,\n          // so we need to use array instead of object to collect them.\n          queryItems.push(translateFiltersIntoMethods(key, value));\n        }\n        const body = Object.create(null);\n        if (is.isPlainObject(typedThis.body)) {\n          for (const [key, value] of Object.entries(typedThis.body)) {\n            body[key] = value;\n          }\n        }\n\n        // Adding operation to the beginning of the description if it's not a `select` operation\n        // For example, it can be an `insert` or `update` operation but the query can be `select(...)`\n        // For `select` operations, we don't need repeat it in the description\n        const description = `${operation === 'select' ? '' : `${operation}${body ? '(...) ' : ''}`}${queryItems.join(\n          ' ',\n        )} from(${table})`;\n\n        const attributes = {\n          'db.table': table,\n          'db.schema': typedThis.schema,\n          'db.url': typedThis.url.origin,\n          'db.sdk': typedThis.headers['X-Client-Info'],\n          'db.system': 'postgresql',\n          'db.operation': operation,\n          [semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_ORIGIN]: 'auto.db.supabase',\n          [semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_OP]: 'db',\n        };\n\n        if (queryItems.length) {\n          attributes['db.query'] = queryItems;\n        }\n\n        if (Object.keys(body).length) {\n          attributes['db.body'] = body;\n        }\n\n        return trace.startSpan(\n          {\n            name: description,\n            attributes,\n          },\n          span => {\n            return (Reflect.apply(target, thisArg, []) )\n              .then(\n                (res) => {\n                  if (span) {\n                    if (res && typeof res === 'object' && 'status' in res) {\n                      spanstatus.setHttpStatus(span, res.status || 500);\n                    }\n                    span.end();\n                  }\n\n                  if (res.error) {\n                    const err = new Error(res.error.message) ;\n                    if (res.error.code) {\n                      err.code = res.error.code;\n                    }\n                    if (res.error.details) {\n                      err.details = res.error.details;\n                    }\n\n                    const supabaseContext = {};\n                    if (queryItems.length) {\n                      supabaseContext.query = queryItems;\n                    }\n                    if (Object.keys(body).length) {\n                      supabaseContext.body = body;\n                    }\n\n                    exports$1.captureException(err, {\n                      contexts: {\n                        supabase: supabaseContext,\n                      },\n                    });\n                  }\n\n                  const breadcrumb = {\n                    type: 'supabase',\n                    category: `db.${operation}`,\n                    message: description,\n                  };\n\n                  const data = {};\n\n                  if (queryItems.length) {\n                    data.query = queryItems;\n                  }\n\n                  if (Object.keys(body).length) {\n                    data.body = body;\n                  }\n\n                  if (Object.keys(data).length) {\n                    breadcrumb.data = data;\n                  }\n\n                  breadcrumbs.addBreadcrumb(breadcrumb);\n\n                  return res;\n                },\n                (err) => {\n                  if (span) {\n                    spanstatus.setHttpStatus(span, 500);\n                    span.end();\n                  }\n                  throw err;\n                },\n              )\n              .then(...argumentsList);\n          },\n        );\n      },\n    },\n  );\n\n  markAsInstrumented((PostgRESTFilterBuilder.prototype ).then);\n}\n\nfunction instrumentPostgRESTQueryBuilder(PostgRESTQueryBuilder) {\n  // We need to wrap _all_ operations despite them sharing the same `PostgRESTFilterBuilder`\n  // constructor, as we don't know which method will be called first, and we don't want to miss any calls.\n  for (const operation of DB_OPERATIONS_TO_INSTRUMENT) {\n    if (isInstrumented((PostgRESTQueryBuilder.prototype )[operation])) {\n      continue;\n    }\n\n    (PostgRESTQueryBuilder.prototype )[operation ] = new Proxy(\n      (PostgRESTQueryBuilder.prototype )[operation ],\n      {\n        apply(target, thisArg, argumentsList) {\n          const rv = Reflect.apply(target, thisArg, argumentsList);\n          const PostgRESTFilterBuilder = (rv ).constructor;\n\n          debugBuild.DEBUG_BUILD && debugLogger.debug.log(`Instrumenting ${operation} operation's PostgRESTFilterBuilder`);\n\n          instrumentPostgRESTFilterBuilder(PostgRESTFilterBuilder);\n\n          return rv;\n        },\n      },\n    );\n\n    markAsInstrumented((PostgRESTQueryBuilder.prototype )[operation]);\n  }\n}\n\nconst instrumentSupabaseClient = (supabaseClient) => {\n  if (!supabaseClient) {\n    debugBuild.DEBUG_BUILD && debugLogger.debug.warn('Supabase integration was not installed because no Supabase client was provided.');\n    return;\n  }\n  const SupabaseClientConstructor =\n    supabaseClient.constructor === Function ? supabaseClient : supabaseClient.constructor;\n\n  instrumentSupabaseClientConstructor(SupabaseClientConstructor);\n  instrumentSupabaseAuthClient(supabaseClient );\n};\n\nconst INTEGRATION_NAME = 'Supabase';\n\nconst _supabaseIntegration = ((supabaseClient) => {\n  return {\n    setupOnce() {\n      instrumentSupabaseClient(supabaseClient);\n    },\n    name: INTEGRATION_NAME,\n  };\n}) ;\n\nconst supabaseIntegration = integration.defineIntegration((options) => {\n  return _supabaseIntegration(options.supabaseClient);\n}) ;\n\nexports.DB_OPERATIONS_TO_INSTRUMENT = DB_OPERATIONS_TO_INSTRUMENT;\nexports.FILTER_MAPPINGS = FILTER_MAPPINGS;\nexports.extractOperation = extractOperation;\nexports.instrumentSupabaseClient = instrumentSupabaseClient;\nexports.supabaseIntegration = supabaseIntegration;\nexports.translateFiltersIntoMethods = translateFiltersIntoMethods;\n//# sourceMappingURL=supabase.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvc3VwYWJhc2UuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsb0JBQW9CLG1CQUFPLENBQUMsNEhBQW1CO0FBQy9DLG1CQUFtQixtQkFBTyxDQUFDLDRIQUFtQjtBQUM5QyxrQkFBa0IsbUJBQU8sQ0FBQyxvSEFBZTtBQUN6QyxvQkFBb0IsbUJBQU8sQ0FBQyw0SEFBbUI7QUFDL0MsMkJBQTJCLG1CQUFPLENBQUMsMElBQTBCO0FBQzdELG9CQUFvQixtQkFBTyxDQUFDLDBJQUEwQjtBQUN0RCxXQUFXLG1CQUFPLENBQUMsc0hBQWdCO0FBQ25DLG1CQUFtQixtQkFBTyxDQUFDLDBJQUEwQjtBQUNyRCxjQUFjLG1CQUFPLENBQUMsZ0lBQXFCOztBQUUzQztBQUNBOzs7QUFHQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBLElBQUk7QUFDSjtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0EsSUFBSTtBQUNKO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSw4Q0FBOEM7QUFDOUM7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxRQUFRO0FBQ1I7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBLHFCQUFxQixNQUFNO0FBQzNCOztBQUVBO0FBQ0EsY0FBYyxJQUFJLEVBQUUsTUFBTTtBQUMxQjs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLElBQUk7QUFDSjtBQUNBLElBQUk7QUFDSjtBQUNBLElBQUk7QUFDSjtBQUNBLElBQUk7QUFDSjtBQUNBOztBQUVBLFlBQVksT0FBTyxHQUFHLElBQUksSUFBSSxnQkFBZ0I7QUFDOUM7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLHdCQUF3QiwwQkFBMEIsRUFBRSxlQUFlO0FBQ25FO0FBQ0E7QUFDQTtBQUNBO0FBQ0Esb0NBQW9DLHdCQUF3QixFQUFFLGVBQWU7QUFDN0UsV0FBVztBQUNYLFNBQVM7QUFDVDtBQUNBO0FBQ0E7QUFDQTtBQUNBLGlDQUFpQyxvQ0FBb0M7O0FBRXJFO0FBQ0E7QUFDQTtBQUNBLG1CQUFtQjtBQUNuQixpQkFBaUI7QUFDakIsZ0JBQWdCO0FBQ2hCLGlDQUFpQyxpQ0FBaUM7QUFDbEU7O0FBRUE7QUFDQTtBQUNBLGFBQWE7QUFDYjtBQUNBLCtCQUErQixvQ0FBb0M7QUFDbkU7O0FBRUE7QUFDQTtBQUNBO0FBQ0EsaUJBQWlCO0FBQ2pCLGVBQWU7O0FBRWY7QUFDQSxhQUFhO0FBQ2I7QUFDQSxTQUFTO0FBQ1Q7QUFDQSxLQUFLO0FBQ0wsR0FBRztBQUNIOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBOztBQUVBO0FBQ0EsT0FBTztBQUNQLEtBQUs7QUFDTDs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0EsK0JBQStCLGlDQUFpQyxVQUFVLEVBQUUscUJBQXFCLEVBQUUsRUFBRTtBQUNyRztBQUNBLFdBQVcsT0FBTyxNQUFNOztBQUV4QjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsV0FBVztBQUNYO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0EsdUJBQXVCO0FBQ3ZCLHFCQUFxQjtBQUNyQjs7QUFFQTtBQUNBO0FBQ0Esb0NBQW9DLFVBQVU7QUFDOUM7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBLGlCQUFpQjtBQUNqQjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxpQkFBaUI7QUFDakI7QUFDQTtBQUNBLFdBQVc7QUFDWDtBQUNBLE9BQU87QUFDUCxLQUFLO0FBQ0w7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsMkVBQTJFLFdBQVc7O0FBRXRGOztBQUVBO0FBQ0EsU0FBUztBQUNULE9BQU87QUFDUDs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsS0FBSztBQUNMO0FBQ0E7QUFDQSxDQUFDOztBQUVEO0FBQ0E7QUFDQSxDQUFDOztBQUVELG1DQUFtQztBQUNuQyx1QkFBdUI7QUFDdkIsd0JBQXdCO0FBQ3hCLGdDQUFnQztBQUNoQywyQkFBMkI7QUFDM0IsbUNBQW1DO0FBQ25DIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvaW50ZWdyYXRpb25zL3N1cGFiYXNlLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBicmVhZGNydW1icyA9IHJlcXVpcmUoJy4uL2JyZWFkY3J1bWJzLmpzJyk7XG5jb25zdCBkZWJ1Z0J1aWxkID0gcmVxdWlyZSgnLi4vZGVidWctYnVpbGQuanMnKTtcbmNvbnN0IGV4cG9ydHMkMSA9IHJlcXVpcmUoJy4uL2V4cG9ydHMuanMnKTtcbmNvbnN0IGludGVncmF0aW9uID0gcmVxdWlyZSgnLi4vaW50ZWdyYXRpb24uanMnKTtcbmNvbnN0IHNlbWFudGljQXR0cmlidXRlcyA9IHJlcXVpcmUoJy4uL3NlbWFudGljQXR0cmlidXRlcy5qcycpO1xuY29uc3QgZGVidWdMb2dnZXIgPSByZXF1aXJlKCcuLi91dGlscy9kZWJ1Zy1sb2dnZXIuanMnKTtcbmNvbnN0IGlzID0gcmVxdWlyZSgnLi4vdXRpbHMvaXMuanMnKTtcbmNvbnN0IHNwYW5zdGF0dXMgPSByZXF1aXJlKCcuLi90cmFjaW5nL3NwYW5zdGF0dXMuanMnKTtcbmNvbnN0IHRyYWNlID0gcmVxdWlyZSgnLi4vdHJhY2luZy90cmFjZS5qcycpO1xuXG4vLyBCYXNlZCBvbiBLYW1pbCBPZ8OzcmVrJ3Mgd29yayBvbjpcbi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9zdXBhYmFzZS1jb21tdW5pdHkvc2VudHJ5LWludGVncmF0aW9uLWpzXG5cblxuY29uc3QgQVVUSF9PUEVSQVRJT05TX1RPX0lOU1RSVU1FTlQgPSBbXG4gICdyZWF1dGhlbnRpY2F0ZScsXG4gICdzaWduSW5Bbm9ueW1vdXNseScsXG4gICdzaWduSW5XaXRoT0F1dGgnLFxuICAnc2lnbkluV2l0aElkVG9rZW4nLFxuICAnc2lnbkluV2l0aE90cCcsXG4gICdzaWduSW5XaXRoUGFzc3dvcmQnLFxuICAnc2lnbkluV2l0aFNTTycsXG4gICdzaWduT3V0JyxcbiAgJ3NpZ25VcCcsXG4gICd2ZXJpZnlPdHAnLFxuXTtcblxuY29uc3QgQVVUSF9BRE1JTl9PUEVSQVRJT05TX1RPX0lOU1RSVU1FTlQgPSBbXG4gICdjcmVhdGVVc2VyJyxcbiAgJ2RlbGV0ZVVzZXInLFxuICAnbGlzdFVzZXJzJyxcbiAgJ2dldFVzZXJCeUlkJyxcbiAgJ3VwZGF0ZVVzZXJCeUlkJyxcbiAgJ2ludml0ZVVzZXJCeUVtYWlsJyxcbl07XG5cbmNvbnN0IEZJTFRFUl9NQVBQSU5HUyA9IHtcbiAgZXE6ICdlcScsXG4gIG5lcTogJ25lcScsXG4gIGd0OiAnZ3QnLFxuICBndGU6ICdndGUnLFxuICBsdDogJ2x0JyxcbiAgbHRlOiAnbHRlJyxcbiAgbGlrZTogJ2xpa2UnLFxuICAnbGlrZShhbGwpJzogJ2xpa2VBbGxPZicsXG4gICdsaWtlKGFueSknOiAnbGlrZUFueU9mJyxcbiAgaWxpa2U6ICdpbGlrZScsXG4gICdpbGlrZShhbGwpJzogJ2lsaWtlQWxsT2YnLFxuICAnaWxpa2UoYW55KSc6ICdpbGlrZUFueU9mJyxcbiAgaXM6ICdpcycsXG4gIGluOiAnaW4nLFxuICBjczogJ2NvbnRhaW5zJyxcbiAgY2Q6ICdjb250YWluZWRCeScsXG4gIHNyOiAncmFuZ2VHdCcsXG4gIG54bDogJ3JhbmdlR3RlJyxcbiAgc2w6ICdyYW5nZUx0JyxcbiAgbnhyOiAncmFuZ2VMdGUnLFxuICBhZGo6ICdyYW5nZUFkamFjZW50JyxcbiAgb3Y6ICdvdmVybGFwcycsXG4gIGZ0czogJycsXG4gIHBsZnRzOiAncGxhaW4nLFxuICBwaGZ0czogJ3BocmFzZScsXG4gIHdmdHM6ICd3ZWJzZWFyY2gnLFxuICBub3Q6ICdub3QnLFxufTtcblxuY29uc3QgREJfT1BFUkFUSU9OU19UT19JTlNUUlVNRU5UID0gWydzZWxlY3QnLCAnaW5zZXJ0JywgJ3Vwc2VydCcsICd1cGRhdGUnLCAnZGVsZXRlJ107XG5cbmZ1bmN0aW9uIG1hcmtBc0luc3RydW1lbnRlZChmbikge1xuICB0cnkge1xuICAgIChmbiApLl9fU0VOVFJZX0lOU1RSVU1FTlRFRF9fID0gdHJ1ZTtcbiAgfSBjYXRjaCB7XG4gICAgLy8gaWdub3JlIGVycm9ycyBoZXJlXG4gIH1cbn1cblxuZnVuY3Rpb24gaXNJbnN0cnVtZW50ZWQoZm4pIHtcbiAgdHJ5IHtcbiAgICByZXR1cm4gKGZuICkuX19TRU5UUllfSU5TVFJVTUVOVEVEX187XG4gIH0gY2F0Y2gge1xuICAgIHJldHVybiBmYWxzZTtcbiAgfVxufVxuXG4vKipcbiAqIEV4dHJhY3RzIHRoZSBkYXRhYmFzZSBvcGVyYXRpb24gdHlwZSBmcm9tIHRoZSBIVFRQIG1ldGhvZCBhbmQgaGVhZGVyc1xuICogQHBhcmFtIG1ldGhvZCAtIFRoZSBIVFRQIG1ldGhvZCBvZiB0aGUgcmVxdWVzdFxuICogQHBhcmFtIGhlYWRlcnMgLSBUaGUgcmVxdWVzdCBoZWFkZXJzXG4gKiBAcmV0dXJucyBUaGUgZGF0YWJhc2Ugb3BlcmF0aW9uIHR5cGUgKCdzZWxlY3QnLCAnaW5zZXJ0JywgJ3Vwc2VydCcsICd1cGRhdGUnLCBvciAnZGVsZXRlJylcbiAqL1xuZnVuY3Rpb24gZXh0cmFjdE9wZXJhdGlvbihtZXRob2QsIGhlYWRlcnMgPSB7fSkge1xuICBzd2l0Y2ggKG1ldGhvZCkge1xuICAgIGNhc2UgJ0dFVCc6IHtcbiAgICAgIHJldHVybiAnc2VsZWN0JztcbiAgICB9XG4gICAgY2FzZSAnUE9TVCc6IHtcbiAgICAgIGlmIChoZWFkZXJzWydQcmVmZXInXT8uaW5jbHVkZXMoJ3Jlc29sdXRpb249JykpIHtcbiAgICAgICAgcmV0dXJuICd1cHNlcnQnO1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgcmV0dXJuICdpbnNlcnQnO1xuICAgICAgfVxuICAgIH1cbiAgICBjYXNlICdQQVRDSCc6IHtcbiAgICAgIHJldHVybiAndXBkYXRlJztcbiAgICB9XG4gICAgY2FzZSAnREVMRVRFJzoge1xuICAgICAgcmV0dXJuICdkZWxldGUnO1xuICAgIH1cbiAgICBkZWZhdWx0OiB7XG4gICAgICByZXR1cm4gJzx1bmtub3duLW9wPic7XG4gICAgfVxuICB9XG59XG5cbi8qKlxuICogVHJhbnNsYXRlcyBTdXBhYmFzZSBmaWx0ZXIgcGFyYW1ldGVycyBpbnRvIHJlYWRhYmxlIG1ldGhvZCBuYW1lcyBmb3IgdHJhY2luZ1xuICogQHBhcmFtIGtleSAtIFRoZSBmaWx0ZXIga2V5IGZyb20gdGhlIFVSTCBzZWFyY2ggcGFyYW1ldGVyc1xuICogQHBhcmFtIHF1ZXJ5IC0gVGhlIGZpbHRlciB2YWx1ZSBmcm9tIHRoZSBVUkwgc2VhcmNoIHBhcmFtZXRlcnNcbiAqIEByZXR1cm5zIEEgc3RyaW5nIHJlcHJlc2VudGF0aW9uIG9mIHRoZSBmaWx0ZXIgYXMgYSBtZXRob2QgY2FsbFxuICovXG5mdW5jdGlvbiB0cmFuc2xhdGVGaWx0ZXJzSW50b01ldGhvZHMoa2V5LCBxdWVyeSkge1xuICBpZiAocXVlcnkgPT09ICcnIHx8IHF1ZXJ5ID09PSAnKicpIHtcbiAgICByZXR1cm4gJ3NlbGVjdCgqKSc7XG4gIH1cblxuICBpZiAoa2V5ID09PSAnc2VsZWN0Jykge1xuICAgIHJldHVybiBgc2VsZWN0KCR7cXVlcnl9KWA7XG4gIH1cblxuICBpZiAoa2V5ID09PSAnb3InIHx8IGtleS5lbmRzV2l0aCgnLm9yJykpIHtcbiAgICByZXR1cm4gYCR7a2V5fSR7cXVlcnl9YDtcbiAgfVxuXG4gIGNvbnN0IFtmaWx0ZXIsIC4uLnZhbHVlXSA9IHF1ZXJ5LnNwbGl0KCcuJyk7XG5cbiAgbGV0IG1ldGhvZDtcbiAgLy8gSGFuZGxlIG9wdGlvbmFsIGBjb25maWdQYXJ0YCBvZiB0aGUgZmlsdGVyXG4gIGlmIChmaWx0ZXI/LnN0YXJ0c1dpdGgoJ2Z0cycpKSB7XG4gICAgbWV0aG9kID0gJ3RleHRTZWFyY2gnO1xuICB9IGVsc2UgaWYgKGZpbHRlcj8uc3RhcnRzV2l0aCgncGxmdHMnKSkge1xuICAgIG1ldGhvZCA9ICd0ZXh0U2VhcmNoW3BsYWluXSc7XG4gIH0gZWxzZSBpZiAoZmlsdGVyPy5zdGFydHNXaXRoKCdwaGZ0cycpKSB7XG4gICAgbWV0aG9kID0gJ3RleHRTZWFyY2hbcGhyYXNlXSc7XG4gIH0gZWxzZSBpZiAoZmlsdGVyPy5zdGFydHNXaXRoKCd3ZnRzJykpIHtcbiAgICBtZXRob2QgPSAndGV4dFNlYXJjaFt3ZWJzZWFyY2hdJztcbiAgfSBlbHNlIHtcbiAgICBtZXRob2QgPSAoZmlsdGVyICYmIEZJTFRFUl9NQVBQSU5HU1tmaWx0ZXIgXSkgfHwgJ2ZpbHRlcic7XG4gIH1cblxuICByZXR1cm4gYCR7bWV0aG9kfSgke2tleX0sICR7dmFsdWUuam9pbignLicpfSlgO1xufVxuXG5mdW5jdGlvbiBpbnN0cnVtZW50QXV0aE9wZXJhdGlvbihvcGVyYXRpb24sIGlzQWRtaW4gPSBmYWxzZSkge1xuICByZXR1cm4gbmV3IFByb3h5KG9wZXJhdGlvbiwge1xuICAgIGFwcGx5KHRhcmdldCwgdGhpc0FyZywgYXJndW1lbnRzTGlzdCkge1xuICAgICAgcmV0dXJuIHRyYWNlLnN0YXJ0U3BhbihcbiAgICAgICAge1xuICAgICAgICAgIG5hbWU6IGBhdXRoICR7aXNBZG1pbiA/ICcoYWRtaW4pICcgOiAnJ30ke29wZXJhdGlvbi5uYW1lfWAsXG4gICAgICAgICAgYXR0cmlidXRlczoge1xuICAgICAgICAgICAgW3NlbWFudGljQXR0cmlidXRlcy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX09SSUdJTl06ICdhdXRvLmRiLnN1cGFiYXNlJyxcbiAgICAgICAgICAgIFtzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9PUF06ICdkYicsXG4gICAgICAgICAgICAnZGIuc3lzdGVtJzogJ3Bvc3RncmVzcWwnLFxuICAgICAgICAgICAgJ2RiLm9wZXJhdGlvbic6IGBhdXRoLiR7aXNBZG1pbiA/ICdhZG1pbi4nIDogJyd9JHtvcGVyYXRpb24ubmFtZX1gLFxuICAgICAgICAgIH0sXG4gICAgICAgIH0sXG4gICAgICAgIHNwYW4gPT4ge1xuICAgICAgICAgIHJldHVybiBSZWZsZWN0LmFwcGx5KHRhcmdldCwgdGhpc0FyZywgYXJndW1lbnRzTGlzdClcbiAgICAgICAgICAgIC50aGVuKChyZXMpID0+IHtcbiAgICAgICAgICAgICAgaWYgKHJlcyAmJiB0eXBlb2YgcmVzID09PSAnb2JqZWN0JyAmJiAnZXJyb3InIGluIHJlcyAmJiByZXMuZXJyb3IpIHtcbiAgICAgICAgICAgICAgICBzcGFuLnNldFN0YXR1cyh7IGNvZGU6IHNwYW5zdGF0dXMuU1BBTl9TVEFUVVNfRVJST1IgfSk7XG5cbiAgICAgICAgICAgICAgICBleHBvcnRzJDEuY2FwdHVyZUV4Y2VwdGlvbihyZXMuZXJyb3IsIHtcbiAgICAgICAgICAgICAgICAgIG1lY2hhbmlzbToge1xuICAgICAgICAgICAgICAgICAgICBoYW5kbGVkOiBmYWxzZSxcbiAgICAgICAgICAgICAgICAgIH0sXG4gICAgICAgICAgICAgICAgfSk7XG4gICAgICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICAgICAgc3Bhbi5zZXRTdGF0dXMoeyBjb2RlOiBzcGFuc3RhdHVzLlNQQU5fU1RBVFVTX09LIH0pO1xuICAgICAgICAgICAgICB9XG5cbiAgICAgICAgICAgICAgc3Bhbi5lbmQoKTtcbiAgICAgICAgICAgICAgcmV0dXJuIHJlcztcbiAgICAgICAgICAgIH0pXG4gICAgICAgICAgICAuY2F0Y2goKGVycikgPT4ge1xuICAgICAgICAgICAgICBzcGFuLnNldFN0YXR1cyh7IGNvZGU6IHNwYW5zdGF0dXMuU1BBTl9TVEFUVVNfRVJST1IgfSk7XG4gICAgICAgICAgICAgIHNwYW4uZW5kKCk7XG5cbiAgICAgICAgICAgICAgZXhwb3J0cyQxLmNhcHR1cmVFeGNlcHRpb24oZXJyLCB7XG4gICAgICAgICAgICAgICAgbWVjaGFuaXNtOiB7XG4gICAgICAgICAgICAgICAgICBoYW5kbGVkOiBmYWxzZSxcbiAgICAgICAgICAgICAgICB9LFxuICAgICAgICAgICAgICB9KTtcblxuICAgICAgICAgICAgICB0aHJvdyBlcnI7XG4gICAgICAgICAgICB9KVxuICAgICAgICAgICAgLnRoZW4oLi4uYXJndW1lbnRzTGlzdCk7XG4gICAgICAgIH0sXG4gICAgICApO1xuICAgIH0sXG4gIH0pO1xufVxuXG5mdW5jdGlvbiBpbnN0cnVtZW50U3VwYWJhc2VBdXRoQ2xpZW50KHN1cGFiYXNlQ2xpZW50SW5zdGFuY2UpIHtcbiAgY29uc3QgYXV0aCA9IHN1cGFiYXNlQ2xpZW50SW5zdGFuY2UuYXV0aDtcblxuICBpZiAoIWF1dGggfHwgaXNJbnN0cnVtZW50ZWQoc3VwYWJhc2VDbGllbnRJbnN0YW5jZS5hdXRoKSkge1xuICAgIHJldHVybjtcbiAgfVxuXG4gIGZvciAoY29uc3Qgb3BlcmF0aW9uIG9mIEFVVEhfT1BFUkFUSU9OU19UT19JTlNUUlVNRU5UKSB7XG4gICAgY29uc3QgYXV0aE9wZXJhdGlvbiA9IGF1dGhbb3BlcmF0aW9uXTtcblxuICAgIGlmICghYXV0aE9wZXJhdGlvbikge1xuICAgICAgY29udGludWU7XG4gICAgfVxuXG4gICAgaWYgKHR5cGVvZiBzdXBhYmFzZUNsaWVudEluc3RhbmNlLmF1dGhbb3BlcmF0aW9uXSA9PT0gJ2Z1bmN0aW9uJykge1xuICAgICAgc3VwYWJhc2VDbGllbnRJbnN0YW5jZS5hdXRoW29wZXJhdGlvbl0gPSBpbnN0cnVtZW50QXV0aE9wZXJhdGlvbihhdXRoT3BlcmF0aW9uKTtcbiAgICB9XG4gIH1cblxuICBmb3IgKGNvbnN0IG9wZXJhdGlvbiBvZiBBVVRIX0FETUlOX09QRVJBVElPTlNfVE9fSU5TVFJVTUVOVCkge1xuICAgIGNvbnN0IGF1dGhPcGVyYXRpb24gPSBhdXRoLmFkbWluW29wZXJhdGlvbl07XG5cbiAgICBpZiAoIWF1dGhPcGVyYXRpb24pIHtcbiAgICAgIGNvbnRpbnVlO1xuICAgIH1cblxuICAgIGlmICh0eXBlb2Ygc3VwYWJhc2VDbGllbnRJbnN0YW5jZS5hdXRoLmFkbWluW29wZXJhdGlvbl0gPT09ICdmdW5jdGlvbicpIHtcbiAgICAgIHN1cGFiYXNlQ2xpZW50SW5zdGFuY2UuYXV0aC5hZG1pbltvcGVyYXRpb25dID0gaW5zdHJ1bWVudEF1dGhPcGVyYXRpb24oYXV0aE9wZXJhdGlvbiwgdHJ1ZSk7XG4gICAgfVxuICB9XG5cbiAgbWFya0FzSW5zdHJ1bWVudGVkKHN1cGFiYXNlQ2xpZW50SW5zdGFuY2UuYXV0aCk7XG59XG5cbmZ1bmN0aW9uIGluc3RydW1lbnRTdXBhYmFzZUNsaWVudENvbnN0cnVjdG9yKFN1cGFiYXNlQ2xpZW50KSB7XG4gIGlmIChpc0luc3RydW1lbnRlZCgoU3VwYWJhc2VDbGllbnQgKS5wcm90b3R5cGUuZnJvbSkpIHtcbiAgICByZXR1cm47XG4gIH1cblxuICAoU3VwYWJhc2VDbGllbnQgKS5wcm90b3R5cGUuZnJvbSA9IG5ldyBQcm94eShcbiAgICAoU3VwYWJhc2VDbGllbnQgKS5wcm90b3R5cGUuZnJvbSxcbiAgICB7XG4gICAgICBhcHBseSh0YXJnZXQsIHRoaXNBcmcsIGFyZ3VtZW50c0xpc3QpIHtcbiAgICAgICAgY29uc3QgcnYgPSBSZWZsZWN0LmFwcGx5KHRhcmdldCwgdGhpc0FyZywgYXJndW1lbnRzTGlzdCk7XG4gICAgICAgIGNvbnN0IFBvc3RnUkVTVFF1ZXJ5QnVpbGRlciA9IChydiApLmNvbnN0cnVjdG9yO1xuXG4gICAgICAgIGluc3RydW1lbnRQb3N0Z1JFU1RRdWVyeUJ1aWxkZXIoUG9zdGdSRVNUUXVlcnlCdWlsZGVyICk7XG5cbiAgICAgICAgcmV0dXJuIHJ2O1xuICAgICAgfSxcbiAgICB9LFxuICApO1xuXG4gIG1hcmtBc0luc3RydW1lbnRlZCgoU3VwYWJhc2VDbGllbnQgKS5wcm90b3R5cGUuZnJvbSk7XG59XG5cbmZ1bmN0aW9uIGluc3RydW1lbnRQb3N0Z1JFU1RGaWx0ZXJCdWlsZGVyKFBvc3RnUkVTVEZpbHRlckJ1aWxkZXIpIHtcbiAgaWYgKGlzSW5zdHJ1bWVudGVkKChQb3N0Z1JFU1RGaWx0ZXJCdWlsZGVyLnByb3RvdHlwZSApLnRoZW4pKSB7XG4gICAgcmV0dXJuO1xuICB9XG5cbiAgKFBvc3RnUkVTVEZpbHRlckJ1aWxkZXIucHJvdG90eXBlICkudGhlbiA9IG5ldyBQcm94eShcbiAgICAoUG9zdGdSRVNURmlsdGVyQnVpbGRlci5wcm90b3R5cGUgKS50aGVuLFxuICAgIHtcbiAgICAgIGFwcGx5KHRhcmdldCwgdGhpc0FyZywgYXJndW1lbnRzTGlzdCkge1xuICAgICAgICBjb25zdCBvcGVyYXRpb25zID0gREJfT1BFUkFUSU9OU19UT19JTlNUUlVNRU5UO1xuICAgICAgICBjb25zdCB0eXBlZFRoaXMgPSB0aGlzQXJnIDtcbiAgICAgICAgY29uc3Qgb3BlcmF0aW9uID0gZXh0cmFjdE9wZXJhdGlvbih0eXBlZFRoaXMubWV0aG9kLCB0eXBlZFRoaXMuaGVhZGVycyk7XG5cbiAgICAgICAgaWYgKCFvcGVyYXRpb25zLmluY2x1ZGVzKG9wZXJhdGlvbikpIHtcbiAgICAgICAgICByZXR1cm4gUmVmbGVjdC5hcHBseSh0YXJnZXQsIHRoaXNBcmcsIGFyZ3VtZW50c0xpc3QpO1xuICAgICAgICB9XG5cbiAgICAgICAgaWYgKCF0eXBlZFRoaXM/LnVybD8ucGF0aG5hbWUgfHwgdHlwZW9mIHR5cGVkVGhpcy51cmwucGF0aG5hbWUgIT09ICdzdHJpbmcnKSB7XG4gICAgICAgICAgcmV0dXJuIFJlZmxlY3QuYXBwbHkodGFyZ2V0LCB0aGlzQXJnLCBhcmd1bWVudHNMaXN0KTtcbiAgICAgICAgfVxuXG4gICAgICAgIGNvbnN0IHBhdGhQYXJ0cyA9IHR5cGVkVGhpcy51cmwucGF0aG5hbWUuc3BsaXQoJy8nKTtcbiAgICAgICAgY29uc3QgdGFibGUgPSBwYXRoUGFydHMubGVuZ3RoID4gMCA/IHBhdGhQYXJ0c1twYXRoUGFydHMubGVuZ3RoIC0gMV0gOiAnJztcblxuICAgICAgICBjb25zdCBxdWVyeUl0ZW1zID0gW107XG4gICAgICAgIGZvciAoY29uc3QgW2tleSwgdmFsdWVdIG9mIHR5cGVkVGhpcy51cmwuc2VhcmNoUGFyYW1zLmVudHJpZXMoKSkge1xuICAgICAgICAgIC8vIEl0J3MgcG9zc2libGUgdG8gaGF2ZSBtdWx0aXBsZSBlbnRyaWVzIGZvciB0aGUgc2FtZSBrZXksIGVnLiBgaWQ9ZXEuNyZpZD1lcS4zYCxcbiAgICAgICAgICAvLyBzbyB3ZSBuZWVkIHRvIHVzZSBhcnJheSBpbnN0ZWFkIG9mIG9iamVjdCB0byBjb2xsZWN0IHRoZW0uXG4gICAgICAgICAgcXVlcnlJdGVtcy5wdXNoKHRyYW5zbGF0ZUZpbHRlcnNJbnRvTWV0aG9kcyhrZXksIHZhbHVlKSk7XG4gICAgICAgIH1cbiAgICAgICAgY29uc3QgYm9keSA9IE9iamVjdC5jcmVhdGUobnVsbCk7XG4gICAgICAgIGlmIChpcy5pc1BsYWluT2JqZWN0KHR5cGVkVGhpcy5ib2R5KSkge1xuICAgICAgICAgIGZvciAoY29uc3QgW2tleSwgdmFsdWVdIG9mIE9iamVjdC5lbnRyaWVzKHR5cGVkVGhpcy5ib2R5KSkge1xuICAgICAgICAgICAgYm9keVtrZXldID0gdmFsdWU7XG4gICAgICAgICAgfVxuICAgICAgICB9XG5cbiAgICAgICAgLy8gQWRkaW5nIG9wZXJhdGlvbiB0byB0aGUgYmVnaW5uaW5nIG9mIHRoZSBkZXNjcmlwdGlvbiBpZiBpdCdzIG5vdCBhIGBzZWxlY3RgIG9wZXJhdGlvblxuICAgICAgICAvLyBGb3IgZXhhbXBsZSwgaXQgY2FuIGJlIGFuIGBpbnNlcnRgIG9yIGB1cGRhdGVgIG9wZXJhdGlvbiBidXQgdGhlIHF1ZXJ5IGNhbiBiZSBgc2VsZWN0KC4uLilgXG4gICAgICAgIC8vIEZvciBgc2VsZWN0YCBvcGVyYXRpb25zLCB3ZSBkb24ndCBuZWVkIHJlcGVhdCBpdCBpbiB0aGUgZGVzY3JpcHRpb25cbiAgICAgICAgY29uc3QgZGVzY3JpcHRpb24gPSBgJHtvcGVyYXRpb24gPT09ICdzZWxlY3QnID8gJycgOiBgJHtvcGVyYXRpb259JHtib2R5ID8gJyguLi4pICcgOiAnJ31gfSR7cXVlcnlJdGVtcy5qb2luKFxuICAgICAgICAgICcgJyxcbiAgICAgICAgKX0gZnJvbSgke3RhYmxlfSlgO1xuXG4gICAgICAgIGNvbnN0IGF0dHJpYnV0ZXMgPSB7XG4gICAgICAgICAgJ2RiLnRhYmxlJzogdGFibGUsXG4gICAgICAgICAgJ2RiLnNjaGVtYSc6IHR5cGVkVGhpcy5zY2hlbWEsXG4gICAgICAgICAgJ2RiLnVybCc6IHR5cGVkVGhpcy51cmwub3JpZ2luLFxuICAgICAgICAgICdkYi5zZGsnOiB0eXBlZFRoaXMuaGVhZGVyc1snWC1DbGllbnQtSW5mbyddLFxuICAgICAgICAgICdkYi5zeXN0ZW0nOiAncG9zdGdyZXNxbCcsXG4gICAgICAgICAgJ2RiLm9wZXJhdGlvbic6IG9wZXJhdGlvbixcbiAgICAgICAgICBbc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfT1JJR0lOXTogJ2F1dG8uZGIuc3VwYWJhc2UnLFxuICAgICAgICAgIFtzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9PUF06ICdkYicsXG4gICAgICAgIH07XG5cbiAgICAgICAgaWYgKHF1ZXJ5SXRlbXMubGVuZ3RoKSB7XG4gICAgICAgICAgYXR0cmlidXRlc1snZGIucXVlcnknXSA9IHF1ZXJ5SXRlbXM7XG4gICAgICAgIH1cblxuICAgICAgICBpZiAoT2JqZWN0LmtleXMoYm9keSkubGVuZ3RoKSB7XG4gICAgICAgICAgYXR0cmlidXRlc1snZGIuYm9keSddID0gYm9keTtcbiAgICAgICAgfVxuXG4gICAgICAgIHJldHVybiB0cmFjZS5zdGFydFNwYW4oXG4gICAgICAgICAge1xuICAgICAgICAgICAgbmFtZTogZGVzY3JpcHRpb24sXG4gICAgICAgICAgICBhdHRyaWJ1dGVzLFxuICAgICAgICAgIH0sXG4gICAgICAgICAgc3BhbiA9PiB7XG4gICAgICAgICAgICByZXR1cm4gKFJlZmxlY3QuYXBwbHkodGFyZ2V0LCB0aGlzQXJnLCBbXSkgKVxuICAgICAgICAgICAgICAudGhlbihcbiAgICAgICAgICAgICAgICAocmVzKSA9PiB7XG4gICAgICAgICAgICAgICAgICBpZiAoc3Bhbikge1xuICAgICAgICAgICAgICAgICAgICBpZiAocmVzICYmIHR5cGVvZiByZXMgPT09ICdvYmplY3QnICYmICdzdGF0dXMnIGluIHJlcykge1xuICAgICAgICAgICAgICAgICAgICAgIHNwYW5zdGF0dXMuc2V0SHR0cFN0YXR1cyhzcGFuLCByZXMuc3RhdHVzIHx8IDUwMCk7XG4gICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICAgICAgc3Bhbi5lbmQoKTtcbiAgICAgICAgICAgICAgICAgIH1cblxuICAgICAgICAgICAgICAgICAgaWYgKHJlcy5lcnJvcikge1xuICAgICAgICAgICAgICAgICAgICBjb25zdCBlcnIgPSBuZXcgRXJyb3IocmVzLmVycm9yLm1lc3NhZ2UpIDtcbiAgICAgICAgICAgICAgICAgICAgaWYgKHJlcy5lcnJvci5jb2RlKSB7XG4gICAgICAgICAgICAgICAgICAgICAgZXJyLmNvZGUgPSByZXMuZXJyb3IuY29kZTtcbiAgICAgICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgICAgICBpZiAocmVzLmVycm9yLmRldGFpbHMpIHtcbiAgICAgICAgICAgICAgICAgICAgICBlcnIuZGV0YWlscyA9IHJlcy5lcnJvci5kZXRhaWxzO1xuICAgICAgICAgICAgICAgICAgICB9XG5cbiAgICAgICAgICAgICAgICAgICAgY29uc3Qgc3VwYWJhc2VDb250ZXh0ID0ge307XG4gICAgICAgICAgICAgICAgICAgIGlmIChxdWVyeUl0ZW1zLmxlbmd0aCkge1xuICAgICAgICAgICAgICAgICAgICAgIHN1cGFiYXNlQ29udGV4dC5xdWVyeSA9IHF1ZXJ5SXRlbXM7XG4gICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICAgICAgaWYgKE9iamVjdC5rZXlzKGJvZHkpLmxlbmd0aCkge1xuICAgICAgICAgICAgICAgICAgICAgIHN1cGFiYXNlQ29udGV4dC5ib2R5ID0gYm9keTtcbiAgICAgICAgICAgICAgICAgICAgfVxuXG4gICAgICAgICAgICAgICAgICAgIGV4cG9ydHMkMS5jYXB0dXJlRXhjZXB0aW9uKGVyciwge1xuICAgICAgICAgICAgICAgICAgICAgIGNvbnRleHRzOiB7XG4gICAgICAgICAgICAgICAgICAgICAgICBzdXBhYmFzZTogc3VwYWJhc2VDb250ZXh0LFxuICAgICAgICAgICAgICAgICAgICAgIH0sXG4gICAgICAgICAgICAgICAgICAgIH0pO1xuICAgICAgICAgICAgICAgICAgfVxuXG4gICAgICAgICAgICAgICAgICBjb25zdCBicmVhZGNydW1iID0ge1xuICAgICAgICAgICAgICAgICAgICB0eXBlOiAnc3VwYWJhc2UnLFxuICAgICAgICAgICAgICAgICAgICBjYXRlZ29yeTogYGRiLiR7b3BlcmF0aW9ufWAsXG4gICAgICAgICAgICAgICAgICAgIG1lc3NhZ2U6IGRlc2NyaXB0aW9uLFxuICAgICAgICAgICAgICAgICAgfTtcblxuICAgICAgICAgICAgICAgICAgY29uc3QgZGF0YSA9IHt9O1xuXG4gICAgICAgICAgICAgICAgICBpZiAocXVlcnlJdGVtcy5sZW5ndGgpIHtcbiAgICAgICAgICAgICAgICAgICAgZGF0YS5xdWVyeSA9IHF1ZXJ5SXRlbXM7XG4gICAgICAgICAgICAgICAgICB9XG5cbiAgICAgICAgICAgICAgICAgIGlmIChPYmplY3Qua2V5cyhib2R5KS5sZW5ndGgpIHtcbiAgICAgICAgICAgICAgICAgICAgZGF0YS5ib2R5ID0gYm9keTtcbiAgICAgICAgICAgICAgICAgIH1cblxuICAgICAgICAgICAgICAgICAgaWYgKE9iamVjdC5rZXlzKGRhdGEpLmxlbmd0aCkge1xuICAgICAgICAgICAgICAgICAgICBicmVhZGNydW1iLmRhdGEgPSBkYXRhO1xuICAgICAgICAgICAgICAgICAgfVxuXG4gICAgICAgICAgICAgICAgICBicmVhZGNydW1icy5hZGRCcmVhZGNydW1iKGJyZWFkY3J1bWIpO1xuXG4gICAgICAgICAgICAgICAgICByZXR1cm4gcmVzO1xuICAgICAgICAgICAgICAgIH0sXG4gICAgICAgICAgICAgICAgKGVycikgPT4ge1xuICAgICAgICAgICAgICAgICAgaWYgKHNwYW4pIHtcbiAgICAgICAgICAgICAgICAgICAgc3BhbnN0YXR1cy5zZXRIdHRwU3RhdHVzKHNwYW4sIDUwMCk7XG4gICAgICAgICAgICAgICAgICAgIHNwYW4uZW5kKCk7XG4gICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgICB0aHJvdyBlcnI7XG4gICAgICAgICAgICAgICAgfSxcbiAgICAgICAgICAgICAgKVxuICAgICAgICAgICAgICAudGhlbiguLi5hcmd1bWVudHNMaXN0KTtcbiAgICAgICAgICB9LFxuICAgICAgICApO1xuICAgICAgfSxcbiAgICB9LFxuICApO1xuXG4gIG1hcmtBc0luc3RydW1lbnRlZCgoUG9zdGdSRVNURmlsdGVyQnVpbGRlci5wcm90b3R5cGUgKS50aGVuKTtcbn1cblxuZnVuY3Rpb24gaW5zdHJ1bWVudFBvc3RnUkVTVFF1ZXJ5QnVpbGRlcihQb3N0Z1JFU1RRdWVyeUJ1aWxkZXIpIHtcbiAgLy8gV2UgbmVlZCB0byB3cmFwIF9hbGxfIG9wZXJhdGlvbnMgZGVzcGl0ZSB0aGVtIHNoYXJpbmcgdGhlIHNhbWUgYFBvc3RnUkVTVEZpbHRlckJ1aWxkZXJgXG4gIC8vIGNvbnN0cnVjdG9yLCBhcyB3ZSBkb24ndCBrbm93IHdoaWNoIG1ldGhvZCB3aWxsIGJlIGNhbGxlZCBmaXJzdCwgYW5kIHdlIGRvbid0IHdhbnQgdG8gbWlzcyBhbnkgY2FsbHMuXG4gIGZvciAoY29uc3Qgb3BlcmF0aW9uIG9mIERCX09QRVJBVElPTlNfVE9fSU5TVFJVTUVOVCkge1xuICAgIGlmIChpc0luc3RydW1lbnRlZCgoUG9zdGdSRVNUUXVlcnlCdWlsZGVyLnByb3RvdHlwZSApW29wZXJhdGlvbl0pKSB7XG4gICAgICBjb250aW51ZTtcbiAgICB9XG5cbiAgICAoUG9zdGdSRVNUUXVlcnlCdWlsZGVyLnByb3RvdHlwZSApW29wZXJhdGlvbiBdID0gbmV3IFByb3h5KFxuICAgICAgKFBvc3RnUkVTVFF1ZXJ5QnVpbGRlci5wcm90b3R5cGUgKVtvcGVyYXRpb24gXSxcbiAgICAgIHtcbiAgICAgICAgYXBwbHkodGFyZ2V0LCB0aGlzQXJnLCBhcmd1bWVudHNMaXN0KSB7XG4gICAgICAgICAgY29uc3QgcnYgPSBSZWZsZWN0LmFwcGx5KHRhcmdldCwgdGhpc0FyZywgYXJndW1lbnRzTGlzdCk7XG4gICAgICAgICAgY29uc3QgUG9zdGdSRVNURmlsdGVyQnVpbGRlciA9IChydiApLmNvbnN0cnVjdG9yO1xuXG4gICAgICAgICAgZGVidWdCdWlsZC5ERUJVR19CVUlMRCAmJiBkZWJ1Z0xvZ2dlci5kZWJ1Zy5sb2coYEluc3RydW1lbnRpbmcgJHtvcGVyYXRpb259IG9wZXJhdGlvbidzIFBvc3RnUkVTVEZpbHRlckJ1aWxkZXJgKTtcblxuICAgICAgICAgIGluc3RydW1lbnRQb3N0Z1JFU1RGaWx0ZXJCdWlsZGVyKFBvc3RnUkVTVEZpbHRlckJ1aWxkZXIpO1xuXG4gICAgICAgICAgcmV0dXJuIHJ2O1xuICAgICAgICB9LFxuICAgICAgfSxcbiAgICApO1xuXG4gICAgbWFya0FzSW5zdHJ1bWVudGVkKChQb3N0Z1JFU1RRdWVyeUJ1aWxkZXIucHJvdG90eXBlIClbb3BlcmF0aW9uXSk7XG4gIH1cbn1cblxuY29uc3QgaW5zdHJ1bWVudFN1cGFiYXNlQ2xpZW50ID0gKHN1cGFiYXNlQ2xpZW50KSA9PiB7XG4gIGlmICghc3VwYWJhc2VDbGllbnQpIHtcbiAgICBkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEICYmIGRlYnVnTG9nZ2VyLmRlYnVnLndhcm4oJ1N1cGFiYXNlIGludGVncmF0aW9uIHdhcyBub3QgaW5zdGFsbGVkIGJlY2F1c2Ugbm8gU3VwYWJhc2UgY2xpZW50IHdhcyBwcm92aWRlZC4nKTtcbiAgICByZXR1cm47XG4gIH1cbiAgY29uc3QgU3VwYWJhc2VDbGllbnRDb25zdHJ1Y3RvciA9XG4gICAgc3VwYWJhc2VDbGllbnQuY29uc3RydWN0b3IgPT09IEZ1bmN0aW9uID8gc3VwYWJhc2VDbGllbnQgOiBzdXBhYmFzZUNsaWVudC5jb25zdHJ1Y3RvcjtcblxuICBpbnN0cnVtZW50U3VwYWJhc2VDbGllbnRDb25zdHJ1Y3RvcihTdXBhYmFzZUNsaWVudENvbnN0cnVjdG9yKTtcbiAgaW5zdHJ1bWVudFN1cGFiYXNlQXV0aENsaWVudChzdXBhYmFzZUNsaWVudCApO1xufTtcblxuY29uc3QgSU5URUdSQVRJT05fTkFNRSA9ICdTdXBhYmFzZSc7XG5cbmNvbnN0IF9zdXBhYmFzZUludGVncmF0aW9uID0gKChzdXBhYmFzZUNsaWVudCkgPT4ge1xuICByZXR1cm4ge1xuICAgIHNldHVwT25jZSgpIHtcbiAgICAgIGluc3RydW1lbnRTdXBhYmFzZUNsaWVudChzdXBhYmFzZUNsaWVudCk7XG4gICAgfSxcbiAgICBuYW1lOiBJTlRFR1JBVElPTl9OQU1FLFxuICB9O1xufSkgO1xuXG5jb25zdCBzdXBhYmFzZUludGVncmF0aW9uID0gaW50ZWdyYXRpb24uZGVmaW5lSW50ZWdyYXRpb24oKG9wdGlvbnMpID0+IHtcbiAgcmV0dXJuIF9zdXBhYmFzZUludGVncmF0aW9uKG9wdGlvbnMuc3VwYWJhc2VDbGllbnQpO1xufSkgO1xuXG5leHBvcnRzLkRCX09QRVJBVElPTlNfVE9fSU5TVFJVTUVOVCA9IERCX09QRVJBVElPTlNfVE9fSU5TVFJVTUVOVDtcbmV4cG9ydHMuRklMVEVSX01BUFBJTkdTID0gRklMVEVSX01BUFBJTkdTO1xuZXhwb3J0cy5leHRyYWN0T3BlcmF0aW9uID0gZXh0cmFjdE9wZXJhdGlvbjtcbmV4cG9ydHMuaW5zdHJ1bWVudFN1cGFiYXNlQ2xpZW50ID0gaW5zdHJ1bWVudFN1cGFiYXNlQ2xpZW50O1xuZXhwb3J0cy5zdXBhYmFzZUludGVncmF0aW9uID0gc3VwYWJhc2VJbnRlZ3JhdGlvbjtcbmV4cG9ydHMudHJhbnNsYXRlRmlsdGVyc0ludG9NZXRob2RzID0gdHJhbnNsYXRlRmlsdGVyc0ludG9NZXRob2RzO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9c3VwYWJhc2UuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/supabase.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/third-party-errors-filter.js":
/*!******************************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/third-party-errors-filter.js ***!
  \******************************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst integration = __webpack_require__(/*! ../integration.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integration.js\");\nconst metadata = __webpack_require__(/*! ../metadata.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/metadata.js\");\nconst envelope = __webpack_require__(/*! ../utils/envelope.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/envelope.js\");\nconst stacktrace = __webpack_require__(/*! ../utils/stacktrace.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/stacktrace.js\");\n\n/**\n * This integration allows you to filter out, or tag error events that do not come from user code marked with a bundle key via the Sentry bundler plugins.\n */\nconst thirdPartyErrorFilterIntegration = integration.defineIntegration((options) => {\n  return {\n    name: 'ThirdPartyErrorsFilter',\n    setup(client) {\n      // We need to strip metadata from stack frames before sending them to Sentry since these are client side only.\n      // TODO(lforst): Move this cleanup logic into a more central place in the SDK.\n      client.on('beforeEnvelope', envelope$1 => {\n        envelope.forEachEnvelopeItem(envelope$1, (item, type) => {\n          if (type === 'event') {\n            const event = Array.isArray(item) ? (item )[1] : undefined;\n\n            if (event) {\n              metadata.stripMetadataFromStackFrames(event);\n              item[1] = event;\n            }\n          }\n        });\n      });\n\n      client.on('applyFrameMetadata', event => {\n        // Only apply stack frame metadata to error events\n        if (event.type) {\n          return;\n        }\n\n        const stackParser = client.getOptions().stackParser;\n        metadata.addMetadataToStackFrames(stackParser, event);\n      });\n    },\n\n    processEvent(event) {\n      const frameKeys = getBundleKeysForAllFramesWithFilenames(event);\n\n      if (frameKeys) {\n        const arrayMethod =\n          options.behaviour === 'drop-error-if-contains-third-party-frames' ||\n          options.behaviour === 'apply-tag-if-contains-third-party-frames'\n            ? 'some'\n            : 'every';\n\n        const behaviourApplies = frameKeys[arrayMethod](keys => !keys.some(key => options.filterKeys.includes(key)));\n\n        if (behaviourApplies) {\n          const shouldDrop =\n            options.behaviour === 'drop-error-if-contains-third-party-frames' ||\n            options.behaviour === 'drop-error-if-exclusively-contains-third-party-frames';\n          if (shouldDrop) {\n            return null;\n          } else {\n            event.tags = {\n              ...event.tags,\n              third_party_code: true,\n            };\n          }\n        }\n      }\n\n      return event;\n    },\n  };\n});\n\nfunction getBundleKeysForAllFramesWithFilenames(event) {\n  const frames = stacktrace.getFramesFromEvent(event);\n\n  if (!frames) {\n    return undefined;\n  }\n\n  return (\n    frames\n      // Exclude frames without a filename since these are likely native code or built-ins\n      .filter(frame => !!frame.filename)\n      .map(frame => {\n        if (frame.module_metadata) {\n          return Object.keys(frame.module_metadata)\n            .filter(key => key.startsWith(BUNDLER_PLUGIN_APP_KEY_PREFIX))\n            .map(key => key.slice(BUNDLER_PLUGIN_APP_KEY_PREFIX.length));\n        }\n        return [];\n      })\n  );\n}\n\nconst BUNDLER_PLUGIN_APP_KEY_PREFIX = '_sentryBundlerPluginAppKey:';\n\nexports.thirdPartyErrorFilterIntegration = thirdPartyErrorFilterIntegration;\n//# sourceMappingURL=third-party-errors-filter.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvdGhpcmQtcGFydHktZXJyb3JzLWZpbHRlci5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxvQkFBb0IsbUJBQU8sQ0FBQyw0SEFBbUI7QUFDL0MsaUJBQWlCLG1CQUFPLENBQUMsc0hBQWdCO0FBQ3pDLGlCQUFpQixtQkFBTyxDQUFDLGtJQUFzQjtBQUMvQyxtQkFBbUIsbUJBQU8sQ0FBQyxzSUFBd0I7O0FBRW5EO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxTQUFTO0FBQ1QsT0FBTzs7QUFFUDtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQSxPQUFPO0FBQ1AsS0FBSzs7QUFFTDtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxZQUFZO0FBQ1o7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQSxLQUFLO0FBQ0w7QUFDQSxDQUFDOztBQUVEO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxPQUFPO0FBQ1A7QUFDQTs7QUFFQTs7QUFFQSx3Q0FBd0M7QUFDeEMiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvdGhpcmQtcGFydHktZXJyb3JzLWZpbHRlci5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgaW50ZWdyYXRpb24gPSByZXF1aXJlKCcuLi9pbnRlZ3JhdGlvbi5qcycpO1xuY29uc3QgbWV0YWRhdGEgPSByZXF1aXJlKCcuLi9tZXRhZGF0YS5qcycpO1xuY29uc3QgZW52ZWxvcGUgPSByZXF1aXJlKCcuLi91dGlscy9lbnZlbG9wZS5qcycpO1xuY29uc3Qgc3RhY2t0cmFjZSA9IHJlcXVpcmUoJy4uL3V0aWxzL3N0YWNrdHJhY2UuanMnKTtcblxuLyoqXG4gKiBUaGlzIGludGVncmF0aW9uIGFsbG93cyB5b3UgdG8gZmlsdGVyIG91dCwgb3IgdGFnIGVycm9yIGV2ZW50cyB0aGF0IGRvIG5vdCBjb21lIGZyb20gdXNlciBjb2RlIG1hcmtlZCB3aXRoIGEgYnVuZGxlIGtleSB2aWEgdGhlIFNlbnRyeSBidW5kbGVyIHBsdWdpbnMuXG4gKi9cbmNvbnN0IHRoaXJkUGFydHlFcnJvckZpbHRlckludGVncmF0aW9uID0gaW50ZWdyYXRpb24uZGVmaW5lSW50ZWdyYXRpb24oKG9wdGlvbnMpID0+IHtcbiAgcmV0dXJuIHtcbiAgICBuYW1lOiAnVGhpcmRQYXJ0eUVycm9yc0ZpbHRlcicsXG4gICAgc2V0dXAoY2xpZW50KSB7XG4gICAgICAvLyBXZSBuZWVkIHRvIHN0cmlwIG1ldGFkYXRhIGZyb20gc3RhY2sgZnJhbWVzIGJlZm9yZSBzZW5kaW5nIHRoZW0gdG8gU2VudHJ5IHNpbmNlIHRoZXNlIGFyZSBjbGllbnQgc2lkZSBvbmx5LlxuICAgICAgLy8gVE9ETyhsZm9yc3QpOiBNb3ZlIHRoaXMgY2xlYW51cCBsb2dpYyBpbnRvIGEgbW9yZSBjZW50cmFsIHBsYWNlIGluIHRoZSBTREsuXG4gICAgICBjbGllbnQub24oJ2JlZm9yZUVudmVsb3BlJywgZW52ZWxvcGUkMSA9PiB7XG4gICAgICAgIGVudmVsb3BlLmZvckVhY2hFbnZlbG9wZUl0ZW0oZW52ZWxvcGUkMSwgKGl0ZW0sIHR5cGUpID0+IHtcbiAgICAgICAgICBpZiAodHlwZSA9PT0gJ2V2ZW50Jykge1xuICAgICAgICAgICAgY29uc3QgZXZlbnQgPSBBcnJheS5pc0FycmF5KGl0ZW0pID8gKGl0ZW0gKVsxXSA6IHVuZGVmaW5lZDtcblxuICAgICAgICAgICAgaWYgKGV2ZW50KSB7XG4gICAgICAgICAgICAgIG1ldGFkYXRhLnN0cmlwTWV0YWRhdGFGcm9tU3RhY2tGcmFtZXMoZXZlbnQpO1xuICAgICAgICAgICAgICBpdGVtWzFdID0gZXZlbnQ7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgfVxuICAgICAgICB9KTtcbiAgICAgIH0pO1xuXG4gICAgICBjbGllbnQub24oJ2FwcGx5RnJhbWVNZXRhZGF0YScsIGV2ZW50ID0+IHtcbiAgICAgICAgLy8gT25seSBhcHBseSBzdGFjayBmcmFtZSBtZXRhZGF0YSB0byBlcnJvciBldmVudHNcbiAgICAgICAgaWYgKGV2ZW50LnR5cGUpIHtcbiAgICAgICAgICByZXR1cm47XG4gICAgICAgIH1cblxuICAgICAgICBjb25zdCBzdGFja1BhcnNlciA9IGNsaWVudC5nZXRPcHRpb25zKCkuc3RhY2tQYXJzZXI7XG4gICAgICAgIG1ldGFkYXRhLmFkZE1ldGFkYXRhVG9TdGFja0ZyYW1lcyhzdGFja1BhcnNlciwgZXZlbnQpO1xuICAgICAgfSk7XG4gICAgfSxcblxuICAgIHByb2Nlc3NFdmVudChldmVudCkge1xuICAgICAgY29uc3QgZnJhbWVLZXlzID0gZ2V0QnVuZGxlS2V5c0ZvckFsbEZyYW1lc1dpdGhGaWxlbmFtZXMoZXZlbnQpO1xuXG4gICAgICBpZiAoZnJhbWVLZXlzKSB7XG4gICAgICAgIGNvbnN0IGFycmF5TWV0aG9kID1cbiAgICAgICAgICBvcHRpb25zLmJlaGF2aW91ciA9PT0gJ2Ryb3AtZXJyb3ItaWYtY29udGFpbnMtdGhpcmQtcGFydHktZnJhbWVzJyB8fFxuICAgICAgICAgIG9wdGlvbnMuYmVoYXZpb3VyID09PSAnYXBwbHktdGFnLWlmLWNvbnRhaW5zLXRoaXJkLXBhcnR5LWZyYW1lcydcbiAgICAgICAgICAgID8gJ3NvbWUnXG4gICAgICAgICAgICA6ICdldmVyeSc7XG5cbiAgICAgICAgY29uc3QgYmVoYXZpb3VyQXBwbGllcyA9IGZyYW1lS2V5c1thcnJheU1ldGhvZF0oa2V5cyA9PiAha2V5cy5zb21lKGtleSA9PiBvcHRpb25zLmZpbHRlcktleXMuaW5jbHVkZXMoa2V5KSkpO1xuXG4gICAgICAgIGlmIChiZWhhdmlvdXJBcHBsaWVzKSB7XG4gICAgICAgICAgY29uc3Qgc2hvdWxkRHJvcCA9XG4gICAgICAgICAgICBvcHRpb25zLmJlaGF2aW91ciA9PT0gJ2Ryb3AtZXJyb3ItaWYtY29udGFpbnMtdGhpcmQtcGFydHktZnJhbWVzJyB8fFxuICAgICAgICAgICAgb3B0aW9ucy5iZWhhdmlvdXIgPT09ICdkcm9wLWVycm9yLWlmLWV4Y2x1c2l2ZWx5LWNvbnRhaW5zLXRoaXJkLXBhcnR5LWZyYW1lcyc7XG4gICAgICAgICAgaWYgKHNob3VsZERyb3ApIHtcbiAgICAgICAgICAgIHJldHVybiBudWxsO1xuICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICBldmVudC50YWdzID0ge1xuICAgICAgICAgICAgICAuLi5ldmVudC50YWdzLFxuICAgICAgICAgICAgICB0aGlyZF9wYXJ0eV9jb2RlOiB0cnVlLFxuICAgICAgICAgICAgfTtcbiAgICAgICAgICB9XG4gICAgICAgIH1cbiAgICAgIH1cblxuICAgICAgcmV0dXJuIGV2ZW50O1xuICAgIH0sXG4gIH07XG59KTtcblxuZnVuY3Rpb24gZ2V0QnVuZGxlS2V5c0ZvckFsbEZyYW1lc1dpdGhGaWxlbmFtZXMoZXZlbnQpIHtcbiAgY29uc3QgZnJhbWVzID0gc3RhY2t0cmFjZS5nZXRGcmFtZXNGcm9tRXZlbnQoZXZlbnQpO1xuXG4gIGlmICghZnJhbWVzKSB7XG4gICAgcmV0dXJuIHVuZGVmaW5lZDtcbiAgfVxuXG4gIHJldHVybiAoXG4gICAgZnJhbWVzXG4gICAgICAvLyBFeGNsdWRlIGZyYW1lcyB3aXRob3V0IGEgZmlsZW5hbWUgc2luY2UgdGhlc2UgYXJlIGxpa2VseSBuYXRpdmUgY29kZSBvciBidWlsdC1pbnNcbiAgICAgIC5maWx0ZXIoZnJhbWUgPT4gISFmcmFtZS5maWxlbmFtZSlcbiAgICAgIC5tYXAoZnJhbWUgPT4ge1xuICAgICAgICBpZiAoZnJhbWUubW9kdWxlX21ldGFkYXRhKSB7XG4gICAgICAgICAgcmV0dXJuIE9iamVjdC5rZXlzKGZyYW1lLm1vZHVsZV9tZXRhZGF0YSlcbiAgICAgICAgICAgIC5maWx0ZXIoa2V5ID0+IGtleS5zdGFydHNXaXRoKEJVTkRMRVJfUExVR0lOX0FQUF9LRVlfUFJFRklYKSlcbiAgICAgICAgICAgIC5tYXAoa2V5ID0+IGtleS5zbGljZShCVU5ETEVSX1BMVUdJTl9BUFBfS0VZX1BSRUZJWC5sZW5ndGgpKTtcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gW107XG4gICAgICB9KVxuICApO1xufVxuXG5jb25zdCBCVU5ETEVSX1BMVUdJTl9BUFBfS0VZX1BSRUZJWCA9ICdfc2VudHJ5QnVuZGxlclBsdWdpbkFwcEtleTonO1xuXG5leHBvcnRzLnRoaXJkUGFydHlFcnJvckZpbHRlckludGVncmF0aW9uID0gdGhpcmRQYXJ0eUVycm9yRmlsdGVySW50ZWdyYXRpb247XG4vLyMgc291cmNlTWFwcGluZ1VSTD10aGlyZC1wYXJ0eS1lcnJvcnMtZmlsdGVyLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/third-party-errors-filter.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/zoderrors.js":
/*!**************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/zoderrors.js ***!
  \**************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst integration = __webpack_require__(/*! ../integration.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integration.js\");\nconst is = __webpack_require__(/*! ../utils/is.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js\");\nconst string = __webpack_require__(/*! ../utils/string.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/string.js\");\n\nconst DEFAULT_LIMIT = 10;\nconst INTEGRATION_NAME = 'ZodErrors';\n\n/**\n * Simplified ZodIssue type definition\n */\n\nfunction originalExceptionIsZodError(originalException) {\n  return (\n    is.isError(originalException) &&\n    originalException.name === 'ZodError' &&\n    Array.isArray((originalException ).issues)\n  );\n}\n\n/**\n * Formats child objects or arrays to a string\n * that is preserved when sent to Sentry.\n *\n * Without this, we end up with something like this in Sentry:\n *\n * [\n *  [Object],\n *  [Object],\n *  [Object],\n *  [Object]\n * ]\n */\nfunction flattenIssue(issue) {\n  return {\n    ...issue,\n    path: 'path' in issue && Array.isArray(issue.path) ? issue.path.join('.') : undefined,\n    keys: 'keys' in issue ? JSON.stringify(issue.keys) : undefined,\n    unionErrors: 'unionErrors' in issue ? JSON.stringify(issue.unionErrors) : undefined,\n  };\n}\n\n/**\n * Takes ZodError issue path array and returns a flattened version as a string.\n * This makes it easier to display paths within a Sentry error message.\n *\n * Array indexes are normalized to reduce duplicate entries\n *\n * @param path ZodError issue path\n * @returns flattened path\n *\n * @example\n * flattenIssuePath([0, 'foo', 1, 'bar']) // -> '<array>.foo.<array>.bar'\n */\nfunction flattenIssuePath(path) {\n  return path\n    .map(p => {\n      if (typeof p === 'number') {\n        return '<array>';\n      } else {\n        return p;\n      }\n    })\n    .join('.');\n}\n\n/**\n * Zod error message is a stringified version of ZodError.issues\n * This doesn't display well in the Sentry UI. Replace it with something shorter.\n */\nfunction formatIssueMessage(zodError) {\n  const errorKeyMap = new Set();\n  for (const iss of zodError.issues) {\n    const issuePath = flattenIssuePath(iss.path);\n    if (issuePath.length > 0) {\n      errorKeyMap.add(issuePath);\n    }\n  }\n\n  const errorKeys = Array.from(errorKeyMap);\n  if (errorKeys.length === 0) {\n    // If there are no keys, then we're likely validating the root\n    // variable rather than a key within an object. This attempts\n    // to extract what type it was that failed to validate.\n    // For example, z.string().parse(123) would return \"string\" here.\n    let rootExpectedType = 'variable';\n    if (zodError.issues.length > 0) {\n      const iss = zodError.issues[0];\n      if (iss !== undefined && 'expected' in iss && typeof iss.expected === 'string') {\n        rootExpectedType = iss.expected;\n      }\n    }\n    return `Failed to validate ${rootExpectedType}`;\n  }\n  return `Failed to validate keys: ${string.truncate(errorKeys.join(', '), 100)}`;\n}\n\n/**\n * Applies ZodError issues to an event extra and replaces the error message\n */\nfunction applyZodErrorsToEvent(\n  limit,\n  saveZodIssuesAsAttachment = false,\n  event,\n  hint,\n) {\n  if (\n    !event.exception?.values ||\n    !hint.originalException ||\n    !originalExceptionIsZodError(hint.originalException) ||\n    hint.originalException.issues.length === 0\n  ) {\n    return event;\n  }\n\n  try {\n    const issuesToFlatten = saveZodIssuesAsAttachment\n      ? hint.originalException.issues\n      : hint.originalException.issues.slice(0, limit);\n    const flattenedIssues = issuesToFlatten.map(flattenIssue);\n\n    if (saveZodIssuesAsAttachment) {\n      // Sometimes having the full error details can be helpful.\n      // Attachments have much higher limits, so we can include the full list of issues.\n      if (!Array.isArray(hint.attachments)) {\n        hint.attachments = [];\n      }\n      hint.attachments.push({\n        filename: 'zod_issues.json',\n        data: JSON.stringify({\n          issues: flattenedIssues,\n        }),\n      });\n    }\n\n    return {\n      ...event,\n      exception: {\n        ...event.exception,\n        values: [\n          {\n            ...event.exception.values[0],\n            value: formatIssueMessage(hint.originalException),\n          },\n          ...event.exception.values.slice(1),\n        ],\n      },\n      extra: {\n        ...event.extra,\n        'zoderror.issues': flattenedIssues.slice(0, limit),\n      },\n    };\n  } catch (e) {\n    // Hopefully we never throw errors here, but record it\n    // with the event just in case.\n    return {\n      ...event,\n      extra: {\n        ...event.extra,\n        'zoderrors sentry integration parse error': {\n          message: 'an exception was thrown while processing ZodError within applyZodErrorsToEvent()',\n          error: e instanceof Error ? `${e.name}: ${e.message}\\n${e.stack}` : 'unknown',\n        },\n      },\n    };\n  }\n}\n\nconst _zodErrorsIntegration = ((options = {}) => {\n  const limit = options.limit ?? DEFAULT_LIMIT;\n\n  return {\n    name: INTEGRATION_NAME,\n    processEvent(originalEvent, hint) {\n      const processedEvent = applyZodErrorsToEvent(limit, options.saveZodIssuesAsAttachment, originalEvent, hint);\n      return processedEvent;\n    },\n  };\n}) ;\n\n/**\n * Sentry integration to process Zod errors, making them easier to work with in Sentry.\n */\nconst zodErrorsIntegration = integration.defineIntegration(_zodErrorsIntegration);\n\nexports.applyZodErrorsToEvent = applyZodErrorsToEvent;\nexports.flattenIssue = flattenIssue;\nexports.flattenIssuePath = flattenIssuePath;\nexports.formatIssueMessage = formatIssueMessage;\nexports.zodErrorsIntegration = zodErrorsIntegration;\n//# sourceMappingURL=zoderrors.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvem9kZXJyb3JzLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLG9CQUFvQixtQkFBTyxDQUFDLDRIQUFtQjtBQUMvQyxXQUFXLG1CQUFPLENBQUMsc0hBQWdCO0FBQ25DLGVBQWUsbUJBQU8sQ0FBQyw4SEFBb0I7O0FBRTNDO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsUUFBUTtBQUNSO0FBQ0E7QUFDQSxLQUFLO0FBQ0w7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxpQ0FBaUMsaUJBQWlCO0FBQ2xEO0FBQ0EscUNBQXFDLDJDQUEyQztBQUNoRjs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxTQUFTO0FBQ1QsT0FBTztBQUNQOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxXQUFXO0FBQ1g7QUFDQTtBQUNBLE9BQU87QUFDUDtBQUNBO0FBQ0E7QUFDQSxPQUFPO0FBQ1A7QUFDQSxJQUFJO0FBQ0o7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLHlDQUF5QyxPQUFPLElBQUksVUFBVSxJQUFJLFFBQVE7QUFDMUUsU0FBUztBQUNULE9BQU87QUFDUDtBQUNBO0FBQ0E7O0FBRUEsNENBQTRDO0FBQzVDOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxLQUFLO0FBQ0w7QUFDQSxDQUFDOztBQUVEO0FBQ0E7QUFDQTtBQUNBOztBQUVBLDZCQUE2QjtBQUM3QixvQkFBb0I7QUFDcEIsd0JBQXdCO0FBQ3hCLDBCQUEwQjtBQUMxQiw0QkFBNEI7QUFDNUIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvem9kZXJyb3JzLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBpbnRlZ3JhdGlvbiA9IHJlcXVpcmUoJy4uL2ludGVncmF0aW9uLmpzJyk7XG5jb25zdCBpcyA9IHJlcXVpcmUoJy4uL3V0aWxzL2lzLmpzJyk7XG5jb25zdCBzdHJpbmcgPSByZXF1aXJlKCcuLi91dGlscy9zdHJpbmcuanMnKTtcblxuY29uc3QgREVGQVVMVF9MSU1JVCA9IDEwO1xuY29uc3QgSU5URUdSQVRJT05fTkFNRSA9ICdab2RFcnJvcnMnO1xuXG4vKipcbiAqIFNpbXBsaWZpZWQgWm9kSXNzdWUgdHlwZSBkZWZpbml0aW9uXG4gKi9cblxuZnVuY3Rpb24gb3JpZ2luYWxFeGNlcHRpb25Jc1pvZEVycm9yKG9yaWdpbmFsRXhjZXB0aW9uKSB7XG4gIHJldHVybiAoXG4gICAgaXMuaXNFcnJvcihvcmlnaW5hbEV4Y2VwdGlvbikgJiZcbiAgICBvcmlnaW5hbEV4Y2VwdGlvbi5uYW1lID09PSAnWm9kRXJyb3InICYmXG4gICAgQXJyYXkuaXNBcnJheSgob3JpZ2luYWxFeGNlcHRpb24gKS5pc3N1ZXMpXG4gICk7XG59XG5cbi8qKlxuICogRm9ybWF0cyBjaGlsZCBvYmplY3RzIG9yIGFycmF5cyB0byBhIHN0cmluZ1xuICogdGhhdCBpcyBwcmVzZXJ2ZWQgd2hlbiBzZW50IHRvIFNlbnRyeS5cbiAqXG4gKiBXaXRob3V0IHRoaXMsIHdlIGVuZCB1cCB3aXRoIHNvbWV0aGluZyBsaWtlIHRoaXMgaW4gU2VudHJ5OlxuICpcbiAqIFtcbiAqICBbT2JqZWN0XSxcbiAqICBbT2JqZWN0XSxcbiAqICBbT2JqZWN0XSxcbiAqICBbT2JqZWN0XVxuICogXVxuICovXG5mdW5jdGlvbiBmbGF0dGVuSXNzdWUoaXNzdWUpIHtcbiAgcmV0dXJuIHtcbiAgICAuLi5pc3N1ZSxcbiAgICBwYXRoOiAncGF0aCcgaW4gaXNzdWUgJiYgQXJyYXkuaXNBcnJheShpc3N1ZS5wYXRoKSA/IGlzc3VlLnBhdGguam9pbignLicpIDogdW5kZWZpbmVkLFxuICAgIGtleXM6ICdrZXlzJyBpbiBpc3N1ZSA/IEpTT04uc3RyaW5naWZ5KGlzc3VlLmtleXMpIDogdW5kZWZpbmVkLFxuICAgIHVuaW9uRXJyb3JzOiAndW5pb25FcnJvcnMnIGluIGlzc3VlID8gSlNPTi5zdHJpbmdpZnkoaXNzdWUudW5pb25FcnJvcnMpIDogdW5kZWZpbmVkLFxuICB9O1xufVxuXG4vKipcbiAqIFRha2VzIFpvZEVycm9yIGlzc3VlIHBhdGggYXJyYXkgYW5kIHJldHVybnMgYSBmbGF0dGVuZWQgdmVyc2lvbiBhcyBhIHN0cmluZy5cbiAqIFRoaXMgbWFrZXMgaXQgZWFzaWVyIHRvIGRpc3BsYXkgcGF0aHMgd2l0aGluIGEgU2VudHJ5IGVycm9yIG1lc3NhZ2UuXG4gKlxuICogQXJyYXkgaW5kZXhlcyBhcmUgbm9ybWFsaXplZCB0byByZWR1Y2UgZHVwbGljYXRlIGVudHJpZXNcbiAqXG4gKiBAcGFyYW0gcGF0aCBab2RFcnJvciBpc3N1ZSBwYXRoXG4gKiBAcmV0dXJucyBmbGF0dGVuZWQgcGF0aFxuICpcbiAqIEBleGFtcGxlXG4gKiBmbGF0dGVuSXNzdWVQYXRoKFswLCAnZm9vJywgMSwgJ2JhciddKSAvLyAtPiAnPGFycmF5Pi5mb28uPGFycmF5Pi5iYXInXG4gKi9cbmZ1bmN0aW9uIGZsYXR0ZW5Jc3N1ZVBhdGgocGF0aCkge1xuICByZXR1cm4gcGF0aFxuICAgIC5tYXAocCA9PiB7XG4gICAgICBpZiAodHlwZW9mIHAgPT09ICdudW1iZXInKSB7XG4gICAgICAgIHJldHVybiAnPGFycmF5Pic7XG4gICAgICB9IGVsc2Uge1xuICAgICAgICByZXR1cm4gcDtcbiAgICAgIH1cbiAgICB9KVxuICAgIC5qb2luKCcuJyk7XG59XG5cbi8qKlxuICogWm9kIGVycm9yIG1lc3NhZ2UgaXMgYSBzdHJpbmdpZmllZCB2ZXJzaW9uIG9mIFpvZEVycm9yLmlzc3Vlc1xuICogVGhpcyBkb2Vzbid0IGRpc3BsYXkgd2VsbCBpbiB0aGUgU2VudHJ5IFVJLiBSZXBsYWNlIGl0IHdpdGggc29tZXRoaW5nIHNob3J0ZXIuXG4gKi9cbmZ1bmN0aW9uIGZvcm1hdElzc3VlTWVzc2FnZSh6b2RFcnJvcikge1xuICBjb25zdCBlcnJvcktleU1hcCA9IG5ldyBTZXQoKTtcbiAgZm9yIChjb25zdCBpc3Mgb2Ygem9kRXJyb3IuaXNzdWVzKSB7XG4gICAgY29uc3QgaXNzdWVQYXRoID0gZmxhdHRlbklzc3VlUGF0aChpc3MucGF0aCk7XG4gICAgaWYgKGlzc3VlUGF0aC5sZW5ndGggPiAwKSB7XG4gICAgICBlcnJvcktleU1hcC5hZGQoaXNzdWVQYXRoKTtcbiAgICB9XG4gIH1cblxuICBjb25zdCBlcnJvcktleXMgPSBBcnJheS5mcm9tKGVycm9yS2V5TWFwKTtcbiAgaWYgKGVycm9yS2V5cy5sZW5ndGggPT09IDApIHtcbiAgICAvLyBJZiB0aGVyZSBhcmUgbm8ga2V5cywgdGhlbiB3ZSdyZSBsaWtlbHkgdmFsaWRhdGluZyB0aGUgcm9vdFxuICAgIC8vIHZhcmlhYmxlIHJhdGhlciB0aGFuIGEga2V5IHdpdGhpbiBhbiBvYmplY3QuIFRoaXMgYXR0ZW1wdHNcbiAgICAvLyB0byBleHRyYWN0IHdoYXQgdHlwZSBpdCB3YXMgdGhhdCBmYWlsZWQgdG8gdmFsaWRhdGUuXG4gICAgLy8gRm9yIGV4YW1wbGUsIHouc3RyaW5nKCkucGFyc2UoMTIzKSB3b3VsZCByZXR1cm4gXCJzdHJpbmdcIiBoZXJlLlxuICAgIGxldCByb290RXhwZWN0ZWRUeXBlID0gJ3ZhcmlhYmxlJztcbiAgICBpZiAoem9kRXJyb3IuaXNzdWVzLmxlbmd0aCA+IDApIHtcbiAgICAgIGNvbnN0IGlzcyA9IHpvZEVycm9yLmlzc3Vlc1swXTtcbiAgICAgIGlmIChpc3MgIT09IHVuZGVmaW5lZCAmJiAnZXhwZWN0ZWQnIGluIGlzcyAmJiB0eXBlb2YgaXNzLmV4cGVjdGVkID09PSAnc3RyaW5nJykge1xuICAgICAgICByb290RXhwZWN0ZWRUeXBlID0gaXNzLmV4cGVjdGVkO1xuICAgICAgfVxuICAgIH1cbiAgICByZXR1cm4gYEZhaWxlZCB0byB2YWxpZGF0ZSAke3Jvb3RFeHBlY3RlZFR5cGV9YDtcbiAgfVxuICByZXR1cm4gYEZhaWxlZCB0byB2YWxpZGF0ZSBrZXlzOiAke3N0cmluZy50cnVuY2F0ZShlcnJvcktleXMuam9pbignLCAnKSwgMTAwKX1gO1xufVxuXG4vKipcbiAqIEFwcGxpZXMgWm9kRXJyb3IgaXNzdWVzIHRvIGFuIGV2ZW50IGV4dHJhIGFuZCByZXBsYWNlcyB0aGUgZXJyb3IgbWVzc2FnZVxuICovXG5mdW5jdGlvbiBhcHBseVpvZEVycm9yc1RvRXZlbnQoXG4gIGxpbWl0LFxuICBzYXZlWm9kSXNzdWVzQXNBdHRhY2htZW50ID0gZmFsc2UsXG4gIGV2ZW50LFxuICBoaW50LFxuKSB7XG4gIGlmIChcbiAgICAhZXZlbnQuZXhjZXB0aW9uPy52YWx1ZXMgfHxcbiAgICAhaGludC5vcmlnaW5hbEV4Y2VwdGlvbiB8fFxuICAgICFvcmlnaW5hbEV4Y2VwdGlvbklzWm9kRXJyb3IoaGludC5vcmlnaW5hbEV4Y2VwdGlvbikgfHxcbiAgICBoaW50Lm9yaWdpbmFsRXhjZXB0aW9uLmlzc3Vlcy5sZW5ndGggPT09IDBcbiAgKSB7XG4gICAgcmV0dXJuIGV2ZW50O1xuICB9XG5cbiAgdHJ5IHtcbiAgICBjb25zdCBpc3N1ZXNUb0ZsYXR0ZW4gPSBzYXZlWm9kSXNzdWVzQXNBdHRhY2htZW50XG4gICAgICA/IGhpbnQub3JpZ2luYWxFeGNlcHRpb24uaXNzdWVzXG4gICAgICA6IGhpbnQub3JpZ2luYWxFeGNlcHRpb24uaXNzdWVzLnNsaWNlKDAsIGxpbWl0KTtcbiAgICBjb25zdCBmbGF0dGVuZWRJc3N1ZXMgPSBpc3N1ZXNUb0ZsYXR0ZW4ubWFwKGZsYXR0ZW5Jc3N1ZSk7XG5cbiAgICBpZiAoc2F2ZVpvZElzc3Vlc0FzQXR0YWNobWVudCkge1xuICAgICAgLy8gU29tZXRpbWVzIGhhdmluZyB0aGUgZnVsbCBlcnJvciBkZXRhaWxzIGNhbiBiZSBoZWxwZnVsLlxuICAgICAgLy8gQXR0YWNobWVudHMgaGF2ZSBtdWNoIGhpZ2hlciBsaW1pdHMsIHNvIHdlIGNhbiBpbmNsdWRlIHRoZSBmdWxsIGxpc3Qgb2YgaXNzdWVzLlxuICAgICAgaWYgKCFBcnJheS5pc0FycmF5KGhpbnQuYXR0YWNobWVudHMpKSB7XG4gICAgICAgIGhpbnQuYXR0YWNobWVudHMgPSBbXTtcbiAgICAgIH1cbiAgICAgIGhpbnQuYXR0YWNobWVudHMucHVzaCh7XG4gICAgICAgIGZpbGVuYW1lOiAnem9kX2lzc3Vlcy5qc29uJyxcbiAgICAgICAgZGF0YTogSlNPTi5zdHJpbmdpZnkoe1xuICAgICAgICAgIGlzc3VlczogZmxhdHRlbmVkSXNzdWVzLFxuICAgICAgICB9KSxcbiAgICAgIH0pO1xuICAgIH1cblxuICAgIHJldHVybiB7XG4gICAgICAuLi5ldmVudCxcbiAgICAgIGV4Y2VwdGlvbjoge1xuICAgICAgICAuLi5ldmVudC5leGNlcHRpb24sXG4gICAgICAgIHZhbHVlczogW1xuICAgICAgICAgIHtcbiAgICAgICAgICAgIC4uLmV2ZW50LmV4Y2VwdGlvbi52YWx1ZXNbMF0sXG4gICAgICAgICAgICB2YWx1ZTogZm9ybWF0SXNzdWVNZXNzYWdlKGhpbnQub3JpZ2luYWxFeGNlcHRpb24pLFxuICAgICAgICAgIH0sXG4gICAgICAgICAgLi4uZXZlbnQuZXhjZXB0aW9uLnZhbHVlcy5zbGljZSgxKSxcbiAgICAgICAgXSxcbiAgICAgIH0sXG4gICAgICBleHRyYToge1xuICAgICAgICAuLi5ldmVudC5leHRyYSxcbiAgICAgICAgJ3pvZGVycm9yLmlzc3Vlcyc6IGZsYXR0ZW5lZElzc3Vlcy5zbGljZSgwLCBsaW1pdCksXG4gICAgICB9LFxuICAgIH07XG4gIH0gY2F0Y2ggKGUpIHtcbiAgICAvLyBIb3BlZnVsbHkgd2UgbmV2ZXIgdGhyb3cgZXJyb3JzIGhlcmUsIGJ1dCByZWNvcmQgaXRcbiAgICAvLyB3aXRoIHRoZSBldmVudCBqdXN0IGluIGNhc2UuXG4gICAgcmV0dXJuIHtcbiAgICAgIC4uLmV2ZW50LFxuICAgICAgZXh0cmE6IHtcbiAgICAgICAgLi4uZXZlbnQuZXh0cmEsXG4gICAgICAgICd6b2RlcnJvcnMgc2VudHJ5IGludGVncmF0aW9uIHBhcnNlIGVycm9yJzoge1xuICAgICAgICAgIG1lc3NhZ2U6ICdhbiBleGNlcHRpb24gd2FzIHRocm93biB3aGlsZSBwcm9jZXNzaW5nIFpvZEVycm9yIHdpdGhpbiBhcHBseVpvZEVycm9yc1RvRXZlbnQoKScsXG4gICAgICAgICAgZXJyb3I6IGUgaW5zdGFuY2VvZiBFcnJvciA/IGAke2UubmFtZX06ICR7ZS5tZXNzYWdlfVxcbiR7ZS5zdGFja31gIDogJ3Vua25vd24nLFxuICAgICAgICB9LFxuICAgICAgfSxcbiAgICB9O1xuICB9XG59XG5cbmNvbnN0IF96b2RFcnJvcnNJbnRlZ3JhdGlvbiA9ICgob3B0aW9ucyA9IHt9KSA9PiB7XG4gIGNvbnN0IGxpbWl0ID0gb3B0aW9ucy5saW1pdCA/PyBERUZBVUxUX0xJTUlUO1xuXG4gIHJldHVybiB7XG4gICAgbmFtZTogSU5URUdSQVRJT05fTkFNRSxcbiAgICBwcm9jZXNzRXZlbnQob3JpZ2luYWxFdmVudCwgaGludCkge1xuICAgICAgY29uc3QgcHJvY2Vzc2VkRXZlbnQgPSBhcHBseVpvZEVycm9yc1RvRXZlbnQobGltaXQsIG9wdGlvbnMuc2F2ZVpvZElzc3Vlc0FzQXR0YWNobWVudCwgb3JpZ2luYWxFdmVudCwgaGludCk7XG4gICAgICByZXR1cm4gcHJvY2Vzc2VkRXZlbnQ7XG4gICAgfSxcbiAgfTtcbn0pIDtcblxuLyoqXG4gKiBTZW50cnkgaW50ZWdyYXRpb24gdG8gcHJvY2VzcyBab2QgZXJyb3JzLCBtYWtpbmcgdGhlbSBlYXNpZXIgdG8gd29yayB3aXRoIGluIFNlbnRyeS5cbiAqL1xuY29uc3Qgem9kRXJyb3JzSW50ZWdyYXRpb24gPSBpbnRlZ3JhdGlvbi5kZWZpbmVJbnRlZ3JhdGlvbihfem9kRXJyb3JzSW50ZWdyYXRpb24pO1xuXG5leHBvcnRzLmFwcGx5Wm9kRXJyb3JzVG9FdmVudCA9IGFwcGx5Wm9kRXJyb3JzVG9FdmVudDtcbmV4cG9ydHMuZmxhdHRlbklzc3VlID0gZmxhdHRlbklzc3VlO1xuZXhwb3J0cy5mbGF0dGVuSXNzdWVQYXRoID0gZmxhdHRlbklzc3VlUGF0aDtcbmV4cG9ydHMuZm9ybWF0SXNzdWVNZXNzYWdlID0gZm9ybWF0SXNzdWVNZXNzYWdlO1xuZXhwb3J0cy56b2RFcnJvcnNJbnRlZ3JhdGlvbiA9IHpvZEVycm9yc0ludGVncmF0aW9uO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9em9kZXJyb3JzLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/zoderrors.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/logs/console-integration.js":
/*!****************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/logs/console-integration.js ***!
  \****************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst currentScopes = __webpack_require__(/*! ../currentScopes.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst debugBuild = __webpack_require__(/*! ../debug-build.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst console = __webpack_require__(/*! ../instrument/console.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/console.js\");\nconst integration = __webpack_require__(/*! ../integration.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integration.js\");\nconst semanticAttributes = __webpack_require__(/*! ../semanticAttributes.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/semanticAttributes.js\");\nconst debugLogger = __webpack_require__(/*! ../utils/debug-logger.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst is = __webpack_require__(/*! ../utils/is.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js\");\nconst normalize = __webpack_require__(/*! ../utils/normalize.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/normalize.js\");\nconst worldwide = __webpack_require__(/*! ../utils/worldwide.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/worldwide.js\");\nconst exports$1 = __webpack_require__(/*! ./exports.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/logs/exports.js\");\n\nconst INTEGRATION_NAME = 'ConsoleLogs';\n\nconst DEFAULT_ATTRIBUTES = {\n  [semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_ORIGIN]: 'auto.console.logging',\n};\n\nconst _consoleLoggingIntegration = ((options = {}) => {\n  const levels = options.levels || debugLogger.CONSOLE_LEVELS;\n\n  return {\n    name: INTEGRATION_NAME,\n    setup(client) {\n      const { enableLogs, _experiments, normalizeDepth = 3, normalizeMaxBreadth = 1000 } = client.getOptions();\n      // eslint-disable-next-line deprecation/deprecation\n      const shouldEnableLogs = enableLogs ?? _experiments?.enableLogs;\n      if (!shouldEnableLogs) {\n        debugBuild.DEBUG_BUILD && debugLogger.debug.warn('`enableLogs` is not enabled, ConsoleLogs integration disabled');\n        return;\n      }\n\n      console.addConsoleInstrumentationHandler(({ args, level }) => {\n        if (currentScopes.getClient() !== client || !levels.includes(level)) {\n          return;\n        }\n\n        if (level === 'assert') {\n          if (!args[0]) {\n            const followingArgs = args.slice(1);\n            const assertionMessage =\n              followingArgs.length > 0\n                ? `Assertion failed: ${formatConsoleArgs(followingArgs, normalizeDepth, normalizeMaxBreadth)}`\n                : 'Assertion failed';\n            exports$1._INTERNAL_captureLog({ level: 'error', message: assertionMessage, attributes: DEFAULT_ATTRIBUTES });\n          }\n          return;\n        }\n\n        const isLevelLog = level === 'log';\n        exports$1._INTERNAL_captureLog({\n          level: isLevelLog ? 'info' : level,\n          message: formatConsoleArgs(args, normalizeDepth, normalizeMaxBreadth),\n          severityNumber: isLevelLog ? 10 : undefined,\n          attributes: DEFAULT_ATTRIBUTES,\n        });\n      });\n    },\n  };\n}) ;\n\n/**\n * Captures calls to the `console` API as logs in Sentry. Requires the `enableLogs` option to be enabled.\n *\n * @experimental This feature is experimental and may be changed or removed in future versions.\n *\n * By default the integration instruments `console.debug`, `console.info`, `console.warn`, `console.error`,\n * `console.log`, `console.trace`, and `console.assert`. You can use the `levels` option to customize which\n * levels are captured.\n *\n * @example\n *\n * ```ts\n * import * as Sentry from '@sentry/browser';\n *\n * Sentry.init({\n *   enableLogs: true,\n *   integrations: [Sentry.consoleLoggingIntegration({ levels: ['error', 'warn'] })],\n * });\n * ```\n */\nconst consoleLoggingIntegration = integration.defineIntegration(_consoleLoggingIntegration);\n\nfunction formatConsoleArgs(values, normalizeDepth, normalizeMaxBreadth) {\n  return 'util' in worldwide.GLOBAL_OBJ && typeof (worldwide.GLOBAL_OBJ ).util.format === 'function'\n    ? (worldwide.GLOBAL_OBJ ).util.format(...values)\n    : safeJoinConsoleArgs(values, normalizeDepth, normalizeMaxBreadth);\n}\n\nfunction safeJoinConsoleArgs(values, normalizeDepth, normalizeMaxBreadth) {\n  return values\n    .map(value =>\n      is.isPrimitive(value) ? String(value) : JSON.stringify(normalize.normalize(value, normalizeDepth, normalizeMaxBreadth)),\n    )\n    .join(' ');\n}\n\nexports.consoleLoggingIntegration = consoleLoggingIntegration;\n//# sourceMappingURL=console-integration.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9sb2dzL2NvbnNvbGUtaW50ZWdyYXRpb24uanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsc0JBQXNCLG1CQUFPLENBQUMsZ0lBQXFCO0FBQ25ELG1CQUFtQixtQkFBTyxDQUFDLDRIQUFtQjtBQUM5QyxnQkFBZ0IsbUJBQU8sQ0FBQywwSUFBMEI7QUFDbEQsb0JBQW9CLG1CQUFPLENBQUMsNEhBQW1CO0FBQy9DLDJCQUEyQixtQkFBTyxDQUFDLDBJQUEwQjtBQUM3RCxvQkFBb0IsbUJBQU8sQ0FBQywwSUFBMEI7QUFDdEQsV0FBVyxtQkFBTyxDQUFDLHNIQUFnQjtBQUNuQyxrQkFBa0IsbUJBQU8sQ0FBQyxvSUFBdUI7QUFDakQsa0JBQWtCLG1CQUFPLENBQUMsb0lBQXVCO0FBQ2pELGtCQUFrQixtQkFBTyxDQUFDLHdIQUFjOztBQUV4Qzs7QUFFQTtBQUNBO0FBQ0E7O0FBRUEsaURBQWlEO0FBQ2pEOztBQUVBO0FBQ0E7QUFDQTtBQUNBLGNBQWMsMkVBQTJFO0FBQ3pGO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSxrREFBa0QsYUFBYTtBQUMvRDtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLHVDQUF1QyxzRUFBc0U7QUFDN0c7QUFDQSw2Q0FBNkMsMkVBQTJFO0FBQ3hIO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxTQUFTO0FBQ1QsT0FBTztBQUNQLEtBQUs7QUFDTDtBQUNBLENBQUM7O0FBRUQ7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSx1REFBdUQsMkJBQTJCO0FBQ2xGLElBQUk7QUFDSjtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSxpQ0FBaUM7QUFDakMiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9sb2dzL2NvbnNvbGUtaW50ZWdyYXRpb24uanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGN1cnJlbnRTY29wZXMgPSByZXF1aXJlKCcuLi9jdXJyZW50U2NvcGVzLmpzJyk7XG5jb25zdCBkZWJ1Z0J1aWxkID0gcmVxdWlyZSgnLi4vZGVidWctYnVpbGQuanMnKTtcbmNvbnN0IGNvbnNvbGUgPSByZXF1aXJlKCcuLi9pbnN0cnVtZW50L2NvbnNvbGUuanMnKTtcbmNvbnN0IGludGVncmF0aW9uID0gcmVxdWlyZSgnLi4vaW50ZWdyYXRpb24uanMnKTtcbmNvbnN0IHNlbWFudGljQXR0cmlidXRlcyA9IHJlcXVpcmUoJy4uL3NlbWFudGljQXR0cmlidXRlcy5qcycpO1xuY29uc3QgZGVidWdMb2dnZXIgPSByZXF1aXJlKCcuLi91dGlscy9kZWJ1Zy1sb2dnZXIuanMnKTtcbmNvbnN0IGlzID0gcmVxdWlyZSgnLi4vdXRpbHMvaXMuanMnKTtcbmNvbnN0IG5vcm1hbGl6ZSA9IHJlcXVpcmUoJy4uL3V0aWxzL25vcm1hbGl6ZS5qcycpO1xuY29uc3Qgd29ybGR3aWRlID0gcmVxdWlyZSgnLi4vdXRpbHMvd29ybGR3aWRlLmpzJyk7XG5jb25zdCBleHBvcnRzJDEgPSByZXF1aXJlKCcuL2V4cG9ydHMuanMnKTtcblxuY29uc3QgSU5URUdSQVRJT05fTkFNRSA9ICdDb25zb2xlTG9ncyc7XG5cbmNvbnN0IERFRkFVTFRfQVRUUklCVVRFUyA9IHtcbiAgW3NlbWFudGljQXR0cmlidXRlcy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX09SSUdJTl06ICdhdXRvLmNvbnNvbGUubG9nZ2luZycsXG59O1xuXG5jb25zdCBfY29uc29sZUxvZ2dpbmdJbnRlZ3JhdGlvbiA9ICgob3B0aW9ucyA9IHt9KSA9PiB7XG4gIGNvbnN0IGxldmVscyA9IG9wdGlvbnMubGV2ZWxzIHx8IGRlYnVnTG9nZ2VyLkNPTlNPTEVfTEVWRUxTO1xuXG4gIHJldHVybiB7XG4gICAgbmFtZTogSU5URUdSQVRJT05fTkFNRSxcbiAgICBzZXR1cChjbGllbnQpIHtcbiAgICAgIGNvbnN0IHsgZW5hYmxlTG9ncywgX2V4cGVyaW1lbnRzLCBub3JtYWxpemVEZXB0aCA9IDMsIG5vcm1hbGl6ZU1heEJyZWFkdGggPSAxMDAwIH0gPSBjbGllbnQuZ2V0T3B0aW9ucygpO1xuICAgICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIGRlcHJlY2F0aW9uL2RlcHJlY2F0aW9uXG4gICAgICBjb25zdCBzaG91bGRFbmFibGVMb2dzID0gZW5hYmxlTG9ncyA/PyBfZXhwZXJpbWVudHM/LmVuYWJsZUxvZ3M7XG4gICAgICBpZiAoIXNob3VsZEVuYWJsZUxvZ3MpIHtcbiAgICAgICAgZGVidWdCdWlsZC5ERUJVR19CVUlMRCAmJiBkZWJ1Z0xvZ2dlci5kZWJ1Zy53YXJuKCdgZW5hYmxlTG9nc2AgaXMgbm90IGVuYWJsZWQsIENvbnNvbGVMb2dzIGludGVncmF0aW9uIGRpc2FibGVkJyk7XG4gICAgICAgIHJldHVybjtcbiAgICAgIH1cblxuICAgICAgY29uc29sZS5hZGRDb25zb2xlSW5zdHJ1bWVudGF0aW9uSGFuZGxlcigoeyBhcmdzLCBsZXZlbCB9KSA9PiB7XG4gICAgICAgIGlmIChjdXJyZW50U2NvcGVzLmdldENsaWVudCgpICE9PSBjbGllbnQgfHwgIWxldmVscy5pbmNsdWRlcyhsZXZlbCkpIHtcbiAgICAgICAgICByZXR1cm47XG4gICAgICAgIH1cblxuICAgICAgICBpZiAobGV2ZWwgPT09ICdhc3NlcnQnKSB7XG4gICAgICAgICAgaWYgKCFhcmdzWzBdKSB7XG4gICAgICAgICAgICBjb25zdCBmb2xsb3dpbmdBcmdzID0gYXJncy5zbGljZSgxKTtcbiAgICAgICAgICAgIGNvbnN0IGFzc2VydGlvbk1lc3NhZ2UgPVxuICAgICAgICAgICAgICBmb2xsb3dpbmdBcmdzLmxlbmd0aCA+IDBcbiAgICAgICAgICAgICAgICA/IGBBc3NlcnRpb24gZmFpbGVkOiAke2Zvcm1hdENvbnNvbGVBcmdzKGZvbGxvd2luZ0FyZ3MsIG5vcm1hbGl6ZURlcHRoLCBub3JtYWxpemVNYXhCcmVhZHRoKX1gXG4gICAgICAgICAgICAgICAgOiAnQXNzZXJ0aW9uIGZhaWxlZCc7XG4gICAgICAgICAgICBleHBvcnRzJDEuX0lOVEVSTkFMX2NhcHR1cmVMb2coeyBsZXZlbDogJ2Vycm9yJywgbWVzc2FnZTogYXNzZXJ0aW9uTWVzc2FnZSwgYXR0cmlidXRlczogREVGQVVMVF9BVFRSSUJVVEVTIH0pO1xuICAgICAgICAgIH1cbiAgICAgICAgICByZXR1cm47XG4gICAgICAgIH1cblxuICAgICAgICBjb25zdCBpc0xldmVsTG9nID0gbGV2ZWwgPT09ICdsb2cnO1xuICAgICAgICBleHBvcnRzJDEuX0lOVEVSTkFMX2NhcHR1cmVMb2coe1xuICAgICAgICAgIGxldmVsOiBpc0xldmVsTG9nID8gJ2luZm8nIDogbGV2ZWwsXG4gICAgICAgICAgbWVzc2FnZTogZm9ybWF0Q29uc29sZUFyZ3MoYXJncywgbm9ybWFsaXplRGVwdGgsIG5vcm1hbGl6ZU1heEJyZWFkdGgpLFxuICAgICAgICAgIHNldmVyaXR5TnVtYmVyOiBpc0xldmVsTG9nID8gMTAgOiB1bmRlZmluZWQsXG4gICAgICAgICAgYXR0cmlidXRlczogREVGQVVMVF9BVFRSSUJVVEVTLFxuICAgICAgICB9KTtcbiAgICAgIH0pO1xuICAgIH0sXG4gIH07XG59KSA7XG5cbi8qKlxuICogQ2FwdHVyZXMgY2FsbHMgdG8gdGhlIGBjb25zb2xlYCBBUEkgYXMgbG9ncyBpbiBTZW50cnkuIFJlcXVpcmVzIHRoZSBgZW5hYmxlTG9nc2Agb3B0aW9uIHRvIGJlIGVuYWJsZWQuXG4gKlxuICogQGV4cGVyaW1lbnRhbCBUaGlzIGZlYXR1cmUgaXMgZXhwZXJpbWVudGFsIGFuZCBtYXkgYmUgY2hhbmdlZCBvciByZW1vdmVkIGluIGZ1dHVyZSB2ZXJzaW9ucy5cbiAqXG4gKiBCeSBkZWZhdWx0IHRoZSBpbnRlZ3JhdGlvbiBpbnN0cnVtZW50cyBgY29uc29sZS5kZWJ1Z2AsIGBjb25zb2xlLmluZm9gLCBgY29uc29sZS53YXJuYCwgYGNvbnNvbGUuZXJyb3JgLFxuICogYGNvbnNvbGUubG9nYCwgYGNvbnNvbGUudHJhY2VgLCBhbmQgYGNvbnNvbGUuYXNzZXJ0YC4gWW91IGNhbiB1c2UgdGhlIGBsZXZlbHNgIG9wdGlvbiB0byBjdXN0b21pemUgd2hpY2hcbiAqIGxldmVscyBhcmUgY2FwdHVyZWQuXG4gKlxuICogQGV4YW1wbGVcbiAqXG4gKiBgYGB0c1xuICogaW1wb3J0ICogYXMgU2VudHJ5IGZyb20gJ0BzZW50cnkvYnJvd3Nlcic7XG4gKlxuICogU2VudHJ5LmluaXQoe1xuICogICBlbmFibGVMb2dzOiB0cnVlLFxuICogICBpbnRlZ3JhdGlvbnM6IFtTZW50cnkuY29uc29sZUxvZ2dpbmdJbnRlZ3JhdGlvbih7IGxldmVsczogWydlcnJvcicsICd3YXJuJ10gfSldLFxuICogfSk7XG4gKiBgYGBcbiAqL1xuY29uc3QgY29uc29sZUxvZ2dpbmdJbnRlZ3JhdGlvbiA9IGludGVncmF0aW9uLmRlZmluZUludGVncmF0aW9uKF9jb25zb2xlTG9nZ2luZ0ludGVncmF0aW9uKTtcblxuZnVuY3Rpb24gZm9ybWF0Q29uc29sZUFyZ3ModmFsdWVzLCBub3JtYWxpemVEZXB0aCwgbm9ybWFsaXplTWF4QnJlYWR0aCkge1xuICByZXR1cm4gJ3V0aWwnIGluIHdvcmxkd2lkZS5HTE9CQUxfT0JKICYmIHR5cGVvZiAod29ybGR3aWRlLkdMT0JBTF9PQkogKS51dGlsLmZvcm1hdCA9PT0gJ2Z1bmN0aW9uJ1xuICAgID8gKHdvcmxkd2lkZS5HTE9CQUxfT0JKICkudXRpbC5mb3JtYXQoLi4udmFsdWVzKVxuICAgIDogc2FmZUpvaW5Db25zb2xlQXJncyh2YWx1ZXMsIG5vcm1hbGl6ZURlcHRoLCBub3JtYWxpemVNYXhCcmVhZHRoKTtcbn1cblxuZnVuY3Rpb24gc2FmZUpvaW5Db25zb2xlQXJncyh2YWx1ZXMsIG5vcm1hbGl6ZURlcHRoLCBub3JtYWxpemVNYXhCcmVhZHRoKSB7XG4gIHJldHVybiB2YWx1ZXNcbiAgICAubWFwKHZhbHVlID0+XG4gICAgICBpcy5pc1ByaW1pdGl2ZSh2YWx1ZSkgPyBTdHJpbmcodmFsdWUpIDogSlNPTi5zdHJpbmdpZnkobm9ybWFsaXplLm5vcm1hbGl6ZSh2YWx1ZSwgbm9ybWFsaXplRGVwdGgsIG5vcm1hbGl6ZU1heEJyZWFkdGgpKSxcbiAgICApXG4gICAgLmpvaW4oJyAnKTtcbn1cblxuZXhwb3J0cy5jb25zb2xlTG9nZ2luZ0ludGVncmF0aW9uID0gY29uc29sZUxvZ2dpbmdJbnRlZ3JhdGlvbjtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWNvbnNvbGUtaW50ZWdyYXRpb24uanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/logs/console-integration.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/logs/constants.js":
/*!******************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/logs/constants.js ***!
  \******************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n/**\n * Maps a log severity level to a log severity number.\n *\n * @see LogSeverityLevel\n */\nconst SEVERITY_TEXT_TO_SEVERITY_NUMBER = {\n  trace: 1,\n  debug: 5,\n  info: 9,\n  warn: 13,\n  error: 17,\n  fatal: 21,\n};\n\nexports.SEVERITY_TEXT_TO_SEVERITY_NUMBER = SEVERITY_TEXT_TO_SEVERITY_NUMBER;\n//# sourceMappingURL=constants.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9sb2dzL2NvbnN0YW50cy5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSx3Q0FBd0M7QUFDeEMiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9sb2dzL2NvbnN0YW50cy5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuLyoqXG4gKiBNYXBzIGEgbG9nIHNldmVyaXR5IGxldmVsIHRvIGEgbG9nIHNldmVyaXR5IG51bWJlci5cbiAqXG4gKiBAc2VlIExvZ1NldmVyaXR5TGV2ZWxcbiAqL1xuY29uc3QgU0VWRVJJVFlfVEVYVF9UT19TRVZFUklUWV9OVU1CRVIgPSB7XG4gIHRyYWNlOiAxLFxuICBkZWJ1ZzogNSxcbiAgaW5mbzogOSxcbiAgd2FybjogMTMsXG4gIGVycm9yOiAxNyxcbiAgZmF0YWw6IDIxLFxufTtcblxuZXhwb3J0cy5TRVZFUklUWV9URVhUX1RPX1NFVkVSSVRZX05VTUJFUiA9IFNFVkVSSVRZX1RFWFRfVE9fU0VWRVJJVFlfTlVNQkVSO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9Y29uc3RhbnRzLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/logs/constants.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/logs/envelope.js":
/*!*****************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/logs/envelope.js ***!
  \*****************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst dsn = __webpack_require__(/*! ../utils/dsn.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/dsn.js\");\nconst envelope = __webpack_require__(/*! ../utils/envelope.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/envelope.js\");\n\n/**\n * Creates a log container envelope item for a list of logs.\n *\n * @param items - The logs to include in the envelope.\n * @returns The created log container envelope item.\n */\nfunction createLogContainerEnvelopeItem(items) {\n  return [\n    {\n      type: 'log',\n      item_count: items.length,\n      content_type: 'application/vnd.sentry.items.log+json',\n    },\n    {\n      items,\n    },\n  ];\n}\n\n/**\n * Creates an envelope for a list of logs.\n *\n * Logs from multiple traces can be included in the same envelope.\n *\n * @param logs - The logs to include in the envelope.\n * @param metadata - The metadata to include in the envelope.\n * @param tunnel - The tunnel to include in the envelope.\n * @param dsn - The DSN to include in the envelope.\n * @returns The created envelope.\n */\nfunction createLogEnvelope(\n  logs,\n  metadata,\n  tunnel,\n  dsn$1,\n) {\n  const headers = {};\n\n  if (metadata?.sdk) {\n    headers.sdk = {\n      name: metadata.sdk.name,\n      version: metadata.sdk.version,\n    };\n  }\n\n  if (!!tunnel && !!dsn$1) {\n    headers.dsn = dsn.dsnToString(dsn$1);\n  }\n\n  return envelope.createEnvelope(headers, [createLogContainerEnvelopeItem(logs)]);\n}\n\nexports.createLogContainerEnvelopeItem = createLogContainerEnvelopeItem;\nexports.createLogEnvelope = createLogEnvelope;\n//# sourceMappingURL=envelope.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9sb2dzL2VudmVsb3BlLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLFlBQVksbUJBQU8sQ0FBQyx3SEFBaUI7QUFDckMsaUJBQWlCLG1CQUFPLENBQUMsa0lBQXNCOztBQUUvQztBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxLQUFLO0FBQ0w7QUFDQTtBQUNBLEtBQUs7QUFDTDtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUEsc0NBQXNDO0FBQ3RDLHlCQUF5QjtBQUN6QiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL2xvZ3MvZW52ZWxvcGUuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGRzbiA9IHJlcXVpcmUoJy4uL3V0aWxzL2Rzbi5qcycpO1xuY29uc3QgZW52ZWxvcGUgPSByZXF1aXJlKCcuLi91dGlscy9lbnZlbG9wZS5qcycpO1xuXG4vKipcbiAqIENyZWF0ZXMgYSBsb2cgY29udGFpbmVyIGVudmVsb3BlIGl0ZW0gZm9yIGEgbGlzdCBvZiBsb2dzLlxuICpcbiAqIEBwYXJhbSBpdGVtcyAtIFRoZSBsb2dzIHRvIGluY2x1ZGUgaW4gdGhlIGVudmVsb3BlLlxuICogQHJldHVybnMgVGhlIGNyZWF0ZWQgbG9nIGNvbnRhaW5lciBlbnZlbG9wZSBpdGVtLlxuICovXG5mdW5jdGlvbiBjcmVhdGVMb2dDb250YWluZXJFbnZlbG9wZUl0ZW0oaXRlbXMpIHtcbiAgcmV0dXJuIFtcbiAgICB7XG4gICAgICB0eXBlOiAnbG9nJyxcbiAgICAgIGl0ZW1fY291bnQ6IGl0ZW1zLmxlbmd0aCxcbiAgICAgIGNvbnRlbnRfdHlwZTogJ2FwcGxpY2F0aW9uL3ZuZC5zZW50cnkuaXRlbXMubG9nK2pzb24nLFxuICAgIH0sXG4gICAge1xuICAgICAgaXRlbXMsXG4gICAgfSxcbiAgXTtcbn1cblxuLyoqXG4gKiBDcmVhdGVzIGFuIGVudmVsb3BlIGZvciBhIGxpc3Qgb2YgbG9ncy5cbiAqXG4gKiBMb2dzIGZyb20gbXVsdGlwbGUgdHJhY2VzIGNhbiBiZSBpbmNsdWRlZCBpbiB0aGUgc2FtZSBlbnZlbG9wZS5cbiAqXG4gKiBAcGFyYW0gbG9ncyAtIFRoZSBsb2dzIHRvIGluY2x1ZGUgaW4gdGhlIGVudmVsb3BlLlxuICogQHBhcmFtIG1ldGFkYXRhIC0gVGhlIG1ldGFkYXRhIHRvIGluY2x1ZGUgaW4gdGhlIGVudmVsb3BlLlxuICogQHBhcmFtIHR1bm5lbCAtIFRoZSB0dW5uZWwgdG8gaW5jbHVkZSBpbiB0aGUgZW52ZWxvcGUuXG4gKiBAcGFyYW0gZHNuIC0gVGhlIERTTiB0byBpbmNsdWRlIGluIHRoZSBlbnZlbG9wZS5cbiAqIEByZXR1cm5zIFRoZSBjcmVhdGVkIGVudmVsb3BlLlxuICovXG5mdW5jdGlvbiBjcmVhdGVMb2dFbnZlbG9wZShcbiAgbG9ncyxcbiAgbWV0YWRhdGEsXG4gIHR1bm5lbCxcbiAgZHNuJDEsXG4pIHtcbiAgY29uc3QgaGVhZGVycyA9IHt9O1xuXG4gIGlmIChtZXRhZGF0YT8uc2RrKSB7XG4gICAgaGVhZGVycy5zZGsgPSB7XG4gICAgICBuYW1lOiBtZXRhZGF0YS5zZGsubmFtZSxcbiAgICAgIHZlcnNpb246IG1ldGFkYXRhLnNkay52ZXJzaW9uLFxuICAgIH07XG4gIH1cblxuICBpZiAoISF0dW5uZWwgJiYgISFkc24kMSkge1xuICAgIGhlYWRlcnMuZHNuID0gZHNuLmRzblRvU3RyaW5nKGRzbiQxKTtcbiAgfVxuXG4gIHJldHVybiBlbnZlbG9wZS5jcmVhdGVFbnZlbG9wZShoZWFkZXJzLCBbY3JlYXRlTG9nQ29udGFpbmVyRW52ZWxvcGVJdGVtKGxvZ3MpXSk7XG59XG5cbmV4cG9ydHMuY3JlYXRlTG9nQ29udGFpbmVyRW52ZWxvcGVJdGVtID0gY3JlYXRlTG9nQ29udGFpbmVyRW52ZWxvcGVJdGVtO1xuZXhwb3J0cy5jcmVhdGVMb2dFbnZlbG9wZSA9IGNyZWF0ZUxvZ0VudmVsb3BlO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9ZW52ZWxvcGUuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/logs/envelope.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/logs/exports.js":
/*!****************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/logs/exports.js ***!
  \****************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst carrier = __webpack_require__(/*! ../carrier.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/carrier.js\");\nconst client = __webpack_require__(/*! ../client.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/client.js\");\nconst currentScopes = __webpack_require__(/*! ../currentScopes.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst debugBuild = __webpack_require__(/*! ../debug-build.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst applyScopeDataToEvent = __webpack_require__(/*! ../utils/applyScopeDataToEvent.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/applyScopeDataToEvent.js\");\nconst debugLogger = __webpack_require__(/*! ../utils/debug-logger.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst is = __webpack_require__(/*! ../utils/is.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js\");\nconst spanOnScope = __webpack_require__(/*! ../utils/spanOnScope.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanOnScope.js\");\nconst time = __webpack_require__(/*! ../utils/time.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/time.js\");\nconst constants = __webpack_require__(/*! ./constants.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/logs/constants.js\");\nconst envelope = __webpack_require__(/*! ./envelope.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/logs/envelope.js\");\n\nconst MAX_LOG_BUFFER_SIZE = 100;\n\n/**\n * Converts a log attribute to a serialized log attribute.\n *\n * @param key - The key of the log attribute.\n * @param value - The value of the log attribute.\n * @returns The serialized log attribute.\n */\nfunction logAttributeToSerializedLogAttribute(value) {\n  switch (typeof value) {\n    case 'number':\n      if (Number.isInteger(value)) {\n        return {\n          value,\n          type: 'integer',\n        };\n      }\n      return {\n        value,\n        type: 'double',\n      };\n    case 'boolean':\n      return {\n        value,\n        type: 'boolean',\n      };\n    case 'string':\n      return {\n        value,\n        type: 'string',\n      };\n    default: {\n      let stringValue = '';\n      try {\n        stringValue = JSON.stringify(value) ?? '';\n      } catch {\n        // Do nothing\n      }\n      return {\n        value: stringValue,\n        type: 'string',\n      };\n    }\n  }\n}\n\n/**\n * Sets a log attribute if the value exists and the attribute key is not already present.\n *\n * @param logAttributes - The log attributes object to modify.\n * @param key - The attribute key to set.\n * @param value - The value to set (only sets if truthy and key not present).\n * @param setEvenIfPresent - Whether to set the attribute if it is present. Defaults to true.\n */\nfunction setLogAttribute(\n  logAttributes,\n  key,\n  value,\n  setEvenIfPresent = true,\n) {\n  if (value && (!logAttributes[key] || setEvenIfPresent)) {\n    logAttributes[key] = value;\n  }\n}\n\n/**\n * Captures a serialized log event and adds it to the log buffer for the given client.\n *\n * @param client - A client. Uses the current client if not provided.\n * @param serializedLog - The serialized log event to capture.\n *\n * @experimental This method will experience breaking changes. This is not yet part of\n * the stable Sentry SDK API and can be changed or removed without warning.\n */\nfunction _INTERNAL_captureSerializedLog(client, serializedLog) {\n  const bufferMap = _getBufferMap();\n\n  const logBuffer = _INTERNAL_getLogBuffer(client);\n  if (logBuffer === undefined) {\n    bufferMap.set(client, [serializedLog]);\n  } else {\n    bufferMap.set(client, [...logBuffer, serializedLog]);\n    if (logBuffer.length >= MAX_LOG_BUFFER_SIZE) {\n      _INTERNAL_flushLogsBuffer(client, logBuffer);\n    }\n  }\n}\n\n/**\n * Captures a log event and sends it to Sentry.\n *\n * @param log - The log event to capture.\n * @param scope - A scope. Uses the current scope if not provided.\n * @param client - A client. Uses the current client if not provided.\n * @param captureSerializedLog - A function to capture the serialized log.\n *\n * @experimental This method will experience breaking changes. This is not yet part of\n * the stable Sentry SDK API and can be changed or removed without warning.\n */\nfunction _INTERNAL_captureLog(\n  beforeLog,\n  client$1 = currentScopes.getClient(),\n  currentScope = currentScopes.getCurrentScope(),\n  captureSerializedLog = _INTERNAL_captureSerializedLog,\n) {\n  if (!client$1) {\n    debugBuild.DEBUG_BUILD && debugLogger.debug.warn('No client available to capture log.');\n    return;\n  }\n\n  const { release, environment, enableLogs, beforeSendLog, _experiments } = client$1.getOptions();\n  // eslint-disable-next-line deprecation/deprecation\n  const shouldEnableLogs = enableLogs ?? _experiments?.enableLogs;\n  if (!shouldEnableLogs) {\n    debugBuild.DEBUG_BUILD && debugLogger.debug.warn('logging option not enabled, log will not be captured.');\n    return;\n  }\n  // eslint-disable-next-line deprecation/deprecation\n  const actualBeforeSendLog = beforeSendLog ?? _experiments?.beforeSendLog;\n\n  const [, traceContext] = client._getTraceInfoFromScope(client$1, currentScope);\n\n  const processedLogAttributes = {\n    ...beforeLog.attributes,\n  };\n\n  const {\n    user: { id, email, username },\n  } = getMergedScopeData(currentScope);\n  setLogAttribute(processedLogAttributes, 'user.id', id, false);\n  setLogAttribute(processedLogAttributes, 'user.email', email, false);\n  setLogAttribute(processedLogAttributes, 'user.name', username, false);\n\n  setLogAttribute(processedLogAttributes, 'sentry.release', release);\n  setLogAttribute(processedLogAttributes, 'sentry.environment', environment);\n\n  const { name, version } = client$1.getSdkMetadata()?.sdk ?? {};\n  setLogAttribute(processedLogAttributes, 'sentry.sdk.name', name);\n  setLogAttribute(processedLogAttributes, 'sentry.sdk.version', version);\n\n  const beforeLogMessage = beforeLog.message;\n  if (is.isParameterizedString(beforeLogMessage)) {\n    const { __sentry_template_string__, __sentry_template_values__ = [] } = beforeLogMessage;\n    processedLogAttributes['sentry.message.template'] = __sentry_template_string__;\n    __sentry_template_values__.forEach((param, index) => {\n      processedLogAttributes[`sentry.message.parameter.${index}`] = param;\n    });\n  }\n\n  const span = spanOnScope._getSpanForScope(currentScope);\n  // Add the parent span ID to the log attributes for trace context\n  setLogAttribute(processedLogAttributes, 'sentry.trace.parent_span_id', span?.spanContext().spanId);\n\n  const processedLog = { ...beforeLog, attributes: processedLogAttributes };\n\n  client$1.emit('beforeCaptureLog', processedLog);\n\n  // We need to wrap this in `consoleSandbox` to avoid recursive calls to `beforeSendLog`\n  const log = actualBeforeSendLog ? debugLogger.consoleSandbox(() => actualBeforeSendLog(processedLog)) : processedLog;\n  if (!log) {\n    client$1.recordDroppedEvent('before_send', 'log_item', 1);\n    debugBuild.DEBUG_BUILD && debugLogger.debug.warn('beforeSendLog returned null, log will not be captured.');\n    return;\n  }\n\n  const { level, message, attributes = {}, severityNumber } = log;\n\n  const serializedLog = {\n    timestamp: time.timestampInSeconds(),\n    level,\n    body: message,\n    trace_id: traceContext?.trace_id,\n    severity_number: severityNumber ?? constants.SEVERITY_TEXT_TO_SEVERITY_NUMBER[level],\n    attributes: Object.keys(attributes).reduce(\n      (acc, key) => {\n        acc[key] = logAttributeToSerializedLogAttribute(attributes[key]);\n        return acc;\n      },\n      {} ,\n    ),\n  };\n\n  captureSerializedLog(client$1, serializedLog);\n\n  client$1.emit('afterCaptureLog', log);\n}\n\n/**\n * Flushes the logs buffer to Sentry.\n *\n * @param client - A client.\n * @param maybeLogBuffer - A log buffer. Uses the log buffer for the given client if not provided.\n *\n * @experimental This method will experience breaking changes. This is not yet part of\n * the stable Sentry SDK API and can be changed or removed without warning.\n */\nfunction _INTERNAL_flushLogsBuffer(client, maybeLogBuffer) {\n  const logBuffer = maybeLogBuffer ?? _INTERNAL_getLogBuffer(client) ?? [];\n  if (logBuffer.length === 0) {\n    return;\n  }\n\n  const clientOptions = client.getOptions();\n  const envelope$1 = envelope.createLogEnvelope(logBuffer, clientOptions._metadata, clientOptions.tunnel, client.getDsn());\n\n  // Clear the log buffer after envelopes have been constructed.\n  _getBufferMap().set(client, []);\n\n  client.emit('flushLogs');\n\n  // sendEnvelope should not throw\n  // eslint-disable-next-line @typescript-eslint/no-floating-promises\n  client.sendEnvelope(envelope$1);\n}\n\n/**\n * Returns the log buffer for a given client.\n *\n * Exported for testing purposes.\n *\n * @param client - The client to get the log buffer for.\n * @returns The log buffer for the given client.\n */\nfunction _INTERNAL_getLogBuffer(client) {\n  return _getBufferMap().get(client);\n}\n\n/**\n * Get the scope data for the current scope after merging with the\n * global scope and isolation scope.\n *\n * @param currentScope - The current scope.\n * @returns The scope data.\n */\nfunction getMergedScopeData(currentScope) {\n  const scopeData = currentScopes.getGlobalScope().getScopeData();\n  applyScopeDataToEvent.mergeScopeData(scopeData, currentScopes.getIsolationScope().getScopeData());\n  applyScopeDataToEvent.mergeScopeData(scopeData, currentScope.getScopeData());\n  return scopeData;\n}\n\nfunction _getBufferMap() {\n  // The reference to the Client <> LogBuffer map is stored on the carrier to ensure it's always the same\n  return carrier.getGlobalSingleton('clientToLogBufferMap', () => new WeakMap());\n}\n\nexports._INTERNAL_captureLog = _INTERNAL_captureLog;\nexports._INTERNAL_captureSerializedLog = _INTERNAL_captureSerializedLog;\nexports._INTERNAL_flushLogsBuffer = _INTERNAL_flushLogsBuffer;\nexports._INTERNAL_getLogBuffer = _INTERNAL_getLogBuffer;\nexports.logAttributeToSerializedLogAttribute = logAttributeToSerializedLogAttribute;\n//# sourceMappingURL=exports.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9sb2dzL2V4cG9ydHMuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsZ0JBQWdCLG1CQUFPLENBQUMsb0hBQWU7QUFDdkMsZUFBZSxtQkFBTyxDQUFDLGtIQUFjO0FBQ3JDLHNCQUFzQixtQkFBTyxDQUFDLGdJQUFxQjtBQUNuRCxtQkFBbUIsbUJBQU8sQ0FBQyw0SEFBbUI7QUFDOUMsOEJBQThCLG1CQUFPLENBQUMsNEpBQW1DO0FBQ3pFLG9CQUFvQixtQkFBTyxDQUFDLDBJQUEwQjtBQUN0RCxXQUFXLG1CQUFPLENBQUMsc0hBQWdCO0FBQ25DLG9CQUFvQixtQkFBTyxDQUFDLHdJQUF5QjtBQUNyRCxhQUFhLG1CQUFPLENBQUMsMEhBQWtCO0FBQ3ZDLGtCQUFrQixtQkFBTyxDQUFDLDRIQUFnQjtBQUMxQyxpQkFBaUIsbUJBQU8sQ0FBQywwSEFBZTs7QUFFeEM7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxRQUFRO0FBQ1I7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBLElBQUk7QUFDSjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLFVBQVUsZ0VBQWdFO0FBQzFFO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0EsWUFBWSxxQkFBcUI7QUFDakMsSUFBSTtBQUNKO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBLFVBQVUsZ0JBQWdCO0FBQzFCO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLFlBQVksOERBQThEO0FBQzFFO0FBQ0E7QUFDQSx5REFBeUQsTUFBTTtBQUMvRCxLQUFLO0FBQ0w7O0FBRUE7QUFDQTtBQUNBOztBQUVBLHlCQUF5Qjs7QUFFekI7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsVUFBVSwrQkFBK0IsbUJBQW1COztBQUU1RDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLE9BQU87QUFDUCxTQUFTO0FBQ1Q7QUFDQTs7QUFFQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsNEJBQTRCO0FBQzVCLHNDQUFzQztBQUN0QyxpQ0FBaUM7QUFDakMsOEJBQThCO0FBQzlCLDRDQUE0QztBQUM1QyIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL2xvZ3MvZXhwb3J0cy5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgY2FycmllciA9IHJlcXVpcmUoJy4uL2NhcnJpZXIuanMnKTtcbmNvbnN0IGNsaWVudCA9IHJlcXVpcmUoJy4uL2NsaWVudC5qcycpO1xuY29uc3QgY3VycmVudFNjb3BlcyA9IHJlcXVpcmUoJy4uL2N1cnJlbnRTY29wZXMuanMnKTtcbmNvbnN0IGRlYnVnQnVpbGQgPSByZXF1aXJlKCcuLi9kZWJ1Zy1idWlsZC5qcycpO1xuY29uc3QgYXBwbHlTY29wZURhdGFUb0V2ZW50ID0gcmVxdWlyZSgnLi4vdXRpbHMvYXBwbHlTY29wZURhdGFUb0V2ZW50LmpzJyk7XG5jb25zdCBkZWJ1Z0xvZ2dlciA9IHJlcXVpcmUoJy4uL3V0aWxzL2RlYnVnLWxvZ2dlci5qcycpO1xuY29uc3QgaXMgPSByZXF1aXJlKCcuLi91dGlscy9pcy5qcycpO1xuY29uc3Qgc3Bhbk9uU2NvcGUgPSByZXF1aXJlKCcuLi91dGlscy9zcGFuT25TY29wZS5qcycpO1xuY29uc3QgdGltZSA9IHJlcXVpcmUoJy4uL3V0aWxzL3RpbWUuanMnKTtcbmNvbnN0IGNvbnN0YW50cyA9IHJlcXVpcmUoJy4vY29uc3RhbnRzLmpzJyk7XG5jb25zdCBlbnZlbG9wZSA9IHJlcXVpcmUoJy4vZW52ZWxvcGUuanMnKTtcblxuY29uc3QgTUFYX0xPR19CVUZGRVJfU0laRSA9IDEwMDtcblxuLyoqXG4gKiBDb252ZXJ0cyBhIGxvZyBhdHRyaWJ1dGUgdG8gYSBzZXJpYWxpemVkIGxvZyBhdHRyaWJ1dGUuXG4gKlxuICogQHBhcmFtIGtleSAtIFRoZSBrZXkgb2YgdGhlIGxvZyBhdHRyaWJ1dGUuXG4gKiBAcGFyYW0gdmFsdWUgLSBUaGUgdmFsdWUgb2YgdGhlIGxvZyBhdHRyaWJ1dGUuXG4gKiBAcmV0dXJucyBUaGUgc2VyaWFsaXplZCBsb2cgYXR0cmlidXRlLlxuICovXG5mdW5jdGlvbiBsb2dBdHRyaWJ1dGVUb1NlcmlhbGl6ZWRMb2dBdHRyaWJ1dGUodmFsdWUpIHtcbiAgc3dpdGNoICh0eXBlb2YgdmFsdWUpIHtcbiAgICBjYXNlICdudW1iZXInOlxuICAgICAgaWYgKE51bWJlci5pc0ludGVnZXIodmFsdWUpKSB7XG4gICAgICAgIHJldHVybiB7XG4gICAgICAgICAgdmFsdWUsXG4gICAgICAgICAgdHlwZTogJ2ludGVnZXInLFxuICAgICAgICB9O1xuICAgICAgfVxuICAgICAgcmV0dXJuIHtcbiAgICAgICAgdmFsdWUsXG4gICAgICAgIHR5cGU6ICdkb3VibGUnLFxuICAgICAgfTtcbiAgICBjYXNlICdib29sZWFuJzpcbiAgICAgIHJldHVybiB7XG4gICAgICAgIHZhbHVlLFxuICAgICAgICB0eXBlOiAnYm9vbGVhbicsXG4gICAgICB9O1xuICAgIGNhc2UgJ3N0cmluZyc6XG4gICAgICByZXR1cm4ge1xuICAgICAgICB2YWx1ZSxcbiAgICAgICAgdHlwZTogJ3N0cmluZycsXG4gICAgICB9O1xuICAgIGRlZmF1bHQ6IHtcbiAgICAgIGxldCBzdHJpbmdWYWx1ZSA9ICcnO1xuICAgICAgdHJ5IHtcbiAgICAgICAgc3RyaW5nVmFsdWUgPSBKU09OLnN0cmluZ2lmeSh2YWx1ZSkgPz8gJyc7XG4gICAgICB9IGNhdGNoIHtcbiAgICAgICAgLy8gRG8gbm90aGluZ1xuICAgICAgfVxuICAgICAgcmV0dXJuIHtcbiAgICAgICAgdmFsdWU6IHN0cmluZ1ZhbHVlLFxuICAgICAgICB0eXBlOiAnc3RyaW5nJyxcbiAgICAgIH07XG4gICAgfVxuICB9XG59XG5cbi8qKlxuICogU2V0cyBhIGxvZyBhdHRyaWJ1dGUgaWYgdGhlIHZhbHVlIGV4aXN0cyBhbmQgdGhlIGF0dHJpYnV0ZSBrZXkgaXMgbm90IGFscmVhZHkgcHJlc2VudC5cbiAqXG4gKiBAcGFyYW0gbG9nQXR0cmlidXRlcyAtIFRoZSBsb2cgYXR0cmlidXRlcyBvYmplY3QgdG8gbW9kaWZ5LlxuICogQHBhcmFtIGtleSAtIFRoZSBhdHRyaWJ1dGUga2V5IHRvIHNldC5cbiAqIEBwYXJhbSB2YWx1ZSAtIFRoZSB2YWx1ZSB0byBzZXQgKG9ubHkgc2V0cyBpZiB0cnV0aHkgYW5kIGtleSBub3QgcHJlc2VudCkuXG4gKiBAcGFyYW0gc2V0RXZlbklmUHJlc2VudCAtIFdoZXRoZXIgdG8gc2V0IHRoZSBhdHRyaWJ1dGUgaWYgaXQgaXMgcHJlc2VudC4gRGVmYXVsdHMgdG8gdHJ1ZS5cbiAqL1xuZnVuY3Rpb24gc2V0TG9nQXR0cmlidXRlKFxuICBsb2dBdHRyaWJ1dGVzLFxuICBrZXksXG4gIHZhbHVlLFxuICBzZXRFdmVuSWZQcmVzZW50ID0gdHJ1ZSxcbikge1xuICBpZiAodmFsdWUgJiYgKCFsb2dBdHRyaWJ1dGVzW2tleV0gfHwgc2V0RXZlbklmUHJlc2VudCkpIHtcbiAgICBsb2dBdHRyaWJ1dGVzW2tleV0gPSB2YWx1ZTtcbiAgfVxufVxuXG4vKipcbiAqIENhcHR1cmVzIGEgc2VyaWFsaXplZCBsb2cgZXZlbnQgYW5kIGFkZHMgaXQgdG8gdGhlIGxvZyBidWZmZXIgZm9yIHRoZSBnaXZlbiBjbGllbnQuXG4gKlxuICogQHBhcmFtIGNsaWVudCAtIEEgY2xpZW50LiBVc2VzIHRoZSBjdXJyZW50IGNsaWVudCBpZiBub3QgcHJvdmlkZWQuXG4gKiBAcGFyYW0gc2VyaWFsaXplZExvZyAtIFRoZSBzZXJpYWxpemVkIGxvZyBldmVudCB0byBjYXB0dXJlLlxuICpcbiAqIEBleHBlcmltZW50YWwgVGhpcyBtZXRob2Qgd2lsbCBleHBlcmllbmNlIGJyZWFraW5nIGNoYW5nZXMuIFRoaXMgaXMgbm90IHlldCBwYXJ0IG9mXG4gKiB0aGUgc3RhYmxlIFNlbnRyeSBTREsgQVBJIGFuZCBjYW4gYmUgY2hhbmdlZCBvciByZW1vdmVkIHdpdGhvdXQgd2FybmluZy5cbiAqL1xuZnVuY3Rpb24gX0lOVEVSTkFMX2NhcHR1cmVTZXJpYWxpemVkTG9nKGNsaWVudCwgc2VyaWFsaXplZExvZykge1xuICBjb25zdCBidWZmZXJNYXAgPSBfZ2V0QnVmZmVyTWFwKCk7XG5cbiAgY29uc3QgbG9nQnVmZmVyID0gX0lOVEVSTkFMX2dldExvZ0J1ZmZlcihjbGllbnQpO1xuICBpZiAobG9nQnVmZmVyID09PSB1bmRlZmluZWQpIHtcbiAgICBidWZmZXJNYXAuc2V0KGNsaWVudCwgW3NlcmlhbGl6ZWRMb2ddKTtcbiAgfSBlbHNlIHtcbiAgICBidWZmZXJNYXAuc2V0KGNsaWVudCwgWy4uLmxvZ0J1ZmZlciwgc2VyaWFsaXplZExvZ10pO1xuICAgIGlmIChsb2dCdWZmZXIubGVuZ3RoID49IE1BWF9MT0dfQlVGRkVSX1NJWkUpIHtcbiAgICAgIF9JTlRFUk5BTF9mbHVzaExvZ3NCdWZmZXIoY2xpZW50LCBsb2dCdWZmZXIpO1xuICAgIH1cbiAgfVxufVxuXG4vKipcbiAqIENhcHR1cmVzIGEgbG9nIGV2ZW50IGFuZCBzZW5kcyBpdCB0byBTZW50cnkuXG4gKlxuICogQHBhcmFtIGxvZyAtIFRoZSBsb2cgZXZlbnQgdG8gY2FwdHVyZS5cbiAqIEBwYXJhbSBzY29wZSAtIEEgc2NvcGUuIFVzZXMgdGhlIGN1cnJlbnQgc2NvcGUgaWYgbm90IHByb3ZpZGVkLlxuICogQHBhcmFtIGNsaWVudCAtIEEgY2xpZW50LiBVc2VzIHRoZSBjdXJyZW50IGNsaWVudCBpZiBub3QgcHJvdmlkZWQuXG4gKiBAcGFyYW0gY2FwdHVyZVNlcmlhbGl6ZWRMb2cgLSBBIGZ1bmN0aW9uIHRvIGNhcHR1cmUgdGhlIHNlcmlhbGl6ZWQgbG9nLlxuICpcbiAqIEBleHBlcmltZW50YWwgVGhpcyBtZXRob2Qgd2lsbCBleHBlcmllbmNlIGJyZWFraW5nIGNoYW5nZXMuIFRoaXMgaXMgbm90IHlldCBwYXJ0IG9mXG4gKiB0aGUgc3RhYmxlIFNlbnRyeSBTREsgQVBJIGFuZCBjYW4gYmUgY2hhbmdlZCBvciByZW1vdmVkIHdpdGhvdXQgd2FybmluZy5cbiAqL1xuZnVuY3Rpb24gX0lOVEVSTkFMX2NhcHR1cmVMb2coXG4gIGJlZm9yZUxvZyxcbiAgY2xpZW50JDEgPSBjdXJyZW50U2NvcGVzLmdldENsaWVudCgpLFxuICBjdXJyZW50U2NvcGUgPSBjdXJyZW50U2NvcGVzLmdldEN1cnJlbnRTY29wZSgpLFxuICBjYXB0dXJlU2VyaWFsaXplZExvZyA9IF9JTlRFUk5BTF9jYXB0dXJlU2VyaWFsaXplZExvZyxcbikge1xuICBpZiAoIWNsaWVudCQxKSB7XG4gICAgZGVidWdCdWlsZC5ERUJVR19CVUlMRCAmJiBkZWJ1Z0xvZ2dlci5kZWJ1Zy53YXJuKCdObyBjbGllbnQgYXZhaWxhYmxlIHRvIGNhcHR1cmUgbG9nLicpO1xuICAgIHJldHVybjtcbiAgfVxuXG4gIGNvbnN0IHsgcmVsZWFzZSwgZW52aXJvbm1lbnQsIGVuYWJsZUxvZ3MsIGJlZm9yZVNlbmRMb2csIF9leHBlcmltZW50cyB9ID0gY2xpZW50JDEuZ2V0T3B0aW9ucygpO1xuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgZGVwcmVjYXRpb24vZGVwcmVjYXRpb25cbiAgY29uc3Qgc2hvdWxkRW5hYmxlTG9ncyA9IGVuYWJsZUxvZ3MgPz8gX2V4cGVyaW1lbnRzPy5lbmFibGVMb2dzO1xuICBpZiAoIXNob3VsZEVuYWJsZUxvZ3MpIHtcbiAgICBkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEICYmIGRlYnVnTG9nZ2VyLmRlYnVnLndhcm4oJ2xvZ2dpbmcgb3B0aW9uIG5vdCBlbmFibGVkLCBsb2cgd2lsbCBub3QgYmUgY2FwdHVyZWQuJyk7XG4gICAgcmV0dXJuO1xuICB9XG4gIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBkZXByZWNhdGlvbi9kZXByZWNhdGlvblxuICBjb25zdCBhY3R1YWxCZWZvcmVTZW5kTG9nID0gYmVmb3JlU2VuZExvZyA/PyBfZXhwZXJpbWVudHM/LmJlZm9yZVNlbmRMb2c7XG5cbiAgY29uc3QgWywgdHJhY2VDb250ZXh0XSA9IGNsaWVudC5fZ2V0VHJhY2VJbmZvRnJvbVNjb3BlKGNsaWVudCQxLCBjdXJyZW50U2NvcGUpO1xuXG4gIGNvbnN0IHByb2Nlc3NlZExvZ0F0dHJpYnV0ZXMgPSB7XG4gICAgLi4uYmVmb3JlTG9nLmF0dHJpYnV0ZXMsXG4gIH07XG5cbiAgY29uc3Qge1xuICAgIHVzZXI6IHsgaWQsIGVtYWlsLCB1c2VybmFtZSB9LFxuICB9ID0gZ2V0TWVyZ2VkU2NvcGVEYXRhKGN1cnJlbnRTY29wZSk7XG4gIHNldExvZ0F0dHJpYnV0ZShwcm9jZXNzZWRMb2dBdHRyaWJ1dGVzLCAndXNlci5pZCcsIGlkLCBmYWxzZSk7XG4gIHNldExvZ0F0dHJpYnV0ZShwcm9jZXNzZWRMb2dBdHRyaWJ1dGVzLCAndXNlci5lbWFpbCcsIGVtYWlsLCBmYWxzZSk7XG4gIHNldExvZ0F0dHJpYnV0ZShwcm9jZXNzZWRMb2dBdHRyaWJ1dGVzLCAndXNlci5uYW1lJywgdXNlcm5hbWUsIGZhbHNlKTtcblxuICBzZXRMb2dBdHRyaWJ1dGUocHJvY2Vzc2VkTG9nQXR0cmlidXRlcywgJ3NlbnRyeS5yZWxlYXNlJywgcmVsZWFzZSk7XG4gIHNldExvZ0F0dHJpYnV0ZShwcm9jZXNzZWRMb2dBdHRyaWJ1dGVzLCAnc2VudHJ5LmVudmlyb25tZW50JywgZW52aXJvbm1lbnQpO1xuXG4gIGNvbnN0IHsgbmFtZSwgdmVyc2lvbiB9ID0gY2xpZW50JDEuZ2V0U2RrTWV0YWRhdGEoKT8uc2RrID8/IHt9O1xuICBzZXRMb2dBdHRyaWJ1dGUocHJvY2Vzc2VkTG9nQXR0cmlidXRlcywgJ3NlbnRyeS5zZGsubmFtZScsIG5hbWUpO1xuICBzZXRMb2dBdHRyaWJ1dGUocHJvY2Vzc2VkTG9nQXR0cmlidXRlcywgJ3NlbnRyeS5zZGsudmVyc2lvbicsIHZlcnNpb24pO1xuXG4gIGNvbnN0IGJlZm9yZUxvZ01lc3NhZ2UgPSBiZWZvcmVMb2cubWVzc2FnZTtcbiAgaWYgKGlzLmlzUGFyYW1ldGVyaXplZFN0cmluZyhiZWZvcmVMb2dNZXNzYWdlKSkge1xuICAgIGNvbnN0IHsgX19zZW50cnlfdGVtcGxhdGVfc3RyaW5nX18sIF9fc2VudHJ5X3RlbXBsYXRlX3ZhbHVlc19fID0gW10gfSA9IGJlZm9yZUxvZ01lc3NhZ2U7XG4gICAgcHJvY2Vzc2VkTG9nQXR0cmlidXRlc1snc2VudHJ5Lm1lc3NhZ2UudGVtcGxhdGUnXSA9IF9fc2VudHJ5X3RlbXBsYXRlX3N0cmluZ19fO1xuICAgIF9fc2VudHJ5X3RlbXBsYXRlX3ZhbHVlc19fLmZvckVhY2goKHBhcmFtLCBpbmRleCkgPT4ge1xuICAgICAgcHJvY2Vzc2VkTG9nQXR0cmlidXRlc1tgc2VudHJ5Lm1lc3NhZ2UucGFyYW1ldGVyLiR7aW5kZXh9YF0gPSBwYXJhbTtcbiAgICB9KTtcbiAgfVxuXG4gIGNvbnN0IHNwYW4gPSBzcGFuT25TY29wZS5fZ2V0U3BhbkZvclNjb3BlKGN1cnJlbnRTY29wZSk7XG4gIC8vIEFkZCB0aGUgcGFyZW50IHNwYW4gSUQgdG8gdGhlIGxvZyBhdHRyaWJ1dGVzIGZvciB0cmFjZSBjb250ZXh0XG4gIHNldExvZ0F0dHJpYnV0ZShwcm9jZXNzZWRMb2dBdHRyaWJ1dGVzLCAnc2VudHJ5LnRyYWNlLnBhcmVudF9zcGFuX2lkJywgc3Bhbj8uc3BhbkNvbnRleHQoKS5zcGFuSWQpO1xuXG4gIGNvbnN0IHByb2Nlc3NlZExvZyA9IHsgLi4uYmVmb3JlTG9nLCBhdHRyaWJ1dGVzOiBwcm9jZXNzZWRMb2dBdHRyaWJ1dGVzIH07XG5cbiAgY2xpZW50JDEuZW1pdCgnYmVmb3JlQ2FwdHVyZUxvZycsIHByb2Nlc3NlZExvZyk7XG5cbiAgLy8gV2UgbmVlZCB0byB3cmFwIHRoaXMgaW4gYGNvbnNvbGVTYW5kYm94YCB0byBhdm9pZCByZWN1cnNpdmUgY2FsbHMgdG8gYGJlZm9yZVNlbmRMb2dgXG4gIGNvbnN0IGxvZyA9IGFjdHVhbEJlZm9yZVNlbmRMb2cgPyBkZWJ1Z0xvZ2dlci5jb25zb2xlU2FuZGJveCgoKSA9PiBhY3R1YWxCZWZvcmVTZW5kTG9nKHByb2Nlc3NlZExvZykpIDogcHJvY2Vzc2VkTG9nO1xuICBpZiAoIWxvZykge1xuICAgIGNsaWVudCQxLnJlY29yZERyb3BwZWRFdmVudCgnYmVmb3JlX3NlbmQnLCAnbG9nX2l0ZW0nLCAxKTtcbiAgICBkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEICYmIGRlYnVnTG9nZ2VyLmRlYnVnLndhcm4oJ2JlZm9yZVNlbmRMb2cgcmV0dXJuZWQgbnVsbCwgbG9nIHdpbGwgbm90IGJlIGNhcHR1cmVkLicpO1xuICAgIHJldHVybjtcbiAgfVxuXG4gIGNvbnN0IHsgbGV2ZWwsIG1lc3NhZ2UsIGF0dHJpYnV0ZXMgPSB7fSwgc2V2ZXJpdHlOdW1iZXIgfSA9IGxvZztcblxuICBjb25zdCBzZXJpYWxpemVkTG9nID0ge1xuICAgIHRpbWVzdGFtcDogdGltZS50aW1lc3RhbXBJblNlY29uZHMoKSxcbiAgICBsZXZlbCxcbiAgICBib2R5OiBtZXNzYWdlLFxuICAgIHRyYWNlX2lkOiB0cmFjZUNvbnRleHQ/LnRyYWNlX2lkLFxuICAgIHNldmVyaXR5X251bWJlcjogc2V2ZXJpdHlOdW1iZXIgPz8gY29uc3RhbnRzLlNFVkVSSVRZX1RFWFRfVE9fU0VWRVJJVFlfTlVNQkVSW2xldmVsXSxcbiAgICBhdHRyaWJ1dGVzOiBPYmplY3Qua2V5cyhhdHRyaWJ1dGVzKS5yZWR1Y2UoXG4gICAgICAoYWNjLCBrZXkpID0+IHtcbiAgICAgICAgYWNjW2tleV0gPSBsb2dBdHRyaWJ1dGVUb1NlcmlhbGl6ZWRMb2dBdHRyaWJ1dGUoYXR0cmlidXRlc1trZXldKTtcbiAgICAgICAgcmV0dXJuIGFjYztcbiAgICAgIH0sXG4gICAgICB7fSAsXG4gICAgKSxcbiAgfTtcblxuICBjYXB0dXJlU2VyaWFsaXplZExvZyhjbGllbnQkMSwgc2VyaWFsaXplZExvZyk7XG5cbiAgY2xpZW50JDEuZW1pdCgnYWZ0ZXJDYXB0dXJlTG9nJywgbG9nKTtcbn1cblxuLyoqXG4gKiBGbHVzaGVzIHRoZSBsb2dzIGJ1ZmZlciB0byBTZW50cnkuXG4gKlxuICogQHBhcmFtIGNsaWVudCAtIEEgY2xpZW50LlxuICogQHBhcmFtIG1heWJlTG9nQnVmZmVyIC0gQSBsb2cgYnVmZmVyLiBVc2VzIHRoZSBsb2cgYnVmZmVyIGZvciB0aGUgZ2l2ZW4gY2xpZW50IGlmIG5vdCBwcm92aWRlZC5cbiAqXG4gKiBAZXhwZXJpbWVudGFsIFRoaXMgbWV0aG9kIHdpbGwgZXhwZXJpZW5jZSBicmVha2luZyBjaGFuZ2VzLiBUaGlzIGlzIG5vdCB5ZXQgcGFydCBvZlxuICogdGhlIHN0YWJsZSBTZW50cnkgU0RLIEFQSSBhbmQgY2FuIGJlIGNoYW5nZWQgb3IgcmVtb3ZlZCB3aXRob3V0IHdhcm5pbmcuXG4gKi9cbmZ1bmN0aW9uIF9JTlRFUk5BTF9mbHVzaExvZ3NCdWZmZXIoY2xpZW50LCBtYXliZUxvZ0J1ZmZlcikge1xuICBjb25zdCBsb2dCdWZmZXIgPSBtYXliZUxvZ0J1ZmZlciA/PyBfSU5URVJOQUxfZ2V0TG9nQnVmZmVyKGNsaWVudCkgPz8gW107XG4gIGlmIChsb2dCdWZmZXIubGVuZ3RoID09PSAwKSB7XG4gICAgcmV0dXJuO1xuICB9XG5cbiAgY29uc3QgY2xpZW50T3B0aW9ucyA9IGNsaWVudC5nZXRPcHRpb25zKCk7XG4gIGNvbnN0IGVudmVsb3BlJDEgPSBlbnZlbG9wZS5jcmVhdGVMb2dFbnZlbG9wZShsb2dCdWZmZXIsIGNsaWVudE9wdGlvbnMuX21ldGFkYXRhLCBjbGllbnRPcHRpb25zLnR1bm5lbCwgY2xpZW50LmdldERzbigpKTtcblxuICAvLyBDbGVhciB0aGUgbG9nIGJ1ZmZlciBhZnRlciBlbnZlbG9wZXMgaGF2ZSBiZWVuIGNvbnN0cnVjdGVkLlxuICBfZ2V0QnVmZmVyTWFwKCkuc2V0KGNsaWVudCwgW10pO1xuXG4gIGNsaWVudC5lbWl0KCdmbHVzaExvZ3MnKTtcblxuICAvLyBzZW5kRW52ZWxvcGUgc2hvdWxkIG5vdCB0aHJvd1xuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25vLWZsb2F0aW5nLXByb21pc2VzXG4gIGNsaWVudC5zZW5kRW52ZWxvcGUoZW52ZWxvcGUkMSk7XG59XG5cbi8qKlxuICogUmV0dXJucyB0aGUgbG9nIGJ1ZmZlciBmb3IgYSBnaXZlbiBjbGllbnQuXG4gKlxuICogRXhwb3J0ZWQgZm9yIHRlc3RpbmcgcHVycG9zZXMuXG4gKlxuICogQHBhcmFtIGNsaWVudCAtIFRoZSBjbGllbnQgdG8gZ2V0IHRoZSBsb2cgYnVmZmVyIGZvci5cbiAqIEByZXR1cm5zIFRoZSBsb2cgYnVmZmVyIGZvciB0aGUgZ2l2ZW4gY2xpZW50LlxuICovXG5mdW5jdGlvbiBfSU5URVJOQUxfZ2V0TG9nQnVmZmVyKGNsaWVudCkge1xuICByZXR1cm4gX2dldEJ1ZmZlck1hcCgpLmdldChjbGllbnQpO1xufVxuXG4vKipcbiAqIEdldCB0aGUgc2NvcGUgZGF0YSBmb3IgdGhlIGN1cnJlbnQgc2NvcGUgYWZ0ZXIgbWVyZ2luZyB3aXRoIHRoZVxuICogZ2xvYmFsIHNjb3BlIGFuZCBpc29sYXRpb24gc2NvcGUuXG4gKlxuICogQHBhcmFtIGN1cnJlbnRTY29wZSAtIFRoZSBjdXJyZW50IHNjb3BlLlxuICogQHJldHVybnMgVGhlIHNjb3BlIGRhdGEuXG4gKi9cbmZ1bmN0aW9uIGdldE1lcmdlZFNjb3BlRGF0YShjdXJyZW50U2NvcGUpIHtcbiAgY29uc3Qgc2NvcGVEYXRhID0gY3VycmVudFNjb3Blcy5nZXRHbG9iYWxTY29wZSgpLmdldFNjb3BlRGF0YSgpO1xuICBhcHBseVNjb3BlRGF0YVRvRXZlbnQubWVyZ2VTY29wZURhdGEoc2NvcGVEYXRhLCBjdXJyZW50U2NvcGVzLmdldElzb2xhdGlvblNjb3BlKCkuZ2V0U2NvcGVEYXRhKCkpO1xuICBhcHBseVNjb3BlRGF0YVRvRXZlbnQubWVyZ2VTY29wZURhdGEoc2NvcGVEYXRhLCBjdXJyZW50U2NvcGUuZ2V0U2NvcGVEYXRhKCkpO1xuICByZXR1cm4gc2NvcGVEYXRhO1xufVxuXG5mdW5jdGlvbiBfZ2V0QnVmZmVyTWFwKCkge1xuICAvLyBUaGUgcmVmZXJlbmNlIHRvIHRoZSBDbGllbnQgPD4gTG9nQnVmZmVyIG1hcCBpcyBzdG9yZWQgb24gdGhlIGNhcnJpZXIgdG8gZW5zdXJlIGl0J3MgYWx3YXlzIHRoZSBzYW1lXG4gIHJldHVybiBjYXJyaWVyLmdldEdsb2JhbFNpbmdsZXRvbignY2xpZW50VG9Mb2dCdWZmZXJNYXAnLCAoKSA9PiBuZXcgV2Vha01hcCgpKTtcbn1cblxuZXhwb3J0cy5fSU5URVJOQUxfY2FwdHVyZUxvZyA9IF9JTlRFUk5BTF9jYXB0dXJlTG9nO1xuZXhwb3J0cy5fSU5URVJOQUxfY2FwdHVyZVNlcmlhbGl6ZWRMb2cgPSBfSU5URVJOQUxfY2FwdHVyZVNlcmlhbGl6ZWRMb2c7XG5leHBvcnRzLl9JTlRFUk5BTF9mbHVzaExvZ3NCdWZmZXIgPSBfSU5URVJOQUxfZmx1c2hMb2dzQnVmZmVyO1xuZXhwb3J0cy5fSU5URVJOQUxfZ2V0TG9nQnVmZmVyID0gX0lOVEVSTkFMX2dldExvZ0J1ZmZlcjtcbmV4cG9ydHMubG9nQXR0cmlidXRlVG9TZXJpYWxpemVkTG9nQXR0cmlidXRlID0gbG9nQXR0cmlidXRlVG9TZXJpYWxpemVkTG9nQXR0cmlidXRlO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9ZXhwb3J0cy5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/logs/exports.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/metadata.js":
/*!************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/metadata.js ***!
  \************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst worldwide = __webpack_require__(/*! ./utils/worldwide.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/worldwide.js\");\n\n/** Keys are source filename/url, values are metadata objects. */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nconst filenameMetadataMap = new Map();\n/** Set of stack strings that have already been parsed. */\nconst parsedStacks = new Set();\n\nfunction ensureMetadataStacksAreParsed(parser) {\n  if (!worldwide.GLOBAL_OBJ._sentryModuleMetadata) {\n    return;\n  }\n\n  for (const stack of Object.keys(worldwide.GLOBAL_OBJ._sentryModuleMetadata)) {\n    const metadata = worldwide.GLOBAL_OBJ._sentryModuleMetadata[stack];\n\n    if (parsedStacks.has(stack)) {\n      continue;\n    }\n\n    // Ensure this stack doesn't get parsed again\n    parsedStacks.add(stack);\n\n    const frames = parser(stack);\n\n    // Go through the frames starting from the top of the stack and find the first one with a filename\n    for (const frame of frames.reverse()) {\n      if (frame.filename) {\n        // Save the metadata for this filename\n        filenameMetadataMap.set(frame.filename, metadata);\n        break;\n      }\n    }\n  }\n}\n\n/**\n * Retrieve metadata for a specific JavaScript file URL.\n *\n * Metadata is injected by the Sentry bundler plugins using the `_experiments.moduleMetadata` config option.\n */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction getMetadataForUrl(parser, filename) {\n  ensureMetadataStacksAreParsed(parser);\n  return filenameMetadataMap.get(filename);\n}\n\n/**\n * Adds metadata to stack frames.\n *\n * Metadata is injected by the Sentry bundler plugins using the `_experiments.moduleMetadata` config option.\n */\nfunction addMetadataToStackFrames(parser, event) {\n  try {\n    // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n    event.exception.values.forEach(exception => {\n      if (!exception.stacktrace) {\n        return;\n      }\n\n      for (const frame of exception.stacktrace.frames || []) {\n        if (!frame.filename || frame.module_metadata) {\n          continue;\n        }\n\n        const metadata = getMetadataForUrl(parser, frame.filename);\n\n        if (metadata) {\n          frame.module_metadata = metadata;\n        }\n      }\n    });\n  } catch {\n    // To save bundle size we're just try catching here instead of checking for the existence of all the different objects.\n  }\n}\n\n/**\n * Strips metadata from stack frames.\n */\nfunction stripMetadataFromStackFrames(event) {\n  try {\n    // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n    event.exception.values.forEach(exception => {\n      if (!exception.stacktrace) {\n        return;\n      }\n\n      for (const frame of exception.stacktrace.frames || []) {\n        delete frame.module_metadata;\n      }\n    });\n  } catch {\n    // To save bundle size we're just try catching here instead of checking for the existence of all the different objects.\n  }\n}\n\nexports.addMetadataToStackFrames = addMetadataToStackFrames;\nexports.getMetadataForUrl = getMetadataForUrl;\nexports.stripMetadataFromStackFrames = stripMetadataFromStackFrames;\n//# sourceMappingURL=metadata.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9tZXRhZGF0YS5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxrQkFBa0IsbUJBQU8sQ0FBQyxtSUFBc0I7O0FBRWhEO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQSxLQUFLO0FBQ0wsSUFBSTtBQUNKO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQSxLQUFLO0FBQ0wsSUFBSTtBQUNKO0FBQ0E7QUFDQTs7QUFFQSxnQ0FBZ0M7QUFDaEMseUJBQXlCO0FBQ3pCLG9DQUFvQztBQUNwQyIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL21ldGFkYXRhLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCB3b3JsZHdpZGUgPSByZXF1aXJlKCcuL3V0aWxzL3dvcmxkd2lkZS5qcycpO1xuXG4vKiogS2V5cyBhcmUgc291cmNlIGZpbGVuYW1lL3VybCwgdmFsdWVzIGFyZSBtZXRhZGF0YSBvYmplY3RzLiAqL1xuLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uby1leHBsaWNpdC1hbnlcbmNvbnN0IGZpbGVuYW1lTWV0YWRhdGFNYXAgPSBuZXcgTWFwKCk7XG4vKiogU2V0IG9mIHN0YWNrIHN0cmluZ3MgdGhhdCBoYXZlIGFscmVhZHkgYmVlbiBwYXJzZWQuICovXG5jb25zdCBwYXJzZWRTdGFja3MgPSBuZXcgU2V0KCk7XG5cbmZ1bmN0aW9uIGVuc3VyZU1ldGFkYXRhU3RhY2tzQXJlUGFyc2VkKHBhcnNlcikge1xuICBpZiAoIXdvcmxkd2lkZS5HTE9CQUxfT0JKLl9zZW50cnlNb2R1bGVNZXRhZGF0YSkge1xuICAgIHJldHVybjtcbiAgfVxuXG4gIGZvciAoY29uc3Qgc3RhY2sgb2YgT2JqZWN0LmtleXMod29ybGR3aWRlLkdMT0JBTF9PQkouX3NlbnRyeU1vZHVsZU1ldGFkYXRhKSkge1xuICAgIGNvbnN0IG1ldGFkYXRhID0gd29ybGR3aWRlLkdMT0JBTF9PQkouX3NlbnRyeU1vZHVsZU1ldGFkYXRhW3N0YWNrXTtcblxuICAgIGlmIChwYXJzZWRTdGFja3MuaGFzKHN0YWNrKSkge1xuICAgICAgY29udGludWU7XG4gICAgfVxuXG4gICAgLy8gRW5zdXJlIHRoaXMgc3RhY2sgZG9lc24ndCBnZXQgcGFyc2VkIGFnYWluXG4gICAgcGFyc2VkU3RhY2tzLmFkZChzdGFjayk7XG5cbiAgICBjb25zdCBmcmFtZXMgPSBwYXJzZXIoc3RhY2spO1xuXG4gICAgLy8gR28gdGhyb3VnaCB0aGUgZnJhbWVzIHN0YXJ0aW5nIGZyb20gdGhlIHRvcCBvZiB0aGUgc3RhY2sgYW5kIGZpbmQgdGhlIGZpcnN0IG9uZSB3aXRoIGEgZmlsZW5hbWVcbiAgICBmb3IgKGNvbnN0IGZyYW1lIG9mIGZyYW1lcy5yZXZlcnNlKCkpIHtcbiAgICAgIGlmIChmcmFtZS5maWxlbmFtZSkge1xuICAgICAgICAvLyBTYXZlIHRoZSBtZXRhZGF0YSBmb3IgdGhpcyBmaWxlbmFtZVxuICAgICAgICBmaWxlbmFtZU1ldGFkYXRhTWFwLnNldChmcmFtZS5maWxlbmFtZSwgbWV0YWRhdGEpO1xuICAgICAgICBicmVhaztcbiAgICAgIH1cbiAgICB9XG4gIH1cbn1cblxuLyoqXG4gKiBSZXRyaWV2ZSBtZXRhZGF0YSBmb3IgYSBzcGVjaWZpYyBKYXZhU2NyaXB0IGZpbGUgVVJMLlxuICpcbiAqIE1ldGFkYXRhIGlzIGluamVjdGVkIGJ5IHRoZSBTZW50cnkgYnVuZGxlciBwbHVnaW5zIHVzaW5nIHRoZSBgX2V4cGVyaW1lbnRzLm1vZHVsZU1ldGFkYXRhYCBjb25maWcgb3B0aW9uLlxuICovXG4vLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25vLWV4cGxpY2l0LWFueVxuZnVuY3Rpb24gZ2V0TWV0YWRhdGFGb3JVcmwocGFyc2VyLCBmaWxlbmFtZSkge1xuICBlbnN1cmVNZXRhZGF0YVN0YWNrc0FyZVBhcnNlZChwYXJzZXIpO1xuICByZXR1cm4gZmlsZW5hbWVNZXRhZGF0YU1hcC5nZXQoZmlsZW5hbWUpO1xufVxuXG4vKipcbiAqIEFkZHMgbWV0YWRhdGEgdG8gc3RhY2sgZnJhbWVzLlxuICpcbiAqIE1ldGFkYXRhIGlzIGluamVjdGVkIGJ5IHRoZSBTZW50cnkgYnVuZGxlciBwbHVnaW5zIHVzaW5nIHRoZSBgX2V4cGVyaW1lbnRzLm1vZHVsZU1ldGFkYXRhYCBjb25maWcgb3B0aW9uLlxuICovXG5mdW5jdGlvbiBhZGRNZXRhZGF0YVRvU3RhY2tGcmFtZXMocGFyc2VyLCBldmVudCkge1xuICB0cnkge1xuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tbm9uLW51bGwtYXNzZXJ0aW9uXG4gICAgZXZlbnQuZXhjZXB0aW9uLnZhbHVlcy5mb3JFYWNoKGV4Y2VwdGlvbiA9PiB7XG4gICAgICBpZiAoIWV4Y2VwdGlvbi5zdGFja3RyYWNlKSB7XG4gICAgICAgIHJldHVybjtcbiAgICAgIH1cblxuICAgICAgZm9yIChjb25zdCBmcmFtZSBvZiBleGNlcHRpb24uc3RhY2t0cmFjZS5mcmFtZXMgfHwgW10pIHtcbiAgICAgICAgaWYgKCFmcmFtZS5maWxlbmFtZSB8fCBmcmFtZS5tb2R1bGVfbWV0YWRhdGEpIHtcbiAgICAgICAgICBjb250aW51ZTtcbiAgICAgICAgfVxuXG4gICAgICAgIGNvbnN0IG1ldGFkYXRhID0gZ2V0TWV0YWRhdGFGb3JVcmwocGFyc2VyLCBmcmFtZS5maWxlbmFtZSk7XG5cbiAgICAgICAgaWYgKG1ldGFkYXRhKSB7XG4gICAgICAgICAgZnJhbWUubW9kdWxlX21ldGFkYXRhID0gbWV0YWRhdGE7XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9KTtcbiAgfSBjYXRjaCB7XG4gICAgLy8gVG8gc2F2ZSBidW5kbGUgc2l6ZSB3ZSdyZSBqdXN0IHRyeSBjYXRjaGluZyBoZXJlIGluc3RlYWQgb2YgY2hlY2tpbmcgZm9yIHRoZSBleGlzdGVuY2Ugb2YgYWxsIHRoZSBkaWZmZXJlbnQgb2JqZWN0cy5cbiAgfVxufVxuXG4vKipcbiAqIFN0cmlwcyBtZXRhZGF0YSBmcm9tIHN0YWNrIGZyYW1lcy5cbiAqL1xuZnVuY3Rpb24gc3RyaXBNZXRhZGF0YUZyb21TdGFja0ZyYW1lcyhldmVudCkge1xuICB0cnkge1xuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tbm9uLW51bGwtYXNzZXJ0aW9uXG4gICAgZXZlbnQuZXhjZXB0aW9uLnZhbHVlcy5mb3JFYWNoKGV4Y2VwdGlvbiA9PiB7XG4gICAgICBpZiAoIWV4Y2VwdGlvbi5zdGFja3RyYWNlKSB7XG4gICAgICAgIHJldHVybjtcbiAgICAgIH1cblxuICAgICAgZm9yIChjb25zdCBmcmFtZSBvZiBleGNlcHRpb24uc3RhY2t0cmFjZS5mcmFtZXMgfHwgW10pIHtcbiAgICAgICAgZGVsZXRlIGZyYW1lLm1vZHVsZV9tZXRhZGF0YTtcbiAgICAgIH1cbiAgICB9KTtcbiAgfSBjYXRjaCB7XG4gICAgLy8gVG8gc2F2ZSBidW5kbGUgc2l6ZSB3ZSdyZSBqdXN0IHRyeSBjYXRjaGluZyBoZXJlIGluc3RlYWQgb2YgY2hlY2tpbmcgZm9yIHRoZSBleGlzdGVuY2Ugb2YgYWxsIHRoZSBkaWZmZXJlbnQgb2JqZWN0cy5cbiAgfVxufVxuXG5leHBvcnRzLmFkZE1ldGFkYXRhVG9TdGFja0ZyYW1lcyA9IGFkZE1ldGFkYXRhVG9TdGFja0ZyYW1lcztcbmV4cG9ydHMuZ2V0TWV0YWRhdGFGb3JVcmwgPSBnZXRNZXRhZGF0YUZvclVybDtcbmV4cG9ydHMuc3RyaXBNZXRhZGF0YUZyb21TdGFja0ZyYW1lcyA9IHN0cmlwTWV0YWRhdGFGcm9tU3RhY2tGcmFtZXM7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1tZXRhZGF0YS5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/metadata.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/profiling.js":
/*!*************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/profiling.js ***!
  \*************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst currentScopes = __webpack_require__(/*! ./currentScopes.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst debugBuild = __webpack_require__(/*! ./debug-build.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst debugLogger = __webpack_require__(/*! ./utils/debug-logger.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\n\nfunction isProfilingIntegrationWithProfiler(\n  integration,\n) {\n  return (\n    !!integration &&\n    typeof integration['_profiler'] !== 'undefined' &&\n    typeof integration['_profiler']['start'] === 'function' &&\n    typeof integration['_profiler']['stop'] === 'function'\n  );\n}\n/**\n * Starts the Sentry continuous profiler.\n * This mode is exclusive with the transaction profiler and will only work if the profilesSampleRate is set to a falsy value.\n * In continuous profiling mode, the profiler will keep reporting profile chunks to Sentry until it is stopped, which allows for continuous profiling of the application.\n */\nfunction startProfiler() {\n  const client = currentScopes.getClient();\n  if (!client) {\n    debugBuild.DEBUG_BUILD && debugLogger.debug.warn('No Sentry client available, profiling is not started');\n    return;\n  }\n\n  const integration = client.getIntegrationByName('ProfilingIntegration');\n\n  if (!integration) {\n    debugBuild.DEBUG_BUILD && debugLogger.debug.warn('ProfilingIntegration is not available');\n    return;\n  }\n\n  if (!isProfilingIntegrationWithProfiler(integration)) {\n    debugBuild.DEBUG_BUILD && debugLogger.debug.warn('Profiler is not available on profiling integration.');\n    return;\n  }\n\n  integration._profiler.start();\n}\n\n/**\n * Stops the Sentry continuous profiler.\n * Calls to stop will stop the profiler and flush the currently collected profile data to Sentry.\n */\nfunction stopProfiler() {\n  const client = currentScopes.getClient();\n  if (!client) {\n    debugBuild.DEBUG_BUILD && debugLogger.debug.warn('No Sentry client available, profiling is not started');\n    return;\n  }\n\n  const integration = client.getIntegrationByName('ProfilingIntegration');\n  if (!integration) {\n    debugBuild.DEBUG_BUILD && debugLogger.debug.warn('ProfilingIntegration is not available');\n    return;\n  }\n\n  if (!isProfilingIntegrationWithProfiler(integration)) {\n    debugBuild.DEBUG_BUILD && debugLogger.debug.warn('Profiler is not available on profiling integration.');\n    return;\n  }\n\n  integration._profiler.stop();\n}\n\nconst profiler = {\n  startProfiler,\n  stopProfiler,\n};\n\nexports.profiler = profiler;\n//# sourceMappingURL=profiling.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9wcm9maWxpbmcuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsc0JBQXNCLG1CQUFPLENBQUMsK0hBQW9CO0FBQ2xELG1CQUFtQixtQkFBTyxDQUFDLDJIQUFrQjtBQUM3QyxvQkFBb0IsbUJBQU8sQ0FBQyx5SUFBeUI7O0FBRXJEO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSxnQkFBZ0I7QUFDaEIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9wcm9maWxpbmcuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGN1cnJlbnRTY29wZXMgPSByZXF1aXJlKCcuL2N1cnJlbnRTY29wZXMuanMnKTtcbmNvbnN0IGRlYnVnQnVpbGQgPSByZXF1aXJlKCcuL2RlYnVnLWJ1aWxkLmpzJyk7XG5jb25zdCBkZWJ1Z0xvZ2dlciA9IHJlcXVpcmUoJy4vdXRpbHMvZGVidWctbG9nZ2VyLmpzJyk7XG5cbmZ1bmN0aW9uIGlzUHJvZmlsaW5nSW50ZWdyYXRpb25XaXRoUHJvZmlsZXIoXG4gIGludGVncmF0aW9uLFxuKSB7XG4gIHJldHVybiAoXG4gICAgISFpbnRlZ3JhdGlvbiAmJlxuICAgIHR5cGVvZiBpbnRlZ3JhdGlvblsnX3Byb2ZpbGVyJ10gIT09ICd1bmRlZmluZWQnICYmXG4gICAgdHlwZW9mIGludGVncmF0aW9uWydfcHJvZmlsZXInXVsnc3RhcnQnXSA9PT0gJ2Z1bmN0aW9uJyAmJlxuICAgIHR5cGVvZiBpbnRlZ3JhdGlvblsnX3Byb2ZpbGVyJ11bJ3N0b3AnXSA9PT0gJ2Z1bmN0aW9uJ1xuICApO1xufVxuLyoqXG4gKiBTdGFydHMgdGhlIFNlbnRyeSBjb250aW51b3VzIHByb2ZpbGVyLlxuICogVGhpcyBtb2RlIGlzIGV4Y2x1c2l2ZSB3aXRoIHRoZSB0cmFuc2FjdGlvbiBwcm9maWxlciBhbmQgd2lsbCBvbmx5IHdvcmsgaWYgdGhlIHByb2ZpbGVzU2FtcGxlUmF0ZSBpcyBzZXQgdG8gYSBmYWxzeSB2YWx1ZS5cbiAqIEluIGNvbnRpbnVvdXMgcHJvZmlsaW5nIG1vZGUsIHRoZSBwcm9maWxlciB3aWxsIGtlZXAgcmVwb3J0aW5nIHByb2ZpbGUgY2h1bmtzIHRvIFNlbnRyeSB1bnRpbCBpdCBpcyBzdG9wcGVkLCB3aGljaCBhbGxvd3MgZm9yIGNvbnRpbnVvdXMgcHJvZmlsaW5nIG9mIHRoZSBhcHBsaWNhdGlvbi5cbiAqL1xuZnVuY3Rpb24gc3RhcnRQcm9maWxlcigpIHtcbiAgY29uc3QgY2xpZW50ID0gY3VycmVudFNjb3Blcy5nZXRDbGllbnQoKTtcbiAgaWYgKCFjbGllbnQpIHtcbiAgICBkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEICYmIGRlYnVnTG9nZ2VyLmRlYnVnLndhcm4oJ05vIFNlbnRyeSBjbGllbnQgYXZhaWxhYmxlLCBwcm9maWxpbmcgaXMgbm90IHN0YXJ0ZWQnKTtcbiAgICByZXR1cm47XG4gIH1cblxuICBjb25zdCBpbnRlZ3JhdGlvbiA9IGNsaWVudC5nZXRJbnRlZ3JhdGlvbkJ5TmFtZSgnUHJvZmlsaW5nSW50ZWdyYXRpb24nKTtcblxuICBpZiAoIWludGVncmF0aW9uKSB7XG4gICAgZGVidWdCdWlsZC5ERUJVR19CVUlMRCAmJiBkZWJ1Z0xvZ2dlci5kZWJ1Zy53YXJuKCdQcm9maWxpbmdJbnRlZ3JhdGlvbiBpcyBub3QgYXZhaWxhYmxlJyk7XG4gICAgcmV0dXJuO1xuICB9XG5cbiAgaWYgKCFpc1Byb2ZpbGluZ0ludGVncmF0aW9uV2l0aFByb2ZpbGVyKGludGVncmF0aW9uKSkge1xuICAgIGRlYnVnQnVpbGQuREVCVUdfQlVJTEQgJiYgZGVidWdMb2dnZXIuZGVidWcud2FybignUHJvZmlsZXIgaXMgbm90IGF2YWlsYWJsZSBvbiBwcm9maWxpbmcgaW50ZWdyYXRpb24uJyk7XG4gICAgcmV0dXJuO1xuICB9XG5cbiAgaW50ZWdyYXRpb24uX3Byb2ZpbGVyLnN0YXJ0KCk7XG59XG5cbi8qKlxuICogU3RvcHMgdGhlIFNlbnRyeSBjb250aW51b3VzIHByb2ZpbGVyLlxuICogQ2FsbHMgdG8gc3RvcCB3aWxsIHN0b3AgdGhlIHByb2ZpbGVyIGFuZCBmbHVzaCB0aGUgY3VycmVudGx5IGNvbGxlY3RlZCBwcm9maWxlIGRhdGEgdG8gU2VudHJ5LlxuICovXG5mdW5jdGlvbiBzdG9wUHJvZmlsZXIoKSB7XG4gIGNvbnN0IGNsaWVudCA9IGN1cnJlbnRTY29wZXMuZ2V0Q2xpZW50KCk7XG4gIGlmICghY2xpZW50KSB7XG4gICAgZGVidWdCdWlsZC5ERUJVR19CVUlMRCAmJiBkZWJ1Z0xvZ2dlci5kZWJ1Zy53YXJuKCdObyBTZW50cnkgY2xpZW50IGF2YWlsYWJsZSwgcHJvZmlsaW5nIGlzIG5vdCBzdGFydGVkJyk7XG4gICAgcmV0dXJuO1xuICB9XG5cbiAgY29uc3QgaW50ZWdyYXRpb24gPSBjbGllbnQuZ2V0SW50ZWdyYXRpb25CeU5hbWUoJ1Byb2ZpbGluZ0ludGVncmF0aW9uJyk7XG4gIGlmICghaW50ZWdyYXRpb24pIHtcbiAgICBkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEICYmIGRlYnVnTG9nZ2VyLmRlYnVnLndhcm4oJ1Byb2ZpbGluZ0ludGVncmF0aW9uIGlzIG5vdCBhdmFpbGFibGUnKTtcbiAgICByZXR1cm47XG4gIH1cblxuICBpZiAoIWlzUHJvZmlsaW5nSW50ZWdyYXRpb25XaXRoUHJvZmlsZXIoaW50ZWdyYXRpb24pKSB7XG4gICAgZGVidWdCdWlsZC5ERUJVR19CVUlMRCAmJiBkZWJ1Z0xvZ2dlci5kZWJ1Zy53YXJuKCdQcm9maWxlciBpcyBub3QgYXZhaWxhYmxlIG9uIHByb2ZpbGluZyBpbnRlZ3JhdGlvbi4nKTtcbiAgICByZXR1cm47XG4gIH1cblxuICBpbnRlZ3JhdGlvbi5fcHJvZmlsZXIuc3RvcCgpO1xufVxuXG5jb25zdCBwcm9maWxlciA9IHtcbiAgc3RhcnRQcm9maWxlcixcbiAgc3RvcFByb2ZpbGVyLFxufTtcblxuZXhwb3J0cy5wcm9maWxlciA9IHByb2ZpbGVyO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9cHJvZmlsaW5nLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/profiling.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/scope.js":
/*!*********************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/scope.js ***!
  \*********************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst debugBuild = __webpack_require__(/*! ./debug-build.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst session = __webpack_require__(/*! ./session.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/session.js\");\nconst debugLogger = __webpack_require__(/*! ./utils/debug-logger.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst is = __webpack_require__(/*! ./utils/is.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js\");\nconst merge = __webpack_require__(/*! ./utils/merge.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/merge.js\");\nconst misc = __webpack_require__(/*! ./utils/misc.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/misc.js\");\nconst propagationContext = __webpack_require__(/*! ./utils/propagationContext.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/propagationContext.js\");\nconst spanOnScope = __webpack_require__(/*! ./utils/spanOnScope.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanOnScope.js\");\nconst string = __webpack_require__(/*! ./utils/string.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/string.js\");\nconst time = __webpack_require__(/*! ./utils/time.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/time.js\");\n\n/**\n * Default value for maximum number of breadcrumbs added to an event.\n */\nconst DEFAULT_MAX_BREADCRUMBS = 100;\n\n/**\n * A context to be used for capturing an event.\n * This can either be a Scope, or a partial ScopeContext,\n * or a callback that receives the current scope and returns a new scope to use.\n */\n\n/**\n * Holds additional event information.\n */\nclass Scope {\n  /** Flag if notifying is happening. */\n\n  /** Callback for client to receive scope changes. */\n\n  /** Callback list that will be called during event processing. */\n\n  /** Array of breadcrumbs. */\n\n  /** User */\n\n  /** Tags */\n\n  /** Extra */\n\n  /** Contexts */\n\n  /** Attachments */\n\n  /** Propagation Context for distributed tracing */\n\n  /**\n   * A place to stash data which is needed at some point in the SDK's event processing pipeline but which shouldn't get\n   * sent to Sentry\n   */\n\n  /** Fingerprint */\n\n  /** Severity */\n\n  /**\n   * Transaction Name\n   *\n   * IMPORTANT: The transaction name on the scope has nothing to do with root spans/transaction objects.\n   * It's purpose is to assign a transaction to the scope that's added to non-transaction events.\n   */\n\n  /** Session */\n\n  /** The client on this scope */\n\n  /** Contains the last event id of a captured event.  */\n\n  // NOTE: Any field which gets added here should get added not only to the constructor but also to the `clone` method.\n\n   constructor() {\n    this._notifyingListeners = false;\n    this._scopeListeners = [];\n    this._eventProcessors = [];\n    this._breadcrumbs = [];\n    this._attachments = [];\n    this._user = {};\n    this._tags = {};\n    this._extra = {};\n    this._contexts = {};\n    this._sdkProcessingMetadata = {};\n    this._propagationContext = {\n      traceId: propagationContext.generateTraceId(),\n      sampleRand: Math.random(),\n    };\n  }\n\n  /**\n   * Clone all data from this scope into a new scope.\n   */\n   clone() {\n    const newScope = new Scope();\n    newScope._breadcrumbs = [...this._breadcrumbs];\n    newScope._tags = { ...this._tags };\n    newScope._extra = { ...this._extra };\n    newScope._contexts = { ...this._contexts };\n    if (this._contexts.flags) {\n      // We need to copy the `values` array so insertions on a cloned scope\n      // won't affect the original array.\n      newScope._contexts.flags = {\n        values: [...this._contexts.flags.values],\n      };\n    }\n\n    newScope._user = this._user;\n    newScope._level = this._level;\n    newScope._session = this._session;\n    newScope._transactionName = this._transactionName;\n    newScope._fingerprint = this._fingerprint;\n    newScope._eventProcessors = [...this._eventProcessors];\n    newScope._attachments = [...this._attachments];\n    newScope._sdkProcessingMetadata = { ...this._sdkProcessingMetadata };\n    newScope._propagationContext = { ...this._propagationContext };\n    newScope._client = this._client;\n    newScope._lastEventId = this._lastEventId;\n\n    spanOnScope._setSpanForScope(newScope, spanOnScope._getSpanForScope(this));\n\n    return newScope;\n  }\n\n  /**\n   * Update the client assigned to this scope.\n   * Note that not every scope will have a client assigned - isolation scopes & the global scope will generally not have a client,\n   * as well as manually created scopes.\n   */\n   setClient(client) {\n    this._client = client;\n  }\n\n  /**\n   * Set the ID of the last captured error event.\n   * This is generally only captured on the isolation scope.\n   */\n   setLastEventId(lastEventId) {\n    this._lastEventId = lastEventId;\n  }\n\n  /**\n   * Get the client assigned to this scope.\n   */\n   getClient() {\n    return this._client ;\n  }\n\n  /**\n   * Get the ID of the last captured error event.\n   * This is generally only available on the isolation scope.\n   */\n   lastEventId() {\n    return this._lastEventId;\n  }\n\n  /**\n   * @inheritDoc\n   */\n   addScopeListener(callback) {\n    this._scopeListeners.push(callback);\n  }\n\n  /**\n   * Add an event processor that will be called before an event is sent.\n   */\n   addEventProcessor(callback) {\n    this._eventProcessors.push(callback);\n    return this;\n  }\n\n  /**\n   * Set the user for this scope.\n   * Set to `null` to unset the user.\n   */\n   setUser(user) {\n    // If null is passed we want to unset everything, but still define keys,\n    // so that later down in the pipeline any existing values are cleared.\n    this._user = user || {\n      email: undefined,\n      id: undefined,\n      ip_address: undefined,\n      username: undefined,\n    };\n\n    if (this._session) {\n      session.updateSession(this._session, { user });\n    }\n\n    this._notifyScopeListeners();\n    return this;\n  }\n\n  /**\n   * Get the user from this scope.\n   */\n   getUser() {\n    return this._user;\n  }\n\n  /**\n   * Set an object that will be merged into existing tags on the scope,\n   * and will be sent as tags data with the event.\n   */\n   setTags(tags) {\n    this._tags = {\n      ...this._tags,\n      ...tags,\n    };\n    this._notifyScopeListeners();\n    return this;\n  }\n\n  /**\n   * Set a single tag that will be sent as tags data with the event.\n   */\n   setTag(key, value) {\n    this._tags = { ...this._tags, [key]: value };\n    this._notifyScopeListeners();\n    return this;\n  }\n\n  /**\n   * Set an object that will be merged into existing extra on the scope,\n   * and will be sent as extra data with the event.\n   */\n   setExtras(extras) {\n    this._extra = {\n      ...this._extra,\n      ...extras,\n    };\n    this._notifyScopeListeners();\n    return this;\n  }\n\n  /**\n   * Set a single key:value extra entry that will be sent as extra data with the event.\n   */\n   setExtra(key, extra) {\n    this._extra = { ...this._extra, [key]: extra };\n    this._notifyScopeListeners();\n    return this;\n  }\n\n  /**\n   * Sets the fingerprint on the scope to send with the events.\n   * @param {string[]} fingerprint Fingerprint to group events in Sentry.\n   */\n   setFingerprint(fingerprint) {\n    this._fingerprint = fingerprint;\n    this._notifyScopeListeners();\n    return this;\n  }\n\n  /**\n   * Sets the level on the scope for future events.\n   */\n   setLevel(level) {\n    this._level = level;\n    this._notifyScopeListeners();\n    return this;\n  }\n\n  /**\n   * Sets the transaction name on the scope so that the name of e.g. taken server route or\n   * the page location is attached to future events.\n   *\n   * IMPORTANT: Calling this function does NOT change the name of the currently active\n   * root span. If you want to change the name of the active root span, use\n   * `Sentry.updateSpanName(rootSpan, 'new name')` instead.\n   *\n   * By default, the SDK updates the scope's transaction name automatically on sensible\n   * occasions, such as a page navigation or when handling a new request on the server.\n   */\n   setTransactionName(name) {\n    this._transactionName = name;\n    this._notifyScopeListeners();\n    return this;\n  }\n\n  /**\n   * Sets context data with the given name.\n   * Data passed as context will be normalized. You can also pass `null` to unset the context.\n   * Note that context data will not be merged - calling `setContext` will overwrite an existing context with the same key.\n   */\n   setContext(key, context) {\n    if (context === null) {\n      // eslint-disable-next-line @typescript-eslint/no-dynamic-delete\n      delete this._contexts[key];\n    } else {\n      this._contexts[key] = context;\n    }\n\n    this._notifyScopeListeners();\n    return this;\n  }\n\n  /**\n   * Set the session for the scope.\n   */\n   setSession(session) {\n    if (!session) {\n      delete this._session;\n    } else {\n      this._session = session;\n    }\n    this._notifyScopeListeners();\n    return this;\n  }\n\n  /**\n   * Get the session from the scope.\n   */\n   getSession() {\n    return this._session;\n  }\n\n  /**\n   * Updates the scope with provided data. Can work in three variations:\n   * - plain object containing updatable attributes\n   * - Scope instance that'll extract the attributes from\n   * - callback function that'll receive the current scope as an argument and allow for modifications\n   */\n   update(captureContext) {\n    if (!captureContext) {\n      return this;\n    }\n\n    const scopeToMerge = typeof captureContext === 'function' ? captureContext(this) : captureContext;\n\n    const scopeInstance =\n      scopeToMerge instanceof Scope\n        ? scopeToMerge.getScopeData()\n        : is.isPlainObject(scopeToMerge)\n          ? (captureContext )\n          : undefined;\n\n    const { tags, extra, user, contexts, level, fingerprint = [], propagationContext } = scopeInstance || {};\n\n    this._tags = { ...this._tags, ...tags };\n    this._extra = { ...this._extra, ...extra };\n    this._contexts = { ...this._contexts, ...contexts };\n\n    if (user && Object.keys(user).length) {\n      this._user = user;\n    }\n\n    if (level) {\n      this._level = level;\n    }\n\n    if (fingerprint.length) {\n      this._fingerprint = fingerprint;\n    }\n\n    if (propagationContext) {\n      this._propagationContext = propagationContext;\n    }\n\n    return this;\n  }\n\n  /**\n   * Clears the current scope and resets its properties.\n   * Note: The client will not be cleared.\n   */\n   clear() {\n    // client is not cleared here on purpose!\n    this._breadcrumbs = [];\n    this._tags = {};\n    this._extra = {};\n    this._user = {};\n    this._contexts = {};\n    this._level = undefined;\n    this._transactionName = undefined;\n    this._fingerprint = undefined;\n    this._session = undefined;\n    spanOnScope._setSpanForScope(this, undefined);\n    this._attachments = [];\n    this.setPropagationContext({ traceId: propagationContext.generateTraceId(), sampleRand: Math.random() });\n\n    this._notifyScopeListeners();\n    return this;\n  }\n\n  /**\n   * Adds a breadcrumb to the scope.\n   * By default, the last 100 breadcrumbs are kept.\n   */\n   addBreadcrumb(breadcrumb, maxBreadcrumbs) {\n    const maxCrumbs = typeof maxBreadcrumbs === 'number' ? maxBreadcrumbs : DEFAULT_MAX_BREADCRUMBS;\n\n    // No data has been changed, so don't notify scope listeners\n    if (maxCrumbs <= 0) {\n      return this;\n    }\n\n    const mergedBreadcrumb = {\n      timestamp: time.dateTimestampInSeconds(),\n      ...breadcrumb,\n      // Breadcrumb messages can theoretically be infinitely large and they're held in memory so we truncate them not to leak (too much) memory\n      message: breadcrumb.message ? string.truncate(breadcrumb.message, 2048) : breadcrumb.message,\n    };\n\n    this._breadcrumbs.push(mergedBreadcrumb);\n    if (this._breadcrumbs.length > maxCrumbs) {\n      this._breadcrumbs = this._breadcrumbs.slice(-maxCrumbs);\n      this._client?.recordDroppedEvent('buffer_overflow', 'log_item');\n    }\n\n    this._notifyScopeListeners();\n\n    return this;\n  }\n\n  /**\n   * Get the last breadcrumb of the scope.\n   */\n   getLastBreadcrumb() {\n    return this._breadcrumbs[this._breadcrumbs.length - 1];\n  }\n\n  /**\n   * Clear all breadcrumbs from the scope.\n   */\n   clearBreadcrumbs() {\n    this._breadcrumbs = [];\n    this._notifyScopeListeners();\n    return this;\n  }\n\n  /**\n   * Add an attachment to the scope.\n   */\n   addAttachment(attachment) {\n    this._attachments.push(attachment);\n    return this;\n  }\n\n  /**\n   * Clear all attachments from the scope.\n   */\n   clearAttachments() {\n    this._attachments = [];\n    return this;\n  }\n\n  /**\n   * Get the data of this scope, which should be applied to an event during processing.\n   */\n   getScopeData() {\n    return {\n      breadcrumbs: this._breadcrumbs,\n      attachments: this._attachments,\n      contexts: this._contexts,\n      tags: this._tags,\n      extra: this._extra,\n      user: this._user,\n      level: this._level,\n      fingerprint: this._fingerprint || [],\n      eventProcessors: this._eventProcessors,\n      propagationContext: this._propagationContext,\n      sdkProcessingMetadata: this._sdkProcessingMetadata,\n      transactionName: this._transactionName,\n      span: spanOnScope._getSpanForScope(this),\n    };\n  }\n\n  /**\n   * Add data which will be accessible during event processing but won't get sent to Sentry.\n   */\n   setSDKProcessingMetadata(newData) {\n    this._sdkProcessingMetadata = merge.merge(this._sdkProcessingMetadata, newData, 2);\n    return this;\n  }\n\n  /**\n   * Add propagation context to the scope, used for distributed tracing\n   */\n   setPropagationContext(context) {\n    this._propagationContext = context;\n    return this;\n  }\n\n  /**\n   * Get propagation context from the scope, used for distributed tracing\n   */\n   getPropagationContext() {\n    return this._propagationContext;\n  }\n\n  /**\n   * Capture an exception for this scope.\n   *\n   * @returns {string} The id of the captured Sentry event.\n   */\n   captureException(exception, hint) {\n    const eventId = hint?.event_id || misc.uuid4();\n\n    if (!this._client) {\n      debugBuild.DEBUG_BUILD && debugLogger.debug.warn('No client configured on scope - will not capture exception!');\n      return eventId;\n    }\n\n    const syntheticException = new Error('Sentry syntheticException');\n\n    this._client.captureException(\n      exception,\n      {\n        originalException: exception,\n        syntheticException,\n        ...hint,\n        event_id: eventId,\n      },\n      this,\n    );\n\n    return eventId;\n  }\n\n  /**\n   * Capture a message for this scope.\n   *\n   * @returns {string} The id of the captured message.\n   */\n   captureMessage(message, level, hint) {\n    const eventId = hint?.event_id || misc.uuid4();\n\n    if (!this._client) {\n      debugBuild.DEBUG_BUILD && debugLogger.debug.warn('No client configured on scope - will not capture message!');\n      return eventId;\n    }\n\n    const syntheticException = new Error(message);\n\n    this._client.captureMessage(\n      message,\n      level,\n      {\n        originalException: message,\n        syntheticException,\n        ...hint,\n        event_id: eventId,\n      },\n      this,\n    );\n\n    return eventId;\n  }\n\n  /**\n   * Capture a Sentry event for this scope.\n   *\n   * @returns {string} The id of the captured event.\n   */\n   captureEvent(event, hint) {\n    const eventId = hint?.event_id || misc.uuid4();\n\n    if (!this._client) {\n      debugBuild.DEBUG_BUILD && debugLogger.debug.warn('No client configured on scope - will not capture event!');\n      return eventId;\n    }\n\n    this._client.captureEvent(event, { ...hint, event_id: eventId }, this);\n\n    return eventId;\n  }\n\n  /**\n   * This will be called on every set call.\n   */\n   _notifyScopeListeners() {\n    // We need this check for this._notifyingListeners to be able to work on scope during updates\n    // If this check is not here we'll produce endless recursion when something is done with the scope\n    // during the callback.\n    if (!this._notifyingListeners) {\n      this._notifyingListeners = true;\n      this._scopeListeners.forEach(callback => {\n        callback(this);\n      });\n      this._notifyingListeners = false;\n    }\n  }\n}\n\nexports.Scope = Scope;\n//# sourceMappingURL=scope.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9zY29wZS5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxtQkFBbUIsbUJBQU8sQ0FBQywySEFBa0I7QUFDN0MsZ0JBQWdCLG1CQUFPLENBQUMsbUhBQWM7QUFDdEMsb0JBQW9CLG1CQUFPLENBQUMseUlBQXlCO0FBQ3JELFdBQVcsbUJBQU8sQ0FBQyxxSEFBZTtBQUNsQyxjQUFjLG1CQUFPLENBQUMsMkhBQWtCO0FBQ3hDLGFBQWEsbUJBQU8sQ0FBQyx5SEFBaUI7QUFDdEMsMkJBQTJCLG1CQUFPLENBQUMscUpBQStCO0FBQ2xFLG9CQUFvQixtQkFBTyxDQUFDLHVJQUF3QjtBQUNwRCxlQUFlLG1CQUFPLENBQUMsNkhBQW1CO0FBQzFDLGFBQWEsbUJBQU8sQ0FBQyx5SEFBaUI7O0FBRXRDO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTs7QUFFQTs7QUFFQTs7QUFFQTs7QUFFQTs7QUFFQTs7QUFFQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7O0FBRUE7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsdUJBQXVCO0FBQ3ZCLHdCQUF3QjtBQUN4QiwyQkFBMkI7QUFDM0I7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSx3Q0FBd0M7QUFDeEMscUNBQXFDO0FBQ3JDO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQSw2Q0FBNkMsTUFBTTtBQUNuRDs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLG1CQUFtQjtBQUNuQjtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0Esb0JBQW9CO0FBQ3BCO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsYUFBYSxVQUFVO0FBQ3ZCO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLE1BQU07QUFDTjtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxNQUFNO0FBQ047QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLFlBQVksMkVBQTJFOztBQUV2RixtQkFBbUI7QUFDbkIsb0JBQW9CO0FBQ3BCLHVCQUF1Qjs7QUFFdkI7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGlDQUFpQywwRUFBMEU7O0FBRTNHO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQSxlQUFlLFFBQVE7QUFDdkI7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsT0FBTztBQUNQO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQSxlQUFlLFFBQVE7QUFDdkI7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxPQUFPO0FBQ1A7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBLGVBQWUsUUFBUTtBQUN2QjtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsdUNBQXVDLDRCQUE0Qjs7QUFFbkU7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsT0FBTztBQUNQO0FBQ0E7QUFDQTtBQUNBOztBQUVBLGFBQWE7QUFDYiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3Njb3BlLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBkZWJ1Z0J1aWxkID0gcmVxdWlyZSgnLi9kZWJ1Zy1idWlsZC5qcycpO1xuY29uc3Qgc2Vzc2lvbiA9IHJlcXVpcmUoJy4vc2Vzc2lvbi5qcycpO1xuY29uc3QgZGVidWdMb2dnZXIgPSByZXF1aXJlKCcuL3V0aWxzL2RlYnVnLWxvZ2dlci5qcycpO1xuY29uc3QgaXMgPSByZXF1aXJlKCcuL3V0aWxzL2lzLmpzJyk7XG5jb25zdCBtZXJnZSA9IHJlcXVpcmUoJy4vdXRpbHMvbWVyZ2UuanMnKTtcbmNvbnN0IG1pc2MgPSByZXF1aXJlKCcuL3V0aWxzL21pc2MuanMnKTtcbmNvbnN0IHByb3BhZ2F0aW9uQ29udGV4dCA9IHJlcXVpcmUoJy4vdXRpbHMvcHJvcGFnYXRpb25Db250ZXh0LmpzJyk7XG5jb25zdCBzcGFuT25TY29wZSA9IHJlcXVpcmUoJy4vdXRpbHMvc3Bhbk9uU2NvcGUuanMnKTtcbmNvbnN0IHN0cmluZyA9IHJlcXVpcmUoJy4vdXRpbHMvc3RyaW5nLmpzJyk7XG5jb25zdCB0aW1lID0gcmVxdWlyZSgnLi91dGlscy90aW1lLmpzJyk7XG5cbi8qKlxuICogRGVmYXVsdCB2YWx1ZSBmb3IgbWF4aW11bSBudW1iZXIgb2YgYnJlYWRjcnVtYnMgYWRkZWQgdG8gYW4gZXZlbnQuXG4gKi9cbmNvbnN0IERFRkFVTFRfTUFYX0JSRUFEQ1JVTUJTID0gMTAwO1xuXG4vKipcbiAqIEEgY29udGV4dCB0byBiZSB1c2VkIGZvciBjYXB0dXJpbmcgYW4gZXZlbnQuXG4gKiBUaGlzIGNhbiBlaXRoZXIgYmUgYSBTY29wZSwgb3IgYSBwYXJ0aWFsIFNjb3BlQ29udGV4dCxcbiAqIG9yIGEgY2FsbGJhY2sgdGhhdCByZWNlaXZlcyB0aGUgY3VycmVudCBzY29wZSBhbmQgcmV0dXJucyBhIG5ldyBzY29wZSB0byB1c2UuXG4gKi9cblxuLyoqXG4gKiBIb2xkcyBhZGRpdGlvbmFsIGV2ZW50IGluZm9ybWF0aW9uLlxuICovXG5jbGFzcyBTY29wZSB7XG4gIC8qKiBGbGFnIGlmIG5vdGlmeWluZyBpcyBoYXBwZW5pbmcuICovXG5cbiAgLyoqIENhbGxiYWNrIGZvciBjbGllbnQgdG8gcmVjZWl2ZSBzY29wZSBjaGFuZ2VzLiAqL1xuXG4gIC8qKiBDYWxsYmFjayBsaXN0IHRoYXQgd2lsbCBiZSBjYWxsZWQgZHVyaW5nIGV2ZW50IHByb2Nlc3NpbmcuICovXG5cbiAgLyoqIEFycmF5IG9mIGJyZWFkY3J1bWJzLiAqL1xuXG4gIC8qKiBVc2VyICovXG5cbiAgLyoqIFRhZ3MgKi9cblxuICAvKiogRXh0cmEgKi9cblxuICAvKiogQ29udGV4dHMgKi9cblxuICAvKiogQXR0YWNobWVudHMgKi9cblxuICAvKiogUHJvcGFnYXRpb24gQ29udGV4dCBmb3IgZGlzdHJpYnV0ZWQgdHJhY2luZyAqL1xuXG4gIC8qKlxuICAgKiBBIHBsYWNlIHRvIHN0YXNoIGRhdGEgd2hpY2ggaXMgbmVlZGVkIGF0IHNvbWUgcG9pbnQgaW4gdGhlIFNESydzIGV2ZW50IHByb2Nlc3NpbmcgcGlwZWxpbmUgYnV0IHdoaWNoIHNob3VsZG4ndCBnZXRcbiAgICogc2VudCB0byBTZW50cnlcbiAgICovXG5cbiAgLyoqIEZpbmdlcnByaW50ICovXG5cbiAgLyoqIFNldmVyaXR5ICovXG5cbiAgLyoqXG4gICAqIFRyYW5zYWN0aW9uIE5hbWVcbiAgICpcbiAgICogSU1QT1JUQU5UOiBUaGUgdHJhbnNhY3Rpb24gbmFtZSBvbiB0aGUgc2NvcGUgaGFzIG5vdGhpbmcgdG8gZG8gd2l0aCByb290IHNwYW5zL3RyYW5zYWN0aW9uIG9iamVjdHMuXG4gICAqIEl0J3MgcHVycG9zZSBpcyB0byBhc3NpZ24gYSB0cmFuc2FjdGlvbiB0byB0aGUgc2NvcGUgdGhhdCdzIGFkZGVkIHRvIG5vbi10cmFuc2FjdGlvbiBldmVudHMuXG4gICAqL1xuXG4gIC8qKiBTZXNzaW9uICovXG5cbiAgLyoqIFRoZSBjbGllbnQgb24gdGhpcyBzY29wZSAqL1xuXG4gIC8qKiBDb250YWlucyB0aGUgbGFzdCBldmVudCBpZCBvZiBhIGNhcHR1cmVkIGV2ZW50LiAgKi9cblxuICAvLyBOT1RFOiBBbnkgZmllbGQgd2hpY2ggZ2V0cyBhZGRlZCBoZXJlIHNob3VsZCBnZXQgYWRkZWQgbm90IG9ubHkgdG8gdGhlIGNvbnN0cnVjdG9yIGJ1dCBhbHNvIHRvIHRoZSBgY2xvbmVgIG1ldGhvZC5cblxuICAgY29uc3RydWN0b3IoKSB7XG4gICAgdGhpcy5fbm90aWZ5aW5nTGlzdGVuZXJzID0gZmFsc2U7XG4gICAgdGhpcy5fc2NvcGVMaXN0ZW5lcnMgPSBbXTtcbiAgICB0aGlzLl9ldmVudFByb2Nlc3NvcnMgPSBbXTtcbiAgICB0aGlzLl9icmVhZGNydW1icyA9IFtdO1xuICAgIHRoaXMuX2F0dGFjaG1lbnRzID0gW107XG4gICAgdGhpcy5fdXNlciA9IHt9O1xuICAgIHRoaXMuX3RhZ3MgPSB7fTtcbiAgICB0aGlzLl9leHRyYSA9IHt9O1xuICAgIHRoaXMuX2NvbnRleHRzID0ge307XG4gICAgdGhpcy5fc2RrUHJvY2Vzc2luZ01ldGFkYXRhID0ge307XG4gICAgdGhpcy5fcHJvcGFnYXRpb25Db250ZXh0ID0ge1xuICAgICAgdHJhY2VJZDogcHJvcGFnYXRpb25Db250ZXh0LmdlbmVyYXRlVHJhY2VJZCgpLFxuICAgICAgc2FtcGxlUmFuZDogTWF0aC5yYW5kb20oKSxcbiAgICB9O1xuICB9XG5cbiAgLyoqXG4gICAqIENsb25lIGFsbCBkYXRhIGZyb20gdGhpcyBzY29wZSBpbnRvIGEgbmV3IHNjb3BlLlxuICAgKi9cbiAgIGNsb25lKCkge1xuICAgIGNvbnN0IG5ld1Njb3BlID0gbmV3IFNjb3BlKCk7XG4gICAgbmV3U2NvcGUuX2JyZWFkY3J1bWJzID0gWy4uLnRoaXMuX2JyZWFkY3J1bWJzXTtcbiAgICBuZXdTY29wZS5fdGFncyA9IHsgLi4udGhpcy5fdGFncyB9O1xuICAgIG5ld1Njb3BlLl9leHRyYSA9IHsgLi4udGhpcy5fZXh0cmEgfTtcbiAgICBuZXdTY29wZS5fY29udGV4dHMgPSB7IC4uLnRoaXMuX2NvbnRleHRzIH07XG4gICAgaWYgKHRoaXMuX2NvbnRleHRzLmZsYWdzKSB7XG4gICAgICAvLyBXZSBuZWVkIHRvIGNvcHkgdGhlIGB2YWx1ZXNgIGFycmF5IHNvIGluc2VydGlvbnMgb24gYSBjbG9uZWQgc2NvcGVcbiAgICAgIC8vIHdvbid0IGFmZmVjdCB0aGUgb3JpZ2luYWwgYXJyYXkuXG4gICAgICBuZXdTY29wZS5fY29udGV4dHMuZmxhZ3MgPSB7XG4gICAgICAgIHZhbHVlczogWy4uLnRoaXMuX2NvbnRleHRzLmZsYWdzLnZhbHVlc10sXG4gICAgICB9O1xuICAgIH1cblxuICAgIG5ld1Njb3BlLl91c2VyID0gdGhpcy5fdXNlcjtcbiAgICBuZXdTY29wZS5fbGV2ZWwgPSB0aGlzLl9sZXZlbDtcbiAgICBuZXdTY29wZS5fc2Vzc2lvbiA9IHRoaXMuX3Nlc3Npb247XG4gICAgbmV3U2NvcGUuX3RyYW5zYWN0aW9uTmFtZSA9IHRoaXMuX3RyYW5zYWN0aW9uTmFtZTtcbiAgICBuZXdTY29wZS5fZmluZ2VycHJpbnQgPSB0aGlzLl9maW5nZXJwcmludDtcbiAgICBuZXdTY29wZS5fZXZlbnRQcm9jZXNzb3JzID0gWy4uLnRoaXMuX2V2ZW50UHJvY2Vzc29yc107XG4gICAgbmV3U2NvcGUuX2F0dGFjaG1lbnRzID0gWy4uLnRoaXMuX2F0dGFjaG1lbnRzXTtcbiAgICBuZXdTY29wZS5fc2RrUHJvY2Vzc2luZ01ldGFkYXRhID0geyAuLi50aGlzLl9zZGtQcm9jZXNzaW5nTWV0YWRhdGEgfTtcbiAgICBuZXdTY29wZS5fcHJvcGFnYXRpb25Db250ZXh0ID0geyAuLi50aGlzLl9wcm9wYWdhdGlvbkNvbnRleHQgfTtcbiAgICBuZXdTY29wZS5fY2xpZW50ID0gdGhpcy5fY2xpZW50O1xuICAgIG5ld1Njb3BlLl9sYXN0RXZlbnRJZCA9IHRoaXMuX2xhc3RFdmVudElkO1xuXG4gICAgc3Bhbk9uU2NvcGUuX3NldFNwYW5Gb3JTY29wZShuZXdTY29wZSwgc3Bhbk9uU2NvcGUuX2dldFNwYW5Gb3JTY29wZSh0aGlzKSk7XG5cbiAgICByZXR1cm4gbmV3U2NvcGU7XG4gIH1cblxuICAvKipcbiAgICogVXBkYXRlIHRoZSBjbGllbnQgYXNzaWduZWQgdG8gdGhpcyBzY29wZS5cbiAgICogTm90ZSB0aGF0IG5vdCBldmVyeSBzY29wZSB3aWxsIGhhdmUgYSBjbGllbnQgYXNzaWduZWQgLSBpc29sYXRpb24gc2NvcGVzICYgdGhlIGdsb2JhbCBzY29wZSB3aWxsIGdlbmVyYWxseSBub3QgaGF2ZSBhIGNsaWVudCxcbiAgICogYXMgd2VsbCBhcyBtYW51YWxseSBjcmVhdGVkIHNjb3Blcy5cbiAgICovXG4gICBzZXRDbGllbnQoY2xpZW50KSB7XG4gICAgdGhpcy5fY2xpZW50ID0gY2xpZW50O1xuICB9XG5cbiAgLyoqXG4gICAqIFNldCB0aGUgSUQgb2YgdGhlIGxhc3QgY2FwdHVyZWQgZXJyb3IgZXZlbnQuXG4gICAqIFRoaXMgaXMgZ2VuZXJhbGx5IG9ubHkgY2FwdHVyZWQgb24gdGhlIGlzb2xhdGlvbiBzY29wZS5cbiAgICovXG4gICBzZXRMYXN0RXZlbnRJZChsYXN0RXZlbnRJZCkge1xuICAgIHRoaXMuX2xhc3RFdmVudElkID0gbGFzdEV2ZW50SWQ7XG4gIH1cblxuICAvKipcbiAgICogR2V0IHRoZSBjbGllbnQgYXNzaWduZWQgdG8gdGhpcyBzY29wZS5cbiAgICovXG4gICBnZXRDbGllbnQoKSB7XG4gICAgcmV0dXJuIHRoaXMuX2NsaWVudCA7XG4gIH1cblxuICAvKipcbiAgICogR2V0IHRoZSBJRCBvZiB0aGUgbGFzdCBjYXB0dXJlZCBlcnJvciBldmVudC5cbiAgICogVGhpcyBpcyBnZW5lcmFsbHkgb25seSBhdmFpbGFibGUgb24gdGhlIGlzb2xhdGlvbiBzY29wZS5cbiAgICovXG4gICBsYXN0RXZlbnRJZCgpIHtcbiAgICByZXR1cm4gdGhpcy5fbGFzdEV2ZW50SWQ7XG4gIH1cblxuICAvKipcbiAgICogQGluaGVyaXREb2NcbiAgICovXG4gICBhZGRTY29wZUxpc3RlbmVyKGNhbGxiYWNrKSB7XG4gICAgdGhpcy5fc2NvcGVMaXN0ZW5lcnMucHVzaChjYWxsYmFjayk7XG4gIH1cblxuICAvKipcbiAgICogQWRkIGFuIGV2ZW50IHByb2Nlc3NvciB0aGF0IHdpbGwgYmUgY2FsbGVkIGJlZm9yZSBhbiBldmVudCBpcyBzZW50LlxuICAgKi9cbiAgIGFkZEV2ZW50UHJvY2Vzc29yKGNhbGxiYWNrKSB7XG4gICAgdGhpcy5fZXZlbnRQcm9jZXNzb3JzLnB1c2goY2FsbGJhY2spO1xuICAgIHJldHVybiB0aGlzO1xuICB9XG5cbiAgLyoqXG4gICAqIFNldCB0aGUgdXNlciBmb3IgdGhpcyBzY29wZS5cbiAgICogU2V0IHRvIGBudWxsYCB0byB1bnNldCB0aGUgdXNlci5cbiAgICovXG4gICBzZXRVc2VyKHVzZXIpIHtcbiAgICAvLyBJZiBudWxsIGlzIHBhc3NlZCB3ZSB3YW50IHRvIHVuc2V0IGV2ZXJ5dGhpbmcsIGJ1dCBzdGlsbCBkZWZpbmUga2V5cyxcbiAgICAvLyBzbyB0aGF0IGxhdGVyIGRvd24gaW4gdGhlIHBpcGVsaW5lIGFueSBleGlzdGluZyB2YWx1ZXMgYXJlIGNsZWFyZWQuXG4gICAgdGhpcy5fdXNlciA9IHVzZXIgfHwge1xuICAgICAgZW1haWw6IHVuZGVmaW5lZCxcbiAgICAgIGlkOiB1bmRlZmluZWQsXG4gICAgICBpcF9hZGRyZXNzOiB1bmRlZmluZWQsXG4gICAgICB1c2VybmFtZTogdW5kZWZpbmVkLFxuICAgIH07XG5cbiAgICBpZiAodGhpcy5fc2Vzc2lvbikge1xuICAgICAgc2Vzc2lvbi51cGRhdGVTZXNzaW9uKHRoaXMuX3Nlc3Npb24sIHsgdXNlciB9KTtcbiAgICB9XG5cbiAgICB0aGlzLl9ub3RpZnlTY29wZUxpc3RlbmVycygpO1xuICAgIHJldHVybiB0aGlzO1xuICB9XG5cbiAgLyoqXG4gICAqIEdldCB0aGUgdXNlciBmcm9tIHRoaXMgc2NvcGUuXG4gICAqL1xuICAgZ2V0VXNlcigpIHtcbiAgICByZXR1cm4gdGhpcy5fdXNlcjtcbiAgfVxuXG4gIC8qKlxuICAgKiBTZXQgYW4gb2JqZWN0IHRoYXQgd2lsbCBiZSBtZXJnZWQgaW50byBleGlzdGluZyB0YWdzIG9uIHRoZSBzY29wZSxcbiAgICogYW5kIHdpbGwgYmUgc2VudCBhcyB0YWdzIGRhdGEgd2l0aCB0aGUgZXZlbnQuXG4gICAqL1xuICAgc2V0VGFncyh0YWdzKSB7XG4gICAgdGhpcy5fdGFncyA9IHtcbiAgICAgIC4uLnRoaXMuX3RhZ3MsXG4gICAgICAuLi50YWdzLFxuICAgIH07XG4gICAgdGhpcy5fbm90aWZ5U2NvcGVMaXN0ZW5lcnMoKTtcbiAgICByZXR1cm4gdGhpcztcbiAgfVxuXG4gIC8qKlxuICAgKiBTZXQgYSBzaW5nbGUgdGFnIHRoYXQgd2lsbCBiZSBzZW50IGFzIHRhZ3MgZGF0YSB3aXRoIHRoZSBldmVudC5cbiAgICovXG4gICBzZXRUYWcoa2V5LCB2YWx1ZSkge1xuICAgIHRoaXMuX3RhZ3MgPSB7IC4uLnRoaXMuX3RhZ3MsIFtrZXldOiB2YWx1ZSB9O1xuICAgIHRoaXMuX25vdGlmeVNjb3BlTGlzdGVuZXJzKCk7XG4gICAgcmV0dXJuIHRoaXM7XG4gIH1cblxuICAvKipcbiAgICogU2V0IGFuIG9iamVjdCB0aGF0IHdpbGwgYmUgbWVyZ2VkIGludG8gZXhpc3RpbmcgZXh0cmEgb24gdGhlIHNjb3BlLFxuICAgKiBhbmQgd2lsbCBiZSBzZW50IGFzIGV4dHJhIGRhdGEgd2l0aCB0aGUgZXZlbnQuXG4gICAqL1xuICAgc2V0RXh0cmFzKGV4dHJhcykge1xuICAgIHRoaXMuX2V4dHJhID0ge1xuICAgICAgLi4udGhpcy5fZXh0cmEsXG4gICAgICAuLi5leHRyYXMsXG4gICAgfTtcbiAgICB0aGlzLl9ub3RpZnlTY29wZUxpc3RlbmVycygpO1xuICAgIHJldHVybiB0aGlzO1xuICB9XG5cbiAgLyoqXG4gICAqIFNldCBhIHNpbmdsZSBrZXk6dmFsdWUgZXh0cmEgZW50cnkgdGhhdCB3aWxsIGJlIHNlbnQgYXMgZXh0cmEgZGF0YSB3aXRoIHRoZSBldmVudC5cbiAgICovXG4gICBzZXRFeHRyYShrZXksIGV4dHJhKSB7XG4gICAgdGhpcy5fZXh0cmEgPSB7IC4uLnRoaXMuX2V4dHJhLCBba2V5XTogZXh0cmEgfTtcbiAgICB0aGlzLl9ub3RpZnlTY29wZUxpc3RlbmVycygpO1xuICAgIHJldHVybiB0aGlzO1xuICB9XG5cbiAgLyoqXG4gICAqIFNldHMgdGhlIGZpbmdlcnByaW50IG9uIHRoZSBzY29wZSB0byBzZW5kIHdpdGggdGhlIGV2ZW50cy5cbiAgICogQHBhcmFtIHtzdHJpbmdbXX0gZmluZ2VycHJpbnQgRmluZ2VycHJpbnQgdG8gZ3JvdXAgZXZlbnRzIGluIFNlbnRyeS5cbiAgICovXG4gICBzZXRGaW5nZXJwcmludChmaW5nZXJwcmludCkge1xuICAgIHRoaXMuX2ZpbmdlcnByaW50ID0gZmluZ2VycHJpbnQ7XG4gICAgdGhpcy5fbm90aWZ5U2NvcGVMaXN0ZW5lcnMoKTtcbiAgICByZXR1cm4gdGhpcztcbiAgfVxuXG4gIC8qKlxuICAgKiBTZXRzIHRoZSBsZXZlbCBvbiB0aGUgc2NvcGUgZm9yIGZ1dHVyZSBldmVudHMuXG4gICAqL1xuICAgc2V0TGV2ZWwobGV2ZWwpIHtcbiAgICB0aGlzLl9sZXZlbCA9IGxldmVsO1xuICAgIHRoaXMuX25vdGlmeVNjb3BlTGlzdGVuZXJzKCk7XG4gICAgcmV0dXJuIHRoaXM7XG4gIH1cblxuICAvKipcbiAgICogU2V0cyB0aGUgdHJhbnNhY3Rpb24gbmFtZSBvbiB0aGUgc2NvcGUgc28gdGhhdCB0aGUgbmFtZSBvZiBlLmcuIHRha2VuIHNlcnZlciByb3V0ZSBvclxuICAgKiB0aGUgcGFnZSBsb2NhdGlvbiBpcyBhdHRhY2hlZCB0byBmdXR1cmUgZXZlbnRzLlxuICAgKlxuICAgKiBJTVBPUlRBTlQ6IENhbGxpbmcgdGhpcyBmdW5jdGlvbiBkb2VzIE5PVCBjaGFuZ2UgdGhlIG5hbWUgb2YgdGhlIGN1cnJlbnRseSBhY3RpdmVcbiAgICogcm9vdCBzcGFuLiBJZiB5b3Ugd2FudCB0byBjaGFuZ2UgdGhlIG5hbWUgb2YgdGhlIGFjdGl2ZSByb290IHNwYW4sIHVzZVxuICAgKiBgU2VudHJ5LnVwZGF0ZVNwYW5OYW1lKHJvb3RTcGFuLCAnbmV3IG5hbWUnKWAgaW5zdGVhZC5cbiAgICpcbiAgICogQnkgZGVmYXVsdCwgdGhlIFNESyB1cGRhdGVzIHRoZSBzY29wZSdzIHRyYW5zYWN0aW9uIG5hbWUgYXV0b21hdGljYWxseSBvbiBzZW5zaWJsZVxuICAgKiBvY2Nhc2lvbnMsIHN1Y2ggYXMgYSBwYWdlIG5hdmlnYXRpb24gb3Igd2hlbiBoYW5kbGluZyBhIG5ldyByZXF1ZXN0IG9uIHRoZSBzZXJ2ZXIuXG4gICAqL1xuICAgc2V0VHJhbnNhY3Rpb25OYW1lKG5hbWUpIHtcbiAgICB0aGlzLl90cmFuc2FjdGlvbk5hbWUgPSBuYW1lO1xuICAgIHRoaXMuX25vdGlmeVNjb3BlTGlzdGVuZXJzKCk7XG4gICAgcmV0dXJuIHRoaXM7XG4gIH1cblxuICAvKipcbiAgICogU2V0cyBjb250ZXh0IGRhdGEgd2l0aCB0aGUgZ2l2ZW4gbmFtZS5cbiAgICogRGF0YSBwYXNzZWQgYXMgY29udGV4dCB3aWxsIGJlIG5vcm1hbGl6ZWQuIFlvdSBjYW4gYWxzbyBwYXNzIGBudWxsYCB0byB1bnNldCB0aGUgY29udGV4dC5cbiAgICogTm90ZSB0aGF0IGNvbnRleHQgZGF0YSB3aWxsIG5vdCBiZSBtZXJnZWQgLSBjYWxsaW5nIGBzZXRDb250ZXh0YCB3aWxsIG92ZXJ3cml0ZSBhbiBleGlzdGluZyBjb250ZXh0IHdpdGggdGhlIHNhbWUga2V5LlxuICAgKi9cbiAgIHNldENvbnRleHQoa2V5LCBjb250ZXh0KSB7XG4gICAgaWYgKGNvbnRleHQgPT09IG51bGwpIHtcbiAgICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tZHluYW1pYy1kZWxldGVcbiAgICAgIGRlbGV0ZSB0aGlzLl9jb250ZXh0c1trZXldO1xuICAgIH0gZWxzZSB7XG4gICAgICB0aGlzLl9jb250ZXh0c1trZXldID0gY29udGV4dDtcbiAgICB9XG5cbiAgICB0aGlzLl9ub3RpZnlTY29wZUxpc3RlbmVycygpO1xuICAgIHJldHVybiB0aGlzO1xuICB9XG5cbiAgLyoqXG4gICAqIFNldCB0aGUgc2Vzc2lvbiBmb3IgdGhlIHNjb3BlLlxuICAgKi9cbiAgIHNldFNlc3Npb24oc2Vzc2lvbikge1xuICAgIGlmICghc2Vzc2lvbikge1xuICAgICAgZGVsZXRlIHRoaXMuX3Nlc3Npb247XG4gICAgfSBlbHNlIHtcbiAgICAgIHRoaXMuX3Nlc3Npb24gPSBzZXNzaW9uO1xuICAgIH1cbiAgICB0aGlzLl9ub3RpZnlTY29wZUxpc3RlbmVycygpO1xuICAgIHJldHVybiB0aGlzO1xuICB9XG5cbiAgLyoqXG4gICAqIEdldCB0aGUgc2Vzc2lvbiBmcm9tIHRoZSBzY29wZS5cbiAgICovXG4gICBnZXRTZXNzaW9uKCkge1xuICAgIHJldHVybiB0aGlzLl9zZXNzaW9uO1xuICB9XG5cbiAgLyoqXG4gICAqIFVwZGF0ZXMgdGhlIHNjb3BlIHdpdGggcHJvdmlkZWQgZGF0YS4gQ2FuIHdvcmsgaW4gdGhyZWUgdmFyaWF0aW9uczpcbiAgICogLSBwbGFpbiBvYmplY3QgY29udGFpbmluZyB1cGRhdGFibGUgYXR0cmlidXRlc1xuICAgKiAtIFNjb3BlIGluc3RhbmNlIHRoYXQnbGwgZXh0cmFjdCB0aGUgYXR0cmlidXRlcyBmcm9tXG4gICAqIC0gY2FsbGJhY2sgZnVuY3Rpb24gdGhhdCdsbCByZWNlaXZlIHRoZSBjdXJyZW50IHNjb3BlIGFzIGFuIGFyZ3VtZW50IGFuZCBhbGxvdyBmb3IgbW9kaWZpY2F0aW9uc1xuICAgKi9cbiAgIHVwZGF0ZShjYXB0dXJlQ29udGV4dCkge1xuICAgIGlmICghY2FwdHVyZUNvbnRleHQpIHtcbiAgICAgIHJldHVybiB0aGlzO1xuICAgIH1cblxuICAgIGNvbnN0IHNjb3BlVG9NZXJnZSA9IHR5cGVvZiBjYXB0dXJlQ29udGV4dCA9PT0gJ2Z1bmN0aW9uJyA/IGNhcHR1cmVDb250ZXh0KHRoaXMpIDogY2FwdHVyZUNvbnRleHQ7XG5cbiAgICBjb25zdCBzY29wZUluc3RhbmNlID1cbiAgICAgIHNjb3BlVG9NZXJnZSBpbnN0YW5jZW9mIFNjb3BlXG4gICAgICAgID8gc2NvcGVUb01lcmdlLmdldFNjb3BlRGF0YSgpXG4gICAgICAgIDogaXMuaXNQbGFpbk9iamVjdChzY29wZVRvTWVyZ2UpXG4gICAgICAgICAgPyAoY2FwdHVyZUNvbnRleHQgKVxuICAgICAgICAgIDogdW5kZWZpbmVkO1xuXG4gICAgY29uc3QgeyB0YWdzLCBleHRyYSwgdXNlciwgY29udGV4dHMsIGxldmVsLCBmaW5nZXJwcmludCA9IFtdLCBwcm9wYWdhdGlvbkNvbnRleHQgfSA9IHNjb3BlSW5zdGFuY2UgfHwge307XG5cbiAgICB0aGlzLl90YWdzID0geyAuLi50aGlzLl90YWdzLCAuLi50YWdzIH07XG4gICAgdGhpcy5fZXh0cmEgPSB7IC4uLnRoaXMuX2V4dHJhLCAuLi5leHRyYSB9O1xuICAgIHRoaXMuX2NvbnRleHRzID0geyAuLi50aGlzLl9jb250ZXh0cywgLi4uY29udGV4dHMgfTtcblxuICAgIGlmICh1c2VyICYmIE9iamVjdC5rZXlzKHVzZXIpLmxlbmd0aCkge1xuICAgICAgdGhpcy5fdXNlciA9IHVzZXI7XG4gICAgfVxuXG4gICAgaWYgKGxldmVsKSB7XG4gICAgICB0aGlzLl9sZXZlbCA9IGxldmVsO1xuICAgIH1cblxuICAgIGlmIChmaW5nZXJwcmludC5sZW5ndGgpIHtcbiAgICAgIHRoaXMuX2ZpbmdlcnByaW50ID0gZmluZ2VycHJpbnQ7XG4gICAgfVxuXG4gICAgaWYgKHByb3BhZ2F0aW9uQ29udGV4dCkge1xuICAgICAgdGhpcy5fcHJvcGFnYXRpb25Db250ZXh0ID0gcHJvcGFnYXRpb25Db250ZXh0O1xuICAgIH1cblxuICAgIHJldHVybiB0aGlzO1xuICB9XG5cbiAgLyoqXG4gICAqIENsZWFycyB0aGUgY3VycmVudCBzY29wZSBhbmQgcmVzZXRzIGl0cyBwcm9wZXJ0aWVzLlxuICAgKiBOb3RlOiBUaGUgY2xpZW50IHdpbGwgbm90IGJlIGNsZWFyZWQuXG4gICAqL1xuICAgY2xlYXIoKSB7XG4gICAgLy8gY2xpZW50IGlzIG5vdCBjbGVhcmVkIGhlcmUgb24gcHVycG9zZSFcbiAgICB0aGlzLl9icmVhZGNydW1icyA9IFtdO1xuICAgIHRoaXMuX3RhZ3MgPSB7fTtcbiAgICB0aGlzLl9leHRyYSA9IHt9O1xuICAgIHRoaXMuX3VzZXIgPSB7fTtcbiAgICB0aGlzLl9jb250ZXh0cyA9IHt9O1xuICAgIHRoaXMuX2xldmVsID0gdW5kZWZpbmVkO1xuICAgIHRoaXMuX3RyYW5zYWN0aW9uTmFtZSA9IHVuZGVmaW5lZDtcbiAgICB0aGlzLl9maW5nZXJwcmludCA9IHVuZGVmaW5lZDtcbiAgICB0aGlzLl9zZXNzaW9uID0gdW5kZWZpbmVkO1xuICAgIHNwYW5PblNjb3BlLl9zZXRTcGFuRm9yU2NvcGUodGhpcywgdW5kZWZpbmVkKTtcbiAgICB0aGlzLl9hdHRhY2htZW50cyA9IFtdO1xuICAgIHRoaXMuc2V0UHJvcGFnYXRpb25Db250ZXh0KHsgdHJhY2VJZDogcHJvcGFnYXRpb25Db250ZXh0LmdlbmVyYXRlVHJhY2VJZCgpLCBzYW1wbGVSYW5kOiBNYXRoLnJhbmRvbSgpIH0pO1xuXG4gICAgdGhpcy5fbm90aWZ5U2NvcGVMaXN0ZW5lcnMoKTtcbiAgICByZXR1cm4gdGhpcztcbiAgfVxuXG4gIC8qKlxuICAgKiBBZGRzIGEgYnJlYWRjcnVtYiB0byB0aGUgc2NvcGUuXG4gICAqIEJ5IGRlZmF1bHQsIHRoZSBsYXN0IDEwMCBicmVhZGNydW1icyBhcmUga2VwdC5cbiAgICovXG4gICBhZGRCcmVhZGNydW1iKGJyZWFkY3J1bWIsIG1heEJyZWFkY3J1bWJzKSB7XG4gICAgY29uc3QgbWF4Q3J1bWJzID0gdHlwZW9mIG1heEJyZWFkY3J1bWJzID09PSAnbnVtYmVyJyA/IG1heEJyZWFkY3J1bWJzIDogREVGQVVMVF9NQVhfQlJFQURDUlVNQlM7XG5cbiAgICAvLyBObyBkYXRhIGhhcyBiZWVuIGNoYW5nZWQsIHNvIGRvbid0IG5vdGlmeSBzY29wZSBsaXN0ZW5lcnNcbiAgICBpZiAobWF4Q3J1bWJzIDw9IDApIHtcbiAgICAgIHJldHVybiB0aGlzO1xuICAgIH1cblxuICAgIGNvbnN0IG1lcmdlZEJyZWFkY3J1bWIgPSB7XG4gICAgICB0aW1lc3RhbXA6IHRpbWUuZGF0ZVRpbWVzdGFtcEluU2Vjb25kcygpLFxuICAgICAgLi4uYnJlYWRjcnVtYixcbiAgICAgIC8vIEJyZWFkY3J1bWIgbWVzc2FnZXMgY2FuIHRoZW9yZXRpY2FsbHkgYmUgaW5maW5pdGVseSBsYXJnZSBhbmQgdGhleSdyZSBoZWxkIGluIG1lbW9yeSBzbyB3ZSB0cnVuY2F0ZSB0aGVtIG5vdCB0byBsZWFrICh0b28gbXVjaCkgbWVtb3J5XG4gICAgICBtZXNzYWdlOiBicmVhZGNydW1iLm1lc3NhZ2UgPyBzdHJpbmcudHJ1bmNhdGUoYnJlYWRjcnVtYi5tZXNzYWdlLCAyMDQ4KSA6IGJyZWFkY3J1bWIubWVzc2FnZSxcbiAgICB9O1xuXG4gICAgdGhpcy5fYnJlYWRjcnVtYnMucHVzaChtZXJnZWRCcmVhZGNydW1iKTtcbiAgICBpZiAodGhpcy5fYnJlYWRjcnVtYnMubGVuZ3RoID4gbWF4Q3J1bWJzKSB7XG4gICAgICB0aGlzLl9icmVhZGNydW1icyA9IHRoaXMuX2JyZWFkY3J1bWJzLnNsaWNlKC1tYXhDcnVtYnMpO1xuICAgICAgdGhpcy5fY2xpZW50Py5yZWNvcmREcm9wcGVkRXZlbnQoJ2J1ZmZlcl9vdmVyZmxvdycsICdsb2dfaXRlbScpO1xuICAgIH1cblxuICAgIHRoaXMuX25vdGlmeVNjb3BlTGlzdGVuZXJzKCk7XG5cbiAgICByZXR1cm4gdGhpcztcbiAgfVxuXG4gIC8qKlxuICAgKiBHZXQgdGhlIGxhc3QgYnJlYWRjcnVtYiBvZiB0aGUgc2NvcGUuXG4gICAqL1xuICAgZ2V0TGFzdEJyZWFkY3J1bWIoKSB7XG4gICAgcmV0dXJuIHRoaXMuX2JyZWFkY3J1bWJzW3RoaXMuX2JyZWFkY3J1bWJzLmxlbmd0aCAtIDFdO1xuICB9XG5cbiAgLyoqXG4gICAqIENsZWFyIGFsbCBicmVhZGNydW1icyBmcm9tIHRoZSBzY29wZS5cbiAgICovXG4gICBjbGVhckJyZWFkY3J1bWJzKCkge1xuICAgIHRoaXMuX2JyZWFkY3J1bWJzID0gW107XG4gICAgdGhpcy5fbm90aWZ5U2NvcGVMaXN0ZW5lcnMoKTtcbiAgICByZXR1cm4gdGhpcztcbiAgfVxuXG4gIC8qKlxuICAgKiBBZGQgYW4gYXR0YWNobWVudCB0byB0aGUgc2NvcGUuXG4gICAqL1xuICAgYWRkQXR0YWNobWVudChhdHRhY2htZW50KSB7XG4gICAgdGhpcy5fYXR0YWNobWVudHMucHVzaChhdHRhY2htZW50KTtcbiAgICByZXR1cm4gdGhpcztcbiAgfVxuXG4gIC8qKlxuICAgKiBDbGVhciBhbGwgYXR0YWNobWVudHMgZnJvbSB0aGUgc2NvcGUuXG4gICAqL1xuICAgY2xlYXJBdHRhY2htZW50cygpIHtcbiAgICB0aGlzLl9hdHRhY2htZW50cyA9IFtdO1xuICAgIHJldHVybiB0aGlzO1xuICB9XG5cbiAgLyoqXG4gICAqIEdldCB0aGUgZGF0YSBvZiB0aGlzIHNjb3BlLCB3aGljaCBzaG91bGQgYmUgYXBwbGllZCB0byBhbiBldmVudCBkdXJpbmcgcHJvY2Vzc2luZy5cbiAgICovXG4gICBnZXRTY29wZURhdGEoKSB7XG4gICAgcmV0dXJuIHtcbiAgICAgIGJyZWFkY3J1bWJzOiB0aGlzLl9icmVhZGNydW1icyxcbiAgICAgIGF0dGFjaG1lbnRzOiB0aGlzLl9hdHRhY2htZW50cyxcbiAgICAgIGNvbnRleHRzOiB0aGlzLl9jb250ZXh0cyxcbiAgICAgIHRhZ3M6IHRoaXMuX3RhZ3MsXG4gICAgICBleHRyYTogdGhpcy5fZXh0cmEsXG4gICAgICB1c2VyOiB0aGlzLl91c2VyLFxuICAgICAgbGV2ZWw6IHRoaXMuX2xldmVsLFxuICAgICAgZmluZ2VycHJpbnQ6IHRoaXMuX2ZpbmdlcnByaW50IHx8IFtdLFxuICAgICAgZXZlbnRQcm9jZXNzb3JzOiB0aGlzLl9ldmVudFByb2Nlc3NvcnMsXG4gICAgICBwcm9wYWdhdGlvbkNvbnRleHQ6IHRoaXMuX3Byb3BhZ2F0aW9uQ29udGV4dCxcbiAgICAgIHNka1Byb2Nlc3NpbmdNZXRhZGF0YTogdGhpcy5fc2RrUHJvY2Vzc2luZ01ldGFkYXRhLFxuICAgICAgdHJhbnNhY3Rpb25OYW1lOiB0aGlzLl90cmFuc2FjdGlvbk5hbWUsXG4gICAgICBzcGFuOiBzcGFuT25TY29wZS5fZ2V0U3BhbkZvclNjb3BlKHRoaXMpLFxuICAgIH07XG4gIH1cblxuICAvKipcbiAgICogQWRkIGRhdGEgd2hpY2ggd2lsbCBiZSBhY2Nlc3NpYmxlIGR1cmluZyBldmVudCBwcm9jZXNzaW5nIGJ1dCB3b24ndCBnZXQgc2VudCB0byBTZW50cnkuXG4gICAqL1xuICAgc2V0U0RLUHJvY2Vzc2luZ01ldGFkYXRhKG5ld0RhdGEpIHtcbiAgICB0aGlzLl9zZGtQcm9jZXNzaW5nTWV0YWRhdGEgPSBtZXJnZS5tZXJnZSh0aGlzLl9zZGtQcm9jZXNzaW5nTWV0YWRhdGEsIG5ld0RhdGEsIDIpO1xuICAgIHJldHVybiB0aGlzO1xuICB9XG5cbiAgLyoqXG4gICAqIEFkZCBwcm9wYWdhdGlvbiBjb250ZXh0IHRvIHRoZSBzY29wZSwgdXNlZCBmb3IgZGlzdHJpYnV0ZWQgdHJhY2luZ1xuICAgKi9cbiAgIHNldFByb3BhZ2F0aW9uQ29udGV4dChjb250ZXh0KSB7XG4gICAgdGhpcy5fcHJvcGFnYXRpb25Db250ZXh0ID0gY29udGV4dDtcbiAgICByZXR1cm4gdGhpcztcbiAgfVxuXG4gIC8qKlxuICAgKiBHZXQgcHJvcGFnYXRpb24gY29udGV4dCBmcm9tIHRoZSBzY29wZSwgdXNlZCBmb3IgZGlzdHJpYnV0ZWQgdHJhY2luZ1xuICAgKi9cbiAgIGdldFByb3BhZ2F0aW9uQ29udGV4dCgpIHtcbiAgICByZXR1cm4gdGhpcy5fcHJvcGFnYXRpb25Db250ZXh0O1xuICB9XG5cbiAgLyoqXG4gICAqIENhcHR1cmUgYW4gZXhjZXB0aW9uIGZvciB0aGlzIHNjb3BlLlxuICAgKlxuICAgKiBAcmV0dXJucyB7c3RyaW5nfSBUaGUgaWQgb2YgdGhlIGNhcHR1cmVkIFNlbnRyeSBldmVudC5cbiAgICovXG4gICBjYXB0dXJlRXhjZXB0aW9uKGV4Y2VwdGlvbiwgaGludCkge1xuICAgIGNvbnN0IGV2ZW50SWQgPSBoaW50Py5ldmVudF9pZCB8fCBtaXNjLnV1aWQ0KCk7XG5cbiAgICBpZiAoIXRoaXMuX2NsaWVudCkge1xuICAgICAgZGVidWdCdWlsZC5ERUJVR19CVUlMRCAmJiBkZWJ1Z0xvZ2dlci5kZWJ1Zy53YXJuKCdObyBjbGllbnQgY29uZmlndXJlZCBvbiBzY29wZSAtIHdpbGwgbm90IGNhcHR1cmUgZXhjZXB0aW9uIScpO1xuICAgICAgcmV0dXJuIGV2ZW50SWQ7XG4gICAgfVxuXG4gICAgY29uc3Qgc3ludGhldGljRXhjZXB0aW9uID0gbmV3IEVycm9yKCdTZW50cnkgc3ludGhldGljRXhjZXB0aW9uJyk7XG5cbiAgICB0aGlzLl9jbGllbnQuY2FwdHVyZUV4Y2VwdGlvbihcbiAgICAgIGV4Y2VwdGlvbixcbiAgICAgIHtcbiAgICAgICAgb3JpZ2luYWxFeGNlcHRpb246IGV4Y2VwdGlvbixcbiAgICAgICAgc3ludGhldGljRXhjZXB0aW9uLFxuICAgICAgICAuLi5oaW50LFxuICAgICAgICBldmVudF9pZDogZXZlbnRJZCxcbiAgICAgIH0sXG4gICAgICB0aGlzLFxuICAgICk7XG5cbiAgICByZXR1cm4gZXZlbnRJZDtcbiAgfVxuXG4gIC8qKlxuICAgKiBDYXB0dXJlIGEgbWVzc2FnZSBmb3IgdGhpcyBzY29wZS5cbiAgICpcbiAgICogQHJldHVybnMge3N0cmluZ30gVGhlIGlkIG9mIHRoZSBjYXB0dXJlZCBtZXNzYWdlLlxuICAgKi9cbiAgIGNhcHR1cmVNZXNzYWdlKG1lc3NhZ2UsIGxldmVsLCBoaW50KSB7XG4gICAgY29uc3QgZXZlbnRJZCA9IGhpbnQ/LmV2ZW50X2lkIHx8IG1pc2MudXVpZDQoKTtcblxuICAgIGlmICghdGhpcy5fY2xpZW50KSB7XG4gICAgICBkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEICYmIGRlYnVnTG9nZ2VyLmRlYnVnLndhcm4oJ05vIGNsaWVudCBjb25maWd1cmVkIG9uIHNjb3BlIC0gd2lsbCBub3QgY2FwdHVyZSBtZXNzYWdlIScpO1xuICAgICAgcmV0dXJuIGV2ZW50SWQ7XG4gICAgfVxuXG4gICAgY29uc3Qgc3ludGhldGljRXhjZXB0aW9uID0gbmV3IEVycm9yKG1lc3NhZ2UpO1xuXG4gICAgdGhpcy5fY2xpZW50LmNhcHR1cmVNZXNzYWdlKFxuICAgICAgbWVzc2FnZSxcbiAgICAgIGxldmVsLFxuICAgICAge1xuICAgICAgICBvcmlnaW5hbEV4Y2VwdGlvbjogbWVzc2FnZSxcbiAgICAgICAgc3ludGhldGljRXhjZXB0aW9uLFxuICAgICAgICAuLi5oaW50LFxuICAgICAgICBldmVudF9pZDogZXZlbnRJZCxcbiAgICAgIH0sXG4gICAgICB0aGlzLFxuICAgICk7XG5cbiAgICByZXR1cm4gZXZlbnRJZDtcbiAgfVxuXG4gIC8qKlxuICAgKiBDYXB0dXJlIGEgU2VudHJ5IGV2ZW50IGZvciB0aGlzIHNjb3BlLlxuICAgKlxuICAgKiBAcmV0dXJucyB7c3RyaW5nfSBUaGUgaWQgb2YgdGhlIGNhcHR1cmVkIGV2ZW50LlxuICAgKi9cbiAgIGNhcHR1cmVFdmVudChldmVudCwgaGludCkge1xuICAgIGNvbnN0IGV2ZW50SWQgPSBoaW50Py5ldmVudF9pZCB8fCBtaXNjLnV1aWQ0KCk7XG5cbiAgICBpZiAoIXRoaXMuX2NsaWVudCkge1xuICAgICAgZGVidWdCdWlsZC5ERUJVR19CVUlMRCAmJiBkZWJ1Z0xvZ2dlci5kZWJ1Zy53YXJuKCdObyBjbGllbnQgY29uZmlndXJlZCBvbiBzY29wZSAtIHdpbGwgbm90IGNhcHR1cmUgZXZlbnQhJyk7XG4gICAgICByZXR1cm4gZXZlbnRJZDtcbiAgICB9XG5cbiAgICB0aGlzLl9jbGllbnQuY2FwdHVyZUV2ZW50KGV2ZW50LCB7IC4uLmhpbnQsIGV2ZW50X2lkOiBldmVudElkIH0sIHRoaXMpO1xuXG4gICAgcmV0dXJuIGV2ZW50SWQ7XG4gIH1cblxuICAvKipcbiAgICogVGhpcyB3aWxsIGJlIGNhbGxlZCBvbiBldmVyeSBzZXQgY2FsbC5cbiAgICovXG4gICBfbm90aWZ5U2NvcGVMaXN0ZW5lcnMoKSB7XG4gICAgLy8gV2UgbmVlZCB0aGlzIGNoZWNrIGZvciB0aGlzLl9ub3RpZnlpbmdMaXN0ZW5lcnMgdG8gYmUgYWJsZSB0byB3b3JrIG9uIHNjb3BlIGR1cmluZyB1cGRhdGVzXG4gICAgLy8gSWYgdGhpcyBjaGVjayBpcyBub3QgaGVyZSB3ZSdsbCBwcm9kdWNlIGVuZGxlc3MgcmVjdXJzaW9uIHdoZW4gc29tZXRoaW5nIGlzIGRvbmUgd2l0aCB0aGUgc2NvcGVcbiAgICAvLyBkdXJpbmcgdGhlIGNhbGxiYWNrLlxuICAgIGlmICghdGhpcy5fbm90aWZ5aW5nTGlzdGVuZXJzKSB7XG4gICAgICB0aGlzLl9ub3RpZnlpbmdMaXN0ZW5lcnMgPSB0cnVlO1xuICAgICAgdGhpcy5fc2NvcGVMaXN0ZW5lcnMuZm9yRWFjaChjYWxsYmFjayA9PiB7XG4gICAgICAgIGNhbGxiYWNrKHRoaXMpO1xuICAgICAgfSk7XG4gICAgICB0aGlzLl9ub3RpZnlpbmdMaXN0ZW5lcnMgPSBmYWxzZTtcbiAgICB9XG4gIH1cbn1cblxuZXhwb3J0cy5TY29wZSA9IFNjb3BlO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9c2NvcGUuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/scope.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/sdk.js":
/*!*******************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/sdk.js ***!
  \*******************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst currentScopes = __webpack_require__(/*! ./currentScopes.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst debugBuild = __webpack_require__(/*! ./debug-build.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst debugLogger = __webpack_require__(/*! ./utils/debug-logger.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\n\n/** A class object that can instantiate Client objects. */\n\n/**\n * Internal function to create a new SDK client instance. The client is\n * installed and then bound to the current scope.\n *\n * @param clientClass The client class to instantiate.\n * @param options Options to pass to the client.\n */\nfunction initAndBind(\n  clientClass,\n  options,\n) {\n  if (options.debug === true) {\n    if (debugBuild.DEBUG_BUILD) {\n      debugLogger.debug.enable();\n    } else {\n      // use `console.warn` rather than `debug.warn` since by non-debug bundles have all `debug.x` statements stripped\n      debugLogger.consoleSandbox(() => {\n        // eslint-disable-next-line no-console\n        console.warn('[Sentry] Cannot initialize SDK with `debug` option using a non-debug bundle.');\n      });\n    }\n  }\n  const scope = currentScopes.getCurrentScope();\n  scope.update(options.initialScope);\n\n  const client = new clientClass(options);\n  setCurrentClient(client);\n  client.init();\n  return client;\n}\n\n/**\n * Make the given client the current client.\n */\nfunction setCurrentClient(client) {\n  currentScopes.getCurrentScope().setClient(client);\n}\n\nexports.initAndBind = initAndBind;\nexports.setCurrentClient = setCurrentClient;\n//# sourceMappingURL=sdk.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9zZGsuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsc0JBQXNCLG1CQUFPLENBQUMsK0hBQW9CO0FBQ2xELG1CQUFtQixtQkFBTyxDQUFDLDJIQUFrQjtBQUM3QyxvQkFBb0IsbUJBQU8sQ0FBQyx5SUFBeUI7O0FBRXJEOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxNQUFNO0FBQ047QUFDQTtBQUNBO0FBQ0E7QUFDQSxPQUFPO0FBQ1A7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsbUJBQW1CO0FBQ25CLHdCQUF3QjtBQUN4QiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3Nkay5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgY3VycmVudFNjb3BlcyA9IHJlcXVpcmUoJy4vY3VycmVudFNjb3Blcy5qcycpO1xuY29uc3QgZGVidWdCdWlsZCA9IHJlcXVpcmUoJy4vZGVidWctYnVpbGQuanMnKTtcbmNvbnN0IGRlYnVnTG9nZ2VyID0gcmVxdWlyZSgnLi91dGlscy9kZWJ1Zy1sb2dnZXIuanMnKTtcblxuLyoqIEEgY2xhc3Mgb2JqZWN0IHRoYXQgY2FuIGluc3RhbnRpYXRlIENsaWVudCBvYmplY3RzLiAqL1xuXG4vKipcbiAqIEludGVybmFsIGZ1bmN0aW9uIHRvIGNyZWF0ZSBhIG5ldyBTREsgY2xpZW50IGluc3RhbmNlLiBUaGUgY2xpZW50IGlzXG4gKiBpbnN0YWxsZWQgYW5kIHRoZW4gYm91bmQgdG8gdGhlIGN1cnJlbnQgc2NvcGUuXG4gKlxuICogQHBhcmFtIGNsaWVudENsYXNzIFRoZSBjbGllbnQgY2xhc3MgdG8gaW5zdGFudGlhdGUuXG4gKiBAcGFyYW0gb3B0aW9ucyBPcHRpb25zIHRvIHBhc3MgdG8gdGhlIGNsaWVudC5cbiAqL1xuZnVuY3Rpb24gaW5pdEFuZEJpbmQoXG4gIGNsaWVudENsYXNzLFxuICBvcHRpb25zLFxuKSB7XG4gIGlmIChvcHRpb25zLmRlYnVnID09PSB0cnVlKSB7XG4gICAgaWYgKGRlYnVnQnVpbGQuREVCVUdfQlVJTEQpIHtcbiAgICAgIGRlYnVnTG9nZ2VyLmRlYnVnLmVuYWJsZSgpO1xuICAgIH0gZWxzZSB7XG4gICAgICAvLyB1c2UgYGNvbnNvbGUud2FybmAgcmF0aGVyIHRoYW4gYGRlYnVnLndhcm5gIHNpbmNlIGJ5IG5vbi1kZWJ1ZyBidW5kbGVzIGhhdmUgYWxsIGBkZWJ1Zy54YCBzdGF0ZW1lbnRzIHN0cmlwcGVkXG4gICAgICBkZWJ1Z0xvZ2dlci5jb25zb2xlU2FuZGJveCgoKSA9PiB7XG4gICAgICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBuby1jb25zb2xlXG4gICAgICAgIGNvbnNvbGUud2FybignW1NlbnRyeV0gQ2Fubm90IGluaXRpYWxpemUgU0RLIHdpdGggYGRlYnVnYCBvcHRpb24gdXNpbmcgYSBub24tZGVidWcgYnVuZGxlLicpO1xuICAgICAgfSk7XG4gICAgfVxuICB9XG4gIGNvbnN0IHNjb3BlID0gY3VycmVudFNjb3Blcy5nZXRDdXJyZW50U2NvcGUoKTtcbiAgc2NvcGUudXBkYXRlKG9wdGlvbnMuaW5pdGlhbFNjb3BlKTtcblxuICBjb25zdCBjbGllbnQgPSBuZXcgY2xpZW50Q2xhc3Mob3B0aW9ucyk7XG4gIHNldEN1cnJlbnRDbGllbnQoY2xpZW50KTtcbiAgY2xpZW50LmluaXQoKTtcbiAgcmV0dXJuIGNsaWVudDtcbn1cblxuLyoqXG4gKiBNYWtlIHRoZSBnaXZlbiBjbGllbnQgdGhlIGN1cnJlbnQgY2xpZW50LlxuICovXG5mdW5jdGlvbiBzZXRDdXJyZW50Q2xpZW50KGNsaWVudCkge1xuICBjdXJyZW50U2NvcGVzLmdldEN1cnJlbnRTY29wZSgpLnNldENsaWVudChjbGllbnQpO1xufVxuXG5leHBvcnRzLmluaXRBbmRCaW5kID0gaW5pdEFuZEJpbmQ7XG5leHBvcnRzLnNldEN1cnJlbnRDbGllbnQgPSBzZXRDdXJyZW50Q2xpZW50O1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9c2RrLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/sdk.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/semanticAttributes.js":
/*!**********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/semanticAttributes.js ***!
  \**********************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n/**\n * Use this attribute to represent the source of a span.\n * Should be one of: custom, url, route, view, component, task, unknown\n *\n */\nconst SEMANTIC_ATTRIBUTE_SENTRY_SOURCE = 'sentry.source';\n\n/**\n * Attributes that holds the sample rate that was locally applied to a span.\n * If this attribute is not defined, it means that the span inherited a sampling decision.\n *\n * NOTE: Is only defined on root spans.\n */\nconst SEMANTIC_ATTRIBUTE_SENTRY_SAMPLE_RATE = 'sentry.sample_rate';\n\n/**\n * Attribute holding the sample rate of the previous trace.\n * This is used to sample consistently across subsequent traces in the browser SDK.\n *\n * Note: Only defined on root spans, if opted into consistent sampling\n */\nconst SEMANTIC_ATTRIBUTE_SENTRY_PREVIOUS_TRACE_SAMPLE_RATE = 'sentry.previous_trace_sample_rate';\n\n/**\n * Use this attribute to represent the operation of a span.\n */\nconst SEMANTIC_ATTRIBUTE_SENTRY_OP = 'sentry.op';\n\n/**\n * Use this attribute to represent the origin of a span.\n */\nconst SEMANTIC_ATTRIBUTE_SENTRY_ORIGIN = 'sentry.origin';\n\n/** The reason why an idle span finished. */\nconst SEMANTIC_ATTRIBUTE_SENTRY_IDLE_SPAN_FINISH_REASON = 'sentry.idle_span_finish_reason';\n\n/** The unit of a measurement, which may be stored as a TimedEvent. */\nconst SEMANTIC_ATTRIBUTE_SENTRY_MEASUREMENT_UNIT = 'sentry.measurement_unit';\n\n/** The value of a measurement, which may be stored as a TimedEvent. */\nconst SEMANTIC_ATTRIBUTE_SENTRY_MEASUREMENT_VALUE = 'sentry.measurement_value';\n\n/**\n * A custom span name set by users guaranteed to be taken over any automatically\n * inferred name. This attribute is removed before the span is sent.\n *\n * @internal only meant for internal SDK usage\n * @hidden\n */\nconst SEMANTIC_ATTRIBUTE_SENTRY_CUSTOM_SPAN_NAME = 'sentry.custom_span_name';\n\n/**\n * The id of the profile that this span occurred in.\n */\nconst SEMANTIC_ATTRIBUTE_PROFILE_ID = 'sentry.profile_id';\n\nconst SEMANTIC_ATTRIBUTE_EXCLUSIVE_TIME = 'sentry.exclusive_time';\n\nconst SEMANTIC_ATTRIBUTE_CACHE_HIT = 'cache.hit';\n\nconst SEMANTIC_ATTRIBUTE_CACHE_KEY = 'cache.key';\n\nconst SEMANTIC_ATTRIBUTE_CACHE_ITEM_SIZE = 'cache.item_size';\n\n/** TODO: Remove these once we update to latest semantic conventions */\nconst SEMANTIC_ATTRIBUTE_HTTP_REQUEST_METHOD = 'http.request.method';\nconst SEMANTIC_ATTRIBUTE_URL_FULL = 'url.full';\n\n/**\n * A span link attribute to mark the link as a special span link.\n *\n * Known values:\n * - `previous_trace`: The span links to the frontend root span of the previous trace.\n * - `next_trace`: The span links to the frontend root span of the next trace. (Not set by the SDK)\n *\n * Other values may be set as appropriate.\n * @see https://develop.sentry.dev/sdk/telemetry/traces/span-links/#link-types\n */\nconst SEMANTIC_LINK_ATTRIBUTE_LINK_TYPE = 'sentry.link.type';\n\nexports.SEMANTIC_ATTRIBUTE_CACHE_HIT = SEMANTIC_ATTRIBUTE_CACHE_HIT;\nexports.SEMANTIC_ATTRIBUTE_CACHE_ITEM_SIZE = SEMANTIC_ATTRIBUTE_CACHE_ITEM_SIZE;\nexports.SEMANTIC_ATTRIBUTE_CACHE_KEY = SEMANTIC_ATTRIBUTE_CACHE_KEY;\nexports.SEMANTIC_ATTRIBUTE_EXCLUSIVE_TIME = SEMANTIC_ATTRIBUTE_EXCLUSIVE_TIME;\nexports.SEMANTIC_ATTRIBUTE_HTTP_REQUEST_METHOD = SEMANTIC_ATTRIBUTE_HTTP_REQUEST_METHOD;\nexports.SEMANTIC_ATTRIBUTE_PROFILE_ID = SEMANTIC_ATTRIBUTE_PROFILE_ID;\nexports.SEMANTIC_ATTRIBUTE_SENTRY_CUSTOM_SPAN_NAME = SEMANTIC_ATTRIBUTE_SENTRY_CUSTOM_SPAN_NAME;\nexports.SEMANTIC_ATTRIBUTE_SENTRY_IDLE_SPAN_FINISH_REASON = SEMANTIC_ATTRIBUTE_SENTRY_IDLE_SPAN_FINISH_REASON;\nexports.SEMANTIC_ATTRIBUTE_SENTRY_MEASUREMENT_UNIT = SEMANTIC_ATTRIBUTE_SENTRY_MEASUREMENT_UNIT;\nexports.SEMANTIC_ATTRIBUTE_SENTRY_MEASUREMENT_VALUE = SEMANTIC_ATTRIBUTE_SENTRY_MEASUREMENT_VALUE;\nexports.SEMANTIC_ATTRIBUTE_SENTRY_OP = SEMANTIC_ATTRIBUTE_SENTRY_OP;\nexports.SEMANTIC_ATTRIBUTE_SENTRY_ORIGIN = SEMANTIC_ATTRIBUTE_SENTRY_ORIGIN;\nexports.SEMANTIC_ATTRIBUTE_SENTRY_PREVIOUS_TRACE_SAMPLE_RATE = SEMANTIC_ATTRIBUTE_SENTRY_PREVIOUS_TRACE_SAMPLE_RATE;\nexports.SEMANTIC_ATTRIBUTE_SENTRY_SAMPLE_RATE = SEMANTIC_ATTRIBUTE_SENTRY_SAMPLE_RATE;\nexports.SEMANTIC_ATTRIBUTE_SENTRY_SOURCE = SEMANTIC_ATTRIBUTE_SENTRY_SOURCE;\nexports.SEMANTIC_ATTRIBUTE_URL_FULL = SEMANTIC_ATTRIBUTE_URL_FULL;\nexports.SEMANTIC_LINK_ATTRIBUTE_LINK_TYPE = SEMANTIC_LINK_ATTRIBUTE_LINK_TYPE;\n//# sourceMappingURL=semanticAttributes.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9zZW1hbnRpY0F0dHJpYnV0ZXMuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEU7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7O0FBRUE7O0FBRUE7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsb0NBQW9DO0FBQ3BDLDBDQUEwQztBQUMxQyxvQ0FBb0M7QUFDcEMseUNBQXlDO0FBQ3pDLDhDQUE4QztBQUM5QyxxQ0FBcUM7QUFDckMsa0RBQWtEO0FBQ2xELHlEQUF5RDtBQUN6RCxrREFBa0Q7QUFDbEQsbURBQW1EO0FBQ25ELG9DQUFvQztBQUNwQyx3Q0FBd0M7QUFDeEMsNERBQTREO0FBQzVELDZDQUE2QztBQUM3Qyx3Q0FBd0M7QUFDeEMsbUNBQW1DO0FBQ25DLHlDQUF5QztBQUN6QyIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3NlbWFudGljQXR0cmlidXRlcy5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuLyoqXG4gKiBVc2UgdGhpcyBhdHRyaWJ1dGUgdG8gcmVwcmVzZW50IHRoZSBzb3VyY2Ugb2YgYSBzcGFuLlxuICogU2hvdWxkIGJlIG9uZSBvZjogY3VzdG9tLCB1cmwsIHJvdXRlLCB2aWV3LCBjb21wb25lbnQsIHRhc2ssIHVua25vd25cbiAqXG4gKi9cbmNvbnN0IFNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfU09VUkNFID0gJ3NlbnRyeS5zb3VyY2UnO1xuXG4vKipcbiAqIEF0dHJpYnV0ZXMgdGhhdCBob2xkcyB0aGUgc2FtcGxlIHJhdGUgdGhhdCB3YXMgbG9jYWxseSBhcHBsaWVkIHRvIGEgc3Bhbi5cbiAqIElmIHRoaXMgYXR0cmlidXRlIGlzIG5vdCBkZWZpbmVkLCBpdCBtZWFucyB0aGF0IHRoZSBzcGFuIGluaGVyaXRlZCBhIHNhbXBsaW5nIGRlY2lzaW9uLlxuICpcbiAqIE5PVEU6IElzIG9ubHkgZGVmaW5lZCBvbiByb290IHNwYW5zLlxuICovXG5jb25zdCBTRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX1NBTVBMRV9SQVRFID0gJ3NlbnRyeS5zYW1wbGVfcmF0ZSc7XG5cbi8qKlxuICogQXR0cmlidXRlIGhvbGRpbmcgdGhlIHNhbXBsZSByYXRlIG9mIHRoZSBwcmV2aW91cyB0cmFjZS5cbiAqIFRoaXMgaXMgdXNlZCB0byBzYW1wbGUgY29uc2lzdGVudGx5IGFjcm9zcyBzdWJzZXF1ZW50IHRyYWNlcyBpbiB0aGUgYnJvd3NlciBTREsuXG4gKlxuICogTm90ZTogT25seSBkZWZpbmVkIG9uIHJvb3Qgc3BhbnMsIGlmIG9wdGVkIGludG8gY29uc2lzdGVudCBzYW1wbGluZ1xuICovXG5jb25zdCBTRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX1BSRVZJT1VTX1RSQUNFX1NBTVBMRV9SQVRFID0gJ3NlbnRyeS5wcmV2aW91c190cmFjZV9zYW1wbGVfcmF0ZSc7XG5cbi8qKlxuICogVXNlIHRoaXMgYXR0cmlidXRlIHRvIHJlcHJlc2VudCB0aGUgb3BlcmF0aW9uIG9mIGEgc3Bhbi5cbiAqL1xuY29uc3QgU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9PUCA9ICdzZW50cnkub3AnO1xuXG4vKipcbiAqIFVzZSB0aGlzIGF0dHJpYnV0ZSB0byByZXByZXNlbnQgdGhlIG9yaWdpbiBvZiBhIHNwYW4uXG4gKi9cbmNvbnN0IFNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfT1JJR0lOID0gJ3NlbnRyeS5vcmlnaW4nO1xuXG4vKiogVGhlIHJlYXNvbiB3aHkgYW4gaWRsZSBzcGFuIGZpbmlzaGVkLiAqL1xuY29uc3QgU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9JRExFX1NQQU5fRklOSVNIX1JFQVNPTiA9ICdzZW50cnkuaWRsZV9zcGFuX2ZpbmlzaF9yZWFzb24nO1xuXG4vKiogVGhlIHVuaXQgb2YgYSBtZWFzdXJlbWVudCwgd2hpY2ggbWF5IGJlIHN0b3JlZCBhcyBhIFRpbWVkRXZlbnQuICovXG5jb25zdCBTRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX01FQVNVUkVNRU5UX1VOSVQgPSAnc2VudHJ5Lm1lYXN1cmVtZW50X3VuaXQnO1xuXG4vKiogVGhlIHZhbHVlIG9mIGEgbWVhc3VyZW1lbnQsIHdoaWNoIG1heSBiZSBzdG9yZWQgYXMgYSBUaW1lZEV2ZW50LiAqL1xuY29uc3QgU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9NRUFTVVJFTUVOVF9WQUxVRSA9ICdzZW50cnkubWVhc3VyZW1lbnRfdmFsdWUnO1xuXG4vKipcbiAqIEEgY3VzdG9tIHNwYW4gbmFtZSBzZXQgYnkgdXNlcnMgZ3VhcmFudGVlZCB0byBiZSB0YWtlbiBvdmVyIGFueSBhdXRvbWF0aWNhbGx5XG4gKiBpbmZlcnJlZCBuYW1lLiBUaGlzIGF0dHJpYnV0ZSBpcyByZW1vdmVkIGJlZm9yZSB0aGUgc3BhbiBpcyBzZW50LlxuICpcbiAqIEBpbnRlcm5hbCBvbmx5IG1lYW50IGZvciBpbnRlcm5hbCBTREsgdXNhZ2VcbiAqIEBoaWRkZW5cbiAqL1xuY29uc3QgU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9DVVNUT01fU1BBTl9OQU1FID0gJ3NlbnRyeS5jdXN0b21fc3Bhbl9uYW1lJztcblxuLyoqXG4gKiBUaGUgaWQgb2YgdGhlIHByb2ZpbGUgdGhhdCB0aGlzIHNwYW4gb2NjdXJyZWQgaW4uXG4gKi9cbmNvbnN0IFNFTUFOVElDX0FUVFJJQlVURV9QUk9GSUxFX0lEID0gJ3NlbnRyeS5wcm9maWxlX2lkJztcblxuY29uc3QgU0VNQU5USUNfQVRUUklCVVRFX0VYQ0xVU0lWRV9USU1FID0gJ3NlbnRyeS5leGNsdXNpdmVfdGltZSc7XG5cbmNvbnN0IFNFTUFOVElDX0FUVFJJQlVURV9DQUNIRV9ISVQgPSAnY2FjaGUuaGl0JztcblxuY29uc3QgU0VNQU5USUNfQVRUUklCVVRFX0NBQ0hFX0tFWSA9ICdjYWNoZS5rZXknO1xuXG5jb25zdCBTRU1BTlRJQ19BVFRSSUJVVEVfQ0FDSEVfSVRFTV9TSVpFID0gJ2NhY2hlLml0ZW1fc2l6ZSc7XG5cbi8qKiBUT0RPOiBSZW1vdmUgdGhlc2Ugb25jZSB3ZSB1cGRhdGUgdG8gbGF0ZXN0IHNlbWFudGljIGNvbnZlbnRpb25zICovXG5jb25zdCBTRU1BTlRJQ19BVFRSSUJVVEVfSFRUUF9SRVFVRVNUX01FVEhPRCA9ICdodHRwLnJlcXVlc3QubWV0aG9kJztcbmNvbnN0IFNFTUFOVElDX0FUVFJJQlVURV9VUkxfRlVMTCA9ICd1cmwuZnVsbCc7XG5cbi8qKlxuICogQSBzcGFuIGxpbmsgYXR0cmlidXRlIHRvIG1hcmsgdGhlIGxpbmsgYXMgYSBzcGVjaWFsIHNwYW4gbGluay5cbiAqXG4gKiBLbm93biB2YWx1ZXM6XG4gKiAtIGBwcmV2aW91c190cmFjZWA6IFRoZSBzcGFuIGxpbmtzIHRvIHRoZSBmcm9udGVuZCByb290IHNwYW4gb2YgdGhlIHByZXZpb3VzIHRyYWNlLlxuICogLSBgbmV4dF90cmFjZWA6IFRoZSBzcGFuIGxpbmtzIHRvIHRoZSBmcm9udGVuZCByb290IHNwYW4gb2YgdGhlIG5leHQgdHJhY2UuIChOb3Qgc2V0IGJ5IHRoZSBTREspXG4gKlxuICogT3RoZXIgdmFsdWVzIG1heSBiZSBzZXQgYXMgYXBwcm9wcmlhdGUuXG4gKiBAc2VlIGh0dHBzOi8vZGV2ZWxvcC5zZW50cnkuZGV2L3Nkay90ZWxlbWV0cnkvdHJhY2VzL3NwYW4tbGlua3MvI2xpbmstdHlwZXNcbiAqL1xuY29uc3QgU0VNQU5USUNfTElOS19BVFRSSUJVVEVfTElOS19UWVBFID0gJ3NlbnRyeS5saW5rLnR5cGUnO1xuXG5leHBvcnRzLlNFTUFOVElDX0FUVFJJQlVURV9DQUNIRV9ISVQgPSBTRU1BTlRJQ19BVFRSSUJVVEVfQ0FDSEVfSElUO1xuZXhwb3J0cy5TRU1BTlRJQ19BVFRSSUJVVEVfQ0FDSEVfSVRFTV9TSVpFID0gU0VNQU5USUNfQVRUUklCVVRFX0NBQ0hFX0lURU1fU0laRTtcbmV4cG9ydHMuU0VNQU5USUNfQVRUUklCVVRFX0NBQ0hFX0tFWSA9IFNFTUFOVElDX0FUVFJJQlVURV9DQUNIRV9LRVk7XG5leHBvcnRzLlNFTUFOVElDX0FUVFJJQlVURV9FWENMVVNJVkVfVElNRSA9IFNFTUFOVElDX0FUVFJJQlVURV9FWENMVVNJVkVfVElNRTtcbmV4cG9ydHMuU0VNQU5USUNfQVRUUklCVVRFX0hUVFBfUkVRVUVTVF9NRVRIT0QgPSBTRU1BTlRJQ19BVFRSSUJVVEVfSFRUUF9SRVFVRVNUX01FVEhPRDtcbmV4cG9ydHMuU0VNQU5USUNfQVRUUklCVVRFX1BST0ZJTEVfSUQgPSBTRU1BTlRJQ19BVFRSSUJVVEVfUFJPRklMRV9JRDtcbmV4cG9ydHMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9DVVNUT01fU1BBTl9OQU1FID0gU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9DVVNUT01fU1BBTl9OQU1FO1xuZXhwb3J0cy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX0lETEVfU1BBTl9GSU5JU0hfUkVBU09OID0gU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9JRExFX1NQQU5fRklOSVNIX1JFQVNPTjtcbmV4cG9ydHMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9NRUFTVVJFTUVOVF9VTklUID0gU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9NRUFTVVJFTUVOVF9VTklUO1xuZXhwb3J0cy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX01FQVNVUkVNRU5UX1ZBTFVFID0gU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9NRUFTVVJFTUVOVF9WQUxVRTtcbmV4cG9ydHMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9PUCA9IFNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfT1A7XG5leHBvcnRzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfT1JJR0lOID0gU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9PUklHSU47XG5leHBvcnRzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfUFJFVklPVVNfVFJBQ0VfU0FNUExFX1JBVEUgPSBTRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX1BSRVZJT1VTX1RSQUNFX1NBTVBMRV9SQVRFO1xuZXhwb3J0cy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX1NBTVBMRV9SQVRFID0gU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9TQU1QTEVfUkFURTtcbmV4cG9ydHMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9TT1VSQ0UgPSBTRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX1NPVVJDRTtcbmV4cG9ydHMuU0VNQU5USUNfQVRUUklCVVRFX1VSTF9GVUxMID0gU0VNQU5USUNfQVRUUklCVVRFX1VSTF9GVUxMO1xuZXhwb3J0cy5TRU1BTlRJQ19MSU5LX0FUVFJJQlVURV9MSU5LX1RZUEUgPSBTRU1BTlRJQ19MSU5LX0FUVFJJQlVURV9MSU5LX1RZUEU7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1zZW1hbnRpY0F0dHJpYnV0ZXMuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/semanticAttributes.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/server-runtime-client.js":
/*!*************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/server-runtime-client.js ***!
  \*************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst checkin = __webpack_require__(/*! ./checkin.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/checkin.js\");\nconst client = __webpack_require__(/*! ./client.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/client.js\");\nconst currentScopes = __webpack_require__(/*! ./currentScopes.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst debugBuild = __webpack_require__(/*! ./debug-build.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst exports$1 = __webpack_require__(/*! ./logs/exports.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/logs/exports.js\");\nconst errors = __webpack_require__(/*! ./tracing/errors.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/errors.js\");\nconst is = __webpack_require__(/*! ./utils/is.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js\");\nconst debugLogger = __webpack_require__(/*! ./utils/debug-logger.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst misc = __webpack_require__(/*! ./utils/misc.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/misc.js\");\nconst eventbuilder = __webpack_require__(/*! ./utils/eventbuilder.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/eventbuilder.js\");\nconst syncpromise = __webpack_require__(/*! ./utils/syncpromise.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/syncpromise.js\");\n\n// TODO: Make this configurable\nconst DEFAULT_LOG_FLUSH_INTERVAL = 5000;\n\n/**\n * The Sentry Server Runtime Client SDK.\n */\nclass ServerRuntimeClient\n\n extends client.Client {\n\n  /**\n   * Creates a new Edge SDK instance.\n   * @param options Configuration options for this SDK.\n   */\n   constructor(options) {\n    // Server clients always support tracing\n    errors.registerSpanErrorInstrumentation();\n\n    super(options);\n\n    this._logWeight = 0;\n\n    // eslint-disable-next-line deprecation/deprecation\n    const shouldEnableLogs = this._options.enableLogs ?? this._options._experiments?.enableLogs;\n    if (shouldEnableLogs) {\n      // eslint-disable-next-line @typescript-eslint/no-this-alias\n      const client = this;\n\n      client.on('flushLogs', () => {\n        client._logWeight = 0;\n        clearTimeout(client._logFlushIdleTimeout);\n      });\n\n      client.on('afterCaptureLog', log => {\n        client._logWeight += estimateLogSizeInBytes(log);\n\n        // We flush the logs buffer if it exceeds 0.8 MB\n        // The log weight is a rough estimate, so we flush way before\n        // the payload gets too big.\n        if (client._logWeight >= 800000) {\n          exports$1._INTERNAL_flushLogsBuffer(client);\n        } else {\n          // start an idle timeout to flush the logs buffer if no logs are captured for a while\n          client._logFlushIdleTimeout = setTimeout(() => {\n            exports$1._INTERNAL_flushLogsBuffer(client);\n          }, DEFAULT_LOG_FLUSH_INTERVAL);\n        }\n      });\n\n      client.on('flush', () => {\n        exports$1._INTERNAL_flushLogsBuffer(client);\n      });\n    }\n  }\n\n  /**\n   * @inheritDoc\n   */\n   eventFromException(exception, hint) {\n    const event = eventbuilder.eventFromUnknownInput(this, this._options.stackParser, exception, hint);\n    event.level = 'error';\n\n    return syncpromise.resolvedSyncPromise(event);\n  }\n\n  /**\n   * @inheritDoc\n   */\n   eventFromMessage(\n    message,\n    level = 'info',\n    hint,\n  ) {\n    return syncpromise.resolvedSyncPromise(\n      eventbuilder.eventFromMessage(this._options.stackParser, message, level, hint, this._options.attachStacktrace),\n    );\n  }\n\n  /**\n   * @inheritDoc\n   */\n   captureException(exception, hint, scope) {\n    setCurrentRequestSessionErroredOrCrashed(hint);\n    return super.captureException(exception, hint, scope);\n  }\n\n  /**\n   * @inheritDoc\n   */\n   captureEvent(event, hint, scope) {\n    // If the event is of type Exception, then a request session should be captured\n    const isException = !event.type && event.exception?.values && event.exception.values.length > 0;\n    if (isException) {\n      setCurrentRequestSessionErroredOrCrashed(hint);\n    }\n\n    return super.captureEvent(event, hint, scope);\n  }\n\n  /**\n   * Create a cron monitor check in and send it to Sentry.\n   *\n   * @param checkIn An object that describes a check in.\n   * @param upsertMonitorConfig An optional object that describes a monitor config. Use this if you want\n   * to create a monitor automatically when sending a check in.\n   */\n   captureCheckIn(checkIn, monitorConfig, scope) {\n    const id = 'checkInId' in checkIn && checkIn.checkInId ? checkIn.checkInId : misc.uuid4();\n    if (!this._isEnabled()) {\n      debugBuild.DEBUG_BUILD && debugLogger.debug.warn('SDK not enabled, will not capture check-in.');\n      return id;\n    }\n\n    const options = this.getOptions();\n    const { release, environment, tunnel } = options;\n\n    const serializedCheckIn = {\n      check_in_id: id,\n      monitor_slug: checkIn.monitorSlug,\n      status: checkIn.status,\n      release,\n      environment,\n    };\n\n    if ('duration' in checkIn) {\n      serializedCheckIn.duration = checkIn.duration;\n    }\n\n    if (monitorConfig) {\n      serializedCheckIn.monitor_config = {\n        schedule: monitorConfig.schedule,\n        checkin_margin: monitorConfig.checkinMargin,\n        max_runtime: monitorConfig.maxRuntime,\n        timezone: monitorConfig.timezone,\n        failure_issue_threshold: monitorConfig.failureIssueThreshold,\n        recovery_threshold: monitorConfig.recoveryThreshold,\n      };\n    }\n\n    const [dynamicSamplingContext, traceContext] = client._getTraceInfoFromScope(this, scope);\n    if (traceContext) {\n      serializedCheckIn.contexts = {\n        trace: traceContext,\n      };\n    }\n\n    const envelope = checkin.createCheckInEnvelope(\n      serializedCheckIn,\n      dynamicSamplingContext,\n      this.getSdkMetadata(),\n      tunnel,\n      this.getDsn(),\n    );\n\n    debugBuild.DEBUG_BUILD && debugLogger.debug.log('Sending checkin:', checkIn.monitorSlug, checkIn.status);\n\n    // sendEnvelope should not throw\n    // eslint-disable-next-line @typescript-eslint/no-floating-promises\n    this.sendEnvelope(envelope);\n\n    return id;\n  }\n\n  /**\n   * @inheritDoc\n   */\n   _prepareEvent(\n    event,\n    hint,\n    currentScope,\n    isolationScope,\n  ) {\n    if (this._options.platform) {\n      event.platform = event.platform || this._options.platform;\n    }\n\n    if (this._options.runtime) {\n      event.contexts = {\n        ...event.contexts,\n        runtime: event.contexts?.runtime || this._options.runtime,\n      };\n    }\n\n    if (this._options.serverName) {\n      event.server_name = event.server_name || this._options.serverName;\n    }\n\n    return super._prepareEvent(event, hint, currentScope, isolationScope);\n  }\n}\n\nfunction setCurrentRequestSessionErroredOrCrashed(eventHint) {\n  const requestSession = currentScopes.getIsolationScope().getScopeData().sdkProcessingMetadata.requestSession;\n  if (requestSession) {\n    // We mutate instead of doing `setSdkProcessingMetadata` because the http integration stores away a particular\n    // isolationScope. If that isolation scope is forked, setting the processing metadata here will not mutate the\n    // original isolation scope that the http integration stored away.\n    const isHandledException = eventHint?.mechanism?.handled ?? true;\n    // A request session can go from \"errored\" -> \"crashed\" but not \"crashed\" -> \"errored\".\n    // Crashed (unhandled exception) is worse than errored (handled exception).\n    if (isHandledException && requestSession.status !== 'crashed') {\n      requestSession.status = 'errored';\n    } else if (!isHandledException) {\n      requestSession.status = 'crashed';\n    }\n  }\n}\n\n/**\n * Estimate the size of a log in bytes.\n *\n * @param log - The log to estimate the size of.\n * @returns The estimated size of the log in bytes.\n */\nfunction estimateLogSizeInBytes(log) {\n  let weight = 0;\n\n  // Estimate byte size of 2 bytes per character. This is a rough estimate JS strings are stored as UTF-16.\n  if (log.message) {\n    weight += log.message.length * 2;\n  }\n\n  if (log.attributes) {\n    Object.values(log.attributes).forEach(value => {\n      if (Array.isArray(value)) {\n        weight += value.length * estimatePrimitiveSizeInBytes(value[0]);\n      } else if (is.isPrimitive(value)) {\n        weight += estimatePrimitiveSizeInBytes(value);\n      } else {\n        // For objects values, we estimate the size of the object as 100 bytes\n        weight += 100;\n      }\n    });\n  }\n\n  return weight;\n}\n\nfunction estimatePrimitiveSizeInBytes(value) {\n  if (typeof value === 'string') {\n    return value.length * 2;\n  } else if (typeof value === 'number') {\n    return 8;\n  } else if (typeof value === 'boolean') {\n    return 4;\n  }\n\n  return 0;\n}\n\nexports.ServerRuntimeClient = ServerRuntimeClient;\n//# sourceMappingURL=server-runtime-client.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9zZXJ2ZXItcnVudGltZS1jbGllbnQuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsZ0JBQWdCLG1CQUFPLENBQUMsbUhBQWM7QUFDdEMsZUFBZSxtQkFBTyxDQUFDLGlIQUFhO0FBQ3BDLHNCQUFzQixtQkFBTyxDQUFDLCtIQUFvQjtBQUNsRCxtQkFBbUIsbUJBQU8sQ0FBQywySEFBa0I7QUFDN0Msa0JBQWtCLG1CQUFPLENBQUMsNkhBQW1CO0FBQzdDLGVBQWUsbUJBQU8sQ0FBQyxpSUFBcUI7QUFDNUMsV0FBVyxtQkFBTyxDQUFDLHFIQUFlO0FBQ2xDLG9CQUFvQixtQkFBTyxDQUFDLHlJQUF5QjtBQUNyRCxhQUFhLG1CQUFPLENBQUMseUhBQWlCO0FBQ3RDLHFCQUFxQixtQkFBTyxDQUFDLHlJQUF5QjtBQUN0RCxvQkFBb0IsbUJBQU8sQ0FBQyx1SUFBd0I7O0FBRXBEO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQSxPQUFPOztBQUVQO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFVBQVU7QUFDVjtBQUNBO0FBQ0E7QUFDQSxXQUFXO0FBQ1g7QUFDQSxPQUFPOztBQUVQO0FBQ0E7QUFDQSxPQUFPO0FBQ1A7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQSxZQUFZLCtCQUErQjs7QUFFM0M7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLE1BQU07QUFDTjtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsUUFBUTtBQUNSO0FBQ0EsUUFBUTtBQUNSO0FBQ0E7QUFDQTtBQUNBLEtBQUs7QUFDTDs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBLElBQUk7QUFDSjtBQUNBLElBQUk7QUFDSjtBQUNBOztBQUVBO0FBQ0E7O0FBRUEsMkJBQTJCO0FBQzNCIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvc2VydmVyLXJ1bnRpbWUtY2xpZW50LmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBjaGVja2luID0gcmVxdWlyZSgnLi9jaGVja2luLmpzJyk7XG5jb25zdCBjbGllbnQgPSByZXF1aXJlKCcuL2NsaWVudC5qcycpO1xuY29uc3QgY3VycmVudFNjb3BlcyA9IHJlcXVpcmUoJy4vY3VycmVudFNjb3Blcy5qcycpO1xuY29uc3QgZGVidWdCdWlsZCA9IHJlcXVpcmUoJy4vZGVidWctYnVpbGQuanMnKTtcbmNvbnN0IGV4cG9ydHMkMSA9IHJlcXVpcmUoJy4vbG9ncy9leHBvcnRzLmpzJyk7XG5jb25zdCBlcnJvcnMgPSByZXF1aXJlKCcuL3RyYWNpbmcvZXJyb3JzLmpzJyk7XG5jb25zdCBpcyA9IHJlcXVpcmUoJy4vdXRpbHMvaXMuanMnKTtcbmNvbnN0IGRlYnVnTG9nZ2VyID0gcmVxdWlyZSgnLi91dGlscy9kZWJ1Zy1sb2dnZXIuanMnKTtcbmNvbnN0IG1pc2MgPSByZXF1aXJlKCcuL3V0aWxzL21pc2MuanMnKTtcbmNvbnN0IGV2ZW50YnVpbGRlciA9IHJlcXVpcmUoJy4vdXRpbHMvZXZlbnRidWlsZGVyLmpzJyk7XG5jb25zdCBzeW5jcHJvbWlzZSA9IHJlcXVpcmUoJy4vdXRpbHMvc3luY3Byb21pc2UuanMnKTtcblxuLy8gVE9ETzogTWFrZSB0aGlzIGNvbmZpZ3VyYWJsZVxuY29uc3QgREVGQVVMVF9MT0dfRkxVU0hfSU5URVJWQUwgPSA1MDAwO1xuXG4vKipcbiAqIFRoZSBTZW50cnkgU2VydmVyIFJ1bnRpbWUgQ2xpZW50IFNESy5cbiAqL1xuY2xhc3MgU2VydmVyUnVudGltZUNsaWVudFxuXG4gZXh0ZW5kcyBjbGllbnQuQ2xpZW50IHtcblxuICAvKipcbiAgICogQ3JlYXRlcyBhIG5ldyBFZGdlIFNESyBpbnN0YW5jZS5cbiAgICogQHBhcmFtIG9wdGlvbnMgQ29uZmlndXJhdGlvbiBvcHRpb25zIGZvciB0aGlzIFNESy5cbiAgICovXG4gICBjb25zdHJ1Y3RvcihvcHRpb25zKSB7XG4gICAgLy8gU2VydmVyIGNsaWVudHMgYWx3YXlzIHN1cHBvcnQgdHJhY2luZ1xuICAgIGVycm9ycy5yZWdpc3RlclNwYW5FcnJvckluc3RydW1lbnRhdGlvbigpO1xuXG4gICAgc3VwZXIob3B0aW9ucyk7XG5cbiAgICB0aGlzLl9sb2dXZWlnaHQgPSAwO1xuXG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIGRlcHJlY2F0aW9uL2RlcHJlY2F0aW9uXG4gICAgY29uc3Qgc2hvdWxkRW5hYmxlTG9ncyA9IHRoaXMuX29wdGlvbnMuZW5hYmxlTG9ncyA/PyB0aGlzLl9vcHRpb25zLl9leHBlcmltZW50cz8uZW5hYmxlTG9ncztcbiAgICBpZiAoc2hvdWxkRW5hYmxlTG9ncykge1xuICAgICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uby10aGlzLWFsaWFzXG4gICAgICBjb25zdCBjbGllbnQgPSB0aGlzO1xuXG4gICAgICBjbGllbnQub24oJ2ZsdXNoTG9ncycsICgpID0+IHtcbiAgICAgICAgY2xpZW50Ll9sb2dXZWlnaHQgPSAwO1xuICAgICAgICBjbGVhclRpbWVvdXQoY2xpZW50Ll9sb2dGbHVzaElkbGVUaW1lb3V0KTtcbiAgICAgIH0pO1xuXG4gICAgICBjbGllbnQub24oJ2FmdGVyQ2FwdHVyZUxvZycsIGxvZyA9PiB7XG4gICAgICAgIGNsaWVudC5fbG9nV2VpZ2h0ICs9IGVzdGltYXRlTG9nU2l6ZUluQnl0ZXMobG9nKTtcblxuICAgICAgICAvLyBXZSBmbHVzaCB0aGUgbG9ncyBidWZmZXIgaWYgaXQgZXhjZWVkcyAwLjggTUJcbiAgICAgICAgLy8gVGhlIGxvZyB3ZWlnaHQgaXMgYSByb3VnaCBlc3RpbWF0ZSwgc28gd2UgZmx1c2ggd2F5IGJlZm9yZVxuICAgICAgICAvLyB0aGUgcGF5bG9hZCBnZXRzIHRvbyBiaWcuXG4gICAgICAgIGlmIChjbGllbnQuX2xvZ1dlaWdodCA+PSA4MDAwMDApIHtcbiAgICAgICAgICBleHBvcnRzJDEuX0lOVEVSTkFMX2ZsdXNoTG9nc0J1ZmZlcihjbGllbnQpO1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgIC8vIHN0YXJ0IGFuIGlkbGUgdGltZW91dCB0byBmbHVzaCB0aGUgbG9ncyBidWZmZXIgaWYgbm8gbG9ncyBhcmUgY2FwdHVyZWQgZm9yIGEgd2hpbGVcbiAgICAgICAgICBjbGllbnQuX2xvZ0ZsdXNoSWRsZVRpbWVvdXQgPSBzZXRUaW1lb3V0KCgpID0+IHtcbiAgICAgICAgICAgIGV4cG9ydHMkMS5fSU5URVJOQUxfZmx1c2hMb2dzQnVmZmVyKGNsaWVudCk7XG4gICAgICAgICAgfSwgREVGQVVMVF9MT0dfRkxVU0hfSU5URVJWQUwpO1xuICAgICAgICB9XG4gICAgICB9KTtcblxuICAgICAgY2xpZW50Lm9uKCdmbHVzaCcsICgpID0+IHtcbiAgICAgICAgZXhwb3J0cyQxLl9JTlRFUk5BTF9mbHVzaExvZ3NCdWZmZXIoY2xpZW50KTtcbiAgICAgIH0pO1xuICAgIH1cbiAgfVxuXG4gIC8qKlxuICAgKiBAaW5oZXJpdERvY1xuICAgKi9cbiAgIGV2ZW50RnJvbUV4Y2VwdGlvbihleGNlcHRpb24sIGhpbnQpIHtcbiAgICBjb25zdCBldmVudCA9IGV2ZW50YnVpbGRlci5ldmVudEZyb21Vbmtub3duSW5wdXQodGhpcywgdGhpcy5fb3B0aW9ucy5zdGFja1BhcnNlciwgZXhjZXB0aW9uLCBoaW50KTtcbiAgICBldmVudC5sZXZlbCA9ICdlcnJvcic7XG5cbiAgICByZXR1cm4gc3luY3Byb21pc2UucmVzb2x2ZWRTeW5jUHJvbWlzZShldmVudCk7XG4gIH1cblxuICAvKipcbiAgICogQGluaGVyaXREb2NcbiAgICovXG4gICBldmVudEZyb21NZXNzYWdlKFxuICAgIG1lc3NhZ2UsXG4gICAgbGV2ZWwgPSAnaW5mbycsXG4gICAgaGludCxcbiAgKSB7XG4gICAgcmV0dXJuIHN5bmNwcm9taXNlLnJlc29sdmVkU3luY1Byb21pc2UoXG4gICAgICBldmVudGJ1aWxkZXIuZXZlbnRGcm9tTWVzc2FnZSh0aGlzLl9vcHRpb25zLnN0YWNrUGFyc2VyLCBtZXNzYWdlLCBsZXZlbCwgaGludCwgdGhpcy5fb3B0aW9ucy5hdHRhY2hTdGFja3RyYWNlKSxcbiAgICApO1xuICB9XG5cbiAgLyoqXG4gICAqIEBpbmhlcml0RG9jXG4gICAqL1xuICAgY2FwdHVyZUV4Y2VwdGlvbihleGNlcHRpb24sIGhpbnQsIHNjb3BlKSB7XG4gICAgc2V0Q3VycmVudFJlcXVlc3RTZXNzaW9uRXJyb3JlZE9yQ3Jhc2hlZChoaW50KTtcbiAgICByZXR1cm4gc3VwZXIuY2FwdHVyZUV4Y2VwdGlvbihleGNlcHRpb24sIGhpbnQsIHNjb3BlKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBAaW5oZXJpdERvY1xuICAgKi9cbiAgIGNhcHR1cmVFdmVudChldmVudCwgaGludCwgc2NvcGUpIHtcbiAgICAvLyBJZiB0aGUgZXZlbnQgaXMgb2YgdHlwZSBFeGNlcHRpb24sIHRoZW4gYSByZXF1ZXN0IHNlc3Npb24gc2hvdWxkIGJlIGNhcHR1cmVkXG4gICAgY29uc3QgaXNFeGNlcHRpb24gPSAhZXZlbnQudHlwZSAmJiBldmVudC5leGNlcHRpb24/LnZhbHVlcyAmJiBldmVudC5leGNlcHRpb24udmFsdWVzLmxlbmd0aCA+IDA7XG4gICAgaWYgKGlzRXhjZXB0aW9uKSB7XG4gICAgICBzZXRDdXJyZW50UmVxdWVzdFNlc3Npb25FcnJvcmVkT3JDcmFzaGVkKGhpbnQpO1xuICAgIH1cblxuICAgIHJldHVybiBzdXBlci5jYXB0dXJlRXZlbnQoZXZlbnQsIGhpbnQsIHNjb3BlKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBDcmVhdGUgYSBjcm9uIG1vbml0b3IgY2hlY2sgaW4gYW5kIHNlbmQgaXQgdG8gU2VudHJ5LlxuICAgKlxuICAgKiBAcGFyYW0gY2hlY2tJbiBBbiBvYmplY3QgdGhhdCBkZXNjcmliZXMgYSBjaGVjayBpbi5cbiAgICogQHBhcmFtIHVwc2VydE1vbml0b3JDb25maWcgQW4gb3B0aW9uYWwgb2JqZWN0IHRoYXQgZGVzY3JpYmVzIGEgbW9uaXRvciBjb25maWcuIFVzZSB0aGlzIGlmIHlvdSB3YW50XG4gICAqIHRvIGNyZWF0ZSBhIG1vbml0b3IgYXV0b21hdGljYWxseSB3aGVuIHNlbmRpbmcgYSBjaGVjayBpbi5cbiAgICovXG4gICBjYXB0dXJlQ2hlY2tJbihjaGVja0luLCBtb25pdG9yQ29uZmlnLCBzY29wZSkge1xuICAgIGNvbnN0IGlkID0gJ2NoZWNrSW5JZCcgaW4gY2hlY2tJbiAmJiBjaGVja0luLmNoZWNrSW5JZCA/IGNoZWNrSW4uY2hlY2tJbklkIDogbWlzYy51dWlkNCgpO1xuICAgIGlmICghdGhpcy5faXNFbmFibGVkKCkpIHtcbiAgICAgIGRlYnVnQnVpbGQuREVCVUdfQlVJTEQgJiYgZGVidWdMb2dnZXIuZGVidWcud2FybignU0RLIG5vdCBlbmFibGVkLCB3aWxsIG5vdCBjYXB0dXJlIGNoZWNrLWluLicpO1xuICAgICAgcmV0dXJuIGlkO1xuICAgIH1cblxuICAgIGNvbnN0IG9wdGlvbnMgPSB0aGlzLmdldE9wdGlvbnMoKTtcbiAgICBjb25zdCB7IHJlbGVhc2UsIGVudmlyb25tZW50LCB0dW5uZWwgfSA9IG9wdGlvbnM7XG5cbiAgICBjb25zdCBzZXJpYWxpemVkQ2hlY2tJbiA9IHtcbiAgICAgIGNoZWNrX2luX2lkOiBpZCxcbiAgICAgIG1vbml0b3Jfc2x1ZzogY2hlY2tJbi5tb25pdG9yU2x1ZyxcbiAgICAgIHN0YXR1czogY2hlY2tJbi5zdGF0dXMsXG4gICAgICByZWxlYXNlLFxuICAgICAgZW52aXJvbm1lbnQsXG4gICAgfTtcblxuICAgIGlmICgnZHVyYXRpb24nIGluIGNoZWNrSW4pIHtcbiAgICAgIHNlcmlhbGl6ZWRDaGVja0luLmR1cmF0aW9uID0gY2hlY2tJbi5kdXJhdGlvbjtcbiAgICB9XG5cbiAgICBpZiAobW9uaXRvckNvbmZpZykge1xuICAgICAgc2VyaWFsaXplZENoZWNrSW4ubW9uaXRvcl9jb25maWcgPSB7XG4gICAgICAgIHNjaGVkdWxlOiBtb25pdG9yQ29uZmlnLnNjaGVkdWxlLFxuICAgICAgICBjaGVja2luX21hcmdpbjogbW9uaXRvckNvbmZpZy5jaGVja2luTWFyZ2luLFxuICAgICAgICBtYXhfcnVudGltZTogbW9uaXRvckNvbmZpZy5tYXhSdW50aW1lLFxuICAgICAgICB0aW1lem9uZTogbW9uaXRvckNvbmZpZy50aW1lem9uZSxcbiAgICAgICAgZmFpbHVyZV9pc3N1ZV90aHJlc2hvbGQ6IG1vbml0b3JDb25maWcuZmFpbHVyZUlzc3VlVGhyZXNob2xkLFxuICAgICAgICByZWNvdmVyeV90aHJlc2hvbGQ6IG1vbml0b3JDb25maWcucmVjb3ZlcnlUaHJlc2hvbGQsXG4gICAgICB9O1xuICAgIH1cblxuICAgIGNvbnN0IFtkeW5hbWljU2FtcGxpbmdDb250ZXh0LCB0cmFjZUNvbnRleHRdID0gY2xpZW50Ll9nZXRUcmFjZUluZm9Gcm9tU2NvcGUodGhpcywgc2NvcGUpO1xuICAgIGlmICh0cmFjZUNvbnRleHQpIHtcbiAgICAgIHNlcmlhbGl6ZWRDaGVja0luLmNvbnRleHRzID0ge1xuICAgICAgICB0cmFjZTogdHJhY2VDb250ZXh0LFxuICAgICAgfTtcbiAgICB9XG5cbiAgICBjb25zdCBlbnZlbG9wZSA9IGNoZWNraW4uY3JlYXRlQ2hlY2tJbkVudmVsb3BlKFxuICAgICAgc2VyaWFsaXplZENoZWNrSW4sXG4gICAgICBkeW5hbWljU2FtcGxpbmdDb250ZXh0LFxuICAgICAgdGhpcy5nZXRTZGtNZXRhZGF0YSgpLFxuICAgICAgdHVubmVsLFxuICAgICAgdGhpcy5nZXREc24oKSxcbiAgICApO1xuXG4gICAgZGVidWdCdWlsZC5ERUJVR19CVUlMRCAmJiBkZWJ1Z0xvZ2dlci5kZWJ1Zy5sb2coJ1NlbmRpbmcgY2hlY2tpbjonLCBjaGVja0luLm1vbml0b3JTbHVnLCBjaGVja0luLnN0YXR1cyk7XG5cbiAgICAvLyBzZW5kRW52ZWxvcGUgc2hvdWxkIG5vdCB0aHJvd1xuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tZmxvYXRpbmctcHJvbWlzZXNcbiAgICB0aGlzLnNlbmRFbnZlbG9wZShlbnZlbG9wZSk7XG5cbiAgICByZXR1cm4gaWQ7XG4gIH1cblxuICAvKipcbiAgICogQGluaGVyaXREb2NcbiAgICovXG4gICBfcHJlcGFyZUV2ZW50KFxuICAgIGV2ZW50LFxuICAgIGhpbnQsXG4gICAgY3VycmVudFNjb3BlLFxuICAgIGlzb2xhdGlvblNjb3BlLFxuICApIHtcbiAgICBpZiAodGhpcy5fb3B0aW9ucy5wbGF0Zm9ybSkge1xuICAgICAgZXZlbnQucGxhdGZvcm0gPSBldmVudC5wbGF0Zm9ybSB8fCB0aGlzLl9vcHRpb25zLnBsYXRmb3JtO1xuICAgIH1cblxuICAgIGlmICh0aGlzLl9vcHRpb25zLnJ1bnRpbWUpIHtcbiAgICAgIGV2ZW50LmNvbnRleHRzID0ge1xuICAgICAgICAuLi5ldmVudC5jb250ZXh0cyxcbiAgICAgICAgcnVudGltZTogZXZlbnQuY29udGV4dHM/LnJ1bnRpbWUgfHwgdGhpcy5fb3B0aW9ucy5ydW50aW1lLFxuICAgICAgfTtcbiAgICB9XG5cbiAgICBpZiAodGhpcy5fb3B0aW9ucy5zZXJ2ZXJOYW1lKSB7XG4gICAgICBldmVudC5zZXJ2ZXJfbmFtZSA9IGV2ZW50LnNlcnZlcl9uYW1lIHx8IHRoaXMuX29wdGlvbnMuc2VydmVyTmFtZTtcbiAgICB9XG5cbiAgICByZXR1cm4gc3VwZXIuX3ByZXBhcmVFdmVudChldmVudCwgaGludCwgY3VycmVudFNjb3BlLCBpc29sYXRpb25TY29wZSk7XG4gIH1cbn1cblxuZnVuY3Rpb24gc2V0Q3VycmVudFJlcXVlc3RTZXNzaW9uRXJyb3JlZE9yQ3Jhc2hlZChldmVudEhpbnQpIHtcbiAgY29uc3QgcmVxdWVzdFNlc3Npb24gPSBjdXJyZW50U2NvcGVzLmdldElzb2xhdGlvblNjb3BlKCkuZ2V0U2NvcGVEYXRhKCkuc2RrUHJvY2Vzc2luZ01ldGFkYXRhLnJlcXVlc3RTZXNzaW9uO1xuICBpZiAocmVxdWVzdFNlc3Npb24pIHtcbiAgICAvLyBXZSBtdXRhdGUgaW5zdGVhZCBvZiBkb2luZyBgc2V0U2RrUHJvY2Vzc2luZ01ldGFkYXRhYCBiZWNhdXNlIHRoZSBodHRwIGludGVncmF0aW9uIHN0b3JlcyBhd2F5IGEgcGFydGljdWxhclxuICAgIC8vIGlzb2xhdGlvblNjb3BlLiBJZiB0aGF0IGlzb2xhdGlvbiBzY29wZSBpcyBmb3JrZWQsIHNldHRpbmcgdGhlIHByb2Nlc3NpbmcgbWV0YWRhdGEgaGVyZSB3aWxsIG5vdCBtdXRhdGUgdGhlXG4gICAgLy8gb3JpZ2luYWwgaXNvbGF0aW9uIHNjb3BlIHRoYXQgdGhlIGh0dHAgaW50ZWdyYXRpb24gc3RvcmVkIGF3YXkuXG4gICAgY29uc3QgaXNIYW5kbGVkRXhjZXB0aW9uID0gZXZlbnRIaW50Py5tZWNoYW5pc20/LmhhbmRsZWQgPz8gdHJ1ZTtcbiAgICAvLyBBIHJlcXVlc3Qgc2Vzc2lvbiBjYW4gZ28gZnJvbSBcImVycm9yZWRcIiAtPiBcImNyYXNoZWRcIiBidXQgbm90IFwiY3Jhc2hlZFwiIC0+IFwiZXJyb3JlZFwiLlxuICAgIC8vIENyYXNoZWQgKHVuaGFuZGxlZCBleGNlcHRpb24pIGlzIHdvcnNlIHRoYW4gZXJyb3JlZCAoaGFuZGxlZCBleGNlcHRpb24pLlxuICAgIGlmIChpc0hhbmRsZWRFeGNlcHRpb24gJiYgcmVxdWVzdFNlc3Npb24uc3RhdHVzICE9PSAnY3Jhc2hlZCcpIHtcbiAgICAgIHJlcXVlc3RTZXNzaW9uLnN0YXR1cyA9ICdlcnJvcmVkJztcbiAgICB9IGVsc2UgaWYgKCFpc0hhbmRsZWRFeGNlcHRpb24pIHtcbiAgICAgIHJlcXVlc3RTZXNzaW9uLnN0YXR1cyA9ICdjcmFzaGVkJztcbiAgICB9XG4gIH1cbn1cblxuLyoqXG4gKiBFc3RpbWF0ZSB0aGUgc2l6ZSBvZiBhIGxvZyBpbiBieXRlcy5cbiAqXG4gKiBAcGFyYW0gbG9nIC0gVGhlIGxvZyB0byBlc3RpbWF0ZSB0aGUgc2l6ZSBvZi5cbiAqIEByZXR1cm5zIFRoZSBlc3RpbWF0ZWQgc2l6ZSBvZiB0aGUgbG9nIGluIGJ5dGVzLlxuICovXG5mdW5jdGlvbiBlc3RpbWF0ZUxvZ1NpemVJbkJ5dGVzKGxvZykge1xuICBsZXQgd2VpZ2h0ID0gMDtcblxuICAvLyBFc3RpbWF0ZSBieXRlIHNpemUgb2YgMiBieXRlcyBwZXIgY2hhcmFjdGVyLiBUaGlzIGlzIGEgcm91Z2ggZXN0aW1hdGUgSlMgc3RyaW5ncyBhcmUgc3RvcmVkIGFzIFVURi0xNi5cbiAgaWYgKGxvZy5tZXNzYWdlKSB7XG4gICAgd2VpZ2h0ICs9IGxvZy5tZXNzYWdlLmxlbmd0aCAqIDI7XG4gIH1cblxuICBpZiAobG9nLmF0dHJpYnV0ZXMpIHtcbiAgICBPYmplY3QudmFsdWVzKGxvZy5hdHRyaWJ1dGVzKS5mb3JFYWNoKHZhbHVlID0+IHtcbiAgICAgIGlmIChBcnJheS5pc0FycmF5KHZhbHVlKSkge1xuICAgICAgICB3ZWlnaHQgKz0gdmFsdWUubGVuZ3RoICogZXN0aW1hdGVQcmltaXRpdmVTaXplSW5CeXRlcyh2YWx1ZVswXSk7XG4gICAgICB9IGVsc2UgaWYgKGlzLmlzUHJpbWl0aXZlKHZhbHVlKSkge1xuICAgICAgICB3ZWlnaHQgKz0gZXN0aW1hdGVQcmltaXRpdmVTaXplSW5CeXRlcyh2YWx1ZSk7XG4gICAgICB9IGVsc2Uge1xuICAgICAgICAvLyBGb3Igb2JqZWN0cyB2YWx1ZXMsIHdlIGVzdGltYXRlIHRoZSBzaXplIG9mIHRoZSBvYmplY3QgYXMgMTAwIGJ5dGVzXG4gICAgICAgIHdlaWdodCArPSAxMDA7XG4gICAgICB9XG4gICAgfSk7XG4gIH1cblxuICByZXR1cm4gd2VpZ2h0O1xufVxuXG5mdW5jdGlvbiBlc3RpbWF0ZVByaW1pdGl2ZVNpemVJbkJ5dGVzKHZhbHVlKSB7XG4gIGlmICh0eXBlb2YgdmFsdWUgPT09ICdzdHJpbmcnKSB7XG4gICAgcmV0dXJuIHZhbHVlLmxlbmd0aCAqIDI7XG4gIH0gZWxzZSBpZiAodHlwZW9mIHZhbHVlID09PSAnbnVtYmVyJykge1xuICAgIHJldHVybiA4O1xuICB9IGVsc2UgaWYgKHR5cGVvZiB2YWx1ZSA9PT0gJ2Jvb2xlYW4nKSB7XG4gICAgcmV0dXJuIDQ7XG4gIH1cblxuICByZXR1cm4gMDtcbn1cblxuZXhwb3J0cy5TZXJ2ZXJSdW50aW1lQ2xpZW50ID0gU2VydmVyUnVudGltZUNsaWVudDtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPXNlcnZlci1ydW50aW1lLWNsaWVudC5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/server-runtime-client.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/session.js":
/*!***********************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/session.js ***!
  \***********************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst misc = __webpack_require__(/*! ./utils/misc.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/misc.js\");\nconst time = __webpack_require__(/*! ./utils/time.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/time.js\");\n\n/**\n * Creates a new `Session` object by setting certain default parameters. If optional @param context\n * is passed, the passed properties are applied to the session object.\n *\n * @param context (optional) additional properties to be applied to the returned session object\n *\n * @returns a new `Session` object\n */\nfunction makeSession(context) {\n  // Both timestamp and started are in seconds since the UNIX epoch.\n  const startingTime = time.timestampInSeconds();\n\n  const session = {\n    sid: misc.uuid4(),\n    init: true,\n    timestamp: startingTime,\n    started: startingTime,\n    duration: 0,\n    status: 'ok',\n    errors: 0,\n    ignoreDuration: false,\n    toJSON: () => sessionToJSON(session),\n  };\n\n  if (context) {\n    updateSession(session, context);\n  }\n\n  return session;\n}\n\n/**\n * Updates a session object with the properties passed in the context.\n *\n * Note that this function mutates the passed object and returns void.\n * (Had to do this instead of returning a new and updated session because closing and sending a session\n * makes an update to the session after it was passed to the sending logic.\n * @see Client.captureSession )\n *\n * @param session the `Session` to update\n * @param context the `SessionContext` holding the properties that should be updated in @param session\n */\n// eslint-disable-next-line complexity\nfunction updateSession(session, context = {}) {\n  if (context.user) {\n    if (!session.ipAddress && context.user.ip_address) {\n      session.ipAddress = context.user.ip_address;\n    }\n\n    if (!session.did && !context.did) {\n      session.did = context.user.id || context.user.email || context.user.username;\n    }\n  }\n\n  session.timestamp = context.timestamp || time.timestampInSeconds();\n\n  if (context.abnormal_mechanism) {\n    session.abnormal_mechanism = context.abnormal_mechanism;\n  }\n\n  if (context.ignoreDuration) {\n    session.ignoreDuration = context.ignoreDuration;\n  }\n  if (context.sid) {\n    // Good enough uuid validation. — Kamil\n    session.sid = context.sid.length === 32 ? context.sid : misc.uuid4();\n  }\n  if (context.init !== undefined) {\n    session.init = context.init;\n  }\n  if (!session.did && context.did) {\n    session.did = `${context.did}`;\n  }\n  if (typeof context.started === 'number') {\n    session.started = context.started;\n  }\n  if (session.ignoreDuration) {\n    session.duration = undefined;\n  } else if (typeof context.duration === 'number') {\n    session.duration = context.duration;\n  } else {\n    const duration = session.timestamp - session.started;\n    session.duration = duration >= 0 ? duration : 0;\n  }\n  if (context.release) {\n    session.release = context.release;\n  }\n  if (context.environment) {\n    session.environment = context.environment;\n  }\n  if (!session.ipAddress && context.ipAddress) {\n    session.ipAddress = context.ipAddress;\n  }\n  if (!session.userAgent && context.userAgent) {\n    session.userAgent = context.userAgent;\n  }\n  if (typeof context.errors === 'number') {\n    session.errors = context.errors;\n  }\n  if (context.status) {\n    session.status = context.status;\n  }\n}\n\n/**\n * Closes a session by setting its status and updating the session object with it.\n * Internally calls `updateSession` to update the passed session object.\n *\n * Note that this function mutates the passed session (@see updateSession for explanation).\n *\n * @param session the `Session` object to be closed\n * @param status the `SessionStatus` with which the session was closed. If you don't pass a status,\n *               this function will keep the previously set status, unless it was `'ok'` in which case\n *               it is changed to `'exited'`.\n */\nfunction closeSession(session, status) {\n  let context = {};\n  if (status) {\n    context = { status };\n  } else if (session.status === 'ok') {\n    context = { status: 'exited' };\n  }\n\n  updateSession(session, context);\n}\n\n/**\n * Serializes a passed session object to a JSON object with a slightly different structure.\n * This is necessary because the Sentry backend requires a slightly different schema of a session\n * than the one the JS SDKs use internally.\n *\n * @param session the session to be converted\n *\n * @returns a JSON object of the passed session\n */\nfunction sessionToJSON(session) {\n  return {\n    sid: `${session.sid}`,\n    init: session.init,\n    // Make sure that sec is converted to ms for date constructor\n    started: new Date(session.started * 1000).toISOString(),\n    timestamp: new Date(session.timestamp * 1000).toISOString(),\n    status: session.status,\n    errors: session.errors,\n    did: typeof session.did === 'number' || typeof session.did === 'string' ? `${session.did}` : undefined,\n    duration: session.duration,\n    abnormal_mechanism: session.abnormal_mechanism,\n    attrs: {\n      release: session.release,\n      environment: session.environment,\n      ip_address: session.ipAddress,\n      user_agent: session.userAgent,\n    },\n  };\n}\n\nexports.closeSession = closeSession;\nexports.makeSession = makeSession;\nexports.updateSession = updateSession;\n//# sourceMappingURL=session.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9zZXNzaW9uLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLGFBQWEsbUJBQU8sQ0FBQyx5SEFBaUI7QUFDdEMsYUFBYSxtQkFBTyxDQUFDLHlIQUFpQjs7QUFFdEM7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLDRDQUE0QztBQUM1QztBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLHFCQUFxQixZQUFZO0FBQ2pDO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLElBQUk7QUFDSjtBQUNBLElBQUk7QUFDSjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsZ0JBQWdCO0FBQ2hCLElBQUk7QUFDSixnQkFBZ0I7QUFDaEI7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsWUFBWSxZQUFZO0FBQ3hCO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGlGQUFpRixZQUFZO0FBQzdGO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsS0FBSztBQUNMO0FBQ0E7O0FBRUEsb0JBQW9CO0FBQ3BCLG1CQUFtQjtBQUNuQixxQkFBcUI7QUFDckIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9zZXNzaW9uLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBtaXNjID0gcmVxdWlyZSgnLi91dGlscy9taXNjLmpzJyk7XG5jb25zdCB0aW1lID0gcmVxdWlyZSgnLi91dGlscy90aW1lLmpzJyk7XG5cbi8qKlxuICogQ3JlYXRlcyBhIG5ldyBgU2Vzc2lvbmAgb2JqZWN0IGJ5IHNldHRpbmcgY2VydGFpbiBkZWZhdWx0IHBhcmFtZXRlcnMuIElmIG9wdGlvbmFsIEBwYXJhbSBjb250ZXh0XG4gKiBpcyBwYXNzZWQsIHRoZSBwYXNzZWQgcHJvcGVydGllcyBhcmUgYXBwbGllZCB0byB0aGUgc2Vzc2lvbiBvYmplY3QuXG4gKlxuICogQHBhcmFtIGNvbnRleHQgKG9wdGlvbmFsKSBhZGRpdGlvbmFsIHByb3BlcnRpZXMgdG8gYmUgYXBwbGllZCB0byB0aGUgcmV0dXJuZWQgc2Vzc2lvbiBvYmplY3RcbiAqXG4gKiBAcmV0dXJucyBhIG5ldyBgU2Vzc2lvbmAgb2JqZWN0XG4gKi9cbmZ1bmN0aW9uIG1ha2VTZXNzaW9uKGNvbnRleHQpIHtcbiAgLy8gQm90aCB0aW1lc3RhbXAgYW5kIHN0YXJ0ZWQgYXJlIGluIHNlY29uZHMgc2luY2UgdGhlIFVOSVggZXBvY2guXG4gIGNvbnN0IHN0YXJ0aW5nVGltZSA9IHRpbWUudGltZXN0YW1wSW5TZWNvbmRzKCk7XG5cbiAgY29uc3Qgc2Vzc2lvbiA9IHtcbiAgICBzaWQ6IG1pc2MudXVpZDQoKSxcbiAgICBpbml0OiB0cnVlLFxuICAgIHRpbWVzdGFtcDogc3RhcnRpbmdUaW1lLFxuICAgIHN0YXJ0ZWQ6IHN0YXJ0aW5nVGltZSxcbiAgICBkdXJhdGlvbjogMCxcbiAgICBzdGF0dXM6ICdvaycsXG4gICAgZXJyb3JzOiAwLFxuICAgIGlnbm9yZUR1cmF0aW9uOiBmYWxzZSxcbiAgICB0b0pTT046ICgpID0+IHNlc3Npb25Ub0pTT04oc2Vzc2lvbiksXG4gIH07XG5cbiAgaWYgKGNvbnRleHQpIHtcbiAgICB1cGRhdGVTZXNzaW9uKHNlc3Npb24sIGNvbnRleHQpO1xuICB9XG5cbiAgcmV0dXJuIHNlc3Npb247XG59XG5cbi8qKlxuICogVXBkYXRlcyBhIHNlc3Npb24gb2JqZWN0IHdpdGggdGhlIHByb3BlcnRpZXMgcGFzc2VkIGluIHRoZSBjb250ZXh0LlxuICpcbiAqIE5vdGUgdGhhdCB0aGlzIGZ1bmN0aW9uIG11dGF0ZXMgdGhlIHBhc3NlZCBvYmplY3QgYW5kIHJldHVybnMgdm9pZC5cbiAqIChIYWQgdG8gZG8gdGhpcyBpbnN0ZWFkIG9mIHJldHVybmluZyBhIG5ldyBhbmQgdXBkYXRlZCBzZXNzaW9uIGJlY2F1c2UgY2xvc2luZyBhbmQgc2VuZGluZyBhIHNlc3Npb25cbiAqIG1ha2VzIGFuIHVwZGF0ZSB0byB0aGUgc2Vzc2lvbiBhZnRlciBpdCB3YXMgcGFzc2VkIHRvIHRoZSBzZW5kaW5nIGxvZ2ljLlxuICogQHNlZSBDbGllbnQuY2FwdHVyZVNlc3Npb24gKVxuICpcbiAqIEBwYXJhbSBzZXNzaW9uIHRoZSBgU2Vzc2lvbmAgdG8gdXBkYXRlXG4gKiBAcGFyYW0gY29udGV4dCB0aGUgYFNlc3Npb25Db250ZXh0YCBob2xkaW5nIHRoZSBwcm9wZXJ0aWVzIHRoYXQgc2hvdWxkIGJlIHVwZGF0ZWQgaW4gQHBhcmFtIHNlc3Npb25cbiAqL1xuLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIGNvbXBsZXhpdHlcbmZ1bmN0aW9uIHVwZGF0ZVNlc3Npb24oc2Vzc2lvbiwgY29udGV4dCA9IHt9KSB7XG4gIGlmIChjb250ZXh0LnVzZXIpIHtcbiAgICBpZiAoIXNlc3Npb24uaXBBZGRyZXNzICYmIGNvbnRleHQudXNlci5pcF9hZGRyZXNzKSB7XG4gICAgICBzZXNzaW9uLmlwQWRkcmVzcyA9IGNvbnRleHQudXNlci5pcF9hZGRyZXNzO1xuICAgIH1cblxuICAgIGlmICghc2Vzc2lvbi5kaWQgJiYgIWNvbnRleHQuZGlkKSB7XG4gICAgICBzZXNzaW9uLmRpZCA9IGNvbnRleHQudXNlci5pZCB8fCBjb250ZXh0LnVzZXIuZW1haWwgfHwgY29udGV4dC51c2VyLnVzZXJuYW1lO1xuICAgIH1cbiAgfVxuXG4gIHNlc3Npb24udGltZXN0YW1wID0gY29udGV4dC50aW1lc3RhbXAgfHwgdGltZS50aW1lc3RhbXBJblNlY29uZHMoKTtcblxuICBpZiAoY29udGV4dC5hYm5vcm1hbF9tZWNoYW5pc20pIHtcbiAgICBzZXNzaW9uLmFibm9ybWFsX21lY2hhbmlzbSA9IGNvbnRleHQuYWJub3JtYWxfbWVjaGFuaXNtO1xuICB9XG5cbiAgaWYgKGNvbnRleHQuaWdub3JlRHVyYXRpb24pIHtcbiAgICBzZXNzaW9uLmlnbm9yZUR1cmF0aW9uID0gY29udGV4dC5pZ25vcmVEdXJhdGlvbjtcbiAgfVxuICBpZiAoY29udGV4dC5zaWQpIHtcbiAgICAvLyBHb29kIGVub3VnaCB1dWlkIHZhbGlkYXRpb24uIOKAlCBLYW1pbFxuICAgIHNlc3Npb24uc2lkID0gY29udGV4dC5zaWQubGVuZ3RoID09PSAzMiA/IGNvbnRleHQuc2lkIDogbWlzYy51dWlkNCgpO1xuICB9XG4gIGlmIChjb250ZXh0LmluaXQgIT09IHVuZGVmaW5lZCkge1xuICAgIHNlc3Npb24uaW5pdCA9IGNvbnRleHQuaW5pdDtcbiAgfVxuICBpZiAoIXNlc3Npb24uZGlkICYmIGNvbnRleHQuZGlkKSB7XG4gICAgc2Vzc2lvbi5kaWQgPSBgJHtjb250ZXh0LmRpZH1gO1xuICB9XG4gIGlmICh0eXBlb2YgY29udGV4dC5zdGFydGVkID09PSAnbnVtYmVyJykge1xuICAgIHNlc3Npb24uc3RhcnRlZCA9IGNvbnRleHQuc3RhcnRlZDtcbiAgfVxuICBpZiAoc2Vzc2lvbi5pZ25vcmVEdXJhdGlvbikge1xuICAgIHNlc3Npb24uZHVyYXRpb24gPSB1bmRlZmluZWQ7XG4gIH0gZWxzZSBpZiAodHlwZW9mIGNvbnRleHQuZHVyYXRpb24gPT09ICdudW1iZXInKSB7XG4gICAgc2Vzc2lvbi5kdXJhdGlvbiA9IGNvbnRleHQuZHVyYXRpb247XG4gIH0gZWxzZSB7XG4gICAgY29uc3QgZHVyYXRpb24gPSBzZXNzaW9uLnRpbWVzdGFtcCAtIHNlc3Npb24uc3RhcnRlZDtcbiAgICBzZXNzaW9uLmR1cmF0aW9uID0gZHVyYXRpb24gPj0gMCA/IGR1cmF0aW9uIDogMDtcbiAgfVxuICBpZiAoY29udGV4dC5yZWxlYXNlKSB7XG4gICAgc2Vzc2lvbi5yZWxlYXNlID0gY29udGV4dC5yZWxlYXNlO1xuICB9XG4gIGlmIChjb250ZXh0LmVudmlyb25tZW50KSB7XG4gICAgc2Vzc2lvbi5lbnZpcm9ubWVudCA9IGNvbnRleHQuZW52aXJvbm1lbnQ7XG4gIH1cbiAgaWYgKCFzZXNzaW9uLmlwQWRkcmVzcyAmJiBjb250ZXh0LmlwQWRkcmVzcykge1xuICAgIHNlc3Npb24uaXBBZGRyZXNzID0gY29udGV4dC5pcEFkZHJlc3M7XG4gIH1cbiAgaWYgKCFzZXNzaW9uLnVzZXJBZ2VudCAmJiBjb250ZXh0LnVzZXJBZ2VudCkge1xuICAgIHNlc3Npb24udXNlckFnZW50ID0gY29udGV4dC51c2VyQWdlbnQ7XG4gIH1cbiAgaWYgKHR5cGVvZiBjb250ZXh0LmVycm9ycyA9PT0gJ251bWJlcicpIHtcbiAgICBzZXNzaW9uLmVycm9ycyA9IGNvbnRleHQuZXJyb3JzO1xuICB9XG4gIGlmIChjb250ZXh0LnN0YXR1cykge1xuICAgIHNlc3Npb24uc3RhdHVzID0gY29udGV4dC5zdGF0dXM7XG4gIH1cbn1cblxuLyoqXG4gKiBDbG9zZXMgYSBzZXNzaW9uIGJ5IHNldHRpbmcgaXRzIHN0YXR1cyBhbmQgdXBkYXRpbmcgdGhlIHNlc3Npb24gb2JqZWN0IHdpdGggaXQuXG4gKiBJbnRlcm5hbGx5IGNhbGxzIGB1cGRhdGVTZXNzaW9uYCB0byB1cGRhdGUgdGhlIHBhc3NlZCBzZXNzaW9uIG9iamVjdC5cbiAqXG4gKiBOb3RlIHRoYXQgdGhpcyBmdW5jdGlvbiBtdXRhdGVzIHRoZSBwYXNzZWQgc2Vzc2lvbiAoQHNlZSB1cGRhdGVTZXNzaW9uIGZvciBleHBsYW5hdGlvbikuXG4gKlxuICogQHBhcmFtIHNlc3Npb24gdGhlIGBTZXNzaW9uYCBvYmplY3QgdG8gYmUgY2xvc2VkXG4gKiBAcGFyYW0gc3RhdHVzIHRoZSBgU2Vzc2lvblN0YXR1c2Agd2l0aCB3aGljaCB0aGUgc2Vzc2lvbiB3YXMgY2xvc2VkLiBJZiB5b3UgZG9uJ3QgcGFzcyBhIHN0YXR1cyxcbiAqICAgICAgICAgICAgICAgdGhpcyBmdW5jdGlvbiB3aWxsIGtlZXAgdGhlIHByZXZpb3VzbHkgc2V0IHN0YXR1cywgdW5sZXNzIGl0IHdhcyBgJ29rJ2AgaW4gd2hpY2ggY2FzZVxuICogICAgICAgICAgICAgICBpdCBpcyBjaGFuZ2VkIHRvIGAnZXhpdGVkJ2AuXG4gKi9cbmZ1bmN0aW9uIGNsb3NlU2Vzc2lvbihzZXNzaW9uLCBzdGF0dXMpIHtcbiAgbGV0IGNvbnRleHQgPSB7fTtcbiAgaWYgKHN0YXR1cykge1xuICAgIGNvbnRleHQgPSB7IHN0YXR1cyB9O1xuICB9IGVsc2UgaWYgKHNlc3Npb24uc3RhdHVzID09PSAnb2snKSB7XG4gICAgY29udGV4dCA9IHsgc3RhdHVzOiAnZXhpdGVkJyB9O1xuICB9XG5cbiAgdXBkYXRlU2Vzc2lvbihzZXNzaW9uLCBjb250ZXh0KTtcbn1cblxuLyoqXG4gKiBTZXJpYWxpemVzIGEgcGFzc2VkIHNlc3Npb24gb2JqZWN0IHRvIGEgSlNPTiBvYmplY3Qgd2l0aCBhIHNsaWdodGx5IGRpZmZlcmVudCBzdHJ1Y3R1cmUuXG4gKiBUaGlzIGlzIG5lY2Vzc2FyeSBiZWNhdXNlIHRoZSBTZW50cnkgYmFja2VuZCByZXF1aXJlcyBhIHNsaWdodGx5IGRpZmZlcmVudCBzY2hlbWEgb2YgYSBzZXNzaW9uXG4gKiB0aGFuIHRoZSBvbmUgdGhlIEpTIFNES3MgdXNlIGludGVybmFsbHkuXG4gKlxuICogQHBhcmFtIHNlc3Npb24gdGhlIHNlc3Npb24gdG8gYmUgY29udmVydGVkXG4gKlxuICogQHJldHVybnMgYSBKU09OIG9iamVjdCBvZiB0aGUgcGFzc2VkIHNlc3Npb25cbiAqL1xuZnVuY3Rpb24gc2Vzc2lvblRvSlNPTihzZXNzaW9uKSB7XG4gIHJldHVybiB7XG4gICAgc2lkOiBgJHtzZXNzaW9uLnNpZH1gLFxuICAgIGluaXQ6IHNlc3Npb24uaW5pdCxcbiAgICAvLyBNYWtlIHN1cmUgdGhhdCBzZWMgaXMgY29udmVydGVkIHRvIG1zIGZvciBkYXRlIGNvbnN0cnVjdG9yXG4gICAgc3RhcnRlZDogbmV3IERhdGUoc2Vzc2lvbi5zdGFydGVkICogMTAwMCkudG9JU09TdHJpbmcoKSxcbiAgICB0aW1lc3RhbXA6IG5ldyBEYXRlKHNlc3Npb24udGltZXN0YW1wICogMTAwMCkudG9JU09TdHJpbmcoKSxcbiAgICBzdGF0dXM6IHNlc3Npb24uc3RhdHVzLFxuICAgIGVycm9yczogc2Vzc2lvbi5lcnJvcnMsXG4gICAgZGlkOiB0eXBlb2Ygc2Vzc2lvbi5kaWQgPT09ICdudW1iZXInIHx8IHR5cGVvZiBzZXNzaW9uLmRpZCA9PT0gJ3N0cmluZycgPyBgJHtzZXNzaW9uLmRpZH1gIDogdW5kZWZpbmVkLFxuICAgIGR1cmF0aW9uOiBzZXNzaW9uLmR1cmF0aW9uLFxuICAgIGFibm9ybWFsX21lY2hhbmlzbTogc2Vzc2lvbi5hYm5vcm1hbF9tZWNoYW5pc20sXG4gICAgYXR0cnM6IHtcbiAgICAgIHJlbGVhc2U6IHNlc3Npb24ucmVsZWFzZSxcbiAgICAgIGVudmlyb25tZW50OiBzZXNzaW9uLmVudmlyb25tZW50LFxuICAgICAgaXBfYWRkcmVzczogc2Vzc2lvbi5pcEFkZHJlc3MsXG4gICAgICB1c2VyX2FnZW50OiBzZXNzaW9uLnVzZXJBZ2VudCxcbiAgICB9LFxuICB9O1xufVxuXG5leHBvcnRzLmNsb3NlU2Vzc2lvbiA9IGNsb3NlU2Vzc2lvbjtcbmV4cG9ydHMubWFrZVNlc3Npb24gPSBtYWtlU2Vzc2lvbjtcbmV4cG9ydHMudXBkYXRlU2Vzc2lvbiA9IHVwZGF0ZVNlc3Npb247XG4vLyMgc291cmNlTWFwcGluZ1VSTD1zZXNzaW9uLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/session.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/dynamicSamplingContext.js":
/*!**********************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/dynamicSamplingContext.js ***!
  \**********************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst constants = __webpack_require__(/*! ../constants.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/constants.js\");\nconst currentScopes = __webpack_require__(/*! ../currentScopes.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst semanticAttributes = __webpack_require__(/*! ../semanticAttributes.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/semanticAttributes.js\");\nconst baggage = __webpack_require__(/*! ../utils/baggage.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/baggage.js\");\nconst dsn = __webpack_require__(/*! ../utils/dsn.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/dsn.js\");\nconst hasSpansEnabled = __webpack_require__(/*! ../utils/hasSpansEnabled.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/hasSpansEnabled.js\");\nconst object = __webpack_require__(/*! ../utils/object.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/object.js\");\nconst spanUtils = __webpack_require__(/*! ../utils/spanUtils.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanUtils.js\");\nconst utils = __webpack_require__(/*! ./utils.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/utils.js\");\n\n/**\n * If you change this value, also update the terser plugin config to\n * avoid minification of the object property!\n */\nconst FROZEN_DSC_FIELD = '_frozenDsc';\n\n/**\n * Freeze the given DSC on the given span.\n */\nfunction freezeDscOnSpan(span, dsc) {\n  const spanWithMaybeDsc = span ;\n  object.addNonEnumerableProperty(spanWithMaybeDsc, FROZEN_DSC_FIELD, dsc);\n}\n\n/**\n * Creates a dynamic sampling context from a client.\n *\n * Dispatches the `createDsc` lifecycle hook as a side effect.\n */\nfunction getDynamicSamplingContextFromClient(trace_id, client) {\n  const options = client.getOptions();\n\n  const { publicKey: public_key, host } = client.getDsn() || {};\n\n  let org_id;\n  if (options.orgId) {\n    org_id = String(options.orgId);\n  } else if (host) {\n    org_id = dsn.extractOrgIdFromDsnHost(host);\n  }\n\n  // Instead of conditionally adding non-undefined values, we add them and then remove them if needed\n  // otherwise, the order of baggage entries changes, which \"breaks\" a bunch of tests etc.\n  const dsc = {\n    environment: options.environment || constants.DEFAULT_ENVIRONMENT,\n    release: options.release,\n    public_key,\n    trace_id,\n    org_id,\n  };\n\n  client.emit('createDsc', dsc);\n\n  return dsc;\n}\n\n/**\n * Get the dynamic sampling context for the currently active scopes.\n */\nfunction getDynamicSamplingContextFromScope(client, scope) {\n  const propagationContext = scope.getPropagationContext();\n  return propagationContext.dsc || getDynamicSamplingContextFromClient(propagationContext.traceId, client);\n}\n\n/**\n * Creates a dynamic sampling context from a span (and client and scope)\n *\n * @param span the span from which a few values like the root span name and sample rate are extracted.\n *\n * @returns a dynamic sampling context\n */\nfunction getDynamicSamplingContextFromSpan(span) {\n  const client = currentScopes.getClient();\n  if (!client) {\n    return {};\n  }\n\n  const rootSpan = spanUtils.getRootSpan(span);\n  const rootSpanJson = spanUtils.spanToJSON(rootSpan);\n  const rootSpanAttributes = rootSpanJson.data;\n  const traceState = rootSpan.spanContext().traceState;\n\n  // The span sample rate that was locally applied to the root span should also always be applied to the DSC, even if the DSC is frozen.\n  // This is so that the downstream traces/services can use parentSampleRate in their `tracesSampler` to make consistent sampling decisions across the entire trace.\n  const rootSpanSampleRate =\n    traceState?.get('sentry.sample_rate') ??\n    rootSpanAttributes[semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_SAMPLE_RATE] ??\n    rootSpanAttributes[semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_PREVIOUS_TRACE_SAMPLE_RATE];\n\n  function applyLocalSampleRateToDsc(dsc) {\n    if (typeof rootSpanSampleRate === 'number' || typeof rootSpanSampleRate === 'string') {\n      dsc.sample_rate = `${rootSpanSampleRate}`;\n    }\n    return dsc;\n  }\n\n  // For core implementation, we freeze the DSC onto the span as a non-enumerable property\n  const frozenDsc = (rootSpan )[FROZEN_DSC_FIELD];\n  if (frozenDsc) {\n    return applyLocalSampleRateToDsc(frozenDsc);\n  }\n\n  // For OpenTelemetry, we freeze the DSC on the trace state\n  const traceStateDsc = traceState?.get('sentry.dsc');\n\n  // If the span has a DSC, we want it to take precedence\n  const dscOnTraceState = traceStateDsc && baggage.baggageHeaderToDynamicSamplingContext(traceStateDsc);\n\n  if (dscOnTraceState) {\n    return applyLocalSampleRateToDsc(dscOnTraceState);\n  }\n\n  // Else, we generate it from the span\n  const dsc = getDynamicSamplingContextFromClient(span.spanContext().traceId, client);\n\n  // We don't want to have a transaction name in the DSC if the source is \"url\" because URLs might contain PII\n  const source = rootSpanAttributes[semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_SOURCE];\n\n  // after JSON conversion, txn.name becomes jsonSpan.description\n  const name = rootSpanJson.description;\n  if (source !== 'url' && name) {\n    dsc.transaction = name;\n  }\n\n  // How can we even land here with hasSpansEnabled() returning false?\n  // Otel creates a Non-recording span in Tracing Without Performance mode when handling incoming requests\n  // So we end up with an active span that is not sampled (neither positively nor negatively)\n  if (hasSpansEnabled.hasSpansEnabled()) {\n    dsc.sampled = String(spanUtils.spanIsSampled(rootSpan));\n    dsc.sample_rand =\n      // In OTEL we store the sample rand on the trace state because we cannot access scopes for NonRecordingSpans\n      // The Sentry OTEL SpanSampler takes care of writing the sample rand on the root span\n      traceState?.get('sentry.sample_rand') ??\n      // On all other platforms we can actually get the scopes from a root span (we use this as a fallback)\n      utils.getCapturedScopesOnSpan(rootSpan).scope?.getPropagationContext().sampleRand.toString();\n  }\n\n  applyLocalSampleRateToDsc(dsc);\n\n  client.emit('createDsc', dsc, rootSpan);\n\n  return dsc;\n}\n\n/**\n * Convert a Span to a baggage header.\n */\nfunction spanToBaggageHeader(span) {\n  const dsc = getDynamicSamplingContextFromSpan(span);\n  return baggage.dynamicSamplingContextToSentryBaggageHeader(dsc);\n}\n\nexports.freezeDscOnSpan = freezeDscOnSpan;\nexports.getDynamicSamplingContextFromClient = getDynamicSamplingContextFromClient;\nexports.getDynamicSamplingContextFromScope = getDynamicSamplingContextFromScope;\nexports.getDynamicSamplingContextFromSpan = getDynamicSamplingContextFromSpan;\nexports.spanToBaggageHeader = spanToBaggageHeader;\n//# sourceMappingURL=dynamicSamplingContext.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy90cmFjaW5nL2R5bmFtaWNTYW1wbGluZ0NvbnRleHQuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsa0JBQWtCLG1CQUFPLENBQUMsd0hBQWlCO0FBQzNDLHNCQUFzQixtQkFBTyxDQUFDLGdJQUFxQjtBQUNuRCwyQkFBMkIsbUJBQU8sQ0FBQywwSUFBMEI7QUFDN0QsZ0JBQWdCLG1CQUFPLENBQUMsZ0lBQXFCO0FBQzdDLFlBQVksbUJBQU8sQ0FBQyx3SEFBaUI7QUFDckMsd0JBQXdCLG1CQUFPLENBQUMsZ0pBQTZCO0FBQzdELGVBQWUsbUJBQU8sQ0FBQyw4SEFBb0I7QUFDM0Msa0JBQWtCLG1CQUFPLENBQUMsb0lBQXVCO0FBQ2pELGNBQWMsbUJBQU8sQ0FBQyx1SEFBWTs7QUFFbEM7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSxVQUFVLDhCQUE4Qjs7QUFFeEM7QUFDQTtBQUNBO0FBQ0EsSUFBSTtBQUNKO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsMkJBQTJCLG1CQUFtQjtBQUM5QztBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLHVCQUF1QjtBQUN2QiwyQ0FBMkM7QUFDM0MsMENBQTBDO0FBQzFDLHlDQUF5QztBQUN6QywyQkFBMkI7QUFDM0IiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy90cmFjaW5nL2R5bmFtaWNTYW1wbGluZ0NvbnRleHQuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGNvbnN0YW50cyA9IHJlcXVpcmUoJy4uL2NvbnN0YW50cy5qcycpO1xuY29uc3QgY3VycmVudFNjb3BlcyA9IHJlcXVpcmUoJy4uL2N1cnJlbnRTY29wZXMuanMnKTtcbmNvbnN0IHNlbWFudGljQXR0cmlidXRlcyA9IHJlcXVpcmUoJy4uL3NlbWFudGljQXR0cmlidXRlcy5qcycpO1xuY29uc3QgYmFnZ2FnZSA9IHJlcXVpcmUoJy4uL3V0aWxzL2JhZ2dhZ2UuanMnKTtcbmNvbnN0IGRzbiA9IHJlcXVpcmUoJy4uL3V0aWxzL2Rzbi5qcycpO1xuY29uc3QgaGFzU3BhbnNFbmFibGVkID0gcmVxdWlyZSgnLi4vdXRpbHMvaGFzU3BhbnNFbmFibGVkLmpzJyk7XG5jb25zdCBvYmplY3QgPSByZXF1aXJlKCcuLi91dGlscy9vYmplY3QuanMnKTtcbmNvbnN0IHNwYW5VdGlscyA9IHJlcXVpcmUoJy4uL3V0aWxzL3NwYW5VdGlscy5qcycpO1xuY29uc3QgdXRpbHMgPSByZXF1aXJlKCcuL3V0aWxzLmpzJyk7XG5cbi8qKlxuICogSWYgeW91IGNoYW5nZSB0aGlzIHZhbHVlLCBhbHNvIHVwZGF0ZSB0aGUgdGVyc2VyIHBsdWdpbiBjb25maWcgdG9cbiAqIGF2b2lkIG1pbmlmaWNhdGlvbiBvZiB0aGUgb2JqZWN0IHByb3BlcnR5IVxuICovXG5jb25zdCBGUk9aRU5fRFNDX0ZJRUxEID0gJ19mcm96ZW5Ec2MnO1xuXG4vKipcbiAqIEZyZWV6ZSB0aGUgZ2l2ZW4gRFNDIG9uIHRoZSBnaXZlbiBzcGFuLlxuICovXG5mdW5jdGlvbiBmcmVlemVEc2NPblNwYW4oc3BhbiwgZHNjKSB7XG4gIGNvbnN0IHNwYW5XaXRoTWF5YmVEc2MgPSBzcGFuIDtcbiAgb2JqZWN0LmFkZE5vbkVudW1lcmFibGVQcm9wZXJ0eShzcGFuV2l0aE1heWJlRHNjLCBGUk9aRU5fRFNDX0ZJRUxELCBkc2MpO1xufVxuXG4vKipcbiAqIENyZWF0ZXMgYSBkeW5hbWljIHNhbXBsaW5nIGNvbnRleHQgZnJvbSBhIGNsaWVudC5cbiAqXG4gKiBEaXNwYXRjaGVzIHRoZSBgY3JlYXRlRHNjYCBsaWZlY3ljbGUgaG9vayBhcyBhIHNpZGUgZWZmZWN0LlxuICovXG5mdW5jdGlvbiBnZXREeW5hbWljU2FtcGxpbmdDb250ZXh0RnJvbUNsaWVudCh0cmFjZV9pZCwgY2xpZW50KSB7XG4gIGNvbnN0IG9wdGlvbnMgPSBjbGllbnQuZ2V0T3B0aW9ucygpO1xuXG4gIGNvbnN0IHsgcHVibGljS2V5OiBwdWJsaWNfa2V5LCBob3N0IH0gPSBjbGllbnQuZ2V0RHNuKCkgfHwge307XG5cbiAgbGV0IG9yZ19pZDtcbiAgaWYgKG9wdGlvbnMub3JnSWQpIHtcbiAgICBvcmdfaWQgPSBTdHJpbmcob3B0aW9ucy5vcmdJZCk7XG4gIH0gZWxzZSBpZiAoaG9zdCkge1xuICAgIG9yZ19pZCA9IGRzbi5leHRyYWN0T3JnSWRGcm9tRHNuSG9zdChob3N0KTtcbiAgfVxuXG4gIC8vIEluc3RlYWQgb2YgY29uZGl0aW9uYWxseSBhZGRpbmcgbm9uLXVuZGVmaW5lZCB2YWx1ZXMsIHdlIGFkZCB0aGVtIGFuZCB0aGVuIHJlbW92ZSB0aGVtIGlmIG5lZWRlZFxuICAvLyBvdGhlcndpc2UsIHRoZSBvcmRlciBvZiBiYWdnYWdlIGVudHJpZXMgY2hhbmdlcywgd2hpY2ggXCJicmVha3NcIiBhIGJ1bmNoIG9mIHRlc3RzIGV0Yy5cbiAgY29uc3QgZHNjID0ge1xuICAgIGVudmlyb25tZW50OiBvcHRpb25zLmVudmlyb25tZW50IHx8IGNvbnN0YW50cy5ERUZBVUxUX0VOVklST05NRU5ULFxuICAgIHJlbGVhc2U6IG9wdGlvbnMucmVsZWFzZSxcbiAgICBwdWJsaWNfa2V5LFxuICAgIHRyYWNlX2lkLFxuICAgIG9yZ19pZCxcbiAgfTtcblxuICBjbGllbnQuZW1pdCgnY3JlYXRlRHNjJywgZHNjKTtcblxuICByZXR1cm4gZHNjO1xufVxuXG4vKipcbiAqIEdldCB0aGUgZHluYW1pYyBzYW1wbGluZyBjb250ZXh0IGZvciB0aGUgY3VycmVudGx5IGFjdGl2ZSBzY29wZXMuXG4gKi9cbmZ1bmN0aW9uIGdldER5bmFtaWNTYW1wbGluZ0NvbnRleHRGcm9tU2NvcGUoY2xpZW50LCBzY29wZSkge1xuICBjb25zdCBwcm9wYWdhdGlvbkNvbnRleHQgPSBzY29wZS5nZXRQcm9wYWdhdGlvbkNvbnRleHQoKTtcbiAgcmV0dXJuIHByb3BhZ2F0aW9uQ29udGV4dC5kc2MgfHwgZ2V0RHluYW1pY1NhbXBsaW5nQ29udGV4dEZyb21DbGllbnQocHJvcGFnYXRpb25Db250ZXh0LnRyYWNlSWQsIGNsaWVudCk7XG59XG5cbi8qKlxuICogQ3JlYXRlcyBhIGR5bmFtaWMgc2FtcGxpbmcgY29udGV4dCBmcm9tIGEgc3BhbiAoYW5kIGNsaWVudCBhbmQgc2NvcGUpXG4gKlxuICogQHBhcmFtIHNwYW4gdGhlIHNwYW4gZnJvbSB3aGljaCBhIGZldyB2YWx1ZXMgbGlrZSB0aGUgcm9vdCBzcGFuIG5hbWUgYW5kIHNhbXBsZSByYXRlIGFyZSBleHRyYWN0ZWQuXG4gKlxuICogQHJldHVybnMgYSBkeW5hbWljIHNhbXBsaW5nIGNvbnRleHRcbiAqL1xuZnVuY3Rpb24gZ2V0RHluYW1pY1NhbXBsaW5nQ29udGV4dEZyb21TcGFuKHNwYW4pIHtcbiAgY29uc3QgY2xpZW50ID0gY3VycmVudFNjb3Blcy5nZXRDbGllbnQoKTtcbiAgaWYgKCFjbGllbnQpIHtcbiAgICByZXR1cm4ge307XG4gIH1cblxuICBjb25zdCByb290U3BhbiA9IHNwYW5VdGlscy5nZXRSb290U3BhbihzcGFuKTtcbiAgY29uc3Qgcm9vdFNwYW5Kc29uID0gc3BhblV0aWxzLnNwYW5Ub0pTT04ocm9vdFNwYW4pO1xuICBjb25zdCByb290U3BhbkF0dHJpYnV0ZXMgPSByb290U3Bhbkpzb24uZGF0YTtcbiAgY29uc3QgdHJhY2VTdGF0ZSA9IHJvb3RTcGFuLnNwYW5Db250ZXh0KCkudHJhY2VTdGF0ZTtcblxuICAvLyBUaGUgc3BhbiBzYW1wbGUgcmF0ZSB0aGF0IHdhcyBsb2NhbGx5IGFwcGxpZWQgdG8gdGhlIHJvb3Qgc3BhbiBzaG91bGQgYWxzbyBhbHdheXMgYmUgYXBwbGllZCB0byB0aGUgRFNDLCBldmVuIGlmIHRoZSBEU0MgaXMgZnJvemVuLlxuICAvLyBUaGlzIGlzIHNvIHRoYXQgdGhlIGRvd25zdHJlYW0gdHJhY2VzL3NlcnZpY2VzIGNhbiB1c2UgcGFyZW50U2FtcGxlUmF0ZSBpbiB0aGVpciBgdHJhY2VzU2FtcGxlcmAgdG8gbWFrZSBjb25zaXN0ZW50IHNhbXBsaW5nIGRlY2lzaW9ucyBhY3Jvc3MgdGhlIGVudGlyZSB0cmFjZS5cbiAgY29uc3Qgcm9vdFNwYW5TYW1wbGVSYXRlID1cbiAgICB0cmFjZVN0YXRlPy5nZXQoJ3NlbnRyeS5zYW1wbGVfcmF0ZScpID8/XG4gICAgcm9vdFNwYW5BdHRyaWJ1dGVzW3NlbWFudGljQXR0cmlidXRlcy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX1NBTVBMRV9SQVRFXSA/P1xuICAgIHJvb3RTcGFuQXR0cmlidXRlc1tzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9QUkVWSU9VU19UUkFDRV9TQU1QTEVfUkFURV07XG5cbiAgZnVuY3Rpb24gYXBwbHlMb2NhbFNhbXBsZVJhdGVUb0RzYyhkc2MpIHtcbiAgICBpZiAodHlwZW9mIHJvb3RTcGFuU2FtcGxlUmF0ZSA9PT0gJ251bWJlcicgfHwgdHlwZW9mIHJvb3RTcGFuU2FtcGxlUmF0ZSA9PT0gJ3N0cmluZycpIHtcbiAgICAgIGRzYy5zYW1wbGVfcmF0ZSA9IGAke3Jvb3RTcGFuU2FtcGxlUmF0ZX1gO1xuICAgIH1cbiAgICByZXR1cm4gZHNjO1xuICB9XG5cbiAgLy8gRm9yIGNvcmUgaW1wbGVtZW50YXRpb24sIHdlIGZyZWV6ZSB0aGUgRFNDIG9udG8gdGhlIHNwYW4gYXMgYSBub24tZW51bWVyYWJsZSBwcm9wZXJ0eVxuICBjb25zdCBmcm96ZW5Ec2MgPSAocm9vdFNwYW4gKVtGUk9aRU5fRFNDX0ZJRUxEXTtcbiAgaWYgKGZyb3plbkRzYykge1xuICAgIHJldHVybiBhcHBseUxvY2FsU2FtcGxlUmF0ZVRvRHNjKGZyb3plbkRzYyk7XG4gIH1cblxuICAvLyBGb3IgT3BlblRlbGVtZXRyeSwgd2UgZnJlZXplIHRoZSBEU0Mgb24gdGhlIHRyYWNlIHN0YXRlXG4gIGNvbnN0IHRyYWNlU3RhdGVEc2MgPSB0cmFjZVN0YXRlPy5nZXQoJ3NlbnRyeS5kc2MnKTtcblxuICAvLyBJZiB0aGUgc3BhbiBoYXMgYSBEU0MsIHdlIHdhbnQgaXQgdG8gdGFrZSBwcmVjZWRlbmNlXG4gIGNvbnN0IGRzY09uVHJhY2VTdGF0ZSA9IHRyYWNlU3RhdGVEc2MgJiYgYmFnZ2FnZS5iYWdnYWdlSGVhZGVyVG9EeW5hbWljU2FtcGxpbmdDb250ZXh0KHRyYWNlU3RhdGVEc2MpO1xuXG4gIGlmIChkc2NPblRyYWNlU3RhdGUpIHtcbiAgICByZXR1cm4gYXBwbHlMb2NhbFNhbXBsZVJhdGVUb0RzYyhkc2NPblRyYWNlU3RhdGUpO1xuICB9XG5cbiAgLy8gRWxzZSwgd2UgZ2VuZXJhdGUgaXQgZnJvbSB0aGUgc3BhblxuICBjb25zdCBkc2MgPSBnZXREeW5hbWljU2FtcGxpbmdDb250ZXh0RnJvbUNsaWVudChzcGFuLnNwYW5Db250ZXh0KCkudHJhY2VJZCwgY2xpZW50KTtcblxuICAvLyBXZSBkb24ndCB3YW50IHRvIGhhdmUgYSB0cmFuc2FjdGlvbiBuYW1lIGluIHRoZSBEU0MgaWYgdGhlIHNvdXJjZSBpcyBcInVybFwiIGJlY2F1c2UgVVJMcyBtaWdodCBjb250YWluIFBJSVxuICBjb25zdCBzb3VyY2UgPSByb290U3BhbkF0dHJpYnV0ZXNbc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfU09VUkNFXTtcblxuICAvLyBhZnRlciBKU09OIGNvbnZlcnNpb24sIHR4bi5uYW1lIGJlY29tZXMganNvblNwYW4uZGVzY3JpcHRpb25cbiAgY29uc3QgbmFtZSA9IHJvb3RTcGFuSnNvbi5kZXNjcmlwdGlvbjtcbiAgaWYgKHNvdXJjZSAhPT0gJ3VybCcgJiYgbmFtZSkge1xuICAgIGRzYy50cmFuc2FjdGlvbiA9IG5hbWU7XG4gIH1cblxuICAvLyBIb3cgY2FuIHdlIGV2ZW4gbGFuZCBoZXJlIHdpdGggaGFzU3BhbnNFbmFibGVkKCkgcmV0dXJuaW5nIGZhbHNlP1xuICAvLyBPdGVsIGNyZWF0ZXMgYSBOb24tcmVjb3JkaW5nIHNwYW4gaW4gVHJhY2luZyBXaXRob3V0IFBlcmZvcm1hbmNlIG1vZGUgd2hlbiBoYW5kbGluZyBpbmNvbWluZyByZXF1ZXN0c1xuICAvLyBTbyB3ZSBlbmQgdXAgd2l0aCBhbiBhY3RpdmUgc3BhbiB0aGF0IGlzIG5vdCBzYW1wbGVkIChuZWl0aGVyIHBvc2l0aXZlbHkgbm9yIG5lZ2F0aXZlbHkpXG4gIGlmIChoYXNTcGFuc0VuYWJsZWQuaGFzU3BhbnNFbmFibGVkKCkpIHtcbiAgICBkc2Muc2FtcGxlZCA9IFN0cmluZyhzcGFuVXRpbHMuc3BhbklzU2FtcGxlZChyb290U3BhbikpO1xuICAgIGRzYy5zYW1wbGVfcmFuZCA9XG4gICAgICAvLyBJbiBPVEVMIHdlIHN0b3JlIHRoZSBzYW1wbGUgcmFuZCBvbiB0aGUgdHJhY2Ugc3RhdGUgYmVjYXVzZSB3ZSBjYW5ub3QgYWNjZXNzIHNjb3BlcyBmb3IgTm9uUmVjb3JkaW5nU3BhbnNcbiAgICAgIC8vIFRoZSBTZW50cnkgT1RFTCBTcGFuU2FtcGxlciB0YWtlcyBjYXJlIG9mIHdyaXRpbmcgdGhlIHNhbXBsZSByYW5kIG9uIHRoZSByb290IHNwYW5cbiAgICAgIHRyYWNlU3RhdGU/LmdldCgnc2VudHJ5LnNhbXBsZV9yYW5kJykgPz9cbiAgICAgIC8vIE9uIGFsbCBvdGhlciBwbGF0Zm9ybXMgd2UgY2FuIGFjdHVhbGx5IGdldCB0aGUgc2NvcGVzIGZyb20gYSByb290IHNwYW4gKHdlIHVzZSB0aGlzIGFzIGEgZmFsbGJhY2spXG4gICAgICB1dGlscy5nZXRDYXB0dXJlZFNjb3Blc09uU3Bhbihyb290U3Bhbikuc2NvcGU/LmdldFByb3BhZ2F0aW9uQ29udGV4dCgpLnNhbXBsZVJhbmQudG9TdHJpbmcoKTtcbiAgfVxuXG4gIGFwcGx5TG9jYWxTYW1wbGVSYXRlVG9Ec2MoZHNjKTtcblxuICBjbGllbnQuZW1pdCgnY3JlYXRlRHNjJywgZHNjLCByb290U3Bhbik7XG5cbiAgcmV0dXJuIGRzYztcbn1cblxuLyoqXG4gKiBDb252ZXJ0IGEgU3BhbiB0byBhIGJhZ2dhZ2UgaGVhZGVyLlxuICovXG5mdW5jdGlvbiBzcGFuVG9CYWdnYWdlSGVhZGVyKHNwYW4pIHtcbiAgY29uc3QgZHNjID0gZ2V0RHluYW1pY1NhbXBsaW5nQ29udGV4dEZyb21TcGFuKHNwYW4pO1xuICByZXR1cm4gYmFnZ2FnZS5keW5hbWljU2FtcGxpbmdDb250ZXh0VG9TZW50cnlCYWdnYWdlSGVhZGVyKGRzYyk7XG59XG5cbmV4cG9ydHMuZnJlZXplRHNjT25TcGFuID0gZnJlZXplRHNjT25TcGFuO1xuZXhwb3J0cy5nZXREeW5hbWljU2FtcGxpbmdDb250ZXh0RnJvbUNsaWVudCA9IGdldER5bmFtaWNTYW1wbGluZ0NvbnRleHRGcm9tQ2xpZW50O1xuZXhwb3J0cy5nZXREeW5hbWljU2FtcGxpbmdDb250ZXh0RnJvbVNjb3BlID0gZ2V0RHluYW1pY1NhbXBsaW5nQ29udGV4dEZyb21TY29wZTtcbmV4cG9ydHMuZ2V0RHluYW1pY1NhbXBsaW5nQ29udGV4dEZyb21TcGFuID0gZ2V0RHluYW1pY1NhbXBsaW5nQ29udGV4dEZyb21TcGFuO1xuZXhwb3J0cy5zcGFuVG9CYWdnYWdlSGVhZGVyID0gc3BhblRvQmFnZ2FnZUhlYWRlcjtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWR5bmFtaWNTYW1wbGluZ0NvbnRleHQuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/dynamicSamplingContext.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/errors.js":
/*!******************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/errors.js ***!
  \******************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst debugBuild = __webpack_require__(/*! ../debug-build.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst globalError = __webpack_require__(/*! ../instrument/globalError.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/globalError.js\");\nconst globalUnhandledRejection = __webpack_require__(/*! ../instrument/globalUnhandledRejection.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/globalUnhandledRejection.js\");\nconst debugLogger = __webpack_require__(/*! ../utils/debug-logger.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst spanUtils = __webpack_require__(/*! ../utils/spanUtils.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanUtils.js\");\nconst spanstatus = __webpack_require__(/*! ./spanstatus.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/spanstatus.js\");\n\nlet errorsInstrumented = false;\n\n/**\n * Ensure that global errors automatically set the active span status.\n */\nfunction registerSpanErrorInstrumentation() {\n  if (errorsInstrumented) {\n    return;\n  }\n\n  /**\n   * If an error or unhandled promise occurs, we mark the active root span as failed\n   */\n  function errorCallback() {\n    const activeSpan = spanUtils.getActiveSpan();\n    const rootSpan = activeSpan && spanUtils.getRootSpan(activeSpan);\n    if (rootSpan) {\n      const message = 'internal_error';\n      debugBuild.DEBUG_BUILD && debugLogger.debug.log(`[Tracing] Root span: ${message} -> Global error occurred`);\n      rootSpan.setStatus({ code: spanstatus.SPAN_STATUS_ERROR, message });\n    }\n  }\n\n  // The function name will be lost when bundling but we need to be able to identify this listener later to maintain the\n  // node.js default exit behaviour\n  errorCallback.tag = 'sentry_tracingErrorCallback';\n\n  errorsInstrumented = true;\n  globalError.addGlobalErrorInstrumentationHandler(errorCallback);\n  globalUnhandledRejection.addGlobalUnhandledRejectionInstrumentationHandler(errorCallback);\n}\n\nexports.registerSpanErrorInstrumentation = registerSpanErrorInstrumentation;\n//# sourceMappingURL=errors.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy90cmFjaW5nL2Vycm9ycy5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxtQkFBbUIsbUJBQU8sQ0FBQyw0SEFBbUI7QUFDOUMsb0JBQW9CLG1CQUFPLENBQUMsa0pBQThCO0FBQzFELGlDQUFpQyxtQkFBTyxDQUFDLDRLQUEyQztBQUNwRixvQkFBb0IsbUJBQU8sQ0FBQywwSUFBMEI7QUFDdEQsa0JBQWtCLG1CQUFPLENBQUMsb0lBQXVCO0FBQ2pELG1CQUFtQixtQkFBTyxDQUFDLGlJQUFpQjs7QUFFNUM7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLDhFQUE4RSxTQUFTO0FBQ3ZGLDJCQUEyQiw2Q0FBNkM7QUFDeEU7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsd0NBQXdDO0FBQ3hDIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdHJhY2luZy9lcnJvcnMuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGRlYnVnQnVpbGQgPSByZXF1aXJlKCcuLi9kZWJ1Zy1idWlsZC5qcycpO1xuY29uc3QgZ2xvYmFsRXJyb3IgPSByZXF1aXJlKCcuLi9pbnN0cnVtZW50L2dsb2JhbEVycm9yLmpzJyk7XG5jb25zdCBnbG9iYWxVbmhhbmRsZWRSZWplY3Rpb24gPSByZXF1aXJlKCcuLi9pbnN0cnVtZW50L2dsb2JhbFVuaGFuZGxlZFJlamVjdGlvbi5qcycpO1xuY29uc3QgZGVidWdMb2dnZXIgPSByZXF1aXJlKCcuLi91dGlscy9kZWJ1Zy1sb2dnZXIuanMnKTtcbmNvbnN0IHNwYW5VdGlscyA9IHJlcXVpcmUoJy4uL3V0aWxzL3NwYW5VdGlscy5qcycpO1xuY29uc3Qgc3BhbnN0YXR1cyA9IHJlcXVpcmUoJy4vc3BhbnN0YXR1cy5qcycpO1xuXG5sZXQgZXJyb3JzSW5zdHJ1bWVudGVkID0gZmFsc2U7XG5cbi8qKlxuICogRW5zdXJlIHRoYXQgZ2xvYmFsIGVycm9ycyBhdXRvbWF0aWNhbGx5IHNldCB0aGUgYWN0aXZlIHNwYW4gc3RhdHVzLlxuICovXG5mdW5jdGlvbiByZWdpc3RlclNwYW5FcnJvckluc3RydW1lbnRhdGlvbigpIHtcbiAgaWYgKGVycm9yc0luc3RydW1lbnRlZCkge1xuICAgIHJldHVybjtcbiAgfVxuXG4gIC8qKlxuICAgKiBJZiBhbiBlcnJvciBvciB1bmhhbmRsZWQgcHJvbWlzZSBvY2N1cnMsIHdlIG1hcmsgdGhlIGFjdGl2ZSByb290IHNwYW4gYXMgZmFpbGVkXG4gICAqL1xuICBmdW5jdGlvbiBlcnJvckNhbGxiYWNrKCkge1xuICAgIGNvbnN0IGFjdGl2ZVNwYW4gPSBzcGFuVXRpbHMuZ2V0QWN0aXZlU3BhbigpO1xuICAgIGNvbnN0IHJvb3RTcGFuID0gYWN0aXZlU3BhbiAmJiBzcGFuVXRpbHMuZ2V0Um9vdFNwYW4oYWN0aXZlU3Bhbik7XG4gICAgaWYgKHJvb3RTcGFuKSB7XG4gICAgICBjb25zdCBtZXNzYWdlID0gJ2ludGVybmFsX2Vycm9yJztcbiAgICAgIGRlYnVnQnVpbGQuREVCVUdfQlVJTEQgJiYgZGVidWdMb2dnZXIuZGVidWcubG9nKGBbVHJhY2luZ10gUm9vdCBzcGFuOiAke21lc3NhZ2V9IC0+IEdsb2JhbCBlcnJvciBvY2N1cnJlZGApO1xuICAgICAgcm9vdFNwYW4uc2V0U3RhdHVzKHsgY29kZTogc3BhbnN0YXR1cy5TUEFOX1NUQVRVU19FUlJPUiwgbWVzc2FnZSB9KTtcbiAgICB9XG4gIH1cblxuICAvLyBUaGUgZnVuY3Rpb24gbmFtZSB3aWxsIGJlIGxvc3Qgd2hlbiBidW5kbGluZyBidXQgd2UgbmVlZCB0byBiZSBhYmxlIHRvIGlkZW50aWZ5IHRoaXMgbGlzdGVuZXIgbGF0ZXIgdG8gbWFpbnRhaW4gdGhlXG4gIC8vIG5vZGUuanMgZGVmYXVsdCBleGl0IGJlaGF2aW91clxuICBlcnJvckNhbGxiYWNrLnRhZyA9ICdzZW50cnlfdHJhY2luZ0Vycm9yQ2FsbGJhY2snO1xuXG4gIGVycm9yc0luc3RydW1lbnRlZCA9IHRydWU7XG4gIGdsb2JhbEVycm9yLmFkZEdsb2JhbEVycm9ySW5zdHJ1bWVudGF0aW9uSGFuZGxlcihlcnJvckNhbGxiYWNrKTtcbiAgZ2xvYmFsVW5oYW5kbGVkUmVqZWN0aW9uLmFkZEdsb2JhbFVuaGFuZGxlZFJlamVjdGlvbkluc3RydW1lbnRhdGlvbkhhbmRsZXIoZXJyb3JDYWxsYmFjayk7XG59XG5cbmV4cG9ydHMucmVnaXN0ZXJTcGFuRXJyb3JJbnN0cnVtZW50YXRpb24gPSByZWdpc3RlclNwYW5FcnJvckluc3RydW1lbnRhdGlvbjtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWVycm9ycy5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/errors.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/idleSpan.js":
/*!********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/idleSpan.js ***!
  \********************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst currentScopes = __webpack_require__(/*! ../currentScopes.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst debugBuild = __webpack_require__(/*! ../debug-build.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst semanticAttributes = __webpack_require__(/*! ../semanticAttributes.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/semanticAttributes.js\");\nconst debugLogger = __webpack_require__(/*! ../utils/debug-logger.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst hasSpansEnabled = __webpack_require__(/*! ../utils/hasSpansEnabled.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/hasSpansEnabled.js\");\nconst spanOnScope = __webpack_require__(/*! ../utils/spanOnScope.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanOnScope.js\");\nconst spanUtils = __webpack_require__(/*! ../utils/spanUtils.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanUtils.js\");\nconst time = __webpack_require__(/*! ../utils/time.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/time.js\");\nconst dynamicSamplingContext = __webpack_require__(/*! ./dynamicSamplingContext.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/dynamicSamplingContext.js\");\nconst sentryNonRecordingSpan = __webpack_require__(/*! ./sentryNonRecordingSpan.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/sentryNonRecordingSpan.js\");\nconst sentrySpan = __webpack_require__(/*! ./sentrySpan.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/sentrySpan.js\");\nconst spanstatus = __webpack_require__(/*! ./spanstatus.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/spanstatus.js\");\nconst trace = __webpack_require__(/*! ./trace.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/trace.js\");\n\nconst TRACING_DEFAULTS = {\n  idleTimeout: 1000,\n  finalTimeout: 30000,\n  childSpanTimeout: 15000,\n};\n\nconst FINISH_REASON_HEARTBEAT_FAILED = 'heartbeatFailed';\nconst FINISH_REASON_IDLE_TIMEOUT = 'idleTimeout';\nconst FINISH_REASON_FINAL_TIMEOUT = 'finalTimeout';\nconst FINISH_REASON_EXTERNAL_FINISH = 'externalFinish';\n\n/**\n * An idle span is a span that automatically finishes. It does this by tracking child spans as activities.\n * An idle span is always the active span.\n */\nfunction startIdleSpan(startSpanOptions, options = {}) {\n  // Activities store a list of active spans\n  const activities = new Map();\n\n  // We should not use heartbeat if we finished a span\n  let _finished = false;\n\n  // Timer that tracks idleTimeout\n  let _idleTimeoutID;\n\n  // The reason why the span was finished\n  let _finishReason = FINISH_REASON_EXTERNAL_FINISH;\n\n  let _autoFinishAllowed = !options.disableAutoFinish;\n\n  const _cleanupHooks = [];\n\n  const {\n    idleTimeout = TRACING_DEFAULTS.idleTimeout,\n    finalTimeout = TRACING_DEFAULTS.finalTimeout,\n    childSpanTimeout = TRACING_DEFAULTS.childSpanTimeout,\n    beforeSpanEnd,\n  } = options;\n\n  const client = currentScopes.getClient();\n\n  if (!client || !hasSpansEnabled.hasSpansEnabled()) {\n    const span = new sentryNonRecordingSpan.SentryNonRecordingSpan();\n\n    const dsc = {\n      sample_rate: '0',\n      sampled: 'false',\n      ...dynamicSamplingContext.getDynamicSamplingContextFromSpan(span),\n    } ;\n    dynamicSamplingContext.freezeDscOnSpan(span, dsc);\n\n    return span;\n  }\n\n  const scope = currentScopes.getCurrentScope();\n  const previousActiveSpan = spanUtils.getActiveSpan();\n  const span = _startIdleSpan(startSpanOptions);\n\n  // We patch span.end to ensure we can run some things before the span is ended\n  // eslint-disable-next-line @typescript-eslint/unbound-method\n  span.end = new Proxy(span.end, {\n    apply(target, thisArg, args) {\n      if (beforeSpanEnd) {\n        beforeSpanEnd(span);\n      }\n\n      // If the span is non-recording, nothing more to do here...\n      // This is the case if tracing is enabled but this specific span was not sampled\n      if (thisArg instanceof sentryNonRecordingSpan.SentryNonRecordingSpan) {\n        return;\n      }\n\n      // Just ensuring that this keeps working, even if we ever have more arguments here\n      const [definedEndTimestamp, ...rest] = args;\n      const timestamp = definedEndTimestamp || time.timestampInSeconds();\n      const spanEndTimestamp = spanUtils.spanTimeInputToSeconds(timestamp);\n\n      // Ensure we end with the last span timestamp, if possible\n      const spans = spanUtils.getSpanDescendants(span).filter(child => child !== span);\n\n      // If we have no spans, we just end, nothing else to do here\n      if (!spans.length) {\n        onIdleSpanEnded(spanEndTimestamp);\n        return Reflect.apply(target, thisArg, [spanEndTimestamp, ...rest]);\n      }\n\n      const childEndTimestamps = spans\n        .map(span => spanUtils.spanToJSON(span).timestamp)\n        .filter(timestamp => !!timestamp) ;\n      const latestSpanEndTimestamp = childEndTimestamps.length ? Math.max(...childEndTimestamps) : undefined;\n\n      // In reality this should always exist here, but type-wise it may be undefined...\n      const spanStartTimestamp = spanUtils.spanToJSON(span).start_timestamp;\n\n      // The final endTimestamp should:\n      // * Never be before the span start timestamp\n      // * Be the latestSpanEndTimestamp, if there is one, and it is smaller than the passed span end timestamp\n      // * Otherwise be the passed end timestamp\n      // Final timestamp can never be after finalTimeout\n      const endTimestamp = Math.min(\n        spanStartTimestamp ? spanStartTimestamp + finalTimeout / 1000 : Infinity,\n        Math.max(spanStartTimestamp || -Infinity, Math.min(spanEndTimestamp, latestSpanEndTimestamp || Infinity)),\n      );\n\n      onIdleSpanEnded(endTimestamp);\n      return Reflect.apply(target, thisArg, [endTimestamp, ...rest]);\n    },\n  });\n\n  /**\n   * Cancels the existing idle timeout, if there is one.\n   */\n  function _cancelIdleTimeout() {\n    if (_idleTimeoutID) {\n      clearTimeout(_idleTimeoutID);\n      _idleTimeoutID = undefined;\n    }\n  }\n\n  /**\n   * Restarts idle timeout, if there is no running idle timeout it will start one.\n   */\n  function _restartIdleTimeout(endTimestamp) {\n    _cancelIdleTimeout();\n    _idleTimeoutID = setTimeout(() => {\n      if (!_finished && activities.size === 0 && _autoFinishAllowed) {\n        _finishReason = FINISH_REASON_IDLE_TIMEOUT;\n        span.end(endTimestamp);\n      }\n    }, idleTimeout);\n  }\n\n  /**\n   * Restarts child span timeout, if there is none running it will start one.\n   */\n  function _restartChildSpanTimeout(endTimestamp) {\n    _idleTimeoutID = setTimeout(() => {\n      if (!_finished && _autoFinishAllowed) {\n        _finishReason = FINISH_REASON_HEARTBEAT_FAILED;\n        span.end(endTimestamp);\n      }\n    }, childSpanTimeout);\n  }\n\n  /**\n   * Start tracking a specific activity.\n   * @param spanId The span id that represents the activity\n   */\n  function _pushActivity(spanId) {\n    _cancelIdleTimeout();\n    activities.set(spanId, true);\n\n    const endTimestamp = time.timestampInSeconds();\n    // We need to add the timeout here to have the real endtimestamp of the idle span\n    // Remember timestampInSeconds is in seconds, timeout is in ms\n    _restartChildSpanTimeout(endTimestamp + childSpanTimeout / 1000);\n  }\n\n  /**\n   * Remove an activity from usage\n   * @param spanId The span id that represents the activity\n   */\n  function _popActivity(spanId) {\n    if (activities.has(spanId)) {\n      activities.delete(spanId);\n    }\n\n    if (activities.size === 0) {\n      const endTimestamp = time.timestampInSeconds();\n      // We need to add the timeout here to have the real endtimestamp of the idle span\n      // Remember timestampInSeconds is in seconds, timeout is in ms\n      _restartIdleTimeout(endTimestamp + idleTimeout / 1000);\n    }\n  }\n\n  function onIdleSpanEnded(endTimestamp) {\n    _finished = true;\n    activities.clear();\n\n    _cleanupHooks.forEach(cleanup => cleanup());\n\n    spanOnScope._setSpanForScope(scope, previousActiveSpan);\n\n    const spanJSON = spanUtils.spanToJSON(span);\n\n    const { start_timestamp: startTimestamp } = spanJSON;\n    // This should never happen, but to make TS happy...\n    if (!startTimestamp) {\n      return;\n    }\n\n    const attributes = spanJSON.data;\n    if (!attributes[semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_IDLE_SPAN_FINISH_REASON]) {\n      span.setAttribute(semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_IDLE_SPAN_FINISH_REASON, _finishReason);\n    }\n\n    debugLogger.debug.log(`[Tracing] Idle span \"${spanJSON.op}\" finished`);\n\n    const childSpans = spanUtils.getSpanDescendants(span).filter(child => child !== span);\n\n    let discardedSpans = 0;\n    childSpans.forEach(childSpan => {\n      // We cancel all pending spans with status \"cancelled\" to indicate the idle span was finished early\n      if (childSpan.isRecording()) {\n        childSpan.setStatus({ code: spanstatus.SPAN_STATUS_ERROR, message: 'cancelled' });\n        childSpan.end(endTimestamp);\n        debugBuild.DEBUG_BUILD &&\n          debugLogger.debug.log('[Tracing] Cancelling span since span ended early', JSON.stringify(childSpan, undefined, 2));\n      }\n\n      const childSpanJSON = spanUtils.spanToJSON(childSpan);\n      const { timestamp: childEndTimestamp = 0, start_timestamp: childStartTimestamp = 0 } = childSpanJSON;\n\n      const spanStartedBeforeIdleSpanEnd = childStartTimestamp <= endTimestamp;\n\n      // Add a delta with idle timeout so that we prevent false positives\n      const timeoutWithMarginOfError = (finalTimeout + idleTimeout) / 1000;\n      const spanEndedBeforeFinalTimeout = childEndTimestamp - childStartTimestamp <= timeoutWithMarginOfError;\n\n      if (debugBuild.DEBUG_BUILD) {\n        const stringifiedSpan = JSON.stringify(childSpan, undefined, 2);\n        if (!spanStartedBeforeIdleSpanEnd) {\n          debugLogger.debug.log('[Tracing] Discarding span since it happened after idle span was finished', stringifiedSpan);\n        } else if (!spanEndedBeforeFinalTimeout) {\n          debugLogger.debug.log('[Tracing] Discarding span since it finished after idle span final timeout', stringifiedSpan);\n        }\n      }\n\n      if (!spanEndedBeforeFinalTimeout || !spanStartedBeforeIdleSpanEnd) {\n        spanUtils.removeChildSpanFromSpan(span, childSpan);\n        discardedSpans++;\n      }\n    });\n\n    if (discardedSpans > 0) {\n      span.setAttribute('sentry.idle_span_discarded_spans', discardedSpans);\n    }\n  }\n\n  _cleanupHooks.push(\n    client.on('spanStart', startedSpan => {\n      // If we already finished the idle span,\n      // or if this is the idle span itself being started,\n      // or if the started span has already been closed,\n      // we don't care about it for activity\n      if (\n        _finished ||\n        startedSpan === span ||\n        !!spanUtils.spanToJSON(startedSpan).timestamp ||\n        (startedSpan instanceof sentrySpan.SentrySpan && startedSpan.isStandaloneSpan())\n      ) {\n        return;\n      }\n\n      const allSpans = spanUtils.getSpanDescendants(span);\n\n      // If the span that was just started is a child of the idle span, we should track it\n      if (allSpans.includes(startedSpan)) {\n        _pushActivity(startedSpan.spanContext().spanId);\n      }\n    }),\n  );\n\n  _cleanupHooks.push(\n    client.on('spanEnd', endedSpan => {\n      if (_finished) {\n        return;\n      }\n\n      _popActivity(endedSpan.spanContext().spanId);\n    }),\n  );\n\n  _cleanupHooks.push(\n    client.on('idleSpanEnableAutoFinish', spanToAllowAutoFinish => {\n      if (spanToAllowAutoFinish === span) {\n        _autoFinishAllowed = true;\n        _restartIdleTimeout();\n\n        if (activities.size) {\n          _restartChildSpanTimeout();\n        }\n      }\n    }),\n  );\n\n  // We only start the initial idle timeout if we are not delaying the auto finish\n  if (!options.disableAutoFinish) {\n    _restartIdleTimeout();\n  }\n\n  setTimeout(() => {\n    if (!_finished) {\n      span.setStatus({ code: spanstatus.SPAN_STATUS_ERROR, message: 'deadline_exceeded' });\n      _finishReason = FINISH_REASON_FINAL_TIMEOUT;\n      span.end();\n    }\n  }, finalTimeout);\n\n  return span;\n}\n\nfunction _startIdleSpan(options) {\n  const span = trace.startInactiveSpan(options);\n\n  spanOnScope._setSpanForScope(currentScopes.getCurrentScope(), span);\n\n  debugBuild.DEBUG_BUILD && debugLogger.debug.log('[Tracing] Started span is an idle span');\n\n  return span;\n}\n\nexports.TRACING_DEFAULTS = TRACING_DEFAULTS;\nexports.startIdleSpan = startIdleSpan;\n//# sourceMappingURL=idleSpan.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy90cmFjaW5nL2lkbGVTcGFuLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLHNCQUFzQixtQkFBTyxDQUFDLGdJQUFxQjtBQUNuRCxtQkFBbUIsbUJBQU8sQ0FBQyw0SEFBbUI7QUFDOUMsMkJBQTJCLG1CQUFPLENBQUMsMElBQTBCO0FBQzdELG9CQUFvQixtQkFBTyxDQUFDLDBJQUEwQjtBQUN0RCx3QkFBd0IsbUJBQU8sQ0FBQyxnSkFBNkI7QUFDN0Qsb0JBQW9CLG1CQUFPLENBQUMsd0lBQXlCO0FBQ3JELGtCQUFrQixtQkFBTyxDQUFDLG9JQUF1QjtBQUNqRCxhQUFhLG1CQUFPLENBQUMsMEhBQWtCO0FBQ3ZDLCtCQUErQixtQkFBTyxDQUFDLHlKQUE2QjtBQUNwRSwrQkFBK0IsbUJBQU8sQ0FBQyx5SkFBNkI7QUFDcEUsbUJBQW1CLG1CQUFPLENBQUMsaUlBQWlCO0FBQzVDLG1CQUFtQixtQkFBTyxDQUFDLGlJQUFpQjtBQUM1QyxjQUFjLG1CQUFPLENBQUMsdUhBQVk7O0FBRWxDO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQSxxREFBcUQ7QUFDckQ7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsSUFBSTs7QUFFSjs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsS0FBSztBQUNMLEdBQUc7O0FBRUg7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsS0FBSztBQUNMOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEtBQUs7QUFDTDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBOztBQUVBOztBQUVBOztBQUVBLFlBQVksa0NBQWtDO0FBQzlDO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLGtEQUFrRCxZQUFZOztBQUU5RDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLDhCQUE4QiwwREFBMEQ7QUFDeEY7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQSxjQUFjLDZFQUE2RTs7QUFFM0Y7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsVUFBVTtBQUNWO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEtBQUs7O0FBRUw7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEtBQUs7QUFDTDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0EsS0FBSztBQUNMOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQSxLQUFLO0FBQ0w7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLHVCQUF1QixrRUFBa0U7QUFDekY7QUFDQTtBQUNBO0FBQ0EsR0FBRzs7QUFFSDtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7O0FBRUE7O0FBRUE7QUFDQTs7QUFFQSx3QkFBd0I7QUFDeEIscUJBQXFCO0FBQ3JCIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdHJhY2luZy9pZGxlU3Bhbi5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgY3VycmVudFNjb3BlcyA9IHJlcXVpcmUoJy4uL2N1cnJlbnRTY29wZXMuanMnKTtcbmNvbnN0IGRlYnVnQnVpbGQgPSByZXF1aXJlKCcuLi9kZWJ1Zy1idWlsZC5qcycpO1xuY29uc3Qgc2VtYW50aWNBdHRyaWJ1dGVzID0gcmVxdWlyZSgnLi4vc2VtYW50aWNBdHRyaWJ1dGVzLmpzJyk7XG5jb25zdCBkZWJ1Z0xvZ2dlciA9IHJlcXVpcmUoJy4uL3V0aWxzL2RlYnVnLWxvZ2dlci5qcycpO1xuY29uc3QgaGFzU3BhbnNFbmFibGVkID0gcmVxdWlyZSgnLi4vdXRpbHMvaGFzU3BhbnNFbmFibGVkLmpzJyk7XG5jb25zdCBzcGFuT25TY29wZSA9IHJlcXVpcmUoJy4uL3V0aWxzL3NwYW5PblNjb3BlLmpzJyk7XG5jb25zdCBzcGFuVXRpbHMgPSByZXF1aXJlKCcuLi91dGlscy9zcGFuVXRpbHMuanMnKTtcbmNvbnN0IHRpbWUgPSByZXF1aXJlKCcuLi91dGlscy90aW1lLmpzJyk7XG5jb25zdCBkeW5hbWljU2FtcGxpbmdDb250ZXh0ID0gcmVxdWlyZSgnLi9keW5hbWljU2FtcGxpbmdDb250ZXh0LmpzJyk7XG5jb25zdCBzZW50cnlOb25SZWNvcmRpbmdTcGFuID0gcmVxdWlyZSgnLi9zZW50cnlOb25SZWNvcmRpbmdTcGFuLmpzJyk7XG5jb25zdCBzZW50cnlTcGFuID0gcmVxdWlyZSgnLi9zZW50cnlTcGFuLmpzJyk7XG5jb25zdCBzcGFuc3RhdHVzID0gcmVxdWlyZSgnLi9zcGFuc3RhdHVzLmpzJyk7XG5jb25zdCB0cmFjZSA9IHJlcXVpcmUoJy4vdHJhY2UuanMnKTtcblxuY29uc3QgVFJBQ0lOR19ERUZBVUxUUyA9IHtcbiAgaWRsZVRpbWVvdXQ6IDEwMDAsXG4gIGZpbmFsVGltZW91dDogMzAwMDAsXG4gIGNoaWxkU3BhblRpbWVvdXQ6IDE1MDAwLFxufTtcblxuY29uc3QgRklOSVNIX1JFQVNPTl9IRUFSVEJFQVRfRkFJTEVEID0gJ2hlYXJ0YmVhdEZhaWxlZCc7XG5jb25zdCBGSU5JU0hfUkVBU09OX0lETEVfVElNRU9VVCA9ICdpZGxlVGltZW91dCc7XG5jb25zdCBGSU5JU0hfUkVBU09OX0ZJTkFMX1RJTUVPVVQgPSAnZmluYWxUaW1lb3V0JztcbmNvbnN0IEZJTklTSF9SRUFTT05fRVhURVJOQUxfRklOSVNIID0gJ2V4dGVybmFsRmluaXNoJztcblxuLyoqXG4gKiBBbiBpZGxlIHNwYW4gaXMgYSBzcGFuIHRoYXQgYXV0b21hdGljYWxseSBmaW5pc2hlcy4gSXQgZG9lcyB0aGlzIGJ5IHRyYWNraW5nIGNoaWxkIHNwYW5zIGFzIGFjdGl2aXRpZXMuXG4gKiBBbiBpZGxlIHNwYW4gaXMgYWx3YXlzIHRoZSBhY3RpdmUgc3Bhbi5cbiAqL1xuZnVuY3Rpb24gc3RhcnRJZGxlU3BhbihzdGFydFNwYW5PcHRpb25zLCBvcHRpb25zID0ge30pIHtcbiAgLy8gQWN0aXZpdGllcyBzdG9yZSBhIGxpc3Qgb2YgYWN0aXZlIHNwYW5zXG4gIGNvbnN0IGFjdGl2aXRpZXMgPSBuZXcgTWFwKCk7XG5cbiAgLy8gV2Ugc2hvdWxkIG5vdCB1c2UgaGVhcnRiZWF0IGlmIHdlIGZpbmlzaGVkIGEgc3BhblxuICBsZXQgX2ZpbmlzaGVkID0gZmFsc2U7XG5cbiAgLy8gVGltZXIgdGhhdCB0cmFja3MgaWRsZVRpbWVvdXRcbiAgbGV0IF9pZGxlVGltZW91dElEO1xuXG4gIC8vIFRoZSByZWFzb24gd2h5IHRoZSBzcGFuIHdhcyBmaW5pc2hlZFxuICBsZXQgX2ZpbmlzaFJlYXNvbiA9IEZJTklTSF9SRUFTT05fRVhURVJOQUxfRklOSVNIO1xuXG4gIGxldCBfYXV0b0ZpbmlzaEFsbG93ZWQgPSAhb3B0aW9ucy5kaXNhYmxlQXV0b0ZpbmlzaDtcblxuICBjb25zdCBfY2xlYW51cEhvb2tzID0gW107XG5cbiAgY29uc3Qge1xuICAgIGlkbGVUaW1lb3V0ID0gVFJBQ0lOR19ERUZBVUxUUy5pZGxlVGltZW91dCxcbiAgICBmaW5hbFRpbWVvdXQgPSBUUkFDSU5HX0RFRkFVTFRTLmZpbmFsVGltZW91dCxcbiAgICBjaGlsZFNwYW5UaW1lb3V0ID0gVFJBQ0lOR19ERUZBVUxUUy5jaGlsZFNwYW5UaW1lb3V0LFxuICAgIGJlZm9yZVNwYW5FbmQsXG4gIH0gPSBvcHRpb25zO1xuXG4gIGNvbnN0IGNsaWVudCA9IGN1cnJlbnRTY29wZXMuZ2V0Q2xpZW50KCk7XG5cbiAgaWYgKCFjbGllbnQgfHwgIWhhc1NwYW5zRW5hYmxlZC5oYXNTcGFuc0VuYWJsZWQoKSkge1xuICAgIGNvbnN0IHNwYW4gPSBuZXcgc2VudHJ5Tm9uUmVjb3JkaW5nU3Bhbi5TZW50cnlOb25SZWNvcmRpbmdTcGFuKCk7XG5cbiAgICBjb25zdCBkc2MgPSB7XG4gICAgICBzYW1wbGVfcmF0ZTogJzAnLFxuICAgICAgc2FtcGxlZDogJ2ZhbHNlJyxcbiAgICAgIC4uLmR5bmFtaWNTYW1wbGluZ0NvbnRleHQuZ2V0RHluYW1pY1NhbXBsaW5nQ29udGV4dEZyb21TcGFuKHNwYW4pLFxuICAgIH0gO1xuICAgIGR5bmFtaWNTYW1wbGluZ0NvbnRleHQuZnJlZXplRHNjT25TcGFuKHNwYW4sIGRzYyk7XG5cbiAgICByZXR1cm4gc3BhbjtcbiAgfVxuXG4gIGNvbnN0IHNjb3BlID0gY3VycmVudFNjb3Blcy5nZXRDdXJyZW50U2NvcGUoKTtcbiAgY29uc3QgcHJldmlvdXNBY3RpdmVTcGFuID0gc3BhblV0aWxzLmdldEFjdGl2ZVNwYW4oKTtcbiAgY29uc3Qgc3BhbiA9IF9zdGFydElkbGVTcGFuKHN0YXJ0U3Bhbk9wdGlvbnMpO1xuXG4gIC8vIFdlIHBhdGNoIHNwYW4uZW5kIHRvIGVuc3VyZSB3ZSBjYW4gcnVuIHNvbWUgdGhpbmdzIGJlZm9yZSB0aGUgc3BhbiBpcyBlbmRlZFxuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L3VuYm91bmQtbWV0aG9kXG4gIHNwYW4uZW5kID0gbmV3IFByb3h5KHNwYW4uZW5kLCB7XG4gICAgYXBwbHkodGFyZ2V0LCB0aGlzQXJnLCBhcmdzKSB7XG4gICAgICBpZiAoYmVmb3JlU3BhbkVuZCkge1xuICAgICAgICBiZWZvcmVTcGFuRW5kKHNwYW4pO1xuICAgICAgfVxuXG4gICAgICAvLyBJZiB0aGUgc3BhbiBpcyBub24tcmVjb3JkaW5nLCBub3RoaW5nIG1vcmUgdG8gZG8gaGVyZS4uLlxuICAgICAgLy8gVGhpcyBpcyB0aGUgY2FzZSBpZiB0cmFjaW5nIGlzIGVuYWJsZWQgYnV0IHRoaXMgc3BlY2lmaWMgc3BhbiB3YXMgbm90IHNhbXBsZWRcbiAgICAgIGlmICh0aGlzQXJnIGluc3RhbmNlb2Ygc2VudHJ5Tm9uUmVjb3JkaW5nU3Bhbi5TZW50cnlOb25SZWNvcmRpbmdTcGFuKSB7XG4gICAgICAgIHJldHVybjtcbiAgICAgIH1cblxuICAgICAgLy8gSnVzdCBlbnN1cmluZyB0aGF0IHRoaXMga2VlcHMgd29ya2luZywgZXZlbiBpZiB3ZSBldmVyIGhhdmUgbW9yZSBhcmd1bWVudHMgaGVyZVxuICAgICAgY29uc3QgW2RlZmluZWRFbmRUaW1lc3RhbXAsIC4uLnJlc3RdID0gYXJncztcbiAgICAgIGNvbnN0IHRpbWVzdGFtcCA9IGRlZmluZWRFbmRUaW1lc3RhbXAgfHwgdGltZS50aW1lc3RhbXBJblNlY29uZHMoKTtcbiAgICAgIGNvbnN0IHNwYW5FbmRUaW1lc3RhbXAgPSBzcGFuVXRpbHMuc3BhblRpbWVJbnB1dFRvU2Vjb25kcyh0aW1lc3RhbXApO1xuXG4gICAgICAvLyBFbnN1cmUgd2UgZW5kIHdpdGggdGhlIGxhc3Qgc3BhbiB0aW1lc3RhbXAsIGlmIHBvc3NpYmxlXG4gICAgICBjb25zdCBzcGFucyA9IHNwYW5VdGlscy5nZXRTcGFuRGVzY2VuZGFudHMoc3BhbikuZmlsdGVyKGNoaWxkID0+IGNoaWxkICE9PSBzcGFuKTtcblxuICAgICAgLy8gSWYgd2UgaGF2ZSBubyBzcGFucywgd2UganVzdCBlbmQsIG5vdGhpbmcgZWxzZSB0byBkbyBoZXJlXG4gICAgICBpZiAoIXNwYW5zLmxlbmd0aCkge1xuICAgICAgICBvbklkbGVTcGFuRW5kZWQoc3BhbkVuZFRpbWVzdGFtcCk7XG4gICAgICAgIHJldHVybiBSZWZsZWN0LmFwcGx5KHRhcmdldCwgdGhpc0FyZywgW3NwYW5FbmRUaW1lc3RhbXAsIC4uLnJlc3RdKTtcbiAgICAgIH1cblxuICAgICAgY29uc3QgY2hpbGRFbmRUaW1lc3RhbXBzID0gc3BhbnNcbiAgICAgICAgLm1hcChzcGFuID0+IHNwYW5VdGlscy5zcGFuVG9KU09OKHNwYW4pLnRpbWVzdGFtcClcbiAgICAgICAgLmZpbHRlcih0aW1lc3RhbXAgPT4gISF0aW1lc3RhbXApIDtcbiAgICAgIGNvbnN0IGxhdGVzdFNwYW5FbmRUaW1lc3RhbXAgPSBjaGlsZEVuZFRpbWVzdGFtcHMubGVuZ3RoID8gTWF0aC5tYXgoLi4uY2hpbGRFbmRUaW1lc3RhbXBzKSA6IHVuZGVmaW5lZDtcblxuICAgICAgLy8gSW4gcmVhbGl0eSB0aGlzIHNob3VsZCBhbHdheXMgZXhpc3QgaGVyZSwgYnV0IHR5cGUtd2lzZSBpdCBtYXkgYmUgdW5kZWZpbmVkLi4uXG4gICAgICBjb25zdCBzcGFuU3RhcnRUaW1lc3RhbXAgPSBzcGFuVXRpbHMuc3BhblRvSlNPTihzcGFuKS5zdGFydF90aW1lc3RhbXA7XG5cbiAgICAgIC8vIFRoZSBmaW5hbCBlbmRUaW1lc3RhbXAgc2hvdWxkOlxuICAgICAgLy8gKiBOZXZlciBiZSBiZWZvcmUgdGhlIHNwYW4gc3RhcnQgdGltZXN0YW1wXG4gICAgICAvLyAqIEJlIHRoZSBsYXRlc3RTcGFuRW5kVGltZXN0YW1wLCBpZiB0aGVyZSBpcyBvbmUsIGFuZCBpdCBpcyBzbWFsbGVyIHRoYW4gdGhlIHBhc3NlZCBzcGFuIGVuZCB0aW1lc3RhbXBcbiAgICAgIC8vICogT3RoZXJ3aXNlIGJlIHRoZSBwYXNzZWQgZW5kIHRpbWVzdGFtcFxuICAgICAgLy8gRmluYWwgdGltZXN0YW1wIGNhbiBuZXZlciBiZSBhZnRlciBmaW5hbFRpbWVvdXRcbiAgICAgIGNvbnN0IGVuZFRpbWVzdGFtcCA9IE1hdGgubWluKFxuICAgICAgICBzcGFuU3RhcnRUaW1lc3RhbXAgPyBzcGFuU3RhcnRUaW1lc3RhbXAgKyBmaW5hbFRpbWVvdXQgLyAxMDAwIDogSW5maW5pdHksXG4gICAgICAgIE1hdGgubWF4KHNwYW5TdGFydFRpbWVzdGFtcCB8fCAtSW5maW5pdHksIE1hdGgubWluKHNwYW5FbmRUaW1lc3RhbXAsIGxhdGVzdFNwYW5FbmRUaW1lc3RhbXAgfHwgSW5maW5pdHkpKSxcbiAgICAgICk7XG5cbiAgICAgIG9uSWRsZVNwYW5FbmRlZChlbmRUaW1lc3RhbXApO1xuICAgICAgcmV0dXJuIFJlZmxlY3QuYXBwbHkodGFyZ2V0LCB0aGlzQXJnLCBbZW5kVGltZXN0YW1wLCAuLi5yZXN0XSk7XG4gICAgfSxcbiAgfSk7XG5cbiAgLyoqXG4gICAqIENhbmNlbHMgdGhlIGV4aXN0aW5nIGlkbGUgdGltZW91dCwgaWYgdGhlcmUgaXMgb25lLlxuICAgKi9cbiAgZnVuY3Rpb24gX2NhbmNlbElkbGVUaW1lb3V0KCkge1xuICAgIGlmIChfaWRsZVRpbWVvdXRJRCkge1xuICAgICAgY2xlYXJUaW1lb3V0KF9pZGxlVGltZW91dElEKTtcbiAgICAgIF9pZGxlVGltZW91dElEID0gdW5kZWZpbmVkO1xuICAgIH1cbiAgfVxuXG4gIC8qKlxuICAgKiBSZXN0YXJ0cyBpZGxlIHRpbWVvdXQsIGlmIHRoZXJlIGlzIG5vIHJ1bm5pbmcgaWRsZSB0aW1lb3V0IGl0IHdpbGwgc3RhcnQgb25lLlxuICAgKi9cbiAgZnVuY3Rpb24gX3Jlc3RhcnRJZGxlVGltZW91dChlbmRUaW1lc3RhbXApIHtcbiAgICBfY2FuY2VsSWRsZVRpbWVvdXQoKTtcbiAgICBfaWRsZVRpbWVvdXRJRCA9IHNldFRpbWVvdXQoKCkgPT4ge1xuICAgICAgaWYgKCFfZmluaXNoZWQgJiYgYWN0aXZpdGllcy5zaXplID09PSAwICYmIF9hdXRvRmluaXNoQWxsb3dlZCkge1xuICAgICAgICBfZmluaXNoUmVhc29uID0gRklOSVNIX1JFQVNPTl9JRExFX1RJTUVPVVQ7XG4gICAgICAgIHNwYW4uZW5kKGVuZFRpbWVzdGFtcCk7XG4gICAgICB9XG4gICAgfSwgaWRsZVRpbWVvdXQpO1xuICB9XG5cbiAgLyoqXG4gICAqIFJlc3RhcnRzIGNoaWxkIHNwYW4gdGltZW91dCwgaWYgdGhlcmUgaXMgbm9uZSBydW5uaW5nIGl0IHdpbGwgc3RhcnQgb25lLlxuICAgKi9cbiAgZnVuY3Rpb24gX3Jlc3RhcnRDaGlsZFNwYW5UaW1lb3V0KGVuZFRpbWVzdGFtcCkge1xuICAgIF9pZGxlVGltZW91dElEID0gc2V0VGltZW91dCgoKSA9PiB7XG4gICAgICBpZiAoIV9maW5pc2hlZCAmJiBfYXV0b0ZpbmlzaEFsbG93ZWQpIHtcbiAgICAgICAgX2ZpbmlzaFJlYXNvbiA9IEZJTklTSF9SRUFTT05fSEVBUlRCRUFUX0ZBSUxFRDtcbiAgICAgICAgc3Bhbi5lbmQoZW5kVGltZXN0YW1wKTtcbiAgICAgIH1cbiAgICB9LCBjaGlsZFNwYW5UaW1lb3V0KTtcbiAgfVxuXG4gIC8qKlxuICAgKiBTdGFydCB0cmFja2luZyBhIHNwZWNpZmljIGFjdGl2aXR5LlxuICAgKiBAcGFyYW0gc3BhbklkIFRoZSBzcGFuIGlkIHRoYXQgcmVwcmVzZW50cyB0aGUgYWN0aXZpdHlcbiAgICovXG4gIGZ1bmN0aW9uIF9wdXNoQWN0aXZpdHkoc3BhbklkKSB7XG4gICAgX2NhbmNlbElkbGVUaW1lb3V0KCk7XG4gICAgYWN0aXZpdGllcy5zZXQoc3BhbklkLCB0cnVlKTtcblxuICAgIGNvbnN0IGVuZFRpbWVzdGFtcCA9IHRpbWUudGltZXN0YW1wSW5TZWNvbmRzKCk7XG4gICAgLy8gV2UgbmVlZCB0byBhZGQgdGhlIHRpbWVvdXQgaGVyZSB0byBoYXZlIHRoZSByZWFsIGVuZHRpbWVzdGFtcCBvZiB0aGUgaWRsZSBzcGFuXG4gICAgLy8gUmVtZW1iZXIgdGltZXN0YW1wSW5TZWNvbmRzIGlzIGluIHNlY29uZHMsIHRpbWVvdXQgaXMgaW4gbXNcbiAgICBfcmVzdGFydENoaWxkU3BhblRpbWVvdXQoZW5kVGltZXN0YW1wICsgY2hpbGRTcGFuVGltZW91dCAvIDEwMDApO1xuICB9XG5cbiAgLyoqXG4gICAqIFJlbW92ZSBhbiBhY3Rpdml0eSBmcm9tIHVzYWdlXG4gICAqIEBwYXJhbSBzcGFuSWQgVGhlIHNwYW4gaWQgdGhhdCByZXByZXNlbnRzIHRoZSBhY3Rpdml0eVxuICAgKi9cbiAgZnVuY3Rpb24gX3BvcEFjdGl2aXR5KHNwYW5JZCkge1xuICAgIGlmIChhY3Rpdml0aWVzLmhhcyhzcGFuSWQpKSB7XG4gICAgICBhY3Rpdml0aWVzLmRlbGV0ZShzcGFuSWQpO1xuICAgIH1cblxuICAgIGlmIChhY3Rpdml0aWVzLnNpemUgPT09IDApIHtcbiAgICAgIGNvbnN0IGVuZFRpbWVzdGFtcCA9IHRpbWUudGltZXN0YW1wSW5TZWNvbmRzKCk7XG4gICAgICAvLyBXZSBuZWVkIHRvIGFkZCB0aGUgdGltZW91dCBoZXJlIHRvIGhhdmUgdGhlIHJlYWwgZW5kdGltZXN0YW1wIG9mIHRoZSBpZGxlIHNwYW5cbiAgICAgIC8vIFJlbWVtYmVyIHRpbWVzdGFtcEluU2Vjb25kcyBpcyBpbiBzZWNvbmRzLCB0aW1lb3V0IGlzIGluIG1zXG4gICAgICBfcmVzdGFydElkbGVUaW1lb3V0KGVuZFRpbWVzdGFtcCArIGlkbGVUaW1lb3V0IC8gMTAwMCk7XG4gICAgfVxuICB9XG5cbiAgZnVuY3Rpb24gb25JZGxlU3BhbkVuZGVkKGVuZFRpbWVzdGFtcCkge1xuICAgIF9maW5pc2hlZCA9IHRydWU7XG4gICAgYWN0aXZpdGllcy5jbGVhcigpO1xuXG4gICAgX2NsZWFudXBIb29rcy5mb3JFYWNoKGNsZWFudXAgPT4gY2xlYW51cCgpKTtcblxuICAgIHNwYW5PblNjb3BlLl9zZXRTcGFuRm9yU2NvcGUoc2NvcGUsIHByZXZpb3VzQWN0aXZlU3Bhbik7XG5cbiAgICBjb25zdCBzcGFuSlNPTiA9IHNwYW5VdGlscy5zcGFuVG9KU09OKHNwYW4pO1xuXG4gICAgY29uc3QgeyBzdGFydF90aW1lc3RhbXA6IHN0YXJ0VGltZXN0YW1wIH0gPSBzcGFuSlNPTjtcbiAgICAvLyBUaGlzIHNob3VsZCBuZXZlciBoYXBwZW4sIGJ1dCB0byBtYWtlIFRTIGhhcHB5Li4uXG4gICAgaWYgKCFzdGFydFRpbWVzdGFtcCkge1xuICAgICAgcmV0dXJuO1xuICAgIH1cblxuICAgIGNvbnN0IGF0dHJpYnV0ZXMgPSBzcGFuSlNPTi5kYXRhO1xuICAgIGlmICghYXR0cmlidXRlc1tzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9JRExFX1NQQU5fRklOSVNIX1JFQVNPTl0pIHtcbiAgICAgIHNwYW4uc2V0QXR0cmlidXRlKHNlbWFudGljQXR0cmlidXRlcy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX0lETEVfU1BBTl9GSU5JU0hfUkVBU09OLCBfZmluaXNoUmVhc29uKTtcbiAgICB9XG5cbiAgICBkZWJ1Z0xvZ2dlci5kZWJ1Zy5sb2coYFtUcmFjaW5nXSBJZGxlIHNwYW4gXCIke3NwYW5KU09OLm9wfVwiIGZpbmlzaGVkYCk7XG5cbiAgICBjb25zdCBjaGlsZFNwYW5zID0gc3BhblV0aWxzLmdldFNwYW5EZXNjZW5kYW50cyhzcGFuKS5maWx0ZXIoY2hpbGQgPT4gY2hpbGQgIT09IHNwYW4pO1xuXG4gICAgbGV0IGRpc2NhcmRlZFNwYW5zID0gMDtcbiAgICBjaGlsZFNwYW5zLmZvckVhY2goY2hpbGRTcGFuID0+IHtcbiAgICAgIC8vIFdlIGNhbmNlbCBhbGwgcGVuZGluZyBzcGFucyB3aXRoIHN0YXR1cyBcImNhbmNlbGxlZFwiIHRvIGluZGljYXRlIHRoZSBpZGxlIHNwYW4gd2FzIGZpbmlzaGVkIGVhcmx5XG4gICAgICBpZiAoY2hpbGRTcGFuLmlzUmVjb3JkaW5nKCkpIHtcbiAgICAgICAgY2hpbGRTcGFuLnNldFN0YXR1cyh7IGNvZGU6IHNwYW5zdGF0dXMuU1BBTl9TVEFUVVNfRVJST1IsIG1lc3NhZ2U6ICdjYW5jZWxsZWQnIH0pO1xuICAgICAgICBjaGlsZFNwYW4uZW5kKGVuZFRpbWVzdGFtcCk7XG4gICAgICAgIGRlYnVnQnVpbGQuREVCVUdfQlVJTEQgJiZcbiAgICAgICAgICBkZWJ1Z0xvZ2dlci5kZWJ1Zy5sb2coJ1tUcmFjaW5nXSBDYW5jZWxsaW5nIHNwYW4gc2luY2Ugc3BhbiBlbmRlZCBlYXJseScsIEpTT04uc3RyaW5naWZ5KGNoaWxkU3BhbiwgdW5kZWZpbmVkLCAyKSk7XG4gICAgICB9XG5cbiAgICAgIGNvbnN0IGNoaWxkU3BhbkpTT04gPSBzcGFuVXRpbHMuc3BhblRvSlNPTihjaGlsZFNwYW4pO1xuICAgICAgY29uc3QgeyB0aW1lc3RhbXA6IGNoaWxkRW5kVGltZXN0YW1wID0gMCwgc3RhcnRfdGltZXN0YW1wOiBjaGlsZFN0YXJ0VGltZXN0YW1wID0gMCB9ID0gY2hpbGRTcGFuSlNPTjtcblxuICAgICAgY29uc3Qgc3BhblN0YXJ0ZWRCZWZvcmVJZGxlU3BhbkVuZCA9IGNoaWxkU3RhcnRUaW1lc3RhbXAgPD0gZW5kVGltZXN0YW1wO1xuXG4gICAgICAvLyBBZGQgYSBkZWx0YSB3aXRoIGlkbGUgdGltZW91dCBzbyB0aGF0IHdlIHByZXZlbnQgZmFsc2UgcG9zaXRpdmVzXG4gICAgICBjb25zdCB0aW1lb3V0V2l0aE1hcmdpbk9mRXJyb3IgPSAoZmluYWxUaW1lb3V0ICsgaWRsZVRpbWVvdXQpIC8gMTAwMDtcbiAgICAgIGNvbnN0IHNwYW5FbmRlZEJlZm9yZUZpbmFsVGltZW91dCA9IGNoaWxkRW5kVGltZXN0YW1wIC0gY2hpbGRTdGFydFRpbWVzdGFtcCA8PSB0aW1lb3V0V2l0aE1hcmdpbk9mRXJyb3I7XG5cbiAgICAgIGlmIChkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEKSB7XG4gICAgICAgIGNvbnN0IHN0cmluZ2lmaWVkU3BhbiA9IEpTT04uc3RyaW5naWZ5KGNoaWxkU3BhbiwgdW5kZWZpbmVkLCAyKTtcbiAgICAgICAgaWYgKCFzcGFuU3RhcnRlZEJlZm9yZUlkbGVTcGFuRW5kKSB7XG4gICAgICAgICAgZGVidWdMb2dnZXIuZGVidWcubG9nKCdbVHJhY2luZ10gRGlzY2FyZGluZyBzcGFuIHNpbmNlIGl0IGhhcHBlbmVkIGFmdGVyIGlkbGUgc3BhbiB3YXMgZmluaXNoZWQnLCBzdHJpbmdpZmllZFNwYW4pO1xuICAgICAgICB9IGVsc2UgaWYgKCFzcGFuRW5kZWRCZWZvcmVGaW5hbFRpbWVvdXQpIHtcbiAgICAgICAgICBkZWJ1Z0xvZ2dlci5kZWJ1Zy5sb2coJ1tUcmFjaW5nXSBEaXNjYXJkaW5nIHNwYW4gc2luY2UgaXQgZmluaXNoZWQgYWZ0ZXIgaWRsZSBzcGFuIGZpbmFsIHRpbWVvdXQnLCBzdHJpbmdpZmllZFNwYW4pO1xuICAgICAgICB9XG4gICAgICB9XG5cbiAgICAgIGlmICghc3BhbkVuZGVkQmVmb3JlRmluYWxUaW1lb3V0IHx8ICFzcGFuU3RhcnRlZEJlZm9yZUlkbGVTcGFuRW5kKSB7XG4gICAgICAgIHNwYW5VdGlscy5yZW1vdmVDaGlsZFNwYW5Gcm9tU3BhbihzcGFuLCBjaGlsZFNwYW4pO1xuICAgICAgICBkaXNjYXJkZWRTcGFucysrO1xuICAgICAgfVxuICAgIH0pO1xuXG4gICAgaWYgKGRpc2NhcmRlZFNwYW5zID4gMCkge1xuICAgICAgc3Bhbi5zZXRBdHRyaWJ1dGUoJ3NlbnRyeS5pZGxlX3NwYW5fZGlzY2FyZGVkX3NwYW5zJywgZGlzY2FyZGVkU3BhbnMpO1xuICAgIH1cbiAgfVxuXG4gIF9jbGVhbnVwSG9va3MucHVzaChcbiAgICBjbGllbnQub24oJ3NwYW5TdGFydCcsIHN0YXJ0ZWRTcGFuID0+IHtcbiAgICAgIC8vIElmIHdlIGFscmVhZHkgZmluaXNoZWQgdGhlIGlkbGUgc3BhbixcbiAgICAgIC8vIG9yIGlmIHRoaXMgaXMgdGhlIGlkbGUgc3BhbiBpdHNlbGYgYmVpbmcgc3RhcnRlZCxcbiAgICAgIC8vIG9yIGlmIHRoZSBzdGFydGVkIHNwYW4gaGFzIGFscmVhZHkgYmVlbiBjbG9zZWQsXG4gICAgICAvLyB3ZSBkb24ndCBjYXJlIGFib3V0IGl0IGZvciBhY3Rpdml0eVxuICAgICAgaWYgKFxuICAgICAgICBfZmluaXNoZWQgfHxcbiAgICAgICAgc3RhcnRlZFNwYW4gPT09IHNwYW4gfHxcbiAgICAgICAgISFzcGFuVXRpbHMuc3BhblRvSlNPTihzdGFydGVkU3BhbikudGltZXN0YW1wIHx8XG4gICAgICAgIChzdGFydGVkU3BhbiBpbnN0YW5jZW9mIHNlbnRyeVNwYW4uU2VudHJ5U3BhbiAmJiBzdGFydGVkU3Bhbi5pc1N0YW5kYWxvbmVTcGFuKCkpXG4gICAgICApIHtcbiAgICAgICAgcmV0dXJuO1xuICAgICAgfVxuXG4gICAgICBjb25zdCBhbGxTcGFucyA9IHNwYW5VdGlscy5nZXRTcGFuRGVzY2VuZGFudHMoc3Bhbik7XG5cbiAgICAgIC8vIElmIHRoZSBzcGFuIHRoYXQgd2FzIGp1c3Qgc3RhcnRlZCBpcyBhIGNoaWxkIG9mIHRoZSBpZGxlIHNwYW4sIHdlIHNob3VsZCB0cmFjayBpdFxuICAgICAgaWYgKGFsbFNwYW5zLmluY2x1ZGVzKHN0YXJ0ZWRTcGFuKSkge1xuICAgICAgICBfcHVzaEFjdGl2aXR5KHN0YXJ0ZWRTcGFuLnNwYW5Db250ZXh0KCkuc3BhbklkKTtcbiAgICAgIH1cbiAgICB9KSxcbiAgKTtcblxuICBfY2xlYW51cEhvb2tzLnB1c2goXG4gICAgY2xpZW50Lm9uKCdzcGFuRW5kJywgZW5kZWRTcGFuID0+IHtcbiAgICAgIGlmIChfZmluaXNoZWQpIHtcbiAgICAgICAgcmV0dXJuO1xuICAgICAgfVxuXG4gICAgICBfcG9wQWN0aXZpdHkoZW5kZWRTcGFuLnNwYW5Db250ZXh0KCkuc3BhbklkKTtcbiAgICB9KSxcbiAgKTtcblxuICBfY2xlYW51cEhvb2tzLnB1c2goXG4gICAgY2xpZW50Lm9uKCdpZGxlU3BhbkVuYWJsZUF1dG9GaW5pc2gnLCBzcGFuVG9BbGxvd0F1dG9GaW5pc2ggPT4ge1xuICAgICAgaWYgKHNwYW5Ub0FsbG93QXV0b0ZpbmlzaCA9PT0gc3Bhbikge1xuICAgICAgICBfYXV0b0ZpbmlzaEFsbG93ZWQgPSB0cnVlO1xuICAgICAgICBfcmVzdGFydElkbGVUaW1lb3V0KCk7XG5cbiAgICAgICAgaWYgKGFjdGl2aXRpZXMuc2l6ZSkge1xuICAgICAgICAgIF9yZXN0YXJ0Q2hpbGRTcGFuVGltZW91dCgpO1xuICAgICAgICB9XG4gICAgICB9XG4gICAgfSksXG4gICk7XG5cbiAgLy8gV2Ugb25seSBzdGFydCB0aGUgaW5pdGlhbCBpZGxlIHRpbWVvdXQgaWYgd2UgYXJlIG5vdCBkZWxheWluZyB0aGUgYXV0byBmaW5pc2hcbiAgaWYgKCFvcHRpb25zLmRpc2FibGVBdXRvRmluaXNoKSB7XG4gICAgX3Jlc3RhcnRJZGxlVGltZW91dCgpO1xuICB9XG5cbiAgc2V0VGltZW91dCgoKSA9PiB7XG4gICAgaWYgKCFfZmluaXNoZWQpIHtcbiAgICAgIHNwYW4uc2V0U3RhdHVzKHsgY29kZTogc3BhbnN0YXR1cy5TUEFOX1NUQVRVU19FUlJPUiwgbWVzc2FnZTogJ2RlYWRsaW5lX2V4Y2VlZGVkJyB9KTtcbiAgICAgIF9maW5pc2hSZWFzb24gPSBGSU5JU0hfUkVBU09OX0ZJTkFMX1RJTUVPVVQ7XG4gICAgICBzcGFuLmVuZCgpO1xuICAgIH1cbiAgfSwgZmluYWxUaW1lb3V0KTtcblxuICByZXR1cm4gc3Bhbjtcbn1cblxuZnVuY3Rpb24gX3N0YXJ0SWRsZVNwYW4ob3B0aW9ucykge1xuICBjb25zdCBzcGFuID0gdHJhY2Uuc3RhcnRJbmFjdGl2ZVNwYW4ob3B0aW9ucyk7XG5cbiAgc3Bhbk9uU2NvcGUuX3NldFNwYW5Gb3JTY29wZShjdXJyZW50U2NvcGVzLmdldEN1cnJlbnRTY29wZSgpLCBzcGFuKTtcblxuICBkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEICYmIGRlYnVnTG9nZ2VyLmRlYnVnLmxvZygnW1RyYWNpbmddIFN0YXJ0ZWQgc3BhbiBpcyBhbiBpZGxlIHNwYW4nKTtcblxuICByZXR1cm4gc3Bhbjtcbn1cblxuZXhwb3J0cy5UUkFDSU5HX0RFRkFVTFRTID0gVFJBQ0lOR19ERUZBVUxUUztcbmV4cG9ydHMuc3RhcnRJZGxlU3BhbiA9IHN0YXJ0SWRsZVNwYW47XG4vLyMgc291cmNlTWFwcGluZ1VSTD1pZGxlU3Bhbi5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/idleSpan.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/logSpans.js":
/*!********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/logSpans.js ***!
  \********************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst debugBuild = __webpack_require__(/*! ../debug-build.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst debugLogger = __webpack_require__(/*! ../utils/debug-logger.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst spanUtils = __webpack_require__(/*! ../utils/spanUtils.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanUtils.js\");\n\n/**\n * Print a log message for a started span.\n */\nfunction logSpanStart(span) {\n  if (!debugBuild.DEBUG_BUILD) return;\n\n  const { description = '< unknown name >', op = '< unknown op >', parent_span_id: parentSpanId } = spanUtils.spanToJSON(span);\n  const { spanId } = span.spanContext();\n\n  const sampled = spanUtils.spanIsSampled(span);\n  const rootSpan = spanUtils.getRootSpan(span);\n  const isRootSpan = rootSpan === span;\n\n  const header = `[Tracing] Starting ${sampled ? 'sampled' : 'unsampled'} ${isRootSpan ? 'root ' : ''}span`;\n\n  const infoParts = [`op: ${op}`, `name: ${description}`, `ID: ${spanId}`];\n\n  if (parentSpanId) {\n    infoParts.push(`parent ID: ${parentSpanId}`);\n  }\n\n  if (!isRootSpan) {\n    const { op, description } = spanUtils.spanToJSON(rootSpan);\n    infoParts.push(`root ID: ${rootSpan.spanContext().spanId}`);\n    if (op) {\n      infoParts.push(`root op: ${op}`);\n    }\n    if (description) {\n      infoParts.push(`root description: ${description}`);\n    }\n  }\n\n  debugLogger.debug.log(`${header}\n  ${infoParts.join('\\n  ')}`);\n}\n\n/**\n * Print a log message for an ended span.\n */\nfunction logSpanEnd(span) {\n  if (!debugBuild.DEBUG_BUILD) return;\n\n  const { description = '< unknown name >', op = '< unknown op >' } = spanUtils.spanToJSON(span);\n  const { spanId } = span.spanContext();\n  const rootSpan = spanUtils.getRootSpan(span);\n  const isRootSpan = rootSpan === span;\n\n  const msg = `[Tracing] Finishing \"${op}\" ${isRootSpan ? 'root ' : ''}span \"${description}\" with ID ${spanId}`;\n  debugLogger.debug.log(msg);\n}\n\nexports.logSpanEnd = logSpanEnd;\nexports.logSpanStart = logSpanStart;\n//# sourceMappingURL=logSpans.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy90cmFjaW5nL2xvZ1NwYW5zLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLG1CQUFtQixtQkFBTyxDQUFDLDRIQUFtQjtBQUM5QyxvQkFBb0IsbUJBQU8sQ0FBQywwSUFBMEI7QUFDdEQsa0JBQWtCLG1CQUFPLENBQUMsb0lBQXVCOztBQUVqRDtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLFVBQVUsd0ZBQXdGO0FBQ2xHLFVBQVUsU0FBUzs7QUFFbkI7QUFDQTtBQUNBOztBQUVBLHVDQUF1QyxtQ0FBbUMsRUFBRSwwQkFBMEI7O0FBRXRHLDRCQUE0QixHQUFHLFlBQVksWUFBWSxVQUFVLE9BQU87O0FBRXhFO0FBQ0EsaUNBQWlDLGFBQWE7QUFDOUM7O0FBRUE7QUFDQSxZQUFZLGtCQUFrQjtBQUM5QiwrQkFBK0IsOEJBQThCO0FBQzdEO0FBQ0EsaUNBQWlDLEdBQUc7QUFDcEM7QUFDQTtBQUNBLDBDQUEwQyxZQUFZO0FBQ3REO0FBQ0E7O0FBRUEsMkJBQTJCO0FBQzNCLElBQUksdUJBQXVCO0FBQzNCOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsVUFBVSwwREFBMEQ7QUFDcEUsVUFBVSxTQUFTO0FBQ25CO0FBQ0E7O0FBRUEsc0NBQXNDLEdBQUcsSUFBSSwwQkFBMEIsUUFBUSxZQUFZLFlBQVksT0FBTztBQUM5RztBQUNBOztBQUVBLGtCQUFrQjtBQUNsQixvQkFBb0I7QUFDcEIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy90cmFjaW5nL2xvZ1NwYW5zLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBkZWJ1Z0J1aWxkID0gcmVxdWlyZSgnLi4vZGVidWctYnVpbGQuanMnKTtcbmNvbnN0IGRlYnVnTG9nZ2VyID0gcmVxdWlyZSgnLi4vdXRpbHMvZGVidWctbG9nZ2VyLmpzJyk7XG5jb25zdCBzcGFuVXRpbHMgPSByZXF1aXJlKCcuLi91dGlscy9zcGFuVXRpbHMuanMnKTtcblxuLyoqXG4gKiBQcmludCBhIGxvZyBtZXNzYWdlIGZvciBhIHN0YXJ0ZWQgc3Bhbi5cbiAqL1xuZnVuY3Rpb24gbG9nU3BhblN0YXJ0KHNwYW4pIHtcbiAgaWYgKCFkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEKSByZXR1cm47XG5cbiAgY29uc3QgeyBkZXNjcmlwdGlvbiA9ICc8IHVua25vd24gbmFtZSA+Jywgb3AgPSAnPCB1bmtub3duIG9wID4nLCBwYXJlbnRfc3Bhbl9pZDogcGFyZW50U3BhbklkIH0gPSBzcGFuVXRpbHMuc3BhblRvSlNPTihzcGFuKTtcbiAgY29uc3QgeyBzcGFuSWQgfSA9IHNwYW4uc3BhbkNvbnRleHQoKTtcblxuICBjb25zdCBzYW1wbGVkID0gc3BhblV0aWxzLnNwYW5Jc1NhbXBsZWQoc3Bhbik7XG4gIGNvbnN0IHJvb3RTcGFuID0gc3BhblV0aWxzLmdldFJvb3RTcGFuKHNwYW4pO1xuICBjb25zdCBpc1Jvb3RTcGFuID0gcm9vdFNwYW4gPT09IHNwYW47XG5cbiAgY29uc3QgaGVhZGVyID0gYFtUcmFjaW5nXSBTdGFydGluZyAke3NhbXBsZWQgPyAnc2FtcGxlZCcgOiAndW5zYW1wbGVkJ30gJHtpc1Jvb3RTcGFuID8gJ3Jvb3QgJyA6ICcnfXNwYW5gO1xuXG4gIGNvbnN0IGluZm9QYXJ0cyA9IFtgb3A6ICR7b3B9YCwgYG5hbWU6ICR7ZGVzY3JpcHRpb259YCwgYElEOiAke3NwYW5JZH1gXTtcblxuICBpZiAocGFyZW50U3BhbklkKSB7XG4gICAgaW5mb1BhcnRzLnB1c2goYHBhcmVudCBJRDogJHtwYXJlbnRTcGFuSWR9YCk7XG4gIH1cblxuICBpZiAoIWlzUm9vdFNwYW4pIHtcbiAgICBjb25zdCB7IG9wLCBkZXNjcmlwdGlvbiB9ID0gc3BhblV0aWxzLnNwYW5Ub0pTT04ocm9vdFNwYW4pO1xuICAgIGluZm9QYXJ0cy5wdXNoKGByb290IElEOiAke3Jvb3RTcGFuLnNwYW5Db250ZXh0KCkuc3BhbklkfWApO1xuICAgIGlmIChvcCkge1xuICAgICAgaW5mb1BhcnRzLnB1c2goYHJvb3Qgb3A6ICR7b3B9YCk7XG4gICAgfVxuICAgIGlmIChkZXNjcmlwdGlvbikge1xuICAgICAgaW5mb1BhcnRzLnB1c2goYHJvb3QgZGVzY3JpcHRpb246ICR7ZGVzY3JpcHRpb259YCk7XG4gICAgfVxuICB9XG5cbiAgZGVidWdMb2dnZXIuZGVidWcubG9nKGAke2hlYWRlcn1cbiAgJHtpbmZvUGFydHMuam9pbignXFxuICAnKX1gKTtcbn1cblxuLyoqXG4gKiBQcmludCBhIGxvZyBtZXNzYWdlIGZvciBhbiBlbmRlZCBzcGFuLlxuICovXG5mdW5jdGlvbiBsb2dTcGFuRW5kKHNwYW4pIHtcbiAgaWYgKCFkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEKSByZXR1cm47XG5cbiAgY29uc3QgeyBkZXNjcmlwdGlvbiA9ICc8IHVua25vd24gbmFtZSA+Jywgb3AgPSAnPCB1bmtub3duIG9wID4nIH0gPSBzcGFuVXRpbHMuc3BhblRvSlNPTihzcGFuKTtcbiAgY29uc3QgeyBzcGFuSWQgfSA9IHNwYW4uc3BhbkNvbnRleHQoKTtcbiAgY29uc3Qgcm9vdFNwYW4gPSBzcGFuVXRpbHMuZ2V0Um9vdFNwYW4oc3Bhbik7XG4gIGNvbnN0IGlzUm9vdFNwYW4gPSByb290U3BhbiA9PT0gc3BhbjtcblxuICBjb25zdCBtc2cgPSBgW1RyYWNpbmddIEZpbmlzaGluZyBcIiR7b3B9XCIgJHtpc1Jvb3RTcGFuID8gJ3Jvb3QgJyA6ICcnfXNwYW4gXCIke2Rlc2NyaXB0aW9ufVwiIHdpdGggSUQgJHtzcGFuSWR9YDtcbiAgZGVidWdMb2dnZXIuZGVidWcubG9nKG1zZyk7XG59XG5cbmV4cG9ydHMubG9nU3BhbkVuZCA9IGxvZ1NwYW5FbmQ7XG5leHBvcnRzLmxvZ1NwYW5TdGFydCA9IGxvZ1NwYW5TdGFydDtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWxvZ1NwYW5zLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/logSpans.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/measurement.js":
/*!***********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/measurement.js ***!
  \***********************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst debugBuild = __webpack_require__(/*! ../debug-build.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst semanticAttributes = __webpack_require__(/*! ../semanticAttributes.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/semanticAttributes.js\");\nconst debugLogger = __webpack_require__(/*! ../utils/debug-logger.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst spanUtils = __webpack_require__(/*! ../utils/spanUtils.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanUtils.js\");\n\n/**\n * Adds a measurement to the active transaction on the current global scope. You can optionally pass in a different span\n * as the 4th parameter.\n */\nfunction setMeasurement(name, value, unit, activeSpan = spanUtils.getActiveSpan()) {\n  const rootSpan = activeSpan && spanUtils.getRootSpan(activeSpan);\n\n  if (rootSpan) {\n    debugBuild.DEBUG_BUILD && debugLogger.debug.log(`[Measurement] Setting measurement on root span: ${name} = ${value} ${unit}`);\n    rootSpan.addEvent(name, {\n      [semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_MEASUREMENT_VALUE]: value,\n      [semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_MEASUREMENT_UNIT]: unit ,\n    });\n  }\n}\n\n/**\n * Convert timed events to measurements.\n */\nfunction timedEventsToMeasurements(events) {\n  if (!events || events.length === 0) {\n    return undefined;\n  }\n\n  const measurements = {};\n  events.forEach(event => {\n    const attributes = event.attributes || {};\n    const unit = attributes[semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_MEASUREMENT_UNIT] ;\n    const value = attributes[semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_MEASUREMENT_VALUE] ;\n\n    if (typeof unit === 'string' && typeof value === 'number') {\n      measurements[event.name] = { value, unit };\n    }\n  });\n\n  return measurements;\n}\n\nexports.setMeasurement = setMeasurement;\nexports.timedEventsToMeasurements = timedEventsToMeasurements;\n//# sourceMappingURL=measurement.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy90cmFjaW5nL21lYXN1cmVtZW50LmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLG1CQUFtQixtQkFBTyxDQUFDLDRIQUFtQjtBQUM5QywyQkFBMkIsbUJBQU8sQ0FBQywwSUFBMEI7QUFDN0Qsb0JBQW9CLG1CQUFPLENBQUMsMElBQTBCO0FBQ3RELGtCQUFrQixtQkFBTyxDQUFDLG9JQUF1Qjs7QUFFakQ7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0EsdUdBQXVHLE1BQU0sSUFBSSxPQUFPLEVBQUUsS0FBSztBQUMvSDtBQUNBO0FBQ0E7QUFDQSxLQUFLO0FBQ0w7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0EsbUNBQW1DO0FBQ25DO0FBQ0EsR0FBRzs7QUFFSDtBQUNBOztBQUVBLHNCQUFzQjtBQUN0QixpQ0FBaUM7QUFDakMiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy90cmFjaW5nL21lYXN1cmVtZW50LmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBkZWJ1Z0J1aWxkID0gcmVxdWlyZSgnLi4vZGVidWctYnVpbGQuanMnKTtcbmNvbnN0IHNlbWFudGljQXR0cmlidXRlcyA9IHJlcXVpcmUoJy4uL3NlbWFudGljQXR0cmlidXRlcy5qcycpO1xuY29uc3QgZGVidWdMb2dnZXIgPSByZXF1aXJlKCcuLi91dGlscy9kZWJ1Zy1sb2dnZXIuanMnKTtcbmNvbnN0IHNwYW5VdGlscyA9IHJlcXVpcmUoJy4uL3V0aWxzL3NwYW5VdGlscy5qcycpO1xuXG4vKipcbiAqIEFkZHMgYSBtZWFzdXJlbWVudCB0byB0aGUgYWN0aXZlIHRyYW5zYWN0aW9uIG9uIHRoZSBjdXJyZW50IGdsb2JhbCBzY29wZS4gWW91IGNhbiBvcHRpb25hbGx5IHBhc3MgaW4gYSBkaWZmZXJlbnQgc3BhblxuICogYXMgdGhlIDR0aCBwYXJhbWV0ZXIuXG4gKi9cbmZ1bmN0aW9uIHNldE1lYXN1cmVtZW50KG5hbWUsIHZhbHVlLCB1bml0LCBhY3RpdmVTcGFuID0gc3BhblV0aWxzLmdldEFjdGl2ZVNwYW4oKSkge1xuICBjb25zdCByb290U3BhbiA9IGFjdGl2ZVNwYW4gJiYgc3BhblV0aWxzLmdldFJvb3RTcGFuKGFjdGl2ZVNwYW4pO1xuXG4gIGlmIChyb290U3Bhbikge1xuICAgIGRlYnVnQnVpbGQuREVCVUdfQlVJTEQgJiYgZGVidWdMb2dnZXIuZGVidWcubG9nKGBbTWVhc3VyZW1lbnRdIFNldHRpbmcgbWVhc3VyZW1lbnQgb24gcm9vdCBzcGFuOiAke25hbWV9ID0gJHt2YWx1ZX0gJHt1bml0fWApO1xuICAgIHJvb3RTcGFuLmFkZEV2ZW50KG5hbWUsIHtcbiAgICAgIFtzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9NRUFTVVJFTUVOVF9WQUxVRV06IHZhbHVlLFxuICAgICAgW3NlbWFudGljQXR0cmlidXRlcy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX01FQVNVUkVNRU5UX1VOSVRdOiB1bml0ICxcbiAgICB9KTtcbiAgfVxufVxuXG4vKipcbiAqIENvbnZlcnQgdGltZWQgZXZlbnRzIHRvIG1lYXN1cmVtZW50cy5cbiAqL1xuZnVuY3Rpb24gdGltZWRFdmVudHNUb01lYXN1cmVtZW50cyhldmVudHMpIHtcbiAgaWYgKCFldmVudHMgfHwgZXZlbnRzLmxlbmd0aCA9PT0gMCkge1xuICAgIHJldHVybiB1bmRlZmluZWQ7XG4gIH1cblxuICBjb25zdCBtZWFzdXJlbWVudHMgPSB7fTtcbiAgZXZlbnRzLmZvckVhY2goZXZlbnQgPT4ge1xuICAgIGNvbnN0IGF0dHJpYnV0ZXMgPSBldmVudC5hdHRyaWJ1dGVzIHx8IHt9O1xuICAgIGNvbnN0IHVuaXQgPSBhdHRyaWJ1dGVzW3NlbWFudGljQXR0cmlidXRlcy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX01FQVNVUkVNRU5UX1VOSVRdIDtcbiAgICBjb25zdCB2YWx1ZSA9IGF0dHJpYnV0ZXNbc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfTUVBU1VSRU1FTlRfVkFMVUVdIDtcblxuICAgIGlmICh0eXBlb2YgdW5pdCA9PT0gJ3N0cmluZycgJiYgdHlwZW9mIHZhbHVlID09PSAnbnVtYmVyJykge1xuICAgICAgbWVhc3VyZW1lbnRzW2V2ZW50Lm5hbWVdID0geyB2YWx1ZSwgdW5pdCB9O1xuICAgIH1cbiAgfSk7XG5cbiAgcmV0dXJuIG1lYXN1cmVtZW50cztcbn1cblxuZXhwb3J0cy5zZXRNZWFzdXJlbWVudCA9IHNldE1lYXN1cmVtZW50O1xuZXhwb3J0cy50aW1lZEV2ZW50c1RvTWVhc3VyZW1lbnRzID0gdGltZWRFdmVudHNUb01lYXN1cmVtZW50cztcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPW1lYXN1cmVtZW50LmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/measurement.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/sampling.js":
/*!********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/sampling.js ***!
  \********************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst debugBuild = __webpack_require__(/*! ../debug-build.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst debugLogger = __webpack_require__(/*! ../utils/debug-logger.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst hasSpansEnabled = __webpack_require__(/*! ../utils/hasSpansEnabled.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/hasSpansEnabled.js\");\nconst parseSampleRate = __webpack_require__(/*! ../utils/parseSampleRate.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/parseSampleRate.js\");\n\n/**\n * Makes a sampling decision for the given options.\n *\n * Called every time a root span is created. Only root spans which emerge with a `sampled` value of `true` will be\n * sent to Sentry.\n */\nfunction sampleSpan(\n  options,\n  samplingContext,\n  sampleRand,\n) {\n  // nothing to do if span recording is not enabled\n  if (!hasSpansEnabled.hasSpansEnabled(options)) {\n    return [false];\n  }\n\n  let localSampleRateWasApplied = undefined;\n\n  // we would have bailed already if neither `tracesSampler` nor `tracesSampleRate` were defined, so one of these should\n  // work; prefer the hook if so\n  let sampleRate;\n  if (typeof options.tracesSampler === 'function') {\n    sampleRate = options.tracesSampler({\n      ...samplingContext,\n      inheritOrSampleWith: fallbackSampleRate => {\n        // If we have an incoming parent sample rate, we'll just use that one.\n        // The sampling decision will be inherited because of the sample_rand that was generated when the trace reached the incoming boundaries of the SDK.\n        if (typeof samplingContext.parentSampleRate === 'number') {\n          return samplingContext.parentSampleRate;\n        }\n\n        // Fallback if parent sample rate is not on the incoming trace (e.g. if there is no baggage)\n        // This is to provide backwards compatibility if there are incoming traces from older SDKs that don't send a parent sample rate or a sample rand. In these cases we just want to force either a sampling decision on the downstream traces via the sample rate.\n        if (typeof samplingContext.parentSampled === 'boolean') {\n          return Number(samplingContext.parentSampled);\n        }\n\n        return fallbackSampleRate;\n      },\n    });\n    localSampleRateWasApplied = true;\n  } else if (samplingContext.parentSampled !== undefined) {\n    sampleRate = samplingContext.parentSampled;\n  } else if (typeof options.tracesSampleRate !== 'undefined') {\n    sampleRate = options.tracesSampleRate;\n    localSampleRateWasApplied = true;\n  }\n\n  // Since this is coming from the user (or from a function provided by the user), who knows what we might get.\n  // (The only valid values are booleans or numbers between 0 and 1.)\n  const parsedSampleRate = parseSampleRate.parseSampleRate(sampleRate);\n\n  if (parsedSampleRate === undefined) {\n    debugBuild.DEBUG_BUILD &&\n      debugLogger.debug.warn(\n        `[Tracing] Discarding root span because of invalid sample rate. Sample rate must be a boolean or a number between 0 and 1. Got ${JSON.stringify(\n          sampleRate,\n        )} of type ${JSON.stringify(typeof sampleRate)}.`,\n      );\n    return [false];\n  }\n\n  // if the function returned 0 (or false), or if `tracesSampleRate` is 0, it's a sign the transaction should be dropped\n  if (!parsedSampleRate) {\n    debugBuild.DEBUG_BUILD &&\n      debugLogger.debug.log(\n        `[Tracing] Discarding transaction because ${\n          typeof options.tracesSampler === 'function'\n            ? 'tracesSampler returned 0 or false'\n            : 'a negative sampling decision was inherited or tracesSampleRate is set to 0'\n        }`,\n      );\n    return [false, parsedSampleRate, localSampleRateWasApplied];\n  }\n\n  // We always compare the sample rand for the current execution context against the chosen sample rate.\n  // Read more: https://develop.sentry.dev/sdk/telemetry/traces/#propagated-random-value\n  const shouldSample = sampleRand < parsedSampleRate;\n\n  // if we're not going to keep it, we're done\n  if (!shouldSample) {\n    debugBuild.DEBUG_BUILD &&\n      debugLogger.debug.log(\n        `[Tracing] Discarding transaction because it's not included in the random sample (sampling rate = ${Number(\n          sampleRate,\n        )})`,\n      );\n  }\n\n  return [shouldSample, parsedSampleRate, localSampleRateWasApplied];\n}\n\nexports.sampleSpan = sampleSpan;\n//# sourceMappingURL=sampling.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy90cmFjaW5nL3NhbXBsaW5nLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLG1CQUFtQixtQkFBTyxDQUFDLDRIQUFtQjtBQUM5QyxvQkFBb0IsbUJBQU8sQ0FBQywwSUFBMEI7QUFDdEQsd0JBQXdCLG1CQUFPLENBQUMsZ0pBQTZCO0FBQzdELHdCQUF3QixtQkFBTyxDQUFDLGdKQUE2Qjs7QUFFN0Q7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBOztBQUVBO0FBQ0EsV0FBVztBQUNYO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQSxPQUFPO0FBQ1AsS0FBSztBQUNMO0FBQ0EsSUFBSTtBQUNKO0FBQ0EsSUFBSTtBQUNKO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0EseUlBQXlJO0FBQ3pJO0FBQ0EsV0FBVyxVQUFVLGtDQUFrQztBQUN2RDtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFNBQVM7QUFDVDtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsNEdBQTRHO0FBQzVHO0FBQ0EsVUFBVTtBQUNWO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQSxrQkFBa0I7QUFDbEIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy90cmFjaW5nL3NhbXBsaW5nLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBkZWJ1Z0J1aWxkID0gcmVxdWlyZSgnLi4vZGVidWctYnVpbGQuanMnKTtcbmNvbnN0IGRlYnVnTG9nZ2VyID0gcmVxdWlyZSgnLi4vdXRpbHMvZGVidWctbG9nZ2VyLmpzJyk7XG5jb25zdCBoYXNTcGFuc0VuYWJsZWQgPSByZXF1aXJlKCcuLi91dGlscy9oYXNTcGFuc0VuYWJsZWQuanMnKTtcbmNvbnN0IHBhcnNlU2FtcGxlUmF0ZSA9IHJlcXVpcmUoJy4uL3V0aWxzL3BhcnNlU2FtcGxlUmF0ZS5qcycpO1xuXG4vKipcbiAqIE1ha2VzIGEgc2FtcGxpbmcgZGVjaXNpb24gZm9yIHRoZSBnaXZlbiBvcHRpb25zLlxuICpcbiAqIENhbGxlZCBldmVyeSB0aW1lIGEgcm9vdCBzcGFuIGlzIGNyZWF0ZWQuIE9ubHkgcm9vdCBzcGFucyB3aGljaCBlbWVyZ2Ugd2l0aCBhIGBzYW1wbGVkYCB2YWx1ZSBvZiBgdHJ1ZWAgd2lsbCBiZVxuICogc2VudCB0byBTZW50cnkuXG4gKi9cbmZ1bmN0aW9uIHNhbXBsZVNwYW4oXG4gIG9wdGlvbnMsXG4gIHNhbXBsaW5nQ29udGV4dCxcbiAgc2FtcGxlUmFuZCxcbikge1xuICAvLyBub3RoaW5nIHRvIGRvIGlmIHNwYW4gcmVjb3JkaW5nIGlzIG5vdCBlbmFibGVkXG4gIGlmICghaGFzU3BhbnNFbmFibGVkLmhhc1NwYW5zRW5hYmxlZChvcHRpb25zKSkge1xuICAgIHJldHVybiBbZmFsc2VdO1xuICB9XG5cbiAgbGV0IGxvY2FsU2FtcGxlUmF0ZVdhc0FwcGxpZWQgPSB1bmRlZmluZWQ7XG5cbiAgLy8gd2Ugd291bGQgaGF2ZSBiYWlsZWQgYWxyZWFkeSBpZiBuZWl0aGVyIGB0cmFjZXNTYW1wbGVyYCBub3IgYHRyYWNlc1NhbXBsZVJhdGVgIHdlcmUgZGVmaW5lZCwgc28gb25lIG9mIHRoZXNlIHNob3VsZFxuICAvLyB3b3JrOyBwcmVmZXIgdGhlIGhvb2sgaWYgc29cbiAgbGV0IHNhbXBsZVJhdGU7XG4gIGlmICh0eXBlb2Ygb3B0aW9ucy50cmFjZXNTYW1wbGVyID09PSAnZnVuY3Rpb24nKSB7XG4gICAgc2FtcGxlUmF0ZSA9IG9wdGlvbnMudHJhY2VzU2FtcGxlcih7XG4gICAgICAuLi5zYW1wbGluZ0NvbnRleHQsXG4gICAgICBpbmhlcml0T3JTYW1wbGVXaXRoOiBmYWxsYmFja1NhbXBsZVJhdGUgPT4ge1xuICAgICAgICAvLyBJZiB3ZSBoYXZlIGFuIGluY29taW5nIHBhcmVudCBzYW1wbGUgcmF0ZSwgd2UnbGwganVzdCB1c2UgdGhhdCBvbmUuXG4gICAgICAgIC8vIFRoZSBzYW1wbGluZyBkZWNpc2lvbiB3aWxsIGJlIGluaGVyaXRlZCBiZWNhdXNlIG9mIHRoZSBzYW1wbGVfcmFuZCB0aGF0IHdhcyBnZW5lcmF0ZWQgd2hlbiB0aGUgdHJhY2UgcmVhY2hlZCB0aGUgaW5jb21pbmcgYm91bmRhcmllcyBvZiB0aGUgU0RLLlxuICAgICAgICBpZiAodHlwZW9mIHNhbXBsaW5nQ29udGV4dC5wYXJlbnRTYW1wbGVSYXRlID09PSAnbnVtYmVyJykge1xuICAgICAgICAgIHJldHVybiBzYW1wbGluZ0NvbnRleHQucGFyZW50U2FtcGxlUmF0ZTtcbiAgICAgICAgfVxuXG4gICAgICAgIC8vIEZhbGxiYWNrIGlmIHBhcmVudCBzYW1wbGUgcmF0ZSBpcyBub3Qgb24gdGhlIGluY29taW5nIHRyYWNlIChlLmcuIGlmIHRoZXJlIGlzIG5vIGJhZ2dhZ2UpXG4gICAgICAgIC8vIFRoaXMgaXMgdG8gcHJvdmlkZSBiYWNrd2FyZHMgY29tcGF0aWJpbGl0eSBpZiB0aGVyZSBhcmUgaW5jb21pbmcgdHJhY2VzIGZyb20gb2xkZXIgU0RLcyB0aGF0IGRvbid0IHNlbmQgYSBwYXJlbnQgc2FtcGxlIHJhdGUgb3IgYSBzYW1wbGUgcmFuZC4gSW4gdGhlc2UgY2FzZXMgd2UganVzdCB3YW50IHRvIGZvcmNlIGVpdGhlciBhIHNhbXBsaW5nIGRlY2lzaW9uIG9uIHRoZSBkb3duc3RyZWFtIHRyYWNlcyB2aWEgdGhlIHNhbXBsZSByYXRlLlxuICAgICAgICBpZiAodHlwZW9mIHNhbXBsaW5nQ29udGV4dC5wYXJlbnRTYW1wbGVkID09PSAnYm9vbGVhbicpIHtcbiAgICAgICAgICByZXR1cm4gTnVtYmVyKHNhbXBsaW5nQ29udGV4dC5wYXJlbnRTYW1wbGVkKTtcbiAgICAgICAgfVxuXG4gICAgICAgIHJldHVybiBmYWxsYmFja1NhbXBsZVJhdGU7XG4gICAgICB9LFxuICAgIH0pO1xuICAgIGxvY2FsU2FtcGxlUmF0ZVdhc0FwcGxpZWQgPSB0cnVlO1xuICB9IGVsc2UgaWYgKHNhbXBsaW5nQ29udGV4dC5wYXJlbnRTYW1wbGVkICE9PSB1bmRlZmluZWQpIHtcbiAgICBzYW1wbGVSYXRlID0gc2FtcGxpbmdDb250ZXh0LnBhcmVudFNhbXBsZWQ7XG4gIH0gZWxzZSBpZiAodHlwZW9mIG9wdGlvbnMudHJhY2VzU2FtcGxlUmF0ZSAhPT0gJ3VuZGVmaW5lZCcpIHtcbiAgICBzYW1wbGVSYXRlID0gb3B0aW9ucy50cmFjZXNTYW1wbGVSYXRlO1xuICAgIGxvY2FsU2FtcGxlUmF0ZVdhc0FwcGxpZWQgPSB0cnVlO1xuICB9XG5cbiAgLy8gU2luY2UgdGhpcyBpcyBjb21pbmcgZnJvbSB0aGUgdXNlciAob3IgZnJvbSBhIGZ1bmN0aW9uIHByb3ZpZGVkIGJ5IHRoZSB1c2VyKSwgd2hvIGtub3dzIHdoYXQgd2UgbWlnaHQgZ2V0LlxuICAvLyAoVGhlIG9ubHkgdmFsaWQgdmFsdWVzIGFyZSBib29sZWFucyBvciBudW1iZXJzIGJldHdlZW4gMCBhbmQgMS4pXG4gIGNvbnN0IHBhcnNlZFNhbXBsZVJhdGUgPSBwYXJzZVNhbXBsZVJhdGUucGFyc2VTYW1wbGVSYXRlKHNhbXBsZVJhdGUpO1xuXG4gIGlmIChwYXJzZWRTYW1wbGVSYXRlID09PSB1bmRlZmluZWQpIHtcbiAgICBkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEICYmXG4gICAgICBkZWJ1Z0xvZ2dlci5kZWJ1Zy53YXJuKFxuICAgICAgICBgW1RyYWNpbmddIERpc2NhcmRpbmcgcm9vdCBzcGFuIGJlY2F1c2Ugb2YgaW52YWxpZCBzYW1wbGUgcmF0ZS4gU2FtcGxlIHJhdGUgbXVzdCBiZSBhIGJvb2xlYW4gb3IgYSBudW1iZXIgYmV0d2VlbiAwIGFuZCAxLiBHb3QgJHtKU09OLnN0cmluZ2lmeShcbiAgICAgICAgICBzYW1wbGVSYXRlLFxuICAgICAgICApfSBvZiB0eXBlICR7SlNPTi5zdHJpbmdpZnkodHlwZW9mIHNhbXBsZVJhdGUpfS5gLFxuICAgICAgKTtcbiAgICByZXR1cm4gW2ZhbHNlXTtcbiAgfVxuXG4gIC8vIGlmIHRoZSBmdW5jdGlvbiByZXR1cm5lZCAwIChvciBmYWxzZSksIG9yIGlmIGB0cmFjZXNTYW1wbGVSYXRlYCBpcyAwLCBpdCdzIGEgc2lnbiB0aGUgdHJhbnNhY3Rpb24gc2hvdWxkIGJlIGRyb3BwZWRcbiAgaWYgKCFwYXJzZWRTYW1wbGVSYXRlKSB7XG4gICAgZGVidWdCdWlsZC5ERUJVR19CVUlMRCAmJlxuICAgICAgZGVidWdMb2dnZXIuZGVidWcubG9nKFxuICAgICAgICBgW1RyYWNpbmddIERpc2NhcmRpbmcgdHJhbnNhY3Rpb24gYmVjYXVzZSAke1xuICAgICAgICAgIHR5cGVvZiBvcHRpb25zLnRyYWNlc1NhbXBsZXIgPT09ICdmdW5jdGlvbidcbiAgICAgICAgICAgID8gJ3RyYWNlc1NhbXBsZXIgcmV0dXJuZWQgMCBvciBmYWxzZSdcbiAgICAgICAgICAgIDogJ2EgbmVnYXRpdmUgc2FtcGxpbmcgZGVjaXNpb24gd2FzIGluaGVyaXRlZCBvciB0cmFjZXNTYW1wbGVSYXRlIGlzIHNldCB0byAwJ1xuICAgICAgICB9YCxcbiAgICAgICk7XG4gICAgcmV0dXJuIFtmYWxzZSwgcGFyc2VkU2FtcGxlUmF0ZSwgbG9jYWxTYW1wbGVSYXRlV2FzQXBwbGllZF07XG4gIH1cblxuICAvLyBXZSBhbHdheXMgY29tcGFyZSB0aGUgc2FtcGxlIHJhbmQgZm9yIHRoZSBjdXJyZW50IGV4ZWN1dGlvbiBjb250ZXh0IGFnYWluc3QgdGhlIGNob3NlbiBzYW1wbGUgcmF0ZS5cbiAgLy8gUmVhZCBtb3JlOiBodHRwczovL2RldmVsb3Auc2VudHJ5LmRldi9zZGsvdGVsZW1ldHJ5L3RyYWNlcy8jcHJvcGFnYXRlZC1yYW5kb20tdmFsdWVcbiAgY29uc3Qgc2hvdWxkU2FtcGxlID0gc2FtcGxlUmFuZCA8IHBhcnNlZFNhbXBsZVJhdGU7XG5cbiAgLy8gaWYgd2UncmUgbm90IGdvaW5nIHRvIGtlZXAgaXQsIHdlJ3JlIGRvbmVcbiAgaWYgKCFzaG91bGRTYW1wbGUpIHtcbiAgICBkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEICYmXG4gICAgICBkZWJ1Z0xvZ2dlci5kZWJ1Zy5sb2coXG4gICAgICAgIGBbVHJhY2luZ10gRGlzY2FyZGluZyB0cmFuc2FjdGlvbiBiZWNhdXNlIGl0J3Mgbm90IGluY2x1ZGVkIGluIHRoZSByYW5kb20gc2FtcGxlIChzYW1wbGluZyByYXRlID0gJHtOdW1iZXIoXG4gICAgICAgICAgc2FtcGxlUmF0ZSxcbiAgICAgICAgKX0pYCxcbiAgICAgICk7XG4gIH1cblxuICByZXR1cm4gW3Nob3VsZFNhbXBsZSwgcGFyc2VkU2FtcGxlUmF0ZSwgbG9jYWxTYW1wbGVSYXRlV2FzQXBwbGllZF07XG59XG5cbmV4cG9ydHMuc2FtcGxlU3BhbiA9IHNhbXBsZVNwYW47XG4vLyMgc291cmNlTWFwcGluZ1VSTD1zYW1wbGluZy5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/sampling.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/sentryNonRecordingSpan.js":
/*!**********************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/sentryNonRecordingSpan.js ***!
  \**********************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst propagationContext = __webpack_require__(/*! ../utils/propagationContext.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/propagationContext.js\");\nconst spanUtils = __webpack_require__(/*! ../utils/spanUtils.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanUtils.js\");\n\n/**\n * A Sentry Span that is non-recording, meaning it will not be sent to Sentry.\n */\nclass SentryNonRecordingSpan  {\n\n   constructor(spanContext = {}) {\n    this._traceId = spanContext.traceId || propagationContext.generateTraceId();\n    this._spanId = spanContext.spanId || propagationContext.generateSpanId();\n  }\n\n  /** @inheritdoc */\n   spanContext() {\n    return {\n      spanId: this._spanId,\n      traceId: this._traceId,\n      traceFlags: spanUtils.TRACE_FLAG_NONE,\n    };\n  }\n\n  /** @inheritdoc */\n   end(_timestamp) {}\n\n  /** @inheritdoc */\n   setAttribute(_key, _value) {\n    return this;\n  }\n\n  /** @inheritdoc */\n   setAttributes(_values) {\n    return this;\n  }\n\n  /** @inheritdoc */\n   setStatus(_status) {\n    return this;\n  }\n\n  /** @inheritdoc */\n   updateName(_name) {\n    return this;\n  }\n\n  /** @inheritdoc */\n   isRecording() {\n    return false;\n  }\n\n  /** @inheritdoc */\n   addEvent(\n    _name,\n    _attributesOrStartTime,\n    _startTime,\n  ) {\n    return this;\n  }\n\n  /** @inheritDoc */\n   addLink(_link) {\n    return this;\n  }\n\n  /** @inheritDoc */\n   addLinks(_links) {\n    return this;\n  }\n\n  /**\n   * This should generally not be used,\n   * but we need it for being compliant with the OTEL Span interface.\n   *\n   * @hidden\n   * @internal\n   */\n   recordException(_exception, _time) {\n    // noop\n  }\n}\n\nexports.SentryNonRecordingSpan = SentryNonRecordingSpan;\n//# sourceMappingURL=sentryNonRecordingSpan.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy90cmFjaW5nL3NlbnRyeU5vblJlY29yZGluZ1NwYW4uanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsMkJBQTJCLG1CQUFPLENBQUMsc0pBQWdDO0FBQ25FLGtCQUFrQixtQkFBTyxDQUFDLG9JQUF1Qjs7QUFFakQ7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsK0JBQStCO0FBQy9CO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLDhCQUE4QjtBQUM5QiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3RyYWNpbmcvc2VudHJ5Tm9uUmVjb3JkaW5nU3Bhbi5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgcHJvcGFnYXRpb25Db250ZXh0ID0gcmVxdWlyZSgnLi4vdXRpbHMvcHJvcGFnYXRpb25Db250ZXh0LmpzJyk7XG5jb25zdCBzcGFuVXRpbHMgPSByZXF1aXJlKCcuLi91dGlscy9zcGFuVXRpbHMuanMnKTtcblxuLyoqXG4gKiBBIFNlbnRyeSBTcGFuIHRoYXQgaXMgbm9uLXJlY29yZGluZywgbWVhbmluZyBpdCB3aWxsIG5vdCBiZSBzZW50IHRvIFNlbnRyeS5cbiAqL1xuY2xhc3MgU2VudHJ5Tm9uUmVjb3JkaW5nU3BhbiAge1xuXG4gICBjb25zdHJ1Y3RvcihzcGFuQ29udGV4dCA9IHt9KSB7XG4gICAgdGhpcy5fdHJhY2VJZCA9IHNwYW5Db250ZXh0LnRyYWNlSWQgfHwgcHJvcGFnYXRpb25Db250ZXh0LmdlbmVyYXRlVHJhY2VJZCgpO1xuICAgIHRoaXMuX3NwYW5JZCA9IHNwYW5Db250ZXh0LnNwYW5JZCB8fCBwcm9wYWdhdGlvbkNvbnRleHQuZ2VuZXJhdGVTcGFuSWQoKTtcbiAgfVxuXG4gIC8qKiBAaW5oZXJpdGRvYyAqL1xuICAgc3BhbkNvbnRleHQoKSB7XG4gICAgcmV0dXJuIHtcbiAgICAgIHNwYW5JZDogdGhpcy5fc3BhbklkLFxuICAgICAgdHJhY2VJZDogdGhpcy5fdHJhY2VJZCxcbiAgICAgIHRyYWNlRmxhZ3M6IHNwYW5VdGlscy5UUkFDRV9GTEFHX05PTkUsXG4gICAgfTtcbiAgfVxuXG4gIC8qKiBAaW5oZXJpdGRvYyAqL1xuICAgZW5kKF90aW1lc3RhbXApIHt9XG5cbiAgLyoqIEBpbmhlcml0ZG9jICovXG4gICBzZXRBdHRyaWJ1dGUoX2tleSwgX3ZhbHVlKSB7XG4gICAgcmV0dXJuIHRoaXM7XG4gIH1cblxuICAvKiogQGluaGVyaXRkb2MgKi9cbiAgIHNldEF0dHJpYnV0ZXMoX3ZhbHVlcykge1xuICAgIHJldHVybiB0aGlzO1xuICB9XG5cbiAgLyoqIEBpbmhlcml0ZG9jICovXG4gICBzZXRTdGF0dXMoX3N0YXR1cykge1xuICAgIHJldHVybiB0aGlzO1xuICB9XG5cbiAgLyoqIEBpbmhlcml0ZG9jICovXG4gICB1cGRhdGVOYW1lKF9uYW1lKSB7XG4gICAgcmV0dXJuIHRoaXM7XG4gIH1cblxuICAvKiogQGluaGVyaXRkb2MgKi9cbiAgIGlzUmVjb3JkaW5nKCkge1xuICAgIHJldHVybiBmYWxzZTtcbiAgfVxuXG4gIC8qKiBAaW5oZXJpdGRvYyAqL1xuICAgYWRkRXZlbnQoXG4gICAgX25hbWUsXG4gICAgX2F0dHJpYnV0ZXNPclN0YXJ0VGltZSxcbiAgICBfc3RhcnRUaW1lLFxuICApIHtcbiAgICByZXR1cm4gdGhpcztcbiAgfVxuXG4gIC8qKiBAaW5oZXJpdERvYyAqL1xuICAgYWRkTGluayhfbGluaykge1xuICAgIHJldHVybiB0aGlzO1xuICB9XG5cbiAgLyoqIEBpbmhlcml0RG9jICovXG4gICBhZGRMaW5rcyhfbGlua3MpIHtcbiAgICByZXR1cm4gdGhpcztcbiAgfVxuXG4gIC8qKlxuICAgKiBUaGlzIHNob3VsZCBnZW5lcmFsbHkgbm90IGJlIHVzZWQsXG4gICAqIGJ1dCB3ZSBuZWVkIGl0IGZvciBiZWluZyBjb21wbGlhbnQgd2l0aCB0aGUgT1RFTCBTcGFuIGludGVyZmFjZS5cbiAgICpcbiAgICogQGhpZGRlblxuICAgKiBAaW50ZXJuYWxcbiAgICovXG4gICByZWNvcmRFeGNlcHRpb24oX2V4Y2VwdGlvbiwgX3RpbWUpIHtcbiAgICAvLyBub29wXG4gIH1cbn1cblxuZXhwb3J0cy5TZW50cnlOb25SZWNvcmRpbmdTcGFuID0gU2VudHJ5Tm9uUmVjb3JkaW5nU3Bhbjtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPXNlbnRyeU5vblJlY29yZGluZ1NwYW4uanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/sentryNonRecordingSpan.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/sentrySpan.js":
/*!**********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/sentrySpan.js ***!
  \**********************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst currentScopes = __webpack_require__(/*! ../currentScopes.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst debugBuild = __webpack_require__(/*! ../debug-build.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst envelope = __webpack_require__(/*! ../envelope.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/envelope.js\");\nconst semanticAttributes = __webpack_require__(/*! ../semanticAttributes.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/semanticAttributes.js\");\nconst debugLogger = __webpack_require__(/*! ../utils/debug-logger.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst propagationContext = __webpack_require__(/*! ../utils/propagationContext.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/propagationContext.js\");\nconst spanUtils = __webpack_require__(/*! ../utils/spanUtils.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanUtils.js\");\nconst time = __webpack_require__(/*! ../utils/time.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/time.js\");\nconst dynamicSamplingContext = __webpack_require__(/*! ./dynamicSamplingContext.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/dynamicSamplingContext.js\");\nconst logSpans = __webpack_require__(/*! ./logSpans.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/logSpans.js\");\nconst measurement = __webpack_require__(/*! ./measurement.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/measurement.js\");\nconst utils = __webpack_require__(/*! ./utils.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/utils.js\");\n\nconst MAX_SPAN_COUNT = 1000;\n\n/**\n * Span contains all data about a span\n */\nclass SentrySpan  {\n\n  /** Epoch timestamp in seconds when the span started. */\n\n  /** Epoch timestamp in seconds when the span ended. */\n\n  /** Internal keeper of the status */\n\n  /** The timed events added to this span. */\n\n  /** if true, treat span as a standalone span (not part of a transaction) */\n\n  /**\n   * You should never call the constructor manually, always use `Sentry.startSpan()`\n   * or other span methods.\n   * @internal\n   * @hideconstructor\n   * @hidden\n   */\n   constructor(spanContext = {}) {\n    this._traceId = spanContext.traceId || propagationContext.generateTraceId();\n    this._spanId = spanContext.spanId || propagationContext.generateSpanId();\n    this._startTime = spanContext.startTimestamp || time.timestampInSeconds();\n    this._links = spanContext.links;\n\n    this._attributes = {};\n    this.setAttributes({\n      [semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_ORIGIN]: 'manual',\n      [semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_OP]: spanContext.op,\n      ...spanContext.attributes,\n    });\n\n    this._name = spanContext.name;\n\n    if (spanContext.parentSpanId) {\n      this._parentSpanId = spanContext.parentSpanId;\n    }\n    // We want to include booleans as well here\n    if ('sampled' in spanContext) {\n      this._sampled = spanContext.sampled;\n    }\n    if (spanContext.endTimestamp) {\n      this._endTime = spanContext.endTimestamp;\n    }\n\n    this._events = [];\n\n    this._isStandaloneSpan = spanContext.isStandalone;\n\n    // If the span is already ended, ensure we finalize the span immediately\n    if (this._endTime) {\n      this._onSpanEnded();\n    }\n  }\n\n  /** @inheritDoc */\n   addLink(link) {\n    if (this._links) {\n      this._links.push(link);\n    } else {\n      this._links = [link];\n    }\n    return this;\n  }\n\n  /** @inheritDoc */\n   addLinks(links) {\n    if (this._links) {\n      this._links.push(...links);\n    } else {\n      this._links = links;\n    }\n    return this;\n  }\n\n  /**\n   * This should generally not be used,\n   * but it is needed for being compliant with the OTEL Span interface.\n   *\n   * @hidden\n   * @internal\n   */\n   recordException(_exception, _time) {\n    // noop\n  }\n\n  /** @inheritdoc */\n   spanContext() {\n    const { _spanId: spanId, _traceId: traceId, _sampled: sampled } = this;\n    return {\n      spanId,\n      traceId,\n      traceFlags: sampled ? spanUtils.TRACE_FLAG_SAMPLED : spanUtils.TRACE_FLAG_NONE,\n    };\n  }\n\n  /** @inheritdoc */\n   setAttribute(key, value) {\n    if (value === undefined) {\n      // eslint-disable-next-line @typescript-eslint/no-dynamic-delete\n      delete this._attributes[key];\n    } else {\n      this._attributes[key] = value;\n    }\n\n    return this;\n  }\n\n  /** @inheritdoc */\n   setAttributes(attributes) {\n    Object.keys(attributes).forEach(key => this.setAttribute(key, attributes[key]));\n    return this;\n  }\n\n  /**\n   * This should generally not be used,\n   * but we need it for browser tracing where we want to adjust the start time afterwards.\n   * USE THIS WITH CAUTION!\n   *\n   * @hidden\n   * @internal\n   */\n   updateStartTime(timeInput) {\n    this._startTime = spanUtils.spanTimeInputToSeconds(timeInput);\n  }\n\n  /**\n   * @inheritDoc\n   */\n   setStatus(value) {\n    this._status = value;\n    return this;\n  }\n\n  /**\n   * @inheritDoc\n   */\n   updateName(name) {\n    this._name = name;\n    this.setAttribute(semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_SOURCE, 'custom');\n    return this;\n  }\n\n  /** @inheritdoc */\n   end(endTimestamp) {\n    // If already ended, skip\n    if (this._endTime) {\n      return;\n    }\n\n    this._endTime = spanUtils.spanTimeInputToSeconds(endTimestamp);\n    logSpans.logSpanEnd(this);\n\n    this._onSpanEnded();\n  }\n\n  /**\n   * Get JSON representation of this span.\n   *\n   * @hidden\n   * @internal This method is purely for internal purposes and should not be used outside\n   * of SDK code. If you need to get a JSON representation of a span,\n   * use `spanToJSON(span)` instead.\n   */\n   getSpanJSON() {\n    return {\n      data: this._attributes,\n      description: this._name,\n      op: this._attributes[semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_OP],\n      parent_span_id: this._parentSpanId,\n      span_id: this._spanId,\n      start_timestamp: this._startTime,\n      status: spanUtils.getStatusMessage(this._status),\n      timestamp: this._endTime,\n      trace_id: this._traceId,\n      origin: this._attributes[semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_ORIGIN] ,\n      profile_id: this._attributes[semanticAttributes.SEMANTIC_ATTRIBUTE_PROFILE_ID] ,\n      exclusive_time: this._attributes[semanticAttributes.SEMANTIC_ATTRIBUTE_EXCLUSIVE_TIME] ,\n      measurements: measurement.timedEventsToMeasurements(this._events),\n      is_segment: (this._isStandaloneSpan && spanUtils.getRootSpan(this) === this) || undefined,\n      segment_id: this._isStandaloneSpan ? spanUtils.getRootSpan(this).spanContext().spanId : undefined,\n      links: spanUtils.convertSpanLinksForEnvelope(this._links),\n    };\n  }\n\n  /** @inheritdoc */\n   isRecording() {\n    return !this._endTime && !!this._sampled;\n  }\n\n  /**\n   * @inheritdoc\n   */\n   addEvent(\n    name,\n    attributesOrStartTime,\n    startTime,\n  ) {\n    debugBuild.DEBUG_BUILD && debugLogger.debug.log('[Tracing] Adding an event to span:', name);\n\n    const time$1 = isSpanTimeInput(attributesOrStartTime) ? attributesOrStartTime : startTime || time.timestampInSeconds();\n    const attributes = isSpanTimeInput(attributesOrStartTime) ? {} : attributesOrStartTime || {};\n\n    const event = {\n      name,\n      time: spanUtils.spanTimeInputToSeconds(time$1),\n      attributes,\n    };\n\n    this._events.push(event);\n\n    return this;\n  }\n\n  /**\n   * This method should generally not be used,\n   * but for now we need a way to publicly check if the `_isStandaloneSpan` flag is set.\n   * USE THIS WITH CAUTION!\n   * @internal\n   * @hidden\n   * @experimental\n   */\n   isStandaloneSpan() {\n    return !!this._isStandaloneSpan;\n  }\n\n  /** Emit `spanEnd` when the span is ended. */\n   _onSpanEnded() {\n    const client = currentScopes.getClient();\n    if (client) {\n      client.emit('spanEnd', this);\n    }\n\n    // A segment span is basically the root span of a local span tree.\n    // So for now, this is either what we previously refer to as the root span,\n    // or a standalone span.\n    const isSegmentSpan = this._isStandaloneSpan || this === spanUtils.getRootSpan(this);\n\n    if (!isSegmentSpan) {\n      return;\n    }\n\n    // if this is a standalone span, we send it immediately\n    if (this._isStandaloneSpan) {\n      if (this._sampled) {\n        sendSpanEnvelope(envelope.createSpanEnvelope([this], client));\n      } else {\n        debugBuild.DEBUG_BUILD &&\n          debugLogger.debug.log('[Tracing] Discarding standalone span because its trace was not chosen to be sampled.');\n        if (client) {\n          client.recordDroppedEvent('sample_rate', 'span');\n        }\n      }\n      return;\n    }\n\n    const transactionEvent = this._convertSpanToTransaction();\n    if (transactionEvent) {\n      const scope = utils.getCapturedScopesOnSpan(this).scope || currentScopes.getCurrentScope();\n      scope.captureEvent(transactionEvent);\n    }\n  }\n\n  /**\n   * Finish the transaction & prepare the event to send to Sentry.\n   */\n   _convertSpanToTransaction() {\n    // We can only convert finished spans\n    if (!isFullFinishedSpan(spanUtils.spanToJSON(this))) {\n      return undefined;\n    }\n\n    if (!this._name) {\n      debugBuild.DEBUG_BUILD && debugLogger.debug.warn('Transaction has no name, falling back to `<unlabeled transaction>`.');\n      this._name = '<unlabeled transaction>';\n    }\n\n    const { scope: capturedSpanScope, isolationScope: capturedSpanIsolationScope } = utils.getCapturedScopesOnSpan(this);\n\n    const normalizedRequest = capturedSpanScope?.getScopeData().sdkProcessingMetadata?.normalizedRequest;\n\n    if (this._sampled !== true) {\n      return undefined;\n    }\n\n    // The transaction span itself as well as any potential standalone spans should be filtered out\n    const finishedSpans = spanUtils.getSpanDescendants(this).filter(span => span !== this && !isStandaloneSpan(span));\n\n    const spans = finishedSpans.map(span => spanUtils.spanToJSON(span)).filter(isFullFinishedSpan);\n\n    const source = this._attributes[semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_SOURCE] ;\n\n    // remove internal root span attributes we don't need to send.\n    /* eslint-disable @typescript-eslint/no-dynamic-delete */\n    delete this._attributes[semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_CUSTOM_SPAN_NAME];\n    spans.forEach(span => {\n      delete span.data[semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_CUSTOM_SPAN_NAME];\n    });\n    // eslint-enabled-next-line @typescript-eslint/no-dynamic-delete\n\n    const transaction = {\n      contexts: {\n        trace: spanUtils.spanToTransactionTraceContext(this),\n      },\n      spans:\n        // spans.sort() mutates the array, but `spans` is already a copy so we can safely do this here\n        // we do not use spans anymore after this point\n        spans.length > MAX_SPAN_COUNT\n          ? spans.sort((a, b) => a.start_timestamp - b.start_timestamp).slice(0, MAX_SPAN_COUNT)\n          : spans,\n      start_timestamp: this._startTime,\n      timestamp: this._endTime,\n      transaction: this._name,\n      type: 'transaction',\n      sdkProcessingMetadata: {\n        capturedSpanScope,\n        capturedSpanIsolationScope,\n        dynamicSamplingContext: dynamicSamplingContext.getDynamicSamplingContextFromSpan(this),\n      },\n      request: normalizedRequest,\n      ...(source && {\n        transaction_info: {\n          source,\n        },\n      }),\n    };\n\n    const measurements = measurement.timedEventsToMeasurements(this._events);\n    const hasMeasurements = measurements && Object.keys(measurements).length;\n\n    if (hasMeasurements) {\n      debugBuild.DEBUG_BUILD &&\n        debugLogger.debug.log(\n          '[Measurements] Adding measurements to transaction event',\n          JSON.stringify(measurements, undefined, 2),\n        );\n      transaction.measurements = measurements;\n    }\n\n    return transaction;\n  }\n}\n\nfunction isSpanTimeInput(value) {\n  return (value && typeof value === 'number') || value instanceof Date || Array.isArray(value);\n}\n\n// We want to filter out any incomplete SpanJSON objects\nfunction isFullFinishedSpan(input) {\n  return !!input.start_timestamp && !!input.timestamp && !!input.span_id && !!input.trace_id;\n}\n\n/** `SentrySpan`s can be sent as a standalone span rather than belonging to a transaction */\nfunction isStandaloneSpan(span) {\n  return span instanceof SentrySpan && span.isStandaloneSpan();\n}\n\n/**\n * Sends a `SpanEnvelope`.\n *\n * Note: If the envelope's spans are dropped, e.g. via `beforeSendSpan`,\n * the envelope will not be sent either.\n */\nfunction sendSpanEnvelope(envelope) {\n  const client = currentScopes.getClient();\n  if (!client) {\n    return;\n  }\n\n  const spanItems = envelope[1];\n  if (!spanItems || spanItems.length === 0) {\n    client.recordDroppedEvent('before_send', 'span');\n    return;\n  }\n\n  // sendEnvelope should not throw\n  // eslint-disable-next-line @typescript-eslint/no-floating-promises\n  client.sendEnvelope(envelope);\n}\n\nexports.SentrySpan = SentrySpan;\n//# sourceMappingURL=sentrySpan.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy90cmFjaW5nL3NlbnRyeVNwYW4uanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsc0JBQXNCLG1CQUFPLENBQUMsZ0lBQXFCO0FBQ25ELG1CQUFtQixtQkFBTyxDQUFDLDRIQUFtQjtBQUM5QyxpQkFBaUIsbUJBQU8sQ0FBQyxzSEFBZ0I7QUFDekMsMkJBQTJCLG1CQUFPLENBQUMsMElBQTBCO0FBQzdELG9CQUFvQixtQkFBTyxDQUFDLDBJQUEwQjtBQUN0RCwyQkFBMkIsbUJBQU8sQ0FBQyxzSkFBZ0M7QUFDbkUsa0JBQWtCLG1CQUFPLENBQUMsb0lBQXVCO0FBQ2pELGFBQWEsbUJBQU8sQ0FBQywwSEFBa0I7QUFDdkMsK0JBQStCLG1CQUFPLENBQUMseUpBQTZCO0FBQ3BFLGlCQUFpQixtQkFBTyxDQUFDLDZIQUFlO0FBQ3hDLG9CQUFvQixtQkFBTyxDQUFDLG1JQUFrQjtBQUM5QyxjQUFjLG1CQUFPLENBQUMsdUhBQVk7O0FBRWxDOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBOztBQUVBOztBQUVBOztBQUVBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsK0JBQStCO0FBQy9CO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxLQUFLOztBQUVMOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQSxNQUFNO0FBQ047QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQSxNQUFNO0FBQ047QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLFlBQVksd0RBQXdEO0FBQ3BFO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsTUFBTTtBQUNOO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBLG1FQUFtRTs7QUFFbkU7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFFBQVE7QUFDUjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLFlBQVksdUVBQXVFOztBQUVuRjs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsS0FBSztBQUNMOztBQUVBO0FBQ0E7QUFDQTtBQUNBLE9BQU87QUFDUDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsT0FBTztBQUNQO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsU0FBUztBQUNULE9BQU87QUFDUDs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsa0JBQWtCO0FBQ2xCIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdHJhY2luZy9zZW50cnlTcGFuLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBjdXJyZW50U2NvcGVzID0gcmVxdWlyZSgnLi4vY3VycmVudFNjb3Blcy5qcycpO1xuY29uc3QgZGVidWdCdWlsZCA9IHJlcXVpcmUoJy4uL2RlYnVnLWJ1aWxkLmpzJyk7XG5jb25zdCBlbnZlbG9wZSA9IHJlcXVpcmUoJy4uL2VudmVsb3BlLmpzJyk7XG5jb25zdCBzZW1hbnRpY0F0dHJpYnV0ZXMgPSByZXF1aXJlKCcuLi9zZW1hbnRpY0F0dHJpYnV0ZXMuanMnKTtcbmNvbnN0IGRlYnVnTG9nZ2VyID0gcmVxdWlyZSgnLi4vdXRpbHMvZGVidWctbG9nZ2VyLmpzJyk7XG5jb25zdCBwcm9wYWdhdGlvbkNvbnRleHQgPSByZXF1aXJlKCcuLi91dGlscy9wcm9wYWdhdGlvbkNvbnRleHQuanMnKTtcbmNvbnN0IHNwYW5VdGlscyA9IHJlcXVpcmUoJy4uL3V0aWxzL3NwYW5VdGlscy5qcycpO1xuY29uc3QgdGltZSA9IHJlcXVpcmUoJy4uL3V0aWxzL3RpbWUuanMnKTtcbmNvbnN0IGR5bmFtaWNTYW1wbGluZ0NvbnRleHQgPSByZXF1aXJlKCcuL2R5bmFtaWNTYW1wbGluZ0NvbnRleHQuanMnKTtcbmNvbnN0IGxvZ1NwYW5zID0gcmVxdWlyZSgnLi9sb2dTcGFucy5qcycpO1xuY29uc3QgbWVhc3VyZW1lbnQgPSByZXF1aXJlKCcuL21lYXN1cmVtZW50LmpzJyk7XG5jb25zdCB1dGlscyA9IHJlcXVpcmUoJy4vdXRpbHMuanMnKTtcblxuY29uc3QgTUFYX1NQQU5fQ09VTlQgPSAxMDAwO1xuXG4vKipcbiAqIFNwYW4gY29udGFpbnMgYWxsIGRhdGEgYWJvdXQgYSBzcGFuXG4gKi9cbmNsYXNzIFNlbnRyeVNwYW4gIHtcblxuICAvKiogRXBvY2ggdGltZXN0YW1wIGluIHNlY29uZHMgd2hlbiB0aGUgc3BhbiBzdGFydGVkLiAqL1xuXG4gIC8qKiBFcG9jaCB0aW1lc3RhbXAgaW4gc2Vjb25kcyB3aGVuIHRoZSBzcGFuIGVuZGVkLiAqL1xuXG4gIC8qKiBJbnRlcm5hbCBrZWVwZXIgb2YgdGhlIHN0YXR1cyAqL1xuXG4gIC8qKiBUaGUgdGltZWQgZXZlbnRzIGFkZGVkIHRvIHRoaXMgc3Bhbi4gKi9cblxuICAvKiogaWYgdHJ1ZSwgdHJlYXQgc3BhbiBhcyBhIHN0YW5kYWxvbmUgc3BhbiAobm90IHBhcnQgb2YgYSB0cmFuc2FjdGlvbikgKi9cblxuICAvKipcbiAgICogWW91IHNob3VsZCBuZXZlciBjYWxsIHRoZSBjb25zdHJ1Y3RvciBtYW51YWxseSwgYWx3YXlzIHVzZSBgU2VudHJ5LnN0YXJ0U3BhbigpYFxuICAgKiBvciBvdGhlciBzcGFuIG1ldGhvZHMuXG4gICAqIEBpbnRlcm5hbFxuICAgKiBAaGlkZWNvbnN0cnVjdG9yXG4gICAqIEBoaWRkZW5cbiAgICovXG4gICBjb25zdHJ1Y3RvcihzcGFuQ29udGV4dCA9IHt9KSB7XG4gICAgdGhpcy5fdHJhY2VJZCA9IHNwYW5Db250ZXh0LnRyYWNlSWQgfHwgcHJvcGFnYXRpb25Db250ZXh0LmdlbmVyYXRlVHJhY2VJZCgpO1xuICAgIHRoaXMuX3NwYW5JZCA9IHNwYW5Db250ZXh0LnNwYW5JZCB8fCBwcm9wYWdhdGlvbkNvbnRleHQuZ2VuZXJhdGVTcGFuSWQoKTtcbiAgICB0aGlzLl9zdGFydFRpbWUgPSBzcGFuQ29udGV4dC5zdGFydFRpbWVzdGFtcCB8fCB0aW1lLnRpbWVzdGFtcEluU2Vjb25kcygpO1xuICAgIHRoaXMuX2xpbmtzID0gc3BhbkNvbnRleHQubGlua3M7XG5cbiAgICB0aGlzLl9hdHRyaWJ1dGVzID0ge307XG4gICAgdGhpcy5zZXRBdHRyaWJ1dGVzKHtcbiAgICAgIFtzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9PUklHSU5dOiAnbWFudWFsJyxcbiAgICAgIFtzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9PUF06IHNwYW5Db250ZXh0Lm9wLFxuICAgICAgLi4uc3BhbkNvbnRleHQuYXR0cmlidXRlcyxcbiAgICB9KTtcblxuICAgIHRoaXMuX25hbWUgPSBzcGFuQ29udGV4dC5uYW1lO1xuXG4gICAgaWYgKHNwYW5Db250ZXh0LnBhcmVudFNwYW5JZCkge1xuICAgICAgdGhpcy5fcGFyZW50U3BhbklkID0gc3BhbkNvbnRleHQucGFyZW50U3BhbklkO1xuICAgIH1cbiAgICAvLyBXZSB3YW50IHRvIGluY2x1ZGUgYm9vbGVhbnMgYXMgd2VsbCBoZXJlXG4gICAgaWYgKCdzYW1wbGVkJyBpbiBzcGFuQ29udGV4dCkge1xuICAgICAgdGhpcy5fc2FtcGxlZCA9IHNwYW5Db250ZXh0LnNhbXBsZWQ7XG4gICAgfVxuICAgIGlmIChzcGFuQ29udGV4dC5lbmRUaW1lc3RhbXApIHtcbiAgICAgIHRoaXMuX2VuZFRpbWUgPSBzcGFuQ29udGV4dC5lbmRUaW1lc3RhbXA7XG4gICAgfVxuXG4gICAgdGhpcy5fZXZlbnRzID0gW107XG5cbiAgICB0aGlzLl9pc1N0YW5kYWxvbmVTcGFuID0gc3BhbkNvbnRleHQuaXNTdGFuZGFsb25lO1xuXG4gICAgLy8gSWYgdGhlIHNwYW4gaXMgYWxyZWFkeSBlbmRlZCwgZW5zdXJlIHdlIGZpbmFsaXplIHRoZSBzcGFuIGltbWVkaWF0ZWx5XG4gICAgaWYgKHRoaXMuX2VuZFRpbWUpIHtcbiAgICAgIHRoaXMuX29uU3BhbkVuZGVkKCk7XG4gICAgfVxuICB9XG5cbiAgLyoqIEBpbmhlcml0RG9jICovXG4gICBhZGRMaW5rKGxpbmspIHtcbiAgICBpZiAodGhpcy5fbGlua3MpIHtcbiAgICAgIHRoaXMuX2xpbmtzLnB1c2gobGluayk7XG4gICAgfSBlbHNlIHtcbiAgICAgIHRoaXMuX2xpbmtzID0gW2xpbmtdO1xuICAgIH1cbiAgICByZXR1cm4gdGhpcztcbiAgfVxuXG4gIC8qKiBAaW5oZXJpdERvYyAqL1xuICAgYWRkTGlua3MobGlua3MpIHtcbiAgICBpZiAodGhpcy5fbGlua3MpIHtcbiAgICAgIHRoaXMuX2xpbmtzLnB1c2goLi4ubGlua3MpO1xuICAgIH0gZWxzZSB7XG4gICAgICB0aGlzLl9saW5rcyA9IGxpbmtzO1xuICAgIH1cbiAgICByZXR1cm4gdGhpcztcbiAgfVxuXG4gIC8qKlxuICAgKiBUaGlzIHNob3VsZCBnZW5lcmFsbHkgbm90IGJlIHVzZWQsXG4gICAqIGJ1dCBpdCBpcyBuZWVkZWQgZm9yIGJlaW5nIGNvbXBsaWFudCB3aXRoIHRoZSBPVEVMIFNwYW4gaW50ZXJmYWNlLlxuICAgKlxuICAgKiBAaGlkZGVuXG4gICAqIEBpbnRlcm5hbFxuICAgKi9cbiAgIHJlY29yZEV4Y2VwdGlvbihfZXhjZXB0aW9uLCBfdGltZSkge1xuICAgIC8vIG5vb3BcbiAgfVxuXG4gIC8qKiBAaW5oZXJpdGRvYyAqL1xuICAgc3BhbkNvbnRleHQoKSB7XG4gICAgY29uc3QgeyBfc3BhbklkOiBzcGFuSWQsIF90cmFjZUlkOiB0cmFjZUlkLCBfc2FtcGxlZDogc2FtcGxlZCB9ID0gdGhpcztcbiAgICByZXR1cm4ge1xuICAgICAgc3BhbklkLFxuICAgICAgdHJhY2VJZCxcbiAgICAgIHRyYWNlRmxhZ3M6IHNhbXBsZWQgPyBzcGFuVXRpbHMuVFJBQ0VfRkxBR19TQU1QTEVEIDogc3BhblV0aWxzLlRSQUNFX0ZMQUdfTk9ORSxcbiAgICB9O1xuICB9XG5cbiAgLyoqIEBpbmhlcml0ZG9jICovXG4gICBzZXRBdHRyaWJ1dGUoa2V5LCB2YWx1ZSkge1xuICAgIGlmICh2YWx1ZSA9PT0gdW5kZWZpbmVkKSB7XG4gICAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25vLWR5bmFtaWMtZGVsZXRlXG4gICAgICBkZWxldGUgdGhpcy5fYXR0cmlidXRlc1trZXldO1xuICAgIH0gZWxzZSB7XG4gICAgICB0aGlzLl9hdHRyaWJ1dGVzW2tleV0gPSB2YWx1ZTtcbiAgICB9XG5cbiAgICByZXR1cm4gdGhpcztcbiAgfVxuXG4gIC8qKiBAaW5oZXJpdGRvYyAqL1xuICAgc2V0QXR0cmlidXRlcyhhdHRyaWJ1dGVzKSB7XG4gICAgT2JqZWN0LmtleXMoYXR0cmlidXRlcykuZm9yRWFjaChrZXkgPT4gdGhpcy5zZXRBdHRyaWJ1dGUoa2V5LCBhdHRyaWJ1dGVzW2tleV0pKTtcbiAgICByZXR1cm4gdGhpcztcbiAgfVxuXG4gIC8qKlxuICAgKiBUaGlzIHNob3VsZCBnZW5lcmFsbHkgbm90IGJlIHVzZWQsXG4gICAqIGJ1dCB3ZSBuZWVkIGl0IGZvciBicm93c2VyIHRyYWNpbmcgd2hlcmUgd2Ugd2FudCB0byBhZGp1c3QgdGhlIHN0YXJ0IHRpbWUgYWZ0ZXJ3YXJkcy5cbiAgICogVVNFIFRISVMgV0lUSCBDQVVUSU9OIVxuICAgKlxuICAgKiBAaGlkZGVuXG4gICAqIEBpbnRlcm5hbFxuICAgKi9cbiAgIHVwZGF0ZVN0YXJ0VGltZSh0aW1lSW5wdXQpIHtcbiAgICB0aGlzLl9zdGFydFRpbWUgPSBzcGFuVXRpbHMuc3BhblRpbWVJbnB1dFRvU2Vjb25kcyh0aW1lSW5wdXQpO1xuICB9XG5cbiAgLyoqXG4gICAqIEBpbmhlcml0RG9jXG4gICAqL1xuICAgc2V0U3RhdHVzKHZhbHVlKSB7XG4gICAgdGhpcy5fc3RhdHVzID0gdmFsdWU7XG4gICAgcmV0dXJuIHRoaXM7XG4gIH1cblxuICAvKipcbiAgICogQGluaGVyaXREb2NcbiAgICovXG4gICB1cGRhdGVOYW1lKG5hbWUpIHtcbiAgICB0aGlzLl9uYW1lID0gbmFtZTtcbiAgICB0aGlzLnNldEF0dHJpYnV0ZShzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9TT1VSQ0UsICdjdXN0b20nKTtcbiAgICByZXR1cm4gdGhpcztcbiAgfVxuXG4gIC8qKiBAaW5oZXJpdGRvYyAqL1xuICAgZW5kKGVuZFRpbWVzdGFtcCkge1xuICAgIC8vIElmIGFscmVhZHkgZW5kZWQsIHNraXBcbiAgICBpZiAodGhpcy5fZW5kVGltZSkge1xuICAgICAgcmV0dXJuO1xuICAgIH1cblxuICAgIHRoaXMuX2VuZFRpbWUgPSBzcGFuVXRpbHMuc3BhblRpbWVJbnB1dFRvU2Vjb25kcyhlbmRUaW1lc3RhbXApO1xuICAgIGxvZ1NwYW5zLmxvZ1NwYW5FbmQodGhpcyk7XG5cbiAgICB0aGlzLl9vblNwYW5FbmRlZCgpO1xuICB9XG5cbiAgLyoqXG4gICAqIEdldCBKU09OIHJlcHJlc2VudGF0aW9uIG9mIHRoaXMgc3Bhbi5cbiAgICpcbiAgICogQGhpZGRlblxuICAgKiBAaW50ZXJuYWwgVGhpcyBtZXRob2QgaXMgcHVyZWx5IGZvciBpbnRlcm5hbCBwdXJwb3NlcyBhbmQgc2hvdWxkIG5vdCBiZSB1c2VkIG91dHNpZGVcbiAgICogb2YgU0RLIGNvZGUuIElmIHlvdSBuZWVkIHRvIGdldCBhIEpTT04gcmVwcmVzZW50YXRpb24gb2YgYSBzcGFuLFxuICAgKiB1c2UgYHNwYW5Ub0pTT04oc3BhbilgIGluc3RlYWQuXG4gICAqL1xuICAgZ2V0U3BhbkpTT04oKSB7XG4gICAgcmV0dXJuIHtcbiAgICAgIGRhdGE6IHRoaXMuX2F0dHJpYnV0ZXMsXG4gICAgICBkZXNjcmlwdGlvbjogdGhpcy5fbmFtZSxcbiAgICAgIG9wOiB0aGlzLl9hdHRyaWJ1dGVzW3NlbWFudGljQXR0cmlidXRlcy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX09QXSxcbiAgICAgIHBhcmVudF9zcGFuX2lkOiB0aGlzLl9wYXJlbnRTcGFuSWQsXG4gICAgICBzcGFuX2lkOiB0aGlzLl9zcGFuSWQsXG4gICAgICBzdGFydF90aW1lc3RhbXA6IHRoaXMuX3N0YXJ0VGltZSxcbiAgICAgIHN0YXR1czogc3BhblV0aWxzLmdldFN0YXR1c01lc3NhZ2UodGhpcy5fc3RhdHVzKSxcbiAgICAgIHRpbWVzdGFtcDogdGhpcy5fZW5kVGltZSxcbiAgICAgIHRyYWNlX2lkOiB0aGlzLl90cmFjZUlkLFxuICAgICAgb3JpZ2luOiB0aGlzLl9hdHRyaWJ1dGVzW3NlbWFudGljQXR0cmlidXRlcy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX09SSUdJTl0gLFxuICAgICAgcHJvZmlsZV9pZDogdGhpcy5fYXR0cmlidXRlc1tzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX1BST0ZJTEVfSURdICxcbiAgICAgIGV4Y2x1c2l2ZV90aW1lOiB0aGlzLl9hdHRyaWJ1dGVzW3NlbWFudGljQXR0cmlidXRlcy5TRU1BTlRJQ19BVFRSSUJVVEVfRVhDTFVTSVZFX1RJTUVdICxcbiAgICAgIG1lYXN1cmVtZW50czogbWVhc3VyZW1lbnQudGltZWRFdmVudHNUb01lYXN1cmVtZW50cyh0aGlzLl9ldmVudHMpLFxuICAgICAgaXNfc2VnbWVudDogKHRoaXMuX2lzU3RhbmRhbG9uZVNwYW4gJiYgc3BhblV0aWxzLmdldFJvb3RTcGFuKHRoaXMpID09PSB0aGlzKSB8fCB1bmRlZmluZWQsXG4gICAgICBzZWdtZW50X2lkOiB0aGlzLl9pc1N0YW5kYWxvbmVTcGFuID8gc3BhblV0aWxzLmdldFJvb3RTcGFuKHRoaXMpLnNwYW5Db250ZXh0KCkuc3BhbklkIDogdW5kZWZpbmVkLFxuICAgICAgbGlua3M6IHNwYW5VdGlscy5jb252ZXJ0U3BhbkxpbmtzRm9yRW52ZWxvcGUodGhpcy5fbGlua3MpLFxuICAgIH07XG4gIH1cblxuICAvKiogQGluaGVyaXRkb2MgKi9cbiAgIGlzUmVjb3JkaW5nKCkge1xuICAgIHJldHVybiAhdGhpcy5fZW5kVGltZSAmJiAhIXRoaXMuX3NhbXBsZWQ7XG4gIH1cblxuICAvKipcbiAgICogQGluaGVyaXRkb2NcbiAgICovXG4gICBhZGRFdmVudChcbiAgICBuYW1lLFxuICAgIGF0dHJpYnV0ZXNPclN0YXJ0VGltZSxcbiAgICBzdGFydFRpbWUsXG4gICkge1xuICAgIGRlYnVnQnVpbGQuREVCVUdfQlVJTEQgJiYgZGVidWdMb2dnZXIuZGVidWcubG9nKCdbVHJhY2luZ10gQWRkaW5nIGFuIGV2ZW50IHRvIHNwYW46JywgbmFtZSk7XG5cbiAgICBjb25zdCB0aW1lJDEgPSBpc1NwYW5UaW1lSW5wdXQoYXR0cmlidXRlc09yU3RhcnRUaW1lKSA/IGF0dHJpYnV0ZXNPclN0YXJ0VGltZSA6IHN0YXJ0VGltZSB8fCB0aW1lLnRpbWVzdGFtcEluU2Vjb25kcygpO1xuICAgIGNvbnN0IGF0dHJpYnV0ZXMgPSBpc1NwYW5UaW1lSW5wdXQoYXR0cmlidXRlc09yU3RhcnRUaW1lKSA/IHt9IDogYXR0cmlidXRlc09yU3RhcnRUaW1lIHx8IHt9O1xuXG4gICAgY29uc3QgZXZlbnQgPSB7XG4gICAgICBuYW1lLFxuICAgICAgdGltZTogc3BhblV0aWxzLnNwYW5UaW1lSW5wdXRUb1NlY29uZHModGltZSQxKSxcbiAgICAgIGF0dHJpYnV0ZXMsXG4gICAgfTtcblxuICAgIHRoaXMuX2V2ZW50cy5wdXNoKGV2ZW50KTtcblxuICAgIHJldHVybiB0aGlzO1xuICB9XG5cbiAgLyoqXG4gICAqIFRoaXMgbWV0aG9kIHNob3VsZCBnZW5lcmFsbHkgbm90IGJlIHVzZWQsXG4gICAqIGJ1dCBmb3Igbm93IHdlIG5lZWQgYSB3YXkgdG8gcHVibGljbHkgY2hlY2sgaWYgdGhlIGBfaXNTdGFuZGFsb25lU3BhbmAgZmxhZyBpcyBzZXQuXG4gICAqIFVTRSBUSElTIFdJVEggQ0FVVElPTiFcbiAgICogQGludGVybmFsXG4gICAqIEBoaWRkZW5cbiAgICogQGV4cGVyaW1lbnRhbFxuICAgKi9cbiAgIGlzU3RhbmRhbG9uZVNwYW4oKSB7XG4gICAgcmV0dXJuICEhdGhpcy5faXNTdGFuZGFsb25lU3BhbjtcbiAgfVxuXG4gIC8qKiBFbWl0IGBzcGFuRW5kYCB3aGVuIHRoZSBzcGFuIGlzIGVuZGVkLiAqL1xuICAgX29uU3BhbkVuZGVkKCkge1xuICAgIGNvbnN0IGNsaWVudCA9IGN1cnJlbnRTY29wZXMuZ2V0Q2xpZW50KCk7XG4gICAgaWYgKGNsaWVudCkge1xuICAgICAgY2xpZW50LmVtaXQoJ3NwYW5FbmQnLCB0aGlzKTtcbiAgICB9XG5cbiAgICAvLyBBIHNlZ21lbnQgc3BhbiBpcyBiYXNpY2FsbHkgdGhlIHJvb3Qgc3BhbiBvZiBhIGxvY2FsIHNwYW4gdHJlZS5cbiAgICAvLyBTbyBmb3Igbm93LCB0aGlzIGlzIGVpdGhlciB3aGF0IHdlIHByZXZpb3VzbHkgcmVmZXIgdG8gYXMgdGhlIHJvb3Qgc3BhbixcbiAgICAvLyBvciBhIHN0YW5kYWxvbmUgc3Bhbi5cbiAgICBjb25zdCBpc1NlZ21lbnRTcGFuID0gdGhpcy5faXNTdGFuZGFsb25lU3BhbiB8fCB0aGlzID09PSBzcGFuVXRpbHMuZ2V0Um9vdFNwYW4odGhpcyk7XG5cbiAgICBpZiAoIWlzU2VnbWVudFNwYW4pIHtcbiAgICAgIHJldHVybjtcbiAgICB9XG5cbiAgICAvLyBpZiB0aGlzIGlzIGEgc3RhbmRhbG9uZSBzcGFuLCB3ZSBzZW5kIGl0IGltbWVkaWF0ZWx5XG4gICAgaWYgKHRoaXMuX2lzU3RhbmRhbG9uZVNwYW4pIHtcbiAgICAgIGlmICh0aGlzLl9zYW1wbGVkKSB7XG4gICAgICAgIHNlbmRTcGFuRW52ZWxvcGUoZW52ZWxvcGUuY3JlYXRlU3BhbkVudmVsb3BlKFt0aGlzXSwgY2xpZW50KSk7XG4gICAgICB9IGVsc2Uge1xuICAgICAgICBkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEICYmXG4gICAgICAgICAgZGVidWdMb2dnZXIuZGVidWcubG9nKCdbVHJhY2luZ10gRGlzY2FyZGluZyBzdGFuZGFsb25lIHNwYW4gYmVjYXVzZSBpdHMgdHJhY2Ugd2FzIG5vdCBjaG9zZW4gdG8gYmUgc2FtcGxlZC4nKTtcbiAgICAgICAgaWYgKGNsaWVudCkge1xuICAgICAgICAgIGNsaWVudC5yZWNvcmREcm9wcGVkRXZlbnQoJ3NhbXBsZV9yYXRlJywgJ3NwYW4nKTtcbiAgICAgICAgfVxuICAgICAgfVxuICAgICAgcmV0dXJuO1xuICAgIH1cblxuICAgIGNvbnN0IHRyYW5zYWN0aW9uRXZlbnQgPSB0aGlzLl9jb252ZXJ0U3BhblRvVHJhbnNhY3Rpb24oKTtcbiAgICBpZiAodHJhbnNhY3Rpb25FdmVudCkge1xuICAgICAgY29uc3Qgc2NvcGUgPSB1dGlscy5nZXRDYXB0dXJlZFNjb3Blc09uU3Bhbih0aGlzKS5zY29wZSB8fCBjdXJyZW50U2NvcGVzLmdldEN1cnJlbnRTY29wZSgpO1xuICAgICAgc2NvcGUuY2FwdHVyZUV2ZW50KHRyYW5zYWN0aW9uRXZlbnQpO1xuICAgIH1cbiAgfVxuXG4gIC8qKlxuICAgKiBGaW5pc2ggdGhlIHRyYW5zYWN0aW9uICYgcHJlcGFyZSB0aGUgZXZlbnQgdG8gc2VuZCB0byBTZW50cnkuXG4gICAqL1xuICAgX2NvbnZlcnRTcGFuVG9UcmFuc2FjdGlvbigpIHtcbiAgICAvLyBXZSBjYW4gb25seSBjb252ZXJ0IGZpbmlzaGVkIHNwYW5zXG4gICAgaWYgKCFpc0Z1bGxGaW5pc2hlZFNwYW4oc3BhblV0aWxzLnNwYW5Ub0pTT04odGhpcykpKSB7XG4gICAgICByZXR1cm4gdW5kZWZpbmVkO1xuICAgIH1cblxuICAgIGlmICghdGhpcy5fbmFtZSkge1xuICAgICAgZGVidWdCdWlsZC5ERUJVR19CVUlMRCAmJiBkZWJ1Z0xvZ2dlci5kZWJ1Zy53YXJuKCdUcmFuc2FjdGlvbiBoYXMgbm8gbmFtZSwgZmFsbGluZyBiYWNrIHRvIGA8dW5sYWJlbGVkIHRyYW5zYWN0aW9uPmAuJyk7XG4gICAgICB0aGlzLl9uYW1lID0gJzx1bmxhYmVsZWQgdHJhbnNhY3Rpb24+JztcbiAgICB9XG5cbiAgICBjb25zdCB7IHNjb3BlOiBjYXB0dXJlZFNwYW5TY29wZSwgaXNvbGF0aW9uU2NvcGU6IGNhcHR1cmVkU3Bhbklzb2xhdGlvblNjb3BlIH0gPSB1dGlscy5nZXRDYXB0dXJlZFNjb3Blc09uU3Bhbih0aGlzKTtcblxuICAgIGNvbnN0IG5vcm1hbGl6ZWRSZXF1ZXN0ID0gY2FwdHVyZWRTcGFuU2NvcGU/LmdldFNjb3BlRGF0YSgpLnNka1Byb2Nlc3NpbmdNZXRhZGF0YT8ubm9ybWFsaXplZFJlcXVlc3Q7XG5cbiAgICBpZiAodGhpcy5fc2FtcGxlZCAhPT0gdHJ1ZSkge1xuICAgICAgcmV0dXJuIHVuZGVmaW5lZDtcbiAgICB9XG5cbiAgICAvLyBUaGUgdHJhbnNhY3Rpb24gc3BhbiBpdHNlbGYgYXMgd2VsbCBhcyBhbnkgcG90ZW50aWFsIHN0YW5kYWxvbmUgc3BhbnMgc2hvdWxkIGJlIGZpbHRlcmVkIG91dFxuICAgIGNvbnN0IGZpbmlzaGVkU3BhbnMgPSBzcGFuVXRpbHMuZ2V0U3BhbkRlc2NlbmRhbnRzKHRoaXMpLmZpbHRlcihzcGFuID0+IHNwYW4gIT09IHRoaXMgJiYgIWlzU3RhbmRhbG9uZVNwYW4oc3BhbikpO1xuXG4gICAgY29uc3Qgc3BhbnMgPSBmaW5pc2hlZFNwYW5zLm1hcChzcGFuID0+IHNwYW5VdGlscy5zcGFuVG9KU09OKHNwYW4pKS5maWx0ZXIoaXNGdWxsRmluaXNoZWRTcGFuKTtcblxuICAgIGNvbnN0IHNvdXJjZSA9IHRoaXMuX2F0dHJpYnV0ZXNbc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfU09VUkNFXSA7XG5cbiAgICAvLyByZW1vdmUgaW50ZXJuYWwgcm9vdCBzcGFuIGF0dHJpYnV0ZXMgd2UgZG9uJ3QgbmVlZCB0byBzZW5kLlxuICAgIC8qIGVzbGludC1kaXNhYmxlIEB0eXBlc2NyaXB0LWVzbGludC9uby1keW5hbWljLWRlbGV0ZSAqL1xuICAgIGRlbGV0ZSB0aGlzLl9hdHRyaWJ1dGVzW3NlbWFudGljQXR0cmlidXRlcy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX0NVU1RPTV9TUEFOX05BTUVdO1xuICAgIHNwYW5zLmZvckVhY2goc3BhbiA9PiB7XG4gICAgICBkZWxldGUgc3Bhbi5kYXRhW3NlbWFudGljQXR0cmlidXRlcy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX0NVU1RPTV9TUEFOX05BTUVdO1xuICAgIH0pO1xuICAgIC8vIGVzbGludC1lbmFibGVkLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tZHluYW1pYy1kZWxldGVcblxuICAgIGNvbnN0IHRyYW5zYWN0aW9uID0ge1xuICAgICAgY29udGV4dHM6IHtcbiAgICAgICAgdHJhY2U6IHNwYW5VdGlscy5zcGFuVG9UcmFuc2FjdGlvblRyYWNlQ29udGV4dCh0aGlzKSxcbiAgICAgIH0sXG4gICAgICBzcGFuczpcbiAgICAgICAgLy8gc3BhbnMuc29ydCgpIG11dGF0ZXMgdGhlIGFycmF5LCBidXQgYHNwYW5zYCBpcyBhbHJlYWR5IGEgY29weSBzbyB3ZSBjYW4gc2FmZWx5IGRvIHRoaXMgaGVyZVxuICAgICAgICAvLyB3ZSBkbyBub3QgdXNlIHNwYW5zIGFueW1vcmUgYWZ0ZXIgdGhpcyBwb2ludFxuICAgICAgICBzcGFucy5sZW5ndGggPiBNQVhfU1BBTl9DT1VOVFxuICAgICAgICAgID8gc3BhbnMuc29ydCgoYSwgYikgPT4gYS5zdGFydF90aW1lc3RhbXAgLSBiLnN0YXJ0X3RpbWVzdGFtcCkuc2xpY2UoMCwgTUFYX1NQQU5fQ09VTlQpXG4gICAgICAgICAgOiBzcGFucyxcbiAgICAgIHN0YXJ0X3RpbWVzdGFtcDogdGhpcy5fc3RhcnRUaW1lLFxuICAgICAgdGltZXN0YW1wOiB0aGlzLl9lbmRUaW1lLFxuICAgICAgdHJhbnNhY3Rpb246IHRoaXMuX25hbWUsXG4gICAgICB0eXBlOiAndHJhbnNhY3Rpb24nLFxuICAgICAgc2RrUHJvY2Vzc2luZ01ldGFkYXRhOiB7XG4gICAgICAgIGNhcHR1cmVkU3BhblNjb3BlLFxuICAgICAgICBjYXB0dXJlZFNwYW5Jc29sYXRpb25TY29wZSxcbiAgICAgICAgZHluYW1pY1NhbXBsaW5nQ29udGV4dDogZHluYW1pY1NhbXBsaW5nQ29udGV4dC5nZXREeW5hbWljU2FtcGxpbmdDb250ZXh0RnJvbVNwYW4odGhpcyksXG4gICAgICB9LFxuICAgICAgcmVxdWVzdDogbm9ybWFsaXplZFJlcXVlc3QsXG4gICAgICAuLi4oc291cmNlICYmIHtcbiAgICAgICAgdHJhbnNhY3Rpb25faW5mbzoge1xuICAgICAgICAgIHNvdXJjZSxcbiAgICAgICAgfSxcbiAgICAgIH0pLFxuICAgIH07XG5cbiAgICBjb25zdCBtZWFzdXJlbWVudHMgPSBtZWFzdXJlbWVudC50aW1lZEV2ZW50c1RvTWVhc3VyZW1lbnRzKHRoaXMuX2V2ZW50cyk7XG4gICAgY29uc3QgaGFzTWVhc3VyZW1lbnRzID0gbWVhc3VyZW1lbnRzICYmIE9iamVjdC5rZXlzKG1lYXN1cmVtZW50cykubGVuZ3RoO1xuXG4gICAgaWYgKGhhc01lYXN1cmVtZW50cykge1xuICAgICAgZGVidWdCdWlsZC5ERUJVR19CVUlMRCAmJlxuICAgICAgICBkZWJ1Z0xvZ2dlci5kZWJ1Zy5sb2coXG4gICAgICAgICAgJ1tNZWFzdXJlbWVudHNdIEFkZGluZyBtZWFzdXJlbWVudHMgdG8gdHJhbnNhY3Rpb24gZXZlbnQnLFxuICAgICAgICAgIEpTT04uc3RyaW5naWZ5KG1lYXN1cmVtZW50cywgdW5kZWZpbmVkLCAyKSxcbiAgICAgICAgKTtcbiAgICAgIHRyYW5zYWN0aW9uLm1lYXN1cmVtZW50cyA9IG1lYXN1cmVtZW50cztcbiAgICB9XG5cbiAgICByZXR1cm4gdHJhbnNhY3Rpb247XG4gIH1cbn1cblxuZnVuY3Rpb24gaXNTcGFuVGltZUlucHV0KHZhbHVlKSB7XG4gIHJldHVybiAodmFsdWUgJiYgdHlwZW9mIHZhbHVlID09PSAnbnVtYmVyJykgfHwgdmFsdWUgaW5zdGFuY2VvZiBEYXRlIHx8IEFycmF5LmlzQXJyYXkodmFsdWUpO1xufVxuXG4vLyBXZSB3YW50IHRvIGZpbHRlciBvdXQgYW55IGluY29tcGxldGUgU3BhbkpTT04gb2JqZWN0c1xuZnVuY3Rpb24gaXNGdWxsRmluaXNoZWRTcGFuKGlucHV0KSB7XG4gIHJldHVybiAhIWlucHV0LnN0YXJ0X3RpbWVzdGFtcCAmJiAhIWlucHV0LnRpbWVzdGFtcCAmJiAhIWlucHV0LnNwYW5faWQgJiYgISFpbnB1dC50cmFjZV9pZDtcbn1cblxuLyoqIGBTZW50cnlTcGFuYHMgY2FuIGJlIHNlbnQgYXMgYSBzdGFuZGFsb25lIHNwYW4gcmF0aGVyIHRoYW4gYmVsb25naW5nIHRvIGEgdHJhbnNhY3Rpb24gKi9cbmZ1bmN0aW9uIGlzU3RhbmRhbG9uZVNwYW4oc3Bhbikge1xuICByZXR1cm4gc3BhbiBpbnN0YW5jZW9mIFNlbnRyeVNwYW4gJiYgc3Bhbi5pc1N0YW5kYWxvbmVTcGFuKCk7XG59XG5cbi8qKlxuICogU2VuZHMgYSBgU3BhbkVudmVsb3BlYC5cbiAqXG4gKiBOb3RlOiBJZiB0aGUgZW52ZWxvcGUncyBzcGFucyBhcmUgZHJvcHBlZCwgZS5nLiB2aWEgYGJlZm9yZVNlbmRTcGFuYCxcbiAqIHRoZSBlbnZlbG9wZSB3aWxsIG5vdCBiZSBzZW50IGVpdGhlci5cbiAqL1xuZnVuY3Rpb24gc2VuZFNwYW5FbnZlbG9wZShlbnZlbG9wZSkge1xuICBjb25zdCBjbGllbnQgPSBjdXJyZW50U2NvcGVzLmdldENsaWVudCgpO1xuICBpZiAoIWNsaWVudCkge1xuICAgIHJldHVybjtcbiAgfVxuXG4gIGNvbnN0IHNwYW5JdGVtcyA9IGVudmVsb3BlWzFdO1xuICBpZiAoIXNwYW5JdGVtcyB8fCBzcGFuSXRlbXMubGVuZ3RoID09PSAwKSB7XG4gICAgY2xpZW50LnJlY29yZERyb3BwZWRFdmVudCgnYmVmb3JlX3NlbmQnLCAnc3BhbicpO1xuICAgIHJldHVybjtcbiAgfVxuXG4gIC8vIHNlbmRFbnZlbG9wZSBzaG91bGQgbm90IHRocm93XG4gIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tZmxvYXRpbmctcHJvbWlzZXNcbiAgY2xpZW50LnNlbmRFbnZlbG9wZShlbnZlbG9wZSk7XG59XG5cbmV4cG9ydHMuU2VudHJ5U3BhbiA9IFNlbnRyeVNwYW47XG4vLyMgc291cmNlTWFwcGluZ1VSTD1zZW50cnlTcGFuLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/sentrySpan.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/spanstatus.js":
/*!**********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/spanstatus.js ***!
  \**********************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst SPAN_STATUS_UNSET = 0;\nconst SPAN_STATUS_OK = 1;\nconst SPAN_STATUS_ERROR = 2;\n\n/**\n * Converts a HTTP status code into a sentry status with a message.\n *\n * @param httpStatus The HTTP response status code.\n * @returns The span status or unknown_error.\n */\n// https://develop.sentry.dev/sdk/event-payloads/span/\nfunction getSpanStatusFromHttpCode(httpStatus) {\n  if (httpStatus < 400 && httpStatus >= 100) {\n    return { code: SPAN_STATUS_OK };\n  }\n\n  if (httpStatus >= 400 && httpStatus < 500) {\n    switch (httpStatus) {\n      case 401:\n        return { code: SPAN_STATUS_ERROR, message: 'unauthenticated' };\n      case 403:\n        return { code: SPAN_STATUS_ERROR, message: 'permission_denied' };\n      case 404:\n        return { code: SPAN_STATUS_ERROR, message: 'not_found' };\n      case 409:\n        return { code: SPAN_STATUS_ERROR, message: 'already_exists' };\n      case 413:\n        return { code: SPAN_STATUS_ERROR, message: 'failed_precondition' };\n      case 429:\n        return { code: SPAN_STATUS_ERROR, message: 'resource_exhausted' };\n      case 499:\n        return { code: SPAN_STATUS_ERROR, message: 'cancelled' };\n      default:\n        return { code: SPAN_STATUS_ERROR, message: 'invalid_argument' };\n    }\n  }\n\n  if (httpStatus >= 500 && httpStatus < 600) {\n    switch (httpStatus) {\n      case 501:\n        return { code: SPAN_STATUS_ERROR, message: 'unimplemented' };\n      case 503:\n        return { code: SPAN_STATUS_ERROR, message: 'unavailable' };\n      case 504:\n        return { code: SPAN_STATUS_ERROR, message: 'deadline_exceeded' };\n      default:\n        return { code: SPAN_STATUS_ERROR, message: 'internal_error' };\n    }\n  }\n\n  return { code: SPAN_STATUS_ERROR, message: 'unknown_error' };\n}\n\n/**\n * Sets the Http status attributes on the current span based on the http code.\n * Additionally, the span's status is updated, depending on the http code.\n */\nfunction setHttpStatus(span, httpStatus) {\n  span.setAttribute('http.response.status_code', httpStatus);\n\n  const spanStatus = getSpanStatusFromHttpCode(httpStatus);\n  if (spanStatus.message !== 'unknown_error') {\n    span.setStatus(spanStatus);\n  }\n}\n\nexports.SPAN_STATUS_ERROR = SPAN_STATUS_ERROR;\nexports.SPAN_STATUS_OK = SPAN_STATUS_OK;\nexports.SPAN_STATUS_UNSET = SPAN_STATUS_UNSET;\nexports.getSpanStatusFromHttpCode = getSpanStatusFromHttpCode;\nexports.setHttpStatus = setHttpStatus;\n//# sourceMappingURL=spanstatus.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy90cmFjaW5nL3NwYW5zdGF0dXMuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEU7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGFBQWE7QUFDYjs7QUFFQTtBQUNBO0FBQ0E7QUFDQSxpQkFBaUI7QUFDakI7QUFDQSxpQkFBaUI7QUFDakI7QUFDQSxpQkFBaUI7QUFDakI7QUFDQSxpQkFBaUI7QUFDakI7QUFDQSxpQkFBaUI7QUFDakI7QUFDQSxpQkFBaUI7QUFDakI7QUFDQSxpQkFBaUI7QUFDakI7QUFDQSxpQkFBaUI7QUFDakI7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQSxpQkFBaUI7QUFDakI7QUFDQSxpQkFBaUI7QUFDakI7QUFDQSxpQkFBaUI7QUFDakI7QUFDQSxpQkFBaUI7QUFDakI7QUFDQTs7QUFFQSxXQUFXO0FBQ1g7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEseUJBQXlCO0FBQ3pCLHNCQUFzQjtBQUN0Qix5QkFBeUI7QUFDekIsaUNBQWlDO0FBQ2pDLHFCQUFxQjtBQUNyQiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3RyYWNpbmcvc3BhbnN0YXR1cy5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgU1BBTl9TVEFUVVNfVU5TRVQgPSAwO1xuY29uc3QgU1BBTl9TVEFUVVNfT0sgPSAxO1xuY29uc3QgU1BBTl9TVEFUVVNfRVJST1IgPSAyO1xuXG4vKipcbiAqIENvbnZlcnRzIGEgSFRUUCBzdGF0dXMgY29kZSBpbnRvIGEgc2VudHJ5IHN0YXR1cyB3aXRoIGEgbWVzc2FnZS5cbiAqXG4gKiBAcGFyYW0gaHR0cFN0YXR1cyBUaGUgSFRUUCByZXNwb25zZSBzdGF0dXMgY29kZS5cbiAqIEByZXR1cm5zIFRoZSBzcGFuIHN0YXR1cyBvciB1bmtub3duX2Vycm9yLlxuICovXG4vLyBodHRwczovL2RldmVsb3Auc2VudHJ5LmRldi9zZGsvZXZlbnQtcGF5bG9hZHMvc3Bhbi9cbmZ1bmN0aW9uIGdldFNwYW5TdGF0dXNGcm9tSHR0cENvZGUoaHR0cFN0YXR1cykge1xuICBpZiAoaHR0cFN0YXR1cyA8IDQwMCAmJiBodHRwU3RhdHVzID49IDEwMCkge1xuICAgIHJldHVybiB7IGNvZGU6IFNQQU5fU1RBVFVTX09LIH07XG4gIH1cblxuICBpZiAoaHR0cFN0YXR1cyA+PSA0MDAgJiYgaHR0cFN0YXR1cyA8IDUwMCkge1xuICAgIHN3aXRjaCAoaHR0cFN0YXR1cykge1xuICAgICAgY2FzZSA0MDE6XG4gICAgICAgIHJldHVybiB7IGNvZGU6IFNQQU5fU1RBVFVTX0VSUk9SLCBtZXNzYWdlOiAndW5hdXRoZW50aWNhdGVkJyB9O1xuICAgICAgY2FzZSA0MDM6XG4gICAgICAgIHJldHVybiB7IGNvZGU6IFNQQU5fU1RBVFVTX0VSUk9SLCBtZXNzYWdlOiAncGVybWlzc2lvbl9kZW5pZWQnIH07XG4gICAgICBjYXNlIDQwNDpcbiAgICAgICAgcmV0dXJuIHsgY29kZTogU1BBTl9TVEFUVVNfRVJST1IsIG1lc3NhZ2U6ICdub3RfZm91bmQnIH07XG4gICAgICBjYXNlIDQwOTpcbiAgICAgICAgcmV0dXJuIHsgY29kZTogU1BBTl9TVEFUVVNfRVJST1IsIG1lc3NhZ2U6ICdhbHJlYWR5X2V4aXN0cycgfTtcbiAgICAgIGNhc2UgNDEzOlxuICAgICAgICByZXR1cm4geyBjb2RlOiBTUEFOX1NUQVRVU19FUlJPUiwgbWVzc2FnZTogJ2ZhaWxlZF9wcmVjb25kaXRpb24nIH07XG4gICAgICBjYXNlIDQyOTpcbiAgICAgICAgcmV0dXJuIHsgY29kZTogU1BBTl9TVEFUVVNfRVJST1IsIG1lc3NhZ2U6ICdyZXNvdXJjZV9leGhhdXN0ZWQnIH07XG4gICAgICBjYXNlIDQ5OTpcbiAgICAgICAgcmV0dXJuIHsgY29kZTogU1BBTl9TVEFUVVNfRVJST1IsIG1lc3NhZ2U6ICdjYW5jZWxsZWQnIH07XG4gICAgICBkZWZhdWx0OlxuICAgICAgICByZXR1cm4geyBjb2RlOiBTUEFOX1NUQVRVU19FUlJPUiwgbWVzc2FnZTogJ2ludmFsaWRfYXJndW1lbnQnIH07XG4gICAgfVxuICB9XG5cbiAgaWYgKGh0dHBTdGF0dXMgPj0gNTAwICYmIGh0dHBTdGF0dXMgPCA2MDApIHtcbiAgICBzd2l0Y2ggKGh0dHBTdGF0dXMpIHtcbiAgICAgIGNhc2UgNTAxOlxuICAgICAgICByZXR1cm4geyBjb2RlOiBTUEFOX1NUQVRVU19FUlJPUiwgbWVzc2FnZTogJ3VuaW1wbGVtZW50ZWQnIH07XG4gICAgICBjYXNlIDUwMzpcbiAgICAgICAgcmV0dXJuIHsgY29kZTogU1BBTl9TVEFUVVNfRVJST1IsIG1lc3NhZ2U6ICd1bmF2YWlsYWJsZScgfTtcbiAgICAgIGNhc2UgNTA0OlxuICAgICAgICByZXR1cm4geyBjb2RlOiBTUEFOX1NUQVRVU19FUlJPUiwgbWVzc2FnZTogJ2RlYWRsaW5lX2V4Y2VlZGVkJyB9O1xuICAgICAgZGVmYXVsdDpcbiAgICAgICAgcmV0dXJuIHsgY29kZTogU1BBTl9TVEFUVVNfRVJST1IsIG1lc3NhZ2U6ICdpbnRlcm5hbF9lcnJvcicgfTtcbiAgICB9XG4gIH1cblxuICByZXR1cm4geyBjb2RlOiBTUEFOX1NUQVRVU19FUlJPUiwgbWVzc2FnZTogJ3Vua25vd25fZXJyb3InIH07XG59XG5cbi8qKlxuICogU2V0cyB0aGUgSHR0cCBzdGF0dXMgYXR0cmlidXRlcyBvbiB0aGUgY3VycmVudCBzcGFuIGJhc2VkIG9uIHRoZSBodHRwIGNvZGUuXG4gKiBBZGRpdGlvbmFsbHksIHRoZSBzcGFuJ3Mgc3RhdHVzIGlzIHVwZGF0ZWQsIGRlcGVuZGluZyBvbiB0aGUgaHR0cCBjb2RlLlxuICovXG5mdW5jdGlvbiBzZXRIdHRwU3RhdHVzKHNwYW4sIGh0dHBTdGF0dXMpIHtcbiAgc3Bhbi5zZXRBdHRyaWJ1dGUoJ2h0dHAucmVzcG9uc2Uuc3RhdHVzX2NvZGUnLCBodHRwU3RhdHVzKTtcblxuICBjb25zdCBzcGFuU3RhdHVzID0gZ2V0U3BhblN0YXR1c0Zyb21IdHRwQ29kZShodHRwU3RhdHVzKTtcbiAgaWYgKHNwYW5TdGF0dXMubWVzc2FnZSAhPT0gJ3Vua25vd25fZXJyb3InKSB7XG4gICAgc3Bhbi5zZXRTdGF0dXMoc3BhblN0YXR1cyk7XG4gIH1cbn1cblxuZXhwb3J0cy5TUEFOX1NUQVRVU19FUlJPUiA9IFNQQU5fU1RBVFVTX0VSUk9SO1xuZXhwb3J0cy5TUEFOX1NUQVRVU19PSyA9IFNQQU5fU1RBVFVTX09LO1xuZXhwb3J0cy5TUEFOX1NUQVRVU19VTlNFVCA9IFNQQU5fU1RBVFVTX1VOU0VUO1xuZXhwb3J0cy5nZXRTcGFuU3RhdHVzRnJvbUh0dHBDb2RlID0gZ2V0U3BhblN0YXR1c0Zyb21IdHRwQ29kZTtcbmV4cG9ydHMuc2V0SHR0cFN0YXR1cyA9IHNldEh0dHBTdGF0dXM7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1zcGFuc3RhdHVzLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/spanstatus.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/trace.js":
/*!*****************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/trace.js ***!
  \*****************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst index = __webpack_require__(/*! ../asyncContext/index.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/asyncContext/index.js\");\nconst carrier = __webpack_require__(/*! ../carrier.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/carrier.js\");\nconst currentScopes = __webpack_require__(/*! ../currentScopes.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst debugBuild = __webpack_require__(/*! ../debug-build.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst semanticAttributes = __webpack_require__(/*! ../semanticAttributes.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/semanticAttributes.js\");\nconst debugLogger = __webpack_require__(/*! ../utils/debug-logger.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst handleCallbackErrors = __webpack_require__(/*! ../utils/handleCallbackErrors.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/handleCallbackErrors.js\");\nconst hasSpansEnabled = __webpack_require__(/*! ../utils/hasSpansEnabled.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/hasSpansEnabled.js\");\nconst parseSampleRate = __webpack_require__(/*! ../utils/parseSampleRate.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/parseSampleRate.js\");\nconst propagationContext = __webpack_require__(/*! ../utils/propagationContext.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/propagationContext.js\");\nconst spanOnScope = __webpack_require__(/*! ../utils/spanOnScope.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanOnScope.js\");\nconst spanUtils = __webpack_require__(/*! ../utils/spanUtils.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanUtils.js\");\nconst tracing = __webpack_require__(/*! ../utils/tracing.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/tracing.js\");\nconst dynamicSamplingContext = __webpack_require__(/*! ./dynamicSamplingContext.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/dynamicSamplingContext.js\");\nconst logSpans = __webpack_require__(/*! ./logSpans.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/logSpans.js\");\nconst sampling = __webpack_require__(/*! ./sampling.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/sampling.js\");\nconst sentryNonRecordingSpan = __webpack_require__(/*! ./sentryNonRecordingSpan.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/sentryNonRecordingSpan.js\");\nconst sentrySpan = __webpack_require__(/*! ./sentrySpan.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/sentrySpan.js\");\nconst spanstatus = __webpack_require__(/*! ./spanstatus.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/spanstatus.js\");\nconst utils = __webpack_require__(/*! ./utils.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/utils.js\");\n\n/* eslint-disable max-lines */\n\n\nconst SUPPRESS_TRACING_KEY = '__SENTRY_SUPPRESS_TRACING__';\n\n/**\n * Wraps a function with a transaction/span and finishes the span after the function is done.\n * The created span is the active span and will be used as parent by other spans created inside the function\n * and can be accessed via `Sentry.getActiveSpan()`, as long as the function is executed while the scope is active.\n *\n * If you want to create a span that is not set as active, use {@link startInactiveSpan}.\n *\n * You'll always get a span passed to the callback,\n * it may just be a non-recording span if the span is not sampled or if tracing is disabled.\n */\nfunction startSpan(options, callback) {\n  const acs = getAcs();\n  if (acs.startSpan) {\n    return acs.startSpan(options, callback);\n  }\n\n  const spanArguments = parseSentrySpanArguments(options);\n  const { forceTransaction, parentSpan: customParentSpan, scope: customScope } = options;\n\n  // We still need to fork a potentially passed scope, as we set the active span on it\n  // and we need to ensure that it is cleaned up properly once the span ends.\n  const customForkedScope = customScope?.clone();\n\n  return currentScopes.withScope(customForkedScope, () => {\n    // If `options.parentSpan` is defined, we want to wrap the callback in `withActiveSpan`\n    const wrapper = getActiveSpanWrapper(customParentSpan);\n\n    return wrapper(() => {\n      const scope = currentScopes.getCurrentScope();\n      const parentSpan = getParentSpan(scope, customParentSpan);\n\n      const shouldSkipSpan = options.onlyIfParent && !parentSpan;\n      const activeSpan = shouldSkipSpan\n        ? new sentryNonRecordingSpan.SentryNonRecordingSpan()\n        : createChildOrRootSpan({\n            parentSpan,\n            spanArguments,\n            forceTransaction,\n            scope,\n          });\n\n      spanOnScope._setSpanForScope(scope, activeSpan);\n\n      return handleCallbackErrors.handleCallbackErrors(\n        () => callback(activeSpan),\n        () => {\n          // Only update the span status if it hasn't been changed yet, and the span is not yet finished\n          const { status } = spanUtils.spanToJSON(activeSpan);\n          if (activeSpan.isRecording() && (!status || status === 'ok')) {\n            activeSpan.setStatus({ code: spanstatus.SPAN_STATUS_ERROR, message: 'internal_error' });\n          }\n        },\n        () => {\n          activeSpan.end();\n        },\n      );\n    });\n  });\n}\n\n/**\n * Similar to `Sentry.startSpan`. Wraps a function with a transaction/span, but does not finish the span\n * after the function is done automatically. Use `span.end()` to end the span.\n *\n * The created span is the active span and will be used as parent by other spans created inside the function\n * and can be accessed via `Sentry.getActiveSpan()`, as long as the function is executed while the scope is active.\n *\n * You'll always get a span passed to the callback,\n * it may just be a non-recording span if the span is not sampled or if tracing is disabled.\n */\nfunction startSpanManual(options, callback) {\n  const acs = getAcs();\n  if (acs.startSpanManual) {\n    return acs.startSpanManual(options, callback);\n  }\n\n  const spanArguments = parseSentrySpanArguments(options);\n  const { forceTransaction, parentSpan: customParentSpan, scope: customScope } = options;\n\n  const customForkedScope = customScope?.clone();\n\n  return currentScopes.withScope(customForkedScope, () => {\n    // If `options.parentSpan` is defined, we want to wrap the callback in `withActiveSpan`\n    const wrapper = getActiveSpanWrapper(customParentSpan);\n\n    return wrapper(() => {\n      const scope = currentScopes.getCurrentScope();\n      const parentSpan = getParentSpan(scope, customParentSpan);\n\n      const shouldSkipSpan = options.onlyIfParent && !parentSpan;\n      const activeSpan = shouldSkipSpan\n        ? new sentryNonRecordingSpan.SentryNonRecordingSpan()\n        : createChildOrRootSpan({\n            parentSpan,\n            spanArguments,\n            forceTransaction,\n            scope,\n          });\n\n      spanOnScope._setSpanForScope(scope, activeSpan);\n\n      return handleCallbackErrors.handleCallbackErrors(\n        // We pass the `finish` function to the callback, so the user can finish the span manually\n        // this is mainly here for historic purposes because previously, we instructed users to call\n        // `finish` instead of `span.end()` to also clean up the scope. Nowadays, calling `span.end()`\n        // or `finish` has the same effect and we simply leave it here to avoid breaking user code.\n        () => callback(activeSpan, () => activeSpan.end()),\n        () => {\n          // Only update the span status if it hasn't been changed yet, and the span is not yet finished\n          const { status } = spanUtils.spanToJSON(activeSpan);\n          if (activeSpan.isRecording() && (!status || status === 'ok')) {\n            activeSpan.setStatus({ code: spanstatus.SPAN_STATUS_ERROR, message: 'internal_error' });\n          }\n        },\n      );\n    });\n  });\n}\n\n/**\n * Creates a span. This span is not set as active, so will not get automatic instrumentation spans\n * as children or be able to be accessed via `Sentry.getActiveSpan()`.\n *\n * If you want to create a span that is set as active, use {@link startSpan}.\n *\n * This function will always return a span,\n * it may just be a non-recording span if the span is not sampled or if tracing is disabled.\n */\nfunction startInactiveSpan(options) {\n  const acs = getAcs();\n  if (acs.startInactiveSpan) {\n    return acs.startInactiveSpan(options);\n  }\n\n  const spanArguments = parseSentrySpanArguments(options);\n  const { forceTransaction, parentSpan: customParentSpan } = options;\n\n  // If `options.scope` is defined, we use this as as a wrapper,\n  // If `options.parentSpan` is defined, we want to wrap the callback in `withActiveSpan`\n  const wrapper = options.scope\n    ? (callback) => currentScopes.withScope(options.scope, callback)\n    : customParentSpan !== undefined\n      ? (callback) => withActiveSpan(customParentSpan, callback)\n      : (callback) => callback();\n\n  return wrapper(() => {\n    const scope = currentScopes.getCurrentScope();\n    const parentSpan = getParentSpan(scope, customParentSpan);\n\n    const shouldSkipSpan = options.onlyIfParent && !parentSpan;\n\n    if (shouldSkipSpan) {\n      return new sentryNonRecordingSpan.SentryNonRecordingSpan();\n    }\n\n    return createChildOrRootSpan({\n      parentSpan,\n      spanArguments,\n      forceTransaction,\n      scope,\n    });\n  });\n}\n\n/**\n * Continue a trace from `sentry-trace` and `baggage` values.\n * These values can be obtained from incoming request headers, or in the browser from `<meta name=\"sentry-trace\">`\n * and `<meta name=\"baggage\">` HTML tags.\n *\n * Spans started with `startSpan`, `startSpanManual` and `startInactiveSpan`, within the callback will automatically\n * be attached to the incoming trace.\n */\nconst continueTrace = (\n  options\n\n,\n  callback,\n) => {\n  const carrier$1 = carrier.getMainCarrier();\n  const acs = index.getAsyncContextStrategy(carrier$1);\n  if (acs.continueTrace) {\n    return acs.continueTrace(options, callback);\n  }\n\n  const { sentryTrace, baggage } = options;\n\n  return currentScopes.withScope(scope => {\n    const propagationContext = tracing.propagationContextFromHeaders(sentryTrace, baggage);\n    scope.setPropagationContext(propagationContext);\n    return callback();\n  });\n};\n\n/**\n * Forks the current scope and sets the provided span as active span in the context of the provided callback. Can be\n * passed `null` to start an entirely new span tree.\n *\n * @param span Spans started in the context of the provided callback will be children of this span. If `null` is passed,\n * spans started within the callback will not be attached to a parent span.\n * @param callback Execution context in which the provided span will be active. Is passed the newly forked scope.\n * @returns the value returned from the provided callback function.\n */\nfunction withActiveSpan(span, callback) {\n  const acs = getAcs();\n  if (acs.withActiveSpan) {\n    return acs.withActiveSpan(span, callback);\n  }\n\n  return currentScopes.withScope(scope => {\n    spanOnScope._setSpanForScope(scope, span || undefined);\n    return callback(scope);\n  });\n}\n\n/** Suppress tracing in the given callback, ensuring no spans are generated inside of it. */\nfunction suppressTracing(callback) {\n  const acs = getAcs();\n\n  if (acs.suppressTracing) {\n    return acs.suppressTracing(callback);\n  }\n\n  return currentScopes.withScope(scope => {\n    // Note: We do not wait for the callback to finish before we reset the metadata\n    // the reason for this is that otherwise, in the browser this can lead to very weird behavior\n    // as there is only a single top scope, if the callback takes longer to finish,\n    // other, unrelated spans may also be suppressed, which we do not want\n    // so instead, we only suppress tracing synchronoysly in the browser\n    scope.setSDKProcessingMetadata({ [SUPPRESS_TRACING_KEY]: true });\n    const res = callback();\n    scope.setSDKProcessingMetadata({ [SUPPRESS_TRACING_KEY]: undefined });\n    return res;\n  });\n}\n\n/**\n * Starts a new trace for the duration of the provided callback. Spans started within the\n * callback will be part of the new trace instead of a potentially previously started trace.\n *\n * Important: Only use this function if you want to override the default trace lifetime and\n * propagation mechanism of the SDK for the duration and scope of the provided callback.\n * The newly created trace will also be the root of a new distributed trace, for example if\n * you make http requests within the callback.\n * This function might be useful if the operation you want to instrument should not be part\n * of a potentially ongoing trace.\n *\n * Default behavior:\n * - Server-side: A new trace is started for each incoming request.\n * - Browser: A new trace is started for each page our route. Navigating to a new route\n *            or page will automatically create a new trace.\n */\nfunction startNewTrace(callback) {\n  return currentScopes.withScope(scope => {\n    scope.setPropagationContext({\n      traceId: propagationContext.generateTraceId(),\n      sampleRand: Math.random(),\n    });\n    debugBuild.DEBUG_BUILD && debugLogger.debug.log(`Starting a new trace with id ${scope.getPropagationContext().traceId}`);\n    return withActiveSpan(null, callback);\n  });\n}\n\nfunction createChildOrRootSpan({\n  parentSpan,\n  spanArguments,\n  forceTransaction,\n  scope,\n}\n\n) {\n  if (!hasSpansEnabled.hasSpansEnabled()) {\n    const span = new sentryNonRecordingSpan.SentryNonRecordingSpan();\n\n    // If this is a root span, we ensure to freeze a DSC\n    // So we can have at least partial data here\n    if (forceTransaction || !parentSpan) {\n      const dsc = {\n        sampled: 'false',\n        sample_rate: '0',\n        transaction: spanArguments.name,\n        ...dynamicSamplingContext.getDynamicSamplingContextFromSpan(span),\n      } ;\n      dynamicSamplingContext.freezeDscOnSpan(span, dsc);\n    }\n\n    return span;\n  }\n\n  const isolationScope = currentScopes.getIsolationScope();\n\n  let span;\n  if (parentSpan && !forceTransaction) {\n    span = _startChildSpan(parentSpan, scope, spanArguments);\n    spanUtils.addChildSpanToSpan(parentSpan, span);\n  } else if (parentSpan) {\n    // If we forced a transaction but have a parent span, make sure to continue from the parent span, not the scope\n    const dsc = dynamicSamplingContext.getDynamicSamplingContextFromSpan(parentSpan);\n    const { traceId, spanId: parentSpanId } = parentSpan.spanContext();\n    const parentSampled = spanUtils.spanIsSampled(parentSpan);\n\n    span = _startRootSpan(\n      {\n        traceId,\n        parentSpanId,\n        ...spanArguments,\n      },\n      scope,\n      parentSampled,\n    );\n\n    dynamicSamplingContext.freezeDscOnSpan(span, dsc);\n  } else {\n    const {\n      traceId,\n      dsc,\n      parentSpanId,\n      sampled: parentSampled,\n    } = {\n      ...isolationScope.getPropagationContext(),\n      ...scope.getPropagationContext(),\n    };\n\n    span = _startRootSpan(\n      {\n        traceId,\n        parentSpanId,\n        ...spanArguments,\n      },\n      scope,\n      parentSampled,\n    );\n\n    if (dsc) {\n      dynamicSamplingContext.freezeDscOnSpan(span, dsc);\n    }\n  }\n\n  logSpans.logSpanStart(span);\n\n  utils.setCapturedScopesOnSpan(span, scope, isolationScope);\n\n  return span;\n}\n\n/**\n * This converts StartSpanOptions to SentrySpanArguments.\n * For the most part (for now) we accept the same options,\n * but some of them need to be transformed.\n */\nfunction parseSentrySpanArguments(options) {\n  const exp = options.experimental || {};\n  const initialCtx = {\n    isStandalone: exp.standalone,\n    ...options,\n  };\n\n  if (options.startTime) {\n    const ctx = { ...initialCtx };\n    ctx.startTimestamp = spanUtils.spanTimeInputToSeconds(options.startTime);\n    delete ctx.startTime;\n    return ctx;\n  }\n\n  return initialCtx;\n}\n\nfunction getAcs() {\n  const carrier$1 = carrier.getMainCarrier();\n  return index.getAsyncContextStrategy(carrier$1);\n}\n\nfunction _startRootSpan(spanArguments, scope, parentSampled) {\n  const client = currentScopes.getClient();\n  const options = client?.getOptions() || {};\n\n  const { name = '' } = spanArguments;\n\n  const mutableSpanSamplingData = { spanAttributes: { ...spanArguments.attributes }, spanName: name, parentSampled };\n\n  // we don't care about the decision for the moment; this is just a placeholder\n  client?.emit('beforeSampling', mutableSpanSamplingData, { decision: false });\n\n  // If hook consumers override the parentSampled flag, we will use that value instead of the actual one\n  const finalParentSampled = mutableSpanSamplingData.parentSampled ?? parentSampled;\n  const finalAttributes = mutableSpanSamplingData.spanAttributes;\n\n  const currentPropagationContext = scope.getPropagationContext();\n  const [sampled, sampleRate, localSampleRateWasApplied] = scope.getScopeData().sdkProcessingMetadata[\n    SUPPRESS_TRACING_KEY\n  ]\n    ? [false]\n    : sampling.sampleSpan(\n        options,\n        {\n          name,\n          parentSampled: finalParentSampled,\n          attributes: finalAttributes,\n          parentSampleRate: parseSampleRate.parseSampleRate(currentPropagationContext.dsc?.sample_rate),\n        },\n        currentPropagationContext.sampleRand,\n      );\n\n  const rootSpan = new sentrySpan.SentrySpan({\n    ...spanArguments,\n    attributes: {\n      [semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_SOURCE]: 'custom',\n      [semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_SAMPLE_RATE]:\n        sampleRate !== undefined && localSampleRateWasApplied ? sampleRate : undefined,\n      ...finalAttributes,\n    },\n    sampled,\n  });\n\n  if (!sampled && client) {\n    debugBuild.DEBUG_BUILD && debugLogger.debug.log('[Tracing] Discarding root span because its trace was not chosen to be sampled.');\n    client.recordDroppedEvent('sample_rate', 'transaction');\n  }\n\n  if (client) {\n    client.emit('spanStart', rootSpan);\n  }\n\n  return rootSpan;\n}\n\n/**\n * Creates a new `Span` while setting the current `Span.id` as `parentSpanId`.\n * This inherits the sampling decision from the parent span.\n */\nfunction _startChildSpan(parentSpan, scope, spanArguments) {\n  const { spanId, traceId } = parentSpan.spanContext();\n  const sampled = scope.getScopeData().sdkProcessingMetadata[SUPPRESS_TRACING_KEY] ? false : spanUtils.spanIsSampled(parentSpan);\n\n  const childSpan = sampled\n    ? new sentrySpan.SentrySpan({\n        ...spanArguments,\n        parentSpanId: spanId,\n        traceId,\n        sampled,\n      })\n    : new sentryNonRecordingSpan.SentryNonRecordingSpan({ traceId });\n\n  spanUtils.addChildSpanToSpan(parentSpan, childSpan);\n\n  const client = currentScopes.getClient();\n  if (client) {\n    client.emit('spanStart', childSpan);\n    // If it has an endTimestamp, it's already ended\n    if (spanArguments.endTimestamp) {\n      client.emit('spanEnd', childSpan);\n    }\n  }\n\n  return childSpan;\n}\n\nfunction getParentSpan(scope, customParentSpan) {\n  // always use the passed in span directly\n  if (customParentSpan) {\n    return customParentSpan ;\n  }\n\n  // This is different from `undefined` as it means the user explicitly wants no parent span\n  if (customParentSpan === null) {\n    return undefined;\n  }\n\n  const span = spanOnScope._getSpanForScope(scope) ;\n\n  if (!span) {\n    return undefined;\n  }\n\n  const client = currentScopes.getClient();\n  const options = client ? client.getOptions() : {};\n  if (options.parentSpanIsAlwaysRootSpan) {\n    return spanUtils.getRootSpan(span) ;\n  }\n\n  return span;\n}\n\nfunction getActiveSpanWrapper(parentSpan) {\n  return parentSpan !== undefined\n    ? (callback) => {\n        return withActiveSpan(parentSpan, callback);\n      }\n    : (callback) => callback();\n}\n\nexports.continueTrace = continueTrace;\nexports.startInactiveSpan = startInactiveSpan;\nexports.startNewTrace = startNewTrace;\nexports.startSpan = startSpan;\nexports.startSpanManual = startSpanManual;\nexports.suppressTracing = suppressTracing;\nexports.withActiveSpan = withActiveSpan;\n//# sourceMappingURL=trace.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy90cmFjaW5nL3RyYWNlLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLGNBQWMsbUJBQU8sQ0FBQywwSUFBMEI7QUFDaEQsZ0JBQWdCLG1CQUFPLENBQUMsb0hBQWU7QUFDdkMsc0JBQXNCLG1CQUFPLENBQUMsZ0lBQXFCO0FBQ25ELG1CQUFtQixtQkFBTyxDQUFDLDRIQUFtQjtBQUM5QywyQkFBMkIsbUJBQU8sQ0FBQywwSUFBMEI7QUFDN0Qsb0JBQW9CLG1CQUFPLENBQUMsMElBQTBCO0FBQ3RELDZCQUE2QixtQkFBTyxDQUFDLDBKQUFrQztBQUN2RSx3QkFBd0IsbUJBQU8sQ0FBQyxnSkFBNkI7QUFDN0Qsd0JBQXdCLG1CQUFPLENBQUMsZ0pBQTZCO0FBQzdELDJCQUEyQixtQkFBTyxDQUFDLHNKQUFnQztBQUNuRSxvQkFBb0IsbUJBQU8sQ0FBQyx3SUFBeUI7QUFDckQsa0JBQWtCLG1CQUFPLENBQUMsb0lBQXVCO0FBQ2pELGdCQUFnQixtQkFBTyxDQUFDLGdJQUFxQjtBQUM3QywrQkFBK0IsbUJBQU8sQ0FBQyx5SkFBNkI7QUFDcEUsaUJBQWlCLG1CQUFPLENBQUMsNkhBQWU7QUFDeEMsaUJBQWlCLG1CQUFPLENBQUMsNkhBQWU7QUFDeEMsK0JBQStCLG1CQUFPLENBQUMseUpBQTZCO0FBQ3BFLG1CQUFtQixtQkFBTyxDQUFDLGlJQUFpQjtBQUM1QyxtQkFBbUIsbUJBQU8sQ0FBQyxpSUFBaUI7QUFDNUMsY0FBYyxtQkFBTyxDQUFDLHVIQUFZOztBQUVsQzs7O0FBR0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGdFQUFnRSx3QkFBd0I7QUFDeEY7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0EsVUFBVSxxRUFBcUU7O0FBRS9FO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxXQUFXOztBQUVYOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0Esa0JBQWtCLFNBQVM7QUFDM0I7QUFDQSxtQ0FBbUMsK0RBQStEO0FBQ2xHO0FBQ0EsU0FBUztBQUNUO0FBQ0E7QUFDQSxTQUFTO0FBQ1Q7QUFDQSxLQUFLO0FBQ0wsR0FBRztBQUNIOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBLFVBQVUscUVBQXFFOztBQUUvRTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxXQUFXOztBQUVYOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxrQkFBa0IsU0FBUztBQUMzQjtBQUNBLG1DQUFtQywrREFBK0Q7QUFDbEc7QUFDQSxTQUFTO0FBQ1Q7QUFDQSxLQUFLO0FBQ0wsR0FBRztBQUNIOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsNERBQTRELGdCQUFnQjtBQUM1RTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQSxVQUFVLGlEQUFpRDs7QUFFM0Q7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsS0FBSztBQUNMLEdBQUc7QUFDSDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLFVBQVUsdUJBQXVCOztBQUVqQztBQUNBO0FBQ0E7QUFDQTtBQUNBLEdBQUc7QUFDSDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBLEdBQUc7QUFDSDs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLHFDQUFxQyw4QkFBOEI7QUFDbkU7QUFDQSxxQ0FBcUMsbUNBQW1DO0FBQ3hFO0FBQ0EsR0FBRztBQUNIOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEtBQUs7QUFDTCxvRkFBb0Ysc0NBQXNDO0FBQzFIO0FBQ0EsR0FBRztBQUNIOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsSUFBSTtBQUNKO0FBQ0E7QUFDQSxZQUFZLGdDQUFnQztBQUM1Qzs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsT0FBTztBQUNQO0FBQ0E7QUFDQTs7QUFFQTtBQUNBLElBQUk7QUFDSjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsTUFBTTtBQUNOO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsT0FBTztBQUNQO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQSxrQkFBa0I7QUFDbEI7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUEsVUFBVSxZQUFZOztBQUV0QixvQ0FBb0Msa0JBQWtCLDZCQUE2Qjs7QUFFbkYsc0RBQXNEO0FBQ3RELDREQUE0RCxpQkFBaUI7O0FBRTdFO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxTQUFTO0FBQ1Q7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEtBQUs7QUFDTDtBQUNBLEdBQUc7O0FBRUg7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFVBQVUsa0JBQWtCO0FBQzVCOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLE9BQU87QUFDUCwwREFBMEQsU0FBUzs7QUFFbkU7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSxxQkFBcUI7QUFDckIseUJBQXlCO0FBQ3pCLHFCQUFxQjtBQUNyQixpQkFBaUI7QUFDakIsdUJBQXVCO0FBQ3ZCLHVCQUF1QjtBQUN2QixzQkFBc0I7QUFDdEIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy90cmFjaW5nL3RyYWNlLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBpbmRleCA9IHJlcXVpcmUoJy4uL2FzeW5jQ29udGV4dC9pbmRleC5qcycpO1xuY29uc3QgY2FycmllciA9IHJlcXVpcmUoJy4uL2NhcnJpZXIuanMnKTtcbmNvbnN0IGN1cnJlbnRTY29wZXMgPSByZXF1aXJlKCcuLi9jdXJyZW50U2NvcGVzLmpzJyk7XG5jb25zdCBkZWJ1Z0J1aWxkID0gcmVxdWlyZSgnLi4vZGVidWctYnVpbGQuanMnKTtcbmNvbnN0IHNlbWFudGljQXR0cmlidXRlcyA9IHJlcXVpcmUoJy4uL3NlbWFudGljQXR0cmlidXRlcy5qcycpO1xuY29uc3QgZGVidWdMb2dnZXIgPSByZXF1aXJlKCcuLi91dGlscy9kZWJ1Zy1sb2dnZXIuanMnKTtcbmNvbnN0IGhhbmRsZUNhbGxiYWNrRXJyb3JzID0gcmVxdWlyZSgnLi4vdXRpbHMvaGFuZGxlQ2FsbGJhY2tFcnJvcnMuanMnKTtcbmNvbnN0IGhhc1NwYW5zRW5hYmxlZCA9IHJlcXVpcmUoJy4uL3V0aWxzL2hhc1NwYW5zRW5hYmxlZC5qcycpO1xuY29uc3QgcGFyc2VTYW1wbGVSYXRlID0gcmVxdWlyZSgnLi4vdXRpbHMvcGFyc2VTYW1wbGVSYXRlLmpzJyk7XG5jb25zdCBwcm9wYWdhdGlvbkNvbnRleHQgPSByZXF1aXJlKCcuLi91dGlscy9wcm9wYWdhdGlvbkNvbnRleHQuanMnKTtcbmNvbnN0IHNwYW5PblNjb3BlID0gcmVxdWlyZSgnLi4vdXRpbHMvc3Bhbk9uU2NvcGUuanMnKTtcbmNvbnN0IHNwYW5VdGlscyA9IHJlcXVpcmUoJy4uL3V0aWxzL3NwYW5VdGlscy5qcycpO1xuY29uc3QgdHJhY2luZyA9IHJlcXVpcmUoJy4uL3V0aWxzL3RyYWNpbmcuanMnKTtcbmNvbnN0IGR5bmFtaWNTYW1wbGluZ0NvbnRleHQgPSByZXF1aXJlKCcuL2R5bmFtaWNTYW1wbGluZ0NvbnRleHQuanMnKTtcbmNvbnN0IGxvZ1NwYW5zID0gcmVxdWlyZSgnLi9sb2dTcGFucy5qcycpO1xuY29uc3Qgc2FtcGxpbmcgPSByZXF1aXJlKCcuL3NhbXBsaW5nLmpzJyk7XG5jb25zdCBzZW50cnlOb25SZWNvcmRpbmdTcGFuID0gcmVxdWlyZSgnLi9zZW50cnlOb25SZWNvcmRpbmdTcGFuLmpzJyk7XG5jb25zdCBzZW50cnlTcGFuID0gcmVxdWlyZSgnLi9zZW50cnlTcGFuLmpzJyk7XG5jb25zdCBzcGFuc3RhdHVzID0gcmVxdWlyZSgnLi9zcGFuc3RhdHVzLmpzJyk7XG5jb25zdCB1dGlscyA9IHJlcXVpcmUoJy4vdXRpbHMuanMnKTtcblxuLyogZXNsaW50LWRpc2FibGUgbWF4LWxpbmVzICovXG5cblxuY29uc3QgU1VQUFJFU1NfVFJBQ0lOR19LRVkgPSAnX19TRU5UUllfU1VQUFJFU1NfVFJBQ0lOR19fJztcblxuLyoqXG4gKiBXcmFwcyBhIGZ1bmN0aW9uIHdpdGggYSB0cmFuc2FjdGlvbi9zcGFuIGFuZCBmaW5pc2hlcyB0aGUgc3BhbiBhZnRlciB0aGUgZnVuY3Rpb24gaXMgZG9uZS5cbiAqIFRoZSBjcmVhdGVkIHNwYW4gaXMgdGhlIGFjdGl2ZSBzcGFuIGFuZCB3aWxsIGJlIHVzZWQgYXMgcGFyZW50IGJ5IG90aGVyIHNwYW5zIGNyZWF0ZWQgaW5zaWRlIHRoZSBmdW5jdGlvblxuICogYW5kIGNhbiBiZSBhY2Nlc3NlZCB2aWEgYFNlbnRyeS5nZXRBY3RpdmVTcGFuKClgLCBhcyBsb25nIGFzIHRoZSBmdW5jdGlvbiBpcyBleGVjdXRlZCB3aGlsZSB0aGUgc2NvcGUgaXMgYWN0aXZlLlxuICpcbiAqIElmIHlvdSB3YW50IHRvIGNyZWF0ZSBhIHNwYW4gdGhhdCBpcyBub3Qgc2V0IGFzIGFjdGl2ZSwgdXNlIHtAbGluayBzdGFydEluYWN0aXZlU3Bhbn0uXG4gKlxuICogWW91J2xsIGFsd2F5cyBnZXQgYSBzcGFuIHBhc3NlZCB0byB0aGUgY2FsbGJhY2ssXG4gKiBpdCBtYXkganVzdCBiZSBhIG5vbi1yZWNvcmRpbmcgc3BhbiBpZiB0aGUgc3BhbiBpcyBub3Qgc2FtcGxlZCBvciBpZiB0cmFjaW5nIGlzIGRpc2FibGVkLlxuICovXG5mdW5jdGlvbiBzdGFydFNwYW4ob3B0aW9ucywgY2FsbGJhY2spIHtcbiAgY29uc3QgYWNzID0gZ2V0QWNzKCk7XG4gIGlmIChhY3Muc3RhcnRTcGFuKSB7XG4gICAgcmV0dXJuIGFjcy5zdGFydFNwYW4ob3B0aW9ucywgY2FsbGJhY2spO1xuICB9XG5cbiAgY29uc3Qgc3BhbkFyZ3VtZW50cyA9IHBhcnNlU2VudHJ5U3BhbkFyZ3VtZW50cyhvcHRpb25zKTtcbiAgY29uc3QgeyBmb3JjZVRyYW5zYWN0aW9uLCBwYXJlbnRTcGFuOiBjdXN0b21QYXJlbnRTcGFuLCBzY29wZTogY3VzdG9tU2NvcGUgfSA9IG9wdGlvbnM7XG5cbiAgLy8gV2Ugc3RpbGwgbmVlZCB0byBmb3JrIGEgcG90ZW50aWFsbHkgcGFzc2VkIHNjb3BlLCBhcyB3ZSBzZXQgdGhlIGFjdGl2ZSBzcGFuIG9uIGl0XG4gIC8vIGFuZCB3ZSBuZWVkIHRvIGVuc3VyZSB0aGF0IGl0IGlzIGNsZWFuZWQgdXAgcHJvcGVybHkgb25jZSB0aGUgc3BhbiBlbmRzLlxuICBjb25zdCBjdXN0b21Gb3JrZWRTY29wZSA9IGN1c3RvbVNjb3BlPy5jbG9uZSgpO1xuXG4gIHJldHVybiBjdXJyZW50U2NvcGVzLndpdGhTY29wZShjdXN0b21Gb3JrZWRTY29wZSwgKCkgPT4ge1xuICAgIC8vIElmIGBvcHRpb25zLnBhcmVudFNwYW5gIGlzIGRlZmluZWQsIHdlIHdhbnQgdG8gd3JhcCB0aGUgY2FsbGJhY2sgaW4gYHdpdGhBY3RpdmVTcGFuYFxuICAgIGNvbnN0IHdyYXBwZXIgPSBnZXRBY3RpdmVTcGFuV3JhcHBlcihjdXN0b21QYXJlbnRTcGFuKTtcblxuICAgIHJldHVybiB3cmFwcGVyKCgpID0+IHtcbiAgICAgIGNvbnN0IHNjb3BlID0gY3VycmVudFNjb3Blcy5nZXRDdXJyZW50U2NvcGUoKTtcbiAgICAgIGNvbnN0IHBhcmVudFNwYW4gPSBnZXRQYXJlbnRTcGFuKHNjb3BlLCBjdXN0b21QYXJlbnRTcGFuKTtcblxuICAgICAgY29uc3Qgc2hvdWxkU2tpcFNwYW4gPSBvcHRpb25zLm9ubHlJZlBhcmVudCAmJiAhcGFyZW50U3BhbjtcbiAgICAgIGNvbnN0IGFjdGl2ZVNwYW4gPSBzaG91bGRTa2lwU3BhblxuICAgICAgICA/IG5ldyBzZW50cnlOb25SZWNvcmRpbmdTcGFuLlNlbnRyeU5vblJlY29yZGluZ1NwYW4oKVxuICAgICAgICA6IGNyZWF0ZUNoaWxkT3JSb290U3Bhbih7XG4gICAgICAgICAgICBwYXJlbnRTcGFuLFxuICAgICAgICAgICAgc3BhbkFyZ3VtZW50cyxcbiAgICAgICAgICAgIGZvcmNlVHJhbnNhY3Rpb24sXG4gICAgICAgICAgICBzY29wZSxcbiAgICAgICAgICB9KTtcblxuICAgICAgc3Bhbk9uU2NvcGUuX3NldFNwYW5Gb3JTY29wZShzY29wZSwgYWN0aXZlU3Bhbik7XG5cbiAgICAgIHJldHVybiBoYW5kbGVDYWxsYmFja0Vycm9ycy5oYW5kbGVDYWxsYmFja0Vycm9ycyhcbiAgICAgICAgKCkgPT4gY2FsbGJhY2soYWN0aXZlU3BhbiksXG4gICAgICAgICgpID0+IHtcbiAgICAgICAgICAvLyBPbmx5IHVwZGF0ZSB0aGUgc3BhbiBzdGF0dXMgaWYgaXQgaGFzbid0IGJlZW4gY2hhbmdlZCB5ZXQsIGFuZCB0aGUgc3BhbiBpcyBub3QgeWV0IGZpbmlzaGVkXG4gICAgICAgICAgY29uc3QgeyBzdGF0dXMgfSA9IHNwYW5VdGlscy5zcGFuVG9KU09OKGFjdGl2ZVNwYW4pO1xuICAgICAgICAgIGlmIChhY3RpdmVTcGFuLmlzUmVjb3JkaW5nKCkgJiYgKCFzdGF0dXMgfHwgc3RhdHVzID09PSAnb2snKSkge1xuICAgICAgICAgICAgYWN0aXZlU3Bhbi5zZXRTdGF0dXMoeyBjb2RlOiBzcGFuc3RhdHVzLlNQQU5fU1RBVFVTX0VSUk9SLCBtZXNzYWdlOiAnaW50ZXJuYWxfZXJyb3InIH0pO1xuICAgICAgICAgIH1cbiAgICAgICAgfSxcbiAgICAgICAgKCkgPT4ge1xuICAgICAgICAgIGFjdGl2ZVNwYW4uZW5kKCk7XG4gICAgICAgIH0sXG4gICAgICApO1xuICAgIH0pO1xuICB9KTtcbn1cblxuLyoqXG4gKiBTaW1pbGFyIHRvIGBTZW50cnkuc3RhcnRTcGFuYC4gV3JhcHMgYSBmdW5jdGlvbiB3aXRoIGEgdHJhbnNhY3Rpb24vc3BhbiwgYnV0IGRvZXMgbm90IGZpbmlzaCB0aGUgc3BhblxuICogYWZ0ZXIgdGhlIGZ1bmN0aW9uIGlzIGRvbmUgYXV0b21hdGljYWxseS4gVXNlIGBzcGFuLmVuZCgpYCB0byBlbmQgdGhlIHNwYW4uXG4gKlxuICogVGhlIGNyZWF0ZWQgc3BhbiBpcyB0aGUgYWN0aXZlIHNwYW4gYW5kIHdpbGwgYmUgdXNlZCBhcyBwYXJlbnQgYnkgb3RoZXIgc3BhbnMgY3JlYXRlZCBpbnNpZGUgdGhlIGZ1bmN0aW9uXG4gKiBhbmQgY2FuIGJlIGFjY2Vzc2VkIHZpYSBgU2VudHJ5LmdldEFjdGl2ZVNwYW4oKWAsIGFzIGxvbmcgYXMgdGhlIGZ1bmN0aW9uIGlzIGV4ZWN1dGVkIHdoaWxlIHRoZSBzY29wZSBpcyBhY3RpdmUuXG4gKlxuICogWW91J2xsIGFsd2F5cyBnZXQgYSBzcGFuIHBhc3NlZCB0byB0aGUgY2FsbGJhY2ssXG4gKiBpdCBtYXkganVzdCBiZSBhIG5vbi1yZWNvcmRpbmcgc3BhbiBpZiB0aGUgc3BhbiBpcyBub3Qgc2FtcGxlZCBvciBpZiB0cmFjaW5nIGlzIGRpc2FibGVkLlxuICovXG5mdW5jdGlvbiBzdGFydFNwYW5NYW51YWwob3B0aW9ucywgY2FsbGJhY2spIHtcbiAgY29uc3QgYWNzID0gZ2V0QWNzKCk7XG4gIGlmIChhY3Muc3RhcnRTcGFuTWFudWFsKSB7XG4gICAgcmV0dXJuIGFjcy5zdGFydFNwYW5NYW51YWwob3B0aW9ucywgY2FsbGJhY2spO1xuICB9XG5cbiAgY29uc3Qgc3BhbkFyZ3VtZW50cyA9IHBhcnNlU2VudHJ5U3BhbkFyZ3VtZW50cyhvcHRpb25zKTtcbiAgY29uc3QgeyBmb3JjZVRyYW5zYWN0aW9uLCBwYXJlbnRTcGFuOiBjdXN0b21QYXJlbnRTcGFuLCBzY29wZTogY3VzdG9tU2NvcGUgfSA9IG9wdGlvbnM7XG5cbiAgY29uc3QgY3VzdG9tRm9ya2VkU2NvcGUgPSBjdXN0b21TY29wZT8uY2xvbmUoKTtcblxuICByZXR1cm4gY3VycmVudFNjb3Blcy53aXRoU2NvcGUoY3VzdG9tRm9ya2VkU2NvcGUsICgpID0+IHtcbiAgICAvLyBJZiBgb3B0aW9ucy5wYXJlbnRTcGFuYCBpcyBkZWZpbmVkLCB3ZSB3YW50IHRvIHdyYXAgdGhlIGNhbGxiYWNrIGluIGB3aXRoQWN0aXZlU3BhbmBcbiAgICBjb25zdCB3cmFwcGVyID0gZ2V0QWN0aXZlU3BhbldyYXBwZXIoY3VzdG9tUGFyZW50U3Bhbik7XG5cbiAgICByZXR1cm4gd3JhcHBlcigoKSA9PiB7XG4gICAgICBjb25zdCBzY29wZSA9IGN1cnJlbnRTY29wZXMuZ2V0Q3VycmVudFNjb3BlKCk7XG4gICAgICBjb25zdCBwYXJlbnRTcGFuID0gZ2V0UGFyZW50U3BhbihzY29wZSwgY3VzdG9tUGFyZW50U3Bhbik7XG5cbiAgICAgIGNvbnN0IHNob3VsZFNraXBTcGFuID0gb3B0aW9ucy5vbmx5SWZQYXJlbnQgJiYgIXBhcmVudFNwYW47XG4gICAgICBjb25zdCBhY3RpdmVTcGFuID0gc2hvdWxkU2tpcFNwYW5cbiAgICAgICAgPyBuZXcgc2VudHJ5Tm9uUmVjb3JkaW5nU3Bhbi5TZW50cnlOb25SZWNvcmRpbmdTcGFuKClcbiAgICAgICAgOiBjcmVhdGVDaGlsZE9yUm9vdFNwYW4oe1xuICAgICAgICAgICAgcGFyZW50U3BhbixcbiAgICAgICAgICAgIHNwYW5Bcmd1bWVudHMsXG4gICAgICAgICAgICBmb3JjZVRyYW5zYWN0aW9uLFxuICAgICAgICAgICAgc2NvcGUsXG4gICAgICAgICAgfSk7XG5cbiAgICAgIHNwYW5PblNjb3BlLl9zZXRTcGFuRm9yU2NvcGUoc2NvcGUsIGFjdGl2ZVNwYW4pO1xuXG4gICAgICByZXR1cm4gaGFuZGxlQ2FsbGJhY2tFcnJvcnMuaGFuZGxlQ2FsbGJhY2tFcnJvcnMoXG4gICAgICAgIC8vIFdlIHBhc3MgdGhlIGBmaW5pc2hgIGZ1bmN0aW9uIHRvIHRoZSBjYWxsYmFjaywgc28gdGhlIHVzZXIgY2FuIGZpbmlzaCB0aGUgc3BhbiBtYW51YWxseVxuICAgICAgICAvLyB0aGlzIGlzIG1haW5seSBoZXJlIGZvciBoaXN0b3JpYyBwdXJwb3NlcyBiZWNhdXNlIHByZXZpb3VzbHksIHdlIGluc3RydWN0ZWQgdXNlcnMgdG8gY2FsbFxuICAgICAgICAvLyBgZmluaXNoYCBpbnN0ZWFkIG9mIGBzcGFuLmVuZCgpYCB0byBhbHNvIGNsZWFuIHVwIHRoZSBzY29wZS4gTm93YWRheXMsIGNhbGxpbmcgYHNwYW4uZW5kKClgXG4gICAgICAgIC8vIG9yIGBmaW5pc2hgIGhhcyB0aGUgc2FtZSBlZmZlY3QgYW5kIHdlIHNpbXBseSBsZWF2ZSBpdCBoZXJlIHRvIGF2b2lkIGJyZWFraW5nIHVzZXIgY29kZS5cbiAgICAgICAgKCkgPT4gY2FsbGJhY2soYWN0aXZlU3BhbiwgKCkgPT4gYWN0aXZlU3Bhbi5lbmQoKSksXG4gICAgICAgICgpID0+IHtcbiAgICAgICAgICAvLyBPbmx5IHVwZGF0ZSB0aGUgc3BhbiBzdGF0dXMgaWYgaXQgaGFzbid0IGJlZW4gY2hhbmdlZCB5ZXQsIGFuZCB0aGUgc3BhbiBpcyBub3QgeWV0IGZpbmlzaGVkXG4gICAgICAgICAgY29uc3QgeyBzdGF0dXMgfSA9IHNwYW5VdGlscy5zcGFuVG9KU09OKGFjdGl2ZVNwYW4pO1xuICAgICAgICAgIGlmIChhY3RpdmVTcGFuLmlzUmVjb3JkaW5nKCkgJiYgKCFzdGF0dXMgfHwgc3RhdHVzID09PSAnb2snKSkge1xuICAgICAgICAgICAgYWN0aXZlU3Bhbi5zZXRTdGF0dXMoeyBjb2RlOiBzcGFuc3RhdHVzLlNQQU5fU1RBVFVTX0VSUk9SLCBtZXNzYWdlOiAnaW50ZXJuYWxfZXJyb3InIH0pO1xuICAgICAgICAgIH1cbiAgICAgICAgfSxcbiAgICAgICk7XG4gICAgfSk7XG4gIH0pO1xufVxuXG4vKipcbiAqIENyZWF0ZXMgYSBzcGFuLiBUaGlzIHNwYW4gaXMgbm90IHNldCBhcyBhY3RpdmUsIHNvIHdpbGwgbm90IGdldCBhdXRvbWF0aWMgaW5zdHJ1bWVudGF0aW9uIHNwYW5zXG4gKiBhcyBjaGlsZHJlbiBvciBiZSBhYmxlIHRvIGJlIGFjY2Vzc2VkIHZpYSBgU2VudHJ5LmdldEFjdGl2ZVNwYW4oKWAuXG4gKlxuICogSWYgeW91IHdhbnQgdG8gY3JlYXRlIGEgc3BhbiB0aGF0IGlzIHNldCBhcyBhY3RpdmUsIHVzZSB7QGxpbmsgc3RhcnRTcGFufS5cbiAqXG4gKiBUaGlzIGZ1bmN0aW9uIHdpbGwgYWx3YXlzIHJldHVybiBhIHNwYW4sXG4gKiBpdCBtYXkganVzdCBiZSBhIG5vbi1yZWNvcmRpbmcgc3BhbiBpZiB0aGUgc3BhbiBpcyBub3Qgc2FtcGxlZCBvciBpZiB0cmFjaW5nIGlzIGRpc2FibGVkLlxuICovXG5mdW5jdGlvbiBzdGFydEluYWN0aXZlU3BhbihvcHRpb25zKSB7XG4gIGNvbnN0IGFjcyA9IGdldEFjcygpO1xuICBpZiAoYWNzLnN0YXJ0SW5hY3RpdmVTcGFuKSB7XG4gICAgcmV0dXJuIGFjcy5zdGFydEluYWN0aXZlU3BhbihvcHRpb25zKTtcbiAgfVxuXG4gIGNvbnN0IHNwYW5Bcmd1bWVudHMgPSBwYXJzZVNlbnRyeVNwYW5Bcmd1bWVudHMob3B0aW9ucyk7XG4gIGNvbnN0IHsgZm9yY2VUcmFuc2FjdGlvbiwgcGFyZW50U3BhbjogY3VzdG9tUGFyZW50U3BhbiB9ID0gb3B0aW9ucztcblxuICAvLyBJZiBgb3B0aW9ucy5zY29wZWAgaXMgZGVmaW5lZCwgd2UgdXNlIHRoaXMgYXMgYXMgYSB3cmFwcGVyLFxuICAvLyBJZiBgb3B0aW9ucy5wYXJlbnRTcGFuYCBpcyBkZWZpbmVkLCB3ZSB3YW50IHRvIHdyYXAgdGhlIGNhbGxiYWNrIGluIGB3aXRoQWN0aXZlU3BhbmBcbiAgY29uc3Qgd3JhcHBlciA9IG9wdGlvbnMuc2NvcGVcbiAgICA/IChjYWxsYmFjaykgPT4gY3VycmVudFNjb3Blcy53aXRoU2NvcGUob3B0aW9ucy5zY29wZSwgY2FsbGJhY2spXG4gICAgOiBjdXN0b21QYXJlbnRTcGFuICE9PSB1bmRlZmluZWRcbiAgICAgID8gKGNhbGxiYWNrKSA9PiB3aXRoQWN0aXZlU3BhbihjdXN0b21QYXJlbnRTcGFuLCBjYWxsYmFjaylcbiAgICAgIDogKGNhbGxiYWNrKSA9PiBjYWxsYmFjaygpO1xuXG4gIHJldHVybiB3cmFwcGVyKCgpID0+IHtcbiAgICBjb25zdCBzY29wZSA9IGN1cnJlbnRTY29wZXMuZ2V0Q3VycmVudFNjb3BlKCk7XG4gICAgY29uc3QgcGFyZW50U3BhbiA9IGdldFBhcmVudFNwYW4oc2NvcGUsIGN1c3RvbVBhcmVudFNwYW4pO1xuXG4gICAgY29uc3Qgc2hvdWxkU2tpcFNwYW4gPSBvcHRpb25zLm9ubHlJZlBhcmVudCAmJiAhcGFyZW50U3BhbjtcblxuICAgIGlmIChzaG91bGRTa2lwU3Bhbikge1xuICAgICAgcmV0dXJuIG5ldyBzZW50cnlOb25SZWNvcmRpbmdTcGFuLlNlbnRyeU5vblJlY29yZGluZ1NwYW4oKTtcbiAgICB9XG5cbiAgICByZXR1cm4gY3JlYXRlQ2hpbGRPclJvb3RTcGFuKHtcbiAgICAgIHBhcmVudFNwYW4sXG4gICAgICBzcGFuQXJndW1lbnRzLFxuICAgICAgZm9yY2VUcmFuc2FjdGlvbixcbiAgICAgIHNjb3BlLFxuICAgIH0pO1xuICB9KTtcbn1cblxuLyoqXG4gKiBDb250aW51ZSBhIHRyYWNlIGZyb20gYHNlbnRyeS10cmFjZWAgYW5kIGBiYWdnYWdlYCB2YWx1ZXMuXG4gKiBUaGVzZSB2YWx1ZXMgY2FuIGJlIG9idGFpbmVkIGZyb20gaW5jb21pbmcgcmVxdWVzdCBoZWFkZXJzLCBvciBpbiB0aGUgYnJvd3NlciBmcm9tIGA8bWV0YSBuYW1lPVwic2VudHJ5LXRyYWNlXCI+YFxuICogYW5kIGA8bWV0YSBuYW1lPVwiYmFnZ2FnZVwiPmAgSFRNTCB0YWdzLlxuICpcbiAqIFNwYW5zIHN0YXJ0ZWQgd2l0aCBgc3RhcnRTcGFuYCwgYHN0YXJ0U3Bhbk1hbnVhbGAgYW5kIGBzdGFydEluYWN0aXZlU3BhbmAsIHdpdGhpbiB0aGUgY2FsbGJhY2sgd2lsbCBhdXRvbWF0aWNhbGx5XG4gKiBiZSBhdHRhY2hlZCB0byB0aGUgaW5jb21pbmcgdHJhY2UuXG4gKi9cbmNvbnN0IGNvbnRpbnVlVHJhY2UgPSAoXG4gIG9wdGlvbnNcblxuLFxuICBjYWxsYmFjayxcbikgPT4ge1xuICBjb25zdCBjYXJyaWVyJDEgPSBjYXJyaWVyLmdldE1haW5DYXJyaWVyKCk7XG4gIGNvbnN0IGFjcyA9IGluZGV4LmdldEFzeW5jQ29udGV4dFN0cmF0ZWd5KGNhcnJpZXIkMSk7XG4gIGlmIChhY3MuY29udGludWVUcmFjZSkge1xuICAgIHJldHVybiBhY3MuY29udGludWVUcmFjZShvcHRpb25zLCBjYWxsYmFjayk7XG4gIH1cblxuICBjb25zdCB7IHNlbnRyeVRyYWNlLCBiYWdnYWdlIH0gPSBvcHRpb25zO1xuXG4gIHJldHVybiBjdXJyZW50U2NvcGVzLndpdGhTY29wZShzY29wZSA9PiB7XG4gICAgY29uc3QgcHJvcGFnYXRpb25Db250ZXh0ID0gdHJhY2luZy5wcm9wYWdhdGlvbkNvbnRleHRGcm9tSGVhZGVycyhzZW50cnlUcmFjZSwgYmFnZ2FnZSk7XG4gICAgc2NvcGUuc2V0UHJvcGFnYXRpb25Db250ZXh0KHByb3BhZ2F0aW9uQ29udGV4dCk7XG4gICAgcmV0dXJuIGNhbGxiYWNrKCk7XG4gIH0pO1xufTtcblxuLyoqXG4gKiBGb3JrcyB0aGUgY3VycmVudCBzY29wZSBhbmQgc2V0cyB0aGUgcHJvdmlkZWQgc3BhbiBhcyBhY3RpdmUgc3BhbiBpbiB0aGUgY29udGV4dCBvZiB0aGUgcHJvdmlkZWQgY2FsbGJhY2suIENhbiBiZVxuICogcGFzc2VkIGBudWxsYCB0byBzdGFydCBhbiBlbnRpcmVseSBuZXcgc3BhbiB0cmVlLlxuICpcbiAqIEBwYXJhbSBzcGFuIFNwYW5zIHN0YXJ0ZWQgaW4gdGhlIGNvbnRleHQgb2YgdGhlIHByb3ZpZGVkIGNhbGxiYWNrIHdpbGwgYmUgY2hpbGRyZW4gb2YgdGhpcyBzcGFuLiBJZiBgbnVsbGAgaXMgcGFzc2VkLFxuICogc3BhbnMgc3RhcnRlZCB3aXRoaW4gdGhlIGNhbGxiYWNrIHdpbGwgbm90IGJlIGF0dGFjaGVkIHRvIGEgcGFyZW50IHNwYW4uXG4gKiBAcGFyYW0gY2FsbGJhY2sgRXhlY3V0aW9uIGNvbnRleHQgaW4gd2hpY2ggdGhlIHByb3ZpZGVkIHNwYW4gd2lsbCBiZSBhY3RpdmUuIElzIHBhc3NlZCB0aGUgbmV3bHkgZm9ya2VkIHNjb3BlLlxuICogQHJldHVybnMgdGhlIHZhbHVlIHJldHVybmVkIGZyb20gdGhlIHByb3ZpZGVkIGNhbGxiYWNrIGZ1bmN0aW9uLlxuICovXG5mdW5jdGlvbiB3aXRoQWN0aXZlU3BhbihzcGFuLCBjYWxsYmFjaykge1xuICBjb25zdCBhY3MgPSBnZXRBY3MoKTtcbiAgaWYgKGFjcy53aXRoQWN0aXZlU3Bhbikge1xuICAgIHJldHVybiBhY3Mud2l0aEFjdGl2ZVNwYW4oc3BhbiwgY2FsbGJhY2spO1xuICB9XG5cbiAgcmV0dXJuIGN1cnJlbnRTY29wZXMud2l0aFNjb3BlKHNjb3BlID0+IHtcbiAgICBzcGFuT25TY29wZS5fc2V0U3BhbkZvclNjb3BlKHNjb3BlLCBzcGFuIHx8IHVuZGVmaW5lZCk7XG4gICAgcmV0dXJuIGNhbGxiYWNrKHNjb3BlKTtcbiAgfSk7XG59XG5cbi8qKiBTdXBwcmVzcyB0cmFjaW5nIGluIHRoZSBnaXZlbiBjYWxsYmFjaywgZW5zdXJpbmcgbm8gc3BhbnMgYXJlIGdlbmVyYXRlZCBpbnNpZGUgb2YgaXQuICovXG5mdW5jdGlvbiBzdXBwcmVzc1RyYWNpbmcoY2FsbGJhY2spIHtcbiAgY29uc3QgYWNzID0gZ2V0QWNzKCk7XG5cbiAgaWYgKGFjcy5zdXBwcmVzc1RyYWNpbmcpIHtcbiAgICByZXR1cm4gYWNzLnN1cHByZXNzVHJhY2luZyhjYWxsYmFjayk7XG4gIH1cblxuICByZXR1cm4gY3VycmVudFNjb3Blcy53aXRoU2NvcGUoc2NvcGUgPT4ge1xuICAgIC8vIE5vdGU6IFdlIGRvIG5vdCB3YWl0IGZvciB0aGUgY2FsbGJhY2sgdG8gZmluaXNoIGJlZm9yZSB3ZSByZXNldCB0aGUgbWV0YWRhdGFcbiAgICAvLyB0aGUgcmVhc29uIGZvciB0aGlzIGlzIHRoYXQgb3RoZXJ3aXNlLCBpbiB0aGUgYnJvd3NlciB0aGlzIGNhbiBsZWFkIHRvIHZlcnkgd2VpcmQgYmVoYXZpb3JcbiAgICAvLyBhcyB0aGVyZSBpcyBvbmx5IGEgc2luZ2xlIHRvcCBzY29wZSwgaWYgdGhlIGNhbGxiYWNrIHRha2VzIGxvbmdlciB0byBmaW5pc2gsXG4gICAgLy8gb3RoZXIsIHVucmVsYXRlZCBzcGFucyBtYXkgYWxzbyBiZSBzdXBwcmVzc2VkLCB3aGljaCB3ZSBkbyBub3Qgd2FudFxuICAgIC8vIHNvIGluc3RlYWQsIHdlIG9ubHkgc3VwcHJlc3MgdHJhY2luZyBzeW5jaHJvbm95c2x5IGluIHRoZSBicm93c2VyXG4gICAgc2NvcGUuc2V0U0RLUHJvY2Vzc2luZ01ldGFkYXRhKHsgW1NVUFBSRVNTX1RSQUNJTkdfS0VZXTogdHJ1ZSB9KTtcbiAgICBjb25zdCByZXMgPSBjYWxsYmFjaygpO1xuICAgIHNjb3BlLnNldFNES1Byb2Nlc3NpbmdNZXRhZGF0YSh7IFtTVVBQUkVTU19UUkFDSU5HX0tFWV06IHVuZGVmaW5lZCB9KTtcbiAgICByZXR1cm4gcmVzO1xuICB9KTtcbn1cblxuLyoqXG4gKiBTdGFydHMgYSBuZXcgdHJhY2UgZm9yIHRoZSBkdXJhdGlvbiBvZiB0aGUgcHJvdmlkZWQgY2FsbGJhY2suIFNwYW5zIHN0YXJ0ZWQgd2l0aGluIHRoZVxuICogY2FsbGJhY2sgd2lsbCBiZSBwYXJ0IG9mIHRoZSBuZXcgdHJhY2UgaW5zdGVhZCBvZiBhIHBvdGVudGlhbGx5IHByZXZpb3VzbHkgc3RhcnRlZCB0cmFjZS5cbiAqXG4gKiBJbXBvcnRhbnQ6IE9ubHkgdXNlIHRoaXMgZnVuY3Rpb24gaWYgeW91IHdhbnQgdG8gb3ZlcnJpZGUgdGhlIGRlZmF1bHQgdHJhY2UgbGlmZXRpbWUgYW5kXG4gKiBwcm9wYWdhdGlvbiBtZWNoYW5pc20gb2YgdGhlIFNESyBmb3IgdGhlIGR1cmF0aW9uIGFuZCBzY29wZSBvZiB0aGUgcHJvdmlkZWQgY2FsbGJhY2suXG4gKiBUaGUgbmV3bHkgY3JlYXRlZCB0cmFjZSB3aWxsIGFsc28gYmUgdGhlIHJvb3Qgb2YgYSBuZXcgZGlzdHJpYnV0ZWQgdHJhY2UsIGZvciBleGFtcGxlIGlmXG4gKiB5b3UgbWFrZSBodHRwIHJlcXVlc3RzIHdpdGhpbiB0aGUgY2FsbGJhY2suXG4gKiBUaGlzIGZ1bmN0aW9uIG1pZ2h0IGJlIHVzZWZ1bCBpZiB0aGUgb3BlcmF0aW9uIHlvdSB3YW50IHRvIGluc3RydW1lbnQgc2hvdWxkIG5vdCBiZSBwYXJ0XG4gKiBvZiBhIHBvdGVudGlhbGx5IG9uZ29pbmcgdHJhY2UuXG4gKlxuICogRGVmYXVsdCBiZWhhdmlvcjpcbiAqIC0gU2VydmVyLXNpZGU6IEEgbmV3IHRyYWNlIGlzIHN0YXJ0ZWQgZm9yIGVhY2ggaW5jb21pbmcgcmVxdWVzdC5cbiAqIC0gQnJvd3NlcjogQSBuZXcgdHJhY2UgaXMgc3RhcnRlZCBmb3IgZWFjaCBwYWdlIG91ciByb3V0ZS4gTmF2aWdhdGluZyB0byBhIG5ldyByb3V0ZVxuICogICAgICAgICAgICBvciBwYWdlIHdpbGwgYXV0b21hdGljYWxseSBjcmVhdGUgYSBuZXcgdHJhY2UuXG4gKi9cbmZ1bmN0aW9uIHN0YXJ0TmV3VHJhY2UoY2FsbGJhY2spIHtcbiAgcmV0dXJuIGN1cnJlbnRTY29wZXMud2l0aFNjb3BlKHNjb3BlID0+IHtcbiAgICBzY29wZS5zZXRQcm9wYWdhdGlvbkNvbnRleHQoe1xuICAgICAgdHJhY2VJZDogcHJvcGFnYXRpb25Db250ZXh0LmdlbmVyYXRlVHJhY2VJZCgpLFxuICAgICAgc2FtcGxlUmFuZDogTWF0aC5yYW5kb20oKSxcbiAgICB9KTtcbiAgICBkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEICYmIGRlYnVnTG9nZ2VyLmRlYnVnLmxvZyhgU3RhcnRpbmcgYSBuZXcgdHJhY2Ugd2l0aCBpZCAke3Njb3BlLmdldFByb3BhZ2F0aW9uQ29udGV4dCgpLnRyYWNlSWR9YCk7XG4gICAgcmV0dXJuIHdpdGhBY3RpdmVTcGFuKG51bGwsIGNhbGxiYWNrKTtcbiAgfSk7XG59XG5cbmZ1bmN0aW9uIGNyZWF0ZUNoaWxkT3JSb290U3Bhbih7XG4gIHBhcmVudFNwYW4sXG4gIHNwYW5Bcmd1bWVudHMsXG4gIGZvcmNlVHJhbnNhY3Rpb24sXG4gIHNjb3BlLFxufVxuXG4pIHtcbiAgaWYgKCFoYXNTcGFuc0VuYWJsZWQuaGFzU3BhbnNFbmFibGVkKCkpIHtcbiAgICBjb25zdCBzcGFuID0gbmV3IHNlbnRyeU5vblJlY29yZGluZ1NwYW4uU2VudHJ5Tm9uUmVjb3JkaW5nU3BhbigpO1xuXG4gICAgLy8gSWYgdGhpcyBpcyBhIHJvb3Qgc3Bhbiwgd2UgZW5zdXJlIHRvIGZyZWV6ZSBhIERTQ1xuICAgIC8vIFNvIHdlIGNhbiBoYXZlIGF0IGxlYXN0IHBhcnRpYWwgZGF0YSBoZXJlXG4gICAgaWYgKGZvcmNlVHJhbnNhY3Rpb24gfHwgIXBhcmVudFNwYW4pIHtcbiAgICAgIGNvbnN0IGRzYyA9IHtcbiAgICAgICAgc2FtcGxlZDogJ2ZhbHNlJyxcbiAgICAgICAgc2FtcGxlX3JhdGU6ICcwJyxcbiAgICAgICAgdHJhbnNhY3Rpb246IHNwYW5Bcmd1bWVudHMubmFtZSxcbiAgICAgICAgLi4uZHluYW1pY1NhbXBsaW5nQ29udGV4dC5nZXREeW5hbWljU2FtcGxpbmdDb250ZXh0RnJvbVNwYW4oc3BhbiksXG4gICAgICB9IDtcbiAgICAgIGR5bmFtaWNTYW1wbGluZ0NvbnRleHQuZnJlZXplRHNjT25TcGFuKHNwYW4sIGRzYyk7XG4gICAgfVxuXG4gICAgcmV0dXJuIHNwYW47XG4gIH1cblxuICBjb25zdCBpc29sYXRpb25TY29wZSA9IGN1cnJlbnRTY29wZXMuZ2V0SXNvbGF0aW9uU2NvcGUoKTtcblxuICBsZXQgc3BhbjtcbiAgaWYgKHBhcmVudFNwYW4gJiYgIWZvcmNlVHJhbnNhY3Rpb24pIHtcbiAgICBzcGFuID0gX3N0YXJ0Q2hpbGRTcGFuKHBhcmVudFNwYW4sIHNjb3BlLCBzcGFuQXJndW1lbnRzKTtcbiAgICBzcGFuVXRpbHMuYWRkQ2hpbGRTcGFuVG9TcGFuKHBhcmVudFNwYW4sIHNwYW4pO1xuICB9IGVsc2UgaWYgKHBhcmVudFNwYW4pIHtcbiAgICAvLyBJZiB3ZSBmb3JjZWQgYSB0cmFuc2FjdGlvbiBidXQgaGF2ZSBhIHBhcmVudCBzcGFuLCBtYWtlIHN1cmUgdG8gY29udGludWUgZnJvbSB0aGUgcGFyZW50IHNwYW4sIG5vdCB0aGUgc2NvcGVcbiAgICBjb25zdCBkc2MgPSBkeW5hbWljU2FtcGxpbmdDb250ZXh0LmdldER5bmFtaWNTYW1wbGluZ0NvbnRleHRGcm9tU3BhbihwYXJlbnRTcGFuKTtcbiAgICBjb25zdCB7IHRyYWNlSWQsIHNwYW5JZDogcGFyZW50U3BhbklkIH0gPSBwYXJlbnRTcGFuLnNwYW5Db250ZXh0KCk7XG4gICAgY29uc3QgcGFyZW50U2FtcGxlZCA9IHNwYW5VdGlscy5zcGFuSXNTYW1wbGVkKHBhcmVudFNwYW4pO1xuXG4gICAgc3BhbiA9IF9zdGFydFJvb3RTcGFuKFxuICAgICAge1xuICAgICAgICB0cmFjZUlkLFxuICAgICAgICBwYXJlbnRTcGFuSWQsXG4gICAgICAgIC4uLnNwYW5Bcmd1bWVudHMsXG4gICAgICB9LFxuICAgICAgc2NvcGUsXG4gICAgICBwYXJlbnRTYW1wbGVkLFxuICAgICk7XG5cbiAgICBkeW5hbWljU2FtcGxpbmdDb250ZXh0LmZyZWV6ZURzY09uU3BhbihzcGFuLCBkc2MpO1xuICB9IGVsc2Uge1xuICAgIGNvbnN0IHtcbiAgICAgIHRyYWNlSWQsXG4gICAgICBkc2MsXG4gICAgICBwYXJlbnRTcGFuSWQsXG4gICAgICBzYW1wbGVkOiBwYXJlbnRTYW1wbGVkLFxuICAgIH0gPSB7XG4gICAgICAuLi5pc29sYXRpb25TY29wZS5nZXRQcm9wYWdhdGlvbkNvbnRleHQoKSxcbiAgICAgIC4uLnNjb3BlLmdldFByb3BhZ2F0aW9uQ29udGV4dCgpLFxuICAgIH07XG5cbiAgICBzcGFuID0gX3N0YXJ0Um9vdFNwYW4oXG4gICAgICB7XG4gICAgICAgIHRyYWNlSWQsXG4gICAgICAgIHBhcmVudFNwYW5JZCxcbiAgICAgICAgLi4uc3BhbkFyZ3VtZW50cyxcbiAgICAgIH0sXG4gICAgICBzY29wZSxcbiAgICAgIHBhcmVudFNhbXBsZWQsXG4gICAgKTtcblxuICAgIGlmIChkc2MpIHtcbiAgICAgIGR5bmFtaWNTYW1wbGluZ0NvbnRleHQuZnJlZXplRHNjT25TcGFuKHNwYW4sIGRzYyk7XG4gICAgfVxuICB9XG5cbiAgbG9nU3BhbnMubG9nU3BhblN0YXJ0KHNwYW4pO1xuXG4gIHV0aWxzLnNldENhcHR1cmVkU2NvcGVzT25TcGFuKHNwYW4sIHNjb3BlLCBpc29sYXRpb25TY29wZSk7XG5cbiAgcmV0dXJuIHNwYW47XG59XG5cbi8qKlxuICogVGhpcyBjb252ZXJ0cyBTdGFydFNwYW5PcHRpb25zIHRvIFNlbnRyeVNwYW5Bcmd1bWVudHMuXG4gKiBGb3IgdGhlIG1vc3QgcGFydCAoZm9yIG5vdykgd2UgYWNjZXB0IHRoZSBzYW1lIG9wdGlvbnMsXG4gKiBidXQgc29tZSBvZiB0aGVtIG5lZWQgdG8gYmUgdHJhbnNmb3JtZWQuXG4gKi9cbmZ1bmN0aW9uIHBhcnNlU2VudHJ5U3BhbkFyZ3VtZW50cyhvcHRpb25zKSB7XG4gIGNvbnN0IGV4cCA9IG9wdGlvbnMuZXhwZXJpbWVudGFsIHx8IHt9O1xuICBjb25zdCBpbml0aWFsQ3R4ID0ge1xuICAgIGlzU3RhbmRhbG9uZTogZXhwLnN0YW5kYWxvbmUsXG4gICAgLi4ub3B0aW9ucyxcbiAgfTtcblxuICBpZiAob3B0aW9ucy5zdGFydFRpbWUpIHtcbiAgICBjb25zdCBjdHggPSB7IC4uLmluaXRpYWxDdHggfTtcbiAgICBjdHguc3RhcnRUaW1lc3RhbXAgPSBzcGFuVXRpbHMuc3BhblRpbWVJbnB1dFRvU2Vjb25kcyhvcHRpb25zLnN0YXJ0VGltZSk7XG4gICAgZGVsZXRlIGN0eC5zdGFydFRpbWU7XG4gICAgcmV0dXJuIGN0eDtcbiAgfVxuXG4gIHJldHVybiBpbml0aWFsQ3R4O1xufVxuXG5mdW5jdGlvbiBnZXRBY3MoKSB7XG4gIGNvbnN0IGNhcnJpZXIkMSA9IGNhcnJpZXIuZ2V0TWFpbkNhcnJpZXIoKTtcbiAgcmV0dXJuIGluZGV4LmdldEFzeW5jQ29udGV4dFN0cmF0ZWd5KGNhcnJpZXIkMSk7XG59XG5cbmZ1bmN0aW9uIF9zdGFydFJvb3RTcGFuKHNwYW5Bcmd1bWVudHMsIHNjb3BlLCBwYXJlbnRTYW1wbGVkKSB7XG4gIGNvbnN0IGNsaWVudCA9IGN1cnJlbnRTY29wZXMuZ2V0Q2xpZW50KCk7XG4gIGNvbnN0IG9wdGlvbnMgPSBjbGllbnQ/LmdldE9wdGlvbnMoKSB8fCB7fTtcblxuICBjb25zdCB7IG5hbWUgPSAnJyB9ID0gc3BhbkFyZ3VtZW50cztcblxuICBjb25zdCBtdXRhYmxlU3BhblNhbXBsaW5nRGF0YSA9IHsgc3BhbkF0dHJpYnV0ZXM6IHsgLi4uc3BhbkFyZ3VtZW50cy5hdHRyaWJ1dGVzIH0sIHNwYW5OYW1lOiBuYW1lLCBwYXJlbnRTYW1wbGVkIH07XG5cbiAgLy8gd2UgZG9uJ3QgY2FyZSBhYm91dCB0aGUgZGVjaXNpb24gZm9yIHRoZSBtb21lbnQ7IHRoaXMgaXMganVzdCBhIHBsYWNlaG9sZGVyXG4gIGNsaWVudD8uZW1pdCgnYmVmb3JlU2FtcGxpbmcnLCBtdXRhYmxlU3BhblNhbXBsaW5nRGF0YSwgeyBkZWNpc2lvbjogZmFsc2UgfSk7XG5cbiAgLy8gSWYgaG9vayBjb25zdW1lcnMgb3ZlcnJpZGUgdGhlIHBhcmVudFNhbXBsZWQgZmxhZywgd2Ugd2lsbCB1c2UgdGhhdCB2YWx1ZSBpbnN0ZWFkIG9mIHRoZSBhY3R1YWwgb25lXG4gIGNvbnN0IGZpbmFsUGFyZW50U2FtcGxlZCA9IG11dGFibGVTcGFuU2FtcGxpbmdEYXRhLnBhcmVudFNhbXBsZWQgPz8gcGFyZW50U2FtcGxlZDtcbiAgY29uc3QgZmluYWxBdHRyaWJ1dGVzID0gbXV0YWJsZVNwYW5TYW1wbGluZ0RhdGEuc3BhbkF0dHJpYnV0ZXM7XG5cbiAgY29uc3QgY3VycmVudFByb3BhZ2F0aW9uQ29udGV4dCA9IHNjb3BlLmdldFByb3BhZ2F0aW9uQ29udGV4dCgpO1xuICBjb25zdCBbc2FtcGxlZCwgc2FtcGxlUmF0ZSwgbG9jYWxTYW1wbGVSYXRlV2FzQXBwbGllZF0gPSBzY29wZS5nZXRTY29wZURhdGEoKS5zZGtQcm9jZXNzaW5nTWV0YWRhdGFbXG4gICAgU1VQUFJFU1NfVFJBQ0lOR19LRVlcbiAgXVxuICAgID8gW2ZhbHNlXVxuICAgIDogc2FtcGxpbmcuc2FtcGxlU3BhbihcbiAgICAgICAgb3B0aW9ucyxcbiAgICAgICAge1xuICAgICAgICAgIG5hbWUsXG4gICAgICAgICAgcGFyZW50U2FtcGxlZDogZmluYWxQYXJlbnRTYW1wbGVkLFxuICAgICAgICAgIGF0dHJpYnV0ZXM6IGZpbmFsQXR0cmlidXRlcyxcbiAgICAgICAgICBwYXJlbnRTYW1wbGVSYXRlOiBwYXJzZVNhbXBsZVJhdGUucGFyc2VTYW1wbGVSYXRlKGN1cnJlbnRQcm9wYWdhdGlvbkNvbnRleHQuZHNjPy5zYW1wbGVfcmF0ZSksXG4gICAgICAgIH0sXG4gICAgICAgIGN1cnJlbnRQcm9wYWdhdGlvbkNvbnRleHQuc2FtcGxlUmFuZCxcbiAgICAgICk7XG5cbiAgY29uc3Qgcm9vdFNwYW4gPSBuZXcgc2VudHJ5U3Bhbi5TZW50cnlTcGFuKHtcbiAgICAuLi5zcGFuQXJndW1lbnRzLFxuICAgIGF0dHJpYnV0ZXM6IHtcbiAgICAgIFtzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9TT1VSQ0VdOiAnY3VzdG9tJyxcbiAgICAgIFtzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9TQU1QTEVfUkFURV06XG4gICAgICAgIHNhbXBsZVJhdGUgIT09IHVuZGVmaW5lZCAmJiBsb2NhbFNhbXBsZVJhdGVXYXNBcHBsaWVkID8gc2FtcGxlUmF0ZSA6IHVuZGVmaW5lZCxcbiAgICAgIC4uLmZpbmFsQXR0cmlidXRlcyxcbiAgICB9LFxuICAgIHNhbXBsZWQsXG4gIH0pO1xuXG4gIGlmICghc2FtcGxlZCAmJiBjbGllbnQpIHtcbiAgICBkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEICYmIGRlYnVnTG9nZ2VyLmRlYnVnLmxvZygnW1RyYWNpbmddIERpc2NhcmRpbmcgcm9vdCBzcGFuIGJlY2F1c2UgaXRzIHRyYWNlIHdhcyBub3QgY2hvc2VuIHRvIGJlIHNhbXBsZWQuJyk7XG4gICAgY2xpZW50LnJlY29yZERyb3BwZWRFdmVudCgnc2FtcGxlX3JhdGUnLCAndHJhbnNhY3Rpb24nKTtcbiAgfVxuXG4gIGlmIChjbGllbnQpIHtcbiAgICBjbGllbnQuZW1pdCgnc3BhblN0YXJ0Jywgcm9vdFNwYW4pO1xuICB9XG5cbiAgcmV0dXJuIHJvb3RTcGFuO1xufVxuXG4vKipcbiAqIENyZWF0ZXMgYSBuZXcgYFNwYW5gIHdoaWxlIHNldHRpbmcgdGhlIGN1cnJlbnQgYFNwYW4uaWRgIGFzIGBwYXJlbnRTcGFuSWRgLlxuICogVGhpcyBpbmhlcml0cyB0aGUgc2FtcGxpbmcgZGVjaXNpb24gZnJvbSB0aGUgcGFyZW50IHNwYW4uXG4gKi9cbmZ1bmN0aW9uIF9zdGFydENoaWxkU3BhbihwYXJlbnRTcGFuLCBzY29wZSwgc3BhbkFyZ3VtZW50cykge1xuICBjb25zdCB7IHNwYW5JZCwgdHJhY2VJZCB9ID0gcGFyZW50U3Bhbi5zcGFuQ29udGV4dCgpO1xuICBjb25zdCBzYW1wbGVkID0gc2NvcGUuZ2V0U2NvcGVEYXRhKCkuc2RrUHJvY2Vzc2luZ01ldGFkYXRhW1NVUFBSRVNTX1RSQUNJTkdfS0VZXSA/IGZhbHNlIDogc3BhblV0aWxzLnNwYW5Jc1NhbXBsZWQocGFyZW50U3Bhbik7XG5cbiAgY29uc3QgY2hpbGRTcGFuID0gc2FtcGxlZFxuICAgID8gbmV3IHNlbnRyeVNwYW4uU2VudHJ5U3Bhbih7XG4gICAgICAgIC4uLnNwYW5Bcmd1bWVudHMsXG4gICAgICAgIHBhcmVudFNwYW5JZDogc3BhbklkLFxuICAgICAgICB0cmFjZUlkLFxuICAgICAgICBzYW1wbGVkLFxuICAgICAgfSlcbiAgICA6IG5ldyBzZW50cnlOb25SZWNvcmRpbmdTcGFuLlNlbnRyeU5vblJlY29yZGluZ1NwYW4oeyB0cmFjZUlkIH0pO1xuXG4gIHNwYW5VdGlscy5hZGRDaGlsZFNwYW5Ub1NwYW4ocGFyZW50U3BhbiwgY2hpbGRTcGFuKTtcblxuICBjb25zdCBjbGllbnQgPSBjdXJyZW50U2NvcGVzLmdldENsaWVudCgpO1xuICBpZiAoY2xpZW50KSB7XG4gICAgY2xpZW50LmVtaXQoJ3NwYW5TdGFydCcsIGNoaWxkU3Bhbik7XG4gICAgLy8gSWYgaXQgaGFzIGFuIGVuZFRpbWVzdGFtcCwgaXQncyBhbHJlYWR5IGVuZGVkXG4gICAgaWYgKHNwYW5Bcmd1bWVudHMuZW5kVGltZXN0YW1wKSB7XG4gICAgICBjbGllbnQuZW1pdCgnc3BhbkVuZCcsIGNoaWxkU3Bhbik7XG4gICAgfVxuICB9XG5cbiAgcmV0dXJuIGNoaWxkU3Bhbjtcbn1cblxuZnVuY3Rpb24gZ2V0UGFyZW50U3BhbihzY29wZSwgY3VzdG9tUGFyZW50U3Bhbikge1xuICAvLyBhbHdheXMgdXNlIHRoZSBwYXNzZWQgaW4gc3BhbiBkaXJlY3RseVxuICBpZiAoY3VzdG9tUGFyZW50U3Bhbikge1xuICAgIHJldHVybiBjdXN0b21QYXJlbnRTcGFuIDtcbiAgfVxuXG4gIC8vIFRoaXMgaXMgZGlmZmVyZW50IGZyb20gYHVuZGVmaW5lZGAgYXMgaXQgbWVhbnMgdGhlIHVzZXIgZXhwbGljaXRseSB3YW50cyBubyBwYXJlbnQgc3BhblxuICBpZiAoY3VzdG9tUGFyZW50U3BhbiA9PT0gbnVsbCkge1xuICAgIHJldHVybiB1bmRlZmluZWQ7XG4gIH1cblxuICBjb25zdCBzcGFuID0gc3Bhbk9uU2NvcGUuX2dldFNwYW5Gb3JTY29wZShzY29wZSkgO1xuXG4gIGlmICghc3Bhbikge1xuICAgIHJldHVybiB1bmRlZmluZWQ7XG4gIH1cblxuICBjb25zdCBjbGllbnQgPSBjdXJyZW50U2NvcGVzLmdldENsaWVudCgpO1xuICBjb25zdCBvcHRpb25zID0gY2xpZW50ID8gY2xpZW50LmdldE9wdGlvbnMoKSA6IHt9O1xuICBpZiAob3B0aW9ucy5wYXJlbnRTcGFuSXNBbHdheXNSb290U3Bhbikge1xuICAgIHJldHVybiBzcGFuVXRpbHMuZ2V0Um9vdFNwYW4oc3BhbikgO1xuICB9XG5cbiAgcmV0dXJuIHNwYW47XG59XG5cbmZ1bmN0aW9uIGdldEFjdGl2ZVNwYW5XcmFwcGVyKHBhcmVudFNwYW4pIHtcbiAgcmV0dXJuIHBhcmVudFNwYW4gIT09IHVuZGVmaW5lZFxuICAgID8gKGNhbGxiYWNrKSA9PiB7XG4gICAgICAgIHJldHVybiB3aXRoQWN0aXZlU3BhbihwYXJlbnRTcGFuLCBjYWxsYmFjayk7XG4gICAgICB9XG4gICAgOiAoY2FsbGJhY2spID0+IGNhbGxiYWNrKCk7XG59XG5cbmV4cG9ydHMuY29udGludWVUcmFjZSA9IGNvbnRpbnVlVHJhY2U7XG5leHBvcnRzLnN0YXJ0SW5hY3RpdmVTcGFuID0gc3RhcnRJbmFjdGl2ZVNwYW47XG5leHBvcnRzLnN0YXJ0TmV3VHJhY2UgPSBzdGFydE5ld1RyYWNlO1xuZXhwb3J0cy5zdGFydFNwYW4gPSBzdGFydFNwYW47XG5leHBvcnRzLnN0YXJ0U3Bhbk1hbnVhbCA9IHN0YXJ0U3Bhbk1hbnVhbDtcbmV4cG9ydHMuc3VwcHJlc3NUcmFjaW5nID0gc3VwcHJlc3NUcmFjaW5nO1xuZXhwb3J0cy53aXRoQWN0aXZlU3BhbiA9IHdpdGhBY3RpdmVTcGFuO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9dHJhY2UuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/trace.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/utils.js":
/*!*****************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/utils.js ***!
  \*****************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst object = __webpack_require__(/*! ../utils/object.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/object.js\");\n\nconst SCOPE_ON_START_SPAN_FIELD = '_sentryScope';\nconst ISOLATION_SCOPE_ON_START_SPAN_FIELD = '_sentryIsolationScope';\n\n/** Store the scope & isolation scope for a span, which can the be used when it is finished. */\nfunction setCapturedScopesOnSpan(span, scope, isolationScope) {\n  if (span) {\n    object.addNonEnumerableProperty(span, ISOLATION_SCOPE_ON_START_SPAN_FIELD, isolationScope);\n    object.addNonEnumerableProperty(span, SCOPE_ON_START_SPAN_FIELD, scope);\n  }\n}\n\n/**\n * Grabs the scope and isolation scope off a span that were active when the span was started.\n */\nfunction getCapturedScopesOnSpan(span) {\n  return {\n    scope: (span )[SCOPE_ON_START_SPAN_FIELD],\n    isolationScope: (span )[ISOLATION_SCOPE_ON_START_SPAN_FIELD],\n  };\n}\n\nexports.getCapturedScopesOnSpan = getCapturedScopesOnSpan;\nexports.setCapturedScopesOnSpan = setCapturedScopesOnSpan;\n//# sourceMappingURL=utils.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy90cmFjaW5nL3V0aWxzLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLGVBQWUsbUJBQU8sQ0FBQyw4SEFBb0I7O0FBRTNDO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLCtCQUErQjtBQUMvQiwrQkFBK0I7QUFDL0IiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy90cmFjaW5nL3V0aWxzLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBvYmplY3QgPSByZXF1aXJlKCcuLi91dGlscy9vYmplY3QuanMnKTtcblxuY29uc3QgU0NPUEVfT05fU1RBUlRfU1BBTl9GSUVMRCA9ICdfc2VudHJ5U2NvcGUnO1xuY29uc3QgSVNPTEFUSU9OX1NDT1BFX09OX1NUQVJUX1NQQU5fRklFTEQgPSAnX3NlbnRyeUlzb2xhdGlvblNjb3BlJztcblxuLyoqIFN0b3JlIHRoZSBzY29wZSAmIGlzb2xhdGlvbiBzY29wZSBmb3IgYSBzcGFuLCB3aGljaCBjYW4gdGhlIGJlIHVzZWQgd2hlbiBpdCBpcyBmaW5pc2hlZC4gKi9cbmZ1bmN0aW9uIHNldENhcHR1cmVkU2NvcGVzT25TcGFuKHNwYW4sIHNjb3BlLCBpc29sYXRpb25TY29wZSkge1xuICBpZiAoc3Bhbikge1xuICAgIG9iamVjdC5hZGROb25FbnVtZXJhYmxlUHJvcGVydHkoc3BhbiwgSVNPTEFUSU9OX1NDT1BFX09OX1NUQVJUX1NQQU5fRklFTEQsIGlzb2xhdGlvblNjb3BlKTtcbiAgICBvYmplY3QuYWRkTm9uRW51bWVyYWJsZVByb3BlcnR5KHNwYW4sIFNDT1BFX09OX1NUQVJUX1NQQU5fRklFTEQsIHNjb3BlKTtcbiAgfVxufVxuXG4vKipcbiAqIEdyYWJzIHRoZSBzY29wZSBhbmQgaXNvbGF0aW9uIHNjb3BlIG9mZiBhIHNwYW4gdGhhdCB3ZXJlIGFjdGl2ZSB3aGVuIHRoZSBzcGFuIHdhcyBzdGFydGVkLlxuICovXG5mdW5jdGlvbiBnZXRDYXB0dXJlZFNjb3Blc09uU3BhbihzcGFuKSB7XG4gIHJldHVybiB7XG4gICAgc2NvcGU6IChzcGFuIClbU0NPUEVfT05fU1RBUlRfU1BBTl9GSUVMRF0sXG4gICAgaXNvbGF0aW9uU2NvcGU6IChzcGFuIClbSVNPTEFUSU9OX1NDT1BFX09OX1NUQVJUX1NQQU5fRklFTERdLFxuICB9O1xufVxuXG5leHBvcnRzLmdldENhcHR1cmVkU2NvcGVzT25TcGFuID0gZ2V0Q2FwdHVyZWRTY29wZXNPblNwYW47XG5leHBvcnRzLnNldENhcHR1cmVkU2NvcGVzT25TcGFuID0gc2V0Q2FwdHVyZWRTY29wZXNPblNwYW47XG4vLyMgc291cmNlTWFwcGluZ1VSTD11dGlscy5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/utils.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/transports/base.js":
/*!*******************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/transports/base.js ***!
  \*******************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst debugBuild = __webpack_require__(/*! ../debug-build.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst debugLogger = __webpack_require__(/*! ../utils/debug-logger.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst envelope = __webpack_require__(/*! ../utils/envelope.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/envelope.js\");\nconst promisebuffer = __webpack_require__(/*! ../utils/promisebuffer.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/promisebuffer.js\");\nconst ratelimit = __webpack_require__(/*! ../utils/ratelimit.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/ratelimit.js\");\nconst syncpromise = __webpack_require__(/*! ../utils/syncpromise.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/syncpromise.js\");\n\nconst DEFAULT_TRANSPORT_BUFFER_SIZE = 64;\n\n/**\n * Creates an instance of a Sentry `Transport`\n *\n * @param options\n * @param makeRequest\n */\nfunction createTransport(\n  options,\n  makeRequest,\n  buffer = promisebuffer.makePromiseBuffer(\n    options.bufferSize || DEFAULT_TRANSPORT_BUFFER_SIZE,\n  ),\n) {\n  let rateLimits = {};\n  const flush = (timeout) => buffer.drain(timeout);\n\n  function send(envelope$1) {\n    const filteredEnvelopeItems = [];\n\n    // Drop rate limited items from envelope\n    envelope.forEachEnvelopeItem(envelope$1, (item, type) => {\n      const dataCategory = envelope.envelopeItemTypeToDataCategory(type);\n      if (ratelimit.isRateLimited(rateLimits, dataCategory)) {\n        options.recordDroppedEvent('ratelimit_backoff', dataCategory);\n      } else {\n        filteredEnvelopeItems.push(item);\n      }\n    });\n\n    // Skip sending if envelope is empty after filtering out rate limited events\n    if (filteredEnvelopeItems.length === 0) {\n      return syncpromise.resolvedSyncPromise({});\n    }\n\n    const filteredEnvelope = envelope.createEnvelope(envelope$1[0], filteredEnvelopeItems );\n\n    // Creates client report for each item in an envelope\n    const recordEnvelopeLoss = (reason) => {\n      envelope.forEachEnvelopeItem(filteredEnvelope, (item, type) => {\n        options.recordDroppedEvent(reason, envelope.envelopeItemTypeToDataCategory(type));\n      });\n    };\n\n    const requestTask = () =>\n      makeRequest({ body: envelope.serializeEnvelope(filteredEnvelope) }).then(\n        response => {\n          // We don't want to throw on NOK responses, but we want to at least log them\n          if (response.statusCode !== undefined && (response.statusCode < 200 || response.statusCode >= 300)) {\n            debugBuild.DEBUG_BUILD && debugLogger.debug.warn(`Sentry responded with status code ${response.statusCode} to sent event.`);\n          }\n\n          rateLimits = ratelimit.updateRateLimits(rateLimits, response);\n          return response;\n        },\n        error => {\n          recordEnvelopeLoss('network_error');\n          debugBuild.DEBUG_BUILD && debugLogger.debug.error('Encountered error running transport request:', error);\n          throw error;\n        },\n      );\n\n    return buffer.add(requestTask).then(\n      result => result,\n      error => {\n        if (error === promisebuffer.SENTRY_BUFFER_FULL_ERROR) {\n          debugBuild.DEBUG_BUILD && debugLogger.debug.error('Skipped sending event because buffer is full.');\n          recordEnvelopeLoss('queue_overflow');\n          return syncpromise.resolvedSyncPromise({});\n        } else {\n          throw error;\n        }\n      },\n    );\n  }\n\n  return {\n    send,\n    flush,\n  };\n}\n\nexports.DEFAULT_TRANSPORT_BUFFER_SIZE = DEFAULT_TRANSPORT_BUFFER_SIZE;\nexports.createTransport = createTransport;\n//# sourceMappingURL=base.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy90cmFuc3BvcnRzL2Jhc2UuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsbUJBQW1CLG1CQUFPLENBQUMsNEhBQW1CO0FBQzlDLG9CQUFvQixtQkFBTyxDQUFDLDBJQUEwQjtBQUN0RCxpQkFBaUIsbUJBQU8sQ0FBQyxrSUFBc0I7QUFDL0Msc0JBQXNCLG1CQUFPLENBQUMsNElBQTJCO0FBQ3pELGtCQUFrQixtQkFBTyxDQUFDLG9JQUF1QjtBQUNqRCxvQkFBb0IsbUJBQU8sQ0FBQyx3SUFBeUI7O0FBRXJEOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxRQUFRO0FBQ1I7QUFDQTtBQUNBLEtBQUs7O0FBRUw7QUFDQTtBQUNBLCtDQUErQztBQUMvQzs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLE9BQU87QUFDUDs7QUFFQTtBQUNBLG9CQUFvQixvREFBb0Q7QUFDeEU7QUFDQTtBQUNBO0FBQ0Esa0dBQWtHLHFCQUFxQjtBQUN2SDs7QUFFQTtBQUNBO0FBQ0EsU0FBUztBQUNUO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsU0FBUztBQUNUOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLG1EQUFtRDtBQUNuRCxVQUFVO0FBQ1Y7QUFDQTtBQUNBLE9BQU87QUFDUDtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEscUNBQXFDO0FBQ3JDLHVCQUF1QjtBQUN2QiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3RyYW5zcG9ydHMvYmFzZS5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgZGVidWdCdWlsZCA9IHJlcXVpcmUoJy4uL2RlYnVnLWJ1aWxkLmpzJyk7XG5jb25zdCBkZWJ1Z0xvZ2dlciA9IHJlcXVpcmUoJy4uL3V0aWxzL2RlYnVnLWxvZ2dlci5qcycpO1xuY29uc3QgZW52ZWxvcGUgPSByZXF1aXJlKCcuLi91dGlscy9lbnZlbG9wZS5qcycpO1xuY29uc3QgcHJvbWlzZWJ1ZmZlciA9IHJlcXVpcmUoJy4uL3V0aWxzL3Byb21pc2VidWZmZXIuanMnKTtcbmNvbnN0IHJhdGVsaW1pdCA9IHJlcXVpcmUoJy4uL3V0aWxzL3JhdGVsaW1pdC5qcycpO1xuY29uc3Qgc3luY3Byb21pc2UgPSByZXF1aXJlKCcuLi91dGlscy9zeW5jcHJvbWlzZS5qcycpO1xuXG5jb25zdCBERUZBVUxUX1RSQU5TUE9SVF9CVUZGRVJfU0laRSA9IDY0O1xuXG4vKipcbiAqIENyZWF0ZXMgYW4gaW5zdGFuY2Ugb2YgYSBTZW50cnkgYFRyYW5zcG9ydGBcbiAqXG4gKiBAcGFyYW0gb3B0aW9uc1xuICogQHBhcmFtIG1ha2VSZXF1ZXN0XG4gKi9cbmZ1bmN0aW9uIGNyZWF0ZVRyYW5zcG9ydChcbiAgb3B0aW9ucyxcbiAgbWFrZVJlcXVlc3QsXG4gIGJ1ZmZlciA9IHByb21pc2VidWZmZXIubWFrZVByb21pc2VCdWZmZXIoXG4gICAgb3B0aW9ucy5idWZmZXJTaXplIHx8IERFRkFVTFRfVFJBTlNQT1JUX0JVRkZFUl9TSVpFLFxuICApLFxuKSB7XG4gIGxldCByYXRlTGltaXRzID0ge307XG4gIGNvbnN0IGZsdXNoID0gKHRpbWVvdXQpID0+IGJ1ZmZlci5kcmFpbih0aW1lb3V0KTtcblxuICBmdW5jdGlvbiBzZW5kKGVudmVsb3BlJDEpIHtcbiAgICBjb25zdCBmaWx0ZXJlZEVudmVsb3BlSXRlbXMgPSBbXTtcblxuICAgIC8vIERyb3AgcmF0ZSBsaW1pdGVkIGl0ZW1zIGZyb20gZW52ZWxvcGVcbiAgICBlbnZlbG9wZS5mb3JFYWNoRW52ZWxvcGVJdGVtKGVudmVsb3BlJDEsIChpdGVtLCB0eXBlKSA9PiB7XG4gICAgICBjb25zdCBkYXRhQ2F0ZWdvcnkgPSBlbnZlbG9wZS5lbnZlbG9wZUl0ZW1UeXBlVG9EYXRhQ2F0ZWdvcnkodHlwZSk7XG4gICAgICBpZiAocmF0ZWxpbWl0LmlzUmF0ZUxpbWl0ZWQocmF0ZUxpbWl0cywgZGF0YUNhdGVnb3J5KSkge1xuICAgICAgICBvcHRpb25zLnJlY29yZERyb3BwZWRFdmVudCgncmF0ZWxpbWl0X2JhY2tvZmYnLCBkYXRhQ2F0ZWdvcnkpO1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgZmlsdGVyZWRFbnZlbG9wZUl0ZW1zLnB1c2goaXRlbSk7XG4gICAgICB9XG4gICAgfSk7XG5cbiAgICAvLyBTa2lwIHNlbmRpbmcgaWYgZW52ZWxvcGUgaXMgZW1wdHkgYWZ0ZXIgZmlsdGVyaW5nIG91dCByYXRlIGxpbWl0ZWQgZXZlbnRzXG4gICAgaWYgKGZpbHRlcmVkRW52ZWxvcGVJdGVtcy5sZW5ndGggPT09IDApIHtcbiAgICAgIHJldHVybiBzeW5jcHJvbWlzZS5yZXNvbHZlZFN5bmNQcm9taXNlKHt9KTtcbiAgICB9XG5cbiAgICBjb25zdCBmaWx0ZXJlZEVudmVsb3BlID0gZW52ZWxvcGUuY3JlYXRlRW52ZWxvcGUoZW52ZWxvcGUkMVswXSwgZmlsdGVyZWRFbnZlbG9wZUl0ZW1zICk7XG5cbiAgICAvLyBDcmVhdGVzIGNsaWVudCByZXBvcnQgZm9yIGVhY2ggaXRlbSBpbiBhbiBlbnZlbG9wZVxuICAgIGNvbnN0IHJlY29yZEVudmVsb3BlTG9zcyA9IChyZWFzb24pID0+IHtcbiAgICAgIGVudmVsb3BlLmZvckVhY2hFbnZlbG9wZUl0ZW0oZmlsdGVyZWRFbnZlbG9wZSwgKGl0ZW0sIHR5cGUpID0+IHtcbiAgICAgICAgb3B0aW9ucy5yZWNvcmREcm9wcGVkRXZlbnQocmVhc29uLCBlbnZlbG9wZS5lbnZlbG9wZUl0ZW1UeXBlVG9EYXRhQ2F0ZWdvcnkodHlwZSkpO1xuICAgICAgfSk7XG4gICAgfTtcblxuICAgIGNvbnN0IHJlcXVlc3RUYXNrID0gKCkgPT5cbiAgICAgIG1ha2VSZXF1ZXN0KHsgYm9keTogZW52ZWxvcGUuc2VyaWFsaXplRW52ZWxvcGUoZmlsdGVyZWRFbnZlbG9wZSkgfSkudGhlbihcbiAgICAgICAgcmVzcG9uc2UgPT4ge1xuICAgICAgICAgIC8vIFdlIGRvbid0IHdhbnQgdG8gdGhyb3cgb24gTk9LIHJlc3BvbnNlcywgYnV0IHdlIHdhbnQgdG8gYXQgbGVhc3QgbG9nIHRoZW1cbiAgICAgICAgICBpZiAocmVzcG9uc2Uuc3RhdHVzQ29kZSAhPT0gdW5kZWZpbmVkICYmIChyZXNwb25zZS5zdGF0dXNDb2RlIDwgMjAwIHx8IHJlc3BvbnNlLnN0YXR1c0NvZGUgPj0gMzAwKSkge1xuICAgICAgICAgICAgZGVidWdCdWlsZC5ERUJVR19CVUlMRCAmJiBkZWJ1Z0xvZ2dlci5kZWJ1Zy53YXJuKGBTZW50cnkgcmVzcG9uZGVkIHdpdGggc3RhdHVzIGNvZGUgJHtyZXNwb25zZS5zdGF0dXNDb2RlfSB0byBzZW50IGV2ZW50LmApO1xuICAgICAgICAgIH1cblxuICAgICAgICAgIHJhdGVMaW1pdHMgPSByYXRlbGltaXQudXBkYXRlUmF0ZUxpbWl0cyhyYXRlTGltaXRzLCByZXNwb25zZSk7XG4gICAgICAgICAgcmV0dXJuIHJlc3BvbnNlO1xuICAgICAgICB9LFxuICAgICAgICBlcnJvciA9PiB7XG4gICAgICAgICAgcmVjb3JkRW52ZWxvcGVMb3NzKCduZXR3b3JrX2Vycm9yJyk7XG4gICAgICAgICAgZGVidWdCdWlsZC5ERUJVR19CVUlMRCAmJiBkZWJ1Z0xvZ2dlci5kZWJ1Zy5lcnJvcignRW5jb3VudGVyZWQgZXJyb3IgcnVubmluZyB0cmFuc3BvcnQgcmVxdWVzdDonLCBlcnJvcik7XG4gICAgICAgICAgdGhyb3cgZXJyb3I7XG4gICAgICAgIH0sXG4gICAgICApO1xuXG4gICAgcmV0dXJuIGJ1ZmZlci5hZGQocmVxdWVzdFRhc2spLnRoZW4oXG4gICAgICByZXN1bHQgPT4gcmVzdWx0LFxuICAgICAgZXJyb3IgPT4ge1xuICAgICAgICBpZiAoZXJyb3IgPT09IHByb21pc2VidWZmZXIuU0VOVFJZX0JVRkZFUl9GVUxMX0VSUk9SKSB7XG4gICAgICAgICAgZGVidWdCdWlsZC5ERUJVR19CVUlMRCAmJiBkZWJ1Z0xvZ2dlci5kZWJ1Zy5lcnJvcignU2tpcHBlZCBzZW5kaW5nIGV2ZW50IGJlY2F1c2UgYnVmZmVyIGlzIGZ1bGwuJyk7XG4gICAgICAgICAgcmVjb3JkRW52ZWxvcGVMb3NzKCdxdWV1ZV9vdmVyZmxvdycpO1xuICAgICAgICAgIHJldHVybiBzeW5jcHJvbWlzZS5yZXNvbHZlZFN5bmNQcm9taXNlKHt9KTtcbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICB0aHJvdyBlcnJvcjtcbiAgICAgICAgfVxuICAgICAgfSxcbiAgICApO1xuICB9XG5cbiAgcmV0dXJuIHtcbiAgICBzZW5kLFxuICAgIGZsdXNoLFxuICB9O1xufVxuXG5leHBvcnRzLkRFRkFVTFRfVFJBTlNQT1JUX0JVRkZFUl9TSVpFID0gREVGQVVMVF9UUkFOU1BPUlRfQlVGRkVSX1NJWkU7XG5leHBvcnRzLmNyZWF0ZVRyYW5zcG9ydCA9IGNyZWF0ZVRyYW5zcG9ydDtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWJhc2UuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/transports/base.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/transports/multiplexed.js":
/*!**************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/transports/multiplexed.js ***!
  \**************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst api = __webpack_require__(/*! ../api.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/api.js\");\nconst dsn = __webpack_require__(/*! ../utils/dsn.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/dsn.js\");\nconst envelope = __webpack_require__(/*! ../utils/envelope.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/envelope.js\");\n\n/**\n * Gets an event from an envelope.\n *\n * This is only exported for use in the tests\n */\nfunction eventFromEnvelope(env, types) {\n  let event;\n\n  envelope.forEachEnvelopeItem(env, (item, type) => {\n    if (types.includes(type)) {\n      event = Array.isArray(item) ? (item )[1] : undefined;\n    }\n    // bail out if we found an event\n    return !!event;\n  });\n\n  return event;\n}\n\n/**\n * Creates a transport that overrides the release on all events.\n */\nfunction makeOverrideReleaseTransport(\n  createTransport,\n  release,\n) {\n  return options => {\n    const transport = createTransport(options);\n\n    return {\n      ...transport,\n      send: async (envelope) => {\n        const event = eventFromEnvelope(envelope, ['event', 'transaction', 'profile', 'replay_event']);\n\n        if (event) {\n          event.release = release;\n        }\n        return transport.send(envelope);\n      },\n    };\n  };\n}\n\n/** Overrides the DSN in the envelope header  */\nfunction overrideDsn(envelope$1, dsn) {\n  return envelope.createEnvelope(\n    dsn\n      ? {\n          ...envelope$1[0],\n          dsn,\n        }\n      : envelope$1[0],\n    envelope$1[1],\n  );\n}\n\n/**\n * Creates a transport that can send events to different DSNs depending on the envelope contents.\n */\nfunction makeMultiplexedTransport(\n  createTransport,\n  matcher,\n) {\n  return options => {\n    const fallbackTransport = createTransport(options);\n    const otherTransports = new Map();\n\n    function getTransport(dsn$1, release) {\n      // We create a transport for every unique dsn/release combination as there may be code from multiple releases in\n      // use at the same time\n      const key = release ? `${dsn$1}:${release}` : dsn$1;\n\n      let transport = otherTransports.get(key);\n\n      if (!transport) {\n        const validatedDsn = dsn.dsnFromString(dsn$1);\n        if (!validatedDsn) {\n          return undefined;\n        }\n        const url = api.getEnvelopeEndpointWithUrlEncodedAuth(validatedDsn, options.tunnel);\n\n        transport = release\n          ? makeOverrideReleaseTransport(createTransport, release)({ ...options, url })\n          : createTransport({ ...options, url });\n\n        otherTransports.set(key, transport);\n      }\n\n      return [dsn$1, transport];\n    }\n\n    async function send(envelope) {\n      function getEvent(types) {\n        const eventTypes = types?.length ? types : ['event'];\n        return eventFromEnvelope(envelope, eventTypes);\n      }\n\n      const transports = matcher({ envelope, getEvent })\n        .map(result => {\n          if (typeof result === 'string') {\n            return getTransport(result, undefined);\n          } else {\n            return getTransport(result.dsn, result.release);\n          }\n        })\n        .filter((t) => !!t);\n\n      // If we have no transports to send to, use the fallback transport\n      // Don't override the DSN in the header for the fallback transport. '' is falsy\n      const transportsWithFallback = transports.length ? transports : [['', fallbackTransport]];\n\n      const results = (await Promise.all(\n        transportsWithFallback.map(([dsn, transport]) => transport.send(overrideDsn(envelope, dsn))),\n      )) ;\n\n      return results[0];\n    }\n\n    async function flush(timeout) {\n      const allTransports = [...otherTransports.values(), fallbackTransport];\n      const results = await Promise.all(allTransports.map(transport => transport.flush(timeout)));\n      return results.every(r => r);\n    }\n\n    return {\n      send,\n      flush,\n    };\n  };\n}\n\nexports.eventFromEnvelope = eventFromEnvelope;\nexports.makeMultiplexedTransport = makeMultiplexedTransport;\n//# sourceMappingURL=multiplexed.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy90cmFuc3BvcnRzL211bHRpcGxleGVkLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLFlBQVksbUJBQU8sQ0FBQyw0R0FBVztBQUMvQixZQUFZLG1CQUFPLENBQUMsd0hBQWlCO0FBQ3JDLGlCQUFpQixtQkFBTyxDQUFDLGtJQUFzQjs7QUFFL0M7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsR0FBRzs7QUFFSDtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLE9BQU87QUFDUDtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBLCtCQUErQixNQUFNLEdBQUcsUUFBUTs7QUFFaEQ7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0EscUVBQXFFLGlCQUFpQjtBQUN0Riw4QkFBOEIsaUJBQWlCOztBQUUvQztBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSxtQ0FBbUMsb0JBQW9CO0FBQ3ZEO0FBQ0E7QUFDQTtBQUNBLFlBQVk7QUFDWjtBQUNBO0FBQ0EsU0FBUztBQUNUOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSx5QkFBeUI7QUFDekIsZ0NBQWdDO0FBQ2hDIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdHJhbnNwb3J0cy9tdWx0aXBsZXhlZC5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgYXBpID0gcmVxdWlyZSgnLi4vYXBpLmpzJyk7XG5jb25zdCBkc24gPSByZXF1aXJlKCcuLi91dGlscy9kc24uanMnKTtcbmNvbnN0IGVudmVsb3BlID0gcmVxdWlyZSgnLi4vdXRpbHMvZW52ZWxvcGUuanMnKTtcblxuLyoqXG4gKiBHZXRzIGFuIGV2ZW50IGZyb20gYW4gZW52ZWxvcGUuXG4gKlxuICogVGhpcyBpcyBvbmx5IGV4cG9ydGVkIGZvciB1c2UgaW4gdGhlIHRlc3RzXG4gKi9cbmZ1bmN0aW9uIGV2ZW50RnJvbUVudmVsb3BlKGVudiwgdHlwZXMpIHtcbiAgbGV0IGV2ZW50O1xuXG4gIGVudmVsb3BlLmZvckVhY2hFbnZlbG9wZUl0ZW0oZW52LCAoaXRlbSwgdHlwZSkgPT4ge1xuICAgIGlmICh0eXBlcy5pbmNsdWRlcyh0eXBlKSkge1xuICAgICAgZXZlbnQgPSBBcnJheS5pc0FycmF5KGl0ZW0pID8gKGl0ZW0gKVsxXSA6IHVuZGVmaW5lZDtcbiAgICB9XG4gICAgLy8gYmFpbCBvdXQgaWYgd2UgZm91bmQgYW4gZXZlbnRcbiAgICByZXR1cm4gISFldmVudDtcbiAgfSk7XG5cbiAgcmV0dXJuIGV2ZW50O1xufVxuXG4vKipcbiAqIENyZWF0ZXMgYSB0cmFuc3BvcnQgdGhhdCBvdmVycmlkZXMgdGhlIHJlbGVhc2Ugb24gYWxsIGV2ZW50cy5cbiAqL1xuZnVuY3Rpb24gbWFrZU92ZXJyaWRlUmVsZWFzZVRyYW5zcG9ydChcbiAgY3JlYXRlVHJhbnNwb3J0LFxuICByZWxlYXNlLFxuKSB7XG4gIHJldHVybiBvcHRpb25zID0+IHtcbiAgICBjb25zdCB0cmFuc3BvcnQgPSBjcmVhdGVUcmFuc3BvcnQob3B0aW9ucyk7XG5cbiAgICByZXR1cm4ge1xuICAgICAgLi4udHJhbnNwb3J0LFxuICAgICAgc2VuZDogYXN5bmMgKGVudmVsb3BlKSA9PiB7XG4gICAgICAgIGNvbnN0IGV2ZW50ID0gZXZlbnRGcm9tRW52ZWxvcGUoZW52ZWxvcGUsIFsnZXZlbnQnLCAndHJhbnNhY3Rpb24nLCAncHJvZmlsZScsICdyZXBsYXlfZXZlbnQnXSk7XG5cbiAgICAgICAgaWYgKGV2ZW50KSB7XG4gICAgICAgICAgZXZlbnQucmVsZWFzZSA9IHJlbGVhc2U7XG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuIHRyYW5zcG9ydC5zZW5kKGVudmVsb3BlKTtcbiAgICAgIH0sXG4gICAgfTtcbiAgfTtcbn1cblxuLyoqIE92ZXJyaWRlcyB0aGUgRFNOIGluIHRoZSBlbnZlbG9wZSBoZWFkZXIgICovXG5mdW5jdGlvbiBvdmVycmlkZURzbihlbnZlbG9wZSQxLCBkc24pIHtcbiAgcmV0dXJuIGVudmVsb3BlLmNyZWF0ZUVudmVsb3BlKFxuICAgIGRzblxuICAgICAgPyB7XG4gICAgICAgICAgLi4uZW52ZWxvcGUkMVswXSxcbiAgICAgICAgICBkc24sXG4gICAgICAgIH1cbiAgICAgIDogZW52ZWxvcGUkMVswXSxcbiAgICBlbnZlbG9wZSQxWzFdLFxuICApO1xufVxuXG4vKipcbiAqIENyZWF0ZXMgYSB0cmFuc3BvcnQgdGhhdCBjYW4gc2VuZCBldmVudHMgdG8gZGlmZmVyZW50IERTTnMgZGVwZW5kaW5nIG9uIHRoZSBlbnZlbG9wZSBjb250ZW50cy5cbiAqL1xuZnVuY3Rpb24gbWFrZU11bHRpcGxleGVkVHJhbnNwb3J0KFxuICBjcmVhdGVUcmFuc3BvcnQsXG4gIG1hdGNoZXIsXG4pIHtcbiAgcmV0dXJuIG9wdGlvbnMgPT4ge1xuICAgIGNvbnN0IGZhbGxiYWNrVHJhbnNwb3J0ID0gY3JlYXRlVHJhbnNwb3J0KG9wdGlvbnMpO1xuICAgIGNvbnN0IG90aGVyVHJhbnNwb3J0cyA9IG5ldyBNYXAoKTtcblxuICAgIGZ1bmN0aW9uIGdldFRyYW5zcG9ydChkc24kMSwgcmVsZWFzZSkge1xuICAgICAgLy8gV2UgY3JlYXRlIGEgdHJhbnNwb3J0IGZvciBldmVyeSB1bmlxdWUgZHNuL3JlbGVhc2UgY29tYmluYXRpb24gYXMgdGhlcmUgbWF5IGJlIGNvZGUgZnJvbSBtdWx0aXBsZSByZWxlYXNlcyBpblxuICAgICAgLy8gdXNlIGF0IHRoZSBzYW1lIHRpbWVcbiAgICAgIGNvbnN0IGtleSA9IHJlbGVhc2UgPyBgJHtkc24kMX06JHtyZWxlYXNlfWAgOiBkc24kMTtcblxuICAgICAgbGV0IHRyYW5zcG9ydCA9IG90aGVyVHJhbnNwb3J0cy5nZXQoa2V5KTtcblxuICAgICAgaWYgKCF0cmFuc3BvcnQpIHtcbiAgICAgICAgY29uc3QgdmFsaWRhdGVkRHNuID0gZHNuLmRzbkZyb21TdHJpbmcoZHNuJDEpO1xuICAgICAgICBpZiAoIXZhbGlkYXRlZERzbikge1xuICAgICAgICAgIHJldHVybiB1bmRlZmluZWQ7XG4gICAgICAgIH1cbiAgICAgICAgY29uc3QgdXJsID0gYXBpLmdldEVudmVsb3BlRW5kcG9pbnRXaXRoVXJsRW5jb2RlZEF1dGgodmFsaWRhdGVkRHNuLCBvcHRpb25zLnR1bm5lbCk7XG5cbiAgICAgICAgdHJhbnNwb3J0ID0gcmVsZWFzZVxuICAgICAgICAgID8gbWFrZU92ZXJyaWRlUmVsZWFzZVRyYW5zcG9ydChjcmVhdGVUcmFuc3BvcnQsIHJlbGVhc2UpKHsgLi4ub3B0aW9ucywgdXJsIH0pXG4gICAgICAgICAgOiBjcmVhdGVUcmFuc3BvcnQoeyAuLi5vcHRpb25zLCB1cmwgfSk7XG5cbiAgICAgICAgb3RoZXJUcmFuc3BvcnRzLnNldChrZXksIHRyYW5zcG9ydCk7XG4gICAgICB9XG5cbiAgICAgIHJldHVybiBbZHNuJDEsIHRyYW5zcG9ydF07XG4gICAgfVxuXG4gICAgYXN5bmMgZnVuY3Rpb24gc2VuZChlbnZlbG9wZSkge1xuICAgICAgZnVuY3Rpb24gZ2V0RXZlbnQodHlwZXMpIHtcbiAgICAgICAgY29uc3QgZXZlbnRUeXBlcyA9IHR5cGVzPy5sZW5ndGggPyB0eXBlcyA6IFsnZXZlbnQnXTtcbiAgICAgICAgcmV0dXJuIGV2ZW50RnJvbUVudmVsb3BlKGVudmVsb3BlLCBldmVudFR5cGVzKTtcbiAgICAgIH1cblxuICAgICAgY29uc3QgdHJhbnNwb3J0cyA9IG1hdGNoZXIoeyBlbnZlbG9wZSwgZ2V0RXZlbnQgfSlcbiAgICAgICAgLm1hcChyZXN1bHQgPT4ge1xuICAgICAgICAgIGlmICh0eXBlb2YgcmVzdWx0ID09PSAnc3RyaW5nJykge1xuICAgICAgICAgICAgcmV0dXJuIGdldFRyYW5zcG9ydChyZXN1bHQsIHVuZGVmaW5lZCk7XG4gICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgIHJldHVybiBnZXRUcmFuc3BvcnQocmVzdWx0LmRzbiwgcmVzdWx0LnJlbGVhc2UpO1xuICAgICAgICAgIH1cbiAgICAgICAgfSlcbiAgICAgICAgLmZpbHRlcigodCkgPT4gISF0KTtcblxuICAgICAgLy8gSWYgd2UgaGF2ZSBubyB0cmFuc3BvcnRzIHRvIHNlbmQgdG8sIHVzZSB0aGUgZmFsbGJhY2sgdHJhbnNwb3J0XG4gICAgICAvLyBEb24ndCBvdmVycmlkZSB0aGUgRFNOIGluIHRoZSBoZWFkZXIgZm9yIHRoZSBmYWxsYmFjayB0cmFuc3BvcnQuICcnIGlzIGZhbHN5XG4gICAgICBjb25zdCB0cmFuc3BvcnRzV2l0aEZhbGxiYWNrID0gdHJhbnNwb3J0cy5sZW5ndGggPyB0cmFuc3BvcnRzIDogW1snJywgZmFsbGJhY2tUcmFuc3BvcnRdXTtcblxuICAgICAgY29uc3QgcmVzdWx0cyA9IChhd2FpdCBQcm9taXNlLmFsbChcbiAgICAgICAgdHJhbnNwb3J0c1dpdGhGYWxsYmFjay5tYXAoKFtkc24sIHRyYW5zcG9ydF0pID0+IHRyYW5zcG9ydC5zZW5kKG92ZXJyaWRlRHNuKGVudmVsb3BlLCBkc24pKSksXG4gICAgICApKSA7XG5cbiAgICAgIHJldHVybiByZXN1bHRzWzBdO1xuICAgIH1cblxuICAgIGFzeW5jIGZ1bmN0aW9uIGZsdXNoKHRpbWVvdXQpIHtcbiAgICAgIGNvbnN0IGFsbFRyYW5zcG9ydHMgPSBbLi4ub3RoZXJUcmFuc3BvcnRzLnZhbHVlcygpLCBmYWxsYmFja1RyYW5zcG9ydF07XG4gICAgICBjb25zdCByZXN1bHRzID0gYXdhaXQgUHJvbWlzZS5hbGwoYWxsVHJhbnNwb3J0cy5tYXAodHJhbnNwb3J0ID0+IHRyYW5zcG9ydC5mbHVzaCh0aW1lb3V0KSkpO1xuICAgICAgcmV0dXJuIHJlc3VsdHMuZXZlcnkociA9PiByKTtcbiAgICB9XG5cbiAgICByZXR1cm4ge1xuICAgICAgc2VuZCxcbiAgICAgIGZsdXNoLFxuICAgIH07XG4gIH07XG59XG5cbmV4cG9ydHMuZXZlbnRGcm9tRW52ZWxvcGUgPSBldmVudEZyb21FbnZlbG9wZTtcbmV4cG9ydHMubWFrZU11bHRpcGxleGVkVHJhbnNwb3J0ID0gbWFrZU11bHRpcGxleGVkVHJhbnNwb3J0O1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9bXVsdGlwbGV4ZWQuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/transports/multiplexed.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/transports/offline.js":
/*!**********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/transports/offline.js ***!
  \**********************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst debugBuild = __webpack_require__(/*! ../debug-build.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst debugLogger = __webpack_require__(/*! ../utils/debug-logger.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst envelope = __webpack_require__(/*! ../utils/envelope.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/envelope.js\");\nconst ratelimit = __webpack_require__(/*! ../utils/ratelimit.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/ratelimit.js\");\n\nconst MIN_DELAY = 100; // 100 ms\nconst START_DELAY = 5000; // 5 seconds\nconst MAX_DELAY = 3.6e6; // 1 hour\n\n/**\n * Wraps a transport and stores and retries events when they fail to send.\n *\n * @param createTransport The transport to wrap.\n */\nfunction makeOfflineTransport(\n  createTransport,\n) {\n  function log(...args) {\n    debugBuild.DEBUG_BUILD && debugLogger.debug.log('[Offline]:', ...args);\n  }\n\n  return options => {\n    const transport = createTransport(options);\n\n    if (!options.createStore) {\n      throw new Error('No `createStore` function was provided');\n    }\n\n    const store = options.createStore(options);\n\n    let retryDelay = START_DELAY;\n    let flushTimer;\n\n    function shouldQueue(env, error, retryDelay) {\n      // We want to drop client reports because they can be generated when we retry sending events while offline.\n      if (envelope.envelopeContainsItemType(env, ['client_report'])) {\n        return false;\n      }\n\n      if (options.shouldStore) {\n        return options.shouldStore(env, error, retryDelay);\n      }\n\n      return true;\n    }\n\n    function flushIn(delay) {\n      if (flushTimer) {\n        clearTimeout(flushTimer );\n      }\n\n      flushTimer = setTimeout(async () => {\n        flushTimer = undefined;\n\n        const found = await store.shift();\n        if (found) {\n          log('Attempting to send previously queued event');\n\n          // We should to update the sent_at timestamp to the current time.\n          found[0].sent_at = new Date().toISOString();\n\n          void send(found, true).catch(e => {\n            log('Failed to retry sending', e);\n          });\n        }\n      }, delay) ;\n\n      // We need to unref the timer in node.js, otherwise the node process never exit.\n      if (typeof flushTimer !== 'number' && flushTimer.unref) {\n        flushTimer.unref();\n      }\n    }\n\n    function flushWithBackOff() {\n      if (flushTimer) {\n        return;\n      }\n\n      flushIn(retryDelay);\n\n      retryDelay = Math.min(retryDelay * 2, MAX_DELAY);\n    }\n\n    async function send(envelope$1, isRetry = false) {\n      // We queue all replay envelopes to avoid multiple replay envelopes being sent at the same time. If one fails, we\n      // need to retry them in order.\n      if (!isRetry && envelope.envelopeContainsItemType(envelope$1, ['replay_event', 'replay_recording'])) {\n        await store.push(envelope$1);\n        flushIn(MIN_DELAY);\n        return {};\n      }\n\n      try {\n        if (options.shouldSend && (await options.shouldSend(envelope$1)) === false) {\n          throw new Error('Envelope not sent because `shouldSend` callback returned false');\n        }\n\n        const result = await transport.send(envelope$1);\n\n        let delay = MIN_DELAY;\n\n        if (result) {\n          // If there's a retry-after header, use that as the next delay.\n          if (result.headers?.['retry-after']) {\n            delay = ratelimit.parseRetryAfterHeader(result.headers['retry-after']);\n          } else if (result.headers?.['x-sentry-rate-limits']) {\n            delay = 60000; // 60 seconds\n          } // If we have a server error, return now so we don't flush the queue.\n          else if ((result.statusCode || 0) >= 400) {\n            return result;\n          }\n        }\n\n        flushIn(delay);\n        retryDelay = START_DELAY;\n        return result;\n      } catch (e) {\n        if (await shouldQueue(envelope$1, e , retryDelay)) {\n          // If this envelope was a retry, we want to add it to the front of the queue so it's retried again first.\n          if (isRetry) {\n            await store.unshift(envelope$1);\n          } else {\n            await store.push(envelope$1);\n          }\n          flushWithBackOff();\n          log('Error sending. Event queued.', e );\n          return {};\n        } else {\n          throw e;\n        }\n      }\n    }\n\n    if (options.flushAtStartup) {\n      flushWithBackOff();\n    }\n\n    return {\n      send,\n      flush: timeout => {\n        // If there's no timeout, we should attempt to flush the offline queue.\n        if (timeout === undefined) {\n          retryDelay = START_DELAY;\n          flushIn(MIN_DELAY);\n        }\n\n        return transport.flush(timeout);\n      },\n    };\n  };\n}\n\nexports.MIN_DELAY = MIN_DELAY;\nexports.START_DELAY = START_DELAY;\nexports.makeOfflineTransport = makeOfflineTransport;\n//# sourceMappingURL=offline.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy90cmFuc3BvcnRzL29mZmxpbmUuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsbUJBQW1CLG1CQUFPLENBQUMsNEhBQW1CO0FBQzlDLG9CQUFvQixtQkFBTyxDQUFDLDBJQUEwQjtBQUN0RCxpQkFBaUIsbUJBQU8sQ0FBQyxrSUFBc0I7QUFDL0Msa0JBQWtCLG1CQUFPLENBQUMsb0lBQXVCOztBQUVqRCx1QkFBdUI7QUFDdkIsMEJBQTBCO0FBQzFCLHlCQUF5Qjs7QUFFekI7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsV0FBVztBQUNYO0FBQ0EsT0FBTzs7QUFFUDtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFlBQVk7QUFDWiwyQkFBMkI7QUFDM0IsWUFBWTtBQUNaO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBLFFBQVE7QUFDUjtBQUNBO0FBQ0E7QUFDQTtBQUNBLFlBQVk7QUFDWjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsVUFBVTtBQUNWO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0EsT0FBTztBQUNQO0FBQ0E7QUFDQTs7QUFFQSxpQkFBaUI7QUFDakIsbUJBQW1CO0FBQ25CLDRCQUE0QjtBQUM1QiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3RyYW5zcG9ydHMvb2ZmbGluZS5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgZGVidWdCdWlsZCA9IHJlcXVpcmUoJy4uL2RlYnVnLWJ1aWxkLmpzJyk7XG5jb25zdCBkZWJ1Z0xvZ2dlciA9IHJlcXVpcmUoJy4uL3V0aWxzL2RlYnVnLWxvZ2dlci5qcycpO1xuY29uc3QgZW52ZWxvcGUgPSByZXF1aXJlKCcuLi91dGlscy9lbnZlbG9wZS5qcycpO1xuY29uc3QgcmF0ZWxpbWl0ID0gcmVxdWlyZSgnLi4vdXRpbHMvcmF0ZWxpbWl0LmpzJyk7XG5cbmNvbnN0IE1JTl9ERUxBWSA9IDEwMDsgLy8gMTAwIG1zXG5jb25zdCBTVEFSVF9ERUxBWSA9IDUwMDA7IC8vIDUgc2Vjb25kc1xuY29uc3QgTUFYX0RFTEFZID0gMy42ZTY7IC8vIDEgaG91clxuXG4vKipcbiAqIFdyYXBzIGEgdHJhbnNwb3J0IGFuZCBzdG9yZXMgYW5kIHJldHJpZXMgZXZlbnRzIHdoZW4gdGhleSBmYWlsIHRvIHNlbmQuXG4gKlxuICogQHBhcmFtIGNyZWF0ZVRyYW5zcG9ydCBUaGUgdHJhbnNwb3J0IHRvIHdyYXAuXG4gKi9cbmZ1bmN0aW9uIG1ha2VPZmZsaW5lVHJhbnNwb3J0KFxuICBjcmVhdGVUcmFuc3BvcnQsXG4pIHtcbiAgZnVuY3Rpb24gbG9nKC4uLmFyZ3MpIHtcbiAgICBkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEICYmIGRlYnVnTG9nZ2VyLmRlYnVnLmxvZygnW09mZmxpbmVdOicsIC4uLmFyZ3MpO1xuICB9XG5cbiAgcmV0dXJuIG9wdGlvbnMgPT4ge1xuICAgIGNvbnN0IHRyYW5zcG9ydCA9IGNyZWF0ZVRyYW5zcG9ydChvcHRpb25zKTtcblxuICAgIGlmICghb3B0aW9ucy5jcmVhdGVTdG9yZSkge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKCdObyBgY3JlYXRlU3RvcmVgIGZ1bmN0aW9uIHdhcyBwcm92aWRlZCcpO1xuICAgIH1cblxuICAgIGNvbnN0IHN0b3JlID0gb3B0aW9ucy5jcmVhdGVTdG9yZShvcHRpb25zKTtcblxuICAgIGxldCByZXRyeURlbGF5ID0gU1RBUlRfREVMQVk7XG4gICAgbGV0IGZsdXNoVGltZXI7XG5cbiAgICBmdW5jdGlvbiBzaG91bGRRdWV1ZShlbnYsIGVycm9yLCByZXRyeURlbGF5KSB7XG4gICAgICAvLyBXZSB3YW50IHRvIGRyb3AgY2xpZW50IHJlcG9ydHMgYmVjYXVzZSB0aGV5IGNhbiBiZSBnZW5lcmF0ZWQgd2hlbiB3ZSByZXRyeSBzZW5kaW5nIGV2ZW50cyB3aGlsZSBvZmZsaW5lLlxuICAgICAgaWYgKGVudmVsb3BlLmVudmVsb3BlQ29udGFpbnNJdGVtVHlwZShlbnYsIFsnY2xpZW50X3JlcG9ydCddKSkge1xuICAgICAgICByZXR1cm4gZmFsc2U7XG4gICAgICB9XG5cbiAgICAgIGlmIChvcHRpb25zLnNob3VsZFN0b3JlKSB7XG4gICAgICAgIHJldHVybiBvcHRpb25zLnNob3VsZFN0b3JlKGVudiwgZXJyb3IsIHJldHJ5RGVsYXkpO1xuICAgICAgfVxuXG4gICAgICByZXR1cm4gdHJ1ZTtcbiAgICB9XG5cbiAgICBmdW5jdGlvbiBmbHVzaEluKGRlbGF5KSB7XG4gICAgICBpZiAoZmx1c2hUaW1lcikge1xuICAgICAgICBjbGVhclRpbWVvdXQoZmx1c2hUaW1lciApO1xuICAgICAgfVxuXG4gICAgICBmbHVzaFRpbWVyID0gc2V0VGltZW91dChhc3luYyAoKSA9PiB7XG4gICAgICAgIGZsdXNoVGltZXIgPSB1bmRlZmluZWQ7XG5cbiAgICAgICAgY29uc3QgZm91bmQgPSBhd2FpdCBzdG9yZS5zaGlmdCgpO1xuICAgICAgICBpZiAoZm91bmQpIHtcbiAgICAgICAgICBsb2coJ0F0dGVtcHRpbmcgdG8gc2VuZCBwcmV2aW91c2x5IHF1ZXVlZCBldmVudCcpO1xuXG4gICAgICAgICAgLy8gV2Ugc2hvdWxkIHRvIHVwZGF0ZSB0aGUgc2VudF9hdCB0aW1lc3RhbXAgdG8gdGhlIGN1cnJlbnQgdGltZS5cbiAgICAgICAgICBmb3VuZFswXS5zZW50X2F0ID0gbmV3IERhdGUoKS50b0lTT1N0cmluZygpO1xuXG4gICAgICAgICAgdm9pZCBzZW5kKGZvdW5kLCB0cnVlKS5jYXRjaChlID0+IHtcbiAgICAgICAgICAgIGxvZygnRmFpbGVkIHRvIHJldHJ5IHNlbmRpbmcnLCBlKTtcbiAgICAgICAgICB9KTtcbiAgICAgICAgfVxuICAgICAgfSwgZGVsYXkpIDtcblxuICAgICAgLy8gV2UgbmVlZCB0byB1bnJlZiB0aGUgdGltZXIgaW4gbm9kZS5qcywgb3RoZXJ3aXNlIHRoZSBub2RlIHByb2Nlc3MgbmV2ZXIgZXhpdC5cbiAgICAgIGlmICh0eXBlb2YgZmx1c2hUaW1lciAhPT0gJ251bWJlcicgJiYgZmx1c2hUaW1lci51bnJlZikge1xuICAgICAgICBmbHVzaFRpbWVyLnVucmVmKCk7XG4gICAgICB9XG4gICAgfVxuXG4gICAgZnVuY3Rpb24gZmx1c2hXaXRoQmFja09mZigpIHtcbiAgICAgIGlmIChmbHVzaFRpbWVyKSB7XG4gICAgICAgIHJldHVybjtcbiAgICAgIH1cblxuICAgICAgZmx1c2hJbihyZXRyeURlbGF5KTtcblxuICAgICAgcmV0cnlEZWxheSA9IE1hdGgubWluKHJldHJ5RGVsYXkgKiAyLCBNQVhfREVMQVkpO1xuICAgIH1cblxuICAgIGFzeW5jIGZ1bmN0aW9uIHNlbmQoZW52ZWxvcGUkMSwgaXNSZXRyeSA9IGZhbHNlKSB7XG4gICAgICAvLyBXZSBxdWV1ZSBhbGwgcmVwbGF5IGVudmVsb3BlcyB0byBhdm9pZCBtdWx0aXBsZSByZXBsYXkgZW52ZWxvcGVzIGJlaW5nIHNlbnQgYXQgdGhlIHNhbWUgdGltZS4gSWYgb25lIGZhaWxzLCB3ZVxuICAgICAgLy8gbmVlZCB0byByZXRyeSB0aGVtIGluIG9yZGVyLlxuICAgICAgaWYgKCFpc1JldHJ5ICYmIGVudmVsb3BlLmVudmVsb3BlQ29udGFpbnNJdGVtVHlwZShlbnZlbG9wZSQxLCBbJ3JlcGxheV9ldmVudCcsICdyZXBsYXlfcmVjb3JkaW5nJ10pKSB7XG4gICAgICAgIGF3YWl0IHN0b3JlLnB1c2goZW52ZWxvcGUkMSk7XG4gICAgICAgIGZsdXNoSW4oTUlOX0RFTEFZKTtcbiAgICAgICAgcmV0dXJuIHt9O1xuICAgICAgfVxuXG4gICAgICB0cnkge1xuICAgICAgICBpZiAob3B0aW9ucy5zaG91bGRTZW5kICYmIChhd2FpdCBvcHRpb25zLnNob3VsZFNlbmQoZW52ZWxvcGUkMSkpID09PSBmYWxzZSkge1xuICAgICAgICAgIHRocm93IG5ldyBFcnJvcignRW52ZWxvcGUgbm90IHNlbnQgYmVjYXVzZSBgc2hvdWxkU2VuZGAgY2FsbGJhY2sgcmV0dXJuZWQgZmFsc2UnKTtcbiAgICAgICAgfVxuXG4gICAgICAgIGNvbnN0IHJlc3VsdCA9IGF3YWl0IHRyYW5zcG9ydC5zZW5kKGVudmVsb3BlJDEpO1xuXG4gICAgICAgIGxldCBkZWxheSA9IE1JTl9ERUxBWTtcblxuICAgICAgICBpZiAocmVzdWx0KSB7XG4gICAgICAgICAgLy8gSWYgdGhlcmUncyBhIHJldHJ5LWFmdGVyIGhlYWRlciwgdXNlIHRoYXQgYXMgdGhlIG5leHQgZGVsYXkuXG4gICAgICAgICAgaWYgKHJlc3VsdC5oZWFkZXJzPy5bJ3JldHJ5LWFmdGVyJ10pIHtcbiAgICAgICAgICAgIGRlbGF5ID0gcmF0ZWxpbWl0LnBhcnNlUmV0cnlBZnRlckhlYWRlcihyZXN1bHQuaGVhZGVyc1sncmV0cnktYWZ0ZXInXSk7XG4gICAgICAgICAgfSBlbHNlIGlmIChyZXN1bHQuaGVhZGVycz8uWyd4LXNlbnRyeS1yYXRlLWxpbWl0cyddKSB7XG4gICAgICAgICAgICBkZWxheSA9IDYwMDAwOyAvLyA2MCBzZWNvbmRzXG4gICAgICAgICAgfSAvLyBJZiB3ZSBoYXZlIGEgc2VydmVyIGVycm9yLCByZXR1cm4gbm93IHNvIHdlIGRvbid0IGZsdXNoIHRoZSBxdWV1ZS5cbiAgICAgICAgICBlbHNlIGlmICgocmVzdWx0LnN0YXR1c0NvZGUgfHwgMCkgPj0gNDAwKSB7XG4gICAgICAgICAgICByZXR1cm4gcmVzdWx0O1xuICAgICAgICAgIH1cbiAgICAgICAgfVxuXG4gICAgICAgIGZsdXNoSW4oZGVsYXkpO1xuICAgICAgICByZXRyeURlbGF5ID0gU1RBUlRfREVMQVk7XG4gICAgICAgIHJldHVybiByZXN1bHQ7XG4gICAgICB9IGNhdGNoIChlKSB7XG4gICAgICAgIGlmIChhd2FpdCBzaG91bGRRdWV1ZShlbnZlbG9wZSQxLCBlICwgcmV0cnlEZWxheSkpIHtcbiAgICAgICAgICAvLyBJZiB0aGlzIGVudmVsb3BlIHdhcyBhIHJldHJ5LCB3ZSB3YW50IHRvIGFkZCBpdCB0byB0aGUgZnJvbnQgb2YgdGhlIHF1ZXVlIHNvIGl0J3MgcmV0cmllZCBhZ2FpbiBmaXJzdC5cbiAgICAgICAgICBpZiAoaXNSZXRyeSkge1xuICAgICAgICAgICAgYXdhaXQgc3RvcmUudW5zaGlmdChlbnZlbG9wZSQxKTtcbiAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgYXdhaXQgc3RvcmUucHVzaChlbnZlbG9wZSQxKTtcbiAgICAgICAgICB9XG4gICAgICAgICAgZmx1c2hXaXRoQmFja09mZigpO1xuICAgICAgICAgIGxvZygnRXJyb3Igc2VuZGluZy4gRXZlbnQgcXVldWVkLicsIGUgKTtcbiAgICAgICAgICByZXR1cm4ge307XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgdGhyb3cgZTtcbiAgICAgICAgfVxuICAgICAgfVxuICAgIH1cblxuICAgIGlmIChvcHRpb25zLmZsdXNoQXRTdGFydHVwKSB7XG4gICAgICBmbHVzaFdpdGhCYWNrT2ZmKCk7XG4gICAgfVxuXG4gICAgcmV0dXJuIHtcbiAgICAgIHNlbmQsXG4gICAgICBmbHVzaDogdGltZW91dCA9PiB7XG4gICAgICAgIC8vIElmIHRoZXJlJ3Mgbm8gdGltZW91dCwgd2Ugc2hvdWxkIGF0dGVtcHQgdG8gZmx1c2ggdGhlIG9mZmxpbmUgcXVldWUuXG4gICAgICAgIGlmICh0aW1lb3V0ID09PSB1bmRlZmluZWQpIHtcbiAgICAgICAgICByZXRyeURlbGF5ID0gU1RBUlRfREVMQVk7XG4gICAgICAgICAgZmx1c2hJbihNSU5fREVMQVkpO1xuICAgICAgICB9XG5cbiAgICAgICAgcmV0dXJuIHRyYW5zcG9ydC5mbHVzaCh0aW1lb3V0KTtcbiAgICAgIH0sXG4gICAgfTtcbiAgfTtcbn1cblxuZXhwb3J0cy5NSU5fREVMQVkgPSBNSU5fREVMQVk7XG5leHBvcnRzLlNUQVJUX0RFTEFZID0gU1RBUlRfREVMQVk7XG5leHBvcnRzLm1ha2VPZmZsaW5lVHJhbnNwb3J0ID0gbWFrZU9mZmxpbmVUcmFuc3BvcnQ7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1vZmZsaW5lLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/transports/offline.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/trpc.js":
/*!********************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/trpc.js ***!
  \********************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst currentScopes = __webpack_require__(/*! ./currentScopes.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst exports$1 = __webpack_require__(/*! ./exports.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/exports.js\");\nconst semanticAttributes = __webpack_require__(/*! ./semanticAttributes.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/semanticAttributes.js\");\nconst object = __webpack_require__(/*! ./utils/object.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/object.js\");\nconst normalize = __webpack_require__(/*! ./utils/normalize.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/normalize.js\");\nconst trace = __webpack_require__(/*! ./tracing/trace.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/trace.js\");\n\nconst trpcCaptureContext = { mechanism: { handled: false, data: { function: 'trpcMiddleware' } } };\n\nfunction captureIfError(nextResult) {\n  // TODO: Set span status based on what TRPCError was encountered\n  if (\n    typeof nextResult === 'object' &&\n    nextResult !== null &&\n    'ok' in nextResult &&\n    !nextResult.ok &&\n    'error' in nextResult\n  ) {\n    exports$1.captureException(nextResult.error, trpcCaptureContext);\n  }\n}\n\n/**\n * Sentry tRPC middleware that captures errors and creates spans for tRPC procedures.\n */\nfunction trpcMiddleware(options = {}) {\n  // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n  // @ts-ignore\n  return async function (opts) {\n    const { path, type, next, rawInput, getRawInput } = opts;\n\n    const client = currentScopes.getClient();\n    const clientOptions = client?.getOptions();\n\n    const trpcContext = {\n      procedure_path: path,\n      procedure_type: type,\n    };\n\n    object.addNonEnumerableProperty(\n      trpcContext,\n      '__sentry_override_normalization_depth__',\n      1 + // 1 for context.input + the normal normalization depth\n        (clientOptions?.normalizeDepth ?? 5), // 5 is a sane depth\n    );\n\n    if (options.attachRpcInput !== undefined ? options.attachRpcInput : clientOptions?.sendDefaultPii) {\n      if (rawInput !== undefined) {\n        trpcContext.input = normalize.normalize(rawInput);\n      }\n\n      if (getRawInput !== undefined && typeof getRawInput === 'function') {\n        try {\n          const rawRes = await getRawInput();\n\n          trpcContext.input = normalize.normalize(rawRes);\n        } catch {\n          // noop\n        }\n      }\n    }\n\n    return currentScopes.withIsolationScope(scope => {\n      scope.setContext('trpc', trpcContext);\n      return trace.startSpanManual(\n        {\n          name: `trpc/${path}`,\n          op: 'rpc.server',\n          attributes: {\n            [semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_SOURCE]: 'route',\n            [semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_ORIGIN]: 'auto.rpc.trpc',\n          },\n          forceTransaction: !!options.forceTransaction,\n        },\n        async span => {\n          try {\n            const nextResult = await next();\n            captureIfError(nextResult);\n            span.end();\n            return nextResult;\n          } catch (e) {\n            exports$1.captureException(e, trpcCaptureContext);\n            span.end();\n            throw e;\n          }\n        },\n      ) ;\n    });\n  };\n}\n\nexports.trpcMiddleware = trpcMiddleware;\n//# sourceMappingURL=trpc.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy90cnBjLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLHNCQUFzQixtQkFBTyxDQUFDLCtIQUFvQjtBQUNsRCxrQkFBa0IsbUJBQU8sQ0FBQyxtSEFBYztBQUN4QywyQkFBMkIsbUJBQU8sQ0FBQyx5SUFBeUI7QUFDNUQsZUFBZSxtQkFBTyxDQUFDLDZIQUFtQjtBQUMxQyxrQkFBa0IsbUJBQU8sQ0FBQyxtSUFBc0I7QUFDaEQsY0FBYyxtQkFBTyxDQUFDLCtIQUFvQjs7QUFFMUMsNkJBQTZCLGFBQWEsd0JBQXdCOztBQUVsRTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0Esb0NBQW9DO0FBQ3BDO0FBQ0E7QUFDQTtBQUNBLFlBQVksMENBQTBDOztBQUV0RDtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQSxVQUFVO0FBQ1Y7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQSx3QkFBd0IsS0FBSztBQUM3QjtBQUNBO0FBQ0E7QUFDQTtBQUNBLFdBQVc7QUFDWDtBQUNBLFNBQVM7QUFDVDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxZQUFZO0FBQ1o7QUFDQTtBQUNBO0FBQ0E7QUFDQSxTQUFTO0FBQ1Q7QUFDQSxLQUFLO0FBQ0w7QUFDQTs7QUFFQSxzQkFBc0I7QUFDdEIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy90cnBjLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBjdXJyZW50U2NvcGVzID0gcmVxdWlyZSgnLi9jdXJyZW50U2NvcGVzLmpzJyk7XG5jb25zdCBleHBvcnRzJDEgPSByZXF1aXJlKCcuL2V4cG9ydHMuanMnKTtcbmNvbnN0IHNlbWFudGljQXR0cmlidXRlcyA9IHJlcXVpcmUoJy4vc2VtYW50aWNBdHRyaWJ1dGVzLmpzJyk7XG5jb25zdCBvYmplY3QgPSByZXF1aXJlKCcuL3V0aWxzL29iamVjdC5qcycpO1xuY29uc3Qgbm9ybWFsaXplID0gcmVxdWlyZSgnLi91dGlscy9ub3JtYWxpemUuanMnKTtcbmNvbnN0IHRyYWNlID0gcmVxdWlyZSgnLi90cmFjaW5nL3RyYWNlLmpzJyk7XG5cbmNvbnN0IHRycGNDYXB0dXJlQ29udGV4dCA9IHsgbWVjaGFuaXNtOiB7IGhhbmRsZWQ6IGZhbHNlLCBkYXRhOiB7IGZ1bmN0aW9uOiAndHJwY01pZGRsZXdhcmUnIH0gfSB9O1xuXG5mdW5jdGlvbiBjYXB0dXJlSWZFcnJvcihuZXh0UmVzdWx0KSB7XG4gIC8vIFRPRE86IFNldCBzcGFuIHN0YXR1cyBiYXNlZCBvbiB3aGF0IFRSUENFcnJvciB3YXMgZW5jb3VudGVyZWRcbiAgaWYgKFxuICAgIHR5cGVvZiBuZXh0UmVzdWx0ID09PSAnb2JqZWN0JyAmJlxuICAgIG5leHRSZXN1bHQgIT09IG51bGwgJiZcbiAgICAnb2snIGluIG5leHRSZXN1bHQgJiZcbiAgICAhbmV4dFJlc3VsdC5vayAmJlxuICAgICdlcnJvcicgaW4gbmV4dFJlc3VsdFxuICApIHtcbiAgICBleHBvcnRzJDEuY2FwdHVyZUV4Y2VwdGlvbihuZXh0UmVzdWx0LmVycm9yLCB0cnBjQ2FwdHVyZUNvbnRleHQpO1xuICB9XG59XG5cbi8qKlxuICogU2VudHJ5IHRSUEMgbWlkZGxld2FyZSB0aGF0IGNhcHR1cmVzIGVycm9ycyBhbmQgY3JlYXRlcyBzcGFucyBmb3IgdFJQQyBwcm9jZWR1cmVzLlxuICovXG5mdW5jdGlvbiB0cnBjTWlkZGxld2FyZShvcHRpb25zID0ge30pIHtcbiAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9iYW4tdHMtY29tbWVudFxuICAvLyBAdHMtaWdub3JlXG4gIHJldHVybiBhc3luYyBmdW5jdGlvbiAob3B0cykge1xuICAgIGNvbnN0IHsgcGF0aCwgdHlwZSwgbmV4dCwgcmF3SW5wdXQsIGdldFJhd0lucHV0IH0gPSBvcHRzO1xuXG4gICAgY29uc3QgY2xpZW50ID0gY3VycmVudFNjb3Blcy5nZXRDbGllbnQoKTtcbiAgICBjb25zdCBjbGllbnRPcHRpb25zID0gY2xpZW50Py5nZXRPcHRpb25zKCk7XG5cbiAgICBjb25zdCB0cnBjQ29udGV4dCA9IHtcbiAgICAgIHByb2NlZHVyZV9wYXRoOiBwYXRoLFxuICAgICAgcHJvY2VkdXJlX3R5cGU6IHR5cGUsXG4gICAgfTtcblxuICAgIG9iamVjdC5hZGROb25FbnVtZXJhYmxlUHJvcGVydHkoXG4gICAgICB0cnBjQ29udGV4dCxcbiAgICAgICdfX3NlbnRyeV9vdmVycmlkZV9ub3JtYWxpemF0aW9uX2RlcHRoX18nLFxuICAgICAgMSArIC8vIDEgZm9yIGNvbnRleHQuaW5wdXQgKyB0aGUgbm9ybWFsIG5vcm1hbGl6YXRpb24gZGVwdGhcbiAgICAgICAgKGNsaWVudE9wdGlvbnM/Lm5vcm1hbGl6ZURlcHRoID8/IDUpLCAvLyA1IGlzIGEgc2FuZSBkZXB0aFxuICAgICk7XG5cbiAgICBpZiAob3B0aW9ucy5hdHRhY2hScGNJbnB1dCAhPT0gdW5kZWZpbmVkID8gb3B0aW9ucy5hdHRhY2hScGNJbnB1dCA6IGNsaWVudE9wdGlvbnM/LnNlbmREZWZhdWx0UGlpKSB7XG4gICAgICBpZiAocmF3SW5wdXQgIT09IHVuZGVmaW5lZCkge1xuICAgICAgICB0cnBjQ29udGV4dC5pbnB1dCA9IG5vcm1hbGl6ZS5ub3JtYWxpemUocmF3SW5wdXQpO1xuICAgICAgfVxuXG4gICAgICBpZiAoZ2V0UmF3SW5wdXQgIT09IHVuZGVmaW5lZCAmJiB0eXBlb2YgZ2V0UmF3SW5wdXQgPT09ICdmdW5jdGlvbicpIHtcbiAgICAgICAgdHJ5IHtcbiAgICAgICAgICBjb25zdCByYXdSZXMgPSBhd2FpdCBnZXRSYXdJbnB1dCgpO1xuXG4gICAgICAgICAgdHJwY0NvbnRleHQuaW5wdXQgPSBub3JtYWxpemUubm9ybWFsaXplKHJhd1Jlcyk7XG4gICAgICAgIH0gY2F0Y2gge1xuICAgICAgICAgIC8vIG5vb3BcbiAgICAgICAgfVxuICAgICAgfVxuICAgIH1cblxuICAgIHJldHVybiBjdXJyZW50U2NvcGVzLndpdGhJc29sYXRpb25TY29wZShzY29wZSA9PiB7XG4gICAgICBzY29wZS5zZXRDb250ZXh0KCd0cnBjJywgdHJwY0NvbnRleHQpO1xuICAgICAgcmV0dXJuIHRyYWNlLnN0YXJ0U3Bhbk1hbnVhbChcbiAgICAgICAge1xuICAgICAgICAgIG5hbWU6IGB0cnBjLyR7cGF0aH1gLFxuICAgICAgICAgIG9wOiAncnBjLnNlcnZlcicsXG4gICAgICAgICAgYXR0cmlidXRlczoge1xuICAgICAgICAgICAgW3NlbWFudGljQXR0cmlidXRlcy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX1NPVVJDRV06ICdyb3V0ZScsXG4gICAgICAgICAgICBbc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfT1JJR0lOXTogJ2F1dG8ucnBjLnRycGMnLFxuICAgICAgICAgIH0sXG4gICAgICAgICAgZm9yY2VUcmFuc2FjdGlvbjogISFvcHRpb25zLmZvcmNlVHJhbnNhY3Rpb24sXG4gICAgICAgIH0sXG4gICAgICAgIGFzeW5jIHNwYW4gPT4ge1xuICAgICAgICAgIHRyeSB7XG4gICAgICAgICAgICBjb25zdCBuZXh0UmVzdWx0ID0gYXdhaXQgbmV4dCgpO1xuICAgICAgICAgICAgY2FwdHVyZUlmRXJyb3IobmV4dFJlc3VsdCk7XG4gICAgICAgICAgICBzcGFuLmVuZCgpO1xuICAgICAgICAgICAgcmV0dXJuIG5leHRSZXN1bHQ7XG4gICAgICAgICAgfSBjYXRjaCAoZSkge1xuICAgICAgICAgICAgZXhwb3J0cyQxLmNhcHR1cmVFeGNlcHRpb24oZSwgdHJwY0NhcHR1cmVDb250ZXh0KTtcbiAgICAgICAgICAgIHNwYW4uZW5kKCk7XG4gICAgICAgICAgICB0aHJvdyBlO1xuICAgICAgICAgIH1cbiAgICAgICAgfSxcbiAgICAgICkgO1xuICAgIH0pO1xuICB9O1xufVxuXG5leHBvcnRzLnRycGNNaWRkbGV3YXJlID0gdHJwY01pZGRsZXdhcmU7XG4vLyMgc291cmNlTWFwcGluZ1VSTD10cnBjLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/trpc.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/aggregate-errors.js":
/*!**************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/aggregate-errors.js ***!
  \**************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst is = __webpack_require__(/*! ./is.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js\");\n\n/**\n * Creates exceptions inside `event.exception.values` for errors that are nested on properties based on the `key` parameter.\n */\nfunction applyAggregateErrorsToEvent(\n  exceptionFromErrorImplementation,\n  parser,\n  key,\n  limit,\n  event,\n  hint,\n) {\n  if (!event.exception?.values || !hint || !is.isInstanceOf(hint.originalException, Error)) {\n    return;\n  }\n\n  // Generally speaking the last item in `event.exception.values` is the exception originating from the original Error\n  const originalException =\n    event.exception.values.length > 0 ? event.exception.values[event.exception.values.length - 1] : undefined;\n\n  // We only create exception grouping if there is an exception in the event.\n  if (originalException) {\n    event.exception.values = aggregateExceptionsFromError(\n      exceptionFromErrorImplementation,\n      parser,\n      limit,\n      hint.originalException ,\n      key,\n      event.exception.values,\n      originalException,\n      0,\n    );\n  }\n}\n\nfunction aggregateExceptionsFromError(\n  exceptionFromErrorImplementation,\n  parser,\n  limit,\n  error,\n  key,\n  prevExceptions,\n  exception,\n  exceptionId,\n) {\n  if (prevExceptions.length >= limit + 1) {\n    return prevExceptions;\n  }\n\n  let newExceptions = [...prevExceptions];\n\n  // Recursively call this function in order to walk down a chain of errors\n  if (is.isInstanceOf(error[key], Error)) {\n    applyExceptionGroupFieldsForParentException(exception, exceptionId);\n    const newException = exceptionFromErrorImplementation(parser, error[key]);\n    const newExceptionId = newExceptions.length;\n    applyExceptionGroupFieldsForChildException(newException, key, newExceptionId, exceptionId);\n    newExceptions = aggregateExceptionsFromError(\n      exceptionFromErrorImplementation,\n      parser,\n      limit,\n      error[key],\n      key,\n      [newException, ...newExceptions],\n      newException,\n      newExceptionId,\n    );\n  }\n\n  // This will create exception grouping for AggregateErrors\n  // https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/AggregateError\n  if (Array.isArray(error.errors)) {\n    error.errors.forEach((childError, i) => {\n      if (is.isInstanceOf(childError, Error)) {\n        applyExceptionGroupFieldsForParentException(exception, exceptionId);\n        const newException = exceptionFromErrorImplementation(parser, childError);\n        const newExceptionId = newExceptions.length;\n        applyExceptionGroupFieldsForChildException(newException, `errors[${i}]`, newExceptionId, exceptionId);\n        newExceptions = aggregateExceptionsFromError(\n          exceptionFromErrorImplementation,\n          parser,\n          limit,\n          childError,\n          key,\n          [newException, ...newExceptions],\n          newException,\n          newExceptionId,\n        );\n      }\n    });\n  }\n\n  return newExceptions;\n}\n\nfunction applyExceptionGroupFieldsForParentException(exception, exceptionId) {\n  // Don't know if this default makes sense. The protocol requires us to set these values so we pick *some* default.\n  exception.mechanism = exception.mechanism || { type: 'generic', handled: true };\n\n  exception.mechanism = {\n    ...exception.mechanism,\n    ...(exception.type === 'AggregateError' && { is_exception_group: true }),\n    exception_id: exceptionId,\n  };\n}\n\nfunction applyExceptionGroupFieldsForChildException(\n  exception,\n  source,\n  exceptionId,\n  parentId,\n) {\n  // Don't know if this default makes sense. The protocol requires us to set these values so we pick *some* default.\n  exception.mechanism = exception.mechanism || { type: 'generic', handled: true };\n\n  exception.mechanism = {\n    ...exception.mechanism,\n    type: 'chained',\n    source,\n    exception_id: exceptionId,\n    parent_id: parentId,\n  };\n}\n\nexports.applyAggregateErrorsToEvent = applyAggregateErrorsToEvent;\n//# sourceMappingURL=aggregate-errors.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9hZ2dyZWdhdGUtZXJyb3JzLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLFdBQVcsbUJBQU8sQ0FBQywrR0FBUzs7QUFFNUI7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSwyRUFBMkUsRUFBRTtBQUM3RTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsS0FBSztBQUNMOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLGlEQUFpRDs7QUFFakQ7QUFDQTtBQUNBLGlEQUFpRCwwQkFBMEI7QUFDM0U7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsaURBQWlEOztBQUVqRDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLG1DQUFtQztBQUNuQyIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3V0aWxzL2FnZ3JlZ2F0ZS1lcnJvcnMuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGlzID0gcmVxdWlyZSgnLi9pcy5qcycpO1xuXG4vKipcbiAqIENyZWF0ZXMgZXhjZXB0aW9ucyBpbnNpZGUgYGV2ZW50LmV4Y2VwdGlvbi52YWx1ZXNgIGZvciBlcnJvcnMgdGhhdCBhcmUgbmVzdGVkIG9uIHByb3BlcnRpZXMgYmFzZWQgb24gdGhlIGBrZXlgIHBhcmFtZXRlci5cbiAqL1xuZnVuY3Rpb24gYXBwbHlBZ2dyZWdhdGVFcnJvcnNUb0V2ZW50KFxuICBleGNlcHRpb25Gcm9tRXJyb3JJbXBsZW1lbnRhdGlvbixcbiAgcGFyc2VyLFxuICBrZXksXG4gIGxpbWl0LFxuICBldmVudCxcbiAgaGludCxcbikge1xuICBpZiAoIWV2ZW50LmV4Y2VwdGlvbj8udmFsdWVzIHx8ICFoaW50IHx8ICFpcy5pc0luc3RhbmNlT2YoaGludC5vcmlnaW5hbEV4Y2VwdGlvbiwgRXJyb3IpKSB7XG4gICAgcmV0dXJuO1xuICB9XG5cbiAgLy8gR2VuZXJhbGx5IHNwZWFraW5nIHRoZSBsYXN0IGl0ZW0gaW4gYGV2ZW50LmV4Y2VwdGlvbi52YWx1ZXNgIGlzIHRoZSBleGNlcHRpb24gb3JpZ2luYXRpbmcgZnJvbSB0aGUgb3JpZ2luYWwgRXJyb3JcbiAgY29uc3Qgb3JpZ2luYWxFeGNlcHRpb24gPVxuICAgIGV2ZW50LmV4Y2VwdGlvbi52YWx1ZXMubGVuZ3RoID4gMCA/IGV2ZW50LmV4Y2VwdGlvbi52YWx1ZXNbZXZlbnQuZXhjZXB0aW9uLnZhbHVlcy5sZW5ndGggLSAxXSA6IHVuZGVmaW5lZDtcblxuICAvLyBXZSBvbmx5IGNyZWF0ZSBleGNlcHRpb24gZ3JvdXBpbmcgaWYgdGhlcmUgaXMgYW4gZXhjZXB0aW9uIGluIHRoZSBldmVudC5cbiAgaWYgKG9yaWdpbmFsRXhjZXB0aW9uKSB7XG4gICAgZXZlbnQuZXhjZXB0aW9uLnZhbHVlcyA9IGFnZ3JlZ2F0ZUV4Y2VwdGlvbnNGcm9tRXJyb3IoXG4gICAgICBleGNlcHRpb25Gcm9tRXJyb3JJbXBsZW1lbnRhdGlvbixcbiAgICAgIHBhcnNlcixcbiAgICAgIGxpbWl0LFxuICAgICAgaGludC5vcmlnaW5hbEV4Y2VwdGlvbiAsXG4gICAgICBrZXksXG4gICAgICBldmVudC5leGNlcHRpb24udmFsdWVzLFxuICAgICAgb3JpZ2luYWxFeGNlcHRpb24sXG4gICAgICAwLFxuICAgICk7XG4gIH1cbn1cblxuZnVuY3Rpb24gYWdncmVnYXRlRXhjZXB0aW9uc0Zyb21FcnJvcihcbiAgZXhjZXB0aW9uRnJvbUVycm9ySW1wbGVtZW50YXRpb24sXG4gIHBhcnNlcixcbiAgbGltaXQsXG4gIGVycm9yLFxuICBrZXksXG4gIHByZXZFeGNlcHRpb25zLFxuICBleGNlcHRpb24sXG4gIGV4Y2VwdGlvbklkLFxuKSB7XG4gIGlmIChwcmV2RXhjZXB0aW9ucy5sZW5ndGggPj0gbGltaXQgKyAxKSB7XG4gICAgcmV0dXJuIHByZXZFeGNlcHRpb25zO1xuICB9XG5cbiAgbGV0IG5ld0V4Y2VwdGlvbnMgPSBbLi4ucHJldkV4Y2VwdGlvbnNdO1xuXG4gIC8vIFJlY3Vyc2l2ZWx5IGNhbGwgdGhpcyBmdW5jdGlvbiBpbiBvcmRlciB0byB3YWxrIGRvd24gYSBjaGFpbiBvZiBlcnJvcnNcbiAgaWYgKGlzLmlzSW5zdGFuY2VPZihlcnJvcltrZXldLCBFcnJvcikpIHtcbiAgICBhcHBseUV4Y2VwdGlvbkdyb3VwRmllbGRzRm9yUGFyZW50RXhjZXB0aW9uKGV4Y2VwdGlvbiwgZXhjZXB0aW9uSWQpO1xuICAgIGNvbnN0IG5ld0V4Y2VwdGlvbiA9IGV4Y2VwdGlvbkZyb21FcnJvckltcGxlbWVudGF0aW9uKHBhcnNlciwgZXJyb3Jba2V5XSk7XG4gICAgY29uc3QgbmV3RXhjZXB0aW9uSWQgPSBuZXdFeGNlcHRpb25zLmxlbmd0aDtcbiAgICBhcHBseUV4Y2VwdGlvbkdyb3VwRmllbGRzRm9yQ2hpbGRFeGNlcHRpb24obmV3RXhjZXB0aW9uLCBrZXksIG5ld0V4Y2VwdGlvbklkLCBleGNlcHRpb25JZCk7XG4gICAgbmV3RXhjZXB0aW9ucyA9IGFnZ3JlZ2F0ZUV4Y2VwdGlvbnNGcm9tRXJyb3IoXG4gICAgICBleGNlcHRpb25Gcm9tRXJyb3JJbXBsZW1lbnRhdGlvbixcbiAgICAgIHBhcnNlcixcbiAgICAgIGxpbWl0LFxuICAgICAgZXJyb3Jba2V5XSxcbiAgICAgIGtleSxcbiAgICAgIFtuZXdFeGNlcHRpb24sIC4uLm5ld0V4Y2VwdGlvbnNdLFxuICAgICAgbmV3RXhjZXB0aW9uLFxuICAgICAgbmV3RXhjZXB0aW9uSWQsXG4gICAgKTtcbiAgfVxuXG4gIC8vIFRoaXMgd2lsbCBjcmVhdGUgZXhjZXB0aW9uIGdyb3VwaW5nIGZvciBBZ2dyZWdhdGVFcnJvcnNcbiAgLy8gaHR0cHM6Ly9kZXZlbG9wZXIubW96aWxsYS5vcmcvZW4tVVMvZG9jcy9XZWIvSmF2YVNjcmlwdC9SZWZlcmVuY2UvR2xvYmFsX09iamVjdHMvQWdncmVnYXRlRXJyb3JcbiAgaWYgKEFycmF5LmlzQXJyYXkoZXJyb3IuZXJyb3JzKSkge1xuICAgIGVycm9yLmVycm9ycy5mb3JFYWNoKChjaGlsZEVycm9yLCBpKSA9PiB7XG4gICAgICBpZiAoaXMuaXNJbnN0YW5jZU9mKGNoaWxkRXJyb3IsIEVycm9yKSkge1xuICAgICAgICBhcHBseUV4Y2VwdGlvbkdyb3VwRmllbGRzRm9yUGFyZW50RXhjZXB0aW9uKGV4Y2VwdGlvbiwgZXhjZXB0aW9uSWQpO1xuICAgICAgICBjb25zdCBuZXdFeGNlcHRpb24gPSBleGNlcHRpb25Gcm9tRXJyb3JJbXBsZW1lbnRhdGlvbihwYXJzZXIsIGNoaWxkRXJyb3IpO1xuICAgICAgICBjb25zdCBuZXdFeGNlcHRpb25JZCA9IG5ld0V4Y2VwdGlvbnMubGVuZ3RoO1xuICAgICAgICBhcHBseUV4Y2VwdGlvbkdyb3VwRmllbGRzRm9yQ2hpbGRFeGNlcHRpb24obmV3RXhjZXB0aW9uLCBgZXJyb3JzWyR7aX1dYCwgbmV3RXhjZXB0aW9uSWQsIGV4Y2VwdGlvbklkKTtcbiAgICAgICAgbmV3RXhjZXB0aW9ucyA9IGFnZ3JlZ2F0ZUV4Y2VwdGlvbnNGcm9tRXJyb3IoXG4gICAgICAgICAgZXhjZXB0aW9uRnJvbUVycm9ySW1wbGVtZW50YXRpb24sXG4gICAgICAgICAgcGFyc2VyLFxuICAgICAgICAgIGxpbWl0LFxuICAgICAgICAgIGNoaWxkRXJyb3IsXG4gICAgICAgICAga2V5LFxuICAgICAgICAgIFtuZXdFeGNlcHRpb24sIC4uLm5ld0V4Y2VwdGlvbnNdLFxuICAgICAgICAgIG5ld0V4Y2VwdGlvbixcbiAgICAgICAgICBuZXdFeGNlcHRpb25JZCxcbiAgICAgICAgKTtcbiAgICAgIH1cbiAgICB9KTtcbiAgfVxuXG4gIHJldHVybiBuZXdFeGNlcHRpb25zO1xufVxuXG5mdW5jdGlvbiBhcHBseUV4Y2VwdGlvbkdyb3VwRmllbGRzRm9yUGFyZW50RXhjZXB0aW9uKGV4Y2VwdGlvbiwgZXhjZXB0aW9uSWQpIHtcbiAgLy8gRG9uJ3Qga25vdyBpZiB0aGlzIGRlZmF1bHQgbWFrZXMgc2Vuc2UuIFRoZSBwcm90b2NvbCByZXF1aXJlcyB1cyB0byBzZXQgdGhlc2UgdmFsdWVzIHNvIHdlIHBpY2sgKnNvbWUqIGRlZmF1bHQuXG4gIGV4Y2VwdGlvbi5tZWNoYW5pc20gPSBleGNlcHRpb24ubWVjaGFuaXNtIHx8IHsgdHlwZTogJ2dlbmVyaWMnLCBoYW5kbGVkOiB0cnVlIH07XG5cbiAgZXhjZXB0aW9uLm1lY2hhbmlzbSA9IHtcbiAgICAuLi5leGNlcHRpb24ubWVjaGFuaXNtLFxuICAgIC4uLihleGNlcHRpb24udHlwZSA9PT0gJ0FnZ3JlZ2F0ZUVycm9yJyAmJiB7IGlzX2V4Y2VwdGlvbl9ncm91cDogdHJ1ZSB9KSxcbiAgICBleGNlcHRpb25faWQ6IGV4Y2VwdGlvbklkLFxuICB9O1xufVxuXG5mdW5jdGlvbiBhcHBseUV4Y2VwdGlvbkdyb3VwRmllbGRzRm9yQ2hpbGRFeGNlcHRpb24oXG4gIGV4Y2VwdGlvbixcbiAgc291cmNlLFxuICBleGNlcHRpb25JZCxcbiAgcGFyZW50SWQsXG4pIHtcbiAgLy8gRG9uJ3Qga25vdyBpZiB0aGlzIGRlZmF1bHQgbWFrZXMgc2Vuc2UuIFRoZSBwcm90b2NvbCByZXF1aXJlcyB1cyB0byBzZXQgdGhlc2UgdmFsdWVzIHNvIHdlIHBpY2sgKnNvbWUqIGRlZmF1bHQuXG4gIGV4Y2VwdGlvbi5tZWNoYW5pc20gPSBleGNlcHRpb24ubWVjaGFuaXNtIHx8IHsgdHlwZTogJ2dlbmVyaWMnLCBoYW5kbGVkOiB0cnVlIH07XG5cbiAgZXhjZXB0aW9uLm1lY2hhbmlzbSA9IHtcbiAgICAuLi5leGNlcHRpb24ubWVjaGFuaXNtLFxuICAgIHR5cGU6ICdjaGFpbmVkJyxcbiAgICBzb3VyY2UsXG4gICAgZXhjZXB0aW9uX2lkOiBleGNlcHRpb25JZCxcbiAgICBwYXJlbnRfaWQ6IHBhcmVudElkLFxuICB9O1xufVxuXG5leHBvcnRzLmFwcGx5QWdncmVnYXRlRXJyb3JzVG9FdmVudCA9IGFwcGx5QWdncmVnYXRlRXJyb3JzVG9FdmVudDtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWFnZ3JlZ2F0ZS1lcnJvcnMuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/aggregate-errors.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/anr.js":
/*!*************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/anr.js ***!
  \*************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst nodeStackTrace = __webpack_require__(/*! ./node-stack-trace.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/node-stack-trace.js\");\nconst stacktrace = __webpack_require__(/*! ./stacktrace.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/stacktrace.js\");\n\n/**\n * A node.js watchdog timer\n * @param pollInterval The interval that we expect to get polled at\n * @param anrThreshold The threshold for when we consider ANR\n * @param callback The callback to call for ANR\n * @returns An object with `poll` and `enabled` functions {@link WatchdogReturn}\n */\nfunction watchdogTimer(\n  createTimer,\n  pollInterval,\n  anrThreshold,\n  callback,\n) {\n  const timer = createTimer();\n  let triggered = false;\n  let enabled = true;\n\n  setInterval(() => {\n    const diffMs = timer.getTimeMs();\n\n    if (triggered === false && diffMs > pollInterval + anrThreshold) {\n      triggered = true;\n      if (enabled) {\n        callback();\n      }\n    }\n\n    if (diffMs < pollInterval + anrThreshold) {\n      triggered = false;\n    }\n  }, 20);\n\n  return {\n    poll: () => {\n      timer.reset();\n    },\n    enabled: (state) => {\n      enabled = state;\n    },\n  };\n}\n\n// types copied from inspector.d.ts\n\n/**\n * Converts Debugger.CallFrame to Sentry StackFrame\n */\nfunction callFrameToStackFrame(\n  frame,\n  url,\n  getModuleFromFilename,\n) {\n  const filename = url ? url.replace(/^file:\\/\\//, '') : undefined;\n\n  // CallFrame row/col are 0 based, whereas StackFrame are 1 based\n  const colno = frame.location.columnNumber ? frame.location.columnNumber + 1 : undefined;\n  const lineno = frame.location.lineNumber ? frame.location.lineNumber + 1 : undefined;\n\n  return {\n    filename,\n    module: getModuleFromFilename(filename),\n    function: frame.functionName || stacktrace.UNKNOWN_FUNCTION,\n    colno,\n    lineno,\n    in_app: filename ? nodeStackTrace.filenameIsInApp(filename) : undefined,\n  };\n}\n\nexports.callFrameToStackFrame = callFrameToStackFrame;\nexports.watchdogTimer = watchdogTimer;\n//# sourceMappingURL=anr.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9hbnIuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsdUJBQXVCLG1CQUFPLENBQUMsMklBQXVCO0FBQ3RELG1CQUFtQixtQkFBTyxDQUFDLCtIQUFpQjs7QUFFNUM7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLDJEQUEyRDtBQUMzRDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQSxHQUFHOztBQUVIO0FBQ0E7QUFDQTtBQUNBLEtBQUs7QUFDTDtBQUNBO0FBQ0EsS0FBSztBQUNMO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsNkJBQTZCO0FBQzdCLHFCQUFxQjtBQUNyQiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3V0aWxzL2Fuci5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3Qgbm9kZVN0YWNrVHJhY2UgPSByZXF1aXJlKCcuL25vZGUtc3RhY2stdHJhY2UuanMnKTtcbmNvbnN0IHN0YWNrdHJhY2UgPSByZXF1aXJlKCcuL3N0YWNrdHJhY2UuanMnKTtcblxuLyoqXG4gKiBBIG5vZGUuanMgd2F0Y2hkb2cgdGltZXJcbiAqIEBwYXJhbSBwb2xsSW50ZXJ2YWwgVGhlIGludGVydmFsIHRoYXQgd2UgZXhwZWN0IHRvIGdldCBwb2xsZWQgYXRcbiAqIEBwYXJhbSBhbnJUaHJlc2hvbGQgVGhlIHRocmVzaG9sZCBmb3Igd2hlbiB3ZSBjb25zaWRlciBBTlJcbiAqIEBwYXJhbSBjYWxsYmFjayBUaGUgY2FsbGJhY2sgdG8gY2FsbCBmb3IgQU5SXG4gKiBAcmV0dXJucyBBbiBvYmplY3Qgd2l0aCBgcG9sbGAgYW5kIGBlbmFibGVkYCBmdW5jdGlvbnMge0BsaW5rIFdhdGNoZG9nUmV0dXJufVxuICovXG5mdW5jdGlvbiB3YXRjaGRvZ1RpbWVyKFxuICBjcmVhdGVUaW1lcixcbiAgcG9sbEludGVydmFsLFxuICBhbnJUaHJlc2hvbGQsXG4gIGNhbGxiYWNrLFxuKSB7XG4gIGNvbnN0IHRpbWVyID0gY3JlYXRlVGltZXIoKTtcbiAgbGV0IHRyaWdnZXJlZCA9IGZhbHNlO1xuICBsZXQgZW5hYmxlZCA9IHRydWU7XG5cbiAgc2V0SW50ZXJ2YWwoKCkgPT4ge1xuICAgIGNvbnN0IGRpZmZNcyA9IHRpbWVyLmdldFRpbWVNcygpO1xuXG4gICAgaWYgKHRyaWdnZXJlZCA9PT0gZmFsc2UgJiYgZGlmZk1zID4gcG9sbEludGVydmFsICsgYW5yVGhyZXNob2xkKSB7XG4gICAgICB0cmlnZ2VyZWQgPSB0cnVlO1xuICAgICAgaWYgKGVuYWJsZWQpIHtcbiAgICAgICAgY2FsbGJhY2soKTtcbiAgICAgIH1cbiAgICB9XG5cbiAgICBpZiAoZGlmZk1zIDwgcG9sbEludGVydmFsICsgYW5yVGhyZXNob2xkKSB7XG4gICAgICB0cmlnZ2VyZWQgPSBmYWxzZTtcbiAgICB9XG4gIH0sIDIwKTtcblxuICByZXR1cm4ge1xuICAgIHBvbGw6ICgpID0+IHtcbiAgICAgIHRpbWVyLnJlc2V0KCk7XG4gICAgfSxcbiAgICBlbmFibGVkOiAoc3RhdGUpID0+IHtcbiAgICAgIGVuYWJsZWQgPSBzdGF0ZTtcbiAgICB9LFxuICB9O1xufVxuXG4vLyB0eXBlcyBjb3BpZWQgZnJvbSBpbnNwZWN0b3IuZC50c1xuXG4vKipcbiAqIENvbnZlcnRzIERlYnVnZ2VyLkNhbGxGcmFtZSB0byBTZW50cnkgU3RhY2tGcmFtZVxuICovXG5mdW5jdGlvbiBjYWxsRnJhbWVUb1N0YWNrRnJhbWUoXG4gIGZyYW1lLFxuICB1cmwsXG4gIGdldE1vZHVsZUZyb21GaWxlbmFtZSxcbikge1xuICBjb25zdCBmaWxlbmFtZSA9IHVybCA/IHVybC5yZXBsYWNlKC9eZmlsZTpcXC9cXC8vLCAnJykgOiB1bmRlZmluZWQ7XG5cbiAgLy8gQ2FsbEZyYW1lIHJvdy9jb2wgYXJlIDAgYmFzZWQsIHdoZXJlYXMgU3RhY2tGcmFtZSBhcmUgMSBiYXNlZFxuICBjb25zdCBjb2xubyA9IGZyYW1lLmxvY2F0aW9uLmNvbHVtbk51bWJlciA/IGZyYW1lLmxvY2F0aW9uLmNvbHVtbk51bWJlciArIDEgOiB1bmRlZmluZWQ7XG4gIGNvbnN0IGxpbmVubyA9IGZyYW1lLmxvY2F0aW9uLmxpbmVOdW1iZXIgPyBmcmFtZS5sb2NhdGlvbi5saW5lTnVtYmVyICsgMSA6IHVuZGVmaW5lZDtcblxuICByZXR1cm4ge1xuICAgIGZpbGVuYW1lLFxuICAgIG1vZHVsZTogZ2V0TW9kdWxlRnJvbUZpbGVuYW1lKGZpbGVuYW1lKSxcbiAgICBmdW5jdGlvbjogZnJhbWUuZnVuY3Rpb25OYW1lIHx8IHN0YWNrdHJhY2UuVU5LTk9XTl9GVU5DVElPTixcbiAgICBjb2xubyxcbiAgICBsaW5lbm8sXG4gICAgaW5fYXBwOiBmaWxlbmFtZSA/IG5vZGVTdGFja1RyYWNlLmZpbGVuYW1lSXNJbkFwcChmaWxlbmFtZSkgOiB1bmRlZmluZWQsXG4gIH07XG59XG5cbmV4cG9ydHMuY2FsbEZyYW1lVG9TdGFja0ZyYW1lID0gY2FsbEZyYW1lVG9TdGFja0ZyYW1lO1xuZXhwb3J0cy53YXRjaGRvZ1RpbWVyID0gd2F0Y2hkb2dUaW1lcjtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWFuci5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/anr.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/applyScopeDataToEvent.js":
/*!*******************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/applyScopeDataToEvent.js ***!
  \*******************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst dynamicSamplingContext = __webpack_require__(/*! ../tracing/dynamicSamplingContext.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/dynamicSamplingContext.js\");\nconst merge = __webpack_require__(/*! ./merge.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/merge.js\");\nconst spanUtils = __webpack_require__(/*! ./spanUtils.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanUtils.js\");\n\n/**\n * Applies data from the scope to the event and runs all event processors on it.\n */\nfunction applyScopeDataToEvent(event, data) {\n  const { fingerprint, span, breadcrumbs, sdkProcessingMetadata } = data;\n\n  // Apply general data\n  applyDataToEvent(event, data);\n\n  // We want to set the trace context for normal events only if there isn't already\n  // a trace context on the event. There is a product feature in place where we link\n  // errors with transaction and it relies on that.\n  if (span) {\n    applySpanToEvent(event, span);\n  }\n\n  applyFingerprintToEvent(event, fingerprint);\n  applyBreadcrumbsToEvent(event, breadcrumbs);\n  applySdkMetadataToEvent(event, sdkProcessingMetadata);\n}\n\n/** Merge data of two scopes together. */\nfunction mergeScopeData(data, mergeData) {\n  const {\n    extra,\n    tags,\n    user,\n    contexts,\n    level,\n    sdkProcessingMetadata,\n    breadcrumbs,\n    fingerprint,\n    eventProcessors,\n    attachments,\n    propagationContext,\n    transactionName,\n    span,\n  } = mergeData;\n\n  mergeAndOverwriteScopeData(data, 'extra', extra);\n  mergeAndOverwriteScopeData(data, 'tags', tags);\n  mergeAndOverwriteScopeData(data, 'user', user);\n  mergeAndOverwriteScopeData(data, 'contexts', contexts);\n\n  data.sdkProcessingMetadata = merge.merge(data.sdkProcessingMetadata, sdkProcessingMetadata, 2);\n\n  if (level) {\n    data.level = level;\n  }\n\n  if (transactionName) {\n    data.transactionName = transactionName;\n  }\n\n  if (span) {\n    data.span = span;\n  }\n\n  if (breadcrumbs.length) {\n    data.breadcrumbs = [...data.breadcrumbs, ...breadcrumbs];\n  }\n\n  if (fingerprint.length) {\n    data.fingerprint = [...data.fingerprint, ...fingerprint];\n  }\n\n  if (eventProcessors.length) {\n    data.eventProcessors = [...data.eventProcessors, ...eventProcessors];\n  }\n\n  if (attachments.length) {\n    data.attachments = [...data.attachments, ...attachments];\n  }\n\n  data.propagationContext = { ...data.propagationContext, ...propagationContext };\n}\n\n/**\n * Merges certain scope data. Undefined values will overwrite any existing values.\n * Exported only for tests.\n */\nfunction mergeAndOverwriteScopeData\n\n(data, prop, mergeVal) {\n  data[prop] = merge.merge(data[prop], mergeVal, 1);\n}\n\nfunction applyDataToEvent(event, data) {\n  const { extra, tags, user, contexts, level, transactionName } = data;\n\n  if (Object.keys(extra).length) {\n    event.extra = { ...extra, ...event.extra };\n  }\n\n  if (Object.keys(tags).length) {\n    event.tags = { ...tags, ...event.tags };\n  }\n\n  if (Object.keys(user).length) {\n    event.user = { ...user, ...event.user };\n  }\n\n  if (Object.keys(contexts).length) {\n    event.contexts = { ...contexts, ...event.contexts };\n  }\n\n  if (level) {\n    event.level = level;\n  }\n\n  // transaction events get their `transaction` from the root span name\n  if (transactionName && event.type !== 'transaction') {\n    event.transaction = transactionName;\n  }\n}\n\nfunction applyBreadcrumbsToEvent(event, breadcrumbs) {\n  const mergedBreadcrumbs = [...(event.breadcrumbs || []), ...breadcrumbs];\n  event.breadcrumbs = mergedBreadcrumbs.length ? mergedBreadcrumbs : undefined;\n}\n\nfunction applySdkMetadataToEvent(event, sdkProcessingMetadata) {\n  event.sdkProcessingMetadata = {\n    ...event.sdkProcessingMetadata,\n    ...sdkProcessingMetadata,\n  };\n}\n\nfunction applySpanToEvent(event, span) {\n  event.contexts = {\n    trace: spanUtils.spanToTraceContext(span),\n    ...event.contexts,\n  };\n\n  event.sdkProcessingMetadata = {\n    dynamicSamplingContext: dynamicSamplingContext.getDynamicSamplingContextFromSpan(span),\n    ...event.sdkProcessingMetadata,\n  };\n\n  const rootSpan = spanUtils.getRootSpan(span);\n  const transactionName = spanUtils.spanToJSON(rootSpan).description;\n  if (transactionName && !event.transaction && event.type === 'transaction') {\n    event.transaction = transactionName;\n  }\n}\n\n/**\n * Applies fingerprint from the scope to the event if there's one,\n * uses message if there's one instead or get rid of empty fingerprint\n */\nfunction applyFingerprintToEvent(event, fingerprint) {\n  // Make sure it's an array first and we actually have something in place\n  event.fingerprint = event.fingerprint\n    ? Array.isArray(event.fingerprint)\n      ? event.fingerprint\n      : [event.fingerprint]\n    : [];\n\n  // If we have something on the scope, then merge it with event\n  if (fingerprint) {\n    event.fingerprint = event.fingerprint.concat(fingerprint);\n  }\n\n  // If we have no data at all, remove empty array default\n  if (!event.fingerprint.length) {\n    delete event.fingerprint;\n  }\n}\n\nexports.applyScopeDataToEvent = applyScopeDataToEvent;\nexports.mergeAndOverwriteScopeData = mergeAndOverwriteScopeData;\nexports.mergeScopeData = mergeScopeData;\n//# sourceMappingURL=applyScopeDataToEvent.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9hcHBseVNjb3BlRGF0YVRvRXZlbnQuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsK0JBQStCLG1CQUFPLENBQUMsa0tBQXNDO0FBQzdFLGNBQWMsbUJBQU8sQ0FBQyxxSEFBWTtBQUNsQyxrQkFBa0IsbUJBQU8sQ0FBQyw2SEFBZ0I7O0FBRTFDO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsVUFBVSx3REFBd0Q7O0FBRWxFO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsSUFBSTs7QUFFSjtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUEsOEJBQThCO0FBQzlCOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0EsVUFBVSxzREFBc0Q7O0FBRWhFO0FBQ0Esb0JBQW9CO0FBQ3BCOztBQUVBO0FBQ0EsbUJBQW1CO0FBQ25COztBQUVBO0FBQ0EsbUJBQW1CO0FBQ25COztBQUVBO0FBQ0EsdUJBQXVCO0FBQ3ZCOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsNkJBQTZCO0FBQzdCLGtDQUFrQztBQUNsQyxzQkFBc0I7QUFDdEIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9hcHBseVNjb3BlRGF0YVRvRXZlbnQuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGR5bmFtaWNTYW1wbGluZ0NvbnRleHQgPSByZXF1aXJlKCcuLi90cmFjaW5nL2R5bmFtaWNTYW1wbGluZ0NvbnRleHQuanMnKTtcbmNvbnN0IG1lcmdlID0gcmVxdWlyZSgnLi9tZXJnZS5qcycpO1xuY29uc3Qgc3BhblV0aWxzID0gcmVxdWlyZSgnLi9zcGFuVXRpbHMuanMnKTtcblxuLyoqXG4gKiBBcHBsaWVzIGRhdGEgZnJvbSB0aGUgc2NvcGUgdG8gdGhlIGV2ZW50IGFuZCBydW5zIGFsbCBldmVudCBwcm9jZXNzb3JzIG9uIGl0LlxuICovXG5mdW5jdGlvbiBhcHBseVNjb3BlRGF0YVRvRXZlbnQoZXZlbnQsIGRhdGEpIHtcbiAgY29uc3QgeyBmaW5nZXJwcmludCwgc3BhbiwgYnJlYWRjcnVtYnMsIHNka1Byb2Nlc3NpbmdNZXRhZGF0YSB9ID0gZGF0YTtcblxuICAvLyBBcHBseSBnZW5lcmFsIGRhdGFcbiAgYXBwbHlEYXRhVG9FdmVudChldmVudCwgZGF0YSk7XG5cbiAgLy8gV2Ugd2FudCB0byBzZXQgdGhlIHRyYWNlIGNvbnRleHQgZm9yIG5vcm1hbCBldmVudHMgb25seSBpZiB0aGVyZSBpc24ndCBhbHJlYWR5XG4gIC8vIGEgdHJhY2UgY29udGV4dCBvbiB0aGUgZXZlbnQuIFRoZXJlIGlzIGEgcHJvZHVjdCBmZWF0dXJlIGluIHBsYWNlIHdoZXJlIHdlIGxpbmtcbiAgLy8gZXJyb3JzIHdpdGggdHJhbnNhY3Rpb24gYW5kIGl0IHJlbGllcyBvbiB0aGF0LlxuICBpZiAoc3Bhbikge1xuICAgIGFwcGx5U3BhblRvRXZlbnQoZXZlbnQsIHNwYW4pO1xuICB9XG5cbiAgYXBwbHlGaW5nZXJwcmludFRvRXZlbnQoZXZlbnQsIGZpbmdlcnByaW50KTtcbiAgYXBwbHlCcmVhZGNydW1ic1RvRXZlbnQoZXZlbnQsIGJyZWFkY3J1bWJzKTtcbiAgYXBwbHlTZGtNZXRhZGF0YVRvRXZlbnQoZXZlbnQsIHNka1Byb2Nlc3NpbmdNZXRhZGF0YSk7XG59XG5cbi8qKiBNZXJnZSBkYXRhIG9mIHR3byBzY29wZXMgdG9nZXRoZXIuICovXG5mdW5jdGlvbiBtZXJnZVNjb3BlRGF0YShkYXRhLCBtZXJnZURhdGEpIHtcbiAgY29uc3Qge1xuICAgIGV4dHJhLFxuICAgIHRhZ3MsXG4gICAgdXNlcixcbiAgICBjb250ZXh0cyxcbiAgICBsZXZlbCxcbiAgICBzZGtQcm9jZXNzaW5nTWV0YWRhdGEsXG4gICAgYnJlYWRjcnVtYnMsXG4gICAgZmluZ2VycHJpbnQsXG4gICAgZXZlbnRQcm9jZXNzb3JzLFxuICAgIGF0dGFjaG1lbnRzLFxuICAgIHByb3BhZ2F0aW9uQ29udGV4dCxcbiAgICB0cmFuc2FjdGlvbk5hbWUsXG4gICAgc3BhbixcbiAgfSA9IG1lcmdlRGF0YTtcblxuICBtZXJnZUFuZE92ZXJ3cml0ZVNjb3BlRGF0YShkYXRhLCAnZXh0cmEnLCBleHRyYSk7XG4gIG1lcmdlQW5kT3ZlcndyaXRlU2NvcGVEYXRhKGRhdGEsICd0YWdzJywgdGFncyk7XG4gIG1lcmdlQW5kT3ZlcndyaXRlU2NvcGVEYXRhKGRhdGEsICd1c2VyJywgdXNlcik7XG4gIG1lcmdlQW5kT3ZlcndyaXRlU2NvcGVEYXRhKGRhdGEsICdjb250ZXh0cycsIGNvbnRleHRzKTtcblxuICBkYXRhLnNka1Byb2Nlc3NpbmdNZXRhZGF0YSA9IG1lcmdlLm1lcmdlKGRhdGEuc2RrUHJvY2Vzc2luZ01ldGFkYXRhLCBzZGtQcm9jZXNzaW5nTWV0YWRhdGEsIDIpO1xuXG4gIGlmIChsZXZlbCkge1xuICAgIGRhdGEubGV2ZWwgPSBsZXZlbDtcbiAgfVxuXG4gIGlmICh0cmFuc2FjdGlvbk5hbWUpIHtcbiAgICBkYXRhLnRyYW5zYWN0aW9uTmFtZSA9IHRyYW5zYWN0aW9uTmFtZTtcbiAgfVxuXG4gIGlmIChzcGFuKSB7XG4gICAgZGF0YS5zcGFuID0gc3BhbjtcbiAgfVxuXG4gIGlmIChicmVhZGNydW1icy5sZW5ndGgpIHtcbiAgICBkYXRhLmJyZWFkY3J1bWJzID0gWy4uLmRhdGEuYnJlYWRjcnVtYnMsIC4uLmJyZWFkY3J1bWJzXTtcbiAgfVxuXG4gIGlmIChmaW5nZXJwcmludC5sZW5ndGgpIHtcbiAgICBkYXRhLmZpbmdlcnByaW50ID0gWy4uLmRhdGEuZmluZ2VycHJpbnQsIC4uLmZpbmdlcnByaW50XTtcbiAgfVxuXG4gIGlmIChldmVudFByb2Nlc3NvcnMubGVuZ3RoKSB7XG4gICAgZGF0YS5ldmVudFByb2Nlc3NvcnMgPSBbLi4uZGF0YS5ldmVudFByb2Nlc3NvcnMsIC4uLmV2ZW50UHJvY2Vzc29yc107XG4gIH1cblxuICBpZiAoYXR0YWNobWVudHMubGVuZ3RoKSB7XG4gICAgZGF0YS5hdHRhY2htZW50cyA9IFsuLi5kYXRhLmF0dGFjaG1lbnRzLCAuLi5hdHRhY2htZW50c107XG4gIH1cblxuICBkYXRhLnByb3BhZ2F0aW9uQ29udGV4dCA9IHsgLi4uZGF0YS5wcm9wYWdhdGlvbkNvbnRleHQsIC4uLnByb3BhZ2F0aW9uQ29udGV4dCB9O1xufVxuXG4vKipcbiAqIE1lcmdlcyBjZXJ0YWluIHNjb3BlIGRhdGEuIFVuZGVmaW5lZCB2YWx1ZXMgd2lsbCBvdmVyd3JpdGUgYW55IGV4aXN0aW5nIHZhbHVlcy5cbiAqIEV4cG9ydGVkIG9ubHkgZm9yIHRlc3RzLlxuICovXG5mdW5jdGlvbiBtZXJnZUFuZE92ZXJ3cml0ZVNjb3BlRGF0YVxuXG4oZGF0YSwgcHJvcCwgbWVyZ2VWYWwpIHtcbiAgZGF0YVtwcm9wXSA9IG1lcmdlLm1lcmdlKGRhdGFbcHJvcF0sIG1lcmdlVmFsLCAxKTtcbn1cblxuZnVuY3Rpb24gYXBwbHlEYXRhVG9FdmVudChldmVudCwgZGF0YSkge1xuICBjb25zdCB7IGV4dHJhLCB0YWdzLCB1c2VyLCBjb250ZXh0cywgbGV2ZWwsIHRyYW5zYWN0aW9uTmFtZSB9ID0gZGF0YTtcblxuICBpZiAoT2JqZWN0LmtleXMoZXh0cmEpLmxlbmd0aCkge1xuICAgIGV2ZW50LmV4dHJhID0geyAuLi5leHRyYSwgLi4uZXZlbnQuZXh0cmEgfTtcbiAgfVxuXG4gIGlmIChPYmplY3Qua2V5cyh0YWdzKS5sZW5ndGgpIHtcbiAgICBldmVudC50YWdzID0geyAuLi50YWdzLCAuLi5ldmVudC50YWdzIH07XG4gIH1cblxuICBpZiAoT2JqZWN0LmtleXModXNlcikubGVuZ3RoKSB7XG4gICAgZXZlbnQudXNlciA9IHsgLi4udXNlciwgLi4uZXZlbnQudXNlciB9O1xuICB9XG5cbiAgaWYgKE9iamVjdC5rZXlzKGNvbnRleHRzKS5sZW5ndGgpIHtcbiAgICBldmVudC5jb250ZXh0cyA9IHsgLi4uY29udGV4dHMsIC4uLmV2ZW50LmNvbnRleHRzIH07XG4gIH1cblxuICBpZiAobGV2ZWwpIHtcbiAgICBldmVudC5sZXZlbCA9IGxldmVsO1xuICB9XG5cbiAgLy8gdHJhbnNhY3Rpb24gZXZlbnRzIGdldCB0aGVpciBgdHJhbnNhY3Rpb25gIGZyb20gdGhlIHJvb3Qgc3BhbiBuYW1lXG4gIGlmICh0cmFuc2FjdGlvbk5hbWUgJiYgZXZlbnQudHlwZSAhPT0gJ3RyYW5zYWN0aW9uJykge1xuICAgIGV2ZW50LnRyYW5zYWN0aW9uID0gdHJhbnNhY3Rpb25OYW1lO1xuICB9XG59XG5cbmZ1bmN0aW9uIGFwcGx5QnJlYWRjcnVtYnNUb0V2ZW50KGV2ZW50LCBicmVhZGNydW1icykge1xuICBjb25zdCBtZXJnZWRCcmVhZGNydW1icyA9IFsuLi4oZXZlbnQuYnJlYWRjcnVtYnMgfHwgW10pLCAuLi5icmVhZGNydW1ic107XG4gIGV2ZW50LmJyZWFkY3J1bWJzID0gbWVyZ2VkQnJlYWRjcnVtYnMubGVuZ3RoID8gbWVyZ2VkQnJlYWRjcnVtYnMgOiB1bmRlZmluZWQ7XG59XG5cbmZ1bmN0aW9uIGFwcGx5U2RrTWV0YWRhdGFUb0V2ZW50KGV2ZW50LCBzZGtQcm9jZXNzaW5nTWV0YWRhdGEpIHtcbiAgZXZlbnQuc2RrUHJvY2Vzc2luZ01ldGFkYXRhID0ge1xuICAgIC4uLmV2ZW50LnNka1Byb2Nlc3NpbmdNZXRhZGF0YSxcbiAgICAuLi5zZGtQcm9jZXNzaW5nTWV0YWRhdGEsXG4gIH07XG59XG5cbmZ1bmN0aW9uIGFwcGx5U3BhblRvRXZlbnQoZXZlbnQsIHNwYW4pIHtcbiAgZXZlbnQuY29udGV4dHMgPSB7XG4gICAgdHJhY2U6IHNwYW5VdGlscy5zcGFuVG9UcmFjZUNvbnRleHQoc3BhbiksXG4gICAgLi4uZXZlbnQuY29udGV4dHMsXG4gIH07XG5cbiAgZXZlbnQuc2RrUHJvY2Vzc2luZ01ldGFkYXRhID0ge1xuICAgIGR5bmFtaWNTYW1wbGluZ0NvbnRleHQ6IGR5bmFtaWNTYW1wbGluZ0NvbnRleHQuZ2V0RHluYW1pY1NhbXBsaW5nQ29udGV4dEZyb21TcGFuKHNwYW4pLFxuICAgIC4uLmV2ZW50LnNka1Byb2Nlc3NpbmdNZXRhZGF0YSxcbiAgfTtcblxuICBjb25zdCByb290U3BhbiA9IHNwYW5VdGlscy5nZXRSb290U3BhbihzcGFuKTtcbiAgY29uc3QgdHJhbnNhY3Rpb25OYW1lID0gc3BhblV0aWxzLnNwYW5Ub0pTT04ocm9vdFNwYW4pLmRlc2NyaXB0aW9uO1xuICBpZiAodHJhbnNhY3Rpb25OYW1lICYmICFldmVudC50cmFuc2FjdGlvbiAmJiBldmVudC50eXBlID09PSAndHJhbnNhY3Rpb24nKSB7XG4gICAgZXZlbnQudHJhbnNhY3Rpb24gPSB0cmFuc2FjdGlvbk5hbWU7XG4gIH1cbn1cblxuLyoqXG4gKiBBcHBsaWVzIGZpbmdlcnByaW50IGZyb20gdGhlIHNjb3BlIHRvIHRoZSBldmVudCBpZiB0aGVyZSdzIG9uZSxcbiAqIHVzZXMgbWVzc2FnZSBpZiB0aGVyZSdzIG9uZSBpbnN0ZWFkIG9yIGdldCByaWQgb2YgZW1wdHkgZmluZ2VycHJpbnRcbiAqL1xuZnVuY3Rpb24gYXBwbHlGaW5nZXJwcmludFRvRXZlbnQoZXZlbnQsIGZpbmdlcnByaW50KSB7XG4gIC8vIE1ha2Ugc3VyZSBpdCdzIGFuIGFycmF5IGZpcnN0IGFuZCB3ZSBhY3R1YWxseSBoYXZlIHNvbWV0aGluZyBpbiBwbGFjZVxuICBldmVudC5maW5nZXJwcmludCA9IGV2ZW50LmZpbmdlcnByaW50XG4gICAgPyBBcnJheS5pc0FycmF5KGV2ZW50LmZpbmdlcnByaW50KVxuICAgICAgPyBldmVudC5maW5nZXJwcmludFxuICAgICAgOiBbZXZlbnQuZmluZ2VycHJpbnRdXG4gICAgOiBbXTtcblxuICAvLyBJZiB3ZSBoYXZlIHNvbWV0aGluZyBvbiB0aGUgc2NvcGUsIHRoZW4gbWVyZ2UgaXQgd2l0aCBldmVudFxuICBpZiAoZmluZ2VycHJpbnQpIHtcbiAgICBldmVudC5maW5nZXJwcmludCA9IGV2ZW50LmZpbmdlcnByaW50LmNvbmNhdChmaW5nZXJwcmludCk7XG4gIH1cblxuICAvLyBJZiB3ZSBoYXZlIG5vIGRhdGEgYXQgYWxsLCByZW1vdmUgZW1wdHkgYXJyYXkgZGVmYXVsdFxuICBpZiAoIWV2ZW50LmZpbmdlcnByaW50Lmxlbmd0aCkge1xuICAgIGRlbGV0ZSBldmVudC5maW5nZXJwcmludDtcbiAgfVxufVxuXG5leHBvcnRzLmFwcGx5U2NvcGVEYXRhVG9FdmVudCA9IGFwcGx5U2NvcGVEYXRhVG9FdmVudDtcbmV4cG9ydHMubWVyZ2VBbmRPdmVyd3JpdGVTY29wZURhdGEgPSBtZXJnZUFuZE92ZXJ3cml0ZVNjb3BlRGF0YTtcbmV4cG9ydHMubWVyZ2VTY29wZURhdGEgPSBtZXJnZVNjb3BlRGF0YTtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWFwcGx5U2NvcGVEYXRhVG9FdmVudC5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/applyScopeDataToEvent.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/baggage.js":
/*!*****************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/baggage.js ***!
  \*****************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst debugBuild = __webpack_require__(/*! ../debug-build.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst debugLogger = __webpack_require__(/*! ./debug-logger.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst is = __webpack_require__(/*! ./is.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js\");\n\nconst SENTRY_BAGGAGE_KEY_PREFIX = 'sentry-';\n\nconst SENTRY_BAGGAGE_KEY_PREFIX_REGEX = /^sentry-/;\n\n/**\n * Max length of a serialized baggage string\n *\n * https://www.w3.org/TR/baggage/#limits\n */\nconst MAX_BAGGAGE_STRING_LENGTH = 8192;\n\n/**\n * Takes a baggage header and turns it into Dynamic Sampling Context, by extracting all the \"sentry-\" prefixed values\n * from it.\n *\n * @param baggageHeader A very bread definition of a baggage header as it might appear in various frameworks.\n * @returns The Dynamic Sampling Context that was found on `baggageHeader`, if there was any, `undefined` otherwise.\n */\nfunction baggageHeaderToDynamicSamplingContext(\n  // Very liberal definition of what any incoming header might look like\n  baggageHeader,\n) {\n  const baggageObject = parseBaggageHeader(baggageHeader);\n\n  if (!baggageObject) {\n    return undefined;\n  }\n\n  // Read all \"sentry-\" prefixed values out of the baggage object and put it onto a dynamic sampling context object.\n  const dynamicSamplingContext = Object.entries(baggageObject).reduce((acc, [key, value]) => {\n    if (key.match(SENTRY_BAGGAGE_KEY_PREFIX_REGEX)) {\n      const nonPrefixedKey = key.slice(SENTRY_BAGGAGE_KEY_PREFIX.length);\n      acc[nonPrefixedKey] = value;\n    }\n    return acc;\n  }, {});\n\n  // Only return a dynamic sampling context object if there are keys in it.\n  // A keyless object means there were no sentry values on the header, which means that there is no DSC.\n  if (Object.keys(dynamicSamplingContext).length > 0) {\n    return dynamicSamplingContext ;\n  } else {\n    return undefined;\n  }\n}\n\n/**\n * Turns a Dynamic Sampling Object into a baggage header by prefixing all the keys on the object with \"sentry-\".\n *\n * @param dynamicSamplingContext The Dynamic Sampling Context to turn into a header. For convenience and compatibility\n * with the `getDynamicSamplingContext` method on the Transaction class ,this argument can also be `undefined`. If it is\n * `undefined` the function will return `undefined`.\n * @returns a baggage header, created from `dynamicSamplingContext`, or `undefined` either if `dynamicSamplingContext`\n * was `undefined`, or if `dynamicSamplingContext` didn't contain any values.\n */\nfunction dynamicSamplingContextToSentryBaggageHeader(\n  // this also takes undefined for convenience and bundle size in other places\n  dynamicSamplingContext,\n) {\n  if (!dynamicSamplingContext) {\n    return undefined;\n  }\n\n  // Prefix all DSC keys with \"sentry-\" and put them into a new object\n  const sentryPrefixedDSC = Object.entries(dynamicSamplingContext).reduce(\n    (acc, [dscKey, dscValue]) => {\n      if (dscValue) {\n        acc[`${SENTRY_BAGGAGE_KEY_PREFIX}${dscKey}`] = dscValue;\n      }\n      return acc;\n    },\n    {},\n  );\n\n  return objectToBaggageHeader(sentryPrefixedDSC);\n}\n\n/**\n * Take a baggage header and parse it into an object.\n */\nfunction parseBaggageHeader(\n  baggageHeader,\n) {\n  if (!baggageHeader || (!is.isString(baggageHeader) && !Array.isArray(baggageHeader))) {\n    return undefined;\n  }\n\n  if (Array.isArray(baggageHeader)) {\n    // Combine all baggage headers into one object containing the baggage values so we can later read the Sentry-DSC-values from it\n    return baggageHeader.reduce((acc, curr) => {\n      const currBaggageObject = baggageHeaderToObject(curr);\n      Object.entries(currBaggageObject).forEach(([key, value]) => {\n        acc[key] = value;\n      });\n      return acc;\n    }, {});\n  }\n\n  return baggageHeaderToObject(baggageHeader);\n}\n\n/**\n * Will parse a baggage header, which is a simple key-value map, into a flat object.\n *\n * @param baggageHeader The baggage header to parse.\n * @returns a flat object containing all the key-value pairs from `baggageHeader`.\n */\nfunction baggageHeaderToObject(baggageHeader) {\n  return baggageHeader\n    .split(',')\n    .map(baggageEntry =>\n      baggageEntry.split('=').map(keyOrValue => {\n        try {\n          return decodeURIComponent(keyOrValue.trim());\n        } catch {\n          // We ignore errors here, e.g. if the value cannot be URL decoded.\n          // This will then be skipped in the next step\n          return;\n        }\n      }),\n    )\n    .reduce((acc, [key, value]) => {\n      if (key && value) {\n        acc[key] = value;\n      }\n      return acc;\n    }, {});\n}\n\n/**\n * Turns a flat object (key-value pairs) into a baggage header, which is also just key-value pairs.\n *\n * @param object The object to turn into a baggage header.\n * @returns a baggage header string, or `undefined` if the object didn't have any values, since an empty baggage header\n * is not spec compliant.\n */\nfunction objectToBaggageHeader(object) {\n  if (Object.keys(object).length === 0) {\n    // An empty baggage header is not spec compliant: We return undefined.\n    return undefined;\n  }\n\n  return Object.entries(object).reduce((baggageHeader, [objectKey, objectValue], currentIndex) => {\n    const baggageEntry = `${encodeURIComponent(objectKey)}=${encodeURIComponent(objectValue)}`;\n    const newBaggageHeader = currentIndex === 0 ? baggageEntry : `${baggageHeader},${baggageEntry}`;\n    if (newBaggageHeader.length > MAX_BAGGAGE_STRING_LENGTH) {\n      debugBuild.DEBUG_BUILD &&\n        debugLogger.debug.warn(\n          `Not adding key: ${objectKey} with val: ${objectValue} to baggage header due to exceeding baggage size limits.`,\n        );\n      return baggageHeader;\n    } else {\n      return newBaggageHeader;\n    }\n  }, '');\n}\n\nexports.MAX_BAGGAGE_STRING_LENGTH = MAX_BAGGAGE_STRING_LENGTH;\nexports.SENTRY_BAGGAGE_KEY_PREFIX = SENTRY_BAGGAGE_KEY_PREFIX;\nexports.SENTRY_BAGGAGE_KEY_PREFIX_REGEX = SENTRY_BAGGAGE_KEY_PREFIX_REGEX;\nexports.baggageHeaderToDynamicSamplingContext = baggageHeaderToDynamicSamplingContext;\nexports.dynamicSamplingContextToSentryBaggageHeader = dynamicSamplingContextToSentryBaggageHeader;\nexports.objectToBaggageHeader = objectToBaggageHeader;\nexports.parseBaggageHeader = parseBaggageHeader;\n//# sourceMappingURL=baggage.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9iYWdnYWdlLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLG1CQUFtQixtQkFBTyxDQUFDLDRIQUFtQjtBQUM5QyxvQkFBb0IsbUJBQU8sQ0FBQyxtSUFBbUI7QUFDL0MsV0FBVyxtQkFBTyxDQUFDLCtHQUFTOztBQUU1Qjs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEdBQUcsSUFBSTs7QUFFUDtBQUNBO0FBQ0E7QUFDQTtBQUNBLElBQUk7QUFDSjtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQSxlQUFlLDBCQUEwQixFQUFFLE9BQU87QUFDbEQ7QUFDQTtBQUNBLEtBQUs7QUFDTCxNQUFNO0FBQ047O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsT0FBTztBQUNQO0FBQ0EsS0FBSyxJQUFJO0FBQ1Q7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFVBQVU7QUFDVjtBQUNBO0FBQ0E7QUFDQTtBQUNBLE9BQU87QUFDUDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxLQUFLLElBQUk7QUFDVDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQSw0QkFBNEIsOEJBQThCLEdBQUcsZ0NBQWdDO0FBQzdGLG9FQUFvRSxjQUFjLEdBQUcsYUFBYTtBQUNsRztBQUNBO0FBQ0E7QUFDQSw2QkFBNkIsV0FBVyxZQUFZLGFBQWE7QUFDakU7QUFDQTtBQUNBLE1BQU07QUFDTjtBQUNBO0FBQ0EsR0FBRztBQUNIOztBQUVBLGlDQUFpQztBQUNqQyxpQ0FBaUM7QUFDakMsdUNBQXVDO0FBQ3ZDLDZDQUE2QztBQUM3QyxtREFBbUQ7QUFDbkQsNkJBQTZCO0FBQzdCLDBCQUEwQjtBQUMxQiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3V0aWxzL2JhZ2dhZ2UuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGRlYnVnQnVpbGQgPSByZXF1aXJlKCcuLi9kZWJ1Zy1idWlsZC5qcycpO1xuY29uc3QgZGVidWdMb2dnZXIgPSByZXF1aXJlKCcuL2RlYnVnLWxvZ2dlci5qcycpO1xuY29uc3QgaXMgPSByZXF1aXJlKCcuL2lzLmpzJyk7XG5cbmNvbnN0IFNFTlRSWV9CQUdHQUdFX0tFWV9QUkVGSVggPSAnc2VudHJ5LSc7XG5cbmNvbnN0IFNFTlRSWV9CQUdHQUdFX0tFWV9QUkVGSVhfUkVHRVggPSAvXnNlbnRyeS0vO1xuXG4vKipcbiAqIE1heCBsZW5ndGggb2YgYSBzZXJpYWxpemVkIGJhZ2dhZ2Ugc3RyaW5nXG4gKlxuICogaHR0cHM6Ly93d3cudzMub3JnL1RSL2JhZ2dhZ2UvI2xpbWl0c1xuICovXG5jb25zdCBNQVhfQkFHR0FHRV9TVFJJTkdfTEVOR1RIID0gODE5MjtcblxuLyoqXG4gKiBUYWtlcyBhIGJhZ2dhZ2UgaGVhZGVyIGFuZCB0dXJucyBpdCBpbnRvIER5bmFtaWMgU2FtcGxpbmcgQ29udGV4dCwgYnkgZXh0cmFjdGluZyBhbGwgdGhlIFwic2VudHJ5LVwiIHByZWZpeGVkIHZhbHVlc1xuICogZnJvbSBpdC5cbiAqXG4gKiBAcGFyYW0gYmFnZ2FnZUhlYWRlciBBIHZlcnkgYnJlYWQgZGVmaW5pdGlvbiBvZiBhIGJhZ2dhZ2UgaGVhZGVyIGFzIGl0IG1pZ2h0IGFwcGVhciBpbiB2YXJpb3VzIGZyYW1ld29ya3MuXG4gKiBAcmV0dXJucyBUaGUgRHluYW1pYyBTYW1wbGluZyBDb250ZXh0IHRoYXQgd2FzIGZvdW5kIG9uIGBiYWdnYWdlSGVhZGVyYCwgaWYgdGhlcmUgd2FzIGFueSwgYHVuZGVmaW5lZGAgb3RoZXJ3aXNlLlxuICovXG5mdW5jdGlvbiBiYWdnYWdlSGVhZGVyVG9EeW5hbWljU2FtcGxpbmdDb250ZXh0KFxuICAvLyBWZXJ5IGxpYmVyYWwgZGVmaW5pdGlvbiBvZiB3aGF0IGFueSBpbmNvbWluZyBoZWFkZXIgbWlnaHQgbG9vayBsaWtlXG4gIGJhZ2dhZ2VIZWFkZXIsXG4pIHtcbiAgY29uc3QgYmFnZ2FnZU9iamVjdCA9IHBhcnNlQmFnZ2FnZUhlYWRlcihiYWdnYWdlSGVhZGVyKTtcblxuICBpZiAoIWJhZ2dhZ2VPYmplY3QpIHtcbiAgICByZXR1cm4gdW5kZWZpbmVkO1xuICB9XG5cbiAgLy8gUmVhZCBhbGwgXCJzZW50cnktXCIgcHJlZml4ZWQgdmFsdWVzIG91dCBvZiB0aGUgYmFnZ2FnZSBvYmplY3QgYW5kIHB1dCBpdCBvbnRvIGEgZHluYW1pYyBzYW1wbGluZyBjb250ZXh0IG9iamVjdC5cbiAgY29uc3QgZHluYW1pY1NhbXBsaW5nQ29udGV4dCA9IE9iamVjdC5lbnRyaWVzKGJhZ2dhZ2VPYmplY3QpLnJlZHVjZSgoYWNjLCBba2V5LCB2YWx1ZV0pID0+IHtcbiAgICBpZiAoa2V5Lm1hdGNoKFNFTlRSWV9CQUdHQUdFX0tFWV9QUkVGSVhfUkVHRVgpKSB7XG4gICAgICBjb25zdCBub25QcmVmaXhlZEtleSA9IGtleS5zbGljZShTRU5UUllfQkFHR0FHRV9LRVlfUFJFRklYLmxlbmd0aCk7XG4gICAgICBhY2Nbbm9uUHJlZml4ZWRLZXldID0gdmFsdWU7XG4gICAgfVxuICAgIHJldHVybiBhY2M7XG4gIH0sIHt9KTtcblxuICAvLyBPbmx5IHJldHVybiBhIGR5bmFtaWMgc2FtcGxpbmcgY29udGV4dCBvYmplY3QgaWYgdGhlcmUgYXJlIGtleXMgaW4gaXQuXG4gIC8vIEEga2V5bGVzcyBvYmplY3QgbWVhbnMgdGhlcmUgd2VyZSBubyBzZW50cnkgdmFsdWVzIG9uIHRoZSBoZWFkZXIsIHdoaWNoIG1lYW5zIHRoYXQgdGhlcmUgaXMgbm8gRFNDLlxuICBpZiAoT2JqZWN0LmtleXMoZHluYW1pY1NhbXBsaW5nQ29udGV4dCkubGVuZ3RoID4gMCkge1xuICAgIHJldHVybiBkeW5hbWljU2FtcGxpbmdDb250ZXh0IDtcbiAgfSBlbHNlIHtcbiAgICByZXR1cm4gdW5kZWZpbmVkO1xuICB9XG59XG5cbi8qKlxuICogVHVybnMgYSBEeW5hbWljIFNhbXBsaW5nIE9iamVjdCBpbnRvIGEgYmFnZ2FnZSBoZWFkZXIgYnkgcHJlZml4aW5nIGFsbCB0aGUga2V5cyBvbiB0aGUgb2JqZWN0IHdpdGggXCJzZW50cnktXCIuXG4gKlxuICogQHBhcmFtIGR5bmFtaWNTYW1wbGluZ0NvbnRleHQgVGhlIER5bmFtaWMgU2FtcGxpbmcgQ29udGV4dCB0byB0dXJuIGludG8gYSBoZWFkZXIuIEZvciBjb252ZW5pZW5jZSBhbmQgY29tcGF0aWJpbGl0eVxuICogd2l0aCB0aGUgYGdldER5bmFtaWNTYW1wbGluZ0NvbnRleHRgIG1ldGhvZCBvbiB0aGUgVHJhbnNhY3Rpb24gY2xhc3MgLHRoaXMgYXJndW1lbnQgY2FuIGFsc28gYmUgYHVuZGVmaW5lZGAuIElmIGl0IGlzXG4gKiBgdW5kZWZpbmVkYCB0aGUgZnVuY3Rpb24gd2lsbCByZXR1cm4gYHVuZGVmaW5lZGAuXG4gKiBAcmV0dXJucyBhIGJhZ2dhZ2UgaGVhZGVyLCBjcmVhdGVkIGZyb20gYGR5bmFtaWNTYW1wbGluZ0NvbnRleHRgLCBvciBgdW5kZWZpbmVkYCBlaXRoZXIgaWYgYGR5bmFtaWNTYW1wbGluZ0NvbnRleHRgXG4gKiB3YXMgYHVuZGVmaW5lZGAsIG9yIGlmIGBkeW5hbWljU2FtcGxpbmdDb250ZXh0YCBkaWRuJ3QgY29udGFpbiBhbnkgdmFsdWVzLlxuICovXG5mdW5jdGlvbiBkeW5hbWljU2FtcGxpbmdDb250ZXh0VG9TZW50cnlCYWdnYWdlSGVhZGVyKFxuICAvLyB0aGlzIGFsc28gdGFrZXMgdW5kZWZpbmVkIGZvciBjb252ZW5pZW5jZSBhbmQgYnVuZGxlIHNpemUgaW4gb3RoZXIgcGxhY2VzXG4gIGR5bmFtaWNTYW1wbGluZ0NvbnRleHQsXG4pIHtcbiAgaWYgKCFkeW5hbWljU2FtcGxpbmdDb250ZXh0KSB7XG4gICAgcmV0dXJuIHVuZGVmaW5lZDtcbiAgfVxuXG4gIC8vIFByZWZpeCBhbGwgRFNDIGtleXMgd2l0aCBcInNlbnRyeS1cIiBhbmQgcHV0IHRoZW0gaW50byBhIG5ldyBvYmplY3RcbiAgY29uc3Qgc2VudHJ5UHJlZml4ZWREU0MgPSBPYmplY3QuZW50cmllcyhkeW5hbWljU2FtcGxpbmdDb250ZXh0KS5yZWR1Y2UoXG4gICAgKGFjYywgW2RzY0tleSwgZHNjVmFsdWVdKSA9PiB7XG4gICAgICBpZiAoZHNjVmFsdWUpIHtcbiAgICAgICAgYWNjW2Ake1NFTlRSWV9CQUdHQUdFX0tFWV9QUkVGSVh9JHtkc2NLZXl9YF0gPSBkc2NWYWx1ZTtcbiAgICAgIH1cbiAgICAgIHJldHVybiBhY2M7XG4gICAgfSxcbiAgICB7fSxcbiAgKTtcblxuICByZXR1cm4gb2JqZWN0VG9CYWdnYWdlSGVhZGVyKHNlbnRyeVByZWZpeGVkRFNDKTtcbn1cblxuLyoqXG4gKiBUYWtlIGEgYmFnZ2FnZSBoZWFkZXIgYW5kIHBhcnNlIGl0IGludG8gYW4gb2JqZWN0LlxuICovXG5mdW5jdGlvbiBwYXJzZUJhZ2dhZ2VIZWFkZXIoXG4gIGJhZ2dhZ2VIZWFkZXIsXG4pIHtcbiAgaWYgKCFiYWdnYWdlSGVhZGVyIHx8ICghaXMuaXNTdHJpbmcoYmFnZ2FnZUhlYWRlcikgJiYgIUFycmF5LmlzQXJyYXkoYmFnZ2FnZUhlYWRlcikpKSB7XG4gICAgcmV0dXJuIHVuZGVmaW5lZDtcbiAgfVxuXG4gIGlmIChBcnJheS5pc0FycmF5KGJhZ2dhZ2VIZWFkZXIpKSB7XG4gICAgLy8gQ29tYmluZSBhbGwgYmFnZ2FnZSBoZWFkZXJzIGludG8gb25lIG9iamVjdCBjb250YWluaW5nIHRoZSBiYWdnYWdlIHZhbHVlcyBzbyB3ZSBjYW4gbGF0ZXIgcmVhZCB0aGUgU2VudHJ5LURTQy12YWx1ZXMgZnJvbSBpdFxuICAgIHJldHVybiBiYWdnYWdlSGVhZGVyLnJlZHVjZSgoYWNjLCBjdXJyKSA9PiB7XG4gICAgICBjb25zdCBjdXJyQmFnZ2FnZU9iamVjdCA9IGJhZ2dhZ2VIZWFkZXJUb09iamVjdChjdXJyKTtcbiAgICAgIE9iamVjdC5lbnRyaWVzKGN1cnJCYWdnYWdlT2JqZWN0KS5mb3JFYWNoKChba2V5LCB2YWx1ZV0pID0+IHtcbiAgICAgICAgYWNjW2tleV0gPSB2YWx1ZTtcbiAgICAgIH0pO1xuICAgICAgcmV0dXJuIGFjYztcbiAgICB9LCB7fSk7XG4gIH1cblxuICByZXR1cm4gYmFnZ2FnZUhlYWRlclRvT2JqZWN0KGJhZ2dhZ2VIZWFkZXIpO1xufVxuXG4vKipcbiAqIFdpbGwgcGFyc2UgYSBiYWdnYWdlIGhlYWRlciwgd2hpY2ggaXMgYSBzaW1wbGUga2V5LXZhbHVlIG1hcCwgaW50byBhIGZsYXQgb2JqZWN0LlxuICpcbiAqIEBwYXJhbSBiYWdnYWdlSGVhZGVyIFRoZSBiYWdnYWdlIGhlYWRlciB0byBwYXJzZS5cbiAqIEByZXR1cm5zIGEgZmxhdCBvYmplY3QgY29udGFpbmluZyBhbGwgdGhlIGtleS12YWx1ZSBwYWlycyBmcm9tIGBiYWdnYWdlSGVhZGVyYC5cbiAqL1xuZnVuY3Rpb24gYmFnZ2FnZUhlYWRlclRvT2JqZWN0KGJhZ2dhZ2VIZWFkZXIpIHtcbiAgcmV0dXJuIGJhZ2dhZ2VIZWFkZXJcbiAgICAuc3BsaXQoJywnKVxuICAgIC5tYXAoYmFnZ2FnZUVudHJ5ID0+XG4gICAgICBiYWdnYWdlRW50cnkuc3BsaXQoJz0nKS5tYXAoa2V5T3JWYWx1ZSA9PiB7XG4gICAgICAgIHRyeSB7XG4gICAgICAgICAgcmV0dXJuIGRlY29kZVVSSUNvbXBvbmVudChrZXlPclZhbHVlLnRyaW0oKSk7XG4gICAgICAgIH0gY2F0Y2gge1xuICAgICAgICAgIC8vIFdlIGlnbm9yZSBlcnJvcnMgaGVyZSwgZS5nLiBpZiB0aGUgdmFsdWUgY2Fubm90IGJlIFVSTCBkZWNvZGVkLlxuICAgICAgICAgIC8vIFRoaXMgd2lsbCB0aGVuIGJlIHNraXBwZWQgaW4gdGhlIG5leHQgc3RlcFxuICAgICAgICAgIHJldHVybjtcbiAgICAgICAgfVxuICAgICAgfSksXG4gICAgKVxuICAgIC5yZWR1Y2UoKGFjYywgW2tleSwgdmFsdWVdKSA9PiB7XG4gICAgICBpZiAoa2V5ICYmIHZhbHVlKSB7XG4gICAgICAgIGFjY1trZXldID0gdmFsdWU7XG4gICAgICB9XG4gICAgICByZXR1cm4gYWNjO1xuICAgIH0sIHt9KTtcbn1cblxuLyoqXG4gKiBUdXJucyBhIGZsYXQgb2JqZWN0IChrZXktdmFsdWUgcGFpcnMpIGludG8gYSBiYWdnYWdlIGhlYWRlciwgd2hpY2ggaXMgYWxzbyBqdXN0IGtleS12YWx1ZSBwYWlycy5cbiAqXG4gKiBAcGFyYW0gb2JqZWN0IFRoZSBvYmplY3QgdG8gdHVybiBpbnRvIGEgYmFnZ2FnZSBoZWFkZXIuXG4gKiBAcmV0dXJucyBhIGJhZ2dhZ2UgaGVhZGVyIHN0cmluZywgb3IgYHVuZGVmaW5lZGAgaWYgdGhlIG9iamVjdCBkaWRuJ3QgaGF2ZSBhbnkgdmFsdWVzLCBzaW5jZSBhbiBlbXB0eSBiYWdnYWdlIGhlYWRlclxuICogaXMgbm90IHNwZWMgY29tcGxpYW50LlxuICovXG5mdW5jdGlvbiBvYmplY3RUb0JhZ2dhZ2VIZWFkZXIob2JqZWN0KSB7XG4gIGlmIChPYmplY3Qua2V5cyhvYmplY3QpLmxlbmd0aCA9PT0gMCkge1xuICAgIC8vIEFuIGVtcHR5IGJhZ2dhZ2UgaGVhZGVyIGlzIG5vdCBzcGVjIGNvbXBsaWFudDogV2UgcmV0dXJuIHVuZGVmaW5lZC5cbiAgICByZXR1cm4gdW5kZWZpbmVkO1xuICB9XG5cbiAgcmV0dXJuIE9iamVjdC5lbnRyaWVzKG9iamVjdCkucmVkdWNlKChiYWdnYWdlSGVhZGVyLCBbb2JqZWN0S2V5LCBvYmplY3RWYWx1ZV0sIGN1cnJlbnRJbmRleCkgPT4ge1xuICAgIGNvbnN0IGJhZ2dhZ2VFbnRyeSA9IGAke2VuY29kZVVSSUNvbXBvbmVudChvYmplY3RLZXkpfT0ke2VuY29kZVVSSUNvbXBvbmVudChvYmplY3RWYWx1ZSl9YDtcbiAgICBjb25zdCBuZXdCYWdnYWdlSGVhZGVyID0gY3VycmVudEluZGV4ID09PSAwID8gYmFnZ2FnZUVudHJ5IDogYCR7YmFnZ2FnZUhlYWRlcn0sJHtiYWdnYWdlRW50cnl9YDtcbiAgICBpZiAobmV3QmFnZ2FnZUhlYWRlci5sZW5ndGggPiBNQVhfQkFHR0FHRV9TVFJJTkdfTEVOR1RIKSB7XG4gICAgICBkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEICYmXG4gICAgICAgIGRlYnVnTG9nZ2VyLmRlYnVnLndhcm4oXG4gICAgICAgICAgYE5vdCBhZGRpbmcga2V5OiAke29iamVjdEtleX0gd2l0aCB2YWw6ICR7b2JqZWN0VmFsdWV9IHRvIGJhZ2dhZ2UgaGVhZGVyIGR1ZSB0byBleGNlZWRpbmcgYmFnZ2FnZSBzaXplIGxpbWl0cy5gLFxuICAgICAgICApO1xuICAgICAgcmV0dXJuIGJhZ2dhZ2VIZWFkZXI7XG4gICAgfSBlbHNlIHtcbiAgICAgIHJldHVybiBuZXdCYWdnYWdlSGVhZGVyO1xuICAgIH1cbiAgfSwgJycpO1xufVxuXG5leHBvcnRzLk1BWF9CQUdHQUdFX1NUUklOR19MRU5HVEggPSBNQVhfQkFHR0FHRV9TVFJJTkdfTEVOR1RIO1xuZXhwb3J0cy5TRU5UUllfQkFHR0FHRV9LRVlfUFJFRklYID0gU0VOVFJZX0JBR0dBR0VfS0VZX1BSRUZJWDtcbmV4cG9ydHMuU0VOVFJZX0JBR0dBR0VfS0VZX1BSRUZJWF9SRUdFWCA9IFNFTlRSWV9CQUdHQUdFX0tFWV9QUkVGSVhfUkVHRVg7XG5leHBvcnRzLmJhZ2dhZ2VIZWFkZXJUb0R5bmFtaWNTYW1wbGluZ0NvbnRleHQgPSBiYWdnYWdlSGVhZGVyVG9EeW5hbWljU2FtcGxpbmdDb250ZXh0O1xuZXhwb3J0cy5keW5hbWljU2FtcGxpbmdDb250ZXh0VG9TZW50cnlCYWdnYWdlSGVhZGVyID0gZHluYW1pY1NhbXBsaW5nQ29udGV4dFRvU2VudHJ5QmFnZ2FnZUhlYWRlcjtcbmV4cG9ydHMub2JqZWN0VG9CYWdnYWdlSGVhZGVyID0gb2JqZWN0VG9CYWdnYWdlSGVhZGVyO1xuZXhwb3J0cy5wYXJzZUJhZ2dhZ2VIZWFkZXIgPSBwYXJzZUJhZ2dhZ2VIZWFkZXI7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1iYWdnYWdlLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/baggage.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/breadcrumb-log-level.js":
/*!******************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/breadcrumb-log-level.js ***!
  \******************************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n/**\n * Determine a breadcrumb's log level (only `warning` or `error`) based on an HTTP status code.\n */\nfunction getBreadcrumbLogLevelFromHttpStatusCode(statusCode) {\n  // NOTE: undefined defaults to 'info' in Sentry\n  if (statusCode === undefined) {\n    return undefined;\n  } else if (statusCode >= 400 && statusCode < 500) {\n    return 'warning';\n  } else if (statusCode >= 500) {\n    return 'error';\n  } else {\n    return undefined;\n  }\n}\n\nexports.getBreadcrumbLogLevelFromHttpStatusCode = getBreadcrumbLogLevelFromHttpStatusCode;\n//# sourceMappingURL=breadcrumb-log-level.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9icmVhZGNydW1iLWxvZy1sZXZlbC5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLElBQUk7QUFDSjtBQUNBLElBQUk7QUFDSjtBQUNBLElBQUk7QUFDSjtBQUNBO0FBQ0E7O0FBRUEsK0NBQStDO0FBQy9DIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvYnJlYWRjcnVtYi1sb2ctbGV2ZWwuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbi8qKlxuICogRGV0ZXJtaW5lIGEgYnJlYWRjcnVtYidzIGxvZyBsZXZlbCAob25seSBgd2FybmluZ2Agb3IgYGVycm9yYCkgYmFzZWQgb24gYW4gSFRUUCBzdGF0dXMgY29kZS5cbiAqL1xuZnVuY3Rpb24gZ2V0QnJlYWRjcnVtYkxvZ0xldmVsRnJvbUh0dHBTdGF0dXNDb2RlKHN0YXR1c0NvZGUpIHtcbiAgLy8gTk9URTogdW5kZWZpbmVkIGRlZmF1bHRzIHRvICdpbmZvJyBpbiBTZW50cnlcbiAgaWYgKHN0YXR1c0NvZGUgPT09IHVuZGVmaW5lZCkge1xuICAgIHJldHVybiB1bmRlZmluZWQ7XG4gIH0gZWxzZSBpZiAoc3RhdHVzQ29kZSA+PSA0MDAgJiYgc3RhdHVzQ29kZSA8IDUwMCkge1xuICAgIHJldHVybiAnd2FybmluZyc7XG4gIH0gZWxzZSBpZiAoc3RhdHVzQ29kZSA+PSA1MDApIHtcbiAgICByZXR1cm4gJ2Vycm9yJztcbiAgfSBlbHNlIHtcbiAgICByZXR1cm4gdW5kZWZpbmVkO1xuICB9XG59XG5cbmV4cG9ydHMuZ2V0QnJlYWRjcnVtYkxvZ0xldmVsRnJvbUh0dHBTdGF0dXNDb2RlID0gZ2V0QnJlYWRjcnVtYkxvZ0xldmVsRnJvbUh0dHBTdGF0dXNDb2RlO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9YnJlYWRjcnVtYi1sb2ctbGV2ZWwuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/breadcrumb-log-level.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/browser.js":
/*!*****************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/browser.js ***!
  \*****************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst is = __webpack_require__(/*! ./is.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js\");\nconst worldwide = __webpack_require__(/*! ./worldwide.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/worldwide.js\");\n\nconst WINDOW = worldwide.GLOBAL_OBJ ;\n\nconst DEFAULT_MAX_STRING_LENGTH = 80;\n\n/**\n * Given a child DOM element, returns a query-selector statement describing that\n * and its ancestors\n * e.g. [HTMLElement] => body > div > input#foo.btn[name=baz]\n * @returns generated DOM path\n */\nfunction htmlTreeAsString(\n  elem,\n  options = {},\n) {\n  if (!elem) {\n    return '<unknown>';\n  }\n\n  // try/catch both:\n  // - accessing event.target (see getsentry/raven-js#838, #768)\n  // - `htmlTreeAsString` because it's complex, and just accessing the DOM incorrectly\n  // - can throw an exception in some circumstances.\n  try {\n    let currentElem = elem ;\n    const MAX_TRAVERSE_HEIGHT = 5;\n    const out = [];\n    let height = 0;\n    let len = 0;\n    const separator = ' > ';\n    const sepLength = separator.length;\n    let nextStr;\n    const keyAttrs = Array.isArray(options) ? options : options.keyAttrs;\n    const maxStringLength = (!Array.isArray(options) && options.maxStringLength) || DEFAULT_MAX_STRING_LENGTH;\n\n    while (currentElem && height++ < MAX_TRAVERSE_HEIGHT) {\n      nextStr = _htmlElementAsString(currentElem, keyAttrs);\n      // bail out if\n      // - nextStr is the 'html' element\n      // - the length of the string that would be created exceeds maxStringLength\n      //   (ignore this limit if we are on the first iteration)\n      if (nextStr === 'html' || (height > 1 && len + out.length * sepLength + nextStr.length >= maxStringLength)) {\n        break;\n      }\n\n      out.push(nextStr);\n\n      len += nextStr.length;\n      currentElem = currentElem.parentNode;\n    }\n\n    return out.reverse().join(separator);\n  } catch {\n    return '<unknown>';\n  }\n}\n\n/**\n * Returns a simple, query-selector representation of a DOM element\n * e.g. [HTMLElement] => input#foo.btn[name=baz]\n * @returns generated DOM path\n */\nfunction _htmlElementAsString(el, keyAttrs) {\n  const elem = el\n\n;\n\n  const out = [];\n\n  if (!elem?.tagName) {\n    return '';\n  }\n\n  // @ts-expect-error WINDOW has HTMLElement\n  if (WINDOW.HTMLElement) {\n    // If using the component name annotation plugin, this value may be available on the DOM node\n    if (elem instanceof HTMLElement && elem.dataset) {\n      if (elem.dataset['sentryComponent']) {\n        return elem.dataset['sentryComponent'];\n      }\n      if (elem.dataset['sentryElement']) {\n        return elem.dataset['sentryElement'];\n      }\n    }\n  }\n\n  out.push(elem.tagName.toLowerCase());\n\n  // Pairs of attribute keys defined in `serializeAttribute` and their values on element.\n  const keyAttrPairs = keyAttrs?.length\n    ? keyAttrs.filter(keyAttr => elem.getAttribute(keyAttr)).map(keyAttr => [keyAttr, elem.getAttribute(keyAttr)])\n    : null;\n\n  if (keyAttrPairs?.length) {\n    keyAttrPairs.forEach(keyAttrPair => {\n      out.push(`[${keyAttrPair[0]}=\"${keyAttrPair[1]}\"]`);\n    });\n  } else {\n    if (elem.id) {\n      out.push(`#${elem.id}`);\n    }\n\n    const className = elem.className;\n    if (className && is.isString(className)) {\n      const classes = className.split(/\\s+/);\n      for (const c of classes) {\n        out.push(`.${c}`);\n      }\n    }\n  }\n  const allowedAttrs = ['aria-label', 'type', 'name', 'title', 'alt'];\n  for (const k of allowedAttrs) {\n    const attr = elem.getAttribute(k);\n    if (attr) {\n      out.push(`[${k}=\"${attr}\"]`);\n    }\n  }\n\n  return out.join('');\n}\n\n/**\n * A safe form of location.href\n */\nfunction getLocationHref() {\n  try {\n    return WINDOW.document.location.href;\n  } catch {\n    return '';\n  }\n}\n\n/**\n * Given a DOM element, traverses up the tree until it finds the first ancestor node\n * that has the `data-sentry-component` or `data-sentry-element` attribute with `data-sentry-component` taking\n * precedence. This attribute is added at build-time by projects that have the component name annotation plugin installed.\n *\n * @returns a string representation of the component for the provided DOM element, or `null` if not found\n */\nfunction getComponentName(elem) {\n  // @ts-expect-error WINDOW has HTMLElement\n  if (!WINDOW.HTMLElement) {\n    return null;\n  }\n\n  let currentElem = elem ;\n  const MAX_TRAVERSE_HEIGHT = 5;\n  for (let i = 0; i < MAX_TRAVERSE_HEIGHT; i++) {\n    if (!currentElem) {\n      return null;\n    }\n\n    if (currentElem instanceof HTMLElement) {\n      if (currentElem.dataset['sentryComponent']) {\n        return currentElem.dataset['sentryComponent'];\n      }\n      if (currentElem.dataset['sentryElement']) {\n        return currentElem.dataset['sentryElement'];\n      }\n    }\n\n    currentElem = currentElem.parentNode;\n  }\n\n  return null;\n}\n\nexports.getComponentName = getComponentName;\nexports.getLocationHref = getLocationHref;\nexports.htmlTreeAsString = htmlTreeAsString;\n//# sourceMappingURL=browser.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9icm93c2VyLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLFdBQVcsbUJBQU8sQ0FBQywrR0FBUztBQUM1QixrQkFBa0IsbUJBQU8sQ0FBQyw2SEFBZ0I7O0FBRTFDOztBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxjQUFjO0FBQ2Q7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQSxJQUFJO0FBQ0o7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLG1CQUFtQixlQUFlLElBQUksZUFBZTtBQUNyRCxLQUFLO0FBQ0wsSUFBSTtBQUNKO0FBQ0EsbUJBQW1CLFFBQVE7QUFDM0I7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQSxxQkFBcUIsRUFBRTtBQUN2QjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLG1CQUFtQixFQUFFLElBQUksS0FBSztBQUM5QjtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsSUFBSTtBQUNKO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLGtCQUFrQix5QkFBeUI7QUFDM0M7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBOztBQUVBLHdCQUF3QjtBQUN4Qix1QkFBdUI7QUFDdkIsd0JBQXdCO0FBQ3hCIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvYnJvd3Nlci5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgaXMgPSByZXF1aXJlKCcuL2lzLmpzJyk7XG5jb25zdCB3b3JsZHdpZGUgPSByZXF1aXJlKCcuL3dvcmxkd2lkZS5qcycpO1xuXG5jb25zdCBXSU5ET1cgPSB3b3JsZHdpZGUuR0xPQkFMX09CSiA7XG5cbmNvbnN0IERFRkFVTFRfTUFYX1NUUklOR19MRU5HVEggPSA4MDtcblxuLyoqXG4gKiBHaXZlbiBhIGNoaWxkIERPTSBlbGVtZW50LCByZXR1cm5zIGEgcXVlcnktc2VsZWN0b3Igc3RhdGVtZW50IGRlc2NyaWJpbmcgdGhhdFxuICogYW5kIGl0cyBhbmNlc3RvcnNcbiAqIGUuZy4gW0hUTUxFbGVtZW50XSA9PiBib2R5ID4gZGl2ID4gaW5wdXQjZm9vLmJ0bltuYW1lPWJhel1cbiAqIEByZXR1cm5zIGdlbmVyYXRlZCBET00gcGF0aFxuICovXG5mdW5jdGlvbiBodG1sVHJlZUFzU3RyaW5nKFxuICBlbGVtLFxuICBvcHRpb25zID0ge30sXG4pIHtcbiAgaWYgKCFlbGVtKSB7XG4gICAgcmV0dXJuICc8dW5rbm93bj4nO1xuICB9XG5cbiAgLy8gdHJ5L2NhdGNoIGJvdGg6XG4gIC8vIC0gYWNjZXNzaW5nIGV2ZW50LnRhcmdldCAoc2VlIGdldHNlbnRyeS9yYXZlbi1qcyM4MzgsICM3NjgpXG4gIC8vIC0gYGh0bWxUcmVlQXNTdHJpbmdgIGJlY2F1c2UgaXQncyBjb21wbGV4LCBhbmQganVzdCBhY2Nlc3NpbmcgdGhlIERPTSBpbmNvcnJlY3RseVxuICAvLyAtIGNhbiB0aHJvdyBhbiBleGNlcHRpb24gaW4gc29tZSBjaXJjdW1zdGFuY2VzLlxuICB0cnkge1xuICAgIGxldCBjdXJyZW50RWxlbSA9IGVsZW0gO1xuICAgIGNvbnN0IE1BWF9UUkFWRVJTRV9IRUlHSFQgPSA1O1xuICAgIGNvbnN0IG91dCA9IFtdO1xuICAgIGxldCBoZWlnaHQgPSAwO1xuICAgIGxldCBsZW4gPSAwO1xuICAgIGNvbnN0IHNlcGFyYXRvciA9ICcgPiAnO1xuICAgIGNvbnN0IHNlcExlbmd0aCA9IHNlcGFyYXRvci5sZW5ndGg7XG4gICAgbGV0IG5leHRTdHI7XG4gICAgY29uc3Qga2V5QXR0cnMgPSBBcnJheS5pc0FycmF5KG9wdGlvbnMpID8gb3B0aW9ucyA6IG9wdGlvbnMua2V5QXR0cnM7XG4gICAgY29uc3QgbWF4U3RyaW5nTGVuZ3RoID0gKCFBcnJheS5pc0FycmF5KG9wdGlvbnMpICYmIG9wdGlvbnMubWF4U3RyaW5nTGVuZ3RoKSB8fCBERUZBVUxUX01BWF9TVFJJTkdfTEVOR1RIO1xuXG4gICAgd2hpbGUgKGN1cnJlbnRFbGVtICYmIGhlaWdodCsrIDwgTUFYX1RSQVZFUlNFX0hFSUdIVCkge1xuICAgICAgbmV4dFN0ciA9IF9odG1sRWxlbWVudEFzU3RyaW5nKGN1cnJlbnRFbGVtLCBrZXlBdHRycyk7XG4gICAgICAvLyBiYWlsIG91dCBpZlxuICAgICAgLy8gLSBuZXh0U3RyIGlzIHRoZSAnaHRtbCcgZWxlbWVudFxuICAgICAgLy8gLSB0aGUgbGVuZ3RoIG9mIHRoZSBzdHJpbmcgdGhhdCB3b3VsZCBiZSBjcmVhdGVkIGV4Y2VlZHMgbWF4U3RyaW5nTGVuZ3RoXG4gICAgICAvLyAgIChpZ25vcmUgdGhpcyBsaW1pdCBpZiB3ZSBhcmUgb24gdGhlIGZpcnN0IGl0ZXJhdGlvbilcbiAgICAgIGlmIChuZXh0U3RyID09PSAnaHRtbCcgfHwgKGhlaWdodCA+IDEgJiYgbGVuICsgb3V0Lmxlbmd0aCAqIHNlcExlbmd0aCArIG5leHRTdHIubGVuZ3RoID49IG1heFN0cmluZ0xlbmd0aCkpIHtcbiAgICAgICAgYnJlYWs7XG4gICAgICB9XG5cbiAgICAgIG91dC5wdXNoKG5leHRTdHIpO1xuXG4gICAgICBsZW4gKz0gbmV4dFN0ci5sZW5ndGg7XG4gICAgICBjdXJyZW50RWxlbSA9IGN1cnJlbnRFbGVtLnBhcmVudE5vZGU7XG4gICAgfVxuXG4gICAgcmV0dXJuIG91dC5yZXZlcnNlKCkuam9pbihzZXBhcmF0b3IpO1xuICB9IGNhdGNoIHtcbiAgICByZXR1cm4gJzx1bmtub3duPic7XG4gIH1cbn1cblxuLyoqXG4gKiBSZXR1cm5zIGEgc2ltcGxlLCBxdWVyeS1zZWxlY3RvciByZXByZXNlbnRhdGlvbiBvZiBhIERPTSBlbGVtZW50XG4gKiBlLmcuIFtIVE1MRWxlbWVudF0gPT4gaW5wdXQjZm9vLmJ0bltuYW1lPWJhel1cbiAqIEByZXR1cm5zIGdlbmVyYXRlZCBET00gcGF0aFxuICovXG5mdW5jdGlvbiBfaHRtbEVsZW1lbnRBc1N0cmluZyhlbCwga2V5QXR0cnMpIHtcbiAgY29uc3QgZWxlbSA9IGVsXG5cbjtcblxuICBjb25zdCBvdXQgPSBbXTtcblxuICBpZiAoIWVsZW0/LnRhZ05hbWUpIHtcbiAgICByZXR1cm4gJyc7XG4gIH1cblxuICAvLyBAdHMtZXhwZWN0LWVycm9yIFdJTkRPVyBoYXMgSFRNTEVsZW1lbnRcbiAgaWYgKFdJTkRPVy5IVE1MRWxlbWVudCkge1xuICAgIC8vIElmIHVzaW5nIHRoZSBjb21wb25lbnQgbmFtZSBhbm5vdGF0aW9uIHBsdWdpbiwgdGhpcyB2YWx1ZSBtYXkgYmUgYXZhaWxhYmxlIG9uIHRoZSBET00gbm9kZVxuICAgIGlmIChlbGVtIGluc3RhbmNlb2YgSFRNTEVsZW1lbnQgJiYgZWxlbS5kYXRhc2V0KSB7XG4gICAgICBpZiAoZWxlbS5kYXRhc2V0WydzZW50cnlDb21wb25lbnQnXSkge1xuICAgICAgICByZXR1cm4gZWxlbS5kYXRhc2V0WydzZW50cnlDb21wb25lbnQnXTtcbiAgICAgIH1cbiAgICAgIGlmIChlbGVtLmRhdGFzZXRbJ3NlbnRyeUVsZW1lbnQnXSkge1xuICAgICAgICByZXR1cm4gZWxlbS5kYXRhc2V0WydzZW50cnlFbGVtZW50J107XG4gICAgICB9XG4gICAgfVxuICB9XG5cbiAgb3V0LnB1c2goZWxlbS50YWdOYW1lLnRvTG93ZXJDYXNlKCkpO1xuXG4gIC8vIFBhaXJzIG9mIGF0dHJpYnV0ZSBrZXlzIGRlZmluZWQgaW4gYHNlcmlhbGl6ZUF0dHJpYnV0ZWAgYW5kIHRoZWlyIHZhbHVlcyBvbiBlbGVtZW50LlxuICBjb25zdCBrZXlBdHRyUGFpcnMgPSBrZXlBdHRycz8ubGVuZ3RoXG4gICAgPyBrZXlBdHRycy5maWx0ZXIoa2V5QXR0ciA9PiBlbGVtLmdldEF0dHJpYnV0ZShrZXlBdHRyKSkubWFwKGtleUF0dHIgPT4gW2tleUF0dHIsIGVsZW0uZ2V0QXR0cmlidXRlKGtleUF0dHIpXSlcbiAgICA6IG51bGw7XG5cbiAgaWYgKGtleUF0dHJQYWlycz8ubGVuZ3RoKSB7XG4gICAga2V5QXR0clBhaXJzLmZvckVhY2goa2V5QXR0clBhaXIgPT4ge1xuICAgICAgb3V0LnB1c2goYFske2tleUF0dHJQYWlyWzBdfT1cIiR7a2V5QXR0clBhaXJbMV19XCJdYCk7XG4gICAgfSk7XG4gIH0gZWxzZSB7XG4gICAgaWYgKGVsZW0uaWQpIHtcbiAgICAgIG91dC5wdXNoKGAjJHtlbGVtLmlkfWApO1xuICAgIH1cblxuICAgIGNvbnN0IGNsYXNzTmFtZSA9IGVsZW0uY2xhc3NOYW1lO1xuICAgIGlmIChjbGFzc05hbWUgJiYgaXMuaXNTdHJpbmcoY2xhc3NOYW1lKSkge1xuICAgICAgY29uc3QgY2xhc3NlcyA9IGNsYXNzTmFtZS5zcGxpdCgvXFxzKy8pO1xuICAgICAgZm9yIChjb25zdCBjIG9mIGNsYXNzZXMpIHtcbiAgICAgICAgb3V0LnB1c2goYC4ke2N9YCk7XG4gICAgICB9XG4gICAgfVxuICB9XG4gIGNvbnN0IGFsbG93ZWRBdHRycyA9IFsnYXJpYS1sYWJlbCcsICd0eXBlJywgJ25hbWUnLCAndGl0bGUnLCAnYWx0J107XG4gIGZvciAoY29uc3QgayBvZiBhbGxvd2VkQXR0cnMpIHtcbiAgICBjb25zdCBhdHRyID0gZWxlbS5nZXRBdHRyaWJ1dGUoayk7XG4gICAgaWYgKGF0dHIpIHtcbiAgICAgIG91dC5wdXNoKGBbJHtrfT1cIiR7YXR0cn1cIl1gKTtcbiAgICB9XG4gIH1cblxuICByZXR1cm4gb3V0LmpvaW4oJycpO1xufVxuXG4vKipcbiAqIEEgc2FmZSBmb3JtIG9mIGxvY2F0aW9uLmhyZWZcbiAqL1xuZnVuY3Rpb24gZ2V0TG9jYXRpb25IcmVmKCkge1xuICB0cnkge1xuICAgIHJldHVybiBXSU5ET1cuZG9jdW1lbnQubG9jYXRpb24uaHJlZjtcbiAgfSBjYXRjaCB7XG4gICAgcmV0dXJuICcnO1xuICB9XG59XG5cbi8qKlxuICogR2l2ZW4gYSBET00gZWxlbWVudCwgdHJhdmVyc2VzIHVwIHRoZSB0cmVlIHVudGlsIGl0IGZpbmRzIHRoZSBmaXJzdCBhbmNlc3RvciBub2RlXG4gKiB0aGF0IGhhcyB0aGUgYGRhdGEtc2VudHJ5LWNvbXBvbmVudGAgb3IgYGRhdGEtc2VudHJ5LWVsZW1lbnRgIGF0dHJpYnV0ZSB3aXRoIGBkYXRhLXNlbnRyeS1jb21wb25lbnRgIHRha2luZ1xuICogcHJlY2VkZW5jZS4gVGhpcyBhdHRyaWJ1dGUgaXMgYWRkZWQgYXQgYnVpbGQtdGltZSBieSBwcm9qZWN0cyB0aGF0IGhhdmUgdGhlIGNvbXBvbmVudCBuYW1lIGFubm90YXRpb24gcGx1Z2luIGluc3RhbGxlZC5cbiAqXG4gKiBAcmV0dXJucyBhIHN0cmluZyByZXByZXNlbnRhdGlvbiBvZiB0aGUgY29tcG9uZW50IGZvciB0aGUgcHJvdmlkZWQgRE9NIGVsZW1lbnQsIG9yIGBudWxsYCBpZiBub3QgZm91bmRcbiAqL1xuZnVuY3Rpb24gZ2V0Q29tcG9uZW50TmFtZShlbGVtKSB7XG4gIC8vIEB0cy1leHBlY3QtZXJyb3IgV0lORE9XIGhhcyBIVE1MRWxlbWVudFxuICBpZiAoIVdJTkRPVy5IVE1MRWxlbWVudCkge1xuICAgIHJldHVybiBudWxsO1xuICB9XG5cbiAgbGV0IGN1cnJlbnRFbGVtID0gZWxlbSA7XG4gIGNvbnN0IE1BWF9UUkFWRVJTRV9IRUlHSFQgPSA1O1xuICBmb3IgKGxldCBpID0gMDsgaSA8IE1BWF9UUkFWRVJTRV9IRUlHSFQ7IGkrKykge1xuICAgIGlmICghY3VycmVudEVsZW0pIHtcbiAgICAgIHJldHVybiBudWxsO1xuICAgIH1cblxuICAgIGlmIChjdXJyZW50RWxlbSBpbnN0YW5jZW9mIEhUTUxFbGVtZW50KSB7XG4gICAgICBpZiAoY3VycmVudEVsZW0uZGF0YXNldFsnc2VudHJ5Q29tcG9uZW50J10pIHtcbiAgICAgICAgcmV0dXJuIGN1cnJlbnRFbGVtLmRhdGFzZXRbJ3NlbnRyeUNvbXBvbmVudCddO1xuICAgICAgfVxuICAgICAgaWYgKGN1cnJlbnRFbGVtLmRhdGFzZXRbJ3NlbnRyeUVsZW1lbnQnXSkge1xuICAgICAgICByZXR1cm4gY3VycmVudEVsZW0uZGF0YXNldFsnc2VudHJ5RWxlbWVudCddO1xuICAgICAgfVxuICAgIH1cblxuICAgIGN1cnJlbnRFbGVtID0gY3VycmVudEVsZW0ucGFyZW50Tm9kZTtcbiAgfVxuXG4gIHJldHVybiBudWxsO1xufVxuXG5leHBvcnRzLmdldENvbXBvbmVudE5hbWUgPSBnZXRDb21wb25lbnROYW1lO1xuZXhwb3J0cy5nZXRMb2NhdGlvbkhyZWYgPSBnZXRMb2NhdGlvbkhyZWY7XG5leHBvcnRzLmh0bWxUcmVlQXNTdHJpbmcgPSBodG1sVHJlZUFzU3RyaW5nO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9YnJvd3Nlci5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/browser.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/clientreport.js":
/*!**********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/clientreport.js ***!
  \**********************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst envelope = __webpack_require__(/*! ./envelope.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/envelope.js\");\nconst time = __webpack_require__(/*! ./time.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/time.js\");\n\n/**\n * Creates client report envelope\n * @param discarded_events An array of discard events\n * @param dsn A DSN that can be set on the header. Optional.\n */\nfunction createClientReportEnvelope(\n  discarded_events,\n  dsn,\n  timestamp,\n) {\n  const clientReportItem = [\n    { type: 'client_report' },\n    {\n      timestamp: timestamp || time.dateTimestampInSeconds(),\n      discarded_events,\n    },\n  ];\n  return envelope.createEnvelope(dsn ? { dsn } : {}, [clientReportItem]);\n}\n\nexports.createClientReportEnvelope = createClientReportEnvelope;\n//# sourceMappingURL=clientreport.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9jbGllbnRyZXBvcnQuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsaUJBQWlCLG1CQUFPLENBQUMsMkhBQWU7QUFDeEMsYUFBYSxtQkFBTyxDQUFDLG1IQUFXOztBQUVoQztBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsTUFBTSx1QkFBdUI7QUFDN0I7QUFDQTtBQUNBO0FBQ0EsS0FBSztBQUNMO0FBQ0EseUNBQXlDLE1BQU0sSUFBSTtBQUNuRDs7QUFFQSxrQ0FBa0M7QUFDbEMiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9jbGllbnRyZXBvcnQuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGVudmVsb3BlID0gcmVxdWlyZSgnLi9lbnZlbG9wZS5qcycpO1xuY29uc3QgdGltZSA9IHJlcXVpcmUoJy4vdGltZS5qcycpO1xuXG4vKipcbiAqIENyZWF0ZXMgY2xpZW50IHJlcG9ydCBlbnZlbG9wZVxuICogQHBhcmFtIGRpc2NhcmRlZF9ldmVudHMgQW4gYXJyYXkgb2YgZGlzY2FyZCBldmVudHNcbiAqIEBwYXJhbSBkc24gQSBEU04gdGhhdCBjYW4gYmUgc2V0IG9uIHRoZSBoZWFkZXIuIE9wdGlvbmFsLlxuICovXG5mdW5jdGlvbiBjcmVhdGVDbGllbnRSZXBvcnRFbnZlbG9wZShcbiAgZGlzY2FyZGVkX2V2ZW50cyxcbiAgZHNuLFxuICB0aW1lc3RhbXAsXG4pIHtcbiAgY29uc3QgY2xpZW50UmVwb3J0SXRlbSA9IFtcbiAgICB7IHR5cGU6ICdjbGllbnRfcmVwb3J0JyB9LFxuICAgIHtcbiAgICAgIHRpbWVzdGFtcDogdGltZXN0YW1wIHx8IHRpbWUuZGF0ZVRpbWVzdGFtcEluU2Vjb25kcygpLFxuICAgICAgZGlzY2FyZGVkX2V2ZW50cyxcbiAgICB9LFxuICBdO1xuICByZXR1cm4gZW52ZWxvcGUuY3JlYXRlRW52ZWxvcGUoZHNuID8geyBkc24gfSA6IHt9LCBbY2xpZW50UmVwb3J0SXRlbV0pO1xufVxuXG5leHBvcnRzLmNyZWF0ZUNsaWVudFJlcG9ydEVudmVsb3BlID0gY3JlYXRlQ2xpZW50UmVwb3J0RW52ZWxvcGU7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1jbGllbnRyZXBvcnQuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/clientreport.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/cookie.js":
/*!****************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/cookie.js ***!
  \****************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n/**\n * This code was originally copied from the 'cookie` module at v0.5.0 and was simplified for our use case.\n * https://github.com/jshttp/cookie/blob/a0c84147aab6266bdb3996cf4062e93907c0b0fc/index.js\n * It had the following license:\n *\n * (The MIT License)\n *\n * Copyright (c) 2012-2014 Roman Shtylman <shtylman@gmail.com>\n * Copyright (c) 2015 Douglas Christopher Wilson <doug@somethingdoug.com>\n *\n * Permission is hereby granted, free of charge, to any person obtaining\n * a copy of this software and associated documentation files (the\n * 'Software'), to deal in the Software without restriction, including\n * without limitation the rights to use, copy, modify, merge, publish,\n * distribute, sublicense, and/or sell copies of the Software, and to\n * permit persons to whom the Software is furnished to do so, subject to\n * the following conditions:\n *\n * The above copyright notice and this permission notice shall be\n * included in all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND,\n * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.\n * IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY\n * CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,\n * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE\n * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.\n */\n\n/**\n * Parses a cookie string\n */\nfunction parseCookie(str) {\n  const obj = {};\n  let index = 0;\n\n  while (index < str.length) {\n    const eqIdx = str.indexOf('=', index);\n\n    // no more cookie pairs\n    if (eqIdx === -1) {\n      break;\n    }\n\n    let endIdx = str.indexOf(';', index);\n\n    if (endIdx === -1) {\n      endIdx = str.length;\n    } else if (endIdx < eqIdx) {\n      // backtrack on prior semicolon\n      index = str.lastIndexOf(';', eqIdx - 1) + 1;\n      continue;\n    }\n\n    const key = str.slice(index, eqIdx).trim();\n\n    // only assign once\n    if (undefined === obj[key]) {\n      let val = str.slice(eqIdx + 1, endIdx).trim();\n\n      // quoted values\n      if (val.charCodeAt(0) === 0x22) {\n        val = val.slice(1, -1);\n      }\n\n      try {\n        obj[key] = val.indexOf('%') !== -1 ? decodeURIComponent(val) : val;\n      } catch {\n        obj[key] = val;\n      }\n    }\n\n    index = endIdx + 1;\n  }\n\n  return obj;\n}\n\nexports.parseCookie = parseCookie;\n//# sourceMappingURL=cookie.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9jb29raWUuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEU7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSwrQkFBK0I7O0FBRS9CO0FBQ0E7QUFDQSxNQUFNO0FBQ047QUFDQSxnQ0FBZ0M7QUFDaEM7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLFFBQVE7QUFDUjtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBOztBQUVBLG1CQUFtQjtBQUNuQiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3V0aWxzL2Nvb2tpZS5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuLyoqXG4gKiBUaGlzIGNvZGUgd2FzIG9yaWdpbmFsbHkgY29waWVkIGZyb20gdGhlICdjb29raWVgIG1vZHVsZSBhdCB2MC41LjAgYW5kIHdhcyBzaW1wbGlmaWVkIGZvciBvdXIgdXNlIGNhc2UuXG4gKiBodHRwczovL2dpdGh1Yi5jb20vanNodHRwL2Nvb2tpZS9ibG9iL2EwYzg0MTQ3YWFiNjI2NmJkYjM5OTZjZjQwNjJlOTM5MDdjMGIwZmMvaW5kZXguanNcbiAqIEl0IGhhZCB0aGUgZm9sbG93aW5nIGxpY2Vuc2U6XG4gKlxuICogKFRoZSBNSVQgTGljZW5zZSlcbiAqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMTItMjAxNCBSb21hbiBTaHR5bG1hbiA8c2h0eWxtYW5AZ21haWwuY29tPlxuICogQ29weXJpZ2h0IChjKSAyMDE1IERvdWdsYXMgQ2hyaXN0b3BoZXIgV2lsc29uIDxkb3VnQHNvbWV0aGluZ2RvdWcuY29tPlxuICpcbiAqIFBlcm1pc3Npb24gaXMgaGVyZWJ5IGdyYW50ZWQsIGZyZWUgb2YgY2hhcmdlLCB0byBhbnkgcGVyc29uIG9idGFpbmluZ1xuICogYSBjb3B5IG9mIHRoaXMgc29mdHdhcmUgYW5kIGFzc29jaWF0ZWQgZG9jdW1lbnRhdGlvbiBmaWxlcyAodGhlXG4gKiAnU29mdHdhcmUnKSwgdG8gZGVhbCBpbiB0aGUgU29mdHdhcmUgd2l0aG91dCByZXN0cmljdGlvbiwgaW5jbHVkaW5nXG4gKiB3aXRob3V0IGxpbWl0YXRpb24gdGhlIHJpZ2h0cyB0byB1c2UsIGNvcHksIG1vZGlmeSwgbWVyZ2UsIHB1Ymxpc2gsXG4gKiBkaXN0cmlidXRlLCBzdWJsaWNlbnNlLCBhbmQvb3Igc2VsbCBjb3BpZXMgb2YgdGhlIFNvZnR3YXJlLCBhbmQgdG9cbiAqIHBlcm1pdCBwZXJzb25zIHRvIHdob20gdGhlIFNvZnR3YXJlIGlzIGZ1cm5pc2hlZCB0byBkbyBzbywgc3ViamVjdCB0b1xuICogdGhlIGZvbGxvd2luZyBjb25kaXRpb25zOlxuICpcbiAqIFRoZSBhYm92ZSBjb3B5cmlnaHQgbm90aWNlIGFuZCB0aGlzIHBlcm1pc3Npb24gbm90aWNlIHNoYWxsIGJlXG4gKiBpbmNsdWRlZCBpbiBhbGwgY29waWVzIG9yIHN1YnN0YW50aWFsIHBvcnRpb25zIG9mIHRoZSBTb2Z0d2FyZS5cbiAqXG4gKiBUSEUgU09GVFdBUkUgSVMgUFJPVklERUQgJ0FTIElTJywgV0lUSE9VVCBXQVJSQU5UWSBPRiBBTlkgS0lORCxcbiAqIEVYUFJFU1MgT1IgSU1QTElFRCwgSU5DTFVESU5HIEJVVCBOT1QgTElNSVRFRCBUTyBUSEUgV0FSUkFOVElFUyBPRlxuICogTUVSQ0hBTlRBQklMSVRZLCBGSVRORVNTIEZPUiBBIFBBUlRJQ1VMQVIgUFVSUE9TRSBBTkQgTk9OSU5GUklOR0VNRU5ULlxuICogSU4gTk8gRVZFTlQgU0hBTEwgVEhFIEFVVEhPUlMgT1IgQ09QWVJJR0hUIEhPTERFUlMgQkUgTElBQkxFIEZPUiBBTllcbiAqIENMQUlNLCBEQU1BR0VTIE9SIE9USEVSIExJQUJJTElUWSwgV0hFVEhFUiBJTiBBTiBBQ1RJT04gT0YgQ09OVFJBQ1QsXG4gKiBUT1JUIE9SIE9USEVSV0lTRSwgQVJJU0lORyBGUk9NLCBPVVQgT0YgT1IgSU4gQ09OTkVDVElPTiBXSVRIIFRIRVxuICogU09GVFdBUkUgT1IgVEhFIFVTRSBPUiBPVEhFUiBERUFMSU5HUyBJTiBUSEUgU09GVFdBUkUuXG4gKi9cblxuLyoqXG4gKiBQYXJzZXMgYSBjb29raWUgc3RyaW5nXG4gKi9cbmZ1bmN0aW9uIHBhcnNlQ29va2llKHN0cikge1xuICBjb25zdCBvYmogPSB7fTtcbiAgbGV0IGluZGV4ID0gMDtcblxuICB3aGlsZSAoaW5kZXggPCBzdHIubGVuZ3RoKSB7XG4gICAgY29uc3QgZXFJZHggPSBzdHIuaW5kZXhPZignPScsIGluZGV4KTtcblxuICAgIC8vIG5vIG1vcmUgY29va2llIHBhaXJzXG4gICAgaWYgKGVxSWR4ID09PSAtMSkge1xuICAgICAgYnJlYWs7XG4gICAgfVxuXG4gICAgbGV0IGVuZElkeCA9IHN0ci5pbmRleE9mKCc7JywgaW5kZXgpO1xuXG4gICAgaWYgKGVuZElkeCA9PT0gLTEpIHtcbiAgICAgIGVuZElkeCA9IHN0ci5sZW5ndGg7XG4gICAgfSBlbHNlIGlmIChlbmRJZHggPCBlcUlkeCkge1xuICAgICAgLy8gYmFja3RyYWNrIG9uIHByaW9yIHNlbWljb2xvblxuICAgICAgaW5kZXggPSBzdHIubGFzdEluZGV4T2YoJzsnLCBlcUlkeCAtIDEpICsgMTtcbiAgICAgIGNvbnRpbnVlO1xuICAgIH1cblxuICAgIGNvbnN0IGtleSA9IHN0ci5zbGljZShpbmRleCwgZXFJZHgpLnRyaW0oKTtcblxuICAgIC8vIG9ubHkgYXNzaWduIG9uY2VcbiAgICBpZiAodW5kZWZpbmVkID09PSBvYmpba2V5XSkge1xuICAgICAgbGV0IHZhbCA9IHN0ci5zbGljZShlcUlkeCArIDEsIGVuZElkeCkudHJpbSgpO1xuXG4gICAgICAvLyBxdW90ZWQgdmFsdWVzXG4gICAgICBpZiAodmFsLmNoYXJDb2RlQXQoMCkgPT09IDB4MjIpIHtcbiAgICAgICAgdmFsID0gdmFsLnNsaWNlKDEsIC0xKTtcbiAgICAgIH1cblxuICAgICAgdHJ5IHtcbiAgICAgICAgb2JqW2tleV0gPSB2YWwuaW5kZXhPZignJScpICE9PSAtMSA/IGRlY29kZVVSSUNvbXBvbmVudCh2YWwpIDogdmFsO1xuICAgICAgfSBjYXRjaCB7XG4gICAgICAgIG9ialtrZXldID0gdmFsO1xuICAgICAgfVxuICAgIH1cblxuICAgIGluZGV4ID0gZW5kSWR4ICsgMTtcbiAgfVxuXG4gIHJldHVybiBvYmo7XG59XG5cbmV4cG9ydHMucGFyc2VDb29raWUgPSBwYXJzZUNvb2tpZTtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWNvb2tpZS5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/cookie.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debounce.js":
/*!******************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debounce.js ***!
  \******************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n/**\n * Heavily simplified debounce function based on lodash.debounce.\n *\n * This function takes a callback function (@param fun) and delays its invocation\n * by @param wait milliseconds. Optionally, a maxWait can be specified in @param options,\n * which ensures that the callback is invoked at least once after the specified max. wait time.\n *\n * @param func the function whose invocation is to be debounced\n * @param wait the minimum time until the function is invoked after it was called once\n * @param options the options object, which can contain the `maxWait` property\n *\n * @returns the debounced version of the function, which needs to be called at least once to start the\n *          debouncing process. Subsequent calls will reset the debouncing timer and, in case @paramfunc\n *          was already invoked in the meantime, return @param func's return value.\n *          The debounced function has two additional properties:\n *          - `flush`: Invokes the debounced function immediately and returns its return value\n *          - `cancel`: Cancels the debouncing process and resets the debouncing timer\n */\nfunction debounce(func, wait, options) {\n  let callbackReturnValue;\n\n  let timerId;\n  let maxTimerId;\n\n  const maxWait = options?.maxWait ? Math.max(options.maxWait, wait) : 0;\n  const setTimeoutImpl = options?.setTimeoutImpl || setTimeout;\n\n  function invokeFunc() {\n    cancelTimers();\n    callbackReturnValue = func();\n    return callbackReturnValue;\n  }\n\n  function cancelTimers() {\n    timerId !== undefined && clearTimeout(timerId);\n    maxTimerId !== undefined && clearTimeout(maxTimerId);\n    timerId = maxTimerId = undefined;\n  }\n\n  function flush() {\n    if (timerId !== undefined || maxTimerId !== undefined) {\n      return invokeFunc();\n    }\n    return callbackReturnValue;\n  }\n\n  function debounced() {\n    if (timerId) {\n      clearTimeout(timerId);\n    }\n    timerId = setTimeoutImpl(invokeFunc, wait);\n\n    if (maxWait && maxTimerId === undefined) {\n      maxTimerId = setTimeoutImpl(invokeFunc, maxWait);\n    }\n\n    return callbackReturnValue;\n  }\n\n  debounced.cancel = cancelTimers;\n  debounced.flush = flush;\n  return debounced;\n}\n\nexports.debounce = debounce;\n//# sourceMappingURL=debounce.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9kZWJvdW5jZS5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsZ0JBQWdCO0FBQ2hCIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvZGVib3VuY2UuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbi8qKlxuICogSGVhdmlseSBzaW1wbGlmaWVkIGRlYm91bmNlIGZ1bmN0aW9uIGJhc2VkIG9uIGxvZGFzaC5kZWJvdW5jZS5cbiAqXG4gKiBUaGlzIGZ1bmN0aW9uIHRha2VzIGEgY2FsbGJhY2sgZnVuY3Rpb24gKEBwYXJhbSBmdW4pIGFuZCBkZWxheXMgaXRzIGludm9jYXRpb25cbiAqIGJ5IEBwYXJhbSB3YWl0IG1pbGxpc2Vjb25kcy4gT3B0aW9uYWxseSwgYSBtYXhXYWl0IGNhbiBiZSBzcGVjaWZpZWQgaW4gQHBhcmFtIG9wdGlvbnMsXG4gKiB3aGljaCBlbnN1cmVzIHRoYXQgdGhlIGNhbGxiYWNrIGlzIGludm9rZWQgYXQgbGVhc3Qgb25jZSBhZnRlciB0aGUgc3BlY2lmaWVkIG1heC4gd2FpdCB0aW1lLlxuICpcbiAqIEBwYXJhbSBmdW5jIHRoZSBmdW5jdGlvbiB3aG9zZSBpbnZvY2F0aW9uIGlzIHRvIGJlIGRlYm91bmNlZFxuICogQHBhcmFtIHdhaXQgdGhlIG1pbmltdW0gdGltZSB1bnRpbCB0aGUgZnVuY3Rpb24gaXMgaW52b2tlZCBhZnRlciBpdCB3YXMgY2FsbGVkIG9uY2VcbiAqIEBwYXJhbSBvcHRpb25zIHRoZSBvcHRpb25zIG9iamVjdCwgd2hpY2ggY2FuIGNvbnRhaW4gdGhlIGBtYXhXYWl0YCBwcm9wZXJ0eVxuICpcbiAqIEByZXR1cm5zIHRoZSBkZWJvdW5jZWQgdmVyc2lvbiBvZiB0aGUgZnVuY3Rpb24sIHdoaWNoIG5lZWRzIHRvIGJlIGNhbGxlZCBhdCBsZWFzdCBvbmNlIHRvIHN0YXJ0IHRoZVxuICogICAgICAgICAgZGVib3VuY2luZyBwcm9jZXNzLiBTdWJzZXF1ZW50IGNhbGxzIHdpbGwgcmVzZXQgdGhlIGRlYm91bmNpbmcgdGltZXIgYW5kLCBpbiBjYXNlIEBwYXJhbWZ1bmNcbiAqICAgICAgICAgIHdhcyBhbHJlYWR5IGludm9rZWQgaW4gdGhlIG1lYW50aW1lLCByZXR1cm4gQHBhcmFtIGZ1bmMncyByZXR1cm4gdmFsdWUuXG4gKiAgICAgICAgICBUaGUgZGVib3VuY2VkIGZ1bmN0aW9uIGhhcyB0d28gYWRkaXRpb25hbCBwcm9wZXJ0aWVzOlxuICogICAgICAgICAgLSBgZmx1c2hgOiBJbnZva2VzIHRoZSBkZWJvdW5jZWQgZnVuY3Rpb24gaW1tZWRpYXRlbHkgYW5kIHJldHVybnMgaXRzIHJldHVybiB2YWx1ZVxuICogICAgICAgICAgLSBgY2FuY2VsYDogQ2FuY2VscyB0aGUgZGVib3VuY2luZyBwcm9jZXNzIGFuZCByZXNldHMgdGhlIGRlYm91bmNpbmcgdGltZXJcbiAqL1xuZnVuY3Rpb24gZGVib3VuY2UoZnVuYywgd2FpdCwgb3B0aW9ucykge1xuICBsZXQgY2FsbGJhY2tSZXR1cm5WYWx1ZTtcblxuICBsZXQgdGltZXJJZDtcbiAgbGV0IG1heFRpbWVySWQ7XG5cbiAgY29uc3QgbWF4V2FpdCA9IG9wdGlvbnM/Lm1heFdhaXQgPyBNYXRoLm1heChvcHRpb25zLm1heFdhaXQsIHdhaXQpIDogMDtcbiAgY29uc3Qgc2V0VGltZW91dEltcGwgPSBvcHRpb25zPy5zZXRUaW1lb3V0SW1wbCB8fCBzZXRUaW1lb3V0O1xuXG4gIGZ1bmN0aW9uIGludm9rZUZ1bmMoKSB7XG4gICAgY2FuY2VsVGltZXJzKCk7XG4gICAgY2FsbGJhY2tSZXR1cm5WYWx1ZSA9IGZ1bmMoKTtcbiAgICByZXR1cm4gY2FsbGJhY2tSZXR1cm5WYWx1ZTtcbiAgfVxuXG4gIGZ1bmN0aW9uIGNhbmNlbFRpbWVycygpIHtcbiAgICB0aW1lcklkICE9PSB1bmRlZmluZWQgJiYgY2xlYXJUaW1lb3V0KHRpbWVySWQpO1xuICAgIG1heFRpbWVySWQgIT09IHVuZGVmaW5lZCAmJiBjbGVhclRpbWVvdXQobWF4VGltZXJJZCk7XG4gICAgdGltZXJJZCA9IG1heFRpbWVySWQgPSB1bmRlZmluZWQ7XG4gIH1cblxuICBmdW5jdGlvbiBmbHVzaCgpIHtcbiAgICBpZiAodGltZXJJZCAhPT0gdW5kZWZpbmVkIHx8IG1heFRpbWVySWQgIT09IHVuZGVmaW5lZCkge1xuICAgICAgcmV0dXJuIGludm9rZUZ1bmMoKTtcbiAgICB9XG4gICAgcmV0dXJuIGNhbGxiYWNrUmV0dXJuVmFsdWU7XG4gIH1cblxuICBmdW5jdGlvbiBkZWJvdW5jZWQoKSB7XG4gICAgaWYgKHRpbWVySWQpIHtcbiAgICAgIGNsZWFyVGltZW91dCh0aW1lcklkKTtcbiAgICB9XG4gICAgdGltZXJJZCA9IHNldFRpbWVvdXRJbXBsKGludm9rZUZ1bmMsIHdhaXQpO1xuXG4gICAgaWYgKG1heFdhaXQgJiYgbWF4VGltZXJJZCA9PT0gdW5kZWZpbmVkKSB7XG4gICAgICBtYXhUaW1lcklkID0gc2V0VGltZW91dEltcGwoaW52b2tlRnVuYywgbWF4V2FpdCk7XG4gICAgfVxuXG4gICAgcmV0dXJuIGNhbGxiYWNrUmV0dXJuVmFsdWU7XG4gIH1cblxuICBkZWJvdW5jZWQuY2FuY2VsID0gY2FuY2VsVGltZXJzO1xuICBkZWJvdW5jZWQuZmx1c2ggPSBmbHVzaDtcbiAgcmV0dXJuIGRlYm91bmNlZDtcbn1cblxuZXhwb3J0cy5kZWJvdW5jZSA9IGRlYm91bmNlO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9ZGVib3VuY2UuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debounce.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-ids.js":
/*!*******************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-ids.js ***!
  \*******************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst worldwide = __webpack_require__(/*! ./worldwide.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/worldwide.js\");\n\nlet parsedStackResults;\nlet lastKeysCount;\nlet cachedFilenameDebugIds;\n\n/**\n * Returns a map of filenames to debug identifiers.\n */\nfunction getFilenameToDebugIdMap(stackParser) {\n  const debugIdMap = worldwide.GLOBAL_OBJ._sentryDebugIds;\n  if (!debugIdMap) {\n    return {};\n  }\n\n  const debugIdKeys = Object.keys(debugIdMap);\n\n  // If the count of registered globals hasn't changed since the last call, we\n  // can just return the cached result.\n  if (cachedFilenameDebugIds && debugIdKeys.length === lastKeysCount) {\n    return cachedFilenameDebugIds;\n  }\n\n  lastKeysCount = debugIdKeys.length;\n\n  // Build a map of filename -> debug_id.\n  cachedFilenameDebugIds = debugIdKeys.reduce((acc, stackKey) => {\n    if (!parsedStackResults) {\n      parsedStackResults = {};\n    }\n\n    const result = parsedStackResults[stackKey];\n\n    if (result) {\n      acc[result[0]] = result[1];\n    } else {\n      const parsedStack = stackParser(stackKey);\n\n      for (let i = parsedStack.length - 1; i >= 0; i--) {\n        const stackFrame = parsedStack[i];\n        const filename = stackFrame?.filename;\n        const debugId = debugIdMap[stackKey];\n\n        if (filename && debugId) {\n          acc[filename] = debugId;\n          parsedStackResults[stackKey] = [filename, debugId];\n          break;\n        }\n      }\n    }\n\n    return acc;\n  }, {});\n\n  return cachedFilenameDebugIds;\n}\n\n/**\n * Returns a list of debug images for the given resources.\n */\nfunction getDebugImagesForResources(\n  stackParser,\n  resource_paths,\n) {\n  const filenameDebugIdMap = getFilenameToDebugIdMap(stackParser);\n\n  if (!filenameDebugIdMap) {\n    return [];\n  }\n\n  const images = [];\n  for (const path of resource_paths) {\n    if (path && filenameDebugIdMap[path]) {\n      images.push({\n        type: 'sourcemap',\n        code_file: path,\n        debug_id: filenameDebugIdMap[path] ,\n      });\n    }\n  }\n\n  return images;\n}\n\nexports.getDebugImagesForResources = getDebugImagesForResources;\nexports.getFilenameToDebugIdMap = getFilenameToDebugIdMap;\n//# sourceMappingURL=debug-ids.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9kZWJ1Zy1pZHMuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsa0JBQWtCLG1CQUFPLENBQUMsNkhBQWdCOztBQUUxQztBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBLE1BQU07QUFDTjs7QUFFQSwyQ0FBMkMsUUFBUTtBQUNuRDtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQSxHQUFHLElBQUk7O0FBRVA7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLE9BQU87QUFDUDtBQUNBOztBQUVBO0FBQ0E7O0FBRUEsa0NBQWtDO0FBQ2xDLCtCQUErQjtBQUMvQiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3V0aWxzL2RlYnVnLWlkcy5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3Qgd29ybGR3aWRlID0gcmVxdWlyZSgnLi93b3JsZHdpZGUuanMnKTtcblxubGV0IHBhcnNlZFN0YWNrUmVzdWx0cztcbmxldCBsYXN0S2V5c0NvdW50O1xubGV0IGNhY2hlZEZpbGVuYW1lRGVidWdJZHM7XG5cbi8qKlxuICogUmV0dXJucyBhIG1hcCBvZiBmaWxlbmFtZXMgdG8gZGVidWcgaWRlbnRpZmllcnMuXG4gKi9cbmZ1bmN0aW9uIGdldEZpbGVuYW1lVG9EZWJ1Z0lkTWFwKHN0YWNrUGFyc2VyKSB7XG4gIGNvbnN0IGRlYnVnSWRNYXAgPSB3b3JsZHdpZGUuR0xPQkFMX09CSi5fc2VudHJ5RGVidWdJZHM7XG4gIGlmICghZGVidWdJZE1hcCkge1xuICAgIHJldHVybiB7fTtcbiAgfVxuXG4gIGNvbnN0IGRlYnVnSWRLZXlzID0gT2JqZWN0LmtleXMoZGVidWdJZE1hcCk7XG5cbiAgLy8gSWYgdGhlIGNvdW50IG9mIHJlZ2lzdGVyZWQgZ2xvYmFscyBoYXNuJ3QgY2hhbmdlZCBzaW5jZSB0aGUgbGFzdCBjYWxsLCB3ZVxuICAvLyBjYW4ganVzdCByZXR1cm4gdGhlIGNhY2hlZCByZXN1bHQuXG4gIGlmIChjYWNoZWRGaWxlbmFtZURlYnVnSWRzICYmIGRlYnVnSWRLZXlzLmxlbmd0aCA9PT0gbGFzdEtleXNDb3VudCkge1xuICAgIHJldHVybiBjYWNoZWRGaWxlbmFtZURlYnVnSWRzO1xuICB9XG5cbiAgbGFzdEtleXNDb3VudCA9IGRlYnVnSWRLZXlzLmxlbmd0aDtcblxuICAvLyBCdWlsZCBhIG1hcCBvZiBmaWxlbmFtZSAtPiBkZWJ1Z19pZC5cbiAgY2FjaGVkRmlsZW5hbWVEZWJ1Z0lkcyA9IGRlYnVnSWRLZXlzLnJlZHVjZSgoYWNjLCBzdGFja0tleSkgPT4ge1xuICAgIGlmICghcGFyc2VkU3RhY2tSZXN1bHRzKSB7XG4gICAgICBwYXJzZWRTdGFja1Jlc3VsdHMgPSB7fTtcbiAgICB9XG5cbiAgICBjb25zdCByZXN1bHQgPSBwYXJzZWRTdGFja1Jlc3VsdHNbc3RhY2tLZXldO1xuXG4gICAgaWYgKHJlc3VsdCkge1xuICAgICAgYWNjW3Jlc3VsdFswXV0gPSByZXN1bHRbMV07XG4gICAgfSBlbHNlIHtcbiAgICAgIGNvbnN0IHBhcnNlZFN0YWNrID0gc3RhY2tQYXJzZXIoc3RhY2tLZXkpO1xuXG4gICAgICBmb3IgKGxldCBpID0gcGFyc2VkU3RhY2subGVuZ3RoIC0gMTsgaSA+PSAwOyBpLS0pIHtcbiAgICAgICAgY29uc3Qgc3RhY2tGcmFtZSA9IHBhcnNlZFN0YWNrW2ldO1xuICAgICAgICBjb25zdCBmaWxlbmFtZSA9IHN0YWNrRnJhbWU/LmZpbGVuYW1lO1xuICAgICAgICBjb25zdCBkZWJ1Z0lkID0gZGVidWdJZE1hcFtzdGFja0tleV07XG5cbiAgICAgICAgaWYgKGZpbGVuYW1lICYmIGRlYnVnSWQpIHtcbiAgICAgICAgICBhY2NbZmlsZW5hbWVdID0gZGVidWdJZDtcbiAgICAgICAgICBwYXJzZWRTdGFja1Jlc3VsdHNbc3RhY2tLZXldID0gW2ZpbGVuYW1lLCBkZWJ1Z0lkXTtcbiAgICAgICAgICBicmVhaztcbiAgICAgICAgfVxuICAgICAgfVxuICAgIH1cblxuICAgIHJldHVybiBhY2M7XG4gIH0sIHt9KTtcblxuICByZXR1cm4gY2FjaGVkRmlsZW5hbWVEZWJ1Z0lkcztcbn1cblxuLyoqXG4gKiBSZXR1cm5zIGEgbGlzdCBvZiBkZWJ1ZyBpbWFnZXMgZm9yIHRoZSBnaXZlbiByZXNvdXJjZXMuXG4gKi9cbmZ1bmN0aW9uIGdldERlYnVnSW1hZ2VzRm9yUmVzb3VyY2VzKFxuICBzdGFja1BhcnNlcixcbiAgcmVzb3VyY2VfcGF0aHMsXG4pIHtcbiAgY29uc3QgZmlsZW5hbWVEZWJ1Z0lkTWFwID0gZ2V0RmlsZW5hbWVUb0RlYnVnSWRNYXAoc3RhY2tQYXJzZXIpO1xuXG4gIGlmICghZmlsZW5hbWVEZWJ1Z0lkTWFwKSB7XG4gICAgcmV0dXJuIFtdO1xuICB9XG5cbiAgY29uc3QgaW1hZ2VzID0gW107XG4gIGZvciAoY29uc3QgcGF0aCBvZiByZXNvdXJjZV9wYXRocykge1xuICAgIGlmIChwYXRoICYmIGZpbGVuYW1lRGVidWdJZE1hcFtwYXRoXSkge1xuICAgICAgaW1hZ2VzLnB1c2goe1xuICAgICAgICB0eXBlOiAnc291cmNlbWFwJyxcbiAgICAgICAgY29kZV9maWxlOiBwYXRoLFxuICAgICAgICBkZWJ1Z19pZDogZmlsZW5hbWVEZWJ1Z0lkTWFwW3BhdGhdICxcbiAgICAgIH0pO1xuICAgIH1cbiAgfVxuXG4gIHJldHVybiBpbWFnZXM7XG59XG5cbmV4cG9ydHMuZ2V0RGVidWdJbWFnZXNGb3JSZXNvdXJjZXMgPSBnZXREZWJ1Z0ltYWdlc0ZvclJlc291cmNlcztcbmV4cG9ydHMuZ2V0RmlsZW5hbWVUb0RlYnVnSWRNYXAgPSBnZXRGaWxlbmFtZVRvRGVidWdJZE1hcDtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWRlYnVnLWlkcy5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-ids.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js":
/*!**********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js ***!
  \**********************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst carrier = __webpack_require__(/*! ../carrier.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/carrier.js\");\nconst debugBuild = __webpack_require__(/*! ../debug-build.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst worldwide = __webpack_require__(/*! ./worldwide.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/worldwide.js\");\n\n/**\n * A Sentry Logger instance.\n *\n * @deprecated Use {@link debug} instead with the {@link SentryDebugLogger} type.\n */\n\nconst CONSOLE_LEVELS = [\n  'debug',\n  'info',\n  'warn',\n  'error',\n  'log',\n  'assert',\n  'trace',\n] ;\n\n/** Prefix for logging strings */\nconst PREFIX = 'Sentry Logger ';\n\n/** This may be mutated by the console instrumentation. */\nconst originalConsoleMethods\n\n = {};\n\n/**\n * Temporarily disable sentry console instrumentations.\n *\n * @param callback The function to run against the original `console` messages\n * @returns The results of the callback\n */\nfunction consoleSandbox(callback) {\n  if (!('console' in worldwide.GLOBAL_OBJ)) {\n    return callback();\n  }\n\n  const console = worldwide.GLOBAL_OBJ.console ;\n  const wrappedFuncs = {};\n\n  const wrappedLevels = Object.keys(originalConsoleMethods) ;\n\n  // Restore all wrapped console methods\n  wrappedLevels.forEach(level => {\n    const originalConsoleMethod = originalConsoleMethods[level];\n    wrappedFuncs[level] = console[level] ;\n    console[level] = originalConsoleMethod ;\n  });\n\n  try {\n    return callback();\n  } finally {\n    // Revert restoration to wrapped state\n    wrappedLevels.forEach(level => {\n      console[level] = wrappedFuncs[level] ;\n    });\n  }\n}\n\nfunction enable() {\n  _getLoggerSettings().enabled = true;\n}\n\nfunction disable() {\n  _getLoggerSettings().enabled = false;\n}\n\nfunction isEnabled() {\n  return _getLoggerSettings().enabled;\n}\n\nfunction log(...args) {\n  _maybeLog('log', ...args);\n}\n\nfunction info(...args) {\n  _maybeLog('info', ...args);\n}\n\nfunction warn(...args) {\n  _maybeLog('warn', ...args);\n}\n\nfunction error(...args) {\n  _maybeLog('error', ...args);\n}\n\nfunction _debug(...args) {\n  _maybeLog('debug', ...args);\n}\n\nfunction assert(...args) {\n  _maybeLog('assert', ...args);\n}\n\nfunction trace(...args) {\n  _maybeLog('trace', ...args);\n}\n\nfunction _maybeLog(level, ...args) {\n  if (!debugBuild.DEBUG_BUILD) {\n    return;\n  }\n\n  if (isEnabled()) {\n    consoleSandbox(() => {\n      worldwide.GLOBAL_OBJ.console[level](`${PREFIX}[${level}]:`, ...args);\n    });\n  }\n}\n\nfunction _getLoggerSettings() {\n  if (!debugBuild.DEBUG_BUILD) {\n    return { enabled: false };\n  }\n\n  return carrier.getGlobalSingleton('loggerSettings', () => ({ enabled: false }));\n}\n\n/**\n * This is a logger singleton which either logs things or no-ops if logging is not enabled.\n * The logger is a singleton on the carrier, to ensure that a consistent logger is used throughout the SDK.\n *\n * @deprecated Use {@link debug} instead.\n */\nconst logger = {\n  /** Enable logging. */\n  enable,\n  /** Disable logging. */\n  disable,\n  /** Check if logging is enabled. */\n  isEnabled,\n  /** Log a message. */\n  log,\n  /** Log level info */\n  info,\n  /** Log a warning. */\n  warn,\n  /** Log an error. */\n  error,\n  /** Log a debug message. */\n  debug: _debug,\n  /** Log an assertion. */\n  assert,\n  /** Log a trace. */\n  trace,\n  // eslint-disable-next-line deprecation/deprecation\n} ;\n\n/**\n * This is a logger singleton which either logs things or no-ops if logging is not enabled.\n */\nconst debug = {\n  /** Enable logging. */\n  enable,\n  /** Disable logging. */\n  disable,\n  /** Check if logging is enabled. */\n  isEnabled,\n  /** Log a message. */\n  log,\n  /** Log a warning. */\n  warn,\n  /** Log an error. */\n  error,\n} ;\n\nexports.CONSOLE_LEVELS = CONSOLE_LEVELS;\nexports.consoleSandbox = consoleSandbox;\nexports.debug = debug;\nexports.logger = logger;\nexports.originalConsoleMethods = originalConsoleMethods;\n//# sourceMappingURL=debug-logger.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9kZWJ1Zy1sb2dnZXIuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsZ0JBQWdCLG1CQUFPLENBQUMsb0hBQWU7QUFDdkMsbUJBQW1CLG1CQUFPLENBQUMsNEhBQW1CO0FBQzlDLGtCQUFrQixtQkFBTyxDQUFDLDZIQUFnQjs7QUFFMUM7QUFDQTtBQUNBO0FBQ0Esb0JBQW9CLGFBQWEsa0JBQWtCLHlCQUF5QjtBQUM1RTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEdBQUc7O0FBRUg7QUFDQTtBQUNBLElBQUk7QUFDSjtBQUNBO0FBQ0E7QUFDQSxLQUFLO0FBQ0w7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLDZDQUE2QyxPQUFPLEdBQUcsTUFBTTtBQUM3RCxLQUFLO0FBQ0w7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsYUFBYTtBQUNiOztBQUVBLCtEQUErRCxnQkFBZ0I7QUFDL0U7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQSxvQkFBb0IsYUFBYTtBQUNqQztBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSxzQkFBc0I7QUFDdEIsc0JBQXNCO0FBQ3RCLGFBQWE7QUFDYixjQUFjO0FBQ2QsOEJBQThCO0FBQzlCIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvZGVidWctbG9nZ2VyLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBjYXJyaWVyID0gcmVxdWlyZSgnLi4vY2Fycmllci5qcycpO1xuY29uc3QgZGVidWdCdWlsZCA9IHJlcXVpcmUoJy4uL2RlYnVnLWJ1aWxkLmpzJyk7XG5jb25zdCB3b3JsZHdpZGUgPSByZXF1aXJlKCcuL3dvcmxkd2lkZS5qcycpO1xuXG4vKipcbiAqIEEgU2VudHJ5IExvZ2dlciBpbnN0YW5jZS5cbiAqXG4gKiBAZGVwcmVjYXRlZCBVc2Uge0BsaW5rIGRlYnVnfSBpbnN0ZWFkIHdpdGggdGhlIHtAbGluayBTZW50cnlEZWJ1Z0xvZ2dlcn0gdHlwZS5cbiAqL1xuXG5jb25zdCBDT05TT0xFX0xFVkVMUyA9IFtcbiAgJ2RlYnVnJyxcbiAgJ2luZm8nLFxuICAnd2FybicsXG4gICdlcnJvcicsXG4gICdsb2cnLFxuICAnYXNzZXJ0JyxcbiAgJ3RyYWNlJyxcbl0gO1xuXG4vKiogUHJlZml4IGZvciBsb2dnaW5nIHN0cmluZ3MgKi9cbmNvbnN0IFBSRUZJWCA9ICdTZW50cnkgTG9nZ2VyICc7XG5cbi8qKiBUaGlzIG1heSBiZSBtdXRhdGVkIGJ5IHRoZSBjb25zb2xlIGluc3RydW1lbnRhdGlvbi4gKi9cbmNvbnN0IG9yaWdpbmFsQ29uc29sZU1ldGhvZHNcblxuID0ge307XG5cbi8qKlxuICogVGVtcG9yYXJpbHkgZGlzYWJsZSBzZW50cnkgY29uc29sZSBpbnN0cnVtZW50YXRpb25zLlxuICpcbiAqIEBwYXJhbSBjYWxsYmFjayBUaGUgZnVuY3Rpb24gdG8gcnVuIGFnYWluc3QgdGhlIG9yaWdpbmFsIGBjb25zb2xlYCBtZXNzYWdlc1xuICogQHJldHVybnMgVGhlIHJlc3VsdHMgb2YgdGhlIGNhbGxiYWNrXG4gKi9cbmZ1bmN0aW9uIGNvbnNvbGVTYW5kYm94KGNhbGxiYWNrKSB7XG4gIGlmICghKCdjb25zb2xlJyBpbiB3b3JsZHdpZGUuR0xPQkFMX09CSikpIHtcbiAgICByZXR1cm4gY2FsbGJhY2soKTtcbiAgfVxuXG4gIGNvbnN0IGNvbnNvbGUgPSB3b3JsZHdpZGUuR0xPQkFMX09CSi5jb25zb2xlIDtcbiAgY29uc3Qgd3JhcHBlZEZ1bmNzID0ge307XG5cbiAgY29uc3Qgd3JhcHBlZExldmVscyA9IE9iamVjdC5rZXlzKG9yaWdpbmFsQ29uc29sZU1ldGhvZHMpIDtcblxuICAvLyBSZXN0b3JlIGFsbCB3cmFwcGVkIGNvbnNvbGUgbWV0aG9kc1xuICB3cmFwcGVkTGV2ZWxzLmZvckVhY2gobGV2ZWwgPT4ge1xuICAgIGNvbnN0IG9yaWdpbmFsQ29uc29sZU1ldGhvZCA9IG9yaWdpbmFsQ29uc29sZU1ldGhvZHNbbGV2ZWxdO1xuICAgIHdyYXBwZWRGdW5jc1tsZXZlbF0gPSBjb25zb2xlW2xldmVsXSA7XG4gICAgY29uc29sZVtsZXZlbF0gPSBvcmlnaW5hbENvbnNvbGVNZXRob2QgO1xuICB9KTtcblxuICB0cnkge1xuICAgIHJldHVybiBjYWxsYmFjaygpO1xuICB9IGZpbmFsbHkge1xuICAgIC8vIFJldmVydCByZXN0b3JhdGlvbiB0byB3cmFwcGVkIHN0YXRlXG4gICAgd3JhcHBlZExldmVscy5mb3JFYWNoKGxldmVsID0+IHtcbiAgICAgIGNvbnNvbGVbbGV2ZWxdID0gd3JhcHBlZEZ1bmNzW2xldmVsXSA7XG4gICAgfSk7XG4gIH1cbn1cblxuZnVuY3Rpb24gZW5hYmxlKCkge1xuICBfZ2V0TG9nZ2VyU2V0dGluZ3MoKS5lbmFibGVkID0gdHJ1ZTtcbn1cblxuZnVuY3Rpb24gZGlzYWJsZSgpIHtcbiAgX2dldExvZ2dlclNldHRpbmdzKCkuZW5hYmxlZCA9IGZhbHNlO1xufVxuXG5mdW5jdGlvbiBpc0VuYWJsZWQoKSB7XG4gIHJldHVybiBfZ2V0TG9nZ2VyU2V0dGluZ3MoKS5lbmFibGVkO1xufVxuXG5mdW5jdGlvbiBsb2coLi4uYXJncykge1xuICBfbWF5YmVMb2coJ2xvZycsIC4uLmFyZ3MpO1xufVxuXG5mdW5jdGlvbiBpbmZvKC4uLmFyZ3MpIHtcbiAgX21heWJlTG9nKCdpbmZvJywgLi4uYXJncyk7XG59XG5cbmZ1bmN0aW9uIHdhcm4oLi4uYXJncykge1xuICBfbWF5YmVMb2coJ3dhcm4nLCAuLi5hcmdzKTtcbn1cblxuZnVuY3Rpb24gZXJyb3IoLi4uYXJncykge1xuICBfbWF5YmVMb2coJ2Vycm9yJywgLi4uYXJncyk7XG59XG5cbmZ1bmN0aW9uIF9kZWJ1ZyguLi5hcmdzKSB7XG4gIF9tYXliZUxvZygnZGVidWcnLCAuLi5hcmdzKTtcbn1cblxuZnVuY3Rpb24gYXNzZXJ0KC4uLmFyZ3MpIHtcbiAgX21heWJlTG9nKCdhc3NlcnQnLCAuLi5hcmdzKTtcbn1cblxuZnVuY3Rpb24gdHJhY2UoLi4uYXJncykge1xuICBfbWF5YmVMb2coJ3RyYWNlJywgLi4uYXJncyk7XG59XG5cbmZ1bmN0aW9uIF9tYXliZUxvZyhsZXZlbCwgLi4uYXJncykge1xuICBpZiAoIWRlYnVnQnVpbGQuREVCVUdfQlVJTEQpIHtcbiAgICByZXR1cm47XG4gIH1cblxuICBpZiAoaXNFbmFibGVkKCkpIHtcbiAgICBjb25zb2xlU2FuZGJveCgoKSA9PiB7XG4gICAgICB3b3JsZHdpZGUuR0xPQkFMX09CSi5jb25zb2xlW2xldmVsXShgJHtQUkVGSVh9WyR7bGV2ZWx9XTpgLCAuLi5hcmdzKTtcbiAgICB9KTtcbiAgfVxufVxuXG5mdW5jdGlvbiBfZ2V0TG9nZ2VyU2V0dGluZ3MoKSB7XG4gIGlmICghZGVidWdCdWlsZC5ERUJVR19CVUlMRCkge1xuICAgIHJldHVybiB7IGVuYWJsZWQ6IGZhbHNlIH07XG4gIH1cblxuICByZXR1cm4gY2Fycmllci5nZXRHbG9iYWxTaW5nbGV0b24oJ2xvZ2dlclNldHRpbmdzJywgKCkgPT4gKHsgZW5hYmxlZDogZmFsc2UgfSkpO1xufVxuXG4vKipcbiAqIFRoaXMgaXMgYSBsb2dnZXIgc2luZ2xldG9uIHdoaWNoIGVpdGhlciBsb2dzIHRoaW5ncyBvciBuby1vcHMgaWYgbG9nZ2luZyBpcyBub3QgZW5hYmxlZC5cbiAqIFRoZSBsb2dnZXIgaXMgYSBzaW5nbGV0b24gb24gdGhlIGNhcnJpZXIsIHRvIGVuc3VyZSB0aGF0IGEgY29uc2lzdGVudCBsb2dnZXIgaXMgdXNlZCB0aHJvdWdob3V0IHRoZSBTREsuXG4gKlxuICogQGRlcHJlY2F0ZWQgVXNlIHtAbGluayBkZWJ1Z30gaW5zdGVhZC5cbiAqL1xuY29uc3QgbG9nZ2VyID0ge1xuICAvKiogRW5hYmxlIGxvZ2dpbmcuICovXG4gIGVuYWJsZSxcbiAgLyoqIERpc2FibGUgbG9nZ2luZy4gKi9cbiAgZGlzYWJsZSxcbiAgLyoqIENoZWNrIGlmIGxvZ2dpbmcgaXMgZW5hYmxlZC4gKi9cbiAgaXNFbmFibGVkLFxuICAvKiogTG9nIGEgbWVzc2FnZS4gKi9cbiAgbG9nLFxuICAvKiogTG9nIGxldmVsIGluZm8gKi9cbiAgaW5mbyxcbiAgLyoqIExvZyBhIHdhcm5pbmcuICovXG4gIHdhcm4sXG4gIC8qKiBMb2cgYW4gZXJyb3IuICovXG4gIGVycm9yLFxuICAvKiogTG9nIGEgZGVidWcgbWVzc2FnZS4gKi9cbiAgZGVidWc6IF9kZWJ1ZyxcbiAgLyoqIExvZyBhbiBhc3NlcnRpb24uICovXG4gIGFzc2VydCxcbiAgLyoqIExvZyBhIHRyYWNlLiAqL1xuICB0cmFjZSxcbiAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIGRlcHJlY2F0aW9uL2RlcHJlY2F0aW9uXG59IDtcblxuLyoqXG4gKiBUaGlzIGlzIGEgbG9nZ2VyIHNpbmdsZXRvbiB3aGljaCBlaXRoZXIgbG9ncyB0aGluZ3Mgb3Igbm8tb3BzIGlmIGxvZ2dpbmcgaXMgbm90IGVuYWJsZWQuXG4gKi9cbmNvbnN0IGRlYnVnID0ge1xuICAvKiogRW5hYmxlIGxvZ2dpbmcuICovXG4gIGVuYWJsZSxcbiAgLyoqIERpc2FibGUgbG9nZ2luZy4gKi9cbiAgZGlzYWJsZSxcbiAgLyoqIENoZWNrIGlmIGxvZ2dpbmcgaXMgZW5hYmxlZC4gKi9cbiAgaXNFbmFibGVkLFxuICAvKiogTG9nIGEgbWVzc2FnZS4gKi9cbiAgbG9nLFxuICAvKiogTG9nIGEgd2FybmluZy4gKi9cbiAgd2FybixcbiAgLyoqIExvZyBhbiBlcnJvci4gKi9cbiAgZXJyb3IsXG59IDtcblxuZXhwb3J0cy5DT05TT0xFX0xFVkVMUyA9IENPTlNPTEVfTEVWRUxTO1xuZXhwb3J0cy5jb25zb2xlU2FuZGJveCA9IGNvbnNvbGVTYW5kYm94O1xuZXhwb3J0cy5kZWJ1ZyA9IGRlYnVnO1xuZXhwb3J0cy5sb2dnZXIgPSBsb2dnZXI7XG5leHBvcnRzLm9yaWdpbmFsQ29uc29sZU1ldGhvZHMgPSBvcmlnaW5hbENvbnNvbGVNZXRob2RzO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9ZGVidWctbG9nZ2VyLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/dsn.js":
/*!*************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/dsn.js ***!
  \*************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst debugBuild = __webpack_require__(/*! ../debug-build.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst debugLogger = __webpack_require__(/*! ./debug-logger.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\n\n/** Regular expression used to extract org ID from a DSN host. */\nconst ORG_ID_REGEX = /^o(\\d+)\\./;\n\n/** Regular expression used to parse a Dsn. */\nconst DSN_REGEX = /^(?:(\\w+):)\\/\\/(?:(\\w+)(?::(\\w+)?)?@)([\\w.-]+)(?::(\\d+))?\\/(.+)/;\n\nfunction isValidProtocol(protocol) {\n  return protocol === 'http' || protocol === 'https';\n}\n\n/**\n * Renders the string representation of this Dsn.\n *\n * By default, this will render the public representation without the password\n * component. To get the deprecated private representation, set `withPassword`\n * to true.\n *\n * @param withPassword When set to true, the password will be included.\n */\nfunction dsnToString(dsn, withPassword = false) {\n  const { host, path, pass, port, projectId, protocol, publicKey } = dsn;\n  return (\n    `${protocol}://${publicKey}${withPassword && pass ? `:${pass}` : ''}` +\n    `@${host}${port ? `:${port}` : ''}/${path ? `${path}/` : path}${projectId}`\n  );\n}\n\n/**\n * Parses a Dsn from a given string.\n *\n * @param str A Dsn as string\n * @returns Dsn as DsnComponents or undefined if @param str is not a valid DSN string\n */\nfunction dsnFromString(str) {\n  const match = DSN_REGEX.exec(str);\n\n  if (!match) {\n    // This should be logged to the console\n    debugLogger.consoleSandbox(() => {\n      // eslint-disable-next-line no-console\n      console.error(`Invalid Sentry Dsn: ${str}`);\n    });\n    return undefined;\n  }\n\n  const [protocol, publicKey, pass = '', host = '', port = '', lastPath = ''] = match.slice(1);\n  let path = '';\n  let projectId = lastPath;\n\n  const split = projectId.split('/');\n  if (split.length > 1) {\n    path = split.slice(0, -1).join('/');\n    projectId = split.pop() ;\n  }\n\n  if (projectId) {\n    const projectMatch = projectId.match(/^\\d+/);\n    if (projectMatch) {\n      projectId = projectMatch[0];\n    }\n  }\n\n  return dsnFromComponents({ host, pass, path, projectId, port, protocol: protocol , publicKey });\n}\n\nfunction dsnFromComponents(components) {\n  return {\n    protocol: components.protocol,\n    publicKey: components.publicKey || '',\n    pass: components.pass || '',\n    host: components.host,\n    port: components.port || '',\n    path: components.path || '',\n    projectId: components.projectId,\n  };\n}\n\nfunction validateDsn(dsn) {\n  if (!debugBuild.DEBUG_BUILD) {\n    return true;\n  }\n\n  const { port, projectId, protocol } = dsn;\n\n  const requiredComponents = ['protocol', 'publicKey', 'host', 'projectId'];\n  const hasMissingRequiredComponent = requiredComponents.find(component => {\n    if (!dsn[component]) {\n      debugLogger.debug.error(`Invalid Sentry Dsn: ${component} missing`);\n      return true;\n    }\n    return false;\n  });\n\n  if (hasMissingRequiredComponent) {\n    return false;\n  }\n\n  if (!projectId.match(/^\\d+$/)) {\n    debugLogger.debug.error(`Invalid Sentry Dsn: Invalid projectId ${projectId}`);\n    return false;\n  }\n\n  if (!isValidProtocol(protocol)) {\n    debugLogger.debug.error(`Invalid Sentry Dsn: Invalid protocol ${protocol}`);\n    return false;\n  }\n\n  if (port && isNaN(parseInt(port, 10))) {\n    debugLogger.debug.error(`Invalid Sentry Dsn: Invalid port ${port}`);\n    return false;\n  }\n\n  return true;\n}\n\n/**\n * Extract the org ID from a DSN host.\n *\n * @param host The host from a DSN\n * @returns The org ID if found, undefined otherwise\n */\nfunction extractOrgIdFromDsnHost(host) {\n  const match = host.match(ORG_ID_REGEX);\n\n  return match?.[1];\n}\n\n/**\n * Creates a valid Sentry Dsn object, identifying a Sentry instance and project.\n * @returns a valid DsnComponents object or `undefined` if @param from is an invalid DSN source\n */\nfunction makeDsn(from) {\n  const components = typeof from === 'string' ? dsnFromString(from) : dsnFromComponents(from);\n  if (!components || !validateDsn(components)) {\n    return undefined;\n  }\n  return components;\n}\n\nexports.dsnFromString = dsnFromString;\nexports.dsnToString = dsnToString;\nexports.extractOrgIdFromDsnHost = extractOrgIdFromDsnHost;\nexports.makeDsn = makeDsn;\n//# sourceMappingURL=dsn.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9kc24uanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsbUJBQW1CLG1CQUFPLENBQUMsNEhBQW1CO0FBQzlDLG9CQUFvQixtQkFBTyxDQUFDLG1JQUFtQjs7QUFFL0M7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFVBQVUseURBQXlEO0FBQ25FO0FBQ0EsT0FBTyxTQUFTLEtBQUssVUFBVSxFQUFFLDJCQUEyQixLQUFLLE9BQU87QUFDeEUsUUFBUSxLQUFLLEVBQUUsV0FBVyxLQUFLLE9BQU8sR0FBRyxVQUFVLEtBQUssVUFBVSxFQUFFLFVBQVU7QUFDOUU7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsMkNBQTJDLElBQUk7QUFDL0MsS0FBSztBQUNMO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLDZCQUE2QixtRUFBbUU7QUFDaEc7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSxVQUFVLDRCQUE0Qjs7QUFFdEM7QUFDQTtBQUNBO0FBQ0EscURBQXFELFdBQVc7QUFDaEU7QUFDQTtBQUNBO0FBQ0EsR0FBRzs7QUFFSDtBQUNBO0FBQ0E7O0FBRUE7QUFDQSxxRUFBcUUsVUFBVTtBQUMvRTtBQUNBOztBQUVBO0FBQ0Esb0VBQW9FLFNBQVM7QUFDN0U7QUFDQTs7QUFFQTtBQUNBLGdFQUFnRSxLQUFLO0FBQ3JFO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSxxQkFBcUI7QUFDckIsbUJBQW1CO0FBQ25CLCtCQUErQjtBQUMvQixlQUFlO0FBQ2YiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9kc24uanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGRlYnVnQnVpbGQgPSByZXF1aXJlKCcuLi9kZWJ1Zy1idWlsZC5qcycpO1xuY29uc3QgZGVidWdMb2dnZXIgPSByZXF1aXJlKCcuL2RlYnVnLWxvZ2dlci5qcycpO1xuXG4vKiogUmVndWxhciBleHByZXNzaW9uIHVzZWQgdG8gZXh0cmFjdCBvcmcgSUQgZnJvbSBhIERTTiBob3N0LiAqL1xuY29uc3QgT1JHX0lEX1JFR0VYID0gL15vKFxcZCspXFwuLztcblxuLyoqIFJlZ3VsYXIgZXhwcmVzc2lvbiB1c2VkIHRvIHBhcnNlIGEgRHNuLiAqL1xuY29uc3QgRFNOX1JFR0VYID0gL14oPzooXFx3Kyk6KVxcL1xcLyg/OihcXHcrKSg/OjooXFx3Kyk/KT9AKShbXFx3Li1dKykoPzo6KFxcZCspKT9cXC8oLispLztcblxuZnVuY3Rpb24gaXNWYWxpZFByb3RvY29sKHByb3RvY29sKSB7XG4gIHJldHVybiBwcm90b2NvbCA9PT0gJ2h0dHAnIHx8IHByb3RvY29sID09PSAnaHR0cHMnO1xufVxuXG4vKipcbiAqIFJlbmRlcnMgdGhlIHN0cmluZyByZXByZXNlbnRhdGlvbiBvZiB0aGlzIERzbi5cbiAqXG4gKiBCeSBkZWZhdWx0LCB0aGlzIHdpbGwgcmVuZGVyIHRoZSBwdWJsaWMgcmVwcmVzZW50YXRpb24gd2l0aG91dCB0aGUgcGFzc3dvcmRcbiAqIGNvbXBvbmVudC4gVG8gZ2V0IHRoZSBkZXByZWNhdGVkIHByaXZhdGUgcmVwcmVzZW50YXRpb24sIHNldCBgd2l0aFBhc3N3b3JkYFxuICogdG8gdHJ1ZS5cbiAqXG4gKiBAcGFyYW0gd2l0aFBhc3N3b3JkIFdoZW4gc2V0IHRvIHRydWUsIHRoZSBwYXNzd29yZCB3aWxsIGJlIGluY2x1ZGVkLlxuICovXG5mdW5jdGlvbiBkc25Ub1N0cmluZyhkc24sIHdpdGhQYXNzd29yZCA9IGZhbHNlKSB7XG4gIGNvbnN0IHsgaG9zdCwgcGF0aCwgcGFzcywgcG9ydCwgcHJvamVjdElkLCBwcm90b2NvbCwgcHVibGljS2V5IH0gPSBkc247XG4gIHJldHVybiAoXG4gICAgYCR7cHJvdG9jb2x9Oi8vJHtwdWJsaWNLZXl9JHt3aXRoUGFzc3dvcmQgJiYgcGFzcyA/IGA6JHtwYXNzfWAgOiAnJ31gICtcbiAgICBgQCR7aG9zdH0ke3BvcnQgPyBgOiR7cG9ydH1gIDogJyd9LyR7cGF0aCA/IGAke3BhdGh9L2AgOiBwYXRofSR7cHJvamVjdElkfWBcbiAgKTtcbn1cblxuLyoqXG4gKiBQYXJzZXMgYSBEc24gZnJvbSBhIGdpdmVuIHN0cmluZy5cbiAqXG4gKiBAcGFyYW0gc3RyIEEgRHNuIGFzIHN0cmluZ1xuICogQHJldHVybnMgRHNuIGFzIERzbkNvbXBvbmVudHMgb3IgdW5kZWZpbmVkIGlmIEBwYXJhbSBzdHIgaXMgbm90IGEgdmFsaWQgRFNOIHN0cmluZ1xuICovXG5mdW5jdGlvbiBkc25Gcm9tU3RyaW5nKHN0cikge1xuICBjb25zdCBtYXRjaCA9IERTTl9SRUdFWC5leGVjKHN0cik7XG5cbiAgaWYgKCFtYXRjaCkge1xuICAgIC8vIFRoaXMgc2hvdWxkIGJlIGxvZ2dlZCB0byB0aGUgY29uc29sZVxuICAgIGRlYnVnTG9nZ2VyLmNvbnNvbGVTYW5kYm94KCgpID0+IHtcbiAgICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBuby1jb25zb2xlXG4gICAgICBjb25zb2xlLmVycm9yKGBJbnZhbGlkIFNlbnRyeSBEc246ICR7c3RyfWApO1xuICAgIH0pO1xuICAgIHJldHVybiB1bmRlZmluZWQ7XG4gIH1cblxuICBjb25zdCBbcHJvdG9jb2wsIHB1YmxpY0tleSwgcGFzcyA9ICcnLCBob3N0ID0gJycsIHBvcnQgPSAnJywgbGFzdFBhdGggPSAnJ10gPSBtYXRjaC5zbGljZSgxKTtcbiAgbGV0IHBhdGggPSAnJztcbiAgbGV0IHByb2plY3RJZCA9IGxhc3RQYXRoO1xuXG4gIGNvbnN0IHNwbGl0ID0gcHJvamVjdElkLnNwbGl0KCcvJyk7XG4gIGlmIChzcGxpdC5sZW5ndGggPiAxKSB7XG4gICAgcGF0aCA9IHNwbGl0LnNsaWNlKDAsIC0xKS5qb2luKCcvJyk7XG4gICAgcHJvamVjdElkID0gc3BsaXQucG9wKCkgO1xuICB9XG5cbiAgaWYgKHByb2plY3RJZCkge1xuICAgIGNvbnN0IHByb2plY3RNYXRjaCA9IHByb2plY3RJZC5tYXRjaCgvXlxcZCsvKTtcbiAgICBpZiAocHJvamVjdE1hdGNoKSB7XG4gICAgICBwcm9qZWN0SWQgPSBwcm9qZWN0TWF0Y2hbMF07XG4gICAgfVxuICB9XG5cbiAgcmV0dXJuIGRzbkZyb21Db21wb25lbnRzKHsgaG9zdCwgcGFzcywgcGF0aCwgcHJvamVjdElkLCBwb3J0LCBwcm90b2NvbDogcHJvdG9jb2wgLCBwdWJsaWNLZXkgfSk7XG59XG5cbmZ1bmN0aW9uIGRzbkZyb21Db21wb25lbnRzKGNvbXBvbmVudHMpIHtcbiAgcmV0dXJuIHtcbiAgICBwcm90b2NvbDogY29tcG9uZW50cy5wcm90b2NvbCxcbiAgICBwdWJsaWNLZXk6IGNvbXBvbmVudHMucHVibGljS2V5IHx8ICcnLFxuICAgIHBhc3M6IGNvbXBvbmVudHMucGFzcyB8fCAnJyxcbiAgICBob3N0OiBjb21wb25lbnRzLmhvc3QsXG4gICAgcG9ydDogY29tcG9uZW50cy5wb3J0IHx8ICcnLFxuICAgIHBhdGg6IGNvbXBvbmVudHMucGF0aCB8fCAnJyxcbiAgICBwcm9qZWN0SWQ6IGNvbXBvbmVudHMucHJvamVjdElkLFxuICB9O1xufVxuXG5mdW5jdGlvbiB2YWxpZGF0ZURzbihkc24pIHtcbiAgaWYgKCFkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEKSB7XG4gICAgcmV0dXJuIHRydWU7XG4gIH1cblxuICBjb25zdCB7IHBvcnQsIHByb2plY3RJZCwgcHJvdG9jb2wgfSA9IGRzbjtcblxuICBjb25zdCByZXF1aXJlZENvbXBvbmVudHMgPSBbJ3Byb3RvY29sJywgJ3B1YmxpY0tleScsICdob3N0JywgJ3Byb2plY3RJZCddO1xuICBjb25zdCBoYXNNaXNzaW5nUmVxdWlyZWRDb21wb25lbnQgPSByZXF1aXJlZENvbXBvbmVudHMuZmluZChjb21wb25lbnQgPT4ge1xuICAgIGlmICghZHNuW2NvbXBvbmVudF0pIHtcbiAgICAgIGRlYnVnTG9nZ2VyLmRlYnVnLmVycm9yKGBJbnZhbGlkIFNlbnRyeSBEc246ICR7Y29tcG9uZW50fSBtaXNzaW5nYCk7XG4gICAgICByZXR1cm4gdHJ1ZTtcbiAgICB9XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9KTtcblxuICBpZiAoaGFzTWlzc2luZ1JlcXVpcmVkQ29tcG9uZW50KSB7XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG5cbiAgaWYgKCFwcm9qZWN0SWQubWF0Y2goL15cXGQrJC8pKSB7XG4gICAgZGVidWdMb2dnZXIuZGVidWcuZXJyb3IoYEludmFsaWQgU2VudHJ5IERzbjogSW52YWxpZCBwcm9qZWN0SWQgJHtwcm9qZWN0SWR9YCk7XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG5cbiAgaWYgKCFpc1ZhbGlkUHJvdG9jb2wocHJvdG9jb2wpKSB7XG4gICAgZGVidWdMb2dnZXIuZGVidWcuZXJyb3IoYEludmFsaWQgU2VudHJ5IERzbjogSW52YWxpZCBwcm90b2NvbCAke3Byb3RvY29sfWApO1xuICAgIHJldHVybiBmYWxzZTtcbiAgfVxuXG4gIGlmIChwb3J0ICYmIGlzTmFOKHBhcnNlSW50KHBvcnQsIDEwKSkpIHtcbiAgICBkZWJ1Z0xvZ2dlci5kZWJ1Zy5lcnJvcihgSW52YWxpZCBTZW50cnkgRHNuOiBJbnZhbGlkIHBvcnQgJHtwb3J0fWApO1xuICAgIHJldHVybiBmYWxzZTtcbiAgfVxuXG4gIHJldHVybiB0cnVlO1xufVxuXG4vKipcbiAqIEV4dHJhY3QgdGhlIG9yZyBJRCBmcm9tIGEgRFNOIGhvc3QuXG4gKlxuICogQHBhcmFtIGhvc3QgVGhlIGhvc3QgZnJvbSBhIERTTlxuICogQHJldHVybnMgVGhlIG9yZyBJRCBpZiBmb3VuZCwgdW5kZWZpbmVkIG90aGVyd2lzZVxuICovXG5mdW5jdGlvbiBleHRyYWN0T3JnSWRGcm9tRHNuSG9zdChob3N0KSB7XG4gIGNvbnN0IG1hdGNoID0gaG9zdC5tYXRjaChPUkdfSURfUkVHRVgpO1xuXG4gIHJldHVybiBtYXRjaD8uWzFdO1xufVxuXG4vKipcbiAqIENyZWF0ZXMgYSB2YWxpZCBTZW50cnkgRHNuIG9iamVjdCwgaWRlbnRpZnlpbmcgYSBTZW50cnkgaW5zdGFuY2UgYW5kIHByb2plY3QuXG4gKiBAcmV0dXJucyBhIHZhbGlkIERzbkNvbXBvbmVudHMgb2JqZWN0IG9yIGB1bmRlZmluZWRgIGlmIEBwYXJhbSBmcm9tIGlzIGFuIGludmFsaWQgRFNOIHNvdXJjZVxuICovXG5mdW5jdGlvbiBtYWtlRHNuKGZyb20pIHtcbiAgY29uc3QgY29tcG9uZW50cyA9IHR5cGVvZiBmcm9tID09PSAnc3RyaW5nJyA/IGRzbkZyb21TdHJpbmcoZnJvbSkgOiBkc25Gcm9tQ29tcG9uZW50cyhmcm9tKTtcbiAgaWYgKCFjb21wb25lbnRzIHx8ICF2YWxpZGF0ZURzbihjb21wb25lbnRzKSkge1xuICAgIHJldHVybiB1bmRlZmluZWQ7XG4gIH1cbiAgcmV0dXJuIGNvbXBvbmVudHM7XG59XG5cbmV4cG9ydHMuZHNuRnJvbVN0cmluZyA9IGRzbkZyb21TdHJpbmc7XG5leHBvcnRzLmRzblRvU3RyaW5nID0gZHNuVG9TdHJpbmc7XG5leHBvcnRzLmV4dHJhY3RPcmdJZEZyb21Ec25Ib3N0ID0gZXh0cmFjdE9yZ0lkRnJvbURzbkhvc3Q7XG5leHBvcnRzLm1ha2VEc24gPSBtYWtlRHNuO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9ZHNuLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/dsn.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/env.js":
/*!*************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/env.js ***!
  \*************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n/*\n * This module exists for optimizations in the build process through rollup and terser.  We define some global\n * constants, which can be overridden during build. By guarding certain pieces of code with functions that return these\n * constants, we can control whether or not they appear in the final bundle. (Any code guarded by a false condition will\n * never run, and will hence be dropped during treeshaking.) The two primary uses for this are stripping out calls to\n * `debug` and preventing node-related code from appearing in browser bundles.\n *\n * Attention:\n * This file should not be used to define constants/flags that are intended to be used for tree-shaking conducted by\n * users. These flags should live in their respective packages, as we identified user tooling (specifically webpack)\n * having issues tree-shaking these constants across package boundaries.\n * An example for this is the __SENTRY_DEBUG__ constant. It is declared in each package individually because we want\n * users to be able to shake away expressions that it guards.\n */\n\n/**\n * Figures out if we're building a browser bundle.\n *\n * @returns true if this is a browser bundle build.\n */\nfunction isBrowserBundle() {\n  return typeof __SENTRY_BROWSER_BUNDLE__ !== 'undefined' && !!__SENTRY_BROWSER_BUNDLE__;\n}\n\n/**\n * Get source of SDK.\n */\nfunction getSDKSource() {\n  // This comment is used to identify this line in the CDN bundle build step and replace this with \"return 'cdn';\"\n  /* __SENTRY_SDK_SOURCE__ */ return 'npm';\n}\n\nexports.getSDKSource = getSDKSource;\nexports.isBrowserBundle = isBrowserBundle;\n//# sourceMappingURL=env.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9lbnYuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEU7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsaUhBQWlIO0FBQ2pIO0FBQ0E7O0FBRUEsb0JBQW9CO0FBQ3BCLHVCQUF1QjtBQUN2QiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3V0aWxzL2Vudi5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuLypcbiAqIFRoaXMgbW9kdWxlIGV4aXN0cyBmb3Igb3B0aW1pemF0aW9ucyBpbiB0aGUgYnVpbGQgcHJvY2VzcyB0aHJvdWdoIHJvbGx1cCBhbmQgdGVyc2VyLiAgV2UgZGVmaW5lIHNvbWUgZ2xvYmFsXG4gKiBjb25zdGFudHMsIHdoaWNoIGNhbiBiZSBvdmVycmlkZGVuIGR1cmluZyBidWlsZC4gQnkgZ3VhcmRpbmcgY2VydGFpbiBwaWVjZXMgb2YgY29kZSB3aXRoIGZ1bmN0aW9ucyB0aGF0IHJldHVybiB0aGVzZVxuICogY29uc3RhbnRzLCB3ZSBjYW4gY29udHJvbCB3aGV0aGVyIG9yIG5vdCB0aGV5IGFwcGVhciBpbiB0aGUgZmluYWwgYnVuZGxlLiAoQW55IGNvZGUgZ3VhcmRlZCBieSBhIGZhbHNlIGNvbmRpdGlvbiB3aWxsXG4gKiBuZXZlciBydW4sIGFuZCB3aWxsIGhlbmNlIGJlIGRyb3BwZWQgZHVyaW5nIHRyZWVzaGFraW5nLikgVGhlIHR3byBwcmltYXJ5IHVzZXMgZm9yIHRoaXMgYXJlIHN0cmlwcGluZyBvdXQgY2FsbHMgdG9cbiAqIGBkZWJ1Z2AgYW5kIHByZXZlbnRpbmcgbm9kZS1yZWxhdGVkIGNvZGUgZnJvbSBhcHBlYXJpbmcgaW4gYnJvd3NlciBidW5kbGVzLlxuICpcbiAqIEF0dGVudGlvbjpcbiAqIFRoaXMgZmlsZSBzaG91bGQgbm90IGJlIHVzZWQgdG8gZGVmaW5lIGNvbnN0YW50cy9mbGFncyB0aGF0IGFyZSBpbnRlbmRlZCB0byBiZSB1c2VkIGZvciB0cmVlLXNoYWtpbmcgY29uZHVjdGVkIGJ5XG4gKiB1c2Vycy4gVGhlc2UgZmxhZ3Mgc2hvdWxkIGxpdmUgaW4gdGhlaXIgcmVzcGVjdGl2ZSBwYWNrYWdlcywgYXMgd2UgaWRlbnRpZmllZCB1c2VyIHRvb2xpbmcgKHNwZWNpZmljYWxseSB3ZWJwYWNrKVxuICogaGF2aW5nIGlzc3VlcyB0cmVlLXNoYWtpbmcgdGhlc2UgY29uc3RhbnRzIGFjcm9zcyBwYWNrYWdlIGJvdW5kYXJpZXMuXG4gKiBBbiBleGFtcGxlIGZvciB0aGlzIGlzIHRoZSBfX1NFTlRSWV9ERUJVR19fIGNvbnN0YW50LiBJdCBpcyBkZWNsYXJlZCBpbiBlYWNoIHBhY2thZ2UgaW5kaXZpZHVhbGx5IGJlY2F1c2Ugd2Ugd2FudFxuICogdXNlcnMgdG8gYmUgYWJsZSB0byBzaGFrZSBhd2F5IGV4cHJlc3Npb25zIHRoYXQgaXQgZ3VhcmRzLlxuICovXG5cbi8qKlxuICogRmlndXJlcyBvdXQgaWYgd2UncmUgYnVpbGRpbmcgYSBicm93c2VyIGJ1bmRsZS5cbiAqXG4gKiBAcmV0dXJucyB0cnVlIGlmIHRoaXMgaXMgYSBicm93c2VyIGJ1bmRsZSBidWlsZC5cbiAqL1xuZnVuY3Rpb24gaXNCcm93c2VyQnVuZGxlKCkge1xuICByZXR1cm4gdHlwZW9mIF9fU0VOVFJZX0JST1dTRVJfQlVORExFX18gIT09ICd1bmRlZmluZWQnICYmICEhX19TRU5UUllfQlJPV1NFUl9CVU5ETEVfXztcbn1cblxuLyoqXG4gKiBHZXQgc291cmNlIG9mIFNESy5cbiAqL1xuZnVuY3Rpb24gZ2V0U0RLU291cmNlKCkge1xuICAvLyBUaGlzIGNvbW1lbnQgaXMgdXNlZCB0byBpZGVudGlmeSB0aGlzIGxpbmUgaW4gdGhlIENETiBidW5kbGUgYnVpbGQgc3RlcCBhbmQgcmVwbGFjZSB0aGlzIHdpdGggXCJyZXR1cm4gJ2Nkbic7XCJcbiAgLyogX19TRU5UUllfU0RLX1NPVVJDRV9fICovIHJldHVybiAnbnBtJztcbn1cblxuZXhwb3J0cy5nZXRTREtTb3VyY2UgPSBnZXRTREtTb3VyY2U7XG5leHBvcnRzLmlzQnJvd3NlckJ1bmRsZSA9IGlzQnJvd3NlckJ1bmRsZTtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWVudi5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/env.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/envelope.js":
/*!******************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/envelope.js ***!
  \******************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst carrier = __webpack_require__(/*! ../carrier.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/carrier.js\");\nconst dsn = __webpack_require__(/*! ./dsn.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/dsn.js\");\nconst normalize = __webpack_require__(/*! ./normalize.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/normalize.js\");\nconst worldwide = __webpack_require__(/*! ./worldwide.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/worldwide.js\");\n\n/**\n * Creates an envelope.\n * Make sure to always explicitly provide the generic to this function\n * so that the envelope types resolve correctly.\n */\nfunction createEnvelope(headers, items = []) {\n  return [headers, items] ;\n}\n\n/**\n * Add an item to an envelope.\n * Make sure to always explicitly provide the generic to this function\n * so that the envelope types resolve correctly.\n */\nfunction addItemToEnvelope(envelope, newItem) {\n  const [headers, items] = envelope;\n  return [headers, [...items, newItem]] ;\n}\n\n/**\n * Convenience function to loop through the items and item types of an envelope.\n * (This function was mostly created because working with envelope types is painful at the moment)\n *\n * If the callback returns true, the rest of the items will be skipped.\n */\nfunction forEachEnvelopeItem(\n  envelope,\n  callback,\n) {\n  const envelopeItems = envelope[1];\n\n  for (const envelopeItem of envelopeItems) {\n    const envelopeItemType = envelopeItem[0].type;\n    const result = callback(envelopeItem, envelopeItemType);\n\n    if (result) {\n      return true;\n    }\n  }\n\n  return false;\n}\n\n/**\n * Returns true if the envelope contains any of the given envelope item types\n */\nfunction envelopeContainsItemType(envelope, types) {\n  return forEachEnvelopeItem(envelope, (_, type) => types.includes(type));\n}\n\n/**\n * Encode a string to UTF8 array.\n */\nfunction encodeUTF8(input) {\n  const carrier$1 = carrier.getSentryCarrier(worldwide.GLOBAL_OBJ);\n  return carrier$1.encodePolyfill ? carrier$1.encodePolyfill(input) : new TextEncoder().encode(input);\n}\n\n/**\n * Decode a UTF8 array to string.\n */\nfunction decodeUTF8(input) {\n  const carrier$1 = carrier.getSentryCarrier(worldwide.GLOBAL_OBJ);\n  return carrier$1.decodePolyfill ? carrier$1.decodePolyfill(input) : new TextDecoder().decode(input);\n}\n\n/**\n * Serializes an envelope.\n */\nfunction serializeEnvelope(envelope) {\n  const [envHeaders, items] = envelope;\n  // Initially we construct our envelope as a string and only convert to binary chunks if we encounter binary data\n  let parts = JSON.stringify(envHeaders);\n\n  function append(next) {\n    if (typeof parts === 'string') {\n      parts = typeof next === 'string' ? parts + next : [encodeUTF8(parts), next];\n    } else {\n      parts.push(typeof next === 'string' ? encodeUTF8(next) : next);\n    }\n  }\n\n  for (const item of items) {\n    const [itemHeaders, payload] = item;\n\n    append(`\\n${JSON.stringify(itemHeaders)}\\n`);\n\n    if (typeof payload === 'string' || payload instanceof Uint8Array) {\n      append(payload);\n    } else {\n      let stringifiedPayload;\n      try {\n        stringifiedPayload = JSON.stringify(payload);\n      } catch {\n        // In case, despite all our efforts to keep `payload` circular-dependency-free, `JSON.stringify()` still\n        // fails, we try again after normalizing it again with infinite normalization depth. This of course has a\n        // performance impact but in this case a performance hit is better than throwing.\n        stringifiedPayload = JSON.stringify(normalize.normalize(payload));\n      }\n      append(stringifiedPayload);\n    }\n  }\n\n  return typeof parts === 'string' ? parts : concatBuffers(parts);\n}\n\nfunction concatBuffers(buffers) {\n  const totalLength = buffers.reduce((acc, buf) => acc + buf.length, 0);\n\n  const merged = new Uint8Array(totalLength);\n  let offset = 0;\n  for (const buffer of buffers) {\n    merged.set(buffer, offset);\n    offset += buffer.length;\n  }\n\n  return merged;\n}\n\n/**\n * Parses an envelope\n */\nfunction parseEnvelope(env) {\n  let buffer = typeof env === 'string' ? encodeUTF8(env) : env;\n\n  function readBinary(length) {\n    const bin = buffer.subarray(0, length);\n    // Replace the buffer with the remaining data excluding trailing newline\n    buffer = buffer.subarray(length + 1);\n    return bin;\n  }\n\n  function readJson() {\n    let i = buffer.indexOf(0xa);\n    // If we couldn't find a newline, we must have found the end of the buffer\n    if (i < 0) {\n      i = buffer.length;\n    }\n\n    return JSON.parse(decodeUTF8(readBinary(i))) ;\n  }\n\n  const envelopeHeader = readJson();\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  const items = [];\n\n  while (buffer.length) {\n    const itemHeader = readJson();\n    const binaryLength = typeof itemHeader.length === 'number' ? itemHeader.length : undefined;\n\n    items.push([itemHeader, binaryLength ? readBinary(binaryLength) : readJson()]);\n  }\n\n  return [envelopeHeader, items];\n}\n\n/**\n * Creates envelope item for a single span\n */\nfunction createSpanEnvelopeItem(spanJson) {\n  const spanHeaders = {\n    type: 'span',\n  };\n\n  return [spanHeaders, spanJson];\n}\n\n/**\n * Creates attachment envelope items\n */\nfunction createAttachmentEnvelopeItem(attachment) {\n  const buffer = typeof attachment.data === 'string' ? encodeUTF8(attachment.data) : attachment.data;\n\n  return [\n    {\n      type: 'attachment',\n      length: buffer.length,\n      filename: attachment.filename,\n      content_type: attachment.contentType,\n      attachment_type: attachment.attachmentType,\n    },\n    buffer,\n  ];\n}\n\nconst ITEM_TYPE_TO_DATA_CATEGORY_MAP = {\n  session: 'session',\n  sessions: 'session',\n  attachment: 'attachment',\n  transaction: 'transaction',\n  event: 'error',\n  client_report: 'internal',\n  user_report: 'default',\n  profile: 'profile',\n  profile_chunk: 'profile',\n  replay_event: 'replay',\n  replay_recording: 'replay',\n  check_in: 'monitor',\n  feedback: 'feedback',\n  span: 'span',\n  raw_security: 'security',\n  log: 'log_item',\n};\n\n/**\n * Maps the type of an envelope item to a data category.\n */\nfunction envelopeItemTypeToDataCategory(type) {\n  return ITEM_TYPE_TO_DATA_CATEGORY_MAP[type];\n}\n\n/** Extracts the minimal SDK info from the metadata or an events */\nfunction getSdkMetadataForEnvelopeHeader(metadataOrEvent) {\n  if (!metadataOrEvent?.sdk) {\n    return;\n  }\n  const { name, version } = metadataOrEvent.sdk;\n  return { name, version };\n}\n\n/**\n * Creates event envelope headers, based on event, sdk info and tunnel\n * Note: This function was extracted from the core package to make it available in Replay\n */\nfunction createEventEnvelopeHeaders(\n  event,\n  sdkInfo,\n  tunnel,\n  dsn$1,\n) {\n  const dynamicSamplingContext = event.sdkProcessingMetadata?.dynamicSamplingContext;\n  return {\n    event_id: event.event_id ,\n    sent_at: new Date().toISOString(),\n    ...(sdkInfo && { sdk: sdkInfo }),\n    ...(!!tunnel && dsn$1 && { dsn: dsn.dsnToString(dsn$1) }),\n    ...(dynamicSamplingContext && {\n      trace: dynamicSamplingContext,\n    }),\n  };\n}\n\nexports.addItemToEnvelope = addItemToEnvelope;\nexports.createAttachmentEnvelopeItem = createAttachmentEnvelopeItem;\nexports.createEnvelope = createEnvelope;\nexports.createEventEnvelopeHeaders = createEventEnvelopeHeaders;\nexports.createSpanEnvelopeItem = createSpanEnvelopeItem;\nexports.envelopeContainsItemType = envelopeContainsItemType;\nexports.envelopeItemTypeToDataCategory = envelopeItemTypeToDataCategory;\nexports.forEachEnvelopeItem = forEachEnvelopeItem;\nexports.getSdkMetadataForEnvelopeHeader = getSdkMetadataForEnvelopeHeader;\nexports.parseEnvelope = parseEnvelope;\nexports.serializeEnvelope = serializeEnvelope;\n//# sourceMappingURL=envelope.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9lbnZlbG9wZS5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxnQkFBZ0IsbUJBQU8sQ0FBQyxvSEFBZTtBQUN2QyxZQUFZLG1CQUFPLENBQUMsaUhBQVU7QUFDOUIsa0JBQWtCLG1CQUFPLENBQUMsNkhBQWdCO0FBQzFDLGtCQUFrQixtQkFBTyxDQUFDLDZIQUFnQjs7QUFFMUM7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0EsTUFBTTtBQUNOO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBLGdCQUFnQiw0QkFBNEI7O0FBRTVDO0FBQ0E7QUFDQSxNQUFNO0FBQ047QUFDQTtBQUNBO0FBQ0EsUUFBUTtBQUNSO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEtBQUs7QUFDTDtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsVUFBVSxnQkFBZ0I7QUFDMUIsV0FBVztBQUNYOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxxQkFBcUIsY0FBYztBQUNuQywrQkFBK0IsNkJBQTZCO0FBQzVEO0FBQ0E7QUFDQSxLQUFLO0FBQ0w7QUFDQTs7QUFFQSx5QkFBeUI7QUFDekIsb0NBQW9DO0FBQ3BDLHNCQUFzQjtBQUN0QixrQ0FBa0M7QUFDbEMsOEJBQThCO0FBQzlCLGdDQUFnQztBQUNoQyxzQ0FBc0M7QUFDdEMsMkJBQTJCO0FBQzNCLHVDQUF1QztBQUN2QyxxQkFBcUI7QUFDckIseUJBQXlCO0FBQ3pCIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvZW52ZWxvcGUuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGNhcnJpZXIgPSByZXF1aXJlKCcuLi9jYXJyaWVyLmpzJyk7XG5jb25zdCBkc24gPSByZXF1aXJlKCcuL2Rzbi5qcycpO1xuY29uc3Qgbm9ybWFsaXplID0gcmVxdWlyZSgnLi9ub3JtYWxpemUuanMnKTtcbmNvbnN0IHdvcmxkd2lkZSA9IHJlcXVpcmUoJy4vd29ybGR3aWRlLmpzJyk7XG5cbi8qKlxuICogQ3JlYXRlcyBhbiBlbnZlbG9wZS5cbiAqIE1ha2Ugc3VyZSB0byBhbHdheXMgZXhwbGljaXRseSBwcm92aWRlIHRoZSBnZW5lcmljIHRvIHRoaXMgZnVuY3Rpb25cbiAqIHNvIHRoYXQgdGhlIGVudmVsb3BlIHR5cGVzIHJlc29sdmUgY29ycmVjdGx5LlxuICovXG5mdW5jdGlvbiBjcmVhdGVFbnZlbG9wZShoZWFkZXJzLCBpdGVtcyA9IFtdKSB7XG4gIHJldHVybiBbaGVhZGVycywgaXRlbXNdIDtcbn1cblxuLyoqXG4gKiBBZGQgYW4gaXRlbSB0byBhbiBlbnZlbG9wZS5cbiAqIE1ha2Ugc3VyZSB0byBhbHdheXMgZXhwbGljaXRseSBwcm92aWRlIHRoZSBnZW5lcmljIHRvIHRoaXMgZnVuY3Rpb25cbiAqIHNvIHRoYXQgdGhlIGVudmVsb3BlIHR5cGVzIHJlc29sdmUgY29ycmVjdGx5LlxuICovXG5mdW5jdGlvbiBhZGRJdGVtVG9FbnZlbG9wZShlbnZlbG9wZSwgbmV3SXRlbSkge1xuICBjb25zdCBbaGVhZGVycywgaXRlbXNdID0gZW52ZWxvcGU7XG4gIHJldHVybiBbaGVhZGVycywgWy4uLml0ZW1zLCBuZXdJdGVtXV0gO1xufVxuXG4vKipcbiAqIENvbnZlbmllbmNlIGZ1bmN0aW9uIHRvIGxvb3AgdGhyb3VnaCB0aGUgaXRlbXMgYW5kIGl0ZW0gdHlwZXMgb2YgYW4gZW52ZWxvcGUuXG4gKiAoVGhpcyBmdW5jdGlvbiB3YXMgbW9zdGx5IGNyZWF0ZWQgYmVjYXVzZSB3b3JraW5nIHdpdGggZW52ZWxvcGUgdHlwZXMgaXMgcGFpbmZ1bCBhdCB0aGUgbW9tZW50KVxuICpcbiAqIElmIHRoZSBjYWxsYmFjayByZXR1cm5zIHRydWUsIHRoZSByZXN0IG9mIHRoZSBpdGVtcyB3aWxsIGJlIHNraXBwZWQuXG4gKi9cbmZ1bmN0aW9uIGZvckVhY2hFbnZlbG9wZUl0ZW0oXG4gIGVudmVsb3BlLFxuICBjYWxsYmFjayxcbikge1xuICBjb25zdCBlbnZlbG9wZUl0ZW1zID0gZW52ZWxvcGVbMV07XG5cbiAgZm9yIChjb25zdCBlbnZlbG9wZUl0ZW0gb2YgZW52ZWxvcGVJdGVtcykge1xuICAgIGNvbnN0IGVudmVsb3BlSXRlbVR5cGUgPSBlbnZlbG9wZUl0ZW1bMF0udHlwZTtcbiAgICBjb25zdCByZXN1bHQgPSBjYWxsYmFjayhlbnZlbG9wZUl0ZW0sIGVudmVsb3BlSXRlbVR5cGUpO1xuXG4gICAgaWYgKHJlc3VsdCkge1xuICAgICAgcmV0dXJuIHRydWU7XG4gICAgfVxuICB9XG5cbiAgcmV0dXJuIGZhbHNlO1xufVxuXG4vKipcbiAqIFJldHVybnMgdHJ1ZSBpZiB0aGUgZW52ZWxvcGUgY29udGFpbnMgYW55IG9mIHRoZSBnaXZlbiBlbnZlbG9wZSBpdGVtIHR5cGVzXG4gKi9cbmZ1bmN0aW9uIGVudmVsb3BlQ29udGFpbnNJdGVtVHlwZShlbnZlbG9wZSwgdHlwZXMpIHtcbiAgcmV0dXJuIGZvckVhY2hFbnZlbG9wZUl0ZW0oZW52ZWxvcGUsIChfLCB0eXBlKSA9PiB0eXBlcy5pbmNsdWRlcyh0eXBlKSk7XG59XG5cbi8qKlxuICogRW5jb2RlIGEgc3RyaW5nIHRvIFVURjggYXJyYXkuXG4gKi9cbmZ1bmN0aW9uIGVuY29kZVVURjgoaW5wdXQpIHtcbiAgY29uc3QgY2FycmllciQxID0gY2Fycmllci5nZXRTZW50cnlDYXJyaWVyKHdvcmxkd2lkZS5HTE9CQUxfT0JKKTtcbiAgcmV0dXJuIGNhcnJpZXIkMS5lbmNvZGVQb2x5ZmlsbCA/IGNhcnJpZXIkMS5lbmNvZGVQb2x5ZmlsbChpbnB1dCkgOiBuZXcgVGV4dEVuY29kZXIoKS5lbmNvZGUoaW5wdXQpO1xufVxuXG4vKipcbiAqIERlY29kZSBhIFVURjggYXJyYXkgdG8gc3RyaW5nLlxuICovXG5mdW5jdGlvbiBkZWNvZGVVVEY4KGlucHV0KSB7XG4gIGNvbnN0IGNhcnJpZXIkMSA9IGNhcnJpZXIuZ2V0U2VudHJ5Q2Fycmllcih3b3JsZHdpZGUuR0xPQkFMX09CSik7XG4gIHJldHVybiBjYXJyaWVyJDEuZGVjb2RlUG9seWZpbGwgPyBjYXJyaWVyJDEuZGVjb2RlUG9seWZpbGwoaW5wdXQpIDogbmV3IFRleHREZWNvZGVyKCkuZGVjb2RlKGlucHV0KTtcbn1cblxuLyoqXG4gKiBTZXJpYWxpemVzIGFuIGVudmVsb3BlLlxuICovXG5mdW5jdGlvbiBzZXJpYWxpemVFbnZlbG9wZShlbnZlbG9wZSkge1xuICBjb25zdCBbZW52SGVhZGVycywgaXRlbXNdID0gZW52ZWxvcGU7XG4gIC8vIEluaXRpYWxseSB3ZSBjb25zdHJ1Y3Qgb3VyIGVudmVsb3BlIGFzIGEgc3RyaW5nIGFuZCBvbmx5IGNvbnZlcnQgdG8gYmluYXJ5IGNodW5rcyBpZiB3ZSBlbmNvdW50ZXIgYmluYXJ5IGRhdGFcbiAgbGV0IHBhcnRzID0gSlNPTi5zdHJpbmdpZnkoZW52SGVhZGVycyk7XG5cbiAgZnVuY3Rpb24gYXBwZW5kKG5leHQpIHtcbiAgICBpZiAodHlwZW9mIHBhcnRzID09PSAnc3RyaW5nJykge1xuICAgICAgcGFydHMgPSB0eXBlb2YgbmV4dCA9PT0gJ3N0cmluZycgPyBwYXJ0cyArIG5leHQgOiBbZW5jb2RlVVRGOChwYXJ0cyksIG5leHRdO1xuICAgIH0gZWxzZSB7XG4gICAgICBwYXJ0cy5wdXNoKHR5cGVvZiBuZXh0ID09PSAnc3RyaW5nJyA/IGVuY29kZVVURjgobmV4dCkgOiBuZXh0KTtcbiAgICB9XG4gIH1cblxuICBmb3IgKGNvbnN0IGl0ZW0gb2YgaXRlbXMpIHtcbiAgICBjb25zdCBbaXRlbUhlYWRlcnMsIHBheWxvYWRdID0gaXRlbTtcblxuICAgIGFwcGVuZChgXFxuJHtKU09OLnN0cmluZ2lmeShpdGVtSGVhZGVycyl9XFxuYCk7XG5cbiAgICBpZiAodHlwZW9mIHBheWxvYWQgPT09ICdzdHJpbmcnIHx8IHBheWxvYWQgaW5zdGFuY2VvZiBVaW50OEFycmF5KSB7XG4gICAgICBhcHBlbmQocGF5bG9hZCk7XG4gICAgfSBlbHNlIHtcbiAgICAgIGxldCBzdHJpbmdpZmllZFBheWxvYWQ7XG4gICAgICB0cnkge1xuICAgICAgICBzdHJpbmdpZmllZFBheWxvYWQgPSBKU09OLnN0cmluZ2lmeShwYXlsb2FkKTtcbiAgICAgIH0gY2F0Y2gge1xuICAgICAgICAvLyBJbiBjYXNlLCBkZXNwaXRlIGFsbCBvdXIgZWZmb3J0cyB0byBrZWVwIGBwYXlsb2FkYCBjaXJjdWxhci1kZXBlbmRlbmN5LWZyZWUsIGBKU09OLnN0cmluZ2lmeSgpYCBzdGlsbFxuICAgICAgICAvLyBmYWlscywgd2UgdHJ5IGFnYWluIGFmdGVyIG5vcm1hbGl6aW5nIGl0IGFnYWluIHdpdGggaW5maW5pdGUgbm9ybWFsaXphdGlvbiBkZXB0aC4gVGhpcyBvZiBjb3Vyc2UgaGFzIGFcbiAgICAgICAgLy8gcGVyZm9ybWFuY2UgaW1wYWN0IGJ1dCBpbiB0aGlzIGNhc2UgYSBwZXJmb3JtYW5jZSBoaXQgaXMgYmV0dGVyIHRoYW4gdGhyb3dpbmcuXG4gICAgICAgIHN0cmluZ2lmaWVkUGF5bG9hZCA9IEpTT04uc3RyaW5naWZ5KG5vcm1hbGl6ZS5ub3JtYWxpemUocGF5bG9hZCkpO1xuICAgICAgfVxuICAgICAgYXBwZW5kKHN0cmluZ2lmaWVkUGF5bG9hZCk7XG4gICAgfVxuICB9XG5cbiAgcmV0dXJuIHR5cGVvZiBwYXJ0cyA9PT0gJ3N0cmluZycgPyBwYXJ0cyA6IGNvbmNhdEJ1ZmZlcnMocGFydHMpO1xufVxuXG5mdW5jdGlvbiBjb25jYXRCdWZmZXJzKGJ1ZmZlcnMpIHtcbiAgY29uc3QgdG90YWxMZW5ndGggPSBidWZmZXJzLnJlZHVjZSgoYWNjLCBidWYpID0+IGFjYyArIGJ1Zi5sZW5ndGgsIDApO1xuXG4gIGNvbnN0IG1lcmdlZCA9IG5ldyBVaW50OEFycmF5KHRvdGFsTGVuZ3RoKTtcbiAgbGV0IG9mZnNldCA9IDA7XG4gIGZvciAoY29uc3QgYnVmZmVyIG9mIGJ1ZmZlcnMpIHtcbiAgICBtZXJnZWQuc2V0KGJ1ZmZlciwgb2Zmc2V0KTtcbiAgICBvZmZzZXQgKz0gYnVmZmVyLmxlbmd0aDtcbiAgfVxuXG4gIHJldHVybiBtZXJnZWQ7XG59XG5cbi8qKlxuICogUGFyc2VzIGFuIGVudmVsb3BlXG4gKi9cbmZ1bmN0aW9uIHBhcnNlRW52ZWxvcGUoZW52KSB7XG4gIGxldCBidWZmZXIgPSB0eXBlb2YgZW52ID09PSAnc3RyaW5nJyA/IGVuY29kZVVURjgoZW52KSA6IGVudjtcblxuICBmdW5jdGlvbiByZWFkQmluYXJ5KGxlbmd0aCkge1xuICAgIGNvbnN0IGJpbiA9IGJ1ZmZlci5zdWJhcnJheSgwLCBsZW5ndGgpO1xuICAgIC8vIFJlcGxhY2UgdGhlIGJ1ZmZlciB3aXRoIHRoZSByZW1haW5pbmcgZGF0YSBleGNsdWRpbmcgdHJhaWxpbmcgbmV3bGluZVxuICAgIGJ1ZmZlciA9IGJ1ZmZlci5zdWJhcnJheShsZW5ndGggKyAxKTtcbiAgICByZXR1cm4gYmluO1xuICB9XG5cbiAgZnVuY3Rpb24gcmVhZEpzb24oKSB7XG4gICAgbGV0IGkgPSBidWZmZXIuaW5kZXhPZigweGEpO1xuICAgIC8vIElmIHdlIGNvdWxkbid0IGZpbmQgYSBuZXdsaW5lLCB3ZSBtdXN0IGhhdmUgZm91bmQgdGhlIGVuZCBvZiB0aGUgYnVmZmVyXG4gICAgaWYgKGkgPCAwKSB7XG4gICAgICBpID0gYnVmZmVyLmxlbmd0aDtcbiAgICB9XG5cbiAgICByZXR1cm4gSlNPTi5wYXJzZShkZWNvZGVVVEY4KHJlYWRCaW5hcnkoaSkpKSA7XG4gIH1cblxuICBjb25zdCBlbnZlbG9wZUhlYWRlciA9IHJlYWRKc29uKCk7XG4gIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tZXhwbGljaXQtYW55XG4gIGNvbnN0IGl0ZW1zID0gW107XG5cbiAgd2hpbGUgKGJ1ZmZlci5sZW5ndGgpIHtcbiAgICBjb25zdCBpdGVtSGVhZGVyID0gcmVhZEpzb24oKTtcbiAgICBjb25zdCBiaW5hcnlMZW5ndGggPSB0eXBlb2YgaXRlbUhlYWRlci5sZW5ndGggPT09ICdudW1iZXInID8gaXRlbUhlYWRlci5sZW5ndGggOiB1bmRlZmluZWQ7XG5cbiAgICBpdGVtcy5wdXNoKFtpdGVtSGVhZGVyLCBiaW5hcnlMZW5ndGggPyByZWFkQmluYXJ5KGJpbmFyeUxlbmd0aCkgOiByZWFkSnNvbigpXSk7XG4gIH1cblxuICByZXR1cm4gW2VudmVsb3BlSGVhZGVyLCBpdGVtc107XG59XG5cbi8qKlxuICogQ3JlYXRlcyBlbnZlbG9wZSBpdGVtIGZvciBhIHNpbmdsZSBzcGFuXG4gKi9cbmZ1bmN0aW9uIGNyZWF0ZVNwYW5FbnZlbG9wZUl0ZW0oc3Bhbkpzb24pIHtcbiAgY29uc3Qgc3BhbkhlYWRlcnMgPSB7XG4gICAgdHlwZTogJ3NwYW4nLFxuICB9O1xuXG4gIHJldHVybiBbc3BhbkhlYWRlcnMsIHNwYW5Kc29uXTtcbn1cblxuLyoqXG4gKiBDcmVhdGVzIGF0dGFjaG1lbnQgZW52ZWxvcGUgaXRlbXNcbiAqL1xuZnVuY3Rpb24gY3JlYXRlQXR0YWNobWVudEVudmVsb3BlSXRlbShhdHRhY2htZW50KSB7XG4gIGNvbnN0IGJ1ZmZlciA9IHR5cGVvZiBhdHRhY2htZW50LmRhdGEgPT09ICdzdHJpbmcnID8gZW5jb2RlVVRGOChhdHRhY2htZW50LmRhdGEpIDogYXR0YWNobWVudC5kYXRhO1xuXG4gIHJldHVybiBbXG4gICAge1xuICAgICAgdHlwZTogJ2F0dGFjaG1lbnQnLFxuICAgICAgbGVuZ3RoOiBidWZmZXIubGVuZ3RoLFxuICAgICAgZmlsZW5hbWU6IGF0dGFjaG1lbnQuZmlsZW5hbWUsXG4gICAgICBjb250ZW50X3R5cGU6IGF0dGFjaG1lbnQuY29udGVudFR5cGUsXG4gICAgICBhdHRhY2htZW50X3R5cGU6IGF0dGFjaG1lbnQuYXR0YWNobWVudFR5cGUsXG4gICAgfSxcbiAgICBidWZmZXIsXG4gIF07XG59XG5cbmNvbnN0IElURU1fVFlQRV9UT19EQVRBX0NBVEVHT1JZX01BUCA9IHtcbiAgc2Vzc2lvbjogJ3Nlc3Npb24nLFxuICBzZXNzaW9uczogJ3Nlc3Npb24nLFxuICBhdHRhY2htZW50OiAnYXR0YWNobWVudCcsXG4gIHRyYW5zYWN0aW9uOiAndHJhbnNhY3Rpb24nLFxuICBldmVudDogJ2Vycm9yJyxcbiAgY2xpZW50X3JlcG9ydDogJ2ludGVybmFsJyxcbiAgdXNlcl9yZXBvcnQ6ICdkZWZhdWx0JyxcbiAgcHJvZmlsZTogJ3Byb2ZpbGUnLFxuICBwcm9maWxlX2NodW5rOiAncHJvZmlsZScsXG4gIHJlcGxheV9ldmVudDogJ3JlcGxheScsXG4gIHJlcGxheV9yZWNvcmRpbmc6ICdyZXBsYXknLFxuICBjaGVja19pbjogJ21vbml0b3InLFxuICBmZWVkYmFjazogJ2ZlZWRiYWNrJyxcbiAgc3BhbjogJ3NwYW4nLFxuICByYXdfc2VjdXJpdHk6ICdzZWN1cml0eScsXG4gIGxvZzogJ2xvZ19pdGVtJyxcbn07XG5cbi8qKlxuICogTWFwcyB0aGUgdHlwZSBvZiBhbiBlbnZlbG9wZSBpdGVtIHRvIGEgZGF0YSBjYXRlZ29yeS5cbiAqL1xuZnVuY3Rpb24gZW52ZWxvcGVJdGVtVHlwZVRvRGF0YUNhdGVnb3J5KHR5cGUpIHtcbiAgcmV0dXJuIElURU1fVFlQRV9UT19EQVRBX0NBVEVHT1JZX01BUFt0eXBlXTtcbn1cblxuLyoqIEV4dHJhY3RzIHRoZSBtaW5pbWFsIFNESyBpbmZvIGZyb20gdGhlIG1ldGFkYXRhIG9yIGFuIGV2ZW50cyAqL1xuZnVuY3Rpb24gZ2V0U2RrTWV0YWRhdGFGb3JFbnZlbG9wZUhlYWRlcihtZXRhZGF0YU9yRXZlbnQpIHtcbiAgaWYgKCFtZXRhZGF0YU9yRXZlbnQ/LnNkaykge1xuICAgIHJldHVybjtcbiAgfVxuICBjb25zdCB7IG5hbWUsIHZlcnNpb24gfSA9IG1ldGFkYXRhT3JFdmVudC5zZGs7XG4gIHJldHVybiB7IG5hbWUsIHZlcnNpb24gfTtcbn1cblxuLyoqXG4gKiBDcmVhdGVzIGV2ZW50IGVudmVsb3BlIGhlYWRlcnMsIGJhc2VkIG9uIGV2ZW50LCBzZGsgaW5mbyBhbmQgdHVubmVsXG4gKiBOb3RlOiBUaGlzIGZ1bmN0aW9uIHdhcyBleHRyYWN0ZWQgZnJvbSB0aGUgY29yZSBwYWNrYWdlIHRvIG1ha2UgaXQgYXZhaWxhYmxlIGluIFJlcGxheVxuICovXG5mdW5jdGlvbiBjcmVhdGVFdmVudEVudmVsb3BlSGVhZGVycyhcbiAgZXZlbnQsXG4gIHNka0luZm8sXG4gIHR1bm5lbCxcbiAgZHNuJDEsXG4pIHtcbiAgY29uc3QgZHluYW1pY1NhbXBsaW5nQ29udGV4dCA9IGV2ZW50LnNka1Byb2Nlc3NpbmdNZXRhZGF0YT8uZHluYW1pY1NhbXBsaW5nQ29udGV4dDtcbiAgcmV0dXJuIHtcbiAgICBldmVudF9pZDogZXZlbnQuZXZlbnRfaWQgLFxuICAgIHNlbnRfYXQ6IG5ldyBEYXRlKCkudG9JU09TdHJpbmcoKSxcbiAgICAuLi4oc2RrSW5mbyAmJiB7IHNkazogc2RrSW5mbyB9KSxcbiAgICAuLi4oISF0dW5uZWwgJiYgZHNuJDEgJiYgeyBkc246IGRzbi5kc25Ub1N0cmluZyhkc24kMSkgfSksXG4gICAgLi4uKGR5bmFtaWNTYW1wbGluZ0NvbnRleHQgJiYge1xuICAgICAgdHJhY2U6IGR5bmFtaWNTYW1wbGluZ0NvbnRleHQsXG4gICAgfSksXG4gIH07XG59XG5cbmV4cG9ydHMuYWRkSXRlbVRvRW52ZWxvcGUgPSBhZGRJdGVtVG9FbnZlbG9wZTtcbmV4cG9ydHMuY3JlYXRlQXR0YWNobWVudEVudmVsb3BlSXRlbSA9IGNyZWF0ZUF0dGFjaG1lbnRFbnZlbG9wZUl0ZW07XG5leHBvcnRzLmNyZWF0ZUVudmVsb3BlID0gY3JlYXRlRW52ZWxvcGU7XG5leHBvcnRzLmNyZWF0ZUV2ZW50RW52ZWxvcGVIZWFkZXJzID0gY3JlYXRlRXZlbnRFbnZlbG9wZUhlYWRlcnM7XG5leHBvcnRzLmNyZWF0ZVNwYW5FbnZlbG9wZUl0ZW0gPSBjcmVhdGVTcGFuRW52ZWxvcGVJdGVtO1xuZXhwb3J0cy5lbnZlbG9wZUNvbnRhaW5zSXRlbVR5cGUgPSBlbnZlbG9wZUNvbnRhaW5zSXRlbVR5cGU7XG5leHBvcnRzLmVudmVsb3BlSXRlbVR5cGVUb0RhdGFDYXRlZ29yeSA9IGVudmVsb3BlSXRlbVR5cGVUb0RhdGFDYXRlZ29yeTtcbmV4cG9ydHMuZm9yRWFjaEVudmVsb3BlSXRlbSA9IGZvckVhY2hFbnZlbG9wZUl0ZW07XG5leHBvcnRzLmdldFNka01ldGFkYXRhRm9yRW52ZWxvcGVIZWFkZXIgPSBnZXRTZGtNZXRhZGF0YUZvckVudmVsb3BlSGVhZGVyO1xuZXhwb3J0cy5wYXJzZUVudmVsb3BlID0gcGFyc2VFbnZlbG9wZTtcbmV4cG9ydHMuc2VyaWFsaXplRW52ZWxvcGUgPSBzZXJpYWxpemVFbnZlbG9wZTtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWVudmVsb3BlLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/envelope.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/error.js":
/*!***************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/error.js ***!
  \***************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n/**\n * An error emitted by Sentry SDKs and related utilities.\n * @deprecated This class is no longer used and will be removed in a future version. Use `Error` instead.\n */\nclass SentryError extends Error {\n\n   constructor(\n     message,\n    logLevel = 'warn',\n  ) {\n    super(message);this.message = message;\n    this.logLevel = logLevel;\n  }\n}\n\nexports.SentryError = SentryError;\n//# sourceMappingURL=error.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9lcnJvci5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsbUJBQW1CO0FBQ25CO0FBQ0E7QUFDQTs7QUFFQSxtQkFBbUI7QUFDbkIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9lcnJvci5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuLyoqXG4gKiBBbiBlcnJvciBlbWl0dGVkIGJ5IFNlbnRyeSBTREtzIGFuZCByZWxhdGVkIHV0aWxpdGllcy5cbiAqIEBkZXByZWNhdGVkIFRoaXMgY2xhc3MgaXMgbm8gbG9uZ2VyIHVzZWQgYW5kIHdpbGwgYmUgcmVtb3ZlZCBpbiBhIGZ1dHVyZSB2ZXJzaW9uLiBVc2UgYEVycm9yYCBpbnN0ZWFkLlxuICovXG5jbGFzcyBTZW50cnlFcnJvciBleHRlbmRzIEVycm9yIHtcblxuICAgY29uc3RydWN0b3IoXG4gICAgIG1lc3NhZ2UsXG4gICAgbG9nTGV2ZWwgPSAnd2FybicsXG4gICkge1xuICAgIHN1cGVyKG1lc3NhZ2UpO3RoaXMubWVzc2FnZSA9IG1lc3NhZ2U7XG4gICAgdGhpcy5sb2dMZXZlbCA9IGxvZ0xldmVsO1xuICB9XG59XG5cbmV4cG9ydHMuU2VudHJ5RXJyb3IgPSBTZW50cnlFcnJvcjtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWVycm9yLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/error.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/eventUtils.js":
/*!********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/eventUtils.js ***!
  \********************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n/**\n * Get a list of possible event messages from a Sentry event.\n */\nfunction getPossibleEventMessages(event) {\n  const possibleMessages = [];\n\n  if (event.message) {\n    possibleMessages.push(event.message);\n  }\n\n  try {\n    // @ts-expect-error Try catching to save bundle size\n    const lastException = event.exception.values[event.exception.values.length - 1];\n    if (lastException?.value) {\n      possibleMessages.push(lastException.value);\n      if (lastException.type) {\n        possibleMessages.push(`${lastException.type}: ${lastException.value}`);\n      }\n    }\n  } catch {\n    // ignore errors here\n  }\n\n  return possibleMessages;\n}\n\nexports.getPossibleEventMessages = getPossibleEventMessages;\n//# sourceMappingURL=eventUtils.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9ldmVudFV0aWxzLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGlDQUFpQyxtQkFBbUIsSUFBSSxvQkFBb0I7QUFDNUU7QUFDQTtBQUNBLElBQUk7QUFDSjtBQUNBOztBQUVBO0FBQ0E7O0FBRUEsZ0NBQWdDO0FBQ2hDIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvZXZlbnRVdGlscy5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuLyoqXG4gKiBHZXQgYSBsaXN0IG9mIHBvc3NpYmxlIGV2ZW50IG1lc3NhZ2VzIGZyb20gYSBTZW50cnkgZXZlbnQuXG4gKi9cbmZ1bmN0aW9uIGdldFBvc3NpYmxlRXZlbnRNZXNzYWdlcyhldmVudCkge1xuICBjb25zdCBwb3NzaWJsZU1lc3NhZ2VzID0gW107XG5cbiAgaWYgKGV2ZW50Lm1lc3NhZ2UpIHtcbiAgICBwb3NzaWJsZU1lc3NhZ2VzLnB1c2goZXZlbnQubWVzc2FnZSk7XG4gIH1cblxuICB0cnkge1xuICAgIC8vIEB0cy1leHBlY3QtZXJyb3IgVHJ5IGNhdGNoaW5nIHRvIHNhdmUgYnVuZGxlIHNpemVcbiAgICBjb25zdCBsYXN0RXhjZXB0aW9uID0gZXZlbnQuZXhjZXB0aW9uLnZhbHVlc1tldmVudC5leGNlcHRpb24udmFsdWVzLmxlbmd0aCAtIDFdO1xuICAgIGlmIChsYXN0RXhjZXB0aW9uPy52YWx1ZSkge1xuICAgICAgcG9zc2libGVNZXNzYWdlcy5wdXNoKGxhc3RFeGNlcHRpb24udmFsdWUpO1xuICAgICAgaWYgKGxhc3RFeGNlcHRpb24udHlwZSkge1xuICAgICAgICBwb3NzaWJsZU1lc3NhZ2VzLnB1c2goYCR7bGFzdEV4Y2VwdGlvbi50eXBlfTogJHtsYXN0RXhjZXB0aW9uLnZhbHVlfWApO1xuICAgICAgfVxuICAgIH1cbiAgfSBjYXRjaCB7XG4gICAgLy8gaWdub3JlIGVycm9ycyBoZXJlXG4gIH1cblxuICByZXR1cm4gcG9zc2libGVNZXNzYWdlcztcbn1cblxuZXhwb3J0cy5nZXRQb3NzaWJsZUV2ZW50TWVzc2FnZXMgPSBnZXRQb3NzaWJsZUV2ZW50TWVzc2FnZXM7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1ldmVudFV0aWxzLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/eventUtils.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/eventbuilder.js":
/*!**********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/eventbuilder.js ***!
  \**********************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst is = __webpack_require__(/*! ./is.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js\");\nconst misc = __webpack_require__(/*! ./misc.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/misc.js\");\nconst normalize = __webpack_require__(/*! ./normalize.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/normalize.js\");\nconst object = __webpack_require__(/*! ./object.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/object.js\");\n\n/**\n * Extracts stack frames from the error.stack string\n */\nfunction parseStackFrames(stackParser, error) {\n  return stackParser(error.stack || '', 1);\n}\n\n/**\n * Extracts stack frames from the error and builds a Sentry Exception\n */\nfunction exceptionFromError(stackParser, error) {\n  const exception = {\n    type: error.name || error.constructor.name,\n    value: error.message,\n  };\n\n  const frames = parseStackFrames(stackParser, error);\n  if (frames.length) {\n    exception.stacktrace = { frames };\n  }\n\n  return exception;\n}\n\n/** If a plain object has a property that is an `Error`, return this error. */\nfunction getErrorPropertyFromObject(obj) {\n  for (const prop in obj) {\n    if (Object.prototype.hasOwnProperty.call(obj, prop)) {\n      const value = obj[prop];\n      if (value instanceof Error) {\n        return value;\n      }\n    }\n  }\n\n  return undefined;\n}\n\nfunction getMessageForObject(exception) {\n  if ('name' in exception && typeof exception.name === 'string') {\n    let message = `'${exception.name}' captured as exception`;\n\n    if ('message' in exception && typeof exception.message === 'string') {\n      message += ` with message '${exception.message}'`;\n    }\n\n    return message;\n  } else if ('message' in exception && typeof exception.message === 'string') {\n    return exception.message;\n  }\n\n  const keys = object.extractExceptionKeysForMessage(exception);\n\n  // Some ErrorEvent instances do not have an `error` property, which is why they are not handled before\n  // We still want to try to get a decent message for these cases\n  if (is.isErrorEvent(exception)) {\n    return `Event \\`ErrorEvent\\` captured as exception with message \\`${exception.message}\\``;\n  }\n\n  const className = getObjectClassName(exception);\n\n  return `${\n    className && className !== 'Object' ? `'${className}'` : 'Object'\n  } captured as exception with keys: ${keys}`;\n}\n\nfunction getObjectClassName(obj) {\n  try {\n    const prototype = Object.getPrototypeOf(obj);\n    return prototype ? prototype.constructor.name : undefined;\n  } catch {\n    // ignore errors here\n  }\n}\n\nfunction getException(\n  client,\n  mechanism,\n  exception,\n  hint,\n) {\n  if (is.isError(exception)) {\n    return [exception, undefined];\n  }\n\n  // Mutate this!\n  mechanism.synthetic = true;\n\n  if (is.isPlainObject(exception)) {\n    const normalizeDepth = client?.getOptions().normalizeDepth;\n    const extras = { ['__serialized__']: normalize.normalizeToSize(exception , normalizeDepth) };\n\n    const errorFromProp = getErrorPropertyFromObject(exception);\n    if (errorFromProp) {\n      return [errorFromProp, extras];\n    }\n\n    const message = getMessageForObject(exception);\n    const ex = hint?.syntheticException || new Error(message);\n    ex.message = message;\n\n    return [ex, extras];\n  }\n\n  // This handles when someone does: `throw \"something awesome\";`\n  // We use synthesized Error here so we can extract a (rough) stack trace.\n  const ex = hint?.syntheticException || new Error(exception );\n  ex.message = `${exception}`;\n\n  return [ex, undefined];\n}\n\n/**\n * Builds and Event from a Exception\n * @hidden\n */\nfunction eventFromUnknownInput(\n  client,\n  stackParser,\n  exception,\n  hint,\n) {\n  const providedMechanism = hint?.data && (hint.data ).mechanism;\n  const mechanism = providedMechanism || {\n    handled: true,\n    type: 'generic',\n  };\n\n  const [ex, extras] = getException(client, mechanism, exception, hint);\n\n  const event = {\n    exception: {\n      values: [exceptionFromError(stackParser, ex)],\n    },\n  };\n\n  if (extras) {\n    event.extra = extras;\n  }\n\n  misc.addExceptionTypeValue(event, undefined, undefined);\n  misc.addExceptionMechanism(event, mechanism);\n\n  return {\n    ...event,\n    event_id: hint?.event_id,\n  };\n}\n\n/**\n * Builds and Event from a Message\n * @hidden\n */\nfunction eventFromMessage(\n  stackParser,\n  message,\n  level = 'info',\n  hint,\n  attachStacktrace,\n) {\n  const event = {\n    event_id: hint?.event_id,\n    level,\n  };\n\n  if (attachStacktrace && hint?.syntheticException) {\n    const frames = parseStackFrames(stackParser, hint.syntheticException);\n    if (frames.length) {\n      event.exception = {\n        values: [\n          {\n            value: message,\n            stacktrace: { frames },\n          },\n        ],\n      };\n      misc.addExceptionMechanism(event, { synthetic: true });\n    }\n  }\n\n  if (is.isParameterizedString(message)) {\n    const { __sentry_template_string__, __sentry_template_values__ } = message;\n\n    event.logentry = {\n      message: __sentry_template_string__,\n      params: __sentry_template_values__,\n    };\n    return event;\n  }\n\n  event.message = message;\n  return event;\n}\n\nexports.eventFromMessage = eventFromMessage;\nexports.eventFromUnknownInput = eventFromUnknownInput;\nexports.exceptionFromError = exceptionFromError;\nexports.parseStackFrames = parseStackFrames;\n//# sourceMappingURL=eventbuilder.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9ldmVudGJ1aWxkZXIuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsV0FBVyxtQkFBTyxDQUFDLCtHQUFTO0FBQzVCLGFBQWEsbUJBQU8sQ0FBQyxtSEFBVztBQUNoQyxrQkFBa0IsbUJBQU8sQ0FBQyw2SEFBZ0I7QUFDMUMsZUFBZSxtQkFBTyxDQUFDLHVIQUFhOztBQUVwQztBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsNkJBQTZCO0FBQzdCOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0Esc0JBQXNCLGVBQWU7O0FBRXJDO0FBQ0EsbUNBQW1DLGtCQUFrQjtBQUNyRDs7QUFFQTtBQUNBLElBQUk7QUFDSjtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBLHdFQUF3RSxrQkFBa0I7QUFDMUY7O0FBRUE7O0FBRUE7QUFDQSw4Q0FBOEMsVUFBVTtBQUN4RCxJQUFJLG1DQUFtQyxLQUFLO0FBQzVDOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsSUFBSTtBQUNKO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0EscUJBQXFCOztBQUVyQjtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQSxnRUFBZ0U7QUFDaEU7QUFDQTtBQUNBLGtCQUFrQixVQUFVOztBQUU1QjtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQSxLQUFLO0FBQ0w7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSwwQkFBMEIsUUFBUTtBQUNsQyxXQUFXO0FBQ1g7QUFDQTtBQUNBLDBDQUEwQyxpQkFBaUI7QUFDM0Q7QUFDQTs7QUFFQTtBQUNBLFlBQVkseURBQXlEOztBQUVyRTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBLHdCQUF3QjtBQUN4Qiw2QkFBNkI7QUFDN0IsMEJBQTBCO0FBQzFCLHdCQUF3QjtBQUN4QiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3V0aWxzL2V2ZW50YnVpbGRlci5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgaXMgPSByZXF1aXJlKCcuL2lzLmpzJyk7XG5jb25zdCBtaXNjID0gcmVxdWlyZSgnLi9taXNjLmpzJyk7XG5jb25zdCBub3JtYWxpemUgPSByZXF1aXJlKCcuL25vcm1hbGl6ZS5qcycpO1xuY29uc3Qgb2JqZWN0ID0gcmVxdWlyZSgnLi9vYmplY3QuanMnKTtcblxuLyoqXG4gKiBFeHRyYWN0cyBzdGFjayBmcmFtZXMgZnJvbSB0aGUgZXJyb3Iuc3RhY2sgc3RyaW5nXG4gKi9cbmZ1bmN0aW9uIHBhcnNlU3RhY2tGcmFtZXMoc3RhY2tQYXJzZXIsIGVycm9yKSB7XG4gIHJldHVybiBzdGFja1BhcnNlcihlcnJvci5zdGFjayB8fCAnJywgMSk7XG59XG5cbi8qKlxuICogRXh0cmFjdHMgc3RhY2sgZnJhbWVzIGZyb20gdGhlIGVycm9yIGFuZCBidWlsZHMgYSBTZW50cnkgRXhjZXB0aW9uXG4gKi9cbmZ1bmN0aW9uIGV4Y2VwdGlvbkZyb21FcnJvcihzdGFja1BhcnNlciwgZXJyb3IpIHtcbiAgY29uc3QgZXhjZXB0aW9uID0ge1xuICAgIHR5cGU6IGVycm9yLm5hbWUgfHwgZXJyb3IuY29uc3RydWN0b3IubmFtZSxcbiAgICB2YWx1ZTogZXJyb3IubWVzc2FnZSxcbiAgfTtcblxuICBjb25zdCBmcmFtZXMgPSBwYXJzZVN0YWNrRnJhbWVzKHN0YWNrUGFyc2VyLCBlcnJvcik7XG4gIGlmIChmcmFtZXMubGVuZ3RoKSB7XG4gICAgZXhjZXB0aW9uLnN0YWNrdHJhY2UgPSB7IGZyYW1lcyB9O1xuICB9XG5cbiAgcmV0dXJuIGV4Y2VwdGlvbjtcbn1cblxuLyoqIElmIGEgcGxhaW4gb2JqZWN0IGhhcyBhIHByb3BlcnR5IHRoYXQgaXMgYW4gYEVycm9yYCwgcmV0dXJuIHRoaXMgZXJyb3IuICovXG5mdW5jdGlvbiBnZXRFcnJvclByb3BlcnR5RnJvbU9iamVjdChvYmopIHtcbiAgZm9yIChjb25zdCBwcm9wIGluIG9iaikge1xuICAgIGlmIChPYmplY3QucHJvdG90eXBlLmhhc093blByb3BlcnR5LmNhbGwob2JqLCBwcm9wKSkge1xuICAgICAgY29uc3QgdmFsdWUgPSBvYmpbcHJvcF07XG4gICAgICBpZiAodmFsdWUgaW5zdGFuY2VvZiBFcnJvcikge1xuICAgICAgICByZXR1cm4gdmFsdWU7XG4gICAgICB9XG4gICAgfVxuICB9XG5cbiAgcmV0dXJuIHVuZGVmaW5lZDtcbn1cblxuZnVuY3Rpb24gZ2V0TWVzc2FnZUZvck9iamVjdChleGNlcHRpb24pIHtcbiAgaWYgKCduYW1lJyBpbiBleGNlcHRpb24gJiYgdHlwZW9mIGV4Y2VwdGlvbi5uYW1lID09PSAnc3RyaW5nJykge1xuICAgIGxldCBtZXNzYWdlID0gYCcke2V4Y2VwdGlvbi5uYW1lfScgY2FwdHVyZWQgYXMgZXhjZXB0aW9uYDtcblxuICAgIGlmICgnbWVzc2FnZScgaW4gZXhjZXB0aW9uICYmIHR5cGVvZiBleGNlcHRpb24ubWVzc2FnZSA9PT0gJ3N0cmluZycpIHtcbiAgICAgIG1lc3NhZ2UgKz0gYCB3aXRoIG1lc3NhZ2UgJyR7ZXhjZXB0aW9uLm1lc3NhZ2V9J2A7XG4gICAgfVxuXG4gICAgcmV0dXJuIG1lc3NhZ2U7XG4gIH0gZWxzZSBpZiAoJ21lc3NhZ2UnIGluIGV4Y2VwdGlvbiAmJiB0eXBlb2YgZXhjZXB0aW9uLm1lc3NhZ2UgPT09ICdzdHJpbmcnKSB7XG4gICAgcmV0dXJuIGV4Y2VwdGlvbi5tZXNzYWdlO1xuICB9XG5cbiAgY29uc3Qga2V5cyA9IG9iamVjdC5leHRyYWN0RXhjZXB0aW9uS2V5c0Zvck1lc3NhZ2UoZXhjZXB0aW9uKTtcblxuICAvLyBTb21lIEVycm9yRXZlbnQgaW5zdGFuY2VzIGRvIG5vdCBoYXZlIGFuIGBlcnJvcmAgcHJvcGVydHksIHdoaWNoIGlzIHdoeSB0aGV5IGFyZSBub3QgaGFuZGxlZCBiZWZvcmVcbiAgLy8gV2Ugc3RpbGwgd2FudCB0byB0cnkgdG8gZ2V0IGEgZGVjZW50IG1lc3NhZ2UgZm9yIHRoZXNlIGNhc2VzXG4gIGlmIChpcy5pc0Vycm9yRXZlbnQoZXhjZXB0aW9uKSkge1xuICAgIHJldHVybiBgRXZlbnQgXFxgRXJyb3JFdmVudFxcYCBjYXB0dXJlZCBhcyBleGNlcHRpb24gd2l0aCBtZXNzYWdlIFxcYCR7ZXhjZXB0aW9uLm1lc3NhZ2V9XFxgYDtcbiAgfVxuXG4gIGNvbnN0IGNsYXNzTmFtZSA9IGdldE9iamVjdENsYXNzTmFtZShleGNlcHRpb24pO1xuXG4gIHJldHVybiBgJHtcbiAgICBjbGFzc05hbWUgJiYgY2xhc3NOYW1lICE9PSAnT2JqZWN0JyA/IGAnJHtjbGFzc05hbWV9J2AgOiAnT2JqZWN0J1xuICB9IGNhcHR1cmVkIGFzIGV4Y2VwdGlvbiB3aXRoIGtleXM6ICR7a2V5c31gO1xufVxuXG5mdW5jdGlvbiBnZXRPYmplY3RDbGFzc05hbWUob2JqKSB7XG4gIHRyeSB7XG4gICAgY29uc3QgcHJvdG90eXBlID0gT2JqZWN0LmdldFByb3RvdHlwZU9mKG9iaik7XG4gICAgcmV0dXJuIHByb3RvdHlwZSA/IHByb3RvdHlwZS5jb25zdHJ1Y3Rvci5uYW1lIDogdW5kZWZpbmVkO1xuICB9IGNhdGNoIHtcbiAgICAvLyBpZ25vcmUgZXJyb3JzIGhlcmVcbiAgfVxufVxuXG5mdW5jdGlvbiBnZXRFeGNlcHRpb24oXG4gIGNsaWVudCxcbiAgbWVjaGFuaXNtLFxuICBleGNlcHRpb24sXG4gIGhpbnQsXG4pIHtcbiAgaWYgKGlzLmlzRXJyb3IoZXhjZXB0aW9uKSkge1xuICAgIHJldHVybiBbZXhjZXB0aW9uLCB1bmRlZmluZWRdO1xuICB9XG5cbiAgLy8gTXV0YXRlIHRoaXMhXG4gIG1lY2hhbmlzbS5zeW50aGV0aWMgPSB0cnVlO1xuXG4gIGlmIChpcy5pc1BsYWluT2JqZWN0KGV4Y2VwdGlvbikpIHtcbiAgICBjb25zdCBub3JtYWxpemVEZXB0aCA9IGNsaWVudD8uZ2V0T3B0aW9ucygpLm5vcm1hbGl6ZURlcHRoO1xuICAgIGNvbnN0IGV4dHJhcyA9IHsgWydfX3NlcmlhbGl6ZWRfXyddOiBub3JtYWxpemUubm9ybWFsaXplVG9TaXplKGV4Y2VwdGlvbiAsIG5vcm1hbGl6ZURlcHRoKSB9O1xuXG4gICAgY29uc3QgZXJyb3JGcm9tUHJvcCA9IGdldEVycm9yUHJvcGVydHlGcm9tT2JqZWN0KGV4Y2VwdGlvbik7XG4gICAgaWYgKGVycm9yRnJvbVByb3ApIHtcbiAgICAgIHJldHVybiBbZXJyb3JGcm9tUHJvcCwgZXh0cmFzXTtcbiAgICB9XG5cbiAgICBjb25zdCBtZXNzYWdlID0gZ2V0TWVzc2FnZUZvck9iamVjdChleGNlcHRpb24pO1xuICAgIGNvbnN0IGV4ID0gaGludD8uc3ludGhldGljRXhjZXB0aW9uIHx8IG5ldyBFcnJvcihtZXNzYWdlKTtcbiAgICBleC5tZXNzYWdlID0gbWVzc2FnZTtcblxuICAgIHJldHVybiBbZXgsIGV4dHJhc107XG4gIH1cblxuICAvLyBUaGlzIGhhbmRsZXMgd2hlbiBzb21lb25lIGRvZXM6IGB0aHJvdyBcInNvbWV0aGluZyBhd2Vzb21lXCI7YFxuICAvLyBXZSB1c2Ugc3ludGhlc2l6ZWQgRXJyb3IgaGVyZSBzbyB3ZSBjYW4gZXh0cmFjdCBhIChyb3VnaCkgc3RhY2sgdHJhY2UuXG4gIGNvbnN0IGV4ID0gaGludD8uc3ludGhldGljRXhjZXB0aW9uIHx8IG5ldyBFcnJvcihleGNlcHRpb24gKTtcbiAgZXgubWVzc2FnZSA9IGAke2V4Y2VwdGlvbn1gO1xuXG4gIHJldHVybiBbZXgsIHVuZGVmaW5lZF07XG59XG5cbi8qKlxuICogQnVpbGRzIGFuZCBFdmVudCBmcm9tIGEgRXhjZXB0aW9uXG4gKiBAaGlkZGVuXG4gKi9cbmZ1bmN0aW9uIGV2ZW50RnJvbVVua25vd25JbnB1dChcbiAgY2xpZW50LFxuICBzdGFja1BhcnNlcixcbiAgZXhjZXB0aW9uLFxuICBoaW50LFxuKSB7XG4gIGNvbnN0IHByb3ZpZGVkTWVjaGFuaXNtID0gaGludD8uZGF0YSAmJiAoaGludC5kYXRhICkubWVjaGFuaXNtO1xuICBjb25zdCBtZWNoYW5pc20gPSBwcm92aWRlZE1lY2hhbmlzbSB8fCB7XG4gICAgaGFuZGxlZDogdHJ1ZSxcbiAgICB0eXBlOiAnZ2VuZXJpYycsXG4gIH07XG5cbiAgY29uc3QgW2V4LCBleHRyYXNdID0gZ2V0RXhjZXB0aW9uKGNsaWVudCwgbWVjaGFuaXNtLCBleGNlcHRpb24sIGhpbnQpO1xuXG4gIGNvbnN0IGV2ZW50ID0ge1xuICAgIGV4Y2VwdGlvbjoge1xuICAgICAgdmFsdWVzOiBbZXhjZXB0aW9uRnJvbUVycm9yKHN0YWNrUGFyc2VyLCBleCldLFxuICAgIH0sXG4gIH07XG5cbiAgaWYgKGV4dHJhcykge1xuICAgIGV2ZW50LmV4dHJhID0gZXh0cmFzO1xuICB9XG5cbiAgbWlzYy5hZGRFeGNlcHRpb25UeXBlVmFsdWUoZXZlbnQsIHVuZGVmaW5lZCwgdW5kZWZpbmVkKTtcbiAgbWlzYy5hZGRFeGNlcHRpb25NZWNoYW5pc20oZXZlbnQsIG1lY2hhbmlzbSk7XG5cbiAgcmV0dXJuIHtcbiAgICAuLi5ldmVudCxcbiAgICBldmVudF9pZDogaGludD8uZXZlbnRfaWQsXG4gIH07XG59XG5cbi8qKlxuICogQnVpbGRzIGFuZCBFdmVudCBmcm9tIGEgTWVzc2FnZVxuICogQGhpZGRlblxuICovXG5mdW5jdGlvbiBldmVudEZyb21NZXNzYWdlKFxuICBzdGFja1BhcnNlcixcbiAgbWVzc2FnZSxcbiAgbGV2ZWwgPSAnaW5mbycsXG4gIGhpbnQsXG4gIGF0dGFjaFN0YWNrdHJhY2UsXG4pIHtcbiAgY29uc3QgZXZlbnQgPSB7XG4gICAgZXZlbnRfaWQ6IGhpbnQ/LmV2ZW50X2lkLFxuICAgIGxldmVsLFxuICB9O1xuXG4gIGlmIChhdHRhY2hTdGFja3RyYWNlICYmIGhpbnQ/LnN5bnRoZXRpY0V4Y2VwdGlvbikge1xuICAgIGNvbnN0IGZyYW1lcyA9IHBhcnNlU3RhY2tGcmFtZXMoc3RhY2tQYXJzZXIsIGhpbnQuc3ludGhldGljRXhjZXB0aW9uKTtcbiAgICBpZiAoZnJhbWVzLmxlbmd0aCkge1xuICAgICAgZXZlbnQuZXhjZXB0aW9uID0ge1xuICAgICAgICB2YWx1ZXM6IFtcbiAgICAgICAgICB7XG4gICAgICAgICAgICB2YWx1ZTogbWVzc2FnZSxcbiAgICAgICAgICAgIHN0YWNrdHJhY2U6IHsgZnJhbWVzIH0sXG4gICAgICAgICAgfSxcbiAgICAgICAgXSxcbiAgICAgIH07XG4gICAgICBtaXNjLmFkZEV4Y2VwdGlvbk1lY2hhbmlzbShldmVudCwgeyBzeW50aGV0aWM6IHRydWUgfSk7XG4gICAgfVxuICB9XG5cbiAgaWYgKGlzLmlzUGFyYW1ldGVyaXplZFN0cmluZyhtZXNzYWdlKSkge1xuICAgIGNvbnN0IHsgX19zZW50cnlfdGVtcGxhdGVfc3RyaW5nX18sIF9fc2VudHJ5X3RlbXBsYXRlX3ZhbHVlc19fIH0gPSBtZXNzYWdlO1xuXG4gICAgZXZlbnQubG9nZW50cnkgPSB7XG4gICAgICBtZXNzYWdlOiBfX3NlbnRyeV90ZW1wbGF0ZV9zdHJpbmdfXyxcbiAgICAgIHBhcmFtczogX19zZW50cnlfdGVtcGxhdGVfdmFsdWVzX18sXG4gICAgfTtcbiAgICByZXR1cm4gZXZlbnQ7XG4gIH1cblxuICBldmVudC5tZXNzYWdlID0gbWVzc2FnZTtcbiAgcmV0dXJuIGV2ZW50O1xufVxuXG5leHBvcnRzLmV2ZW50RnJvbU1lc3NhZ2UgPSBldmVudEZyb21NZXNzYWdlO1xuZXhwb3J0cy5ldmVudEZyb21Vbmtub3duSW5wdXQgPSBldmVudEZyb21Vbmtub3duSW5wdXQ7XG5leHBvcnRzLmV4Y2VwdGlvbkZyb21FcnJvciA9IGV4Y2VwdGlvbkZyb21FcnJvcjtcbmV4cG9ydHMucGFyc2VTdGFja0ZyYW1lcyA9IHBhcnNlU3RhY2tGcmFtZXM7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1ldmVudGJ1aWxkZXIuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/eventbuilder.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/featureFlags.js":
/*!**********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/featureFlags.js ***!
  \**********************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst currentScopes = __webpack_require__(/*! ../currentScopes.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst debugBuild = __webpack_require__(/*! ../debug-build.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst debugLogger = __webpack_require__(/*! ./debug-logger.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst spanUtils = __webpack_require__(/*! ./spanUtils.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanUtils.js\");\n\n/**\n * Ordered LRU cache for storing feature flags in the scope context. The name\n * of each flag in the buffer is unique, and the output of getAll() is ordered\n * from oldest to newest.\n */\n\n/**\n * Max size of the LRU flag buffer stored in Sentry scope and event contexts.\n */\nconst _INTERNAL_FLAG_BUFFER_SIZE = 100;\n\n/**\n * Max number of flag evaluations to record per span.\n */\nconst _INTERNAL_MAX_FLAGS_PER_SPAN = 10;\n\nconst SPAN_FLAG_ATTRIBUTE_PREFIX = 'flag.evaluation.';\n\n/**\n * Copies feature flags that are in current scope context to the event context\n */\nfunction _INTERNAL_copyFlagsFromScopeToEvent(event) {\n  const scope = currentScopes.getCurrentScope();\n  const flagContext = scope.getScopeData().contexts.flags;\n  const flagBuffer = flagContext ? flagContext.values : [];\n\n  if (!flagBuffer.length) {\n    return event;\n  }\n\n  if (event.contexts === undefined) {\n    event.contexts = {};\n  }\n  event.contexts.flags = { values: [...flagBuffer] };\n  return event;\n}\n\n/**\n * Inserts a flag into the current scope's context while maintaining ordered LRU properties.\n * Not thread-safe. After inserting:\n * - The flag buffer is sorted in order of recency, with the newest evaluation at the end.\n * - The names in the buffer are always unique.\n * - The length of the buffer never exceeds `maxSize`.\n *\n * @param name     Name of the feature flag to insert.\n * @param value    Value of the feature flag.\n * @param maxSize  Max number of flags the buffer should store. Default value should always be used in production.\n */\nfunction _INTERNAL_insertFlagToScope(\n  name,\n  value,\n  maxSize = _INTERNAL_FLAG_BUFFER_SIZE,\n) {\n  const scopeContexts = currentScopes.getCurrentScope().getScopeData().contexts;\n  if (!scopeContexts.flags) {\n    scopeContexts.flags = { values: [] };\n  }\n  const flags = scopeContexts.flags.values ;\n  _INTERNAL_insertToFlagBuffer(flags, name, value, maxSize);\n}\n\n/**\n * Exported for tests only. Currently only accepts boolean values (otherwise no-op).\n * Inserts a flag into a FeatureFlag array while maintaining the following properties:\n * - Flags are sorted in order of recency, with the newest evaluation at the end.\n * - The flag names are always unique.\n * - The length of the array never exceeds `maxSize`.\n *\n * @param flags      The buffer to insert the flag into.\n * @param name       Name of the feature flag to insert.\n * @param value      Value of the feature flag.\n * @param maxSize    Max number of flags the buffer should store. Default value should always be used in production.\n */\nfunction _INTERNAL_insertToFlagBuffer(\n  flags,\n  name,\n  value,\n  maxSize,\n) {\n  if (typeof value !== 'boolean') {\n    return;\n  }\n\n  if (flags.length > maxSize) {\n    debugBuild.DEBUG_BUILD && debugLogger.debug.error(`[Feature Flags] insertToFlagBuffer called on a buffer larger than maxSize=${maxSize}`);\n    return;\n  }\n\n  // Check if the flag is already in the buffer - O(n)\n  const index = flags.findIndex(f => f.flag === name);\n\n  if (index !== -1) {\n    // The flag was found, remove it from its current position - O(n)\n    flags.splice(index, 1);\n  }\n\n  if (flags.length === maxSize) {\n    // If at capacity, pop the earliest flag - O(n)\n    flags.shift();\n  }\n\n  // Push the flag to the end - O(1)\n  flags.push({\n    flag: name,\n    result: value,\n  });\n}\n\n/**\n * Records a feature flag evaluation for the active span. This is a no-op for non-boolean values.\n * The flag and its value is stored in span attributes with the `flag.evaluation` prefix. Once the\n * unique flags for a span reaches maxFlagsPerSpan, subsequent flags are dropped.\n *\n * @param name             Name of the feature flag.\n * @param value            Value of the feature flag. Non-boolean values are ignored.\n * @param maxFlagsPerSpan  Max number of flags a buffer should store. Default value should always be used in production.\n */\nfunction _INTERNAL_addFeatureFlagToActiveSpan(\n  name,\n  value,\n  maxFlagsPerSpan = _INTERNAL_MAX_FLAGS_PER_SPAN,\n) {\n  if (typeof value !== 'boolean') {\n    return;\n  }\n\n  const span = spanUtils.getActiveSpan();\n  if (!span) {\n    return;\n  }\n\n  const attributes = spanUtils.spanToJSON(span).data;\n\n  // If the flag already exists, always update it\n  if (`${SPAN_FLAG_ATTRIBUTE_PREFIX}${name}` in attributes) {\n    span.setAttribute(`${SPAN_FLAG_ATTRIBUTE_PREFIX}${name}`, value);\n    return;\n  }\n\n  // Else, add the flag to the span if we have not reached the max number of flags\n  const numOfAddedFlags = Object.keys(attributes).filter(key => key.startsWith(SPAN_FLAG_ATTRIBUTE_PREFIX)).length;\n  if (numOfAddedFlags < maxFlagsPerSpan) {\n    span.setAttribute(`${SPAN_FLAG_ATTRIBUTE_PREFIX}${name}`, value);\n  }\n}\n\nexports._INTERNAL_FLAG_BUFFER_SIZE = _INTERNAL_FLAG_BUFFER_SIZE;\nexports._INTERNAL_MAX_FLAGS_PER_SPAN = _INTERNAL_MAX_FLAGS_PER_SPAN;\nexports._INTERNAL_addFeatureFlagToActiveSpan = _INTERNAL_addFeatureFlagToActiveSpan;\nexports._INTERNAL_copyFlagsFromScopeToEvent = _INTERNAL_copyFlagsFromScopeToEvent;\nexports._INTERNAL_insertFlagToScope = _INTERNAL_insertFlagToScope;\nexports._INTERNAL_insertToFlagBuffer = _INTERNAL_insertToFlagBuffer;\n//# sourceMappingURL=featureFlags.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9mZWF0dXJlRmxhZ3MuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsc0JBQXNCLG1CQUFPLENBQUMsZ0lBQXFCO0FBQ25ELG1CQUFtQixtQkFBTyxDQUFDLDRIQUFtQjtBQUM5QyxvQkFBb0IsbUJBQU8sQ0FBQyxtSUFBbUI7QUFDL0Msa0JBQWtCLG1CQUFPLENBQUMsNkhBQWdCOztBQUUxQztBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQSwyQkFBMkI7QUFDM0I7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSw0QkFBNEI7QUFDNUI7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0EsbUlBQW1JLFFBQVE7QUFDM0k7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsR0FBRztBQUNIOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQSxTQUFTLDJCQUEyQixFQUFFLEtBQUs7QUFDM0MseUJBQXlCLDJCQUEyQixFQUFFLEtBQUs7QUFDM0Q7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQSx5QkFBeUIsMkJBQTJCLEVBQUUsS0FBSztBQUMzRDtBQUNBOztBQUVBLGtDQUFrQztBQUNsQyxvQ0FBb0M7QUFDcEMsNENBQTRDO0FBQzVDLDJDQUEyQztBQUMzQyxtQ0FBbUM7QUFDbkMsb0NBQW9DO0FBQ3BDIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvZmVhdHVyZUZsYWdzLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBjdXJyZW50U2NvcGVzID0gcmVxdWlyZSgnLi4vY3VycmVudFNjb3Blcy5qcycpO1xuY29uc3QgZGVidWdCdWlsZCA9IHJlcXVpcmUoJy4uL2RlYnVnLWJ1aWxkLmpzJyk7XG5jb25zdCBkZWJ1Z0xvZ2dlciA9IHJlcXVpcmUoJy4vZGVidWctbG9nZ2VyLmpzJyk7XG5jb25zdCBzcGFuVXRpbHMgPSByZXF1aXJlKCcuL3NwYW5VdGlscy5qcycpO1xuXG4vKipcbiAqIE9yZGVyZWQgTFJVIGNhY2hlIGZvciBzdG9yaW5nIGZlYXR1cmUgZmxhZ3MgaW4gdGhlIHNjb3BlIGNvbnRleHQuIFRoZSBuYW1lXG4gKiBvZiBlYWNoIGZsYWcgaW4gdGhlIGJ1ZmZlciBpcyB1bmlxdWUsIGFuZCB0aGUgb3V0cHV0IG9mIGdldEFsbCgpIGlzIG9yZGVyZWRcbiAqIGZyb20gb2xkZXN0IHRvIG5ld2VzdC5cbiAqL1xuXG4vKipcbiAqIE1heCBzaXplIG9mIHRoZSBMUlUgZmxhZyBidWZmZXIgc3RvcmVkIGluIFNlbnRyeSBzY29wZSBhbmQgZXZlbnQgY29udGV4dHMuXG4gKi9cbmNvbnN0IF9JTlRFUk5BTF9GTEFHX0JVRkZFUl9TSVpFID0gMTAwO1xuXG4vKipcbiAqIE1heCBudW1iZXIgb2YgZmxhZyBldmFsdWF0aW9ucyB0byByZWNvcmQgcGVyIHNwYW4uXG4gKi9cbmNvbnN0IF9JTlRFUk5BTF9NQVhfRkxBR1NfUEVSX1NQQU4gPSAxMDtcblxuY29uc3QgU1BBTl9GTEFHX0FUVFJJQlVURV9QUkVGSVggPSAnZmxhZy5ldmFsdWF0aW9uLic7XG5cbi8qKlxuICogQ29waWVzIGZlYXR1cmUgZmxhZ3MgdGhhdCBhcmUgaW4gY3VycmVudCBzY29wZSBjb250ZXh0IHRvIHRoZSBldmVudCBjb250ZXh0XG4gKi9cbmZ1bmN0aW9uIF9JTlRFUk5BTF9jb3B5RmxhZ3NGcm9tU2NvcGVUb0V2ZW50KGV2ZW50KSB7XG4gIGNvbnN0IHNjb3BlID0gY3VycmVudFNjb3Blcy5nZXRDdXJyZW50U2NvcGUoKTtcbiAgY29uc3QgZmxhZ0NvbnRleHQgPSBzY29wZS5nZXRTY29wZURhdGEoKS5jb250ZXh0cy5mbGFncztcbiAgY29uc3QgZmxhZ0J1ZmZlciA9IGZsYWdDb250ZXh0ID8gZmxhZ0NvbnRleHQudmFsdWVzIDogW107XG5cbiAgaWYgKCFmbGFnQnVmZmVyLmxlbmd0aCkge1xuICAgIHJldHVybiBldmVudDtcbiAgfVxuXG4gIGlmIChldmVudC5jb250ZXh0cyA9PT0gdW5kZWZpbmVkKSB7XG4gICAgZXZlbnQuY29udGV4dHMgPSB7fTtcbiAgfVxuICBldmVudC5jb250ZXh0cy5mbGFncyA9IHsgdmFsdWVzOiBbLi4uZmxhZ0J1ZmZlcl0gfTtcbiAgcmV0dXJuIGV2ZW50O1xufVxuXG4vKipcbiAqIEluc2VydHMgYSBmbGFnIGludG8gdGhlIGN1cnJlbnQgc2NvcGUncyBjb250ZXh0IHdoaWxlIG1haW50YWluaW5nIG9yZGVyZWQgTFJVIHByb3BlcnRpZXMuXG4gKiBOb3QgdGhyZWFkLXNhZmUuIEFmdGVyIGluc2VydGluZzpcbiAqIC0gVGhlIGZsYWcgYnVmZmVyIGlzIHNvcnRlZCBpbiBvcmRlciBvZiByZWNlbmN5LCB3aXRoIHRoZSBuZXdlc3QgZXZhbHVhdGlvbiBhdCB0aGUgZW5kLlxuICogLSBUaGUgbmFtZXMgaW4gdGhlIGJ1ZmZlciBhcmUgYWx3YXlzIHVuaXF1ZS5cbiAqIC0gVGhlIGxlbmd0aCBvZiB0aGUgYnVmZmVyIG5ldmVyIGV4Y2VlZHMgYG1heFNpemVgLlxuICpcbiAqIEBwYXJhbSBuYW1lICAgICBOYW1lIG9mIHRoZSBmZWF0dXJlIGZsYWcgdG8gaW5zZXJ0LlxuICogQHBhcmFtIHZhbHVlICAgIFZhbHVlIG9mIHRoZSBmZWF0dXJlIGZsYWcuXG4gKiBAcGFyYW0gbWF4U2l6ZSAgTWF4IG51bWJlciBvZiBmbGFncyB0aGUgYnVmZmVyIHNob3VsZCBzdG9yZS4gRGVmYXVsdCB2YWx1ZSBzaG91bGQgYWx3YXlzIGJlIHVzZWQgaW4gcHJvZHVjdGlvbi5cbiAqL1xuZnVuY3Rpb24gX0lOVEVSTkFMX2luc2VydEZsYWdUb1Njb3BlKFxuICBuYW1lLFxuICB2YWx1ZSxcbiAgbWF4U2l6ZSA9IF9JTlRFUk5BTF9GTEFHX0JVRkZFUl9TSVpFLFxuKSB7XG4gIGNvbnN0IHNjb3BlQ29udGV4dHMgPSBjdXJyZW50U2NvcGVzLmdldEN1cnJlbnRTY29wZSgpLmdldFNjb3BlRGF0YSgpLmNvbnRleHRzO1xuICBpZiAoIXNjb3BlQ29udGV4dHMuZmxhZ3MpIHtcbiAgICBzY29wZUNvbnRleHRzLmZsYWdzID0geyB2YWx1ZXM6IFtdIH07XG4gIH1cbiAgY29uc3QgZmxhZ3MgPSBzY29wZUNvbnRleHRzLmZsYWdzLnZhbHVlcyA7XG4gIF9JTlRFUk5BTF9pbnNlcnRUb0ZsYWdCdWZmZXIoZmxhZ3MsIG5hbWUsIHZhbHVlLCBtYXhTaXplKTtcbn1cblxuLyoqXG4gKiBFeHBvcnRlZCBmb3IgdGVzdHMgb25seS4gQ3VycmVudGx5IG9ubHkgYWNjZXB0cyBib29sZWFuIHZhbHVlcyAob3RoZXJ3aXNlIG5vLW9wKS5cbiAqIEluc2VydHMgYSBmbGFnIGludG8gYSBGZWF0dXJlRmxhZyBhcnJheSB3aGlsZSBtYWludGFpbmluZyB0aGUgZm9sbG93aW5nIHByb3BlcnRpZXM6XG4gKiAtIEZsYWdzIGFyZSBzb3J0ZWQgaW4gb3JkZXIgb2YgcmVjZW5jeSwgd2l0aCB0aGUgbmV3ZXN0IGV2YWx1YXRpb24gYXQgdGhlIGVuZC5cbiAqIC0gVGhlIGZsYWcgbmFtZXMgYXJlIGFsd2F5cyB1bmlxdWUuXG4gKiAtIFRoZSBsZW5ndGggb2YgdGhlIGFycmF5IG5ldmVyIGV4Y2VlZHMgYG1heFNpemVgLlxuICpcbiAqIEBwYXJhbSBmbGFncyAgICAgIFRoZSBidWZmZXIgdG8gaW5zZXJ0IHRoZSBmbGFnIGludG8uXG4gKiBAcGFyYW0gbmFtZSAgICAgICBOYW1lIG9mIHRoZSBmZWF0dXJlIGZsYWcgdG8gaW5zZXJ0LlxuICogQHBhcmFtIHZhbHVlICAgICAgVmFsdWUgb2YgdGhlIGZlYXR1cmUgZmxhZy5cbiAqIEBwYXJhbSBtYXhTaXplICAgIE1heCBudW1iZXIgb2YgZmxhZ3MgdGhlIGJ1ZmZlciBzaG91bGQgc3RvcmUuIERlZmF1bHQgdmFsdWUgc2hvdWxkIGFsd2F5cyBiZSB1c2VkIGluIHByb2R1Y3Rpb24uXG4gKi9cbmZ1bmN0aW9uIF9JTlRFUk5BTF9pbnNlcnRUb0ZsYWdCdWZmZXIoXG4gIGZsYWdzLFxuICBuYW1lLFxuICB2YWx1ZSxcbiAgbWF4U2l6ZSxcbikge1xuICBpZiAodHlwZW9mIHZhbHVlICE9PSAnYm9vbGVhbicpIHtcbiAgICByZXR1cm47XG4gIH1cblxuICBpZiAoZmxhZ3MubGVuZ3RoID4gbWF4U2l6ZSkge1xuICAgIGRlYnVnQnVpbGQuREVCVUdfQlVJTEQgJiYgZGVidWdMb2dnZXIuZGVidWcuZXJyb3IoYFtGZWF0dXJlIEZsYWdzXSBpbnNlcnRUb0ZsYWdCdWZmZXIgY2FsbGVkIG9uIGEgYnVmZmVyIGxhcmdlciB0aGFuIG1heFNpemU9JHttYXhTaXplfWApO1xuICAgIHJldHVybjtcbiAgfVxuXG4gIC8vIENoZWNrIGlmIHRoZSBmbGFnIGlzIGFscmVhZHkgaW4gdGhlIGJ1ZmZlciAtIE8obilcbiAgY29uc3QgaW5kZXggPSBmbGFncy5maW5kSW5kZXgoZiA9PiBmLmZsYWcgPT09IG5hbWUpO1xuXG4gIGlmIChpbmRleCAhPT0gLTEpIHtcbiAgICAvLyBUaGUgZmxhZyB3YXMgZm91bmQsIHJlbW92ZSBpdCBmcm9tIGl0cyBjdXJyZW50IHBvc2l0aW9uIC0gTyhuKVxuICAgIGZsYWdzLnNwbGljZShpbmRleCwgMSk7XG4gIH1cblxuICBpZiAoZmxhZ3MubGVuZ3RoID09PSBtYXhTaXplKSB7XG4gICAgLy8gSWYgYXQgY2FwYWNpdHksIHBvcCB0aGUgZWFybGllc3QgZmxhZyAtIE8obilcbiAgICBmbGFncy5zaGlmdCgpO1xuICB9XG5cbiAgLy8gUHVzaCB0aGUgZmxhZyB0byB0aGUgZW5kIC0gTygxKVxuICBmbGFncy5wdXNoKHtcbiAgICBmbGFnOiBuYW1lLFxuICAgIHJlc3VsdDogdmFsdWUsXG4gIH0pO1xufVxuXG4vKipcbiAqIFJlY29yZHMgYSBmZWF0dXJlIGZsYWcgZXZhbHVhdGlvbiBmb3IgdGhlIGFjdGl2ZSBzcGFuLiBUaGlzIGlzIGEgbm8tb3AgZm9yIG5vbi1ib29sZWFuIHZhbHVlcy5cbiAqIFRoZSBmbGFnIGFuZCBpdHMgdmFsdWUgaXMgc3RvcmVkIGluIHNwYW4gYXR0cmlidXRlcyB3aXRoIHRoZSBgZmxhZy5ldmFsdWF0aW9uYCBwcmVmaXguIE9uY2UgdGhlXG4gKiB1bmlxdWUgZmxhZ3MgZm9yIGEgc3BhbiByZWFjaGVzIG1heEZsYWdzUGVyU3Bhbiwgc3Vic2VxdWVudCBmbGFncyBhcmUgZHJvcHBlZC5cbiAqXG4gKiBAcGFyYW0gbmFtZSAgICAgICAgICAgICBOYW1lIG9mIHRoZSBmZWF0dXJlIGZsYWcuXG4gKiBAcGFyYW0gdmFsdWUgICAgICAgICAgICBWYWx1ZSBvZiB0aGUgZmVhdHVyZSBmbGFnLiBOb24tYm9vbGVhbiB2YWx1ZXMgYXJlIGlnbm9yZWQuXG4gKiBAcGFyYW0gbWF4RmxhZ3NQZXJTcGFuICBNYXggbnVtYmVyIG9mIGZsYWdzIGEgYnVmZmVyIHNob3VsZCBzdG9yZS4gRGVmYXVsdCB2YWx1ZSBzaG91bGQgYWx3YXlzIGJlIHVzZWQgaW4gcHJvZHVjdGlvbi5cbiAqL1xuZnVuY3Rpb24gX0lOVEVSTkFMX2FkZEZlYXR1cmVGbGFnVG9BY3RpdmVTcGFuKFxuICBuYW1lLFxuICB2YWx1ZSxcbiAgbWF4RmxhZ3NQZXJTcGFuID0gX0lOVEVSTkFMX01BWF9GTEFHU19QRVJfU1BBTixcbikge1xuICBpZiAodHlwZW9mIHZhbHVlICE9PSAnYm9vbGVhbicpIHtcbiAgICByZXR1cm47XG4gIH1cblxuICBjb25zdCBzcGFuID0gc3BhblV0aWxzLmdldEFjdGl2ZVNwYW4oKTtcbiAgaWYgKCFzcGFuKSB7XG4gICAgcmV0dXJuO1xuICB9XG5cbiAgY29uc3QgYXR0cmlidXRlcyA9IHNwYW5VdGlscy5zcGFuVG9KU09OKHNwYW4pLmRhdGE7XG5cbiAgLy8gSWYgdGhlIGZsYWcgYWxyZWFkeSBleGlzdHMsIGFsd2F5cyB1cGRhdGUgaXRcbiAgaWYgKGAke1NQQU5fRkxBR19BVFRSSUJVVEVfUFJFRklYfSR7bmFtZX1gIGluIGF0dHJpYnV0ZXMpIHtcbiAgICBzcGFuLnNldEF0dHJpYnV0ZShgJHtTUEFOX0ZMQUdfQVRUUklCVVRFX1BSRUZJWH0ke25hbWV9YCwgdmFsdWUpO1xuICAgIHJldHVybjtcbiAgfVxuXG4gIC8vIEVsc2UsIGFkZCB0aGUgZmxhZyB0byB0aGUgc3BhbiBpZiB3ZSBoYXZlIG5vdCByZWFjaGVkIHRoZSBtYXggbnVtYmVyIG9mIGZsYWdzXG4gIGNvbnN0IG51bU9mQWRkZWRGbGFncyA9IE9iamVjdC5rZXlzKGF0dHJpYnV0ZXMpLmZpbHRlcihrZXkgPT4ga2V5LnN0YXJ0c1dpdGgoU1BBTl9GTEFHX0FUVFJJQlVURV9QUkVGSVgpKS5sZW5ndGg7XG4gIGlmIChudW1PZkFkZGVkRmxhZ3MgPCBtYXhGbGFnc1BlclNwYW4pIHtcbiAgICBzcGFuLnNldEF0dHJpYnV0ZShgJHtTUEFOX0ZMQUdfQVRUUklCVVRFX1BSRUZJWH0ke25hbWV9YCwgdmFsdWUpO1xuICB9XG59XG5cbmV4cG9ydHMuX0lOVEVSTkFMX0ZMQUdfQlVGRkVSX1NJWkUgPSBfSU5URVJOQUxfRkxBR19CVUZGRVJfU0laRTtcbmV4cG9ydHMuX0lOVEVSTkFMX01BWF9GTEFHU19QRVJfU1BBTiA9IF9JTlRFUk5BTF9NQVhfRkxBR1NfUEVSX1NQQU47XG5leHBvcnRzLl9JTlRFUk5BTF9hZGRGZWF0dXJlRmxhZ1RvQWN0aXZlU3BhbiA9IF9JTlRFUk5BTF9hZGRGZWF0dXJlRmxhZ1RvQWN0aXZlU3BhbjtcbmV4cG9ydHMuX0lOVEVSTkFMX2NvcHlGbGFnc0Zyb21TY29wZVRvRXZlbnQgPSBfSU5URVJOQUxfY29weUZsYWdzRnJvbVNjb3BlVG9FdmVudDtcbmV4cG9ydHMuX0lOVEVSTkFMX2luc2VydEZsYWdUb1Njb3BlID0gX0lOVEVSTkFMX2luc2VydEZsYWdUb1Njb3BlO1xuZXhwb3J0cy5fSU5URVJOQUxfaW5zZXJ0VG9GbGFnQnVmZmVyID0gX0lOVEVSTkFMX2luc2VydFRvRmxhZ0J1ZmZlcjtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWZlYXR1cmVGbGFncy5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/featureFlags.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/flushIfServerless.js":
/*!***************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/flushIfServerless.js ***!
  \***************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst exports$1 = __webpack_require__(/*! ../exports.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/exports.js\");\nconst debugLogger = __webpack_require__(/*! ./debug-logger.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst vercelWaitUntil = __webpack_require__(/*! ./vercelWaitUntil.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/vercelWaitUntil.js\");\nconst worldwide = __webpack_require__(/*! ./worldwide.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/worldwide.js\");\n\nasync function flushWithTimeout(timeout) {\n  try {\n    debugLogger.debug.log('Flushing events...');\n    await exports$1.flush(timeout);\n    debugLogger.debug.log('Done flushing events');\n  } catch (e) {\n    debugLogger.debug.log('Error while flushing events:\\n', e);\n  }\n}\n\n/**\n *  Flushes the event queue with a timeout in serverless environments to ensure that events are sent to Sentry before the\n *  serverless function execution ends.\n *\n * The function is async, but in environments that support a `waitUntil` mechanism, it will run synchronously.\n *\n * This function is aware of the following serverless platforms:\n * - Cloudflare: If a Cloudflare context is provided, it will use `ctx.waitUntil()` to flush events (keeps the `this` context of `ctx`).\n *               If a `cloudflareWaitUntil` function is provided, it will use that to flush events (looses the `this` context of `ctx`).\n * - Vercel: It detects the Vercel environment and uses Vercel's `waitUntil` function.\n * - Other Serverless (AWS Lambda, Google Cloud, etc.): It detects the environment via environment variables\n *   and uses a regular `await flush()`.\n *\n *  @internal This function is supposed for internal Sentry SDK usage only.\n *  @hidden\n */\nasync function flushIfServerless(\n  params\n\n = {},\n) {\n  const { timeout = 2000 } = params;\n\n  if ('cloudflareWaitUntil' in params && typeof params?.cloudflareWaitUntil === 'function') {\n    params.cloudflareWaitUntil(flushWithTimeout(timeout));\n    return;\n  }\n\n  if ('cloudflareCtx' in params && typeof params.cloudflareCtx?.waitUntil === 'function') {\n    params.cloudflareCtx.waitUntil(flushWithTimeout(timeout));\n    return;\n  }\n\n  // @ts-expect-error This is not typed\n  if (worldwide.GLOBAL_OBJ[Symbol.for('@vercel/request-context')]) {\n    // Vercel has a waitUntil equivalent that works without execution context\n    vercelWaitUntil.vercelWaitUntil(flushWithTimeout(timeout));\n    return;\n  }\n\n  if (typeof process === 'undefined') {\n    return;\n  }\n\n  const isServerless =\n    !!process.env.FUNCTIONS_WORKER_RUNTIME || // Azure Functions\n    !!process.env.LAMBDA_TASK_ROOT || // AWS Lambda\n    !!process.env.K_SERVICE || // Google Cloud Run\n    !!process.env.CF_PAGES || // Cloudflare Pages\n    !!process.env.VERCEL ||\n    !!process.env.NETLIFY;\n\n  if (isServerless) {\n    // Use regular flush for environments without a generic waitUntil mechanism\n    await flushWithTimeout(timeout);\n  }\n}\n\nexports.flushIfServerless = flushIfServerless;\n//# sourceMappingURL=flushIfServerless.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9mbHVzaElmU2VydmVybGVzcy5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxrQkFBa0IsbUJBQU8sQ0FBQyxvSEFBZTtBQUN6QyxvQkFBb0IsbUJBQU8sQ0FBQyxtSUFBbUI7QUFDL0Msd0JBQXdCLG1CQUFPLENBQUMseUlBQXNCO0FBQ3RELGtCQUFrQixtQkFBTyxDQUFDLDZIQUFnQjs7QUFFMUM7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLElBQUk7QUFDSjtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLEtBQUs7QUFDTDtBQUNBLFVBQVUsaUJBQWlCOztBQUUzQjtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEseUJBQXlCO0FBQ3pCIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvZmx1c2hJZlNlcnZlcmxlc3MuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGV4cG9ydHMkMSA9IHJlcXVpcmUoJy4uL2V4cG9ydHMuanMnKTtcbmNvbnN0IGRlYnVnTG9nZ2VyID0gcmVxdWlyZSgnLi9kZWJ1Zy1sb2dnZXIuanMnKTtcbmNvbnN0IHZlcmNlbFdhaXRVbnRpbCA9IHJlcXVpcmUoJy4vdmVyY2VsV2FpdFVudGlsLmpzJyk7XG5jb25zdCB3b3JsZHdpZGUgPSByZXF1aXJlKCcuL3dvcmxkd2lkZS5qcycpO1xuXG5hc3luYyBmdW5jdGlvbiBmbHVzaFdpdGhUaW1lb3V0KHRpbWVvdXQpIHtcbiAgdHJ5IHtcbiAgICBkZWJ1Z0xvZ2dlci5kZWJ1Zy5sb2coJ0ZsdXNoaW5nIGV2ZW50cy4uLicpO1xuICAgIGF3YWl0IGV4cG9ydHMkMS5mbHVzaCh0aW1lb3V0KTtcbiAgICBkZWJ1Z0xvZ2dlci5kZWJ1Zy5sb2coJ0RvbmUgZmx1c2hpbmcgZXZlbnRzJyk7XG4gIH0gY2F0Y2ggKGUpIHtcbiAgICBkZWJ1Z0xvZ2dlci5kZWJ1Zy5sb2coJ0Vycm9yIHdoaWxlIGZsdXNoaW5nIGV2ZW50czpcXG4nLCBlKTtcbiAgfVxufVxuXG4vKipcbiAqICBGbHVzaGVzIHRoZSBldmVudCBxdWV1ZSB3aXRoIGEgdGltZW91dCBpbiBzZXJ2ZXJsZXNzIGVudmlyb25tZW50cyB0byBlbnN1cmUgdGhhdCBldmVudHMgYXJlIHNlbnQgdG8gU2VudHJ5IGJlZm9yZSB0aGVcbiAqICBzZXJ2ZXJsZXNzIGZ1bmN0aW9uIGV4ZWN1dGlvbiBlbmRzLlxuICpcbiAqIFRoZSBmdW5jdGlvbiBpcyBhc3luYywgYnV0IGluIGVudmlyb25tZW50cyB0aGF0IHN1cHBvcnQgYSBgd2FpdFVudGlsYCBtZWNoYW5pc20sIGl0IHdpbGwgcnVuIHN5bmNocm9ub3VzbHkuXG4gKlxuICogVGhpcyBmdW5jdGlvbiBpcyBhd2FyZSBvZiB0aGUgZm9sbG93aW5nIHNlcnZlcmxlc3MgcGxhdGZvcm1zOlxuICogLSBDbG91ZGZsYXJlOiBJZiBhIENsb3VkZmxhcmUgY29udGV4dCBpcyBwcm92aWRlZCwgaXQgd2lsbCB1c2UgYGN0eC53YWl0VW50aWwoKWAgdG8gZmx1c2ggZXZlbnRzIChrZWVwcyB0aGUgYHRoaXNgIGNvbnRleHQgb2YgYGN0eGApLlxuICogICAgICAgICAgICAgICBJZiBhIGBjbG91ZGZsYXJlV2FpdFVudGlsYCBmdW5jdGlvbiBpcyBwcm92aWRlZCwgaXQgd2lsbCB1c2UgdGhhdCB0byBmbHVzaCBldmVudHMgKGxvb3NlcyB0aGUgYHRoaXNgIGNvbnRleHQgb2YgYGN0eGApLlxuICogLSBWZXJjZWw6IEl0IGRldGVjdHMgdGhlIFZlcmNlbCBlbnZpcm9ubWVudCBhbmQgdXNlcyBWZXJjZWwncyBgd2FpdFVudGlsYCBmdW5jdGlvbi5cbiAqIC0gT3RoZXIgU2VydmVybGVzcyAoQVdTIExhbWJkYSwgR29vZ2xlIENsb3VkLCBldGMuKTogSXQgZGV0ZWN0cyB0aGUgZW52aXJvbm1lbnQgdmlhIGVudmlyb25tZW50IHZhcmlhYmxlc1xuICogICBhbmQgdXNlcyBhIHJlZ3VsYXIgYGF3YWl0IGZsdXNoKClgLlxuICpcbiAqICBAaW50ZXJuYWwgVGhpcyBmdW5jdGlvbiBpcyBzdXBwb3NlZCBmb3IgaW50ZXJuYWwgU2VudHJ5IFNESyB1c2FnZSBvbmx5LlxuICogIEBoaWRkZW5cbiAqL1xuYXN5bmMgZnVuY3Rpb24gZmx1c2hJZlNlcnZlcmxlc3MoXG4gIHBhcmFtc1xuXG4gPSB7fSxcbikge1xuICBjb25zdCB7IHRpbWVvdXQgPSAyMDAwIH0gPSBwYXJhbXM7XG5cbiAgaWYgKCdjbG91ZGZsYXJlV2FpdFVudGlsJyBpbiBwYXJhbXMgJiYgdHlwZW9mIHBhcmFtcz8uY2xvdWRmbGFyZVdhaXRVbnRpbCA9PT0gJ2Z1bmN0aW9uJykge1xuICAgIHBhcmFtcy5jbG91ZGZsYXJlV2FpdFVudGlsKGZsdXNoV2l0aFRpbWVvdXQodGltZW91dCkpO1xuICAgIHJldHVybjtcbiAgfVxuXG4gIGlmICgnY2xvdWRmbGFyZUN0eCcgaW4gcGFyYW1zICYmIHR5cGVvZiBwYXJhbXMuY2xvdWRmbGFyZUN0eD8ud2FpdFVudGlsID09PSAnZnVuY3Rpb24nKSB7XG4gICAgcGFyYW1zLmNsb3VkZmxhcmVDdHgud2FpdFVudGlsKGZsdXNoV2l0aFRpbWVvdXQodGltZW91dCkpO1xuICAgIHJldHVybjtcbiAgfVxuXG4gIC8vIEB0cy1leHBlY3QtZXJyb3IgVGhpcyBpcyBub3QgdHlwZWRcbiAgaWYgKHdvcmxkd2lkZS5HTE9CQUxfT0JKW1N5bWJvbC5mb3IoJ0B2ZXJjZWwvcmVxdWVzdC1jb250ZXh0JyldKSB7XG4gICAgLy8gVmVyY2VsIGhhcyBhIHdhaXRVbnRpbCBlcXVpdmFsZW50IHRoYXQgd29ya3Mgd2l0aG91dCBleGVjdXRpb24gY29udGV4dFxuICAgIHZlcmNlbFdhaXRVbnRpbC52ZXJjZWxXYWl0VW50aWwoZmx1c2hXaXRoVGltZW91dCh0aW1lb3V0KSk7XG4gICAgcmV0dXJuO1xuICB9XG5cbiAgaWYgKHR5cGVvZiBwcm9jZXNzID09PSAndW5kZWZpbmVkJykge1xuICAgIHJldHVybjtcbiAgfVxuXG4gIGNvbnN0IGlzU2VydmVybGVzcyA9XG4gICAgISFwcm9jZXNzLmVudi5GVU5DVElPTlNfV09SS0VSX1JVTlRJTUUgfHwgLy8gQXp1cmUgRnVuY3Rpb25zXG4gICAgISFwcm9jZXNzLmVudi5MQU1CREFfVEFTS19ST09UIHx8IC8vIEFXUyBMYW1iZGFcbiAgICAhIXByb2Nlc3MuZW52LktfU0VSVklDRSB8fCAvLyBHb29nbGUgQ2xvdWQgUnVuXG4gICAgISFwcm9jZXNzLmVudi5DRl9QQUdFUyB8fCAvLyBDbG91ZGZsYXJlIFBhZ2VzXG4gICAgISFwcm9jZXNzLmVudi5WRVJDRUwgfHxcbiAgICAhIXByb2Nlc3MuZW52Lk5FVExJRlk7XG5cbiAgaWYgKGlzU2VydmVybGVzcykge1xuICAgIC8vIFVzZSByZWd1bGFyIGZsdXNoIGZvciBlbnZpcm9ubWVudHMgd2l0aG91dCBhIGdlbmVyaWMgd2FpdFVudGlsIG1lY2hhbmlzbVxuICAgIGF3YWl0IGZsdXNoV2l0aFRpbWVvdXQodGltZW91dCk7XG4gIH1cbn1cblxuZXhwb3J0cy5mbHVzaElmU2VydmVybGVzcyA9IGZsdXNoSWZTZXJ2ZXJsZXNzO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9Zmx1c2hJZlNlcnZlcmxlc3MuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/flushIfServerless.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/gen-ai-attributes.js":
/*!***************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/gen-ai-attributes.js ***!
  \***************************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n/**\n * OpenAI Integration Telemetry Attributes\n * Based on OpenTelemetry Semantic Conventions for Generative AI\n * @see https://opentelemetry.io/docs/specs/semconv/gen-ai/\n */\n\n// =============================================================================\n// OPENTELEMETRY SEMANTIC CONVENTIONS FOR GENAI\n// =============================================================================\n\n/**\n * The Generative AI system being used\n * For OpenAI, this should always be \"openai\"\n */\nconst GEN_AI_SYSTEM_ATTRIBUTE = 'gen_ai.system';\n\n/**\n * The name of the model as requested\n * Examples: \"gpt-4\", \"gpt-3.5-turbo\"\n */\nconst GEN_AI_REQUEST_MODEL_ATTRIBUTE = 'gen_ai.request.model';\n\n/**\n * The temperature setting for the model request\n */\nconst GEN_AI_REQUEST_TEMPERATURE_ATTRIBUTE = 'gen_ai.request.temperature';\n\n/**\n * The frequency penalty setting for the model request\n */\nconst GEN_AI_REQUEST_FREQUENCY_PENALTY_ATTRIBUTE = 'gen_ai.request.frequency_penalty';\n\n/**\n * The presence penalty setting for the model request\n */\nconst GEN_AI_REQUEST_PRESENCE_PENALTY_ATTRIBUTE = 'gen_ai.request.presence_penalty';\n\n/**\n * The top_p (nucleus sampling) setting for the model request\n */\nconst GEN_AI_REQUEST_TOP_P_ATTRIBUTE = 'gen_ai.request.top_p';\n\n/**\n * Array of reasons why the model stopped generating tokens\n */\nconst GEN_AI_RESPONSE_FINISH_REASONS_ATTRIBUTE = 'gen_ai.response.finish_reasons';\n\n/**\n * The name of the model that generated the response\n */\nconst GEN_AI_RESPONSE_MODEL_ATTRIBUTE = 'gen_ai.response.model';\n\n/**\n * The unique identifier for the response\n */\nconst GEN_AI_RESPONSE_ID_ATTRIBUTE = 'gen_ai.response.id';\n\n/**\n * The number of tokens used in the prompt\n */\nconst GEN_AI_USAGE_INPUT_TOKENS_ATTRIBUTE = 'gen_ai.usage.input_tokens';\n\n/**\n * The number of tokens used in the response\n */\nconst GEN_AI_USAGE_OUTPUT_TOKENS_ATTRIBUTE = 'gen_ai.usage.output_tokens';\n\n/**\n * The total number of tokens used (input + output)\n */\nconst GEN_AI_USAGE_TOTAL_TOKENS_ATTRIBUTE = 'gen_ai.usage.total_tokens';\n\n/**\n * The operation name for OpenAI API calls\n */\nconst GEN_AI_OPERATION_NAME_ATTRIBUTE = 'gen_ai.operation.name';\n\n/**\n * The prompt messages sent to OpenAI (stringified JSON)\n * Only recorded when recordInputs is enabled\n */\nconst GEN_AI_REQUEST_MESSAGES_ATTRIBUTE = 'gen_ai.request.messages';\n\n/**\n * The response text from OpenAI (stringified JSON array)\n * Only recorded when recordOutputs is enabled\n */\nconst GEN_AI_RESPONSE_TEXT_ATTRIBUTE = 'gen_ai.response.text';\n\n// =============================================================================\n// OPENAI-SPECIFIC ATTRIBUTES\n// =============================================================================\n\n/**\n * The response ID from OpenAI\n */\nconst OPENAI_RESPONSE_ID_ATTRIBUTE = 'openai.response.id';\n\n/**\n * The response model from OpenAI\n */\nconst OPENAI_RESPONSE_MODEL_ATTRIBUTE = 'openai.response.model';\n\n/**\n * The response timestamp from OpenAI (ISO string)\n */\nconst OPENAI_RESPONSE_TIMESTAMP_ATTRIBUTE = 'openai.response.timestamp';\n\n/**\n * The number of completion tokens used (OpenAI specific)\n */\nconst OPENAI_USAGE_COMPLETION_TOKENS_ATTRIBUTE = 'openai.usage.completion_tokens';\n\n/**\n * The number of prompt tokens used (OpenAI specific)\n */\nconst OPENAI_USAGE_PROMPT_TOKENS_ATTRIBUTE = 'openai.usage.prompt_tokens';\n\n// =============================================================================\n// OPENAI OPERATIONS\n// =============================================================================\n\n/**\n * OpenAI API operations\n */\nconst OPENAI_OPERATIONS = {\n  CHAT: 'chat',\n} ;\n\nexports.GEN_AI_OPERATION_NAME_ATTRIBUTE = GEN_AI_OPERATION_NAME_ATTRIBUTE;\nexports.GEN_AI_REQUEST_FREQUENCY_PENALTY_ATTRIBUTE = GEN_AI_REQUEST_FREQUENCY_PENALTY_ATTRIBUTE;\nexports.GEN_AI_REQUEST_MESSAGES_ATTRIBUTE = GEN_AI_REQUEST_MESSAGES_ATTRIBUTE;\nexports.GEN_AI_REQUEST_MODEL_ATTRIBUTE = GEN_AI_REQUEST_MODEL_ATTRIBUTE;\nexports.GEN_AI_REQUEST_PRESENCE_PENALTY_ATTRIBUTE = GEN_AI_REQUEST_PRESENCE_PENALTY_ATTRIBUTE;\nexports.GEN_AI_REQUEST_TEMPERATURE_ATTRIBUTE = GEN_AI_REQUEST_TEMPERATURE_ATTRIBUTE;\nexports.GEN_AI_REQUEST_TOP_P_ATTRIBUTE = GEN_AI_REQUEST_TOP_P_ATTRIBUTE;\nexports.GEN_AI_RESPONSE_FINISH_REASONS_ATTRIBUTE = GEN_AI_RESPONSE_FINISH_REASONS_ATTRIBUTE;\nexports.GEN_AI_RESPONSE_ID_ATTRIBUTE = GEN_AI_RESPONSE_ID_ATTRIBUTE;\nexports.GEN_AI_RESPONSE_MODEL_ATTRIBUTE = GEN_AI_RESPONSE_MODEL_ATTRIBUTE;\nexports.GEN_AI_RESPONSE_TEXT_ATTRIBUTE = GEN_AI_RESPONSE_TEXT_ATTRIBUTE;\nexports.GEN_AI_SYSTEM_ATTRIBUTE = GEN_AI_SYSTEM_ATTRIBUTE;\nexports.GEN_AI_USAGE_INPUT_TOKENS_ATTRIBUTE = GEN_AI_USAGE_INPUT_TOKENS_ATTRIBUTE;\nexports.GEN_AI_USAGE_OUTPUT_TOKENS_ATTRIBUTE = GEN_AI_USAGE_OUTPUT_TOKENS_ATTRIBUTE;\nexports.GEN_AI_USAGE_TOTAL_TOKENS_ATTRIBUTE = GEN_AI_USAGE_TOTAL_TOKENS_ATTRIBUTE;\nexports.OPENAI_OPERATIONS = OPENAI_OPERATIONS;\nexports.OPENAI_RESPONSE_ID_ATTRIBUTE = OPENAI_RESPONSE_ID_ATTRIBUTE;\nexports.OPENAI_RESPONSE_MODEL_ATTRIBUTE = OPENAI_RESPONSE_MODEL_ATTRIBUTE;\nexports.OPENAI_RESPONSE_TIMESTAMP_ATTRIBUTE = OPENAI_RESPONSE_TIMESTAMP_ATTRIBUTE;\nexports.OPENAI_USAGE_COMPLETION_TOKENS_ATTRIBUTE = OPENAI_USAGE_COMPLETION_TOKENS_ATTRIBUTE;\nexports.OPENAI_USAGE_PROMPT_TOKENS_ATTRIBUTE = OPENAI_USAGE_PROMPT_TOKENS_ATTRIBUTE;\n//# sourceMappingURL=gen-ai-attributes.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9nZW4tYWktYXR0cmlidXRlcy5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLHVDQUF1QztBQUN2QyxrREFBa0Q7QUFDbEQseUNBQXlDO0FBQ3pDLHNDQUFzQztBQUN0QyxpREFBaUQ7QUFDakQsNENBQTRDO0FBQzVDLHNDQUFzQztBQUN0QyxnREFBZ0Q7QUFDaEQsb0NBQW9DO0FBQ3BDLHVDQUF1QztBQUN2QyxzQ0FBc0M7QUFDdEMsK0JBQStCO0FBQy9CLDJDQUEyQztBQUMzQyw0Q0FBNEM7QUFDNUMsMkNBQTJDO0FBQzNDLHlCQUF5QjtBQUN6QixvQ0FBb0M7QUFDcEMsdUNBQXVDO0FBQ3ZDLDJDQUEyQztBQUMzQyxnREFBZ0Q7QUFDaEQsNENBQTRDO0FBQzVDIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvZ2VuLWFpLWF0dHJpYnV0ZXMuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbi8qKlxuICogT3BlbkFJIEludGVncmF0aW9uIFRlbGVtZXRyeSBBdHRyaWJ1dGVzXG4gKiBCYXNlZCBvbiBPcGVuVGVsZW1ldHJ5IFNlbWFudGljIENvbnZlbnRpb25zIGZvciBHZW5lcmF0aXZlIEFJXG4gKiBAc2VlIGh0dHBzOi8vb3BlbnRlbGVtZXRyeS5pby9kb2NzL3NwZWNzL3NlbWNvbnYvZ2VuLWFpL1xuICovXG5cbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG4vLyBPUEVOVEVMRU1FVFJZIFNFTUFOVElDIENPTlZFTlRJT05TIEZPUiBHRU5BSVxuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cblxuLyoqXG4gKiBUaGUgR2VuZXJhdGl2ZSBBSSBzeXN0ZW0gYmVpbmcgdXNlZFxuICogRm9yIE9wZW5BSSwgdGhpcyBzaG91bGQgYWx3YXlzIGJlIFwib3BlbmFpXCJcbiAqL1xuY29uc3QgR0VOX0FJX1NZU1RFTV9BVFRSSUJVVEUgPSAnZ2VuX2FpLnN5c3RlbSc7XG5cbi8qKlxuICogVGhlIG5hbWUgb2YgdGhlIG1vZGVsIGFzIHJlcXVlc3RlZFxuICogRXhhbXBsZXM6IFwiZ3B0LTRcIiwgXCJncHQtMy41LXR1cmJvXCJcbiAqL1xuY29uc3QgR0VOX0FJX1JFUVVFU1RfTU9ERUxfQVRUUklCVVRFID0gJ2dlbl9haS5yZXF1ZXN0Lm1vZGVsJztcblxuLyoqXG4gKiBUaGUgdGVtcGVyYXR1cmUgc2V0dGluZyBmb3IgdGhlIG1vZGVsIHJlcXVlc3RcbiAqL1xuY29uc3QgR0VOX0FJX1JFUVVFU1RfVEVNUEVSQVRVUkVfQVRUUklCVVRFID0gJ2dlbl9haS5yZXF1ZXN0LnRlbXBlcmF0dXJlJztcblxuLyoqXG4gKiBUaGUgZnJlcXVlbmN5IHBlbmFsdHkgc2V0dGluZyBmb3IgdGhlIG1vZGVsIHJlcXVlc3RcbiAqL1xuY29uc3QgR0VOX0FJX1JFUVVFU1RfRlJFUVVFTkNZX1BFTkFMVFlfQVRUUklCVVRFID0gJ2dlbl9haS5yZXF1ZXN0LmZyZXF1ZW5jeV9wZW5hbHR5JztcblxuLyoqXG4gKiBUaGUgcHJlc2VuY2UgcGVuYWx0eSBzZXR0aW5nIGZvciB0aGUgbW9kZWwgcmVxdWVzdFxuICovXG5jb25zdCBHRU5fQUlfUkVRVUVTVF9QUkVTRU5DRV9QRU5BTFRZX0FUVFJJQlVURSA9ICdnZW5fYWkucmVxdWVzdC5wcmVzZW5jZV9wZW5hbHR5JztcblxuLyoqXG4gKiBUaGUgdG9wX3AgKG51Y2xldXMgc2FtcGxpbmcpIHNldHRpbmcgZm9yIHRoZSBtb2RlbCByZXF1ZXN0XG4gKi9cbmNvbnN0IEdFTl9BSV9SRVFVRVNUX1RPUF9QX0FUVFJJQlVURSA9ICdnZW5fYWkucmVxdWVzdC50b3BfcCc7XG5cbi8qKlxuICogQXJyYXkgb2YgcmVhc29ucyB3aHkgdGhlIG1vZGVsIHN0b3BwZWQgZ2VuZXJhdGluZyB0b2tlbnNcbiAqL1xuY29uc3QgR0VOX0FJX1JFU1BPTlNFX0ZJTklTSF9SRUFTT05TX0FUVFJJQlVURSA9ICdnZW5fYWkucmVzcG9uc2UuZmluaXNoX3JlYXNvbnMnO1xuXG4vKipcbiAqIFRoZSBuYW1lIG9mIHRoZSBtb2RlbCB0aGF0IGdlbmVyYXRlZCB0aGUgcmVzcG9uc2VcbiAqL1xuY29uc3QgR0VOX0FJX1JFU1BPTlNFX01PREVMX0FUVFJJQlVURSA9ICdnZW5fYWkucmVzcG9uc2UubW9kZWwnO1xuXG4vKipcbiAqIFRoZSB1bmlxdWUgaWRlbnRpZmllciBmb3IgdGhlIHJlc3BvbnNlXG4gKi9cbmNvbnN0IEdFTl9BSV9SRVNQT05TRV9JRF9BVFRSSUJVVEUgPSAnZ2VuX2FpLnJlc3BvbnNlLmlkJztcblxuLyoqXG4gKiBUaGUgbnVtYmVyIG9mIHRva2VucyB1c2VkIGluIHRoZSBwcm9tcHRcbiAqL1xuY29uc3QgR0VOX0FJX1VTQUdFX0lOUFVUX1RPS0VOU19BVFRSSUJVVEUgPSAnZ2VuX2FpLnVzYWdlLmlucHV0X3Rva2Vucyc7XG5cbi8qKlxuICogVGhlIG51bWJlciBvZiB0b2tlbnMgdXNlZCBpbiB0aGUgcmVzcG9uc2VcbiAqL1xuY29uc3QgR0VOX0FJX1VTQUdFX09VVFBVVF9UT0tFTlNfQVRUUklCVVRFID0gJ2dlbl9haS51c2FnZS5vdXRwdXRfdG9rZW5zJztcblxuLyoqXG4gKiBUaGUgdG90YWwgbnVtYmVyIG9mIHRva2VucyB1c2VkIChpbnB1dCArIG91dHB1dClcbiAqL1xuY29uc3QgR0VOX0FJX1VTQUdFX1RPVEFMX1RPS0VOU19BVFRSSUJVVEUgPSAnZ2VuX2FpLnVzYWdlLnRvdGFsX3Rva2Vucyc7XG5cbi8qKlxuICogVGhlIG9wZXJhdGlvbiBuYW1lIGZvciBPcGVuQUkgQVBJIGNhbGxzXG4gKi9cbmNvbnN0IEdFTl9BSV9PUEVSQVRJT05fTkFNRV9BVFRSSUJVVEUgPSAnZ2VuX2FpLm9wZXJhdGlvbi5uYW1lJztcblxuLyoqXG4gKiBUaGUgcHJvbXB0IG1lc3NhZ2VzIHNlbnQgdG8gT3BlbkFJIChzdHJpbmdpZmllZCBKU09OKVxuICogT25seSByZWNvcmRlZCB3aGVuIHJlY29yZElucHV0cyBpcyBlbmFibGVkXG4gKi9cbmNvbnN0IEdFTl9BSV9SRVFVRVNUX01FU1NBR0VTX0FUVFJJQlVURSA9ICdnZW5fYWkucmVxdWVzdC5tZXNzYWdlcyc7XG5cbi8qKlxuICogVGhlIHJlc3BvbnNlIHRleHQgZnJvbSBPcGVuQUkgKHN0cmluZ2lmaWVkIEpTT04gYXJyYXkpXG4gKiBPbmx5IHJlY29yZGVkIHdoZW4gcmVjb3JkT3V0cHV0cyBpcyBlbmFibGVkXG4gKi9cbmNvbnN0IEdFTl9BSV9SRVNQT05TRV9URVhUX0FUVFJJQlVURSA9ICdnZW5fYWkucmVzcG9uc2UudGV4dCc7XG5cbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG4vLyBPUEVOQUktU1BFQ0lGSUMgQVRUUklCVVRFU1xuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cblxuLyoqXG4gKiBUaGUgcmVzcG9uc2UgSUQgZnJvbSBPcGVuQUlcbiAqL1xuY29uc3QgT1BFTkFJX1JFU1BPTlNFX0lEX0FUVFJJQlVURSA9ICdvcGVuYWkucmVzcG9uc2UuaWQnO1xuXG4vKipcbiAqIFRoZSByZXNwb25zZSBtb2RlbCBmcm9tIE9wZW5BSVxuICovXG5jb25zdCBPUEVOQUlfUkVTUE9OU0VfTU9ERUxfQVRUUklCVVRFID0gJ29wZW5haS5yZXNwb25zZS5tb2RlbCc7XG5cbi8qKlxuICogVGhlIHJlc3BvbnNlIHRpbWVzdGFtcCBmcm9tIE9wZW5BSSAoSVNPIHN0cmluZylcbiAqL1xuY29uc3QgT1BFTkFJX1JFU1BPTlNFX1RJTUVTVEFNUF9BVFRSSUJVVEUgPSAnb3BlbmFpLnJlc3BvbnNlLnRpbWVzdGFtcCc7XG5cbi8qKlxuICogVGhlIG51bWJlciBvZiBjb21wbGV0aW9uIHRva2VucyB1c2VkIChPcGVuQUkgc3BlY2lmaWMpXG4gKi9cbmNvbnN0IE9QRU5BSV9VU0FHRV9DT01QTEVUSU9OX1RPS0VOU19BVFRSSUJVVEUgPSAnb3BlbmFpLnVzYWdlLmNvbXBsZXRpb25fdG9rZW5zJztcblxuLyoqXG4gKiBUaGUgbnVtYmVyIG9mIHByb21wdCB0b2tlbnMgdXNlZCAoT3BlbkFJIHNwZWNpZmljKVxuICovXG5jb25zdCBPUEVOQUlfVVNBR0VfUFJPTVBUX1RPS0VOU19BVFRSSUJVVEUgPSAnb3BlbmFpLnVzYWdlLnByb21wdF90b2tlbnMnO1xuXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuLy8gT1BFTkFJIE9QRVJBVElPTlNcbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG5cbi8qKlxuICogT3BlbkFJIEFQSSBvcGVyYXRpb25zXG4gKi9cbmNvbnN0IE9QRU5BSV9PUEVSQVRJT05TID0ge1xuICBDSEFUOiAnY2hhdCcsXG59IDtcblxuZXhwb3J0cy5HRU5fQUlfT1BFUkFUSU9OX05BTUVfQVRUUklCVVRFID0gR0VOX0FJX09QRVJBVElPTl9OQU1FX0FUVFJJQlVURTtcbmV4cG9ydHMuR0VOX0FJX1JFUVVFU1RfRlJFUVVFTkNZX1BFTkFMVFlfQVRUUklCVVRFID0gR0VOX0FJX1JFUVVFU1RfRlJFUVVFTkNZX1BFTkFMVFlfQVRUUklCVVRFO1xuZXhwb3J0cy5HRU5fQUlfUkVRVUVTVF9NRVNTQUdFU19BVFRSSUJVVEUgPSBHRU5fQUlfUkVRVUVTVF9NRVNTQUdFU19BVFRSSUJVVEU7XG5leHBvcnRzLkdFTl9BSV9SRVFVRVNUX01PREVMX0FUVFJJQlVURSA9IEdFTl9BSV9SRVFVRVNUX01PREVMX0FUVFJJQlVURTtcbmV4cG9ydHMuR0VOX0FJX1JFUVVFU1RfUFJFU0VOQ0VfUEVOQUxUWV9BVFRSSUJVVEUgPSBHRU5fQUlfUkVRVUVTVF9QUkVTRU5DRV9QRU5BTFRZX0FUVFJJQlVURTtcbmV4cG9ydHMuR0VOX0FJX1JFUVVFU1RfVEVNUEVSQVRVUkVfQVRUUklCVVRFID0gR0VOX0FJX1JFUVVFU1RfVEVNUEVSQVRVUkVfQVRUUklCVVRFO1xuZXhwb3J0cy5HRU5fQUlfUkVRVUVTVF9UT1BfUF9BVFRSSUJVVEUgPSBHRU5fQUlfUkVRVUVTVF9UT1BfUF9BVFRSSUJVVEU7XG5leHBvcnRzLkdFTl9BSV9SRVNQT05TRV9GSU5JU0hfUkVBU09OU19BVFRSSUJVVEUgPSBHRU5fQUlfUkVTUE9OU0VfRklOSVNIX1JFQVNPTlNfQVRUUklCVVRFO1xuZXhwb3J0cy5HRU5fQUlfUkVTUE9OU0VfSURfQVRUUklCVVRFID0gR0VOX0FJX1JFU1BPTlNFX0lEX0FUVFJJQlVURTtcbmV4cG9ydHMuR0VOX0FJX1JFU1BPTlNFX01PREVMX0FUVFJJQlVURSA9IEdFTl9BSV9SRVNQT05TRV9NT0RFTF9BVFRSSUJVVEU7XG5leHBvcnRzLkdFTl9BSV9SRVNQT05TRV9URVhUX0FUVFJJQlVURSA9IEdFTl9BSV9SRVNQT05TRV9URVhUX0FUVFJJQlVURTtcbmV4cG9ydHMuR0VOX0FJX1NZU1RFTV9BVFRSSUJVVEUgPSBHRU5fQUlfU1lTVEVNX0FUVFJJQlVURTtcbmV4cG9ydHMuR0VOX0FJX1VTQUdFX0lOUFVUX1RPS0VOU19BVFRSSUJVVEUgPSBHRU5fQUlfVVNBR0VfSU5QVVRfVE9LRU5TX0FUVFJJQlVURTtcbmV4cG9ydHMuR0VOX0FJX1VTQUdFX09VVFBVVF9UT0tFTlNfQVRUUklCVVRFID0gR0VOX0FJX1VTQUdFX09VVFBVVF9UT0tFTlNfQVRUUklCVVRFO1xuZXhwb3J0cy5HRU5fQUlfVVNBR0VfVE9UQUxfVE9LRU5TX0FUVFJJQlVURSA9IEdFTl9BSV9VU0FHRV9UT1RBTF9UT0tFTlNfQVRUUklCVVRFO1xuZXhwb3J0cy5PUEVOQUlfT1BFUkFUSU9OUyA9IE9QRU5BSV9PUEVSQVRJT05TO1xuZXhwb3J0cy5PUEVOQUlfUkVTUE9OU0VfSURfQVRUUklCVVRFID0gT1BFTkFJX1JFU1BPTlNFX0lEX0FUVFJJQlVURTtcbmV4cG9ydHMuT1BFTkFJX1JFU1BPTlNFX01PREVMX0FUVFJJQlVURSA9IE9QRU5BSV9SRVNQT05TRV9NT0RFTF9BVFRSSUJVVEU7XG5leHBvcnRzLk9QRU5BSV9SRVNQT05TRV9USU1FU1RBTVBfQVRUUklCVVRFID0gT1BFTkFJX1JFU1BPTlNFX1RJTUVTVEFNUF9BVFRSSUJVVEU7XG5leHBvcnRzLk9QRU5BSV9VU0FHRV9DT01QTEVUSU9OX1RPS0VOU19BVFRSSUJVVEUgPSBPUEVOQUlfVVNBR0VfQ09NUExFVElPTl9UT0tFTlNfQVRUUklCVVRFO1xuZXhwb3J0cy5PUEVOQUlfVVNBR0VfUFJPTVBUX1RPS0VOU19BVFRSSUJVVEUgPSBPUEVOQUlfVVNBR0VfUFJPTVBUX1RPS0VOU19BVFRSSUJVVEU7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1nZW4tYWktYXR0cmlidXRlcy5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/gen-ai-attributes.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/handleCallbackErrors.js":
/*!******************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/handleCallbackErrors.js ***!
  \******************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst is = __webpack_require__(/*! ./is.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js\");\n\n/**\n * Wrap a callback function with error handling.\n * If an error is thrown, it will be passed to the `onError` callback and re-thrown.\n *\n * If the return value of the function is a promise, it will be handled with `maybeHandlePromiseRejection`.\n *\n * If an `onFinally` callback is provided, this will be called when the callback has finished\n * - so if it returns a promise, once the promise resolved/rejected,\n * else once the callback has finished executing.\n * The `onFinally` callback will _always_ be called, no matter if an error was thrown or not.\n */\nfunction handleCallbackErrors\n\n(fn, onError, onFinally = () => {}) {\n  let maybePromiseResult;\n  try {\n    maybePromiseResult = fn();\n  } catch (e) {\n    onError(e);\n    onFinally();\n    throw e;\n  }\n\n  return maybeHandlePromiseRejection(maybePromiseResult, onError, onFinally);\n}\n\n/**\n * Maybe handle a promise rejection.\n * This expects to be given a value that _may_ be a promise, or any other value.\n * If it is a promise, and it rejects, it will call the `onError` callback.\n * Other than this, it will generally return the given value as-is.\n */\nfunction maybeHandlePromiseRejection(\n  value,\n  onError,\n  onFinally,\n) {\n  if (is.isThenable(value)) {\n    // @ts-expect-error - the isThenable check returns the \"wrong\" type here\n    return value.then(\n      res => {\n        onFinally();\n        return res;\n      },\n      e => {\n        onError(e);\n        onFinally();\n        throw e;\n      },\n    );\n  }\n\n  onFinally();\n  return value;\n}\n\nexports.handleCallbackErrors = handleCallbackErrors;\n//# sourceMappingURL=handleCallbackErrors.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9oYW5kbGVDYWxsYmFja0Vycm9ycy5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxXQUFXLG1CQUFPLENBQUMsK0dBQVM7O0FBRTVCO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSxrQ0FBa0M7QUFDbEM7QUFDQTtBQUNBO0FBQ0EsSUFBSTtBQUNKO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLE9BQU87QUFDUDtBQUNBO0FBQ0E7QUFDQTtBQUNBLE9BQU87QUFDUDtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQSw0QkFBNEI7QUFDNUIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9oYW5kbGVDYWxsYmFja0Vycm9ycy5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgaXMgPSByZXF1aXJlKCcuL2lzLmpzJyk7XG5cbi8qKlxuICogV3JhcCBhIGNhbGxiYWNrIGZ1bmN0aW9uIHdpdGggZXJyb3IgaGFuZGxpbmcuXG4gKiBJZiBhbiBlcnJvciBpcyB0aHJvd24sIGl0IHdpbGwgYmUgcGFzc2VkIHRvIHRoZSBgb25FcnJvcmAgY2FsbGJhY2sgYW5kIHJlLXRocm93bi5cbiAqXG4gKiBJZiB0aGUgcmV0dXJuIHZhbHVlIG9mIHRoZSBmdW5jdGlvbiBpcyBhIHByb21pc2UsIGl0IHdpbGwgYmUgaGFuZGxlZCB3aXRoIGBtYXliZUhhbmRsZVByb21pc2VSZWplY3Rpb25gLlxuICpcbiAqIElmIGFuIGBvbkZpbmFsbHlgIGNhbGxiYWNrIGlzIHByb3ZpZGVkLCB0aGlzIHdpbGwgYmUgY2FsbGVkIHdoZW4gdGhlIGNhbGxiYWNrIGhhcyBmaW5pc2hlZFxuICogLSBzbyBpZiBpdCByZXR1cm5zIGEgcHJvbWlzZSwgb25jZSB0aGUgcHJvbWlzZSByZXNvbHZlZC9yZWplY3RlZCxcbiAqIGVsc2Ugb25jZSB0aGUgY2FsbGJhY2sgaGFzIGZpbmlzaGVkIGV4ZWN1dGluZy5cbiAqIFRoZSBgb25GaW5hbGx5YCBjYWxsYmFjayB3aWxsIF9hbHdheXNfIGJlIGNhbGxlZCwgbm8gbWF0dGVyIGlmIGFuIGVycm9yIHdhcyB0aHJvd24gb3Igbm90LlxuICovXG5mdW5jdGlvbiBoYW5kbGVDYWxsYmFja0Vycm9yc1xuXG4oZm4sIG9uRXJyb3IsIG9uRmluYWxseSA9ICgpID0+IHt9KSB7XG4gIGxldCBtYXliZVByb21pc2VSZXN1bHQ7XG4gIHRyeSB7XG4gICAgbWF5YmVQcm9taXNlUmVzdWx0ID0gZm4oKTtcbiAgfSBjYXRjaCAoZSkge1xuICAgIG9uRXJyb3IoZSk7XG4gICAgb25GaW5hbGx5KCk7XG4gICAgdGhyb3cgZTtcbiAgfVxuXG4gIHJldHVybiBtYXliZUhhbmRsZVByb21pc2VSZWplY3Rpb24obWF5YmVQcm9taXNlUmVzdWx0LCBvbkVycm9yLCBvbkZpbmFsbHkpO1xufVxuXG4vKipcbiAqIE1heWJlIGhhbmRsZSBhIHByb21pc2UgcmVqZWN0aW9uLlxuICogVGhpcyBleHBlY3RzIHRvIGJlIGdpdmVuIGEgdmFsdWUgdGhhdCBfbWF5XyBiZSBhIHByb21pc2UsIG9yIGFueSBvdGhlciB2YWx1ZS5cbiAqIElmIGl0IGlzIGEgcHJvbWlzZSwgYW5kIGl0IHJlamVjdHMsIGl0IHdpbGwgY2FsbCB0aGUgYG9uRXJyb3JgIGNhbGxiYWNrLlxuICogT3RoZXIgdGhhbiB0aGlzLCBpdCB3aWxsIGdlbmVyYWxseSByZXR1cm4gdGhlIGdpdmVuIHZhbHVlIGFzLWlzLlxuICovXG5mdW5jdGlvbiBtYXliZUhhbmRsZVByb21pc2VSZWplY3Rpb24oXG4gIHZhbHVlLFxuICBvbkVycm9yLFxuICBvbkZpbmFsbHksXG4pIHtcbiAgaWYgKGlzLmlzVGhlbmFibGUodmFsdWUpKSB7XG4gICAgLy8gQHRzLWV4cGVjdC1lcnJvciAtIHRoZSBpc1RoZW5hYmxlIGNoZWNrIHJldHVybnMgdGhlIFwid3JvbmdcIiB0eXBlIGhlcmVcbiAgICByZXR1cm4gdmFsdWUudGhlbihcbiAgICAgIHJlcyA9PiB7XG4gICAgICAgIG9uRmluYWxseSgpO1xuICAgICAgICByZXR1cm4gcmVzO1xuICAgICAgfSxcbiAgICAgIGUgPT4ge1xuICAgICAgICBvbkVycm9yKGUpO1xuICAgICAgICBvbkZpbmFsbHkoKTtcbiAgICAgICAgdGhyb3cgZTtcbiAgICAgIH0sXG4gICAgKTtcbiAgfVxuXG4gIG9uRmluYWxseSgpO1xuICByZXR1cm4gdmFsdWU7XG59XG5cbmV4cG9ydHMuaGFuZGxlQ2FsbGJhY2tFcnJvcnMgPSBoYW5kbGVDYWxsYmFja0Vycm9ycztcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWhhbmRsZUNhbGxiYWNrRXJyb3JzLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/handleCallbackErrors.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/hasSpansEnabled.js":
/*!*************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/hasSpansEnabled.js ***!
  \*************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst currentScopes = __webpack_require__(/*! ../currentScopes.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\n\n// Treeshakable guard to remove all code related to tracing\n\n/**\n * Determines if span recording is currently enabled.\n *\n * Spans are recorded when at least one of `tracesSampleRate` and `tracesSampler`\n * is defined in the SDK config. This function does not make any assumption about\n * sampling decisions, it only checks if the SDK is configured to record spans.\n *\n * Important: This function only determines if span recording is enabled. Trace\n * continuation and propagation is separately controlled and not covered by this function.\n * If this function returns `false`, traces can still be propagated (which is what\n * we refer to by \"Tracing without Performance\")\n * @see https://develop.sentry.dev/sdk/telemetry/traces/tracing-without-performance/\n *\n * @param maybeOptions An SDK options object to be passed to this function.\n * If this option is not provided, the function will use the current client's options.\n */\nfunction hasSpansEnabled(\n  maybeOptions,\n) {\n  if (typeof __SENTRY_TRACING__ === 'boolean' && !__SENTRY_TRACING__) {\n    return false;\n  }\n\n  const options = maybeOptions || currentScopes.getClient()?.getOptions();\n  return (\n    !!options &&\n    // Note: This check is `!= null`, meaning \"nullish\". `0` is not \"nullish\", `undefined` and `null` are. (This comment was brought to you by 15 minutes of questioning life)\n    (options.tracesSampleRate != null || !!options.tracesSampler)\n  );\n}\n\n/**\n * @see JSDoc of `hasSpansEnabled`\n * @deprecated Use `hasSpansEnabled` instead, which is a more accurately named version of this function.\n * This function will be removed in the next major version of the SDK.\n */\n// TODO(v10): Remove this export\nconst hasTracingEnabled = hasSpansEnabled;\n\nexports.hasSpansEnabled = hasSpansEnabled;\nexports.hasTracingEnabled = hasTracingEnabled;\n//# sourceMappingURL=hasSpansEnabled.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9oYXNTcGFuc0VuYWJsZWQuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsc0JBQXNCLG1CQUFPLENBQUMsZ0lBQXFCOztBQUVuRDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSx1QkFBdUI7QUFDdkIseUJBQXlCO0FBQ3pCIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvaGFzU3BhbnNFbmFibGVkLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBjdXJyZW50U2NvcGVzID0gcmVxdWlyZSgnLi4vY3VycmVudFNjb3Blcy5qcycpO1xuXG4vLyBUcmVlc2hha2FibGUgZ3VhcmQgdG8gcmVtb3ZlIGFsbCBjb2RlIHJlbGF0ZWQgdG8gdHJhY2luZ1xuXG4vKipcbiAqIERldGVybWluZXMgaWYgc3BhbiByZWNvcmRpbmcgaXMgY3VycmVudGx5IGVuYWJsZWQuXG4gKlxuICogU3BhbnMgYXJlIHJlY29yZGVkIHdoZW4gYXQgbGVhc3Qgb25lIG9mIGB0cmFjZXNTYW1wbGVSYXRlYCBhbmQgYHRyYWNlc1NhbXBsZXJgXG4gKiBpcyBkZWZpbmVkIGluIHRoZSBTREsgY29uZmlnLiBUaGlzIGZ1bmN0aW9uIGRvZXMgbm90IG1ha2UgYW55IGFzc3VtcHRpb24gYWJvdXRcbiAqIHNhbXBsaW5nIGRlY2lzaW9ucywgaXQgb25seSBjaGVja3MgaWYgdGhlIFNESyBpcyBjb25maWd1cmVkIHRvIHJlY29yZCBzcGFucy5cbiAqXG4gKiBJbXBvcnRhbnQ6IFRoaXMgZnVuY3Rpb24gb25seSBkZXRlcm1pbmVzIGlmIHNwYW4gcmVjb3JkaW5nIGlzIGVuYWJsZWQuIFRyYWNlXG4gKiBjb250aW51YXRpb24gYW5kIHByb3BhZ2F0aW9uIGlzIHNlcGFyYXRlbHkgY29udHJvbGxlZCBhbmQgbm90IGNvdmVyZWQgYnkgdGhpcyBmdW5jdGlvbi5cbiAqIElmIHRoaXMgZnVuY3Rpb24gcmV0dXJucyBgZmFsc2VgLCB0cmFjZXMgY2FuIHN0aWxsIGJlIHByb3BhZ2F0ZWQgKHdoaWNoIGlzIHdoYXRcbiAqIHdlIHJlZmVyIHRvIGJ5IFwiVHJhY2luZyB3aXRob3V0IFBlcmZvcm1hbmNlXCIpXG4gKiBAc2VlIGh0dHBzOi8vZGV2ZWxvcC5zZW50cnkuZGV2L3Nkay90ZWxlbWV0cnkvdHJhY2VzL3RyYWNpbmctd2l0aG91dC1wZXJmb3JtYW5jZS9cbiAqXG4gKiBAcGFyYW0gbWF5YmVPcHRpb25zIEFuIFNESyBvcHRpb25zIG9iamVjdCB0byBiZSBwYXNzZWQgdG8gdGhpcyBmdW5jdGlvbi5cbiAqIElmIHRoaXMgb3B0aW9uIGlzIG5vdCBwcm92aWRlZCwgdGhlIGZ1bmN0aW9uIHdpbGwgdXNlIHRoZSBjdXJyZW50IGNsaWVudCdzIG9wdGlvbnMuXG4gKi9cbmZ1bmN0aW9uIGhhc1NwYW5zRW5hYmxlZChcbiAgbWF5YmVPcHRpb25zLFxuKSB7XG4gIGlmICh0eXBlb2YgX19TRU5UUllfVFJBQ0lOR19fID09PSAnYm9vbGVhbicgJiYgIV9fU0VOVFJZX1RSQUNJTkdfXykge1xuICAgIHJldHVybiBmYWxzZTtcbiAgfVxuXG4gIGNvbnN0IG9wdGlvbnMgPSBtYXliZU9wdGlvbnMgfHwgY3VycmVudFNjb3Blcy5nZXRDbGllbnQoKT8uZ2V0T3B0aW9ucygpO1xuICByZXR1cm4gKFxuICAgICEhb3B0aW9ucyAmJlxuICAgIC8vIE5vdGU6IFRoaXMgY2hlY2sgaXMgYCE9IG51bGxgLCBtZWFuaW5nIFwibnVsbGlzaFwiLiBgMGAgaXMgbm90IFwibnVsbGlzaFwiLCBgdW5kZWZpbmVkYCBhbmQgYG51bGxgIGFyZS4gKFRoaXMgY29tbWVudCB3YXMgYnJvdWdodCB0byB5b3UgYnkgMTUgbWludXRlcyBvZiBxdWVzdGlvbmluZyBsaWZlKVxuICAgIChvcHRpb25zLnRyYWNlc1NhbXBsZVJhdGUgIT0gbnVsbCB8fCAhIW9wdGlvbnMudHJhY2VzU2FtcGxlcilcbiAgKTtcbn1cblxuLyoqXG4gKiBAc2VlIEpTRG9jIG9mIGBoYXNTcGFuc0VuYWJsZWRgXG4gKiBAZGVwcmVjYXRlZCBVc2UgYGhhc1NwYW5zRW5hYmxlZGAgaW5zdGVhZCwgd2hpY2ggaXMgYSBtb3JlIGFjY3VyYXRlbHkgbmFtZWQgdmVyc2lvbiBvZiB0aGlzIGZ1bmN0aW9uLlxuICogVGhpcyBmdW5jdGlvbiB3aWxsIGJlIHJlbW92ZWQgaW4gdGhlIG5leHQgbWFqb3IgdmVyc2lvbiBvZiB0aGUgU0RLLlxuICovXG4vLyBUT0RPKHYxMCk6IFJlbW92ZSB0aGlzIGV4cG9ydFxuY29uc3QgaGFzVHJhY2luZ0VuYWJsZWQgPSBoYXNTcGFuc0VuYWJsZWQ7XG5cbmV4cG9ydHMuaGFzU3BhbnNFbmFibGVkID0gaGFzU3BhbnNFbmFibGVkO1xuZXhwb3J0cy5oYXNUcmFjaW5nRW5hYmxlZCA9IGhhc1RyYWNpbmdFbmFibGVkO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9aGFzU3BhbnNFbmFibGVkLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/hasSpansEnabled.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/ipAddress.js":
/*!*******************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/ipAddress.js ***!
  \*******************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n// By default, we want to infer the IP address, unless this is explicitly set to `null`\n// We do this after all other processing is done\n// If `ip_address` is explicitly set to `null` or a value, we leave it as is\n\n/**\n * @internal\n */\nfunction addAutoIpAddressToUser(objWithMaybeUser) {\n  if (objWithMaybeUser.user?.ip_address === undefined) {\n    objWithMaybeUser.user = {\n      ...objWithMaybeUser.user,\n      ip_address: '{{auto}}',\n    };\n  }\n}\n\n/**\n * @internal\n */\nfunction addAutoIpAddressToSession(session) {\n  if ('aggregates' in session) {\n    if (session.attrs?.['ip_address'] === undefined) {\n      session.attrs = {\n        ...session.attrs,\n        ip_address: '{{auto}}',\n      };\n    }\n  } else {\n    if (session.ipAddress === undefined) {\n      session.ipAddress = '{{auto}}';\n    }\n  }\n}\n\nexports.addAutoIpAddressToSession = addAutoIpAddressToSession;\nexports.addAutoIpAddressToUser = addAutoIpAddressToUser;\n//# sourceMappingURL=ipAddress.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9pcEFkZHJlc3MuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEU7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EscUJBQXFCLE1BQU07QUFDM0I7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSx1QkFBdUIsTUFBTTtBQUM3QjtBQUNBO0FBQ0EsSUFBSTtBQUNKO0FBQ0EsNkJBQTZCLE1BQU07QUFDbkM7QUFDQTtBQUNBOztBQUVBLGlDQUFpQztBQUNqQyw4QkFBOEI7QUFDOUIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9pcEFkZHJlc3MuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbi8vIEJ5IGRlZmF1bHQsIHdlIHdhbnQgdG8gaW5mZXIgdGhlIElQIGFkZHJlc3MsIHVubGVzcyB0aGlzIGlzIGV4cGxpY2l0bHkgc2V0IHRvIGBudWxsYFxuLy8gV2UgZG8gdGhpcyBhZnRlciBhbGwgb3RoZXIgcHJvY2Vzc2luZyBpcyBkb25lXG4vLyBJZiBgaXBfYWRkcmVzc2AgaXMgZXhwbGljaXRseSBzZXQgdG8gYG51bGxgIG9yIGEgdmFsdWUsIHdlIGxlYXZlIGl0IGFzIGlzXG5cbi8qKlxuICogQGludGVybmFsXG4gKi9cbmZ1bmN0aW9uIGFkZEF1dG9JcEFkZHJlc3NUb1VzZXIob2JqV2l0aE1heWJlVXNlcikge1xuICBpZiAob2JqV2l0aE1heWJlVXNlci51c2VyPy5pcF9hZGRyZXNzID09PSB1bmRlZmluZWQpIHtcbiAgICBvYmpXaXRoTWF5YmVVc2VyLnVzZXIgPSB7XG4gICAgICAuLi5vYmpXaXRoTWF5YmVVc2VyLnVzZXIsXG4gICAgICBpcF9hZGRyZXNzOiAne3thdXRvfX0nLFxuICAgIH07XG4gIH1cbn1cblxuLyoqXG4gKiBAaW50ZXJuYWxcbiAqL1xuZnVuY3Rpb24gYWRkQXV0b0lwQWRkcmVzc1RvU2Vzc2lvbihzZXNzaW9uKSB7XG4gIGlmICgnYWdncmVnYXRlcycgaW4gc2Vzc2lvbikge1xuICAgIGlmIChzZXNzaW9uLmF0dHJzPy5bJ2lwX2FkZHJlc3MnXSA9PT0gdW5kZWZpbmVkKSB7XG4gICAgICBzZXNzaW9uLmF0dHJzID0ge1xuICAgICAgICAuLi5zZXNzaW9uLmF0dHJzLFxuICAgICAgICBpcF9hZGRyZXNzOiAne3thdXRvfX0nLFxuICAgICAgfTtcbiAgICB9XG4gIH0gZWxzZSB7XG4gICAgaWYgKHNlc3Npb24uaXBBZGRyZXNzID09PSB1bmRlZmluZWQpIHtcbiAgICAgIHNlc3Npb24uaXBBZGRyZXNzID0gJ3t7YXV0b319JztcbiAgICB9XG4gIH1cbn1cblxuZXhwb3J0cy5hZGRBdXRvSXBBZGRyZXNzVG9TZXNzaW9uID0gYWRkQXV0b0lwQWRkcmVzc1RvU2Vzc2lvbjtcbmV4cG9ydHMuYWRkQXV0b0lwQWRkcmVzc1RvVXNlciA9IGFkZEF1dG9JcEFkZHJlc3NUb1VzZXI7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1pcEFkZHJlc3MuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/ipAddress.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js":
/*!************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js ***!
  \************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n// eslint-disable-next-line @typescript-eslint/unbound-method\nconst objectToString = Object.prototype.toString;\n\n/**\n * Checks whether given value's type is one of a few Error or Error-like\n * {@link isError}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isError(wat) {\n  switch (objectToString.call(wat)) {\n    case '[object Error]':\n    case '[object Exception]':\n    case '[object DOMException]':\n    case '[object WebAssembly.Exception]':\n      return true;\n    default:\n      return isInstanceOf(wat, Error);\n  }\n}\n/**\n * Checks whether given value is an instance of the given built-in class.\n *\n * @param wat The value to be checked\n * @param className\n * @returns A boolean representing the result.\n */\nfunction isBuiltin(wat, className) {\n  return objectToString.call(wat) === `[object ${className}]`;\n}\n\n/**\n * Checks whether given value's type is ErrorEvent\n * {@link isErrorEvent}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isErrorEvent(wat) {\n  return isBuiltin(wat, 'ErrorEvent');\n}\n\n/**\n * Checks whether given value's type is DOMError\n * {@link isDOMError}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isDOMError(wat) {\n  return isBuiltin(wat, 'DOMError');\n}\n\n/**\n * Checks whether given value's type is DOMException\n * {@link isDOMException}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isDOMException(wat) {\n  return isBuiltin(wat, 'DOMException');\n}\n\n/**\n * Checks whether given value's type is a string\n * {@link isString}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isString(wat) {\n  return isBuiltin(wat, 'String');\n}\n\n/**\n * Checks whether given string is parameterized\n * {@link isParameterizedString}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isParameterizedString(wat) {\n  return (\n    typeof wat === 'object' &&\n    wat !== null &&\n    '__sentry_template_string__' in wat &&\n    '__sentry_template_values__' in wat\n  );\n}\n\n/**\n * Checks whether given value is a primitive (undefined, null, number, boolean, string, bigint, symbol)\n * {@link isPrimitive}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isPrimitive(wat) {\n  return wat === null || isParameterizedString(wat) || (typeof wat !== 'object' && typeof wat !== 'function');\n}\n\n/**\n * Checks whether given value's type is an object literal, or a class instance.\n * {@link isPlainObject}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isPlainObject(wat) {\n  return isBuiltin(wat, 'Object');\n}\n\n/**\n * Checks whether given value's type is an Event instance\n * {@link isEvent}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isEvent(wat) {\n  return typeof Event !== 'undefined' && isInstanceOf(wat, Event);\n}\n\n/**\n * Checks whether given value's type is an Element instance\n * {@link isElement}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isElement(wat) {\n  return typeof Element !== 'undefined' && isInstanceOf(wat, Element);\n}\n\n/**\n * Checks whether given value's type is an regexp\n * {@link isRegExp}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isRegExp(wat) {\n  return isBuiltin(wat, 'RegExp');\n}\n\n/**\n * Checks whether given value has a then function.\n * @param wat A value to be checked.\n */\nfunction isThenable(wat) {\n  // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n  return Boolean(wat?.then && typeof wat.then === 'function');\n}\n\n/**\n * Checks whether given value's type is a SyntheticEvent\n * {@link isSyntheticEvent}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isSyntheticEvent(wat) {\n  return isPlainObject(wat) && 'nativeEvent' in wat && 'preventDefault' in wat && 'stopPropagation' in wat;\n}\n\n/**\n * Checks whether given value's type is an instance of provided constructor.\n * {@link isInstanceOf}.\n *\n * @param wat A value to be checked.\n * @param base A constructor to be used in a check.\n * @returns A boolean representing the result.\n */\nfunction isInstanceOf(wat, base) {\n  try {\n    return wat instanceof base;\n  } catch {\n    return false;\n  }\n}\n\n/**\n * Checks whether given value's type is a Vue ViewModel.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isVueViewModel(wat) {\n  // Not using Object.prototype.toString because in Vue 3 it would read the instance's Symbol(Symbol.toStringTag) property.\n  return !!(typeof wat === 'object' && wat !== null && ((wat ).__isVue || (wat )._isVue));\n}\n\n/**\n * Checks whether the given parameter is a Standard Web API Request instance.\n *\n * Returns false if Request is not available in the current runtime.\n */\nfunction isRequest(request) {\n  return typeof Request !== 'undefined' && isInstanceOf(request, Request);\n}\n\nexports.isDOMError = isDOMError;\nexports.isDOMException = isDOMException;\nexports.isElement = isElement;\nexports.isError = isError;\nexports.isErrorEvent = isErrorEvent;\nexports.isEvent = isEvent;\nexports.isInstanceOf = isInstanceOf;\nexports.isParameterizedString = isParameterizedString;\nexports.isPlainObject = isPlainObject;\nexports.isPrimitive = isPrimitive;\nexports.isRegExp = isRegExp;\nexports.isRequest = isRequest;\nexports.isString = isString;\nexports.isSyntheticEvent = isSyntheticEvent;\nexports.isThenable = isThenable;\nexports.isVueViewModel = isVueViewModel;\n//# sourceMappingURL=is.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9pcy5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RTtBQUNBOztBQUVBO0FBQ0E7QUFDQSxJQUFJLGNBQWM7QUFDbEI7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGlEQUFpRCxVQUFVO0FBQzNEOztBQUVBO0FBQ0E7QUFDQSxJQUFJLG1CQUFtQjtBQUN2QjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsSUFBSSxpQkFBaUI7QUFDckI7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLElBQUkscUJBQXFCO0FBQ3pCO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQSxJQUFJLGVBQWU7QUFDbkI7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLElBQUksNEJBQTRCO0FBQ2hDO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsSUFBSSxrQkFBa0I7QUFDdEI7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLElBQUksb0JBQW9CO0FBQ3hCO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQSxJQUFJLGNBQWM7QUFDbEI7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLElBQUksZ0JBQWdCO0FBQ3BCO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQSxJQUFJLGVBQWU7QUFDbkI7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsSUFBSSx1QkFBdUI7QUFDM0I7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLElBQUksbUJBQW1CO0FBQ3ZCO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxJQUFJO0FBQ0o7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsa0JBQWtCO0FBQ2xCLHNCQUFzQjtBQUN0QixpQkFBaUI7QUFDakIsZUFBZTtBQUNmLG9CQUFvQjtBQUNwQixlQUFlO0FBQ2Ysb0JBQW9CO0FBQ3BCLDZCQUE2QjtBQUM3QixxQkFBcUI7QUFDckIsbUJBQW1CO0FBQ25CLGdCQUFnQjtBQUNoQixpQkFBaUI7QUFDakIsZ0JBQWdCO0FBQ2hCLHdCQUF3QjtBQUN4QixrQkFBa0I7QUFDbEIsc0JBQXNCO0FBQ3RCIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvaXMuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbi8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvdW5ib3VuZC1tZXRob2RcbmNvbnN0IG9iamVjdFRvU3RyaW5nID0gT2JqZWN0LnByb3RvdHlwZS50b1N0cmluZztcblxuLyoqXG4gKiBDaGVja3Mgd2hldGhlciBnaXZlbiB2YWx1ZSdzIHR5cGUgaXMgb25lIG9mIGEgZmV3IEVycm9yIG9yIEVycm9yLWxpa2VcbiAqIHtAbGluayBpc0Vycm9yfS5cbiAqXG4gKiBAcGFyYW0gd2F0IEEgdmFsdWUgdG8gYmUgY2hlY2tlZC5cbiAqIEByZXR1cm5zIEEgYm9vbGVhbiByZXByZXNlbnRpbmcgdGhlIHJlc3VsdC5cbiAqL1xuZnVuY3Rpb24gaXNFcnJvcih3YXQpIHtcbiAgc3dpdGNoIChvYmplY3RUb1N0cmluZy5jYWxsKHdhdCkpIHtcbiAgICBjYXNlICdbb2JqZWN0IEVycm9yXSc6XG4gICAgY2FzZSAnW29iamVjdCBFeGNlcHRpb25dJzpcbiAgICBjYXNlICdbb2JqZWN0IERPTUV4Y2VwdGlvbl0nOlxuICAgIGNhc2UgJ1tvYmplY3QgV2ViQXNzZW1ibHkuRXhjZXB0aW9uXSc6XG4gICAgICByZXR1cm4gdHJ1ZTtcbiAgICBkZWZhdWx0OlxuICAgICAgcmV0dXJuIGlzSW5zdGFuY2VPZih3YXQsIEVycm9yKTtcbiAgfVxufVxuLyoqXG4gKiBDaGVja3Mgd2hldGhlciBnaXZlbiB2YWx1ZSBpcyBhbiBpbnN0YW5jZSBvZiB0aGUgZ2l2ZW4gYnVpbHQtaW4gY2xhc3MuXG4gKlxuICogQHBhcmFtIHdhdCBUaGUgdmFsdWUgdG8gYmUgY2hlY2tlZFxuICogQHBhcmFtIGNsYXNzTmFtZVxuICogQHJldHVybnMgQSBib29sZWFuIHJlcHJlc2VudGluZyB0aGUgcmVzdWx0LlxuICovXG5mdW5jdGlvbiBpc0J1aWx0aW4od2F0LCBjbGFzc05hbWUpIHtcbiAgcmV0dXJuIG9iamVjdFRvU3RyaW5nLmNhbGwod2F0KSA9PT0gYFtvYmplY3QgJHtjbGFzc05hbWV9XWA7XG59XG5cbi8qKlxuICogQ2hlY2tzIHdoZXRoZXIgZ2l2ZW4gdmFsdWUncyB0eXBlIGlzIEVycm9yRXZlbnRcbiAqIHtAbGluayBpc0Vycm9yRXZlbnR9LlxuICpcbiAqIEBwYXJhbSB3YXQgQSB2YWx1ZSB0byBiZSBjaGVja2VkLlxuICogQHJldHVybnMgQSBib29sZWFuIHJlcHJlc2VudGluZyB0aGUgcmVzdWx0LlxuICovXG5mdW5jdGlvbiBpc0Vycm9yRXZlbnQod2F0KSB7XG4gIHJldHVybiBpc0J1aWx0aW4od2F0LCAnRXJyb3JFdmVudCcpO1xufVxuXG4vKipcbiAqIENoZWNrcyB3aGV0aGVyIGdpdmVuIHZhbHVlJ3MgdHlwZSBpcyBET01FcnJvclxuICoge0BsaW5rIGlzRE9NRXJyb3J9LlxuICpcbiAqIEBwYXJhbSB3YXQgQSB2YWx1ZSB0byBiZSBjaGVja2VkLlxuICogQHJldHVybnMgQSBib29sZWFuIHJlcHJlc2VudGluZyB0aGUgcmVzdWx0LlxuICovXG5mdW5jdGlvbiBpc0RPTUVycm9yKHdhdCkge1xuICByZXR1cm4gaXNCdWlsdGluKHdhdCwgJ0RPTUVycm9yJyk7XG59XG5cbi8qKlxuICogQ2hlY2tzIHdoZXRoZXIgZ2l2ZW4gdmFsdWUncyB0eXBlIGlzIERPTUV4Y2VwdGlvblxuICoge0BsaW5rIGlzRE9NRXhjZXB0aW9ufS5cbiAqXG4gKiBAcGFyYW0gd2F0IEEgdmFsdWUgdG8gYmUgY2hlY2tlZC5cbiAqIEByZXR1cm5zIEEgYm9vbGVhbiByZXByZXNlbnRpbmcgdGhlIHJlc3VsdC5cbiAqL1xuZnVuY3Rpb24gaXNET01FeGNlcHRpb24od2F0KSB7XG4gIHJldHVybiBpc0J1aWx0aW4od2F0LCAnRE9NRXhjZXB0aW9uJyk7XG59XG5cbi8qKlxuICogQ2hlY2tzIHdoZXRoZXIgZ2l2ZW4gdmFsdWUncyB0eXBlIGlzIGEgc3RyaW5nXG4gKiB7QGxpbmsgaXNTdHJpbmd9LlxuICpcbiAqIEBwYXJhbSB3YXQgQSB2YWx1ZSB0byBiZSBjaGVja2VkLlxuICogQHJldHVybnMgQSBib29sZWFuIHJlcHJlc2VudGluZyB0aGUgcmVzdWx0LlxuICovXG5mdW5jdGlvbiBpc1N0cmluZyh3YXQpIHtcbiAgcmV0dXJuIGlzQnVpbHRpbih3YXQsICdTdHJpbmcnKTtcbn1cblxuLyoqXG4gKiBDaGVja3Mgd2hldGhlciBnaXZlbiBzdHJpbmcgaXMgcGFyYW1ldGVyaXplZFxuICoge0BsaW5rIGlzUGFyYW1ldGVyaXplZFN0cmluZ30uXG4gKlxuICogQHBhcmFtIHdhdCBBIHZhbHVlIHRvIGJlIGNoZWNrZWQuXG4gKiBAcmV0dXJucyBBIGJvb2xlYW4gcmVwcmVzZW50aW5nIHRoZSByZXN1bHQuXG4gKi9cbmZ1bmN0aW9uIGlzUGFyYW1ldGVyaXplZFN0cmluZyh3YXQpIHtcbiAgcmV0dXJuIChcbiAgICB0eXBlb2Ygd2F0ID09PSAnb2JqZWN0JyAmJlxuICAgIHdhdCAhPT0gbnVsbCAmJlxuICAgICdfX3NlbnRyeV90ZW1wbGF0ZV9zdHJpbmdfXycgaW4gd2F0ICYmXG4gICAgJ19fc2VudHJ5X3RlbXBsYXRlX3ZhbHVlc19fJyBpbiB3YXRcbiAgKTtcbn1cblxuLyoqXG4gKiBDaGVja3Mgd2hldGhlciBnaXZlbiB2YWx1ZSBpcyBhIHByaW1pdGl2ZSAodW5kZWZpbmVkLCBudWxsLCBudW1iZXIsIGJvb2xlYW4sIHN0cmluZywgYmlnaW50LCBzeW1ib2wpXG4gKiB7QGxpbmsgaXNQcmltaXRpdmV9LlxuICpcbiAqIEBwYXJhbSB3YXQgQSB2YWx1ZSB0byBiZSBjaGVja2VkLlxuICogQHJldHVybnMgQSBib29sZWFuIHJlcHJlc2VudGluZyB0aGUgcmVzdWx0LlxuICovXG5mdW5jdGlvbiBpc1ByaW1pdGl2ZSh3YXQpIHtcbiAgcmV0dXJuIHdhdCA9PT0gbnVsbCB8fCBpc1BhcmFtZXRlcml6ZWRTdHJpbmcod2F0KSB8fCAodHlwZW9mIHdhdCAhPT0gJ29iamVjdCcgJiYgdHlwZW9mIHdhdCAhPT0gJ2Z1bmN0aW9uJyk7XG59XG5cbi8qKlxuICogQ2hlY2tzIHdoZXRoZXIgZ2l2ZW4gdmFsdWUncyB0eXBlIGlzIGFuIG9iamVjdCBsaXRlcmFsLCBvciBhIGNsYXNzIGluc3RhbmNlLlxuICoge0BsaW5rIGlzUGxhaW5PYmplY3R9LlxuICpcbiAqIEBwYXJhbSB3YXQgQSB2YWx1ZSB0byBiZSBjaGVja2VkLlxuICogQHJldHVybnMgQSBib29sZWFuIHJlcHJlc2VudGluZyB0aGUgcmVzdWx0LlxuICovXG5mdW5jdGlvbiBpc1BsYWluT2JqZWN0KHdhdCkge1xuICByZXR1cm4gaXNCdWlsdGluKHdhdCwgJ09iamVjdCcpO1xufVxuXG4vKipcbiAqIENoZWNrcyB3aGV0aGVyIGdpdmVuIHZhbHVlJ3MgdHlwZSBpcyBhbiBFdmVudCBpbnN0YW5jZVxuICoge0BsaW5rIGlzRXZlbnR9LlxuICpcbiAqIEBwYXJhbSB3YXQgQSB2YWx1ZSB0byBiZSBjaGVja2VkLlxuICogQHJldHVybnMgQSBib29sZWFuIHJlcHJlc2VudGluZyB0aGUgcmVzdWx0LlxuICovXG5mdW5jdGlvbiBpc0V2ZW50KHdhdCkge1xuICByZXR1cm4gdHlwZW9mIEV2ZW50ICE9PSAndW5kZWZpbmVkJyAmJiBpc0luc3RhbmNlT2Yod2F0LCBFdmVudCk7XG59XG5cbi8qKlxuICogQ2hlY2tzIHdoZXRoZXIgZ2l2ZW4gdmFsdWUncyB0eXBlIGlzIGFuIEVsZW1lbnQgaW5zdGFuY2VcbiAqIHtAbGluayBpc0VsZW1lbnR9LlxuICpcbiAqIEBwYXJhbSB3YXQgQSB2YWx1ZSB0byBiZSBjaGVja2VkLlxuICogQHJldHVybnMgQSBib29sZWFuIHJlcHJlc2VudGluZyB0aGUgcmVzdWx0LlxuICovXG5mdW5jdGlvbiBpc0VsZW1lbnQod2F0KSB7XG4gIHJldHVybiB0eXBlb2YgRWxlbWVudCAhPT0gJ3VuZGVmaW5lZCcgJiYgaXNJbnN0YW5jZU9mKHdhdCwgRWxlbWVudCk7XG59XG5cbi8qKlxuICogQ2hlY2tzIHdoZXRoZXIgZ2l2ZW4gdmFsdWUncyB0eXBlIGlzIGFuIHJlZ2V4cFxuICoge0BsaW5rIGlzUmVnRXhwfS5cbiAqXG4gKiBAcGFyYW0gd2F0IEEgdmFsdWUgdG8gYmUgY2hlY2tlZC5cbiAqIEByZXR1cm5zIEEgYm9vbGVhbiByZXByZXNlbnRpbmcgdGhlIHJlc3VsdC5cbiAqL1xuZnVuY3Rpb24gaXNSZWdFeHAod2F0KSB7XG4gIHJldHVybiBpc0J1aWx0aW4od2F0LCAnUmVnRXhwJyk7XG59XG5cbi8qKlxuICogQ2hlY2tzIHdoZXRoZXIgZ2l2ZW4gdmFsdWUgaGFzIGEgdGhlbiBmdW5jdGlvbi5cbiAqIEBwYXJhbSB3YXQgQSB2YWx1ZSB0byBiZSBjaGVja2VkLlxuICovXG5mdW5jdGlvbiBpc1RoZW5hYmxlKHdhdCkge1xuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25vLXVuc2FmZS1tZW1iZXItYWNjZXNzXG4gIHJldHVybiBCb29sZWFuKHdhdD8udGhlbiAmJiB0eXBlb2Ygd2F0LnRoZW4gPT09ICdmdW5jdGlvbicpO1xufVxuXG4vKipcbiAqIENoZWNrcyB3aGV0aGVyIGdpdmVuIHZhbHVlJ3MgdHlwZSBpcyBhIFN5bnRoZXRpY0V2ZW50XG4gKiB7QGxpbmsgaXNTeW50aGV0aWNFdmVudH0uXG4gKlxuICogQHBhcmFtIHdhdCBBIHZhbHVlIHRvIGJlIGNoZWNrZWQuXG4gKiBAcmV0dXJucyBBIGJvb2xlYW4gcmVwcmVzZW50aW5nIHRoZSByZXN1bHQuXG4gKi9cbmZ1bmN0aW9uIGlzU3ludGhldGljRXZlbnQod2F0KSB7XG4gIHJldHVybiBpc1BsYWluT2JqZWN0KHdhdCkgJiYgJ25hdGl2ZUV2ZW50JyBpbiB3YXQgJiYgJ3ByZXZlbnREZWZhdWx0JyBpbiB3YXQgJiYgJ3N0b3BQcm9wYWdhdGlvbicgaW4gd2F0O1xufVxuXG4vKipcbiAqIENoZWNrcyB3aGV0aGVyIGdpdmVuIHZhbHVlJ3MgdHlwZSBpcyBhbiBpbnN0YW5jZSBvZiBwcm92aWRlZCBjb25zdHJ1Y3Rvci5cbiAqIHtAbGluayBpc0luc3RhbmNlT2Z9LlxuICpcbiAqIEBwYXJhbSB3YXQgQSB2YWx1ZSB0byBiZSBjaGVja2VkLlxuICogQHBhcmFtIGJhc2UgQSBjb25zdHJ1Y3RvciB0byBiZSB1c2VkIGluIGEgY2hlY2suXG4gKiBAcmV0dXJucyBBIGJvb2xlYW4gcmVwcmVzZW50aW5nIHRoZSByZXN1bHQuXG4gKi9cbmZ1bmN0aW9uIGlzSW5zdGFuY2VPZih3YXQsIGJhc2UpIHtcbiAgdHJ5IHtcbiAgICByZXR1cm4gd2F0IGluc3RhbmNlb2YgYmFzZTtcbiAgfSBjYXRjaCB7XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG59XG5cbi8qKlxuICogQ2hlY2tzIHdoZXRoZXIgZ2l2ZW4gdmFsdWUncyB0eXBlIGlzIGEgVnVlIFZpZXdNb2RlbC5cbiAqXG4gKiBAcGFyYW0gd2F0IEEgdmFsdWUgdG8gYmUgY2hlY2tlZC5cbiAqIEByZXR1cm5zIEEgYm9vbGVhbiByZXByZXNlbnRpbmcgdGhlIHJlc3VsdC5cbiAqL1xuZnVuY3Rpb24gaXNWdWVWaWV3TW9kZWwod2F0KSB7XG4gIC8vIE5vdCB1c2luZyBPYmplY3QucHJvdG90eXBlLnRvU3RyaW5nIGJlY2F1c2UgaW4gVnVlIDMgaXQgd291bGQgcmVhZCB0aGUgaW5zdGFuY2UncyBTeW1ib2woU3ltYm9sLnRvU3RyaW5nVGFnKSBwcm9wZXJ0eS5cbiAgcmV0dXJuICEhKHR5cGVvZiB3YXQgPT09ICdvYmplY3QnICYmIHdhdCAhPT0gbnVsbCAmJiAoKHdhdCApLl9faXNWdWUgfHwgKHdhdCApLl9pc1Z1ZSkpO1xufVxuXG4vKipcbiAqIENoZWNrcyB3aGV0aGVyIHRoZSBnaXZlbiBwYXJhbWV0ZXIgaXMgYSBTdGFuZGFyZCBXZWIgQVBJIFJlcXVlc3QgaW5zdGFuY2UuXG4gKlxuICogUmV0dXJucyBmYWxzZSBpZiBSZXF1ZXN0IGlzIG5vdCBhdmFpbGFibGUgaW4gdGhlIGN1cnJlbnQgcnVudGltZS5cbiAqL1xuZnVuY3Rpb24gaXNSZXF1ZXN0KHJlcXVlc3QpIHtcbiAgcmV0dXJuIHR5cGVvZiBSZXF1ZXN0ICE9PSAndW5kZWZpbmVkJyAmJiBpc0luc3RhbmNlT2YocmVxdWVzdCwgUmVxdWVzdCk7XG59XG5cbmV4cG9ydHMuaXNET01FcnJvciA9IGlzRE9NRXJyb3I7XG5leHBvcnRzLmlzRE9NRXhjZXB0aW9uID0gaXNET01FeGNlcHRpb247XG5leHBvcnRzLmlzRWxlbWVudCA9IGlzRWxlbWVudDtcbmV4cG9ydHMuaXNFcnJvciA9IGlzRXJyb3I7XG5leHBvcnRzLmlzRXJyb3JFdmVudCA9IGlzRXJyb3JFdmVudDtcbmV4cG9ydHMuaXNFdmVudCA9IGlzRXZlbnQ7XG5leHBvcnRzLmlzSW5zdGFuY2VPZiA9IGlzSW5zdGFuY2VPZjtcbmV4cG9ydHMuaXNQYXJhbWV0ZXJpemVkU3RyaW5nID0gaXNQYXJhbWV0ZXJpemVkU3RyaW5nO1xuZXhwb3J0cy5pc1BsYWluT2JqZWN0ID0gaXNQbGFpbk9iamVjdDtcbmV4cG9ydHMuaXNQcmltaXRpdmUgPSBpc1ByaW1pdGl2ZTtcbmV4cG9ydHMuaXNSZWdFeHAgPSBpc1JlZ0V4cDtcbmV4cG9ydHMuaXNSZXF1ZXN0ID0gaXNSZXF1ZXN0O1xuZXhwb3J0cy5pc1N0cmluZyA9IGlzU3RyaW5nO1xuZXhwb3J0cy5pc1N5bnRoZXRpY0V2ZW50ID0gaXNTeW50aGV0aWNFdmVudDtcbmV4cG9ydHMuaXNUaGVuYWJsZSA9IGlzVGhlbmFibGU7XG5leHBvcnRzLmlzVnVlVmlld01vZGVsID0gaXNWdWVWaWV3TW9kZWw7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1pcy5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/isBrowser.js":
/*!*******************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/isBrowser.js ***!
  \*******************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst node = __webpack_require__(/*! ./node.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/node.js\");\nconst worldwide = __webpack_require__(/*! ./worldwide.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/worldwide.js\");\n\n/**\n * Returns true if we are in the browser.\n */\nfunction isBrowser() {\n  // eslint-disable-next-line no-restricted-globals\n  return typeof window !== 'undefined' && (!node.isNodeEnv() || isElectronNodeRenderer());\n}\n\n// Electron renderers with nodeIntegration enabled are detected as Node.js so we specifically test for them\nfunction isElectronNodeRenderer() {\n  const process = (worldwide.GLOBAL_OBJ ).process;\n  return process?.type === 'renderer';\n}\n\nexports.isBrowser = isBrowser;\n//# sourceMappingURL=isBrowser.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9pc0Jyb3dzZXIuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsYUFBYSxtQkFBTyxDQUFDLG1IQUFXO0FBQ2hDLGtCQUFrQixtQkFBTyxDQUFDLDZIQUFnQjs7QUFFMUM7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSxpQkFBaUI7QUFDakIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9pc0Jyb3dzZXIuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IG5vZGUgPSByZXF1aXJlKCcuL25vZGUuanMnKTtcbmNvbnN0IHdvcmxkd2lkZSA9IHJlcXVpcmUoJy4vd29ybGR3aWRlLmpzJyk7XG5cbi8qKlxuICogUmV0dXJucyB0cnVlIGlmIHdlIGFyZSBpbiB0aGUgYnJvd3Nlci5cbiAqL1xuZnVuY3Rpb24gaXNCcm93c2VyKCkge1xuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgbm8tcmVzdHJpY3RlZC1nbG9iYWxzXG4gIHJldHVybiB0eXBlb2Ygd2luZG93ICE9PSAndW5kZWZpbmVkJyAmJiAoIW5vZGUuaXNOb2RlRW52KCkgfHwgaXNFbGVjdHJvbk5vZGVSZW5kZXJlcigpKTtcbn1cblxuLy8gRWxlY3Ryb24gcmVuZGVyZXJzIHdpdGggbm9kZUludGVncmF0aW9uIGVuYWJsZWQgYXJlIGRldGVjdGVkIGFzIE5vZGUuanMgc28gd2Ugc3BlY2lmaWNhbGx5IHRlc3QgZm9yIHRoZW1cbmZ1bmN0aW9uIGlzRWxlY3Ryb25Ob2RlUmVuZGVyZXIoKSB7XG4gIGNvbnN0IHByb2Nlc3MgPSAod29ybGR3aWRlLkdMT0JBTF9PQkogKS5wcm9jZXNzO1xuICByZXR1cm4gcHJvY2Vzcz8udHlwZSA9PT0gJ3JlbmRlcmVyJztcbn1cblxuZXhwb3J0cy5pc0Jyb3dzZXIgPSBpc0Jyb3dzZXI7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1pc0Jyb3dzZXIuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/isBrowser.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/isSentryRequestUrl.js":
/*!****************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/isSentryRequestUrl.js ***!
  \****************************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n/**\n * Checks whether given url points to Sentry server\n *\n * @param url url to verify\n */\nfunction isSentryRequestUrl(url, client) {\n  const dsn = client?.getDsn();\n  const tunnel = client?.getOptions().tunnel;\n  return checkDsn(url, dsn) || checkTunnel(url, tunnel);\n}\n\nfunction checkTunnel(url, tunnel) {\n  if (!tunnel) {\n    return false;\n  }\n\n  return removeTrailingSlash(url) === removeTrailingSlash(tunnel);\n}\n\nfunction checkDsn(url, dsn) {\n  return dsn ? url.includes(dsn.host) : false;\n}\n\nfunction removeTrailingSlash(str) {\n  return str[str.length - 1] === '/' ? str.slice(0, -1) : str;\n}\n\nexports.isSentryRequestUrl = isSentryRequestUrl;\n//# sourceMappingURL=isSentryRequestUrl.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9pc1NlbnRyeVJlcXVlc3RVcmwuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEU7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBLDBCQUEwQjtBQUMxQiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3V0aWxzL2lzU2VudHJ5UmVxdWVzdFVybC5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuLyoqXG4gKiBDaGVja3Mgd2hldGhlciBnaXZlbiB1cmwgcG9pbnRzIHRvIFNlbnRyeSBzZXJ2ZXJcbiAqXG4gKiBAcGFyYW0gdXJsIHVybCB0byB2ZXJpZnlcbiAqL1xuZnVuY3Rpb24gaXNTZW50cnlSZXF1ZXN0VXJsKHVybCwgY2xpZW50KSB7XG4gIGNvbnN0IGRzbiA9IGNsaWVudD8uZ2V0RHNuKCk7XG4gIGNvbnN0IHR1bm5lbCA9IGNsaWVudD8uZ2V0T3B0aW9ucygpLnR1bm5lbDtcbiAgcmV0dXJuIGNoZWNrRHNuKHVybCwgZHNuKSB8fCBjaGVja1R1bm5lbCh1cmwsIHR1bm5lbCk7XG59XG5cbmZ1bmN0aW9uIGNoZWNrVHVubmVsKHVybCwgdHVubmVsKSB7XG4gIGlmICghdHVubmVsKSB7XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG5cbiAgcmV0dXJuIHJlbW92ZVRyYWlsaW5nU2xhc2godXJsKSA9PT0gcmVtb3ZlVHJhaWxpbmdTbGFzaCh0dW5uZWwpO1xufVxuXG5mdW5jdGlvbiBjaGVja0Rzbih1cmwsIGRzbikge1xuICByZXR1cm4gZHNuID8gdXJsLmluY2x1ZGVzKGRzbi5ob3N0KSA6IGZhbHNlO1xufVxuXG5mdW5jdGlvbiByZW1vdmVUcmFpbGluZ1NsYXNoKHN0cikge1xuICByZXR1cm4gc3RyW3N0ci5sZW5ndGggLSAxXSA9PT0gJy8nID8gc3RyLnNsaWNlKDAsIC0xKSA6IHN0cjtcbn1cblxuZXhwb3J0cy5pc1NlbnRyeVJlcXVlc3RVcmwgPSBpc1NlbnRyeVJlcXVlc3RVcmw7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1pc1NlbnRyeVJlcXVlc3RVcmwuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/isSentryRequestUrl.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/lru.js":
/*!*************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/lru.js ***!
  \*************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n/** A simple Least Recently Used map */\nclass LRUMap {\n\n   constructor(  _maxSize) {this._maxSize = _maxSize;\n    this._cache = new Map();\n  }\n\n  /** Get the current size of the cache */\n   get size() {\n    return this._cache.size;\n  }\n\n  /** Get an entry or undefined if it was not in the cache. Re-inserts to update the recently used order */\n   get(key) {\n    const value = this._cache.get(key);\n    if (value === undefined) {\n      return undefined;\n    }\n    // Remove and re-insert to update the order\n    this._cache.delete(key);\n    this._cache.set(key, value);\n    return value;\n  }\n\n  /** Insert an entry and evict an older entry if we've reached maxSize */\n   set(key, value) {\n    if (this._cache.size >= this._maxSize) {\n      // keys() returns an iterator in insertion order so keys().next() gives us the oldest key\n      this._cache.delete(this._cache.keys().next().value);\n    }\n    this._cache.set(key, value);\n  }\n\n  /** Remove an entry and return the entry if it was in the cache */\n   remove(key) {\n    const value = this._cache.get(key);\n    if (value) {\n      this._cache.delete(key);\n    }\n    return value;\n  }\n\n  /** Clear all entries */\n   clear() {\n    this._cache.clear();\n  }\n\n  /** Get all the keys */\n   keys() {\n    return Array.from(this._cache.keys());\n  }\n\n  /** Get all the values */\n   values() {\n    const values = [];\n    this._cache.forEach(value => values.push(value));\n    return values;\n  }\n}\n\nexports.LRUMap = LRUMap;\n//# sourceMappingURL=lru.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9scnUuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEU7QUFDQTs7QUFFQSw0QkFBNEI7QUFDNUI7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSxjQUFjO0FBQ2QiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9scnUuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbi8qKiBBIHNpbXBsZSBMZWFzdCBSZWNlbnRseSBVc2VkIG1hcCAqL1xuY2xhc3MgTFJVTWFwIHtcblxuICAgY29uc3RydWN0b3IoICBfbWF4U2l6ZSkge3RoaXMuX21heFNpemUgPSBfbWF4U2l6ZTtcbiAgICB0aGlzLl9jYWNoZSA9IG5ldyBNYXAoKTtcbiAgfVxuXG4gIC8qKiBHZXQgdGhlIGN1cnJlbnQgc2l6ZSBvZiB0aGUgY2FjaGUgKi9cbiAgIGdldCBzaXplKCkge1xuICAgIHJldHVybiB0aGlzLl9jYWNoZS5zaXplO1xuICB9XG5cbiAgLyoqIEdldCBhbiBlbnRyeSBvciB1bmRlZmluZWQgaWYgaXQgd2FzIG5vdCBpbiB0aGUgY2FjaGUuIFJlLWluc2VydHMgdG8gdXBkYXRlIHRoZSByZWNlbnRseSB1c2VkIG9yZGVyICovXG4gICBnZXQoa2V5KSB7XG4gICAgY29uc3QgdmFsdWUgPSB0aGlzLl9jYWNoZS5nZXQoa2V5KTtcbiAgICBpZiAodmFsdWUgPT09IHVuZGVmaW5lZCkge1xuICAgICAgcmV0dXJuIHVuZGVmaW5lZDtcbiAgICB9XG4gICAgLy8gUmVtb3ZlIGFuZCByZS1pbnNlcnQgdG8gdXBkYXRlIHRoZSBvcmRlclxuICAgIHRoaXMuX2NhY2hlLmRlbGV0ZShrZXkpO1xuICAgIHRoaXMuX2NhY2hlLnNldChrZXksIHZhbHVlKTtcbiAgICByZXR1cm4gdmFsdWU7XG4gIH1cblxuICAvKiogSW5zZXJ0IGFuIGVudHJ5IGFuZCBldmljdCBhbiBvbGRlciBlbnRyeSBpZiB3ZSd2ZSByZWFjaGVkIG1heFNpemUgKi9cbiAgIHNldChrZXksIHZhbHVlKSB7XG4gICAgaWYgKHRoaXMuX2NhY2hlLnNpemUgPj0gdGhpcy5fbWF4U2l6ZSkge1xuICAgICAgLy8ga2V5cygpIHJldHVybnMgYW4gaXRlcmF0b3IgaW4gaW5zZXJ0aW9uIG9yZGVyIHNvIGtleXMoKS5uZXh0KCkgZ2l2ZXMgdXMgdGhlIG9sZGVzdCBrZXlcbiAgICAgIHRoaXMuX2NhY2hlLmRlbGV0ZSh0aGlzLl9jYWNoZS5rZXlzKCkubmV4dCgpLnZhbHVlKTtcbiAgICB9XG4gICAgdGhpcy5fY2FjaGUuc2V0KGtleSwgdmFsdWUpO1xuICB9XG5cbiAgLyoqIFJlbW92ZSBhbiBlbnRyeSBhbmQgcmV0dXJuIHRoZSBlbnRyeSBpZiBpdCB3YXMgaW4gdGhlIGNhY2hlICovXG4gICByZW1vdmUoa2V5KSB7XG4gICAgY29uc3QgdmFsdWUgPSB0aGlzLl9jYWNoZS5nZXQoa2V5KTtcbiAgICBpZiAodmFsdWUpIHtcbiAgICAgIHRoaXMuX2NhY2hlLmRlbGV0ZShrZXkpO1xuICAgIH1cbiAgICByZXR1cm4gdmFsdWU7XG4gIH1cblxuICAvKiogQ2xlYXIgYWxsIGVudHJpZXMgKi9cbiAgIGNsZWFyKCkge1xuICAgIHRoaXMuX2NhY2hlLmNsZWFyKCk7XG4gIH1cblxuICAvKiogR2V0IGFsbCB0aGUga2V5cyAqL1xuICAga2V5cygpIHtcbiAgICByZXR1cm4gQXJyYXkuZnJvbSh0aGlzLl9jYWNoZS5rZXlzKCkpO1xuICB9XG5cbiAgLyoqIEdldCBhbGwgdGhlIHZhbHVlcyAqL1xuICAgdmFsdWVzKCkge1xuICAgIGNvbnN0IHZhbHVlcyA9IFtdO1xuICAgIHRoaXMuX2NhY2hlLmZvckVhY2godmFsdWUgPT4gdmFsdWVzLnB1c2godmFsdWUpKTtcbiAgICByZXR1cm4gdmFsdWVzO1xuICB9XG59XG5cbmV4cG9ydHMuTFJVTWFwID0gTFJVTWFwO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9bHJ1LmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/lru.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/merge.js":
/*!***************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/merge.js ***!
  \***************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n/**\n * Shallow merge two objects.\n * Does not mutate the passed in objects.\n * Undefined/empty values in the merge object will overwrite existing values.\n *\n * By default, this merges 2 levels deep.\n */\nfunction merge(initialObj, mergeObj, levels = 2) {\n  // If the merge value is not an object, or we have no merge levels left,\n  // we just set the value to the merge value\n  if (!mergeObj || typeof mergeObj !== 'object' || levels <= 0) {\n    return mergeObj;\n  }\n\n  // If the merge object is an empty object, and the initial object is not undefined, we return the initial object\n  if (initialObj && Object.keys(mergeObj).length === 0) {\n    return initialObj;\n  }\n\n  // Clone object\n  const output = { ...initialObj };\n\n  // Merge values into output, resursively\n  for (const key in mergeObj) {\n    if (Object.prototype.hasOwnProperty.call(mergeObj, key)) {\n      output[key] = merge(output[key], mergeObj[key], levels - 1);\n    }\n  }\n\n  return output;\n}\n\nexports.merge = merge;\n//# sourceMappingURL=merge.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9tZXJnZS5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBLG1CQUFtQjs7QUFFbkI7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUEsYUFBYTtBQUNiIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvbWVyZ2UuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbi8qKlxuICogU2hhbGxvdyBtZXJnZSB0d28gb2JqZWN0cy5cbiAqIERvZXMgbm90IG11dGF0ZSB0aGUgcGFzc2VkIGluIG9iamVjdHMuXG4gKiBVbmRlZmluZWQvZW1wdHkgdmFsdWVzIGluIHRoZSBtZXJnZSBvYmplY3Qgd2lsbCBvdmVyd3JpdGUgZXhpc3RpbmcgdmFsdWVzLlxuICpcbiAqIEJ5IGRlZmF1bHQsIHRoaXMgbWVyZ2VzIDIgbGV2ZWxzIGRlZXAuXG4gKi9cbmZ1bmN0aW9uIG1lcmdlKGluaXRpYWxPYmosIG1lcmdlT2JqLCBsZXZlbHMgPSAyKSB7XG4gIC8vIElmIHRoZSBtZXJnZSB2YWx1ZSBpcyBub3QgYW4gb2JqZWN0LCBvciB3ZSBoYXZlIG5vIG1lcmdlIGxldmVscyBsZWZ0LFxuICAvLyB3ZSBqdXN0IHNldCB0aGUgdmFsdWUgdG8gdGhlIG1lcmdlIHZhbHVlXG4gIGlmICghbWVyZ2VPYmogfHwgdHlwZW9mIG1lcmdlT2JqICE9PSAnb2JqZWN0JyB8fCBsZXZlbHMgPD0gMCkge1xuICAgIHJldHVybiBtZXJnZU9iajtcbiAgfVxuXG4gIC8vIElmIHRoZSBtZXJnZSBvYmplY3QgaXMgYW4gZW1wdHkgb2JqZWN0LCBhbmQgdGhlIGluaXRpYWwgb2JqZWN0IGlzIG5vdCB1bmRlZmluZWQsIHdlIHJldHVybiB0aGUgaW5pdGlhbCBvYmplY3RcbiAgaWYgKGluaXRpYWxPYmogJiYgT2JqZWN0LmtleXMobWVyZ2VPYmopLmxlbmd0aCA9PT0gMCkge1xuICAgIHJldHVybiBpbml0aWFsT2JqO1xuICB9XG5cbiAgLy8gQ2xvbmUgb2JqZWN0XG4gIGNvbnN0IG91dHB1dCA9IHsgLi4uaW5pdGlhbE9iaiB9O1xuXG4gIC8vIE1lcmdlIHZhbHVlcyBpbnRvIG91dHB1dCwgcmVzdXJzaXZlbHlcbiAgZm9yIChjb25zdCBrZXkgaW4gbWVyZ2VPYmopIHtcbiAgICBpZiAoT2JqZWN0LnByb3RvdHlwZS5oYXNPd25Qcm9wZXJ0eS5jYWxsKG1lcmdlT2JqLCBrZXkpKSB7XG4gICAgICBvdXRwdXRba2V5XSA9IG1lcmdlKG91dHB1dFtrZXldLCBtZXJnZU9ialtrZXldLCBsZXZlbHMgLSAxKTtcbiAgICB9XG4gIH1cblxuICByZXR1cm4gb3V0cHV0O1xufVxuXG5leHBvcnRzLm1lcmdlID0gbWVyZ2U7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1tZXJnZS5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/merge.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/meta.js":
/*!**************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/meta.js ***!
  \**************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst traceData = __webpack_require__(/*! ./traceData.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/traceData.js\");\n\n/**\n * Returns a string of meta tags that represent the current trace data.\n *\n * You can use this to propagate a trace from your server-side rendered Html to the browser.\n * This function returns up to two meta tags, `sentry-trace` and `baggage`, depending on the\n * current trace data state.\n *\n * @example\n * Usage example:\n *\n * ```js\n * function renderHtml() {\n *   return `\n *     <head>\n *       ${getTraceMetaTags()}\n *     </head>\n *   `;\n * }\n * ```\n *\n */\nfunction getTraceMetaTags(traceData$1) {\n  return Object.entries(traceData$1 || traceData.getTraceData())\n    .map(([key, value]) => `<meta name=\"${key}\" content=\"${value}\"/>`)\n    .join('\\n');\n}\n\nexports.getTraceMetaTags = getTraceMetaTags;\n//# sourceMappingURL=meta.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9tZXRhLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLGtCQUFrQixtQkFBTyxDQUFDLDZIQUFnQjs7QUFFMUM7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFdBQVc7QUFDWDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsMENBQTBDLElBQUksYUFBYSxNQUFNO0FBQ2pFO0FBQ0E7O0FBRUEsd0JBQXdCO0FBQ3hCIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvbWV0YS5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgdHJhY2VEYXRhID0gcmVxdWlyZSgnLi90cmFjZURhdGEuanMnKTtcblxuLyoqXG4gKiBSZXR1cm5zIGEgc3RyaW5nIG9mIG1ldGEgdGFncyB0aGF0IHJlcHJlc2VudCB0aGUgY3VycmVudCB0cmFjZSBkYXRhLlxuICpcbiAqIFlvdSBjYW4gdXNlIHRoaXMgdG8gcHJvcGFnYXRlIGEgdHJhY2UgZnJvbSB5b3VyIHNlcnZlci1zaWRlIHJlbmRlcmVkIEh0bWwgdG8gdGhlIGJyb3dzZXIuXG4gKiBUaGlzIGZ1bmN0aW9uIHJldHVybnMgdXAgdG8gdHdvIG1ldGEgdGFncywgYHNlbnRyeS10cmFjZWAgYW5kIGBiYWdnYWdlYCwgZGVwZW5kaW5nIG9uIHRoZVxuICogY3VycmVudCB0cmFjZSBkYXRhIHN0YXRlLlxuICpcbiAqIEBleGFtcGxlXG4gKiBVc2FnZSBleGFtcGxlOlxuICpcbiAqIGBgYGpzXG4gKiBmdW5jdGlvbiByZW5kZXJIdG1sKCkge1xuICogICByZXR1cm4gYFxuICogICAgIDxoZWFkPlxuICogICAgICAgJHtnZXRUcmFjZU1ldGFUYWdzKCl9XG4gKiAgICAgPC9oZWFkPlxuICogICBgO1xuICogfVxuICogYGBgXG4gKlxuICovXG5mdW5jdGlvbiBnZXRUcmFjZU1ldGFUYWdzKHRyYWNlRGF0YSQxKSB7XG4gIHJldHVybiBPYmplY3QuZW50cmllcyh0cmFjZURhdGEkMSB8fCB0cmFjZURhdGEuZ2V0VHJhY2VEYXRhKCkpXG4gICAgLm1hcCgoW2tleSwgdmFsdWVdKSA9PiBgPG1ldGEgbmFtZT1cIiR7a2V5fVwiIGNvbnRlbnQ9XCIke3ZhbHVlfVwiLz5gKVxuICAgIC5qb2luKCdcXG4nKTtcbn1cblxuZXhwb3J0cy5nZXRUcmFjZU1ldGFUYWdzID0gZ2V0VHJhY2VNZXRhVGFncztcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPW1ldGEuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/meta.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/misc.js":
/*!**************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/misc.js ***!
  \**************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst object = __webpack_require__(/*! ./object.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/object.js\");\nconst string = __webpack_require__(/*! ./string.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/string.js\");\nconst worldwide = __webpack_require__(/*! ./worldwide.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/worldwide.js\");\n\nfunction getCrypto() {\n  const gbl = worldwide.GLOBAL_OBJ ;\n  return gbl.crypto || gbl.msCrypto;\n}\n\n/**\n * UUID4 generator\n * @param crypto Object that provides the crypto API.\n * @returns string Generated UUID4.\n */\nfunction uuid4(crypto = getCrypto()) {\n  let getRandomByte = () => Math.random() * 16;\n  try {\n    if (crypto?.randomUUID) {\n      return crypto.randomUUID().replace(/-/g, '');\n    }\n    if (crypto?.getRandomValues) {\n      getRandomByte = () => {\n        // crypto.getRandomValues might return undefined instead of the typed array\n        // in old Chromium versions (e.g. 23.0.1235.0 (151422))\n        // However, `typedArray` is still filled in-place.\n        // @see https://developer.mozilla.org/en-US/docs/Web/API/Crypto/getRandomValues#typedarray\n        const typedArray = new Uint8Array(1);\n        crypto.getRandomValues(typedArray);\n        // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n        return typedArray[0];\n      };\n    }\n  } catch {\n    // some runtimes can crash invoking crypto\n    // https://github.com/getsentry/sentry-javascript/issues/8935\n  }\n\n  // http://stackoverflow.com/questions/105034/how-to-create-a-guid-uuid-in-javascript/2117523#2117523\n  // Concatenating the following numbers as strings results in '10000000100040008000100000000000'\n  return (([1e7] ) + 1e3 + 4e3 + 8e3 + 1e11).replace(/[018]/g, c =>\n    // eslint-disable-next-line no-bitwise\n    ((c ) ^ ((getRandomByte() & 15) >> ((c ) / 4))).toString(16),\n  );\n}\n\nfunction getFirstException(event) {\n  return event.exception?.values?.[0];\n}\n\n/**\n * Extracts either message or type+value from an event that can be used for user-facing logs\n * @returns event's description\n */\nfunction getEventDescription(event) {\n  const { message, event_id: eventId } = event;\n  if (message) {\n    return message;\n  }\n\n  const firstException = getFirstException(event);\n  if (firstException) {\n    if (firstException.type && firstException.value) {\n      return `${firstException.type}: ${firstException.value}`;\n    }\n    return firstException.type || firstException.value || eventId || '<unknown>';\n  }\n  return eventId || '<unknown>';\n}\n\n/**\n * Adds exception values, type and value to an synthetic Exception.\n * @param event The event to modify.\n * @param value Value of the exception.\n * @param type Type of the exception.\n * @hidden\n */\nfunction addExceptionTypeValue(event, value, type) {\n  const exception = (event.exception = event.exception || {});\n  const values = (exception.values = exception.values || []);\n  const firstException = (values[0] = values[0] || {});\n  if (!firstException.value) {\n    firstException.value = value || '';\n  }\n  if (!firstException.type) {\n    firstException.type = type || 'Error';\n  }\n}\n\n/**\n * Adds exception mechanism data to a given event. Uses defaults if the second parameter is not passed.\n *\n * @param event The event to modify.\n * @param newMechanism Mechanism data to add to the event.\n * @hidden\n */\nfunction addExceptionMechanism(event, newMechanism) {\n  const firstException = getFirstException(event);\n  if (!firstException) {\n    return;\n  }\n\n  const defaultMechanism = { type: 'generic', handled: true };\n  const currentMechanism = firstException.mechanism;\n  firstException.mechanism = { ...defaultMechanism, ...currentMechanism, ...newMechanism };\n\n  if (newMechanism && 'data' in newMechanism) {\n    const mergedData = { ...currentMechanism?.data, ...newMechanism.data };\n    firstException.mechanism.data = mergedData;\n  }\n}\n\n// https://semver.org/#is-there-a-suggested-regular-expression-regex-to-check-a-semver-string\nconst SEMVER_REGEXP =\n  /^(0|[1-9]\\d*)\\.(0|[1-9]\\d*)\\.(0|[1-9]\\d*)(?:-((?:0|[1-9]\\d*|\\d*[a-zA-Z-][0-9a-zA-Z-]*)(?:\\.(?:0|[1-9]\\d*|\\d*[a-zA-Z-][0-9a-zA-Z-]*))*))?(?:\\+([0-9a-zA-Z-]+(?:\\.[0-9a-zA-Z-]+)*))?$/;\n\n/**\n * Represents Semantic Versioning object\n */\n\nfunction _parseInt(input) {\n  return parseInt(input || '', 10);\n}\n\n/**\n * Parses input into a SemVer interface\n * @param input string representation of a semver version\n */\nfunction parseSemver(input) {\n  const match = input.match(SEMVER_REGEXP) || [];\n  const major = _parseInt(match[1]);\n  const minor = _parseInt(match[2]);\n  const patch = _parseInt(match[3]);\n  return {\n    buildmetadata: match[5],\n    major: isNaN(major) ? undefined : major,\n    minor: isNaN(minor) ? undefined : minor,\n    patch: isNaN(patch) ? undefined : patch,\n    prerelease: match[4],\n  };\n}\n\n/**\n * This function adds context (pre/post/line) lines to the provided frame\n *\n * @param lines string[] containing all lines\n * @param frame StackFrame that will be mutated\n * @param linesOfContext number of context lines we want to add pre/post\n */\nfunction addContextToFrame(lines, frame, linesOfContext = 5) {\n  // When there is no line number in the frame, attaching context is nonsensical and will even break grouping\n  if (frame.lineno === undefined) {\n    return;\n  }\n\n  const maxLines = lines.length;\n  const sourceLine = Math.max(Math.min(maxLines - 1, frame.lineno - 1), 0);\n\n  frame.pre_context = lines\n    .slice(Math.max(0, sourceLine - linesOfContext), sourceLine)\n    .map((line) => string.snipLine(line, 0));\n\n  // We guard here to ensure this is not larger than the existing number of lines\n  const lineIndex = Math.min(maxLines - 1, sourceLine);\n\n  // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n  frame.context_line = string.snipLine(lines[lineIndex], frame.colno || 0);\n\n  frame.post_context = lines\n    .slice(Math.min(sourceLine + 1, maxLines), sourceLine + 1 + linesOfContext)\n    .map((line) => string.snipLine(line, 0));\n}\n\n/**\n * Checks whether or not we've already captured the given exception (note: not an identical exception - the very object\n * in question), and marks it captured if not.\n *\n * This is useful because it's possible for an error to get captured by more than one mechanism. After we intercept and\n * record an error, we rethrow it (assuming we've intercepted it before it's reached the top-level global handlers), so\n * that we don't interfere with whatever effects the error might have had were the SDK not there. At that point, because\n * the error has been rethrown, it's possible for it to bubble up to some other code we've instrumented. If it's not\n * caught after that, it will bubble all the way up to the global handlers (which of course we also instrument). This\n * function helps us ensure that even if we encounter the same error more than once, we only record it the first time we\n * see it.\n *\n * Note: It will ignore primitives (always return `false` and not mark them as seen), as properties can't be set on\n * them. {@link: Object.objectify} can be used on exceptions to convert any that are primitives into their equivalent\n * object wrapper forms so that this check will always work. However, because we need to flag the exact object which\n * will get rethrown, and because that rethrowing happens outside of the event processing pipeline, the objectification\n * must be done before the exception captured.\n *\n * @param A thrown exception to check or flag as having been seen\n * @returns `true` if the exception has already been captured, `false` if not (with the side effect of marking it seen)\n */\nfunction checkOrSetAlreadyCaught(exception) {\n  if (isAlreadyCaptured(exception)) {\n    return true;\n  }\n\n  try {\n    // set it this way rather than by assignment so that it's not ennumerable and therefore isn't recorded by the\n    // `ExtraErrorData` integration\n    object.addNonEnumerableProperty(exception , '__sentry_captured__', true);\n  } catch {\n    // `exception` is a primitive, so we can't mark it seen\n  }\n\n  return false;\n}\n\nfunction isAlreadyCaptured(exception) {\n  try {\n    return (exception ).__sentry_captured__;\n  } catch {} // eslint-disable-line no-empty\n}\n\nexports.addContextToFrame = addContextToFrame;\nexports.addExceptionMechanism = addExceptionMechanism;\nexports.addExceptionTypeValue = addExceptionTypeValue;\nexports.checkOrSetAlreadyCaught = checkOrSetAlreadyCaught;\nexports.getEventDescription = getEventDescription;\nexports.parseSemver = parseSemver;\nexports.uuid4 = uuid4;\n//# sourceMappingURL=misc.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9taXNjLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLGVBQWUsbUJBQU8sQ0FBQyx1SEFBYTtBQUNwQyxlQUFlLG1CQUFPLENBQUMsdUhBQWE7QUFDcEMsa0JBQWtCLG1CQUFPLENBQUMsNkhBQWdCOztBQUUxQztBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsSUFBSTtBQUNKO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFVBQVUsNkJBQTZCO0FBQ3ZDO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQSxnQkFBZ0Isb0JBQW9CLElBQUkscUJBQXFCO0FBQzdEO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLDREQUE0RDtBQUM1RDtBQUNBLHFEQUFxRDtBQUNyRDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsNkJBQTZCO0FBQzdCO0FBQ0EsK0JBQStCOztBQUUvQjtBQUNBLHlCQUF5QjtBQUN6QjtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsVUFBVSx5QkFBeUI7QUFDbkM7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLElBQUk7QUFDSjtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0EsSUFBSSxTQUFTO0FBQ2I7O0FBRUEseUJBQXlCO0FBQ3pCLDZCQUE2QjtBQUM3Qiw2QkFBNkI7QUFDN0IsK0JBQStCO0FBQy9CLDJCQUEyQjtBQUMzQixtQkFBbUI7QUFDbkIsYUFBYTtBQUNiIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvbWlzYy5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3Qgb2JqZWN0ID0gcmVxdWlyZSgnLi9vYmplY3QuanMnKTtcbmNvbnN0IHN0cmluZyA9IHJlcXVpcmUoJy4vc3RyaW5nLmpzJyk7XG5jb25zdCB3b3JsZHdpZGUgPSByZXF1aXJlKCcuL3dvcmxkd2lkZS5qcycpO1xuXG5mdW5jdGlvbiBnZXRDcnlwdG8oKSB7XG4gIGNvbnN0IGdibCA9IHdvcmxkd2lkZS5HTE9CQUxfT0JKIDtcbiAgcmV0dXJuIGdibC5jcnlwdG8gfHwgZ2JsLm1zQ3J5cHRvO1xufVxuXG4vKipcbiAqIFVVSUQ0IGdlbmVyYXRvclxuICogQHBhcmFtIGNyeXB0byBPYmplY3QgdGhhdCBwcm92aWRlcyB0aGUgY3J5cHRvIEFQSS5cbiAqIEByZXR1cm5zIHN0cmluZyBHZW5lcmF0ZWQgVVVJRDQuXG4gKi9cbmZ1bmN0aW9uIHV1aWQ0KGNyeXB0byA9IGdldENyeXB0bygpKSB7XG4gIGxldCBnZXRSYW5kb21CeXRlID0gKCkgPT4gTWF0aC5yYW5kb20oKSAqIDE2O1xuICB0cnkge1xuICAgIGlmIChjcnlwdG8/LnJhbmRvbVVVSUQpIHtcbiAgICAgIHJldHVybiBjcnlwdG8ucmFuZG9tVVVJRCgpLnJlcGxhY2UoLy0vZywgJycpO1xuICAgIH1cbiAgICBpZiAoY3J5cHRvPy5nZXRSYW5kb21WYWx1ZXMpIHtcbiAgICAgIGdldFJhbmRvbUJ5dGUgPSAoKSA9PiB7XG4gICAgICAgIC8vIGNyeXB0by5nZXRSYW5kb21WYWx1ZXMgbWlnaHQgcmV0dXJuIHVuZGVmaW5lZCBpbnN0ZWFkIG9mIHRoZSB0eXBlZCBhcnJheVxuICAgICAgICAvLyBpbiBvbGQgQ2hyb21pdW0gdmVyc2lvbnMgKGUuZy4gMjMuMC4xMjM1LjAgKDE1MTQyMikpXG4gICAgICAgIC8vIEhvd2V2ZXIsIGB0eXBlZEFycmF5YCBpcyBzdGlsbCBmaWxsZWQgaW4tcGxhY2UuXG4gICAgICAgIC8vIEBzZWUgaHR0cHM6Ly9kZXZlbG9wZXIubW96aWxsYS5vcmcvZW4tVVMvZG9jcy9XZWIvQVBJL0NyeXB0by9nZXRSYW5kb21WYWx1ZXMjdHlwZWRhcnJheVxuICAgICAgICBjb25zdCB0eXBlZEFycmF5ID0gbmV3IFVpbnQ4QXJyYXkoMSk7XG4gICAgICAgIGNyeXB0by5nZXRSYW5kb21WYWx1ZXModHlwZWRBcnJheSk7XG4gICAgICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tbm9uLW51bGwtYXNzZXJ0aW9uXG4gICAgICAgIHJldHVybiB0eXBlZEFycmF5WzBdO1xuICAgICAgfTtcbiAgICB9XG4gIH0gY2F0Y2gge1xuICAgIC8vIHNvbWUgcnVudGltZXMgY2FuIGNyYXNoIGludm9raW5nIGNyeXB0b1xuICAgIC8vIGh0dHBzOi8vZ2l0aHViLmNvbS9nZXRzZW50cnkvc2VudHJ5LWphdmFzY3JpcHQvaXNzdWVzLzg5MzVcbiAgfVxuXG4gIC8vIGh0dHA6Ly9zdGFja292ZXJmbG93LmNvbS9xdWVzdGlvbnMvMTA1MDM0L2hvdy10by1jcmVhdGUtYS1ndWlkLXV1aWQtaW4tamF2YXNjcmlwdC8yMTE3NTIzIzIxMTc1MjNcbiAgLy8gQ29uY2F0ZW5hdGluZyB0aGUgZm9sbG93aW5nIG51bWJlcnMgYXMgc3RyaW5ncyByZXN1bHRzIGluICcxMDAwMDAwMDEwMDA0MDAwODAwMDEwMDAwMDAwMDAwMCdcbiAgcmV0dXJuICgoWzFlN10gKSArIDFlMyArIDRlMyArIDhlMyArIDFlMTEpLnJlcGxhY2UoL1swMThdL2csIGMgPT5cbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgbm8tYml0d2lzZVxuICAgICgoYyApIF4gKChnZXRSYW5kb21CeXRlKCkgJiAxNSkgPj4gKChjICkgLyA0KSkpLnRvU3RyaW5nKDE2KSxcbiAgKTtcbn1cblxuZnVuY3Rpb24gZ2V0Rmlyc3RFeGNlcHRpb24oZXZlbnQpIHtcbiAgcmV0dXJuIGV2ZW50LmV4Y2VwdGlvbj8udmFsdWVzPy5bMF07XG59XG5cbi8qKlxuICogRXh0cmFjdHMgZWl0aGVyIG1lc3NhZ2Ugb3IgdHlwZSt2YWx1ZSBmcm9tIGFuIGV2ZW50IHRoYXQgY2FuIGJlIHVzZWQgZm9yIHVzZXItZmFjaW5nIGxvZ3NcbiAqIEByZXR1cm5zIGV2ZW50J3MgZGVzY3JpcHRpb25cbiAqL1xuZnVuY3Rpb24gZ2V0RXZlbnREZXNjcmlwdGlvbihldmVudCkge1xuICBjb25zdCB7IG1lc3NhZ2UsIGV2ZW50X2lkOiBldmVudElkIH0gPSBldmVudDtcbiAgaWYgKG1lc3NhZ2UpIHtcbiAgICByZXR1cm4gbWVzc2FnZTtcbiAgfVxuXG4gIGNvbnN0IGZpcnN0RXhjZXB0aW9uID0gZ2V0Rmlyc3RFeGNlcHRpb24oZXZlbnQpO1xuICBpZiAoZmlyc3RFeGNlcHRpb24pIHtcbiAgICBpZiAoZmlyc3RFeGNlcHRpb24udHlwZSAmJiBmaXJzdEV4Y2VwdGlvbi52YWx1ZSkge1xuICAgICAgcmV0dXJuIGAke2ZpcnN0RXhjZXB0aW9uLnR5cGV9OiAke2ZpcnN0RXhjZXB0aW9uLnZhbHVlfWA7XG4gICAgfVxuICAgIHJldHVybiBmaXJzdEV4Y2VwdGlvbi50eXBlIHx8IGZpcnN0RXhjZXB0aW9uLnZhbHVlIHx8IGV2ZW50SWQgfHwgJzx1bmtub3duPic7XG4gIH1cbiAgcmV0dXJuIGV2ZW50SWQgfHwgJzx1bmtub3duPic7XG59XG5cbi8qKlxuICogQWRkcyBleGNlcHRpb24gdmFsdWVzLCB0eXBlIGFuZCB2YWx1ZSB0byBhbiBzeW50aGV0aWMgRXhjZXB0aW9uLlxuICogQHBhcmFtIGV2ZW50IFRoZSBldmVudCB0byBtb2RpZnkuXG4gKiBAcGFyYW0gdmFsdWUgVmFsdWUgb2YgdGhlIGV4Y2VwdGlvbi5cbiAqIEBwYXJhbSB0eXBlIFR5cGUgb2YgdGhlIGV4Y2VwdGlvbi5cbiAqIEBoaWRkZW5cbiAqL1xuZnVuY3Rpb24gYWRkRXhjZXB0aW9uVHlwZVZhbHVlKGV2ZW50LCB2YWx1ZSwgdHlwZSkge1xuICBjb25zdCBleGNlcHRpb24gPSAoZXZlbnQuZXhjZXB0aW9uID0gZXZlbnQuZXhjZXB0aW9uIHx8IHt9KTtcbiAgY29uc3QgdmFsdWVzID0gKGV4Y2VwdGlvbi52YWx1ZXMgPSBleGNlcHRpb24udmFsdWVzIHx8IFtdKTtcbiAgY29uc3QgZmlyc3RFeGNlcHRpb24gPSAodmFsdWVzWzBdID0gdmFsdWVzWzBdIHx8IHt9KTtcbiAgaWYgKCFmaXJzdEV4Y2VwdGlvbi52YWx1ZSkge1xuICAgIGZpcnN0RXhjZXB0aW9uLnZhbHVlID0gdmFsdWUgfHwgJyc7XG4gIH1cbiAgaWYgKCFmaXJzdEV4Y2VwdGlvbi50eXBlKSB7XG4gICAgZmlyc3RFeGNlcHRpb24udHlwZSA9IHR5cGUgfHwgJ0Vycm9yJztcbiAgfVxufVxuXG4vKipcbiAqIEFkZHMgZXhjZXB0aW9uIG1lY2hhbmlzbSBkYXRhIHRvIGEgZ2l2ZW4gZXZlbnQuIFVzZXMgZGVmYXVsdHMgaWYgdGhlIHNlY29uZCBwYXJhbWV0ZXIgaXMgbm90IHBhc3NlZC5cbiAqXG4gKiBAcGFyYW0gZXZlbnQgVGhlIGV2ZW50IHRvIG1vZGlmeS5cbiAqIEBwYXJhbSBuZXdNZWNoYW5pc20gTWVjaGFuaXNtIGRhdGEgdG8gYWRkIHRvIHRoZSBldmVudC5cbiAqIEBoaWRkZW5cbiAqL1xuZnVuY3Rpb24gYWRkRXhjZXB0aW9uTWVjaGFuaXNtKGV2ZW50LCBuZXdNZWNoYW5pc20pIHtcbiAgY29uc3QgZmlyc3RFeGNlcHRpb24gPSBnZXRGaXJzdEV4Y2VwdGlvbihldmVudCk7XG4gIGlmICghZmlyc3RFeGNlcHRpb24pIHtcbiAgICByZXR1cm47XG4gIH1cblxuICBjb25zdCBkZWZhdWx0TWVjaGFuaXNtID0geyB0eXBlOiAnZ2VuZXJpYycsIGhhbmRsZWQ6IHRydWUgfTtcbiAgY29uc3QgY3VycmVudE1lY2hhbmlzbSA9IGZpcnN0RXhjZXB0aW9uLm1lY2hhbmlzbTtcbiAgZmlyc3RFeGNlcHRpb24ubWVjaGFuaXNtID0geyAuLi5kZWZhdWx0TWVjaGFuaXNtLCAuLi5jdXJyZW50TWVjaGFuaXNtLCAuLi5uZXdNZWNoYW5pc20gfTtcblxuICBpZiAobmV3TWVjaGFuaXNtICYmICdkYXRhJyBpbiBuZXdNZWNoYW5pc20pIHtcbiAgICBjb25zdCBtZXJnZWREYXRhID0geyAuLi5jdXJyZW50TWVjaGFuaXNtPy5kYXRhLCAuLi5uZXdNZWNoYW5pc20uZGF0YSB9O1xuICAgIGZpcnN0RXhjZXB0aW9uLm1lY2hhbmlzbS5kYXRhID0gbWVyZ2VkRGF0YTtcbiAgfVxufVxuXG4vLyBodHRwczovL3NlbXZlci5vcmcvI2lzLXRoZXJlLWEtc3VnZ2VzdGVkLXJlZ3VsYXItZXhwcmVzc2lvbi1yZWdleC10by1jaGVjay1hLXNlbXZlci1zdHJpbmdcbmNvbnN0IFNFTVZFUl9SRUdFWFAgPVxuICAvXigwfFsxLTldXFxkKilcXC4oMHxbMS05XVxcZCopXFwuKDB8WzEtOV1cXGQqKSg/Oi0oKD86MHxbMS05XVxcZCp8XFxkKlthLXpBLVotXVswLTlhLXpBLVotXSopKD86XFwuKD86MHxbMS05XVxcZCp8XFxkKlthLXpBLVotXVswLTlhLXpBLVotXSopKSopKT8oPzpcXCsoWzAtOWEtekEtWi1dKyg/OlxcLlswLTlhLXpBLVotXSspKikpPyQvO1xuXG4vKipcbiAqIFJlcHJlc2VudHMgU2VtYW50aWMgVmVyc2lvbmluZyBvYmplY3RcbiAqL1xuXG5mdW5jdGlvbiBfcGFyc2VJbnQoaW5wdXQpIHtcbiAgcmV0dXJuIHBhcnNlSW50KGlucHV0IHx8ICcnLCAxMCk7XG59XG5cbi8qKlxuICogUGFyc2VzIGlucHV0IGludG8gYSBTZW1WZXIgaW50ZXJmYWNlXG4gKiBAcGFyYW0gaW5wdXQgc3RyaW5nIHJlcHJlc2VudGF0aW9uIG9mIGEgc2VtdmVyIHZlcnNpb25cbiAqL1xuZnVuY3Rpb24gcGFyc2VTZW12ZXIoaW5wdXQpIHtcbiAgY29uc3QgbWF0Y2ggPSBpbnB1dC5tYXRjaChTRU1WRVJfUkVHRVhQKSB8fCBbXTtcbiAgY29uc3QgbWFqb3IgPSBfcGFyc2VJbnQobWF0Y2hbMV0pO1xuICBjb25zdCBtaW5vciA9IF9wYXJzZUludChtYXRjaFsyXSk7XG4gIGNvbnN0IHBhdGNoID0gX3BhcnNlSW50KG1hdGNoWzNdKTtcbiAgcmV0dXJuIHtcbiAgICBidWlsZG1ldGFkYXRhOiBtYXRjaFs1XSxcbiAgICBtYWpvcjogaXNOYU4obWFqb3IpID8gdW5kZWZpbmVkIDogbWFqb3IsXG4gICAgbWlub3I6IGlzTmFOKG1pbm9yKSA/IHVuZGVmaW5lZCA6IG1pbm9yLFxuICAgIHBhdGNoOiBpc05hTihwYXRjaCkgPyB1bmRlZmluZWQgOiBwYXRjaCxcbiAgICBwcmVyZWxlYXNlOiBtYXRjaFs0XSxcbiAgfTtcbn1cblxuLyoqXG4gKiBUaGlzIGZ1bmN0aW9uIGFkZHMgY29udGV4dCAocHJlL3Bvc3QvbGluZSkgbGluZXMgdG8gdGhlIHByb3ZpZGVkIGZyYW1lXG4gKlxuICogQHBhcmFtIGxpbmVzIHN0cmluZ1tdIGNvbnRhaW5pbmcgYWxsIGxpbmVzXG4gKiBAcGFyYW0gZnJhbWUgU3RhY2tGcmFtZSB0aGF0IHdpbGwgYmUgbXV0YXRlZFxuICogQHBhcmFtIGxpbmVzT2ZDb250ZXh0IG51bWJlciBvZiBjb250ZXh0IGxpbmVzIHdlIHdhbnQgdG8gYWRkIHByZS9wb3N0XG4gKi9cbmZ1bmN0aW9uIGFkZENvbnRleHRUb0ZyYW1lKGxpbmVzLCBmcmFtZSwgbGluZXNPZkNvbnRleHQgPSA1KSB7XG4gIC8vIFdoZW4gdGhlcmUgaXMgbm8gbGluZSBudW1iZXIgaW4gdGhlIGZyYW1lLCBhdHRhY2hpbmcgY29udGV4dCBpcyBub25zZW5zaWNhbCBhbmQgd2lsbCBldmVuIGJyZWFrIGdyb3VwaW5nXG4gIGlmIChmcmFtZS5saW5lbm8gPT09IHVuZGVmaW5lZCkge1xuICAgIHJldHVybjtcbiAgfVxuXG4gIGNvbnN0IG1heExpbmVzID0gbGluZXMubGVuZ3RoO1xuICBjb25zdCBzb3VyY2VMaW5lID0gTWF0aC5tYXgoTWF0aC5taW4obWF4TGluZXMgLSAxLCBmcmFtZS5saW5lbm8gLSAxKSwgMCk7XG5cbiAgZnJhbWUucHJlX2NvbnRleHQgPSBsaW5lc1xuICAgIC5zbGljZShNYXRoLm1heCgwLCBzb3VyY2VMaW5lIC0gbGluZXNPZkNvbnRleHQpLCBzb3VyY2VMaW5lKVxuICAgIC5tYXAoKGxpbmUpID0+IHN0cmluZy5zbmlwTGluZShsaW5lLCAwKSk7XG5cbiAgLy8gV2UgZ3VhcmQgaGVyZSB0byBlbnN1cmUgdGhpcyBpcyBub3QgbGFyZ2VyIHRoYW4gdGhlIGV4aXN0aW5nIG51bWJlciBvZiBsaW5lc1xuICBjb25zdCBsaW5lSW5kZXggPSBNYXRoLm1pbihtYXhMaW5lcyAtIDEsIHNvdXJjZUxpbmUpO1xuXG4gIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tbm9uLW51bGwtYXNzZXJ0aW9uXG4gIGZyYW1lLmNvbnRleHRfbGluZSA9IHN0cmluZy5zbmlwTGluZShsaW5lc1tsaW5lSW5kZXhdLCBmcmFtZS5jb2xubyB8fCAwKTtcblxuICBmcmFtZS5wb3N0X2NvbnRleHQgPSBsaW5lc1xuICAgIC5zbGljZShNYXRoLm1pbihzb3VyY2VMaW5lICsgMSwgbWF4TGluZXMpLCBzb3VyY2VMaW5lICsgMSArIGxpbmVzT2ZDb250ZXh0KVxuICAgIC5tYXAoKGxpbmUpID0+IHN0cmluZy5zbmlwTGluZShsaW5lLCAwKSk7XG59XG5cbi8qKlxuICogQ2hlY2tzIHdoZXRoZXIgb3Igbm90IHdlJ3ZlIGFscmVhZHkgY2FwdHVyZWQgdGhlIGdpdmVuIGV4Y2VwdGlvbiAobm90ZTogbm90IGFuIGlkZW50aWNhbCBleGNlcHRpb24gLSB0aGUgdmVyeSBvYmplY3RcbiAqIGluIHF1ZXN0aW9uKSwgYW5kIG1hcmtzIGl0IGNhcHR1cmVkIGlmIG5vdC5cbiAqXG4gKiBUaGlzIGlzIHVzZWZ1bCBiZWNhdXNlIGl0J3MgcG9zc2libGUgZm9yIGFuIGVycm9yIHRvIGdldCBjYXB0dXJlZCBieSBtb3JlIHRoYW4gb25lIG1lY2hhbmlzbS4gQWZ0ZXIgd2UgaW50ZXJjZXB0IGFuZFxuICogcmVjb3JkIGFuIGVycm9yLCB3ZSByZXRocm93IGl0IChhc3N1bWluZyB3ZSd2ZSBpbnRlcmNlcHRlZCBpdCBiZWZvcmUgaXQncyByZWFjaGVkIHRoZSB0b3AtbGV2ZWwgZ2xvYmFsIGhhbmRsZXJzKSwgc29cbiAqIHRoYXQgd2UgZG9uJ3QgaW50ZXJmZXJlIHdpdGggd2hhdGV2ZXIgZWZmZWN0cyB0aGUgZXJyb3IgbWlnaHQgaGF2ZSBoYWQgd2VyZSB0aGUgU0RLIG5vdCB0aGVyZS4gQXQgdGhhdCBwb2ludCwgYmVjYXVzZVxuICogdGhlIGVycm9yIGhhcyBiZWVuIHJldGhyb3duLCBpdCdzIHBvc3NpYmxlIGZvciBpdCB0byBidWJibGUgdXAgdG8gc29tZSBvdGhlciBjb2RlIHdlJ3ZlIGluc3RydW1lbnRlZC4gSWYgaXQncyBub3RcbiAqIGNhdWdodCBhZnRlciB0aGF0LCBpdCB3aWxsIGJ1YmJsZSBhbGwgdGhlIHdheSB1cCB0byB0aGUgZ2xvYmFsIGhhbmRsZXJzICh3aGljaCBvZiBjb3Vyc2Ugd2UgYWxzbyBpbnN0cnVtZW50KS4gVGhpc1xuICogZnVuY3Rpb24gaGVscHMgdXMgZW5zdXJlIHRoYXQgZXZlbiBpZiB3ZSBlbmNvdW50ZXIgdGhlIHNhbWUgZXJyb3IgbW9yZSB0aGFuIG9uY2UsIHdlIG9ubHkgcmVjb3JkIGl0IHRoZSBmaXJzdCB0aW1lIHdlXG4gKiBzZWUgaXQuXG4gKlxuICogTm90ZTogSXQgd2lsbCBpZ25vcmUgcHJpbWl0aXZlcyAoYWx3YXlzIHJldHVybiBgZmFsc2VgIGFuZCBub3QgbWFyayB0aGVtIGFzIHNlZW4pLCBhcyBwcm9wZXJ0aWVzIGNhbid0IGJlIHNldCBvblxuICogdGhlbS4ge0BsaW5rOiBPYmplY3Qub2JqZWN0aWZ5fSBjYW4gYmUgdXNlZCBvbiBleGNlcHRpb25zIHRvIGNvbnZlcnQgYW55IHRoYXQgYXJlIHByaW1pdGl2ZXMgaW50byB0aGVpciBlcXVpdmFsZW50XG4gKiBvYmplY3Qgd3JhcHBlciBmb3JtcyBzbyB0aGF0IHRoaXMgY2hlY2sgd2lsbCBhbHdheXMgd29yay4gSG93ZXZlciwgYmVjYXVzZSB3ZSBuZWVkIHRvIGZsYWcgdGhlIGV4YWN0IG9iamVjdCB3aGljaFxuICogd2lsbCBnZXQgcmV0aHJvd24sIGFuZCBiZWNhdXNlIHRoYXQgcmV0aHJvd2luZyBoYXBwZW5zIG91dHNpZGUgb2YgdGhlIGV2ZW50IHByb2Nlc3NpbmcgcGlwZWxpbmUsIHRoZSBvYmplY3RpZmljYXRpb25cbiAqIG11c3QgYmUgZG9uZSBiZWZvcmUgdGhlIGV4Y2VwdGlvbiBjYXB0dXJlZC5cbiAqXG4gKiBAcGFyYW0gQSB0aHJvd24gZXhjZXB0aW9uIHRvIGNoZWNrIG9yIGZsYWcgYXMgaGF2aW5nIGJlZW4gc2VlblxuICogQHJldHVybnMgYHRydWVgIGlmIHRoZSBleGNlcHRpb24gaGFzIGFscmVhZHkgYmVlbiBjYXB0dXJlZCwgYGZhbHNlYCBpZiBub3QgKHdpdGggdGhlIHNpZGUgZWZmZWN0IG9mIG1hcmtpbmcgaXQgc2VlbilcbiAqL1xuZnVuY3Rpb24gY2hlY2tPclNldEFscmVhZHlDYXVnaHQoZXhjZXB0aW9uKSB7XG4gIGlmIChpc0FscmVhZHlDYXB0dXJlZChleGNlcHRpb24pKSB7XG4gICAgcmV0dXJuIHRydWU7XG4gIH1cblxuICB0cnkge1xuICAgIC8vIHNldCBpdCB0aGlzIHdheSByYXRoZXIgdGhhbiBieSBhc3NpZ25tZW50IHNvIHRoYXQgaXQncyBub3QgZW5udW1lcmFibGUgYW5kIHRoZXJlZm9yZSBpc24ndCByZWNvcmRlZCBieSB0aGVcbiAgICAvLyBgRXh0cmFFcnJvckRhdGFgIGludGVncmF0aW9uXG4gICAgb2JqZWN0LmFkZE5vbkVudW1lcmFibGVQcm9wZXJ0eShleGNlcHRpb24gLCAnX19zZW50cnlfY2FwdHVyZWRfXycsIHRydWUpO1xuICB9IGNhdGNoIHtcbiAgICAvLyBgZXhjZXB0aW9uYCBpcyBhIHByaW1pdGl2ZSwgc28gd2UgY2FuJ3QgbWFyayBpdCBzZWVuXG4gIH1cblxuICByZXR1cm4gZmFsc2U7XG59XG5cbmZ1bmN0aW9uIGlzQWxyZWFkeUNhcHR1cmVkKGV4Y2VwdGlvbikge1xuICB0cnkge1xuICAgIHJldHVybiAoZXhjZXB0aW9uICkuX19zZW50cnlfY2FwdHVyZWRfXztcbiAgfSBjYXRjaCB7fSAvLyBlc2xpbnQtZGlzYWJsZS1saW5lIG5vLWVtcHR5XG59XG5cbmV4cG9ydHMuYWRkQ29udGV4dFRvRnJhbWUgPSBhZGRDb250ZXh0VG9GcmFtZTtcbmV4cG9ydHMuYWRkRXhjZXB0aW9uTWVjaGFuaXNtID0gYWRkRXhjZXB0aW9uTWVjaGFuaXNtO1xuZXhwb3J0cy5hZGRFeGNlcHRpb25UeXBlVmFsdWUgPSBhZGRFeGNlcHRpb25UeXBlVmFsdWU7XG5leHBvcnRzLmNoZWNrT3JTZXRBbHJlYWR5Q2F1Z2h0ID0gY2hlY2tPclNldEFscmVhZHlDYXVnaHQ7XG5leHBvcnRzLmdldEV2ZW50RGVzY3JpcHRpb24gPSBnZXRFdmVudERlc2NyaXB0aW9uO1xuZXhwb3J0cy5wYXJzZVNlbXZlciA9IHBhcnNlU2VtdmVyO1xuZXhwb3J0cy51dWlkNCA9IHV1aWQ0O1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9bWlzYy5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/misc.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/node-stack-trace.js":
/*!**************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/node-stack-trace.js ***!
  \**************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst stacktrace = __webpack_require__(/*! ./stacktrace.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/stacktrace.js\");\n\n/**\n * Does this filename look like it's part of the app code?\n */\nfunction filenameIsInApp(filename, isNative = false) {\n  const isInternal =\n    isNative ||\n    (filename &&\n      // It's not internal if it's an absolute linux path\n      !filename.startsWith('/') &&\n      // It's not internal if it's an absolute windows path\n      !filename.match(/^[A-Z]:/) &&\n      // It's not internal if the path is starting with a dot\n      !filename.startsWith('.') &&\n      // It's not internal if the frame has a protocol. In node, this is usually the case if the file got pre-processed with a bundler like webpack\n      !filename.match(/^[a-zA-Z]([a-zA-Z0-9.\\-+])*:\\/\\//)); // Schema from: https://stackoverflow.com/a/3641782\n\n  // in_app is all that's not an internal Node function or a module within node_modules\n  // note that isNative appears to return true even for node core libraries\n  // see https://github.com/getsentry/raven-node/issues/176\n\n  return !isInternal && filename !== undefined && !filename.includes('node_modules/');\n}\n\n/** Node Stack line parser */\nfunction node(getModule) {\n  const FILENAME_MATCH = /^\\s*[-]{4,}$/;\n  const FULL_MATCH = /at (?:async )?(?:(.+?)\\s+\\()?(?:(.+):(\\d+):(\\d+)?|([^)]+))\\)?/;\n\n  // eslint-disable-next-line complexity\n  return (line) => {\n    const lineMatch = line.match(FULL_MATCH);\n\n    if (lineMatch) {\n      let object;\n      let method;\n      let functionName;\n      let typeName;\n      let methodName;\n\n      if (lineMatch[1]) {\n        functionName = lineMatch[1];\n\n        let methodStart = functionName.lastIndexOf('.');\n        if (functionName[methodStart - 1] === '.') {\n          methodStart--;\n        }\n\n        if (methodStart > 0) {\n          object = functionName.slice(0, methodStart);\n          method = functionName.slice(methodStart + 1);\n          const objectEnd = object.indexOf('.Module');\n          if (objectEnd > 0) {\n            functionName = functionName.slice(objectEnd + 1);\n            object = object.slice(0, objectEnd);\n          }\n        }\n        typeName = undefined;\n      }\n\n      if (method) {\n        typeName = object;\n        methodName = method;\n      }\n\n      if (method === '<anonymous>') {\n        methodName = undefined;\n        functionName = undefined;\n      }\n\n      if (functionName === undefined) {\n        methodName = methodName || stacktrace.UNKNOWN_FUNCTION;\n        functionName = typeName ? `${typeName}.${methodName}` : methodName;\n      }\n\n      let filename = lineMatch[2]?.startsWith('file://') ? lineMatch[2].slice(7) : lineMatch[2];\n      const isNative = lineMatch[5] === 'native';\n\n      // If it's a Windows path, trim the leading slash so that `/C:/foo` becomes `C:/foo`\n      if (filename?.match(/\\/[A-Z]:/)) {\n        filename = filename.slice(1);\n      }\n\n      if (!filename && lineMatch[5] && !isNative) {\n        filename = lineMatch[5];\n      }\n\n      return {\n        filename: filename ? decodeURI(filename) : undefined,\n        module: getModule ? getModule(filename) : undefined,\n        function: functionName,\n        lineno: _parseIntOrUndefined(lineMatch[3]),\n        colno: _parseIntOrUndefined(lineMatch[4]),\n        in_app: filenameIsInApp(filename || '', isNative),\n      };\n    }\n\n    if (line.match(FILENAME_MATCH)) {\n      return {\n        filename: line,\n      };\n    }\n\n    return undefined;\n  };\n}\n\n/**\n * Node.js stack line parser\n *\n * This is in @sentry/core so it can be used from the Electron SDK in the browser for when `nodeIntegration == true`.\n * This allows it to be used without referencing or importing any node specific code which causes bundlers to complain\n */\nfunction nodeStackLineParser(getModule) {\n  return [90, node(getModule)];\n}\n\nfunction _parseIntOrUndefined(input) {\n  return parseInt(input || '', 10) || undefined;\n}\n\nexports.filenameIsInApp = filenameIsInApp;\nexports.node = node;\nexports.nodeStackLineParser = nodeStackLineParser;\n//# sourceMappingURL=node-stack-trace.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9ub2RlLXN0YWNrLXRyYWNlLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLG1CQUFtQixtQkFBTyxDQUFDLCtIQUFpQjs7QUFFNUM7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLDREQUE0RDs7QUFFNUQ7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLGtDQUFrQyxHQUFHO0FBQ3JDOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQSxxQ0FBcUMsU0FBUyxHQUFHLFdBQVc7QUFDNUQ7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUEsdUJBQXVCO0FBQ3ZCLFlBQVk7QUFDWiwyQkFBMkI7QUFDM0IiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9ub2RlLXN0YWNrLXRyYWNlLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBzdGFja3RyYWNlID0gcmVxdWlyZSgnLi9zdGFja3RyYWNlLmpzJyk7XG5cbi8qKlxuICogRG9lcyB0aGlzIGZpbGVuYW1lIGxvb2sgbGlrZSBpdCdzIHBhcnQgb2YgdGhlIGFwcCBjb2RlP1xuICovXG5mdW5jdGlvbiBmaWxlbmFtZUlzSW5BcHAoZmlsZW5hbWUsIGlzTmF0aXZlID0gZmFsc2UpIHtcbiAgY29uc3QgaXNJbnRlcm5hbCA9XG4gICAgaXNOYXRpdmUgfHxcbiAgICAoZmlsZW5hbWUgJiZcbiAgICAgIC8vIEl0J3Mgbm90IGludGVybmFsIGlmIGl0J3MgYW4gYWJzb2x1dGUgbGludXggcGF0aFxuICAgICAgIWZpbGVuYW1lLnN0YXJ0c1dpdGgoJy8nKSAmJlxuICAgICAgLy8gSXQncyBub3QgaW50ZXJuYWwgaWYgaXQncyBhbiBhYnNvbHV0ZSB3aW5kb3dzIHBhdGhcbiAgICAgICFmaWxlbmFtZS5tYXRjaCgvXltBLVpdOi8pICYmXG4gICAgICAvLyBJdCdzIG5vdCBpbnRlcm5hbCBpZiB0aGUgcGF0aCBpcyBzdGFydGluZyB3aXRoIGEgZG90XG4gICAgICAhZmlsZW5hbWUuc3RhcnRzV2l0aCgnLicpICYmXG4gICAgICAvLyBJdCdzIG5vdCBpbnRlcm5hbCBpZiB0aGUgZnJhbWUgaGFzIGEgcHJvdG9jb2wuIEluIG5vZGUsIHRoaXMgaXMgdXN1YWxseSB0aGUgY2FzZSBpZiB0aGUgZmlsZSBnb3QgcHJlLXByb2Nlc3NlZCB3aXRoIGEgYnVuZGxlciBsaWtlIHdlYnBhY2tcbiAgICAgICFmaWxlbmFtZS5tYXRjaCgvXlthLXpBLVpdKFthLXpBLVowLTkuXFwtK10pKjpcXC9cXC8vKSk7IC8vIFNjaGVtYSBmcm9tOiBodHRwczovL3N0YWNrb3ZlcmZsb3cuY29tL2EvMzY0MTc4MlxuXG4gIC8vIGluX2FwcCBpcyBhbGwgdGhhdCdzIG5vdCBhbiBpbnRlcm5hbCBOb2RlIGZ1bmN0aW9uIG9yIGEgbW9kdWxlIHdpdGhpbiBub2RlX21vZHVsZXNcbiAgLy8gbm90ZSB0aGF0IGlzTmF0aXZlIGFwcGVhcnMgdG8gcmV0dXJuIHRydWUgZXZlbiBmb3Igbm9kZSBjb3JlIGxpYnJhcmllc1xuICAvLyBzZWUgaHR0cHM6Ly9naXRodWIuY29tL2dldHNlbnRyeS9yYXZlbi1ub2RlL2lzc3Vlcy8xNzZcblxuICByZXR1cm4gIWlzSW50ZXJuYWwgJiYgZmlsZW5hbWUgIT09IHVuZGVmaW5lZCAmJiAhZmlsZW5hbWUuaW5jbHVkZXMoJ25vZGVfbW9kdWxlcy8nKTtcbn1cblxuLyoqIE5vZGUgU3RhY2sgbGluZSBwYXJzZXIgKi9cbmZ1bmN0aW9uIG5vZGUoZ2V0TW9kdWxlKSB7XG4gIGNvbnN0IEZJTEVOQU1FX01BVENIID0gL15cXHMqWy1dezQsfSQvO1xuICBjb25zdCBGVUxMX01BVENIID0gL2F0ICg/OmFzeW5jICk/KD86KC4rPylcXHMrXFwoKT8oPzooLispOihcXGQrKTooXFxkKyk/fChbXildKykpXFwpPy87XG5cbiAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIGNvbXBsZXhpdHlcbiAgcmV0dXJuIChsaW5lKSA9PiB7XG4gICAgY29uc3QgbGluZU1hdGNoID0gbGluZS5tYXRjaChGVUxMX01BVENIKTtcblxuICAgIGlmIChsaW5lTWF0Y2gpIHtcbiAgICAgIGxldCBvYmplY3Q7XG4gICAgICBsZXQgbWV0aG9kO1xuICAgICAgbGV0IGZ1bmN0aW9uTmFtZTtcbiAgICAgIGxldCB0eXBlTmFtZTtcbiAgICAgIGxldCBtZXRob2ROYW1lO1xuXG4gICAgICBpZiAobGluZU1hdGNoWzFdKSB7XG4gICAgICAgIGZ1bmN0aW9uTmFtZSA9IGxpbmVNYXRjaFsxXTtcblxuICAgICAgICBsZXQgbWV0aG9kU3RhcnQgPSBmdW5jdGlvbk5hbWUubGFzdEluZGV4T2YoJy4nKTtcbiAgICAgICAgaWYgKGZ1bmN0aW9uTmFtZVttZXRob2RTdGFydCAtIDFdID09PSAnLicpIHtcbiAgICAgICAgICBtZXRob2RTdGFydC0tO1xuICAgICAgICB9XG5cbiAgICAgICAgaWYgKG1ldGhvZFN0YXJ0ID4gMCkge1xuICAgICAgICAgIG9iamVjdCA9IGZ1bmN0aW9uTmFtZS5zbGljZSgwLCBtZXRob2RTdGFydCk7XG4gICAgICAgICAgbWV0aG9kID0gZnVuY3Rpb25OYW1lLnNsaWNlKG1ldGhvZFN0YXJ0ICsgMSk7XG4gICAgICAgICAgY29uc3Qgb2JqZWN0RW5kID0gb2JqZWN0LmluZGV4T2YoJy5Nb2R1bGUnKTtcbiAgICAgICAgICBpZiAob2JqZWN0RW5kID4gMCkge1xuICAgICAgICAgICAgZnVuY3Rpb25OYW1lID0gZnVuY3Rpb25OYW1lLnNsaWNlKG9iamVjdEVuZCArIDEpO1xuICAgICAgICAgICAgb2JqZWN0ID0gb2JqZWN0LnNsaWNlKDAsIG9iamVjdEVuZCk7XG4gICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICAgIHR5cGVOYW1lID0gdW5kZWZpbmVkO1xuICAgICAgfVxuXG4gICAgICBpZiAobWV0aG9kKSB7XG4gICAgICAgIHR5cGVOYW1lID0gb2JqZWN0O1xuICAgICAgICBtZXRob2ROYW1lID0gbWV0aG9kO1xuICAgICAgfVxuXG4gICAgICBpZiAobWV0aG9kID09PSAnPGFub255bW91cz4nKSB7XG4gICAgICAgIG1ldGhvZE5hbWUgPSB1bmRlZmluZWQ7XG4gICAgICAgIGZ1bmN0aW9uTmFtZSA9IHVuZGVmaW5lZDtcbiAgICAgIH1cblxuICAgICAgaWYgKGZ1bmN0aW9uTmFtZSA9PT0gdW5kZWZpbmVkKSB7XG4gICAgICAgIG1ldGhvZE5hbWUgPSBtZXRob2ROYW1lIHx8IHN0YWNrdHJhY2UuVU5LTk9XTl9GVU5DVElPTjtcbiAgICAgICAgZnVuY3Rpb25OYW1lID0gdHlwZU5hbWUgPyBgJHt0eXBlTmFtZX0uJHttZXRob2ROYW1lfWAgOiBtZXRob2ROYW1lO1xuICAgICAgfVxuXG4gICAgICBsZXQgZmlsZW5hbWUgPSBsaW5lTWF0Y2hbMl0/LnN0YXJ0c1dpdGgoJ2ZpbGU6Ly8nKSA/IGxpbmVNYXRjaFsyXS5zbGljZSg3KSA6IGxpbmVNYXRjaFsyXTtcbiAgICAgIGNvbnN0IGlzTmF0aXZlID0gbGluZU1hdGNoWzVdID09PSAnbmF0aXZlJztcblxuICAgICAgLy8gSWYgaXQncyBhIFdpbmRvd3MgcGF0aCwgdHJpbSB0aGUgbGVhZGluZyBzbGFzaCBzbyB0aGF0IGAvQzovZm9vYCBiZWNvbWVzIGBDOi9mb29gXG4gICAgICBpZiAoZmlsZW5hbWU/Lm1hdGNoKC9cXC9bQS1aXTovKSkge1xuICAgICAgICBmaWxlbmFtZSA9IGZpbGVuYW1lLnNsaWNlKDEpO1xuICAgICAgfVxuXG4gICAgICBpZiAoIWZpbGVuYW1lICYmIGxpbmVNYXRjaFs1XSAmJiAhaXNOYXRpdmUpIHtcbiAgICAgICAgZmlsZW5hbWUgPSBsaW5lTWF0Y2hbNV07XG4gICAgICB9XG5cbiAgICAgIHJldHVybiB7XG4gICAgICAgIGZpbGVuYW1lOiBmaWxlbmFtZSA/IGRlY29kZVVSSShmaWxlbmFtZSkgOiB1bmRlZmluZWQsXG4gICAgICAgIG1vZHVsZTogZ2V0TW9kdWxlID8gZ2V0TW9kdWxlKGZpbGVuYW1lKSA6IHVuZGVmaW5lZCxcbiAgICAgICAgZnVuY3Rpb246IGZ1bmN0aW9uTmFtZSxcbiAgICAgICAgbGluZW5vOiBfcGFyc2VJbnRPclVuZGVmaW5lZChsaW5lTWF0Y2hbM10pLFxuICAgICAgICBjb2xubzogX3BhcnNlSW50T3JVbmRlZmluZWQobGluZU1hdGNoWzRdKSxcbiAgICAgICAgaW5fYXBwOiBmaWxlbmFtZUlzSW5BcHAoZmlsZW5hbWUgfHwgJycsIGlzTmF0aXZlKSxcbiAgICAgIH07XG4gICAgfVxuXG4gICAgaWYgKGxpbmUubWF0Y2goRklMRU5BTUVfTUFUQ0gpKSB7XG4gICAgICByZXR1cm4ge1xuICAgICAgICBmaWxlbmFtZTogbGluZSxcbiAgICAgIH07XG4gICAgfVxuXG4gICAgcmV0dXJuIHVuZGVmaW5lZDtcbiAgfTtcbn1cblxuLyoqXG4gKiBOb2RlLmpzIHN0YWNrIGxpbmUgcGFyc2VyXG4gKlxuICogVGhpcyBpcyBpbiBAc2VudHJ5L2NvcmUgc28gaXQgY2FuIGJlIHVzZWQgZnJvbSB0aGUgRWxlY3Ryb24gU0RLIGluIHRoZSBicm93c2VyIGZvciB3aGVuIGBub2RlSW50ZWdyYXRpb24gPT0gdHJ1ZWAuXG4gKiBUaGlzIGFsbG93cyBpdCB0byBiZSB1c2VkIHdpdGhvdXQgcmVmZXJlbmNpbmcgb3IgaW1wb3J0aW5nIGFueSBub2RlIHNwZWNpZmljIGNvZGUgd2hpY2ggY2F1c2VzIGJ1bmRsZXJzIHRvIGNvbXBsYWluXG4gKi9cbmZ1bmN0aW9uIG5vZGVTdGFja0xpbmVQYXJzZXIoZ2V0TW9kdWxlKSB7XG4gIHJldHVybiBbOTAsIG5vZGUoZ2V0TW9kdWxlKV07XG59XG5cbmZ1bmN0aW9uIF9wYXJzZUludE9yVW5kZWZpbmVkKGlucHV0KSB7XG4gIHJldHVybiBwYXJzZUludChpbnB1dCB8fCAnJywgMTApIHx8IHVuZGVmaW5lZDtcbn1cblxuZXhwb3J0cy5maWxlbmFtZUlzSW5BcHAgPSBmaWxlbmFtZUlzSW5BcHA7XG5leHBvcnRzLm5vZGUgPSBub2RlO1xuZXhwb3J0cy5ub2RlU3RhY2tMaW5lUGFyc2VyID0gbm9kZVN0YWNrTGluZVBhcnNlcjtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPW5vZGUtc3RhY2stdHJhY2UuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/node-stack-trace.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/node.js":
/*!**************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/node.js ***!
  \**************************************************************************************************/
/***/ ((module, exports, __webpack_require__) => {
 
eval("/* module decorator */ module = __webpack_require__.nmd(module);\nObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst env = __webpack_require__(/*! ./env.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/env.js\");\n\n/**\n * NOTE: In order to avoid circular dependencies, if you add a function to this module and it needs to print something,\n * you must either a) use `console.log` rather than the `debug` singleton, or b) put your function elsewhere.\n */\n\n\n/**\n * Checks whether we're in the Node.js or Browser environment\n *\n * @returns Answer to given question\n */\nfunction isNodeEnv() {\n  // explicitly check for browser bundles as those can be optimized statically\n  // by terser/rollup.\n  return (\n    !env.isBrowserBundle() &&\n    Object.prototype.toString.call(typeof process !== 'undefined' ? process : 0) === '[object process]'\n  );\n}\n\n/**\n * Requires a module which is protected against bundler minification.\n *\n * @param request The module path to resolve\n */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction dynamicRequire(mod, request) {\n  // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n  return mod.require(request);\n}\n\n/**\n * Helper for dynamically loading module that should work with linked dependencies.\n * The problem is that we _should_ be using `require(require.resolve(moduleName, { paths: [cwd()] }))`\n * However it's _not possible_ to do that with Webpack, as it has to know all the dependencies during\n * build time. `require.resolve` is also not available in any other way, so we cannot create,\n * a fake helper like we do with `dynamicRequire`.\n *\n * We always prefer to use local package, thus the value is not returned early from each `try/catch` block.\n * That is to mimic the behavior of `require.resolve` exactly.\n *\n * @param moduleName module name to require\n * @param existingModule module to use for requiring\n * @returns possibly required module\n */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction loadModule(moduleName, existingModule = module) {\n  let mod;\n\n  try {\n    mod = dynamicRequire(existingModule, moduleName);\n  } catch {\n    // no-empty\n  }\n\n  if (!mod) {\n    try {\n      const { cwd } = dynamicRequire(existingModule, 'process');\n      mod = dynamicRequire(existingModule, `${cwd()}/node_modules/${moduleName}`) ;\n    } catch {\n      // no-empty\n    }\n  }\n\n  return mod;\n}\n\nexports.isNodeEnv = isNodeEnv;\nexports.loadModule = loadModule;\n//# sourceMappingURL=node.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9ub2RlLmpzIiwibWFwcGluZ3MiOiI7QUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxZQUFZLG1CQUFPLENBQUMsaUhBQVU7O0FBRTlCO0FBQ0E7QUFDQTtBQUNBOzs7QUFHQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsbUZBQW1GLGdCQUFnQjtBQUNuRztBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQSxJQUFJO0FBQ0o7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsY0FBYyxNQUFNO0FBQ3BCLDhDQUE4QyxNQUFNLGdCQUFnQixXQUFXO0FBQy9FLE1BQU07QUFDTjtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQSxpQkFBaUI7QUFDakIsa0JBQWtCO0FBQ2xCIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvbm9kZS5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgZW52ID0gcmVxdWlyZSgnLi9lbnYuanMnKTtcblxuLyoqXG4gKiBOT1RFOiBJbiBvcmRlciB0byBhdm9pZCBjaXJjdWxhciBkZXBlbmRlbmNpZXMsIGlmIHlvdSBhZGQgYSBmdW5jdGlvbiB0byB0aGlzIG1vZHVsZSBhbmQgaXQgbmVlZHMgdG8gcHJpbnQgc29tZXRoaW5nLFxuICogeW91IG11c3QgZWl0aGVyIGEpIHVzZSBgY29uc29sZS5sb2dgIHJhdGhlciB0aGFuIHRoZSBgZGVidWdgIHNpbmdsZXRvbiwgb3IgYikgcHV0IHlvdXIgZnVuY3Rpb24gZWxzZXdoZXJlLlxuICovXG5cblxuLyoqXG4gKiBDaGVja3Mgd2hldGhlciB3ZSdyZSBpbiB0aGUgTm9kZS5qcyBvciBCcm93c2VyIGVudmlyb25tZW50XG4gKlxuICogQHJldHVybnMgQW5zd2VyIHRvIGdpdmVuIHF1ZXN0aW9uXG4gKi9cbmZ1bmN0aW9uIGlzTm9kZUVudigpIHtcbiAgLy8gZXhwbGljaXRseSBjaGVjayBmb3IgYnJvd3NlciBidW5kbGVzIGFzIHRob3NlIGNhbiBiZSBvcHRpbWl6ZWQgc3RhdGljYWxseVxuICAvLyBieSB0ZXJzZXIvcm9sbHVwLlxuICByZXR1cm4gKFxuICAgICFlbnYuaXNCcm93c2VyQnVuZGxlKCkgJiZcbiAgICBPYmplY3QucHJvdG90eXBlLnRvU3RyaW5nLmNhbGwodHlwZW9mIHByb2Nlc3MgIT09ICd1bmRlZmluZWQnID8gcHJvY2VzcyA6IDApID09PSAnW29iamVjdCBwcm9jZXNzXSdcbiAgKTtcbn1cblxuLyoqXG4gKiBSZXF1aXJlcyBhIG1vZHVsZSB3aGljaCBpcyBwcm90ZWN0ZWQgYWdhaW5zdCBidW5kbGVyIG1pbmlmaWNhdGlvbi5cbiAqXG4gKiBAcGFyYW0gcmVxdWVzdCBUaGUgbW9kdWxlIHBhdGggdG8gcmVzb2x2ZVxuICovXG4vLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25vLWV4cGxpY2l0LWFueVxuZnVuY3Rpb24gZHluYW1pY1JlcXVpcmUobW9kLCByZXF1ZXN0KSB7XG4gIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tdW5zYWZlLW1lbWJlci1hY2Nlc3NcbiAgcmV0dXJuIG1vZC5yZXF1aXJlKHJlcXVlc3QpO1xufVxuXG4vKipcbiAqIEhlbHBlciBmb3IgZHluYW1pY2FsbHkgbG9hZGluZyBtb2R1bGUgdGhhdCBzaG91bGQgd29yayB3aXRoIGxpbmtlZCBkZXBlbmRlbmNpZXMuXG4gKiBUaGUgcHJvYmxlbSBpcyB0aGF0IHdlIF9zaG91bGRfIGJlIHVzaW5nIGByZXF1aXJlKHJlcXVpcmUucmVzb2x2ZShtb2R1bGVOYW1lLCB7IHBhdGhzOiBbY3dkKCldIH0pKWBcbiAqIEhvd2V2ZXIgaXQncyBfbm90IHBvc3NpYmxlXyB0byBkbyB0aGF0IHdpdGggV2VicGFjaywgYXMgaXQgaGFzIHRvIGtub3cgYWxsIHRoZSBkZXBlbmRlbmNpZXMgZHVyaW5nXG4gKiBidWlsZCB0aW1lLiBgcmVxdWlyZS5yZXNvbHZlYCBpcyBhbHNvIG5vdCBhdmFpbGFibGUgaW4gYW55IG90aGVyIHdheSwgc28gd2UgY2Fubm90IGNyZWF0ZSxcbiAqIGEgZmFrZSBoZWxwZXIgbGlrZSB3ZSBkbyB3aXRoIGBkeW5hbWljUmVxdWlyZWAuXG4gKlxuICogV2UgYWx3YXlzIHByZWZlciB0byB1c2UgbG9jYWwgcGFja2FnZSwgdGh1cyB0aGUgdmFsdWUgaXMgbm90IHJldHVybmVkIGVhcmx5IGZyb20gZWFjaCBgdHJ5L2NhdGNoYCBibG9jay5cbiAqIFRoYXQgaXMgdG8gbWltaWMgdGhlIGJlaGF2aW9yIG9mIGByZXF1aXJlLnJlc29sdmVgIGV4YWN0bHkuXG4gKlxuICogQHBhcmFtIG1vZHVsZU5hbWUgbW9kdWxlIG5hbWUgdG8gcmVxdWlyZVxuICogQHBhcmFtIGV4aXN0aW5nTW9kdWxlIG1vZHVsZSB0byB1c2UgZm9yIHJlcXVpcmluZ1xuICogQHJldHVybnMgcG9zc2libHkgcmVxdWlyZWQgbW9kdWxlXG4gKi9cbi8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tZXhwbGljaXQtYW55XG5mdW5jdGlvbiBsb2FkTW9kdWxlKG1vZHVsZU5hbWUsIGV4aXN0aW5nTW9kdWxlID0gbW9kdWxlKSB7XG4gIGxldCBtb2Q7XG5cbiAgdHJ5IHtcbiAgICBtb2QgPSBkeW5hbWljUmVxdWlyZShleGlzdGluZ01vZHVsZSwgbW9kdWxlTmFtZSk7XG4gIH0gY2F0Y2gge1xuICAgIC8vIG5vLWVtcHR5XG4gIH1cblxuICBpZiAoIW1vZCkge1xuICAgIHRyeSB7XG4gICAgICBjb25zdCB7IGN3ZCB9ID0gZHluYW1pY1JlcXVpcmUoZXhpc3RpbmdNb2R1bGUsICdwcm9jZXNzJyk7XG4gICAgICBtb2QgPSBkeW5hbWljUmVxdWlyZShleGlzdGluZ01vZHVsZSwgYCR7Y3dkKCl9L25vZGVfbW9kdWxlcy8ke21vZHVsZU5hbWV9YCkgO1xuICAgIH0gY2F0Y2gge1xuICAgICAgLy8gbm8tZW1wdHlcbiAgICB9XG4gIH1cblxuICByZXR1cm4gbW9kO1xufVxuXG5leHBvcnRzLmlzTm9kZUVudiA9IGlzTm9kZUVudjtcbmV4cG9ydHMubG9hZE1vZHVsZSA9IGxvYWRNb2R1bGU7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1ub2RlLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/node.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/normalize.js":
/*!*******************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/normalize.js ***!
  \*******************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst is = __webpack_require__(/*! ./is.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js\");\nconst object = __webpack_require__(/*! ./object.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/object.js\");\nconst stacktrace = __webpack_require__(/*! ./stacktrace.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/stacktrace.js\");\n\n/**\n * Recursively normalizes the given object.\n *\n * - Creates a copy to prevent original input mutation\n * - Skips non-enumerable properties\n * - When stringifying, calls `toJSON` if implemented\n * - Removes circular references\n * - Translates non-serializable values (`undefined`/`NaN`/functions) to serializable format\n * - Translates known global objects/classes to a string representations\n * - Takes care of `Error` object serialization\n * - Optionally limits depth of final output\n * - Optionally limits number of properties/elements included in any single object/array\n *\n * @param input The object to be normalized.\n * @param depth The max depth to which to normalize the object. (Anything deeper stringified whole.)\n * @param maxProperties The max number of elements or properties to be included in any single array or\n * object in the normalized output.\n * @returns A normalized version of the object, or `\"**non-serializable**\"` if any errors are thrown during normalization.\n */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction normalize(input, depth = 100, maxProperties = +Infinity) {\n  try {\n    // since we're at the outermost level, we don't provide a key\n    return visit('', input, depth, maxProperties);\n  } catch (err) {\n    return { ERROR: `**non-serializable** (${err})` };\n  }\n}\n\n/** JSDoc */\nfunction normalizeToSize(\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  object,\n  // Default Node.js REPL depth\n  depth = 3,\n  // 100kB, as 200kB is max payload size, so half sounds reasonable\n  maxSize = 100 * 1024,\n) {\n  const normalized = normalize(object, depth);\n\n  if (jsonSize(normalized) > maxSize) {\n    return normalizeToSize(object, depth - 1, maxSize);\n  }\n\n  return normalized ;\n}\n\n/**\n * Visits a node to perform normalization on it\n *\n * @param key The key corresponding to the given node\n * @param value The node to be visited\n * @param depth Optional number indicating the maximum recursion depth\n * @param maxProperties Optional maximum number of properties/elements included in any single object/array\n * @param memo Optional Memo class handling decycling\n */\nfunction visit(\n  key,\n  value,\n  depth = +Infinity,\n  maxProperties = +Infinity,\n  memo = memoBuilder(),\n) {\n  const [memoize, unmemoize] = memo;\n\n  // Get the simple cases out of the way first\n  if (\n    value == null || // this matches null and undefined -> eqeq not eqeqeq\n    ['boolean', 'string'].includes(typeof value) ||\n    (typeof value === 'number' && Number.isFinite(value))\n  ) {\n    return value ;\n  }\n\n  const stringified = stringifyValue(key, value);\n\n  // Anything we could potentially dig into more (objects or arrays) will have come back as `\"[object XXXX]\"`.\n  // Everything else will have already been serialized, so if we don't see that pattern, we're done.\n  if (!stringified.startsWith('[object ')) {\n    return stringified;\n  }\n\n  // From here on, we can assert that `value` is either an object or an array.\n\n  // Do not normalize objects that we know have already been normalized. As a general rule, the\n  // \"__sentry_skip_normalization__\" property should only be used sparingly and only should only be set on objects that\n  // have already been normalized.\n  if ((value )['__sentry_skip_normalization__']) {\n    return value ;\n  }\n\n  // We can set `__sentry_override_normalization_depth__` on an object to ensure that from there\n  // We keep a certain amount of depth.\n  // This should be used sparingly, e.g. we use it for the redux integration to ensure we get a certain amount of state.\n  const remainingDepth =\n    typeof (value )['__sentry_override_normalization_depth__'] === 'number'\n      ? ((value )['__sentry_override_normalization_depth__'] )\n      : depth;\n\n  // We're also done if we've reached the max depth\n  if (remainingDepth === 0) {\n    // At this point we know `serialized` is a string of the form `\"[object XXXX]\"`. Clean it up so it's just `\"[XXXX]\"`.\n    return stringified.replace('object ', '');\n  }\n\n  // If we've already visited this branch, bail out, as it's circular reference. If not, note that we're seeing it now.\n  if (memoize(value)) {\n    return '[Circular ~]';\n  }\n\n  // If the value has a `toJSON` method, we call it to extract more information\n  const valueWithToJSON = value ;\n  if (valueWithToJSON && typeof valueWithToJSON.toJSON === 'function') {\n    try {\n      const jsonValue = valueWithToJSON.toJSON();\n      // We need to normalize the return value of `.toJSON()` in case it has circular references\n      return visit('', jsonValue, remainingDepth - 1, maxProperties, memo);\n    } catch {\n      // pass (The built-in `toJSON` failed, but we can still try to do it ourselves)\n    }\n  }\n\n  // At this point we know we either have an object or an array, we haven't seen it before, and we're going to recurse\n  // because we haven't yet reached the max depth. Create an accumulator to hold the results of visiting each\n  // property/entry, and keep track of the number of items we add to it.\n  const normalized = (Array.isArray(value) ? [] : {}) ;\n  let numAdded = 0;\n\n  // Before we begin, convert`Error` and`Event` instances into plain objects, since some of each of their relevant\n  // properties are non-enumerable and otherwise would get missed.\n  const visitable = object.convertToPlainObject(value );\n\n  for (const visitKey in visitable) {\n    // Avoid iterating over fields in the prototype if they've somehow been exposed to enumeration.\n    if (!Object.prototype.hasOwnProperty.call(visitable, visitKey)) {\n      continue;\n    }\n\n    if (numAdded >= maxProperties) {\n      normalized[visitKey] = '[MaxProperties ~]';\n      break;\n    }\n\n    // Recursively visit all the child nodes\n    const visitValue = visitable[visitKey];\n    normalized[visitKey] = visit(visitKey, visitValue, remainingDepth - 1, maxProperties, memo);\n\n    numAdded++;\n  }\n\n  // Once we've visited all the branches, remove the parent from memo storage\n  unmemoize(value);\n\n  // Return accumulated values\n  return normalized;\n}\n\n/* eslint-disable complexity */\n/**\n * Stringify the given value. Handles various known special values and types.\n *\n * Not meant to be used on simple primitives which already have a string representation, as it will, for example, turn\n * the number 1231 into \"[Object Number]\", nor on `null`, as it will throw.\n *\n * @param value The value to stringify\n * @returns A stringified representation of the given value\n */\nfunction stringifyValue(\n  key,\n  // this type is a tiny bit of a cheat, since this function does handle NaN (which is technically a number), but for\n  // our internal use, it'll do\n  value,\n) {\n  try {\n    if (key === 'domain' && value && typeof value === 'object' && (value )._events) {\n      return '[Domain]';\n    }\n\n    if (key === 'domainEmitter') {\n      return '[DomainEmitter]';\n    }\n\n    // It's safe to use `global`, `window`, and `document` here in this manner, as we are asserting using `typeof` first\n    // which won't throw if they are not present.\n\n    if (typeof global !== 'undefined' && value === global) {\n      return '[Global]';\n    }\n\n    // eslint-disable-next-line no-restricted-globals\n    if (typeof window !== 'undefined' && value === window) {\n      return '[Window]';\n    }\n\n    // eslint-disable-next-line no-restricted-globals\n    if (typeof document !== 'undefined' && value === document) {\n      return '[Document]';\n    }\n\n    if (is.isVueViewModel(value)) {\n      return '[VueViewModel]';\n    }\n\n    // React's SyntheticEvent thingy\n    if (is.isSyntheticEvent(value)) {\n      return '[SyntheticEvent]';\n    }\n\n    if (typeof value === 'number' && !Number.isFinite(value)) {\n      return `[${value}]`;\n    }\n\n    if (typeof value === 'function') {\n      return `[Function: ${stacktrace.getFunctionName(value)}]`;\n    }\n\n    if (typeof value === 'symbol') {\n      return `[${String(value)}]`;\n    }\n\n    // stringified BigInts are indistinguishable from regular numbers, so we need to label them to avoid confusion\n    if (typeof value === 'bigint') {\n      return `[BigInt: ${String(value)}]`;\n    }\n\n    // Now that we've knocked out all the special cases and the primitives, all we have left are objects. Simply casting\n    // them to strings means that instances of classes which haven't defined their `toStringTag` will just come out as\n    // `\"[object Object]\"`. If we instead look at the constructor's name (which is the same as the name of the class),\n    // we can make sure that only plain objects come out that way.\n    const objName = getConstructorName(value);\n\n    // Handle HTML Elements\n    if (/^HTML(\\w*)Element$/.test(objName)) {\n      return `[HTMLElement: ${objName}]`;\n    }\n\n    return `[object ${objName}]`;\n  } catch (err) {\n    return `**non-serializable** (${err})`;\n  }\n}\n/* eslint-enable complexity */\n\nfunction getConstructorName(value) {\n  const prototype = Object.getPrototypeOf(value);\n\n  return prototype?.constructor ? prototype.constructor.name : 'null prototype';\n}\n\n/** Calculates bytes size of input string */\nfunction utf8Length(value) {\n  // eslint-disable-next-line no-bitwise\n  return ~-encodeURI(value).split(/%..|./).length;\n}\n\n/** Calculates bytes size of input object */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction jsonSize(value) {\n  return utf8Length(JSON.stringify(value));\n}\n\n/**\n * Normalizes URLs in exceptions and stacktraces to a base path so Sentry can fingerprint\n * across platforms and working directory.\n *\n * @param url The URL to be normalized.\n * @param basePath The application base path.\n * @returns The normalized URL.\n */\nfunction normalizeUrlToBase(url, basePath) {\n  const escapedBase = basePath\n    // Backslash to forward\n    .replace(/\\\\/g, '/')\n    // Escape RegExp special characters\n    .replace(/[|\\\\{}()[\\]^$+*?.]/g, '\\\\$&');\n\n  let newUrl = url;\n  try {\n    newUrl = decodeURI(url);\n  } catch {\n    // Sometime this breaks\n  }\n  return (\n    newUrl\n      .replace(/\\\\/g, '/')\n      .replace(/webpack:\\/?/g, '') // Remove intermediate base path\n      // eslint-disable-next-line @sentry-internal/sdk/no-regexp-constructor\n      .replace(new RegExp(`(file://)?/*${escapedBase}/*`, 'ig'), 'app:///')\n  );\n}\n\n/**\n * Helper to decycle json objects\n */\nfunction memoBuilder() {\n  const inner = new WeakSet();\n  function memoize(obj) {\n    if (inner.has(obj)) {\n      return true;\n    }\n    inner.add(obj);\n    return false;\n  }\n\n  function unmemoize(obj) {\n    inner.delete(obj);\n  }\n  return [memoize, unmemoize];\n}\n\nexports.normalize = normalize;\nexports.normalizeToSize = normalizeToSize;\nexports.normalizeUrlToBase = normalizeUrlToBase;\n//# sourceMappingURL=normalize.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9ub3JtYWxpemUuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsV0FBVyxtQkFBTyxDQUFDLCtHQUFTO0FBQzVCLGVBQWUsbUJBQU8sQ0FBQyx1SEFBYTtBQUNwQyxtQkFBbUIsbUJBQU8sQ0FBQywrSEFBaUI7O0FBRTVDO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLElBQUk7QUFDSixhQUFhLGdDQUFnQyxJQUFJO0FBQ2pEO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxNQUFNO0FBQ047QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBLG9EQUFvRDtBQUNwRDs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQSxpQkFBaUIsTUFBTTtBQUN2Qjs7QUFFQTtBQUNBLDJCQUEyQixrQ0FBa0M7QUFDN0Q7O0FBRUE7QUFDQSxpQkFBaUIsY0FBYztBQUMvQjs7QUFFQTtBQUNBO0FBQ0EseUJBQXlCLGNBQWM7QUFDdkM7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsOEJBQThCLFFBQVE7QUFDdEM7O0FBRUEsc0JBQXNCLFFBQVE7QUFDOUIsSUFBSTtBQUNKLG9DQUFvQyxJQUFJO0FBQ3hDO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0Esb0JBQW9COztBQUVwQjtBQUNBO0FBQ0E7QUFDQSxJQUFJO0FBQ0o7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSx5Q0FBeUMsWUFBWTtBQUNyRDtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLGlCQUFpQjtBQUNqQix1QkFBdUI7QUFDdkIsMEJBQTBCO0FBQzFCIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvbm9ybWFsaXplLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBpcyA9IHJlcXVpcmUoJy4vaXMuanMnKTtcbmNvbnN0IG9iamVjdCA9IHJlcXVpcmUoJy4vb2JqZWN0LmpzJyk7XG5jb25zdCBzdGFja3RyYWNlID0gcmVxdWlyZSgnLi9zdGFja3RyYWNlLmpzJyk7XG5cbi8qKlxuICogUmVjdXJzaXZlbHkgbm9ybWFsaXplcyB0aGUgZ2l2ZW4gb2JqZWN0LlxuICpcbiAqIC0gQ3JlYXRlcyBhIGNvcHkgdG8gcHJldmVudCBvcmlnaW5hbCBpbnB1dCBtdXRhdGlvblxuICogLSBTa2lwcyBub24tZW51bWVyYWJsZSBwcm9wZXJ0aWVzXG4gKiAtIFdoZW4gc3RyaW5naWZ5aW5nLCBjYWxscyBgdG9KU09OYCBpZiBpbXBsZW1lbnRlZFxuICogLSBSZW1vdmVzIGNpcmN1bGFyIHJlZmVyZW5jZXNcbiAqIC0gVHJhbnNsYXRlcyBub24tc2VyaWFsaXphYmxlIHZhbHVlcyAoYHVuZGVmaW5lZGAvYE5hTmAvZnVuY3Rpb25zKSB0byBzZXJpYWxpemFibGUgZm9ybWF0XG4gKiAtIFRyYW5zbGF0ZXMga25vd24gZ2xvYmFsIG9iamVjdHMvY2xhc3NlcyB0byBhIHN0cmluZyByZXByZXNlbnRhdGlvbnNcbiAqIC0gVGFrZXMgY2FyZSBvZiBgRXJyb3JgIG9iamVjdCBzZXJpYWxpemF0aW9uXG4gKiAtIE9wdGlvbmFsbHkgbGltaXRzIGRlcHRoIG9mIGZpbmFsIG91dHB1dFxuICogLSBPcHRpb25hbGx5IGxpbWl0cyBudW1iZXIgb2YgcHJvcGVydGllcy9lbGVtZW50cyBpbmNsdWRlZCBpbiBhbnkgc2luZ2xlIG9iamVjdC9hcnJheVxuICpcbiAqIEBwYXJhbSBpbnB1dCBUaGUgb2JqZWN0IHRvIGJlIG5vcm1hbGl6ZWQuXG4gKiBAcGFyYW0gZGVwdGggVGhlIG1heCBkZXB0aCB0byB3aGljaCB0byBub3JtYWxpemUgdGhlIG9iamVjdC4gKEFueXRoaW5nIGRlZXBlciBzdHJpbmdpZmllZCB3aG9sZS4pXG4gKiBAcGFyYW0gbWF4UHJvcGVydGllcyBUaGUgbWF4IG51bWJlciBvZiBlbGVtZW50cyBvciBwcm9wZXJ0aWVzIHRvIGJlIGluY2x1ZGVkIGluIGFueSBzaW5nbGUgYXJyYXkgb3JcbiAqIG9iamVjdCBpbiB0aGUgbm9ybWFsaXplZCBvdXRwdXQuXG4gKiBAcmV0dXJucyBBIG5vcm1hbGl6ZWQgdmVyc2lvbiBvZiB0aGUgb2JqZWN0LCBvciBgXCIqKm5vbi1zZXJpYWxpemFibGUqKlwiYCBpZiBhbnkgZXJyb3JzIGFyZSB0aHJvd24gZHVyaW5nIG5vcm1hbGl6YXRpb24uXG4gKi9cbi8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tZXhwbGljaXQtYW55XG5mdW5jdGlvbiBub3JtYWxpemUoaW5wdXQsIGRlcHRoID0gMTAwLCBtYXhQcm9wZXJ0aWVzID0gK0luZmluaXR5KSB7XG4gIHRyeSB7XG4gICAgLy8gc2luY2Ugd2UncmUgYXQgdGhlIG91dGVybW9zdCBsZXZlbCwgd2UgZG9uJ3QgcHJvdmlkZSBhIGtleVxuICAgIHJldHVybiB2aXNpdCgnJywgaW5wdXQsIGRlcHRoLCBtYXhQcm9wZXJ0aWVzKTtcbiAgfSBjYXRjaCAoZXJyKSB7XG4gICAgcmV0dXJuIHsgRVJST1I6IGAqKm5vbi1zZXJpYWxpemFibGUqKiAoJHtlcnJ9KWAgfTtcbiAgfVxufVxuXG4vKiogSlNEb2MgKi9cbmZ1bmN0aW9uIG5vcm1hbGl6ZVRvU2l6ZShcbiAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uby1leHBsaWNpdC1hbnlcbiAgb2JqZWN0LFxuICAvLyBEZWZhdWx0IE5vZGUuanMgUkVQTCBkZXB0aFxuICBkZXB0aCA9IDMsXG4gIC8vIDEwMGtCLCBhcyAyMDBrQiBpcyBtYXggcGF5bG9hZCBzaXplLCBzbyBoYWxmIHNvdW5kcyByZWFzb25hYmxlXG4gIG1heFNpemUgPSAxMDAgKiAxMDI0LFxuKSB7XG4gIGNvbnN0IG5vcm1hbGl6ZWQgPSBub3JtYWxpemUob2JqZWN0LCBkZXB0aCk7XG5cbiAgaWYgKGpzb25TaXplKG5vcm1hbGl6ZWQpID4gbWF4U2l6ZSkge1xuICAgIHJldHVybiBub3JtYWxpemVUb1NpemUob2JqZWN0LCBkZXB0aCAtIDEsIG1heFNpemUpO1xuICB9XG5cbiAgcmV0dXJuIG5vcm1hbGl6ZWQgO1xufVxuXG4vKipcbiAqIFZpc2l0cyBhIG5vZGUgdG8gcGVyZm9ybSBub3JtYWxpemF0aW9uIG9uIGl0XG4gKlxuICogQHBhcmFtIGtleSBUaGUga2V5IGNvcnJlc3BvbmRpbmcgdG8gdGhlIGdpdmVuIG5vZGVcbiAqIEBwYXJhbSB2YWx1ZSBUaGUgbm9kZSB0byBiZSB2aXNpdGVkXG4gKiBAcGFyYW0gZGVwdGggT3B0aW9uYWwgbnVtYmVyIGluZGljYXRpbmcgdGhlIG1heGltdW0gcmVjdXJzaW9uIGRlcHRoXG4gKiBAcGFyYW0gbWF4UHJvcGVydGllcyBPcHRpb25hbCBtYXhpbXVtIG51bWJlciBvZiBwcm9wZXJ0aWVzL2VsZW1lbnRzIGluY2x1ZGVkIGluIGFueSBzaW5nbGUgb2JqZWN0L2FycmF5XG4gKiBAcGFyYW0gbWVtbyBPcHRpb25hbCBNZW1vIGNsYXNzIGhhbmRsaW5nIGRlY3ljbGluZ1xuICovXG5mdW5jdGlvbiB2aXNpdChcbiAga2V5LFxuICB2YWx1ZSxcbiAgZGVwdGggPSArSW5maW5pdHksXG4gIG1heFByb3BlcnRpZXMgPSArSW5maW5pdHksXG4gIG1lbW8gPSBtZW1vQnVpbGRlcigpLFxuKSB7XG4gIGNvbnN0IFttZW1vaXplLCB1bm1lbW9pemVdID0gbWVtbztcblxuICAvLyBHZXQgdGhlIHNpbXBsZSBjYXNlcyBvdXQgb2YgdGhlIHdheSBmaXJzdFxuICBpZiAoXG4gICAgdmFsdWUgPT0gbnVsbCB8fCAvLyB0aGlzIG1hdGNoZXMgbnVsbCBhbmQgdW5kZWZpbmVkIC0+IGVxZXEgbm90IGVxZXFlcVxuICAgIFsnYm9vbGVhbicsICdzdHJpbmcnXS5pbmNsdWRlcyh0eXBlb2YgdmFsdWUpIHx8XG4gICAgKHR5cGVvZiB2YWx1ZSA9PT0gJ251bWJlcicgJiYgTnVtYmVyLmlzRmluaXRlKHZhbHVlKSlcbiAgKSB7XG4gICAgcmV0dXJuIHZhbHVlIDtcbiAgfVxuXG4gIGNvbnN0IHN0cmluZ2lmaWVkID0gc3RyaW5naWZ5VmFsdWUoa2V5LCB2YWx1ZSk7XG5cbiAgLy8gQW55dGhpbmcgd2UgY291bGQgcG90ZW50aWFsbHkgZGlnIGludG8gbW9yZSAob2JqZWN0cyBvciBhcnJheXMpIHdpbGwgaGF2ZSBjb21lIGJhY2sgYXMgYFwiW29iamVjdCBYWFhYXVwiYC5cbiAgLy8gRXZlcnl0aGluZyBlbHNlIHdpbGwgaGF2ZSBhbHJlYWR5IGJlZW4gc2VyaWFsaXplZCwgc28gaWYgd2UgZG9uJ3Qgc2VlIHRoYXQgcGF0dGVybiwgd2UncmUgZG9uZS5cbiAgaWYgKCFzdHJpbmdpZmllZC5zdGFydHNXaXRoKCdbb2JqZWN0ICcpKSB7XG4gICAgcmV0dXJuIHN0cmluZ2lmaWVkO1xuICB9XG5cbiAgLy8gRnJvbSBoZXJlIG9uLCB3ZSBjYW4gYXNzZXJ0IHRoYXQgYHZhbHVlYCBpcyBlaXRoZXIgYW4gb2JqZWN0IG9yIGFuIGFycmF5LlxuXG4gIC8vIERvIG5vdCBub3JtYWxpemUgb2JqZWN0cyB0aGF0IHdlIGtub3cgaGF2ZSBhbHJlYWR5IGJlZW4gbm9ybWFsaXplZC4gQXMgYSBnZW5lcmFsIHJ1bGUsIHRoZVxuICAvLyBcIl9fc2VudHJ5X3NraXBfbm9ybWFsaXphdGlvbl9fXCIgcHJvcGVydHkgc2hvdWxkIG9ubHkgYmUgdXNlZCBzcGFyaW5nbHkgYW5kIG9ubHkgc2hvdWxkIG9ubHkgYmUgc2V0IG9uIG9iamVjdHMgdGhhdFxuICAvLyBoYXZlIGFscmVhZHkgYmVlbiBub3JtYWxpemVkLlxuICBpZiAoKHZhbHVlIClbJ19fc2VudHJ5X3NraXBfbm9ybWFsaXphdGlvbl9fJ10pIHtcbiAgICByZXR1cm4gdmFsdWUgO1xuICB9XG5cbiAgLy8gV2UgY2FuIHNldCBgX19zZW50cnlfb3ZlcnJpZGVfbm9ybWFsaXphdGlvbl9kZXB0aF9fYCBvbiBhbiBvYmplY3QgdG8gZW5zdXJlIHRoYXQgZnJvbSB0aGVyZVxuICAvLyBXZSBrZWVwIGEgY2VydGFpbiBhbW91bnQgb2YgZGVwdGguXG4gIC8vIFRoaXMgc2hvdWxkIGJlIHVzZWQgc3BhcmluZ2x5LCBlLmcuIHdlIHVzZSBpdCBmb3IgdGhlIHJlZHV4IGludGVncmF0aW9uIHRvIGVuc3VyZSB3ZSBnZXQgYSBjZXJ0YWluIGFtb3VudCBvZiBzdGF0ZS5cbiAgY29uc3QgcmVtYWluaW5nRGVwdGggPVxuICAgIHR5cGVvZiAodmFsdWUgKVsnX19zZW50cnlfb3ZlcnJpZGVfbm9ybWFsaXphdGlvbl9kZXB0aF9fJ10gPT09ICdudW1iZXInXG4gICAgICA/ICgodmFsdWUgKVsnX19zZW50cnlfb3ZlcnJpZGVfbm9ybWFsaXphdGlvbl9kZXB0aF9fJ10gKVxuICAgICAgOiBkZXB0aDtcblxuICAvLyBXZSdyZSBhbHNvIGRvbmUgaWYgd2UndmUgcmVhY2hlZCB0aGUgbWF4IGRlcHRoXG4gIGlmIChyZW1haW5pbmdEZXB0aCA9PT0gMCkge1xuICAgIC8vIEF0IHRoaXMgcG9pbnQgd2Uga25vdyBgc2VyaWFsaXplZGAgaXMgYSBzdHJpbmcgb2YgdGhlIGZvcm0gYFwiW29iamVjdCBYWFhYXVwiYC4gQ2xlYW4gaXQgdXAgc28gaXQncyBqdXN0IGBcIltYWFhYXVwiYC5cbiAgICByZXR1cm4gc3RyaW5naWZpZWQucmVwbGFjZSgnb2JqZWN0ICcsICcnKTtcbiAgfVxuXG4gIC8vIElmIHdlJ3ZlIGFscmVhZHkgdmlzaXRlZCB0aGlzIGJyYW5jaCwgYmFpbCBvdXQsIGFzIGl0J3MgY2lyY3VsYXIgcmVmZXJlbmNlLiBJZiBub3QsIG5vdGUgdGhhdCB3ZSdyZSBzZWVpbmcgaXQgbm93LlxuICBpZiAobWVtb2l6ZSh2YWx1ZSkpIHtcbiAgICByZXR1cm4gJ1tDaXJjdWxhciB+XSc7XG4gIH1cblxuICAvLyBJZiB0aGUgdmFsdWUgaGFzIGEgYHRvSlNPTmAgbWV0aG9kLCB3ZSBjYWxsIGl0IHRvIGV4dHJhY3QgbW9yZSBpbmZvcm1hdGlvblxuICBjb25zdCB2YWx1ZVdpdGhUb0pTT04gPSB2YWx1ZSA7XG4gIGlmICh2YWx1ZVdpdGhUb0pTT04gJiYgdHlwZW9mIHZhbHVlV2l0aFRvSlNPTi50b0pTT04gPT09ICdmdW5jdGlvbicpIHtcbiAgICB0cnkge1xuICAgICAgY29uc3QganNvblZhbHVlID0gdmFsdWVXaXRoVG9KU09OLnRvSlNPTigpO1xuICAgICAgLy8gV2UgbmVlZCB0byBub3JtYWxpemUgdGhlIHJldHVybiB2YWx1ZSBvZiBgLnRvSlNPTigpYCBpbiBjYXNlIGl0IGhhcyBjaXJjdWxhciByZWZlcmVuY2VzXG4gICAgICByZXR1cm4gdmlzaXQoJycsIGpzb25WYWx1ZSwgcmVtYWluaW5nRGVwdGggLSAxLCBtYXhQcm9wZXJ0aWVzLCBtZW1vKTtcbiAgICB9IGNhdGNoIHtcbiAgICAgIC8vIHBhc3MgKFRoZSBidWlsdC1pbiBgdG9KU09OYCBmYWlsZWQsIGJ1dCB3ZSBjYW4gc3RpbGwgdHJ5IHRvIGRvIGl0IG91cnNlbHZlcylcbiAgICB9XG4gIH1cblxuICAvLyBBdCB0aGlzIHBvaW50IHdlIGtub3cgd2UgZWl0aGVyIGhhdmUgYW4gb2JqZWN0IG9yIGFuIGFycmF5LCB3ZSBoYXZlbid0IHNlZW4gaXQgYmVmb3JlLCBhbmQgd2UncmUgZ29pbmcgdG8gcmVjdXJzZVxuICAvLyBiZWNhdXNlIHdlIGhhdmVuJ3QgeWV0IHJlYWNoZWQgdGhlIG1heCBkZXB0aC4gQ3JlYXRlIGFuIGFjY3VtdWxhdG9yIHRvIGhvbGQgdGhlIHJlc3VsdHMgb2YgdmlzaXRpbmcgZWFjaFxuICAvLyBwcm9wZXJ0eS9lbnRyeSwgYW5kIGtlZXAgdHJhY2sgb2YgdGhlIG51bWJlciBvZiBpdGVtcyB3ZSBhZGQgdG8gaXQuXG4gIGNvbnN0IG5vcm1hbGl6ZWQgPSAoQXJyYXkuaXNBcnJheSh2YWx1ZSkgPyBbXSA6IHt9KSA7XG4gIGxldCBudW1BZGRlZCA9IDA7XG5cbiAgLy8gQmVmb3JlIHdlIGJlZ2luLCBjb252ZXJ0YEVycm9yYCBhbmRgRXZlbnRgIGluc3RhbmNlcyBpbnRvIHBsYWluIG9iamVjdHMsIHNpbmNlIHNvbWUgb2YgZWFjaCBvZiB0aGVpciByZWxldmFudFxuICAvLyBwcm9wZXJ0aWVzIGFyZSBub24tZW51bWVyYWJsZSBhbmQgb3RoZXJ3aXNlIHdvdWxkIGdldCBtaXNzZWQuXG4gIGNvbnN0IHZpc2l0YWJsZSA9IG9iamVjdC5jb252ZXJ0VG9QbGFpbk9iamVjdCh2YWx1ZSApO1xuXG4gIGZvciAoY29uc3QgdmlzaXRLZXkgaW4gdmlzaXRhYmxlKSB7XG4gICAgLy8gQXZvaWQgaXRlcmF0aW5nIG92ZXIgZmllbGRzIGluIHRoZSBwcm90b3R5cGUgaWYgdGhleSd2ZSBzb21laG93IGJlZW4gZXhwb3NlZCB0byBlbnVtZXJhdGlvbi5cbiAgICBpZiAoIU9iamVjdC5wcm90b3R5cGUuaGFzT3duUHJvcGVydHkuY2FsbCh2aXNpdGFibGUsIHZpc2l0S2V5KSkge1xuICAgICAgY29udGludWU7XG4gICAgfVxuXG4gICAgaWYgKG51bUFkZGVkID49IG1heFByb3BlcnRpZXMpIHtcbiAgICAgIG5vcm1hbGl6ZWRbdmlzaXRLZXldID0gJ1tNYXhQcm9wZXJ0aWVzIH5dJztcbiAgICAgIGJyZWFrO1xuICAgIH1cblxuICAgIC8vIFJlY3Vyc2l2ZWx5IHZpc2l0IGFsbCB0aGUgY2hpbGQgbm9kZXNcbiAgICBjb25zdCB2aXNpdFZhbHVlID0gdmlzaXRhYmxlW3Zpc2l0S2V5XTtcbiAgICBub3JtYWxpemVkW3Zpc2l0S2V5XSA9IHZpc2l0KHZpc2l0S2V5LCB2aXNpdFZhbHVlLCByZW1haW5pbmdEZXB0aCAtIDEsIG1heFByb3BlcnRpZXMsIG1lbW8pO1xuXG4gICAgbnVtQWRkZWQrKztcbiAgfVxuXG4gIC8vIE9uY2Ugd2UndmUgdmlzaXRlZCBhbGwgdGhlIGJyYW5jaGVzLCByZW1vdmUgdGhlIHBhcmVudCBmcm9tIG1lbW8gc3RvcmFnZVxuICB1bm1lbW9pemUodmFsdWUpO1xuXG4gIC8vIFJldHVybiBhY2N1bXVsYXRlZCB2YWx1ZXNcbiAgcmV0dXJuIG5vcm1hbGl6ZWQ7XG59XG5cbi8qIGVzbGludC1kaXNhYmxlIGNvbXBsZXhpdHkgKi9cbi8qKlxuICogU3RyaW5naWZ5IHRoZSBnaXZlbiB2YWx1ZS4gSGFuZGxlcyB2YXJpb3VzIGtub3duIHNwZWNpYWwgdmFsdWVzIGFuZCB0eXBlcy5cbiAqXG4gKiBOb3QgbWVhbnQgdG8gYmUgdXNlZCBvbiBzaW1wbGUgcHJpbWl0aXZlcyB3aGljaCBhbHJlYWR5IGhhdmUgYSBzdHJpbmcgcmVwcmVzZW50YXRpb24sIGFzIGl0IHdpbGwsIGZvciBleGFtcGxlLCB0dXJuXG4gKiB0aGUgbnVtYmVyIDEyMzEgaW50byBcIltPYmplY3QgTnVtYmVyXVwiLCBub3Igb24gYG51bGxgLCBhcyBpdCB3aWxsIHRocm93LlxuICpcbiAqIEBwYXJhbSB2YWx1ZSBUaGUgdmFsdWUgdG8gc3RyaW5naWZ5XG4gKiBAcmV0dXJucyBBIHN0cmluZ2lmaWVkIHJlcHJlc2VudGF0aW9uIG9mIHRoZSBnaXZlbiB2YWx1ZVxuICovXG5mdW5jdGlvbiBzdHJpbmdpZnlWYWx1ZShcbiAga2V5LFxuICAvLyB0aGlzIHR5cGUgaXMgYSB0aW55IGJpdCBvZiBhIGNoZWF0LCBzaW5jZSB0aGlzIGZ1bmN0aW9uIGRvZXMgaGFuZGxlIE5hTiAod2hpY2ggaXMgdGVjaG5pY2FsbHkgYSBudW1iZXIpLCBidXQgZm9yXG4gIC8vIG91ciBpbnRlcm5hbCB1c2UsIGl0J2xsIGRvXG4gIHZhbHVlLFxuKSB7XG4gIHRyeSB7XG4gICAgaWYgKGtleSA9PT0gJ2RvbWFpbicgJiYgdmFsdWUgJiYgdHlwZW9mIHZhbHVlID09PSAnb2JqZWN0JyAmJiAodmFsdWUgKS5fZXZlbnRzKSB7XG4gICAgICByZXR1cm4gJ1tEb21haW5dJztcbiAgICB9XG5cbiAgICBpZiAoa2V5ID09PSAnZG9tYWluRW1pdHRlcicpIHtcbiAgICAgIHJldHVybiAnW0RvbWFpbkVtaXR0ZXJdJztcbiAgICB9XG5cbiAgICAvLyBJdCdzIHNhZmUgdG8gdXNlIGBnbG9iYWxgLCBgd2luZG93YCwgYW5kIGBkb2N1bWVudGAgaGVyZSBpbiB0aGlzIG1hbm5lciwgYXMgd2UgYXJlIGFzc2VydGluZyB1c2luZyBgdHlwZW9mYCBmaXJzdFxuICAgIC8vIHdoaWNoIHdvbid0IHRocm93IGlmIHRoZXkgYXJlIG5vdCBwcmVzZW50LlxuXG4gICAgaWYgKHR5cGVvZiBnbG9iYWwgIT09ICd1bmRlZmluZWQnICYmIHZhbHVlID09PSBnbG9iYWwpIHtcbiAgICAgIHJldHVybiAnW0dsb2JhbF0nO1xuICAgIH1cblxuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBuby1yZXN0cmljdGVkLWdsb2JhbHNcbiAgICBpZiAodHlwZW9mIHdpbmRvdyAhPT0gJ3VuZGVmaW5lZCcgJiYgdmFsdWUgPT09IHdpbmRvdykge1xuICAgICAgcmV0dXJuICdbV2luZG93XSc7XG4gICAgfVxuXG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIG5vLXJlc3RyaWN0ZWQtZ2xvYmFsc1xuICAgIGlmICh0eXBlb2YgZG9jdW1lbnQgIT09ICd1bmRlZmluZWQnICYmIHZhbHVlID09PSBkb2N1bWVudCkge1xuICAgICAgcmV0dXJuICdbRG9jdW1lbnRdJztcbiAgICB9XG5cbiAgICBpZiAoaXMuaXNWdWVWaWV3TW9kZWwodmFsdWUpKSB7XG4gICAgICByZXR1cm4gJ1tWdWVWaWV3TW9kZWxdJztcbiAgICB9XG5cbiAgICAvLyBSZWFjdCdzIFN5bnRoZXRpY0V2ZW50IHRoaW5neVxuICAgIGlmIChpcy5pc1N5bnRoZXRpY0V2ZW50KHZhbHVlKSkge1xuICAgICAgcmV0dXJuICdbU3ludGhldGljRXZlbnRdJztcbiAgICB9XG5cbiAgICBpZiAodHlwZW9mIHZhbHVlID09PSAnbnVtYmVyJyAmJiAhTnVtYmVyLmlzRmluaXRlKHZhbHVlKSkge1xuICAgICAgcmV0dXJuIGBbJHt2YWx1ZX1dYDtcbiAgICB9XG5cbiAgICBpZiAodHlwZW9mIHZhbHVlID09PSAnZnVuY3Rpb24nKSB7XG4gICAgICByZXR1cm4gYFtGdW5jdGlvbjogJHtzdGFja3RyYWNlLmdldEZ1bmN0aW9uTmFtZSh2YWx1ZSl9XWA7XG4gICAgfVxuXG4gICAgaWYgKHR5cGVvZiB2YWx1ZSA9PT0gJ3N5bWJvbCcpIHtcbiAgICAgIHJldHVybiBgWyR7U3RyaW5nKHZhbHVlKX1dYDtcbiAgICB9XG5cbiAgICAvLyBzdHJpbmdpZmllZCBCaWdJbnRzIGFyZSBpbmRpc3Rpbmd1aXNoYWJsZSBmcm9tIHJlZ3VsYXIgbnVtYmVycywgc28gd2UgbmVlZCB0byBsYWJlbCB0aGVtIHRvIGF2b2lkIGNvbmZ1c2lvblxuICAgIGlmICh0eXBlb2YgdmFsdWUgPT09ICdiaWdpbnQnKSB7XG4gICAgICByZXR1cm4gYFtCaWdJbnQ6ICR7U3RyaW5nKHZhbHVlKX1dYDtcbiAgICB9XG5cbiAgICAvLyBOb3cgdGhhdCB3ZSd2ZSBrbm9ja2VkIG91dCBhbGwgdGhlIHNwZWNpYWwgY2FzZXMgYW5kIHRoZSBwcmltaXRpdmVzLCBhbGwgd2UgaGF2ZSBsZWZ0IGFyZSBvYmplY3RzLiBTaW1wbHkgY2FzdGluZ1xuICAgIC8vIHRoZW0gdG8gc3RyaW5ncyBtZWFucyB0aGF0IGluc3RhbmNlcyBvZiBjbGFzc2VzIHdoaWNoIGhhdmVuJ3QgZGVmaW5lZCB0aGVpciBgdG9TdHJpbmdUYWdgIHdpbGwganVzdCBjb21lIG91dCBhc1xuICAgIC8vIGBcIltvYmplY3QgT2JqZWN0XVwiYC4gSWYgd2UgaW5zdGVhZCBsb29rIGF0IHRoZSBjb25zdHJ1Y3RvcidzIG5hbWUgKHdoaWNoIGlzIHRoZSBzYW1lIGFzIHRoZSBuYW1lIG9mIHRoZSBjbGFzcyksXG4gICAgLy8gd2UgY2FuIG1ha2Ugc3VyZSB0aGF0IG9ubHkgcGxhaW4gb2JqZWN0cyBjb21lIG91dCB0aGF0IHdheS5cbiAgICBjb25zdCBvYmpOYW1lID0gZ2V0Q29uc3RydWN0b3JOYW1lKHZhbHVlKTtcblxuICAgIC8vIEhhbmRsZSBIVE1MIEVsZW1lbnRzXG4gICAgaWYgKC9eSFRNTChcXHcqKUVsZW1lbnQkLy50ZXN0KG9iak5hbWUpKSB7XG4gICAgICByZXR1cm4gYFtIVE1MRWxlbWVudDogJHtvYmpOYW1lfV1gO1xuICAgIH1cblxuICAgIHJldHVybiBgW29iamVjdCAke29iak5hbWV9XWA7XG4gIH0gY2F0Y2ggKGVycikge1xuICAgIHJldHVybiBgKipub24tc2VyaWFsaXphYmxlKiogKCR7ZXJyfSlgO1xuICB9XG59XG4vKiBlc2xpbnQtZW5hYmxlIGNvbXBsZXhpdHkgKi9cblxuZnVuY3Rpb24gZ2V0Q29uc3RydWN0b3JOYW1lKHZhbHVlKSB7XG4gIGNvbnN0IHByb3RvdHlwZSA9IE9iamVjdC5nZXRQcm90b3R5cGVPZih2YWx1ZSk7XG5cbiAgcmV0dXJuIHByb3RvdHlwZT8uY29uc3RydWN0b3IgPyBwcm90b3R5cGUuY29uc3RydWN0b3IubmFtZSA6ICdudWxsIHByb3RvdHlwZSc7XG59XG5cbi8qKiBDYWxjdWxhdGVzIGJ5dGVzIHNpemUgb2YgaW5wdXQgc3RyaW5nICovXG5mdW5jdGlvbiB1dGY4TGVuZ3RoKHZhbHVlKSB7XG4gIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBuby1iaXR3aXNlXG4gIHJldHVybiB+LWVuY29kZVVSSSh2YWx1ZSkuc3BsaXQoLyUuLnwuLykubGVuZ3RoO1xufVxuXG4vKiogQ2FsY3VsYXRlcyBieXRlcyBzaXplIG9mIGlucHV0IG9iamVjdCAqL1xuLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uby1leHBsaWNpdC1hbnlcbmZ1bmN0aW9uIGpzb25TaXplKHZhbHVlKSB7XG4gIHJldHVybiB1dGY4TGVuZ3RoKEpTT04uc3RyaW5naWZ5KHZhbHVlKSk7XG59XG5cbi8qKlxuICogTm9ybWFsaXplcyBVUkxzIGluIGV4Y2VwdGlvbnMgYW5kIHN0YWNrdHJhY2VzIHRvIGEgYmFzZSBwYXRoIHNvIFNlbnRyeSBjYW4gZmluZ2VycHJpbnRcbiAqIGFjcm9zcyBwbGF0Zm9ybXMgYW5kIHdvcmtpbmcgZGlyZWN0b3J5LlxuICpcbiAqIEBwYXJhbSB1cmwgVGhlIFVSTCB0byBiZSBub3JtYWxpemVkLlxuICogQHBhcmFtIGJhc2VQYXRoIFRoZSBhcHBsaWNhdGlvbiBiYXNlIHBhdGguXG4gKiBAcmV0dXJucyBUaGUgbm9ybWFsaXplZCBVUkwuXG4gKi9cbmZ1bmN0aW9uIG5vcm1hbGl6ZVVybFRvQmFzZSh1cmwsIGJhc2VQYXRoKSB7XG4gIGNvbnN0IGVzY2FwZWRCYXNlID0gYmFzZVBhdGhcbiAgICAvLyBCYWNrc2xhc2ggdG8gZm9yd2FyZFxuICAgIC5yZXBsYWNlKC9cXFxcL2csICcvJylcbiAgICAvLyBFc2NhcGUgUmVnRXhwIHNwZWNpYWwgY2hhcmFjdGVyc1xuICAgIC5yZXBsYWNlKC9bfFxcXFx7fSgpW1xcXV4kKyo/Ll0vZywgJ1xcXFwkJicpO1xuXG4gIGxldCBuZXdVcmwgPSB1cmw7XG4gIHRyeSB7XG4gICAgbmV3VXJsID0gZGVjb2RlVVJJKHVybCk7XG4gIH0gY2F0Y2gge1xuICAgIC8vIFNvbWV0aW1lIHRoaXMgYnJlYWtzXG4gIH1cbiAgcmV0dXJuIChcbiAgICBuZXdVcmxcbiAgICAgIC5yZXBsYWNlKC9cXFxcL2csICcvJylcbiAgICAgIC5yZXBsYWNlKC93ZWJwYWNrOlxcLz8vZywgJycpIC8vIFJlbW92ZSBpbnRlcm1lZGlhdGUgYmFzZSBwYXRoXG4gICAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHNlbnRyeS1pbnRlcm5hbC9zZGsvbm8tcmVnZXhwLWNvbnN0cnVjdG9yXG4gICAgICAucmVwbGFjZShuZXcgUmVnRXhwKGAoZmlsZTovLyk/Lyoke2VzY2FwZWRCYXNlfS8qYCwgJ2lnJyksICdhcHA6Ly8vJylcbiAgKTtcbn1cblxuLyoqXG4gKiBIZWxwZXIgdG8gZGVjeWNsZSBqc29uIG9iamVjdHNcbiAqL1xuZnVuY3Rpb24gbWVtb0J1aWxkZXIoKSB7XG4gIGNvbnN0IGlubmVyID0gbmV3IFdlYWtTZXQoKTtcbiAgZnVuY3Rpb24gbWVtb2l6ZShvYmopIHtcbiAgICBpZiAoaW5uZXIuaGFzKG9iaikpIHtcbiAgICAgIHJldHVybiB0cnVlO1xuICAgIH1cbiAgICBpbm5lci5hZGQob2JqKTtcbiAgICByZXR1cm4gZmFsc2U7XG4gIH1cblxuICBmdW5jdGlvbiB1bm1lbW9pemUob2JqKSB7XG4gICAgaW5uZXIuZGVsZXRlKG9iaik7XG4gIH1cbiAgcmV0dXJuIFttZW1vaXplLCB1bm1lbW9pemVdO1xufVxuXG5leHBvcnRzLm5vcm1hbGl6ZSA9IG5vcm1hbGl6ZTtcbmV4cG9ydHMubm9ybWFsaXplVG9TaXplID0gbm9ybWFsaXplVG9TaXplO1xuZXhwb3J0cy5ub3JtYWxpemVVcmxUb0Jhc2UgPSBub3JtYWxpemVVcmxUb0Jhc2U7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1ub3JtYWxpemUuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/normalize.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/object.js":
/*!****************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/object.js ***!
  \****************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst debugBuild = __webpack_require__(/*! ../debug-build.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst browser = __webpack_require__(/*! ./browser.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/browser.js\");\nconst debugLogger = __webpack_require__(/*! ./debug-logger.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst is = __webpack_require__(/*! ./is.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js\");\nconst string = __webpack_require__(/*! ./string.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/string.js\");\n\n/* eslint-disable @typescript-eslint/no-explicit-any */\n\n/**\n * Replace a method in an object with a wrapped version of itself.\n *\n * If the method on the passed object is not a function, the wrapper will not be applied.\n *\n * @param source An object that contains a method to be wrapped.\n * @param name The name of the method to be wrapped.\n * @param replacementFactory A higher-order function that takes the original version of the given method and returns a\n * wrapped version. Note: The function returned by `replacementFactory` needs to be a non-arrow function, in order to\n * preserve the correct value of `this`, and the original method must be called using `origMethod.call(this, <other\n * args>)` or `origMethod.apply(this, [<other args>])` (rather than being called directly), again to preserve `this`.\n * @returns void\n */\nfunction fill(source, name, replacementFactory) {\n  if (!(name in source)) {\n    return;\n  }\n\n  // explicitly casting to unknown because we don't know the type of the method initially at all\n  const original = source[name] ;\n\n  if (typeof original !== 'function') {\n    return;\n  }\n\n  const wrapped = replacementFactory(original) ;\n\n  // Make sure it's a function first, as we need to attach an empty prototype for `defineProperties` to work\n  // otherwise it'll throw \"TypeError: Object.defineProperties called on non-object\"\n  if (typeof wrapped === 'function') {\n    markFunctionWrapped(wrapped, original);\n  }\n\n  try {\n    source[name] = wrapped;\n  } catch {\n    debugBuild.DEBUG_BUILD && debugLogger.debug.log(`Failed to replace method \"${name}\" in object`, source);\n  }\n}\n\n/**\n * Defines a non-enumerable property on the given object.\n *\n * @param obj The object on which to set the property\n * @param name The name of the property to be set\n * @param value The value to which to set the property\n */\nfunction addNonEnumerableProperty(obj, name, value) {\n  try {\n    Object.defineProperty(obj, name, {\n      // enumerable: false, // the default, so we can save on bundle size by not explicitly setting it\n      value: value,\n      writable: true,\n      configurable: true,\n    });\n  } catch {\n    debugBuild.DEBUG_BUILD && debugLogger.debug.log(`Failed to add non-enumerable property \"${name}\" to object`, obj);\n  }\n}\n\n/**\n * Remembers the original function on the wrapped function and\n * patches up the prototype.\n *\n * @param wrapped the wrapper function\n * @param original the original function that gets wrapped\n */\nfunction markFunctionWrapped(wrapped, original) {\n  try {\n    const proto = original.prototype || {};\n    wrapped.prototype = original.prototype = proto;\n    addNonEnumerableProperty(wrapped, '__sentry_original__', original);\n  } catch {} // eslint-disable-line no-empty\n}\n\n/**\n * This extracts the original function if available.  See\n * `markFunctionWrapped` for more information.\n *\n * @param func the function to unwrap\n * @returns the unwrapped version of the function if available.\n */\n// eslint-disable-next-line @typescript-eslint/ban-types\nfunction getOriginalFunction(func) {\n  return func.__sentry_original__;\n}\n\n/**\n * Transforms any `Error` or `Event` into a plain object with all of their enumerable properties, and some of their\n * non-enumerable properties attached.\n *\n * @param value Initial source that we have to transform in order for it to be usable by the serializer\n * @returns An Event or Error turned into an object - or the value argument itself, when value is neither an Event nor\n *  an Error.\n */\nfunction convertToPlainObject(value)\n\n {\n  if (is.isError(value)) {\n    return {\n      message: value.message,\n      name: value.name,\n      stack: value.stack,\n      ...getOwnProperties(value),\n    };\n  } else if (is.isEvent(value)) {\n    const newObj\n\n = {\n      type: value.type,\n      target: serializeEventTarget(value.target),\n      currentTarget: serializeEventTarget(value.currentTarget),\n      ...getOwnProperties(value),\n    };\n\n    if (typeof CustomEvent !== 'undefined' && is.isInstanceOf(value, CustomEvent)) {\n      newObj.detail = value.detail;\n    }\n\n    return newObj;\n  } else {\n    return value;\n  }\n}\n\n/** Creates a string representation of the target of an `Event` object */\nfunction serializeEventTarget(target) {\n  try {\n    return is.isElement(target) ? browser.htmlTreeAsString(target) : Object.prototype.toString.call(target);\n  } catch {\n    return '<unknown>';\n  }\n}\n\n/** Filters out all but an object's own properties */\nfunction getOwnProperties(obj) {\n  if (typeof obj === 'object' && obj !== null) {\n    const extractedProps = {};\n    for (const property in obj) {\n      if (Object.prototype.hasOwnProperty.call(obj, property)) {\n        extractedProps[property] = (obj )[property];\n      }\n    }\n    return extractedProps;\n  } else {\n    return {};\n  }\n}\n\n/**\n * Given any captured exception, extract its keys and create a sorted\n * and truncated list that will be used inside the event message.\n * eg. `Non-error exception captured with keys: foo, bar, baz`\n */\nfunction extractExceptionKeysForMessage(exception, maxLength = 40) {\n  const keys = Object.keys(convertToPlainObject(exception));\n  keys.sort();\n\n  const firstKey = keys[0];\n\n  if (!firstKey) {\n    return '[object has no keys]';\n  }\n\n  if (firstKey.length >= maxLength) {\n    return string.truncate(firstKey, maxLength);\n  }\n\n  for (let includedKeys = keys.length; includedKeys > 0; includedKeys--) {\n    const serialized = keys.slice(0, includedKeys).join(', ');\n    if (serialized.length > maxLength) {\n      continue;\n    }\n    if (includedKeys === keys.length) {\n      return serialized;\n    }\n    return string.truncate(serialized, maxLength);\n  }\n\n  return '';\n}\n\n/**\n * Given any object, return a new object having removed all fields whose value was `undefined`.\n * Works recursively on objects and arrays.\n *\n * Attention: This function keeps circular references in the returned object.\n *\n * @deprecated This function is no longer used by the SDK and will be removed in a future major version.\n */\nfunction dropUndefinedKeys(inputValue) {\n  // This map keeps track of what already visited nodes map to.\n  // Our Set - based memoBuilder doesn't work here because we want to the output object to have the same circular\n  // references as the input object.\n  const memoizationMap = new Map();\n\n  // This function just proxies `_dropUndefinedKeys` to keep the `memoBuilder` out of this function's API\n  return _dropUndefinedKeys(inputValue, memoizationMap);\n}\n\nfunction _dropUndefinedKeys(inputValue, memoizationMap) {\n  // Early return for primitive values\n  if (inputValue === null || typeof inputValue !== 'object') {\n    return inputValue;\n  }\n\n  // Check memo map first for all object types\n  const memoVal = memoizationMap.get(inputValue);\n  if (memoVal !== undefined) {\n    return memoVal ;\n  }\n\n  // handle arrays\n  if (Array.isArray(inputValue)) {\n    const returnValue = [];\n    // Store mapping to handle circular references\n    memoizationMap.set(inputValue, returnValue);\n\n    inputValue.forEach(value => {\n      returnValue.push(_dropUndefinedKeys(value, memoizationMap));\n    });\n\n    return returnValue ;\n  }\n\n  if (isPojo(inputValue)) {\n    const returnValue = {};\n    // Store mapping to handle circular references\n    memoizationMap.set(inputValue, returnValue);\n\n    const keys = Object.keys(inputValue);\n\n    keys.forEach(key => {\n      const val = inputValue[key];\n      if (val !== undefined) {\n        returnValue[key] = _dropUndefinedKeys(val, memoizationMap);\n      }\n    });\n\n    return returnValue ;\n  }\n\n  // For other object types, return as is\n  return inputValue;\n}\n\nfunction isPojo(input) {\n  // Plain objects have Object as constructor or no constructor\n  const constructor = (input ).constructor;\n  return constructor === Object || constructor === undefined;\n}\n\n/**\n * Ensure that something is an object.\n *\n * Turns `undefined` and `null` into `String`s and all other primitives into instances of their respective wrapper\n * classes (String, Boolean, Number, etc.). Acts as the identity function on non-primitives.\n *\n * @param wat The subject of the objectification\n * @returns A version of `wat` which can safely be used with `Object` class methods\n */\nfunction objectify(wat) {\n  let objectified;\n  switch (true) {\n    // this will catch both undefined and null\n    case wat == undefined:\n      objectified = new String(wat);\n      break;\n\n    // Though symbols and bigints do have wrapper classes (`Symbol` and `BigInt`, respectively), for whatever reason\n    // those classes don't have constructors which can be used with the `new` keyword. We therefore need to cast each as\n    // an object in order to wrap it.\n    case typeof wat === 'symbol' || typeof wat === 'bigint':\n      objectified = Object(wat);\n      break;\n\n    // this will catch the remaining primitives: `String`, `Number`, and `Boolean`\n    case is.isPrimitive(wat):\n      // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n      objectified = new (wat ).constructor(wat);\n      break;\n\n    // by process of elimination, at this point we know that `wat` must already be an object\n    default:\n      objectified = wat;\n      break;\n  }\n  return objectified;\n}\n\nexports.addNonEnumerableProperty = addNonEnumerableProperty;\nexports.convertToPlainObject = convertToPlainObject;\nexports.dropUndefinedKeys = dropUndefinedKeys;\nexports.extractExceptionKeysForMessage = extractExceptionKeysForMessage;\nexports.fill = fill;\nexports.getOriginalFunction = getOriginalFunction;\nexports.markFunctionWrapped = markFunctionWrapped;\nexports.objectify = objectify;\n//# sourceMappingURL=object.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9vYmplY3QuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsbUJBQW1CLG1CQUFPLENBQUMsNEhBQW1CO0FBQzlDLGdCQUFnQixtQkFBTyxDQUFDLHlIQUFjO0FBQ3RDLG9CQUFvQixtQkFBTyxDQUFDLG1JQUFtQjtBQUMvQyxXQUFXLG1CQUFPLENBQUMsK0dBQVM7QUFDNUIsZUFBZSxtQkFBTyxDQUFDLHVIQUFhOztBQUVwQzs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLElBQUk7QUFDSixpRkFBaUYsS0FBSztBQUN0RjtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxLQUFLO0FBQ0wsSUFBSTtBQUNKLDhGQUE4RixLQUFLO0FBQ25HO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsSUFBSSxTQUFTO0FBQ2I7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLElBQUk7QUFDSjs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0EsSUFBSTtBQUNKO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLElBQUk7QUFDSjtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxJQUFJO0FBQ0o7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQSx1Q0FBdUMsa0JBQWtCO0FBQ3pEO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsS0FBSzs7QUFFTDtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxLQUFLOztBQUVMO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsZ0NBQWdDO0FBQ2hDLDRCQUE0QjtBQUM1Qix5QkFBeUI7QUFDekIsc0NBQXNDO0FBQ3RDLFlBQVk7QUFDWiwyQkFBMkI7QUFDM0IsMkJBQTJCO0FBQzNCLGlCQUFpQjtBQUNqQiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3V0aWxzL29iamVjdC5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgZGVidWdCdWlsZCA9IHJlcXVpcmUoJy4uL2RlYnVnLWJ1aWxkLmpzJyk7XG5jb25zdCBicm93c2VyID0gcmVxdWlyZSgnLi9icm93c2VyLmpzJyk7XG5jb25zdCBkZWJ1Z0xvZ2dlciA9IHJlcXVpcmUoJy4vZGVidWctbG9nZ2VyLmpzJyk7XG5jb25zdCBpcyA9IHJlcXVpcmUoJy4vaXMuanMnKTtcbmNvbnN0IHN0cmluZyA9IHJlcXVpcmUoJy4vc3RyaW5nLmpzJyk7XG5cbi8qIGVzbGludC1kaXNhYmxlIEB0eXBlc2NyaXB0LWVzbGludC9uby1leHBsaWNpdC1hbnkgKi9cblxuLyoqXG4gKiBSZXBsYWNlIGEgbWV0aG9kIGluIGFuIG9iamVjdCB3aXRoIGEgd3JhcHBlZCB2ZXJzaW9uIG9mIGl0c2VsZi5cbiAqXG4gKiBJZiB0aGUgbWV0aG9kIG9uIHRoZSBwYXNzZWQgb2JqZWN0IGlzIG5vdCBhIGZ1bmN0aW9uLCB0aGUgd3JhcHBlciB3aWxsIG5vdCBiZSBhcHBsaWVkLlxuICpcbiAqIEBwYXJhbSBzb3VyY2UgQW4gb2JqZWN0IHRoYXQgY29udGFpbnMgYSBtZXRob2QgdG8gYmUgd3JhcHBlZC5cbiAqIEBwYXJhbSBuYW1lIFRoZSBuYW1lIG9mIHRoZSBtZXRob2QgdG8gYmUgd3JhcHBlZC5cbiAqIEBwYXJhbSByZXBsYWNlbWVudEZhY3RvcnkgQSBoaWdoZXItb3JkZXIgZnVuY3Rpb24gdGhhdCB0YWtlcyB0aGUgb3JpZ2luYWwgdmVyc2lvbiBvZiB0aGUgZ2l2ZW4gbWV0aG9kIGFuZCByZXR1cm5zIGFcbiAqIHdyYXBwZWQgdmVyc2lvbi4gTm90ZTogVGhlIGZ1bmN0aW9uIHJldHVybmVkIGJ5IGByZXBsYWNlbWVudEZhY3RvcnlgIG5lZWRzIHRvIGJlIGEgbm9uLWFycm93IGZ1bmN0aW9uLCBpbiBvcmRlciB0b1xuICogcHJlc2VydmUgdGhlIGNvcnJlY3QgdmFsdWUgb2YgYHRoaXNgLCBhbmQgdGhlIG9yaWdpbmFsIG1ldGhvZCBtdXN0IGJlIGNhbGxlZCB1c2luZyBgb3JpZ01ldGhvZC5jYWxsKHRoaXMsIDxvdGhlclxuICogYXJncz4pYCBvciBgb3JpZ01ldGhvZC5hcHBseSh0aGlzLCBbPG90aGVyIGFyZ3M+XSlgIChyYXRoZXIgdGhhbiBiZWluZyBjYWxsZWQgZGlyZWN0bHkpLCBhZ2FpbiB0byBwcmVzZXJ2ZSBgdGhpc2AuXG4gKiBAcmV0dXJucyB2b2lkXG4gKi9cbmZ1bmN0aW9uIGZpbGwoc291cmNlLCBuYW1lLCByZXBsYWNlbWVudEZhY3RvcnkpIHtcbiAgaWYgKCEobmFtZSBpbiBzb3VyY2UpKSB7XG4gICAgcmV0dXJuO1xuICB9XG5cbiAgLy8gZXhwbGljaXRseSBjYXN0aW5nIHRvIHVua25vd24gYmVjYXVzZSB3ZSBkb24ndCBrbm93IHRoZSB0eXBlIG9mIHRoZSBtZXRob2QgaW5pdGlhbGx5IGF0IGFsbFxuICBjb25zdCBvcmlnaW5hbCA9IHNvdXJjZVtuYW1lXSA7XG5cbiAgaWYgKHR5cGVvZiBvcmlnaW5hbCAhPT0gJ2Z1bmN0aW9uJykge1xuICAgIHJldHVybjtcbiAgfVxuXG4gIGNvbnN0IHdyYXBwZWQgPSByZXBsYWNlbWVudEZhY3Rvcnkob3JpZ2luYWwpIDtcblxuICAvLyBNYWtlIHN1cmUgaXQncyBhIGZ1bmN0aW9uIGZpcnN0LCBhcyB3ZSBuZWVkIHRvIGF0dGFjaCBhbiBlbXB0eSBwcm90b3R5cGUgZm9yIGBkZWZpbmVQcm9wZXJ0aWVzYCB0byB3b3JrXG4gIC8vIG90aGVyd2lzZSBpdCdsbCB0aHJvdyBcIlR5cGVFcnJvcjogT2JqZWN0LmRlZmluZVByb3BlcnRpZXMgY2FsbGVkIG9uIG5vbi1vYmplY3RcIlxuICBpZiAodHlwZW9mIHdyYXBwZWQgPT09ICdmdW5jdGlvbicpIHtcbiAgICBtYXJrRnVuY3Rpb25XcmFwcGVkKHdyYXBwZWQsIG9yaWdpbmFsKTtcbiAgfVxuXG4gIHRyeSB7XG4gICAgc291cmNlW25hbWVdID0gd3JhcHBlZDtcbiAgfSBjYXRjaCB7XG4gICAgZGVidWdCdWlsZC5ERUJVR19CVUlMRCAmJiBkZWJ1Z0xvZ2dlci5kZWJ1Zy5sb2coYEZhaWxlZCB0byByZXBsYWNlIG1ldGhvZCBcIiR7bmFtZX1cIiBpbiBvYmplY3RgLCBzb3VyY2UpO1xuICB9XG59XG5cbi8qKlxuICogRGVmaW5lcyBhIG5vbi1lbnVtZXJhYmxlIHByb3BlcnR5IG9uIHRoZSBnaXZlbiBvYmplY3QuXG4gKlxuICogQHBhcmFtIG9iaiBUaGUgb2JqZWN0IG9uIHdoaWNoIHRvIHNldCB0aGUgcHJvcGVydHlcbiAqIEBwYXJhbSBuYW1lIFRoZSBuYW1lIG9mIHRoZSBwcm9wZXJ0eSB0byBiZSBzZXRcbiAqIEBwYXJhbSB2YWx1ZSBUaGUgdmFsdWUgdG8gd2hpY2ggdG8gc2V0IHRoZSBwcm9wZXJ0eVxuICovXG5mdW5jdGlvbiBhZGROb25FbnVtZXJhYmxlUHJvcGVydHkob2JqLCBuYW1lLCB2YWx1ZSkge1xuICB0cnkge1xuICAgIE9iamVjdC5kZWZpbmVQcm9wZXJ0eShvYmosIG5hbWUsIHtcbiAgICAgIC8vIGVudW1lcmFibGU6IGZhbHNlLCAvLyB0aGUgZGVmYXVsdCwgc28gd2UgY2FuIHNhdmUgb24gYnVuZGxlIHNpemUgYnkgbm90IGV4cGxpY2l0bHkgc2V0dGluZyBpdFxuICAgICAgdmFsdWU6IHZhbHVlLFxuICAgICAgd3JpdGFibGU6IHRydWUsXG4gICAgICBjb25maWd1cmFibGU6IHRydWUsXG4gICAgfSk7XG4gIH0gY2F0Y2gge1xuICAgIGRlYnVnQnVpbGQuREVCVUdfQlVJTEQgJiYgZGVidWdMb2dnZXIuZGVidWcubG9nKGBGYWlsZWQgdG8gYWRkIG5vbi1lbnVtZXJhYmxlIHByb3BlcnR5IFwiJHtuYW1lfVwiIHRvIG9iamVjdGAsIG9iaik7XG4gIH1cbn1cblxuLyoqXG4gKiBSZW1lbWJlcnMgdGhlIG9yaWdpbmFsIGZ1bmN0aW9uIG9uIHRoZSB3cmFwcGVkIGZ1bmN0aW9uIGFuZFxuICogcGF0Y2hlcyB1cCB0aGUgcHJvdG90eXBlLlxuICpcbiAqIEBwYXJhbSB3cmFwcGVkIHRoZSB3cmFwcGVyIGZ1bmN0aW9uXG4gKiBAcGFyYW0gb3JpZ2luYWwgdGhlIG9yaWdpbmFsIGZ1bmN0aW9uIHRoYXQgZ2V0cyB3cmFwcGVkXG4gKi9cbmZ1bmN0aW9uIG1hcmtGdW5jdGlvbldyYXBwZWQod3JhcHBlZCwgb3JpZ2luYWwpIHtcbiAgdHJ5IHtcbiAgICBjb25zdCBwcm90byA9IG9yaWdpbmFsLnByb3RvdHlwZSB8fCB7fTtcbiAgICB3cmFwcGVkLnByb3RvdHlwZSA9IG9yaWdpbmFsLnByb3RvdHlwZSA9IHByb3RvO1xuICAgIGFkZE5vbkVudW1lcmFibGVQcm9wZXJ0eSh3cmFwcGVkLCAnX19zZW50cnlfb3JpZ2luYWxfXycsIG9yaWdpbmFsKTtcbiAgfSBjYXRjaCB7fSAvLyBlc2xpbnQtZGlzYWJsZS1saW5lIG5vLWVtcHR5XG59XG5cbi8qKlxuICogVGhpcyBleHRyYWN0cyB0aGUgb3JpZ2luYWwgZnVuY3Rpb24gaWYgYXZhaWxhYmxlLiAgU2VlXG4gKiBgbWFya0Z1bmN0aW9uV3JhcHBlZGAgZm9yIG1vcmUgaW5mb3JtYXRpb24uXG4gKlxuICogQHBhcmFtIGZ1bmMgdGhlIGZ1bmN0aW9uIHRvIHVud3JhcFxuICogQHJldHVybnMgdGhlIHVud3JhcHBlZCB2ZXJzaW9uIG9mIHRoZSBmdW5jdGlvbiBpZiBhdmFpbGFibGUuXG4gKi9cbi8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvYmFuLXR5cGVzXG5mdW5jdGlvbiBnZXRPcmlnaW5hbEZ1bmN0aW9uKGZ1bmMpIHtcbiAgcmV0dXJuIGZ1bmMuX19zZW50cnlfb3JpZ2luYWxfXztcbn1cblxuLyoqXG4gKiBUcmFuc2Zvcm1zIGFueSBgRXJyb3JgIG9yIGBFdmVudGAgaW50byBhIHBsYWluIG9iamVjdCB3aXRoIGFsbCBvZiB0aGVpciBlbnVtZXJhYmxlIHByb3BlcnRpZXMsIGFuZCBzb21lIG9mIHRoZWlyXG4gKiBub24tZW51bWVyYWJsZSBwcm9wZXJ0aWVzIGF0dGFjaGVkLlxuICpcbiAqIEBwYXJhbSB2YWx1ZSBJbml0aWFsIHNvdXJjZSB0aGF0IHdlIGhhdmUgdG8gdHJhbnNmb3JtIGluIG9yZGVyIGZvciBpdCB0byBiZSB1c2FibGUgYnkgdGhlIHNlcmlhbGl6ZXJcbiAqIEByZXR1cm5zIEFuIEV2ZW50IG9yIEVycm9yIHR1cm5lZCBpbnRvIGFuIG9iamVjdCAtIG9yIHRoZSB2YWx1ZSBhcmd1bWVudCBpdHNlbGYsIHdoZW4gdmFsdWUgaXMgbmVpdGhlciBhbiBFdmVudCBub3JcbiAqICBhbiBFcnJvci5cbiAqL1xuZnVuY3Rpb24gY29udmVydFRvUGxhaW5PYmplY3QodmFsdWUpXG5cbiB7XG4gIGlmIChpcy5pc0Vycm9yKHZhbHVlKSkge1xuICAgIHJldHVybiB7XG4gICAgICBtZXNzYWdlOiB2YWx1ZS5tZXNzYWdlLFxuICAgICAgbmFtZTogdmFsdWUubmFtZSxcbiAgICAgIHN0YWNrOiB2YWx1ZS5zdGFjayxcbiAgICAgIC4uLmdldE93blByb3BlcnRpZXModmFsdWUpLFxuICAgIH07XG4gIH0gZWxzZSBpZiAoaXMuaXNFdmVudCh2YWx1ZSkpIHtcbiAgICBjb25zdCBuZXdPYmpcblxuID0ge1xuICAgICAgdHlwZTogdmFsdWUudHlwZSxcbiAgICAgIHRhcmdldDogc2VyaWFsaXplRXZlbnRUYXJnZXQodmFsdWUudGFyZ2V0KSxcbiAgICAgIGN1cnJlbnRUYXJnZXQ6IHNlcmlhbGl6ZUV2ZW50VGFyZ2V0KHZhbHVlLmN1cnJlbnRUYXJnZXQpLFxuICAgICAgLi4uZ2V0T3duUHJvcGVydGllcyh2YWx1ZSksXG4gICAgfTtcblxuICAgIGlmICh0eXBlb2YgQ3VzdG9tRXZlbnQgIT09ICd1bmRlZmluZWQnICYmIGlzLmlzSW5zdGFuY2VPZih2YWx1ZSwgQ3VzdG9tRXZlbnQpKSB7XG4gICAgICBuZXdPYmouZGV0YWlsID0gdmFsdWUuZGV0YWlsO1xuICAgIH1cblxuICAgIHJldHVybiBuZXdPYmo7XG4gIH0gZWxzZSB7XG4gICAgcmV0dXJuIHZhbHVlO1xuICB9XG59XG5cbi8qKiBDcmVhdGVzIGEgc3RyaW5nIHJlcHJlc2VudGF0aW9uIG9mIHRoZSB0YXJnZXQgb2YgYW4gYEV2ZW50YCBvYmplY3QgKi9cbmZ1bmN0aW9uIHNlcmlhbGl6ZUV2ZW50VGFyZ2V0KHRhcmdldCkge1xuICB0cnkge1xuICAgIHJldHVybiBpcy5pc0VsZW1lbnQodGFyZ2V0KSA/IGJyb3dzZXIuaHRtbFRyZWVBc1N0cmluZyh0YXJnZXQpIDogT2JqZWN0LnByb3RvdHlwZS50b1N0cmluZy5jYWxsKHRhcmdldCk7XG4gIH0gY2F0Y2gge1xuICAgIHJldHVybiAnPHVua25vd24+JztcbiAgfVxufVxuXG4vKiogRmlsdGVycyBvdXQgYWxsIGJ1dCBhbiBvYmplY3QncyBvd24gcHJvcGVydGllcyAqL1xuZnVuY3Rpb24gZ2V0T3duUHJvcGVydGllcyhvYmopIHtcbiAgaWYgKHR5cGVvZiBvYmogPT09ICdvYmplY3QnICYmIG9iaiAhPT0gbnVsbCkge1xuICAgIGNvbnN0IGV4dHJhY3RlZFByb3BzID0ge307XG4gICAgZm9yIChjb25zdCBwcm9wZXJ0eSBpbiBvYmopIHtcbiAgICAgIGlmIChPYmplY3QucHJvdG90eXBlLmhhc093blByb3BlcnR5LmNhbGwob2JqLCBwcm9wZXJ0eSkpIHtcbiAgICAgICAgZXh0cmFjdGVkUHJvcHNbcHJvcGVydHldID0gKG9iaiApW3Byb3BlcnR5XTtcbiAgICAgIH1cbiAgICB9XG4gICAgcmV0dXJuIGV4dHJhY3RlZFByb3BzO1xuICB9IGVsc2Uge1xuICAgIHJldHVybiB7fTtcbiAgfVxufVxuXG4vKipcbiAqIEdpdmVuIGFueSBjYXB0dXJlZCBleGNlcHRpb24sIGV4dHJhY3QgaXRzIGtleXMgYW5kIGNyZWF0ZSBhIHNvcnRlZFxuICogYW5kIHRydW5jYXRlZCBsaXN0IHRoYXQgd2lsbCBiZSB1c2VkIGluc2lkZSB0aGUgZXZlbnQgbWVzc2FnZS5cbiAqIGVnLiBgTm9uLWVycm9yIGV4Y2VwdGlvbiBjYXB0dXJlZCB3aXRoIGtleXM6IGZvbywgYmFyLCBiYXpgXG4gKi9cbmZ1bmN0aW9uIGV4dHJhY3RFeGNlcHRpb25LZXlzRm9yTWVzc2FnZShleGNlcHRpb24sIG1heExlbmd0aCA9IDQwKSB7XG4gIGNvbnN0IGtleXMgPSBPYmplY3Qua2V5cyhjb252ZXJ0VG9QbGFpbk9iamVjdChleGNlcHRpb24pKTtcbiAga2V5cy5zb3J0KCk7XG5cbiAgY29uc3QgZmlyc3RLZXkgPSBrZXlzWzBdO1xuXG4gIGlmICghZmlyc3RLZXkpIHtcbiAgICByZXR1cm4gJ1tvYmplY3QgaGFzIG5vIGtleXNdJztcbiAgfVxuXG4gIGlmIChmaXJzdEtleS5sZW5ndGggPj0gbWF4TGVuZ3RoKSB7XG4gICAgcmV0dXJuIHN0cmluZy50cnVuY2F0ZShmaXJzdEtleSwgbWF4TGVuZ3RoKTtcbiAgfVxuXG4gIGZvciAobGV0IGluY2x1ZGVkS2V5cyA9IGtleXMubGVuZ3RoOyBpbmNsdWRlZEtleXMgPiAwOyBpbmNsdWRlZEtleXMtLSkge1xuICAgIGNvbnN0IHNlcmlhbGl6ZWQgPSBrZXlzLnNsaWNlKDAsIGluY2x1ZGVkS2V5cykuam9pbignLCAnKTtcbiAgICBpZiAoc2VyaWFsaXplZC5sZW5ndGggPiBtYXhMZW5ndGgpIHtcbiAgICAgIGNvbnRpbnVlO1xuICAgIH1cbiAgICBpZiAoaW5jbHVkZWRLZXlzID09PSBrZXlzLmxlbmd0aCkge1xuICAgICAgcmV0dXJuIHNlcmlhbGl6ZWQ7XG4gICAgfVxuICAgIHJldHVybiBzdHJpbmcudHJ1bmNhdGUoc2VyaWFsaXplZCwgbWF4TGVuZ3RoKTtcbiAgfVxuXG4gIHJldHVybiAnJztcbn1cblxuLyoqXG4gKiBHaXZlbiBhbnkgb2JqZWN0LCByZXR1cm4gYSBuZXcgb2JqZWN0IGhhdmluZyByZW1vdmVkIGFsbCBmaWVsZHMgd2hvc2UgdmFsdWUgd2FzIGB1bmRlZmluZWRgLlxuICogV29ya3MgcmVjdXJzaXZlbHkgb24gb2JqZWN0cyBhbmQgYXJyYXlzLlxuICpcbiAqIEF0dGVudGlvbjogVGhpcyBmdW5jdGlvbiBrZWVwcyBjaXJjdWxhciByZWZlcmVuY2VzIGluIHRoZSByZXR1cm5lZCBvYmplY3QuXG4gKlxuICogQGRlcHJlY2F0ZWQgVGhpcyBmdW5jdGlvbiBpcyBubyBsb25nZXIgdXNlZCBieSB0aGUgU0RLIGFuZCB3aWxsIGJlIHJlbW92ZWQgaW4gYSBmdXR1cmUgbWFqb3IgdmVyc2lvbi5cbiAqL1xuZnVuY3Rpb24gZHJvcFVuZGVmaW5lZEtleXMoaW5wdXRWYWx1ZSkge1xuICAvLyBUaGlzIG1hcCBrZWVwcyB0cmFjayBvZiB3aGF0IGFscmVhZHkgdmlzaXRlZCBub2RlcyBtYXAgdG8uXG4gIC8vIE91ciBTZXQgLSBiYXNlZCBtZW1vQnVpbGRlciBkb2Vzbid0IHdvcmsgaGVyZSBiZWNhdXNlIHdlIHdhbnQgdG8gdGhlIG91dHB1dCBvYmplY3QgdG8gaGF2ZSB0aGUgc2FtZSBjaXJjdWxhclxuICAvLyByZWZlcmVuY2VzIGFzIHRoZSBpbnB1dCBvYmplY3QuXG4gIGNvbnN0IG1lbW9pemF0aW9uTWFwID0gbmV3IE1hcCgpO1xuXG4gIC8vIFRoaXMgZnVuY3Rpb24ganVzdCBwcm94aWVzIGBfZHJvcFVuZGVmaW5lZEtleXNgIHRvIGtlZXAgdGhlIGBtZW1vQnVpbGRlcmAgb3V0IG9mIHRoaXMgZnVuY3Rpb24ncyBBUElcbiAgcmV0dXJuIF9kcm9wVW5kZWZpbmVkS2V5cyhpbnB1dFZhbHVlLCBtZW1vaXphdGlvbk1hcCk7XG59XG5cbmZ1bmN0aW9uIF9kcm9wVW5kZWZpbmVkS2V5cyhpbnB1dFZhbHVlLCBtZW1vaXphdGlvbk1hcCkge1xuICAvLyBFYXJseSByZXR1cm4gZm9yIHByaW1pdGl2ZSB2YWx1ZXNcbiAgaWYgKGlucHV0VmFsdWUgPT09IG51bGwgfHwgdHlwZW9mIGlucHV0VmFsdWUgIT09ICdvYmplY3QnKSB7XG4gICAgcmV0dXJuIGlucHV0VmFsdWU7XG4gIH1cblxuICAvLyBDaGVjayBtZW1vIG1hcCBmaXJzdCBmb3IgYWxsIG9iamVjdCB0eXBlc1xuICBjb25zdCBtZW1vVmFsID0gbWVtb2l6YXRpb25NYXAuZ2V0KGlucHV0VmFsdWUpO1xuICBpZiAobWVtb1ZhbCAhPT0gdW5kZWZpbmVkKSB7XG4gICAgcmV0dXJuIG1lbW9WYWwgO1xuICB9XG5cbiAgLy8gaGFuZGxlIGFycmF5c1xuICBpZiAoQXJyYXkuaXNBcnJheShpbnB1dFZhbHVlKSkge1xuICAgIGNvbnN0IHJldHVyblZhbHVlID0gW107XG4gICAgLy8gU3RvcmUgbWFwcGluZyB0byBoYW5kbGUgY2lyY3VsYXIgcmVmZXJlbmNlc1xuICAgIG1lbW9pemF0aW9uTWFwLnNldChpbnB1dFZhbHVlLCByZXR1cm5WYWx1ZSk7XG5cbiAgICBpbnB1dFZhbHVlLmZvckVhY2godmFsdWUgPT4ge1xuICAgICAgcmV0dXJuVmFsdWUucHVzaChfZHJvcFVuZGVmaW5lZEtleXModmFsdWUsIG1lbW9pemF0aW9uTWFwKSk7XG4gICAgfSk7XG5cbiAgICByZXR1cm4gcmV0dXJuVmFsdWUgO1xuICB9XG5cbiAgaWYgKGlzUG9qbyhpbnB1dFZhbHVlKSkge1xuICAgIGNvbnN0IHJldHVyblZhbHVlID0ge307XG4gICAgLy8gU3RvcmUgbWFwcGluZyB0byBoYW5kbGUgY2lyY3VsYXIgcmVmZXJlbmNlc1xuICAgIG1lbW9pemF0aW9uTWFwLnNldChpbnB1dFZhbHVlLCByZXR1cm5WYWx1ZSk7XG5cbiAgICBjb25zdCBrZXlzID0gT2JqZWN0LmtleXMoaW5wdXRWYWx1ZSk7XG5cbiAgICBrZXlzLmZvckVhY2goa2V5ID0+IHtcbiAgICAgIGNvbnN0IHZhbCA9IGlucHV0VmFsdWVba2V5XTtcbiAgICAgIGlmICh2YWwgIT09IHVuZGVmaW5lZCkge1xuICAgICAgICByZXR1cm5WYWx1ZVtrZXldID0gX2Ryb3BVbmRlZmluZWRLZXlzKHZhbCwgbWVtb2l6YXRpb25NYXApO1xuICAgICAgfVxuICAgIH0pO1xuXG4gICAgcmV0dXJuIHJldHVyblZhbHVlIDtcbiAgfVxuXG4gIC8vIEZvciBvdGhlciBvYmplY3QgdHlwZXMsIHJldHVybiBhcyBpc1xuICByZXR1cm4gaW5wdXRWYWx1ZTtcbn1cblxuZnVuY3Rpb24gaXNQb2pvKGlucHV0KSB7XG4gIC8vIFBsYWluIG9iamVjdHMgaGF2ZSBPYmplY3QgYXMgY29uc3RydWN0b3Igb3Igbm8gY29uc3RydWN0b3JcbiAgY29uc3QgY29uc3RydWN0b3IgPSAoaW5wdXQgKS5jb25zdHJ1Y3RvcjtcbiAgcmV0dXJuIGNvbnN0cnVjdG9yID09PSBPYmplY3QgfHwgY29uc3RydWN0b3IgPT09IHVuZGVmaW5lZDtcbn1cblxuLyoqXG4gKiBFbnN1cmUgdGhhdCBzb21ldGhpbmcgaXMgYW4gb2JqZWN0LlxuICpcbiAqIFR1cm5zIGB1bmRlZmluZWRgIGFuZCBgbnVsbGAgaW50byBgU3RyaW5nYHMgYW5kIGFsbCBvdGhlciBwcmltaXRpdmVzIGludG8gaW5zdGFuY2VzIG9mIHRoZWlyIHJlc3BlY3RpdmUgd3JhcHBlclxuICogY2xhc3NlcyAoU3RyaW5nLCBCb29sZWFuLCBOdW1iZXIsIGV0Yy4pLiBBY3RzIGFzIHRoZSBpZGVudGl0eSBmdW5jdGlvbiBvbiBub24tcHJpbWl0aXZlcy5cbiAqXG4gKiBAcGFyYW0gd2F0IFRoZSBzdWJqZWN0IG9mIHRoZSBvYmplY3RpZmljYXRpb25cbiAqIEByZXR1cm5zIEEgdmVyc2lvbiBvZiBgd2F0YCB3aGljaCBjYW4gc2FmZWx5IGJlIHVzZWQgd2l0aCBgT2JqZWN0YCBjbGFzcyBtZXRob2RzXG4gKi9cbmZ1bmN0aW9uIG9iamVjdGlmeSh3YXQpIHtcbiAgbGV0IG9iamVjdGlmaWVkO1xuICBzd2l0Y2ggKHRydWUpIHtcbiAgICAvLyB0aGlzIHdpbGwgY2F0Y2ggYm90aCB1bmRlZmluZWQgYW5kIG51bGxcbiAgICBjYXNlIHdhdCA9PSB1bmRlZmluZWQ6XG4gICAgICBvYmplY3RpZmllZCA9IG5ldyBTdHJpbmcod2F0KTtcbiAgICAgIGJyZWFrO1xuXG4gICAgLy8gVGhvdWdoIHN5bWJvbHMgYW5kIGJpZ2ludHMgZG8gaGF2ZSB3cmFwcGVyIGNsYXNzZXMgKGBTeW1ib2xgIGFuZCBgQmlnSW50YCwgcmVzcGVjdGl2ZWx5KSwgZm9yIHdoYXRldmVyIHJlYXNvblxuICAgIC8vIHRob3NlIGNsYXNzZXMgZG9uJ3QgaGF2ZSBjb25zdHJ1Y3RvcnMgd2hpY2ggY2FuIGJlIHVzZWQgd2l0aCB0aGUgYG5ld2Aga2V5d29yZC4gV2UgdGhlcmVmb3JlIG5lZWQgdG8gY2FzdCBlYWNoIGFzXG4gICAgLy8gYW4gb2JqZWN0IGluIG9yZGVyIHRvIHdyYXAgaXQuXG4gICAgY2FzZSB0eXBlb2Ygd2F0ID09PSAnc3ltYm9sJyB8fCB0eXBlb2Ygd2F0ID09PSAnYmlnaW50JzpcbiAgICAgIG9iamVjdGlmaWVkID0gT2JqZWN0KHdhdCk7XG4gICAgICBicmVhaztcblxuICAgIC8vIHRoaXMgd2lsbCBjYXRjaCB0aGUgcmVtYWluaW5nIHByaW1pdGl2ZXM6IGBTdHJpbmdgLCBgTnVtYmVyYCwgYW5kIGBCb29sZWFuYFxuICAgIGNhc2UgaXMuaXNQcmltaXRpdmUod2F0KTpcbiAgICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tdW5zYWZlLW1lbWJlci1hY2Nlc3NcbiAgICAgIG9iamVjdGlmaWVkID0gbmV3ICh3YXQgKS5jb25zdHJ1Y3Rvcih3YXQpO1xuICAgICAgYnJlYWs7XG5cbiAgICAvLyBieSBwcm9jZXNzIG9mIGVsaW1pbmF0aW9uLCBhdCB0aGlzIHBvaW50IHdlIGtub3cgdGhhdCBgd2F0YCBtdXN0IGFscmVhZHkgYmUgYW4gb2JqZWN0XG4gICAgZGVmYXVsdDpcbiAgICAgIG9iamVjdGlmaWVkID0gd2F0O1xuICAgICAgYnJlYWs7XG4gIH1cbiAgcmV0dXJuIG9iamVjdGlmaWVkO1xufVxuXG5leHBvcnRzLmFkZE5vbkVudW1lcmFibGVQcm9wZXJ0eSA9IGFkZE5vbkVudW1lcmFibGVQcm9wZXJ0eTtcbmV4cG9ydHMuY29udmVydFRvUGxhaW5PYmplY3QgPSBjb252ZXJ0VG9QbGFpbk9iamVjdDtcbmV4cG9ydHMuZHJvcFVuZGVmaW5lZEtleXMgPSBkcm9wVW5kZWZpbmVkS2V5cztcbmV4cG9ydHMuZXh0cmFjdEV4Y2VwdGlvbktleXNGb3JNZXNzYWdlID0gZXh0cmFjdEV4Y2VwdGlvbktleXNGb3JNZXNzYWdlO1xuZXhwb3J0cy5maWxsID0gZmlsbDtcbmV4cG9ydHMuZ2V0T3JpZ2luYWxGdW5jdGlvbiA9IGdldE9yaWdpbmFsRnVuY3Rpb247XG5leHBvcnRzLm1hcmtGdW5jdGlvbldyYXBwZWQgPSBtYXJrRnVuY3Rpb25XcmFwcGVkO1xuZXhwb3J0cy5vYmplY3RpZnkgPSBvYmplY3RpZnk7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1vYmplY3QuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/object.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/openai/constants.js":
/*!**************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/openai/constants.js ***!
  \**************************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst OPENAI_INTEGRATION_NAME = 'OpenAI';\n\n// https://platform.openai.com/docs/quickstart?api-mode=responses\n// https://platform.openai.com/docs/quickstart?api-mode=chat\nconst INSTRUMENTED_METHODS = ['responses.create', 'chat.completions.create'] ;\n\nexports.INSTRUMENTED_METHODS = INSTRUMENTED_METHODS;\nexports.OPENAI_INTEGRATION_NAME = OPENAI_INTEGRATION_NAME;\n//# sourceMappingURL=constants.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9vcGVuYWkvY29uc3RhbnRzLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFOztBQUVBO0FBQ0E7QUFDQTs7QUFFQSw0QkFBNEI7QUFDNUIsK0JBQStCO0FBQy9CIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvb3BlbmFpL2NvbnN0YW50cy5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgT1BFTkFJX0lOVEVHUkFUSU9OX05BTUUgPSAnT3BlbkFJJztcblxuLy8gaHR0cHM6Ly9wbGF0Zm9ybS5vcGVuYWkuY29tL2RvY3MvcXVpY2tzdGFydD9hcGktbW9kZT1yZXNwb25zZXNcbi8vIGh0dHBzOi8vcGxhdGZvcm0ub3BlbmFpLmNvbS9kb2NzL3F1aWNrc3RhcnQ/YXBpLW1vZGU9Y2hhdFxuY29uc3QgSU5TVFJVTUVOVEVEX01FVEhPRFMgPSBbJ3Jlc3BvbnNlcy5jcmVhdGUnLCAnY2hhdC5jb21wbGV0aW9ucy5jcmVhdGUnXSA7XG5cbmV4cG9ydHMuSU5TVFJVTUVOVEVEX01FVEhPRFMgPSBJTlNUUlVNRU5URURfTUVUSE9EUztcbmV4cG9ydHMuT1BFTkFJX0lOVEVHUkFUSU9OX05BTUUgPSBPUEVOQUlfSU5URUdSQVRJT05fTkFNRTtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWNvbnN0YW50cy5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/openai/constants.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/openai/index.js":
/*!**********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/openai/index.js ***!
  \**********************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst currentScopes = __webpack_require__(/*! ../../currentScopes.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst exports$1 = __webpack_require__(/*! ../../exports.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/exports.js\");\nconst trace = __webpack_require__(/*! ../../tracing/trace.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/trace.js\");\nconst genAiAttributes = __webpack_require__(/*! ../gen-ai-attributes.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/gen-ai-attributes.js\");\nconst constants = __webpack_require__(/*! ./constants.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/openai/constants.js\");\nconst utils = __webpack_require__(/*! ./utils.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/openai/utils.js\");\n\n/**\n * Extract request attributes from method arguments\n */\nfunction extractRequestAttributes(args, methodPath) {\n  const attributes = {\n    [genAiAttributes.GEN_AI_SYSTEM_ATTRIBUTE]: 'openai',\n    [genAiAttributes.GEN_AI_OPERATION_NAME_ATTRIBUTE]: utils.getOperationName(methodPath),\n  };\n\n  if (args.length > 0 && typeof args[0] === 'object' && args[0] !== null) {\n    const params = args[0] ;\n\n    attributes[genAiAttributes.GEN_AI_REQUEST_MODEL_ATTRIBUTE] = params.model ?? 'unknown';\n    if ('temperature' in params) attributes[genAiAttributes.GEN_AI_REQUEST_TEMPERATURE_ATTRIBUTE] = params.temperature;\n    if ('top_p' in params) attributes[genAiAttributes.GEN_AI_REQUEST_TOP_P_ATTRIBUTE] = params.top_p;\n    if ('frequency_penalty' in params)\n      attributes[genAiAttributes.GEN_AI_REQUEST_FREQUENCY_PENALTY_ATTRIBUTE] = params.frequency_penalty;\n    if ('presence_penalty' in params) attributes[genAiAttributes.GEN_AI_REQUEST_PRESENCE_PENALTY_ATTRIBUTE] = params.presence_penalty;\n  } else {\n    attributes[genAiAttributes.GEN_AI_REQUEST_MODEL_ATTRIBUTE] = 'unknown';\n  }\n\n  return attributes;\n}\n\n/**\n * Helper function to set token usage attributes\n */\nfunction setTokenUsageAttributes(\n  span,\n  promptTokens,\n  completionTokens,\n  totalTokens,\n) {\n  if (promptTokens !== undefined) {\n    span.setAttributes({\n      [genAiAttributes.OPENAI_USAGE_PROMPT_TOKENS_ATTRIBUTE]: promptTokens,\n      [genAiAttributes.GEN_AI_USAGE_INPUT_TOKENS_ATTRIBUTE]: promptTokens,\n    });\n  }\n  if (completionTokens !== undefined) {\n    span.setAttributes({\n      [genAiAttributes.OPENAI_USAGE_COMPLETION_TOKENS_ATTRIBUTE]: completionTokens,\n      [genAiAttributes.GEN_AI_USAGE_OUTPUT_TOKENS_ATTRIBUTE]: completionTokens,\n    });\n  }\n  if (totalTokens !== undefined) {\n    span.setAttributes({\n      [genAiAttributes.GEN_AI_USAGE_TOTAL_TOKENS_ATTRIBUTE]: totalTokens,\n    });\n  }\n}\n\n/**\n * Helper function to set common response attributes (ID, model, timestamp)\n */\nfunction setCommonResponseAttributes(span, id, model, timestamp) {\n  if (id) {\n    span.setAttributes({\n      [genAiAttributes.OPENAI_RESPONSE_ID_ATTRIBUTE]: id,\n      [genAiAttributes.GEN_AI_RESPONSE_ID_ATTRIBUTE]: id,\n    });\n  }\n  if (model) {\n    span.setAttributes({\n      [genAiAttributes.OPENAI_RESPONSE_MODEL_ATTRIBUTE]: model,\n      [genAiAttributes.GEN_AI_RESPONSE_MODEL_ATTRIBUTE]: model,\n    });\n  }\n  if (timestamp) {\n    span.setAttributes({\n      [genAiAttributes.OPENAI_RESPONSE_TIMESTAMP_ATTRIBUTE]: new Date(timestamp * 1000).toISOString(),\n    });\n  }\n}\n\n/**\n * Add attributes for Chat Completion responses\n */\nfunction addChatCompletionAttributes(span, response) {\n  setCommonResponseAttributes(span, response.id, response.model, response.created);\n  if (response.usage) {\n    setTokenUsageAttributes(\n      span,\n      response.usage.prompt_tokens,\n      response.usage.completion_tokens,\n      response.usage.total_tokens,\n    );\n  }\n  if (Array.isArray(response.choices)) {\n    const finishReasons = response.choices\n      .map(choice => choice.finish_reason)\n      .filter((reason) => reason !== null);\n    if (finishReasons.length > 0) {\n      span.setAttributes({\n        [genAiAttributes.GEN_AI_RESPONSE_FINISH_REASONS_ATTRIBUTE]: JSON.stringify(finishReasons),\n      });\n    }\n  }\n}\n\n/**\n * Add attributes for Responses API responses\n */\nfunction addResponsesApiAttributes(span, response) {\n  setCommonResponseAttributes(span, response.id, response.model, response.created_at);\n  if (response.status) {\n    span.setAttributes({\n      [genAiAttributes.GEN_AI_RESPONSE_FINISH_REASONS_ATTRIBUTE]: JSON.stringify([response.status]),\n    });\n  }\n  if (response.usage) {\n    setTokenUsageAttributes(\n      span,\n      response.usage.input_tokens,\n      response.usage.output_tokens,\n      response.usage.total_tokens,\n    );\n  }\n}\n\n/**\n * Add response attributes to spans\n * This currently supports both Chat Completion and Responses API responses\n */\nfunction addResponseAttributes(span, result, recordOutputs) {\n  if (!result || typeof result !== 'object') return;\n\n  const response = result ;\n\n  if (utils.isChatCompletionResponse(response)) {\n    addChatCompletionAttributes(span, response);\n    if (recordOutputs && response.choices?.length) {\n      const responseTexts = response.choices.map(choice => choice.message?.content || '');\n      span.setAttributes({ [genAiAttributes.GEN_AI_RESPONSE_TEXT_ATTRIBUTE]: JSON.stringify(responseTexts) });\n    }\n  } else if (utils.isResponsesApiResponse(response)) {\n    addResponsesApiAttributes(span, response);\n    if (recordOutputs && response.output_text) {\n      span.setAttributes({ [genAiAttributes.GEN_AI_RESPONSE_TEXT_ATTRIBUTE]: response.output_text });\n    }\n  }\n}\n\n// Extract and record AI request inputs, if present. This is intentionally separate from response attributes.\nfunction addRequestAttributes(span, params) {\n  if ('messages' in params) {\n    span.setAttributes({ [genAiAttributes.GEN_AI_REQUEST_MESSAGES_ATTRIBUTE]: JSON.stringify(params.messages) });\n  }\n  if ('input' in params) {\n    span.setAttributes({ [genAiAttributes.GEN_AI_REQUEST_MESSAGES_ATTRIBUTE]: JSON.stringify(params.input) });\n  }\n}\n\nfunction getOptionsFromIntegration() {\n  const scope = currentScopes.getCurrentScope();\n  const client = scope.getClient();\n  const integration = client?.getIntegrationByName(constants.OPENAI_INTEGRATION_NAME) ;\n  const shouldRecordInputsAndOutputs = integration ? Boolean(client?.getOptions().sendDefaultPii) : false;\n\n  return {\n    recordInputs: integration?.options?.recordInputs ?? shouldRecordInputsAndOutputs,\n    recordOutputs: integration?.options?.recordOutputs ?? shouldRecordInputsAndOutputs,\n  };\n}\n\n/**\n * Instrument a method with Sentry spans\n * Following Sentry AI Agents Manual Instrumentation conventions\n * @see https://docs.sentry.io/platforms/javascript/guides/node/tracing/instrumentation/ai-agents-module/#manual-instrumentation\n */\nfunction instrumentMethod(\n  originalMethod,\n  methodPath,\n  context,\n  options,\n) {\n  return async function instrumentedMethod(...args) {\n    const finalOptions = options || getOptionsFromIntegration();\n    const requestAttributes = extractRequestAttributes(args, methodPath);\n    const model = (requestAttributes[genAiAttributes.GEN_AI_REQUEST_MODEL_ATTRIBUTE] ) || 'unknown';\n    const operationName = utils.getOperationName(methodPath);\n\n    return trace.startSpan(\n      {\n        name: `${operationName} ${model}`,\n        op: utils.getSpanOperation(methodPath),\n        attributes: requestAttributes ,\n      },\n      async (span) => {\n        try {\n          if (finalOptions.recordInputs && args[0] && typeof args[0] === 'object') {\n            addRequestAttributes(span, args[0] );\n          }\n\n          const result = await originalMethod.apply(context, args);\n          // TODO: Add streaming support\n          addResponseAttributes(span, result, finalOptions.recordOutputs);\n          return result;\n        } catch (error) {\n          exports$1.captureException(error);\n          throw error;\n        }\n      },\n    );\n  };\n}\n\n/**\n * Create a deep proxy for OpenAI client instrumentation\n */\nfunction createDeepProxy(target, currentPath = '', options) {\n  return new Proxy(target, {\n    get(obj, prop) {\n      const value = (obj )[prop];\n      const methodPath = utils.buildMethodPath(currentPath, String(prop));\n\n      if (typeof value === 'function' && utils.shouldInstrument(methodPath)) {\n        return instrumentMethod(value , methodPath, obj, options);\n      }\n\n      if (typeof value === 'function') {\n        // Bind non-instrumented functions to preserve the original `this` context,\n        // which is required for accessing private class fields (e.g. #baseURL) in OpenAI SDK v5.\n        return value.bind(obj);\n      }\n\n      if (value && typeof value === 'object') {\n        return createDeepProxy(value , methodPath, options);\n      }\n\n      return value;\n    },\n  });\n}\n\n/**\n * Instrument an OpenAI client with Sentry tracing\n * Can be used across Node.js, Cloudflare Workers, and Vercel Edge\n */\nfunction instrumentOpenAiClient(client, options) {\n  return createDeepProxy(client, '', options);\n}\n\nexports.instrumentOpenAiClient = instrumentOpenAiClient;\n//# sourceMappingURL=index.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9vcGVuYWkvaW5kZXguanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsc0JBQXNCLG1CQUFPLENBQUMsbUlBQXdCO0FBQ3RELGtCQUFrQixtQkFBTyxDQUFDLHVIQUFrQjtBQUM1QyxjQUFjLG1CQUFPLENBQUMsbUlBQXdCO0FBQzlDLHdCQUF3QixtQkFBTyxDQUFDLDhJQUF5QjtBQUN6RCxrQkFBa0IsbUJBQU8sQ0FBQyxvSUFBZ0I7QUFDMUMsY0FBYyxtQkFBTyxDQUFDLDRIQUFZOztBQUVsQztBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsSUFBSTtBQUNKO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEtBQUs7QUFDTDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsS0FBSztBQUNMO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsS0FBSztBQUNMO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEtBQUs7QUFDTDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsS0FBSztBQUNMO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsS0FBSztBQUNMO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLE9BQU87QUFDUDtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEtBQUs7QUFDTDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQSwyQkFBMkIsaUZBQWlGO0FBQzVHO0FBQ0EsSUFBSTtBQUNKO0FBQ0E7QUFDQSwyQkFBMkIsd0VBQXdFO0FBQ25HO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQSx5QkFBeUIsc0ZBQXNGO0FBQy9HO0FBQ0E7QUFDQSx5QkFBeUIsbUZBQW1GO0FBQzVHO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQSxpQkFBaUIsZUFBZSxFQUFFLE1BQU07QUFDeEM7QUFDQTtBQUNBLE9BQU87QUFDUDtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsVUFBVTtBQUNWO0FBQ0E7QUFDQTtBQUNBLE9BQU87QUFDUDtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQSxLQUFLO0FBQ0wsR0FBRztBQUNIOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLDhCQUE4QjtBQUM5QiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3V0aWxzL29wZW5haS9pbmRleC5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgY3VycmVudFNjb3BlcyA9IHJlcXVpcmUoJy4uLy4uL2N1cnJlbnRTY29wZXMuanMnKTtcbmNvbnN0IGV4cG9ydHMkMSA9IHJlcXVpcmUoJy4uLy4uL2V4cG9ydHMuanMnKTtcbmNvbnN0IHRyYWNlID0gcmVxdWlyZSgnLi4vLi4vdHJhY2luZy90cmFjZS5qcycpO1xuY29uc3QgZ2VuQWlBdHRyaWJ1dGVzID0gcmVxdWlyZSgnLi4vZ2VuLWFpLWF0dHJpYnV0ZXMuanMnKTtcbmNvbnN0IGNvbnN0YW50cyA9IHJlcXVpcmUoJy4vY29uc3RhbnRzLmpzJyk7XG5jb25zdCB1dGlscyA9IHJlcXVpcmUoJy4vdXRpbHMuanMnKTtcblxuLyoqXG4gKiBFeHRyYWN0IHJlcXVlc3QgYXR0cmlidXRlcyBmcm9tIG1ldGhvZCBhcmd1bWVudHNcbiAqL1xuZnVuY3Rpb24gZXh0cmFjdFJlcXVlc3RBdHRyaWJ1dGVzKGFyZ3MsIG1ldGhvZFBhdGgpIHtcbiAgY29uc3QgYXR0cmlidXRlcyA9IHtcbiAgICBbZ2VuQWlBdHRyaWJ1dGVzLkdFTl9BSV9TWVNURU1fQVRUUklCVVRFXTogJ29wZW5haScsXG4gICAgW2dlbkFpQXR0cmlidXRlcy5HRU5fQUlfT1BFUkFUSU9OX05BTUVfQVRUUklCVVRFXTogdXRpbHMuZ2V0T3BlcmF0aW9uTmFtZShtZXRob2RQYXRoKSxcbiAgfTtcblxuICBpZiAoYXJncy5sZW5ndGggPiAwICYmIHR5cGVvZiBhcmdzWzBdID09PSAnb2JqZWN0JyAmJiBhcmdzWzBdICE9PSBudWxsKSB7XG4gICAgY29uc3QgcGFyYW1zID0gYXJnc1swXSA7XG5cbiAgICBhdHRyaWJ1dGVzW2dlbkFpQXR0cmlidXRlcy5HRU5fQUlfUkVRVUVTVF9NT0RFTF9BVFRSSUJVVEVdID0gcGFyYW1zLm1vZGVsID8/ICd1bmtub3duJztcbiAgICBpZiAoJ3RlbXBlcmF0dXJlJyBpbiBwYXJhbXMpIGF0dHJpYnV0ZXNbZ2VuQWlBdHRyaWJ1dGVzLkdFTl9BSV9SRVFVRVNUX1RFTVBFUkFUVVJFX0FUVFJJQlVURV0gPSBwYXJhbXMudGVtcGVyYXR1cmU7XG4gICAgaWYgKCd0b3BfcCcgaW4gcGFyYW1zKSBhdHRyaWJ1dGVzW2dlbkFpQXR0cmlidXRlcy5HRU5fQUlfUkVRVUVTVF9UT1BfUF9BVFRSSUJVVEVdID0gcGFyYW1zLnRvcF9wO1xuICAgIGlmICgnZnJlcXVlbmN5X3BlbmFsdHknIGluIHBhcmFtcylcbiAgICAgIGF0dHJpYnV0ZXNbZ2VuQWlBdHRyaWJ1dGVzLkdFTl9BSV9SRVFVRVNUX0ZSRVFVRU5DWV9QRU5BTFRZX0FUVFJJQlVURV0gPSBwYXJhbXMuZnJlcXVlbmN5X3BlbmFsdHk7XG4gICAgaWYgKCdwcmVzZW5jZV9wZW5hbHR5JyBpbiBwYXJhbXMpIGF0dHJpYnV0ZXNbZ2VuQWlBdHRyaWJ1dGVzLkdFTl9BSV9SRVFVRVNUX1BSRVNFTkNFX1BFTkFMVFlfQVRUUklCVVRFXSA9IHBhcmFtcy5wcmVzZW5jZV9wZW5hbHR5O1xuICB9IGVsc2Uge1xuICAgIGF0dHJpYnV0ZXNbZ2VuQWlBdHRyaWJ1dGVzLkdFTl9BSV9SRVFVRVNUX01PREVMX0FUVFJJQlVURV0gPSAndW5rbm93bic7XG4gIH1cblxuICByZXR1cm4gYXR0cmlidXRlcztcbn1cblxuLyoqXG4gKiBIZWxwZXIgZnVuY3Rpb24gdG8gc2V0IHRva2VuIHVzYWdlIGF0dHJpYnV0ZXNcbiAqL1xuZnVuY3Rpb24gc2V0VG9rZW5Vc2FnZUF0dHJpYnV0ZXMoXG4gIHNwYW4sXG4gIHByb21wdFRva2VucyxcbiAgY29tcGxldGlvblRva2VucyxcbiAgdG90YWxUb2tlbnMsXG4pIHtcbiAgaWYgKHByb21wdFRva2VucyAhPT0gdW5kZWZpbmVkKSB7XG4gICAgc3Bhbi5zZXRBdHRyaWJ1dGVzKHtcbiAgICAgIFtnZW5BaUF0dHJpYnV0ZXMuT1BFTkFJX1VTQUdFX1BST01QVF9UT0tFTlNfQVRUUklCVVRFXTogcHJvbXB0VG9rZW5zLFxuICAgICAgW2dlbkFpQXR0cmlidXRlcy5HRU5fQUlfVVNBR0VfSU5QVVRfVE9LRU5TX0FUVFJJQlVURV06IHByb21wdFRva2VucyxcbiAgICB9KTtcbiAgfVxuICBpZiAoY29tcGxldGlvblRva2VucyAhPT0gdW5kZWZpbmVkKSB7XG4gICAgc3Bhbi5zZXRBdHRyaWJ1dGVzKHtcbiAgICAgIFtnZW5BaUF0dHJpYnV0ZXMuT1BFTkFJX1VTQUdFX0NPTVBMRVRJT05fVE9LRU5TX0FUVFJJQlVURV06IGNvbXBsZXRpb25Ub2tlbnMsXG4gICAgICBbZ2VuQWlBdHRyaWJ1dGVzLkdFTl9BSV9VU0FHRV9PVVRQVVRfVE9LRU5TX0FUVFJJQlVURV06IGNvbXBsZXRpb25Ub2tlbnMsXG4gICAgfSk7XG4gIH1cbiAgaWYgKHRvdGFsVG9rZW5zICE9PSB1bmRlZmluZWQpIHtcbiAgICBzcGFuLnNldEF0dHJpYnV0ZXMoe1xuICAgICAgW2dlbkFpQXR0cmlidXRlcy5HRU5fQUlfVVNBR0VfVE9UQUxfVE9LRU5TX0FUVFJJQlVURV06IHRvdGFsVG9rZW5zLFxuICAgIH0pO1xuICB9XG59XG5cbi8qKlxuICogSGVscGVyIGZ1bmN0aW9uIHRvIHNldCBjb21tb24gcmVzcG9uc2UgYXR0cmlidXRlcyAoSUQsIG1vZGVsLCB0aW1lc3RhbXApXG4gKi9cbmZ1bmN0aW9uIHNldENvbW1vblJlc3BvbnNlQXR0cmlidXRlcyhzcGFuLCBpZCwgbW9kZWwsIHRpbWVzdGFtcCkge1xuICBpZiAoaWQpIHtcbiAgICBzcGFuLnNldEF0dHJpYnV0ZXMoe1xuICAgICAgW2dlbkFpQXR0cmlidXRlcy5PUEVOQUlfUkVTUE9OU0VfSURfQVRUUklCVVRFXTogaWQsXG4gICAgICBbZ2VuQWlBdHRyaWJ1dGVzLkdFTl9BSV9SRVNQT05TRV9JRF9BVFRSSUJVVEVdOiBpZCxcbiAgICB9KTtcbiAgfVxuICBpZiAobW9kZWwpIHtcbiAgICBzcGFuLnNldEF0dHJpYnV0ZXMoe1xuICAgICAgW2dlbkFpQXR0cmlidXRlcy5PUEVOQUlfUkVTUE9OU0VfTU9ERUxfQVRUUklCVVRFXTogbW9kZWwsXG4gICAgICBbZ2VuQWlBdHRyaWJ1dGVzLkdFTl9BSV9SRVNQT05TRV9NT0RFTF9BVFRSSUJVVEVdOiBtb2RlbCxcbiAgICB9KTtcbiAgfVxuICBpZiAodGltZXN0YW1wKSB7XG4gICAgc3Bhbi5zZXRBdHRyaWJ1dGVzKHtcbiAgICAgIFtnZW5BaUF0dHJpYnV0ZXMuT1BFTkFJX1JFU1BPTlNFX1RJTUVTVEFNUF9BVFRSSUJVVEVdOiBuZXcgRGF0ZSh0aW1lc3RhbXAgKiAxMDAwKS50b0lTT1N0cmluZygpLFxuICAgIH0pO1xuICB9XG59XG5cbi8qKlxuICogQWRkIGF0dHJpYnV0ZXMgZm9yIENoYXQgQ29tcGxldGlvbiByZXNwb25zZXNcbiAqL1xuZnVuY3Rpb24gYWRkQ2hhdENvbXBsZXRpb25BdHRyaWJ1dGVzKHNwYW4sIHJlc3BvbnNlKSB7XG4gIHNldENvbW1vblJlc3BvbnNlQXR0cmlidXRlcyhzcGFuLCByZXNwb25zZS5pZCwgcmVzcG9uc2UubW9kZWwsIHJlc3BvbnNlLmNyZWF0ZWQpO1xuICBpZiAocmVzcG9uc2UudXNhZ2UpIHtcbiAgICBzZXRUb2tlblVzYWdlQXR0cmlidXRlcyhcbiAgICAgIHNwYW4sXG4gICAgICByZXNwb25zZS51c2FnZS5wcm9tcHRfdG9rZW5zLFxuICAgICAgcmVzcG9uc2UudXNhZ2UuY29tcGxldGlvbl90b2tlbnMsXG4gICAgICByZXNwb25zZS51c2FnZS50b3RhbF90b2tlbnMsXG4gICAgKTtcbiAgfVxuICBpZiAoQXJyYXkuaXNBcnJheShyZXNwb25zZS5jaG9pY2VzKSkge1xuICAgIGNvbnN0IGZpbmlzaFJlYXNvbnMgPSByZXNwb25zZS5jaG9pY2VzXG4gICAgICAubWFwKGNob2ljZSA9PiBjaG9pY2UuZmluaXNoX3JlYXNvbilcbiAgICAgIC5maWx0ZXIoKHJlYXNvbikgPT4gcmVhc29uICE9PSBudWxsKTtcbiAgICBpZiAoZmluaXNoUmVhc29ucy5sZW5ndGggPiAwKSB7XG4gICAgICBzcGFuLnNldEF0dHJpYnV0ZXMoe1xuICAgICAgICBbZ2VuQWlBdHRyaWJ1dGVzLkdFTl9BSV9SRVNQT05TRV9GSU5JU0hfUkVBU09OU19BVFRSSUJVVEVdOiBKU09OLnN0cmluZ2lmeShmaW5pc2hSZWFzb25zKSxcbiAgICAgIH0pO1xuICAgIH1cbiAgfVxufVxuXG4vKipcbiAqIEFkZCBhdHRyaWJ1dGVzIGZvciBSZXNwb25zZXMgQVBJIHJlc3BvbnNlc1xuICovXG5mdW5jdGlvbiBhZGRSZXNwb25zZXNBcGlBdHRyaWJ1dGVzKHNwYW4sIHJlc3BvbnNlKSB7XG4gIHNldENvbW1vblJlc3BvbnNlQXR0cmlidXRlcyhzcGFuLCByZXNwb25zZS5pZCwgcmVzcG9uc2UubW9kZWwsIHJlc3BvbnNlLmNyZWF0ZWRfYXQpO1xuICBpZiAocmVzcG9uc2Uuc3RhdHVzKSB7XG4gICAgc3Bhbi5zZXRBdHRyaWJ1dGVzKHtcbiAgICAgIFtnZW5BaUF0dHJpYnV0ZXMuR0VOX0FJX1JFU1BPTlNFX0ZJTklTSF9SRUFTT05TX0FUVFJJQlVURV06IEpTT04uc3RyaW5naWZ5KFtyZXNwb25zZS5zdGF0dXNdKSxcbiAgICB9KTtcbiAgfVxuICBpZiAocmVzcG9uc2UudXNhZ2UpIHtcbiAgICBzZXRUb2tlblVzYWdlQXR0cmlidXRlcyhcbiAgICAgIHNwYW4sXG4gICAgICByZXNwb25zZS51c2FnZS5pbnB1dF90b2tlbnMsXG4gICAgICByZXNwb25zZS51c2FnZS5vdXRwdXRfdG9rZW5zLFxuICAgICAgcmVzcG9uc2UudXNhZ2UudG90YWxfdG9rZW5zLFxuICAgICk7XG4gIH1cbn1cblxuLyoqXG4gKiBBZGQgcmVzcG9uc2UgYXR0cmlidXRlcyB0byBzcGFuc1xuICogVGhpcyBjdXJyZW50bHkgc3VwcG9ydHMgYm90aCBDaGF0IENvbXBsZXRpb24gYW5kIFJlc3BvbnNlcyBBUEkgcmVzcG9uc2VzXG4gKi9cbmZ1bmN0aW9uIGFkZFJlc3BvbnNlQXR0cmlidXRlcyhzcGFuLCByZXN1bHQsIHJlY29yZE91dHB1dHMpIHtcbiAgaWYgKCFyZXN1bHQgfHwgdHlwZW9mIHJlc3VsdCAhPT0gJ29iamVjdCcpIHJldHVybjtcblxuICBjb25zdCByZXNwb25zZSA9IHJlc3VsdCA7XG5cbiAgaWYgKHV0aWxzLmlzQ2hhdENvbXBsZXRpb25SZXNwb25zZShyZXNwb25zZSkpIHtcbiAgICBhZGRDaGF0Q29tcGxldGlvbkF0dHJpYnV0ZXMoc3BhbiwgcmVzcG9uc2UpO1xuICAgIGlmIChyZWNvcmRPdXRwdXRzICYmIHJlc3BvbnNlLmNob2ljZXM/Lmxlbmd0aCkge1xuICAgICAgY29uc3QgcmVzcG9uc2VUZXh0cyA9IHJlc3BvbnNlLmNob2ljZXMubWFwKGNob2ljZSA9PiBjaG9pY2UubWVzc2FnZT8uY29udGVudCB8fCAnJyk7XG4gICAgICBzcGFuLnNldEF0dHJpYnV0ZXMoeyBbZ2VuQWlBdHRyaWJ1dGVzLkdFTl9BSV9SRVNQT05TRV9URVhUX0FUVFJJQlVURV06IEpTT04uc3RyaW5naWZ5KHJlc3BvbnNlVGV4dHMpIH0pO1xuICAgIH1cbiAgfSBlbHNlIGlmICh1dGlscy5pc1Jlc3BvbnNlc0FwaVJlc3BvbnNlKHJlc3BvbnNlKSkge1xuICAgIGFkZFJlc3BvbnNlc0FwaUF0dHJpYnV0ZXMoc3BhbiwgcmVzcG9uc2UpO1xuICAgIGlmIChyZWNvcmRPdXRwdXRzICYmIHJlc3BvbnNlLm91dHB1dF90ZXh0KSB7XG4gICAgICBzcGFuLnNldEF0dHJpYnV0ZXMoeyBbZ2VuQWlBdHRyaWJ1dGVzLkdFTl9BSV9SRVNQT05TRV9URVhUX0FUVFJJQlVURV06IHJlc3BvbnNlLm91dHB1dF90ZXh0IH0pO1xuICAgIH1cbiAgfVxufVxuXG4vLyBFeHRyYWN0IGFuZCByZWNvcmQgQUkgcmVxdWVzdCBpbnB1dHMsIGlmIHByZXNlbnQuIFRoaXMgaXMgaW50ZW50aW9uYWxseSBzZXBhcmF0ZSBmcm9tIHJlc3BvbnNlIGF0dHJpYnV0ZXMuXG5mdW5jdGlvbiBhZGRSZXF1ZXN0QXR0cmlidXRlcyhzcGFuLCBwYXJhbXMpIHtcbiAgaWYgKCdtZXNzYWdlcycgaW4gcGFyYW1zKSB7XG4gICAgc3Bhbi5zZXRBdHRyaWJ1dGVzKHsgW2dlbkFpQXR0cmlidXRlcy5HRU5fQUlfUkVRVUVTVF9NRVNTQUdFU19BVFRSSUJVVEVdOiBKU09OLnN0cmluZ2lmeShwYXJhbXMubWVzc2FnZXMpIH0pO1xuICB9XG4gIGlmICgnaW5wdXQnIGluIHBhcmFtcykge1xuICAgIHNwYW4uc2V0QXR0cmlidXRlcyh7IFtnZW5BaUF0dHJpYnV0ZXMuR0VOX0FJX1JFUVVFU1RfTUVTU0FHRVNfQVRUUklCVVRFXTogSlNPTi5zdHJpbmdpZnkocGFyYW1zLmlucHV0KSB9KTtcbiAgfVxufVxuXG5mdW5jdGlvbiBnZXRPcHRpb25zRnJvbUludGVncmF0aW9uKCkge1xuICBjb25zdCBzY29wZSA9IGN1cnJlbnRTY29wZXMuZ2V0Q3VycmVudFNjb3BlKCk7XG4gIGNvbnN0IGNsaWVudCA9IHNjb3BlLmdldENsaWVudCgpO1xuICBjb25zdCBpbnRlZ3JhdGlvbiA9IGNsaWVudD8uZ2V0SW50ZWdyYXRpb25CeU5hbWUoY29uc3RhbnRzLk9QRU5BSV9JTlRFR1JBVElPTl9OQU1FKSA7XG4gIGNvbnN0IHNob3VsZFJlY29yZElucHV0c0FuZE91dHB1dHMgPSBpbnRlZ3JhdGlvbiA/IEJvb2xlYW4oY2xpZW50Py5nZXRPcHRpb25zKCkuc2VuZERlZmF1bHRQaWkpIDogZmFsc2U7XG5cbiAgcmV0dXJuIHtcbiAgICByZWNvcmRJbnB1dHM6IGludGVncmF0aW9uPy5vcHRpb25zPy5yZWNvcmRJbnB1dHMgPz8gc2hvdWxkUmVjb3JkSW5wdXRzQW5kT3V0cHV0cyxcbiAgICByZWNvcmRPdXRwdXRzOiBpbnRlZ3JhdGlvbj8ub3B0aW9ucz8ucmVjb3JkT3V0cHV0cyA/PyBzaG91bGRSZWNvcmRJbnB1dHNBbmRPdXRwdXRzLFxuICB9O1xufVxuXG4vKipcbiAqIEluc3RydW1lbnQgYSBtZXRob2Qgd2l0aCBTZW50cnkgc3BhbnNcbiAqIEZvbGxvd2luZyBTZW50cnkgQUkgQWdlbnRzIE1hbnVhbCBJbnN0cnVtZW50YXRpb24gY29udmVudGlvbnNcbiAqIEBzZWUgaHR0cHM6Ly9kb2NzLnNlbnRyeS5pby9wbGF0Zm9ybXMvamF2YXNjcmlwdC9ndWlkZXMvbm9kZS90cmFjaW5nL2luc3RydW1lbnRhdGlvbi9haS1hZ2VudHMtbW9kdWxlLyNtYW51YWwtaW5zdHJ1bWVudGF0aW9uXG4gKi9cbmZ1bmN0aW9uIGluc3RydW1lbnRNZXRob2QoXG4gIG9yaWdpbmFsTWV0aG9kLFxuICBtZXRob2RQYXRoLFxuICBjb250ZXh0LFxuICBvcHRpb25zLFxuKSB7XG4gIHJldHVybiBhc3luYyBmdW5jdGlvbiBpbnN0cnVtZW50ZWRNZXRob2QoLi4uYXJncykge1xuICAgIGNvbnN0IGZpbmFsT3B0aW9ucyA9IG9wdGlvbnMgfHwgZ2V0T3B0aW9uc0Zyb21JbnRlZ3JhdGlvbigpO1xuICAgIGNvbnN0IHJlcXVlc3RBdHRyaWJ1dGVzID0gZXh0cmFjdFJlcXVlc3RBdHRyaWJ1dGVzKGFyZ3MsIG1ldGhvZFBhdGgpO1xuICAgIGNvbnN0IG1vZGVsID0gKHJlcXVlc3RBdHRyaWJ1dGVzW2dlbkFpQXR0cmlidXRlcy5HRU5fQUlfUkVRVUVTVF9NT0RFTF9BVFRSSUJVVEVdICkgfHwgJ3Vua25vd24nO1xuICAgIGNvbnN0IG9wZXJhdGlvbk5hbWUgPSB1dGlscy5nZXRPcGVyYXRpb25OYW1lKG1ldGhvZFBhdGgpO1xuXG4gICAgcmV0dXJuIHRyYWNlLnN0YXJ0U3BhbihcbiAgICAgIHtcbiAgICAgICAgbmFtZTogYCR7b3BlcmF0aW9uTmFtZX0gJHttb2RlbH1gLFxuICAgICAgICBvcDogdXRpbHMuZ2V0U3Bhbk9wZXJhdGlvbihtZXRob2RQYXRoKSxcbiAgICAgICAgYXR0cmlidXRlczogcmVxdWVzdEF0dHJpYnV0ZXMgLFxuICAgICAgfSxcbiAgICAgIGFzeW5jIChzcGFuKSA9PiB7XG4gICAgICAgIHRyeSB7XG4gICAgICAgICAgaWYgKGZpbmFsT3B0aW9ucy5yZWNvcmRJbnB1dHMgJiYgYXJnc1swXSAmJiB0eXBlb2YgYXJnc1swXSA9PT0gJ29iamVjdCcpIHtcbiAgICAgICAgICAgIGFkZFJlcXVlc3RBdHRyaWJ1dGVzKHNwYW4sIGFyZ3NbMF0gKTtcbiAgICAgICAgICB9XG5cbiAgICAgICAgICBjb25zdCByZXN1bHQgPSBhd2FpdCBvcmlnaW5hbE1ldGhvZC5hcHBseShjb250ZXh0LCBhcmdzKTtcbiAgICAgICAgICAvLyBUT0RPOiBBZGQgc3RyZWFtaW5nIHN1cHBvcnRcbiAgICAgICAgICBhZGRSZXNwb25zZUF0dHJpYnV0ZXMoc3BhbiwgcmVzdWx0LCBmaW5hbE9wdGlvbnMucmVjb3JkT3V0cHV0cyk7XG4gICAgICAgICAgcmV0dXJuIHJlc3VsdDtcbiAgICAgICAgfSBjYXRjaCAoZXJyb3IpIHtcbiAgICAgICAgICBleHBvcnRzJDEuY2FwdHVyZUV4Y2VwdGlvbihlcnJvcik7XG4gICAgICAgICAgdGhyb3cgZXJyb3I7XG4gICAgICAgIH1cbiAgICAgIH0sXG4gICAgKTtcbiAgfTtcbn1cblxuLyoqXG4gKiBDcmVhdGUgYSBkZWVwIHByb3h5IGZvciBPcGVuQUkgY2xpZW50IGluc3RydW1lbnRhdGlvblxuICovXG5mdW5jdGlvbiBjcmVhdGVEZWVwUHJveHkodGFyZ2V0LCBjdXJyZW50UGF0aCA9ICcnLCBvcHRpb25zKSB7XG4gIHJldHVybiBuZXcgUHJveHkodGFyZ2V0LCB7XG4gICAgZ2V0KG9iaiwgcHJvcCkge1xuICAgICAgY29uc3QgdmFsdWUgPSAob2JqIClbcHJvcF07XG4gICAgICBjb25zdCBtZXRob2RQYXRoID0gdXRpbHMuYnVpbGRNZXRob2RQYXRoKGN1cnJlbnRQYXRoLCBTdHJpbmcocHJvcCkpO1xuXG4gICAgICBpZiAodHlwZW9mIHZhbHVlID09PSAnZnVuY3Rpb24nICYmIHV0aWxzLnNob3VsZEluc3RydW1lbnQobWV0aG9kUGF0aCkpIHtcbiAgICAgICAgcmV0dXJuIGluc3RydW1lbnRNZXRob2QodmFsdWUgLCBtZXRob2RQYXRoLCBvYmosIG9wdGlvbnMpO1xuICAgICAgfVxuXG4gICAgICBpZiAodHlwZW9mIHZhbHVlID09PSAnZnVuY3Rpb24nKSB7XG4gICAgICAgIC8vIEJpbmQgbm9uLWluc3RydW1lbnRlZCBmdW5jdGlvbnMgdG8gcHJlc2VydmUgdGhlIG9yaWdpbmFsIGB0aGlzYCBjb250ZXh0LFxuICAgICAgICAvLyB3aGljaCBpcyByZXF1aXJlZCBmb3IgYWNjZXNzaW5nIHByaXZhdGUgY2xhc3MgZmllbGRzIChlLmcuICNiYXNlVVJMKSBpbiBPcGVuQUkgU0RLIHY1LlxuICAgICAgICByZXR1cm4gdmFsdWUuYmluZChvYmopO1xuICAgICAgfVxuXG4gICAgICBpZiAodmFsdWUgJiYgdHlwZW9mIHZhbHVlID09PSAnb2JqZWN0Jykge1xuICAgICAgICByZXR1cm4gY3JlYXRlRGVlcFByb3h5KHZhbHVlICwgbWV0aG9kUGF0aCwgb3B0aW9ucyk7XG4gICAgICB9XG5cbiAgICAgIHJldHVybiB2YWx1ZTtcbiAgICB9LFxuICB9KTtcbn1cblxuLyoqXG4gKiBJbnN0cnVtZW50IGFuIE9wZW5BSSBjbGllbnQgd2l0aCBTZW50cnkgdHJhY2luZ1xuICogQ2FuIGJlIHVzZWQgYWNyb3NzIE5vZGUuanMsIENsb3VkZmxhcmUgV29ya2VycywgYW5kIFZlcmNlbCBFZGdlXG4gKi9cbmZ1bmN0aW9uIGluc3RydW1lbnRPcGVuQWlDbGllbnQoY2xpZW50LCBvcHRpb25zKSB7XG4gIHJldHVybiBjcmVhdGVEZWVwUHJveHkoY2xpZW50LCAnJywgb3B0aW9ucyk7XG59XG5cbmV4cG9ydHMuaW5zdHJ1bWVudE9wZW5BaUNsaWVudCA9IGluc3RydW1lbnRPcGVuQWlDbGllbnQ7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1pbmRleC5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/openai/index.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/openai/utils.js":
/*!**********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/openai/utils.js ***!
  \**********************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst genAiAttributes = __webpack_require__(/*! ../gen-ai-attributes.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/gen-ai-attributes.js\");\nconst constants = __webpack_require__(/*! ./constants.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/openai/constants.js\");\n\n/**\n * Maps OpenAI method paths to Sentry operation names\n */\nfunction getOperationName(methodPath) {\n  if (methodPath.includes('chat.completions')) {\n    return genAiAttributes.OPENAI_OPERATIONS.CHAT;\n  }\n  if (methodPath.includes('responses')) {\n    // The responses API is also a chat operation\n    return genAiAttributes.OPENAI_OPERATIONS.CHAT;\n  }\n  return methodPath.split('.').pop() || 'unknown';\n}\n\n/**\n * Get the span operation for OpenAI methods\n * Following Sentry's convention: \"gen_ai.{operation_name}\"\n */\nfunction getSpanOperation(methodPath) {\n  return `gen_ai.${getOperationName(methodPath)}`;\n}\n\n/**\n * Check if a method path should be instrumented\n */\nfunction shouldInstrument(methodPath) {\n  return constants.INSTRUMENTED_METHODS.includes(methodPath );\n}\n\n/**\n * Build method path from current traversal\n */\nfunction buildMethodPath(currentPath, prop) {\n  return currentPath ? `${currentPath}.${prop}` : prop;\n}\n\n/**\n * Check if response is a Chat Completion object\n */\nfunction isChatCompletionResponse(response) {\n  return (\n    response !== null &&\n    typeof response === 'object' &&\n    'object' in response &&\n    (response ).object === 'chat.completion'\n  );\n}\n\n/**\n * Check if response is a Responses API object\n */\nfunction isResponsesApiResponse(response) {\n  return (\n    response !== null &&\n    typeof response === 'object' &&\n    'object' in response &&\n    (response ).object === 'response'\n  );\n}\n\nexports.buildMethodPath = buildMethodPath;\nexports.getOperationName = getOperationName;\nexports.getSpanOperation = getSpanOperation;\nexports.isChatCompletionResponse = isChatCompletionResponse;\nexports.isResponsesApiResponse = isResponsesApiResponse;\nexports.shouldInstrument = shouldInstrument;\n//# sourceMappingURL=utils.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9vcGVuYWkvdXRpbHMuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsd0JBQXdCLG1CQUFPLENBQUMsOElBQXlCO0FBQ3pELGtCQUFrQixtQkFBTyxDQUFDLG9JQUFnQjs7QUFFMUM7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLDJDQUEyQyxlQUFlO0FBQzFEO0FBQ0E7QUFDQSxtQkFBbUIsNkJBQTZCO0FBQ2hEOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLDBCQUEwQixZQUFZLEdBQUcsS0FBSztBQUM5Qzs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsdUJBQXVCO0FBQ3ZCLHdCQUF3QjtBQUN4Qix3QkFBd0I7QUFDeEIsZ0NBQWdDO0FBQ2hDLDhCQUE4QjtBQUM5Qix3QkFBd0I7QUFDeEIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9vcGVuYWkvdXRpbHMuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGdlbkFpQXR0cmlidXRlcyA9IHJlcXVpcmUoJy4uL2dlbi1haS1hdHRyaWJ1dGVzLmpzJyk7XG5jb25zdCBjb25zdGFudHMgPSByZXF1aXJlKCcuL2NvbnN0YW50cy5qcycpO1xuXG4vKipcbiAqIE1hcHMgT3BlbkFJIG1ldGhvZCBwYXRocyB0byBTZW50cnkgb3BlcmF0aW9uIG5hbWVzXG4gKi9cbmZ1bmN0aW9uIGdldE9wZXJhdGlvbk5hbWUobWV0aG9kUGF0aCkge1xuICBpZiAobWV0aG9kUGF0aC5pbmNsdWRlcygnY2hhdC5jb21wbGV0aW9ucycpKSB7XG4gICAgcmV0dXJuIGdlbkFpQXR0cmlidXRlcy5PUEVOQUlfT1BFUkFUSU9OUy5DSEFUO1xuICB9XG4gIGlmIChtZXRob2RQYXRoLmluY2x1ZGVzKCdyZXNwb25zZXMnKSkge1xuICAgIC8vIFRoZSByZXNwb25zZXMgQVBJIGlzIGFsc28gYSBjaGF0IG9wZXJhdGlvblxuICAgIHJldHVybiBnZW5BaUF0dHJpYnV0ZXMuT1BFTkFJX09QRVJBVElPTlMuQ0hBVDtcbiAgfVxuICByZXR1cm4gbWV0aG9kUGF0aC5zcGxpdCgnLicpLnBvcCgpIHx8ICd1bmtub3duJztcbn1cblxuLyoqXG4gKiBHZXQgdGhlIHNwYW4gb3BlcmF0aW9uIGZvciBPcGVuQUkgbWV0aG9kc1xuICogRm9sbG93aW5nIFNlbnRyeSdzIGNvbnZlbnRpb246IFwiZ2VuX2FpLntvcGVyYXRpb25fbmFtZX1cIlxuICovXG5mdW5jdGlvbiBnZXRTcGFuT3BlcmF0aW9uKG1ldGhvZFBhdGgpIHtcbiAgcmV0dXJuIGBnZW5fYWkuJHtnZXRPcGVyYXRpb25OYW1lKG1ldGhvZFBhdGgpfWA7XG59XG5cbi8qKlxuICogQ2hlY2sgaWYgYSBtZXRob2QgcGF0aCBzaG91bGQgYmUgaW5zdHJ1bWVudGVkXG4gKi9cbmZ1bmN0aW9uIHNob3VsZEluc3RydW1lbnQobWV0aG9kUGF0aCkge1xuICByZXR1cm4gY29uc3RhbnRzLklOU1RSVU1FTlRFRF9NRVRIT0RTLmluY2x1ZGVzKG1ldGhvZFBhdGggKTtcbn1cblxuLyoqXG4gKiBCdWlsZCBtZXRob2QgcGF0aCBmcm9tIGN1cnJlbnQgdHJhdmVyc2FsXG4gKi9cbmZ1bmN0aW9uIGJ1aWxkTWV0aG9kUGF0aChjdXJyZW50UGF0aCwgcHJvcCkge1xuICByZXR1cm4gY3VycmVudFBhdGggPyBgJHtjdXJyZW50UGF0aH0uJHtwcm9wfWAgOiBwcm9wO1xufVxuXG4vKipcbiAqIENoZWNrIGlmIHJlc3BvbnNlIGlzIGEgQ2hhdCBDb21wbGV0aW9uIG9iamVjdFxuICovXG5mdW5jdGlvbiBpc0NoYXRDb21wbGV0aW9uUmVzcG9uc2UocmVzcG9uc2UpIHtcbiAgcmV0dXJuIChcbiAgICByZXNwb25zZSAhPT0gbnVsbCAmJlxuICAgIHR5cGVvZiByZXNwb25zZSA9PT0gJ29iamVjdCcgJiZcbiAgICAnb2JqZWN0JyBpbiByZXNwb25zZSAmJlxuICAgIChyZXNwb25zZSApLm9iamVjdCA9PT0gJ2NoYXQuY29tcGxldGlvbidcbiAgKTtcbn1cblxuLyoqXG4gKiBDaGVjayBpZiByZXNwb25zZSBpcyBhIFJlc3BvbnNlcyBBUEkgb2JqZWN0XG4gKi9cbmZ1bmN0aW9uIGlzUmVzcG9uc2VzQXBpUmVzcG9uc2UocmVzcG9uc2UpIHtcbiAgcmV0dXJuIChcbiAgICByZXNwb25zZSAhPT0gbnVsbCAmJlxuICAgIHR5cGVvZiByZXNwb25zZSA9PT0gJ29iamVjdCcgJiZcbiAgICAnb2JqZWN0JyBpbiByZXNwb25zZSAmJlxuICAgIChyZXNwb25zZSApLm9iamVjdCA9PT0gJ3Jlc3BvbnNlJ1xuICApO1xufVxuXG5leHBvcnRzLmJ1aWxkTWV0aG9kUGF0aCA9IGJ1aWxkTWV0aG9kUGF0aDtcbmV4cG9ydHMuZ2V0T3BlcmF0aW9uTmFtZSA9IGdldE9wZXJhdGlvbk5hbWU7XG5leHBvcnRzLmdldFNwYW5PcGVyYXRpb24gPSBnZXRTcGFuT3BlcmF0aW9uO1xuZXhwb3J0cy5pc0NoYXRDb21wbGV0aW9uUmVzcG9uc2UgPSBpc0NoYXRDb21wbGV0aW9uUmVzcG9uc2U7XG5leHBvcnRzLmlzUmVzcG9uc2VzQXBpUmVzcG9uc2UgPSBpc1Jlc3BvbnNlc0FwaVJlc3BvbnNlO1xuZXhwb3J0cy5zaG91bGRJbnN0cnVtZW50ID0gc2hvdWxkSW5zdHJ1bWVudDtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPXV0aWxzLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/openai/utils.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/parameterize.js":
/*!**********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/parameterize.js ***!
  \**********************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n/**\n * Tagged template function which returns parameterized representation of the message\n * For example: parameterize`This is a log statement with ${x} and ${y} params`, would return:\n * \"__sentry_template_string__\": 'This is a log statement with %s and %s params',\n * \"__sentry_template_values__\": ['first', 'second']\n *\n * @param strings An array of string values splitted between expressions\n * @param values Expressions extracted from template string\n *\n * @returns A `ParameterizedString` object that can be passed into `captureMessage` or Sentry.logger.X methods.\n */\nfunction parameterize(strings, ...values) {\n  const formatted = new String(String.raw(strings, ...values)) ;\n  formatted.__sentry_template_string__ = strings.join('\\x00').replace(/%/g, '%%').replace(/\\0/g, '%s');\n  formatted.__sentry_template_values__ = values;\n  return formatted;\n}\n\n/**\n * Tagged template function which returns parameterized representation of the message.\n *\n * @param strings An array of string values splitted between expressions\n * @param values Expressions extracted from template string\n * @returns A `ParameterizedString` object that can be passed into `captureMessage` or Sentry.logger.X methods.\n */\nconst fmt = parameterize;\n\nexports.fmt = fmt;\nexports.parameterize = parameterize;\n//# sourceMappingURL=parameterize.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9wYXJhbWV0ZXJpemUuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEU7QUFDQTtBQUNBLDREQUE0RCxHQUFHLE1BQU0sR0FBRztBQUN4RTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsV0FBVztBQUNYLG9CQUFvQjtBQUNwQiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3V0aWxzL3BhcmFtZXRlcml6ZS5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuLyoqXG4gKiBUYWdnZWQgdGVtcGxhdGUgZnVuY3Rpb24gd2hpY2ggcmV0dXJucyBwYXJhbWV0ZXJpemVkIHJlcHJlc2VudGF0aW9uIG9mIHRoZSBtZXNzYWdlXG4gKiBGb3IgZXhhbXBsZTogcGFyYW1ldGVyaXplYFRoaXMgaXMgYSBsb2cgc3RhdGVtZW50IHdpdGggJHt4fSBhbmQgJHt5fSBwYXJhbXNgLCB3b3VsZCByZXR1cm46XG4gKiBcIl9fc2VudHJ5X3RlbXBsYXRlX3N0cmluZ19fXCI6ICdUaGlzIGlzIGEgbG9nIHN0YXRlbWVudCB3aXRoICVzIGFuZCAlcyBwYXJhbXMnLFxuICogXCJfX3NlbnRyeV90ZW1wbGF0ZV92YWx1ZXNfX1wiOiBbJ2ZpcnN0JywgJ3NlY29uZCddXG4gKlxuICogQHBhcmFtIHN0cmluZ3MgQW4gYXJyYXkgb2Ygc3RyaW5nIHZhbHVlcyBzcGxpdHRlZCBiZXR3ZWVuIGV4cHJlc3Npb25zXG4gKiBAcGFyYW0gdmFsdWVzIEV4cHJlc3Npb25zIGV4dHJhY3RlZCBmcm9tIHRlbXBsYXRlIHN0cmluZ1xuICpcbiAqIEByZXR1cm5zIEEgYFBhcmFtZXRlcml6ZWRTdHJpbmdgIG9iamVjdCB0aGF0IGNhbiBiZSBwYXNzZWQgaW50byBgY2FwdHVyZU1lc3NhZ2VgIG9yIFNlbnRyeS5sb2dnZXIuWCBtZXRob2RzLlxuICovXG5mdW5jdGlvbiBwYXJhbWV0ZXJpemUoc3RyaW5ncywgLi4udmFsdWVzKSB7XG4gIGNvbnN0IGZvcm1hdHRlZCA9IG5ldyBTdHJpbmcoU3RyaW5nLnJhdyhzdHJpbmdzLCAuLi52YWx1ZXMpKSA7XG4gIGZvcm1hdHRlZC5fX3NlbnRyeV90ZW1wbGF0ZV9zdHJpbmdfXyA9IHN0cmluZ3Muam9pbignXFx4MDAnKS5yZXBsYWNlKC8lL2csICclJScpLnJlcGxhY2UoL1xcMC9nLCAnJXMnKTtcbiAgZm9ybWF0dGVkLl9fc2VudHJ5X3RlbXBsYXRlX3ZhbHVlc19fID0gdmFsdWVzO1xuICByZXR1cm4gZm9ybWF0dGVkO1xufVxuXG4vKipcbiAqIFRhZ2dlZCB0ZW1wbGF0ZSBmdW5jdGlvbiB3aGljaCByZXR1cm5zIHBhcmFtZXRlcml6ZWQgcmVwcmVzZW50YXRpb24gb2YgdGhlIG1lc3NhZ2UuXG4gKlxuICogQHBhcmFtIHN0cmluZ3MgQW4gYXJyYXkgb2Ygc3RyaW5nIHZhbHVlcyBzcGxpdHRlZCBiZXR3ZWVuIGV4cHJlc3Npb25zXG4gKiBAcGFyYW0gdmFsdWVzIEV4cHJlc3Npb25zIGV4dHJhY3RlZCBmcm9tIHRlbXBsYXRlIHN0cmluZ1xuICogQHJldHVybnMgQSBgUGFyYW1ldGVyaXplZFN0cmluZ2Agb2JqZWN0IHRoYXQgY2FuIGJlIHBhc3NlZCBpbnRvIGBjYXB0dXJlTWVzc2FnZWAgb3IgU2VudHJ5LmxvZ2dlci5YIG1ldGhvZHMuXG4gKi9cbmNvbnN0IGZtdCA9IHBhcmFtZXRlcml6ZTtcblxuZXhwb3J0cy5mbXQgPSBmbXQ7XG5leHBvcnRzLnBhcmFtZXRlcml6ZSA9IHBhcmFtZXRlcml6ZTtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPXBhcmFtZXRlcml6ZS5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/parameterize.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/parseSampleRate.js":
/*!*************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/parseSampleRate.js ***!
  \*************************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n/**\n * Parse a sample rate from a given value.\n * This will either return a boolean or number sample rate, if the sample rate is valid (between 0 and 1).\n * If a string is passed, we try to convert it to a number.\n *\n * Any invalid sample rate will return `undefined`.\n */\nfunction parseSampleRate(sampleRate) {\n  if (typeof sampleRate === 'boolean') {\n    return Number(sampleRate);\n  }\n\n  const rate = typeof sampleRate === 'string' ? parseFloat(sampleRate) : sampleRate;\n  if (typeof rate !== 'number' || isNaN(rate) || rate < 0 || rate > 1) {\n    return undefined;\n  }\n\n  return rate;\n}\n\nexports.parseSampleRate = parseSampleRate;\n//# sourceMappingURL=parseSampleRate.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9wYXJzZVNhbXBsZVJhdGUuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEU7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBLHVCQUF1QjtBQUN2QiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3V0aWxzL3BhcnNlU2FtcGxlUmF0ZS5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuLyoqXG4gKiBQYXJzZSBhIHNhbXBsZSByYXRlIGZyb20gYSBnaXZlbiB2YWx1ZS5cbiAqIFRoaXMgd2lsbCBlaXRoZXIgcmV0dXJuIGEgYm9vbGVhbiBvciBudW1iZXIgc2FtcGxlIHJhdGUsIGlmIHRoZSBzYW1wbGUgcmF0ZSBpcyB2YWxpZCAoYmV0d2VlbiAwIGFuZCAxKS5cbiAqIElmIGEgc3RyaW5nIGlzIHBhc3NlZCwgd2UgdHJ5IHRvIGNvbnZlcnQgaXQgdG8gYSBudW1iZXIuXG4gKlxuICogQW55IGludmFsaWQgc2FtcGxlIHJhdGUgd2lsbCByZXR1cm4gYHVuZGVmaW5lZGAuXG4gKi9cbmZ1bmN0aW9uIHBhcnNlU2FtcGxlUmF0ZShzYW1wbGVSYXRlKSB7XG4gIGlmICh0eXBlb2Ygc2FtcGxlUmF0ZSA9PT0gJ2Jvb2xlYW4nKSB7XG4gICAgcmV0dXJuIE51bWJlcihzYW1wbGVSYXRlKTtcbiAgfVxuXG4gIGNvbnN0IHJhdGUgPSB0eXBlb2Ygc2FtcGxlUmF0ZSA9PT0gJ3N0cmluZycgPyBwYXJzZUZsb2F0KHNhbXBsZVJhdGUpIDogc2FtcGxlUmF0ZTtcbiAgaWYgKHR5cGVvZiByYXRlICE9PSAnbnVtYmVyJyB8fCBpc05hTihyYXRlKSB8fCByYXRlIDwgMCB8fCByYXRlID4gMSkge1xuICAgIHJldHVybiB1bmRlZmluZWQ7XG4gIH1cblxuICByZXR1cm4gcmF0ZTtcbn1cblxuZXhwb3J0cy5wYXJzZVNhbXBsZVJhdGUgPSBwYXJzZVNhbXBsZVJhdGU7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1wYXJzZVNhbXBsZVJhdGUuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/parseSampleRate.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/path.js":
/*!**************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/path.js ***!
  \**************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n// Slightly modified (no IE8 support, ES6) and transcribed to TypeScript\n// https://github.com/calvinmetcalf/rollup-plugin-node-builtins/blob/63ab8aacd013767445ca299e468d9a60a95328d7/src/es6/path.js\n//\n// Copyright Joyent, Inc.and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n/** JSDoc */\nfunction normalizeArray(parts, allowAboveRoot) {\n  // if the path tries to go above the root, `up` ends up > 0\n  let up = 0;\n  for (let i = parts.length - 1; i >= 0; i--) {\n    const last = parts[i];\n    if (last === '.') {\n      parts.splice(i, 1);\n    } else if (last === '..') {\n      parts.splice(i, 1);\n      up++;\n    } else if (up) {\n      parts.splice(i, 1);\n      up--;\n    }\n  }\n\n  // if the path is allowed to go above the root, restore leading ..s\n  if (allowAboveRoot) {\n    for (; up--; up) {\n      parts.unshift('..');\n    }\n  }\n\n  return parts;\n}\n\n// Split a filename into [root, dir, basename, ext], unix version\n// 'root' is just a slash, or nothing.\nconst splitPathRe = /^(\\S+:\\\\|\\/?)([\\s\\S]*?)((?:\\.{1,2}|[^/\\\\]+?|)(\\.[^./\\\\]*|))(?:[/\\\\]*)$/;\n/** JSDoc */\nfunction splitPath(filename) {\n  // Truncate files names greater than 1024 characters to avoid regex dos\n  // https://github.com/getsentry/sentry-javascript/pull/8737#discussion_r1285719172\n  const truncated = filename.length > 1024 ? `<truncated>${filename.slice(-1024)}` : filename;\n  const parts = splitPathRe.exec(truncated);\n  return parts ? parts.slice(1) : [];\n}\n\n// path.resolve([from ...], to)\n// posix version\n/** JSDoc */\nfunction resolve(...args) {\n  let resolvedPath = '';\n  let resolvedAbsolute = false;\n\n  for (let i = args.length - 1; i >= -1 && !resolvedAbsolute; i--) {\n    const path = i >= 0 ? args[i] : '/';\n\n    // Skip empty entries\n    if (!path) {\n      continue;\n    }\n\n    resolvedPath = `${path}/${resolvedPath}`;\n    resolvedAbsolute = path.charAt(0) === '/';\n  }\n\n  // At this point the path should be resolved to a full absolute path, but\n  // handle relative paths to be safe (might happen when process.cwd() fails)\n\n  // Normalize the path\n  resolvedPath = normalizeArray(\n    resolvedPath.split('/').filter(p => !!p),\n    !resolvedAbsolute,\n  ).join('/');\n\n  return (resolvedAbsolute ? '/' : '') + resolvedPath || '.';\n}\n\n/** JSDoc */\nfunction trim(arr) {\n  let start = 0;\n  for (; start < arr.length; start++) {\n    if (arr[start] !== '') {\n      break;\n    }\n  }\n\n  let end = arr.length - 1;\n  for (; end >= 0; end--) {\n    if (arr[end] !== '') {\n      break;\n    }\n  }\n\n  if (start > end) {\n    return [];\n  }\n  return arr.slice(start, end - start + 1);\n}\n\n// path.relative(from, to)\n// posix version\n/** JSDoc */\nfunction relative(from, to) {\n  /* eslint-disable no-param-reassign */\n  from = resolve(from).slice(1);\n  to = resolve(to).slice(1);\n  /* eslint-enable no-param-reassign */\n\n  const fromParts = trim(from.split('/'));\n  const toParts = trim(to.split('/'));\n\n  const length = Math.min(fromParts.length, toParts.length);\n  let samePartsLength = length;\n  for (let i = 0; i < length; i++) {\n    if (fromParts[i] !== toParts[i]) {\n      samePartsLength = i;\n      break;\n    }\n  }\n\n  let outputParts = [];\n  for (let i = samePartsLength; i < fromParts.length; i++) {\n    outputParts.push('..');\n  }\n\n  outputParts = outputParts.concat(toParts.slice(samePartsLength));\n\n  return outputParts.join('/');\n}\n\n// path.normalize(path)\n// posix version\n/** JSDoc */\nfunction normalizePath(path) {\n  const isPathAbsolute = isAbsolute(path);\n  const trailingSlash = path.slice(-1) === '/';\n\n  // Normalize the path\n  let normalizedPath = normalizeArray(\n    path.split('/').filter(p => !!p),\n    !isPathAbsolute,\n  ).join('/');\n\n  if (!normalizedPath && !isPathAbsolute) {\n    normalizedPath = '.';\n  }\n  if (normalizedPath && trailingSlash) {\n    normalizedPath += '/';\n  }\n\n  return (isPathAbsolute ? '/' : '') + normalizedPath;\n}\n\n// posix version\n/** JSDoc */\nfunction isAbsolute(path) {\n  return path.charAt(0) === '/';\n}\n\n// posix version\n/** JSDoc */\nfunction join(...args) {\n  return normalizePath(args.join('/'));\n}\n\n/** JSDoc */\nfunction dirname(path) {\n  const result = splitPath(path);\n  const root = result[0] || '';\n  let dir = result[1];\n\n  if (!root && !dir) {\n    // No dirname whatsoever\n    return '.';\n  }\n\n  if (dir) {\n    // It has a dirname, strip trailing slash\n    dir = dir.slice(0, dir.length - 1);\n  }\n\n  return root + dir;\n}\n\n/** JSDoc */\nfunction basename(path, ext) {\n  let f = splitPath(path)[2] || '';\n  if (ext && f.slice(ext.length * -1) === ext) {\n    f = f.slice(0, f.length - ext.length);\n  }\n  return f;\n}\n\nexports.basename = basename;\nexports.dirname = dirname;\nexports.isAbsolute = isAbsolute;\nexports.join = join;\nexports.normalizePath = normalizePath;\nexports.relative = relative;\nexports.resolve = resolve;\n//# sourceMappingURL=path.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9wYXRoLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQSxpQ0FBaUMsUUFBUTtBQUN6QztBQUNBO0FBQ0E7QUFDQSxNQUFNO0FBQ047QUFDQTtBQUNBLE1BQU07QUFDTjtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsV0FBVyxNQUFNO0FBQ2pCO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQSxtREFBbUQsSUFBSTtBQUN2RDtBQUNBO0FBQ0E7QUFDQTtBQUNBLDJEQUEyRCxzQkFBc0I7QUFDakY7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSxnQ0FBZ0MsOEJBQThCO0FBQzlEOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLHNCQUFzQixLQUFLLEdBQUcsYUFBYTtBQUMzQztBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBLFNBQVMsb0JBQW9CO0FBQzdCO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0EsU0FBUyxVQUFVO0FBQ25CO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQSxrQkFBa0IsWUFBWTtBQUM5QjtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0EsZ0NBQWdDLHNCQUFzQjtBQUN0RDtBQUNBOztBQUVBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLGdCQUFnQjtBQUNoQixlQUFlO0FBQ2Ysa0JBQWtCO0FBQ2xCLFlBQVk7QUFDWixxQkFBcUI7QUFDckIsZ0JBQWdCO0FBQ2hCLGVBQWU7QUFDZiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3V0aWxzL3BhdGguanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbi8vIFNsaWdodGx5IG1vZGlmaWVkIChubyBJRTggc3VwcG9ydCwgRVM2KSBhbmQgdHJhbnNjcmliZWQgdG8gVHlwZVNjcmlwdFxuLy8gaHR0cHM6Ly9naXRodWIuY29tL2NhbHZpbm1ldGNhbGYvcm9sbHVwLXBsdWdpbi1ub2RlLWJ1aWx0aW5zL2Jsb2IvNjNhYjhhYWNkMDEzNzY3NDQ1Y2EyOTllNDY4ZDlhNjBhOTUzMjhkNy9zcmMvZXM2L3BhdGguanNcbi8vXG4vLyBDb3B5cmlnaHQgSm95ZW50LCBJbmMuYW5kIG90aGVyIE5vZGUgY29udHJpYnV0b3JzLlxuLy9cbi8vIFBlcm1pc3Npb24gaXMgaGVyZWJ5IGdyYW50ZWQsIGZyZWUgb2YgY2hhcmdlLCB0byBhbnkgcGVyc29uIG9idGFpbmluZyBhXG4vLyBjb3B5IG9mIHRoaXMgc29mdHdhcmUgYW5kIGFzc29jaWF0ZWQgZG9jdW1lbnRhdGlvbiBmaWxlcyAodGhlXG4vLyBcIlNvZnR3YXJlXCIpLCB0byBkZWFsIGluIHRoZSBTb2Z0d2FyZSB3aXRob3V0IHJlc3RyaWN0aW9uLCBpbmNsdWRpbmdcbi8vIHdpdGhvdXQgbGltaXRhdGlvbiB0aGUgcmlnaHRzIHRvIHVzZSwgY29weSwgbW9kaWZ5LCBtZXJnZSwgcHVibGlzaCxcbi8vIGRpc3RyaWJ1dGUsIHN1YmxpY2Vuc2UsIGFuZC9vciBzZWxsIGNvcGllcyBvZiB0aGUgU29mdHdhcmUsIGFuZCB0byBwZXJtaXRcbi8vIHBlcnNvbnMgdG8gd2hvbSB0aGUgU29mdHdhcmUgaXMgZnVybmlzaGVkIHRvIGRvIHNvLCBzdWJqZWN0IHRvIHRoZVxuLy8gZm9sbG93aW5nIGNvbmRpdGlvbnM6XG4vL1xuLy8gVGhlIGFib3ZlIGNvcHlyaWdodCBub3RpY2UgYW5kIHRoaXMgcGVybWlzc2lvbiBub3RpY2Ugc2hhbGwgYmUgaW5jbHVkZWRcbi8vIGluIGFsbCBjb3BpZXMgb3Igc3Vic3RhbnRpYWwgcG9ydGlvbnMgb2YgdGhlIFNvZnR3YXJlLlxuLy9cbi8vIFRIRSBTT0ZUV0FSRSBJUyBQUk9WSURFRCBcIkFTIElTXCIsIFdJVEhPVVQgV0FSUkFOVFkgT0YgQU5ZIEtJTkQsIEVYUFJFU1Ncbi8vIE9SIElNUExJRUQsIElOQ0xVRElORyBCVVQgTk9UIExJTUlURUQgVE8gVEhFIFdBUlJBTlRJRVMgT0Zcbi8vIE1FUkNIQU5UQUJJTElUWSwgRklUTkVTUyBGT1IgQSBQQVJUSUNVTEFSIFBVUlBPU0UgQU5EIE5PTklORlJJTkdFTUVOVC4gSU5cbi8vIE5PIEVWRU5UIFNIQUxMIFRIRSBBVVRIT1JTIE9SIENPUFlSSUdIVCBIT0xERVJTIEJFIExJQUJMRSBGT1IgQU5ZIENMQUlNLFxuLy8gREFNQUdFUyBPUiBPVEhFUiBMSUFCSUxJVFksIFdIRVRIRVIgSU4gQU4gQUNUSU9OIE9GIENPTlRSQUNULCBUT1JUIE9SXG4vLyBPVEhFUldJU0UsIEFSSVNJTkcgRlJPTSwgT1VUIE9GIE9SIElOIENPTk5FQ1RJT04gV0lUSCBUSEUgU09GVFdBUkUgT1IgVEhFXG4vLyBVU0UgT1IgT1RIRVIgREVBTElOR1MgSU4gVEhFIFNPRlRXQVJFLlxuXG4vKiogSlNEb2MgKi9cbmZ1bmN0aW9uIG5vcm1hbGl6ZUFycmF5KHBhcnRzLCBhbGxvd0Fib3ZlUm9vdCkge1xuICAvLyBpZiB0aGUgcGF0aCB0cmllcyB0byBnbyBhYm92ZSB0aGUgcm9vdCwgYHVwYCBlbmRzIHVwID4gMFxuICBsZXQgdXAgPSAwO1xuICBmb3IgKGxldCBpID0gcGFydHMubGVuZ3RoIC0gMTsgaSA+PSAwOyBpLS0pIHtcbiAgICBjb25zdCBsYXN0ID0gcGFydHNbaV07XG4gICAgaWYgKGxhc3QgPT09ICcuJykge1xuICAgICAgcGFydHMuc3BsaWNlKGksIDEpO1xuICAgIH0gZWxzZSBpZiAobGFzdCA9PT0gJy4uJykge1xuICAgICAgcGFydHMuc3BsaWNlKGksIDEpO1xuICAgICAgdXArKztcbiAgICB9IGVsc2UgaWYgKHVwKSB7XG4gICAgICBwYXJ0cy5zcGxpY2UoaSwgMSk7XG4gICAgICB1cC0tO1xuICAgIH1cbiAgfVxuXG4gIC8vIGlmIHRoZSBwYXRoIGlzIGFsbG93ZWQgdG8gZ28gYWJvdmUgdGhlIHJvb3QsIHJlc3RvcmUgbGVhZGluZyAuLnNcbiAgaWYgKGFsbG93QWJvdmVSb290KSB7XG4gICAgZm9yICg7IHVwLS07IHVwKSB7XG4gICAgICBwYXJ0cy51bnNoaWZ0KCcuLicpO1xuICAgIH1cbiAgfVxuXG4gIHJldHVybiBwYXJ0cztcbn1cblxuLy8gU3BsaXQgYSBmaWxlbmFtZSBpbnRvIFtyb290LCBkaXIsIGJhc2VuYW1lLCBleHRdLCB1bml4IHZlcnNpb25cbi8vICdyb290JyBpcyBqdXN0IGEgc2xhc2gsIG9yIG5vdGhpbmcuXG5jb25zdCBzcGxpdFBhdGhSZSA9IC9eKFxcUys6XFxcXHxcXC8/KShbXFxzXFxTXSo/KSgoPzpcXC57MSwyfXxbXi9cXFxcXSs/fCkoXFwuW14uL1xcXFxdKnwpKSg/OlsvXFxcXF0qKSQvO1xuLyoqIEpTRG9jICovXG5mdW5jdGlvbiBzcGxpdFBhdGgoZmlsZW5hbWUpIHtcbiAgLy8gVHJ1bmNhdGUgZmlsZXMgbmFtZXMgZ3JlYXRlciB0aGFuIDEwMjQgY2hhcmFjdGVycyB0byBhdm9pZCByZWdleCBkb3NcbiAgLy8gaHR0cHM6Ly9naXRodWIuY29tL2dldHNlbnRyeS9zZW50cnktamF2YXNjcmlwdC9wdWxsLzg3MzcjZGlzY3Vzc2lvbl9yMTI4NTcxOTE3MlxuICBjb25zdCB0cnVuY2F0ZWQgPSBmaWxlbmFtZS5sZW5ndGggPiAxMDI0ID8gYDx0cnVuY2F0ZWQ+JHtmaWxlbmFtZS5zbGljZSgtMTAyNCl9YCA6IGZpbGVuYW1lO1xuICBjb25zdCBwYXJ0cyA9IHNwbGl0UGF0aFJlLmV4ZWModHJ1bmNhdGVkKTtcbiAgcmV0dXJuIHBhcnRzID8gcGFydHMuc2xpY2UoMSkgOiBbXTtcbn1cblxuLy8gcGF0aC5yZXNvbHZlKFtmcm9tIC4uLl0sIHRvKVxuLy8gcG9zaXggdmVyc2lvblxuLyoqIEpTRG9jICovXG5mdW5jdGlvbiByZXNvbHZlKC4uLmFyZ3MpIHtcbiAgbGV0IHJlc29sdmVkUGF0aCA9ICcnO1xuICBsZXQgcmVzb2x2ZWRBYnNvbHV0ZSA9IGZhbHNlO1xuXG4gIGZvciAobGV0IGkgPSBhcmdzLmxlbmd0aCAtIDE7IGkgPj0gLTEgJiYgIXJlc29sdmVkQWJzb2x1dGU7IGktLSkge1xuICAgIGNvbnN0IHBhdGggPSBpID49IDAgPyBhcmdzW2ldIDogJy8nO1xuXG4gICAgLy8gU2tpcCBlbXB0eSBlbnRyaWVzXG4gICAgaWYgKCFwYXRoKSB7XG4gICAgICBjb250aW51ZTtcbiAgICB9XG5cbiAgICByZXNvbHZlZFBhdGggPSBgJHtwYXRofS8ke3Jlc29sdmVkUGF0aH1gO1xuICAgIHJlc29sdmVkQWJzb2x1dGUgPSBwYXRoLmNoYXJBdCgwKSA9PT0gJy8nO1xuICB9XG5cbiAgLy8gQXQgdGhpcyBwb2ludCB0aGUgcGF0aCBzaG91bGQgYmUgcmVzb2x2ZWQgdG8gYSBmdWxsIGFic29sdXRlIHBhdGgsIGJ1dFxuICAvLyBoYW5kbGUgcmVsYXRpdmUgcGF0aHMgdG8gYmUgc2FmZSAobWlnaHQgaGFwcGVuIHdoZW4gcHJvY2Vzcy5jd2QoKSBmYWlscylcblxuICAvLyBOb3JtYWxpemUgdGhlIHBhdGhcbiAgcmVzb2x2ZWRQYXRoID0gbm9ybWFsaXplQXJyYXkoXG4gICAgcmVzb2x2ZWRQYXRoLnNwbGl0KCcvJykuZmlsdGVyKHAgPT4gISFwKSxcbiAgICAhcmVzb2x2ZWRBYnNvbHV0ZSxcbiAgKS5qb2luKCcvJyk7XG5cbiAgcmV0dXJuIChyZXNvbHZlZEFic29sdXRlID8gJy8nIDogJycpICsgcmVzb2x2ZWRQYXRoIHx8ICcuJztcbn1cblxuLyoqIEpTRG9jICovXG5mdW5jdGlvbiB0cmltKGFycikge1xuICBsZXQgc3RhcnQgPSAwO1xuICBmb3IgKDsgc3RhcnQgPCBhcnIubGVuZ3RoOyBzdGFydCsrKSB7XG4gICAgaWYgKGFycltzdGFydF0gIT09ICcnKSB7XG4gICAgICBicmVhaztcbiAgICB9XG4gIH1cblxuICBsZXQgZW5kID0gYXJyLmxlbmd0aCAtIDE7XG4gIGZvciAoOyBlbmQgPj0gMDsgZW5kLS0pIHtcbiAgICBpZiAoYXJyW2VuZF0gIT09ICcnKSB7XG4gICAgICBicmVhaztcbiAgICB9XG4gIH1cblxuICBpZiAoc3RhcnQgPiBlbmQpIHtcbiAgICByZXR1cm4gW107XG4gIH1cbiAgcmV0dXJuIGFyci5zbGljZShzdGFydCwgZW5kIC0gc3RhcnQgKyAxKTtcbn1cblxuLy8gcGF0aC5yZWxhdGl2ZShmcm9tLCB0bylcbi8vIHBvc2l4IHZlcnNpb25cbi8qKiBKU0RvYyAqL1xuZnVuY3Rpb24gcmVsYXRpdmUoZnJvbSwgdG8pIHtcbiAgLyogZXNsaW50LWRpc2FibGUgbm8tcGFyYW0tcmVhc3NpZ24gKi9cbiAgZnJvbSA9IHJlc29sdmUoZnJvbSkuc2xpY2UoMSk7XG4gIHRvID0gcmVzb2x2ZSh0bykuc2xpY2UoMSk7XG4gIC8qIGVzbGludC1lbmFibGUgbm8tcGFyYW0tcmVhc3NpZ24gKi9cblxuICBjb25zdCBmcm9tUGFydHMgPSB0cmltKGZyb20uc3BsaXQoJy8nKSk7XG4gIGNvbnN0IHRvUGFydHMgPSB0cmltKHRvLnNwbGl0KCcvJykpO1xuXG4gIGNvbnN0IGxlbmd0aCA9IE1hdGgubWluKGZyb21QYXJ0cy5sZW5ndGgsIHRvUGFydHMubGVuZ3RoKTtcbiAgbGV0IHNhbWVQYXJ0c0xlbmd0aCA9IGxlbmd0aDtcbiAgZm9yIChsZXQgaSA9IDA7IGkgPCBsZW5ndGg7IGkrKykge1xuICAgIGlmIChmcm9tUGFydHNbaV0gIT09IHRvUGFydHNbaV0pIHtcbiAgICAgIHNhbWVQYXJ0c0xlbmd0aCA9IGk7XG4gICAgICBicmVhaztcbiAgICB9XG4gIH1cblxuICBsZXQgb3V0cHV0UGFydHMgPSBbXTtcbiAgZm9yIChsZXQgaSA9IHNhbWVQYXJ0c0xlbmd0aDsgaSA8IGZyb21QYXJ0cy5sZW5ndGg7IGkrKykge1xuICAgIG91dHB1dFBhcnRzLnB1c2goJy4uJyk7XG4gIH1cblxuICBvdXRwdXRQYXJ0cyA9IG91dHB1dFBhcnRzLmNvbmNhdCh0b1BhcnRzLnNsaWNlKHNhbWVQYXJ0c0xlbmd0aCkpO1xuXG4gIHJldHVybiBvdXRwdXRQYXJ0cy5qb2luKCcvJyk7XG59XG5cbi8vIHBhdGgubm9ybWFsaXplKHBhdGgpXG4vLyBwb3NpeCB2ZXJzaW9uXG4vKiogSlNEb2MgKi9cbmZ1bmN0aW9uIG5vcm1hbGl6ZVBhdGgocGF0aCkge1xuICBjb25zdCBpc1BhdGhBYnNvbHV0ZSA9IGlzQWJzb2x1dGUocGF0aCk7XG4gIGNvbnN0IHRyYWlsaW5nU2xhc2ggPSBwYXRoLnNsaWNlKC0xKSA9PT0gJy8nO1xuXG4gIC8vIE5vcm1hbGl6ZSB0aGUgcGF0aFxuICBsZXQgbm9ybWFsaXplZFBhdGggPSBub3JtYWxpemVBcnJheShcbiAgICBwYXRoLnNwbGl0KCcvJykuZmlsdGVyKHAgPT4gISFwKSxcbiAgICAhaXNQYXRoQWJzb2x1dGUsXG4gICkuam9pbignLycpO1xuXG4gIGlmICghbm9ybWFsaXplZFBhdGggJiYgIWlzUGF0aEFic29sdXRlKSB7XG4gICAgbm9ybWFsaXplZFBhdGggPSAnLic7XG4gIH1cbiAgaWYgKG5vcm1hbGl6ZWRQYXRoICYmIHRyYWlsaW5nU2xhc2gpIHtcbiAgICBub3JtYWxpemVkUGF0aCArPSAnLyc7XG4gIH1cblxuICByZXR1cm4gKGlzUGF0aEFic29sdXRlID8gJy8nIDogJycpICsgbm9ybWFsaXplZFBhdGg7XG59XG5cbi8vIHBvc2l4IHZlcnNpb25cbi8qKiBKU0RvYyAqL1xuZnVuY3Rpb24gaXNBYnNvbHV0ZShwYXRoKSB7XG4gIHJldHVybiBwYXRoLmNoYXJBdCgwKSA9PT0gJy8nO1xufVxuXG4vLyBwb3NpeCB2ZXJzaW9uXG4vKiogSlNEb2MgKi9cbmZ1bmN0aW9uIGpvaW4oLi4uYXJncykge1xuICByZXR1cm4gbm9ybWFsaXplUGF0aChhcmdzLmpvaW4oJy8nKSk7XG59XG5cbi8qKiBKU0RvYyAqL1xuZnVuY3Rpb24gZGlybmFtZShwYXRoKSB7XG4gIGNvbnN0IHJlc3VsdCA9IHNwbGl0UGF0aChwYXRoKTtcbiAgY29uc3Qgcm9vdCA9IHJlc3VsdFswXSB8fCAnJztcbiAgbGV0IGRpciA9IHJlc3VsdFsxXTtcblxuICBpZiAoIXJvb3QgJiYgIWRpcikge1xuICAgIC8vIE5vIGRpcm5hbWUgd2hhdHNvZXZlclxuICAgIHJldHVybiAnLic7XG4gIH1cblxuICBpZiAoZGlyKSB7XG4gICAgLy8gSXQgaGFzIGEgZGlybmFtZSwgc3RyaXAgdHJhaWxpbmcgc2xhc2hcbiAgICBkaXIgPSBkaXIuc2xpY2UoMCwgZGlyLmxlbmd0aCAtIDEpO1xuICB9XG5cbiAgcmV0dXJuIHJvb3QgKyBkaXI7XG59XG5cbi8qKiBKU0RvYyAqL1xuZnVuY3Rpb24gYmFzZW5hbWUocGF0aCwgZXh0KSB7XG4gIGxldCBmID0gc3BsaXRQYXRoKHBhdGgpWzJdIHx8ICcnO1xuICBpZiAoZXh0ICYmIGYuc2xpY2UoZXh0Lmxlbmd0aCAqIC0xKSA9PT0gZXh0KSB7XG4gICAgZiA9IGYuc2xpY2UoMCwgZi5sZW5ndGggLSBleHQubGVuZ3RoKTtcbiAgfVxuICByZXR1cm4gZjtcbn1cblxuZXhwb3J0cy5iYXNlbmFtZSA9IGJhc2VuYW1lO1xuZXhwb3J0cy5kaXJuYW1lID0gZGlybmFtZTtcbmV4cG9ydHMuaXNBYnNvbHV0ZSA9IGlzQWJzb2x1dGU7XG5leHBvcnRzLmpvaW4gPSBqb2luO1xuZXhwb3J0cy5ub3JtYWxpemVQYXRoID0gbm9ybWFsaXplUGF0aDtcbmV4cG9ydHMucmVsYXRpdmUgPSByZWxhdGl2ZTtcbmV4cG9ydHMucmVzb2x2ZSA9IHJlc29sdmU7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1wYXRoLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/path.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/prepareEvent.js":
/*!**********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/prepareEvent.js ***!
  \**********************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst constants = __webpack_require__(/*! ../constants.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/constants.js\");\nconst currentScopes = __webpack_require__(/*! ../currentScopes.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst eventProcessors = __webpack_require__(/*! ../eventProcessors.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/eventProcessors.js\");\nconst scope = __webpack_require__(/*! ../scope.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/scope.js\");\nconst applyScopeDataToEvent = __webpack_require__(/*! ./applyScopeDataToEvent.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/applyScopeDataToEvent.js\");\nconst debugIds = __webpack_require__(/*! ./debug-ids.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-ids.js\");\nconst misc = __webpack_require__(/*! ./misc.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/misc.js\");\nconst normalize = __webpack_require__(/*! ./normalize.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/normalize.js\");\nconst string = __webpack_require__(/*! ./string.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/string.js\");\nconst time = __webpack_require__(/*! ./time.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/time.js\");\n\n/**\n * This type makes sure that we get either a CaptureContext, OR an EventHint.\n * It does not allow mixing them, which could lead to unexpected outcomes, e.g. this is disallowed:\n * { user: { id: '123' }, mechanism: { handled: false } }\n */\n\n/**\n * Adds common information to events.\n *\n * The information includes release and environment from `options`,\n * breadcrumbs and context (extra, tags and user) from the scope.\n *\n * Information that is already present in the event is never overwritten. For\n * nested objects, such as the context, keys are merged.\n *\n * @param event The original event.\n * @param hint May contain additional information about the original exception.\n * @param scope A scope containing event metadata.\n * @returns A new event with more information.\n * @hidden\n */\nfunction prepareEvent(\n  options,\n  event,\n  hint,\n  scope,\n  client,\n  isolationScope,\n) {\n  const { normalizeDepth = 3, normalizeMaxBreadth = 1000 } = options;\n  const prepared = {\n    ...event,\n    event_id: event.event_id || hint.event_id || misc.uuid4(),\n    timestamp: event.timestamp || time.dateTimestampInSeconds(),\n  };\n  const integrations = hint.integrations || options.integrations.map(i => i.name);\n\n  applyClientOptions(prepared, options);\n  applyIntegrationsMetadata(prepared, integrations);\n\n  if (client) {\n    client.emit('applyFrameMetadata', event);\n  }\n\n  // Only put debug IDs onto frames for error events.\n  if (event.type === undefined) {\n    applyDebugIds(prepared, options.stackParser);\n  }\n\n  // If we have scope given to us, use it as the base for further modifications.\n  // This allows us to prevent unnecessary copying of data if `captureContext` is not provided.\n  const finalScope = getFinalScope(scope, hint.captureContext);\n\n  if (hint.mechanism) {\n    misc.addExceptionMechanism(prepared, hint.mechanism);\n  }\n\n  const clientEventProcessors = client ? client.getEventProcessors() : [];\n\n  // This should be the last thing called, since we want that\n  // {@link Scope.addEventProcessor} gets the finished prepared event.\n  // Merge scope data together\n  const data = currentScopes.getGlobalScope().getScopeData();\n\n  if (isolationScope) {\n    const isolationData = isolationScope.getScopeData();\n    applyScopeDataToEvent.mergeScopeData(data, isolationData);\n  }\n\n  if (finalScope) {\n    const finalScopeData = finalScope.getScopeData();\n    applyScopeDataToEvent.mergeScopeData(data, finalScopeData);\n  }\n\n  const attachments = [...(hint.attachments || []), ...data.attachments];\n  if (attachments.length) {\n    hint.attachments = attachments;\n  }\n\n  applyScopeDataToEvent.applyScopeDataToEvent(prepared, data);\n\n  const eventProcessors$1 = [\n    ...clientEventProcessors,\n    // Run scope event processors _after_ all other processors\n    ...data.eventProcessors,\n  ];\n\n  const result = eventProcessors.notifyEventProcessors(eventProcessors$1, prepared, hint);\n\n  return result.then(evt => {\n    if (evt) {\n      // We apply the debug_meta field only after all event processors have ran, so that if any event processors modified\n      // file names (e.g.the RewriteFrames integration) the filename -> debug ID relationship isn't destroyed.\n      // This should not cause any PII issues, since we're only moving data that is already on the event and not adding\n      // any new data\n      applyDebugMeta(evt);\n    }\n\n    if (typeof normalizeDepth === 'number' && normalizeDepth > 0) {\n      return normalizeEvent(evt, normalizeDepth, normalizeMaxBreadth);\n    }\n    return evt;\n  });\n}\n\n/**\n * Enhances event using the client configuration.\n * It takes care of all \"static\" values like environment, release and `dist`,\n * as well as truncating overly long values.\n *\n * Only exported for tests.\n *\n * @param event event instance to be enhanced\n */\nfunction applyClientOptions(event, options) {\n  const { environment, release, dist, maxValueLength = 250 } = options;\n\n  // empty strings do not make sense for environment, release, and dist\n  // so we handle them the same as if they were not provided\n  event.environment = event.environment || environment || constants.DEFAULT_ENVIRONMENT;\n\n  if (!event.release && release) {\n    event.release = release;\n  }\n\n  if (!event.dist && dist) {\n    event.dist = dist;\n  }\n\n  const request = event.request;\n  if (request?.url) {\n    request.url = string.truncate(request.url, maxValueLength);\n  }\n}\n\n/**\n * Puts debug IDs into the stack frames of an error event.\n */\nfunction applyDebugIds(event, stackParser) {\n  // Build a map of filename -> debug_id\n  const filenameDebugIdMap = debugIds.getFilenameToDebugIdMap(stackParser);\n\n  event.exception?.values?.forEach(exception => {\n    exception.stacktrace?.frames?.forEach(frame => {\n      if (frame.filename) {\n        frame.debug_id = filenameDebugIdMap[frame.filename];\n      }\n    });\n  });\n}\n\n/**\n * Moves debug IDs from the stack frames of an error event into the debug_meta field.\n */\nfunction applyDebugMeta(event) {\n  // Extract debug IDs and filenames from the stack frames on the event.\n  const filenameDebugIdMap = {};\n  event.exception?.values?.forEach(exception => {\n    exception.stacktrace?.frames?.forEach(frame => {\n      if (frame.debug_id) {\n        if (frame.abs_path) {\n          filenameDebugIdMap[frame.abs_path] = frame.debug_id;\n        } else if (frame.filename) {\n          filenameDebugIdMap[frame.filename] = frame.debug_id;\n        }\n        delete frame.debug_id;\n      }\n    });\n  });\n\n  if (Object.keys(filenameDebugIdMap).length === 0) {\n    return;\n  }\n\n  // Fill debug_meta information\n  event.debug_meta = event.debug_meta || {};\n  event.debug_meta.images = event.debug_meta.images || [];\n  const images = event.debug_meta.images;\n  Object.entries(filenameDebugIdMap).forEach(([filename, debug_id]) => {\n    images.push({\n      type: 'sourcemap',\n      code_file: filename,\n      debug_id,\n    });\n  });\n}\n\n/**\n * This function adds all used integrations to the SDK info in the event.\n * @param event The event that will be filled with all integrations.\n */\nfunction applyIntegrationsMetadata(event, integrationNames) {\n  if (integrationNames.length > 0) {\n    event.sdk = event.sdk || {};\n    event.sdk.integrations = [...(event.sdk.integrations || []), ...integrationNames];\n  }\n}\n\n/**\n * Applies `normalize` function on necessary `Event` attributes to make them safe for serialization.\n * Normalized keys:\n * - `breadcrumbs.data`\n * - `user`\n * - `contexts`\n * - `extra`\n * @param event Event\n * @returns Normalized event\n */\nfunction normalizeEvent(event, depth, maxBreadth) {\n  if (!event) {\n    return null;\n  }\n\n  const normalized = {\n    ...event,\n    ...(event.breadcrumbs && {\n      breadcrumbs: event.breadcrumbs.map(b => ({\n        ...b,\n        ...(b.data && {\n          data: normalize.normalize(b.data, depth, maxBreadth),\n        }),\n      })),\n    }),\n    ...(event.user && {\n      user: normalize.normalize(event.user, depth, maxBreadth),\n    }),\n    ...(event.contexts && {\n      contexts: normalize.normalize(event.contexts, depth, maxBreadth),\n    }),\n    ...(event.extra && {\n      extra: normalize.normalize(event.extra, depth, maxBreadth),\n    }),\n  };\n\n  // event.contexts.trace stores information about a Transaction. Similarly,\n  // event.spans[] stores information about child Spans. Given that a\n  // Transaction is conceptually a Span, normalization should apply to both\n  // Transactions and Spans consistently.\n  // For now the decision is to skip normalization of Transactions and Spans,\n  // so this block overwrites the normalized event to add back the original\n  // Transaction information prior to normalization.\n  if (event.contexts?.trace && normalized.contexts) {\n    normalized.contexts.trace = event.contexts.trace;\n\n    // event.contexts.trace.data may contain circular/dangerous data so we need to normalize it\n    if (event.contexts.trace.data) {\n      normalized.contexts.trace.data = normalize.normalize(event.contexts.trace.data, depth, maxBreadth);\n    }\n  }\n\n  // event.spans[].data may contain circular/dangerous data so we need to normalize it\n  if (event.spans) {\n    normalized.spans = event.spans.map(span => {\n      return {\n        ...span,\n        ...(span.data && {\n          data: normalize.normalize(span.data, depth, maxBreadth),\n        }),\n      };\n    });\n  }\n\n  // event.contexts.flags (FeatureFlagContext) stores context for our feature\n  // flag integrations. It has a greater nesting depth than our other typed\n  // Contexts, so we re-normalize with a fixed depth of 3 here. We do not want\n  // to skip this in case of conflicting, user-provided context.\n  if (event.contexts?.flags && normalized.contexts) {\n    normalized.contexts.flags = normalize.normalize(event.contexts.flags, 3, maxBreadth);\n  }\n\n  return normalized;\n}\n\nfunction getFinalScope(scope$1, captureContext) {\n  if (!captureContext) {\n    return scope$1;\n  }\n\n  const finalScope = scope$1 ? scope$1.clone() : new scope.Scope();\n  finalScope.update(captureContext);\n  return finalScope;\n}\n\n/**\n * Parse either an `EventHint` directly, or convert a `CaptureContext` to an `EventHint`.\n * This is used to allow to update method signatures that used to accept a `CaptureContext` but should now accept an `EventHint`.\n */\nfunction parseEventHintOrCaptureContext(\n  hint,\n) {\n  if (!hint) {\n    return undefined;\n  }\n\n  // If you pass a Scope or `() => Scope` as CaptureContext, we just return this as captureContext\n  if (hintIsScopeOrFunction(hint)) {\n    return { captureContext: hint };\n  }\n\n  if (hintIsScopeContext(hint)) {\n    return {\n      captureContext: hint,\n    };\n  }\n\n  return hint;\n}\n\nfunction hintIsScopeOrFunction(hint) {\n  return hint instanceof scope.Scope || typeof hint === 'function';\n}\n\nconst captureContextKeys = [\n  'user',\n  'level',\n  'extra',\n  'contexts',\n  'tags',\n  'fingerprint',\n  'propagationContext',\n] ;\n\nfunction hintIsScopeContext(hint) {\n  return Object.keys(hint).some(key => captureContextKeys.includes(key ));\n}\n\nexports.applyClientOptions = applyClientOptions;\nexports.applyDebugIds = applyDebugIds;\nexports.applyDebugMeta = applyDebugMeta;\nexports.parseEventHintOrCaptureContext = parseEventHintOrCaptureContext;\nexports.prepareEvent = prepareEvent;\n//# sourceMappingURL=prepareEvent.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9wcmVwYXJlRXZlbnQuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsa0JBQWtCLG1CQUFPLENBQUMsd0hBQWlCO0FBQzNDLHNCQUFzQixtQkFBTyxDQUFDLGdJQUFxQjtBQUNuRCx3QkFBd0IsbUJBQU8sQ0FBQyxvSUFBdUI7QUFDdkQsY0FBYyxtQkFBTyxDQUFDLGdIQUFhO0FBQ25DLDhCQUE4QixtQkFBTyxDQUFDLHFKQUE0QjtBQUNsRSxpQkFBaUIsbUJBQU8sQ0FBQyw2SEFBZ0I7QUFDekMsYUFBYSxtQkFBTyxDQUFDLG1IQUFXO0FBQ2hDLGtCQUFrQixtQkFBTyxDQUFDLDZIQUFnQjtBQUMxQyxlQUFlLG1CQUFPLENBQUMsdUhBQWE7QUFDcEMsYUFBYSxtQkFBTyxDQUFDLG1IQUFXOztBQUVoQztBQUNBO0FBQ0E7QUFDQSxLQUFLLFFBQVEsV0FBVyxlQUFlO0FBQ3ZDOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxVQUFVLGlEQUFpRDtBQUMzRDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBLE1BQU0sK0JBQStCO0FBQ3JDO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsR0FBRztBQUNIOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsVUFBVSxtREFBbUQ7O0FBRTdEO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxLQUFLO0FBQ0wsR0FBRztBQUNIOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxVQUFVO0FBQ1Y7QUFDQTtBQUNBO0FBQ0E7QUFDQSxLQUFLO0FBQ0wsR0FBRzs7QUFFSDtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsS0FBSztBQUNMLEdBQUc7QUFDSDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsU0FBUztBQUNULE9BQU87QUFDUCxLQUFLO0FBQ0w7QUFDQTtBQUNBLEtBQUs7QUFDTDtBQUNBO0FBQ0EsS0FBSztBQUNMO0FBQ0E7QUFDQSxLQUFLO0FBQ0w7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxTQUFTO0FBQ1Q7QUFDQSxLQUFLO0FBQ0w7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsYUFBYTtBQUNiOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQSwwQkFBMEI7QUFDMUIscUJBQXFCO0FBQ3JCLHNCQUFzQjtBQUN0QixzQ0FBc0M7QUFDdEMsb0JBQW9CO0FBQ3BCIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvcHJlcGFyZUV2ZW50LmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBjb25zdGFudHMgPSByZXF1aXJlKCcuLi9jb25zdGFudHMuanMnKTtcbmNvbnN0IGN1cnJlbnRTY29wZXMgPSByZXF1aXJlKCcuLi9jdXJyZW50U2NvcGVzLmpzJyk7XG5jb25zdCBldmVudFByb2Nlc3NvcnMgPSByZXF1aXJlKCcuLi9ldmVudFByb2Nlc3NvcnMuanMnKTtcbmNvbnN0IHNjb3BlID0gcmVxdWlyZSgnLi4vc2NvcGUuanMnKTtcbmNvbnN0IGFwcGx5U2NvcGVEYXRhVG9FdmVudCA9IHJlcXVpcmUoJy4vYXBwbHlTY29wZURhdGFUb0V2ZW50LmpzJyk7XG5jb25zdCBkZWJ1Z0lkcyA9IHJlcXVpcmUoJy4vZGVidWctaWRzLmpzJyk7XG5jb25zdCBtaXNjID0gcmVxdWlyZSgnLi9taXNjLmpzJyk7XG5jb25zdCBub3JtYWxpemUgPSByZXF1aXJlKCcuL25vcm1hbGl6ZS5qcycpO1xuY29uc3Qgc3RyaW5nID0gcmVxdWlyZSgnLi9zdHJpbmcuanMnKTtcbmNvbnN0IHRpbWUgPSByZXF1aXJlKCcuL3RpbWUuanMnKTtcblxuLyoqXG4gKiBUaGlzIHR5cGUgbWFrZXMgc3VyZSB0aGF0IHdlIGdldCBlaXRoZXIgYSBDYXB0dXJlQ29udGV4dCwgT1IgYW4gRXZlbnRIaW50LlxuICogSXQgZG9lcyBub3QgYWxsb3cgbWl4aW5nIHRoZW0sIHdoaWNoIGNvdWxkIGxlYWQgdG8gdW5leHBlY3RlZCBvdXRjb21lcywgZS5nLiB0aGlzIGlzIGRpc2FsbG93ZWQ6XG4gKiB7IHVzZXI6IHsgaWQ6ICcxMjMnIH0sIG1lY2hhbmlzbTogeyBoYW5kbGVkOiBmYWxzZSB9IH1cbiAqL1xuXG4vKipcbiAqIEFkZHMgY29tbW9uIGluZm9ybWF0aW9uIHRvIGV2ZW50cy5cbiAqXG4gKiBUaGUgaW5mb3JtYXRpb24gaW5jbHVkZXMgcmVsZWFzZSBhbmQgZW52aXJvbm1lbnQgZnJvbSBgb3B0aW9uc2AsXG4gKiBicmVhZGNydW1icyBhbmQgY29udGV4dCAoZXh0cmEsIHRhZ3MgYW5kIHVzZXIpIGZyb20gdGhlIHNjb3BlLlxuICpcbiAqIEluZm9ybWF0aW9uIHRoYXQgaXMgYWxyZWFkeSBwcmVzZW50IGluIHRoZSBldmVudCBpcyBuZXZlciBvdmVyd3JpdHRlbi4gRm9yXG4gKiBuZXN0ZWQgb2JqZWN0cywgc3VjaCBhcyB0aGUgY29udGV4dCwga2V5cyBhcmUgbWVyZ2VkLlxuICpcbiAqIEBwYXJhbSBldmVudCBUaGUgb3JpZ2luYWwgZXZlbnQuXG4gKiBAcGFyYW0gaGludCBNYXkgY29udGFpbiBhZGRpdGlvbmFsIGluZm9ybWF0aW9uIGFib3V0IHRoZSBvcmlnaW5hbCBleGNlcHRpb24uXG4gKiBAcGFyYW0gc2NvcGUgQSBzY29wZSBjb250YWluaW5nIGV2ZW50IG1ldGFkYXRhLlxuICogQHJldHVybnMgQSBuZXcgZXZlbnQgd2l0aCBtb3JlIGluZm9ybWF0aW9uLlxuICogQGhpZGRlblxuICovXG5mdW5jdGlvbiBwcmVwYXJlRXZlbnQoXG4gIG9wdGlvbnMsXG4gIGV2ZW50LFxuICBoaW50LFxuICBzY29wZSxcbiAgY2xpZW50LFxuICBpc29sYXRpb25TY29wZSxcbikge1xuICBjb25zdCB7IG5vcm1hbGl6ZURlcHRoID0gMywgbm9ybWFsaXplTWF4QnJlYWR0aCA9IDEwMDAgfSA9IG9wdGlvbnM7XG4gIGNvbnN0IHByZXBhcmVkID0ge1xuICAgIC4uLmV2ZW50LFxuICAgIGV2ZW50X2lkOiBldmVudC5ldmVudF9pZCB8fCBoaW50LmV2ZW50X2lkIHx8IG1pc2MudXVpZDQoKSxcbiAgICB0aW1lc3RhbXA6IGV2ZW50LnRpbWVzdGFtcCB8fCB0aW1lLmRhdGVUaW1lc3RhbXBJblNlY29uZHMoKSxcbiAgfTtcbiAgY29uc3QgaW50ZWdyYXRpb25zID0gaGludC5pbnRlZ3JhdGlvbnMgfHwgb3B0aW9ucy5pbnRlZ3JhdGlvbnMubWFwKGkgPT4gaS5uYW1lKTtcblxuICBhcHBseUNsaWVudE9wdGlvbnMocHJlcGFyZWQsIG9wdGlvbnMpO1xuICBhcHBseUludGVncmF0aW9uc01ldGFkYXRhKHByZXBhcmVkLCBpbnRlZ3JhdGlvbnMpO1xuXG4gIGlmIChjbGllbnQpIHtcbiAgICBjbGllbnQuZW1pdCgnYXBwbHlGcmFtZU1ldGFkYXRhJywgZXZlbnQpO1xuICB9XG5cbiAgLy8gT25seSBwdXQgZGVidWcgSURzIG9udG8gZnJhbWVzIGZvciBlcnJvciBldmVudHMuXG4gIGlmIChldmVudC50eXBlID09PSB1bmRlZmluZWQpIHtcbiAgICBhcHBseURlYnVnSWRzKHByZXBhcmVkLCBvcHRpb25zLnN0YWNrUGFyc2VyKTtcbiAgfVxuXG4gIC8vIElmIHdlIGhhdmUgc2NvcGUgZ2l2ZW4gdG8gdXMsIHVzZSBpdCBhcyB0aGUgYmFzZSBmb3IgZnVydGhlciBtb2RpZmljYXRpb25zLlxuICAvLyBUaGlzIGFsbG93cyB1cyB0byBwcmV2ZW50IHVubmVjZXNzYXJ5IGNvcHlpbmcgb2YgZGF0YSBpZiBgY2FwdHVyZUNvbnRleHRgIGlzIG5vdCBwcm92aWRlZC5cbiAgY29uc3QgZmluYWxTY29wZSA9IGdldEZpbmFsU2NvcGUoc2NvcGUsIGhpbnQuY2FwdHVyZUNvbnRleHQpO1xuXG4gIGlmIChoaW50Lm1lY2hhbmlzbSkge1xuICAgIG1pc2MuYWRkRXhjZXB0aW9uTWVjaGFuaXNtKHByZXBhcmVkLCBoaW50Lm1lY2hhbmlzbSk7XG4gIH1cblxuICBjb25zdCBjbGllbnRFdmVudFByb2Nlc3NvcnMgPSBjbGllbnQgPyBjbGllbnQuZ2V0RXZlbnRQcm9jZXNzb3JzKCkgOiBbXTtcblxuICAvLyBUaGlzIHNob3VsZCBiZSB0aGUgbGFzdCB0aGluZyBjYWxsZWQsIHNpbmNlIHdlIHdhbnQgdGhhdFxuICAvLyB7QGxpbmsgU2NvcGUuYWRkRXZlbnRQcm9jZXNzb3J9IGdldHMgdGhlIGZpbmlzaGVkIHByZXBhcmVkIGV2ZW50LlxuICAvLyBNZXJnZSBzY29wZSBkYXRhIHRvZ2V0aGVyXG4gIGNvbnN0IGRhdGEgPSBjdXJyZW50U2NvcGVzLmdldEdsb2JhbFNjb3BlKCkuZ2V0U2NvcGVEYXRhKCk7XG5cbiAgaWYgKGlzb2xhdGlvblNjb3BlKSB7XG4gICAgY29uc3QgaXNvbGF0aW9uRGF0YSA9IGlzb2xhdGlvblNjb3BlLmdldFNjb3BlRGF0YSgpO1xuICAgIGFwcGx5U2NvcGVEYXRhVG9FdmVudC5tZXJnZVNjb3BlRGF0YShkYXRhLCBpc29sYXRpb25EYXRhKTtcbiAgfVxuXG4gIGlmIChmaW5hbFNjb3BlKSB7XG4gICAgY29uc3QgZmluYWxTY29wZURhdGEgPSBmaW5hbFNjb3BlLmdldFNjb3BlRGF0YSgpO1xuICAgIGFwcGx5U2NvcGVEYXRhVG9FdmVudC5tZXJnZVNjb3BlRGF0YShkYXRhLCBmaW5hbFNjb3BlRGF0YSk7XG4gIH1cblxuICBjb25zdCBhdHRhY2htZW50cyA9IFsuLi4oaGludC5hdHRhY2htZW50cyB8fCBbXSksIC4uLmRhdGEuYXR0YWNobWVudHNdO1xuICBpZiAoYXR0YWNobWVudHMubGVuZ3RoKSB7XG4gICAgaGludC5hdHRhY2htZW50cyA9IGF0dGFjaG1lbnRzO1xuICB9XG5cbiAgYXBwbHlTY29wZURhdGFUb0V2ZW50LmFwcGx5U2NvcGVEYXRhVG9FdmVudChwcmVwYXJlZCwgZGF0YSk7XG5cbiAgY29uc3QgZXZlbnRQcm9jZXNzb3JzJDEgPSBbXG4gICAgLi4uY2xpZW50RXZlbnRQcm9jZXNzb3JzLFxuICAgIC8vIFJ1biBzY29wZSBldmVudCBwcm9jZXNzb3JzIF9hZnRlcl8gYWxsIG90aGVyIHByb2Nlc3NvcnNcbiAgICAuLi5kYXRhLmV2ZW50UHJvY2Vzc29ycyxcbiAgXTtcblxuICBjb25zdCByZXN1bHQgPSBldmVudFByb2Nlc3NvcnMubm90aWZ5RXZlbnRQcm9jZXNzb3JzKGV2ZW50UHJvY2Vzc29ycyQxLCBwcmVwYXJlZCwgaGludCk7XG5cbiAgcmV0dXJuIHJlc3VsdC50aGVuKGV2dCA9PiB7XG4gICAgaWYgKGV2dCkge1xuICAgICAgLy8gV2UgYXBwbHkgdGhlIGRlYnVnX21ldGEgZmllbGQgb25seSBhZnRlciBhbGwgZXZlbnQgcHJvY2Vzc29ycyBoYXZlIHJhbiwgc28gdGhhdCBpZiBhbnkgZXZlbnQgcHJvY2Vzc29ycyBtb2RpZmllZFxuICAgICAgLy8gZmlsZSBuYW1lcyAoZS5nLnRoZSBSZXdyaXRlRnJhbWVzIGludGVncmF0aW9uKSB0aGUgZmlsZW5hbWUgLT4gZGVidWcgSUQgcmVsYXRpb25zaGlwIGlzbid0IGRlc3Ryb3llZC5cbiAgICAgIC8vIFRoaXMgc2hvdWxkIG5vdCBjYXVzZSBhbnkgUElJIGlzc3Vlcywgc2luY2Ugd2UncmUgb25seSBtb3ZpbmcgZGF0YSB0aGF0IGlzIGFscmVhZHkgb24gdGhlIGV2ZW50IGFuZCBub3QgYWRkaW5nXG4gICAgICAvLyBhbnkgbmV3IGRhdGFcbiAgICAgIGFwcGx5RGVidWdNZXRhKGV2dCk7XG4gICAgfVxuXG4gICAgaWYgKHR5cGVvZiBub3JtYWxpemVEZXB0aCA9PT0gJ251bWJlcicgJiYgbm9ybWFsaXplRGVwdGggPiAwKSB7XG4gICAgICByZXR1cm4gbm9ybWFsaXplRXZlbnQoZXZ0LCBub3JtYWxpemVEZXB0aCwgbm9ybWFsaXplTWF4QnJlYWR0aCk7XG4gICAgfVxuICAgIHJldHVybiBldnQ7XG4gIH0pO1xufVxuXG4vKipcbiAqIEVuaGFuY2VzIGV2ZW50IHVzaW5nIHRoZSBjbGllbnQgY29uZmlndXJhdGlvbi5cbiAqIEl0IHRha2VzIGNhcmUgb2YgYWxsIFwic3RhdGljXCIgdmFsdWVzIGxpa2UgZW52aXJvbm1lbnQsIHJlbGVhc2UgYW5kIGBkaXN0YCxcbiAqIGFzIHdlbGwgYXMgdHJ1bmNhdGluZyBvdmVybHkgbG9uZyB2YWx1ZXMuXG4gKlxuICogT25seSBleHBvcnRlZCBmb3IgdGVzdHMuXG4gKlxuICogQHBhcmFtIGV2ZW50IGV2ZW50IGluc3RhbmNlIHRvIGJlIGVuaGFuY2VkXG4gKi9cbmZ1bmN0aW9uIGFwcGx5Q2xpZW50T3B0aW9ucyhldmVudCwgb3B0aW9ucykge1xuICBjb25zdCB7IGVudmlyb25tZW50LCByZWxlYXNlLCBkaXN0LCBtYXhWYWx1ZUxlbmd0aCA9IDI1MCB9ID0gb3B0aW9ucztcblxuICAvLyBlbXB0eSBzdHJpbmdzIGRvIG5vdCBtYWtlIHNlbnNlIGZvciBlbnZpcm9ubWVudCwgcmVsZWFzZSwgYW5kIGRpc3RcbiAgLy8gc28gd2UgaGFuZGxlIHRoZW0gdGhlIHNhbWUgYXMgaWYgdGhleSB3ZXJlIG5vdCBwcm92aWRlZFxuICBldmVudC5lbnZpcm9ubWVudCA9IGV2ZW50LmVudmlyb25tZW50IHx8IGVudmlyb25tZW50IHx8IGNvbnN0YW50cy5ERUZBVUxUX0VOVklST05NRU5UO1xuXG4gIGlmICghZXZlbnQucmVsZWFzZSAmJiByZWxlYXNlKSB7XG4gICAgZXZlbnQucmVsZWFzZSA9IHJlbGVhc2U7XG4gIH1cblxuICBpZiAoIWV2ZW50LmRpc3QgJiYgZGlzdCkge1xuICAgIGV2ZW50LmRpc3QgPSBkaXN0O1xuICB9XG5cbiAgY29uc3QgcmVxdWVzdCA9IGV2ZW50LnJlcXVlc3Q7XG4gIGlmIChyZXF1ZXN0Py51cmwpIHtcbiAgICByZXF1ZXN0LnVybCA9IHN0cmluZy50cnVuY2F0ZShyZXF1ZXN0LnVybCwgbWF4VmFsdWVMZW5ndGgpO1xuICB9XG59XG5cbi8qKlxuICogUHV0cyBkZWJ1ZyBJRHMgaW50byB0aGUgc3RhY2sgZnJhbWVzIG9mIGFuIGVycm9yIGV2ZW50LlxuICovXG5mdW5jdGlvbiBhcHBseURlYnVnSWRzKGV2ZW50LCBzdGFja1BhcnNlcikge1xuICAvLyBCdWlsZCBhIG1hcCBvZiBmaWxlbmFtZSAtPiBkZWJ1Z19pZFxuICBjb25zdCBmaWxlbmFtZURlYnVnSWRNYXAgPSBkZWJ1Z0lkcy5nZXRGaWxlbmFtZVRvRGVidWdJZE1hcChzdGFja1BhcnNlcik7XG5cbiAgZXZlbnQuZXhjZXB0aW9uPy52YWx1ZXM/LmZvckVhY2goZXhjZXB0aW9uID0+IHtcbiAgICBleGNlcHRpb24uc3RhY2t0cmFjZT8uZnJhbWVzPy5mb3JFYWNoKGZyYW1lID0+IHtcbiAgICAgIGlmIChmcmFtZS5maWxlbmFtZSkge1xuICAgICAgICBmcmFtZS5kZWJ1Z19pZCA9IGZpbGVuYW1lRGVidWdJZE1hcFtmcmFtZS5maWxlbmFtZV07XG4gICAgICB9XG4gICAgfSk7XG4gIH0pO1xufVxuXG4vKipcbiAqIE1vdmVzIGRlYnVnIElEcyBmcm9tIHRoZSBzdGFjayBmcmFtZXMgb2YgYW4gZXJyb3IgZXZlbnQgaW50byB0aGUgZGVidWdfbWV0YSBmaWVsZC5cbiAqL1xuZnVuY3Rpb24gYXBwbHlEZWJ1Z01ldGEoZXZlbnQpIHtcbiAgLy8gRXh0cmFjdCBkZWJ1ZyBJRHMgYW5kIGZpbGVuYW1lcyBmcm9tIHRoZSBzdGFjayBmcmFtZXMgb24gdGhlIGV2ZW50LlxuICBjb25zdCBmaWxlbmFtZURlYnVnSWRNYXAgPSB7fTtcbiAgZXZlbnQuZXhjZXB0aW9uPy52YWx1ZXM/LmZvckVhY2goZXhjZXB0aW9uID0+IHtcbiAgICBleGNlcHRpb24uc3RhY2t0cmFjZT8uZnJhbWVzPy5mb3JFYWNoKGZyYW1lID0+IHtcbiAgICAgIGlmIChmcmFtZS5kZWJ1Z19pZCkge1xuICAgICAgICBpZiAoZnJhbWUuYWJzX3BhdGgpIHtcbiAgICAgICAgICBmaWxlbmFtZURlYnVnSWRNYXBbZnJhbWUuYWJzX3BhdGhdID0gZnJhbWUuZGVidWdfaWQ7XG4gICAgICAgIH0gZWxzZSBpZiAoZnJhbWUuZmlsZW5hbWUpIHtcbiAgICAgICAgICBmaWxlbmFtZURlYnVnSWRNYXBbZnJhbWUuZmlsZW5hbWVdID0gZnJhbWUuZGVidWdfaWQ7XG4gICAgICAgIH1cbiAgICAgICAgZGVsZXRlIGZyYW1lLmRlYnVnX2lkO1xuICAgICAgfVxuICAgIH0pO1xuICB9KTtcblxuICBpZiAoT2JqZWN0LmtleXMoZmlsZW5hbWVEZWJ1Z0lkTWFwKS5sZW5ndGggPT09IDApIHtcbiAgICByZXR1cm47XG4gIH1cblxuICAvLyBGaWxsIGRlYnVnX21ldGEgaW5mb3JtYXRpb25cbiAgZXZlbnQuZGVidWdfbWV0YSA9IGV2ZW50LmRlYnVnX21ldGEgfHwge307XG4gIGV2ZW50LmRlYnVnX21ldGEuaW1hZ2VzID0gZXZlbnQuZGVidWdfbWV0YS5pbWFnZXMgfHwgW107XG4gIGNvbnN0IGltYWdlcyA9IGV2ZW50LmRlYnVnX21ldGEuaW1hZ2VzO1xuICBPYmplY3QuZW50cmllcyhmaWxlbmFtZURlYnVnSWRNYXApLmZvckVhY2goKFtmaWxlbmFtZSwgZGVidWdfaWRdKSA9PiB7XG4gICAgaW1hZ2VzLnB1c2goe1xuICAgICAgdHlwZTogJ3NvdXJjZW1hcCcsXG4gICAgICBjb2RlX2ZpbGU6IGZpbGVuYW1lLFxuICAgICAgZGVidWdfaWQsXG4gICAgfSk7XG4gIH0pO1xufVxuXG4vKipcbiAqIFRoaXMgZnVuY3Rpb24gYWRkcyBhbGwgdXNlZCBpbnRlZ3JhdGlvbnMgdG8gdGhlIFNESyBpbmZvIGluIHRoZSBldmVudC5cbiAqIEBwYXJhbSBldmVudCBUaGUgZXZlbnQgdGhhdCB3aWxsIGJlIGZpbGxlZCB3aXRoIGFsbCBpbnRlZ3JhdGlvbnMuXG4gKi9cbmZ1bmN0aW9uIGFwcGx5SW50ZWdyYXRpb25zTWV0YWRhdGEoZXZlbnQsIGludGVncmF0aW9uTmFtZXMpIHtcbiAgaWYgKGludGVncmF0aW9uTmFtZXMubGVuZ3RoID4gMCkge1xuICAgIGV2ZW50LnNkayA9IGV2ZW50LnNkayB8fCB7fTtcbiAgICBldmVudC5zZGsuaW50ZWdyYXRpb25zID0gWy4uLihldmVudC5zZGsuaW50ZWdyYXRpb25zIHx8IFtdKSwgLi4uaW50ZWdyYXRpb25OYW1lc107XG4gIH1cbn1cblxuLyoqXG4gKiBBcHBsaWVzIGBub3JtYWxpemVgIGZ1bmN0aW9uIG9uIG5lY2Vzc2FyeSBgRXZlbnRgIGF0dHJpYnV0ZXMgdG8gbWFrZSB0aGVtIHNhZmUgZm9yIHNlcmlhbGl6YXRpb24uXG4gKiBOb3JtYWxpemVkIGtleXM6XG4gKiAtIGBicmVhZGNydW1icy5kYXRhYFxuICogLSBgdXNlcmBcbiAqIC0gYGNvbnRleHRzYFxuICogLSBgZXh0cmFgXG4gKiBAcGFyYW0gZXZlbnQgRXZlbnRcbiAqIEByZXR1cm5zIE5vcm1hbGl6ZWQgZXZlbnRcbiAqL1xuZnVuY3Rpb24gbm9ybWFsaXplRXZlbnQoZXZlbnQsIGRlcHRoLCBtYXhCcmVhZHRoKSB7XG4gIGlmICghZXZlbnQpIHtcbiAgICByZXR1cm4gbnVsbDtcbiAgfVxuXG4gIGNvbnN0IG5vcm1hbGl6ZWQgPSB7XG4gICAgLi4uZXZlbnQsXG4gICAgLi4uKGV2ZW50LmJyZWFkY3J1bWJzICYmIHtcbiAgICAgIGJyZWFkY3J1bWJzOiBldmVudC5icmVhZGNydW1icy5tYXAoYiA9PiAoe1xuICAgICAgICAuLi5iLFxuICAgICAgICAuLi4oYi5kYXRhICYmIHtcbiAgICAgICAgICBkYXRhOiBub3JtYWxpemUubm9ybWFsaXplKGIuZGF0YSwgZGVwdGgsIG1heEJyZWFkdGgpLFxuICAgICAgICB9KSxcbiAgICAgIH0pKSxcbiAgICB9KSxcbiAgICAuLi4oZXZlbnQudXNlciAmJiB7XG4gICAgICB1c2VyOiBub3JtYWxpemUubm9ybWFsaXplKGV2ZW50LnVzZXIsIGRlcHRoLCBtYXhCcmVhZHRoKSxcbiAgICB9KSxcbiAgICAuLi4oZXZlbnQuY29udGV4dHMgJiYge1xuICAgICAgY29udGV4dHM6IG5vcm1hbGl6ZS5ub3JtYWxpemUoZXZlbnQuY29udGV4dHMsIGRlcHRoLCBtYXhCcmVhZHRoKSxcbiAgICB9KSxcbiAgICAuLi4oZXZlbnQuZXh0cmEgJiYge1xuICAgICAgZXh0cmE6IG5vcm1hbGl6ZS5ub3JtYWxpemUoZXZlbnQuZXh0cmEsIGRlcHRoLCBtYXhCcmVhZHRoKSxcbiAgICB9KSxcbiAgfTtcblxuICAvLyBldmVudC5jb250ZXh0cy50cmFjZSBzdG9yZXMgaW5mb3JtYXRpb24gYWJvdXQgYSBUcmFuc2FjdGlvbi4gU2ltaWxhcmx5LFxuICAvLyBldmVudC5zcGFuc1tdIHN0b3JlcyBpbmZvcm1hdGlvbiBhYm91dCBjaGlsZCBTcGFucy4gR2l2ZW4gdGhhdCBhXG4gIC8vIFRyYW5zYWN0aW9uIGlzIGNvbmNlcHR1YWxseSBhIFNwYW4sIG5vcm1hbGl6YXRpb24gc2hvdWxkIGFwcGx5IHRvIGJvdGhcbiAgLy8gVHJhbnNhY3Rpb25zIGFuZCBTcGFucyBjb25zaXN0ZW50bHkuXG4gIC8vIEZvciBub3cgdGhlIGRlY2lzaW9uIGlzIHRvIHNraXAgbm9ybWFsaXphdGlvbiBvZiBUcmFuc2FjdGlvbnMgYW5kIFNwYW5zLFxuICAvLyBzbyB0aGlzIGJsb2NrIG92ZXJ3cml0ZXMgdGhlIG5vcm1hbGl6ZWQgZXZlbnQgdG8gYWRkIGJhY2sgdGhlIG9yaWdpbmFsXG4gIC8vIFRyYW5zYWN0aW9uIGluZm9ybWF0aW9uIHByaW9yIHRvIG5vcm1hbGl6YXRpb24uXG4gIGlmIChldmVudC5jb250ZXh0cz8udHJhY2UgJiYgbm9ybWFsaXplZC5jb250ZXh0cykge1xuICAgIG5vcm1hbGl6ZWQuY29udGV4dHMudHJhY2UgPSBldmVudC5jb250ZXh0cy50cmFjZTtcblxuICAgIC8vIGV2ZW50LmNvbnRleHRzLnRyYWNlLmRhdGEgbWF5IGNvbnRhaW4gY2lyY3VsYXIvZGFuZ2Vyb3VzIGRhdGEgc28gd2UgbmVlZCB0byBub3JtYWxpemUgaXRcbiAgICBpZiAoZXZlbnQuY29udGV4dHMudHJhY2UuZGF0YSkge1xuICAgICAgbm9ybWFsaXplZC5jb250ZXh0cy50cmFjZS5kYXRhID0gbm9ybWFsaXplLm5vcm1hbGl6ZShldmVudC5jb250ZXh0cy50cmFjZS5kYXRhLCBkZXB0aCwgbWF4QnJlYWR0aCk7XG4gICAgfVxuICB9XG5cbiAgLy8gZXZlbnQuc3BhbnNbXS5kYXRhIG1heSBjb250YWluIGNpcmN1bGFyL2Rhbmdlcm91cyBkYXRhIHNvIHdlIG5lZWQgdG8gbm9ybWFsaXplIGl0XG4gIGlmIChldmVudC5zcGFucykge1xuICAgIG5vcm1hbGl6ZWQuc3BhbnMgPSBldmVudC5zcGFucy5tYXAoc3BhbiA9PiB7XG4gICAgICByZXR1cm4ge1xuICAgICAgICAuLi5zcGFuLFxuICAgICAgICAuLi4oc3Bhbi5kYXRhICYmIHtcbiAgICAgICAgICBkYXRhOiBub3JtYWxpemUubm9ybWFsaXplKHNwYW4uZGF0YSwgZGVwdGgsIG1heEJyZWFkdGgpLFxuICAgICAgICB9KSxcbiAgICAgIH07XG4gICAgfSk7XG4gIH1cblxuICAvLyBldmVudC5jb250ZXh0cy5mbGFncyAoRmVhdHVyZUZsYWdDb250ZXh0KSBzdG9yZXMgY29udGV4dCBmb3Igb3VyIGZlYXR1cmVcbiAgLy8gZmxhZyBpbnRlZ3JhdGlvbnMuIEl0IGhhcyBhIGdyZWF0ZXIgbmVzdGluZyBkZXB0aCB0aGFuIG91ciBvdGhlciB0eXBlZFxuICAvLyBDb250ZXh0cywgc28gd2UgcmUtbm9ybWFsaXplIHdpdGggYSBmaXhlZCBkZXB0aCBvZiAzIGhlcmUuIFdlIGRvIG5vdCB3YW50XG4gIC8vIHRvIHNraXAgdGhpcyBpbiBjYXNlIG9mIGNvbmZsaWN0aW5nLCB1c2VyLXByb3ZpZGVkIGNvbnRleHQuXG4gIGlmIChldmVudC5jb250ZXh0cz8uZmxhZ3MgJiYgbm9ybWFsaXplZC5jb250ZXh0cykge1xuICAgIG5vcm1hbGl6ZWQuY29udGV4dHMuZmxhZ3MgPSBub3JtYWxpemUubm9ybWFsaXplKGV2ZW50LmNvbnRleHRzLmZsYWdzLCAzLCBtYXhCcmVhZHRoKTtcbiAgfVxuXG4gIHJldHVybiBub3JtYWxpemVkO1xufVxuXG5mdW5jdGlvbiBnZXRGaW5hbFNjb3BlKHNjb3BlJDEsIGNhcHR1cmVDb250ZXh0KSB7XG4gIGlmICghY2FwdHVyZUNvbnRleHQpIHtcbiAgICByZXR1cm4gc2NvcGUkMTtcbiAgfVxuXG4gIGNvbnN0IGZpbmFsU2NvcGUgPSBzY29wZSQxID8gc2NvcGUkMS5jbG9uZSgpIDogbmV3IHNjb3BlLlNjb3BlKCk7XG4gIGZpbmFsU2NvcGUudXBkYXRlKGNhcHR1cmVDb250ZXh0KTtcbiAgcmV0dXJuIGZpbmFsU2NvcGU7XG59XG5cbi8qKlxuICogUGFyc2UgZWl0aGVyIGFuIGBFdmVudEhpbnRgIGRpcmVjdGx5LCBvciBjb252ZXJ0IGEgYENhcHR1cmVDb250ZXh0YCB0byBhbiBgRXZlbnRIaW50YC5cbiAqIFRoaXMgaXMgdXNlZCB0byBhbGxvdyB0byB1cGRhdGUgbWV0aG9kIHNpZ25hdHVyZXMgdGhhdCB1c2VkIHRvIGFjY2VwdCBhIGBDYXB0dXJlQ29udGV4dGAgYnV0IHNob3VsZCBub3cgYWNjZXB0IGFuIGBFdmVudEhpbnRgLlxuICovXG5mdW5jdGlvbiBwYXJzZUV2ZW50SGludE9yQ2FwdHVyZUNvbnRleHQoXG4gIGhpbnQsXG4pIHtcbiAgaWYgKCFoaW50KSB7XG4gICAgcmV0dXJuIHVuZGVmaW5lZDtcbiAgfVxuXG4gIC8vIElmIHlvdSBwYXNzIGEgU2NvcGUgb3IgYCgpID0+IFNjb3BlYCBhcyBDYXB0dXJlQ29udGV4dCwgd2UganVzdCByZXR1cm4gdGhpcyBhcyBjYXB0dXJlQ29udGV4dFxuICBpZiAoaGludElzU2NvcGVPckZ1bmN0aW9uKGhpbnQpKSB7XG4gICAgcmV0dXJuIHsgY2FwdHVyZUNvbnRleHQ6IGhpbnQgfTtcbiAgfVxuXG4gIGlmIChoaW50SXNTY29wZUNvbnRleHQoaGludCkpIHtcbiAgICByZXR1cm4ge1xuICAgICAgY2FwdHVyZUNvbnRleHQ6IGhpbnQsXG4gICAgfTtcbiAgfVxuXG4gIHJldHVybiBoaW50O1xufVxuXG5mdW5jdGlvbiBoaW50SXNTY29wZU9yRnVuY3Rpb24oaGludCkge1xuICByZXR1cm4gaGludCBpbnN0YW5jZW9mIHNjb3BlLlNjb3BlIHx8IHR5cGVvZiBoaW50ID09PSAnZnVuY3Rpb24nO1xufVxuXG5jb25zdCBjYXB0dXJlQ29udGV4dEtleXMgPSBbXG4gICd1c2VyJyxcbiAgJ2xldmVsJyxcbiAgJ2V4dHJhJyxcbiAgJ2NvbnRleHRzJyxcbiAgJ3RhZ3MnLFxuICAnZmluZ2VycHJpbnQnLFxuICAncHJvcGFnYXRpb25Db250ZXh0Jyxcbl0gO1xuXG5mdW5jdGlvbiBoaW50SXNTY29wZUNvbnRleHQoaGludCkge1xuICByZXR1cm4gT2JqZWN0LmtleXMoaGludCkuc29tZShrZXkgPT4gY2FwdHVyZUNvbnRleHRLZXlzLmluY2x1ZGVzKGtleSApKTtcbn1cblxuZXhwb3J0cy5hcHBseUNsaWVudE9wdGlvbnMgPSBhcHBseUNsaWVudE9wdGlvbnM7XG5leHBvcnRzLmFwcGx5RGVidWdJZHMgPSBhcHBseURlYnVnSWRzO1xuZXhwb3J0cy5hcHBseURlYnVnTWV0YSA9IGFwcGx5RGVidWdNZXRhO1xuZXhwb3J0cy5wYXJzZUV2ZW50SGludE9yQ2FwdHVyZUNvbnRleHQgPSBwYXJzZUV2ZW50SGludE9yQ2FwdHVyZUNvbnRleHQ7XG5leHBvcnRzLnByZXBhcmVFdmVudCA9IHByZXBhcmVFdmVudDtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPXByZXBhcmVFdmVudC5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/prepareEvent.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/promisebuffer.js":
/*!***********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/promisebuffer.js ***!
  \***********************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst syncpromise = __webpack_require__(/*! ./syncpromise.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/syncpromise.js\");\n\nconst SENTRY_BUFFER_FULL_ERROR = Symbol.for('SentryBufferFullError');\n\n/**\n * Creates an new PromiseBuffer object with the specified limit\n * @param limit max number of promises that can be stored in the buffer\n */\nfunction makePromiseBuffer(limit) {\n  const buffer = [];\n\n  function isReady() {\n    return limit === undefined || buffer.length < limit;\n  }\n\n  /**\n   * Remove a promise from the queue.\n   *\n   * @param task Can be any PromiseLike<T>\n   * @returns Removed promise.\n   */\n  function remove(task) {\n    return buffer.splice(buffer.indexOf(task), 1)[0] || Promise.resolve(undefined);\n  }\n\n  /**\n   * Add a promise (representing an in-flight action) to the queue, and set it to remove itself on fulfillment.\n   *\n   * @param taskProducer A function producing any PromiseLike<T>; In previous versions this used to be `task:\n   *        PromiseLike<T>`, but under that model, Promises were instantly created on the call-site and their executor\n   *        functions therefore ran immediately. Thus, even if the buffer was full, the action still happened. By\n   *        requiring the promise to be wrapped in a function, we can defer promise creation until after the buffer\n   *        limit check.\n   * @returns The original promise.\n   */\n  function add(taskProducer) {\n    if (!isReady()) {\n      return syncpromise.rejectedSyncPromise(SENTRY_BUFFER_FULL_ERROR);\n    }\n\n    // start the task and add its promise to the queue\n    const task = taskProducer();\n    if (buffer.indexOf(task) === -1) {\n      buffer.push(task);\n    }\n    void task\n      .then(() => remove(task))\n      // Use `then(null, rejectionHandler)` rather than `catch(rejectionHandler)` so that we can use `PromiseLike`\n      // rather than `Promise`. `PromiseLike` doesn't have a `.catch` method, making its polyfill smaller. (ES5 didn't\n      // have promises, so TS has to polyfill when down-compiling.)\n      .then(null, () =>\n        remove(task).then(null, () => {\n          // We have to add another catch here because `remove()` starts a new promise chain.\n        }),\n      );\n    return task;\n  }\n\n  /**\n   * Wait for all promises in the queue to resolve or for timeout to expire, whichever comes first.\n   *\n   * @param timeout The time, in ms, after which to resolve to `false` if the queue is still non-empty. Passing `0` (or\n   * not passing anything) will make the promise wait as long as it takes for the queue to drain before resolving to\n   * `true`.\n   * @returns A promise which will resolve to `true` if the queue is already empty or drains before the timeout, and\n   * `false` otherwise\n   */\n  function drain(timeout) {\n    return new syncpromise.SyncPromise((resolve, reject) => {\n      let counter = buffer.length;\n\n      if (!counter) {\n        return resolve(true);\n      }\n\n      // wait for `timeout` ms and then resolve to `false` (if not cancelled first)\n      const capturedSetTimeout = setTimeout(() => {\n        if (timeout && timeout > 0) {\n          resolve(false);\n        }\n      }, timeout);\n\n      // if all promises resolve in time, cancel the timer and resolve to `true`\n      buffer.forEach(item => {\n        void syncpromise.resolvedSyncPromise(item).then(() => {\n          if (!--counter) {\n            clearTimeout(capturedSetTimeout);\n            resolve(true);\n          }\n        }, reject);\n      });\n    });\n  }\n\n  return {\n    $: buffer,\n    add,\n    drain,\n  };\n}\n\nexports.SENTRY_BUFFER_FULL_ERROR = SENTRY_BUFFER_FULL_ERROR;\nexports.makePromiseBuffer = makePromiseBuffer;\n//# sourceMappingURL=promisebuffer.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9wcm9taXNlYnVmZmVyLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLG9CQUFvQixtQkFBTyxDQUFDLGlJQUFrQjs7QUFFOUM7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0Esa0VBQWtFO0FBQ2xFO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsU0FBUztBQUNUO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxPQUFPOztBQUVQO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsU0FBUztBQUNULE9BQU87QUFDUCxLQUFLO0FBQ0w7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLGdDQUFnQztBQUNoQyx5QkFBeUI7QUFDekIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9wcm9taXNlYnVmZmVyLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBzeW5jcHJvbWlzZSA9IHJlcXVpcmUoJy4vc3luY3Byb21pc2UuanMnKTtcblxuY29uc3QgU0VOVFJZX0JVRkZFUl9GVUxMX0VSUk9SID0gU3ltYm9sLmZvcignU2VudHJ5QnVmZmVyRnVsbEVycm9yJyk7XG5cbi8qKlxuICogQ3JlYXRlcyBhbiBuZXcgUHJvbWlzZUJ1ZmZlciBvYmplY3Qgd2l0aCB0aGUgc3BlY2lmaWVkIGxpbWl0XG4gKiBAcGFyYW0gbGltaXQgbWF4IG51bWJlciBvZiBwcm9taXNlcyB0aGF0IGNhbiBiZSBzdG9yZWQgaW4gdGhlIGJ1ZmZlclxuICovXG5mdW5jdGlvbiBtYWtlUHJvbWlzZUJ1ZmZlcihsaW1pdCkge1xuICBjb25zdCBidWZmZXIgPSBbXTtcblxuICBmdW5jdGlvbiBpc1JlYWR5KCkge1xuICAgIHJldHVybiBsaW1pdCA9PT0gdW5kZWZpbmVkIHx8IGJ1ZmZlci5sZW5ndGggPCBsaW1pdDtcbiAgfVxuXG4gIC8qKlxuICAgKiBSZW1vdmUgYSBwcm9taXNlIGZyb20gdGhlIHF1ZXVlLlxuICAgKlxuICAgKiBAcGFyYW0gdGFzayBDYW4gYmUgYW55IFByb21pc2VMaWtlPFQ+XG4gICAqIEByZXR1cm5zIFJlbW92ZWQgcHJvbWlzZS5cbiAgICovXG4gIGZ1bmN0aW9uIHJlbW92ZSh0YXNrKSB7XG4gICAgcmV0dXJuIGJ1ZmZlci5zcGxpY2UoYnVmZmVyLmluZGV4T2YodGFzayksIDEpWzBdIHx8IFByb21pc2UucmVzb2x2ZSh1bmRlZmluZWQpO1xuICB9XG5cbiAgLyoqXG4gICAqIEFkZCBhIHByb21pc2UgKHJlcHJlc2VudGluZyBhbiBpbi1mbGlnaHQgYWN0aW9uKSB0byB0aGUgcXVldWUsIGFuZCBzZXQgaXQgdG8gcmVtb3ZlIGl0c2VsZiBvbiBmdWxmaWxsbWVudC5cbiAgICpcbiAgICogQHBhcmFtIHRhc2tQcm9kdWNlciBBIGZ1bmN0aW9uIHByb2R1Y2luZyBhbnkgUHJvbWlzZUxpa2U8VD47IEluIHByZXZpb3VzIHZlcnNpb25zIHRoaXMgdXNlZCB0byBiZSBgdGFzazpcbiAgICogICAgICAgIFByb21pc2VMaWtlPFQ+YCwgYnV0IHVuZGVyIHRoYXQgbW9kZWwsIFByb21pc2VzIHdlcmUgaW5zdGFudGx5IGNyZWF0ZWQgb24gdGhlIGNhbGwtc2l0ZSBhbmQgdGhlaXIgZXhlY3V0b3JcbiAgICogICAgICAgIGZ1bmN0aW9ucyB0aGVyZWZvcmUgcmFuIGltbWVkaWF0ZWx5LiBUaHVzLCBldmVuIGlmIHRoZSBidWZmZXIgd2FzIGZ1bGwsIHRoZSBhY3Rpb24gc3RpbGwgaGFwcGVuZWQuIEJ5XG4gICAqICAgICAgICByZXF1aXJpbmcgdGhlIHByb21pc2UgdG8gYmUgd3JhcHBlZCBpbiBhIGZ1bmN0aW9uLCB3ZSBjYW4gZGVmZXIgcHJvbWlzZSBjcmVhdGlvbiB1bnRpbCBhZnRlciB0aGUgYnVmZmVyXG4gICAqICAgICAgICBsaW1pdCBjaGVjay5cbiAgICogQHJldHVybnMgVGhlIG9yaWdpbmFsIHByb21pc2UuXG4gICAqL1xuICBmdW5jdGlvbiBhZGQodGFza1Byb2R1Y2VyKSB7XG4gICAgaWYgKCFpc1JlYWR5KCkpIHtcbiAgICAgIHJldHVybiBzeW5jcHJvbWlzZS5yZWplY3RlZFN5bmNQcm9taXNlKFNFTlRSWV9CVUZGRVJfRlVMTF9FUlJPUik7XG4gICAgfVxuXG4gICAgLy8gc3RhcnQgdGhlIHRhc2sgYW5kIGFkZCBpdHMgcHJvbWlzZSB0byB0aGUgcXVldWVcbiAgICBjb25zdCB0YXNrID0gdGFza1Byb2R1Y2VyKCk7XG4gICAgaWYgKGJ1ZmZlci5pbmRleE9mKHRhc2spID09PSAtMSkge1xuICAgICAgYnVmZmVyLnB1c2godGFzayk7XG4gICAgfVxuICAgIHZvaWQgdGFza1xuICAgICAgLnRoZW4oKCkgPT4gcmVtb3ZlKHRhc2spKVxuICAgICAgLy8gVXNlIGB0aGVuKG51bGwsIHJlamVjdGlvbkhhbmRsZXIpYCByYXRoZXIgdGhhbiBgY2F0Y2gocmVqZWN0aW9uSGFuZGxlcilgIHNvIHRoYXQgd2UgY2FuIHVzZSBgUHJvbWlzZUxpa2VgXG4gICAgICAvLyByYXRoZXIgdGhhbiBgUHJvbWlzZWAuIGBQcm9taXNlTGlrZWAgZG9lc24ndCBoYXZlIGEgYC5jYXRjaGAgbWV0aG9kLCBtYWtpbmcgaXRzIHBvbHlmaWxsIHNtYWxsZXIuIChFUzUgZGlkbid0XG4gICAgICAvLyBoYXZlIHByb21pc2VzLCBzbyBUUyBoYXMgdG8gcG9seWZpbGwgd2hlbiBkb3duLWNvbXBpbGluZy4pXG4gICAgICAudGhlbihudWxsLCAoKSA9PlxuICAgICAgICByZW1vdmUodGFzaykudGhlbihudWxsLCAoKSA9PiB7XG4gICAgICAgICAgLy8gV2UgaGF2ZSB0byBhZGQgYW5vdGhlciBjYXRjaCBoZXJlIGJlY2F1c2UgYHJlbW92ZSgpYCBzdGFydHMgYSBuZXcgcHJvbWlzZSBjaGFpbi5cbiAgICAgICAgfSksXG4gICAgICApO1xuICAgIHJldHVybiB0YXNrO1xuICB9XG5cbiAgLyoqXG4gICAqIFdhaXQgZm9yIGFsbCBwcm9taXNlcyBpbiB0aGUgcXVldWUgdG8gcmVzb2x2ZSBvciBmb3IgdGltZW91dCB0byBleHBpcmUsIHdoaWNoZXZlciBjb21lcyBmaXJzdC5cbiAgICpcbiAgICogQHBhcmFtIHRpbWVvdXQgVGhlIHRpbWUsIGluIG1zLCBhZnRlciB3aGljaCB0byByZXNvbHZlIHRvIGBmYWxzZWAgaWYgdGhlIHF1ZXVlIGlzIHN0aWxsIG5vbi1lbXB0eS4gUGFzc2luZyBgMGAgKG9yXG4gICAqIG5vdCBwYXNzaW5nIGFueXRoaW5nKSB3aWxsIG1ha2UgdGhlIHByb21pc2Ugd2FpdCBhcyBsb25nIGFzIGl0IHRha2VzIGZvciB0aGUgcXVldWUgdG8gZHJhaW4gYmVmb3JlIHJlc29sdmluZyB0b1xuICAgKiBgdHJ1ZWAuXG4gICAqIEByZXR1cm5zIEEgcHJvbWlzZSB3aGljaCB3aWxsIHJlc29sdmUgdG8gYHRydWVgIGlmIHRoZSBxdWV1ZSBpcyBhbHJlYWR5IGVtcHR5IG9yIGRyYWlucyBiZWZvcmUgdGhlIHRpbWVvdXQsIGFuZFxuICAgKiBgZmFsc2VgIG90aGVyd2lzZVxuICAgKi9cbiAgZnVuY3Rpb24gZHJhaW4odGltZW91dCkge1xuICAgIHJldHVybiBuZXcgc3luY3Byb21pc2UuU3luY1Byb21pc2UoKHJlc29sdmUsIHJlamVjdCkgPT4ge1xuICAgICAgbGV0IGNvdW50ZXIgPSBidWZmZXIubGVuZ3RoO1xuXG4gICAgICBpZiAoIWNvdW50ZXIpIHtcbiAgICAgICAgcmV0dXJuIHJlc29sdmUodHJ1ZSk7XG4gICAgICB9XG5cbiAgICAgIC8vIHdhaXQgZm9yIGB0aW1lb3V0YCBtcyBhbmQgdGhlbiByZXNvbHZlIHRvIGBmYWxzZWAgKGlmIG5vdCBjYW5jZWxsZWQgZmlyc3QpXG4gICAgICBjb25zdCBjYXB0dXJlZFNldFRpbWVvdXQgPSBzZXRUaW1lb3V0KCgpID0+IHtcbiAgICAgICAgaWYgKHRpbWVvdXQgJiYgdGltZW91dCA+IDApIHtcbiAgICAgICAgICByZXNvbHZlKGZhbHNlKTtcbiAgICAgICAgfVxuICAgICAgfSwgdGltZW91dCk7XG5cbiAgICAgIC8vIGlmIGFsbCBwcm9taXNlcyByZXNvbHZlIGluIHRpbWUsIGNhbmNlbCB0aGUgdGltZXIgYW5kIHJlc29sdmUgdG8gYHRydWVgXG4gICAgICBidWZmZXIuZm9yRWFjaChpdGVtID0+IHtcbiAgICAgICAgdm9pZCBzeW5jcHJvbWlzZS5yZXNvbHZlZFN5bmNQcm9taXNlKGl0ZW0pLnRoZW4oKCkgPT4ge1xuICAgICAgICAgIGlmICghLS1jb3VudGVyKSB7XG4gICAgICAgICAgICBjbGVhclRpbWVvdXQoY2FwdHVyZWRTZXRUaW1lb3V0KTtcbiAgICAgICAgICAgIHJlc29sdmUodHJ1ZSk7XG4gICAgICAgICAgfVxuICAgICAgICB9LCByZWplY3QpO1xuICAgICAgfSk7XG4gICAgfSk7XG4gIH1cblxuICByZXR1cm4ge1xuICAgICQ6IGJ1ZmZlcixcbiAgICBhZGQsXG4gICAgZHJhaW4sXG4gIH07XG59XG5cbmV4cG9ydHMuU0VOVFJZX0JVRkZFUl9GVUxMX0VSUk9SID0gU0VOVFJZX0JVRkZFUl9GVUxMX0VSUk9SO1xuZXhwb3J0cy5tYWtlUHJvbWlzZUJ1ZmZlciA9IG1ha2VQcm9taXNlQnVmZmVyO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9cHJvbWlzZWJ1ZmZlci5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/promisebuffer.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/propagationContext.js":
/*!****************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/propagationContext.js ***!
  \****************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst misc = __webpack_require__(/*! ./misc.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/misc.js\");\n\n/**\n * Generate a random, valid trace ID.\n */\nfunction generateTraceId() {\n  return misc.uuid4();\n}\n\n/**\n * Generate a random, valid span ID.\n */\nfunction generateSpanId() {\n  return misc.uuid4().substring(16);\n}\n\nexports.generateSpanId = generateSpanId;\nexports.generateTraceId = generateTraceId;\n//# sourceMappingURL=propagationContext.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9wcm9wYWdhdGlvbkNvbnRleHQuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsYUFBYSxtQkFBTyxDQUFDLG1IQUFXOztBQUVoQztBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLHNCQUFzQjtBQUN0Qix1QkFBdUI7QUFDdkIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9wcm9wYWdhdGlvbkNvbnRleHQuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IG1pc2MgPSByZXF1aXJlKCcuL21pc2MuanMnKTtcblxuLyoqXG4gKiBHZW5lcmF0ZSBhIHJhbmRvbSwgdmFsaWQgdHJhY2UgSUQuXG4gKi9cbmZ1bmN0aW9uIGdlbmVyYXRlVHJhY2VJZCgpIHtcbiAgcmV0dXJuIG1pc2MudXVpZDQoKTtcbn1cblxuLyoqXG4gKiBHZW5lcmF0ZSBhIHJhbmRvbSwgdmFsaWQgc3BhbiBJRC5cbiAqL1xuZnVuY3Rpb24gZ2VuZXJhdGVTcGFuSWQoKSB7XG4gIHJldHVybiBtaXNjLnV1aWQ0KCkuc3Vic3RyaW5nKDE2KTtcbn1cblxuZXhwb3J0cy5nZW5lcmF0ZVNwYW5JZCA9IGdlbmVyYXRlU3BhbklkO1xuZXhwb3J0cy5nZW5lcmF0ZVRyYWNlSWQgPSBnZW5lcmF0ZVRyYWNlSWQ7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1wcm9wYWdhdGlvbkNvbnRleHQuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/propagationContext.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/ratelimit.js":
/*!*******************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/ratelimit.js ***!
  \*******************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n// Intentionally keeping the key broad, as we don't know for sure what rate limit headers get returned from backend\n\nconst DEFAULT_RETRY_AFTER = 60 * 1000; // 60 seconds\n\n/**\n * Extracts Retry-After value from the request header or returns default value\n * @param header string representation of 'Retry-After' header\n * @param now current unix timestamp\n *\n */\nfunction parseRetryAfterHeader(header, now = Date.now()) {\n  const headerDelay = parseInt(`${header}`, 10);\n  if (!isNaN(headerDelay)) {\n    return headerDelay * 1000;\n  }\n\n  const headerDate = Date.parse(`${header}`);\n  if (!isNaN(headerDate)) {\n    return headerDate - now;\n  }\n\n  return DEFAULT_RETRY_AFTER;\n}\n\n/**\n * Gets the time that the given category is disabled until for rate limiting.\n * In case no category-specific limit is set but a general rate limit across all categories is active,\n * that time is returned.\n *\n * @return the time in ms that the category is disabled until or 0 if there's no active rate limit.\n */\nfunction disabledUntil(limits, dataCategory) {\n  return limits[dataCategory] || limits.all || 0;\n}\n\n/**\n * Checks if a category is rate limited\n */\nfunction isRateLimited(limits, dataCategory, now = Date.now()) {\n  return disabledUntil(limits, dataCategory) > now;\n}\n\n/**\n * Update ratelimits from incoming headers.\n *\n * @return the updated RateLimits object.\n */\nfunction updateRateLimits(\n  limits,\n  { statusCode, headers },\n  now = Date.now(),\n) {\n  const updatedRateLimits = {\n    ...limits,\n  };\n\n  // \"The name is case-insensitive.\"\n  // https://developer.mozilla.org/en-US/docs/Web/API/Headers/get\n  const rateLimitHeader = headers?.['x-sentry-rate-limits'];\n  const retryAfterHeader = headers?.['retry-after'];\n\n  if (rateLimitHeader) {\n    /**\n     * rate limit headers are of the form\n     *     <header>,<header>,..\n     * where each <header> is of the form\n     *     <retry_after>: <categories>: <scope>: <reason_code>: <namespaces>\n     * where\n     *     <retry_after> is a delay in seconds\n     *     <categories> is the event type(s) (error, transaction, etc) being rate limited and is of the form\n     *         <category>;<category>;...\n     *     <scope> is what's being limited (org, project, or key) - ignored by SDK\n     *     <reason_code> is an arbitrary string like \"org_quota\" - ignored by SDK\n     *     <namespaces> Semicolon-separated list of metric namespace identifiers. Defines which namespace(s) will be affected.\n     *         Only present if rate limit applies to the metric_bucket data category.\n     */\n    for (const limit of rateLimitHeader.trim().split(',')) {\n      const [retryAfter, categories, , , namespaces] = limit.split(':', 5) ;\n      const headerDelay = parseInt(retryAfter, 10);\n      const delay = (!isNaN(headerDelay) ? headerDelay : 60) * 1000; // 60sec default\n      if (!categories) {\n        updatedRateLimits.all = now + delay;\n      } else {\n        for (const category of categories.split(';')) {\n          if (category === 'metric_bucket') {\n            // namespaces will be present when category === 'metric_bucket'\n            if (!namespaces || namespaces.split(';').includes('custom')) {\n              updatedRateLimits[category] = now + delay;\n            }\n          } else {\n            updatedRateLimits[category] = now + delay;\n          }\n        }\n      }\n    }\n  } else if (retryAfterHeader) {\n    updatedRateLimits.all = now + parseRetryAfterHeader(retryAfterHeader, now);\n  } else if (statusCode === 429) {\n    updatedRateLimits.all = now + 60 * 1000;\n  }\n\n  return updatedRateLimits;\n}\n\nexports.DEFAULT_RETRY_AFTER = DEFAULT_RETRY_AFTER;\nexports.disabledUntil = disabledUntil;\nexports.isRateLimited = isRateLimited;\nexports.parseRetryAfterHeader = parseRetryAfterHeader;\nexports.updateRateLimits = updateRateLimits;\n//# sourceMappingURL=ratelimit.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9yYXRlbGltaXQuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEU7O0FBRUEsdUNBQXVDOztBQUV2QztBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGtDQUFrQyxPQUFPO0FBQ3pDO0FBQ0E7QUFDQTs7QUFFQSxtQ0FBbUMsT0FBTztBQUMxQztBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxJQUFJLHFCQUFxQjtBQUN6QjtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLDBCQUEwQixXQUFXO0FBQ3JDO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxxRUFBcUU7QUFDckU7QUFDQTtBQUNBLFFBQVE7QUFDUixrREFBa0Q7QUFDbEQ7QUFDQTtBQUNBLGtEQUFrRDtBQUNsRDtBQUNBO0FBQ0EsWUFBWTtBQUNaO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxJQUFJO0FBQ0o7QUFDQSxJQUFJO0FBQ0o7QUFDQTs7QUFFQTtBQUNBOztBQUVBLDJCQUEyQjtBQUMzQixxQkFBcUI7QUFDckIscUJBQXFCO0FBQ3JCLDZCQUE2QjtBQUM3Qix3QkFBd0I7QUFDeEIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9yYXRlbGltaXQuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbi8vIEludGVudGlvbmFsbHkga2VlcGluZyB0aGUga2V5IGJyb2FkLCBhcyB3ZSBkb24ndCBrbm93IGZvciBzdXJlIHdoYXQgcmF0ZSBsaW1pdCBoZWFkZXJzIGdldCByZXR1cm5lZCBmcm9tIGJhY2tlbmRcblxuY29uc3QgREVGQVVMVF9SRVRSWV9BRlRFUiA9IDYwICogMTAwMDsgLy8gNjAgc2Vjb25kc1xuXG4vKipcbiAqIEV4dHJhY3RzIFJldHJ5LUFmdGVyIHZhbHVlIGZyb20gdGhlIHJlcXVlc3QgaGVhZGVyIG9yIHJldHVybnMgZGVmYXVsdCB2YWx1ZVxuICogQHBhcmFtIGhlYWRlciBzdHJpbmcgcmVwcmVzZW50YXRpb24gb2YgJ1JldHJ5LUFmdGVyJyBoZWFkZXJcbiAqIEBwYXJhbSBub3cgY3VycmVudCB1bml4IHRpbWVzdGFtcFxuICpcbiAqL1xuZnVuY3Rpb24gcGFyc2VSZXRyeUFmdGVySGVhZGVyKGhlYWRlciwgbm93ID0gRGF0ZS5ub3coKSkge1xuICBjb25zdCBoZWFkZXJEZWxheSA9IHBhcnNlSW50KGAke2hlYWRlcn1gLCAxMCk7XG4gIGlmICghaXNOYU4oaGVhZGVyRGVsYXkpKSB7XG4gICAgcmV0dXJuIGhlYWRlckRlbGF5ICogMTAwMDtcbiAgfVxuXG4gIGNvbnN0IGhlYWRlckRhdGUgPSBEYXRlLnBhcnNlKGAke2hlYWRlcn1gKTtcbiAgaWYgKCFpc05hTihoZWFkZXJEYXRlKSkge1xuICAgIHJldHVybiBoZWFkZXJEYXRlIC0gbm93O1xuICB9XG5cbiAgcmV0dXJuIERFRkFVTFRfUkVUUllfQUZURVI7XG59XG5cbi8qKlxuICogR2V0cyB0aGUgdGltZSB0aGF0IHRoZSBnaXZlbiBjYXRlZ29yeSBpcyBkaXNhYmxlZCB1bnRpbCBmb3IgcmF0ZSBsaW1pdGluZy5cbiAqIEluIGNhc2Ugbm8gY2F0ZWdvcnktc3BlY2lmaWMgbGltaXQgaXMgc2V0IGJ1dCBhIGdlbmVyYWwgcmF0ZSBsaW1pdCBhY3Jvc3MgYWxsIGNhdGVnb3JpZXMgaXMgYWN0aXZlLFxuICogdGhhdCB0aW1lIGlzIHJldHVybmVkLlxuICpcbiAqIEByZXR1cm4gdGhlIHRpbWUgaW4gbXMgdGhhdCB0aGUgY2F0ZWdvcnkgaXMgZGlzYWJsZWQgdW50aWwgb3IgMCBpZiB0aGVyZSdzIG5vIGFjdGl2ZSByYXRlIGxpbWl0LlxuICovXG5mdW5jdGlvbiBkaXNhYmxlZFVudGlsKGxpbWl0cywgZGF0YUNhdGVnb3J5KSB7XG4gIHJldHVybiBsaW1pdHNbZGF0YUNhdGVnb3J5XSB8fCBsaW1pdHMuYWxsIHx8IDA7XG59XG5cbi8qKlxuICogQ2hlY2tzIGlmIGEgY2F0ZWdvcnkgaXMgcmF0ZSBsaW1pdGVkXG4gKi9cbmZ1bmN0aW9uIGlzUmF0ZUxpbWl0ZWQobGltaXRzLCBkYXRhQ2F0ZWdvcnksIG5vdyA9IERhdGUubm93KCkpIHtcbiAgcmV0dXJuIGRpc2FibGVkVW50aWwobGltaXRzLCBkYXRhQ2F0ZWdvcnkpID4gbm93O1xufVxuXG4vKipcbiAqIFVwZGF0ZSByYXRlbGltaXRzIGZyb20gaW5jb21pbmcgaGVhZGVycy5cbiAqXG4gKiBAcmV0dXJuIHRoZSB1cGRhdGVkIFJhdGVMaW1pdHMgb2JqZWN0LlxuICovXG5mdW5jdGlvbiB1cGRhdGVSYXRlTGltaXRzKFxuICBsaW1pdHMsXG4gIHsgc3RhdHVzQ29kZSwgaGVhZGVycyB9LFxuICBub3cgPSBEYXRlLm5vdygpLFxuKSB7XG4gIGNvbnN0IHVwZGF0ZWRSYXRlTGltaXRzID0ge1xuICAgIC4uLmxpbWl0cyxcbiAgfTtcblxuICAvLyBcIlRoZSBuYW1lIGlzIGNhc2UtaW5zZW5zaXRpdmUuXCJcbiAgLy8gaHR0cHM6Ly9kZXZlbG9wZXIubW96aWxsYS5vcmcvZW4tVVMvZG9jcy9XZWIvQVBJL0hlYWRlcnMvZ2V0XG4gIGNvbnN0IHJhdGVMaW1pdEhlYWRlciA9IGhlYWRlcnM/LlsneC1zZW50cnktcmF0ZS1saW1pdHMnXTtcbiAgY29uc3QgcmV0cnlBZnRlckhlYWRlciA9IGhlYWRlcnM/LlsncmV0cnktYWZ0ZXInXTtcblxuICBpZiAocmF0ZUxpbWl0SGVhZGVyKSB7XG4gICAgLyoqXG4gICAgICogcmF0ZSBsaW1pdCBoZWFkZXJzIGFyZSBvZiB0aGUgZm9ybVxuICAgICAqICAgICA8aGVhZGVyPiw8aGVhZGVyPiwuLlxuICAgICAqIHdoZXJlIGVhY2ggPGhlYWRlcj4gaXMgb2YgdGhlIGZvcm1cbiAgICAgKiAgICAgPHJldHJ5X2FmdGVyPjogPGNhdGVnb3JpZXM+OiA8c2NvcGU+OiA8cmVhc29uX2NvZGU+OiA8bmFtZXNwYWNlcz5cbiAgICAgKiB3aGVyZVxuICAgICAqICAgICA8cmV0cnlfYWZ0ZXI+IGlzIGEgZGVsYXkgaW4gc2Vjb25kc1xuICAgICAqICAgICA8Y2F0ZWdvcmllcz4gaXMgdGhlIGV2ZW50IHR5cGUocykgKGVycm9yLCB0cmFuc2FjdGlvbiwgZXRjKSBiZWluZyByYXRlIGxpbWl0ZWQgYW5kIGlzIG9mIHRoZSBmb3JtXG4gICAgICogICAgICAgICA8Y2F0ZWdvcnk+OzxjYXRlZ29yeT47Li4uXG4gICAgICogICAgIDxzY29wZT4gaXMgd2hhdCdzIGJlaW5nIGxpbWl0ZWQgKG9yZywgcHJvamVjdCwgb3Iga2V5KSAtIGlnbm9yZWQgYnkgU0RLXG4gICAgICogICAgIDxyZWFzb25fY29kZT4gaXMgYW4gYXJiaXRyYXJ5IHN0cmluZyBsaWtlIFwib3JnX3F1b3RhXCIgLSBpZ25vcmVkIGJ5IFNES1xuICAgICAqICAgICA8bmFtZXNwYWNlcz4gU2VtaWNvbG9uLXNlcGFyYXRlZCBsaXN0IG9mIG1ldHJpYyBuYW1lc3BhY2UgaWRlbnRpZmllcnMuIERlZmluZXMgd2hpY2ggbmFtZXNwYWNlKHMpIHdpbGwgYmUgYWZmZWN0ZWQuXG4gICAgICogICAgICAgICBPbmx5IHByZXNlbnQgaWYgcmF0ZSBsaW1pdCBhcHBsaWVzIHRvIHRoZSBtZXRyaWNfYnVja2V0IGRhdGEgY2F0ZWdvcnkuXG4gICAgICovXG4gICAgZm9yIChjb25zdCBsaW1pdCBvZiByYXRlTGltaXRIZWFkZXIudHJpbSgpLnNwbGl0KCcsJykpIHtcbiAgICAgIGNvbnN0IFtyZXRyeUFmdGVyLCBjYXRlZ29yaWVzLCAsICwgbmFtZXNwYWNlc10gPSBsaW1pdC5zcGxpdCgnOicsIDUpIDtcbiAgICAgIGNvbnN0IGhlYWRlckRlbGF5ID0gcGFyc2VJbnQocmV0cnlBZnRlciwgMTApO1xuICAgICAgY29uc3QgZGVsYXkgPSAoIWlzTmFOKGhlYWRlckRlbGF5KSA/IGhlYWRlckRlbGF5IDogNjApICogMTAwMDsgLy8gNjBzZWMgZGVmYXVsdFxuICAgICAgaWYgKCFjYXRlZ29yaWVzKSB7XG4gICAgICAgIHVwZGF0ZWRSYXRlTGltaXRzLmFsbCA9IG5vdyArIGRlbGF5O1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgZm9yIChjb25zdCBjYXRlZ29yeSBvZiBjYXRlZ29yaWVzLnNwbGl0KCc7JykpIHtcbiAgICAgICAgICBpZiAoY2F0ZWdvcnkgPT09ICdtZXRyaWNfYnVja2V0Jykge1xuICAgICAgICAgICAgLy8gbmFtZXNwYWNlcyB3aWxsIGJlIHByZXNlbnQgd2hlbiBjYXRlZ29yeSA9PT0gJ21ldHJpY19idWNrZXQnXG4gICAgICAgICAgICBpZiAoIW5hbWVzcGFjZXMgfHwgbmFtZXNwYWNlcy5zcGxpdCgnOycpLmluY2x1ZGVzKCdjdXN0b20nKSkge1xuICAgICAgICAgICAgICB1cGRhdGVkUmF0ZUxpbWl0c1tjYXRlZ29yeV0gPSBub3cgKyBkZWxheTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgdXBkYXRlZFJhdGVMaW1pdHNbY2F0ZWdvcnldID0gbm93ICsgZGVsYXk7XG4gICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICB9XG4gICAgfVxuICB9IGVsc2UgaWYgKHJldHJ5QWZ0ZXJIZWFkZXIpIHtcbiAgICB1cGRhdGVkUmF0ZUxpbWl0cy5hbGwgPSBub3cgKyBwYXJzZVJldHJ5QWZ0ZXJIZWFkZXIocmV0cnlBZnRlckhlYWRlciwgbm93KTtcbiAgfSBlbHNlIGlmIChzdGF0dXNDb2RlID09PSA0MjkpIHtcbiAgICB1cGRhdGVkUmF0ZUxpbWl0cy5hbGwgPSBub3cgKyA2MCAqIDEwMDA7XG4gIH1cblxuICByZXR1cm4gdXBkYXRlZFJhdGVMaW1pdHM7XG59XG5cbmV4cG9ydHMuREVGQVVMVF9SRVRSWV9BRlRFUiA9IERFRkFVTFRfUkVUUllfQUZURVI7XG5leHBvcnRzLmRpc2FibGVkVW50aWwgPSBkaXNhYmxlZFVudGlsO1xuZXhwb3J0cy5pc1JhdGVMaW1pdGVkID0gaXNSYXRlTGltaXRlZDtcbmV4cG9ydHMucGFyc2VSZXRyeUFmdGVySGVhZGVyID0gcGFyc2VSZXRyeUFmdGVySGVhZGVyO1xuZXhwb3J0cy51cGRhdGVSYXRlTGltaXRzID0gdXBkYXRlUmF0ZUxpbWl0cztcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPXJhdGVsaW1pdC5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/ratelimit.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/request.js":
/*!*****************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/request.js ***!
  \*****************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n/**\n * Transforms a `Headers` object that implements the `Web Fetch API` (https://developer.mozilla.org/en-US/docs/Web/API/Headers) into a simple key-value dict.\n * The header keys will be lower case: e.g. A \"Content-Type\" header will be stored as \"content-type\".\n */\nfunction winterCGHeadersToDict(winterCGHeaders) {\n  const headers = {};\n  try {\n    winterCGHeaders.forEach((value, key) => {\n      if (typeof value === 'string') {\n        // We check that value is a string even though it might be redundant to make sure prototype pollution is not possible.\n        headers[key] = value;\n      }\n    });\n  } catch {\n    // just return the empty headers\n  }\n\n  return headers;\n}\n\n/**\n * Convert common request headers to a simple dictionary.\n */\nfunction headersToDict(reqHeaders) {\n  const headers = Object.create(null);\n\n  try {\n    Object.entries(reqHeaders).forEach(([key, value]) => {\n      if (typeof value === 'string') {\n        headers[key] = value;\n      }\n    });\n  } catch {\n    // just return the empty headers\n  }\n\n  return headers;\n}\n\n/**\n * Converts a `Request` object that implements the `Web Fetch API` (https://developer.mozilla.org/en-US/docs/Web/API/Headers) into the format that the `RequestData` integration understands.\n */\nfunction winterCGRequestToRequestData(req) {\n  const headers = winterCGHeadersToDict(req.headers);\n\n  return {\n    method: req.method,\n    url: req.url,\n    query_string: extractQueryParamsFromUrl(req.url),\n    headers,\n    // TODO: Can we extract body data from the request?\n  };\n}\n\n/**\n * Convert a HTTP request object to RequestEventData to be passed as normalizedRequest.\n * Instead of allowing `PolymorphicRequest` to be passed,\n * we want to be more specific and generally require a http.IncomingMessage-like object.\n */\nfunction httpRequestToRequestData(request\n\n) {\n  const headers = request.headers || {};\n\n  // Check for x-forwarded-host first, then fall back to host header\n  const forwardedHost = typeof headers['x-forwarded-host'] === 'string' ? headers['x-forwarded-host'] : undefined;\n  const host = forwardedHost || (typeof headers.host === 'string' ? headers.host : undefined);\n\n  // Check for x-forwarded-proto first, then fall back to existing protocol detection\n  const forwardedProto = typeof headers['x-forwarded-proto'] === 'string' ? headers['x-forwarded-proto'] : undefined;\n  const protocol = forwardedProto || request.protocol || (request.socket?.encrypted ? 'https' : 'http');\n\n  const url = request.url || '';\n\n  const absoluteUrl = getAbsoluteUrl({\n    url,\n    host,\n    protocol,\n  });\n\n  // This is non-standard, but may be sometimes set\n  // It may be overwritten later by our own body handling\n  const data = (request ).body || undefined;\n\n  // This is non-standard, but may be set on e.g. Next.js or Express requests\n  const cookies = (request ).cookies;\n\n  return {\n    url: absoluteUrl,\n    method: request.method,\n    query_string: extractQueryParamsFromUrl(url),\n    headers: headersToDict(headers),\n    cookies,\n    data,\n  };\n}\n\nfunction getAbsoluteUrl({\n  url,\n  protocol,\n  host,\n}\n\n) {\n  if (url?.startsWith('http')) {\n    return url;\n  }\n\n  if (url && host) {\n    return `${protocol}://${host}${url}`;\n  }\n\n  return undefined;\n}\n\n/** Extract the query params from an URL. */\nfunction extractQueryParamsFromUrl(url) {\n  // url is path and query string\n  if (!url) {\n    return;\n  }\n\n  try {\n    // The `URL` constructor can't handle internal URLs of the form `/some/path/here`, so stick a dummy protocol and\n    // hostname as the base. Since the point here is just to grab the query string, it doesn't matter what we use.\n    const queryParams = new URL(url, 'http://s.io').search.slice(1);\n    return queryParams.length ? queryParams : undefined;\n  } catch {\n    return undefined;\n  }\n}\n\nexports.extractQueryParamsFromUrl = extractQueryParamsFromUrl;\nexports.headersToDict = headersToDict;\nexports.httpRequestToRequestData = httpRequestToRequestData;\nexports.winterCGHeadersToDict = winterCGHeadersToDict;\nexports.winterCGRequestToRequestData = winterCGRequestToRequestData;\n//# sourceMappingURL=request.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9yZXF1ZXN0LmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEtBQUs7QUFDTCxJQUFJO0FBQ0o7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEtBQUs7QUFDTCxJQUFJO0FBQ0o7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsR0FBRzs7QUFFSDtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBLGNBQWMsU0FBUyxLQUFLLEtBQUssRUFBRSxJQUFJO0FBQ3ZDOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxJQUFJO0FBQ0o7QUFDQTtBQUNBOztBQUVBLGlDQUFpQztBQUNqQyxxQkFBcUI7QUFDckIsZ0NBQWdDO0FBQ2hDLDZCQUE2QjtBQUM3QixvQ0FBb0M7QUFDcEMiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9yZXF1ZXN0LmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG4vKipcbiAqIFRyYW5zZm9ybXMgYSBgSGVhZGVyc2Agb2JqZWN0IHRoYXQgaW1wbGVtZW50cyB0aGUgYFdlYiBGZXRjaCBBUElgIChodHRwczovL2RldmVsb3Blci5tb3ppbGxhLm9yZy9lbi1VUy9kb2NzL1dlYi9BUEkvSGVhZGVycykgaW50byBhIHNpbXBsZSBrZXktdmFsdWUgZGljdC5cbiAqIFRoZSBoZWFkZXIga2V5cyB3aWxsIGJlIGxvd2VyIGNhc2U6IGUuZy4gQSBcIkNvbnRlbnQtVHlwZVwiIGhlYWRlciB3aWxsIGJlIHN0b3JlZCBhcyBcImNvbnRlbnQtdHlwZVwiLlxuICovXG5mdW5jdGlvbiB3aW50ZXJDR0hlYWRlcnNUb0RpY3Qod2ludGVyQ0dIZWFkZXJzKSB7XG4gIGNvbnN0IGhlYWRlcnMgPSB7fTtcbiAgdHJ5IHtcbiAgICB3aW50ZXJDR0hlYWRlcnMuZm9yRWFjaCgodmFsdWUsIGtleSkgPT4ge1xuICAgICAgaWYgKHR5cGVvZiB2YWx1ZSA9PT0gJ3N0cmluZycpIHtcbiAgICAgICAgLy8gV2UgY2hlY2sgdGhhdCB2YWx1ZSBpcyBhIHN0cmluZyBldmVuIHRob3VnaCBpdCBtaWdodCBiZSByZWR1bmRhbnQgdG8gbWFrZSBzdXJlIHByb3RvdHlwZSBwb2xsdXRpb24gaXMgbm90IHBvc3NpYmxlLlxuICAgICAgICBoZWFkZXJzW2tleV0gPSB2YWx1ZTtcbiAgICAgIH1cbiAgICB9KTtcbiAgfSBjYXRjaCB7XG4gICAgLy8ganVzdCByZXR1cm4gdGhlIGVtcHR5IGhlYWRlcnNcbiAgfVxuXG4gIHJldHVybiBoZWFkZXJzO1xufVxuXG4vKipcbiAqIENvbnZlcnQgY29tbW9uIHJlcXVlc3QgaGVhZGVycyB0byBhIHNpbXBsZSBkaWN0aW9uYXJ5LlxuICovXG5mdW5jdGlvbiBoZWFkZXJzVG9EaWN0KHJlcUhlYWRlcnMpIHtcbiAgY29uc3QgaGVhZGVycyA9IE9iamVjdC5jcmVhdGUobnVsbCk7XG5cbiAgdHJ5IHtcbiAgICBPYmplY3QuZW50cmllcyhyZXFIZWFkZXJzKS5mb3JFYWNoKChba2V5LCB2YWx1ZV0pID0+IHtcbiAgICAgIGlmICh0eXBlb2YgdmFsdWUgPT09ICdzdHJpbmcnKSB7XG4gICAgICAgIGhlYWRlcnNba2V5XSA9IHZhbHVlO1xuICAgICAgfVxuICAgIH0pO1xuICB9IGNhdGNoIHtcbiAgICAvLyBqdXN0IHJldHVybiB0aGUgZW1wdHkgaGVhZGVyc1xuICB9XG5cbiAgcmV0dXJuIGhlYWRlcnM7XG59XG5cbi8qKlxuICogQ29udmVydHMgYSBgUmVxdWVzdGAgb2JqZWN0IHRoYXQgaW1wbGVtZW50cyB0aGUgYFdlYiBGZXRjaCBBUElgIChodHRwczovL2RldmVsb3Blci5tb3ppbGxhLm9yZy9lbi1VUy9kb2NzL1dlYi9BUEkvSGVhZGVycykgaW50byB0aGUgZm9ybWF0IHRoYXQgdGhlIGBSZXF1ZXN0RGF0YWAgaW50ZWdyYXRpb24gdW5kZXJzdGFuZHMuXG4gKi9cbmZ1bmN0aW9uIHdpbnRlckNHUmVxdWVzdFRvUmVxdWVzdERhdGEocmVxKSB7XG4gIGNvbnN0IGhlYWRlcnMgPSB3aW50ZXJDR0hlYWRlcnNUb0RpY3QocmVxLmhlYWRlcnMpO1xuXG4gIHJldHVybiB7XG4gICAgbWV0aG9kOiByZXEubWV0aG9kLFxuICAgIHVybDogcmVxLnVybCxcbiAgICBxdWVyeV9zdHJpbmc6IGV4dHJhY3RRdWVyeVBhcmFtc0Zyb21VcmwocmVxLnVybCksXG4gICAgaGVhZGVycyxcbiAgICAvLyBUT0RPOiBDYW4gd2UgZXh0cmFjdCBib2R5IGRhdGEgZnJvbSB0aGUgcmVxdWVzdD9cbiAgfTtcbn1cblxuLyoqXG4gKiBDb252ZXJ0IGEgSFRUUCByZXF1ZXN0IG9iamVjdCB0byBSZXF1ZXN0RXZlbnREYXRhIHRvIGJlIHBhc3NlZCBhcyBub3JtYWxpemVkUmVxdWVzdC5cbiAqIEluc3RlYWQgb2YgYWxsb3dpbmcgYFBvbHltb3JwaGljUmVxdWVzdGAgdG8gYmUgcGFzc2VkLFxuICogd2Ugd2FudCB0byBiZSBtb3JlIHNwZWNpZmljIGFuZCBnZW5lcmFsbHkgcmVxdWlyZSBhIGh0dHAuSW5jb21pbmdNZXNzYWdlLWxpa2Ugb2JqZWN0LlxuICovXG5mdW5jdGlvbiBodHRwUmVxdWVzdFRvUmVxdWVzdERhdGEocmVxdWVzdFxuXG4pIHtcbiAgY29uc3QgaGVhZGVycyA9IHJlcXVlc3QuaGVhZGVycyB8fCB7fTtcblxuICAvLyBDaGVjayBmb3IgeC1mb3J3YXJkZWQtaG9zdCBmaXJzdCwgdGhlbiBmYWxsIGJhY2sgdG8gaG9zdCBoZWFkZXJcbiAgY29uc3QgZm9yd2FyZGVkSG9zdCA9IHR5cGVvZiBoZWFkZXJzWyd4LWZvcndhcmRlZC1ob3N0J10gPT09ICdzdHJpbmcnID8gaGVhZGVyc1sneC1mb3J3YXJkZWQtaG9zdCddIDogdW5kZWZpbmVkO1xuICBjb25zdCBob3N0ID0gZm9yd2FyZGVkSG9zdCB8fCAodHlwZW9mIGhlYWRlcnMuaG9zdCA9PT0gJ3N0cmluZycgPyBoZWFkZXJzLmhvc3QgOiB1bmRlZmluZWQpO1xuXG4gIC8vIENoZWNrIGZvciB4LWZvcndhcmRlZC1wcm90byBmaXJzdCwgdGhlbiBmYWxsIGJhY2sgdG8gZXhpc3RpbmcgcHJvdG9jb2wgZGV0ZWN0aW9uXG4gIGNvbnN0IGZvcndhcmRlZFByb3RvID0gdHlwZW9mIGhlYWRlcnNbJ3gtZm9yd2FyZGVkLXByb3RvJ10gPT09ICdzdHJpbmcnID8gaGVhZGVyc1sneC1mb3J3YXJkZWQtcHJvdG8nXSA6IHVuZGVmaW5lZDtcbiAgY29uc3QgcHJvdG9jb2wgPSBmb3J3YXJkZWRQcm90byB8fCByZXF1ZXN0LnByb3RvY29sIHx8IChyZXF1ZXN0LnNvY2tldD8uZW5jcnlwdGVkID8gJ2h0dHBzJyA6ICdodHRwJyk7XG5cbiAgY29uc3QgdXJsID0gcmVxdWVzdC51cmwgfHwgJyc7XG5cbiAgY29uc3QgYWJzb2x1dGVVcmwgPSBnZXRBYnNvbHV0ZVVybCh7XG4gICAgdXJsLFxuICAgIGhvc3QsXG4gICAgcHJvdG9jb2wsXG4gIH0pO1xuXG4gIC8vIFRoaXMgaXMgbm9uLXN0YW5kYXJkLCBidXQgbWF5IGJlIHNvbWV0aW1lcyBzZXRcbiAgLy8gSXQgbWF5IGJlIG92ZXJ3cml0dGVuIGxhdGVyIGJ5IG91ciBvd24gYm9keSBoYW5kbGluZ1xuICBjb25zdCBkYXRhID0gKHJlcXVlc3QgKS5ib2R5IHx8IHVuZGVmaW5lZDtcblxuICAvLyBUaGlzIGlzIG5vbi1zdGFuZGFyZCwgYnV0IG1heSBiZSBzZXQgb24gZS5nLiBOZXh0LmpzIG9yIEV4cHJlc3MgcmVxdWVzdHNcbiAgY29uc3QgY29va2llcyA9IChyZXF1ZXN0ICkuY29va2llcztcblxuICByZXR1cm4ge1xuICAgIHVybDogYWJzb2x1dGVVcmwsXG4gICAgbWV0aG9kOiByZXF1ZXN0Lm1ldGhvZCxcbiAgICBxdWVyeV9zdHJpbmc6IGV4dHJhY3RRdWVyeVBhcmFtc0Zyb21VcmwodXJsKSxcbiAgICBoZWFkZXJzOiBoZWFkZXJzVG9EaWN0KGhlYWRlcnMpLFxuICAgIGNvb2tpZXMsXG4gICAgZGF0YSxcbiAgfTtcbn1cblxuZnVuY3Rpb24gZ2V0QWJzb2x1dGVVcmwoe1xuICB1cmwsXG4gIHByb3RvY29sLFxuICBob3N0LFxufVxuXG4pIHtcbiAgaWYgKHVybD8uc3RhcnRzV2l0aCgnaHR0cCcpKSB7XG4gICAgcmV0dXJuIHVybDtcbiAgfVxuXG4gIGlmICh1cmwgJiYgaG9zdCkge1xuICAgIHJldHVybiBgJHtwcm90b2NvbH06Ly8ke2hvc3R9JHt1cmx9YDtcbiAgfVxuXG4gIHJldHVybiB1bmRlZmluZWQ7XG59XG5cbi8qKiBFeHRyYWN0IHRoZSBxdWVyeSBwYXJhbXMgZnJvbSBhbiBVUkwuICovXG5mdW5jdGlvbiBleHRyYWN0UXVlcnlQYXJhbXNGcm9tVXJsKHVybCkge1xuICAvLyB1cmwgaXMgcGF0aCBhbmQgcXVlcnkgc3RyaW5nXG4gIGlmICghdXJsKSB7XG4gICAgcmV0dXJuO1xuICB9XG5cbiAgdHJ5IHtcbiAgICAvLyBUaGUgYFVSTGAgY29uc3RydWN0b3IgY2FuJ3QgaGFuZGxlIGludGVybmFsIFVSTHMgb2YgdGhlIGZvcm0gYC9zb21lL3BhdGgvaGVyZWAsIHNvIHN0aWNrIGEgZHVtbXkgcHJvdG9jb2wgYW5kXG4gICAgLy8gaG9zdG5hbWUgYXMgdGhlIGJhc2UuIFNpbmNlIHRoZSBwb2ludCBoZXJlIGlzIGp1c3QgdG8gZ3JhYiB0aGUgcXVlcnkgc3RyaW5nLCBpdCBkb2Vzbid0IG1hdHRlciB3aGF0IHdlIHVzZS5cbiAgICBjb25zdCBxdWVyeVBhcmFtcyA9IG5ldyBVUkwodXJsLCAnaHR0cDovL3MuaW8nKS5zZWFyY2guc2xpY2UoMSk7XG4gICAgcmV0dXJuIHF1ZXJ5UGFyYW1zLmxlbmd0aCA/IHF1ZXJ5UGFyYW1zIDogdW5kZWZpbmVkO1xuICB9IGNhdGNoIHtcbiAgICByZXR1cm4gdW5kZWZpbmVkO1xuICB9XG59XG5cbmV4cG9ydHMuZXh0cmFjdFF1ZXJ5UGFyYW1zRnJvbVVybCA9IGV4dHJhY3RRdWVyeVBhcmFtc0Zyb21Vcmw7XG5leHBvcnRzLmhlYWRlcnNUb0RpY3QgPSBoZWFkZXJzVG9EaWN0O1xuZXhwb3J0cy5odHRwUmVxdWVzdFRvUmVxdWVzdERhdGEgPSBodHRwUmVxdWVzdFRvUmVxdWVzdERhdGE7XG5leHBvcnRzLndpbnRlckNHSGVhZGVyc1RvRGljdCA9IHdpbnRlckNHSGVhZGVyc1RvRGljdDtcbmV4cG9ydHMud2ludGVyQ0dSZXF1ZXN0VG9SZXF1ZXN0RGF0YSA9IHdpbnRlckNHUmVxdWVzdFRvUmVxdWVzdERhdGE7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1yZXF1ZXN0LmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/request.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/sdkMetadata.js":
/*!*********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/sdkMetadata.js ***!
  \*********************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst version = __webpack_require__(/*! ./version.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/version.js\");\n\n/**\n * A builder for the SDK metadata in the options for the SDK initialization.\n *\n * Note: This function is identical to `buildMetadata` in Remix and NextJS and SvelteKit.\n * We don't extract it for bundle size reasons.\n * @see https://github.com/getsentry/sentry-javascript/pull/7404\n * @see https://github.com/getsentry/sentry-javascript/pull/4196\n *\n * If you make changes to this function consider updating the others as well.\n *\n * @param options SDK options object that gets mutated\n * @param names list of package names\n */\nfunction applySdkMetadata(options, name, names = [name], source = 'npm') {\n  const metadata = options._metadata || {};\n\n  if (!metadata.sdk) {\n    metadata.sdk = {\n      name: `sentry.javascript.${name}`,\n      packages: names.map(name => ({\n        name: `${source}:@sentry/${name}`,\n        version: version.SDK_VERSION,\n      })),\n      version: version.SDK_VERSION,\n    };\n  }\n\n  options._metadata = metadata;\n}\n\nexports.applySdkMetadata = applySdkMetadata;\n//# sourceMappingURL=sdkMetadata.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9zZGtNZXRhZGF0YS5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxnQkFBZ0IsbUJBQU8sQ0FBQyx5SEFBYzs7QUFFdEM7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQSxpQ0FBaUMsS0FBSztBQUN0QztBQUNBLGlCQUFpQixPQUFPLFdBQVcsS0FBSztBQUN4QztBQUNBLE9BQU87QUFDUDtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQSx3QkFBd0I7QUFDeEIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9zZGtNZXRhZGF0YS5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgdmVyc2lvbiA9IHJlcXVpcmUoJy4vdmVyc2lvbi5qcycpO1xuXG4vKipcbiAqIEEgYnVpbGRlciBmb3IgdGhlIFNESyBtZXRhZGF0YSBpbiB0aGUgb3B0aW9ucyBmb3IgdGhlIFNESyBpbml0aWFsaXphdGlvbi5cbiAqXG4gKiBOb3RlOiBUaGlzIGZ1bmN0aW9uIGlzIGlkZW50aWNhbCB0byBgYnVpbGRNZXRhZGF0YWAgaW4gUmVtaXggYW5kIE5leHRKUyBhbmQgU3ZlbHRlS2l0LlxuICogV2UgZG9uJ3QgZXh0cmFjdCBpdCBmb3IgYnVuZGxlIHNpemUgcmVhc29ucy5cbiAqIEBzZWUgaHR0cHM6Ly9naXRodWIuY29tL2dldHNlbnRyeS9zZW50cnktamF2YXNjcmlwdC9wdWxsLzc0MDRcbiAqIEBzZWUgaHR0cHM6Ly9naXRodWIuY29tL2dldHNlbnRyeS9zZW50cnktamF2YXNjcmlwdC9wdWxsLzQxOTZcbiAqXG4gKiBJZiB5b3UgbWFrZSBjaGFuZ2VzIHRvIHRoaXMgZnVuY3Rpb24gY29uc2lkZXIgdXBkYXRpbmcgdGhlIG90aGVycyBhcyB3ZWxsLlxuICpcbiAqIEBwYXJhbSBvcHRpb25zIFNESyBvcHRpb25zIG9iamVjdCB0aGF0IGdldHMgbXV0YXRlZFxuICogQHBhcmFtIG5hbWVzIGxpc3Qgb2YgcGFja2FnZSBuYW1lc1xuICovXG5mdW5jdGlvbiBhcHBseVNka01ldGFkYXRhKG9wdGlvbnMsIG5hbWUsIG5hbWVzID0gW25hbWVdLCBzb3VyY2UgPSAnbnBtJykge1xuICBjb25zdCBtZXRhZGF0YSA9IG9wdGlvbnMuX21ldGFkYXRhIHx8IHt9O1xuXG4gIGlmICghbWV0YWRhdGEuc2RrKSB7XG4gICAgbWV0YWRhdGEuc2RrID0ge1xuICAgICAgbmFtZTogYHNlbnRyeS5qYXZhc2NyaXB0LiR7bmFtZX1gLFxuICAgICAgcGFja2FnZXM6IG5hbWVzLm1hcChuYW1lID0+ICh7XG4gICAgICAgIG5hbWU6IGAke3NvdXJjZX06QHNlbnRyeS8ke25hbWV9YCxcbiAgICAgICAgdmVyc2lvbjogdmVyc2lvbi5TREtfVkVSU0lPTixcbiAgICAgIH0pKSxcbiAgICAgIHZlcnNpb246IHZlcnNpb24uU0RLX1ZFUlNJT04sXG4gICAgfTtcbiAgfVxuXG4gIG9wdGlvbnMuX21ldGFkYXRhID0gbWV0YWRhdGE7XG59XG5cbmV4cG9ydHMuYXBwbHlTZGtNZXRhZGF0YSA9IGFwcGx5U2RrTWV0YWRhdGE7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1zZGtNZXRhZGF0YS5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/sdkMetadata.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/severity.js":
/*!******************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/severity.js ***!
  \******************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n/**\n * Converts a string-based level into a `SeverityLevel`, normalizing it along the way.\n *\n * @param level String representation of desired `SeverityLevel`.\n * @returns The `SeverityLevel` corresponding to the given string, or 'log' if the string isn't a valid level.\n */\nfunction severityLevelFromString(level) {\n  return (\n    level === 'warn' ? 'warning' : ['fatal', 'error', 'warning', 'log', 'info', 'debug'].includes(level) ? level : 'log'\n  ) ;\n}\n\nexports.severityLevelFromString = severityLevelFromString;\n//# sourceMappingURL=severity.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9zZXZlcml0eS5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLCtCQUErQjtBQUMvQiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3V0aWxzL3NldmVyaXR5LmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG4vKipcbiAqIENvbnZlcnRzIGEgc3RyaW5nLWJhc2VkIGxldmVsIGludG8gYSBgU2V2ZXJpdHlMZXZlbGAsIG5vcm1hbGl6aW5nIGl0IGFsb25nIHRoZSB3YXkuXG4gKlxuICogQHBhcmFtIGxldmVsIFN0cmluZyByZXByZXNlbnRhdGlvbiBvZiBkZXNpcmVkIGBTZXZlcml0eUxldmVsYC5cbiAqIEByZXR1cm5zIFRoZSBgU2V2ZXJpdHlMZXZlbGAgY29ycmVzcG9uZGluZyB0byB0aGUgZ2l2ZW4gc3RyaW5nLCBvciAnbG9nJyBpZiB0aGUgc3RyaW5nIGlzbid0IGEgdmFsaWQgbGV2ZWwuXG4gKi9cbmZ1bmN0aW9uIHNldmVyaXR5TGV2ZWxGcm9tU3RyaW5nKGxldmVsKSB7XG4gIHJldHVybiAoXG4gICAgbGV2ZWwgPT09ICd3YXJuJyA/ICd3YXJuaW5nJyA6IFsnZmF0YWwnLCAnZXJyb3InLCAnd2FybmluZycsICdsb2cnLCAnaW5mbycsICdkZWJ1ZyddLmluY2x1ZGVzKGxldmVsKSA/IGxldmVsIDogJ2xvZydcbiAgKSA7XG59XG5cbmV4cG9ydHMuc2V2ZXJpdHlMZXZlbEZyb21TdHJpbmcgPSBzZXZlcml0eUxldmVsRnJvbVN0cmluZztcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPXNldmVyaXR5LmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/severity.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanOnScope.js":
/*!*********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanOnScope.js ***!
  \*********************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst object = __webpack_require__(/*! ./object.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/object.js\");\n\nconst SCOPE_SPAN_FIELD = '_sentrySpan';\n\n/**\n * Set the active span for a given scope.\n * NOTE: This should NOT be used directly, but is only used internally by the trace methods.\n */\nfunction _setSpanForScope(scope, span) {\n  if (span) {\n    object.addNonEnumerableProperty(scope , SCOPE_SPAN_FIELD, span);\n  } else {\n    // eslint-disable-next-line @typescript-eslint/no-dynamic-delete\n    delete (scope )[SCOPE_SPAN_FIELD];\n  }\n}\n\n/**\n * Get the active span for a given scope.\n * NOTE: This should NOT be used directly, but is only used internally by the trace methods.\n */\nfunction _getSpanForScope(scope) {\n  return scope[SCOPE_SPAN_FIELD];\n}\n\nexports._getSpanForScope = _getSpanForScope;\nexports._setSpanForScope = _setSpanForScope;\n//# sourceMappingURL=spanOnScope.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9zcGFuT25TY29wZS5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxlQUFlLG1CQUFPLENBQUMsdUhBQWE7O0FBRXBDOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsSUFBSTtBQUNKO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLHdCQUF3QjtBQUN4Qix3QkFBd0I7QUFDeEIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9zcGFuT25TY29wZS5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3Qgb2JqZWN0ID0gcmVxdWlyZSgnLi9vYmplY3QuanMnKTtcblxuY29uc3QgU0NPUEVfU1BBTl9GSUVMRCA9ICdfc2VudHJ5U3Bhbic7XG5cbi8qKlxuICogU2V0IHRoZSBhY3RpdmUgc3BhbiBmb3IgYSBnaXZlbiBzY29wZS5cbiAqIE5PVEU6IFRoaXMgc2hvdWxkIE5PVCBiZSB1c2VkIGRpcmVjdGx5LCBidXQgaXMgb25seSB1c2VkIGludGVybmFsbHkgYnkgdGhlIHRyYWNlIG1ldGhvZHMuXG4gKi9cbmZ1bmN0aW9uIF9zZXRTcGFuRm9yU2NvcGUoc2NvcGUsIHNwYW4pIHtcbiAgaWYgKHNwYW4pIHtcbiAgICBvYmplY3QuYWRkTm9uRW51bWVyYWJsZVByb3BlcnR5KHNjb3BlICwgU0NPUEVfU1BBTl9GSUVMRCwgc3Bhbik7XG4gIH0gZWxzZSB7XG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uby1keW5hbWljLWRlbGV0ZVxuICAgIGRlbGV0ZSAoc2NvcGUgKVtTQ09QRV9TUEFOX0ZJRUxEXTtcbiAgfVxufVxuXG4vKipcbiAqIEdldCB0aGUgYWN0aXZlIHNwYW4gZm9yIGEgZ2l2ZW4gc2NvcGUuXG4gKiBOT1RFOiBUaGlzIHNob3VsZCBOT1QgYmUgdXNlZCBkaXJlY3RseSwgYnV0IGlzIG9ubHkgdXNlZCBpbnRlcm5hbGx5IGJ5IHRoZSB0cmFjZSBtZXRob2RzLlxuICovXG5mdW5jdGlvbiBfZ2V0U3BhbkZvclNjb3BlKHNjb3BlKSB7XG4gIHJldHVybiBzY29wZVtTQ09QRV9TUEFOX0ZJRUxEXTtcbn1cblxuZXhwb3J0cy5fZ2V0U3BhbkZvclNjb3BlID0gX2dldFNwYW5Gb3JTY29wZTtcbmV4cG9ydHMuX3NldFNwYW5Gb3JTY29wZSA9IF9zZXRTcGFuRm9yU2NvcGU7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1zcGFuT25TY29wZS5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanOnScope.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanUtils.js":
/*!*******************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanUtils.js ***!
  \*******************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst index = __webpack_require__(/*! ../asyncContext/index.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/asyncContext/index.js\");\nconst carrier = __webpack_require__(/*! ../carrier.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/carrier.js\");\nconst currentScopes = __webpack_require__(/*! ../currentScopes.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst semanticAttributes = __webpack_require__(/*! ../semanticAttributes.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/semanticAttributes.js\");\nconst spanstatus = __webpack_require__(/*! ../tracing/spanstatus.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/spanstatus.js\");\nconst utils = __webpack_require__(/*! ../tracing/utils.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/utils.js\");\nconst object = __webpack_require__(/*! ./object.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/object.js\");\nconst propagationContext = __webpack_require__(/*! ./propagationContext.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/propagationContext.js\");\nconst time = __webpack_require__(/*! ./time.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/time.js\");\nconst tracing = __webpack_require__(/*! ./tracing.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/tracing.js\");\nconst debugLogger = __webpack_require__(/*! ./debug-logger.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst spanOnScope = __webpack_require__(/*! ./spanOnScope.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanOnScope.js\");\n\n// These are aligned with OpenTelemetry trace flags\nconst TRACE_FLAG_NONE = 0x0;\nconst TRACE_FLAG_SAMPLED = 0x1;\n\nlet hasShownSpanDropWarning = false;\n\n/**\n * Convert a span to a trace context, which can be sent as the `trace` context in an event.\n * By default, this will only include trace_id, span_id & parent_span_id.\n * If `includeAllData` is true, it will also include data, op, status & origin.\n */\nfunction spanToTransactionTraceContext(span) {\n  const { spanId: span_id, traceId: trace_id } = span.spanContext();\n  const { data, op, parent_span_id, status, origin, links } = spanToJSON(span);\n\n  return {\n    parent_span_id,\n    span_id,\n    trace_id,\n    data,\n    op,\n    status,\n    origin,\n    links,\n  };\n}\n\n/**\n * Convert a span to a trace context, which can be sent as the `trace` context in a non-transaction event.\n */\nfunction spanToTraceContext(span) {\n  const { spanId, traceId: trace_id, isRemote } = span.spanContext();\n\n  // If the span is remote, we use a random/virtual span as span_id to the trace context,\n  // and the remote span as parent_span_id\n  const parent_span_id = isRemote ? spanId : spanToJSON(span).parent_span_id;\n  const scope = utils.getCapturedScopesOnSpan(span).scope;\n\n  const span_id = isRemote ? scope?.getPropagationContext().propagationSpanId || propagationContext.generateSpanId() : spanId;\n\n  return {\n    parent_span_id,\n    span_id,\n    trace_id,\n  };\n}\n\n/**\n * Convert a Span to a Sentry trace header.\n */\nfunction spanToTraceHeader(span) {\n  const { traceId, spanId } = span.spanContext();\n  const sampled = spanIsSampled(span);\n  return tracing.generateSentryTraceHeader(traceId, spanId, sampled);\n}\n\n/**\n *  Converts the span links array to a flattened version to be sent within an envelope.\n *\n *  If the links array is empty, it returns `undefined` so the empty value can be dropped before it's sent.\n */\nfunction convertSpanLinksForEnvelope(links) {\n  if (links && links.length > 0) {\n    return links.map(({ context: { spanId, traceId, traceFlags, ...restContext }, attributes }) => ({\n      span_id: spanId,\n      trace_id: traceId,\n      sampled: traceFlags === TRACE_FLAG_SAMPLED,\n      attributes,\n      ...restContext,\n    }));\n  } else {\n    return undefined;\n  }\n}\n\n/**\n * Convert a span time input into a timestamp in seconds.\n */\nfunction spanTimeInputToSeconds(input) {\n  if (typeof input === 'number') {\n    return ensureTimestampInSeconds(input);\n  }\n\n  if (Array.isArray(input)) {\n    // See {@link HrTime} for the array-based time format\n    return input[0] + input[1] / 1e9;\n  }\n\n  if (input instanceof Date) {\n    return ensureTimestampInSeconds(input.getTime());\n  }\n\n  return time.timestampInSeconds();\n}\n\n/**\n * Converts a timestamp to second, if it was in milliseconds, or keeps it as second.\n */\nfunction ensureTimestampInSeconds(timestamp) {\n  const isMs = timestamp > 9999999999;\n  return isMs ? timestamp / 1000 : timestamp;\n}\n\n/**\n * Convert a span to a JSON representation.\n */\n// Note: Because of this, we currently have a circular type dependency (which we opted out of in package.json).\n// This is not avoidable as we need `spanToJSON` in `spanUtils.ts`, which in turn is needed by `span.ts` for backwards compatibility.\n// And `spanToJSON` needs the Span class from `span.ts` to check here.\nfunction spanToJSON(span) {\n  if (spanIsSentrySpan(span)) {\n    return span.getSpanJSON();\n  }\n\n  const { spanId: span_id, traceId: trace_id } = span.spanContext();\n\n  // Handle a span from @opentelemetry/sdk-base-trace's `Span` class\n  if (spanIsOpenTelemetrySdkTraceBaseSpan(span)) {\n    const { attributes, startTime, name, endTime, status, links } = span;\n\n    // In preparation for the next major of OpenTelemetry, we want to support\n    // looking up the parent span id according to the new API\n    // In OTel v1, the parent span id is accessed as `parentSpanId`\n    // In OTel v2, the parent span id is accessed as `spanId` on the `parentSpanContext`\n    const parentSpanId =\n      'parentSpanId' in span\n        ? span.parentSpanId\n        : 'parentSpanContext' in span\n          ? (span.parentSpanContext )?.spanId\n          : undefined;\n\n    return {\n      span_id,\n      trace_id,\n      data: attributes,\n      description: name,\n      parent_span_id: parentSpanId,\n      start_timestamp: spanTimeInputToSeconds(startTime),\n      // This is [0,0] by default in OTEL, in which case we want to interpret this as no end time\n      timestamp: spanTimeInputToSeconds(endTime) || undefined,\n      status: getStatusMessage(status),\n      op: attributes[semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_OP],\n      origin: attributes[semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_ORIGIN] ,\n      links: convertSpanLinksForEnvelope(links),\n    };\n  }\n\n  // Finally, at least we have `spanContext()`....\n  // This should not actually happen in reality, but we need to handle it for type safety.\n  return {\n    span_id,\n    trace_id,\n    start_timestamp: 0,\n    data: {},\n  };\n}\n\nfunction spanIsOpenTelemetrySdkTraceBaseSpan(span) {\n  const castSpan = span ;\n  return !!castSpan.attributes && !!castSpan.startTime && !!castSpan.name && !!castSpan.endTime && !!castSpan.status;\n}\n\n/** Exported only for tests. */\n\n/**\n * Sadly, due to circular dependency checks we cannot actually import the Span class here and check for instanceof.\n * :( So instead we approximate this by checking if it has the `getSpanJSON` method.\n */\nfunction spanIsSentrySpan(span) {\n  return typeof (span ).getSpanJSON === 'function';\n}\n\n/**\n * Returns true if a span is sampled.\n * In most cases, you should just use `span.isRecording()` instead.\n * However, this has a slightly different semantic, as it also returns false if the span is finished.\n * So in the case where this distinction is important, use this method.\n */\nfunction spanIsSampled(span) {\n  // We align our trace flags with the ones OpenTelemetry use\n  // So we also check for sampled the same way they do.\n  const { traceFlags } = span.spanContext();\n  return traceFlags === TRACE_FLAG_SAMPLED;\n}\n\n/** Get the status message to use for a JSON representation of a span. */\nfunction getStatusMessage(status) {\n  if (!status || status.code === spanstatus.SPAN_STATUS_UNSET) {\n    return undefined;\n  }\n\n  if (status.code === spanstatus.SPAN_STATUS_OK) {\n    return 'ok';\n  }\n\n  return status.message || 'unknown_error';\n}\n\nconst CHILD_SPANS_FIELD = '_sentryChildSpans';\nconst ROOT_SPAN_FIELD = '_sentryRootSpan';\n\n/**\n * Adds an opaque child span reference to a span.\n */\nfunction addChildSpanToSpan(span, childSpan) {\n  // We store the root span reference on the child span\n  // We need this for `getRootSpan()` to work\n  const rootSpan = span[ROOT_SPAN_FIELD] || span;\n  object.addNonEnumerableProperty(childSpan , ROOT_SPAN_FIELD, rootSpan);\n\n  // We store a list of child spans on the parent span\n  // We need this for `getSpanDescendants()` to work\n  if (span[CHILD_SPANS_FIELD]) {\n    span[CHILD_SPANS_FIELD].add(childSpan);\n  } else {\n    object.addNonEnumerableProperty(span, CHILD_SPANS_FIELD, new Set([childSpan]));\n  }\n}\n\n/** This is only used internally by Idle Spans. */\nfunction removeChildSpanFromSpan(span, childSpan) {\n  if (span[CHILD_SPANS_FIELD]) {\n    span[CHILD_SPANS_FIELD].delete(childSpan);\n  }\n}\n\n/**\n * Returns an array of the given span and all of its descendants.\n */\nfunction getSpanDescendants(span) {\n  const resultSet = new Set();\n\n  function addSpanChildren(span) {\n    // This exit condition is required to not infinitely loop in case of a circular dependency.\n    if (resultSet.has(span)) {\n      return;\n      // We want to ignore unsampled spans (e.g. non recording spans)\n    } else if (spanIsSampled(span)) {\n      resultSet.add(span);\n      const childSpans = span[CHILD_SPANS_FIELD] ? Array.from(span[CHILD_SPANS_FIELD]) : [];\n      for (const childSpan of childSpans) {\n        addSpanChildren(childSpan);\n      }\n    }\n  }\n\n  addSpanChildren(span);\n\n  return Array.from(resultSet);\n}\n\n/**\n * Returns the root span of a given span.\n */\nfunction getRootSpan(span) {\n  return span[ROOT_SPAN_FIELD] || span;\n}\n\n/**\n * Returns the currently active span.\n */\nfunction getActiveSpan() {\n  const carrier$1 = carrier.getMainCarrier();\n  const acs = index.getAsyncContextStrategy(carrier$1);\n  if (acs.getActiveSpan) {\n    return acs.getActiveSpan();\n  }\n\n  return spanOnScope._getSpanForScope(currentScopes.getCurrentScope());\n}\n\n/**\n * Logs a warning once if `beforeSendSpan` is used to drop spans.\n */\nfunction showSpanDropWarning() {\n  if (!hasShownSpanDropWarning) {\n    debugLogger.consoleSandbox(() => {\n      // eslint-disable-next-line no-console\n      console.warn(\n        '[Sentry] Returning null from `beforeSendSpan` is disallowed. To drop certain spans, configure the respective integrations directly.',\n      );\n    });\n    hasShownSpanDropWarning = true;\n  }\n}\n\n/**\n * Updates the name of the given span and ensures that the span name is not\n * overwritten by the Sentry SDK.\n *\n * Use this function instead of `span.updateName()` if you want to make sure that\n * your name is kept. For some spans, for example root `http.server` spans the\n * Sentry SDK would otherwise overwrite the span name with a high-quality name\n * it infers when the span ends.\n *\n * Use this function in server code or when your span is started on the server\n * and on the client (browser). If you only update a span name on the client,\n * you can also use `span.updateName()` the SDK does not overwrite the name.\n *\n * @param span - The span to update the name of.\n * @param name - The name to set on the span.\n */\nfunction updateSpanName(span, name) {\n  span.updateName(name);\n  span.setAttributes({\n    [semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_SOURCE]: 'custom',\n    [semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_CUSTOM_SPAN_NAME]: name,\n  });\n}\n\nexports.TRACE_FLAG_NONE = TRACE_FLAG_NONE;\nexports.TRACE_FLAG_SAMPLED = TRACE_FLAG_SAMPLED;\nexports.addChildSpanToSpan = addChildSpanToSpan;\nexports.convertSpanLinksForEnvelope = convertSpanLinksForEnvelope;\nexports.getActiveSpan = getActiveSpan;\nexports.getRootSpan = getRootSpan;\nexports.getSpanDescendants = getSpanDescendants;\nexports.getStatusMessage = getStatusMessage;\nexports.removeChildSpanFromSpan = removeChildSpanFromSpan;\nexports.showSpanDropWarning = showSpanDropWarning;\nexports.spanIsSampled = spanIsSampled;\nexports.spanTimeInputToSeconds = spanTimeInputToSeconds;\nexports.spanToJSON = spanToJSON;\nexports.spanToTraceContext = spanToTraceContext;\nexports.spanToTraceHeader = spanToTraceHeader;\nexports.spanToTransactionTraceContext = spanToTransactionTraceContext;\nexports.updateSpanName = updateSpanName;\n//# sourceMappingURL=spanUtils.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9zcGFuVXRpbHMuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsY0FBYyxtQkFBTyxDQUFDLDBJQUEwQjtBQUNoRCxnQkFBZ0IsbUJBQU8sQ0FBQyxvSEFBZTtBQUN2QyxzQkFBc0IsbUJBQU8sQ0FBQyxnSUFBcUI7QUFDbkQsMkJBQTJCLG1CQUFPLENBQUMsMElBQTBCO0FBQzdELG1CQUFtQixtQkFBTyxDQUFDLDBJQUEwQjtBQUNyRCxjQUFjLG1CQUFPLENBQUMsZ0lBQXFCO0FBQzNDLGVBQWUsbUJBQU8sQ0FBQyx1SEFBYTtBQUNwQywyQkFBMkIsbUJBQU8sQ0FBQywrSUFBeUI7QUFDNUQsYUFBYSxtQkFBTyxDQUFDLG1IQUFXO0FBQ2hDLGdCQUFnQixtQkFBTyxDQUFDLHlIQUFjO0FBQ3RDLG9CQUFvQixtQkFBTyxDQUFDLG1JQUFtQjtBQUMvQyxvQkFBb0IsbUJBQU8sQ0FBQyxpSUFBa0I7O0FBRTlDO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxVQUFVLHFDQUFxQztBQUMvQyxVQUFVLGtEQUFrRDs7QUFFNUQ7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFVBQVUsc0NBQXNDOztBQUVoRDtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQSxVQUFVLGtCQUFrQjtBQUM1QjtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSx3QkFBd0IsV0FBVyw2Q0FBNkMsY0FBYztBQUM5RjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsS0FBSztBQUNMLElBQUk7QUFDSjtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQSxZQUFZLGNBQWM7QUFDMUI7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSxVQUFVLHFDQUFxQzs7QUFFL0M7QUFDQTtBQUNBLFlBQVksc0RBQXNEOztBQUVsRTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsWUFBWTtBQUNaO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsVUFBVSxhQUFhO0FBQ3ZCO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQSxJQUFJO0FBQ0o7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxNQUFNO0FBQ047QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxLQUFLO0FBQ0w7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEdBQUc7QUFDSDs7QUFFQSx1QkFBdUI7QUFDdkIsMEJBQTBCO0FBQzFCLDBCQUEwQjtBQUMxQixtQ0FBbUM7QUFDbkMscUJBQXFCO0FBQ3JCLG1CQUFtQjtBQUNuQiwwQkFBMEI7QUFDMUIsd0JBQXdCO0FBQ3hCLCtCQUErQjtBQUMvQiwyQkFBMkI7QUFDM0IscUJBQXFCO0FBQ3JCLDhCQUE4QjtBQUM5QixrQkFBa0I7QUFDbEIsMEJBQTBCO0FBQzFCLHlCQUF5QjtBQUN6QixxQ0FBcUM7QUFDckMsc0JBQXNCO0FBQ3RCIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvc3BhblV0aWxzLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBpbmRleCA9IHJlcXVpcmUoJy4uL2FzeW5jQ29udGV4dC9pbmRleC5qcycpO1xuY29uc3QgY2FycmllciA9IHJlcXVpcmUoJy4uL2NhcnJpZXIuanMnKTtcbmNvbnN0IGN1cnJlbnRTY29wZXMgPSByZXF1aXJlKCcuLi9jdXJyZW50U2NvcGVzLmpzJyk7XG5jb25zdCBzZW1hbnRpY0F0dHJpYnV0ZXMgPSByZXF1aXJlKCcuLi9zZW1hbnRpY0F0dHJpYnV0ZXMuanMnKTtcbmNvbnN0IHNwYW5zdGF0dXMgPSByZXF1aXJlKCcuLi90cmFjaW5nL3NwYW5zdGF0dXMuanMnKTtcbmNvbnN0IHV0aWxzID0gcmVxdWlyZSgnLi4vdHJhY2luZy91dGlscy5qcycpO1xuY29uc3Qgb2JqZWN0ID0gcmVxdWlyZSgnLi9vYmplY3QuanMnKTtcbmNvbnN0IHByb3BhZ2F0aW9uQ29udGV4dCA9IHJlcXVpcmUoJy4vcHJvcGFnYXRpb25Db250ZXh0LmpzJyk7XG5jb25zdCB0aW1lID0gcmVxdWlyZSgnLi90aW1lLmpzJyk7XG5jb25zdCB0cmFjaW5nID0gcmVxdWlyZSgnLi90cmFjaW5nLmpzJyk7XG5jb25zdCBkZWJ1Z0xvZ2dlciA9IHJlcXVpcmUoJy4vZGVidWctbG9nZ2VyLmpzJyk7XG5jb25zdCBzcGFuT25TY29wZSA9IHJlcXVpcmUoJy4vc3Bhbk9uU2NvcGUuanMnKTtcblxuLy8gVGhlc2UgYXJlIGFsaWduZWQgd2l0aCBPcGVuVGVsZW1ldHJ5IHRyYWNlIGZsYWdzXG5jb25zdCBUUkFDRV9GTEFHX05PTkUgPSAweDA7XG5jb25zdCBUUkFDRV9GTEFHX1NBTVBMRUQgPSAweDE7XG5cbmxldCBoYXNTaG93blNwYW5Ecm9wV2FybmluZyA9IGZhbHNlO1xuXG4vKipcbiAqIENvbnZlcnQgYSBzcGFuIHRvIGEgdHJhY2UgY29udGV4dCwgd2hpY2ggY2FuIGJlIHNlbnQgYXMgdGhlIGB0cmFjZWAgY29udGV4dCBpbiBhbiBldmVudC5cbiAqIEJ5IGRlZmF1bHQsIHRoaXMgd2lsbCBvbmx5IGluY2x1ZGUgdHJhY2VfaWQsIHNwYW5faWQgJiBwYXJlbnRfc3Bhbl9pZC5cbiAqIElmIGBpbmNsdWRlQWxsRGF0YWAgaXMgdHJ1ZSwgaXQgd2lsbCBhbHNvIGluY2x1ZGUgZGF0YSwgb3AsIHN0YXR1cyAmIG9yaWdpbi5cbiAqL1xuZnVuY3Rpb24gc3BhblRvVHJhbnNhY3Rpb25UcmFjZUNvbnRleHQoc3Bhbikge1xuICBjb25zdCB7IHNwYW5JZDogc3Bhbl9pZCwgdHJhY2VJZDogdHJhY2VfaWQgfSA9IHNwYW4uc3BhbkNvbnRleHQoKTtcbiAgY29uc3QgeyBkYXRhLCBvcCwgcGFyZW50X3NwYW5faWQsIHN0YXR1cywgb3JpZ2luLCBsaW5rcyB9ID0gc3BhblRvSlNPTihzcGFuKTtcblxuICByZXR1cm4ge1xuICAgIHBhcmVudF9zcGFuX2lkLFxuICAgIHNwYW5faWQsXG4gICAgdHJhY2VfaWQsXG4gICAgZGF0YSxcbiAgICBvcCxcbiAgICBzdGF0dXMsXG4gICAgb3JpZ2luLFxuICAgIGxpbmtzLFxuICB9O1xufVxuXG4vKipcbiAqIENvbnZlcnQgYSBzcGFuIHRvIGEgdHJhY2UgY29udGV4dCwgd2hpY2ggY2FuIGJlIHNlbnQgYXMgdGhlIGB0cmFjZWAgY29udGV4dCBpbiBhIG5vbi10cmFuc2FjdGlvbiBldmVudC5cbiAqL1xuZnVuY3Rpb24gc3BhblRvVHJhY2VDb250ZXh0KHNwYW4pIHtcbiAgY29uc3QgeyBzcGFuSWQsIHRyYWNlSWQ6IHRyYWNlX2lkLCBpc1JlbW90ZSB9ID0gc3Bhbi5zcGFuQ29udGV4dCgpO1xuXG4gIC8vIElmIHRoZSBzcGFuIGlzIHJlbW90ZSwgd2UgdXNlIGEgcmFuZG9tL3ZpcnR1YWwgc3BhbiBhcyBzcGFuX2lkIHRvIHRoZSB0cmFjZSBjb250ZXh0LFxuICAvLyBhbmQgdGhlIHJlbW90ZSBzcGFuIGFzIHBhcmVudF9zcGFuX2lkXG4gIGNvbnN0IHBhcmVudF9zcGFuX2lkID0gaXNSZW1vdGUgPyBzcGFuSWQgOiBzcGFuVG9KU09OKHNwYW4pLnBhcmVudF9zcGFuX2lkO1xuICBjb25zdCBzY29wZSA9IHV0aWxzLmdldENhcHR1cmVkU2NvcGVzT25TcGFuKHNwYW4pLnNjb3BlO1xuXG4gIGNvbnN0IHNwYW5faWQgPSBpc1JlbW90ZSA/IHNjb3BlPy5nZXRQcm9wYWdhdGlvbkNvbnRleHQoKS5wcm9wYWdhdGlvblNwYW5JZCB8fCBwcm9wYWdhdGlvbkNvbnRleHQuZ2VuZXJhdGVTcGFuSWQoKSA6IHNwYW5JZDtcblxuICByZXR1cm4ge1xuICAgIHBhcmVudF9zcGFuX2lkLFxuICAgIHNwYW5faWQsXG4gICAgdHJhY2VfaWQsXG4gIH07XG59XG5cbi8qKlxuICogQ29udmVydCBhIFNwYW4gdG8gYSBTZW50cnkgdHJhY2UgaGVhZGVyLlxuICovXG5mdW5jdGlvbiBzcGFuVG9UcmFjZUhlYWRlcihzcGFuKSB7XG4gIGNvbnN0IHsgdHJhY2VJZCwgc3BhbklkIH0gPSBzcGFuLnNwYW5Db250ZXh0KCk7XG4gIGNvbnN0IHNhbXBsZWQgPSBzcGFuSXNTYW1wbGVkKHNwYW4pO1xuICByZXR1cm4gdHJhY2luZy5nZW5lcmF0ZVNlbnRyeVRyYWNlSGVhZGVyKHRyYWNlSWQsIHNwYW5JZCwgc2FtcGxlZCk7XG59XG5cbi8qKlxuICogIENvbnZlcnRzIHRoZSBzcGFuIGxpbmtzIGFycmF5IHRvIGEgZmxhdHRlbmVkIHZlcnNpb24gdG8gYmUgc2VudCB3aXRoaW4gYW4gZW52ZWxvcGUuXG4gKlxuICogIElmIHRoZSBsaW5rcyBhcnJheSBpcyBlbXB0eSwgaXQgcmV0dXJucyBgdW5kZWZpbmVkYCBzbyB0aGUgZW1wdHkgdmFsdWUgY2FuIGJlIGRyb3BwZWQgYmVmb3JlIGl0J3Mgc2VudC5cbiAqL1xuZnVuY3Rpb24gY29udmVydFNwYW5MaW5rc0ZvckVudmVsb3BlKGxpbmtzKSB7XG4gIGlmIChsaW5rcyAmJiBsaW5rcy5sZW5ndGggPiAwKSB7XG4gICAgcmV0dXJuIGxpbmtzLm1hcCgoeyBjb250ZXh0OiB7IHNwYW5JZCwgdHJhY2VJZCwgdHJhY2VGbGFncywgLi4ucmVzdENvbnRleHQgfSwgYXR0cmlidXRlcyB9KSA9PiAoe1xuICAgICAgc3Bhbl9pZDogc3BhbklkLFxuICAgICAgdHJhY2VfaWQ6IHRyYWNlSWQsXG4gICAgICBzYW1wbGVkOiB0cmFjZUZsYWdzID09PSBUUkFDRV9GTEFHX1NBTVBMRUQsXG4gICAgICBhdHRyaWJ1dGVzLFxuICAgICAgLi4ucmVzdENvbnRleHQsXG4gICAgfSkpO1xuICB9IGVsc2Uge1xuICAgIHJldHVybiB1bmRlZmluZWQ7XG4gIH1cbn1cblxuLyoqXG4gKiBDb252ZXJ0IGEgc3BhbiB0aW1lIGlucHV0IGludG8gYSB0aW1lc3RhbXAgaW4gc2Vjb25kcy5cbiAqL1xuZnVuY3Rpb24gc3BhblRpbWVJbnB1dFRvU2Vjb25kcyhpbnB1dCkge1xuICBpZiAodHlwZW9mIGlucHV0ID09PSAnbnVtYmVyJykge1xuICAgIHJldHVybiBlbnN1cmVUaW1lc3RhbXBJblNlY29uZHMoaW5wdXQpO1xuICB9XG5cbiAgaWYgKEFycmF5LmlzQXJyYXkoaW5wdXQpKSB7XG4gICAgLy8gU2VlIHtAbGluayBIclRpbWV9IGZvciB0aGUgYXJyYXktYmFzZWQgdGltZSBmb3JtYXRcbiAgICByZXR1cm4gaW5wdXRbMF0gKyBpbnB1dFsxXSAvIDFlOTtcbiAgfVxuXG4gIGlmIChpbnB1dCBpbnN0YW5jZW9mIERhdGUpIHtcbiAgICByZXR1cm4gZW5zdXJlVGltZXN0YW1wSW5TZWNvbmRzKGlucHV0LmdldFRpbWUoKSk7XG4gIH1cblxuICByZXR1cm4gdGltZS50aW1lc3RhbXBJblNlY29uZHMoKTtcbn1cblxuLyoqXG4gKiBDb252ZXJ0cyBhIHRpbWVzdGFtcCB0byBzZWNvbmQsIGlmIGl0IHdhcyBpbiBtaWxsaXNlY29uZHMsIG9yIGtlZXBzIGl0IGFzIHNlY29uZC5cbiAqL1xuZnVuY3Rpb24gZW5zdXJlVGltZXN0YW1wSW5TZWNvbmRzKHRpbWVzdGFtcCkge1xuICBjb25zdCBpc01zID0gdGltZXN0YW1wID4gOTk5OTk5OTk5OTtcbiAgcmV0dXJuIGlzTXMgPyB0aW1lc3RhbXAgLyAxMDAwIDogdGltZXN0YW1wO1xufVxuXG4vKipcbiAqIENvbnZlcnQgYSBzcGFuIHRvIGEgSlNPTiByZXByZXNlbnRhdGlvbi5cbiAqL1xuLy8gTm90ZTogQmVjYXVzZSBvZiB0aGlzLCB3ZSBjdXJyZW50bHkgaGF2ZSBhIGNpcmN1bGFyIHR5cGUgZGVwZW5kZW5jeSAod2hpY2ggd2Ugb3B0ZWQgb3V0IG9mIGluIHBhY2thZ2UuanNvbikuXG4vLyBUaGlzIGlzIG5vdCBhdm9pZGFibGUgYXMgd2UgbmVlZCBgc3BhblRvSlNPTmAgaW4gYHNwYW5VdGlscy50c2AsIHdoaWNoIGluIHR1cm4gaXMgbmVlZGVkIGJ5IGBzcGFuLnRzYCBmb3IgYmFja3dhcmRzIGNvbXBhdGliaWxpdHkuXG4vLyBBbmQgYHNwYW5Ub0pTT05gIG5lZWRzIHRoZSBTcGFuIGNsYXNzIGZyb20gYHNwYW4udHNgIHRvIGNoZWNrIGhlcmUuXG5mdW5jdGlvbiBzcGFuVG9KU09OKHNwYW4pIHtcbiAgaWYgKHNwYW5Jc1NlbnRyeVNwYW4oc3BhbikpIHtcbiAgICByZXR1cm4gc3Bhbi5nZXRTcGFuSlNPTigpO1xuICB9XG5cbiAgY29uc3QgeyBzcGFuSWQ6IHNwYW5faWQsIHRyYWNlSWQ6IHRyYWNlX2lkIH0gPSBzcGFuLnNwYW5Db250ZXh0KCk7XG5cbiAgLy8gSGFuZGxlIGEgc3BhbiBmcm9tIEBvcGVudGVsZW1ldHJ5L3Nkay1iYXNlLXRyYWNlJ3MgYFNwYW5gIGNsYXNzXG4gIGlmIChzcGFuSXNPcGVuVGVsZW1ldHJ5U2RrVHJhY2VCYXNlU3BhbihzcGFuKSkge1xuICAgIGNvbnN0IHsgYXR0cmlidXRlcywgc3RhcnRUaW1lLCBuYW1lLCBlbmRUaW1lLCBzdGF0dXMsIGxpbmtzIH0gPSBzcGFuO1xuXG4gICAgLy8gSW4gcHJlcGFyYXRpb24gZm9yIHRoZSBuZXh0IG1ham9yIG9mIE9wZW5UZWxlbWV0cnksIHdlIHdhbnQgdG8gc3VwcG9ydFxuICAgIC8vIGxvb2tpbmcgdXAgdGhlIHBhcmVudCBzcGFuIGlkIGFjY29yZGluZyB0byB0aGUgbmV3IEFQSVxuICAgIC8vIEluIE9UZWwgdjEsIHRoZSBwYXJlbnQgc3BhbiBpZCBpcyBhY2Nlc3NlZCBhcyBgcGFyZW50U3BhbklkYFxuICAgIC8vIEluIE9UZWwgdjIsIHRoZSBwYXJlbnQgc3BhbiBpZCBpcyBhY2Nlc3NlZCBhcyBgc3BhbklkYCBvbiB0aGUgYHBhcmVudFNwYW5Db250ZXh0YFxuICAgIGNvbnN0IHBhcmVudFNwYW5JZCA9XG4gICAgICAncGFyZW50U3BhbklkJyBpbiBzcGFuXG4gICAgICAgID8gc3Bhbi5wYXJlbnRTcGFuSWRcbiAgICAgICAgOiAncGFyZW50U3BhbkNvbnRleHQnIGluIHNwYW5cbiAgICAgICAgICA/IChzcGFuLnBhcmVudFNwYW5Db250ZXh0ICk/LnNwYW5JZFxuICAgICAgICAgIDogdW5kZWZpbmVkO1xuXG4gICAgcmV0dXJuIHtcbiAgICAgIHNwYW5faWQsXG4gICAgICB0cmFjZV9pZCxcbiAgICAgIGRhdGE6IGF0dHJpYnV0ZXMsXG4gICAgICBkZXNjcmlwdGlvbjogbmFtZSxcbiAgICAgIHBhcmVudF9zcGFuX2lkOiBwYXJlbnRTcGFuSWQsXG4gICAgICBzdGFydF90aW1lc3RhbXA6IHNwYW5UaW1lSW5wdXRUb1NlY29uZHMoc3RhcnRUaW1lKSxcbiAgICAgIC8vIFRoaXMgaXMgWzAsMF0gYnkgZGVmYXVsdCBpbiBPVEVMLCBpbiB3aGljaCBjYXNlIHdlIHdhbnQgdG8gaW50ZXJwcmV0IHRoaXMgYXMgbm8gZW5kIHRpbWVcbiAgICAgIHRpbWVzdGFtcDogc3BhblRpbWVJbnB1dFRvU2Vjb25kcyhlbmRUaW1lKSB8fCB1bmRlZmluZWQsXG4gICAgICBzdGF0dXM6IGdldFN0YXR1c01lc3NhZ2Uoc3RhdHVzKSxcbiAgICAgIG9wOiBhdHRyaWJ1dGVzW3NlbWFudGljQXR0cmlidXRlcy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX09QXSxcbiAgICAgIG9yaWdpbjogYXR0cmlidXRlc1tzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9PUklHSU5dICxcbiAgICAgIGxpbmtzOiBjb252ZXJ0U3BhbkxpbmtzRm9yRW52ZWxvcGUobGlua3MpLFxuICAgIH07XG4gIH1cblxuICAvLyBGaW5hbGx5LCBhdCBsZWFzdCB3ZSBoYXZlIGBzcGFuQ29udGV4dCgpYC4uLi5cbiAgLy8gVGhpcyBzaG91bGQgbm90IGFjdHVhbGx5IGhhcHBlbiBpbiByZWFsaXR5LCBidXQgd2UgbmVlZCB0byBoYW5kbGUgaXQgZm9yIHR5cGUgc2FmZXR5LlxuICByZXR1cm4ge1xuICAgIHNwYW5faWQsXG4gICAgdHJhY2VfaWQsXG4gICAgc3RhcnRfdGltZXN0YW1wOiAwLFxuICAgIGRhdGE6IHt9LFxuICB9O1xufVxuXG5mdW5jdGlvbiBzcGFuSXNPcGVuVGVsZW1ldHJ5U2RrVHJhY2VCYXNlU3BhbihzcGFuKSB7XG4gIGNvbnN0IGNhc3RTcGFuID0gc3BhbiA7XG4gIHJldHVybiAhIWNhc3RTcGFuLmF0dHJpYnV0ZXMgJiYgISFjYXN0U3Bhbi5zdGFydFRpbWUgJiYgISFjYXN0U3Bhbi5uYW1lICYmICEhY2FzdFNwYW4uZW5kVGltZSAmJiAhIWNhc3RTcGFuLnN0YXR1cztcbn1cblxuLyoqIEV4cG9ydGVkIG9ubHkgZm9yIHRlc3RzLiAqL1xuXG4vKipcbiAqIFNhZGx5LCBkdWUgdG8gY2lyY3VsYXIgZGVwZW5kZW5jeSBjaGVja3Mgd2UgY2Fubm90IGFjdHVhbGx5IGltcG9ydCB0aGUgU3BhbiBjbGFzcyBoZXJlIGFuZCBjaGVjayBmb3IgaW5zdGFuY2VvZi5cbiAqIDooIFNvIGluc3RlYWQgd2UgYXBwcm94aW1hdGUgdGhpcyBieSBjaGVja2luZyBpZiBpdCBoYXMgdGhlIGBnZXRTcGFuSlNPTmAgbWV0aG9kLlxuICovXG5mdW5jdGlvbiBzcGFuSXNTZW50cnlTcGFuKHNwYW4pIHtcbiAgcmV0dXJuIHR5cGVvZiAoc3BhbiApLmdldFNwYW5KU09OID09PSAnZnVuY3Rpb24nO1xufVxuXG4vKipcbiAqIFJldHVybnMgdHJ1ZSBpZiBhIHNwYW4gaXMgc2FtcGxlZC5cbiAqIEluIG1vc3QgY2FzZXMsIHlvdSBzaG91bGQganVzdCB1c2UgYHNwYW4uaXNSZWNvcmRpbmcoKWAgaW5zdGVhZC5cbiAqIEhvd2V2ZXIsIHRoaXMgaGFzIGEgc2xpZ2h0bHkgZGlmZmVyZW50IHNlbWFudGljLCBhcyBpdCBhbHNvIHJldHVybnMgZmFsc2UgaWYgdGhlIHNwYW4gaXMgZmluaXNoZWQuXG4gKiBTbyBpbiB0aGUgY2FzZSB3aGVyZSB0aGlzIGRpc3RpbmN0aW9uIGlzIGltcG9ydGFudCwgdXNlIHRoaXMgbWV0aG9kLlxuICovXG5mdW5jdGlvbiBzcGFuSXNTYW1wbGVkKHNwYW4pIHtcbiAgLy8gV2UgYWxpZ24gb3VyIHRyYWNlIGZsYWdzIHdpdGggdGhlIG9uZXMgT3BlblRlbGVtZXRyeSB1c2VcbiAgLy8gU28gd2UgYWxzbyBjaGVjayBmb3Igc2FtcGxlZCB0aGUgc2FtZSB3YXkgdGhleSBkby5cbiAgY29uc3QgeyB0cmFjZUZsYWdzIH0gPSBzcGFuLnNwYW5Db250ZXh0KCk7XG4gIHJldHVybiB0cmFjZUZsYWdzID09PSBUUkFDRV9GTEFHX1NBTVBMRUQ7XG59XG5cbi8qKiBHZXQgdGhlIHN0YXR1cyBtZXNzYWdlIHRvIHVzZSBmb3IgYSBKU09OIHJlcHJlc2VudGF0aW9uIG9mIGEgc3Bhbi4gKi9cbmZ1bmN0aW9uIGdldFN0YXR1c01lc3NhZ2Uoc3RhdHVzKSB7XG4gIGlmICghc3RhdHVzIHx8IHN0YXR1cy5jb2RlID09PSBzcGFuc3RhdHVzLlNQQU5fU1RBVFVTX1VOU0VUKSB7XG4gICAgcmV0dXJuIHVuZGVmaW5lZDtcbiAgfVxuXG4gIGlmIChzdGF0dXMuY29kZSA9PT0gc3BhbnN0YXR1cy5TUEFOX1NUQVRVU19PSykge1xuICAgIHJldHVybiAnb2snO1xuICB9XG5cbiAgcmV0dXJuIHN0YXR1cy5tZXNzYWdlIHx8ICd1bmtub3duX2Vycm9yJztcbn1cblxuY29uc3QgQ0hJTERfU1BBTlNfRklFTEQgPSAnX3NlbnRyeUNoaWxkU3BhbnMnO1xuY29uc3QgUk9PVF9TUEFOX0ZJRUxEID0gJ19zZW50cnlSb290U3Bhbic7XG5cbi8qKlxuICogQWRkcyBhbiBvcGFxdWUgY2hpbGQgc3BhbiByZWZlcmVuY2UgdG8gYSBzcGFuLlxuICovXG5mdW5jdGlvbiBhZGRDaGlsZFNwYW5Ub1NwYW4oc3BhbiwgY2hpbGRTcGFuKSB7XG4gIC8vIFdlIHN0b3JlIHRoZSByb290IHNwYW4gcmVmZXJlbmNlIG9uIHRoZSBjaGlsZCBzcGFuXG4gIC8vIFdlIG5lZWQgdGhpcyBmb3IgYGdldFJvb3RTcGFuKClgIHRvIHdvcmtcbiAgY29uc3Qgcm9vdFNwYW4gPSBzcGFuW1JPT1RfU1BBTl9GSUVMRF0gfHwgc3BhbjtcbiAgb2JqZWN0LmFkZE5vbkVudW1lcmFibGVQcm9wZXJ0eShjaGlsZFNwYW4gLCBST09UX1NQQU5fRklFTEQsIHJvb3RTcGFuKTtcblxuICAvLyBXZSBzdG9yZSBhIGxpc3Qgb2YgY2hpbGQgc3BhbnMgb24gdGhlIHBhcmVudCBzcGFuXG4gIC8vIFdlIG5lZWQgdGhpcyBmb3IgYGdldFNwYW5EZXNjZW5kYW50cygpYCB0byB3b3JrXG4gIGlmIChzcGFuW0NISUxEX1NQQU5TX0ZJRUxEXSkge1xuICAgIHNwYW5bQ0hJTERfU1BBTlNfRklFTERdLmFkZChjaGlsZFNwYW4pO1xuICB9IGVsc2Uge1xuICAgIG9iamVjdC5hZGROb25FbnVtZXJhYmxlUHJvcGVydHkoc3BhbiwgQ0hJTERfU1BBTlNfRklFTEQsIG5ldyBTZXQoW2NoaWxkU3Bhbl0pKTtcbiAgfVxufVxuXG4vKiogVGhpcyBpcyBvbmx5IHVzZWQgaW50ZXJuYWxseSBieSBJZGxlIFNwYW5zLiAqL1xuZnVuY3Rpb24gcmVtb3ZlQ2hpbGRTcGFuRnJvbVNwYW4oc3BhbiwgY2hpbGRTcGFuKSB7XG4gIGlmIChzcGFuW0NISUxEX1NQQU5TX0ZJRUxEXSkge1xuICAgIHNwYW5bQ0hJTERfU1BBTlNfRklFTERdLmRlbGV0ZShjaGlsZFNwYW4pO1xuICB9XG59XG5cbi8qKlxuICogUmV0dXJucyBhbiBhcnJheSBvZiB0aGUgZ2l2ZW4gc3BhbiBhbmQgYWxsIG9mIGl0cyBkZXNjZW5kYW50cy5cbiAqL1xuZnVuY3Rpb24gZ2V0U3BhbkRlc2NlbmRhbnRzKHNwYW4pIHtcbiAgY29uc3QgcmVzdWx0U2V0ID0gbmV3IFNldCgpO1xuXG4gIGZ1bmN0aW9uIGFkZFNwYW5DaGlsZHJlbihzcGFuKSB7XG4gICAgLy8gVGhpcyBleGl0IGNvbmRpdGlvbiBpcyByZXF1aXJlZCB0byBub3QgaW5maW5pdGVseSBsb29wIGluIGNhc2Ugb2YgYSBjaXJjdWxhciBkZXBlbmRlbmN5LlxuICAgIGlmIChyZXN1bHRTZXQuaGFzKHNwYW4pKSB7XG4gICAgICByZXR1cm47XG4gICAgICAvLyBXZSB3YW50IHRvIGlnbm9yZSB1bnNhbXBsZWQgc3BhbnMgKGUuZy4gbm9uIHJlY29yZGluZyBzcGFucylcbiAgICB9IGVsc2UgaWYgKHNwYW5Jc1NhbXBsZWQoc3BhbikpIHtcbiAgICAgIHJlc3VsdFNldC5hZGQoc3Bhbik7XG4gICAgICBjb25zdCBjaGlsZFNwYW5zID0gc3BhbltDSElMRF9TUEFOU19GSUVMRF0gPyBBcnJheS5mcm9tKHNwYW5bQ0hJTERfU1BBTlNfRklFTERdKSA6IFtdO1xuICAgICAgZm9yIChjb25zdCBjaGlsZFNwYW4gb2YgY2hpbGRTcGFucykge1xuICAgICAgICBhZGRTcGFuQ2hpbGRyZW4oY2hpbGRTcGFuKTtcbiAgICAgIH1cbiAgICB9XG4gIH1cblxuICBhZGRTcGFuQ2hpbGRyZW4oc3Bhbik7XG5cbiAgcmV0dXJuIEFycmF5LmZyb20ocmVzdWx0U2V0KTtcbn1cblxuLyoqXG4gKiBSZXR1cm5zIHRoZSByb290IHNwYW4gb2YgYSBnaXZlbiBzcGFuLlxuICovXG5mdW5jdGlvbiBnZXRSb290U3BhbihzcGFuKSB7XG4gIHJldHVybiBzcGFuW1JPT1RfU1BBTl9GSUVMRF0gfHwgc3Bhbjtcbn1cblxuLyoqXG4gKiBSZXR1cm5zIHRoZSBjdXJyZW50bHkgYWN0aXZlIHNwYW4uXG4gKi9cbmZ1bmN0aW9uIGdldEFjdGl2ZVNwYW4oKSB7XG4gIGNvbnN0IGNhcnJpZXIkMSA9IGNhcnJpZXIuZ2V0TWFpbkNhcnJpZXIoKTtcbiAgY29uc3QgYWNzID0gaW5kZXguZ2V0QXN5bmNDb250ZXh0U3RyYXRlZ3koY2FycmllciQxKTtcbiAgaWYgKGFjcy5nZXRBY3RpdmVTcGFuKSB7XG4gICAgcmV0dXJuIGFjcy5nZXRBY3RpdmVTcGFuKCk7XG4gIH1cblxuICByZXR1cm4gc3Bhbk9uU2NvcGUuX2dldFNwYW5Gb3JTY29wZShjdXJyZW50U2NvcGVzLmdldEN1cnJlbnRTY29wZSgpKTtcbn1cblxuLyoqXG4gKiBMb2dzIGEgd2FybmluZyBvbmNlIGlmIGBiZWZvcmVTZW5kU3BhbmAgaXMgdXNlZCB0byBkcm9wIHNwYW5zLlxuICovXG5mdW5jdGlvbiBzaG93U3BhbkRyb3BXYXJuaW5nKCkge1xuICBpZiAoIWhhc1Nob3duU3BhbkRyb3BXYXJuaW5nKSB7XG4gICAgZGVidWdMb2dnZXIuY29uc29sZVNhbmRib3goKCkgPT4ge1xuICAgICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIG5vLWNvbnNvbGVcbiAgICAgIGNvbnNvbGUud2FybihcbiAgICAgICAgJ1tTZW50cnldIFJldHVybmluZyBudWxsIGZyb20gYGJlZm9yZVNlbmRTcGFuYCBpcyBkaXNhbGxvd2VkLiBUbyBkcm9wIGNlcnRhaW4gc3BhbnMsIGNvbmZpZ3VyZSB0aGUgcmVzcGVjdGl2ZSBpbnRlZ3JhdGlvbnMgZGlyZWN0bHkuJyxcbiAgICAgICk7XG4gICAgfSk7XG4gICAgaGFzU2hvd25TcGFuRHJvcFdhcm5pbmcgPSB0cnVlO1xuICB9XG59XG5cbi8qKlxuICogVXBkYXRlcyB0aGUgbmFtZSBvZiB0aGUgZ2l2ZW4gc3BhbiBhbmQgZW5zdXJlcyB0aGF0IHRoZSBzcGFuIG5hbWUgaXMgbm90XG4gKiBvdmVyd3JpdHRlbiBieSB0aGUgU2VudHJ5IFNESy5cbiAqXG4gKiBVc2UgdGhpcyBmdW5jdGlvbiBpbnN0ZWFkIG9mIGBzcGFuLnVwZGF0ZU5hbWUoKWAgaWYgeW91IHdhbnQgdG8gbWFrZSBzdXJlIHRoYXRcbiAqIHlvdXIgbmFtZSBpcyBrZXB0LiBGb3Igc29tZSBzcGFucywgZm9yIGV4YW1wbGUgcm9vdCBgaHR0cC5zZXJ2ZXJgIHNwYW5zIHRoZVxuICogU2VudHJ5IFNESyB3b3VsZCBvdGhlcndpc2Ugb3ZlcndyaXRlIHRoZSBzcGFuIG5hbWUgd2l0aCBhIGhpZ2gtcXVhbGl0eSBuYW1lXG4gKiBpdCBpbmZlcnMgd2hlbiB0aGUgc3BhbiBlbmRzLlxuICpcbiAqIFVzZSB0aGlzIGZ1bmN0aW9uIGluIHNlcnZlciBjb2RlIG9yIHdoZW4geW91ciBzcGFuIGlzIHN0YXJ0ZWQgb24gdGhlIHNlcnZlclxuICogYW5kIG9uIHRoZSBjbGllbnQgKGJyb3dzZXIpLiBJZiB5b3Ugb25seSB1cGRhdGUgYSBzcGFuIG5hbWUgb24gdGhlIGNsaWVudCxcbiAqIHlvdSBjYW4gYWxzbyB1c2UgYHNwYW4udXBkYXRlTmFtZSgpYCB0aGUgU0RLIGRvZXMgbm90IG92ZXJ3cml0ZSB0aGUgbmFtZS5cbiAqXG4gKiBAcGFyYW0gc3BhbiAtIFRoZSBzcGFuIHRvIHVwZGF0ZSB0aGUgbmFtZSBvZi5cbiAqIEBwYXJhbSBuYW1lIC0gVGhlIG5hbWUgdG8gc2V0IG9uIHRoZSBzcGFuLlxuICovXG5mdW5jdGlvbiB1cGRhdGVTcGFuTmFtZShzcGFuLCBuYW1lKSB7XG4gIHNwYW4udXBkYXRlTmFtZShuYW1lKTtcbiAgc3Bhbi5zZXRBdHRyaWJ1dGVzKHtcbiAgICBbc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfU09VUkNFXTogJ2N1c3RvbScsXG4gICAgW3NlbWFudGljQXR0cmlidXRlcy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX0NVU1RPTV9TUEFOX05BTUVdOiBuYW1lLFxuICB9KTtcbn1cblxuZXhwb3J0cy5UUkFDRV9GTEFHX05PTkUgPSBUUkFDRV9GTEFHX05PTkU7XG5leHBvcnRzLlRSQUNFX0ZMQUdfU0FNUExFRCA9IFRSQUNFX0ZMQUdfU0FNUExFRDtcbmV4cG9ydHMuYWRkQ2hpbGRTcGFuVG9TcGFuID0gYWRkQ2hpbGRTcGFuVG9TcGFuO1xuZXhwb3J0cy5jb252ZXJ0U3BhbkxpbmtzRm9yRW52ZWxvcGUgPSBjb252ZXJ0U3BhbkxpbmtzRm9yRW52ZWxvcGU7XG5leHBvcnRzLmdldEFjdGl2ZVNwYW4gPSBnZXRBY3RpdmVTcGFuO1xuZXhwb3J0cy5nZXRSb290U3BhbiA9IGdldFJvb3RTcGFuO1xuZXhwb3J0cy5nZXRTcGFuRGVzY2VuZGFudHMgPSBnZXRTcGFuRGVzY2VuZGFudHM7XG5leHBvcnRzLmdldFN0YXR1c01lc3NhZ2UgPSBnZXRTdGF0dXNNZXNzYWdlO1xuZXhwb3J0cy5yZW1vdmVDaGlsZFNwYW5Gcm9tU3BhbiA9IHJlbW92ZUNoaWxkU3BhbkZyb21TcGFuO1xuZXhwb3J0cy5zaG93U3BhbkRyb3BXYXJuaW5nID0gc2hvd1NwYW5Ecm9wV2FybmluZztcbmV4cG9ydHMuc3BhbklzU2FtcGxlZCA9IHNwYW5Jc1NhbXBsZWQ7XG5leHBvcnRzLnNwYW5UaW1lSW5wdXRUb1NlY29uZHMgPSBzcGFuVGltZUlucHV0VG9TZWNvbmRzO1xuZXhwb3J0cy5zcGFuVG9KU09OID0gc3BhblRvSlNPTjtcbmV4cG9ydHMuc3BhblRvVHJhY2VDb250ZXh0ID0gc3BhblRvVHJhY2VDb250ZXh0O1xuZXhwb3J0cy5zcGFuVG9UcmFjZUhlYWRlciA9IHNwYW5Ub1RyYWNlSGVhZGVyO1xuZXhwb3J0cy5zcGFuVG9UcmFuc2FjdGlvblRyYWNlQ29udGV4dCA9IHNwYW5Ub1RyYW5zYWN0aW9uVHJhY2VDb250ZXh0O1xuZXhwb3J0cy51cGRhdGVTcGFuTmFtZSA9IHVwZGF0ZVNwYW5OYW1lO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9c3BhblV0aWxzLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanUtils.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/stacktrace.js":
/*!********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/stacktrace.js ***!
  \********************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst STACKTRACE_FRAME_LIMIT = 50;\nconst UNKNOWN_FUNCTION = '?';\n// Used to sanitize webpack (error: *) wrapped stack errors\nconst WEBPACK_ERROR_REGEXP = /\\(error: (.*)\\)/;\nconst STRIP_FRAME_REGEXP = /captureMessage|captureException/;\n\n/**\n * Creates a stack parser with the supplied line parsers\n *\n * StackFrames are returned in the correct order for Sentry Exception\n * frames and with Sentry SDK internal frames removed from the top and bottom\n *\n */\nfunction createStackParser(...parsers) {\n  const sortedParsers = parsers.sort((a, b) => a[0] - b[0]).map(p => p[1]);\n\n  return (stack, skipFirstLines = 0, framesToPop = 0) => {\n    const frames = [];\n    const lines = stack.split('\\n');\n\n    for (let i = skipFirstLines; i < lines.length; i++) {\n      const line = lines[i] ;\n      // Ignore lines over 1kb as they are unlikely to be stack frames.\n      // Many of the regular expressions use backtracking which results in run time that increases exponentially with\n      // input size. Huge strings can result in hangs/Denial of Service:\n      // https://github.com/getsentry/sentry-javascript/issues/2286\n      if (line.length > 1024) {\n        continue;\n      }\n\n      // https://github.com/getsentry/sentry-javascript/issues/5459\n      // Remove webpack (error: *) wrappers\n      const cleanedLine = WEBPACK_ERROR_REGEXP.test(line) ? line.replace(WEBPACK_ERROR_REGEXP, '$1') : line;\n\n      // https://github.com/getsentry/sentry-javascript/issues/7813\n      // Skip Error: lines\n      if (cleanedLine.match(/\\S*Error: /)) {\n        continue;\n      }\n\n      for (const parser of sortedParsers) {\n        const frame = parser(cleanedLine);\n\n        if (frame) {\n          frames.push(frame);\n          break;\n        }\n      }\n\n      if (frames.length >= STACKTRACE_FRAME_LIMIT + framesToPop) {\n        break;\n      }\n    }\n\n    return stripSentryFramesAndReverse(frames.slice(framesToPop));\n  };\n}\n\n/**\n * Gets a stack parser implementation from Options.stackParser\n * @see Options\n *\n * If options contains an array of line parsers, it is converted into a parser\n */\nfunction stackParserFromStackParserOptions(stackParser) {\n  if (Array.isArray(stackParser)) {\n    return createStackParser(...stackParser);\n  }\n  return stackParser;\n}\n\n/**\n * Removes Sentry frames from the top and bottom of the stack if present and enforces a limit of max number of frames.\n * Assumes stack input is ordered from top to bottom and returns the reverse representation so call site of the\n * function that caused the crash is the last frame in the array.\n * @hidden\n */\nfunction stripSentryFramesAndReverse(stack) {\n  if (!stack.length) {\n    return [];\n  }\n\n  const localStack = Array.from(stack);\n\n  // If stack starts with one of our API calls, remove it (starts, meaning it's the top of the stack - aka last call)\n  if (/sentryWrapped/.test(getLastStackFrame(localStack).function || '')) {\n    localStack.pop();\n  }\n\n  // Reversing in the middle of the procedure allows us to just pop the values off the stack\n  localStack.reverse();\n\n  // If stack ends with one of our internal API calls, remove it (ends, meaning it's the bottom of the stack - aka top-most call)\n  if (STRIP_FRAME_REGEXP.test(getLastStackFrame(localStack).function || '')) {\n    localStack.pop();\n\n    // When using synthetic events, we will have a 2 levels deep stack, as `new Error('Sentry syntheticException')`\n    // is produced within the scope itself, making it:\n    //\n    //   Sentry.captureException()\n    //   scope.captureException()\n    //\n    // instead of just the top `Sentry` call itself.\n    // This forces us to possibly strip an additional frame in the exact same was as above.\n    if (STRIP_FRAME_REGEXP.test(getLastStackFrame(localStack).function || '')) {\n      localStack.pop();\n    }\n  }\n\n  return localStack.slice(0, STACKTRACE_FRAME_LIMIT).map(frame => ({\n    ...frame,\n    filename: frame.filename || getLastStackFrame(localStack).filename,\n    function: frame.function || UNKNOWN_FUNCTION,\n  }));\n}\n\nfunction getLastStackFrame(arr) {\n  return arr[arr.length - 1] || {};\n}\n\nconst defaultFunctionName = '<anonymous>';\n\n/**\n * Safely extract function name from itself\n */\nfunction getFunctionName(fn) {\n  try {\n    if (!fn || typeof fn !== 'function') {\n      return defaultFunctionName;\n    }\n    return fn.name || defaultFunctionName;\n  } catch {\n    // Just accessing custom props in some Selenium environments\n    // can cause a \"Permission denied\" exception (see raven-js#495).\n    return defaultFunctionName;\n  }\n}\n\n/**\n * Get's stack frames from an event without needing to check for undefined properties.\n */\nfunction getFramesFromEvent(event) {\n  const exception = event.exception;\n\n  if (exception) {\n    const frames = [];\n    try {\n      // @ts-expect-error Object could be undefined\n      exception.values.forEach(value => {\n        // @ts-expect-error Value could be undefined\n        if (value.stacktrace.frames) {\n          // @ts-expect-error Value could be undefined\n          frames.push(...value.stacktrace.frames);\n        }\n      });\n      return frames;\n    } catch {\n      return undefined;\n    }\n  }\n  return undefined;\n}\n\nexports.UNKNOWN_FUNCTION = UNKNOWN_FUNCTION;\nexports.createStackParser = createStackParser;\nexports.getFramesFromEvent = getFramesFromEvent;\nexports.getFunctionName = getFunctionName;\nexports.stackParserFromStackParserOptions = stackParserFromStackParserOptions;\nexports.stripSentryFramesAndReverse = stripSentryFramesAndReverse;\n//# sourceMappingURL=stacktrace.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9zdGFja3RyYWNlLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQSxpQ0FBaUMsa0JBQWtCO0FBQ25EO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsR0FBRztBQUNIOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxJQUFJO0FBQ0o7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsT0FBTztBQUNQO0FBQ0EsTUFBTTtBQUNOO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsd0JBQXdCO0FBQ3hCLHlCQUF5QjtBQUN6QiwwQkFBMEI7QUFDMUIsdUJBQXVCO0FBQ3ZCLHlDQUF5QztBQUN6QyxtQ0FBbUM7QUFDbkMiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9zdGFja3RyYWNlLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBTVEFDS1RSQUNFX0ZSQU1FX0xJTUlUID0gNTA7XG5jb25zdCBVTktOT1dOX0ZVTkNUSU9OID0gJz8nO1xuLy8gVXNlZCB0byBzYW5pdGl6ZSB3ZWJwYWNrIChlcnJvcjogKikgd3JhcHBlZCBzdGFjayBlcnJvcnNcbmNvbnN0IFdFQlBBQ0tfRVJST1JfUkVHRVhQID0gL1xcKGVycm9yOiAoLiopXFwpLztcbmNvbnN0IFNUUklQX0ZSQU1FX1JFR0VYUCA9IC9jYXB0dXJlTWVzc2FnZXxjYXB0dXJlRXhjZXB0aW9uLztcblxuLyoqXG4gKiBDcmVhdGVzIGEgc3RhY2sgcGFyc2VyIHdpdGggdGhlIHN1cHBsaWVkIGxpbmUgcGFyc2Vyc1xuICpcbiAqIFN0YWNrRnJhbWVzIGFyZSByZXR1cm5lZCBpbiB0aGUgY29ycmVjdCBvcmRlciBmb3IgU2VudHJ5IEV4Y2VwdGlvblxuICogZnJhbWVzIGFuZCB3aXRoIFNlbnRyeSBTREsgaW50ZXJuYWwgZnJhbWVzIHJlbW92ZWQgZnJvbSB0aGUgdG9wIGFuZCBib3R0b21cbiAqXG4gKi9cbmZ1bmN0aW9uIGNyZWF0ZVN0YWNrUGFyc2VyKC4uLnBhcnNlcnMpIHtcbiAgY29uc3Qgc29ydGVkUGFyc2VycyA9IHBhcnNlcnMuc29ydCgoYSwgYikgPT4gYVswXSAtIGJbMF0pLm1hcChwID0+IHBbMV0pO1xuXG4gIHJldHVybiAoc3RhY2ssIHNraXBGaXJzdExpbmVzID0gMCwgZnJhbWVzVG9Qb3AgPSAwKSA9PiB7XG4gICAgY29uc3QgZnJhbWVzID0gW107XG4gICAgY29uc3QgbGluZXMgPSBzdGFjay5zcGxpdCgnXFxuJyk7XG5cbiAgICBmb3IgKGxldCBpID0gc2tpcEZpcnN0TGluZXM7IGkgPCBsaW5lcy5sZW5ndGg7IGkrKykge1xuICAgICAgY29uc3QgbGluZSA9IGxpbmVzW2ldIDtcbiAgICAgIC8vIElnbm9yZSBsaW5lcyBvdmVyIDFrYiBhcyB0aGV5IGFyZSB1bmxpa2VseSB0byBiZSBzdGFjayBmcmFtZXMuXG4gICAgICAvLyBNYW55IG9mIHRoZSByZWd1bGFyIGV4cHJlc3Npb25zIHVzZSBiYWNrdHJhY2tpbmcgd2hpY2ggcmVzdWx0cyBpbiBydW4gdGltZSB0aGF0IGluY3JlYXNlcyBleHBvbmVudGlhbGx5IHdpdGhcbiAgICAgIC8vIGlucHV0IHNpemUuIEh1Z2Ugc3RyaW5ncyBjYW4gcmVzdWx0IGluIGhhbmdzL0RlbmlhbCBvZiBTZXJ2aWNlOlxuICAgICAgLy8gaHR0cHM6Ly9naXRodWIuY29tL2dldHNlbnRyeS9zZW50cnktamF2YXNjcmlwdC9pc3N1ZXMvMjI4NlxuICAgICAgaWYgKGxpbmUubGVuZ3RoID4gMTAyNCkge1xuICAgICAgICBjb250aW51ZTtcbiAgICAgIH1cblxuICAgICAgLy8gaHR0cHM6Ly9naXRodWIuY29tL2dldHNlbnRyeS9zZW50cnktamF2YXNjcmlwdC9pc3N1ZXMvNTQ1OVxuICAgICAgLy8gUmVtb3ZlIHdlYnBhY2sgKGVycm9yOiAqKSB3cmFwcGVyc1xuICAgICAgY29uc3QgY2xlYW5lZExpbmUgPSBXRUJQQUNLX0VSUk9SX1JFR0VYUC50ZXN0KGxpbmUpID8gbGluZS5yZXBsYWNlKFdFQlBBQ0tfRVJST1JfUkVHRVhQLCAnJDEnKSA6IGxpbmU7XG5cbiAgICAgIC8vIGh0dHBzOi8vZ2l0aHViLmNvbS9nZXRzZW50cnkvc2VudHJ5LWphdmFzY3JpcHQvaXNzdWVzLzc4MTNcbiAgICAgIC8vIFNraXAgRXJyb3I6IGxpbmVzXG4gICAgICBpZiAoY2xlYW5lZExpbmUubWF0Y2goL1xcUypFcnJvcjogLykpIHtcbiAgICAgICAgY29udGludWU7XG4gICAgICB9XG5cbiAgICAgIGZvciAoY29uc3QgcGFyc2VyIG9mIHNvcnRlZFBhcnNlcnMpIHtcbiAgICAgICAgY29uc3QgZnJhbWUgPSBwYXJzZXIoY2xlYW5lZExpbmUpO1xuXG4gICAgICAgIGlmIChmcmFtZSkge1xuICAgICAgICAgIGZyYW1lcy5wdXNoKGZyYW1lKTtcbiAgICAgICAgICBicmVhaztcbiAgICAgICAgfVxuICAgICAgfVxuXG4gICAgICBpZiAoZnJhbWVzLmxlbmd0aCA+PSBTVEFDS1RSQUNFX0ZSQU1FX0xJTUlUICsgZnJhbWVzVG9Qb3ApIHtcbiAgICAgICAgYnJlYWs7XG4gICAgICB9XG4gICAgfVxuXG4gICAgcmV0dXJuIHN0cmlwU2VudHJ5RnJhbWVzQW5kUmV2ZXJzZShmcmFtZXMuc2xpY2UoZnJhbWVzVG9Qb3ApKTtcbiAgfTtcbn1cblxuLyoqXG4gKiBHZXRzIGEgc3RhY2sgcGFyc2VyIGltcGxlbWVudGF0aW9uIGZyb20gT3B0aW9ucy5zdGFja1BhcnNlclxuICogQHNlZSBPcHRpb25zXG4gKlxuICogSWYgb3B0aW9ucyBjb250YWlucyBhbiBhcnJheSBvZiBsaW5lIHBhcnNlcnMsIGl0IGlzIGNvbnZlcnRlZCBpbnRvIGEgcGFyc2VyXG4gKi9cbmZ1bmN0aW9uIHN0YWNrUGFyc2VyRnJvbVN0YWNrUGFyc2VyT3B0aW9ucyhzdGFja1BhcnNlcikge1xuICBpZiAoQXJyYXkuaXNBcnJheShzdGFja1BhcnNlcikpIHtcbiAgICByZXR1cm4gY3JlYXRlU3RhY2tQYXJzZXIoLi4uc3RhY2tQYXJzZXIpO1xuICB9XG4gIHJldHVybiBzdGFja1BhcnNlcjtcbn1cblxuLyoqXG4gKiBSZW1vdmVzIFNlbnRyeSBmcmFtZXMgZnJvbSB0aGUgdG9wIGFuZCBib3R0b20gb2YgdGhlIHN0YWNrIGlmIHByZXNlbnQgYW5kIGVuZm9yY2VzIGEgbGltaXQgb2YgbWF4IG51bWJlciBvZiBmcmFtZXMuXG4gKiBBc3N1bWVzIHN0YWNrIGlucHV0IGlzIG9yZGVyZWQgZnJvbSB0b3AgdG8gYm90dG9tIGFuZCByZXR1cm5zIHRoZSByZXZlcnNlIHJlcHJlc2VudGF0aW9uIHNvIGNhbGwgc2l0ZSBvZiB0aGVcbiAqIGZ1bmN0aW9uIHRoYXQgY2F1c2VkIHRoZSBjcmFzaCBpcyB0aGUgbGFzdCBmcmFtZSBpbiB0aGUgYXJyYXkuXG4gKiBAaGlkZGVuXG4gKi9cbmZ1bmN0aW9uIHN0cmlwU2VudHJ5RnJhbWVzQW5kUmV2ZXJzZShzdGFjaykge1xuICBpZiAoIXN0YWNrLmxlbmd0aCkge1xuICAgIHJldHVybiBbXTtcbiAgfVxuXG4gIGNvbnN0IGxvY2FsU3RhY2sgPSBBcnJheS5mcm9tKHN0YWNrKTtcblxuICAvLyBJZiBzdGFjayBzdGFydHMgd2l0aCBvbmUgb2Ygb3VyIEFQSSBjYWxscywgcmVtb3ZlIGl0IChzdGFydHMsIG1lYW5pbmcgaXQncyB0aGUgdG9wIG9mIHRoZSBzdGFjayAtIGFrYSBsYXN0IGNhbGwpXG4gIGlmICgvc2VudHJ5V3JhcHBlZC8udGVzdChnZXRMYXN0U3RhY2tGcmFtZShsb2NhbFN0YWNrKS5mdW5jdGlvbiB8fCAnJykpIHtcbiAgICBsb2NhbFN0YWNrLnBvcCgpO1xuICB9XG5cbiAgLy8gUmV2ZXJzaW5nIGluIHRoZSBtaWRkbGUgb2YgdGhlIHByb2NlZHVyZSBhbGxvd3MgdXMgdG8ganVzdCBwb3AgdGhlIHZhbHVlcyBvZmYgdGhlIHN0YWNrXG4gIGxvY2FsU3RhY2sucmV2ZXJzZSgpO1xuXG4gIC8vIElmIHN0YWNrIGVuZHMgd2l0aCBvbmUgb2Ygb3VyIGludGVybmFsIEFQSSBjYWxscywgcmVtb3ZlIGl0IChlbmRzLCBtZWFuaW5nIGl0J3MgdGhlIGJvdHRvbSBvZiB0aGUgc3RhY2sgLSBha2EgdG9wLW1vc3QgY2FsbClcbiAgaWYgKFNUUklQX0ZSQU1FX1JFR0VYUC50ZXN0KGdldExhc3RTdGFja0ZyYW1lKGxvY2FsU3RhY2spLmZ1bmN0aW9uIHx8ICcnKSkge1xuICAgIGxvY2FsU3RhY2sucG9wKCk7XG5cbiAgICAvLyBXaGVuIHVzaW5nIHN5bnRoZXRpYyBldmVudHMsIHdlIHdpbGwgaGF2ZSBhIDIgbGV2ZWxzIGRlZXAgc3RhY2ssIGFzIGBuZXcgRXJyb3IoJ1NlbnRyeSBzeW50aGV0aWNFeGNlcHRpb24nKWBcbiAgICAvLyBpcyBwcm9kdWNlZCB3aXRoaW4gdGhlIHNjb3BlIGl0c2VsZiwgbWFraW5nIGl0OlxuICAgIC8vXG4gICAgLy8gICBTZW50cnkuY2FwdHVyZUV4Y2VwdGlvbigpXG4gICAgLy8gICBzY29wZS5jYXB0dXJlRXhjZXB0aW9uKClcbiAgICAvL1xuICAgIC8vIGluc3RlYWQgb2YganVzdCB0aGUgdG9wIGBTZW50cnlgIGNhbGwgaXRzZWxmLlxuICAgIC8vIFRoaXMgZm9yY2VzIHVzIHRvIHBvc3NpYmx5IHN0cmlwIGFuIGFkZGl0aW9uYWwgZnJhbWUgaW4gdGhlIGV4YWN0IHNhbWUgd2FzIGFzIGFib3ZlLlxuICAgIGlmIChTVFJJUF9GUkFNRV9SRUdFWFAudGVzdChnZXRMYXN0U3RhY2tGcmFtZShsb2NhbFN0YWNrKS5mdW5jdGlvbiB8fCAnJykpIHtcbiAgICAgIGxvY2FsU3RhY2sucG9wKCk7XG4gICAgfVxuICB9XG5cbiAgcmV0dXJuIGxvY2FsU3RhY2suc2xpY2UoMCwgU1RBQ0tUUkFDRV9GUkFNRV9MSU1JVCkubWFwKGZyYW1lID0+ICh7XG4gICAgLi4uZnJhbWUsXG4gICAgZmlsZW5hbWU6IGZyYW1lLmZpbGVuYW1lIHx8IGdldExhc3RTdGFja0ZyYW1lKGxvY2FsU3RhY2spLmZpbGVuYW1lLFxuICAgIGZ1bmN0aW9uOiBmcmFtZS5mdW5jdGlvbiB8fCBVTktOT1dOX0ZVTkNUSU9OLFxuICB9KSk7XG59XG5cbmZ1bmN0aW9uIGdldExhc3RTdGFja0ZyYW1lKGFycikge1xuICByZXR1cm4gYXJyW2Fyci5sZW5ndGggLSAxXSB8fCB7fTtcbn1cblxuY29uc3QgZGVmYXVsdEZ1bmN0aW9uTmFtZSA9ICc8YW5vbnltb3VzPic7XG5cbi8qKlxuICogU2FmZWx5IGV4dHJhY3QgZnVuY3Rpb24gbmFtZSBmcm9tIGl0c2VsZlxuICovXG5mdW5jdGlvbiBnZXRGdW5jdGlvbk5hbWUoZm4pIHtcbiAgdHJ5IHtcbiAgICBpZiAoIWZuIHx8IHR5cGVvZiBmbiAhPT0gJ2Z1bmN0aW9uJykge1xuICAgICAgcmV0dXJuIGRlZmF1bHRGdW5jdGlvbk5hbWU7XG4gICAgfVxuICAgIHJldHVybiBmbi5uYW1lIHx8IGRlZmF1bHRGdW5jdGlvbk5hbWU7XG4gIH0gY2F0Y2gge1xuICAgIC8vIEp1c3QgYWNjZXNzaW5nIGN1c3RvbSBwcm9wcyBpbiBzb21lIFNlbGVuaXVtIGVudmlyb25tZW50c1xuICAgIC8vIGNhbiBjYXVzZSBhIFwiUGVybWlzc2lvbiBkZW5pZWRcIiBleGNlcHRpb24gKHNlZSByYXZlbi1qcyM0OTUpLlxuICAgIHJldHVybiBkZWZhdWx0RnVuY3Rpb25OYW1lO1xuICB9XG59XG5cbi8qKlxuICogR2V0J3Mgc3RhY2sgZnJhbWVzIGZyb20gYW4gZXZlbnQgd2l0aG91dCBuZWVkaW5nIHRvIGNoZWNrIGZvciB1bmRlZmluZWQgcHJvcGVydGllcy5cbiAqL1xuZnVuY3Rpb24gZ2V0RnJhbWVzRnJvbUV2ZW50KGV2ZW50KSB7XG4gIGNvbnN0IGV4Y2VwdGlvbiA9IGV2ZW50LmV4Y2VwdGlvbjtcblxuICBpZiAoZXhjZXB0aW9uKSB7XG4gICAgY29uc3QgZnJhbWVzID0gW107XG4gICAgdHJ5IHtcbiAgICAgIC8vIEB0cy1leHBlY3QtZXJyb3IgT2JqZWN0IGNvdWxkIGJlIHVuZGVmaW5lZFxuICAgICAgZXhjZXB0aW9uLnZhbHVlcy5mb3JFYWNoKHZhbHVlID0+IHtcbiAgICAgICAgLy8gQHRzLWV4cGVjdC1lcnJvciBWYWx1ZSBjb3VsZCBiZSB1bmRlZmluZWRcbiAgICAgICAgaWYgKHZhbHVlLnN0YWNrdHJhY2UuZnJhbWVzKSB7XG4gICAgICAgICAgLy8gQHRzLWV4cGVjdC1lcnJvciBWYWx1ZSBjb3VsZCBiZSB1bmRlZmluZWRcbiAgICAgICAgICBmcmFtZXMucHVzaCguLi52YWx1ZS5zdGFja3RyYWNlLmZyYW1lcyk7XG4gICAgICAgIH1cbiAgICAgIH0pO1xuICAgICAgcmV0dXJuIGZyYW1lcztcbiAgICB9IGNhdGNoIHtcbiAgICAgIHJldHVybiB1bmRlZmluZWQ7XG4gICAgfVxuICB9XG4gIHJldHVybiB1bmRlZmluZWQ7XG59XG5cbmV4cG9ydHMuVU5LTk9XTl9GVU5DVElPTiA9IFVOS05PV05fRlVOQ1RJT047XG5leHBvcnRzLmNyZWF0ZVN0YWNrUGFyc2VyID0gY3JlYXRlU3RhY2tQYXJzZXI7XG5leHBvcnRzLmdldEZyYW1lc0Zyb21FdmVudCA9IGdldEZyYW1lc0Zyb21FdmVudDtcbmV4cG9ydHMuZ2V0RnVuY3Rpb25OYW1lID0gZ2V0RnVuY3Rpb25OYW1lO1xuZXhwb3J0cy5zdGFja1BhcnNlckZyb21TdGFja1BhcnNlck9wdGlvbnMgPSBzdGFja1BhcnNlckZyb21TdGFja1BhcnNlck9wdGlvbnM7XG5leHBvcnRzLnN0cmlwU2VudHJ5RnJhbWVzQW5kUmV2ZXJzZSA9IHN0cmlwU2VudHJ5RnJhbWVzQW5kUmV2ZXJzZTtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPXN0YWNrdHJhY2UuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/stacktrace.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/string.js":
/*!****************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/string.js ***!
  \****************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst is = __webpack_require__(/*! ./is.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js\");\n\n/**\n * Truncates given string to the maximum characters count\n *\n * @param str An object that contains serializable values\n * @param max Maximum number of characters in truncated string (0 = unlimited)\n * @returns string Encoded\n */\nfunction truncate(str, max = 0) {\n  if (typeof str !== 'string' || max === 0) {\n    return str;\n  }\n  return str.length <= max ? str : `${str.slice(0, max)}...`;\n}\n\n/**\n * This is basically just `trim_line` from\n * https://github.com/getsentry/sentry/blob/master/src/sentry/lang/javascript/processor.py#L67\n *\n * @param str An object that contains serializable values\n * @param max Maximum number of characters in truncated string\n * @returns string Encoded\n */\nfunction snipLine(line, colno) {\n  let newLine = line;\n  const lineLength = newLine.length;\n  if (lineLength <= 150) {\n    return newLine;\n  }\n  if (colno > lineLength) {\n    // eslint-disable-next-line no-param-reassign\n    colno = lineLength;\n  }\n\n  let start = Math.max(colno - 60, 0);\n  if (start < 5) {\n    start = 0;\n  }\n\n  let end = Math.min(start + 140, lineLength);\n  if (end > lineLength - 5) {\n    end = lineLength;\n  }\n  if (end === lineLength) {\n    start = Math.max(end - 140, 0);\n  }\n\n  newLine = newLine.slice(start, end);\n  if (start > 0) {\n    newLine = `'{snip} ${newLine}`;\n  }\n  if (end < lineLength) {\n    newLine += ' {snip}';\n  }\n\n  return newLine;\n}\n\n/**\n * Join values in array\n * @param input array of values to be joined together\n * @param delimiter string to be placed in-between values\n * @returns Joined values\n */\nfunction safeJoin(input, delimiter) {\n  if (!Array.isArray(input)) {\n    return '';\n  }\n\n  const output = [];\n  // eslint-disable-next-line @typescript-eslint/prefer-for-of\n  for (let i = 0; i < input.length; i++) {\n    const value = input[i];\n    try {\n      // This is a hack to fix a Vue3-specific bug that causes an infinite loop of\n      // console warnings. This happens when a Vue template is rendered with\n      // an undeclared variable, which we try to stringify, ultimately causing\n      // Vue to issue another warning which repeats indefinitely.\n      // see: https://github.com/getsentry/sentry-javascript/pull/8981\n      if (is.isVueViewModel(value)) {\n        output.push('[VueViewModel]');\n      } else {\n        output.push(String(value));\n      }\n    } catch {\n      output.push('[value cannot be serialized]');\n    }\n  }\n\n  return output.join(delimiter);\n}\n\n/**\n * Checks if the given value matches a regex or string\n *\n * @param value The string to test\n * @param pattern Either a regex or a string against which `value` will be matched\n * @param requireExactStringMatch If true, `value` must match `pattern` exactly. If false, `value` will match\n * `pattern` if it contains `pattern`. Only applies to string-type patterns.\n */\nfunction isMatchingPattern(\n  value,\n  pattern,\n  requireExactStringMatch = false,\n) {\n  if (!is.isString(value)) {\n    return false;\n  }\n\n  if (is.isRegExp(pattern)) {\n    return pattern.test(value);\n  }\n  if (is.isString(pattern)) {\n    return requireExactStringMatch ? value === pattern : value.includes(pattern);\n  }\n\n  return false;\n}\n\n/**\n * Test the given string against an array of strings and regexes. By default, string matching is done on a\n * substring-inclusion basis rather than a strict equality basis\n *\n * @param testString The string to test\n * @param patterns The patterns against which to test the string\n * @param requireExactStringMatch If true, `testString` must match one of the given string patterns exactly in order to\n * count. If false, `testString` will match a string pattern if it contains that pattern.\n * @returns\n */\nfunction stringMatchesSomePattern(\n  testString,\n  patterns = [],\n  requireExactStringMatch = false,\n) {\n  return patterns.some(pattern => isMatchingPattern(testString, pattern, requireExactStringMatch));\n}\n\nexports.isMatchingPattern = isMatchingPattern;\nexports.safeJoin = safeJoin;\nexports.snipLine = snipLine;\nexports.stringMatchesSomePattern = stringMatchesSomePattern;\nexports.truncate = truncate;\n//# sourceMappingURL=string.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9zdHJpbmcuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsV0FBVyxtQkFBTyxDQUFDLCtHQUFTOztBQUU1QjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0Esc0NBQXNDLGtCQUFrQjtBQUN4RDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLGlCQUFpQixNQUFNLEVBQUUsUUFBUTtBQUNqQztBQUNBO0FBQ0Esa0JBQWtCLEtBQUs7QUFDdkI7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0Esa0JBQWtCLGtCQUFrQjtBQUNwQztBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxRQUFRO0FBQ1I7QUFDQTtBQUNBLE1BQU07QUFDTjtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLHlCQUF5QjtBQUN6QixnQkFBZ0I7QUFDaEIsZ0JBQWdCO0FBQ2hCLGdDQUFnQztBQUNoQyxnQkFBZ0I7QUFDaEIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9zdHJpbmcuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGlzID0gcmVxdWlyZSgnLi9pcy5qcycpO1xuXG4vKipcbiAqIFRydW5jYXRlcyBnaXZlbiBzdHJpbmcgdG8gdGhlIG1heGltdW0gY2hhcmFjdGVycyBjb3VudFxuICpcbiAqIEBwYXJhbSBzdHIgQW4gb2JqZWN0IHRoYXQgY29udGFpbnMgc2VyaWFsaXphYmxlIHZhbHVlc1xuICogQHBhcmFtIG1heCBNYXhpbXVtIG51bWJlciBvZiBjaGFyYWN0ZXJzIGluIHRydW5jYXRlZCBzdHJpbmcgKDAgPSB1bmxpbWl0ZWQpXG4gKiBAcmV0dXJucyBzdHJpbmcgRW5jb2RlZFxuICovXG5mdW5jdGlvbiB0cnVuY2F0ZShzdHIsIG1heCA9IDApIHtcbiAgaWYgKHR5cGVvZiBzdHIgIT09ICdzdHJpbmcnIHx8IG1heCA9PT0gMCkge1xuICAgIHJldHVybiBzdHI7XG4gIH1cbiAgcmV0dXJuIHN0ci5sZW5ndGggPD0gbWF4ID8gc3RyIDogYCR7c3RyLnNsaWNlKDAsIG1heCl9Li4uYDtcbn1cblxuLyoqXG4gKiBUaGlzIGlzIGJhc2ljYWxseSBqdXN0IGB0cmltX2xpbmVgIGZyb21cbiAqIGh0dHBzOi8vZ2l0aHViLmNvbS9nZXRzZW50cnkvc2VudHJ5L2Jsb2IvbWFzdGVyL3NyYy9zZW50cnkvbGFuZy9qYXZhc2NyaXB0L3Byb2Nlc3Nvci5weSNMNjdcbiAqXG4gKiBAcGFyYW0gc3RyIEFuIG9iamVjdCB0aGF0IGNvbnRhaW5zIHNlcmlhbGl6YWJsZSB2YWx1ZXNcbiAqIEBwYXJhbSBtYXggTWF4aW11bSBudW1iZXIgb2YgY2hhcmFjdGVycyBpbiB0cnVuY2F0ZWQgc3RyaW5nXG4gKiBAcmV0dXJucyBzdHJpbmcgRW5jb2RlZFxuICovXG5mdW5jdGlvbiBzbmlwTGluZShsaW5lLCBjb2xubykge1xuICBsZXQgbmV3TGluZSA9IGxpbmU7XG4gIGNvbnN0IGxpbmVMZW5ndGggPSBuZXdMaW5lLmxlbmd0aDtcbiAgaWYgKGxpbmVMZW5ndGggPD0gMTUwKSB7XG4gICAgcmV0dXJuIG5ld0xpbmU7XG4gIH1cbiAgaWYgKGNvbG5vID4gbGluZUxlbmd0aCkge1xuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBuby1wYXJhbS1yZWFzc2lnblxuICAgIGNvbG5vID0gbGluZUxlbmd0aDtcbiAgfVxuXG4gIGxldCBzdGFydCA9IE1hdGgubWF4KGNvbG5vIC0gNjAsIDApO1xuICBpZiAoc3RhcnQgPCA1KSB7XG4gICAgc3RhcnQgPSAwO1xuICB9XG5cbiAgbGV0IGVuZCA9IE1hdGgubWluKHN0YXJ0ICsgMTQwLCBsaW5lTGVuZ3RoKTtcbiAgaWYgKGVuZCA+IGxpbmVMZW5ndGggLSA1KSB7XG4gICAgZW5kID0gbGluZUxlbmd0aDtcbiAgfVxuICBpZiAoZW5kID09PSBsaW5lTGVuZ3RoKSB7XG4gICAgc3RhcnQgPSBNYXRoLm1heChlbmQgLSAxNDAsIDApO1xuICB9XG5cbiAgbmV3TGluZSA9IG5ld0xpbmUuc2xpY2Uoc3RhcnQsIGVuZCk7XG4gIGlmIChzdGFydCA+IDApIHtcbiAgICBuZXdMaW5lID0gYCd7c25pcH0gJHtuZXdMaW5lfWA7XG4gIH1cbiAgaWYgKGVuZCA8IGxpbmVMZW5ndGgpIHtcbiAgICBuZXdMaW5lICs9ICcge3NuaXB9JztcbiAgfVxuXG4gIHJldHVybiBuZXdMaW5lO1xufVxuXG4vKipcbiAqIEpvaW4gdmFsdWVzIGluIGFycmF5XG4gKiBAcGFyYW0gaW5wdXQgYXJyYXkgb2YgdmFsdWVzIHRvIGJlIGpvaW5lZCB0b2dldGhlclxuICogQHBhcmFtIGRlbGltaXRlciBzdHJpbmcgdG8gYmUgcGxhY2VkIGluLWJldHdlZW4gdmFsdWVzXG4gKiBAcmV0dXJucyBKb2luZWQgdmFsdWVzXG4gKi9cbmZ1bmN0aW9uIHNhZmVKb2luKGlucHV0LCBkZWxpbWl0ZXIpIHtcbiAgaWYgKCFBcnJheS5pc0FycmF5KGlucHV0KSkge1xuICAgIHJldHVybiAnJztcbiAgfVxuXG4gIGNvbnN0IG91dHB1dCA9IFtdO1xuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L3ByZWZlci1mb3Itb2ZcbiAgZm9yIChsZXQgaSA9IDA7IGkgPCBpbnB1dC5sZW5ndGg7IGkrKykge1xuICAgIGNvbnN0IHZhbHVlID0gaW5wdXRbaV07XG4gICAgdHJ5IHtcbiAgICAgIC8vIFRoaXMgaXMgYSBoYWNrIHRvIGZpeCBhIFZ1ZTMtc3BlY2lmaWMgYnVnIHRoYXQgY2F1c2VzIGFuIGluZmluaXRlIGxvb3Agb2ZcbiAgICAgIC8vIGNvbnNvbGUgd2FybmluZ3MuIFRoaXMgaGFwcGVucyB3aGVuIGEgVnVlIHRlbXBsYXRlIGlzIHJlbmRlcmVkIHdpdGhcbiAgICAgIC8vIGFuIHVuZGVjbGFyZWQgdmFyaWFibGUsIHdoaWNoIHdlIHRyeSB0byBzdHJpbmdpZnksIHVsdGltYXRlbHkgY2F1c2luZ1xuICAgICAgLy8gVnVlIHRvIGlzc3VlIGFub3RoZXIgd2FybmluZyB3aGljaCByZXBlYXRzIGluZGVmaW5pdGVseS5cbiAgICAgIC8vIHNlZTogaHR0cHM6Ly9naXRodWIuY29tL2dldHNlbnRyeS9zZW50cnktamF2YXNjcmlwdC9wdWxsLzg5ODFcbiAgICAgIGlmIChpcy5pc1Z1ZVZpZXdNb2RlbCh2YWx1ZSkpIHtcbiAgICAgICAgb3V0cHV0LnB1c2goJ1tWdWVWaWV3TW9kZWxdJyk7XG4gICAgICB9IGVsc2Uge1xuICAgICAgICBvdXRwdXQucHVzaChTdHJpbmcodmFsdWUpKTtcbiAgICAgIH1cbiAgICB9IGNhdGNoIHtcbiAgICAgIG91dHB1dC5wdXNoKCdbdmFsdWUgY2Fubm90IGJlIHNlcmlhbGl6ZWRdJyk7XG4gICAgfVxuICB9XG5cbiAgcmV0dXJuIG91dHB1dC5qb2luKGRlbGltaXRlcik7XG59XG5cbi8qKlxuICogQ2hlY2tzIGlmIHRoZSBnaXZlbiB2YWx1ZSBtYXRjaGVzIGEgcmVnZXggb3Igc3RyaW5nXG4gKlxuICogQHBhcmFtIHZhbHVlIFRoZSBzdHJpbmcgdG8gdGVzdFxuICogQHBhcmFtIHBhdHRlcm4gRWl0aGVyIGEgcmVnZXggb3IgYSBzdHJpbmcgYWdhaW5zdCB3aGljaCBgdmFsdWVgIHdpbGwgYmUgbWF0Y2hlZFxuICogQHBhcmFtIHJlcXVpcmVFeGFjdFN0cmluZ01hdGNoIElmIHRydWUsIGB2YWx1ZWAgbXVzdCBtYXRjaCBgcGF0dGVybmAgZXhhY3RseS4gSWYgZmFsc2UsIGB2YWx1ZWAgd2lsbCBtYXRjaFxuICogYHBhdHRlcm5gIGlmIGl0IGNvbnRhaW5zIGBwYXR0ZXJuYC4gT25seSBhcHBsaWVzIHRvIHN0cmluZy10eXBlIHBhdHRlcm5zLlxuICovXG5mdW5jdGlvbiBpc01hdGNoaW5nUGF0dGVybihcbiAgdmFsdWUsXG4gIHBhdHRlcm4sXG4gIHJlcXVpcmVFeGFjdFN0cmluZ01hdGNoID0gZmFsc2UsXG4pIHtcbiAgaWYgKCFpcy5pc1N0cmluZyh2YWx1ZSkpIHtcbiAgICByZXR1cm4gZmFsc2U7XG4gIH1cblxuICBpZiAoaXMuaXNSZWdFeHAocGF0dGVybikpIHtcbiAgICByZXR1cm4gcGF0dGVybi50ZXN0KHZhbHVlKTtcbiAgfVxuICBpZiAoaXMuaXNTdHJpbmcocGF0dGVybikpIHtcbiAgICByZXR1cm4gcmVxdWlyZUV4YWN0U3RyaW5nTWF0Y2ggPyB2YWx1ZSA9PT0gcGF0dGVybiA6IHZhbHVlLmluY2x1ZGVzKHBhdHRlcm4pO1xuICB9XG5cbiAgcmV0dXJuIGZhbHNlO1xufVxuXG4vKipcbiAqIFRlc3QgdGhlIGdpdmVuIHN0cmluZyBhZ2FpbnN0IGFuIGFycmF5IG9mIHN0cmluZ3MgYW5kIHJlZ2V4ZXMuIEJ5IGRlZmF1bHQsIHN0cmluZyBtYXRjaGluZyBpcyBkb25lIG9uIGFcbiAqIHN1YnN0cmluZy1pbmNsdXNpb24gYmFzaXMgcmF0aGVyIHRoYW4gYSBzdHJpY3QgZXF1YWxpdHkgYmFzaXNcbiAqXG4gKiBAcGFyYW0gdGVzdFN0cmluZyBUaGUgc3RyaW5nIHRvIHRlc3RcbiAqIEBwYXJhbSBwYXR0ZXJucyBUaGUgcGF0dGVybnMgYWdhaW5zdCB3aGljaCB0byB0ZXN0IHRoZSBzdHJpbmdcbiAqIEBwYXJhbSByZXF1aXJlRXhhY3RTdHJpbmdNYXRjaCBJZiB0cnVlLCBgdGVzdFN0cmluZ2AgbXVzdCBtYXRjaCBvbmUgb2YgdGhlIGdpdmVuIHN0cmluZyBwYXR0ZXJucyBleGFjdGx5IGluIG9yZGVyIHRvXG4gKiBjb3VudC4gSWYgZmFsc2UsIGB0ZXN0U3RyaW5nYCB3aWxsIG1hdGNoIGEgc3RyaW5nIHBhdHRlcm4gaWYgaXQgY29udGFpbnMgdGhhdCBwYXR0ZXJuLlxuICogQHJldHVybnNcbiAqL1xuZnVuY3Rpb24gc3RyaW5nTWF0Y2hlc1NvbWVQYXR0ZXJuKFxuICB0ZXN0U3RyaW5nLFxuICBwYXR0ZXJucyA9IFtdLFxuICByZXF1aXJlRXhhY3RTdHJpbmdNYXRjaCA9IGZhbHNlLFxuKSB7XG4gIHJldHVybiBwYXR0ZXJucy5zb21lKHBhdHRlcm4gPT4gaXNNYXRjaGluZ1BhdHRlcm4odGVzdFN0cmluZywgcGF0dGVybiwgcmVxdWlyZUV4YWN0U3RyaW5nTWF0Y2gpKTtcbn1cblxuZXhwb3J0cy5pc01hdGNoaW5nUGF0dGVybiA9IGlzTWF0Y2hpbmdQYXR0ZXJuO1xuZXhwb3J0cy5zYWZlSm9pbiA9IHNhZmVKb2luO1xuZXhwb3J0cy5zbmlwTGluZSA9IHNuaXBMaW5lO1xuZXhwb3J0cy5zdHJpbmdNYXRjaGVzU29tZVBhdHRlcm4gPSBzdHJpbmdNYXRjaGVzU29tZVBhdHRlcm47XG5leHBvcnRzLnRydW5jYXRlID0gdHJ1bmNhdGU7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1zdHJpbmcuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/string.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/supports.js":
/*!******************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/supports.js ***!
  \******************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst debugBuild = __webpack_require__(/*! ../debug-build.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst debugLogger = __webpack_require__(/*! ./debug-logger.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst worldwide = __webpack_require__(/*! ./worldwide.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/worldwide.js\");\n\nconst WINDOW = worldwide.GLOBAL_OBJ ;\n\n/**\n * Tells whether current environment supports ErrorEvent objects\n * {@link supportsErrorEvent}.\n *\n * @returns Answer to the given question.\n */\nfunction supportsErrorEvent() {\n  try {\n    new ErrorEvent('');\n    return true;\n  } catch {\n    return false;\n  }\n}\n\n/**\n * Tells whether current environment supports DOMError objects\n * {@link supportsDOMError}.\n *\n * @returns Answer to the given question.\n */\nfunction supportsDOMError() {\n  try {\n    // Chrome: VM89:1 Uncaught TypeError: Failed to construct 'DOMError':\n    // 1 argument required, but only 0 present.\n    // @ts-expect-error It really needs 1 argument, not 0.\n    new DOMError('');\n    return true;\n  } catch {\n    return false;\n  }\n}\n\n/**\n * Tells whether current environment supports DOMException objects\n * {@link supportsDOMException}.\n *\n * @returns Answer to the given question.\n */\nfunction supportsDOMException() {\n  try {\n    new DOMException('');\n    return true;\n  } catch {\n    return false;\n  }\n}\n\n/**\n * Tells whether current environment supports History API\n * {@link supportsHistory}.\n *\n * @returns Answer to the given question.\n */\nfunction supportsHistory() {\n  return 'history' in WINDOW && !!WINDOW.history;\n}\n\n/**\n * Tells whether current environment supports Fetch API\n * {@link supportsFetch}.\n *\n * @returns Answer to the given question.\n * @deprecated This is no longer used and will be removed in a future major version.\n */\nconst supportsFetch = _isFetchSupported;\n\nfunction _isFetchSupported() {\n  if (!('fetch' in WINDOW)) {\n    return false;\n  }\n\n  try {\n    new Headers();\n    new Request('http://www.example.com');\n    new Response();\n    return true;\n  } catch {\n    return false;\n  }\n}\n\n/**\n * isNative checks if the given function is a native implementation\n */\n// eslint-disable-next-line @typescript-eslint/ban-types\nfunction isNativeFunction(func) {\n  return func && /^function\\s+\\w+\\(\\)\\s+\\{\\s+\\[native code\\]\\s+\\}$/.test(func.toString());\n}\n\n/**\n * Tells whether current environment supports Fetch API natively\n * {@link supportsNativeFetch}.\n *\n * @returns true if `window.fetch` is natively implemented, false otherwise\n */\nfunction supportsNativeFetch() {\n  if (typeof EdgeRuntime === 'string') {\n    return true;\n  }\n\n  if (!_isFetchSupported()) {\n    return false;\n  }\n\n  // Fast path to avoid DOM I/O\n  // eslint-disable-next-line @typescript-eslint/unbound-method\n  if (isNativeFunction(WINDOW.fetch)) {\n    return true;\n  }\n\n  // window.fetch is implemented, but is polyfilled or already wrapped (e.g: by a chrome extension)\n  // so create a \"pure\" iframe to see if that has native fetch\n  let result = false;\n  const doc = WINDOW.document;\n  // eslint-disable-next-line deprecation/deprecation\n  if (doc && typeof (doc.createElement ) === 'function') {\n    try {\n      const sandbox = doc.createElement('iframe');\n      sandbox.hidden = true;\n      doc.head.appendChild(sandbox);\n      if (sandbox.contentWindow?.fetch) {\n        // eslint-disable-next-line @typescript-eslint/unbound-method\n        result = isNativeFunction(sandbox.contentWindow.fetch);\n      }\n      doc.head.removeChild(sandbox);\n    } catch (err) {\n      debugBuild.DEBUG_BUILD && debugLogger.debug.warn('Could not create sandbox iframe for pure fetch check, bailing to window.fetch: ', err);\n    }\n  }\n\n  return result;\n}\n\n/**\n * Tells whether current environment supports ReportingObserver API\n * {@link supportsReportingObserver}.\n *\n * @returns Answer to the given question.\n */\nfunction supportsReportingObserver() {\n  return 'ReportingObserver' in WINDOW;\n}\n\n/**\n * Tells whether current environment supports Referrer Policy API\n * {@link supportsReferrerPolicy}.\n *\n * @returns Answer to the given question.\n * @deprecated This is no longer used and will be removed in a future major version.\n */\nfunction supportsReferrerPolicy() {\n  // Despite all stars in the sky saying that Edge supports old draft syntax, aka 'never', 'always', 'origin' and 'default'\n  // (see https://caniuse.com/#feat=referrer-policy),\n  // it doesn't. And it throws an exception instead of ignoring this parameter...\n  // REF: https://github.com/getsentry/raven-js/issues/1233\n\n  if (!_isFetchSupported()) {\n    return false;\n  }\n\n  try {\n    new Request('_', {\n      referrerPolicy: 'origin' ,\n    });\n    return true;\n  } catch {\n    return false;\n  }\n}\n\nexports.isNativeFunction = isNativeFunction;\nexports.supportsDOMError = supportsDOMError;\nexports.supportsDOMException = supportsDOMException;\nexports.supportsErrorEvent = supportsErrorEvent;\nexports.supportsFetch = supportsFetch;\nexports.supportsHistory = supportsHistory;\nexports.supportsNativeFetch = supportsNativeFetch;\nexports.supportsReferrerPolicy = supportsReferrerPolicy;\nexports.supportsReportingObserver = supportsReportingObserver;\n//# sourceMappingURL=supports.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9zdXBwb3J0cy5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxtQkFBbUIsbUJBQU8sQ0FBQyw0SEFBbUI7QUFDOUMsb0JBQW9CLG1CQUFPLENBQUMsbUlBQW1CO0FBQy9DLGtCQUFrQixtQkFBTyxDQUFDLDZIQUFnQjs7QUFFMUM7O0FBRUE7QUFDQTtBQUNBLElBQUkseUJBQXlCO0FBQzdCO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsSUFBSTtBQUNKO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsSUFBSSx1QkFBdUI7QUFDM0I7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxJQUFJO0FBQ0o7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQSxJQUFJLDJCQUEyQjtBQUMvQjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLElBQUk7QUFDSjtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLElBQUksc0JBQXNCO0FBQzFCO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsSUFBSSxvQkFBb0I7QUFDeEI7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsSUFBSTtBQUNKO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsMENBQTBDLHVCQUF1QjtBQUNqRTs7QUFFQTtBQUNBO0FBQ0EsSUFBSSwwQkFBMEI7QUFDOUI7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsTUFBTTtBQUNOO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQSxJQUFJLGdDQUFnQztBQUNwQztBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLElBQUksNkJBQTZCO0FBQ2pDO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0EsS0FBSztBQUNMO0FBQ0EsSUFBSTtBQUNKO0FBQ0E7QUFDQTs7QUFFQSx3QkFBd0I7QUFDeEIsd0JBQXdCO0FBQ3hCLDRCQUE0QjtBQUM1QiwwQkFBMEI7QUFDMUIscUJBQXFCO0FBQ3JCLHVCQUF1QjtBQUN2QiwyQkFBMkI7QUFDM0IsOEJBQThCO0FBQzlCLGlDQUFpQztBQUNqQyIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3V0aWxzL3N1cHBvcnRzLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBkZWJ1Z0J1aWxkID0gcmVxdWlyZSgnLi4vZGVidWctYnVpbGQuanMnKTtcbmNvbnN0IGRlYnVnTG9nZ2VyID0gcmVxdWlyZSgnLi9kZWJ1Zy1sb2dnZXIuanMnKTtcbmNvbnN0IHdvcmxkd2lkZSA9IHJlcXVpcmUoJy4vd29ybGR3aWRlLmpzJyk7XG5cbmNvbnN0IFdJTkRPVyA9IHdvcmxkd2lkZS5HTE9CQUxfT0JKIDtcblxuLyoqXG4gKiBUZWxscyB3aGV0aGVyIGN1cnJlbnQgZW52aXJvbm1lbnQgc3VwcG9ydHMgRXJyb3JFdmVudCBvYmplY3RzXG4gKiB7QGxpbmsgc3VwcG9ydHNFcnJvckV2ZW50fS5cbiAqXG4gKiBAcmV0dXJucyBBbnN3ZXIgdG8gdGhlIGdpdmVuIHF1ZXN0aW9uLlxuICovXG5mdW5jdGlvbiBzdXBwb3J0c0Vycm9yRXZlbnQoKSB7XG4gIHRyeSB7XG4gICAgbmV3IEVycm9yRXZlbnQoJycpO1xuICAgIHJldHVybiB0cnVlO1xuICB9IGNhdGNoIHtcbiAgICByZXR1cm4gZmFsc2U7XG4gIH1cbn1cblxuLyoqXG4gKiBUZWxscyB3aGV0aGVyIGN1cnJlbnQgZW52aXJvbm1lbnQgc3VwcG9ydHMgRE9NRXJyb3Igb2JqZWN0c1xuICoge0BsaW5rIHN1cHBvcnRzRE9NRXJyb3J9LlxuICpcbiAqIEByZXR1cm5zIEFuc3dlciB0byB0aGUgZ2l2ZW4gcXVlc3Rpb24uXG4gKi9cbmZ1bmN0aW9uIHN1cHBvcnRzRE9NRXJyb3IoKSB7XG4gIHRyeSB7XG4gICAgLy8gQ2hyb21lOiBWTTg5OjEgVW5jYXVnaHQgVHlwZUVycm9yOiBGYWlsZWQgdG8gY29uc3RydWN0ICdET01FcnJvcic6XG4gICAgLy8gMSBhcmd1bWVudCByZXF1aXJlZCwgYnV0IG9ubHkgMCBwcmVzZW50LlxuICAgIC8vIEB0cy1leHBlY3QtZXJyb3IgSXQgcmVhbGx5IG5lZWRzIDEgYXJndW1lbnQsIG5vdCAwLlxuICAgIG5ldyBET01FcnJvcignJyk7XG4gICAgcmV0dXJuIHRydWU7XG4gIH0gY2F0Y2gge1xuICAgIHJldHVybiBmYWxzZTtcbiAgfVxufVxuXG4vKipcbiAqIFRlbGxzIHdoZXRoZXIgY3VycmVudCBlbnZpcm9ubWVudCBzdXBwb3J0cyBET01FeGNlcHRpb24gb2JqZWN0c1xuICoge0BsaW5rIHN1cHBvcnRzRE9NRXhjZXB0aW9ufS5cbiAqXG4gKiBAcmV0dXJucyBBbnN3ZXIgdG8gdGhlIGdpdmVuIHF1ZXN0aW9uLlxuICovXG5mdW5jdGlvbiBzdXBwb3J0c0RPTUV4Y2VwdGlvbigpIHtcbiAgdHJ5IHtcbiAgICBuZXcgRE9NRXhjZXB0aW9uKCcnKTtcbiAgICByZXR1cm4gdHJ1ZTtcbiAgfSBjYXRjaCB7XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG59XG5cbi8qKlxuICogVGVsbHMgd2hldGhlciBjdXJyZW50IGVudmlyb25tZW50IHN1cHBvcnRzIEhpc3RvcnkgQVBJXG4gKiB7QGxpbmsgc3VwcG9ydHNIaXN0b3J5fS5cbiAqXG4gKiBAcmV0dXJucyBBbnN3ZXIgdG8gdGhlIGdpdmVuIHF1ZXN0aW9uLlxuICovXG5mdW5jdGlvbiBzdXBwb3J0c0hpc3RvcnkoKSB7XG4gIHJldHVybiAnaGlzdG9yeScgaW4gV0lORE9XICYmICEhV0lORE9XLmhpc3Rvcnk7XG59XG5cbi8qKlxuICogVGVsbHMgd2hldGhlciBjdXJyZW50IGVudmlyb25tZW50IHN1cHBvcnRzIEZldGNoIEFQSVxuICoge0BsaW5rIHN1cHBvcnRzRmV0Y2h9LlxuICpcbiAqIEByZXR1cm5zIEFuc3dlciB0byB0aGUgZ2l2ZW4gcXVlc3Rpb24uXG4gKiBAZGVwcmVjYXRlZCBUaGlzIGlzIG5vIGxvbmdlciB1c2VkIGFuZCB3aWxsIGJlIHJlbW92ZWQgaW4gYSBmdXR1cmUgbWFqb3IgdmVyc2lvbi5cbiAqL1xuY29uc3Qgc3VwcG9ydHNGZXRjaCA9IF9pc0ZldGNoU3VwcG9ydGVkO1xuXG5mdW5jdGlvbiBfaXNGZXRjaFN1cHBvcnRlZCgpIHtcbiAgaWYgKCEoJ2ZldGNoJyBpbiBXSU5ET1cpKSB7XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG5cbiAgdHJ5IHtcbiAgICBuZXcgSGVhZGVycygpO1xuICAgIG5ldyBSZXF1ZXN0KCdodHRwOi8vd3d3LmV4YW1wbGUuY29tJyk7XG4gICAgbmV3IFJlc3BvbnNlKCk7XG4gICAgcmV0dXJuIHRydWU7XG4gIH0gY2F0Y2gge1xuICAgIHJldHVybiBmYWxzZTtcbiAgfVxufVxuXG4vKipcbiAqIGlzTmF0aXZlIGNoZWNrcyBpZiB0aGUgZ2l2ZW4gZnVuY3Rpb24gaXMgYSBuYXRpdmUgaW1wbGVtZW50YXRpb25cbiAqL1xuLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9iYW4tdHlwZXNcbmZ1bmN0aW9uIGlzTmF0aXZlRnVuY3Rpb24oZnVuYykge1xuICByZXR1cm4gZnVuYyAmJiAvXmZ1bmN0aW9uXFxzK1xcdytcXChcXClcXHMrXFx7XFxzK1xcW25hdGl2ZSBjb2RlXFxdXFxzK1xcfSQvLnRlc3QoZnVuYy50b1N0cmluZygpKTtcbn1cblxuLyoqXG4gKiBUZWxscyB3aGV0aGVyIGN1cnJlbnQgZW52aXJvbm1lbnQgc3VwcG9ydHMgRmV0Y2ggQVBJIG5hdGl2ZWx5XG4gKiB7QGxpbmsgc3VwcG9ydHNOYXRpdmVGZXRjaH0uXG4gKlxuICogQHJldHVybnMgdHJ1ZSBpZiBgd2luZG93LmZldGNoYCBpcyBuYXRpdmVseSBpbXBsZW1lbnRlZCwgZmFsc2Ugb3RoZXJ3aXNlXG4gKi9cbmZ1bmN0aW9uIHN1cHBvcnRzTmF0aXZlRmV0Y2goKSB7XG4gIGlmICh0eXBlb2YgRWRnZVJ1bnRpbWUgPT09ICdzdHJpbmcnKSB7XG4gICAgcmV0dXJuIHRydWU7XG4gIH1cblxuICBpZiAoIV9pc0ZldGNoU3VwcG9ydGVkKCkpIHtcbiAgICByZXR1cm4gZmFsc2U7XG4gIH1cblxuICAvLyBGYXN0IHBhdGggdG8gYXZvaWQgRE9NIEkvT1xuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L3VuYm91bmQtbWV0aG9kXG4gIGlmIChpc05hdGl2ZUZ1bmN0aW9uKFdJTkRPVy5mZXRjaCkpIHtcbiAgICByZXR1cm4gdHJ1ZTtcbiAgfVxuXG4gIC8vIHdpbmRvdy5mZXRjaCBpcyBpbXBsZW1lbnRlZCwgYnV0IGlzIHBvbHlmaWxsZWQgb3IgYWxyZWFkeSB3cmFwcGVkIChlLmc6IGJ5IGEgY2hyb21lIGV4dGVuc2lvbilcbiAgLy8gc28gY3JlYXRlIGEgXCJwdXJlXCIgaWZyYW1lIHRvIHNlZSBpZiB0aGF0IGhhcyBuYXRpdmUgZmV0Y2hcbiAgbGV0IHJlc3VsdCA9IGZhbHNlO1xuICBjb25zdCBkb2MgPSBXSU5ET1cuZG9jdW1lbnQ7XG4gIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBkZXByZWNhdGlvbi9kZXByZWNhdGlvblxuICBpZiAoZG9jICYmIHR5cGVvZiAoZG9jLmNyZWF0ZUVsZW1lbnQgKSA9PT0gJ2Z1bmN0aW9uJykge1xuICAgIHRyeSB7XG4gICAgICBjb25zdCBzYW5kYm94ID0gZG9jLmNyZWF0ZUVsZW1lbnQoJ2lmcmFtZScpO1xuICAgICAgc2FuZGJveC5oaWRkZW4gPSB0cnVlO1xuICAgICAgZG9jLmhlYWQuYXBwZW5kQ2hpbGQoc2FuZGJveCk7XG4gICAgICBpZiAoc2FuZGJveC5jb250ZW50V2luZG93Py5mZXRjaCkge1xuICAgICAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L3VuYm91bmQtbWV0aG9kXG4gICAgICAgIHJlc3VsdCA9IGlzTmF0aXZlRnVuY3Rpb24oc2FuZGJveC5jb250ZW50V2luZG93LmZldGNoKTtcbiAgICAgIH1cbiAgICAgIGRvYy5oZWFkLnJlbW92ZUNoaWxkKHNhbmRib3gpO1xuICAgIH0gY2F0Y2ggKGVycikge1xuICAgICAgZGVidWdCdWlsZC5ERUJVR19CVUlMRCAmJiBkZWJ1Z0xvZ2dlci5kZWJ1Zy53YXJuKCdDb3VsZCBub3QgY3JlYXRlIHNhbmRib3ggaWZyYW1lIGZvciBwdXJlIGZldGNoIGNoZWNrLCBiYWlsaW5nIHRvIHdpbmRvdy5mZXRjaDogJywgZXJyKTtcbiAgICB9XG4gIH1cblxuICByZXR1cm4gcmVzdWx0O1xufVxuXG4vKipcbiAqIFRlbGxzIHdoZXRoZXIgY3VycmVudCBlbnZpcm9ubWVudCBzdXBwb3J0cyBSZXBvcnRpbmdPYnNlcnZlciBBUElcbiAqIHtAbGluayBzdXBwb3J0c1JlcG9ydGluZ09ic2VydmVyfS5cbiAqXG4gKiBAcmV0dXJucyBBbnN3ZXIgdG8gdGhlIGdpdmVuIHF1ZXN0aW9uLlxuICovXG5mdW5jdGlvbiBzdXBwb3J0c1JlcG9ydGluZ09ic2VydmVyKCkge1xuICByZXR1cm4gJ1JlcG9ydGluZ09ic2VydmVyJyBpbiBXSU5ET1c7XG59XG5cbi8qKlxuICogVGVsbHMgd2hldGhlciBjdXJyZW50IGVudmlyb25tZW50IHN1cHBvcnRzIFJlZmVycmVyIFBvbGljeSBBUElcbiAqIHtAbGluayBzdXBwb3J0c1JlZmVycmVyUG9saWN5fS5cbiAqXG4gKiBAcmV0dXJucyBBbnN3ZXIgdG8gdGhlIGdpdmVuIHF1ZXN0aW9uLlxuICogQGRlcHJlY2F0ZWQgVGhpcyBpcyBubyBsb25nZXIgdXNlZCBhbmQgd2lsbCBiZSByZW1vdmVkIGluIGEgZnV0dXJlIG1ham9yIHZlcnNpb24uXG4gKi9cbmZ1bmN0aW9uIHN1cHBvcnRzUmVmZXJyZXJQb2xpY3koKSB7XG4gIC8vIERlc3BpdGUgYWxsIHN0YXJzIGluIHRoZSBza3kgc2F5aW5nIHRoYXQgRWRnZSBzdXBwb3J0cyBvbGQgZHJhZnQgc3ludGF4LCBha2EgJ25ldmVyJywgJ2Fsd2F5cycsICdvcmlnaW4nIGFuZCAnZGVmYXVsdCdcbiAgLy8gKHNlZSBodHRwczovL2Nhbml1c2UuY29tLyNmZWF0PXJlZmVycmVyLXBvbGljeSksXG4gIC8vIGl0IGRvZXNuJ3QuIEFuZCBpdCB0aHJvd3MgYW4gZXhjZXB0aW9uIGluc3RlYWQgb2YgaWdub3JpbmcgdGhpcyBwYXJhbWV0ZXIuLi5cbiAgLy8gUkVGOiBodHRwczovL2dpdGh1Yi5jb20vZ2V0c2VudHJ5L3JhdmVuLWpzL2lzc3Vlcy8xMjMzXG5cbiAgaWYgKCFfaXNGZXRjaFN1cHBvcnRlZCgpKSB7XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG5cbiAgdHJ5IHtcbiAgICBuZXcgUmVxdWVzdCgnXycsIHtcbiAgICAgIHJlZmVycmVyUG9saWN5OiAnb3JpZ2luJyAsXG4gICAgfSk7XG4gICAgcmV0dXJuIHRydWU7XG4gIH0gY2F0Y2gge1xuICAgIHJldHVybiBmYWxzZTtcbiAgfVxufVxuXG5leHBvcnRzLmlzTmF0aXZlRnVuY3Rpb24gPSBpc05hdGl2ZUZ1bmN0aW9uO1xuZXhwb3J0cy5zdXBwb3J0c0RPTUVycm9yID0gc3VwcG9ydHNET01FcnJvcjtcbmV4cG9ydHMuc3VwcG9ydHNET01FeGNlcHRpb24gPSBzdXBwb3J0c0RPTUV4Y2VwdGlvbjtcbmV4cG9ydHMuc3VwcG9ydHNFcnJvckV2ZW50ID0gc3VwcG9ydHNFcnJvckV2ZW50O1xuZXhwb3J0cy5zdXBwb3J0c0ZldGNoID0gc3VwcG9ydHNGZXRjaDtcbmV4cG9ydHMuc3VwcG9ydHNIaXN0b3J5ID0gc3VwcG9ydHNIaXN0b3J5O1xuZXhwb3J0cy5zdXBwb3J0c05hdGl2ZUZldGNoID0gc3VwcG9ydHNOYXRpdmVGZXRjaDtcbmV4cG9ydHMuc3VwcG9ydHNSZWZlcnJlclBvbGljeSA9IHN1cHBvcnRzUmVmZXJyZXJQb2xpY3k7XG5leHBvcnRzLnN1cHBvcnRzUmVwb3J0aW5nT2JzZXJ2ZXIgPSBzdXBwb3J0c1JlcG9ydGluZ09ic2VydmVyO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9c3VwcG9ydHMuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/supports.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/syncpromise.js":
/*!*********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/syncpromise.js ***!
  \*********************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst is = __webpack_require__(/*! ./is.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js\");\n\n/* eslint-disable @typescript-eslint/no-explicit-any */\n\n/** SyncPromise internal states */\nconst STATE_PENDING = 0;\nconst STATE_RESOLVED = 1;\nconst STATE_REJECTED = 2;\n\n/**\n * Creates a resolved sync promise.\n *\n * @param value the value to resolve the promise with\n * @returns the resolved sync promise\n */\nfunction resolvedSyncPromise(value) {\n  return new SyncPromise(resolve => {\n    resolve(value);\n  });\n}\n\n/**\n * Creates a rejected sync promise.\n *\n * @param value the value to reject the promise with\n * @returns the rejected sync promise\n */\nfunction rejectedSyncPromise(reason) {\n  return new SyncPromise((_, reject) => {\n    reject(reason);\n  });\n}\n\n/**\n * Thenable class that behaves like a Promise and follows it's interface\n * but is not async internally\n */\nclass SyncPromise {\n\n   constructor(executor) {\n    this._state = STATE_PENDING;\n    this._handlers = [];\n\n    this._runExecutor(executor);\n  }\n\n  /** @inheritdoc */\n   then(\n    onfulfilled,\n    onrejected,\n  ) {\n    return new SyncPromise((resolve, reject) => {\n      this._handlers.push([\n        false,\n        result => {\n          if (!onfulfilled) {\n            // TODO: ¯\\_(ツ)_/¯\n            // TODO: FIXME\n            resolve(result );\n          } else {\n            try {\n              resolve(onfulfilled(result));\n            } catch (e) {\n              reject(e);\n            }\n          }\n        },\n        reason => {\n          if (!onrejected) {\n            reject(reason);\n          } else {\n            try {\n              resolve(onrejected(reason));\n            } catch (e) {\n              reject(e);\n            }\n          }\n        },\n      ]);\n      this._executeHandlers();\n    });\n  }\n\n  /** @inheritdoc */\n   catch(\n    onrejected,\n  ) {\n    return this.then(val => val, onrejected);\n  }\n\n  /** @inheritdoc */\n   finally(onfinally) {\n    return new SyncPromise((resolve, reject) => {\n      let val;\n      let isRejected;\n\n      return this.then(\n        value => {\n          isRejected = false;\n          val = value;\n          if (onfinally) {\n            onfinally();\n          }\n        },\n        reason => {\n          isRejected = true;\n          val = reason;\n          if (onfinally) {\n            onfinally();\n          }\n        },\n      ).then(() => {\n        if (isRejected) {\n          reject(val);\n          return;\n        }\n\n        resolve(val );\n      });\n    });\n  }\n\n  /** Excute the resolve/reject handlers. */\n   _executeHandlers() {\n    if (this._state === STATE_PENDING) {\n      return;\n    }\n\n    const cachedHandlers = this._handlers.slice();\n    this._handlers = [];\n\n    cachedHandlers.forEach(handler => {\n      if (handler[0]) {\n        return;\n      }\n\n      if (this._state === STATE_RESOLVED) {\n        handler[1](this._value );\n      }\n\n      if (this._state === STATE_REJECTED) {\n        handler[2](this._value);\n      }\n\n      handler[0] = true;\n    });\n  }\n\n  /** Run the executor for the SyncPromise. */\n   _runExecutor(executor) {\n    const setResult = (state, value) => {\n      if (this._state !== STATE_PENDING) {\n        return;\n      }\n\n      if (is.isThenable(value)) {\n        void (value ).then(resolve, reject);\n        return;\n      }\n\n      this._state = state;\n      this._value = value;\n\n      this._executeHandlers();\n    };\n\n    const resolve = (value) => {\n      setResult(STATE_RESOLVED, value);\n    };\n\n    const reject = (reason) => {\n      setResult(STATE_REJECTED, reason);\n    };\n\n    try {\n      executor(resolve, reject);\n    } catch (e) {\n      reject(e);\n    }\n  }\n}\n\nexports.SyncPromise = SyncPromise;\nexports.rejectedSyncPromise = rejectedSyncPromise;\nexports.resolvedSyncPromise = resolvedSyncPromise;\n//# sourceMappingURL=syncpromise.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9zeW5jcHJvbWlzZS5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxXQUFXLG1CQUFPLENBQUMsK0dBQVM7O0FBRTVCOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEdBQUc7QUFDSDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxHQUFHO0FBQ0g7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFlBQVk7QUFDWjtBQUNBO0FBQ0EsY0FBYztBQUNkO0FBQ0E7QUFDQTtBQUNBLFNBQVM7QUFDVDtBQUNBO0FBQ0E7QUFDQSxZQUFZO0FBQ1o7QUFDQTtBQUNBLGNBQWM7QUFDZDtBQUNBO0FBQ0E7QUFDQSxTQUFTO0FBQ1Q7QUFDQTtBQUNBLEtBQUs7QUFDTDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFNBQVM7QUFDVDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxTQUFTO0FBQ1Q7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBLE9BQU87QUFDUCxLQUFLO0FBQ0w7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQSxLQUFLO0FBQ0w7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQSxNQUFNO0FBQ047QUFDQTtBQUNBO0FBQ0E7O0FBRUEsbUJBQW1CO0FBQ25CLDJCQUEyQjtBQUMzQiwyQkFBMkI7QUFDM0IiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9zeW5jcHJvbWlzZS5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgaXMgPSByZXF1aXJlKCcuL2lzLmpzJyk7XG5cbi8qIGVzbGludC1kaXNhYmxlIEB0eXBlc2NyaXB0LWVzbGludC9uby1leHBsaWNpdC1hbnkgKi9cblxuLyoqIFN5bmNQcm9taXNlIGludGVybmFsIHN0YXRlcyAqL1xuY29uc3QgU1RBVEVfUEVORElORyA9IDA7XG5jb25zdCBTVEFURV9SRVNPTFZFRCA9IDE7XG5jb25zdCBTVEFURV9SRUpFQ1RFRCA9IDI7XG5cbi8qKlxuICogQ3JlYXRlcyBhIHJlc29sdmVkIHN5bmMgcHJvbWlzZS5cbiAqXG4gKiBAcGFyYW0gdmFsdWUgdGhlIHZhbHVlIHRvIHJlc29sdmUgdGhlIHByb21pc2Ugd2l0aFxuICogQHJldHVybnMgdGhlIHJlc29sdmVkIHN5bmMgcHJvbWlzZVxuICovXG5mdW5jdGlvbiByZXNvbHZlZFN5bmNQcm9taXNlKHZhbHVlKSB7XG4gIHJldHVybiBuZXcgU3luY1Byb21pc2UocmVzb2x2ZSA9PiB7XG4gICAgcmVzb2x2ZSh2YWx1ZSk7XG4gIH0pO1xufVxuXG4vKipcbiAqIENyZWF0ZXMgYSByZWplY3RlZCBzeW5jIHByb21pc2UuXG4gKlxuICogQHBhcmFtIHZhbHVlIHRoZSB2YWx1ZSB0byByZWplY3QgdGhlIHByb21pc2Ugd2l0aFxuICogQHJldHVybnMgdGhlIHJlamVjdGVkIHN5bmMgcHJvbWlzZVxuICovXG5mdW5jdGlvbiByZWplY3RlZFN5bmNQcm9taXNlKHJlYXNvbikge1xuICByZXR1cm4gbmV3IFN5bmNQcm9taXNlKChfLCByZWplY3QpID0+IHtcbiAgICByZWplY3QocmVhc29uKTtcbiAgfSk7XG59XG5cbi8qKlxuICogVGhlbmFibGUgY2xhc3MgdGhhdCBiZWhhdmVzIGxpa2UgYSBQcm9taXNlIGFuZCBmb2xsb3dzIGl0J3MgaW50ZXJmYWNlXG4gKiBidXQgaXMgbm90IGFzeW5jIGludGVybmFsbHlcbiAqL1xuY2xhc3MgU3luY1Byb21pc2Uge1xuXG4gICBjb25zdHJ1Y3RvcihleGVjdXRvcikge1xuICAgIHRoaXMuX3N0YXRlID0gU1RBVEVfUEVORElORztcbiAgICB0aGlzLl9oYW5kbGVycyA9IFtdO1xuXG4gICAgdGhpcy5fcnVuRXhlY3V0b3IoZXhlY3V0b3IpO1xuICB9XG5cbiAgLyoqIEBpbmhlcml0ZG9jICovXG4gICB0aGVuKFxuICAgIG9uZnVsZmlsbGVkLFxuICAgIG9ucmVqZWN0ZWQsXG4gICkge1xuICAgIHJldHVybiBuZXcgU3luY1Byb21pc2UoKHJlc29sdmUsIHJlamVjdCkgPT4ge1xuICAgICAgdGhpcy5faGFuZGxlcnMucHVzaChbXG4gICAgICAgIGZhbHNlLFxuICAgICAgICByZXN1bHQgPT4ge1xuICAgICAgICAgIGlmICghb25mdWxmaWxsZWQpIHtcbiAgICAgICAgICAgIC8vIFRPRE86IMKvXFxfKOODhClfL8KvXG4gICAgICAgICAgICAvLyBUT0RPOiBGSVhNRVxuICAgICAgICAgICAgcmVzb2x2ZShyZXN1bHQgKTtcbiAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgdHJ5IHtcbiAgICAgICAgICAgICAgcmVzb2x2ZShvbmZ1bGZpbGxlZChyZXN1bHQpKTtcbiAgICAgICAgICAgIH0gY2F0Y2ggKGUpIHtcbiAgICAgICAgICAgICAgcmVqZWN0KGUpO1xuICAgICAgICAgICAgfVxuICAgICAgICAgIH1cbiAgICAgICAgfSxcbiAgICAgICAgcmVhc29uID0+IHtcbiAgICAgICAgICBpZiAoIW9ucmVqZWN0ZWQpIHtcbiAgICAgICAgICAgIHJlamVjdChyZWFzb24pO1xuICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICB0cnkge1xuICAgICAgICAgICAgICByZXNvbHZlKG9ucmVqZWN0ZWQocmVhc29uKSk7XG4gICAgICAgICAgICB9IGNhdGNoIChlKSB7XG4gICAgICAgICAgICAgIHJlamVjdChlKTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgICB9XG4gICAgICAgIH0sXG4gICAgICBdKTtcbiAgICAgIHRoaXMuX2V4ZWN1dGVIYW5kbGVycygpO1xuICAgIH0pO1xuICB9XG5cbiAgLyoqIEBpbmhlcml0ZG9jICovXG4gICBjYXRjaChcbiAgICBvbnJlamVjdGVkLFxuICApIHtcbiAgICByZXR1cm4gdGhpcy50aGVuKHZhbCA9PiB2YWwsIG9ucmVqZWN0ZWQpO1xuICB9XG5cbiAgLyoqIEBpbmhlcml0ZG9jICovXG4gICBmaW5hbGx5KG9uZmluYWxseSkge1xuICAgIHJldHVybiBuZXcgU3luY1Byb21pc2UoKHJlc29sdmUsIHJlamVjdCkgPT4ge1xuICAgICAgbGV0IHZhbDtcbiAgICAgIGxldCBpc1JlamVjdGVkO1xuXG4gICAgICByZXR1cm4gdGhpcy50aGVuKFxuICAgICAgICB2YWx1ZSA9PiB7XG4gICAgICAgICAgaXNSZWplY3RlZCA9IGZhbHNlO1xuICAgICAgICAgIHZhbCA9IHZhbHVlO1xuICAgICAgICAgIGlmIChvbmZpbmFsbHkpIHtcbiAgICAgICAgICAgIG9uZmluYWxseSgpO1xuICAgICAgICAgIH1cbiAgICAgICAgfSxcbiAgICAgICAgcmVhc29uID0+IHtcbiAgICAgICAgICBpc1JlamVjdGVkID0gdHJ1ZTtcbiAgICAgICAgICB2YWwgPSByZWFzb247XG4gICAgICAgICAgaWYgKG9uZmluYWxseSkge1xuICAgICAgICAgICAgb25maW5hbGx5KCk7XG4gICAgICAgICAgfVxuICAgICAgICB9LFxuICAgICAgKS50aGVuKCgpID0+IHtcbiAgICAgICAgaWYgKGlzUmVqZWN0ZWQpIHtcbiAgICAgICAgICByZWplY3QodmFsKTtcbiAgICAgICAgICByZXR1cm47XG4gICAgICAgIH1cblxuICAgICAgICByZXNvbHZlKHZhbCApO1xuICAgICAgfSk7XG4gICAgfSk7XG4gIH1cblxuICAvKiogRXhjdXRlIHRoZSByZXNvbHZlL3JlamVjdCBoYW5kbGVycy4gKi9cbiAgIF9leGVjdXRlSGFuZGxlcnMoKSB7XG4gICAgaWYgKHRoaXMuX3N0YXRlID09PSBTVEFURV9QRU5ESU5HKSB7XG4gICAgICByZXR1cm47XG4gICAgfVxuXG4gICAgY29uc3QgY2FjaGVkSGFuZGxlcnMgPSB0aGlzLl9oYW5kbGVycy5zbGljZSgpO1xuICAgIHRoaXMuX2hhbmRsZXJzID0gW107XG5cbiAgICBjYWNoZWRIYW5kbGVycy5mb3JFYWNoKGhhbmRsZXIgPT4ge1xuICAgICAgaWYgKGhhbmRsZXJbMF0pIHtcbiAgICAgICAgcmV0dXJuO1xuICAgICAgfVxuXG4gICAgICBpZiAodGhpcy5fc3RhdGUgPT09IFNUQVRFX1JFU09MVkVEKSB7XG4gICAgICAgIGhhbmRsZXJbMV0odGhpcy5fdmFsdWUgKTtcbiAgICAgIH1cblxuICAgICAgaWYgKHRoaXMuX3N0YXRlID09PSBTVEFURV9SRUpFQ1RFRCkge1xuICAgICAgICBoYW5kbGVyWzJdKHRoaXMuX3ZhbHVlKTtcbiAgICAgIH1cblxuICAgICAgaGFuZGxlclswXSA9IHRydWU7XG4gICAgfSk7XG4gIH1cblxuICAvKiogUnVuIHRoZSBleGVjdXRvciBmb3IgdGhlIFN5bmNQcm9taXNlLiAqL1xuICAgX3J1bkV4ZWN1dG9yKGV4ZWN1dG9yKSB7XG4gICAgY29uc3Qgc2V0UmVzdWx0ID0gKHN0YXRlLCB2YWx1ZSkgPT4ge1xuICAgICAgaWYgKHRoaXMuX3N0YXRlICE9PSBTVEFURV9QRU5ESU5HKSB7XG4gICAgICAgIHJldHVybjtcbiAgICAgIH1cblxuICAgICAgaWYgKGlzLmlzVGhlbmFibGUodmFsdWUpKSB7XG4gICAgICAgIHZvaWQgKHZhbHVlICkudGhlbihyZXNvbHZlLCByZWplY3QpO1xuICAgICAgICByZXR1cm47XG4gICAgICB9XG5cbiAgICAgIHRoaXMuX3N0YXRlID0gc3RhdGU7XG4gICAgICB0aGlzLl92YWx1ZSA9IHZhbHVlO1xuXG4gICAgICB0aGlzLl9leGVjdXRlSGFuZGxlcnMoKTtcbiAgICB9O1xuXG4gICAgY29uc3QgcmVzb2x2ZSA9ICh2YWx1ZSkgPT4ge1xuICAgICAgc2V0UmVzdWx0KFNUQVRFX1JFU09MVkVELCB2YWx1ZSk7XG4gICAgfTtcblxuICAgIGNvbnN0IHJlamVjdCA9IChyZWFzb24pID0+IHtcbiAgICAgIHNldFJlc3VsdChTVEFURV9SRUpFQ1RFRCwgcmVhc29uKTtcbiAgICB9O1xuXG4gICAgdHJ5IHtcbiAgICAgIGV4ZWN1dG9yKHJlc29sdmUsIHJlamVjdCk7XG4gICAgfSBjYXRjaCAoZSkge1xuICAgICAgcmVqZWN0KGUpO1xuICAgIH1cbiAgfVxufVxuXG5leHBvcnRzLlN5bmNQcm9taXNlID0gU3luY1Byb21pc2U7XG5leHBvcnRzLnJlamVjdGVkU3luY1Byb21pc2UgPSByZWplY3RlZFN5bmNQcm9taXNlO1xuZXhwb3J0cy5yZXNvbHZlZFN5bmNQcm9taXNlID0gcmVzb2x2ZWRTeW5jUHJvbWlzZTtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPXN5bmNwcm9taXNlLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/syncpromise.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/time.js":
/*!**************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/time.js ***!
  \**************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst worldwide = __webpack_require__(/*! ./worldwide.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/worldwide.js\");\n\nconst ONE_SECOND_IN_MS = 1000;\n\n/**\n * A partial definition of the [Performance Web API]{@link https://developer.mozilla.org/en-US/docs/Web/API/Performance}\n * for accessing a high-resolution monotonic clock.\n */\n\n/**\n * Returns a timestamp in seconds since the UNIX epoch using the Date API.\n */\nfunction dateTimestampInSeconds() {\n  return Date.now() / ONE_SECOND_IN_MS;\n}\n\n/**\n * Returns a wrapper around the native Performance API browser implementation, or undefined for browsers that do not\n * support the API.\n *\n * Wrapping the native API works around differences in behavior from different browsers.\n */\nfunction createUnixTimestampInSecondsFunc() {\n  const { performance } = worldwide.GLOBAL_OBJ ;\n  // Some browser and environments don't have a performance or timeOrigin, so we fallback to\n  // using Date.now() to compute the starting time.\n  if (!performance?.now || !performance.timeOrigin) {\n    return dateTimestampInSeconds;\n  }\n\n  const timeOrigin = performance.timeOrigin;\n\n  // performance.now() is a monotonic clock, which means it starts at 0 when the process begins. To get the current\n  // wall clock time (actual UNIX timestamp), we need to add the starting time origin and the current time elapsed.\n  //\n  // TODO: This does not account for the case where the monotonic clock that powers performance.now() drifts from the\n  // wall clock time, which causes the returned timestamp to be inaccurate. We should investigate how to detect and\n  // correct for this.\n  // See: https://github.com/getsentry/sentry-javascript/issues/2590\n  // See: https://github.com/mdn/content/issues/4713\n  // See: https://dev.to/noamr/when-a-millisecond-is-not-a-millisecond-3h6\n  return () => {\n    return (timeOrigin + performance.now()) / ONE_SECOND_IN_MS;\n  };\n}\n\nlet _cachedTimestampInSeconds;\n\n/**\n * Returns a timestamp in seconds since the UNIX epoch using either the Performance or Date APIs, depending on the\n * availability of the Performance API.\n *\n * BUG: Note that because of how browsers implement the Performance API, the clock might stop when the computer is\n * asleep. This creates a skew between `dateTimestampInSeconds` and `timestampInSeconds`. The\n * skew can grow to arbitrary amounts like days, weeks or months.\n * See https://github.com/getsentry/sentry-javascript/issues/2590.\n */\nfunction timestampInSeconds() {\n  // We store this in a closure so that we don't have to create a new function every time this is called.\n  const func = _cachedTimestampInSeconds ?? (_cachedTimestampInSeconds = createUnixTimestampInSecondsFunc());\n  return func();\n}\n\n/**\n * Cached result of getBrowserTimeOrigin.\n */\nlet cachedTimeOrigin;\n\n/**\n * Gets the time origin and the mode used to determine it.\n */\nfunction getBrowserTimeOrigin() {\n  // Unfortunately browsers may report an inaccurate time origin data, through either performance.timeOrigin or\n  // performance.timing.navigationStart, which results in poor results in performance data. We only treat time origin\n  // data as reliable if they are within a reasonable threshold of the current time.\n\n  const { performance } = worldwide.GLOBAL_OBJ ;\n  if (!performance?.now) {\n    return [undefined, 'none'];\n  }\n\n  const threshold = 3600 * 1000;\n  const performanceNow = performance.now();\n  const dateNow = Date.now();\n\n  // if timeOrigin isn't available set delta to threshold so it isn't used\n  const timeOriginDelta = performance.timeOrigin\n    ? Math.abs(performance.timeOrigin + performanceNow - dateNow)\n    : threshold;\n  const timeOriginIsReliable = timeOriginDelta < threshold;\n\n  // While performance.timing.navigationStart is deprecated in favor of performance.timeOrigin, performance.timeOrigin\n  // is not as widely supported. Namely, performance.timeOrigin is undefined in Safari as of writing.\n  // Also as of writing, performance.timing is not available in Web Workers in mainstream browsers, so it is not always\n  // a valid fallback. In the absence of an initial time provided by the browser, fallback to the current time from the\n  // Date API.\n  // eslint-disable-next-line deprecation/deprecation\n  const navigationStart = performance.timing?.navigationStart;\n  const hasNavigationStart = typeof navigationStart === 'number';\n  // if navigationStart isn't available set delta to threshold so it isn't used\n  const navigationStartDelta = hasNavigationStart ? Math.abs(navigationStart + performanceNow - dateNow) : threshold;\n  const navigationStartIsReliable = navigationStartDelta < threshold;\n\n  if (timeOriginIsReliable || navigationStartIsReliable) {\n    // Use the more reliable time origin\n    if (timeOriginDelta <= navigationStartDelta) {\n      return [performance.timeOrigin, 'timeOrigin'];\n    } else {\n      return [navigationStart, 'navigationStart'];\n    }\n  }\n\n  // Either both timeOrigin and navigationStart are skewed or neither is available, fallback to Date.\n  return [dateNow, 'dateNow'];\n}\n\n/**\n * The number of milliseconds since the UNIX epoch. This value is only usable in a browser, and only when the\n * performance API is available.\n */\nfunction browserPerformanceTimeOrigin() {\n  if (!cachedTimeOrigin) {\n    cachedTimeOrigin = getBrowserTimeOrigin();\n  }\n\n  return cachedTimeOrigin[0];\n}\n\nexports.browserPerformanceTimeOrigin = browserPerformanceTimeOrigin;\nexports.dateTimestampInSeconds = dateTimestampInSeconds;\nexports.timestampInSeconds = timestampInSeconds;\n//# sourceMappingURL=time.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy90aW1lLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLGtCQUFrQixtQkFBTyxDQUFDLDZIQUFnQjs7QUFFMUM7O0FBRUE7QUFDQSxxREFBcUQ7QUFDckQ7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxVQUFVLGNBQWM7QUFDeEI7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLFVBQVUsY0FBYztBQUN4QjtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLE1BQU07QUFDTjtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQSxvQ0FBb0M7QUFDcEMsOEJBQThCO0FBQzlCLDBCQUEwQjtBQUMxQiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3V0aWxzL3RpbWUuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IHdvcmxkd2lkZSA9IHJlcXVpcmUoJy4vd29ybGR3aWRlLmpzJyk7XG5cbmNvbnN0IE9ORV9TRUNPTkRfSU5fTVMgPSAxMDAwO1xuXG4vKipcbiAqIEEgcGFydGlhbCBkZWZpbml0aW9uIG9mIHRoZSBbUGVyZm9ybWFuY2UgV2ViIEFQSV17QGxpbmsgaHR0cHM6Ly9kZXZlbG9wZXIubW96aWxsYS5vcmcvZW4tVVMvZG9jcy9XZWIvQVBJL1BlcmZvcm1hbmNlfVxuICogZm9yIGFjY2Vzc2luZyBhIGhpZ2gtcmVzb2x1dGlvbiBtb25vdG9uaWMgY2xvY2suXG4gKi9cblxuLyoqXG4gKiBSZXR1cm5zIGEgdGltZXN0YW1wIGluIHNlY29uZHMgc2luY2UgdGhlIFVOSVggZXBvY2ggdXNpbmcgdGhlIERhdGUgQVBJLlxuICovXG5mdW5jdGlvbiBkYXRlVGltZXN0YW1wSW5TZWNvbmRzKCkge1xuICByZXR1cm4gRGF0ZS5ub3coKSAvIE9ORV9TRUNPTkRfSU5fTVM7XG59XG5cbi8qKlxuICogUmV0dXJucyBhIHdyYXBwZXIgYXJvdW5kIHRoZSBuYXRpdmUgUGVyZm9ybWFuY2UgQVBJIGJyb3dzZXIgaW1wbGVtZW50YXRpb24sIG9yIHVuZGVmaW5lZCBmb3IgYnJvd3NlcnMgdGhhdCBkbyBub3RcbiAqIHN1cHBvcnQgdGhlIEFQSS5cbiAqXG4gKiBXcmFwcGluZyB0aGUgbmF0aXZlIEFQSSB3b3JrcyBhcm91bmQgZGlmZmVyZW5jZXMgaW4gYmVoYXZpb3IgZnJvbSBkaWZmZXJlbnQgYnJvd3NlcnMuXG4gKi9cbmZ1bmN0aW9uIGNyZWF0ZVVuaXhUaW1lc3RhbXBJblNlY29uZHNGdW5jKCkge1xuICBjb25zdCB7IHBlcmZvcm1hbmNlIH0gPSB3b3JsZHdpZGUuR0xPQkFMX09CSiA7XG4gIC8vIFNvbWUgYnJvd3NlciBhbmQgZW52aXJvbm1lbnRzIGRvbid0IGhhdmUgYSBwZXJmb3JtYW5jZSBvciB0aW1lT3JpZ2luLCBzbyB3ZSBmYWxsYmFjayB0b1xuICAvLyB1c2luZyBEYXRlLm5vdygpIHRvIGNvbXB1dGUgdGhlIHN0YXJ0aW5nIHRpbWUuXG4gIGlmICghcGVyZm9ybWFuY2U/Lm5vdyB8fCAhcGVyZm9ybWFuY2UudGltZU9yaWdpbikge1xuICAgIHJldHVybiBkYXRlVGltZXN0YW1wSW5TZWNvbmRzO1xuICB9XG5cbiAgY29uc3QgdGltZU9yaWdpbiA9IHBlcmZvcm1hbmNlLnRpbWVPcmlnaW47XG5cbiAgLy8gcGVyZm9ybWFuY2Uubm93KCkgaXMgYSBtb25vdG9uaWMgY2xvY2ssIHdoaWNoIG1lYW5zIGl0IHN0YXJ0cyBhdCAwIHdoZW4gdGhlIHByb2Nlc3MgYmVnaW5zLiBUbyBnZXQgdGhlIGN1cnJlbnRcbiAgLy8gd2FsbCBjbG9jayB0aW1lIChhY3R1YWwgVU5JWCB0aW1lc3RhbXApLCB3ZSBuZWVkIHRvIGFkZCB0aGUgc3RhcnRpbmcgdGltZSBvcmlnaW4gYW5kIHRoZSBjdXJyZW50IHRpbWUgZWxhcHNlZC5cbiAgLy9cbiAgLy8gVE9ETzogVGhpcyBkb2VzIG5vdCBhY2NvdW50IGZvciB0aGUgY2FzZSB3aGVyZSB0aGUgbW9ub3RvbmljIGNsb2NrIHRoYXQgcG93ZXJzIHBlcmZvcm1hbmNlLm5vdygpIGRyaWZ0cyBmcm9tIHRoZVxuICAvLyB3YWxsIGNsb2NrIHRpbWUsIHdoaWNoIGNhdXNlcyB0aGUgcmV0dXJuZWQgdGltZXN0YW1wIHRvIGJlIGluYWNjdXJhdGUuIFdlIHNob3VsZCBpbnZlc3RpZ2F0ZSBob3cgdG8gZGV0ZWN0IGFuZFxuICAvLyBjb3JyZWN0IGZvciB0aGlzLlxuICAvLyBTZWU6IGh0dHBzOi8vZ2l0aHViLmNvbS9nZXRzZW50cnkvc2VudHJ5LWphdmFzY3JpcHQvaXNzdWVzLzI1OTBcbiAgLy8gU2VlOiBodHRwczovL2dpdGh1Yi5jb20vbWRuL2NvbnRlbnQvaXNzdWVzLzQ3MTNcbiAgLy8gU2VlOiBodHRwczovL2Rldi50by9ub2Ftci93aGVuLWEtbWlsbGlzZWNvbmQtaXMtbm90LWEtbWlsbGlzZWNvbmQtM2g2XG4gIHJldHVybiAoKSA9PiB7XG4gICAgcmV0dXJuICh0aW1lT3JpZ2luICsgcGVyZm9ybWFuY2Uubm93KCkpIC8gT05FX1NFQ09ORF9JTl9NUztcbiAgfTtcbn1cblxubGV0IF9jYWNoZWRUaW1lc3RhbXBJblNlY29uZHM7XG5cbi8qKlxuICogUmV0dXJucyBhIHRpbWVzdGFtcCBpbiBzZWNvbmRzIHNpbmNlIHRoZSBVTklYIGVwb2NoIHVzaW5nIGVpdGhlciB0aGUgUGVyZm9ybWFuY2Ugb3IgRGF0ZSBBUElzLCBkZXBlbmRpbmcgb24gdGhlXG4gKiBhdmFpbGFiaWxpdHkgb2YgdGhlIFBlcmZvcm1hbmNlIEFQSS5cbiAqXG4gKiBCVUc6IE5vdGUgdGhhdCBiZWNhdXNlIG9mIGhvdyBicm93c2VycyBpbXBsZW1lbnQgdGhlIFBlcmZvcm1hbmNlIEFQSSwgdGhlIGNsb2NrIG1pZ2h0IHN0b3Agd2hlbiB0aGUgY29tcHV0ZXIgaXNcbiAqIGFzbGVlcC4gVGhpcyBjcmVhdGVzIGEgc2tldyBiZXR3ZWVuIGBkYXRlVGltZXN0YW1wSW5TZWNvbmRzYCBhbmQgYHRpbWVzdGFtcEluU2Vjb25kc2AuIFRoZVxuICogc2tldyBjYW4gZ3JvdyB0byBhcmJpdHJhcnkgYW1vdW50cyBsaWtlIGRheXMsIHdlZWtzIG9yIG1vbnRocy5cbiAqIFNlZSBodHRwczovL2dpdGh1Yi5jb20vZ2V0c2VudHJ5L3NlbnRyeS1qYXZhc2NyaXB0L2lzc3Vlcy8yNTkwLlxuICovXG5mdW5jdGlvbiB0aW1lc3RhbXBJblNlY29uZHMoKSB7XG4gIC8vIFdlIHN0b3JlIHRoaXMgaW4gYSBjbG9zdXJlIHNvIHRoYXQgd2UgZG9uJ3QgaGF2ZSB0byBjcmVhdGUgYSBuZXcgZnVuY3Rpb24gZXZlcnkgdGltZSB0aGlzIGlzIGNhbGxlZC5cbiAgY29uc3QgZnVuYyA9IF9jYWNoZWRUaW1lc3RhbXBJblNlY29uZHMgPz8gKF9jYWNoZWRUaW1lc3RhbXBJblNlY29uZHMgPSBjcmVhdGVVbml4VGltZXN0YW1wSW5TZWNvbmRzRnVuYygpKTtcbiAgcmV0dXJuIGZ1bmMoKTtcbn1cblxuLyoqXG4gKiBDYWNoZWQgcmVzdWx0IG9mIGdldEJyb3dzZXJUaW1lT3JpZ2luLlxuICovXG5sZXQgY2FjaGVkVGltZU9yaWdpbjtcblxuLyoqXG4gKiBHZXRzIHRoZSB0aW1lIG9yaWdpbiBhbmQgdGhlIG1vZGUgdXNlZCB0byBkZXRlcm1pbmUgaXQuXG4gKi9cbmZ1bmN0aW9uIGdldEJyb3dzZXJUaW1lT3JpZ2luKCkge1xuICAvLyBVbmZvcnR1bmF0ZWx5IGJyb3dzZXJzIG1heSByZXBvcnQgYW4gaW5hY2N1cmF0ZSB0aW1lIG9yaWdpbiBkYXRhLCB0aHJvdWdoIGVpdGhlciBwZXJmb3JtYW5jZS50aW1lT3JpZ2luIG9yXG4gIC8vIHBlcmZvcm1hbmNlLnRpbWluZy5uYXZpZ2F0aW9uU3RhcnQsIHdoaWNoIHJlc3VsdHMgaW4gcG9vciByZXN1bHRzIGluIHBlcmZvcm1hbmNlIGRhdGEuIFdlIG9ubHkgdHJlYXQgdGltZSBvcmlnaW5cbiAgLy8gZGF0YSBhcyByZWxpYWJsZSBpZiB0aGV5IGFyZSB3aXRoaW4gYSByZWFzb25hYmxlIHRocmVzaG9sZCBvZiB0aGUgY3VycmVudCB0aW1lLlxuXG4gIGNvbnN0IHsgcGVyZm9ybWFuY2UgfSA9IHdvcmxkd2lkZS5HTE9CQUxfT0JKIDtcbiAgaWYgKCFwZXJmb3JtYW5jZT8ubm93KSB7XG4gICAgcmV0dXJuIFt1bmRlZmluZWQsICdub25lJ107XG4gIH1cblxuICBjb25zdCB0aHJlc2hvbGQgPSAzNjAwICogMTAwMDtcbiAgY29uc3QgcGVyZm9ybWFuY2VOb3cgPSBwZXJmb3JtYW5jZS5ub3coKTtcbiAgY29uc3QgZGF0ZU5vdyA9IERhdGUubm93KCk7XG5cbiAgLy8gaWYgdGltZU9yaWdpbiBpc24ndCBhdmFpbGFibGUgc2V0IGRlbHRhIHRvIHRocmVzaG9sZCBzbyBpdCBpc24ndCB1c2VkXG4gIGNvbnN0IHRpbWVPcmlnaW5EZWx0YSA9IHBlcmZvcm1hbmNlLnRpbWVPcmlnaW5cbiAgICA/IE1hdGguYWJzKHBlcmZvcm1hbmNlLnRpbWVPcmlnaW4gKyBwZXJmb3JtYW5jZU5vdyAtIGRhdGVOb3cpXG4gICAgOiB0aHJlc2hvbGQ7XG4gIGNvbnN0IHRpbWVPcmlnaW5Jc1JlbGlhYmxlID0gdGltZU9yaWdpbkRlbHRhIDwgdGhyZXNob2xkO1xuXG4gIC8vIFdoaWxlIHBlcmZvcm1hbmNlLnRpbWluZy5uYXZpZ2F0aW9uU3RhcnQgaXMgZGVwcmVjYXRlZCBpbiBmYXZvciBvZiBwZXJmb3JtYW5jZS50aW1lT3JpZ2luLCBwZXJmb3JtYW5jZS50aW1lT3JpZ2luXG4gIC8vIGlzIG5vdCBhcyB3aWRlbHkgc3VwcG9ydGVkLiBOYW1lbHksIHBlcmZvcm1hbmNlLnRpbWVPcmlnaW4gaXMgdW5kZWZpbmVkIGluIFNhZmFyaSBhcyBvZiB3cml0aW5nLlxuICAvLyBBbHNvIGFzIG9mIHdyaXRpbmcsIHBlcmZvcm1hbmNlLnRpbWluZyBpcyBub3QgYXZhaWxhYmxlIGluIFdlYiBXb3JrZXJzIGluIG1haW5zdHJlYW0gYnJvd3NlcnMsIHNvIGl0IGlzIG5vdCBhbHdheXNcbiAgLy8gYSB2YWxpZCBmYWxsYmFjay4gSW4gdGhlIGFic2VuY2Ugb2YgYW4gaW5pdGlhbCB0aW1lIHByb3ZpZGVkIGJ5IHRoZSBicm93c2VyLCBmYWxsYmFjayB0byB0aGUgY3VycmVudCB0aW1lIGZyb20gdGhlXG4gIC8vIERhdGUgQVBJLlxuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgZGVwcmVjYXRpb24vZGVwcmVjYXRpb25cbiAgY29uc3QgbmF2aWdhdGlvblN0YXJ0ID0gcGVyZm9ybWFuY2UudGltaW5nPy5uYXZpZ2F0aW9uU3RhcnQ7XG4gIGNvbnN0IGhhc05hdmlnYXRpb25TdGFydCA9IHR5cGVvZiBuYXZpZ2F0aW9uU3RhcnQgPT09ICdudW1iZXInO1xuICAvLyBpZiBuYXZpZ2F0aW9uU3RhcnQgaXNuJ3QgYXZhaWxhYmxlIHNldCBkZWx0YSB0byB0aHJlc2hvbGQgc28gaXQgaXNuJ3QgdXNlZFxuICBjb25zdCBuYXZpZ2F0aW9uU3RhcnREZWx0YSA9IGhhc05hdmlnYXRpb25TdGFydCA/IE1hdGguYWJzKG5hdmlnYXRpb25TdGFydCArIHBlcmZvcm1hbmNlTm93IC0gZGF0ZU5vdykgOiB0aHJlc2hvbGQ7XG4gIGNvbnN0IG5hdmlnYXRpb25TdGFydElzUmVsaWFibGUgPSBuYXZpZ2F0aW9uU3RhcnREZWx0YSA8IHRocmVzaG9sZDtcblxuICBpZiAodGltZU9yaWdpbklzUmVsaWFibGUgfHwgbmF2aWdhdGlvblN0YXJ0SXNSZWxpYWJsZSkge1xuICAgIC8vIFVzZSB0aGUgbW9yZSByZWxpYWJsZSB0aW1lIG9yaWdpblxuICAgIGlmICh0aW1lT3JpZ2luRGVsdGEgPD0gbmF2aWdhdGlvblN0YXJ0RGVsdGEpIHtcbiAgICAgIHJldHVybiBbcGVyZm9ybWFuY2UudGltZU9yaWdpbiwgJ3RpbWVPcmlnaW4nXTtcbiAgICB9IGVsc2Uge1xuICAgICAgcmV0dXJuIFtuYXZpZ2F0aW9uU3RhcnQsICduYXZpZ2F0aW9uU3RhcnQnXTtcbiAgICB9XG4gIH1cblxuICAvLyBFaXRoZXIgYm90aCB0aW1lT3JpZ2luIGFuZCBuYXZpZ2F0aW9uU3RhcnQgYXJlIHNrZXdlZCBvciBuZWl0aGVyIGlzIGF2YWlsYWJsZSwgZmFsbGJhY2sgdG8gRGF0ZS5cbiAgcmV0dXJuIFtkYXRlTm93LCAnZGF0ZU5vdyddO1xufVxuXG4vKipcbiAqIFRoZSBudW1iZXIgb2YgbWlsbGlzZWNvbmRzIHNpbmNlIHRoZSBVTklYIGVwb2NoLiBUaGlzIHZhbHVlIGlzIG9ubHkgdXNhYmxlIGluIGEgYnJvd3NlciwgYW5kIG9ubHkgd2hlbiB0aGVcbiAqIHBlcmZvcm1hbmNlIEFQSSBpcyBhdmFpbGFibGUuXG4gKi9cbmZ1bmN0aW9uIGJyb3dzZXJQZXJmb3JtYW5jZVRpbWVPcmlnaW4oKSB7XG4gIGlmICghY2FjaGVkVGltZU9yaWdpbikge1xuICAgIGNhY2hlZFRpbWVPcmlnaW4gPSBnZXRCcm93c2VyVGltZU9yaWdpbigpO1xuICB9XG5cbiAgcmV0dXJuIGNhY2hlZFRpbWVPcmlnaW5bMF07XG59XG5cbmV4cG9ydHMuYnJvd3NlclBlcmZvcm1hbmNlVGltZU9yaWdpbiA9IGJyb3dzZXJQZXJmb3JtYW5jZVRpbWVPcmlnaW47XG5leHBvcnRzLmRhdGVUaW1lc3RhbXBJblNlY29uZHMgPSBkYXRlVGltZXN0YW1wSW5TZWNvbmRzO1xuZXhwb3J0cy50aW1lc3RhbXBJblNlY29uZHMgPSB0aW1lc3RhbXBJblNlY29uZHM7XG4vLyMgc291cmNlTWFwcGluZ1VSTD10aW1lLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/time.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/traceData.js":
/*!*******************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/traceData.js ***!
  \*******************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst index = __webpack_require__(/*! ../asyncContext/index.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/asyncContext/index.js\");\nconst carrier = __webpack_require__(/*! ../carrier.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/carrier.js\");\nconst currentScopes = __webpack_require__(/*! ../currentScopes.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst exports$1 = __webpack_require__(/*! ../exports.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/exports.js\");\nconst debugLogger = __webpack_require__(/*! ./debug-logger.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst spanUtils = __webpack_require__(/*! ./spanUtils.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanUtils.js\");\nconst dynamicSamplingContext = __webpack_require__(/*! ../tracing/dynamicSamplingContext.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/dynamicSamplingContext.js\");\nconst tracing = __webpack_require__(/*! ./tracing.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/tracing.js\");\nconst baggage = __webpack_require__(/*! ./baggage.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/baggage.js\");\n\n/**\n * Extracts trace propagation data from the current span or from the client's scope (via transaction or propagation\n * context) and serializes it to `sentry-trace` and `baggage` values to strings. These values can be used to propagate\n * a trace via our tracing Http headers or Html `<meta>` tags.\n *\n * This function also applies some validation to the generated sentry-trace and baggage values to ensure that\n * only valid strings are returned.\n *\n * @returns an object with the tracing data values. The object keys are the name of the tracing key to be used as header\n * or meta tag name.\n */\nfunction getTraceData(options = {}) {\n  const client = options.client || currentScopes.getClient();\n  if (!exports$1.isEnabled() || !client) {\n    return {};\n  }\n\n  const carrier$1 = carrier.getMainCarrier();\n  const acs = index.getAsyncContextStrategy(carrier$1);\n  if (acs.getTraceData) {\n    return acs.getTraceData(options);\n  }\n\n  const scope = options.scope || currentScopes.getCurrentScope();\n  const span = options.span || spanUtils.getActiveSpan();\n  const sentryTrace = span ? spanUtils.spanToTraceHeader(span) : scopeToTraceHeader(scope);\n  const dsc = span ? dynamicSamplingContext.getDynamicSamplingContextFromSpan(span) : dynamicSamplingContext.getDynamicSamplingContextFromScope(client, scope);\n  const baggage$1 = baggage.dynamicSamplingContextToSentryBaggageHeader(dsc);\n\n  const isValidSentryTraceHeader = tracing.TRACEPARENT_REGEXP.test(sentryTrace);\n  if (!isValidSentryTraceHeader) {\n    debugLogger.debug.warn('Invalid sentry-trace data. Cannot generate trace data');\n    return {};\n  }\n\n  return {\n    'sentry-trace': sentryTrace,\n    baggage: baggage$1,\n  };\n}\n\n/**\n * Get a sentry-trace header value for the given scope.\n */\nfunction scopeToTraceHeader(scope) {\n  const { traceId, sampled, propagationSpanId } = scope.getPropagationContext();\n  return tracing.generateSentryTraceHeader(traceId, propagationSpanId, sampled);\n}\n\nexports.getTraceData = getTraceData;\n//# sourceMappingURL=traceData.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy90cmFjZURhdGEuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsY0FBYyxtQkFBTyxDQUFDLDBJQUEwQjtBQUNoRCxnQkFBZ0IsbUJBQU8sQ0FBQyxvSEFBZTtBQUN2QyxzQkFBc0IsbUJBQU8sQ0FBQyxnSUFBcUI7QUFDbkQsa0JBQWtCLG1CQUFPLENBQUMsb0hBQWU7QUFDekMsb0JBQW9CLG1CQUFPLENBQUMsbUlBQW1CO0FBQy9DLGtCQUFrQixtQkFBTyxDQUFDLDZIQUFnQjtBQUMxQywrQkFBK0IsbUJBQU8sQ0FBQyxrS0FBc0M7QUFDN0UsZ0JBQWdCLG1CQUFPLENBQUMseUhBQWM7QUFDdEMsZ0JBQWdCLG1CQUFPLENBQUMseUhBQWM7O0FBRXRDO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxrQ0FBa0M7QUFDbEM7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFVBQVUsc0NBQXNDO0FBQ2hEO0FBQ0E7O0FBRUEsb0JBQW9CO0FBQ3BCIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvdHJhY2VEYXRhLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBpbmRleCA9IHJlcXVpcmUoJy4uL2FzeW5jQ29udGV4dC9pbmRleC5qcycpO1xuY29uc3QgY2FycmllciA9IHJlcXVpcmUoJy4uL2NhcnJpZXIuanMnKTtcbmNvbnN0IGN1cnJlbnRTY29wZXMgPSByZXF1aXJlKCcuLi9jdXJyZW50U2NvcGVzLmpzJyk7XG5jb25zdCBleHBvcnRzJDEgPSByZXF1aXJlKCcuLi9leHBvcnRzLmpzJyk7XG5jb25zdCBkZWJ1Z0xvZ2dlciA9IHJlcXVpcmUoJy4vZGVidWctbG9nZ2VyLmpzJyk7XG5jb25zdCBzcGFuVXRpbHMgPSByZXF1aXJlKCcuL3NwYW5VdGlscy5qcycpO1xuY29uc3QgZHluYW1pY1NhbXBsaW5nQ29udGV4dCA9IHJlcXVpcmUoJy4uL3RyYWNpbmcvZHluYW1pY1NhbXBsaW5nQ29udGV4dC5qcycpO1xuY29uc3QgdHJhY2luZyA9IHJlcXVpcmUoJy4vdHJhY2luZy5qcycpO1xuY29uc3QgYmFnZ2FnZSA9IHJlcXVpcmUoJy4vYmFnZ2FnZS5qcycpO1xuXG4vKipcbiAqIEV4dHJhY3RzIHRyYWNlIHByb3BhZ2F0aW9uIGRhdGEgZnJvbSB0aGUgY3VycmVudCBzcGFuIG9yIGZyb20gdGhlIGNsaWVudCdzIHNjb3BlICh2aWEgdHJhbnNhY3Rpb24gb3IgcHJvcGFnYXRpb25cbiAqIGNvbnRleHQpIGFuZCBzZXJpYWxpemVzIGl0IHRvIGBzZW50cnktdHJhY2VgIGFuZCBgYmFnZ2FnZWAgdmFsdWVzIHRvIHN0cmluZ3MuIFRoZXNlIHZhbHVlcyBjYW4gYmUgdXNlZCB0byBwcm9wYWdhdGVcbiAqIGEgdHJhY2UgdmlhIG91ciB0cmFjaW5nIEh0dHAgaGVhZGVycyBvciBIdG1sIGA8bWV0YT5gIHRhZ3MuXG4gKlxuICogVGhpcyBmdW5jdGlvbiBhbHNvIGFwcGxpZXMgc29tZSB2YWxpZGF0aW9uIHRvIHRoZSBnZW5lcmF0ZWQgc2VudHJ5LXRyYWNlIGFuZCBiYWdnYWdlIHZhbHVlcyB0byBlbnN1cmUgdGhhdFxuICogb25seSB2YWxpZCBzdHJpbmdzIGFyZSByZXR1cm5lZC5cbiAqXG4gKiBAcmV0dXJucyBhbiBvYmplY3Qgd2l0aCB0aGUgdHJhY2luZyBkYXRhIHZhbHVlcy4gVGhlIG9iamVjdCBrZXlzIGFyZSB0aGUgbmFtZSBvZiB0aGUgdHJhY2luZyBrZXkgdG8gYmUgdXNlZCBhcyBoZWFkZXJcbiAqIG9yIG1ldGEgdGFnIG5hbWUuXG4gKi9cbmZ1bmN0aW9uIGdldFRyYWNlRGF0YShvcHRpb25zID0ge30pIHtcbiAgY29uc3QgY2xpZW50ID0gb3B0aW9ucy5jbGllbnQgfHwgY3VycmVudFNjb3Blcy5nZXRDbGllbnQoKTtcbiAgaWYgKCFleHBvcnRzJDEuaXNFbmFibGVkKCkgfHwgIWNsaWVudCkge1xuICAgIHJldHVybiB7fTtcbiAgfVxuXG4gIGNvbnN0IGNhcnJpZXIkMSA9IGNhcnJpZXIuZ2V0TWFpbkNhcnJpZXIoKTtcbiAgY29uc3QgYWNzID0gaW5kZXguZ2V0QXN5bmNDb250ZXh0U3RyYXRlZ3koY2FycmllciQxKTtcbiAgaWYgKGFjcy5nZXRUcmFjZURhdGEpIHtcbiAgICByZXR1cm4gYWNzLmdldFRyYWNlRGF0YShvcHRpb25zKTtcbiAgfVxuXG4gIGNvbnN0IHNjb3BlID0gb3B0aW9ucy5zY29wZSB8fCBjdXJyZW50U2NvcGVzLmdldEN1cnJlbnRTY29wZSgpO1xuICBjb25zdCBzcGFuID0gb3B0aW9ucy5zcGFuIHx8IHNwYW5VdGlscy5nZXRBY3RpdmVTcGFuKCk7XG4gIGNvbnN0IHNlbnRyeVRyYWNlID0gc3BhbiA/IHNwYW5VdGlscy5zcGFuVG9UcmFjZUhlYWRlcihzcGFuKSA6IHNjb3BlVG9UcmFjZUhlYWRlcihzY29wZSk7XG4gIGNvbnN0IGRzYyA9IHNwYW4gPyBkeW5hbWljU2FtcGxpbmdDb250ZXh0LmdldER5bmFtaWNTYW1wbGluZ0NvbnRleHRGcm9tU3BhbihzcGFuKSA6IGR5bmFtaWNTYW1wbGluZ0NvbnRleHQuZ2V0RHluYW1pY1NhbXBsaW5nQ29udGV4dEZyb21TY29wZShjbGllbnQsIHNjb3BlKTtcbiAgY29uc3QgYmFnZ2FnZSQxID0gYmFnZ2FnZS5keW5hbWljU2FtcGxpbmdDb250ZXh0VG9TZW50cnlCYWdnYWdlSGVhZGVyKGRzYyk7XG5cbiAgY29uc3QgaXNWYWxpZFNlbnRyeVRyYWNlSGVhZGVyID0gdHJhY2luZy5UUkFDRVBBUkVOVF9SRUdFWFAudGVzdChzZW50cnlUcmFjZSk7XG4gIGlmICghaXNWYWxpZFNlbnRyeVRyYWNlSGVhZGVyKSB7XG4gICAgZGVidWdMb2dnZXIuZGVidWcud2FybignSW52YWxpZCBzZW50cnktdHJhY2UgZGF0YS4gQ2Fubm90IGdlbmVyYXRlIHRyYWNlIGRhdGEnKTtcbiAgICByZXR1cm4ge307XG4gIH1cblxuICByZXR1cm4ge1xuICAgICdzZW50cnktdHJhY2UnOiBzZW50cnlUcmFjZSxcbiAgICBiYWdnYWdlOiBiYWdnYWdlJDEsXG4gIH07XG59XG5cbi8qKlxuICogR2V0IGEgc2VudHJ5LXRyYWNlIGhlYWRlciB2YWx1ZSBmb3IgdGhlIGdpdmVuIHNjb3BlLlxuICovXG5mdW5jdGlvbiBzY29wZVRvVHJhY2VIZWFkZXIoc2NvcGUpIHtcbiAgY29uc3QgeyB0cmFjZUlkLCBzYW1wbGVkLCBwcm9wYWdhdGlvblNwYW5JZCB9ID0gc2NvcGUuZ2V0UHJvcGFnYXRpb25Db250ZXh0KCk7XG4gIHJldHVybiB0cmFjaW5nLmdlbmVyYXRlU2VudHJ5VHJhY2VIZWFkZXIodHJhY2VJZCwgcHJvcGFnYXRpb25TcGFuSWQsIHNhbXBsZWQpO1xufVxuXG5leHBvcnRzLmdldFRyYWNlRGF0YSA9IGdldFRyYWNlRGF0YTtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPXRyYWNlRGF0YS5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/traceData.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/tracing.js":
/*!*****************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/tracing.js ***!
  \*****************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst baggage = __webpack_require__(/*! ./baggage.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/baggage.js\");\nconst parseSampleRate = __webpack_require__(/*! ./parseSampleRate.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/parseSampleRate.js\");\nconst propagationContext = __webpack_require__(/*! ./propagationContext.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/propagationContext.js\");\n\n// eslint-disable-next-line @sentry-internal/sdk/no-regexp-constructor -- RegExp is used for readability here\nconst TRACEPARENT_REGEXP = new RegExp(\n  '^[ \\\\t]*' + // whitespace\n    '([0-9a-f]{32})?' + // trace_id\n    '-?([0-9a-f]{16})?' + // span_id\n    '-?([01])?' + // sampled\n    '[ \\\\t]*$', // whitespace\n);\n\n/**\n * Extract transaction context data from a `sentry-trace` header.\n *\n * @param traceparent Traceparent string\n *\n * @returns Object containing data from the header, or undefined if traceparent string is malformed\n */\nfunction extractTraceparentData(traceparent) {\n  if (!traceparent) {\n    return undefined;\n  }\n\n  const matches = traceparent.match(TRACEPARENT_REGEXP);\n  if (!matches) {\n    return undefined;\n  }\n\n  let parentSampled;\n  if (matches[3] === '1') {\n    parentSampled = true;\n  } else if (matches[3] === '0') {\n    parentSampled = false;\n  }\n\n  return {\n    traceId: matches[1],\n    parentSampled,\n    parentSpanId: matches[2],\n  };\n}\n\n/**\n * Create a propagation context from incoming headers or\n * creates a minimal new one if the headers are undefined.\n */\nfunction propagationContextFromHeaders(\n  sentryTrace,\n  baggage$1,\n) {\n  const traceparentData = extractTraceparentData(sentryTrace);\n  const dynamicSamplingContext = baggage.baggageHeaderToDynamicSamplingContext(baggage$1);\n\n  if (!traceparentData?.traceId) {\n    return {\n      traceId: propagationContext.generateTraceId(),\n      sampleRand: Math.random(),\n    };\n  }\n\n  const sampleRand = getSampleRandFromTraceparentAndDsc(traceparentData, dynamicSamplingContext);\n\n  // The sample_rand on the DSC needs to be generated based on traceparent + baggage.\n  if (dynamicSamplingContext) {\n    dynamicSamplingContext.sample_rand = sampleRand.toString();\n  }\n\n  const { traceId, parentSpanId, parentSampled } = traceparentData;\n\n  return {\n    traceId,\n    parentSpanId,\n    sampled: parentSampled,\n    dsc: dynamicSamplingContext || {}, // If we have traceparent data but no DSC it means we are not head of trace and we must freeze it\n    sampleRand,\n  };\n}\n\n/**\n * Create sentry-trace header from span context values.\n */\nfunction generateSentryTraceHeader(\n  traceId = propagationContext.generateTraceId(),\n  spanId = propagationContext.generateSpanId(),\n  sampled,\n) {\n  let sampledString = '';\n  if (sampled !== undefined) {\n    sampledString = sampled ? '-1' : '-0';\n  }\n  return `${traceId}-${spanId}${sampledString}`;\n}\n\n/**\n * Given any combination of an incoming trace, generate a sample rand based on its defined semantics.\n *\n * Read more: https://develop.sentry.dev/sdk/telemetry/traces/#propagated-random-value\n */\nfunction getSampleRandFromTraceparentAndDsc(\n  traceparentData,\n  dsc,\n) {\n  // When there is an incoming sample rand use it.\n  const parsedSampleRand = parseSampleRate.parseSampleRate(dsc?.sample_rand);\n  if (parsedSampleRand !== undefined) {\n    return parsedSampleRand;\n  }\n\n  // Otherwise, if there is an incoming sampling decision + sample rate, generate a sample rand that would lead to the same sampling decision.\n  const parsedSampleRate = parseSampleRate.parseSampleRate(dsc?.sample_rate);\n  if (parsedSampleRate && traceparentData?.parentSampled !== undefined) {\n    return traceparentData.parentSampled\n      ? // Returns a sample rand with positive sampling decision [0, sampleRate)\n        Math.random() * parsedSampleRate\n      : // Returns a sample rand with negative sampling decision [sampleRate, 1)\n        parsedSampleRate + Math.random() * (1 - parsedSampleRate);\n  } else {\n    // If nothing applies, return a random sample rand.\n    return Math.random();\n  }\n}\n\nexports.TRACEPARENT_REGEXP = TRACEPARENT_REGEXP;\nexports.extractTraceparentData = extractTraceparentData;\nexports.generateSentryTraceHeader = generateSentryTraceHeader;\nexports.propagationContextFromHeaders = propagationContextFromHeaders;\n//# sourceMappingURL=tracing.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy90cmFjaW5nLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLGdCQUFnQixtQkFBTyxDQUFDLHlIQUFjO0FBQ3RDLHdCQUF3QixtQkFBTyxDQUFDLHlJQUFzQjtBQUN0RCwyQkFBMkIsbUJBQU8sQ0FBQywrSUFBeUI7O0FBRTVEO0FBQ0E7QUFDQTtBQUNBLGVBQWUsR0FBRztBQUNsQixpQkFBaUIsR0FBRztBQUNwQjtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQSxJQUFJO0FBQ0o7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLFVBQVUsdUNBQXVDOztBQUVqRDtBQUNBO0FBQ0E7QUFDQTtBQUNBLHFDQUFxQztBQUNyQztBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsWUFBWSxRQUFRLEdBQUcsT0FBTyxFQUFFLGNBQWM7QUFDOUM7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsSUFBSTtBQUNKO0FBQ0E7QUFDQTtBQUNBOztBQUVBLDBCQUEwQjtBQUMxQiw4QkFBOEI7QUFDOUIsaUNBQWlDO0FBQ2pDLHFDQUFxQztBQUNyQyIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3V0aWxzL3RyYWNpbmcuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGJhZ2dhZ2UgPSByZXF1aXJlKCcuL2JhZ2dhZ2UuanMnKTtcbmNvbnN0IHBhcnNlU2FtcGxlUmF0ZSA9IHJlcXVpcmUoJy4vcGFyc2VTYW1wbGVSYXRlLmpzJyk7XG5jb25zdCBwcm9wYWdhdGlvbkNvbnRleHQgPSByZXF1aXJlKCcuL3Byb3BhZ2F0aW9uQ29udGV4dC5qcycpO1xuXG4vLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHNlbnRyeS1pbnRlcm5hbC9zZGsvbm8tcmVnZXhwLWNvbnN0cnVjdG9yIC0tIFJlZ0V4cCBpcyB1c2VkIGZvciByZWFkYWJpbGl0eSBoZXJlXG5jb25zdCBUUkFDRVBBUkVOVF9SRUdFWFAgPSBuZXcgUmVnRXhwKFxuICAnXlsgXFxcXHRdKicgKyAvLyB3aGl0ZXNwYWNlXG4gICAgJyhbMC05YS1mXXszMn0pPycgKyAvLyB0cmFjZV9pZFxuICAgICctPyhbMC05YS1mXXsxNn0pPycgKyAvLyBzcGFuX2lkXG4gICAgJy0/KFswMV0pPycgKyAvLyBzYW1wbGVkXG4gICAgJ1sgXFxcXHRdKiQnLCAvLyB3aGl0ZXNwYWNlXG4pO1xuXG4vKipcbiAqIEV4dHJhY3QgdHJhbnNhY3Rpb24gY29udGV4dCBkYXRhIGZyb20gYSBgc2VudHJ5LXRyYWNlYCBoZWFkZXIuXG4gKlxuICogQHBhcmFtIHRyYWNlcGFyZW50IFRyYWNlcGFyZW50IHN0cmluZ1xuICpcbiAqIEByZXR1cm5zIE9iamVjdCBjb250YWluaW5nIGRhdGEgZnJvbSB0aGUgaGVhZGVyLCBvciB1bmRlZmluZWQgaWYgdHJhY2VwYXJlbnQgc3RyaW5nIGlzIG1hbGZvcm1lZFxuICovXG5mdW5jdGlvbiBleHRyYWN0VHJhY2VwYXJlbnREYXRhKHRyYWNlcGFyZW50KSB7XG4gIGlmICghdHJhY2VwYXJlbnQpIHtcbiAgICByZXR1cm4gdW5kZWZpbmVkO1xuICB9XG5cbiAgY29uc3QgbWF0Y2hlcyA9IHRyYWNlcGFyZW50Lm1hdGNoKFRSQUNFUEFSRU5UX1JFR0VYUCk7XG4gIGlmICghbWF0Y2hlcykge1xuICAgIHJldHVybiB1bmRlZmluZWQ7XG4gIH1cblxuICBsZXQgcGFyZW50U2FtcGxlZDtcbiAgaWYgKG1hdGNoZXNbM10gPT09ICcxJykge1xuICAgIHBhcmVudFNhbXBsZWQgPSB0cnVlO1xuICB9IGVsc2UgaWYgKG1hdGNoZXNbM10gPT09ICcwJykge1xuICAgIHBhcmVudFNhbXBsZWQgPSBmYWxzZTtcbiAgfVxuXG4gIHJldHVybiB7XG4gICAgdHJhY2VJZDogbWF0Y2hlc1sxXSxcbiAgICBwYXJlbnRTYW1wbGVkLFxuICAgIHBhcmVudFNwYW5JZDogbWF0Y2hlc1syXSxcbiAgfTtcbn1cblxuLyoqXG4gKiBDcmVhdGUgYSBwcm9wYWdhdGlvbiBjb250ZXh0IGZyb20gaW5jb21pbmcgaGVhZGVycyBvclxuICogY3JlYXRlcyBhIG1pbmltYWwgbmV3IG9uZSBpZiB0aGUgaGVhZGVycyBhcmUgdW5kZWZpbmVkLlxuICovXG5mdW5jdGlvbiBwcm9wYWdhdGlvbkNvbnRleHRGcm9tSGVhZGVycyhcbiAgc2VudHJ5VHJhY2UsXG4gIGJhZ2dhZ2UkMSxcbikge1xuICBjb25zdCB0cmFjZXBhcmVudERhdGEgPSBleHRyYWN0VHJhY2VwYXJlbnREYXRhKHNlbnRyeVRyYWNlKTtcbiAgY29uc3QgZHluYW1pY1NhbXBsaW5nQ29udGV4dCA9IGJhZ2dhZ2UuYmFnZ2FnZUhlYWRlclRvRHluYW1pY1NhbXBsaW5nQ29udGV4dChiYWdnYWdlJDEpO1xuXG4gIGlmICghdHJhY2VwYXJlbnREYXRhPy50cmFjZUlkKSB7XG4gICAgcmV0dXJuIHtcbiAgICAgIHRyYWNlSWQ6IHByb3BhZ2F0aW9uQ29udGV4dC5nZW5lcmF0ZVRyYWNlSWQoKSxcbiAgICAgIHNhbXBsZVJhbmQ6IE1hdGgucmFuZG9tKCksXG4gICAgfTtcbiAgfVxuXG4gIGNvbnN0IHNhbXBsZVJhbmQgPSBnZXRTYW1wbGVSYW5kRnJvbVRyYWNlcGFyZW50QW5kRHNjKHRyYWNlcGFyZW50RGF0YSwgZHluYW1pY1NhbXBsaW5nQ29udGV4dCk7XG5cbiAgLy8gVGhlIHNhbXBsZV9yYW5kIG9uIHRoZSBEU0MgbmVlZHMgdG8gYmUgZ2VuZXJhdGVkIGJhc2VkIG9uIHRyYWNlcGFyZW50ICsgYmFnZ2FnZS5cbiAgaWYgKGR5bmFtaWNTYW1wbGluZ0NvbnRleHQpIHtcbiAgICBkeW5hbWljU2FtcGxpbmdDb250ZXh0LnNhbXBsZV9yYW5kID0gc2FtcGxlUmFuZC50b1N0cmluZygpO1xuICB9XG5cbiAgY29uc3QgeyB0cmFjZUlkLCBwYXJlbnRTcGFuSWQsIHBhcmVudFNhbXBsZWQgfSA9IHRyYWNlcGFyZW50RGF0YTtcblxuICByZXR1cm4ge1xuICAgIHRyYWNlSWQsXG4gICAgcGFyZW50U3BhbklkLFxuICAgIHNhbXBsZWQ6IHBhcmVudFNhbXBsZWQsXG4gICAgZHNjOiBkeW5hbWljU2FtcGxpbmdDb250ZXh0IHx8IHt9LCAvLyBJZiB3ZSBoYXZlIHRyYWNlcGFyZW50IGRhdGEgYnV0IG5vIERTQyBpdCBtZWFucyB3ZSBhcmUgbm90IGhlYWQgb2YgdHJhY2UgYW5kIHdlIG11c3QgZnJlZXplIGl0XG4gICAgc2FtcGxlUmFuZCxcbiAgfTtcbn1cblxuLyoqXG4gKiBDcmVhdGUgc2VudHJ5LXRyYWNlIGhlYWRlciBmcm9tIHNwYW4gY29udGV4dCB2YWx1ZXMuXG4gKi9cbmZ1bmN0aW9uIGdlbmVyYXRlU2VudHJ5VHJhY2VIZWFkZXIoXG4gIHRyYWNlSWQgPSBwcm9wYWdhdGlvbkNvbnRleHQuZ2VuZXJhdGVUcmFjZUlkKCksXG4gIHNwYW5JZCA9IHByb3BhZ2F0aW9uQ29udGV4dC5nZW5lcmF0ZVNwYW5JZCgpLFxuICBzYW1wbGVkLFxuKSB7XG4gIGxldCBzYW1wbGVkU3RyaW5nID0gJyc7XG4gIGlmIChzYW1wbGVkICE9PSB1bmRlZmluZWQpIHtcbiAgICBzYW1wbGVkU3RyaW5nID0gc2FtcGxlZCA/ICctMScgOiAnLTAnO1xuICB9XG4gIHJldHVybiBgJHt0cmFjZUlkfS0ke3NwYW5JZH0ke3NhbXBsZWRTdHJpbmd9YDtcbn1cblxuLyoqXG4gKiBHaXZlbiBhbnkgY29tYmluYXRpb24gb2YgYW4gaW5jb21pbmcgdHJhY2UsIGdlbmVyYXRlIGEgc2FtcGxlIHJhbmQgYmFzZWQgb24gaXRzIGRlZmluZWQgc2VtYW50aWNzLlxuICpcbiAqIFJlYWQgbW9yZTogaHR0cHM6Ly9kZXZlbG9wLnNlbnRyeS5kZXYvc2RrL3RlbGVtZXRyeS90cmFjZXMvI3Byb3BhZ2F0ZWQtcmFuZG9tLXZhbHVlXG4gKi9cbmZ1bmN0aW9uIGdldFNhbXBsZVJhbmRGcm9tVHJhY2VwYXJlbnRBbmREc2MoXG4gIHRyYWNlcGFyZW50RGF0YSxcbiAgZHNjLFxuKSB7XG4gIC8vIFdoZW4gdGhlcmUgaXMgYW4gaW5jb21pbmcgc2FtcGxlIHJhbmQgdXNlIGl0LlxuICBjb25zdCBwYXJzZWRTYW1wbGVSYW5kID0gcGFyc2VTYW1wbGVSYXRlLnBhcnNlU2FtcGxlUmF0ZShkc2M/LnNhbXBsZV9yYW5kKTtcbiAgaWYgKHBhcnNlZFNhbXBsZVJhbmQgIT09IHVuZGVmaW5lZCkge1xuICAgIHJldHVybiBwYXJzZWRTYW1wbGVSYW5kO1xuICB9XG5cbiAgLy8gT3RoZXJ3aXNlLCBpZiB0aGVyZSBpcyBhbiBpbmNvbWluZyBzYW1wbGluZyBkZWNpc2lvbiArIHNhbXBsZSByYXRlLCBnZW5lcmF0ZSBhIHNhbXBsZSByYW5kIHRoYXQgd291bGQgbGVhZCB0byB0aGUgc2FtZSBzYW1wbGluZyBkZWNpc2lvbi5cbiAgY29uc3QgcGFyc2VkU2FtcGxlUmF0ZSA9IHBhcnNlU2FtcGxlUmF0ZS5wYXJzZVNhbXBsZVJhdGUoZHNjPy5zYW1wbGVfcmF0ZSk7XG4gIGlmIChwYXJzZWRTYW1wbGVSYXRlICYmIHRyYWNlcGFyZW50RGF0YT8ucGFyZW50U2FtcGxlZCAhPT0gdW5kZWZpbmVkKSB7XG4gICAgcmV0dXJuIHRyYWNlcGFyZW50RGF0YS5wYXJlbnRTYW1wbGVkXG4gICAgICA/IC8vIFJldHVybnMgYSBzYW1wbGUgcmFuZCB3aXRoIHBvc2l0aXZlIHNhbXBsaW5nIGRlY2lzaW9uIFswLCBzYW1wbGVSYXRlKVxuICAgICAgICBNYXRoLnJhbmRvbSgpICogcGFyc2VkU2FtcGxlUmF0ZVxuICAgICAgOiAvLyBSZXR1cm5zIGEgc2FtcGxlIHJhbmQgd2l0aCBuZWdhdGl2ZSBzYW1wbGluZyBkZWNpc2lvbiBbc2FtcGxlUmF0ZSwgMSlcbiAgICAgICAgcGFyc2VkU2FtcGxlUmF0ZSArIE1hdGgucmFuZG9tKCkgKiAoMSAtIHBhcnNlZFNhbXBsZVJhdGUpO1xuICB9IGVsc2Uge1xuICAgIC8vIElmIG5vdGhpbmcgYXBwbGllcywgcmV0dXJuIGEgcmFuZG9tIHNhbXBsZSByYW5kLlxuICAgIHJldHVybiBNYXRoLnJhbmRvbSgpO1xuICB9XG59XG5cbmV4cG9ydHMuVFJBQ0VQQVJFTlRfUkVHRVhQID0gVFJBQ0VQQVJFTlRfUkVHRVhQO1xuZXhwb3J0cy5leHRyYWN0VHJhY2VwYXJlbnREYXRhID0gZXh0cmFjdFRyYWNlcGFyZW50RGF0YTtcbmV4cG9ydHMuZ2VuZXJhdGVTZW50cnlUcmFjZUhlYWRlciA9IGdlbmVyYXRlU2VudHJ5VHJhY2VIZWFkZXI7XG5leHBvcnRzLnByb3BhZ2F0aW9uQ29udGV4dEZyb21IZWFkZXJzID0gcHJvcGFnYXRpb25Db250ZXh0RnJvbUhlYWRlcnM7XG4vLyMgc291cmNlTWFwcGluZ1VSTD10cmFjaW5nLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/tracing.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/transactionEvent.js":
/*!**************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/transactionEvent.js ***!
  \**************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst semanticAttributes = __webpack_require__(/*! ../semanticAttributes.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/semanticAttributes.js\");\n\n/**\n * Converts a transaction event to a span JSON object.\n */\nfunction convertTransactionEventToSpanJson(event) {\n  const { trace_id, parent_span_id, span_id, status, origin, data, op } = event.contexts?.trace ?? {};\n\n  return {\n    data: data ?? {},\n    description: event.transaction,\n    op,\n    parent_span_id,\n    span_id: span_id ?? '',\n    start_timestamp: event.start_timestamp ?? 0,\n    status,\n    timestamp: event.timestamp,\n    trace_id: trace_id ?? '',\n    origin,\n    profile_id: data?.[semanticAttributes.SEMANTIC_ATTRIBUTE_PROFILE_ID] ,\n    exclusive_time: data?.[semanticAttributes.SEMANTIC_ATTRIBUTE_EXCLUSIVE_TIME] ,\n    measurements: event.measurements,\n    is_segment: true,\n  };\n}\n\n/**\n * Converts a span JSON object to a transaction event.\n */\nfunction convertSpanJsonToTransactionEvent(span) {\n  return {\n    type: 'transaction',\n    timestamp: span.timestamp,\n    start_timestamp: span.start_timestamp,\n    transaction: span.description,\n    contexts: {\n      trace: {\n        trace_id: span.trace_id,\n        span_id: span.span_id,\n        parent_span_id: span.parent_span_id,\n        op: span.op,\n        status: span.status,\n        origin: span.origin,\n        data: {\n          ...span.data,\n          ...(span.profile_id && { [semanticAttributes.SEMANTIC_ATTRIBUTE_PROFILE_ID]: span.profile_id }),\n          ...(span.exclusive_time && { [semanticAttributes.SEMANTIC_ATTRIBUTE_EXCLUSIVE_TIME]: span.exclusive_time }),\n        },\n      },\n    },\n    measurements: span.measurements,\n  };\n}\n\nexports.convertSpanJsonToTransactionEvent = convertSpanJsonToTransactionEvent;\nexports.convertTransactionEventToSpanJson = convertTransactionEventToSpanJson;\n//# sourceMappingURL=transactionEvent.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy90cmFuc2FjdGlvbkV2ZW50LmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLDJCQUEyQixtQkFBTyxDQUFDLDBJQUEwQjs7QUFFN0Q7QUFDQTtBQUNBO0FBQ0E7QUFDQSxVQUFVLDhEQUE4RDs7QUFFeEU7QUFDQSxvQkFBb0I7QUFDcEI7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsbUNBQW1DLHFFQUFxRTtBQUN4Ryx1Q0FBdUMsNkVBQTZFO0FBQ3BILFNBQVM7QUFDVCxPQUFPO0FBQ1AsS0FBSztBQUNMO0FBQ0E7QUFDQTs7QUFFQSx5Q0FBeUM7QUFDekMseUNBQXlDO0FBQ3pDIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvdHJhbnNhY3Rpb25FdmVudC5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3Qgc2VtYW50aWNBdHRyaWJ1dGVzID0gcmVxdWlyZSgnLi4vc2VtYW50aWNBdHRyaWJ1dGVzLmpzJyk7XG5cbi8qKlxuICogQ29udmVydHMgYSB0cmFuc2FjdGlvbiBldmVudCB0byBhIHNwYW4gSlNPTiBvYmplY3QuXG4gKi9cbmZ1bmN0aW9uIGNvbnZlcnRUcmFuc2FjdGlvbkV2ZW50VG9TcGFuSnNvbihldmVudCkge1xuICBjb25zdCB7IHRyYWNlX2lkLCBwYXJlbnRfc3Bhbl9pZCwgc3Bhbl9pZCwgc3RhdHVzLCBvcmlnaW4sIGRhdGEsIG9wIH0gPSBldmVudC5jb250ZXh0cz8udHJhY2UgPz8ge307XG5cbiAgcmV0dXJuIHtcbiAgICBkYXRhOiBkYXRhID8/IHt9LFxuICAgIGRlc2NyaXB0aW9uOiBldmVudC50cmFuc2FjdGlvbixcbiAgICBvcCxcbiAgICBwYXJlbnRfc3Bhbl9pZCxcbiAgICBzcGFuX2lkOiBzcGFuX2lkID8/ICcnLFxuICAgIHN0YXJ0X3RpbWVzdGFtcDogZXZlbnQuc3RhcnRfdGltZXN0YW1wID8/IDAsXG4gICAgc3RhdHVzLFxuICAgIHRpbWVzdGFtcDogZXZlbnQudGltZXN0YW1wLFxuICAgIHRyYWNlX2lkOiB0cmFjZV9pZCA/PyAnJyxcbiAgICBvcmlnaW4sXG4gICAgcHJvZmlsZV9pZDogZGF0YT8uW3NlbWFudGljQXR0cmlidXRlcy5TRU1BTlRJQ19BVFRSSUJVVEVfUFJPRklMRV9JRF0gLFxuICAgIGV4Y2x1c2l2ZV90aW1lOiBkYXRhPy5bc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9FWENMVVNJVkVfVElNRV0gLFxuICAgIG1lYXN1cmVtZW50czogZXZlbnQubWVhc3VyZW1lbnRzLFxuICAgIGlzX3NlZ21lbnQ6IHRydWUsXG4gIH07XG59XG5cbi8qKlxuICogQ29udmVydHMgYSBzcGFuIEpTT04gb2JqZWN0IHRvIGEgdHJhbnNhY3Rpb24gZXZlbnQuXG4gKi9cbmZ1bmN0aW9uIGNvbnZlcnRTcGFuSnNvblRvVHJhbnNhY3Rpb25FdmVudChzcGFuKSB7XG4gIHJldHVybiB7XG4gICAgdHlwZTogJ3RyYW5zYWN0aW9uJyxcbiAgICB0aW1lc3RhbXA6IHNwYW4udGltZXN0YW1wLFxuICAgIHN0YXJ0X3RpbWVzdGFtcDogc3Bhbi5zdGFydF90aW1lc3RhbXAsXG4gICAgdHJhbnNhY3Rpb246IHNwYW4uZGVzY3JpcHRpb24sXG4gICAgY29udGV4dHM6IHtcbiAgICAgIHRyYWNlOiB7XG4gICAgICAgIHRyYWNlX2lkOiBzcGFuLnRyYWNlX2lkLFxuICAgICAgICBzcGFuX2lkOiBzcGFuLnNwYW5faWQsXG4gICAgICAgIHBhcmVudF9zcGFuX2lkOiBzcGFuLnBhcmVudF9zcGFuX2lkLFxuICAgICAgICBvcDogc3Bhbi5vcCxcbiAgICAgICAgc3RhdHVzOiBzcGFuLnN0YXR1cyxcbiAgICAgICAgb3JpZ2luOiBzcGFuLm9yaWdpbixcbiAgICAgICAgZGF0YToge1xuICAgICAgICAgIC4uLnNwYW4uZGF0YSxcbiAgICAgICAgICAuLi4oc3Bhbi5wcm9maWxlX2lkICYmIHsgW3NlbWFudGljQXR0cmlidXRlcy5TRU1BTlRJQ19BVFRSSUJVVEVfUFJPRklMRV9JRF06IHNwYW4ucHJvZmlsZV9pZCB9KSxcbiAgICAgICAgICAuLi4oc3Bhbi5leGNsdXNpdmVfdGltZSAmJiB7IFtzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX0VYQ0xVU0lWRV9USU1FXTogc3Bhbi5leGNsdXNpdmVfdGltZSB9KSxcbiAgICAgICAgfSxcbiAgICAgIH0sXG4gICAgfSxcbiAgICBtZWFzdXJlbWVudHM6IHNwYW4ubWVhc3VyZW1lbnRzLFxuICB9O1xufVxuXG5leHBvcnRzLmNvbnZlcnRTcGFuSnNvblRvVHJhbnNhY3Rpb25FdmVudCA9IGNvbnZlcnRTcGFuSnNvblRvVHJhbnNhY3Rpb25FdmVudDtcbmV4cG9ydHMuY29udmVydFRyYW5zYWN0aW9uRXZlbnRUb1NwYW5Kc29uID0gY29udmVydFRyYW5zYWN0aW9uRXZlbnRUb1NwYW5Kc29uO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9dHJhbnNhY3Rpb25FdmVudC5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/transactionEvent.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/url.js":
/*!*************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/url.js ***!
  \*************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst semanticAttributes = __webpack_require__(/*! ../semanticAttributes.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/semanticAttributes.js\");\n\n// Curious about `thismessage:/`? See: https://www.rfc-editor.org/rfc/rfc2557.html\n//  > When the methods above do not yield an absolute URI, a base URL\n//  > of \"thismessage:/\" MUST be employed. This base URL has been\n//  > defined for the sole purpose of resolving relative references\n//  > within a multipart/related structure when no other base URI is\n//  > specified.\n//\n// We need to provide a base URL to `parseStringToURLObject` because the fetch API gives us a\n// relative URL sometimes.\n//\n// This is the only case where we need to provide a base URL to `parseStringToURLObject`\n// because the relative URL is not valid on its own.\nconst DEFAULT_BASE_URL = 'thismessage:/';\n\n/**\n * Checks if the URL object is relative\n *\n * @param url - The URL object to check\n * @returns True if the URL object is relative, false otherwise\n */\nfunction isURLObjectRelative(url) {\n  return 'isRelative' in url;\n}\n\n/**\n * Parses string to a URL object\n *\n * @param url - The URL to parse\n * @returns The parsed URL object or undefined if the URL is invalid\n */\nfunction parseStringToURLObject(url, urlBase) {\n  const isRelative = url.indexOf('://') <= 0 && url.indexOf('//') !== 0;\n  const base = urlBase ?? (isRelative ? DEFAULT_BASE_URL : undefined);\n  try {\n    // Use `canParse` to short-circuit the URL constructor if it's not a valid URL\n    // This is faster than trying to construct the URL and catching the error\n    // Node 20+, Chrome 120+, Firefox 115+, Safari 17+\n    if ('canParse' in URL && !(URL ).canParse(url, base)) {\n      return undefined;\n    }\n\n    const fullUrlObject = new URL(url, base);\n    if (isRelative) {\n      // Because we used a fake base URL, we need to return a relative URL object.\n      // We cannot return anything about the origin, host, etc. because it will refer to the fake base URL.\n      return {\n        isRelative,\n        pathname: fullUrlObject.pathname,\n        search: fullUrlObject.search,\n        hash: fullUrlObject.hash,\n      };\n    }\n    return fullUrlObject;\n  } catch {\n    // empty body\n  }\n\n  return undefined;\n}\n\n/**\n * Takes a URL object and returns a sanitized string which is safe to use as span name\n * see: https://develop.sentry.dev/sdk/data-handling/#structuring-data\n */\nfunction getSanitizedUrlStringFromUrlObject(url) {\n  if (isURLObjectRelative(url)) {\n    return url.pathname;\n  }\n\n  const newUrl = new URL(url);\n  newUrl.search = '';\n  newUrl.hash = '';\n  if (['80', '443'].includes(newUrl.port)) {\n    newUrl.port = '';\n  }\n  if (newUrl.password) {\n    newUrl.password = '%filtered%';\n  }\n  if (newUrl.username) {\n    newUrl.username = '%filtered%';\n  }\n\n  return newUrl.toString();\n}\n\nfunction getHttpSpanNameFromUrlObject(\n  urlObject,\n  kind,\n  request,\n  routeName,\n) {\n  const method = request?.method?.toUpperCase() ?? 'GET';\n  const route = routeName\n    ? routeName\n    : urlObject\n      ? kind === 'client'\n        ? getSanitizedUrlStringFromUrlObject(urlObject)\n        : urlObject.pathname\n      : '/';\n\n  return `${method} ${route}`;\n}\n\n/**\n * Takes a parsed URL object and returns a set of attributes for the span\n * that represents the HTTP request for that url. This is used for both server\n * and client http spans.\n *\n * Follows https://opentelemetry.io/docs/specs/semconv/http/.\n *\n * @param urlObject - see {@link parseStringToURLObject}\n * @param kind - The type of HTTP operation (server or client)\n * @param spanOrigin - The origin of the span\n * @param request - The request object, see {@link PartialRequest}\n * @param routeName - The name of the route, must be low cardinality\n * @returns The span name and attributes for the HTTP operation\n */\nfunction getHttpSpanDetailsFromUrlObject(\n  urlObject,\n  kind,\n  spanOrigin,\n  request,\n  routeName,\n) {\n  const attributes = {\n    [semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_ORIGIN]: spanOrigin,\n    [semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_SOURCE]: 'url',\n  };\n\n  if (routeName) {\n    // This is based on https://opentelemetry.io/docs/specs/semconv/http/http-spans/#name\n    attributes[kind === 'server' ? 'http.route' : 'url.template'] = routeName;\n    attributes[semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_SOURCE] = 'route';\n  }\n\n  if (request?.method) {\n    attributes[semanticAttributes.SEMANTIC_ATTRIBUTE_HTTP_REQUEST_METHOD] = request.method.toUpperCase();\n  }\n\n  if (urlObject) {\n    if (urlObject.search) {\n      attributes['url.query'] = urlObject.search;\n    }\n    if (urlObject.hash) {\n      attributes['url.fragment'] = urlObject.hash;\n    }\n    if (urlObject.pathname) {\n      attributes['url.path'] = urlObject.pathname;\n      if (urlObject.pathname === '/') {\n        attributes[semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_SOURCE] = 'route';\n      }\n    }\n\n    if (!isURLObjectRelative(urlObject)) {\n      attributes[semanticAttributes.SEMANTIC_ATTRIBUTE_URL_FULL] = urlObject.href;\n      if (urlObject.port) {\n        attributes['url.port'] = urlObject.port;\n      }\n      if (urlObject.protocol) {\n        attributes['url.scheme'] = urlObject.protocol;\n      }\n      if (urlObject.hostname) {\n        attributes[kind === 'server' ? 'server.address' : 'url.domain'] = urlObject.hostname;\n      }\n    }\n  }\n\n  return [getHttpSpanNameFromUrlObject(urlObject, kind, request, routeName), attributes];\n}\n\n/**\n * Parses string form of URL into an object\n * // borrowed from https://tools.ietf.org/html/rfc3986#appendix-B\n * // intentionally using regex and not <a/> href parsing trick because React Native and other\n * // environments where DOM might not be available\n * @returns parsed URL object\n */\nfunction parseUrl(url) {\n  if (!url) {\n    return {};\n  }\n\n  const match = url.match(/^(([^:/?#]+):)?(\\/\\/([^/?#]*))?([^?#]*)(\\?([^#]*))?(#(.*))?$/);\n\n  if (!match) {\n    return {};\n  }\n\n  // coerce to undefined values to empty string so we don't get 'undefined'\n  const query = match[6] || '';\n  const fragment = match[8] || '';\n  return {\n    host: match[4],\n    path: match[5],\n    protocol: match[2],\n    search: query,\n    hash: fragment,\n    relative: match[5] + query + fragment, // everything minus origin\n  };\n}\n\n/**\n * Strip the query string and fragment off of a given URL or path (if present)\n *\n * @param urlPath Full URL or path, including possible query string and/or fragment\n * @returns URL or path without query string or fragment\n */\nfunction stripUrlQueryAndFragment(urlPath) {\n  return (urlPath.split(/[?#]/, 1) )[0];\n}\n\n/**\n * Takes a URL object and returns a sanitized string which is safe to use as span name\n * see: https://develop.sentry.dev/sdk/data-handling/#structuring-data\n */\nfunction getSanitizedUrlString(url) {\n  const { protocol, host, path } = url;\n\n  const filteredHost =\n    host\n      // Always filter out authority\n      ?.replace(/^.*@/, '[filtered]:[filtered]@')\n      // Don't show standard :80 (http) and :443 (https) ports to reduce the noise\n      // TODO: Use new URL global if it exists\n      .replace(/(:80)$/, '')\n      .replace(/(:443)$/, '') || '';\n\n  return `${protocol ? `${protocol}://` : ''}${filteredHost}${path}`;\n}\n\nexports.getHttpSpanDetailsFromUrlObject = getHttpSpanDetailsFromUrlObject;\nexports.getSanitizedUrlString = getSanitizedUrlString;\nexports.getSanitizedUrlStringFromUrlObject = getSanitizedUrlStringFromUrlObject;\nexports.isURLObjectRelative = isURLObjectRelative;\nexports.parseStringToURLObject = parseStringToURLObject;\nexports.parseUrl = parseUrl;\nexports.stripUrlQueryAndFragment = stripUrlQueryAndFragment;\n//# sourceMappingURL=url.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy91cmwuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsMkJBQTJCLG1CQUFPLENBQUMsMElBQTBCOztBQUU3RDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsSUFBSTtBQUNKO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsWUFBWSxRQUFRLEVBQUUsTUFBTTtBQUM1Qjs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLDJCQUEyQjtBQUMzQjtBQUNBO0FBQ0EsNkNBQTZDO0FBQzdDO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxVQUFVLHVCQUF1Qjs7QUFFakM7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSxZQUFZLGNBQWMsU0FBUyxVQUFVLEVBQUUsYUFBYSxFQUFFLEtBQUs7QUFDbkU7O0FBRUEsdUNBQXVDO0FBQ3ZDLDZCQUE2QjtBQUM3QiwwQ0FBMEM7QUFDMUMsMkJBQTJCO0FBQzNCLDhCQUE4QjtBQUM5QixnQkFBZ0I7QUFDaEIsZ0NBQWdDO0FBQ2hDIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvdXJsLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBzZW1hbnRpY0F0dHJpYnV0ZXMgPSByZXF1aXJlKCcuLi9zZW1hbnRpY0F0dHJpYnV0ZXMuanMnKTtcblxuLy8gQ3VyaW91cyBhYm91dCBgdGhpc21lc3NhZ2U6L2A/IFNlZTogaHR0cHM6Ly93d3cucmZjLWVkaXRvci5vcmcvcmZjL3JmYzI1NTcuaHRtbFxuLy8gID4gV2hlbiB0aGUgbWV0aG9kcyBhYm92ZSBkbyBub3QgeWllbGQgYW4gYWJzb2x1dGUgVVJJLCBhIGJhc2UgVVJMXG4vLyAgPiBvZiBcInRoaXNtZXNzYWdlOi9cIiBNVVNUIGJlIGVtcGxveWVkLiBUaGlzIGJhc2UgVVJMIGhhcyBiZWVuXG4vLyAgPiBkZWZpbmVkIGZvciB0aGUgc29sZSBwdXJwb3NlIG9mIHJlc29sdmluZyByZWxhdGl2ZSByZWZlcmVuY2VzXG4vLyAgPiB3aXRoaW4gYSBtdWx0aXBhcnQvcmVsYXRlZCBzdHJ1Y3R1cmUgd2hlbiBubyBvdGhlciBiYXNlIFVSSSBpc1xuLy8gID4gc3BlY2lmaWVkLlxuLy9cbi8vIFdlIG5lZWQgdG8gcHJvdmlkZSBhIGJhc2UgVVJMIHRvIGBwYXJzZVN0cmluZ1RvVVJMT2JqZWN0YCBiZWNhdXNlIHRoZSBmZXRjaCBBUEkgZ2l2ZXMgdXMgYVxuLy8gcmVsYXRpdmUgVVJMIHNvbWV0aW1lcy5cbi8vXG4vLyBUaGlzIGlzIHRoZSBvbmx5IGNhc2Ugd2hlcmUgd2UgbmVlZCB0byBwcm92aWRlIGEgYmFzZSBVUkwgdG8gYHBhcnNlU3RyaW5nVG9VUkxPYmplY3RgXG4vLyBiZWNhdXNlIHRoZSByZWxhdGl2ZSBVUkwgaXMgbm90IHZhbGlkIG9uIGl0cyBvd24uXG5jb25zdCBERUZBVUxUX0JBU0VfVVJMID0gJ3RoaXNtZXNzYWdlOi8nO1xuXG4vKipcbiAqIENoZWNrcyBpZiB0aGUgVVJMIG9iamVjdCBpcyByZWxhdGl2ZVxuICpcbiAqIEBwYXJhbSB1cmwgLSBUaGUgVVJMIG9iamVjdCB0byBjaGVja1xuICogQHJldHVybnMgVHJ1ZSBpZiB0aGUgVVJMIG9iamVjdCBpcyByZWxhdGl2ZSwgZmFsc2Ugb3RoZXJ3aXNlXG4gKi9cbmZ1bmN0aW9uIGlzVVJMT2JqZWN0UmVsYXRpdmUodXJsKSB7XG4gIHJldHVybiAnaXNSZWxhdGl2ZScgaW4gdXJsO1xufVxuXG4vKipcbiAqIFBhcnNlcyBzdHJpbmcgdG8gYSBVUkwgb2JqZWN0XG4gKlxuICogQHBhcmFtIHVybCAtIFRoZSBVUkwgdG8gcGFyc2VcbiAqIEByZXR1cm5zIFRoZSBwYXJzZWQgVVJMIG9iamVjdCBvciB1bmRlZmluZWQgaWYgdGhlIFVSTCBpcyBpbnZhbGlkXG4gKi9cbmZ1bmN0aW9uIHBhcnNlU3RyaW5nVG9VUkxPYmplY3QodXJsLCB1cmxCYXNlKSB7XG4gIGNvbnN0IGlzUmVsYXRpdmUgPSB1cmwuaW5kZXhPZignOi8vJykgPD0gMCAmJiB1cmwuaW5kZXhPZignLy8nKSAhPT0gMDtcbiAgY29uc3QgYmFzZSA9IHVybEJhc2UgPz8gKGlzUmVsYXRpdmUgPyBERUZBVUxUX0JBU0VfVVJMIDogdW5kZWZpbmVkKTtcbiAgdHJ5IHtcbiAgICAvLyBVc2UgYGNhblBhcnNlYCB0byBzaG9ydC1jaXJjdWl0IHRoZSBVUkwgY29uc3RydWN0b3IgaWYgaXQncyBub3QgYSB2YWxpZCBVUkxcbiAgICAvLyBUaGlzIGlzIGZhc3RlciB0aGFuIHRyeWluZyB0byBjb25zdHJ1Y3QgdGhlIFVSTCBhbmQgY2F0Y2hpbmcgdGhlIGVycm9yXG4gICAgLy8gTm9kZSAyMCssIENocm9tZSAxMjArLCBGaXJlZm94IDExNSssIFNhZmFyaSAxNytcbiAgICBpZiAoJ2NhblBhcnNlJyBpbiBVUkwgJiYgIShVUkwgKS5jYW5QYXJzZSh1cmwsIGJhc2UpKSB7XG4gICAgICByZXR1cm4gdW5kZWZpbmVkO1xuICAgIH1cblxuICAgIGNvbnN0IGZ1bGxVcmxPYmplY3QgPSBuZXcgVVJMKHVybCwgYmFzZSk7XG4gICAgaWYgKGlzUmVsYXRpdmUpIHtcbiAgICAgIC8vIEJlY2F1c2Ugd2UgdXNlZCBhIGZha2UgYmFzZSBVUkwsIHdlIG5lZWQgdG8gcmV0dXJuIGEgcmVsYXRpdmUgVVJMIG9iamVjdC5cbiAgICAgIC8vIFdlIGNhbm5vdCByZXR1cm4gYW55dGhpbmcgYWJvdXQgdGhlIG9yaWdpbiwgaG9zdCwgZXRjLiBiZWNhdXNlIGl0IHdpbGwgcmVmZXIgdG8gdGhlIGZha2UgYmFzZSBVUkwuXG4gICAgICByZXR1cm4ge1xuICAgICAgICBpc1JlbGF0aXZlLFxuICAgICAgICBwYXRobmFtZTogZnVsbFVybE9iamVjdC5wYXRobmFtZSxcbiAgICAgICAgc2VhcmNoOiBmdWxsVXJsT2JqZWN0LnNlYXJjaCxcbiAgICAgICAgaGFzaDogZnVsbFVybE9iamVjdC5oYXNoLFxuICAgICAgfTtcbiAgICB9XG4gICAgcmV0dXJuIGZ1bGxVcmxPYmplY3Q7XG4gIH0gY2F0Y2gge1xuICAgIC8vIGVtcHR5IGJvZHlcbiAgfVxuXG4gIHJldHVybiB1bmRlZmluZWQ7XG59XG5cbi8qKlxuICogVGFrZXMgYSBVUkwgb2JqZWN0IGFuZCByZXR1cm5zIGEgc2FuaXRpemVkIHN0cmluZyB3aGljaCBpcyBzYWZlIHRvIHVzZSBhcyBzcGFuIG5hbWVcbiAqIHNlZTogaHR0cHM6Ly9kZXZlbG9wLnNlbnRyeS5kZXYvc2RrL2RhdGEtaGFuZGxpbmcvI3N0cnVjdHVyaW5nLWRhdGFcbiAqL1xuZnVuY3Rpb24gZ2V0U2FuaXRpemVkVXJsU3RyaW5nRnJvbVVybE9iamVjdCh1cmwpIHtcbiAgaWYgKGlzVVJMT2JqZWN0UmVsYXRpdmUodXJsKSkge1xuICAgIHJldHVybiB1cmwucGF0aG5hbWU7XG4gIH1cblxuICBjb25zdCBuZXdVcmwgPSBuZXcgVVJMKHVybCk7XG4gIG5ld1VybC5zZWFyY2ggPSAnJztcbiAgbmV3VXJsLmhhc2ggPSAnJztcbiAgaWYgKFsnODAnLCAnNDQzJ10uaW5jbHVkZXMobmV3VXJsLnBvcnQpKSB7XG4gICAgbmV3VXJsLnBvcnQgPSAnJztcbiAgfVxuICBpZiAobmV3VXJsLnBhc3N3b3JkKSB7XG4gICAgbmV3VXJsLnBhc3N3b3JkID0gJyVmaWx0ZXJlZCUnO1xuICB9XG4gIGlmIChuZXdVcmwudXNlcm5hbWUpIHtcbiAgICBuZXdVcmwudXNlcm5hbWUgPSAnJWZpbHRlcmVkJSc7XG4gIH1cblxuICByZXR1cm4gbmV3VXJsLnRvU3RyaW5nKCk7XG59XG5cbmZ1bmN0aW9uIGdldEh0dHBTcGFuTmFtZUZyb21VcmxPYmplY3QoXG4gIHVybE9iamVjdCxcbiAga2luZCxcbiAgcmVxdWVzdCxcbiAgcm91dGVOYW1lLFxuKSB7XG4gIGNvbnN0IG1ldGhvZCA9IHJlcXVlc3Q/Lm1ldGhvZD8udG9VcHBlckNhc2UoKSA/PyAnR0VUJztcbiAgY29uc3Qgcm91dGUgPSByb3V0ZU5hbWVcbiAgICA/IHJvdXRlTmFtZVxuICAgIDogdXJsT2JqZWN0XG4gICAgICA/IGtpbmQgPT09ICdjbGllbnQnXG4gICAgICAgID8gZ2V0U2FuaXRpemVkVXJsU3RyaW5nRnJvbVVybE9iamVjdCh1cmxPYmplY3QpXG4gICAgICAgIDogdXJsT2JqZWN0LnBhdGhuYW1lXG4gICAgICA6ICcvJztcblxuICByZXR1cm4gYCR7bWV0aG9kfSAke3JvdXRlfWA7XG59XG5cbi8qKlxuICogVGFrZXMgYSBwYXJzZWQgVVJMIG9iamVjdCBhbmQgcmV0dXJucyBhIHNldCBvZiBhdHRyaWJ1dGVzIGZvciB0aGUgc3BhblxuICogdGhhdCByZXByZXNlbnRzIHRoZSBIVFRQIHJlcXVlc3QgZm9yIHRoYXQgdXJsLiBUaGlzIGlzIHVzZWQgZm9yIGJvdGggc2VydmVyXG4gKiBhbmQgY2xpZW50IGh0dHAgc3BhbnMuXG4gKlxuICogRm9sbG93cyBodHRwczovL29wZW50ZWxlbWV0cnkuaW8vZG9jcy9zcGVjcy9zZW1jb252L2h0dHAvLlxuICpcbiAqIEBwYXJhbSB1cmxPYmplY3QgLSBzZWUge0BsaW5rIHBhcnNlU3RyaW5nVG9VUkxPYmplY3R9XG4gKiBAcGFyYW0ga2luZCAtIFRoZSB0eXBlIG9mIEhUVFAgb3BlcmF0aW9uIChzZXJ2ZXIgb3IgY2xpZW50KVxuICogQHBhcmFtIHNwYW5PcmlnaW4gLSBUaGUgb3JpZ2luIG9mIHRoZSBzcGFuXG4gKiBAcGFyYW0gcmVxdWVzdCAtIFRoZSByZXF1ZXN0IG9iamVjdCwgc2VlIHtAbGluayBQYXJ0aWFsUmVxdWVzdH1cbiAqIEBwYXJhbSByb3V0ZU5hbWUgLSBUaGUgbmFtZSBvZiB0aGUgcm91dGUsIG11c3QgYmUgbG93IGNhcmRpbmFsaXR5XG4gKiBAcmV0dXJucyBUaGUgc3BhbiBuYW1lIGFuZCBhdHRyaWJ1dGVzIGZvciB0aGUgSFRUUCBvcGVyYXRpb25cbiAqL1xuZnVuY3Rpb24gZ2V0SHR0cFNwYW5EZXRhaWxzRnJvbVVybE9iamVjdChcbiAgdXJsT2JqZWN0LFxuICBraW5kLFxuICBzcGFuT3JpZ2luLFxuICByZXF1ZXN0LFxuICByb3V0ZU5hbWUsXG4pIHtcbiAgY29uc3QgYXR0cmlidXRlcyA9IHtcbiAgICBbc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfT1JJR0lOXTogc3Bhbk9yaWdpbixcbiAgICBbc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfU09VUkNFXTogJ3VybCcsXG4gIH07XG5cbiAgaWYgKHJvdXRlTmFtZSkge1xuICAgIC8vIFRoaXMgaXMgYmFzZWQgb24gaHR0cHM6Ly9vcGVudGVsZW1ldHJ5LmlvL2RvY3Mvc3BlY3Mvc2VtY29udi9odHRwL2h0dHAtc3BhbnMvI25hbWVcbiAgICBhdHRyaWJ1dGVzW2tpbmQgPT09ICdzZXJ2ZXInID8gJ2h0dHAucm91dGUnIDogJ3VybC50ZW1wbGF0ZSddID0gcm91dGVOYW1lO1xuICAgIGF0dHJpYnV0ZXNbc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfU09VUkNFXSA9ICdyb3V0ZSc7XG4gIH1cblxuICBpZiAocmVxdWVzdD8ubWV0aG9kKSB7XG4gICAgYXR0cmlidXRlc1tzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX0hUVFBfUkVRVUVTVF9NRVRIT0RdID0gcmVxdWVzdC5tZXRob2QudG9VcHBlckNhc2UoKTtcbiAgfVxuXG4gIGlmICh1cmxPYmplY3QpIHtcbiAgICBpZiAodXJsT2JqZWN0LnNlYXJjaCkge1xuICAgICAgYXR0cmlidXRlc1sndXJsLnF1ZXJ5J10gPSB1cmxPYmplY3Quc2VhcmNoO1xuICAgIH1cbiAgICBpZiAodXJsT2JqZWN0Lmhhc2gpIHtcbiAgICAgIGF0dHJpYnV0ZXNbJ3VybC5mcmFnbWVudCddID0gdXJsT2JqZWN0Lmhhc2g7XG4gICAgfVxuICAgIGlmICh1cmxPYmplY3QucGF0aG5hbWUpIHtcbiAgICAgIGF0dHJpYnV0ZXNbJ3VybC5wYXRoJ10gPSB1cmxPYmplY3QucGF0aG5hbWU7XG4gICAgICBpZiAodXJsT2JqZWN0LnBhdGhuYW1lID09PSAnLycpIHtcbiAgICAgICAgYXR0cmlidXRlc1tzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9TT1VSQ0VdID0gJ3JvdXRlJztcbiAgICAgIH1cbiAgICB9XG5cbiAgICBpZiAoIWlzVVJMT2JqZWN0UmVsYXRpdmUodXJsT2JqZWN0KSkge1xuICAgICAgYXR0cmlidXRlc1tzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX1VSTF9GVUxMXSA9IHVybE9iamVjdC5ocmVmO1xuICAgICAgaWYgKHVybE9iamVjdC5wb3J0KSB7XG4gICAgICAgIGF0dHJpYnV0ZXNbJ3VybC5wb3J0J10gPSB1cmxPYmplY3QucG9ydDtcbiAgICAgIH1cbiAgICAgIGlmICh1cmxPYmplY3QucHJvdG9jb2wpIHtcbiAgICAgICAgYXR0cmlidXRlc1sndXJsLnNjaGVtZSddID0gdXJsT2JqZWN0LnByb3RvY29sO1xuICAgICAgfVxuICAgICAgaWYgKHVybE9iamVjdC5ob3N0bmFtZSkge1xuICAgICAgICBhdHRyaWJ1dGVzW2tpbmQgPT09ICdzZXJ2ZXInID8gJ3NlcnZlci5hZGRyZXNzJyA6ICd1cmwuZG9tYWluJ10gPSB1cmxPYmplY3QuaG9zdG5hbWU7XG4gICAgICB9XG4gICAgfVxuICB9XG5cbiAgcmV0dXJuIFtnZXRIdHRwU3Bhbk5hbWVGcm9tVXJsT2JqZWN0KHVybE9iamVjdCwga2luZCwgcmVxdWVzdCwgcm91dGVOYW1lKSwgYXR0cmlidXRlc107XG59XG5cbi8qKlxuICogUGFyc2VzIHN0cmluZyBmb3JtIG9mIFVSTCBpbnRvIGFuIG9iamVjdFxuICogLy8gYm9ycm93ZWQgZnJvbSBodHRwczovL3Rvb2xzLmlldGYub3JnL2h0bWwvcmZjMzk4NiNhcHBlbmRpeC1CXG4gKiAvLyBpbnRlbnRpb25hbGx5IHVzaW5nIHJlZ2V4IGFuZCBub3QgPGEvPiBocmVmIHBhcnNpbmcgdHJpY2sgYmVjYXVzZSBSZWFjdCBOYXRpdmUgYW5kIG90aGVyXG4gKiAvLyBlbnZpcm9ubWVudHMgd2hlcmUgRE9NIG1pZ2h0IG5vdCBiZSBhdmFpbGFibGVcbiAqIEByZXR1cm5zIHBhcnNlZCBVUkwgb2JqZWN0XG4gKi9cbmZ1bmN0aW9uIHBhcnNlVXJsKHVybCkge1xuICBpZiAoIXVybCkge1xuICAgIHJldHVybiB7fTtcbiAgfVxuXG4gIGNvbnN0IG1hdGNoID0gdXJsLm1hdGNoKC9eKChbXjovPyNdKyk6KT8oXFwvXFwvKFteLz8jXSopKT8oW14/I10qKShcXD8oW14jXSopKT8oIyguKikpPyQvKTtcblxuICBpZiAoIW1hdGNoKSB7XG4gICAgcmV0dXJuIHt9O1xuICB9XG5cbiAgLy8gY29lcmNlIHRvIHVuZGVmaW5lZCB2YWx1ZXMgdG8gZW1wdHkgc3RyaW5nIHNvIHdlIGRvbid0IGdldCAndW5kZWZpbmVkJ1xuICBjb25zdCBxdWVyeSA9IG1hdGNoWzZdIHx8ICcnO1xuICBjb25zdCBmcmFnbWVudCA9IG1hdGNoWzhdIHx8ICcnO1xuICByZXR1cm4ge1xuICAgIGhvc3Q6IG1hdGNoWzRdLFxuICAgIHBhdGg6IG1hdGNoWzVdLFxuICAgIHByb3RvY29sOiBtYXRjaFsyXSxcbiAgICBzZWFyY2g6IHF1ZXJ5LFxuICAgIGhhc2g6IGZyYWdtZW50LFxuICAgIHJlbGF0aXZlOiBtYXRjaFs1XSArIHF1ZXJ5ICsgZnJhZ21lbnQsIC8vIGV2ZXJ5dGhpbmcgbWludXMgb3JpZ2luXG4gIH07XG59XG5cbi8qKlxuICogU3RyaXAgdGhlIHF1ZXJ5IHN0cmluZyBhbmQgZnJhZ21lbnQgb2ZmIG9mIGEgZ2l2ZW4gVVJMIG9yIHBhdGggKGlmIHByZXNlbnQpXG4gKlxuICogQHBhcmFtIHVybFBhdGggRnVsbCBVUkwgb3IgcGF0aCwgaW5jbHVkaW5nIHBvc3NpYmxlIHF1ZXJ5IHN0cmluZyBhbmQvb3IgZnJhZ21lbnRcbiAqIEByZXR1cm5zIFVSTCBvciBwYXRoIHdpdGhvdXQgcXVlcnkgc3RyaW5nIG9yIGZyYWdtZW50XG4gKi9cbmZ1bmN0aW9uIHN0cmlwVXJsUXVlcnlBbmRGcmFnbWVudCh1cmxQYXRoKSB7XG4gIHJldHVybiAodXJsUGF0aC5zcGxpdCgvWz8jXS8sIDEpIClbMF07XG59XG5cbi8qKlxuICogVGFrZXMgYSBVUkwgb2JqZWN0IGFuZCByZXR1cm5zIGEgc2FuaXRpemVkIHN0cmluZyB3aGljaCBpcyBzYWZlIHRvIHVzZSBhcyBzcGFuIG5hbWVcbiAqIHNlZTogaHR0cHM6Ly9kZXZlbG9wLnNlbnRyeS5kZXYvc2RrL2RhdGEtaGFuZGxpbmcvI3N0cnVjdHVyaW5nLWRhdGFcbiAqL1xuZnVuY3Rpb24gZ2V0U2FuaXRpemVkVXJsU3RyaW5nKHVybCkge1xuICBjb25zdCB7IHByb3RvY29sLCBob3N0LCBwYXRoIH0gPSB1cmw7XG5cbiAgY29uc3QgZmlsdGVyZWRIb3N0ID1cbiAgICBob3N0XG4gICAgICAvLyBBbHdheXMgZmlsdGVyIG91dCBhdXRob3JpdHlcbiAgICAgID8ucmVwbGFjZSgvXi4qQC8sICdbZmlsdGVyZWRdOltmaWx0ZXJlZF1AJylcbiAgICAgIC8vIERvbid0IHNob3cgc3RhbmRhcmQgOjgwIChodHRwKSBhbmQgOjQ0MyAoaHR0cHMpIHBvcnRzIHRvIHJlZHVjZSB0aGUgbm9pc2VcbiAgICAgIC8vIFRPRE86IFVzZSBuZXcgVVJMIGdsb2JhbCBpZiBpdCBleGlzdHNcbiAgICAgIC5yZXBsYWNlKC8oOjgwKSQvLCAnJylcbiAgICAgIC5yZXBsYWNlKC8oOjQ0MykkLywgJycpIHx8ICcnO1xuXG4gIHJldHVybiBgJHtwcm90b2NvbCA/IGAke3Byb3RvY29sfTovL2AgOiAnJ30ke2ZpbHRlcmVkSG9zdH0ke3BhdGh9YDtcbn1cblxuZXhwb3J0cy5nZXRIdHRwU3BhbkRldGFpbHNGcm9tVXJsT2JqZWN0ID0gZ2V0SHR0cFNwYW5EZXRhaWxzRnJvbVVybE9iamVjdDtcbmV4cG9ydHMuZ2V0U2FuaXRpemVkVXJsU3RyaW5nID0gZ2V0U2FuaXRpemVkVXJsU3RyaW5nO1xuZXhwb3J0cy5nZXRTYW5pdGl6ZWRVcmxTdHJpbmdGcm9tVXJsT2JqZWN0ID0gZ2V0U2FuaXRpemVkVXJsU3RyaW5nRnJvbVVybE9iamVjdDtcbmV4cG9ydHMuaXNVUkxPYmplY3RSZWxhdGl2ZSA9IGlzVVJMT2JqZWN0UmVsYXRpdmU7XG5leHBvcnRzLnBhcnNlU3RyaW5nVG9VUkxPYmplY3QgPSBwYXJzZVN0cmluZ1RvVVJMT2JqZWN0O1xuZXhwb3J0cy5wYXJzZVVybCA9IHBhcnNlVXJsO1xuZXhwb3J0cy5zdHJpcFVybFF1ZXJ5QW5kRnJhZ21lbnQgPSBzdHJpcFVybFF1ZXJ5QW5kRnJhZ21lbnQ7XG4vLyMgc291cmNlTWFwcGluZ1VSTD11cmwuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/url.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/vercel-ai-attributes.js":
/*!******************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/vercel-ai-attributes.js ***!
  \******************************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n/* eslint-disable max-lines */\n/**\n * AI SDK Telemetry Attributes\n * Based on https://ai-sdk.dev/docs/ai-sdk-core/telemetry#collected-data\n */\n\n\n// =============================================================================\n// SHARED ATTRIBUTES\n// =============================================================================\n\n/**\n * `generateText` function - `ai.generateText` span\n * `streamText` function - `ai.streamText` span\n *\n * The prompt that was used when calling the function\n * @see https://ai-sdk.dev/docs/ai-sdk-core/telemetry#generatetext-function\n * @see https://ai-sdk.dev/docs/ai-sdk-core/telemetry#streamtext-function\n */\nconst AI_PROMPT_ATTRIBUTE = 'ai.prompt';\n\n/**\n * `generateObject` function - `ai.generateObject` span\n * `streamObject` function - `ai.streamObject` span\n *\n * The object that was generated (stringified JSON)\n * @see https://ai-sdk.dev/docs/ai-sdk-core/telemetry#generateobject-function\n * @see https://ai-sdk.dev/docs/ai-sdk-core/telemetry#streamobject-function\n */\nconst AI_RESPONSE_OBJECT_ATTRIBUTE = 'ai.response.object';\n\n// =============================================================================\n// GENERATETEXT FUNCTION - UNIQUE ATTRIBUTES\n// =============================================================================\n\n/**\n * `generateText` function - `ai.generateText` span\n *\n * The text that was generated\n * @see https://ai-sdk.dev/docs/ai-sdk-core/telemetry#generatetext-function\n */\nconst AI_RESPONSE_TEXT_ATTRIBUTE = 'ai.response.text';\n\n/**\n * `generateText` function - `ai.generateText` span\n *\n * The tool calls that were made as part of the generation (stringified JSON)\n * @see https://ai-sdk.dev/docs/ai-sdk-core/telemetry#generatetext-function\n */\nconst AI_RESPONSE_TOOL_CALLS_ATTRIBUTE = 'ai.response.toolCalls';\n\n/**\n * `generateText` function - `ai.generateText.doGenerate` span\n *\n * The messages that were passed into the provider\n * @see https://ai-sdk.dev/docs/ai-sdk-core/telemetry#generatetext-function\n */\nconst AI_PROMPT_MESSAGES_ATTRIBUTE = 'ai.prompt.messages';\n\n/**\n * `generateText` function - `ai.generateText.doGenerate` span\n *\n * Array of stringified tool definitions\n * @see https://ai-sdk.dev/docs/ai-sdk-core/telemetry#generatetext-function\n */\nconst AI_PROMPT_TOOLS_ATTRIBUTE = 'ai.prompt.tools';\n\n/**\n * Basic LLM span information\n * Multiple spans\n *\n * The id of the model\n * @see https://ai-sdk.dev/docs/ai-sdk-core/telemetry#basic-llm-span-information\n */\nconst AI_MODEL_ID_ATTRIBUTE = 'ai.model.id';\n\n/**\n * Basic LLM span information\n * Multiple spans\n *\n * The provider of the model\n * @see https://ai-sdk.dev/docs/ai-sdk-core/telemetry#basic-llm-span-information\n */\nconst AI_MODEL_PROVIDER_ATTRIBUTE = 'ai.model.provider';\n\n/**\n * Basic LLM span information\n * Multiple spans\n *\n * Provider specific metadata returned with the generation response\n * @see https://ai-sdk.dev/docs/ai-sdk-core/telemetry#basic-llm-span-information\n */\nconst AI_RESPONSE_PROVIDER_METADATA_ATTRIBUTE = 'ai.response.providerMetadata';\n\n/**\n * Basic LLM span information\n * Multiple spans\n *\n * The functionId that was set through `telemetry.functionId`\n * @see https://ai-sdk.dev/docs/ai-sdk-core/telemetry#basic-llm-span-information\n */\nconst AI_TELEMETRY_FUNCTION_ID_ATTRIBUTE = 'ai.telemetry.functionId';\n\n/**\n * Basic LLM span information\n * Multiple spans\n *\n * The number of completion tokens that were used\n * @see https://ai-sdk.dev/docs/ai-sdk-core/telemetry#basic-llm-span-information\n */\nconst AI_USAGE_COMPLETION_TOKENS_ATTRIBUTE = 'ai.usage.completionTokens';\n\n/**\n * Basic LLM span information\n * Multiple spans\n *\n * The number of prompt tokens that were used\n * @see https://ai-sdk.dev/docs/ai-sdk-core/telemetry#basic-llm-span-information\n */\nconst AI_USAGE_PROMPT_TOKENS_ATTRIBUTE = 'ai.usage.promptTokens';\n\n/**\n * Semantic Conventions for GenAI operations\n * Individual LLM call spans\n *\n * The model that was used to generate the response\n * @see https://ai-sdk.dev/docs/ai-sdk-core/telemetry#call-llm-span-information\n */\nconst GEN_AI_RESPONSE_MODEL_ATTRIBUTE = 'gen_ai.response.model';\n\n/**\n * Semantic Conventions for GenAI operations\n * Individual LLM call spans\n *\n * The number of prompt tokens that were used\n * @see https://ai-sdk.dev/docs/ai-sdk-core/telemetry#call-llm-span-information\n */\nconst GEN_AI_USAGE_INPUT_TOKENS_ATTRIBUTE = 'gen_ai.usage.input_tokens';\n\n/**\n * Semantic Conventions for GenAI operations\n * Individual LLM call spans\n *\n * The number of completion tokens that were used\n * @see https://ai-sdk.dev/docs/ai-sdk-core/telemetry#call-llm-span-information\n */\nconst GEN_AI_USAGE_OUTPUT_TOKENS_ATTRIBUTE = 'gen_ai.usage.output_tokens';\n\n// =============================================================================\n// TOOL CALL SPANS\n// =============================================================================\n\n/**\n * Tool call spans\n * `ai.toolCall` span\n *\n * The name of the tool\n * @see https://ai-sdk.dev/docs/ai-sdk-core/telemetry#tool-call-spans\n */\nconst AI_TOOL_CALL_NAME_ATTRIBUTE = 'ai.toolCall.name';\n\n/**\n * Tool call spans\n * `ai.toolCall` span\n *\n * The id of the tool call\n * @see https://ai-sdk.dev/docs/ai-sdk-core/telemetry#tool-call-spans\n */\nconst AI_TOOL_CALL_ID_ATTRIBUTE = 'ai.toolCall.id';\n\n/**\n * Tool call spans\n * `ai.toolCall` span\n *\n * The parameters of the tool call\n * @see https://ai-sdk.dev/docs/ai-sdk-core/telemetry#tool-call-spans\n */\nconst AI_TOOL_CALL_ARGS_ATTRIBUTE = 'ai.toolCall.args';\n\n/**\n * Tool call spans\n * `ai.toolCall` span\n *\n * The result of the tool call\n * @see https://ai-sdk.dev/docs/ai-sdk-core/telemetry#tool-call-spans\n */\nconst AI_TOOL_CALL_RESULT_ATTRIBUTE = 'ai.toolCall.result';\n\n// =============================================================================\n// PROVIDER METADATA\n// =============================================================================\n\n/**\n * OpenAI Provider Metadata\n * @see https://ai-sdk.dev/providers/ai-sdk-providers/openai\n * @see https://github.com/vercel/ai/blob/65e042afde6aad4da9d7a62526ece839eb34f9a5/packages/openai/src/openai-chat-language-model.ts#L397-L416\n * @see https://github.com/vercel/ai/blob/65e042afde6aad4da9d7a62526ece839eb34f9a5/packages/openai/src/responses/openai-responses-language-model.ts#L377C7-L384\n */\n\nexports.AI_MODEL_ID_ATTRIBUTE = AI_MODEL_ID_ATTRIBUTE;\nexports.AI_MODEL_PROVIDER_ATTRIBUTE = AI_MODEL_PROVIDER_ATTRIBUTE;\nexports.AI_PROMPT_ATTRIBUTE = AI_PROMPT_ATTRIBUTE;\nexports.AI_PROMPT_MESSAGES_ATTRIBUTE = AI_PROMPT_MESSAGES_ATTRIBUTE;\nexports.AI_PROMPT_TOOLS_ATTRIBUTE = AI_PROMPT_TOOLS_ATTRIBUTE;\nexports.AI_RESPONSE_OBJECT_ATTRIBUTE = AI_RESPONSE_OBJECT_ATTRIBUTE;\nexports.AI_RESPONSE_PROVIDER_METADATA_ATTRIBUTE = AI_RESPONSE_PROVIDER_METADATA_ATTRIBUTE;\nexports.AI_RESPONSE_TEXT_ATTRIBUTE = AI_RESPONSE_TEXT_ATTRIBUTE;\nexports.AI_RESPONSE_TOOL_CALLS_ATTRIBUTE = AI_RESPONSE_TOOL_CALLS_ATTRIBUTE;\nexports.AI_TELEMETRY_FUNCTION_ID_ATTRIBUTE = AI_TELEMETRY_FUNCTION_ID_ATTRIBUTE;\nexports.AI_TOOL_CALL_ARGS_ATTRIBUTE = AI_TOOL_CALL_ARGS_ATTRIBUTE;\nexports.AI_TOOL_CALL_ID_ATTRIBUTE = AI_TOOL_CALL_ID_ATTRIBUTE;\nexports.AI_TOOL_CALL_NAME_ATTRIBUTE = AI_TOOL_CALL_NAME_ATTRIBUTE;\nexports.AI_TOOL_CALL_RESULT_ATTRIBUTE = AI_TOOL_CALL_RESULT_ATTRIBUTE;\nexports.AI_USAGE_COMPLETION_TOKENS_ATTRIBUTE = AI_USAGE_COMPLETION_TOKENS_ATTRIBUTE;\nexports.AI_USAGE_PROMPT_TOKENS_ATTRIBUTE = AI_USAGE_PROMPT_TOKENS_ATTRIBUTE;\nexports.GEN_AI_RESPONSE_MODEL_ATTRIBUTE = GEN_AI_RESPONSE_MODEL_ATTRIBUTE;\nexports.GEN_AI_USAGE_INPUT_TOKENS_ATTRIBUTE = GEN_AI_USAGE_INPUT_TOKENS_ATTRIBUTE;\nexports.GEN_AI_USAGE_OUTPUT_TOKENS_ATTRIBUTE = GEN_AI_USAGE_OUTPUT_TOKENS_ATTRIBUTE;\n//# sourceMappingURL=vercel-ai-attributes.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy92ZXJjZWwtYWktYXR0cmlidXRlcy5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RTtBQUNBO0FBQ0E7QUFDQTtBQUNBOzs7QUFHQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSw2QkFBNkI7QUFDN0IsbUNBQW1DO0FBQ25DLDJCQUEyQjtBQUMzQixvQ0FBb0M7QUFDcEMsaUNBQWlDO0FBQ2pDLG9DQUFvQztBQUNwQywrQ0FBK0M7QUFDL0Msa0NBQWtDO0FBQ2xDLHdDQUF3QztBQUN4QywwQ0FBMEM7QUFDMUMsbUNBQW1DO0FBQ25DLGlDQUFpQztBQUNqQyxtQ0FBbUM7QUFDbkMscUNBQXFDO0FBQ3JDLDRDQUE0QztBQUM1Qyx3Q0FBd0M7QUFDeEMsdUNBQXVDO0FBQ3ZDLDJDQUEyQztBQUMzQyw0Q0FBNEM7QUFDNUMiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy92ZXJjZWwtYWktYXR0cmlidXRlcy5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuLyogZXNsaW50LWRpc2FibGUgbWF4LWxpbmVzICovXG4vKipcbiAqIEFJIFNESyBUZWxlbWV0cnkgQXR0cmlidXRlc1xuICogQmFzZWQgb24gaHR0cHM6Ly9haS1zZGsuZGV2L2RvY3MvYWktc2RrLWNvcmUvdGVsZW1ldHJ5I2NvbGxlY3RlZC1kYXRhXG4gKi9cblxuXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuLy8gU0hBUkVEIEFUVFJJQlVURVNcbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG5cbi8qKlxuICogYGdlbmVyYXRlVGV4dGAgZnVuY3Rpb24gLSBgYWkuZ2VuZXJhdGVUZXh0YCBzcGFuXG4gKiBgc3RyZWFtVGV4dGAgZnVuY3Rpb24gLSBgYWkuc3RyZWFtVGV4dGAgc3BhblxuICpcbiAqIFRoZSBwcm9tcHQgdGhhdCB3YXMgdXNlZCB3aGVuIGNhbGxpbmcgdGhlIGZ1bmN0aW9uXG4gKiBAc2VlIGh0dHBzOi8vYWktc2RrLmRldi9kb2NzL2FpLXNkay1jb3JlL3RlbGVtZXRyeSNnZW5lcmF0ZXRleHQtZnVuY3Rpb25cbiAqIEBzZWUgaHR0cHM6Ly9haS1zZGsuZGV2L2RvY3MvYWktc2RrLWNvcmUvdGVsZW1ldHJ5I3N0cmVhbXRleHQtZnVuY3Rpb25cbiAqL1xuY29uc3QgQUlfUFJPTVBUX0FUVFJJQlVURSA9ICdhaS5wcm9tcHQnO1xuXG4vKipcbiAqIGBnZW5lcmF0ZU9iamVjdGAgZnVuY3Rpb24gLSBgYWkuZ2VuZXJhdGVPYmplY3RgIHNwYW5cbiAqIGBzdHJlYW1PYmplY3RgIGZ1bmN0aW9uIC0gYGFpLnN0cmVhbU9iamVjdGAgc3BhblxuICpcbiAqIFRoZSBvYmplY3QgdGhhdCB3YXMgZ2VuZXJhdGVkIChzdHJpbmdpZmllZCBKU09OKVxuICogQHNlZSBodHRwczovL2FpLXNkay5kZXYvZG9jcy9haS1zZGstY29yZS90ZWxlbWV0cnkjZ2VuZXJhdGVvYmplY3QtZnVuY3Rpb25cbiAqIEBzZWUgaHR0cHM6Ly9haS1zZGsuZGV2L2RvY3MvYWktc2RrLWNvcmUvdGVsZW1ldHJ5I3N0cmVhbW9iamVjdC1mdW5jdGlvblxuICovXG5jb25zdCBBSV9SRVNQT05TRV9PQkpFQ1RfQVRUUklCVVRFID0gJ2FpLnJlc3BvbnNlLm9iamVjdCc7XG5cbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG4vLyBHRU5FUkFURVRFWFQgRlVOQ1RJT04gLSBVTklRVUUgQVRUUklCVVRFU1xuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cblxuLyoqXG4gKiBgZ2VuZXJhdGVUZXh0YCBmdW5jdGlvbiAtIGBhaS5nZW5lcmF0ZVRleHRgIHNwYW5cbiAqXG4gKiBUaGUgdGV4dCB0aGF0IHdhcyBnZW5lcmF0ZWRcbiAqIEBzZWUgaHR0cHM6Ly9haS1zZGsuZGV2L2RvY3MvYWktc2RrLWNvcmUvdGVsZW1ldHJ5I2dlbmVyYXRldGV4dC1mdW5jdGlvblxuICovXG5jb25zdCBBSV9SRVNQT05TRV9URVhUX0FUVFJJQlVURSA9ICdhaS5yZXNwb25zZS50ZXh0JztcblxuLyoqXG4gKiBgZ2VuZXJhdGVUZXh0YCBmdW5jdGlvbiAtIGBhaS5nZW5lcmF0ZVRleHRgIHNwYW5cbiAqXG4gKiBUaGUgdG9vbCBjYWxscyB0aGF0IHdlcmUgbWFkZSBhcyBwYXJ0IG9mIHRoZSBnZW5lcmF0aW9uIChzdHJpbmdpZmllZCBKU09OKVxuICogQHNlZSBodHRwczovL2FpLXNkay5kZXYvZG9jcy9haS1zZGstY29yZS90ZWxlbWV0cnkjZ2VuZXJhdGV0ZXh0LWZ1bmN0aW9uXG4gKi9cbmNvbnN0IEFJX1JFU1BPTlNFX1RPT0xfQ0FMTFNfQVRUUklCVVRFID0gJ2FpLnJlc3BvbnNlLnRvb2xDYWxscyc7XG5cbi8qKlxuICogYGdlbmVyYXRlVGV4dGAgZnVuY3Rpb24gLSBgYWkuZ2VuZXJhdGVUZXh0LmRvR2VuZXJhdGVgIHNwYW5cbiAqXG4gKiBUaGUgbWVzc2FnZXMgdGhhdCB3ZXJlIHBhc3NlZCBpbnRvIHRoZSBwcm92aWRlclxuICogQHNlZSBodHRwczovL2FpLXNkay5kZXYvZG9jcy9haS1zZGstY29yZS90ZWxlbWV0cnkjZ2VuZXJhdGV0ZXh0LWZ1bmN0aW9uXG4gKi9cbmNvbnN0IEFJX1BST01QVF9NRVNTQUdFU19BVFRSSUJVVEUgPSAnYWkucHJvbXB0Lm1lc3NhZ2VzJztcblxuLyoqXG4gKiBgZ2VuZXJhdGVUZXh0YCBmdW5jdGlvbiAtIGBhaS5nZW5lcmF0ZVRleHQuZG9HZW5lcmF0ZWAgc3BhblxuICpcbiAqIEFycmF5IG9mIHN0cmluZ2lmaWVkIHRvb2wgZGVmaW5pdGlvbnNcbiAqIEBzZWUgaHR0cHM6Ly9haS1zZGsuZGV2L2RvY3MvYWktc2RrLWNvcmUvdGVsZW1ldHJ5I2dlbmVyYXRldGV4dC1mdW5jdGlvblxuICovXG5jb25zdCBBSV9QUk9NUFRfVE9PTFNfQVRUUklCVVRFID0gJ2FpLnByb21wdC50b29scyc7XG5cbi8qKlxuICogQmFzaWMgTExNIHNwYW4gaW5mb3JtYXRpb25cbiAqIE11bHRpcGxlIHNwYW5zXG4gKlxuICogVGhlIGlkIG9mIHRoZSBtb2RlbFxuICogQHNlZSBodHRwczovL2FpLXNkay5kZXYvZG9jcy9haS1zZGstY29yZS90ZWxlbWV0cnkjYmFzaWMtbGxtLXNwYW4taW5mb3JtYXRpb25cbiAqL1xuY29uc3QgQUlfTU9ERUxfSURfQVRUUklCVVRFID0gJ2FpLm1vZGVsLmlkJztcblxuLyoqXG4gKiBCYXNpYyBMTE0gc3BhbiBpbmZvcm1hdGlvblxuICogTXVsdGlwbGUgc3BhbnNcbiAqXG4gKiBUaGUgcHJvdmlkZXIgb2YgdGhlIG1vZGVsXG4gKiBAc2VlIGh0dHBzOi8vYWktc2RrLmRldi9kb2NzL2FpLXNkay1jb3JlL3RlbGVtZXRyeSNiYXNpYy1sbG0tc3Bhbi1pbmZvcm1hdGlvblxuICovXG5jb25zdCBBSV9NT0RFTF9QUk9WSURFUl9BVFRSSUJVVEUgPSAnYWkubW9kZWwucHJvdmlkZXInO1xuXG4vKipcbiAqIEJhc2ljIExMTSBzcGFuIGluZm9ybWF0aW9uXG4gKiBNdWx0aXBsZSBzcGFuc1xuICpcbiAqIFByb3ZpZGVyIHNwZWNpZmljIG1ldGFkYXRhIHJldHVybmVkIHdpdGggdGhlIGdlbmVyYXRpb24gcmVzcG9uc2VcbiAqIEBzZWUgaHR0cHM6Ly9haS1zZGsuZGV2L2RvY3MvYWktc2RrLWNvcmUvdGVsZW1ldHJ5I2Jhc2ljLWxsbS1zcGFuLWluZm9ybWF0aW9uXG4gKi9cbmNvbnN0IEFJX1JFU1BPTlNFX1BST1ZJREVSX01FVEFEQVRBX0FUVFJJQlVURSA9ICdhaS5yZXNwb25zZS5wcm92aWRlck1ldGFkYXRhJztcblxuLyoqXG4gKiBCYXNpYyBMTE0gc3BhbiBpbmZvcm1hdGlvblxuICogTXVsdGlwbGUgc3BhbnNcbiAqXG4gKiBUaGUgZnVuY3Rpb25JZCB0aGF0IHdhcyBzZXQgdGhyb3VnaCBgdGVsZW1ldHJ5LmZ1bmN0aW9uSWRgXG4gKiBAc2VlIGh0dHBzOi8vYWktc2RrLmRldi9kb2NzL2FpLXNkay1jb3JlL3RlbGVtZXRyeSNiYXNpYy1sbG0tc3Bhbi1pbmZvcm1hdGlvblxuICovXG5jb25zdCBBSV9URUxFTUVUUllfRlVOQ1RJT05fSURfQVRUUklCVVRFID0gJ2FpLnRlbGVtZXRyeS5mdW5jdGlvbklkJztcblxuLyoqXG4gKiBCYXNpYyBMTE0gc3BhbiBpbmZvcm1hdGlvblxuICogTXVsdGlwbGUgc3BhbnNcbiAqXG4gKiBUaGUgbnVtYmVyIG9mIGNvbXBsZXRpb24gdG9rZW5zIHRoYXQgd2VyZSB1c2VkXG4gKiBAc2VlIGh0dHBzOi8vYWktc2RrLmRldi9kb2NzL2FpLXNkay1jb3JlL3RlbGVtZXRyeSNiYXNpYy1sbG0tc3Bhbi1pbmZvcm1hdGlvblxuICovXG5jb25zdCBBSV9VU0FHRV9DT01QTEVUSU9OX1RPS0VOU19BVFRSSUJVVEUgPSAnYWkudXNhZ2UuY29tcGxldGlvblRva2Vucyc7XG5cbi8qKlxuICogQmFzaWMgTExNIHNwYW4gaW5mb3JtYXRpb25cbiAqIE11bHRpcGxlIHNwYW5zXG4gKlxuICogVGhlIG51bWJlciBvZiBwcm9tcHQgdG9rZW5zIHRoYXQgd2VyZSB1c2VkXG4gKiBAc2VlIGh0dHBzOi8vYWktc2RrLmRldi9kb2NzL2FpLXNkay1jb3JlL3RlbGVtZXRyeSNiYXNpYy1sbG0tc3Bhbi1pbmZvcm1hdGlvblxuICovXG5jb25zdCBBSV9VU0FHRV9QUk9NUFRfVE9LRU5TX0FUVFJJQlVURSA9ICdhaS51c2FnZS5wcm9tcHRUb2tlbnMnO1xuXG4vKipcbiAqIFNlbWFudGljIENvbnZlbnRpb25zIGZvciBHZW5BSSBvcGVyYXRpb25zXG4gKiBJbmRpdmlkdWFsIExMTSBjYWxsIHNwYW5zXG4gKlxuICogVGhlIG1vZGVsIHRoYXQgd2FzIHVzZWQgdG8gZ2VuZXJhdGUgdGhlIHJlc3BvbnNlXG4gKiBAc2VlIGh0dHBzOi8vYWktc2RrLmRldi9kb2NzL2FpLXNkay1jb3JlL3RlbGVtZXRyeSNjYWxsLWxsbS1zcGFuLWluZm9ybWF0aW9uXG4gKi9cbmNvbnN0IEdFTl9BSV9SRVNQT05TRV9NT0RFTF9BVFRSSUJVVEUgPSAnZ2VuX2FpLnJlc3BvbnNlLm1vZGVsJztcblxuLyoqXG4gKiBTZW1hbnRpYyBDb252ZW50aW9ucyBmb3IgR2VuQUkgb3BlcmF0aW9uc1xuICogSW5kaXZpZHVhbCBMTE0gY2FsbCBzcGFuc1xuICpcbiAqIFRoZSBudW1iZXIgb2YgcHJvbXB0IHRva2VucyB0aGF0IHdlcmUgdXNlZFxuICogQHNlZSBodHRwczovL2FpLXNkay5kZXYvZG9jcy9haS1zZGstY29yZS90ZWxlbWV0cnkjY2FsbC1sbG0tc3Bhbi1pbmZvcm1hdGlvblxuICovXG5jb25zdCBHRU5fQUlfVVNBR0VfSU5QVVRfVE9LRU5TX0FUVFJJQlVURSA9ICdnZW5fYWkudXNhZ2UuaW5wdXRfdG9rZW5zJztcblxuLyoqXG4gKiBTZW1hbnRpYyBDb252ZW50aW9ucyBmb3IgR2VuQUkgb3BlcmF0aW9uc1xuICogSW5kaXZpZHVhbCBMTE0gY2FsbCBzcGFuc1xuICpcbiAqIFRoZSBudW1iZXIgb2YgY29tcGxldGlvbiB0b2tlbnMgdGhhdCB3ZXJlIHVzZWRcbiAqIEBzZWUgaHR0cHM6Ly9haS1zZGsuZGV2L2RvY3MvYWktc2RrLWNvcmUvdGVsZW1ldHJ5I2NhbGwtbGxtLXNwYW4taW5mb3JtYXRpb25cbiAqL1xuY29uc3QgR0VOX0FJX1VTQUdFX09VVFBVVF9UT0tFTlNfQVRUUklCVVRFID0gJ2dlbl9haS51c2FnZS5vdXRwdXRfdG9rZW5zJztcblxuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cbi8vIFRPT0wgQ0FMTCBTUEFOU1xuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cblxuLyoqXG4gKiBUb29sIGNhbGwgc3BhbnNcbiAqIGBhaS50b29sQ2FsbGAgc3BhblxuICpcbiAqIFRoZSBuYW1lIG9mIHRoZSB0b29sXG4gKiBAc2VlIGh0dHBzOi8vYWktc2RrLmRldi9kb2NzL2FpLXNkay1jb3JlL3RlbGVtZXRyeSN0b29sLWNhbGwtc3BhbnNcbiAqL1xuY29uc3QgQUlfVE9PTF9DQUxMX05BTUVfQVRUUklCVVRFID0gJ2FpLnRvb2xDYWxsLm5hbWUnO1xuXG4vKipcbiAqIFRvb2wgY2FsbCBzcGFuc1xuICogYGFpLnRvb2xDYWxsYCBzcGFuXG4gKlxuICogVGhlIGlkIG9mIHRoZSB0b29sIGNhbGxcbiAqIEBzZWUgaHR0cHM6Ly9haS1zZGsuZGV2L2RvY3MvYWktc2RrLWNvcmUvdGVsZW1ldHJ5I3Rvb2wtY2FsbC1zcGFuc1xuICovXG5jb25zdCBBSV9UT09MX0NBTExfSURfQVRUUklCVVRFID0gJ2FpLnRvb2xDYWxsLmlkJztcblxuLyoqXG4gKiBUb29sIGNhbGwgc3BhbnNcbiAqIGBhaS50b29sQ2FsbGAgc3BhblxuICpcbiAqIFRoZSBwYXJhbWV0ZXJzIG9mIHRoZSB0b29sIGNhbGxcbiAqIEBzZWUgaHR0cHM6Ly9haS1zZGsuZGV2L2RvY3MvYWktc2RrLWNvcmUvdGVsZW1ldHJ5I3Rvb2wtY2FsbC1zcGFuc1xuICovXG5jb25zdCBBSV9UT09MX0NBTExfQVJHU19BVFRSSUJVVEUgPSAnYWkudG9vbENhbGwuYXJncyc7XG5cbi8qKlxuICogVG9vbCBjYWxsIHNwYW5zXG4gKiBgYWkudG9vbENhbGxgIHNwYW5cbiAqXG4gKiBUaGUgcmVzdWx0IG9mIHRoZSB0b29sIGNhbGxcbiAqIEBzZWUgaHR0cHM6Ly9haS1zZGsuZGV2L2RvY3MvYWktc2RrLWNvcmUvdGVsZW1ldHJ5I3Rvb2wtY2FsbC1zcGFuc1xuICovXG5jb25zdCBBSV9UT09MX0NBTExfUkVTVUxUX0FUVFJJQlVURSA9ICdhaS50b29sQ2FsbC5yZXN1bHQnO1xuXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuLy8gUFJPVklERVIgTUVUQURBVEFcbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG5cbi8qKlxuICogT3BlbkFJIFByb3ZpZGVyIE1ldGFkYXRhXG4gKiBAc2VlIGh0dHBzOi8vYWktc2RrLmRldi9wcm92aWRlcnMvYWktc2RrLXByb3ZpZGVycy9vcGVuYWlcbiAqIEBzZWUgaHR0cHM6Ly9naXRodWIuY29tL3ZlcmNlbC9haS9ibG9iLzY1ZTA0MmFmZGU2YWFkNGRhOWQ3YTYyNTI2ZWNlODM5ZWIzNGY5YTUvcGFja2FnZXMvb3BlbmFpL3NyYy9vcGVuYWktY2hhdC1sYW5ndWFnZS1tb2RlbC50cyNMMzk3LUw0MTZcbiAqIEBzZWUgaHR0cHM6Ly9naXRodWIuY29tL3ZlcmNlbC9haS9ibG9iLzY1ZTA0MmFmZGU2YWFkNGRhOWQ3YTYyNTI2ZWNlODM5ZWIzNGY5YTUvcGFja2FnZXMvb3BlbmFpL3NyYy9yZXNwb25zZXMvb3BlbmFpLXJlc3BvbnNlcy1sYW5ndWFnZS1tb2RlbC50cyNMMzc3QzctTDM4NFxuICovXG5cbmV4cG9ydHMuQUlfTU9ERUxfSURfQVRUUklCVVRFID0gQUlfTU9ERUxfSURfQVRUUklCVVRFO1xuZXhwb3J0cy5BSV9NT0RFTF9QUk9WSURFUl9BVFRSSUJVVEUgPSBBSV9NT0RFTF9QUk9WSURFUl9BVFRSSUJVVEU7XG5leHBvcnRzLkFJX1BST01QVF9BVFRSSUJVVEUgPSBBSV9QUk9NUFRfQVRUUklCVVRFO1xuZXhwb3J0cy5BSV9QUk9NUFRfTUVTU0FHRVNfQVRUUklCVVRFID0gQUlfUFJPTVBUX01FU1NBR0VTX0FUVFJJQlVURTtcbmV4cG9ydHMuQUlfUFJPTVBUX1RPT0xTX0FUVFJJQlVURSA9IEFJX1BST01QVF9UT09MU19BVFRSSUJVVEU7XG5leHBvcnRzLkFJX1JFU1BPTlNFX09CSkVDVF9BVFRSSUJVVEUgPSBBSV9SRVNQT05TRV9PQkpFQ1RfQVRUUklCVVRFO1xuZXhwb3J0cy5BSV9SRVNQT05TRV9QUk9WSURFUl9NRVRBREFUQV9BVFRSSUJVVEUgPSBBSV9SRVNQT05TRV9QUk9WSURFUl9NRVRBREFUQV9BVFRSSUJVVEU7XG5leHBvcnRzLkFJX1JFU1BPTlNFX1RFWFRfQVRUUklCVVRFID0gQUlfUkVTUE9OU0VfVEVYVF9BVFRSSUJVVEU7XG5leHBvcnRzLkFJX1JFU1BPTlNFX1RPT0xfQ0FMTFNfQVRUUklCVVRFID0gQUlfUkVTUE9OU0VfVE9PTF9DQUxMU19BVFRSSUJVVEU7XG5leHBvcnRzLkFJX1RFTEVNRVRSWV9GVU5DVElPTl9JRF9BVFRSSUJVVEUgPSBBSV9URUxFTUVUUllfRlVOQ1RJT05fSURfQVRUUklCVVRFO1xuZXhwb3J0cy5BSV9UT09MX0NBTExfQVJHU19BVFRSSUJVVEUgPSBBSV9UT09MX0NBTExfQVJHU19BVFRSSUJVVEU7XG5leHBvcnRzLkFJX1RPT0xfQ0FMTF9JRF9BVFRSSUJVVEUgPSBBSV9UT09MX0NBTExfSURfQVRUUklCVVRFO1xuZXhwb3J0cy5BSV9UT09MX0NBTExfTkFNRV9BVFRSSUJVVEUgPSBBSV9UT09MX0NBTExfTkFNRV9BVFRSSUJVVEU7XG5leHBvcnRzLkFJX1RPT0xfQ0FMTF9SRVNVTFRfQVRUUklCVVRFID0gQUlfVE9PTF9DQUxMX1JFU1VMVF9BVFRSSUJVVEU7XG5leHBvcnRzLkFJX1VTQUdFX0NPTVBMRVRJT05fVE9LRU5TX0FUVFJJQlVURSA9IEFJX1VTQUdFX0NPTVBMRVRJT05fVE9LRU5TX0FUVFJJQlVURTtcbmV4cG9ydHMuQUlfVVNBR0VfUFJPTVBUX1RPS0VOU19BVFRSSUJVVEUgPSBBSV9VU0FHRV9QUk9NUFRfVE9LRU5TX0FUVFJJQlVURTtcbmV4cG9ydHMuR0VOX0FJX1JFU1BPTlNFX01PREVMX0FUVFJJQlVURSA9IEdFTl9BSV9SRVNQT05TRV9NT0RFTF9BVFRSSUJVVEU7XG5leHBvcnRzLkdFTl9BSV9VU0FHRV9JTlBVVF9UT0tFTlNfQVRUUklCVVRFID0gR0VOX0FJX1VTQUdFX0lOUFVUX1RPS0VOU19BVFRSSUJVVEU7XG5leHBvcnRzLkdFTl9BSV9VU0FHRV9PVVRQVVRfVE9LRU5TX0FUVFJJQlVURSA9IEdFTl9BSV9VU0FHRV9PVVRQVVRfVE9LRU5TX0FUVFJJQlVURTtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPXZlcmNlbC1haS1hdHRyaWJ1dGVzLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/vercel-ai-attributes.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/vercel-ai.js":
/*!*******************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/vercel-ai.js ***!
  \*******************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst semanticAttributes = __webpack_require__(/*! ../semanticAttributes.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/semanticAttributes.js\");\nconst spanUtils = __webpack_require__(/*! ./spanUtils.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanUtils.js\");\nconst vercelAiAttributes = __webpack_require__(/*! ./vercel-ai-attributes.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/vercel-ai-attributes.js\");\n\nfunction addOriginToSpan(span, origin) {\n  span.setAttribute(semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_ORIGIN, origin);\n}\n\n/**\n * Post-process spans emitted by the Vercel AI SDK.\n * This is supposed to be used in `client.on('spanStart', ...)\n */\nfunction onVercelAiSpanStart(span) {\n  const { data: attributes, description: name } = spanUtils.spanToJSON(span);\n\n  if (!name) {\n    return;\n  }\n\n  // Tool call spans\n  // https://ai-sdk.dev/docs/ai-sdk-core/telemetry#tool-call-spans\n  if (attributes[vercelAiAttributes.AI_TOOL_CALL_NAME_ATTRIBUTE] && attributes[vercelAiAttributes.AI_TOOL_CALL_ID_ATTRIBUTE] && name === 'ai.toolCall') {\n    processToolCallSpan(span, attributes);\n    return;\n  }\n\n  // The AI and Provider must be defined for generate, stream, and embed spans.\n  // The id of the model\n  const aiModelId = attributes[vercelAiAttributes.AI_MODEL_ID_ATTRIBUTE];\n  // the provider of the model\n  const aiModelProvider = attributes[vercelAiAttributes.AI_MODEL_PROVIDER_ATTRIBUTE];\n  if (typeof aiModelId !== 'string' || typeof aiModelProvider !== 'string' || !aiModelId || !aiModelProvider) {\n    return;\n  }\n\n  processGenerateSpan(span, name, attributes);\n}\n\nfunction vercelAiEventProcessor(event) {\n  if (event.type === 'transaction' && event.spans) {\n    for (const span of event.spans) {\n      // this mutates spans in-place\n      processEndedVercelAiSpan(span);\n    }\n  }\n  return event;\n}\n/**\n * Post-process spans emitted by the Vercel AI SDK.\n */\nfunction processEndedVercelAiSpan(span) {\n  const { data: attributes, origin } = span;\n\n  if (origin !== 'auto.vercelai.otel') {\n    return;\n  }\n\n  renameAttributeKey(attributes, vercelAiAttributes.AI_USAGE_COMPLETION_TOKENS_ATTRIBUTE, vercelAiAttributes.GEN_AI_USAGE_OUTPUT_TOKENS_ATTRIBUTE);\n  renameAttributeKey(attributes, vercelAiAttributes.AI_USAGE_PROMPT_TOKENS_ATTRIBUTE, vercelAiAttributes.GEN_AI_USAGE_INPUT_TOKENS_ATTRIBUTE);\n\n  if (\n    typeof attributes[vercelAiAttributes.GEN_AI_USAGE_OUTPUT_TOKENS_ATTRIBUTE] === 'number' &&\n    typeof attributes[vercelAiAttributes.GEN_AI_USAGE_INPUT_TOKENS_ATTRIBUTE] === 'number'\n  ) {\n    attributes['gen_ai.usage.total_tokens'] =\n      attributes[vercelAiAttributes.GEN_AI_USAGE_OUTPUT_TOKENS_ATTRIBUTE] + attributes[vercelAiAttributes.GEN_AI_USAGE_INPUT_TOKENS_ATTRIBUTE];\n  }\n\n  // Rename AI SDK attributes to standardized gen_ai attributes\n  renameAttributeKey(attributes, vercelAiAttributes.AI_PROMPT_MESSAGES_ATTRIBUTE, 'gen_ai.request.messages');\n  renameAttributeKey(attributes, vercelAiAttributes.AI_RESPONSE_TEXT_ATTRIBUTE, 'gen_ai.response.text');\n  renameAttributeKey(attributes, vercelAiAttributes.AI_RESPONSE_TOOL_CALLS_ATTRIBUTE, 'gen_ai.response.tool_calls');\n  renameAttributeKey(attributes, vercelAiAttributes.AI_RESPONSE_OBJECT_ATTRIBUTE, 'gen_ai.response.object');\n  renameAttributeKey(attributes, vercelAiAttributes.AI_PROMPT_TOOLS_ATTRIBUTE, 'gen_ai.request.available_tools');\n\n  renameAttributeKey(attributes, vercelAiAttributes.AI_TOOL_CALL_ARGS_ATTRIBUTE, 'gen_ai.tool.input');\n  renameAttributeKey(attributes, vercelAiAttributes.AI_TOOL_CALL_RESULT_ATTRIBUTE, 'gen_ai.tool.output');\n\n  addProviderMetadataToAttributes(attributes);\n\n  // Change attributes namespaced with `ai.X` to `vercel.ai.X`\n  for (const key of Object.keys(attributes)) {\n    if (key.startsWith('ai.')) {\n      renameAttributeKey(attributes, key, `vercel.${key}`);\n    }\n  }\n}\n\n/**\n * Renames an attribute key in the provided attributes object if the old key exists.\n * This function safely handles null and undefined values.\n */\nfunction renameAttributeKey(attributes, oldKey, newKey) {\n  if (attributes[oldKey] != null) {\n    attributes[newKey] = attributes[oldKey];\n    // eslint-disable-next-line @typescript-eslint/no-dynamic-delete\n    delete attributes[oldKey];\n  }\n}\n\nfunction processToolCallSpan(span, attributes) {\n  addOriginToSpan(span, 'auto.vercelai.otel');\n  span.setAttribute(semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_OP, 'gen_ai.execute_tool');\n  renameAttributeKey(attributes, vercelAiAttributes.AI_TOOL_CALL_NAME_ATTRIBUTE, 'gen_ai.tool.name');\n  renameAttributeKey(attributes, vercelAiAttributes.AI_TOOL_CALL_ID_ATTRIBUTE, 'gen_ai.tool.call.id');\n  // https://opentelemetry.io/docs/specs/semconv/registry/attributes/gen-ai/#gen-ai-tool-type\n  if (!attributes['gen_ai.tool.type']) {\n    span.setAttribute('gen_ai.tool.type', 'function');\n  }\n  const toolName = attributes['gen_ai.tool.name'];\n  if (toolName) {\n    span.updateName(`execute_tool ${toolName}`);\n  }\n}\n\nfunction processGenerateSpan(span, name, attributes) {\n  addOriginToSpan(span, 'auto.vercelai.otel');\n\n  const nameWthoutAi = name.replace('ai.', '');\n  span.setAttribute('ai.pipeline.name', nameWthoutAi);\n  span.updateName(nameWthoutAi);\n\n  // If a Telemetry name is set and it is a pipeline span, use that as the operation name\n  const functionId = attributes[vercelAiAttributes.AI_TELEMETRY_FUNCTION_ID_ATTRIBUTE];\n  if (functionId && typeof functionId === 'string' && name.split('.').length - 1 === 1) {\n    span.updateName(`${nameWthoutAi} ${functionId}`);\n    span.setAttribute('gen_ai.function_id', functionId);\n  }\n\n  if (attributes[vercelAiAttributes.AI_PROMPT_ATTRIBUTE]) {\n    span.setAttribute('gen_ai.prompt', attributes[vercelAiAttributes.AI_PROMPT_ATTRIBUTE]);\n  }\n  if (attributes[vercelAiAttributes.AI_MODEL_ID_ATTRIBUTE] && !attributes[vercelAiAttributes.GEN_AI_RESPONSE_MODEL_ATTRIBUTE]) {\n    span.setAttribute(vercelAiAttributes.GEN_AI_RESPONSE_MODEL_ATTRIBUTE, attributes[vercelAiAttributes.AI_MODEL_ID_ATTRIBUTE]);\n  }\n  span.setAttribute('ai.streaming', name.includes('stream'));\n\n  // Generate Spans\n  if (name === 'ai.generateText') {\n    span.setAttribute(semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_OP, 'gen_ai.invoke_agent');\n    return;\n  }\n\n  if (name === 'ai.generateText.doGenerate') {\n    span.setAttribute(semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_OP, 'gen_ai.generate_text');\n    span.updateName(`generate_text ${attributes[vercelAiAttributes.AI_MODEL_ID_ATTRIBUTE]}`);\n    return;\n  }\n\n  if (name === 'ai.streamText') {\n    span.setAttribute(semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_OP, 'gen_ai.invoke_agent');\n    return;\n  }\n\n  if (name === 'ai.streamText.doStream') {\n    span.setAttribute(semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_OP, 'gen_ai.stream_text');\n    span.updateName(`stream_text ${attributes[vercelAiAttributes.AI_MODEL_ID_ATTRIBUTE]}`);\n    return;\n  }\n\n  if (name === 'ai.generateObject') {\n    span.setAttribute(semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_OP, 'gen_ai.invoke_agent');\n    return;\n  }\n\n  if (name === 'ai.generateObject.doGenerate') {\n    span.setAttribute(semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_OP, 'gen_ai.generate_object');\n    span.updateName(`generate_object ${attributes[vercelAiAttributes.AI_MODEL_ID_ATTRIBUTE]}`);\n    return;\n  }\n\n  if (name === 'ai.streamObject') {\n    span.setAttribute(semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_OP, 'gen_ai.invoke_agent');\n    return;\n  }\n\n  if (name === 'ai.streamObject.doStream') {\n    span.setAttribute(semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_OP, 'gen_ai.stream_object');\n    span.updateName(`stream_object ${attributes[vercelAiAttributes.AI_MODEL_ID_ATTRIBUTE]}`);\n    return;\n  }\n\n  if (name === 'ai.embed') {\n    span.setAttribute(semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_OP, 'gen_ai.invoke_agent');\n    return;\n  }\n\n  if (name === 'ai.embed.doEmbed') {\n    span.setAttribute(semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_OP, 'gen_ai.embed');\n    span.updateName(`embed ${attributes[vercelAiAttributes.AI_MODEL_ID_ATTRIBUTE]}`);\n    return;\n  }\n\n  if (name === 'ai.embedMany') {\n    span.setAttribute(semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_OP, 'gen_ai.invoke_agent');\n    return;\n  }\n\n  if (name === 'ai.embedMany.doEmbed') {\n    span.setAttribute(semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_OP, 'gen_ai.embed_many');\n    span.updateName(`embed_many ${attributes[vercelAiAttributes.AI_MODEL_ID_ATTRIBUTE]}`);\n    return;\n  }\n\n  if (name.startsWith('ai.stream')) {\n    span.setAttribute(semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_OP, 'ai.run');\n    return;\n  }\n}\n\n/**\n * Add event processors to the given client to process Vercel AI spans.\n */\nfunction addVercelAiProcessors(client) {\n  client.on('spanStart', onVercelAiSpanStart);\n  // Note: We cannot do this on `spanEnd`, because the span cannot be mutated anymore at this point\n  client.addEventProcessor(Object.assign(vercelAiEventProcessor, { id: 'VercelAiEventProcessor' }));\n}\n\nfunction addProviderMetadataToAttributes(attributes) {\n  const providerMetadata = attributes[vercelAiAttributes.AI_RESPONSE_PROVIDER_METADATA_ATTRIBUTE] ;\n  if (providerMetadata) {\n    try {\n      const providerMetadataObject = JSON.parse(providerMetadata) ;\n      if (providerMetadataObject.openai) {\n        setAttributeIfDefined(\n          attributes,\n          'gen_ai.usage.input_tokens.cached',\n          providerMetadataObject.openai.cachedPromptTokens,\n        );\n        setAttributeIfDefined(\n          attributes,\n          'gen_ai.usage.output_tokens.reasoning',\n          providerMetadataObject.openai.reasoningTokens,\n        );\n        setAttributeIfDefined(\n          attributes,\n          'gen_ai.usage.output_tokens.prediction_accepted',\n          providerMetadataObject.openai.acceptedPredictionTokens,\n        );\n        setAttributeIfDefined(\n          attributes,\n          'gen_ai.usage.output_tokens.prediction_rejected',\n          providerMetadataObject.openai.rejectedPredictionTokens,\n        );\n        setAttributeIfDefined(attributes, 'gen_ai.conversation.id', providerMetadataObject.openai.responseId);\n      }\n\n      if (providerMetadataObject.anthropic) {\n        setAttributeIfDefined(\n          attributes,\n          'gen_ai.usage.input_tokens.cached',\n          providerMetadataObject.anthropic.cacheReadInputTokens,\n        );\n        setAttributeIfDefined(\n          attributes,\n          'gen_ai.usage.input_tokens.cache_write',\n          providerMetadataObject.anthropic.cacheCreationInputTokens,\n        );\n      }\n\n      if (providerMetadataObject.bedrock?.usage) {\n        setAttributeIfDefined(\n          attributes,\n          'gen_ai.usage.input_tokens.cached',\n          providerMetadataObject.bedrock.usage.cacheReadInputTokens,\n        );\n        setAttributeIfDefined(\n          attributes,\n          'gen_ai.usage.input_tokens.cache_write',\n          providerMetadataObject.bedrock.usage.cacheWriteInputTokens,\n        );\n      }\n\n      if (providerMetadataObject.deepseek) {\n        setAttributeIfDefined(\n          attributes,\n          'gen_ai.usage.input_tokens.cached',\n          providerMetadataObject.deepseek.promptCacheHitTokens,\n        );\n        setAttributeIfDefined(\n          attributes,\n          'gen_ai.usage.input_tokens.cache_miss',\n          providerMetadataObject.deepseek.promptCacheMissTokens,\n        );\n      }\n    } catch {\n      // Ignore\n    }\n  }\n}\n\n/**\n * Sets an attribute only if the value is not null or undefined.\n */\nfunction setAttributeIfDefined(attributes, key, value) {\n  if (value != null) {\n    attributes[key] = value;\n  }\n}\n\nexports.addVercelAiProcessors = addVercelAiProcessors;\n//# sourceMappingURL=vercel-ai.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy92ZXJjZWwtYWkuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsMkJBQTJCLG1CQUFPLENBQUMsMElBQTBCO0FBQzdELGtCQUFrQixtQkFBTyxDQUFDLDZIQUFnQjtBQUMxQywyQkFBMkIsbUJBQU8sQ0FBQyxtSkFBMkI7O0FBRTlEO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsVUFBVSxzQ0FBc0M7O0FBRWhEO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsVUFBVSwyQkFBMkI7O0FBRXJDO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBLG9EQUFvRCxJQUFJO0FBQ3hEO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxvQ0FBb0MsU0FBUztBQUM3QztBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBLHVCQUF1QixjQUFjLEVBQUUsV0FBVztBQUNsRDtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLHFDQUFxQyxxREFBcUQ7QUFDMUY7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsbUNBQW1DLHFEQUFxRDtBQUN4RjtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQSx1Q0FBdUMscURBQXFEO0FBQzVGO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLHFDQUFxQyxxREFBcUQ7QUFDMUY7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsNkJBQTZCLHFEQUFxRDtBQUNsRjtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQSxrQ0FBa0MscURBQXFEO0FBQ3ZGO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxtRUFBbUUsOEJBQThCO0FBQ2pHOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsTUFBTTtBQUNOO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsNkJBQTZCO0FBQzdCIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvdmVyY2VsLWFpLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBzZW1hbnRpY0F0dHJpYnV0ZXMgPSByZXF1aXJlKCcuLi9zZW1hbnRpY0F0dHJpYnV0ZXMuanMnKTtcbmNvbnN0IHNwYW5VdGlscyA9IHJlcXVpcmUoJy4vc3BhblV0aWxzLmpzJyk7XG5jb25zdCB2ZXJjZWxBaUF0dHJpYnV0ZXMgPSByZXF1aXJlKCcuL3ZlcmNlbC1haS1hdHRyaWJ1dGVzLmpzJyk7XG5cbmZ1bmN0aW9uIGFkZE9yaWdpblRvU3BhbihzcGFuLCBvcmlnaW4pIHtcbiAgc3Bhbi5zZXRBdHRyaWJ1dGUoc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfT1JJR0lOLCBvcmlnaW4pO1xufVxuXG4vKipcbiAqIFBvc3QtcHJvY2VzcyBzcGFucyBlbWl0dGVkIGJ5IHRoZSBWZXJjZWwgQUkgU0RLLlxuICogVGhpcyBpcyBzdXBwb3NlZCB0byBiZSB1c2VkIGluIGBjbGllbnQub24oJ3NwYW5TdGFydCcsIC4uLilcbiAqL1xuZnVuY3Rpb24gb25WZXJjZWxBaVNwYW5TdGFydChzcGFuKSB7XG4gIGNvbnN0IHsgZGF0YTogYXR0cmlidXRlcywgZGVzY3JpcHRpb246IG5hbWUgfSA9IHNwYW5VdGlscy5zcGFuVG9KU09OKHNwYW4pO1xuXG4gIGlmICghbmFtZSkge1xuICAgIHJldHVybjtcbiAgfVxuXG4gIC8vIFRvb2wgY2FsbCBzcGFuc1xuICAvLyBodHRwczovL2FpLXNkay5kZXYvZG9jcy9haS1zZGstY29yZS90ZWxlbWV0cnkjdG9vbC1jYWxsLXNwYW5zXG4gIGlmIChhdHRyaWJ1dGVzW3ZlcmNlbEFpQXR0cmlidXRlcy5BSV9UT09MX0NBTExfTkFNRV9BVFRSSUJVVEVdICYmIGF0dHJpYnV0ZXNbdmVyY2VsQWlBdHRyaWJ1dGVzLkFJX1RPT0xfQ0FMTF9JRF9BVFRSSUJVVEVdICYmIG5hbWUgPT09ICdhaS50b29sQ2FsbCcpIHtcbiAgICBwcm9jZXNzVG9vbENhbGxTcGFuKHNwYW4sIGF0dHJpYnV0ZXMpO1xuICAgIHJldHVybjtcbiAgfVxuXG4gIC8vIFRoZSBBSSBhbmQgUHJvdmlkZXIgbXVzdCBiZSBkZWZpbmVkIGZvciBnZW5lcmF0ZSwgc3RyZWFtLCBhbmQgZW1iZWQgc3BhbnMuXG4gIC8vIFRoZSBpZCBvZiB0aGUgbW9kZWxcbiAgY29uc3QgYWlNb2RlbElkID0gYXR0cmlidXRlc1t2ZXJjZWxBaUF0dHJpYnV0ZXMuQUlfTU9ERUxfSURfQVRUUklCVVRFXTtcbiAgLy8gdGhlIHByb3ZpZGVyIG9mIHRoZSBtb2RlbFxuICBjb25zdCBhaU1vZGVsUHJvdmlkZXIgPSBhdHRyaWJ1dGVzW3ZlcmNlbEFpQXR0cmlidXRlcy5BSV9NT0RFTF9QUk9WSURFUl9BVFRSSUJVVEVdO1xuICBpZiAodHlwZW9mIGFpTW9kZWxJZCAhPT0gJ3N0cmluZycgfHwgdHlwZW9mIGFpTW9kZWxQcm92aWRlciAhPT0gJ3N0cmluZycgfHwgIWFpTW9kZWxJZCB8fCAhYWlNb2RlbFByb3ZpZGVyKSB7XG4gICAgcmV0dXJuO1xuICB9XG5cbiAgcHJvY2Vzc0dlbmVyYXRlU3BhbihzcGFuLCBuYW1lLCBhdHRyaWJ1dGVzKTtcbn1cblxuZnVuY3Rpb24gdmVyY2VsQWlFdmVudFByb2Nlc3NvcihldmVudCkge1xuICBpZiAoZXZlbnQudHlwZSA9PT0gJ3RyYW5zYWN0aW9uJyAmJiBldmVudC5zcGFucykge1xuICAgIGZvciAoY29uc3Qgc3BhbiBvZiBldmVudC5zcGFucykge1xuICAgICAgLy8gdGhpcyBtdXRhdGVzIHNwYW5zIGluLXBsYWNlXG4gICAgICBwcm9jZXNzRW5kZWRWZXJjZWxBaVNwYW4oc3Bhbik7XG4gICAgfVxuICB9XG4gIHJldHVybiBldmVudDtcbn1cbi8qKlxuICogUG9zdC1wcm9jZXNzIHNwYW5zIGVtaXR0ZWQgYnkgdGhlIFZlcmNlbCBBSSBTREsuXG4gKi9cbmZ1bmN0aW9uIHByb2Nlc3NFbmRlZFZlcmNlbEFpU3BhbihzcGFuKSB7XG4gIGNvbnN0IHsgZGF0YTogYXR0cmlidXRlcywgb3JpZ2luIH0gPSBzcGFuO1xuXG4gIGlmIChvcmlnaW4gIT09ICdhdXRvLnZlcmNlbGFpLm90ZWwnKSB7XG4gICAgcmV0dXJuO1xuICB9XG5cbiAgcmVuYW1lQXR0cmlidXRlS2V5KGF0dHJpYnV0ZXMsIHZlcmNlbEFpQXR0cmlidXRlcy5BSV9VU0FHRV9DT01QTEVUSU9OX1RPS0VOU19BVFRSSUJVVEUsIHZlcmNlbEFpQXR0cmlidXRlcy5HRU5fQUlfVVNBR0VfT1VUUFVUX1RPS0VOU19BVFRSSUJVVEUpO1xuICByZW5hbWVBdHRyaWJ1dGVLZXkoYXR0cmlidXRlcywgdmVyY2VsQWlBdHRyaWJ1dGVzLkFJX1VTQUdFX1BST01QVF9UT0tFTlNfQVRUUklCVVRFLCB2ZXJjZWxBaUF0dHJpYnV0ZXMuR0VOX0FJX1VTQUdFX0lOUFVUX1RPS0VOU19BVFRSSUJVVEUpO1xuXG4gIGlmIChcbiAgICB0eXBlb2YgYXR0cmlidXRlc1t2ZXJjZWxBaUF0dHJpYnV0ZXMuR0VOX0FJX1VTQUdFX09VVFBVVF9UT0tFTlNfQVRUUklCVVRFXSA9PT0gJ251bWJlcicgJiZcbiAgICB0eXBlb2YgYXR0cmlidXRlc1t2ZXJjZWxBaUF0dHJpYnV0ZXMuR0VOX0FJX1VTQUdFX0lOUFVUX1RPS0VOU19BVFRSSUJVVEVdID09PSAnbnVtYmVyJ1xuICApIHtcbiAgICBhdHRyaWJ1dGVzWydnZW5fYWkudXNhZ2UudG90YWxfdG9rZW5zJ10gPVxuICAgICAgYXR0cmlidXRlc1t2ZXJjZWxBaUF0dHJpYnV0ZXMuR0VOX0FJX1VTQUdFX09VVFBVVF9UT0tFTlNfQVRUUklCVVRFXSArIGF0dHJpYnV0ZXNbdmVyY2VsQWlBdHRyaWJ1dGVzLkdFTl9BSV9VU0FHRV9JTlBVVF9UT0tFTlNfQVRUUklCVVRFXTtcbiAgfVxuXG4gIC8vIFJlbmFtZSBBSSBTREsgYXR0cmlidXRlcyB0byBzdGFuZGFyZGl6ZWQgZ2VuX2FpIGF0dHJpYnV0ZXNcbiAgcmVuYW1lQXR0cmlidXRlS2V5KGF0dHJpYnV0ZXMsIHZlcmNlbEFpQXR0cmlidXRlcy5BSV9QUk9NUFRfTUVTU0FHRVNfQVRUUklCVVRFLCAnZ2VuX2FpLnJlcXVlc3QubWVzc2FnZXMnKTtcbiAgcmVuYW1lQXR0cmlidXRlS2V5KGF0dHJpYnV0ZXMsIHZlcmNlbEFpQXR0cmlidXRlcy5BSV9SRVNQT05TRV9URVhUX0FUVFJJQlVURSwgJ2dlbl9haS5yZXNwb25zZS50ZXh0Jyk7XG4gIHJlbmFtZUF0dHJpYnV0ZUtleShhdHRyaWJ1dGVzLCB2ZXJjZWxBaUF0dHJpYnV0ZXMuQUlfUkVTUE9OU0VfVE9PTF9DQUxMU19BVFRSSUJVVEUsICdnZW5fYWkucmVzcG9uc2UudG9vbF9jYWxscycpO1xuICByZW5hbWVBdHRyaWJ1dGVLZXkoYXR0cmlidXRlcywgdmVyY2VsQWlBdHRyaWJ1dGVzLkFJX1JFU1BPTlNFX09CSkVDVF9BVFRSSUJVVEUsICdnZW5fYWkucmVzcG9uc2Uub2JqZWN0Jyk7XG4gIHJlbmFtZUF0dHJpYnV0ZUtleShhdHRyaWJ1dGVzLCB2ZXJjZWxBaUF0dHJpYnV0ZXMuQUlfUFJPTVBUX1RPT0xTX0FUVFJJQlVURSwgJ2dlbl9haS5yZXF1ZXN0LmF2YWlsYWJsZV90b29scycpO1xuXG4gIHJlbmFtZUF0dHJpYnV0ZUtleShhdHRyaWJ1dGVzLCB2ZXJjZWxBaUF0dHJpYnV0ZXMuQUlfVE9PTF9DQUxMX0FSR1NfQVRUUklCVVRFLCAnZ2VuX2FpLnRvb2wuaW5wdXQnKTtcbiAgcmVuYW1lQXR0cmlidXRlS2V5KGF0dHJpYnV0ZXMsIHZlcmNlbEFpQXR0cmlidXRlcy5BSV9UT09MX0NBTExfUkVTVUxUX0FUVFJJQlVURSwgJ2dlbl9haS50b29sLm91dHB1dCcpO1xuXG4gIGFkZFByb3ZpZGVyTWV0YWRhdGFUb0F0dHJpYnV0ZXMoYXR0cmlidXRlcyk7XG5cbiAgLy8gQ2hhbmdlIGF0dHJpYnV0ZXMgbmFtZXNwYWNlZCB3aXRoIGBhaS5YYCB0byBgdmVyY2VsLmFpLlhgXG4gIGZvciAoY29uc3Qga2V5IG9mIE9iamVjdC5rZXlzKGF0dHJpYnV0ZXMpKSB7XG4gICAgaWYgKGtleS5zdGFydHNXaXRoKCdhaS4nKSkge1xuICAgICAgcmVuYW1lQXR0cmlidXRlS2V5KGF0dHJpYnV0ZXMsIGtleSwgYHZlcmNlbC4ke2tleX1gKTtcbiAgICB9XG4gIH1cbn1cblxuLyoqXG4gKiBSZW5hbWVzIGFuIGF0dHJpYnV0ZSBrZXkgaW4gdGhlIHByb3ZpZGVkIGF0dHJpYnV0ZXMgb2JqZWN0IGlmIHRoZSBvbGQga2V5IGV4aXN0cy5cbiAqIFRoaXMgZnVuY3Rpb24gc2FmZWx5IGhhbmRsZXMgbnVsbCBhbmQgdW5kZWZpbmVkIHZhbHVlcy5cbiAqL1xuZnVuY3Rpb24gcmVuYW1lQXR0cmlidXRlS2V5KGF0dHJpYnV0ZXMsIG9sZEtleSwgbmV3S2V5KSB7XG4gIGlmIChhdHRyaWJ1dGVzW29sZEtleV0gIT0gbnVsbCkge1xuICAgIGF0dHJpYnV0ZXNbbmV3S2V5XSA9IGF0dHJpYnV0ZXNbb2xkS2V5XTtcbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25vLWR5bmFtaWMtZGVsZXRlXG4gICAgZGVsZXRlIGF0dHJpYnV0ZXNbb2xkS2V5XTtcbiAgfVxufVxuXG5mdW5jdGlvbiBwcm9jZXNzVG9vbENhbGxTcGFuKHNwYW4sIGF0dHJpYnV0ZXMpIHtcbiAgYWRkT3JpZ2luVG9TcGFuKHNwYW4sICdhdXRvLnZlcmNlbGFpLm90ZWwnKTtcbiAgc3Bhbi5zZXRBdHRyaWJ1dGUoc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfT1AsICdnZW5fYWkuZXhlY3V0ZV90b29sJyk7XG4gIHJlbmFtZUF0dHJpYnV0ZUtleShhdHRyaWJ1dGVzLCB2ZXJjZWxBaUF0dHJpYnV0ZXMuQUlfVE9PTF9DQUxMX05BTUVfQVRUUklCVVRFLCAnZ2VuX2FpLnRvb2wubmFtZScpO1xuICByZW5hbWVBdHRyaWJ1dGVLZXkoYXR0cmlidXRlcywgdmVyY2VsQWlBdHRyaWJ1dGVzLkFJX1RPT0xfQ0FMTF9JRF9BVFRSSUJVVEUsICdnZW5fYWkudG9vbC5jYWxsLmlkJyk7XG4gIC8vIGh0dHBzOi8vb3BlbnRlbGVtZXRyeS5pby9kb2NzL3NwZWNzL3NlbWNvbnYvcmVnaXN0cnkvYXR0cmlidXRlcy9nZW4tYWkvI2dlbi1haS10b29sLXR5cGVcbiAgaWYgKCFhdHRyaWJ1dGVzWydnZW5fYWkudG9vbC50eXBlJ10pIHtcbiAgICBzcGFuLnNldEF0dHJpYnV0ZSgnZ2VuX2FpLnRvb2wudHlwZScsICdmdW5jdGlvbicpO1xuICB9XG4gIGNvbnN0IHRvb2xOYW1lID0gYXR0cmlidXRlc1snZ2VuX2FpLnRvb2wubmFtZSddO1xuICBpZiAodG9vbE5hbWUpIHtcbiAgICBzcGFuLnVwZGF0ZU5hbWUoYGV4ZWN1dGVfdG9vbCAke3Rvb2xOYW1lfWApO1xuICB9XG59XG5cbmZ1bmN0aW9uIHByb2Nlc3NHZW5lcmF0ZVNwYW4oc3BhbiwgbmFtZSwgYXR0cmlidXRlcykge1xuICBhZGRPcmlnaW5Ub1NwYW4oc3BhbiwgJ2F1dG8udmVyY2VsYWkub3RlbCcpO1xuXG4gIGNvbnN0IG5hbWVXdGhvdXRBaSA9IG5hbWUucmVwbGFjZSgnYWkuJywgJycpO1xuICBzcGFuLnNldEF0dHJpYnV0ZSgnYWkucGlwZWxpbmUubmFtZScsIG5hbWVXdGhvdXRBaSk7XG4gIHNwYW4udXBkYXRlTmFtZShuYW1lV3Rob3V0QWkpO1xuXG4gIC8vIElmIGEgVGVsZW1ldHJ5IG5hbWUgaXMgc2V0IGFuZCBpdCBpcyBhIHBpcGVsaW5lIHNwYW4sIHVzZSB0aGF0IGFzIHRoZSBvcGVyYXRpb24gbmFtZVxuICBjb25zdCBmdW5jdGlvbklkID0gYXR0cmlidXRlc1t2ZXJjZWxBaUF0dHJpYnV0ZXMuQUlfVEVMRU1FVFJZX0ZVTkNUSU9OX0lEX0FUVFJJQlVURV07XG4gIGlmIChmdW5jdGlvbklkICYmIHR5cGVvZiBmdW5jdGlvbklkID09PSAnc3RyaW5nJyAmJiBuYW1lLnNwbGl0KCcuJykubGVuZ3RoIC0gMSA9PT0gMSkge1xuICAgIHNwYW4udXBkYXRlTmFtZShgJHtuYW1lV3Rob3V0QWl9ICR7ZnVuY3Rpb25JZH1gKTtcbiAgICBzcGFuLnNldEF0dHJpYnV0ZSgnZ2VuX2FpLmZ1bmN0aW9uX2lkJywgZnVuY3Rpb25JZCk7XG4gIH1cblxuICBpZiAoYXR0cmlidXRlc1t2ZXJjZWxBaUF0dHJpYnV0ZXMuQUlfUFJPTVBUX0FUVFJJQlVURV0pIHtcbiAgICBzcGFuLnNldEF0dHJpYnV0ZSgnZ2VuX2FpLnByb21wdCcsIGF0dHJpYnV0ZXNbdmVyY2VsQWlBdHRyaWJ1dGVzLkFJX1BST01QVF9BVFRSSUJVVEVdKTtcbiAgfVxuICBpZiAoYXR0cmlidXRlc1t2ZXJjZWxBaUF0dHJpYnV0ZXMuQUlfTU9ERUxfSURfQVRUUklCVVRFXSAmJiAhYXR0cmlidXRlc1t2ZXJjZWxBaUF0dHJpYnV0ZXMuR0VOX0FJX1JFU1BPTlNFX01PREVMX0FUVFJJQlVURV0pIHtcbiAgICBzcGFuLnNldEF0dHJpYnV0ZSh2ZXJjZWxBaUF0dHJpYnV0ZXMuR0VOX0FJX1JFU1BPTlNFX01PREVMX0FUVFJJQlVURSwgYXR0cmlidXRlc1t2ZXJjZWxBaUF0dHJpYnV0ZXMuQUlfTU9ERUxfSURfQVRUUklCVVRFXSk7XG4gIH1cbiAgc3Bhbi5zZXRBdHRyaWJ1dGUoJ2FpLnN0cmVhbWluZycsIG5hbWUuaW5jbHVkZXMoJ3N0cmVhbScpKTtcblxuICAvLyBHZW5lcmF0ZSBTcGFuc1xuICBpZiAobmFtZSA9PT0gJ2FpLmdlbmVyYXRlVGV4dCcpIHtcbiAgICBzcGFuLnNldEF0dHJpYnV0ZShzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9PUCwgJ2dlbl9haS5pbnZva2VfYWdlbnQnKTtcbiAgICByZXR1cm47XG4gIH1cblxuICBpZiAobmFtZSA9PT0gJ2FpLmdlbmVyYXRlVGV4dC5kb0dlbmVyYXRlJykge1xuICAgIHNwYW4uc2V0QXR0cmlidXRlKHNlbWFudGljQXR0cmlidXRlcy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX09QLCAnZ2VuX2FpLmdlbmVyYXRlX3RleHQnKTtcbiAgICBzcGFuLnVwZGF0ZU5hbWUoYGdlbmVyYXRlX3RleHQgJHthdHRyaWJ1dGVzW3ZlcmNlbEFpQXR0cmlidXRlcy5BSV9NT0RFTF9JRF9BVFRSSUJVVEVdfWApO1xuICAgIHJldHVybjtcbiAgfVxuXG4gIGlmIChuYW1lID09PSAnYWkuc3RyZWFtVGV4dCcpIHtcbiAgICBzcGFuLnNldEF0dHJpYnV0ZShzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9PUCwgJ2dlbl9haS5pbnZva2VfYWdlbnQnKTtcbiAgICByZXR1cm47XG4gIH1cblxuICBpZiAobmFtZSA9PT0gJ2FpLnN0cmVhbVRleHQuZG9TdHJlYW0nKSB7XG4gICAgc3Bhbi5zZXRBdHRyaWJ1dGUoc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfT1AsICdnZW5fYWkuc3RyZWFtX3RleHQnKTtcbiAgICBzcGFuLnVwZGF0ZU5hbWUoYHN0cmVhbV90ZXh0ICR7YXR0cmlidXRlc1t2ZXJjZWxBaUF0dHJpYnV0ZXMuQUlfTU9ERUxfSURfQVRUUklCVVRFXX1gKTtcbiAgICByZXR1cm47XG4gIH1cblxuICBpZiAobmFtZSA9PT0gJ2FpLmdlbmVyYXRlT2JqZWN0Jykge1xuICAgIHNwYW4uc2V0QXR0cmlidXRlKHNlbWFudGljQXR0cmlidXRlcy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX09QLCAnZ2VuX2FpLmludm9rZV9hZ2VudCcpO1xuICAgIHJldHVybjtcbiAgfVxuXG4gIGlmIChuYW1lID09PSAnYWkuZ2VuZXJhdGVPYmplY3QuZG9HZW5lcmF0ZScpIHtcbiAgICBzcGFuLnNldEF0dHJpYnV0ZShzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9PUCwgJ2dlbl9haS5nZW5lcmF0ZV9vYmplY3QnKTtcbiAgICBzcGFuLnVwZGF0ZU5hbWUoYGdlbmVyYXRlX29iamVjdCAke2F0dHJpYnV0ZXNbdmVyY2VsQWlBdHRyaWJ1dGVzLkFJX01PREVMX0lEX0FUVFJJQlVURV19YCk7XG4gICAgcmV0dXJuO1xuICB9XG5cbiAgaWYgKG5hbWUgPT09ICdhaS5zdHJlYW1PYmplY3QnKSB7XG4gICAgc3Bhbi5zZXRBdHRyaWJ1dGUoc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfT1AsICdnZW5fYWkuaW52b2tlX2FnZW50Jyk7XG4gICAgcmV0dXJuO1xuICB9XG5cbiAgaWYgKG5hbWUgPT09ICdhaS5zdHJlYW1PYmplY3QuZG9TdHJlYW0nKSB7XG4gICAgc3Bhbi5zZXRBdHRyaWJ1dGUoc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfT1AsICdnZW5fYWkuc3RyZWFtX29iamVjdCcpO1xuICAgIHNwYW4udXBkYXRlTmFtZShgc3RyZWFtX29iamVjdCAke2F0dHJpYnV0ZXNbdmVyY2VsQWlBdHRyaWJ1dGVzLkFJX01PREVMX0lEX0FUVFJJQlVURV19YCk7XG4gICAgcmV0dXJuO1xuICB9XG5cbiAgaWYgKG5hbWUgPT09ICdhaS5lbWJlZCcpIHtcbiAgICBzcGFuLnNldEF0dHJpYnV0ZShzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9PUCwgJ2dlbl9haS5pbnZva2VfYWdlbnQnKTtcbiAgICByZXR1cm47XG4gIH1cblxuICBpZiAobmFtZSA9PT0gJ2FpLmVtYmVkLmRvRW1iZWQnKSB7XG4gICAgc3Bhbi5zZXRBdHRyaWJ1dGUoc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfT1AsICdnZW5fYWkuZW1iZWQnKTtcbiAgICBzcGFuLnVwZGF0ZU5hbWUoYGVtYmVkICR7YXR0cmlidXRlc1t2ZXJjZWxBaUF0dHJpYnV0ZXMuQUlfTU9ERUxfSURfQVRUUklCVVRFXX1gKTtcbiAgICByZXR1cm47XG4gIH1cblxuICBpZiAobmFtZSA9PT0gJ2FpLmVtYmVkTWFueScpIHtcbiAgICBzcGFuLnNldEF0dHJpYnV0ZShzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9PUCwgJ2dlbl9haS5pbnZva2VfYWdlbnQnKTtcbiAgICByZXR1cm47XG4gIH1cblxuICBpZiAobmFtZSA9PT0gJ2FpLmVtYmVkTWFueS5kb0VtYmVkJykge1xuICAgIHNwYW4uc2V0QXR0cmlidXRlKHNlbWFudGljQXR0cmlidXRlcy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX09QLCAnZ2VuX2FpLmVtYmVkX21hbnknKTtcbiAgICBzcGFuLnVwZGF0ZU5hbWUoYGVtYmVkX21hbnkgJHthdHRyaWJ1dGVzW3ZlcmNlbEFpQXR0cmlidXRlcy5BSV9NT0RFTF9JRF9BVFRSSUJVVEVdfWApO1xuICAgIHJldHVybjtcbiAgfVxuXG4gIGlmIChuYW1lLnN0YXJ0c1dpdGgoJ2FpLnN0cmVhbScpKSB7XG4gICAgc3Bhbi5zZXRBdHRyaWJ1dGUoc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfT1AsICdhaS5ydW4nKTtcbiAgICByZXR1cm47XG4gIH1cbn1cblxuLyoqXG4gKiBBZGQgZXZlbnQgcHJvY2Vzc29ycyB0byB0aGUgZ2l2ZW4gY2xpZW50IHRvIHByb2Nlc3MgVmVyY2VsIEFJIHNwYW5zLlxuICovXG5mdW5jdGlvbiBhZGRWZXJjZWxBaVByb2Nlc3NvcnMoY2xpZW50KSB7XG4gIGNsaWVudC5vbignc3BhblN0YXJ0Jywgb25WZXJjZWxBaVNwYW5TdGFydCk7XG4gIC8vIE5vdGU6IFdlIGNhbm5vdCBkbyB0aGlzIG9uIGBzcGFuRW5kYCwgYmVjYXVzZSB0aGUgc3BhbiBjYW5ub3QgYmUgbXV0YXRlZCBhbnltb3JlIGF0IHRoaXMgcG9pbnRcbiAgY2xpZW50LmFkZEV2ZW50UHJvY2Vzc29yKE9iamVjdC5hc3NpZ24odmVyY2VsQWlFdmVudFByb2Nlc3NvciwgeyBpZDogJ1ZlcmNlbEFpRXZlbnRQcm9jZXNzb3InIH0pKTtcbn1cblxuZnVuY3Rpb24gYWRkUHJvdmlkZXJNZXRhZGF0YVRvQXR0cmlidXRlcyhhdHRyaWJ1dGVzKSB7XG4gIGNvbnN0IHByb3ZpZGVyTWV0YWRhdGEgPSBhdHRyaWJ1dGVzW3ZlcmNlbEFpQXR0cmlidXRlcy5BSV9SRVNQT05TRV9QUk9WSURFUl9NRVRBREFUQV9BVFRSSUJVVEVdIDtcbiAgaWYgKHByb3ZpZGVyTWV0YWRhdGEpIHtcbiAgICB0cnkge1xuICAgICAgY29uc3QgcHJvdmlkZXJNZXRhZGF0YU9iamVjdCA9IEpTT04ucGFyc2UocHJvdmlkZXJNZXRhZGF0YSkgO1xuICAgICAgaWYgKHByb3ZpZGVyTWV0YWRhdGFPYmplY3Qub3BlbmFpKSB7XG4gICAgICAgIHNldEF0dHJpYnV0ZUlmRGVmaW5lZChcbiAgICAgICAgICBhdHRyaWJ1dGVzLFxuICAgICAgICAgICdnZW5fYWkudXNhZ2UuaW5wdXRfdG9rZW5zLmNhY2hlZCcsXG4gICAgICAgICAgcHJvdmlkZXJNZXRhZGF0YU9iamVjdC5vcGVuYWkuY2FjaGVkUHJvbXB0VG9rZW5zLFxuICAgICAgICApO1xuICAgICAgICBzZXRBdHRyaWJ1dGVJZkRlZmluZWQoXG4gICAgICAgICAgYXR0cmlidXRlcyxcbiAgICAgICAgICAnZ2VuX2FpLnVzYWdlLm91dHB1dF90b2tlbnMucmVhc29uaW5nJyxcbiAgICAgICAgICBwcm92aWRlck1ldGFkYXRhT2JqZWN0Lm9wZW5haS5yZWFzb25pbmdUb2tlbnMsXG4gICAgICAgICk7XG4gICAgICAgIHNldEF0dHJpYnV0ZUlmRGVmaW5lZChcbiAgICAgICAgICBhdHRyaWJ1dGVzLFxuICAgICAgICAgICdnZW5fYWkudXNhZ2Uub3V0cHV0X3Rva2Vucy5wcmVkaWN0aW9uX2FjY2VwdGVkJyxcbiAgICAgICAgICBwcm92aWRlck1ldGFkYXRhT2JqZWN0Lm9wZW5haS5hY2NlcHRlZFByZWRpY3Rpb25Ub2tlbnMsXG4gICAgICAgICk7XG4gICAgICAgIHNldEF0dHJpYnV0ZUlmRGVmaW5lZChcbiAgICAgICAgICBhdHRyaWJ1dGVzLFxuICAgICAgICAgICdnZW5fYWkudXNhZ2Uub3V0cHV0X3Rva2Vucy5wcmVkaWN0aW9uX3JlamVjdGVkJyxcbiAgICAgICAgICBwcm92aWRlck1ldGFkYXRhT2JqZWN0Lm9wZW5haS5yZWplY3RlZFByZWRpY3Rpb25Ub2tlbnMsXG4gICAgICAgICk7XG4gICAgICAgIHNldEF0dHJpYnV0ZUlmRGVmaW5lZChhdHRyaWJ1dGVzLCAnZ2VuX2FpLmNvbnZlcnNhdGlvbi5pZCcsIHByb3ZpZGVyTWV0YWRhdGFPYmplY3Qub3BlbmFpLnJlc3BvbnNlSWQpO1xuICAgICAgfVxuXG4gICAgICBpZiAocHJvdmlkZXJNZXRhZGF0YU9iamVjdC5hbnRocm9waWMpIHtcbiAgICAgICAgc2V0QXR0cmlidXRlSWZEZWZpbmVkKFxuICAgICAgICAgIGF0dHJpYnV0ZXMsXG4gICAgICAgICAgJ2dlbl9haS51c2FnZS5pbnB1dF90b2tlbnMuY2FjaGVkJyxcbiAgICAgICAgICBwcm92aWRlck1ldGFkYXRhT2JqZWN0LmFudGhyb3BpYy5jYWNoZVJlYWRJbnB1dFRva2VucyxcbiAgICAgICAgKTtcbiAgICAgICAgc2V0QXR0cmlidXRlSWZEZWZpbmVkKFxuICAgICAgICAgIGF0dHJpYnV0ZXMsXG4gICAgICAgICAgJ2dlbl9haS51c2FnZS5pbnB1dF90b2tlbnMuY2FjaGVfd3JpdGUnLFxuICAgICAgICAgIHByb3ZpZGVyTWV0YWRhdGFPYmplY3QuYW50aHJvcGljLmNhY2hlQ3JlYXRpb25JbnB1dFRva2VucyxcbiAgICAgICAgKTtcbiAgICAgIH1cblxuICAgICAgaWYgKHByb3ZpZGVyTWV0YWRhdGFPYmplY3QuYmVkcm9jaz8udXNhZ2UpIHtcbiAgICAgICAgc2V0QXR0cmlidXRlSWZEZWZpbmVkKFxuICAgICAgICAgIGF0dHJpYnV0ZXMsXG4gICAgICAgICAgJ2dlbl9haS51c2FnZS5pbnB1dF90b2tlbnMuY2FjaGVkJyxcbiAgICAgICAgICBwcm92aWRlck1ldGFkYXRhT2JqZWN0LmJlZHJvY2sudXNhZ2UuY2FjaGVSZWFkSW5wdXRUb2tlbnMsXG4gICAgICAgICk7XG4gICAgICAgIHNldEF0dHJpYnV0ZUlmRGVmaW5lZChcbiAgICAgICAgICBhdHRyaWJ1dGVzLFxuICAgICAgICAgICdnZW5fYWkudXNhZ2UuaW5wdXRfdG9rZW5zLmNhY2hlX3dyaXRlJyxcbiAgICAgICAgICBwcm92aWRlck1ldGFkYXRhT2JqZWN0LmJlZHJvY2sudXNhZ2UuY2FjaGVXcml0ZUlucHV0VG9rZW5zLFxuICAgICAgICApO1xuICAgICAgfVxuXG4gICAgICBpZiAocHJvdmlkZXJNZXRhZGF0YU9iamVjdC5kZWVwc2Vlaykge1xuICAgICAgICBzZXRBdHRyaWJ1dGVJZkRlZmluZWQoXG4gICAgICAgICAgYXR0cmlidXRlcyxcbiAgICAgICAgICAnZ2VuX2FpLnVzYWdlLmlucHV0X3Rva2Vucy5jYWNoZWQnLFxuICAgICAgICAgIHByb3ZpZGVyTWV0YWRhdGFPYmplY3QuZGVlcHNlZWsucHJvbXB0Q2FjaGVIaXRUb2tlbnMsXG4gICAgICAgICk7XG4gICAgICAgIHNldEF0dHJpYnV0ZUlmRGVmaW5lZChcbiAgICAgICAgICBhdHRyaWJ1dGVzLFxuICAgICAgICAgICdnZW5fYWkudXNhZ2UuaW5wdXRfdG9rZW5zLmNhY2hlX21pc3MnLFxuICAgICAgICAgIHByb3ZpZGVyTWV0YWRhdGFPYmplY3QuZGVlcHNlZWsucHJvbXB0Q2FjaGVNaXNzVG9rZW5zLFxuICAgICAgICApO1xuICAgICAgfVxuICAgIH0gY2F0Y2gge1xuICAgICAgLy8gSWdub3JlXG4gICAgfVxuICB9XG59XG5cbi8qKlxuICogU2V0cyBhbiBhdHRyaWJ1dGUgb25seSBpZiB0aGUgdmFsdWUgaXMgbm90IG51bGwgb3IgdW5kZWZpbmVkLlxuICovXG5mdW5jdGlvbiBzZXRBdHRyaWJ1dGVJZkRlZmluZWQoYXR0cmlidXRlcywga2V5LCB2YWx1ZSkge1xuICBpZiAodmFsdWUgIT0gbnVsbCkge1xuICAgIGF0dHJpYnV0ZXNba2V5XSA9IHZhbHVlO1xuICB9XG59XG5cbmV4cG9ydHMuYWRkVmVyY2VsQWlQcm9jZXNzb3JzID0gYWRkVmVyY2VsQWlQcm9jZXNzb3JzO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9dmVyY2VsLWFpLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/vercel-ai.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/vercelWaitUntil.js":
/*!*************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/vercelWaitUntil.js ***!
  \*************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst worldwide = __webpack_require__(/*! ./worldwide.js */ \"(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/worldwide.js\");\n\n/**\n * Function that delays closing of a Vercel lambda until the provided promise is resolved.\n *\n * Vendored from https://www.npmjs.com/package/@vercel/functions\n */\nfunction vercelWaitUntil(task) {\n  const vercelRequestContextGlobal =\n    // @ts-expect-error This is not typed\n    worldwide.GLOBAL_OBJ[Symbol.for('@vercel/request-context')];\n\n  const ctx = vercelRequestContextGlobal?.get?.();\n\n  if (ctx?.waitUntil) {\n    ctx.waitUntil(task);\n  }\n}\n\nexports.vercelWaitUntil = vercelWaitUntil;\n//# sourceMappingURL=vercelWaitUntil.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy92ZXJjZWxXYWl0VW50aWwuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsa0JBQWtCLG1CQUFPLENBQUMsNkhBQWdCOztBQUUxQztBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsdUJBQXVCO0FBQ3ZCIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvdmVyY2VsV2FpdFVudGlsLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCB3b3JsZHdpZGUgPSByZXF1aXJlKCcuL3dvcmxkd2lkZS5qcycpO1xuXG4vKipcbiAqIEZ1bmN0aW9uIHRoYXQgZGVsYXlzIGNsb3Npbmcgb2YgYSBWZXJjZWwgbGFtYmRhIHVudGlsIHRoZSBwcm92aWRlZCBwcm9taXNlIGlzIHJlc29sdmVkLlxuICpcbiAqIFZlbmRvcmVkIGZyb20gaHR0cHM6Ly93d3cubnBtanMuY29tL3BhY2thZ2UvQHZlcmNlbC9mdW5jdGlvbnNcbiAqL1xuZnVuY3Rpb24gdmVyY2VsV2FpdFVudGlsKHRhc2spIHtcbiAgY29uc3QgdmVyY2VsUmVxdWVzdENvbnRleHRHbG9iYWwgPVxuICAgIC8vIEB0cy1leHBlY3QtZXJyb3IgVGhpcyBpcyBub3QgdHlwZWRcbiAgICB3b3JsZHdpZGUuR0xPQkFMX09CSltTeW1ib2wuZm9yKCdAdmVyY2VsL3JlcXVlc3QtY29udGV4dCcpXTtcblxuICBjb25zdCBjdHggPSB2ZXJjZWxSZXF1ZXN0Q29udGV4dEdsb2JhbD8uZ2V0Py4oKTtcblxuICBpZiAoY3R4Py53YWl0VW50aWwpIHtcbiAgICBjdHgud2FpdFVudGlsKHRhc2spO1xuICB9XG59XG5cbmV4cG9ydHMudmVyY2VsV2FpdFVudGlsID0gdmVyY2VsV2FpdFVudGlsO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9dmVyY2VsV2FpdFVudGlsLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/vercelWaitUntil.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/version.js":
/*!*****************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/version.js ***!
  \*****************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n// This is a magic string replaced by rollup\n\nconst SDK_VERSION = \"9.46.0\" ;\n\nexports.SDK_VERSION = SDK_VERSION;\n//# sourceMappingURL=version.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy92ZXJzaW9uLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFOztBQUVBOztBQUVBLG1CQUFtQjtBQUNuQiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3V0aWxzL3ZlcnNpb24uanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbi8vIFRoaXMgaXMgYSBtYWdpYyBzdHJpbmcgcmVwbGFjZWQgYnkgcm9sbHVwXG5cbmNvbnN0IFNES19WRVJTSU9OID0gXCI5LjQ2LjBcIiA7XG5cbmV4cG9ydHMuU0RLX1ZFUlNJT04gPSBTREtfVkVSU0lPTjtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPXZlcnNpb24uanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/version.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/worldwide.js":
/*!*******************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/worldwide.js ***!
  \*******************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n/** Internal global with common properties and Sentry extensions  */\n\n/** Get's the global object for the current JavaScript runtime */\nconst GLOBAL_OBJ = globalThis ;\n\nexports.GLOBAL_OBJ = GLOBAL_OBJ;\n//# sourceMappingURL=worldwide.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy93b3JsZHdpZGUuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEU7O0FBRUE7QUFDQTs7QUFFQSxrQkFBa0I7QUFDbEIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy93b3JsZHdpZGUuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbi8qKiBJbnRlcm5hbCBnbG9iYWwgd2l0aCBjb21tb24gcHJvcGVydGllcyBhbmQgU2VudHJ5IGV4dGVuc2lvbnMgICovXG5cbi8qKiBHZXQncyB0aGUgZ2xvYmFsIG9iamVjdCBmb3IgdGhlIGN1cnJlbnQgSmF2YVNjcmlwdCBydW50aW1lICovXG5jb25zdCBHTE9CQUxfT0JKID0gZ2xvYmFsVGhpcyA7XG5cbmV4cG9ydHMuR0xPQkFMX09CSiA9IEdMT0JBTF9PQko7XG4vLyMgc291cmNlTWFwcGluZ1VSTD13b3JsZHdpZGUuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/worldwide.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/vendor/escapeStringForRegex.js":
/*!*******************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/vendor/escapeStringForRegex.js ***!
  \*******************************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n// Based on https://github.com/sindresorhus/escape-string-regexp but with modifications to:\n//   a) reduce the size by skipping the runtime type - checking\n//   b) ensure it gets down - compiled for old versions of Node(the published package only supports Node 14+).\n//\n// MIT License\n//\n// Copyright (c) Sindre Sorhus <sindresorhus@gmail.com> (https://sindresorhus.com)\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated\n// documentation files(the \"Software\"), to deal in the Software without restriction, including without limitation\n// the rights to use, copy, modify, merge, publish, distribute, sublicense, and / or sell copies of the Software, and\n// to permit persons to whom the Software is furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in all copies or substantial portions of\n// the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO\n// THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,\n// TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS\n// IN THE SOFTWARE.\n\n/**\n * Given a string, escape characters which have meaning in the regex grammar, such that the result is safe to feed to\n * `new RegExp()`.\n *\n * @param regexString The string to escape\n * @returns An version of the string with all special regex characters escaped\n */\nfunction escapeStringForRegex(regexString) {\n  // escape the hyphen separately so we can also replace it with a unicode literal hyphen, to avoid the problems\n  // discussed in https://github.com/sindresorhus/escape-string-regexp/issues/20.\n  return regexString.replace(/[|\\\\{}()[\\]^$+*?.]/g, '\\\\$&').replace(/-/g, '\\\\x2d');\n}\n\nexports.escapeStringForRegex = escapeStringForRegex;\n//# sourceMappingURL=escapeStringForRegex.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy92ZW5kb3IvZXNjYXBlU3RyaW5nRm9yUmVnZXguanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEU7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0Esb0NBQW9DO0FBQ3BDOztBQUVBLDRCQUE0QjtBQUM1QiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3ZlbmRvci9lc2NhcGVTdHJpbmdGb3JSZWdleC5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuLy8gQmFzZWQgb24gaHR0cHM6Ly9naXRodWIuY29tL3NpbmRyZXNvcmh1cy9lc2NhcGUtc3RyaW5nLXJlZ2V4cCBidXQgd2l0aCBtb2RpZmljYXRpb25zIHRvOlxuLy8gICBhKSByZWR1Y2UgdGhlIHNpemUgYnkgc2tpcHBpbmcgdGhlIHJ1bnRpbWUgdHlwZSAtIGNoZWNraW5nXG4vLyAgIGIpIGVuc3VyZSBpdCBnZXRzIGRvd24gLSBjb21waWxlZCBmb3Igb2xkIHZlcnNpb25zIG9mIE5vZGUodGhlIHB1Ymxpc2hlZCBwYWNrYWdlIG9ubHkgc3VwcG9ydHMgTm9kZSAxNCspLlxuLy9cbi8vIE1JVCBMaWNlbnNlXG4vL1xuLy8gQ29weXJpZ2h0IChjKSBTaW5kcmUgU29yaHVzIDxzaW5kcmVzb3JodXNAZ21haWwuY29tPiAoaHR0cHM6Ly9zaW5kcmVzb3JodXMuY29tKVxuLy9cbi8vIFBlcm1pc3Npb24gaXMgaGVyZWJ5IGdyYW50ZWQsIGZyZWUgb2YgY2hhcmdlLCB0byBhbnkgcGVyc29uIG9idGFpbmluZyBhIGNvcHkgb2YgdGhpcyBzb2Z0d2FyZSBhbmQgYXNzb2NpYXRlZFxuLy8gZG9jdW1lbnRhdGlvbiBmaWxlcyh0aGUgXCJTb2Z0d2FyZVwiKSwgdG8gZGVhbCBpbiB0aGUgU29mdHdhcmUgd2l0aG91dCByZXN0cmljdGlvbiwgaW5jbHVkaW5nIHdpdGhvdXQgbGltaXRhdGlvblxuLy8gdGhlIHJpZ2h0cyB0byB1c2UsIGNvcHksIG1vZGlmeSwgbWVyZ2UsIHB1Ymxpc2gsIGRpc3RyaWJ1dGUsIHN1YmxpY2Vuc2UsIGFuZCAvIG9yIHNlbGwgY29waWVzIG9mIHRoZSBTb2Z0d2FyZSwgYW5kXG4vLyB0byBwZXJtaXQgcGVyc29ucyB0byB3aG9tIHRoZSBTb2Z0d2FyZSBpcyBmdXJuaXNoZWQgdG8gZG8gc28sIHN1YmplY3QgdG8gdGhlIGZvbGxvd2luZyBjb25kaXRpb25zOlxuLy9cbi8vIFRoZSBhYm92ZSBjb3B5cmlnaHQgbm90aWNlIGFuZCB0aGlzIHBlcm1pc3Npb24gbm90aWNlIHNoYWxsIGJlIGluY2x1ZGVkIGluIGFsbCBjb3BpZXMgb3Igc3Vic3RhbnRpYWwgcG9ydGlvbnMgb2Zcbi8vIHRoZSBTb2Z0d2FyZS5cbi8vXG4vLyBUSEUgU09GVFdBUkUgSVMgUFJPVklERUQgXCJBUyBJU1wiLCBXSVRIT1VUIFdBUlJBTlRZIE9GIEFOWSBLSU5ELCBFWFBSRVNTIE9SIElNUExJRUQsIElOQ0xVRElORyBCVVQgTk9UIExJTUlURUQgVE9cbi8vIFRIRSBXQVJSQU5USUVTIE9GIE1FUkNIQU5UQUJJTElUWSwgRklUTkVTUyBGT1IgQSBQQVJUSUNVTEFSIFBVUlBPU0UgQU5EIE5PTklORlJJTkdFTUVOVC5JTiBOTyBFVkVOVCBTSEFMTCBUSEVcbi8vIEFVVEhPUlMgT1IgQ09QWVJJR0hUIEhPTERFUlMgQkUgTElBQkxFIEZPUiBBTlkgQ0xBSU0sIERBTUFHRVMgT1IgT1RIRVIgTElBQklMSVRZLCBXSEVUSEVSIElOIEFOIEFDVElPTiBPRiBDT05UUkFDVCxcbi8vIFRPUlQgT1IgT1RIRVJXSVNFLCBBUklTSU5HIEZST00sIE9VVCBPRiBPUiBJTiBDT05ORUNUSU9OIFdJVEggVEhFIFNPRlRXQVJFIE9SIFRIRSBVU0UgT1IgT1RIRVIgREVBTElOR1Ncbi8vIElOIFRIRSBTT0ZUV0FSRS5cblxuLyoqXG4gKiBHaXZlbiBhIHN0cmluZywgZXNjYXBlIGNoYXJhY3RlcnMgd2hpY2ggaGF2ZSBtZWFuaW5nIGluIHRoZSByZWdleCBncmFtbWFyLCBzdWNoIHRoYXQgdGhlIHJlc3VsdCBpcyBzYWZlIHRvIGZlZWQgdG9cbiAqIGBuZXcgUmVnRXhwKClgLlxuICpcbiAqIEBwYXJhbSByZWdleFN0cmluZyBUaGUgc3RyaW5nIHRvIGVzY2FwZVxuICogQHJldHVybnMgQW4gdmVyc2lvbiBvZiB0aGUgc3RyaW5nIHdpdGggYWxsIHNwZWNpYWwgcmVnZXggY2hhcmFjdGVycyBlc2NhcGVkXG4gKi9cbmZ1bmN0aW9uIGVzY2FwZVN0cmluZ0ZvclJlZ2V4KHJlZ2V4U3RyaW5nKSB7XG4gIC8vIGVzY2FwZSB0aGUgaHlwaGVuIHNlcGFyYXRlbHkgc28gd2UgY2FuIGFsc28gcmVwbGFjZSBpdCB3aXRoIGEgdW5pY29kZSBsaXRlcmFsIGh5cGhlbiwgdG8gYXZvaWQgdGhlIHByb2JsZW1zXG4gIC8vIGRpc2N1c3NlZCBpbiBodHRwczovL2dpdGh1Yi5jb20vc2luZHJlc29yaHVzL2VzY2FwZS1zdHJpbmctcmVnZXhwL2lzc3Vlcy8yMC5cbiAgcmV0dXJuIHJlZ2V4U3RyaW5nLnJlcGxhY2UoL1t8XFxcXHt9KClbXFxdXiQrKj8uXS9nLCAnXFxcXCQmJykucmVwbGFjZSgvLS9nLCAnXFxcXHgyZCcpO1xufVxuXG5leHBvcnRzLmVzY2FwZVN0cmluZ0ZvclJlZ2V4ID0gZXNjYXBlU3RyaW5nRm9yUmVnZXg7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1lc2NhcGVTdHJpbmdGb3JSZWdleC5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/vendor/escapeStringForRegex.js\n");
 
/***/ }),
 
/***/ "(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/vendor/getIpAddress.js":
/*!***********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/vendor/getIpAddress.js ***!
  \***********************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n// Vendored / modified from @sergiodxa/remix-utils\n\n// https://github.com/sergiodxa/remix-utils/blob/02af80e12829a53696bfa8f3c2363975cf59f55e/src/server/get-client-ip-address.ts\n// MIT License\n\n// Copyright (c) 2021 Sergio Xalambrí\n\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the \"Software\"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n\n// The above copyright notice and this permission notice shall be included in all\n// copies or substantial portions of the Software.\n\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n// SOFTWARE.\n\n// The headers to check, in priority order\nconst ipHeaderNames = [\n  'X-Client-IP',\n  'X-Forwarded-For',\n  'Fly-Client-IP',\n  'CF-Connecting-IP',\n  'Fastly-Client-Ip',\n  'True-Client-Ip',\n  'X-Real-IP',\n  'X-Cluster-Client-IP',\n  'X-Forwarded',\n  'Forwarded-For',\n  'Forwarded',\n  'X-Vercel-Forwarded-For',\n];\n\n/**\n * Get the IP address of the client sending a request.\n *\n * It receives a Request headers object and use it to get the\n * IP address from one of the following headers in order.\n *\n * If the IP address is valid, it will be returned. Otherwise, null will be\n * returned.\n *\n * If the header values contains more than one IP address, the first valid one\n * will be returned.\n */\nfunction getClientIPAddress(headers) {\n  // This will end up being Array<string | string[] | undefined | null> because of the various possible values a header\n  // can take\n  const headerValues = ipHeaderNames.map((headerName) => {\n    const rawValue = headers[headerName];\n    const value = Array.isArray(rawValue) ? rawValue.join(';') : rawValue;\n\n    if (headerName === 'Forwarded') {\n      return parseForwardedHeader(value);\n    }\n\n    return value?.split(',').map((v) => v.trim());\n  });\n\n  // Flatten the array and filter out any falsy entries\n  const flattenedHeaderValues = headerValues.reduce((acc, val) => {\n    if (!val) {\n      return acc;\n    }\n\n    return acc.concat(val);\n  }, []);\n\n  // Find the first value which is a valid IP address, if any\n  const ipAddress = flattenedHeaderValues.find(ip => ip !== null && isIP(ip));\n\n  return ipAddress || null;\n}\n\nfunction parseForwardedHeader(value) {\n  if (!value) {\n    return null;\n  }\n\n  for (const part of value.split(';')) {\n    if (part.startsWith('for=')) {\n      return part.slice(4);\n    }\n  }\n\n  return null;\n}\n\n//\n/**\n * Custom method instead of importing this from `net` package, as this only exists in node\n * Accepts:\n * 127.0.0.1\n * 192.168.1.1\n * 192.168.1.255\n * 255.255.255.255\n * 10.1.1.1\n * 0.0.0.0\n * 2b01:cb19:8350:ed00:d0dd:fa5b:de31:8be5\n *\n * Rejects:\n * 1.1.1.01\n * 30.168.1.255.1\n * 127.1\n * 192.168.1.256\n * -1.2.3.4\n * 1.1.1.1.\n * 3...3\n * 192.168.1.099\n */\nfunction isIP(str) {\n  const regex =\n    /(?:^(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)(?:\\.(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)){3}$)|(?:^(?:(?:[a-fA-F\\d]{1,4}:){7}(?:[a-fA-F\\d]{1,4}|:)|(?:[a-fA-F\\d]{1,4}:){6}(?:(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)(?:\\\\.(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)){3}|:[a-fA-F\\d]{1,4}|:)|(?:[a-fA-F\\d]{1,4}:){5}(?::(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)(?:\\\\.(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)){3}|(?::[a-fA-F\\d]{1,4}){1,2}|:)|(?:[a-fA-F\\d]{1,4}:){4}(?:(?::[a-fA-F\\d]{1,4}){0,1}:(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)(?:\\\\.(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)){3}|(?::[a-fA-F\\d]{1,4}){1,3}|:)|(?:[a-fA-F\\d]{1,4}:){3}(?:(?::[a-fA-F\\d]{1,4}){0,2}:(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)(?:\\\\.(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)){3}|(?::[a-fA-F\\d]{1,4}){1,4}|:)|(?:[a-fA-F\\d]{1,4}:){2}(?:(?::[a-fA-F\\d]{1,4}){0,3}:(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)(?:\\\\.(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)){3}|(?::[a-fA-F\\d]{1,4}){1,5}|:)|(?:[a-fA-F\\d]{1,4}:){1}(?:(?::[a-fA-F\\d]{1,4}){0,4}:(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)(?:\\\\.(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)){3}|(?::[a-fA-F\\d]{1,4}){1,6}|:)|(?::(?:(?::[a-fA-F\\d]{1,4}){0,5}:(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)(?:\\\\.(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)){3}|(?::[a-fA-F\\d]{1,4}){1,7}|:)))(?:%[0-9a-zA-Z]{1,})?$)/;\n  return regex.test(str);\n}\n\nexports.getClientIPAddress = getClientIPAddress;\nexports.ipHeaderNames = ipHeaderNames;\n//# sourceMappingURL=getIpAddress.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy92ZW5kb3IvZ2V0SXBBZGRyZXNzLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFOztBQUVBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSw0REFBNEQ7O0FBRTVEO0FBQ0E7QUFDQTs7QUFFQTtBQUNBLEdBQUc7O0FBRUg7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBLEdBQUc7O0FBRUg7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLG1DQUFtQztBQUNuQztBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLDBGQUEwRixFQUFFLHdCQUF3QixJQUFJLEdBQUcsRUFBRSxjQUFjLElBQUksa0JBQWtCLElBQUksR0FBRyxFQUFFLHFGQUFxRixFQUFFLGFBQWEsSUFBSSxrQkFBa0IsSUFBSSxHQUFHLEVBQUUsc0ZBQXNGLEVBQUUsZ0JBQWdCLElBQUksRUFBRSxJQUFJLGtCQUFrQixJQUFJLEdBQUcsRUFBRSxrQkFBa0IsSUFBSSxFQUFFLElBQUksbUZBQW1GLEVBQUUsZ0JBQWdCLElBQUksRUFBRSxJQUFJLGtCQUFrQixJQUFJLEdBQUcsRUFBRSxrQkFBa0IsSUFBSSxFQUFFLElBQUksbUZBQW1GLEVBQUUsZ0JBQWdCLElBQUksRUFBRSxJQUFJLGtCQUFrQixJQUFJLEdBQUcsRUFBRSxrQkFBa0IsSUFBSSxFQUFFLElBQUksbUZBQW1GLEVBQUUsZ0JBQWdCLElBQUksRUFBRSxJQUFJLGtCQUFrQixJQUFJLEdBQUcsRUFBRSxrQkFBa0IsSUFBSSxFQUFFLElBQUksbUZBQW1GLEVBQUUsZ0JBQWdCLElBQUksRUFBRSxJQUFJLDBCQUEwQixJQUFJLEVBQUUsSUFBSSxtRkFBbUYsRUFBRSxnQkFBZ0IsSUFBSSxFQUFFLElBQUkscUJBQXFCLEdBQUc7QUFDbHVDO0FBQ0E7O0FBRUEsMEJBQTBCO0FBQzFCLHFCQUFxQjtBQUNyQiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3ZlbmRvci9nZXRJcEFkZHJlc3MuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbi8vIFZlbmRvcmVkIC8gbW9kaWZpZWQgZnJvbSBAc2VyZ2lvZHhhL3JlbWl4LXV0aWxzXG5cbi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9zZXJnaW9keGEvcmVtaXgtdXRpbHMvYmxvYi8wMmFmODBlMTI4MjlhNTM2OTZiZmE4ZjNjMjM2Mzk3NWNmNTlmNTVlL3NyYy9zZXJ2ZXIvZ2V0LWNsaWVudC1pcC1hZGRyZXNzLnRzXG4vLyBNSVQgTGljZW5zZVxuXG4vLyBDb3B5cmlnaHQgKGMpIDIwMjEgU2VyZ2lvIFhhbGFtYnLDrVxuXG4vLyBQZXJtaXNzaW9uIGlzIGhlcmVieSBncmFudGVkLCBmcmVlIG9mIGNoYXJnZSwgdG8gYW55IHBlcnNvbiBvYnRhaW5pbmcgYSBjb3B5XG4vLyBvZiB0aGlzIHNvZnR3YXJlIGFuZCBhc3NvY2lhdGVkIGRvY3VtZW50YXRpb24gZmlsZXMgKHRoZSBcIlNvZnR3YXJlXCIpLCB0byBkZWFsXG4vLyBpbiB0aGUgU29mdHdhcmUgd2l0aG91dCByZXN0cmljdGlvbiwgaW5jbHVkaW5nIHdpdGhvdXQgbGltaXRhdGlvbiB0aGUgcmlnaHRzXG4vLyB0byB1c2UsIGNvcHksIG1vZGlmeSwgbWVyZ2UsIHB1Ymxpc2gsIGRpc3RyaWJ1dGUsIHN1YmxpY2Vuc2UsIGFuZC9vciBzZWxsXG4vLyBjb3BpZXMgb2YgdGhlIFNvZnR3YXJlLCBhbmQgdG8gcGVybWl0IHBlcnNvbnMgdG8gd2hvbSB0aGUgU29mdHdhcmUgaXNcbi8vIGZ1cm5pc2hlZCB0byBkbyBzbywgc3ViamVjdCB0byB0aGUgZm9sbG93aW5nIGNvbmRpdGlvbnM6XG5cbi8vIFRoZSBhYm92ZSBjb3B5cmlnaHQgbm90aWNlIGFuZCB0aGlzIHBlcm1pc3Npb24gbm90aWNlIHNoYWxsIGJlIGluY2x1ZGVkIGluIGFsbFxuLy8gY29waWVzIG9yIHN1YnN0YW50aWFsIHBvcnRpb25zIG9mIHRoZSBTb2Z0d2FyZS5cblxuLy8gVEhFIFNPRlRXQVJFIElTIFBST1ZJREVEIFwiQVMgSVNcIiwgV0lUSE9VVCBXQVJSQU5UWSBPRiBBTlkgS0lORCwgRVhQUkVTUyBPUlxuLy8gSU1QTElFRCwgSU5DTFVESU5HIEJVVCBOT1QgTElNSVRFRCBUTyBUSEUgV0FSUkFOVElFUyBPRiBNRVJDSEFOVEFCSUxJVFksXG4vLyBGSVRORVNTIEZPUiBBIFBBUlRJQ1VMQVIgUFVSUE9TRSBBTkQgTk9OSU5GUklOR0VNRU5ULiBJTiBOTyBFVkVOVCBTSEFMTCBUSEVcbi8vIEFVVEhPUlMgT1IgQ09QWVJJR0hUIEhPTERFUlMgQkUgTElBQkxFIEZPUiBBTlkgQ0xBSU0sIERBTUFHRVMgT1IgT1RIRVJcbi8vIExJQUJJTElUWSwgV0hFVEhFUiBJTiBBTiBBQ1RJT04gT0YgQ09OVFJBQ1QsIFRPUlQgT1IgT1RIRVJXSVNFLCBBUklTSU5HIEZST00sXG4vLyBPVVQgT0YgT1IgSU4gQ09OTkVDVElPTiBXSVRIIFRIRSBTT0ZUV0FSRSBPUiBUSEUgVVNFIE9SIE9USEVSIERFQUxJTkdTIElOIFRIRVxuLy8gU09GVFdBUkUuXG5cbi8vIFRoZSBoZWFkZXJzIHRvIGNoZWNrLCBpbiBwcmlvcml0eSBvcmRlclxuY29uc3QgaXBIZWFkZXJOYW1lcyA9IFtcbiAgJ1gtQ2xpZW50LUlQJyxcbiAgJ1gtRm9yd2FyZGVkLUZvcicsXG4gICdGbHktQ2xpZW50LUlQJyxcbiAgJ0NGLUNvbm5lY3RpbmctSVAnLFxuICAnRmFzdGx5LUNsaWVudC1JcCcsXG4gICdUcnVlLUNsaWVudC1JcCcsXG4gICdYLVJlYWwtSVAnLFxuICAnWC1DbHVzdGVyLUNsaWVudC1JUCcsXG4gICdYLUZvcndhcmRlZCcsXG4gICdGb3J3YXJkZWQtRm9yJyxcbiAgJ0ZvcndhcmRlZCcsXG4gICdYLVZlcmNlbC1Gb3J3YXJkZWQtRm9yJyxcbl07XG5cbi8qKlxuICogR2V0IHRoZSBJUCBhZGRyZXNzIG9mIHRoZSBjbGllbnQgc2VuZGluZyBhIHJlcXVlc3QuXG4gKlxuICogSXQgcmVjZWl2ZXMgYSBSZXF1ZXN0IGhlYWRlcnMgb2JqZWN0IGFuZCB1c2UgaXQgdG8gZ2V0IHRoZVxuICogSVAgYWRkcmVzcyBmcm9tIG9uZSBvZiB0aGUgZm9sbG93aW5nIGhlYWRlcnMgaW4gb3JkZXIuXG4gKlxuICogSWYgdGhlIElQIGFkZHJlc3MgaXMgdmFsaWQsIGl0IHdpbGwgYmUgcmV0dXJuZWQuIE90aGVyd2lzZSwgbnVsbCB3aWxsIGJlXG4gKiByZXR1cm5lZC5cbiAqXG4gKiBJZiB0aGUgaGVhZGVyIHZhbHVlcyBjb250YWlucyBtb3JlIHRoYW4gb25lIElQIGFkZHJlc3MsIHRoZSBmaXJzdCB2YWxpZCBvbmVcbiAqIHdpbGwgYmUgcmV0dXJuZWQuXG4gKi9cbmZ1bmN0aW9uIGdldENsaWVudElQQWRkcmVzcyhoZWFkZXJzKSB7XG4gIC8vIFRoaXMgd2lsbCBlbmQgdXAgYmVpbmcgQXJyYXk8c3RyaW5nIHwgc3RyaW5nW10gfCB1bmRlZmluZWQgfCBudWxsPiBiZWNhdXNlIG9mIHRoZSB2YXJpb3VzIHBvc3NpYmxlIHZhbHVlcyBhIGhlYWRlclxuICAvLyBjYW4gdGFrZVxuICBjb25zdCBoZWFkZXJWYWx1ZXMgPSBpcEhlYWRlck5hbWVzLm1hcCgoaGVhZGVyTmFtZSkgPT4ge1xuICAgIGNvbnN0IHJhd1ZhbHVlID0gaGVhZGVyc1toZWFkZXJOYW1lXTtcbiAgICBjb25zdCB2YWx1ZSA9IEFycmF5LmlzQXJyYXkocmF3VmFsdWUpID8gcmF3VmFsdWUuam9pbignOycpIDogcmF3VmFsdWU7XG5cbiAgICBpZiAoaGVhZGVyTmFtZSA9PT0gJ0ZvcndhcmRlZCcpIHtcbiAgICAgIHJldHVybiBwYXJzZUZvcndhcmRlZEhlYWRlcih2YWx1ZSk7XG4gICAgfVxuXG4gICAgcmV0dXJuIHZhbHVlPy5zcGxpdCgnLCcpLm1hcCgodikgPT4gdi50cmltKCkpO1xuICB9KTtcblxuICAvLyBGbGF0dGVuIHRoZSBhcnJheSBhbmQgZmlsdGVyIG91dCBhbnkgZmFsc3kgZW50cmllc1xuICBjb25zdCBmbGF0dGVuZWRIZWFkZXJWYWx1ZXMgPSBoZWFkZXJWYWx1ZXMucmVkdWNlKChhY2MsIHZhbCkgPT4ge1xuICAgIGlmICghdmFsKSB7XG4gICAgICByZXR1cm4gYWNjO1xuICAgIH1cblxuICAgIHJldHVybiBhY2MuY29uY2F0KHZhbCk7XG4gIH0sIFtdKTtcblxuICAvLyBGaW5kIHRoZSBmaXJzdCB2YWx1ZSB3aGljaCBpcyBhIHZhbGlkIElQIGFkZHJlc3MsIGlmIGFueVxuICBjb25zdCBpcEFkZHJlc3MgPSBmbGF0dGVuZWRIZWFkZXJWYWx1ZXMuZmluZChpcCA9PiBpcCAhPT0gbnVsbCAmJiBpc0lQKGlwKSk7XG5cbiAgcmV0dXJuIGlwQWRkcmVzcyB8fCBudWxsO1xufVxuXG5mdW5jdGlvbiBwYXJzZUZvcndhcmRlZEhlYWRlcih2YWx1ZSkge1xuICBpZiAoIXZhbHVlKSB7XG4gICAgcmV0dXJuIG51bGw7XG4gIH1cblxuICBmb3IgKGNvbnN0IHBhcnQgb2YgdmFsdWUuc3BsaXQoJzsnKSkge1xuICAgIGlmIChwYXJ0LnN0YXJ0c1dpdGgoJ2Zvcj0nKSkge1xuICAgICAgcmV0dXJuIHBhcnQuc2xpY2UoNCk7XG4gICAgfVxuICB9XG5cbiAgcmV0dXJuIG51bGw7XG59XG5cbi8vXG4vKipcbiAqIEN1c3RvbSBtZXRob2QgaW5zdGVhZCBvZiBpbXBvcnRpbmcgdGhpcyBmcm9tIGBuZXRgIHBhY2thZ2UsIGFzIHRoaXMgb25seSBleGlzdHMgaW4gbm9kZVxuICogQWNjZXB0czpcbiAqIDEyNy4wLjAuMVxuICogMTkyLjE2OC4xLjFcbiAqIDE5Mi4xNjguMS4yNTVcbiAqIDI1NS4yNTUuMjU1LjI1NVxuICogMTAuMS4xLjFcbiAqIDAuMC4wLjBcbiAqIDJiMDE6Y2IxOTo4MzUwOmVkMDA6ZDBkZDpmYTViOmRlMzE6OGJlNVxuICpcbiAqIFJlamVjdHM6XG4gKiAxLjEuMS4wMVxuICogMzAuMTY4LjEuMjU1LjFcbiAqIDEyNy4xXG4gKiAxOTIuMTY4LjEuMjU2XG4gKiAtMS4yLjMuNFxuICogMS4xLjEuMS5cbiAqIDMuLi4zXG4gKiAxOTIuMTY4LjEuMDk5XG4gKi9cbmZ1bmN0aW9uIGlzSVAoc3RyKSB7XG4gIGNvbnN0IHJlZ2V4ID1cbiAgICAvKD86Xig/OjI1WzAtNV18MlswLTRdXFxkfDFcXGRcXGR8WzEtOV1cXGR8XFxkKSg/OlxcLig/OjI1WzAtNV18MlswLTRdXFxkfDFcXGRcXGR8WzEtOV1cXGR8XFxkKSl7M30kKXwoPzpeKD86KD86W2EtZkEtRlxcZF17MSw0fTopezd9KD86W2EtZkEtRlxcZF17MSw0fXw6KXwoPzpbYS1mQS1GXFxkXXsxLDR9Oil7Nn0oPzooPzoyNVswLTVdfDJbMC00XVxcZHwxXFxkXFxkfFsxLTldXFxkfFxcZCkoPzpcXFxcLig/OjI1WzAtNV18MlswLTRdXFxkfDFcXGRcXGR8WzEtOV1cXGR8XFxkKSl7M318OlthLWZBLUZcXGRdezEsNH18Oil8KD86W2EtZkEtRlxcZF17MSw0fTopezV9KD86Oig/OjI1WzAtNV18MlswLTRdXFxkfDFcXGRcXGR8WzEtOV1cXGR8XFxkKSg/OlxcXFwuKD86MjVbMC01XXwyWzAtNF1cXGR8MVxcZFxcZHxbMS05XVxcZHxcXGQpKXszfXwoPzo6W2EtZkEtRlxcZF17MSw0fSl7MSwyfXw6KXwoPzpbYS1mQS1GXFxkXXsxLDR9Oil7NH0oPzooPzo6W2EtZkEtRlxcZF17MSw0fSl7MCwxfTooPzoyNVswLTVdfDJbMC00XVxcZHwxXFxkXFxkfFsxLTldXFxkfFxcZCkoPzpcXFxcLig/OjI1WzAtNV18MlswLTRdXFxkfDFcXGRcXGR8WzEtOV1cXGR8XFxkKSl7M318KD86OlthLWZBLUZcXGRdezEsNH0pezEsM318Oil8KD86W2EtZkEtRlxcZF17MSw0fTopezN9KD86KD86OlthLWZBLUZcXGRdezEsNH0pezAsMn06KD86MjVbMC01XXwyWzAtNF1cXGR8MVxcZFxcZHxbMS05XVxcZHxcXGQpKD86XFxcXC4oPzoyNVswLTVdfDJbMC00XVxcZHwxXFxkXFxkfFsxLTldXFxkfFxcZCkpezN9fCg/OjpbYS1mQS1GXFxkXXsxLDR9KXsxLDR9fDopfCg/OlthLWZBLUZcXGRdezEsNH06KXsyfSg/Oig/OjpbYS1mQS1GXFxkXXsxLDR9KXswLDN9Oig/OjI1WzAtNV18MlswLTRdXFxkfDFcXGRcXGR8WzEtOV1cXGR8XFxkKSg/OlxcXFwuKD86MjVbMC01XXwyWzAtNF1cXGR8MVxcZFxcZHxbMS05XVxcZHxcXGQpKXszfXwoPzo6W2EtZkEtRlxcZF17MSw0fSl7MSw1fXw6KXwoPzpbYS1mQS1GXFxkXXsxLDR9Oil7MX0oPzooPzo6W2EtZkEtRlxcZF17MSw0fSl7MCw0fTooPzoyNVswLTVdfDJbMC00XVxcZHwxXFxkXFxkfFsxLTldXFxkfFxcZCkoPzpcXFxcLig/OjI1WzAtNV18MlswLTRdXFxkfDFcXGRcXGR8WzEtOV1cXGR8XFxkKSl7M318KD86OlthLWZBLUZcXGRdezEsNH0pezEsNn18Oil8KD86Oig/Oig/OjpbYS1mQS1GXFxkXXsxLDR9KXswLDV9Oig/OjI1WzAtNV18MlswLTRdXFxkfDFcXGRcXGR8WzEtOV1cXGR8XFxkKSg/OlxcXFwuKD86MjVbMC01XXwyWzAtNF1cXGR8MVxcZFxcZHxbMS05XVxcZHxcXGQpKXszfXwoPzo6W2EtZkEtRlxcZF17MSw0fSl7MSw3fXw6KSkpKD86JVswLTlhLXpBLVpdezEsfSk/JCkvO1xuICByZXR1cm4gcmVnZXgudGVzdChzdHIpO1xufVxuXG5leHBvcnRzLmdldENsaWVudElQQWRkcmVzcyA9IGdldENsaWVudElQQWRkcmVzcztcbmV4cG9ydHMuaXBIZWFkZXJOYW1lcyA9IGlwSGVhZGVyTmFtZXM7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1nZXRJcEFkZHJlc3MuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/vendor/getIpAddress.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/api.js":
/*!*******************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/api.js ***!
  \*******************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst dsn = __webpack_require__(/*! ./utils/dsn.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/dsn.js\");\n\nconst SENTRY_API_VERSION = '7';\n\n/** Returns the prefix to construct Sentry ingestion API endpoints. */\nfunction getBaseApiEndpoint(dsn) {\n  const protocol = dsn.protocol ? `${dsn.protocol}:` : '';\n  const port = dsn.port ? `:${dsn.port}` : '';\n  return `${protocol}//${dsn.host}${port}${dsn.path ? `/${dsn.path}` : ''}/api/`;\n}\n\n/** Returns the ingest API endpoint for target. */\nfunction _getIngestEndpoint(dsn) {\n  return `${getBaseApiEndpoint(dsn)}${dsn.projectId}/envelope/`;\n}\n\n/** Returns a URL-encoded string with auth config suitable for a query string. */\nfunction _encodedAuth(dsn, sdkInfo) {\n  const params = {\n    sentry_version: SENTRY_API_VERSION,\n  };\n\n  if (dsn.publicKey) {\n    // We send only the minimum set of required information. See\n    // https://github.com/getsentry/sentry-javascript/issues/2572.\n    params.sentry_key = dsn.publicKey;\n  }\n\n  if (sdkInfo) {\n    params.sentry_client = `${sdkInfo.name}/${sdkInfo.version}`;\n  }\n\n  return new URLSearchParams(params).toString();\n}\n\n/**\n * Returns the envelope endpoint URL with auth in the query string.\n *\n * Sending auth as part of the query string and not as custom HTTP headers avoids CORS preflight requests.\n */\nfunction getEnvelopeEndpointWithUrlEncodedAuth(dsn, tunnel, sdkInfo) {\n  return tunnel ? tunnel : `${_getIngestEndpoint(dsn)}?${_encodedAuth(dsn, sdkInfo)}`;\n}\n\n/** Returns the url to the report dialog endpoint. */\nfunction getReportDialogEndpoint(dsnLike, dialogOptions) {\n  const dsn$1 = dsn.makeDsn(dsnLike);\n  if (!dsn$1) {\n    return '';\n  }\n\n  const endpoint = `${getBaseApiEndpoint(dsn$1)}embed/error-page/`;\n\n  let encodedOptions = `dsn=${dsn.dsnToString(dsn$1)}`;\n  for (const key in dialogOptions) {\n    if (key === 'dsn') {\n      continue;\n    }\n\n    if (key === 'onClose') {\n      continue;\n    }\n\n    if (key === 'user') {\n      const user = dialogOptions.user;\n      if (!user) {\n        continue;\n      }\n      if (user.name) {\n        encodedOptions += `&name=${encodeURIComponent(user.name)}`;\n      }\n      if (user.email) {\n        encodedOptions += `&email=${encodeURIComponent(user.email)}`;\n      }\n    } else {\n      encodedOptions += `&${encodeURIComponent(key)}=${encodeURIComponent(dialogOptions[key] )}`;\n    }\n  }\n\n  return `${endpoint}?${encodedOptions}`;\n}\n\nexports.getEnvelopeEndpointWithUrlEncodedAuth = getEnvelopeEndpointWithUrlEncodedAuth;\nexports.getReportDialogEndpoint = getReportDialogEndpoint;\n//# sourceMappingURL=api.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9hcGkuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsWUFBWSxtQkFBTyxDQUFDLHVIQUFnQjs7QUFFcEM7O0FBRUE7QUFDQTtBQUNBLHFDQUFxQyxhQUFhO0FBQ2xELDhCQUE4QixTQUFTO0FBQ3ZDLFlBQVksU0FBUyxJQUFJLFNBQVMsRUFBRSxLQUFLLEVBQUUsZUFBZSxTQUFTLE9BQU87QUFDMUU7O0FBRUE7QUFDQTtBQUNBLFlBQVksd0JBQXdCLEVBQUUsY0FBYztBQUNwRDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQSw4QkFBOEIsYUFBYSxHQUFHLGdCQUFnQjtBQUM5RDs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLDhCQUE4Qix3QkFBd0IsR0FBRywyQkFBMkI7QUFDcEY7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLHNCQUFzQiwwQkFBMEI7O0FBRWhELDhCQUE4Qix1QkFBdUI7QUFDckQ7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLG1DQUFtQyw4QkFBOEI7QUFDakU7QUFDQTtBQUNBLG9DQUFvQywrQkFBK0I7QUFDbkU7QUFDQSxNQUFNO0FBQ04sNEJBQTRCLHdCQUF3QixHQUFHLHdDQUF3QztBQUMvRjtBQUNBOztBQUVBLFlBQVksU0FBUyxHQUFHLGVBQWU7QUFDdkM7O0FBRUEsNkNBQTZDO0FBQzdDLCtCQUErQjtBQUMvQiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL2FwaS5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgZHNuID0gcmVxdWlyZSgnLi91dGlscy9kc24uanMnKTtcblxuY29uc3QgU0VOVFJZX0FQSV9WRVJTSU9OID0gJzcnO1xuXG4vKiogUmV0dXJucyB0aGUgcHJlZml4IHRvIGNvbnN0cnVjdCBTZW50cnkgaW5nZXN0aW9uIEFQSSBlbmRwb2ludHMuICovXG5mdW5jdGlvbiBnZXRCYXNlQXBpRW5kcG9pbnQoZHNuKSB7XG4gIGNvbnN0IHByb3RvY29sID0gZHNuLnByb3RvY29sID8gYCR7ZHNuLnByb3RvY29sfTpgIDogJyc7XG4gIGNvbnN0IHBvcnQgPSBkc24ucG9ydCA/IGA6JHtkc24ucG9ydH1gIDogJyc7XG4gIHJldHVybiBgJHtwcm90b2NvbH0vLyR7ZHNuLmhvc3R9JHtwb3J0fSR7ZHNuLnBhdGggPyBgLyR7ZHNuLnBhdGh9YCA6ICcnfS9hcGkvYDtcbn1cblxuLyoqIFJldHVybnMgdGhlIGluZ2VzdCBBUEkgZW5kcG9pbnQgZm9yIHRhcmdldC4gKi9cbmZ1bmN0aW9uIF9nZXRJbmdlc3RFbmRwb2ludChkc24pIHtcbiAgcmV0dXJuIGAke2dldEJhc2VBcGlFbmRwb2ludChkc24pfSR7ZHNuLnByb2plY3RJZH0vZW52ZWxvcGUvYDtcbn1cblxuLyoqIFJldHVybnMgYSBVUkwtZW5jb2RlZCBzdHJpbmcgd2l0aCBhdXRoIGNvbmZpZyBzdWl0YWJsZSBmb3IgYSBxdWVyeSBzdHJpbmcuICovXG5mdW5jdGlvbiBfZW5jb2RlZEF1dGgoZHNuLCBzZGtJbmZvKSB7XG4gIGNvbnN0IHBhcmFtcyA9IHtcbiAgICBzZW50cnlfdmVyc2lvbjogU0VOVFJZX0FQSV9WRVJTSU9OLFxuICB9O1xuXG4gIGlmIChkc24ucHVibGljS2V5KSB7XG4gICAgLy8gV2Ugc2VuZCBvbmx5IHRoZSBtaW5pbXVtIHNldCBvZiByZXF1aXJlZCBpbmZvcm1hdGlvbi4gU2VlXG4gICAgLy8gaHR0cHM6Ly9naXRodWIuY29tL2dldHNlbnRyeS9zZW50cnktamF2YXNjcmlwdC9pc3N1ZXMvMjU3Mi5cbiAgICBwYXJhbXMuc2VudHJ5X2tleSA9IGRzbi5wdWJsaWNLZXk7XG4gIH1cblxuICBpZiAoc2RrSW5mbykge1xuICAgIHBhcmFtcy5zZW50cnlfY2xpZW50ID0gYCR7c2RrSW5mby5uYW1lfS8ke3Nka0luZm8udmVyc2lvbn1gO1xuICB9XG5cbiAgcmV0dXJuIG5ldyBVUkxTZWFyY2hQYXJhbXMocGFyYW1zKS50b1N0cmluZygpO1xufVxuXG4vKipcbiAqIFJldHVybnMgdGhlIGVudmVsb3BlIGVuZHBvaW50IFVSTCB3aXRoIGF1dGggaW4gdGhlIHF1ZXJ5IHN0cmluZy5cbiAqXG4gKiBTZW5kaW5nIGF1dGggYXMgcGFydCBvZiB0aGUgcXVlcnkgc3RyaW5nIGFuZCBub3QgYXMgY3VzdG9tIEhUVFAgaGVhZGVycyBhdm9pZHMgQ09SUyBwcmVmbGlnaHQgcmVxdWVzdHMuXG4gKi9cbmZ1bmN0aW9uIGdldEVudmVsb3BlRW5kcG9pbnRXaXRoVXJsRW5jb2RlZEF1dGgoZHNuLCB0dW5uZWwsIHNka0luZm8pIHtcbiAgcmV0dXJuIHR1bm5lbCA/IHR1bm5lbCA6IGAke19nZXRJbmdlc3RFbmRwb2ludChkc24pfT8ke19lbmNvZGVkQXV0aChkc24sIHNka0luZm8pfWA7XG59XG5cbi8qKiBSZXR1cm5zIHRoZSB1cmwgdG8gdGhlIHJlcG9ydCBkaWFsb2cgZW5kcG9pbnQuICovXG5mdW5jdGlvbiBnZXRSZXBvcnREaWFsb2dFbmRwb2ludChkc25MaWtlLCBkaWFsb2dPcHRpb25zKSB7XG4gIGNvbnN0IGRzbiQxID0gZHNuLm1ha2VEc24oZHNuTGlrZSk7XG4gIGlmICghZHNuJDEpIHtcbiAgICByZXR1cm4gJyc7XG4gIH1cblxuICBjb25zdCBlbmRwb2ludCA9IGAke2dldEJhc2VBcGlFbmRwb2ludChkc24kMSl9ZW1iZWQvZXJyb3ItcGFnZS9gO1xuXG4gIGxldCBlbmNvZGVkT3B0aW9ucyA9IGBkc249JHtkc24uZHNuVG9TdHJpbmcoZHNuJDEpfWA7XG4gIGZvciAoY29uc3Qga2V5IGluIGRpYWxvZ09wdGlvbnMpIHtcbiAgICBpZiAoa2V5ID09PSAnZHNuJykge1xuICAgICAgY29udGludWU7XG4gICAgfVxuXG4gICAgaWYgKGtleSA9PT0gJ29uQ2xvc2UnKSB7XG4gICAgICBjb250aW51ZTtcbiAgICB9XG5cbiAgICBpZiAoa2V5ID09PSAndXNlcicpIHtcbiAgICAgIGNvbnN0IHVzZXIgPSBkaWFsb2dPcHRpb25zLnVzZXI7XG4gICAgICBpZiAoIXVzZXIpIHtcbiAgICAgICAgY29udGludWU7XG4gICAgICB9XG4gICAgICBpZiAodXNlci5uYW1lKSB7XG4gICAgICAgIGVuY29kZWRPcHRpb25zICs9IGAmbmFtZT0ke2VuY29kZVVSSUNvbXBvbmVudCh1c2VyLm5hbWUpfWA7XG4gICAgICB9XG4gICAgICBpZiAodXNlci5lbWFpbCkge1xuICAgICAgICBlbmNvZGVkT3B0aW9ucyArPSBgJmVtYWlsPSR7ZW5jb2RlVVJJQ29tcG9uZW50KHVzZXIuZW1haWwpfWA7XG4gICAgICB9XG4gICAgfSBlbHNlIHtcbiAgICAgIGVuY29kZWRPcHRpb25zICs9IGAmJHtlbmNvZGVVUklDb21wb25lbnQoa2V5KX09JHtlbmNvZGVVUklDb21wb25lbnQoZGlhbG9nT3B0aW9uc1trZXldICl9YDtcbiAgICB9XG4gIH1cblxuICByZXR1cm4gYCR7ZW5kcG9pbnR9PyR7ZW5jb2RlZE9wdGlvbnN9YDtcbn1cblxuZXhwb3J0cy5nZXRFbnZlbG9wZUVuZHBvaW50V2l0aFVybEVuY29kZWRBdXRoID0gZ2V0RW52ZWxvcGVFbmRwb2ludFdpdGhVcmxFbmNvZGVkQXV0aDtcbmV4cG9ydHMuZ2V0UmVwb3J0RGlhbG9nRW5kcG9pbnQgPSBnZXRSZXBvcnREaWFsb2dFbmRwb2ludDtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWFwaS5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/api.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/asyncContext/index.js":
/*!**********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/asyncContext/index.js ***!
  \**********************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst carrier = __webpack_require__(/*! ../carrier.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/carrier.js\");\nconst stackStrategy = __webpack_require__(/*! ./stackStrategy.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/asyncContext/stackStrategy.js\");\n\n/**\n * @private Private API with no semver guarantees!\n *\n * Sets the global async context strategy\n */\nfunction setAsyncContextStrategy(strategy) {\n  // Get main carrier (global for every environment)\n  const registry = carrier.getMainCarrier();\n  const sentry = carrier.getSentryCarrier(registry);\n  sentry.acs = strategy;\n}\n\n/**\n * Get the current async context strategy.\n * If none has been setup, the default will be used.\n */\nfunction getAsyncContextStrategy(carrier$1) {\n  const sentry = carrier.getSentryCarrier(carrier$1);\n\n  if (sentry.acs) {\n    return sentry.acs;\n  }\n\n  // Otherwise, use the default one (stack)\n  return stackStrategy.getStackAsyncContextStrategy();\n}\n\nexports.getAsyncContextStrategy = getAsyncContextStrategy;\nexports.setAsyncContextStrategy = setAsyncContextStrategy;\n//# sourceMappingURL=index.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9hc3luY0NvbnRleHQvaW5kZXguanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsZ0JBQWdCLG1CQUFPLENBQUMsb0hBQWU7QUFDdkMsc0JBQXNCLG1CQUFPLENBQUMsNElBQW9COztBQUVsRDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBLCtCQUErQjtBQUMvQiwrQkFBK0I7QUFDL0IiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9hc3luY0NvbnRleHQvaW5kZXguanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGNhcnJpZXIgPSByZXF1aXJlKCcuLi9jYXJyaWVyLmpzJyk7XG5jb25zdCBzdGFja1N0cmF0ZWd5ID0gcmVxdWlyZSgnLi9zdGFja1N0cmF0ZWd5LmpzJyk7XG5cbi8qKlxuICogQHByaXZhdGUgUHJpdmF0ZSBBUEkgd2l0aCBubyBzZW12ZXIgZ3VhcmFudGVlcyFcbiAqXG4gKiBTZXRzIHRoZSBnbG9iYWwgYXN5bmMgY29udGV4dCBzdHJhdGVneVxuICovXG5mdW5jdGlvbiBzZXRBc3luY0NvbnRleHRTdHJhdGVneShzdHJhdGVneSkge1xuICAvLyBHZXQgbWFpbiBjYXJyaWVyIChnbG9iYWwgZm9yIGV2ZXJ5IGVudmlyb25tZW50KVxuICBjb25zdCByZWdpc3RyeSA9IGNhcnJpZXIuZ2V0TWFpbkNhcnJpZXIoKTtcbiAgY29uc3Qgc2VudHJ5ID0gY2Fycmllci5nZXRTZW50cnlDYXJyaWVyKHJlZ2lzdHJ5KTtcbiAgc2VudHJ5LmFjcyA9IHN0cmF0ZWd5O1xufVxuXG4vKipcbiAqIEdldCB0aGUgY3VycmVudCBhc3luYyBjb250ZXh0IHN0cmF0ZWd5LlxuICogSWYgbm9uZSBoYXMgYmVlbiBzZXR1cCwgdGhlIGRlZmF1bHQgd2lsbCBiZSB1c2VkLlxuICovXG5mdW5jdGlvbiBnZXRBc3luY0NvbnRleHRTdHJhdGVneShjYXJyaWVyJDEpIHtcbiAgY29uc3Qgc2VudHJ5ID0gY2Fycmllci5nZXRTZW50cnlDYXJyaWVyKGNhcnJpZXIkMSk7XG5cbiAgaWYgKHNlbnRyeS5hY3MpIHtcbiAgICByZXR1cm4gc2VudHJ5LmFjcztcbiAgfVxuXG4gIC8vIE90aGVyd2lzZSwgdXNlIHRoZSBkZWZhdWx0IG9uZSAoc3RhY2spXG4gIHJldHVybiBzdGFja1N0cmF0ZWd5LmdldFN0YWNrQXN5bmNDb250ZXh0U3RyYXRlZ3koKTtcbn1cblxuZXhwb3J0cy5nZXRBc3luY0NvbnRleHRTdHJhdGVneSA9IGdldEFzeW5jQ29udGV4dFN0cmF0ZWd5O1xuZXhwb3J0cy5zZXRBc3luY0NvbnRleHRTdHJhdGVneSA9IHNldEFzeW5jQ29udGV4dFN0cmF0ZWd5O1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9aW5kZXguanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/asyncContext/index.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/asyncContext/stackStrategy.js":
/*!******************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/asyncContext/stackStrategy.js ***!
  \******************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst defaultScopes = __webpack_require__(/*! ../defaultScopes.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/defaultScopes.js\");\nconst scope = __webpack_require__(/*! ../scope.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/scope.js\");\nconst is = __webpack_require__(/*! ../utils/is.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js\");\nconst carrier = __webpack_require__(/*! ../carrier.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/carrier.js\");\n\n/**\n * This is an object that holds a stack of scopes.\n */\nclass AsyncContextStack {\n\n   constructor(scope$1, isolationScope) {\n    let assignedScope;\n    if (!scope$1) {\n      assignedScope = new scope.Scope();\n    } else {\n      assignedScope = scope$1;\n    }\n\n    let assignedIsolationScope;\n    if (!isolationScope) {\n      assignedIsolationScope = new scope.Scope();\n    } else {\n      assignedIsolationScope = isolationScope;\n    }\n\n    // scope stack for domains or the process\n    this._stack = [{ scope: assignedScope }];\n    this._isolationScope = assignedIsolationScope;\n  }\n\n  /**\n   * Fork a scope for the stack.\n   */\n   withScope(callback) {\n    const scope = this._pushScope();\n\n    let maybePromiseResult;\n    try {\n      maybePromiseResult = callback(scope);\n    } catch (e) {\n      this._popScope();\n      throw e;\n    }\n\n    if (is.isThenable(maybePromiseResult)) {\n      // @ts-expect-error - isThenable returns the wrong type\n      return maybePromiseResult.then(\n        res => {\n          this._popScope();\n          return res;\n        },\n        e => {\n          this._popScope();\n          throw e;\n        },\n      );\n    }\n\n    this._popScope();\n    return maybePromiseResult;\n  }\n\n  /**\n   * Get the client of the stack.\n   */\n   getClient() {\n    return this.getStackTop().client ;\n  }\n\n  /**\n   * Returns the scope of the top stack.\n   */\n   getScope() {\n    return this.getStackTop().scope;\n  }\n\n  /**\n   * Get the isolation scope for the stack.\n   */\n   getIsolationScope() {\n    return this._isolationScope;\n  }\n\n  /**\n   * Returns the topmost scope layer in the order domain > local > process.\n   */\n   getStackTop() {\n    return this._stack[this._stack.length - 1] ;\n  }\n\n  /**\n   * Push a scope to the stack.\n   */\n   _pushScope() {\n    // We want to clone the content of prev scope\n    const scope = this.getScope().clone();\n    this._stack.push({\n      client: this.getClient(),\n      scope,\n    });\n    return scope;\n  }\n\n  /**\n   * Pop a scope from the stack.\n   */\n   _popScope() {\n    if (this._stack.length <= 1) return false;\n    return !!this._stack.pop();\n  }\n}\n\n/**\n * Get the global async context stack.\n * This will be removed during the v8 cycle and is only here to make migration easier.\n */\nfunction getAsyncContextStack() {\n  const registry = carrier.getMainCarrier();\n  const sentry = carrier.getSentryCarrier(registry);\n\n  return (sentry.stack = sentry.stack || new AsyncContextStack(defaultScopes.getDefaultCurrentScope(), defaultScopes.getDefaultIsolationScope()));\n}\n\nfunction withScope(callback) {\n  return getAsyncContextStack().withScope(callback);\n}\n\nfunction withSetScope(scope, callback) {\n  const stack = getAsyncContextStack() ;\n  return stack.withScope(() => {\n    stack.getStackTop().scope = scope;\n    return callback(scope);\n  });\n}\n\nfunction withIsolationScope(callback) {\n  return getAsyncContextStack().withScope(() => {\n    return callback(getAsyncContextStack().getIsolationScope());\n  });\n}\n\n/**\n * Get the stack-based async context strategy.\n */\nfunction getStackAsyncContextStrategy() {\n  return {\n    withIsolationScope,\n    withScope,\n    withSetScope,\n    withSetIsolationScope: (_isolationScope, callback) => {\n      return withIsolationScope(callback);\n    },\n    getCurrentScope: () => getAsyncContextStack().getScope(),\n    getIsolationScope: () => getAsyncContextStack().getIsolationScope(),\n  };\n}\n\nexports.AsyncContextStack = AsyncContextStack;\nexports.getStackAsyncContextStrategy = getStackAsyncContextStrategy;\n//# sourceMappingURL=stackStrategy.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9hc3luY0NvbnRleHQvc3RhY2tTdHJhdGVneS5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxzQkFBc0IsbUJBQU8sQ0FBQyxnSUFBcUI7QUFDbkQsY0FBYyxtQkFBTyxDQUFDLGdIQUFhO0FBQ25DLFdBQVcsbUJBQU8sQ0FBQyxzSEFBZ0I7QUFDbkMsZ0JBQWdCLG1CQUFPLENBQUMsb0hBQWU7O0FBRXZDO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsTUFBTTtBQUNOO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0EsTUFBTTtBQUNOO0FBQ0E7O0FBRUE7QUFDQSxxQkFBcUIsc0JBQXNCO0FBQzNDO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQSxNQUFNO0FBQ047QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFNBQVM7QUFDVDtBQUNBO0FBQ0E7QUFDQSxTQUFTO0FBQ1Q7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEtBQUs7QUFDTDtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEdBQUc7QUFDSDs7QUFFQTtBQUNBO0FBQ0E7QUFDQSxHQUFHO0FBQ0g7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxLQUFLO0FBQ0w7QUFDQTtBQUNBO0FBQ0E7O0FBRUEseUJBQXlCO0FBQ3pCLG9DQUFvQztBQUNwQyIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL2FzeW5jQ29udGV4dC9zdGFja1N0cmF0ZWd5LmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBkZWZhdWx0U2NvcGVzID0gcmVxdWlyZSgnLi4vZGVmYXVsdFNjb3Blcy5qcycpO1xuY29uc3Qgc2NvcGUgPSByZXF1aXJlKCcuLi9zY29wZS5qcycpO1xuY29uc3QgaXMgPSByZXF1aXJlKCcuLi91dGlscy9pcy5qcycpO1xuY29uc3QgY2FycmllciA9IHJlcXVpcmUoJy4uL2NhcnJpZXIuanMnKTtcblxuLyoqXG4gKiBUaGlzIGlzIGFuIG9iamVjdCB0aGF0IGhvbGRzIGEgc3RhY2sgb2Ygc2NvcGVzLlxuICovXG5jbGFzcyBBc3luY0NvbnRleHRTdGFjayB7XG5cbiAgIGNvbnN0cnVjdG9yKHNjb3BlJDEsIGlzb2xhdGlvblNjb3BlKSB7XG4gICAgbGV0IGFzc2lnbmVkU2NvcGU7XG4gICAgaWYgKCFzY29wZSQxKSB7XG4gICAgICBhc3NpZ25lZFNjb3BlID0gbmV3IHNjb3BlLlNjb3BlKCk7XG4gICAgfSBlbHNlIHtcbiAgICAgIGFzc2lnbmVkU2NvcGUgPSBzY29wZSQxO1xuICAgIH1cblxuICAgIGxldCBhc3NpZ25lZElzb2xhdGlvblNjb3BlO1xuICAgIGlmICghaXNvbGF0aW9uU2NvcGUpIHtcbiAgICAgIGFzc2lnbmVkSXNvbGF0aW9uU2NvcGUgPSBuZXcgc2NvcGUuU2NvcGUoKTtcbiAgICB9IGVsc2Uge1xuICAgICAgYXNzaWduZWRJc29sYXRpb25TY29wZSA9IGlzb2xhdGlvblNjb3BlO1xuICAgIH1cblxuICAgIC8vIHNjb3BlIHN0YWNrIGZvciBkb21haW5zIG9yIHRoZSBwcm9jZXNzXG4gICAgdGhpcy5fc3RhY2sgPSBbeyBzY29wZTogYXNzaWduZWRTY29wZSB9XTtcbiAgICB0aGlzLl9pc29sYXRpb25TY29wZSA9IGFzc2lnbmVkSXNvbGF0aW9uU2NvcGU7XG4gIH1cblxuICAvKipcbiAgICogRm9yayBhIHNjb3BlIGZvciB0aGUgc3RhY2suXG4gICAqL1xuICAgd2l0aFNjb3BlKGNhbGxiYWNrKSB7XG4gICAgY29uc3Qgc2NvcGUgPSB0aGlzLl9wdXNoU2NvcGUoKTtcblxuICAgIGxldCBtYXliZVByb21pc2VSZXN1bHQ7XG4gICAgdHJ5IHtcbiAgICAgIG1heWJlUHJvbWlzZVJlc3VsdCA9IGNhbGxiYWNrKHNjb3BlKTtcbiAgICB9IGNhdGNoIChlKSB7XG4gICAgICB0aGlzLl9wb3BTY29wZSgpO1xuICAgICAgdGhyb3cgZTtcbiAgICB9XG5cbiAgICBpZiAoaXMuaXNUaGVuYWJsZShtYXliZVByb21pc2VSZXN1bHQpKSB7XG4gICAgICAvLyBAdHMtZXhwZWN0LWVycm9yIC0gaXNUaGVuYWJsZSByZXR1cm5zIHRoZSB3cm9uZyB0eXBlXG4gICAgICByZXR1cm4gbWF5YmVQcm9taXNlUmVzdWx0LnRoZW4oXG4gICAgICAgIHJlcyA9PiB7XG4gICAgICAgICAgdGhpcy5fcG9wU2NvcGUoKTtcbiAgICAgICAgICByZXR1cm4gcmVzO1xuICAgICAgICB9LFxuICAgICAgICBlID0+IHtcbiAgICAgICAgICB0aGlzLl9wb3BTY29wZSgpO1xuICAgICAgICAgIHRocm93IGU7XG4gICAgICAgIH0sXG4gICAgICApO1xuICAgIH1cblxuICAgIHRoaXMuX3BvcFNjb3BlKCk7XG4gICAgcmV0dXJuIG1heWJlUHJvbWlzZVJlc3VsdDtcbiAgfVxuXG4gIC8qKlxuICAgKiBHZXQgdGhlIGNsaWVudCBvZiB0aGUgc3RhY2suXG4gICAqL1xuICAgZ2V0Q2xpZW50KCkge1xuICAgIHJldHVybiB0aGlzLmdldFN0YWNrVG9wKCkuY2xpZW50IDtcbiAgfVxuXG4gIC8qKlxuICAgKiBSZXR1cm5zIHRoZSBzY29wZSBvZiB0aGUgdG9wIHN0YWNrLlxuICAgKi9cbiAgIGdldFNjb3BlKCkge1xuICAgIHJldHVybiB0aGlzLmdldFN0YWNrVG9wKCkuc2NvcGU7XG4gIH1cblxuICAvKipcbiAgICogR2V0IHRoZSBpc29sYXRpb24gc2NvcGUgZm9yIHRoZSBzdGFjay5cbiAgICovXG4gICBnZXRJc29sYXRpb25TY29wZSgpIHtcbiAgICByZXR1cm4gdGhpcy5faXNvbGF0aW9uU2NvcGU7XG4gIH1cblxuICAvKipcbiAgICogUmV0dXJucyB0aGUgdG9wbW9zdCBzY29wZSBsYXllciBpbiB0aGUgb3JkZXIgZG9tYWluID4gbG9jYWwgPiBwcm9jZXNzLlxuICAgKi9cbiAgIGdldFN0YWNrVG9wKCkge1xuICAgIHJldHVybiB0aGlzLl9zdGFja1t0aGlzLl9zdGFjay5sZW5ndGggLSAxXSA7XG4gIH1cblxuICAvKipcbiAgICogUHVzaCBhIHNjb3BlIHRvIHRoZSBzdGFjay5cbiAgICovXG4gICBfcHVzaFNjb3BlKCkge1xuICAgIC8vIFdlIHdhbnQgdG8gY2xvbmUgdGhlIGNvbnRlbnQgb2YgcHJldiBzY29wZVxuICAgIGNvbnN0IHNjb3BlID0gdGhpcy5nZXRTY29wZSgpLmNsb25lKCk7XG4gICAgdGhpcy5fc3RhY2sucHVzaCh7XG4gICAgICBjbGllbnQ6IHRoaXMuZ2V0Q2xpZW50KCksXG4gICAgICBzY29wZSxcbiAgICB9KTtcbiAgICByZXR1cm4gc2NvcGU7XG4gIH1cblxuICAvKipcbiAgICogUG9wIGEgc2NvcGUgZnJvbSB0aGUgc3RhY2suXG4gICAqL1xuICAgX3BvcFNjb3BlKCkge1xuICAgIGlmICh0aGlzLl9zdGFjay5sZW5ndGggPD0gMSkgcmV0dXJuIGZhbHNlO1xuICAgIHJldHVybiAhIXRoaXMuX3N0YWNrLnBvcCgpO1xuICB9XG59XG5cbi8qKlxuICogR2V0IHRoZSBnbG9iYWwgYXN5bmMgY29udGV4dCBzdGFjay5cbiAqIFRoaXMgd2lsbCBiZSByZW1vdmVkIGR1cmluZyB0aGUgdjggY3ljbGUgYW5kIGlzIG9ubHkgaGVyZSB0byBtYWtlIG1pZ3JhdGlvbiBlYXNpZXIuXG4gKi9cbmZ1bmN0aW9uIGdldEFzeW5jQ29udGV4dFN0YWNrKCkge1xuICBjb25zdCByZWdpc3RyeSA9IGNhcnJpZXIuZ2V0TWFpbkNhcnJpZXIoKTtcbiAgY29uc3Qgc2VudHJ5ID0gY2Fycmllci5nZXRTZW50cnlDYXJyaWVyKHJlZ2lzdHJ5KTtcblxuICByZXR1cm4gKHNlbnRyeS5zdGFjayA9IHNlbnRyeS5zdGFjayB8fCBuZXcgQXN5bmNDb250ZXh0U3RhY2soZGVmYXVsdFNjb3Blcy5nZXREZWZhdWx0Q3VycmVudFNjb3BlKCksIGRlZmF1bHRTY29wZXMuZ2V0RGVmYXVsdElzb2xhdGlvblNjb3BlKCkpKTtcbn1cblxuZnVuY3Rpb24gd2l0aFNjb3BlKGNhbGxiYWNrKSB7XG4gIHJldHVybiBnZXRBc3luY0NvbnRleHRTdGFjaygpLndpdGhTY29wZShjYWxsYmFjayk7XG59XG5cbmZ1bmN0aW9uIHdpdGhTZXRTY29wZShzY29wZSwgY2FsbGJhY2spIHtcbiAgY29uc3Qgc3RhY2sgPSBnZXRBc3luY0NvbnRleHRTdGFjaygpIDtcbiAgcmV0dXJuIHN0YWNrLndpdGhTY29wZSgoKSA9PiB7XG4gICAgc3RhY2suZ2V0U3RhY2tUb3AoKS5zY29wZSA9IHNjb3BlO1xuICAgIHJldHVybiBjYWxsYmFjayhzY29wZSk7XG4gIH0pO1xufVxuXG5mdW5jdGlvbiB3aXRoSXNvbGF0aW9uU2NvcGUoY2FsbGJhY2spIHtcbiAgcmV0dXJuIGdldEFzeW5jQ29udGV4dFN0YWNrKCkud2l0aFNjb3BlKCgpID0+IHtcbiAgICByZXR1cm4gY2FsbGJhY2soZ2V0QXN5bmNDb250ZXh0U3RhY2soKS5nZXRJc29sYXRpb25TY29wZSgpKTtcbiAgfSk7XG59XG5cbi8qKlxuICogR2V0IHRoZSBzdGFjay1iYXNlZCBhc3luYyBjb250ZXh0IHN0cmF0ZWd5LlxuICovXG5mdW5jdGlvbiBnZXRTdGFja0FzeW5jQ29udGV4dFN0cmF0ZWd5KCkge1xuICByZXR1cm4ge1xuICAgIHdpdGhJc29sYXRpb25TY29wZSxcbiAgICB3aXRoU2NvcGUsXG4gICAgd2l0aFNldFNjb3BlLFxuICAgIHdpdGhTZXRJc29sYXRpb25TY29wZTogKF9pc29sYXRpb25TY29wZSwgY2FsbGJhY2spID0+IHtcbiAgICAgIHJldHVybiB3aXRoSXNvbGF0aW9uU2NvcGUoY2FsbGJhY2spO1xuICAgIH0sXG4gICAgZ2V0Q3VycmVudFNjb3BlOiAoKSA9PiBnZXRBc3luY0NvbnRleHRTdGFjaygpLmdldFNjb3BlKCksXG4gICAgZ2V0SXNvbGF0aW9uU2NvcGU6ICgpID0+IGdldEFzeW5jQ29udGV4dFN0YWNrKCkuZ2V0SXNvbGF0aW9uU2NvcGUoKSxcbiAgfTtcbn1cblxuZXhwb3J0cy5Bc3luY0NvbnRleHRTdGFjayA9IEFzeW5jQ29udGV4dFN0YWNrO1xuZXhwb3J0cy5nZXRTdGFja0FzeW5jQ29udGV4dFN0cmF0ZWd5ID0gZ2V0U3RhY2tBc3luY0NvbnRleHRTdHJhdGVneTtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPXN0YWNrU3RyYXRlZ3kuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/asyncContext/stackStrategy.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/breadcrumbs.js":
/*!***************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/breadcrumbs.js ***!
  \***************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst currentScopes = __webpack_require__(/*! ./currentScopes.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst debugLogger = __webpack_require__(/*! ./utils/debug-logger.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst time = __webpack_require__(/*! ./utils/time.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/time.js\");\n\n/**\n * Default maximum number of breadcrumbs added to an event. Can be overwritten\n * with {@link Options.maxBreadcrumbs}.\n */\nconst DEFAULT_BREADCRUMBS = 100;\n\n/**\n * Records a new breadcrumb which will be attached to future events.\n *\n * Breadcrumbs will be added to subsequent events to provide more context on\n * user's actions prior to an error or crash.\n */\nfunction addBreadcrumb(breadcrumb, hint) {\n  const client = currentScopes.getClient();\n  const isolationScope = currentScopes.getIsolationScope();\n\n  if (!client) return;\n\n  const { beforeBreadcrumb = null, maxBreadcrumbs = DEFAULT_BREADCRUMBS } = client.getOptions();\n\n  if (maxBreadcrumbs <= 0) return;\n\n  const timestamp = time.dateTimestampInSeconds();\n  const mergedBreadcrumb = { timestamp, ...breadcrumb };\n  const finalBreadcrumb = beforeBreadcrumb\n    ? (debugLogger.consoleSandbox(() => beforeBreadcrumb(mergedBreadcrumb, hint)) )\n    : mergedBreadcrumb;\n\n  if (finalBreadcrumb === null) return;\n\n  if (client.emit) {\n    client.emit('beforeAddBreadcrumb', finalBreadcrumb, hint);\n  }\n\n  isolationScope.addBreadcrumb(finalBreadcrumb, maxBreadcrumbs);\n}\n\nexports.addBreadcrumb = addBreadcrumb;\n//# sourceMappingURL=breadcrumbs.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9icmVhZGNydW1icy5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxzQkFBc0IsbUJBQU8sQ0FBQywrSEFBb0I7QUFDbEQsb0JBQW9CLG1CQUFPLENBQUMseUlBQXlCO0FBQ3JELGFBQWEsbUJBQU8sQ0FBQyx5SEFBaUI7O0FBRXRDO0FBQ0E7QUFDQSxTQUFTLDZCQUE2QjtBQUN0QztBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQSxVQUFVLGdFQUFnRTs7QUFFMUU7O0FBRUE7QUFDQSw2QkFBNkI7QUFDN0I7QUFDQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBLHFCQUFxQjtBQUNyQiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL2JyZWFkY3J1bWJzLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBjdXJyZW50U2NvcGVzID0gcmVxdWlyZSgnLi9jdXJyZW50U2NvcGVzLmpzJyk7XG5jb25zdCBkZWJ1Z0xvZ2dlciA9IHJlcXVpcmUoJy4vdXRpbHMvZGVidWctbG9nZ2VyLmpzJyk7XG5jb25zdCB0aW1lID0gcmVxdWlyZSgnLi91dGlscy90aW1lLmpzJyk7XG5cbi8qKlxuICogRGVmYXVsdCBtYXhpbXVtIG51bWJlciBvZiBicmVhZGNydW1icyBhZGRlZCB0byBhbiBldmVudC4gQ2FuIGJlIG92ZXJ3cml0dGVuXG4gKiB3aXRoIHtAbGluayBPcHRpb25zLm1heEJyZWFkY3J1bWJzfS5cbiAqL1xuY29uc3QgREVGQVVMVF9CUkVBRENSVU1CUyA9IDEwMDtcblxuLyoqXG4gKiBSZWNvcmRzIGEgbmV3IGJyZWFkY3J1bWIgd2hpY2ggd2lsbCBiZSBhdHRhY2hlZCB0byBmdXR1cmUgZXZlbnRzLlxuICpcbiAqIEJyZWFkY3J1bWJzIHdpbGwgYmUgYWRkZWQgdG8gc3Vic2VxdWVudCBldmVudHMgdG8gcHJvdmlkZSBtb3JlIGNvbnRleHQgb25cbiAqIHVzZXIncyBhY3Rpb25zIHByaW9yIHRvIGFuIGVycm9yIG9yIGNyYXNoLlxuICovXG5mdW5jdGlvbiBhZGRCcmVhZGNydW1iKGJyZWFkY3J1bWIsIGhpbnQpIHtcbiAgY29uc3QgY2xpZW50ID0gY3VycmVudFNjb3Blcy5nZXRDbGllbnQoKTtcbiAgY29uc3QgaXNvbGF0aW9uU2NvcGUgPSBjdXJyZW50U2NvcGVzLmdldElzb2xhdGlvblNjb3BlKCk7XG5cbiAgaWYgKCFjbGllbnQpIHJldHVybjtcblxuICBjb25zdCB7IGJlZm9yZUJyZWFkY3J1bWIgPSBudWxsLCBtYXhCcmVhZGNydW1icyA9IERFRkFVTFRfQlJFQURDUlVNQlMgfSA9IGNsaWVudC5nZXRPcHRpb25zKCk7XG5cbiAgaWYgKG1heEJyZWFkY3J1bWJzIDw9IDApIHJldHVybjtcblxuICBjb25zdCB0aW1lc3RhbXAgPSB0aW1lLmRhdGVUaW1lc3RhbXBJblNlY29uZHMoKTtcbiAgY29uc3QgbWVyZ2VkQnJlYWRjcnVtYiA9IHsgdGltZXN0YW1wLCAuLi5icmVhZGNydW1iIH07XG4gIGNvbnN0IGZpbmFsQnJlYWRjcnVtYiA9IGJlZm9yZUJyZWFkY3J1bWJcbiAgICA/IChkZWJ1Z0xvZ2dlci5jb25zb2xlU2FuZGJveCgoKSA9PiBiZWZvcmVCcmVhZGNydW1iKG1lcmdlZEJyZWFkY3J1bWIsIGhpbnQpKSApXG4gICAgOiBtZXJnZWRCcmVhZGNydW1iO1xuXG4gIGlmIChmaW5hbEJyZWFkY3J1bWIgPT09IG51bGwpIHJldHVybjtcblxuICBpZiAoY2xpZW50LmVtaXQpIHtcbiAgICBjbGllbnQuZW1pdCgnYmVmb3JlQWRkQnJlYWRjcnVtYicsIGZpbmFsQnJlYWRjcnVtYiwgaGludCk7XG4gIH1cblxuICBpc29sYXRpb25TY29wZS5hZGRCcmVhZGNydW1iKGZpbmFsQnJlYWRjcnVtYiwgbWF4QnJlYWRjcnVtYnMpO1xufVxuXG5leHBvcnRzLmFkZEJyZWFkY3J1bWIgPSBhZGRCcmVhZGNydW1iO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9YnJlYWRjcnVtYnMuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/breadcrumbs.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/carrier.js":
/*!***********************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/carrier.js ***!
  \***********************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst version = __webpack_require__(/*! ./utils/version.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/version.js\");\nconst worldwide = __webpack_require__(/*! ./utils/worldwide.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/worldwide.js\");\n\n/**\n * An object that contains globally accessible properties and maintains a scope stack.\n * @hidden\n */\n\n/**\n * Returns the global shim registry.\n *\n * FIXME: This function is problematic, because despite always returning a valid Carrier,\n * it has an optional `__SENTRY__` property, which then in turn requires us to always perform an unnecessary check\n * at the call-site. We always access the carrier through this function, so we can guarantee that `__SENTRY__` is there.\n **/\nfunction getMainCarrier() {\n  // This ensures a Sentry carrier exists\n  getSentryCarrier(worldwide.GLOBAL_OBJ);\n  return worldwide.GLOBAL_OBJ;\n}\n\n/** Will either get the existing sentry carrier, or create a new one. */\nfunction getSentryCarrier(carrier) {\n  const __SENTRY__ = (carrier.__SENTRY__ = carrier.__SENTRY__ || {});\n\n  // For now: First SDK that sets the .version property wins\n  __SENTRY__.version = __SENTRY__.version || version.SDK_VERSION;\n\n  // Intentionally populating and returning the version of \"this\" SDK instance\n  // rather than what's set in .version so that \"this\" SDK always gets its carrier\n  return (__SENTRY__[version.SDK_VERSION] = __SENTRY__[version.SDK_VERSION] || {});\n}\n\n/**\n * Returns a global singleton contained in the global `__SENTRY__[]` object.\n *\n * If the singleton doesn't already exist in `__SENTRY__`, it will be created using the given factory\n * function and added to the `__SENTRY__` object.\n *\n * @param name name of the global singleton on __SENTRY__\n * @param creator creator Factory function to create the singleton if it doesn't already exist on `__SENTRY__`\n * @param obj (Optional) The global object on which to look for `__SENTRY__`, if not `GLOBAL_OBJ`'s return value\n * @returns the singleton\n */\nfunction getGlobalSingleton(\n  name,\n  creator,\n  obj = worldwide.GLOBAL_OBJ,\n) {\n  const __SENTRY__ = (obj.__SENTRY__ = obj.__SENTRY__ || {});\n  const carrier = (__SENTRY__[version.SDK_VERSION] = __SENTRY__[version.SDK_VERSION] || {});\n  // Note: We do not want to set `carrier.version` here, as this may be called before any `init` is called, e.g. for the default scopes\n  return carrier[name] || (carrier[name] = creator());\n}\n\nexports.getGlobalSingleton = getGlobalSingleton;\nexports.getMainCarrier = getMainCarrier;\nexports.getSentryCarrier = getSentryCarrier;\n//# sourceMappingURL=carrier.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9jYXJyaWVyLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLGdCQUFnQixtQkFBTyxDQUFDLCtIQUFvQjtBQUM1QyxrQkFBa0IsbUJBQU8sQ0FBQyxtSUFBc0I7O0FBRWhEO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsbUVBQW1FOztBQUVuRTtBQUNBOztBQUVBO0FBQ0E7QUFDQSxpRkFBaUY7QUFDakY7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSwyREFBMkQ7QUFDM0QsMEZBQTBGO0FBQzFGO0FBQ0E7QUFDQTs7QUFFQSwwQkFBMEI7QUFDMUIsc0JBQXNCO0FBQ3RCLHdCQUF3QjtBQUN4QiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL2NhcnJpZXIuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IHZlcnNpb24gPSByZXF1aXJlKCcuL3V0aWxzL3ZlcnNpb24uanMnKTtcbmNvbnN0IHdvcmxkd2lkZSA9IHJlcXVpcmUoJy4vdXRpbHMvd29ybGR3aWRlLmpzJyk7XG5cbi8qKlxuICogQW4gb2JqZWN0IHRoYXQgY29udGFpbnMgZ2xvYmFsbHkgYWNjZXNzaWJsZSBwcm9wZXJ0aWVzIGFuZCBtYWludGFpbnMgYSBzY29wZSBzdGFjay5cbiAqIEBoaWRkZW5cbiAqL1xuXG4vKipcbiAqIFJldHVybnMgdGhlIGdsb2JhbCBzaGltIHJlZ2lzdHJ5LlxuICpcbiAqIEZJWE1FOiBUaGlzIGZ1bmN0aW9uIGlzIHByb2JsZW1hdGljLCBiZWNhdXNlIGRlc3BpdGUgYWx3YXlzIHJldHVybmluZyBhIHZhbGlkIENhcnJpZXIsXG4gKiBpdCBoYXMgYW4gb3B0aW9uYWwgYF9fU0VOVFJZX19gIHByb3BlcnR5LCB3aGljaCB0aGVuIGluIHR1cm4gcmVxdWlyZXMgdXMgdG8gYWx3YXlzIHBlcmZvcm0gYW4gdW5uZWNlc3NhcnkgY2hlY2tcbiAqIGF0IHRoZSBjYWxsLXNpdGUuIFdlIGFsd2F5cyBhY2Nlc3MgdGhlIGNhcnJpZXIgdGhyb3VnaCB0aGlzIGZ1bmN0aW9uLCBzbyB3ZSBjYW4gZ3VhcmFudGVlIHRoYXQgYF9fU0VOVFJZX19gIGlzIHRoZXJlLlxuICoqL1xuZnVuY3Rpb24gZ2V0TWFpbkNhcnJpZXIoKSB7XG4gIC8vIFRoaXMgZW5zdXJlcyBhIFNlbnRyeSBjYXJyaWVyIGV4aXN0c1xuICBnZXRTZW50cnlDYXJyaWVyKHdvcmxkd2lkZS5HTE9CQUxfT0JKKTtcbiAgcmV0dXJuIHdvcmxkd2lkZS5HTE9CQUxfT0JKO1xufVxuXG4vKiogV2lsbCBlaXRoZXIgZ2V0IHRoZSBleGlzdGluZyBzZW50cnkgY2Fycmllciwgb3IgY3JlYXRlIGEgbmV3IG9uZS4gKi9cbmZ1bmN0aW9uIGdldFNlbnRyeUNhcnJpZXIoY2Fycmllcikge1xuICBjb25zdCBfX1NFTlRSWV9fID0gKGNhcnJpZXIuX19TRU5UUllfXyA9IGNhcnJpZXIuX19TRU5UUllfXyB8fCB7fSk7XG5cbiAgLy8gRm9yIG5vdzogRmlyc3QgU0RLIHRoYXQgc2V0cyB0aGUgLnZlcnNpb24gcHJvcGVydHkgd2luc1xuICBfX1NFTlRSWV9fLnZlcnNpb24gPSBfX1NFTlRSWV9fLnZlcnNpb24gfHwgdmVyc2lvbi5TREtfVkVSU0lPTjtcblxuICAvLyBJbnRlbnRpb25hbGx5IHBvcHVsYXRpbmcgYW5kIHJldHVybmluZyB0aGUgdmVyc2lvbiBvZiBcInRoaXNcIiBTREsgaW5zdGFuY2VcbiAgLy8gcmF0aGVyIHRoYW4gd2hhdCdzIHNldCBpbiAudmVyc2lvbiBzbyB0aGF0IFwidGhpc1wiIFNESyBhbHdheXMgZ2V0cyBpdHMgY2FycmllclxuICByZXR1cm4gKF9fU0VOVFJZX19bdmVyc2lvbi5TREtfVkVSU0lPTl0gPSBfX1NFTlRSWV9fW3ZlcnNpb24uU0RLX1ZFUlNJT05dIHx8IHt9KTtcbn1cblxuLyoqXG4gKiBSZXR1cm5zIGEgZ2xvYmFsIHNpbmdsZXRvbiBjb250YWluZWQgaW4gdGhlIGdsb2JhbCBgX19TRU5UUllfX1tdYCBvYmplY3QuXG4gKlxuICogSWYgdGhlIHNpbmdsZXRvbiBkb2Vzbid0IGFscmVhZHkgZXhpc3QgaW4gYF9fU0VOVFJZX19gLCBpdCB3aWxsIGJlIGNyZWF0ZWQgdXNpbmcgdGhlIGdpdmVuIGZhY3RvcnlcbiAqIGZ1bmN0aW9uIGFuZCBhZGRlZCB0byB0aGUgYF9fU0VOVFJZX19gIG9iamVjdC5cbiAqXG4gKiBAcGFyYW0gbmFtZSBuYW1lIG9mIHRoZSBnbG9iYWwgc2luZ2xldG9uIG9uIF9fU0VOVFJZX19cbiAqIEBwYXJhbSBjcmVhdG9yIGNyZWF0b3IgRmFjdG9yeSBmdW5jdGlvbiB0byBjcmVhdGUgdGhlIHNpbmdsZXRvbiBpZiBpdCBkb2Vzbid0IGFscmVhZHkgZXhpc3Qgb24gYF9fU0VOVFJZX19gXG4gKiBAcGFyYW0gb2JqIChPcHRpb25hbCkgVGhlIGdsb2JhbCBvYmplY3Qgb24gd2hpY2ggdG8gbG9vayBmb3IgYF9fU0VOVFJZX19gLCBpZiBub3QgYEdMT0JBTF9PQkpgJ3MgcmV0dXJuIHZhbHVlXG4gKiBAcmV0dXJucyB0aGUgc2luZ2xldG9uXG4gKi9cbmZ1bmN0aW9uIGdldEdsb2JhbFNpbmdsZXRvbihcbiAgbmFtZSxcbiAgY3JlYXRvcixcbiAgb2JqID0gd29ybGR3aWRlLkdMT0JBTF9PQkosXG4pIHtcbiAgY29uc3QgX19TRU5UUllfXyA9IChvYmouX19TRU5UUllfXyA9IG9iai5fX1NFTlRSWV9fIHx8IHt9KTtcbiAgY29uc3QgY2FycmllciA9IChfX1NFTlRSWV9fW3ZlcnNpb24uU0RLX1ZFUlNJT05dID0gX19TRU5UUllfX1t2ZXJzaW9uLlNES19WRVJTSU9OXSB8fCB7fSk7XG4gIC8vIE5vdGU6IFdlIGRvIG5vdCB3YW50IHRvIHNldCBgY2Fycmllci52ZXJzaW9uYCBoZXJlLCBhcyB0aGlzIG1heSBiZSBjYWxsZWQgYmVmb3JlIGFueSBgaW5pdGAgaXMgY2FsbGVkLCBlLmcuIGZvciB0aGUgZGVmYXVsdCBzY29wZXNcbiAgcmV0dXJuIGNhcnJpZXJbbmFtZV0gfHwgKGNhcnJpZXJbbmFtZV0gPSBjcmVhdG9yKCkpO1xufVxuXG5leHBvcnRzLmdldEdsb2JhbFNpbmdsZXRvbiA9IGdldEdsb2JhbFNpbmdsZXRvbjtcbmV4cG9ydHMuZ2V0TWFpbkNhcnJpZXIgPSBnZXRNYWluQ2FycmllcjtcbmV4cG9ydHMuZ2V0U2VudHJ5Q2FycmllciA9IGdldFNlbnRyeUNhcnJpZXI7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1jYXJyaWVyLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/carrier.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/checkin.js":
/*!***********************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/checkin.js ***!
  \***********************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst dsn = __webpack_require__(/*! ./utils/dsn.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/dsn.js\");\nconst envelope = __webpack_require__(/*! ./utils/envelope.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/envelope.js\");\n\n/**\n * Create envelope from check in item.\n */\nfunction createCheckInEnvelope(\n  checkIn,\n  dynamicSamplingContext,\n  metadata,\n  tunnel,\n  dsn$1,\n) {\n  const headers = {\n    sent_at: new Date().toISOString(),\n  };\n\n  if (metadata?.sdk) {\n    headers.sdk = {\n      name: metadata.sdk.name,\n      version: metadata.sdk.version,\n    };\n  }\n\n  if (!!tunnel && !!dsn$1) {\n    headers.dsn = dsn.dsnToString(dsn$1);\n  }\n\n  if (dynamicSamplingContext) {\n    headers.trace = dynamicSamplingContext ;\n  }\n\n  const item = createCheckInEnvelopeItem(checkIn);\n  return envelope.createEnvelope(headers, [item]);\n}\n\nfunction createCheckInEnvelopeItem(checkIn) {\n  const checkInHeaders = {\n    type: 'check_in',\n  };\n  return [checkInHeaders, checkIn];\n}\n\nexports.createCheckInEnvelope = createCheckInEnvelope;\n//# sourceMappingURL=checkin.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9jaGVja2luLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLFlBQVksbUJBQU8sQ0FBQyx1SEFBZ0I7QUFDcEMsaUJBQWlCLG1CQUFPLENBQUMsaUlBQXFCOztBQUU5QztBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLDZCQUE2QjtBQUM3QiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL2NoZWNraW4uanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGRzbiA9IHJlcXVpcmUoJy4vdXRpbHMvZHNuLmpzJyk7XG5jb25zdCBlbnZlbG9wZSA9IHJlcXVpcmUoJy4vdXRpbHMvZW52ZWxvcGUuanMnKTtcblxuLyoqXG4gKiBDcmVhdGUgZW52ZWxvcGUgZnJvbSBjaGVjayBpbiBpdGVtLlxuICovXG5mdW5jdGlvbiBjcmVhdGVDaGVja0luRW52ZWxvcGUoXG4gIGNoZWNrSW4sXG4gIGR5bmFtaWNTYW1wbGluZ0NvbnRleHQsXG4gIG1ldGFkYXRhLFxuICB0dW5uZWwsXG4gIGRzbiQxLFxuKSB7XG4gIGNvbnN0IGhlYWRlcnMgPSB7XG4gICAgc2VudF9hdDogbmV3IERhdGUoKS50b0lTT1N0cmluZygpLFxuICB9O1xuXG4gIGlmIChtZXRhZGF0YT8uc2RrKSB7XG4gICAgaGVhZGVycy5zZGsgPSB7XG4gICAgICBuYW1lOiBtZXRhZGF0YS5zZGsubmFtZSxcbiAgICAgIHZlcnNpb246IG1ldGFkYXRhLnNkay52ZXJzaW9uLFxuICAgIH07XG4gIH1cblxuICBpZiAoISF0dW5uZWwgJiYgISFkc24kMSkge1xuICAgIGhlYWRlcnMuZHNuID0gZHNuLmRzblRvU3RyaW5nKGRzbiQxKTtcbiAgfVxuXG4gIGlmIChkeW5hbWljU2FtcGxpbmdDb250ZXh0KSB7XG4gICAgaGVhZGVycy50cmFjZSA9IGR5bmFtaWNTYW1wbGluZ0NvbnRleHQgO1xuICB9XG5cbiAgY29uc3QgaXRlbSA9IGNyZWF0ZUNoZWNrSW5FbnZlbG9wZUl0ZW0oY2hlY2tJbik7XG4gIHJldHVybiBlbnZlbG9wZS5jcmVhdGVFbnZlbG9wZShoZWFkZXJzLCBbaXRlbV0pO1xufVxuXG5mdW5jdGlvbiBjcmVhdGVDaGVja0luRW52ZWxvcGVJdGVtKGNoZWNrSW4pIHtcbiAgY29uc3QgY2hlY2tJbkhlYWRlcnMgPSB7XG4gICAgdHlwZTogJ2NoZWNrX2luJyxcbiAgfTtcbiAgcmV0dXJuIFtjaGVja0luSGVhZGVycywgY2hlY2tJbl07XG59XG5cbmV4cG9ydHMuY3JlYXRlQ2hlY2tJbkVudmVsb3BlID0gY3JlYXRlQ2hlY2tJbkVudmVsb3BlO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9Y2hlY2tpbi5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/checkin.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/client.js":
/*!**********************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/client.js ***!
  \**********************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst api = __webpack_require__(/*! ./api.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/api.js\");\nconst constants = __webpack_require__(/*! ./constants.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/constants.js\");\nconst currentScopes = __webpack_require__(/*! ./currentScopes.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst debugBuild = __webpack_require__(/*! ./debug-build.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst envelope = __webpack_require__(/*! ./envelope.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/envelope.js\");\nconst integration = __webpack_require__(/*! ./integration.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integration.js\");\nconst session = __webpack_require__(/*! ./session.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/session.js\");\nconst dynamicSamplingContext = __webpack_require__(/*! ./tracing/dynamicSamplingContext.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/dynamicSamplingContext.js\");\nconst clientreport = __webpack_require__(/*! ./utils/clientreport.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/clientreport.js\");\nconst debugLogger = __webpack_require__(/*! ./utils/debug-logger.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst dsn = __webpack_require__(/*! ./utils/dsn.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/dsn.js\");\nconst envelope$1 = __webpack_require__(/*! ./utils/envelope.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/envelope.js\");\nconst eventUtils = __webpack_require__(/*! ./utils/eventUtils.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/eventUtils.js\");\nconst is = __webpack_require__(/*! ./utils/is.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js\");\nconst merge = __webpack_require__(/*! ./utils/merge.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/merge.js\");\nconst misc = __webpack_require__(/*! ./utils/misc.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/misc.js\");\nconst parseSampleRate = __webpack_require__(/*! ./utils/parseSampleRate.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/parseSampleRate.js\");\nconst prepareEvent = __webpack_require__(/*! ./utils/prepareEvent.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/prepareEvent.js\");\nconst spanUtils = __webpack_require__(/*! ./utils/spanUtils.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanUtils.js\");\nconst syncpromise = __webpack_require__(/*! ./utils/syncpromise.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/syncpromise.js\");\nconst transactionEvent = __webpack_require__(/*! ./utils/transactionEvent.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/transactionEvent.js\");\n\n/* eslint-disable max-lines */\n\nconst ALREADY_SEEN_ERROR = \"Not capturing exception because it's already been captured.\";\nconst MISSING_RELEASE_FOR_SESSION_ERROR = 'Discarded session because of missing or non-string release';\n\nconst INTERNAL_ERROR_SYMBOL = Symbol.for('SentryInternalError');\nconst DO_NOT_SEND_EVENT_SYMBOL = Symbol.for('SentryDoNotSendEventError');\n\nfunction _makeInternalError(message) {\n  return {\n    message,\n    [INTERNAL_ERROR_SYMBOL]: true,\n  };\n}\n\nfunction _makeDoNotSendEventError(message) {\n  return {\n    message,\n    [DO_NOT_SEND_EVENT_SYMBOL]: true,\n  };\n}\n\nfunction _isInternalError(error) {\n  return !!error && typeof error === 'object' && INTERNAL_ERROR_SYMBOL in error;\n}\n\nfunction _isDoNotSendEventError(error) {\n  return !!error && typeof error === 'object' && DO_NOT_SEND_EVENT_SYMBOL in error;\n}\n\n/**\n * Base implementation for all JavaScript SDK clients.\n *\n * Call the constructor with the corresponding options\n * specific to the client subclass. To access these options later, use\n * {@link Client.getOptions}.\n *\n * If a Dsn is specified in the options, it will be parsed and stored. Use\n * {@link Client.getDsn} to retrieve the Dsn at any moment. In case the Dsn is\n * invalid, the constructor will throw a {@link SentryException}. Note that\n * without a valid Dsn, the SDK will not send any events to Sentry.\n *\n * Before sending an event, it is passed through\n * {@link Client._prepareEvent} to add SDK information and scope data\n * (breadcrumbs and context). To add more custom information, override this\n * method and extend the resulting prepared event.\n *\n * To issue automatically created events (e.g. via instrumentation), use\n * {@link Client.captureEvent}. It will prepare the event and pass it through\n * the callback lifecycle. To issue auto-breadcrumbs, use\n * {@link Client.addBreadcrumb}.\n *\n * @example\n * class NodeClient extends Client<NodeOptions> {\n *   public constructor(options: NodeOptions) {\n *     super(options);\n *   }\n *\n *   // ...\n * }\n */\nclass Client {\n  /** Options passed to the SDK. */\n\n  /** The client Dsn, if specified in options. Without this Dsn, the SDK will be disabled. */\n\n  /** Array of set up integrations. */\n\n  /** Number of calls being processed */\n\n  /** Holds flushable  */\n\n  // eslint-disable-next-line @typescript-eslint/ban-types\n\n  /**\n   * Initializes this client instance.\n   *\n   * @param options Options for the client.\n   */\n   constructor(options) {\n    this._options = options;\n    this._integrations = {};\n    this._numProcessing = 0;\n    this._outcomes = {};\n    this._hooks = {};\n    this._eventProcessors = [];\n\n    if (options.dsn) {\n      this._dsn = dsn.makeDsn(options.dsn);\n    } else {\n      debugBuild.DEBUG_BUILD && debugLogger.debug.warn('No DSN provided, client will not send events.');\n    }\n\n    if (this._dsn) {\n      const url = api.getEnvelopeEndpointWithUrlEncodedAuth(\n        this._dsn,\n        options.tunnel,\n        options._metadata ? options._metadata.sdk : undefined,\n      );\n      this._transport = options.transport({\n        tunnel: this._options.tunnel,\n        recordDroppedEvent: this.recordDroppedEvent.bind(this),\n        ...options.transportOptions,\n        url,\n      });\n    }\n  }\n\n  /**\n   * Captures an exception event and sends it to Sentry.\n   *\n   * Unlike `captureException` exported from every SDK, this method requires that you pass it the current scope.\n   */\n   captureException(exception, hint, scope) {\n    const eventId = misc.uuid4();\n\n    // ensure we haven't captured this very object before\n    if (misc.checkOrSetAlreadyCaught(exception)) {\n      debugBuild.DEBUG_BUILD && debugLogger.debug.log(ALREADY_SEEN_ERROR);\n      return eventId;\n    }\n\n    const hintWithEventId = {\n      event_id: eventId,\n      ...hint,\n    };\n\n    this._process(\n      this.eventFromException(exception, hintWithEventId).then(event =>\n        this._captureEvent(event, hintWithEventId, scope),\n      ),\n    );\n\n    return hintWithEventId.event_id;\n  }\n\n  /**\n   * Captures a message event and sends it to Sentry.\n   *\n   * Unlike `captureMessage` exported from every SDK, this method requires that you pass it the current scope.\n   */\n   captureMessage(\n    message,\n    level,\n    hint,\n    currentScope,\n  ) {\n    const hintWithEventId = {\n      event_id: misc.uuid4(),\n      ...hint,\n    };\n\n    const eventMessage = is.isParameterizedString(message) ? message : String(message);\n\n    const promisedEvent = is.isPrimitive(message)\n      ? this.eventFromMessage(eventMessage, level, hintWithEventId)\n      : this.eventFromException(message, hintWithEventId);\n\n    this._process(promisedEvent.then(event => this._captureEvent(event, hintWithEventId, currentScope)));\n\n    return hintWithEventId.event_id;\n  }\n\n  /**\n   * Captures a manually created event and sends it to Sentry.\n   *\n   * Unlike `captureEvent` exported from every SDK, this method requires that you pass it the current scope.\n   */\n   captureEvent(event, hint, currentScope) {\n    const eventId = misc.uuid4();\n\n    // ensure we haven't captured this very object before\n    if (hint?.originalException && misc.checkOrSetAlreadyCaught(hint.originalException)) {\n      debugBuild.DEBUG_BUILD && debugLogger.debug.log(ALREADY_SEEN_ERROR);\n      return eventId;\n    }\n\n    const hintWithEventId = {\n      event_id: eventId,\n      ...hint,\n    };\n\n    const sdkProcessingMetadata = event.sdkProcessingMetadata || {};\n    const capturedSpanScope = sdkProcessingMetadata.capturedSpanScope;\n    const capturedSpanIsolationScope = sdkProcessingMetadata.capturedSpanIsolationScope;\n\n    this._process(\n      this._captureEvent(event, hintWithEventId, capturedSpanScope || currentScope, capturedSpanIsolationScope),\n    );\n\n    return hintWithEventId.event_id;\n  }\n\n  /**\n   * Captures a session.\n   */\n   captureSession(session$1) {\n    this.sendSession(session$1);\n    // After sending, we set init false to indicate it's not the first occurrence\n    session.updateSession(session$1, { init: false });\n  }\n\n  /**\n   * Create a cron monitor check in and send it to Sentry. This method is not available on all clients.\n   *\n   * @param checkIn An object that describes a check in.\n   * @param upsertMonitorConfig An optional object that describes a monitor config. Use this if you want\n   * to create a monitor automatically when sending a check in.\n   * @param scope An optional scope containing event metadata.\n   * @returns A string representing the id of the check in.\n   */\n\n  /**\n   * Get the current Dsn.\n   */\n   getDsn() {\n    return this._dsn;\n  }\n\n  /**\n   * Get the current options.\n   */\n   getOptions() {\n    return this._options;\n  }\n\n  /**\n   * Get the SDK metadata.\n   * @see SdkMetadata\n   */\n   getSdkMetadata() {\n    return this._options._metadata;\n  }\n\n  /**\n   * Returns the transport that is used by the client.\n   * Please note that the transport gets lazy initialized so it will only be there once the first event has been sent.\n   */\n   getTransport() {\n    return this._transport;\n  }\n\n  /**\n   * Wait for all events to be sent or the timeout to expire, whichever comes first.\n   *\n   * @param timeout Maximum time in ms the client should wait for events to be flushed. Omitting this parameter will\n   *   cause the client to wait until all events are sent before resolving the promise.\n   * @returns A promise that will resolve with `true` if all events are sent before the timeout, or `false` if there are\n   * still events in the queue when the timeout is reached.\n   */\n   flush(timeout) {\n    const transport = this._transport;\n    if (transport) {\n      this.emit('flush');\n      return this._isClientDoneProcessing(timeout).then(clientFinished => {\n        return transport.flush(timeout).then(transportFlushed => clientFinished && transportFlushed);\n      });\n    } else {\n      return syncpromise.resolvedSyncPromise(true);\n    }\n  }\n\n  /**\n   * Flush the event queue and set the client to `enabled = false`. See {@link Client.flush}.\n   *\n   * @param {number} timeout Maximum time in ms the client should wait before shutting down. Omitting this parameter will cause\n   *   the client to wait until all events are sent before disabling itself.\n   * @returns {Promise<boolean>} A promise which resolves to `true` if the flush completes successfully before the timeout, or `false` if\n   * it doesn't.\n   */\n   close(timeout) {\n    return this.flush(timeout).then(result => {\n      this.getOptions().enabled = false;\n      this.emit('close');\n      return result;\n    });\n  }\n\n  /**\n   * Get all installed event processors.\n   */\n   getEventProcessors() {\n    return this._eventProcessors;\n  }\n\n  /**\n   * Adds an event processor that applies to any event processed by this client.\n   */\n   addEventProcessor(eventProcessor) {\n    this._eventProcessors.push(eventProcessor);\n  }\n\n  /**\n   * Initialize this client.\n   * Call this after the client was set on a scope.\n   */\n   init() {\n    if (\n      this._isEnabled() ||\n      // Force integrations to be setup even if no DSN was set when we have\n      // Spotlight enabled. This is particularly important for browser as we\n      // don't support the `spotlight` option there and rely on the users\n      // adding the `spotlightBrowserIntegration()` to their integrations which\n      // wouldn't get initialized with the check below when there's no DSN set.\n      this._options.integrations.some(({ name }) => name.startsWith('Spotlight'))\n    ) {\n      this._setupIntegrations();\n    }\n  }\n\n  /**\n   * Gets an installed integration by its name.\n   *\n   * @returns {Integration|undefined} The installed integration or `undefined` if no integration with that `name` was installed.\n   */\n   getIntegrationByName(integrationName) {\n    return this._integrations[integrationName] ;\n  }\n\n  /**\n   * Add an integration to the client.\n   * This can be used to e.g. lazy load integrations.\n   * In most cases, this should not be necessary,\n   * and you're better off just passing the integrations via `integrations: []` at initialization time.\n   * However, if you find the need to conditionally load & add an integration, you can use `addIntegration` to do so.\n   */\n   addIntegration(integration$1) {\n    const isAlreadyInstalled = this._integrations[integration$1.name];\n\n    // This hook takes care of only installing if not already installed\n    integration.setupIntegration(this, integration$1, this._integrations);\n    // Here we need to check manually to make sure to not run this multiple times\n    if (!isAlreadyInstalled) {\n      integration.afterSetupIntegrations(this, [integration$1]);\n    }\n  }\n\n  /**\n   * Send a fully prepared event to Sentry.\n   */\n   sendEvent(event, hint = {}) {\n    this.emit('beforeSendEvent', event, hint);\n\n    let env = envelope.createEventEnvelope(event, this._dsn, this._options._metadata, this._options.tunnel);\n\n    for (const attachment of hint.attachments || []) {\n      env = envelope$1.addItemToEnvelope(env, envelope$1.createAttachmentEnvelopeItem(attachment));\n    }\n\n    const promise = this.sendEnvelope(env);\n    if (promise) {\n      promise.then(sendResponse => this.emit('afterSendEvent', event, sendResponse), null);\n    }\n  }\n\n  /**\n   * Send a session or session aggregrates to Sentry.\n   */\n   sendSession(session) {\n    // Backfill release and environment on session\n    const { release: clientReleaseOption, environment: clientEnvironmentOption = constants.DEFAULT_ENVIRONMENT } = this._options;\n    if ('aggregates' in session) {\n      const sessionAttrs = session.attrs || {};\n      if (!sessionAttrs.release && !clientReleaseOption) {\n        debugBuild.DEBUG_BUILD && debugLogger.debug.warn(MISSING_RELEASE_FOR_SESSION_ERROR);\n        return;\n      }\n      sessionAttrs.release = sessionAttrs.release || clientReleaseOption;\n      sessionAttrs.environment = sessionAttrs.environment || clientEnvironmentOption;\n      session.attrs = sessionAttrs;\n    } else {\n      if (!session.release && !clientReleaseOption) {\n        debugBuild.DEBUG_BUILD && debugLogger.debug.warn(MISSING_RELEASE_FOR_SESSION_ERROR);\n        return;\n      }\n      session.release = session.release || clientReleaseOption;\n      session.environment = session.environment || clientEnvironmentOption;\n    }\n\n    this.emit('beforeSendSession', session);\n\n    const env = envelope.createSessionEnvelope(session, this._dsn, this._options._metadata, this._options.tunnel);\n\n    // sendEnvelope should not throw\n    // eslint-disable-next-line @typescript-eslint/no-floating-promises\n    this.sendEnvelope(env);\n  }\n\n  /**\n   * Record on the client that an event got dropped (ie, an event that will not be sent to Sentry).\n   */\n   recordDroppedEvent(reason, category, count = 1) {\n    if (this._options.sendClientReports) {\n      // We want to track each category (error, transaction, session, replay_event) separately\n      // but still keep the distinction between different type of outcomes.\n      // We could use nested maps, but it's much easier to read and type this way.\n      // A correct type for map-based implementation if we want to go that route\n      // would be `Partial<Record<SentryRequestType, Partial<Record<Outcome, number>>>>`\n      // With typescript 4.1 we could even use template literal types\n      const key = `${reason}:${category}`;\n      debugBuild.DEBUG_BUILD && debugLogger.debug.log(`Recording outcome: \"${key}\"${count > 1 ? ` (${count} times)` : ''}`);\n      this._outcomes[key] = (this._outcomes[key] || 0) + count;\n    }\n  }\n\n  /* eslint-disable @typescript-eslint/unified-signatures */\n  /**\n   * Register a callback for whenever a span is started.\n   * Receives the span as argument.\n   * @returns {() => void} A function that, when executed, removes the registered callback.\n   */\n\n  /**\n   * Register a hook on this client.\n   */\n   on(hook, callback) {\n    const hooks = (this._hooks[hook] = this._hooks[hook] || []);\n\n    // @ts-expect-error We assume the types are correct\n    hooks.push(callback);\n\n    // This function returns a callback execution handler that, when invoked,\n    // deregisters a callback. This is crucial for managing instances where callbacks\n    // need to be unregistered to prevent self-referencing in callback closures,\n    // ensuring proper garbage collection.\n    return () => {\n      // @ts-expect-error We assume the types are correct\n      const cbIndex = hooks.indexOf(callback);\n      if (cbIndex > -1) {\n        hooks.splice(cbIndex, 1);\n      }\n    };\n  }\n\n  /** Fire a hook whenever a span starts. */\n\n  /**\n   * Emit a hook that was previously registered via `on()`.\n   */\n   emit(hook, ...rest) {\n    const callbacks = this._hooks[hook];\n    if (callbacks) {\n      callbacks.forEach(callback => callback(...rest));\n    }\n  }\n\n  /**\n   * Send an envelope to Sentry.\n   */\n   sendEnvelope(envelope) {\n    this.emit('beforeEnvelope', envelope);\n\n    if (this._isEnabled() && this._transport) {\n      return this._transport.send(envelope).then(null, reason => {\n        debugBuild.DEBUG_BUILD && debugLogger.debug.error('Error while sending envelope:', reason);\n        return reason;\n      });\n    }\n\n    debugBuild.DEBUG_BUILD && debugLogger.debug.error('Transport disabled');\n\n    return syncpromise.resolvedSyncPromise({});\n  }\n\n  /* eslint-enable @typescript-eslint/unified-signatures */\n\n  /** Setup integrations for this client. */\n   _setupIntegrations() {\n    const { integrations } = this._options;\n    this._integrations = integration.setupIntegrations(this, integrations);\n    integration.afterSetupIntegrations(this, integrations);\n  }\n\n  /** Updates existing session based on the provided event */\n   _updateSessionFromEvent(session$1, event) {\n    let crashed = event.level === 'fatal';\n    let errored = false;\n    const exceptions = event.exception?.values;\n\n    if (exceptions) {\n      errored = true;\n\n      for (const ex of exceptions) {\n        const mechanism = ex.mechanism;\n        if (mechanism?.handled === false) {\n          crashed = true;\n          break;\n        }\n      }\n    }\n\n    // A session is updated and that session update is sent in only one of the two following scenarios:\n    // 1. Session with non terminal status and 0 errors + an error occurred -> Will set error count to 1 and send update\n    // 2. Session with non terminal status and 1 error + a crash occurred -> Will set status crashed and send update\n    const sessionNonTerminal = session$1.status === 'ok';\n    const shouldUpdateAndSend = (sessionNonTerminal && session$1.errors === 0) || (sessionNonTerminal && crashed);\n\n    if (shouldUpdateAndSend) {\n      session.updateSession(session$1, {\n        ...(crashed && { status: 'crashed' }),\n        errors: session$1.errors || Number(errored || crashed),\n      });\n      this.captureSession(session$1);\n    }\n  }\n\n  /**\n   * Determine if the client is finished processing. Returns a promise because it will wait `timeout` ms before saying\n   * \"no\" (resolving to `false`) in order to give the client a chance to potentially finish first.\n   *\n   * @param timeout The time, in ms, after which to resolve to `false` if the client is still busy. Passing `0` (or not\n   * passing anything) will make the promise wait as long as it takes for processing to finish before resolving to\n   * `true`.\n   * @returns A promise which will resolve to `true` if processing is already done or finishes before the timeout, and\n   * `false` otherwise\n   */\n   _isClientDoneProcessing(timeout) {\n    return new syncpromise.SyncPromise(resolve => {\n      let ticked = 0;\n      const tick = 1;\n\n      const interval = setInterval(() => {\n        if (this._numProcessing == 0) {\n          clearInterval(interval);\n          resolve(true);\n        } else {\n          ticked += tick;\n          if (timeout && ticked >= timeout) {\n            clearInterval(interval);\n            resolve(false);\n          }\n        }\n      }, tick);\n    });\n  }\n\n  /** Determines whether this SDK is enabled and a transport is present. */\n   _isEnabled() {\n    return this.getOptions().enabled !== false && this._transport !== undefined;\n  }\n\n  /**\n   * Adds common information to events.\n   *\n   * The information includes release and environment from `options`,\n   * breadcrumbs and context (extra, tags and user) from the scope.\n   *\n   * Information that is already present in the event is never overwritten. For\n   * nested objects, such as the context, keys are merged.\n   *\n   * @param event The original event.\n   * @param hint May contain additional information about the original exception.\n   * @param currentScope A scope containing event metadata.\n   * @returns A new event with more information.\n   */\n   _prepareEvent(\n    event,\n    hint,\n    currentScope,\n    isolationScope,\n  ) {\n    const options = this.getOptions();\n    const integrations = Object.keys(this._integrations);\n    if (!hint.integrations && integrations?.length) {\n      hint.integrations = integrations;\n    }\n\n    this.emit('preprocessEvent', event, hint);\n\n    if (!event.type) {\n      isolationScope.setLastEventId(event.event_id || hint.event_id);\n    }\n\n    return prepareEvent.prepareEvent(options, event, hint, currentScope, this, isolationScope).then(evt => {\n      if (evt === null) {\n        return evt;\n      }\n\n      this.emit('postprocessEvent', evt, hint);\n\n      evt.contexts = {\n        trace: currentScopes.getTraceContextFromScope(currentScope),\n        ...evt.contexts,\n      };\n\n      const dynamicSamplingContext$1 = dynamicSamplingContext.getDynamicSamplingContextFromScope(this, currentScope);\n\n      evt.sdkProcessingMetadata = {\n        dynamicSamplingContext: dynamicSamplingContext$1,\n        ...evt.sdkProcessingMetadata,\n      };\n\n      return evt;\n    });\n  }\n\n  /**\n   * Processes the event and logs an error in case of rejection\n   * @param event\n   * @param hint\n   * @param scope\n   */\n   _captureEvent(\n    event,\n    hint = {},\n    currentScope = currentScopes.getCurrentScope(),\n    isolationScope = currentScopes.getIsolationScope(),\n  ) {\n    if (debugBuild.DEBUG_BUILD && isErrorEvent(event)) {\n      debugLogger.debug.log(`Captured error event \\`${eventUtils.getPossibleEventMessages(event)[0] || '<unknown>'}\\``);\n    }\n\n    return this._processEvent(event, hint, currentScope, isolationScope).then(\n      finalEvent => {\n        return finalEvent.event_id;\n      },\n      reason => {\n        if (debugBuild.DEBUG_BUILD) {\n          if (_isDoNotSendEventError(reason)) {\n            debugLogger.debug.log(reason.message);\n          } else if (_isInternalError(reason)) {\n            debugLogger.debug.warn(reason.message);\n          } else {\n            debugLogger.debug.warn(reason);\n          }\n        }\n        return undefined;\n      },\n    );\n  }\n\n  /**\n   * Processes an event (either error or message) and sends it to Sentry.\n   *\n   * This also adds breadcrumbs and context information to the event. However,\n   * platform specific meta data (such as the User's IP address) must be added\n   * by the SDK implementor.\n   *\n   *\n   * @param event The event to send to Sentry.\n   * @param hint May contain additional information about the original exception.\n   * @param currentScope A scope containing event metadata.\n   * @returns A SyncPromise that resolves with the event or rejects in case event was/will not be send.\n   */\n   _processEvent(\n    event,\n    hint,\n    currentScope,\n    isolationScope,\n  ) {\n    const options = this.getOptions();\n    const { sampleRate } = options;\n\n    const isTransaction = isTransactionEvent(event);\n    const isError = isErrorEvent(event);\n    const eventType = event.type || 'error';\n    const beforeSendLabel = `before send for type \\`${eventType}\\``;\n\n    // 1.0 === 100% events are sent\n    // 0.0 === 0% events are sent\n    // Sampling for transaction happens somewhere else\n    const parsedSampleRate = typeof sampleRate === 'undefined' ? undefined : parseSampleRate.parseSampleRate(sampleRate);\n    if (isError && typeof parsedSampleRate === 'number' && Math.random() > parsedSampleRate) {\n      this.recordDroppedEvent('sample_rate', 'error');\n      return syncpromise.rejectedSyncPromise(\n        _makeDoNotSendEventError(\n          `Discarding event because it's not included in the random sample (sampling rate = ${sampleRate})`,\n        ),\n      );\n    }\n\n    const dataCategory = (eventType === 'replay_event' ? 'replay' : eventType) ;\n\n    return this._prepareEvent(event, hint, currentScope, isolationScope)\n      .then(prepared => {\n        if (prepared === null) {\n          this.recordDroppedEvent('event_processor', dataCategory);\n          throw _makeDoNotSendEventError('An event processor returned `null`, will not send event.');\n        }\n\n        const isInternalException = hint.data && (hint.data ).__sentry__ === true;\n        if (isInternalException) {\n          return prepared;\n        }\n\n        const result = processBeforeSend(this, options, prepared, hint);\n        return _validateBeforeSendResult(result, beforeSendLabel);\n      })\n      .then(processedEvent => {\n        if (processedEvent === null) {\n          this.recordDroppedEvent('before_send', dataCategory);\n          if (isTransaction) {\n            const spans = event.spans || [];\n            // the transaction itself counts as one span, plus all the child spans that are added\n            const spanCount = 1 + spans.length;\n            this.recordDroppedEvent('before_send', 'span', spanCount);\n          }\n          throw _makeDoNotSendEventError(`${beforeSendLabel} returned \\`null\\`, will not send event.`);\n        }\n\n        const session = currentScope.getSession() || isolationScope.getSession();\n        if (isError && session) {\n          this._updateSessionFromEvent(session, processedEvent);\n        }\n\n        if (isTransaction) {\n          const spanCountBefore = processedEvent.sdkProcessingMetadata?.spanCountBeforeProcessing || 0;\n          const spanCountAfter = processedEvent.spans ? processedEvent.spans.length : 0;\n\n          const droppedSpanCount = spanCountBefore - spanCountAfter;\n          if (droppedSpanCount > 0) {\n            this.recordDroppedEvent('before_send', 'span', droppedSpanCount);\n          }\n        }\n\n        // None of the Sentry built event processor will update transaction name,\n        // so if the transaction name has been changed by an event processor, we know\n        // it has to come from custom event processor added by a user\n        const transactionInfo = processedEvent.transaction_info;\n        if (isTransaction && transactionInfo && processedEvent.transaction !== event.transaction) {\n          const source = 'custom';\n          processedEvent.transaction_info = {\n            ...transactionInfo,\n            source,\n          };\n        }\n\n        this.sendEvent(processedEvent, hint);\n        return processedEvent;\n      })\n      .then(null, reason => {\n        if (_isDoNotSendEventError(reason) || _isInternalError(reason)) {\n          throw reason;\n        }\n\n        this.captureException(reason, {\n          data: {\n            __sentry__: true,\n          },\n          originalException: reason,\n        });\n        throw _makeInternalError(\n          `Event processing pipeline threw an error, original event will not be sent. Details have been sent as a new event.\\nReason: ${reason}`,\n        );\n      });\n  }\n\n  /**\n   * Occupies the client with processing and event\n   */\n   _process(promise) {\n    this._numProcessing++;\n    void promise.then(\n      value => {\n        this._numProcessing--;\n        return value;\n      },\n      reason => {\n        this._numProcessing--;\n        return reason;\n      },\n    );\n  }\n\n  /**\n   * Clears outcomes on this client and returns them.\n   */\n   _clearOutcomes() {\n    const outcomes = this._outcomes;\n    this._outcomes = {};\n    return Object.entries(outcomes).map(([key, quantity]) => {\n      const [reason, category] = key.split(':') ;\n      return {\n        reason,\n        category,\n        quantity,\n      };\n    });\n  }\n\n  /**\n   * Sends client reports as an envelope.\n   */\n   _flushOutcomes() {\n    debugBuild.DEBUG_BUILD && debugLogger.debug.log('Flushing outcomes...');\n\n    const outcomes = this._clearOutcomes();\n\n    if (outcomes.length === 0) {\n      debugBuild.DEBUG_BUILD && debugLogger.debug.log('No outcomes to send');\n      return;\n    }\n\n    // This is really the only place where we want to check for a DSN and only send outcomes then\n    if (!this._dsn) {\n      debugBuild.DEBUG_BUILD && debugLogger.debug.log('No dsn provided, will not send outcomes');\n      return;\n    }\n\n    debugBuild.DEBUG_BUILD && debugLogger.debug.log('Sending outcomes:', outcomes);\n\n    const envelope = clientreport.createClientReportEnvelope(outcomes, this._options.tunnel && dsn.dsnToString(this._dsn));\n\n    // sendEnvelope should not throw\n    // eslint-disable-next-line @typescript-eslint/no-floating-promises\n    this.sendEnvelope(envelope);\n  }\n\n  /**\n   * Creates an {@link Event} from all inputs to `captureException` and non-primitive inputs to `captureMessage`.\n   */\n\n}\n\n/**\n * @deprecated Use `Client` instead. This alias may be removed in a future major version.\n */\n// TODO(v10): Remove\n\n/**\n * @deprecated Use `Client` instead. This alias may be removed in a future major version.\n */\n// TODO(v10): Remove\nconst BaseClient = Client;\n\n/**\n * Verifies that return value of configured `beforeSend` or `beforeSendTransaction` is of expected type, and returns the value if so.\n */\nfunction _validateBeforeSendResult(\n  beforeSendResult,\n  beforeSendLabel,\n) {\n  const invalidValueError = `${beforeSendLabel} must return \\`null\\` or a valid event.`;\n  if (is.isThenable(beforeSendResult)) {\n    return beforeSendResult.then(\n      event => {\n        if (!is.isPlainObject(event) && event !== null) {\n          throw _makeInternalError(invalidValueError);\n        }\n        return event;\n      },\n      e => {\n        throw _makeInternalError(`${beforeSendLabel} rejected with ${e}`);\n      },\n    );\n  } else if (!is.isPlainObject(beforeSendResult) && beforeSendResult !== null) {\n    throw _makeInternalError(invalidValueError);\n  }\n  return beforeSendResult;\n}\n\n/**\n * Process the matching `beforeSendXXX` callback.\n */\nfunction processBeforeSend(\n  client,\n  options,\n  event,\n  hint,\n) {\n  const { beforeSend, beforeSendTransaction, beforeSendSpan } = options;\n  let processedEvent = event;\n\n  if (isErrorEvent(processedEvent) && beforeSend) {\n    return beforeSend(processedEvent, hint);\n  }\n\n  if (isTransactionEvent(processedEvent)) {\n    if (beforeSendSpan) {\n      // process root span\n      const processedRootSpanJson = beforeSendSpan(transactionEvent.convertTransactionEventToSpanJson(processedEvent));\n      if (!processedRootSpanJson) {\n        spanUtils.showSpanDropWarning();\n      } else {\n        // update event with processed root span values\n        processedEvent = merge.merge(event, transactionEvent.convertSpanJsonToTransactionEvent(processedRootSpanJson));\n      }\n\n      // process child spans\n      if (processedEvent.spans) {\n        const processedSpans = [];\n        for (const span of processedEvent.spans) {\n          const processedSpan = beforeSendSpan(span);\n          if (!processedSpan) {\n            spanUtils.showSpanDropWarning();\n            processedSpans.push(span);\n          } else {\n            processedSpans.push(processedSpan);\n          }\n        }\n        processedEvent.spans = processedSpans;\n      }\n    }\n\n    if (beforeSendTransaction) {\n      if (processedEvent.spans) {\n        // We store the # of spans before processing in SDK metadata,\n        // so we can compare it afterwards to determine how many spans were dropped\n        const spanCountBefore = processedEvent.spans.length;\n        processedEvent.sdkProcessingMetadata = {\n          ...event.sdkProcessingMetadata,\n          spanCountBeforeProcessing: spanCountBefore,\n        };\n      }\n      return beforeSendTransaction(processedEvent , hint);\n    }\n  }\n\n  return processedEvent;\n}\n\nfunction isErrorEvent(event) {\n  return event.type === undefined;\n}\n\nfunction isTransactionEvent(event) {\n  return event.type === 'transaction';\n}\n\n/** Extract trace information from scope */\nfunction _getTraceInfoFromScope(\n  client,\n  scope,\n) {\n  if (!scope) {\n    return [undefined, undefined];\n  }\n\n  return currentScopes.withScope(scope, () => {\n    const span = spanUtils.getActiveSpan();\n    const traceContext = span ? spanUtils.spanToTraceContext(span) : currentScopes.getTraceContextFromScope(scope);\n    const dynamicSamplingContext$1 = span\n      ? dynamicSamplingContext.getDynamicSamplingContextFromSpan(span)\n      : dynamicSamplingContext.getDynamicSamplingContextFromScope(client, scope);\n    return [dynamicSamplingContext$1, traceContext];\n  });\n}\n\nexports.BaseClient = BaseClient;\nexports.Client = Client;\nexports._getTraceInfoFromScope = _getTraceInfoFromScope;\n//# sourceMappingURL=client.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9jbGllbnQuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsWUFBWSxtQkFBTyxDQUFDLDJHQUFVO0FBQzlCLGtCQUFrQixtQkFBTyxDQUFDLHVIQUFnQjtBQUMxQyxzQkFBc0IsbUJBQU8sQ0FBQywrSEFBb0I7QUFDbEQsbUJBQW1CLG1CQUFPLENBQUMsMkhBQWtCO0FBQzdDLGlCQUFpQixtQkFBTyxDQUFDLHFIQUFlO0FBQ3hDLG9CQUFvQixtQkFBTyxDQUFDLDJIQUFrQjtBQUM5QyxnQkFBZ0IsbUJBQU8sQ0FBQyxtSEFBYztBQUN0QywrQkFBK0IsbUJBQU8sQ0FBQyxpS0FBcUM7QUFDNUUscUJBQXFCLG1CQUFPLENBQUMseUlBQXlCO0FBQ3RELG9CQUFvQixtQkFBTyxDQUFDLHlJQUF5QjtBQUNyRCxZQUFZLG1CQUFPLENBQUMsdUhBQWdCO0FBQ3BDLG1CQUFtQixtQkFBTyxDQUFDLGlJQUFxQjtBQUNoRCxtQkFBbUIsbUJBQU8sQ0FBQyxxSUFBdUI7QUFDbEQsV0FBVyxtQkFBTyxDQUFDLHFIQUFlO0FBQ2xDLGNBQWMsbUJBQU8sQ0FBQywySEFBa0I7QUFDeEMsYUFBYSxtQkFBTyxDQUFDLHlIQUFpQjtBQUN0Qyx3QkFBd0IsbUJBQU8sQ0FBQywrSUFBNEI7QUFDNUQscUJBQXFCLG1CQUFPLENBQUMseUlBQXlCO0FBQ3RELGtCQUFrQixtQkFBTyxDQUFDLG1JQUFzQjtBQUNoRCxvQkFBb0IsbUJBQU8sQ0FBQyx1SUFBd0I7QUFDcEQseUJBQXlCLG1CQUFPLENBQUMsaUpBQTZCOztBQUU5RDs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxJQUFJLHdCQUF3QjtBQUM1QjtBQUNBO0FBQ0EsSUFBSSxxQkFBcUI7QUFDekIsMENBQTBDLHNCQUFzQjtBQUNoRTtBQUNBO0FBQ0E7QUFDQSxJQUFJLDRCQUE0QjtBQUNoQztBQUNBO0FBQ0E7QUFDQTtBQUNBLElBQUksMEJBQTBCO0FBQzlCO0FBQ0EsSUFBSSwyQkFBMkI7QUFDL0I7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBOztBQUVBOztBQUVBOztBQUVBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsTUFBTTtBQUNOO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLE9BQU87QUFDUDtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSx1Q0FBdUMsYUFBYTtBQUNwRDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsT0FBTztBQUNQLE1BQU07QUFDTjtBQUNBO0FBQ0E7O0FBRUE7QUFDQSx5RUFBeUUsbUJBQW1CO0FBQzVGO0FBQ0EsYUFBYSxRQUFRO0FBQ3JCO0FBQ0EsZUFBZSxrQkFBa0I7QUFDakM7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxLQUFLO0FBQ0w7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSx5Q0FBeUMsTUFBTTtBQUMvQztBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQSxlQUFlLHVCQUF1QjtBQUN0QztBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0EsNkJBQTZCO0FBQzdCOztBQUVBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxZQUFZLHFHQUFxRztBQUNqSDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxNQUFNO0FBQ047QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLHFCQUFxQixPQUFPLEdBQUcsU0FBUztBQUN4Qyw2RUFBNkUsSUFBSSxHQUFHLGlCQUFpQixPQUFPLGFBQWE7QUFDekg7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsZUFBZSxZQUFZO0FBQzNCOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQSxPQUFPO0FBQ1A7O0FBRUE7O0FBRUEsNkNBQTZDO0FBQzdDOztBQUVBOztBQUVBO0FBQ0E7QUFDQSxZQUFZLGVBQWU7QUFDM0I7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLHlCQUF5QixtQkFBbUI7QUFDNUM7QUFDQSxPQUFPO0FBQ1A7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQSxVQUFVO0FBQ1Y7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsT0FBTztBQUNQLEtBQUs7QUFDTDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQSxLQUFLO0FBQ0w7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGFBQWE7QUFDYjtBQUNBO0FBQ0E7QUFDQTtBQUNBLHNEQUFzRCw2REFBNkQ7QUFDbkg7O0FBRUE7QUFDQTtBQUNBO0FBQ0EsT0FBTztBQUNQO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsWUFBWTtBQUNaO0FBQ0EsWUFBWTtBQUNaO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsT0FBTztBQUNQO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFlBQVksYUFBYTs7QUFFekI7QUFDQTtBQUNBO0FBQ0Esc0RBQXNELFVBQVU7O0FBRWhFO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSw4RkFBOEYsV0FBVztBQUN6RztBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQSxPQUFPO0FBQ1A7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsNENBQTRDLGlCQUFpQjtBQUM3RDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQSxPQUFPO0FBQ1A7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0EsV0FBVztBQUNYO0FBQ0EsU0FBUztBQUNUO0FBQ0Esd0lBQXdJLE9BQU87QUFDL0k7QUFDQSxPQUFPO0FBQ1A7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsT0FBTztBQUNQO0FBQ0E7QUFDQTtBQUNBLE9BQU87QUFDUDtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsS0FBSztBQUNMOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBLGlCQUFpQixhQUFhO0FBQzlCOztBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSwrQkFBK0IsaUJBQWlCO0FBQ2hEO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsT0FBTztBQUNQO0FBQ0Esb0NBQW9DLGlCQUFpQixnQkFBZ0IsRUFBRTtBQUN2RSxPQUFPO0FBQ1A7QUFDQSxJQUFJO0FBQ0o7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsVUFBVSxvREFBb0Q7QUFDOUQ7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFFBQVE7QUFDUjtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFlBQVk7QUFDWjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxHQUFHO0FBQ0g7O0FBRUEsa0JBQWtCO0FBQ2xCLGNBQWM7QUFDZCw4QkFBOEI7QUFDOUIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9jbGllbnQuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGFwaSA9IHJlcXVpcmUoJy4vYXBpLmpzJyk7XG5jb25zdCBjb25zdGFudHMgPSByZXF1aXJlKCcuL2NvbnN0YW50cy5qcycpO1xuY29uc3QgY3VycmVudFNjb3BlcyA9IHJlcXVpcmUoJy4vY3VycmVudFNjb3Blcy5qcycpO1xuY29uc3QgZGVidWdCdWlsZCA9IHJlcXVpcmUoJy4vZGVidWctYnVpbGQuanMnKTtcbmNvbnN0IGVudmVsb3BlID0gcmVxdWlyZSgnLi9lbnZlbG9wZS5qcycpO1xuY29uc3QgaW50ZWdyYXRpb24gPSByZXF1aXJlKCcuL2ludGVncmF0aW9uLmpzJyk7XG5jb25zdCBzZXNzaW9uID0gcmVxdWlyZSgnLi9zZXNzaW9uLmpzJyk7XG5jb25zdCBkeW5hbWljU2FtcGxpbmdDb250ZXh0ID0gcmVxdWlyZSgnLi90cmFjaW5nL2R5bmFtaWNTYW1wbGluZ0NvbnRleHQuanMnKTtcbmNvbnN0IGNsaWVudHJlcG9ydCA9IHJlcXVpcmUoJy4vdXRpbHMvY2xpZW50cmVwb3J0LmpzJyk7XG5jb25zdCBkZWJ1Z0xvZ2dlciA9IHJlcXVpcmUoJy4vdXRpbHMvZGVidWctbG9nZ2VyLmpzJyk7XG5jb25zdCBkc24gPSByZXF1aXJlKCcuL3V0aWxzL2Rzbi5qcycpO1xuY29uc3QgZW52ZWxvcGUkMSA9IHJlcXVpcmUoJy4vdXRpbHMvZW52ZWxvcGUuanMnKTtcbmNvbnN0IGV2ZW50VXRpbHMgPSByZXF1aXJlKCcuL3V0aWxzL2V2ZW50VXRpbHMuanMnKTtcbmNvbnN0IGlzID0gcmVxdWlyZSgnLi91dGlscy9pcy5qcycpO1xuY29uc3QgbWVyZ2UgPSByZXF1aXJlKCcuL3V0aWxzL21lcmdlLmpzJyk7XG5jb25zdCBtaXNjID0gcmVxdWlyZSgnLi91dGlscy9taXNjLmpzJyk7XG5jb25zdCBwYXJzZVNhbXBsZVJhdGUgPSByZXF1aXJlKCcuL3V0aWxzL3BhcnNlU2FtcGxlUmF0ZS5qcycpO1xuY29uc3QgcHJlcGFyZUV2ZW50ID0gcmVxdWlyZSgnLi91dGlscy9wcmVwYXJlRXZlbnQuanMnKTtcbmNvbnN0IHNwYW5VdGlscyA9IHJlcXVpcmUoJy4vdXRpbHMvc3BhblV0aWxzLmpzJyk7XG5jb25zdCBzeW5jcHJvbWlzZSA9IHJlcXVpcmUoJy4vdXRpbHMvc3luY3Byb21pc2UuanMnKTtcbmNvbnN0IHRyYW5zYWN0aW9uRXZlbnQgPSByZXF1aXJlKCcuL3V0aWxzL3RyYW5zYWN0aW9uRXZlbnQuanMnKTtcblxuLyogZXNsaW50LWRpc2FibGUgbWF4LWxpbmVzICovXG5cbmNvbnN0IEFMUkVBRFlfU0VFTl9FUlJPUiA9IFwiTm90IGNhcHR1cmluZyBleGNlcHRpb24gYmVjYXVzZSBpdCdzIGFscmVhZHkgYmVlbiBjYXB0dXJlZC5cIjtcbmNvbnN0IE1JU1NJTkdfUkVMRUFTRV9GT1JfU0VTU0lPTl9FUlJPUiA9ICdEaXNjYXJkZWQgc2Vzc2lvbiBiZWNhdXNlIG9mIG1pc3Npbmcgb3Igbm9uLXN0cmluZyByZWxlYXNlJztcblxuY29uc3QgSU5URVJOQUxfRVJST1JfU1lNQk9MID0gU3ltYm9sLmZvcignU2VudHJ5SW50ZXJuYWxFcnJvcicpO1xuY29uc3QgRE9fTk9UX1NFTkRfRVZFTlRfU1lNQk9MID0gU3ltYm9sLmZvcignU2VudHJ5RG9Ob3RTZW5kRXZlbnRFcnJvcicpO1xuXG5mdW5jdGlvbiBfbWFrZUludGVybmFsRXJyb3IobWVzc2FnZSkge1xuICByZXR1cm4ge1xuICAgIG1lc3NhZ2UsXG4gICAgW0lOVEVSTkFMX0VSUk9SX1NZTUJPTF06IHRydWUsXG4gIH07XG59XG5cbmZ1bmN0aW9uIF9tYWtlRG9Ob3RTZW5kRXZlbnRFcnJvcihtZXNzYWdlKSB7XG4gIHJldHVybiB7XG4gICAgbWVzc2FnZSxcbiAgICBbRE9fTk9UX1NFTkRfRVZFTlRfU1lNQk9MXTogdHJ1ZSxcbiAgfTtcbn1cblxuZnVuY3Rpb24gX2lzSW50ZXJuYWxFcnJvcihlcnJvcikge1xuICByZXR1cm4gISFlcnJvciAmJiB0eXBlb2YgZXJyb3IgPT09ICdvYmplY3QnICYmIElOVEVSTkFMX0VSUk9SX1NZTUJPTCBpbiBlcnJvcjtcbn1cblxuZnVuY3Rpb24gX2lzRG9Ob3RTZW5kRXZlbnRFcnJvcihlcnJvcikge1xuICByZXR1cm4gISFlcnJvciAmJiB0eXBlb2YgZXJyb3IgPT09ICdvYmplY3QnICYmIERPX05PVF9TRU5EX0VWRU5UX1NZTUJPTCBpbiBlcnJvcjtcbn1cblxuLyoqXG4gKiBCYXNlIGltcGxlbWVudGF0aW9uIGZvciBhbGwgSmF2YVNjcmlwdCBTREsgY2xpZW50cy5cbiAqXG4gKiBDYWxsIHRoZSBjb25zdHJ1Y3RvciB3aXRoIHRoZSBjb3JyZXNwb25kaW5nIG9wdGlvbnNcbiAqIHNwZWNpZmljIHRvIHRoZSBjbGllbnQgc3ViY2xhc3MuIFRvIGFjY2VzcyB0aGVzZSBvcHRpb25zIGxhdGVyLCB1c2VcbiAqIHtAbGluayBDbGllbnQuZ2V0T3B0aW9uc30uXG4gKlxuICogSWYgYSBEc24gaXMgc3BlY2lmaWVkIGluIHRoZSBvcHRpb25zLCBpdCB3aWxsIGJlIHBhcnNlZCBhbmQgc3RvcmVkLiBVc2VcbiAqIHtAbGluayBDbGllbnQuZ2V0RHNufSB0byByZXRyaWV2ZSB0aGUgRHNuIGF0IGFueSBtb21lbnQuIEluIGNhc2UgdGhlIERzbiBpc1xuICogaW52YWxpZCwgdGhlIGNvbnN0cnVjdG9yIHdpbGwgdGhyb3cgYSB7QGxpbmsgU2VudHJ5RXhjZXB0aW9ufS4gTm90ZSB0aGF0XG4gKiB3aXRob3V0IGEgdmFsaWQgRHNuLCB0aGUgU0RLIHdpbGwgbm90IHNlbmQgYW55IGV2ZW50cyB0byBTZW50cnkuXG4gKlxuICogQmVmb3JlIHNlbmRpbmcgYW4gZXZlbnQsIGl0IGlzIHBhc3NlZCB0aHJvdWdoXG4gKiB7QGxpbmsgQ2xpZW50Ll9wcmVwYXJlRXZlbnR9IHRvIGFkZCBTREsgaW5mb3JtYXRpb24gYW5kIHNjb3BlIGRhdGFcbiAqIChicmVhZGNydW1icyBhbmQgY29udGV4dCkuIFRvIGFkZCBtb3JlIGN1c3RvbSBpbmZvcm1hdGlvbiwgb3ZlcnJpZGUgdGhpc1xuICogbWV0aG9kIGFuZCBleHRlbmQgdGhlIHJlc3VsdGluZyBwcmVwYXJlZCBldmVudC5cbiAqXG4gKiBUbyBpc3N1ZSBhdXRvbWF0aWNhbGx5IGNyZWF0ZWQgZXZlbnRzIChlLmcuIHZpYSBpbnN0cnVtZW50YXRpb24pLCB1c2VcbiAqIHtAbGluayBDbGllbnQuY2FwdHVyZUV2ZW50fS4gSXQgd2lsbCBwcmVwYXJlIHRoZSBldmVudCBhbmQgcGFzcyBpdCB0aHJvdWdoXG4gKiB0aGUgY2FsbGJhY2sgbGlmZWN5Y2xlLiBUbyBpc3N1ZSBhdXRvLWJyZWFkY3J1bWJzLCB1c2VcbiAqIHtAbGluayBDbGllbnQuYWRkQnJlYWRjcnVtYn0uXG4gKlxuICogQGV4YW1wbGVcbiAqIGNsYXNzIE5vZGVDbGllbnQgZXh0ZW5kcyBDbGllbnQ8Tm9kZU9wdGlvbnM+IHtcbiAqICAgcHVibGljIGNvbnN0cnVjdG9yKG9wdGlvbnM6IE5vZGVPcHRpb25zKSB7XG4gKiAgICAgc3VwZXIob3B0aW9ucyk7XG4gKiAgIH1cbiAqXG4gKiAgIC8vIC4uLlxuICogfVxuICovXG5jbGFzcyBDbGllbnQge1xuICAvKiogT3B0aW9ucyBwYXNzZWQgdG8gdGhlIFNESy4gKi9cblxuICAvKiogVGhlIGNsaWVudCBEc24sIGlmIHNwZWNpZmllZCBpbiBvcHRpb25zLiBXaXRob3V0IHRoaXMgRHNuLCB0aGUgU0RLIHdpbGwgYmUgZGlzYWJsZWQuICovXG5cbiAgLyoqIEFycmF5IG9mIHNldCB1cCBpbnRlZ3JhdGlvbnMuICovXG5cbiAgLyoqIE51bWJlciBvZiBjYWxscyBiZWluZyBwcm9jZXNzZWQgKi9cblxuICAvKiogSG9sZHMgZmx1c2hhYmxlICAqL1xuXG4gIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvYmFuLXR5cGVzXG5cbiAgLyoqXG4gICAqIEluaXRpYWxpemVzIHRoaXMgY2xpZW50IGluc3RhbmNlLlxuICAgKlxuICAgKiBAcGFyYW0gb3B0aW9ucyBPcHRpb25zIGZvciB0aGUgY2xpZW50LlxuICAgKi9cbiAgIGNvbnN0cnVjdG9yKG9wdGlvbnMpIHtcbiAgICB0aGlzLl9vcHRpb25zID0gb3B0aW9ucztcbiAgICB0aGlzLl9pbnRlZ3JhdGlvbnMgPSB7fTtcbiAgICB0aGlzLl9udW1Qcm9jZXNzaW5nID0gMDtcbiAgICB0aGlzLl9vdXRjb21lcyA9IHt9O1xuICAgIHRoaXMuX2hvb2tzID0ge307XG4gICAgdGhpcy5fZXZlbnRQcm9jZXNzb3JzID0gW107XG5cbiAgICBpZiAob3B0aW9ucy5kc24pIHtcbiAgICAgIHRoaXMuX2RzbiA9IGRzbi5tYWtlRHNuKG9wdGlvbnMuZHNuKTtcbiAgICB9IGVsc2Uge1xuICAgICAgZGVidWdCdWlsZC5ERUJVR19CVUlMRCAmJiBkZWJ1Z0xvZ2dlci5kZWJ1Zy53YXJuKCdObyBEU04gcHJvdmlkZWQsIGNsaWVudCB3aWxsIG5vdCBzZW5kIGV2ZW50cy4nKTtcbiAgICB9XG5cbiAgICBpZiAodGhpcy5fZHNuKSB7XG4gICAgICBjb25zdCB1cmwgPSBhcGkuZ2V0RW52ZWxvcGVFbmRwb2ludFdpdGhVcmxFbmNvZGVkQXV0aChcbiAgICAgICAgdGhpcy5fZHNuLFxuICAgICAgICBvcHRpb25zLnR1bm5lbCxcbiAgICAgICAgb3B0aW9ucy5fbWV0YWRhdGEgPyBvcHRpb25zLl9tZXRhZGF0YS5zZGsgOiB1bmRlZmluZWQsXG4gICAgICApO1xuICAgICAgdGhpcy5fdHJhbnNwb3J0ID0gb3B0aW9ucy50cmFuc3BvcnQoe1xuICAgICAgICB0dW5uZWw6IHRoaXMuX29wdGlvbnMudHVubmVsLFxuICAgICAgICByZWNvcmREcm9wcGVkRXZlbnQ6IHRoaXMucmVjb3JkRHJvcHBlZEV2ZW50LmJpbmQodGhpcyksXG4gICAgICAgIC4uLm9wdGlvbnMudHJhbnNwb3J0T3B0aW9ucyxcbiAgICAgICAgdXJsLFxuICAgICAgfSk7XG4gICAgfVxuICB9XG5cbiAgLyoqXG4gICAqIENhcHR1cmVzIGFuIGV4Y2VwdGlvbiBldmVudCBhbmQgc2VuZHMgaXQgdG8gU2VudHJ5LlxuICAgKlxuICAgKiBVbmxpa2UgYGNhcHR1cmVFeGNlcHRpb25gIGV4cG9ydGVkIGZyb20gZXZlcnkgU0RLLCB0aGlzIG1ldGhvZCByZXF1aXJlcyB0aGF0IHlvdSBwYXNzIGl0IHRoZSBjdXJyZW50IHNjb3BlLlxuICAgKi9cbiAgIGNhcHR1cmVFeGNlcHRpb24oZXhjZXB0aW9uLCBoaW50LCBzY29wZSkge1xuICAgIGNvbnN0IGV2ZW50SWQgPSBtaXNjLnV1aWQ0KCk7XG5cbiAgICAvLyBlbnN1cmUgd2UgaGF2ZW4ndCBjYXB0dXJlZCB0aGlzIHZlcnkgb2JqZWN0IGJlZm9yZVxuICAgIGlmIChtaXNjLmNoZWNrT3JTZXRBbHJlYWR5Q2F1Z2h0KGV4Y2VwdGlvbikpIHtcbiAgICAgIGRlYnVnQnVpbGQuREVCVUdfQlVJTEQgJiYgZGVidWdMb2dnZXIuZGVidWcubG9nKEFMUkVBRFlfU0VFTl9FUlJPUik7XG4gICAgICByZXR1cm4gZXZlbnRJZDtcbiAgICB9XG5cbiAgICBjb25zdCBoaW50V2l0aEV2ZW50SWQgPSB7XG4gICAgICBldmVudF9pZDogZXZlbnRJZCxcbiAgICAgIC4uLmhpbnQsXG4gICAgfTtcblxuICAgIHRoaXMuX3Byb2Nlc3MoXG4gICAgICB0aGlzLmV2ZW50RnJvbUV4Y2VwdGlvbihleGNlcHRpb24sIGhpbnRXaXRoRXZlbnRJZCkudGhlbihldmVudCA9PlxuICAgICAgICB0aGlzLl9jYXB0dXJlRXZlbnQoZXZlbnQsIGhpbnRXaXRoRXZlbnRJZCwgc2NvcGUpLFxuICAgICAgKSxcbiAgICApO1xuXG4gICAgcmV0dXJuIGhpbnRXaXRoRXZlbnRJZC5ldmVudF9pZDtcbiAgfVxuXG4gIC8qKlxuICAgKiBDYXB0dXJlcyBhIG1lc3NhZ2UgZXZlbnQgYW5kIHNlbmRzIGl0IHRvIFNlbnRyeS5cbiAgICpcbiAgICogVW5saWtlIGBjYXB0dXJlTWVzc2FnZWAgZXhwb3J0ZWQgZnJvbSBldmVyeSBTREssIHRoaXMgbWV0aG9kIHJlcXVpcmVzIHRoYXQgeW91IHBhc3MgaXQgdGhlIGN1cnJlbnQgc2NvcGUuXG4gICAqL1xuICAgY2FwdHVyZU1lc3NhZ2UoXG4gICAgbWVzc2FnZSxcbiAgICBsZXZlbCxcbiAgICBoaW50LFxuICAgIGN1cnJlbnRTY29wZSxcbiAgKSB7XG4gICAgY29uc3QgaGludFdpdGhFdmVudElkID0ge1xuICAgICAgZXZlbnRfaWQ6IG1pc2MudXVpZDQoKSxcbiAgICAgIC4uLmhpbnQsXG4gICAgfTtcblxuICAgIGNvbnN0IGV2ZW50TWVzc2FnZSA9IGlzLmlzUGFyYW1ldGVyaXplZFN0cmluZyhtZXNzYWdlKSA/IG1lc3NhZ2UgOiBTdHJpbmcobWVzc2FnZSk7XG5cbiAgICBjb25zdCBwcm9taXNlZEV2ZW50ID0gaXMuaXNQcmltaXRpdmUobWVzc2FnZSlcbiAgICAgID8gdGhpcy5ldmVudEZyb21NZXNzYWdlKGV2ZW50TWVzc2FnZSwgbGV2ZWwsIGhpbnRXaXRoRXZlbnRJZClcbiAgICAgIDogdGhpcy5ldmVudEZyb21FeGNlcHRpb24obWVzc2FnZSwgaGludFdpdGhFdmVudElkKTtcblxuICAgIHRoaXMuX3Byb2Nlc3MocHJvbWlzZWRFdmVudC50aGVuKGV2ZW50ID0+IHRoaXMuX2NhcHR1cmVFdmVudChldmVudCwgaGludFdpdGhFdmVudElkLCBjdXJyZW50U2NvcGUpKSk7XG5cbiAgICByZXR1cm4gaGludFdpdGhFdmVudElkLmV2ZW50X2lkO1xuICB9XG5cbiAgLyoqXG4gICAqIENhcHR1cmVzIGEgbWFudWFsbHkgY3JlYXRlZCBldmVudCBhbmQgc2VuZHMgaXQgdG8gU2VudHJ5LlxuICAgKlxuICAgKiBVbmxpa2UgYGNhcHR1cmVFdmVudGAgZXhwb3J0ZWQgZnJvbSBldmVyeSBTREssIHRoaXMgbWV0aG9kIHJlcXVpcmVzIHRoYXQgeW91IHBhc3MgaXQgdGhlIGN1cnJlbnQgc2NvcGUuXG4gICAqL1xuICAgY2FwdHVyZUV2ZW50KGV2ZW50LCBoaW50LCBjdXJyZW50U2NvcGUpIHtcbiAgICBjb25zdCBldmVudElkID0gbWlzYy51dWlkNCgpO1xuXG4gICAgLy8gZW5zdXJlIHdlIGhhdmVuJ3QgY2FwdHVyZWQgdGhpcyB2ZXJ5IG9iamVjdCBiZWZvcmVcbiAgICBpZiAoaGludD8ub3JpZ2luYWxFeGNlcHRpb24gJiYgbWlzYy5jaGVja09yU2V0QWxyZWFkeUNhdWdodChoaW50Lm9yaWdpbmFsRXhjZXB0aW9uKSkge1xuICAgICAgZGVidWdCdWlsZC5ERUJVR19CVUlMRCAmJiBkZWJ1Z0xvZ2dlci5kZWJ1Zy5sb2coQUxSRUFEWV9TRUVOX0VSUk9SKTtcbiAgICAgIHJldHVybiBldmVudElkO1xuICAgIH1cblxuICAgIGNvbnN0IGhpbnRXaXRoRXZlbnRJZCA9IHtcbiAgICAgIGV2ZW50X2lkOiBldmVudElkLFxuICAgICAgLi4uaGludCxcbiAgICB9O1xuXG4gICAgY29uc3Qgc2RrUHJvY2Vzc2luZ01ldGFkYXRhID0gZXZlbnQuc2RrUHJvY2Vzc2luZ01ldGFkYXRhIHx8IHt9O1xuICAgIGNvbnN0IGNhcHR1cmVkU3BhblNjb3BlID0gc2RrUHJvY2Vzc2luZ01ldGFkYXRhLmNhcHR1cmVkU3BhblNjb3BlO1xuICAgIGNvbnN0IGNhcHR1cmVkU3Bhbklzb2xhdGlvblNjb3BlID0gc2RrUHJvY2Vzc2luZ01ldGFkYXRhLmNhcHR1cmVkU3Bhbklzb2xhdGlvblNjb3BlO1xuXG4gICAgdGhpcy5fcHJvY2VzcyhcbiAgICAgIHRoaXMuX2NhcHR1cmVFdmVudChldmVudCwgaGludFdpdGhFdmVudElkLCBjYXB0dXJlZFNwYW5TY29wZSB8fCBjdXJyZW50U2NvcGUsIGNhcHR1cmVkU3Bhbklzb2xhdGlvblNjb3BlKSxcbiAgICApO1xuXG4gICAgcmV0dXJuIGhpbnRXaXRoRXZlbnRJZC5ldmVudF9pZDtcbiAgfVxuXG4gIC8qKlxuICAgKiBDYXB0dXJlcyBhIHNlc3Npb24uXG4gICAqL1xuICAgY2FwdHVyZVNlc3Npb24oc2Vzc2lvbiQxKSB7XG4gICAgdGhpcy5zZW5kU2Vzc2lvbihzZXNzaW9uJDEpO1xuICAgIC8vIEFmdGVyIHNlbmRpbmcsIHdlIHNldCBpbml0IGZhbHNlIHRvIGluZGljYXRlIGl0J3Mgbm90IHRoZSBmaXJzdCBvY2N1cnJlbmNlXG4gICAgc2Vzc2lvbi51cGRhdGVTZXNzaW9uKHNlc3Npb24kMSwgeyBpbml0OiBmYWxzZSB9KTtcbiAgfVxuXG4gIC8qKlxuICAgKiBDcmVhdGUgYSBjcm9uIG1vbml0b3IgY2hlY2sgaW4gYW5kIHNlbmQgaXQgdG8gU2VudHJ5LiBUaGlzIG1ldGhvZCBpcyBub3QgYXZhaWxhYmxlIG9uIGFsbCBjbGllbnRzLlxuICAgKlxuICAgKiBAcGFyYW0gY2hlY2tJbiBBbiBvYmplY3QgdGhhdCBkZXNjcmliZXMgYSBjaGVjayBpbi5cbiAgICogQHBhcmFtIHVwc2VydE1vbml0b3JDb25maWcgQW4gb3B0aW9uYWwgb2JqZWN0IHRoYXQgZGVzY3JpYmVzIGEgbW9uaXRvciBjb25maWcuIFVzZSB0aGlzIGlmIHlvdSB3YW50XG4gICAqIHRvIGNyZWF0ZSBhIG1vbml0b3IgYXV0b21hdGljYWxseSB3aGVuIHNlbmRpbmcgYSBjaGVjayBpbi5cbiAgICogQHBhcmFtIHNjb3BlIEFuIG9wdGlvbmFsIHNjb3BlIGNvbnRhaW5pbmcgZXZlbnQgbWV0YWRhdGEuXG4gICAqIEByZXR1cm5zIEEgc3RyaW5nIHJlcHJlc2VudGluZyB0aGUgaWQgb2YgdGhlIGNoZWNrIGluLlxuICAgKi9cblxuICAvKipcbiAgICogR2V0IHRoZSBjdXJyZW50IERzbi5cbiAgICovXG4gICBnZXREc24oKSB7XG4gICAgcmV0dXJuIHRoaXMuX2RzbjtcbiAgfVxuXG4gIC8qKlxuICAgKiBHZXQgdGhlIGN1cnJlbnQgb3B0aW9ucy5cbiAgICovXG4gICBnZXRPcHRpb25zKCkge1xuICAgIHJldHVybiB0aGlzLl9vcHRpb25zO1xuICB9XG5cbiAgLyoqXG4gICAqIEdldCB0aGUgU0RLIG1ldGFkYXRhLlxuICAgKiBAc2VlIFNka01ldGFkYXRhXG4gICAqL1xuICAgZ2V0U2RrTWV0YWRhdGEoKSB7XG4gICAgcmV0dXJuIHRoaXMuX29wdGlvbnMuX21ldGFkYXRhO1xuICB9XG5cbiAgLyoqXG4gICAqIFJldHVybnMgdGhlIHRyYW5zcG9ydCB0aGF0IGlzIHVzZWQgYnkgdGhlIGNsaWVudC5cbiAgICogUGxlYXNlIG5vdGUgdGhhdCB0aGUgdHJhbnNwb3J0IGdldHMgbGF6eSBpbml0aWFsaXplZCBzbyBpdCB3aWxsIG9ubHkgYmUgdGhlcmUgb25jZSB0aGUgZmlyc3QgZXZlbnQgaGFzIGJlZW4gc2VudC5cbiAgICovXG4gICBnZXRUcmFuc3BvcnQoKSB7XG4gICAgcmV0dXJuIHRoaXMuX3RyYW5zcG9ydDtcbiAgfVxuXG4gIC8qKlxuICAgKiBXYWl0IGZvciBhbGwgZXZlbnRzIHRvIGJlIHNlbnQgb3IgdGhlIHRpbWVvdXQgdG8gZXhwaXJlLCB3aGljaGV2ZXIgY29tZXMgZmlyc3QuXG4gICAqXG4gICAqIEBwYXJhbSB0aW1lb3V0IE1heGltdW0gdGltZSBpbiBtcyB0aGUgY2xpZW50IHNob3VsZCB3YWl0IGZvciBldmVudHMgdG8gYmUgZmx1c2hlZC4gT21pdHRpbmcgdGhpcyBwYXJhbWV0ZXIgd2lsbFxuICAgKiAgIGNhdXNlIHRoZSBjbGllbnQgdG8gd2FpdCB1bnRpbCBhbGwgZXZlbnRzIGFyZSBzZW50IGJlZm9yZSByZXNvbHZpbmcgdGhlIHByb21pc2UuXG4gICAqIEByZXR1cm5zIEEgcHJvbWlzZSB0aGF0IHdpbGwgcmVzb2x2ZSB3aXRoIGB0cnVlYCBpZiBhbGwgZXZlbnRzIGFyZSBzZW50IGJlZm9yZSB0aGUgdGltZW91dCwgb3IgYGZhbHNlYCBpZiB0aGVyZSBhcmVcbiAgICogc3RpbGwgZXZlbnRzIGluIHRoZSBxdWV1ZSB3aGVuIHRoZSB0aW1lb3V0IGlzIHJlYWNoZWQuXG4gICAqL1xuICAgZmx1c2godGltZW91dCkge1xuICAgIGNvbnN0IHRyYW5zcG9ydCA9IHRoaXMuX3RyYW5zcG9ydDtcbiAgICBpZiAodHJhbnNwb3J0KSB7XG4gICAgICB0aGlzLmVtaXQoJ2ZsdXNoJyk7XG4gICAgICByZXR1cm4gdGhpcy5faXNDbGllbnREb25lUHJvY2Vzc2luZyh0aW1lb3V0KS50aGVuKGNsaWVudEZpbmlzaGVkID0+IHtcbiAgICAgICAgcmV0dXJuIHRyYW5zcG9ydC5mbHVzaCh0aW1lb3V0KS50aGVuKHRyYW5zcG9ydEZsdXNoZWQgPT4gY2xpZW50RmluaXNoZWQgJiYgdHJhbnNwb3J0Rmx1c2hlZCk7XG4gICAgICB9KTtcbiAgICB9IGVsc2Uge1xuICAgICAgcmV0dXJuIHN5bmNwcm9taXNlLnJlc29sdmVkU3luY1Byb21pc2UodHJ1ZSk7XG4gICAgfVxuICB9XG5cbiAgLyoqXG4gICAqIEZsdXNoIHRoZSBldmVudCBxdWV1ZSBhbmQgc2V0IHRoZSBjbGllbnQgdG8gYGVuYWJsZWQgPSBmYWxzZWAuIFNlZSB7QGxpbmsgQ2xpZW50LmZsdXNofS5cbiAgICpcbiAgICogQHBhcmFtIHtudW1iZXJ9IHRpbWVvdXQgTWF4aW11bSB0aW1lIGluIG1zIHRoZSBjbGllbnQgc2hvdWxkIHdhaXQgYmVmb3JlIHNodXR0aW5nIGRvd24uIE9taXR0aW5nIHRoaXMgcGFyYW1ldGVyIHdpbGwgY2F1c2VcbiAgICogICB0aGUgY2xpZW50IHRvIHdhaXQgdW50aWwgYWxsIGV2ZW50cyBhcmUgc2VudCBiZWZvcmUgZGlzYWJsaW5nIGl0c2VsZi5cbiAgICogQHJldHVybnMge1Byb21pc2U8Ym9vbGVhbj59IEEgcHJvbWlzZSB3aGljaCByZXNvbHZlcyB0byBgdHJ1ZWAgaWYgdGhlIGZsdXNoIGNvbXBsZXRlcyBzdWNjZXNzZnVsbHkgYmVmb3JlIHRoZSB0aW1lb3V0LCBvciBgZmFsc2VgIGlmXG4gICAqIGl0IGRvZXNuJ3QuXG4gICAqL1xuICAgY2xvc2UodGltZW91dCkge1xuICAgIHJldHVybiB0aGlzLmZsdXNoKHRpbWVvdXQpLnRoZW4ocmVzdWx0ID0+IHtcbiAgICAgIHRoaXMuZ2V0T3B0aW9ucygpLmVuYWJsZWQgPSBmYWxzZTtcbiAgICAgIHRoaXMuZW1pdCgnY2xvc2UnKTtcbiAgICAgIHJldHVybiByZXN1bHQ7XG4gICAgfSk7XG4gIH1cblxuICAvKipcbiAgICogR2V0IGFsbCBpbnN0YWxsZWQgZXZlbnQgcHJvY2Vzc29ycy5cbiAgICovXG4gICBnZXRFdmVudFByb2Nlc3NvcnMoKSB7XG4gICAgcmV0dXJuIHRoaXMuX2V2ZW50UHJvY2Vzc29ycztcbiAgfVxuXG4gIC8qKlxuICAgKiBBZGRzIGFuIGV2ZW50IHByb2Nlc3NvciB0aGF0IGFwcGxpZXMgdG8gYW55IGV2ZW50IHByb2Nlc3NlZCBieSB0aGlzIGNsaWVudC5cbiAgICovXG4gICBhZGRFdmVudFByb2Nlc3NvcihldmVudFByb2Nlc3Nvcikge1xuICAgIHRoaXMuX2V2ZW50UHJvY2Vzc29ycy5wdXNoKGV2ZW50UHJvY2Vzc29yKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBJbml0aWFsaXplIHRoaXMgY2xpZW50LlxuICAgKiBDYWxsIHRoaXMgYWZ0ZXIgdGhlIGNsaWVudCB3YXMgc2V0IG9uIGEgc2NvcGUuXG4gICAqL1xuICAgaW5pdCgpIHtcbiAgICBpZiAoXG4gICAgICB0aGlzLl9pc0VuYWJsZWQoKSB8fFxuICAgICAgLy8gRm9yY2UgaW50ZWdyYXRpb25zIHRvIGJlIHNldHVwIGV2ZW4gaWYgbm8gRFNOIHdhcyBzZXQgd2hlbiB3ZSBoYXZlXG4gICAgICAvLyBTcG90bGlnaHQgZW5hYmxlZC4gVGhpcyBpcyBwYXJ0aWN1bGFybHkgaW1wb3J0YW50IGZvciBicm93c2VyIGFzIHdlXG4gICAgICAvLyBkb24ndCBzdXBwb3J0IHRoZSBgc3BvdGxpZ2h0YCBvcHRpb24gdGhlcmUgYW5kIHJlbHkgb24gdGhlIHVzZXJzXG4gICAgICAvLyBhZGRpbmcgdGhlIGBzcG90bGlnaHRCcm93c2VySW50ZWdyYXRpb24oKWAgdG8gdGhlaXIgaW50ZWdyYXRpb25zIHdoaWNoXG4gICAgICAvLyB3b3VsZG4ndCBnZXQgaW5pdGlhbGl6ZWQgd2l0aCB0aGUgY2hlY2sgYmVsb3cgd2hlbiB0aGVyZSdzIG5vIERTTiBzZXQuXG4gICAgICB0aGlzLl9vcHRpb25zLmludGVncmF0aW9ucy5zb21lKCh7IG5hbWUgfSkgPT4gbmFtZS5zdGFydHNXaXRoKCdTcG90bGlnaHQnKSlcbiAgICApIHtcbiAgICAgIHRoaXMuX3NldHVwSW50ZWdyYXRpb25zKCk7XG4gICAgfVxuICB9XG5cbiAgLyoqXG4gICAqIEdldHMgYW4gaW5zdGFsbGVkIGludGVncmF0aW9uIGJ5IGl0cyBuYW1lLlxuICAgKlxuICAgKiBAcmV0dXJucyB7SW50ZWdyYXRpb258dW5kZWZpbmVkfSBUaGUgaW5zdGFsbGVkIGludGVncmF0aW9uIG9yIGB1bmRlZmluZWRgIGlmIG5vIGludGVncmF0aW9uIHdpdGggdGhhdCBgbmFtZWAgd2FzIGluc3RhbGxlZC5cbiAgICovXG4gICBnZXRJbnRlZ3JhdGlvbkJ5TmFtZShpbnRlZ3JhdGlvbk5hbWUpIHtcbiAgICByZXR1cm4gdGhpcy5faW50ZWdyYXRpb25zW2ludGVncmF0aW9uTmFtZV0gO1xuICB9XG5cbiAgLyoqXG4gICAqIEFkZCBhbiBpbnRlZ3JhdGlvbiB0byB0aGUgY2xpZW50LlxuICAgKiBUaGlzIGNhbiBiZSB1c2VkIHRvIGUuZy4gbGF6eSBsb2FkIGludGVncmF0aW9ucy5cbiAgICogSW4gbW9zdCBjYXNlcywgdGhpcyBzaG91bGQgbm90IGJlIG5lY2Vzc2FyeSxcbiAgICogYW5kIHlvdSdyZSBiZXR0ZXIgb2ZmIGp1c3QgcGFzc2luZyB0aGUgaW50ZWdyYXRpb25zIHZpYSBgaW50ZWdyYXRpb25zOiBbXWAgYXQgaW5pdGlhbGl6YXRpb24gdGltZS5cbiAgICogSG93ZXZlciwgaWYgeW91IGZpbmQgdGhlIG5lZWQgdG8gY29uZGl0aW9uYWxseSBsb2FkICYgYWRkIGFuIGludGVncmF0aW9uLCB5b3UgY2FuIHVzZSBgYWRkSW50ZWdyYXRpb25gIHRvIGRvIHNvLlxuICAgKi9cbiAgIGFkZEludGVncmF0aW9uKGludGVncmF0aW9uJDEpIHtcbiAgICBjb25zdCBpc0FscmVhZHlJbnN0YWxsZWQgPSB0aGlzLl9pbnRlZ3JhdGlvbnNbaW50ZWdyYXRpb24kMS5uYW1lXTtcblxuICAgIC8vIFRoaXMgaG9vayB0YWtlcyBjYXJlIG9mIG9ubHkgaW5zdGFsbGluZyBpZiBub3QgYWxyZWFkeSBpbnN0YWxsZWRcbiAgICBpbnRlZ3JhdGlvbi5zZXR1cEludGVncmF0aW9uKHRoaXMsIGludGVncmF0aW9uJDEsIHRoaXMuX2ludGVncmF0aW9ucyk7XG4gICAgLy8gSGVyZSB3ZSBuZWVkIHRvIGNoZWNrIG1hbnVhbGx5IHRvIG1ha2Ugc3VyZSB0byBub3QgcnVuIHRoaXMgbXVsdGlwbGUgdGltZXNcbiAgICBpZiAoIWlzQWxyZWFkeUluc3RhbGxlZCkge1xuICAgICAgaW50ZWdyYXRpb24uYWZ0ZXJTZXR1cEludGVncmF0aW9ucyh0aGlzLCBbaW50ZWdyYXRpb24kMV0pO1xuICAgIH1cbiAgfVxuXG4gIC8qKlxuICAgKiBTZW5kIGEgZnVsbHkgcHJlcGFyZWQgZXZlbnQgdG8gU2VudHJ5LlxuICAgKi9cbiAgIHNlbmRFdmVudChldmVudCwgaGludCA9IHt9KSB7XG4gICAgdGhpcy5lbWl0KCdiZWZvcmVTZW5kRXZlbnQnLCBldmVudCwgaGludCk7XG5cbiAgICBsZXQgZW52ID0gZW52ZWxvcGUuY3JlYXRlRXZlbnRFbnZlbG9wZShldmVudCwgdGhpcy5fZHNuLCB0aGlzLl9vcHRpb25zLl9tZXRhZGF0YSwgdGhpcy5fb3B0aW9ucy50dW5uZWwpO1xuXG4gICAgZm9yIChjb25zdCBhdHRhY2htZW50IG9mIGhpbnQuYXR0YWNobWVudHMgfHwgW10pIHtcbiAgICAgIGVudiA9IGVudmVsb3BlJDEuYWRkSXRlbVRvRW52ZWxvcGUoZW52LCBlbnZlbG9wZSQxLmNyZWF0ZUF0dGFjaG1lbnRFbnZlbG9wZUl0ZW0oYXR0YWNobWVudCkpO1xuICAgIH1cblxuICAgIGNvbnN0IHByb21pc2UgPSB0aGlzLnNlbmRFbnZlbG9wZShlbnYpO1xuICAgIGlmIChwcm9taXNlKSB7XG4gICAgICBwcm9taXNlLnRoZW4oc2VuZFJlc3BvbnNlID0+IHRoaXMuZW1pdCgnYWZ0ZXJTZW5kRXZlbnQnLCBldmVudCwgc2VuZFJlc3BvbnNlKSwgbnVsbCk7XG4gICAgfVxuICB9XG5cbiAgLyoqXG4gICAqIFNlbmQgYSBzZXNzaW9uIG9yIHNlc3Npb24gYWdncmVncmF0ZXMgdG8gU2VudHJ5LlxuICAgKi9cbiAgIHNlbmRTZXNzaW9uKHNlc3Npb24pIHtcbiAgICAvLyBCYWNrZmlsbCByZWxlYXNlIGFuZCBlbnZpcm9ubWVudCBvbiBzZXNzaW9uXG4gICAgY29uc3QgeyByZWxlYXNlOiBjbGllbnRSZWxlYXNlT3B0aW9uLCBlbnZpcm9ubWVudDogY2xpZW50RW52aXJvbm1lbnRPcHRpb24gPSBjb25zdGFudHMuREVGQVVMVF9FTlZJUk9OTUVOVCB9ID0gdGhpcy5fb3B0aW9ucztcbiAgICBpZiAoJ2FnZ3JlZ2F0ZXMnIGluIHNlc3Npb24pIHtcbiAgICAgIGNvbnN0IHNlc3Npb25BdHRycyA9IHNlc3Npb24uYXR0cnMgfHwge307XG4gICAgICBpZiAoIXNlc3Npb25BdHRycy5yZWxlYXNlICYmICFjbGllbnRSZWxlYXNlT3B0aW9uKSB7XG4gICAgICAgIGRlYnVnQnVpbGQuREVCVUdfQlVJTEQgJiYgZGVidWdMb2dnZXIuZGVidWcud2FybihNSVNTSU5HX1JFTEVBU0VfRk9SX1NFU1NJT05fRVJST1IpO1xuICAgICAgICByZXR1cm47XG4gICAgICB9XG4gICAgICBzZXNzaW9uQXR0cnMucmVsZWFzZSA9IHNlc3Npb25BdHRycy5yZWxlYXNlIHx8IGNsaWVudFJlbGVhc2VPcHRpb247XG4gICAgICBzZXNzaW9uQXR0cnMuZW52aXJvbm1lbnQgPSBzZXNzaW9uQXR0cnMuZW52aXJvbm1lbnQgfHwgY2xpZW50RW52aXJvbm1lbnRPcHRpb247XG4gICAgICBzZXNzaW9uLmF0dHJzID0gc2Vzc2lvbkF0dHJzO1xuICAgIH0gZWxzZSB7XG4gICAgICBpZiAoIXNlc3Npb24ucmVsZWFzZSAmJiAhY2xpZW50UmVsZWFzZU9wdGlvbikge1xuICAgICAgICBkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEICYmIGRlYnVnTG9nZ2VyLmRlYnVnLndhcm4oTUlTU0lOR19SRUxFQVNFX0ZPUl9TRVNTSU9OX0VSUk9SKTtcbiAgICAgICAgcmV0dXJuO1xuICAgICAgfVxuICAgICAgc2Vzc2lvbi5yZWxlYXNlID0gc2Vzc2lvbi5yZWxlYXNlIHx8IGNsaWVudFJlbGVhc2VPcHRpb247XG4gICAgICBzZXNzaW9uLmVudmlyb25tZW50ID0gc2Vzc2lvbi5lbnZpcm9ubWVudCB8fCBjbGllbnRFbnZpcm9ubWVudE9wdGlvbjtcbiAgICB9XG5cbiAgICB0aGlzLmVtaXQoJ2JlZm9yZVNlbmRTZXNzaW9uJywgc2Vzc2lvbik7XG5cbiAgICBjb25zdCBlbnYgPSBlbnZlbG9wZS5jcmVhdGVTZXNzaW9uRW52ZWxvcGUoc2Vzc2lvbiwgdGhpcy5fZHNuLCB0aGlzLl9vcHRpb25zLl9tZXRhZGF0YSwgdGhpcy5fb3B0aW9ucy50dW5uZWwpO1xuXG4gICAgLy8gc2VuZEVudmVsb3BlIHNob3VsZCBub3QgdGhyb3dcbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25vLWZsb2F0aW5nLXByb21pc2VzXG4gICAgdGhpcy5zZW5kRW52ZWxvcGUoZW52KTtcbiAgfVxuXG4gIC8qKlxuICAgKiBSZWNvcmQgb24gdGhlIGNsaWVudCB0aGF0IGFuIGV2ZW50IGdvdCBkcm9wcGVkIChpZSwgYW4gZXZlbnQgdGhhdCB3aWxsIG5vdCBiZSBzZW50IHRvIFNlbnRyeSkuXG4gICAqL1xuICAgcmVjb3JkRHJvcHBlZEV2ZW50KHJlYXNvbiwgY2F0ZWdvcnksIGNvdW50ID0gMSkge1xuICAgIGlmICh0aGlzLl9vcHRpb25zLnNlbmRDbGllbnRSZXBvcnRzKSB7XG4gICAgICAvLyBXZSB3YW50IHRvIHRyYWNrIGVhY2ggY2F0ZWdvcnkgKGVycm9yLCB0cmFuc2FjdGlvbiwgc2Vzc2lvbiwgcmVwbGF5X2V2ZW50KSBzZXBhcmF0ZWx5XG4gICAgICAvLyBidXQgc3RpbGwga2VlcCB0aGUgZGlzdGluY3Rpb24gYmV0d2VlbiBkaWZmZXJlbnQgdHlwZSBvZiBvdXRjb21lcy5cbiAgICAgIC8vIFdlIGNvdWxkIHVzZSBuZXN0ZWQgbWFwcywgYnV0IGl0J3MgbXVjaCBlYXNpZXIgdG8gcmVhZCBhbmQgdHlwZSB0aGlzIHdheS5cbiAgICAgIC8vIEEgY29ycmVjdCB0eXBlIGZvciBtYXAtYmFzZWQgaW1wbGVtZW50YXRpb24gaWYgd2Ugd2FudCB0byBnbyB0aGF0IHJvdXRlXG4gICAgICAvLyB3b3VsZCBiZSBgUGFydGlhbDxSZWNvcmQ8U2VudHJ5UmVxdWVzdFR5cGUsIFBhcnRpYWw8UmVjb3JkPE91dGNvbWUsIG51bWJlcj4+Pj5gXG4gICAgICAvLyBXaXRoIHR5cGVzY3JpcHQgNC4xIHdlIGNvdWxkIGV2ZW4gdXNlIHRlbXBsYXRlIGxpdGVyYWwgdHlwZXNcbiAgICAgIGNvbnN0IGtleSA9IGAke3JlYXNvbn06JHtjYXRlZ29yeX1gO1xuICAgICAgZGVidWdCdWlsZC5ERUJVR19CVUlMRCAmJiBkZWJ1Z0xvZ2dlci5kZWJ1Zy5sb2coYFJlY29yZGluZyBvdXRjb21lOiBcIiR7a2V5fVwiJHtjb3VudCA+IDEgPyBgICgke2NvdW50fSB0aW1lcylgIDogJyd9YCk7XG4gICAgICB0aGlzLl9vdXRjb21lc1trZXldID0gKHRoaXMuX291dGNvbWVzW2tleV0gfHwgMCkgKyBjb3VudDtcbiAgICB9XG4gIH1cblxuICAvKiBlc2xpbnQtZGlzYWJsZSBAdHlwZXNjcmlwdC1lc2xpbnQvdW5pZmllZC1zaWduYXR1cmVzICovXG4gIC8qKlxuICAgKiBSZWdpc3RlciBhIGNhbGxiYWNrIGZvciB3aGVuZXZlciBhIHNwYW4gaXMgc3RhcnRlZC5cbiAgICogUmVjZWl2ZXMgdGhlIHNwYW4gYXMgYXJndW1lbnQuXG4gICAqIEByZXR1cm5zIHsoKSA9PiB2b2lkfSBBIGZ1bmN0aW9uIHRoYXQsIHdoZW4gZXhlY3V0ZWQsIHJlbW92ZXMgdGhlIHJlZ2lzdGVyZWQgY2FsbGJhY2suXG4gICAqL1xuXG4gIC8qKlxuICAgKiBSZWdpc3RlciBhIGhvb2sgb24gdGhpcyBjbGllbnQuXG4gICAqL1xuICAgb24oaG9vaywgY2FsbGJhY2spIHtcbiAgICBjb25zdCBob29rcyA9ICh0aGlzLl9ob29rc1tob29rXSA9IHRoaXMuX2hvb2tzW2hvb2tdIHx8IFtdKTtcblxuICAgIC8vIEB0cy1leHBlY3QtZXJyb3IgV2UgYXNzdW1lIHRoZSB0eXBlcyBhcmUgY29ycmVjdFxuICAgIGhvb2tzLnB1c2goY2FsbGJhY2spO1xuXG4gICAgLy8gVGhpcyBmdW5jdGlvbiByZXR1cm5zIGEgY2FsbGJhY2sgZXhlY3V0aW9uIGhhbmRsZXIgdGhhdCwgd2hlbiBpbnZva2VkLFxuICAgIC8vIGRlcmVnaXN0ZXJzIGEgY2FsbGJhY2suIFRoaXMgaXMgY3J1Y2lhbCBmb3IgbWFuYWdpbmcgaW5zdGFuY2VzIHdoZXJlIGNhbGxiYWNrc1xuICAgIC8vIG5lZWQgdG8gYmUgdW5yZWdpc3RlcmVkIHRvIHByZXZlbnQgc2VsZi1yZWZlcmVuY2luZyBpbiBjYWxsYmFjayBjbG9zdXJlcyxcbiAgICAvLyBlbnN1cmluZyBwcm9wZXIgZ2FyYmFnZSBjb2xsZWN0aW9uLlxuICAgIHJldHVybiAoKSA9PiB7XG4gICAgICAvLyBAdHMtZXhwZWN0LWVycm9yIFdlIGFzc3VtZSB0aGUgdHlwZXMgYXJlIGNvcnJlY3RcbiAgICAgIGNvbnN0IGNiSW5kZXggPSBob29rcy5pbmRleE9mKGNhbGxiYWNrKTtcbiAgICAgIGlmIChjYkluZGV4ID4gLTEpIHtcbiAgICAgICAgaG9va3Muc3BsaWNlKGNiSW5kZXgsIDEpO1xuICAgICAgfVxuICAgIH07XG4gIH1cblxuICAvKiogRmlyZSBhIGhvb2sgd2hlbmV2ZXIgYSBzcGFuIHN0YXJ0cy4gKi9cblxuICAvKipcbiAgICogRW1pdCBhIGhvb2sgdGhhdCB3YXMgcHJldmlvdXNseSByZWdpc3RlcmVkIHZpYSBgb24oKWAuXG4gICAqL1xuICAgZW1pdChob29rLCAuLi5yZXN0KSB7XG4gICAgY29uc3QgY2FsbGJhY2tzID0gdGhpcy5faG9va3NbaG9va107XG4gICAgaWYgKGNhbGxiYWNrcykge1xuICAgICAgY2FsbGJhY2tzLmZvckVhY2goY2FsbGJhY2sgPT4gY2FsbGJhY2soLi4ucmVzdCkpO1xuICAgIH1cbiAgfVxuXG4gIC8qKlxuICAgKiBTZW5kIGFuIGVudmVsb3BlIHRvIFNlbnRyeS5cbiAgICovXG4gICBzZW5kRW52ZWxvcGUoZW52ZWxvcGUpIHtcbiAgICB0aGlzLmVtaXQoJ2JlZm9yZUVudmVsb3BlJywgZW52ZWxvcGUpO1xuXG4gICAgaWYgKHRoaXMuX2lzRW5hYmxlZCgpICYmIHRoaXMuX3RyYW5zcG9ydCkge1xuICAgICAgcmV0dXJuIHRoaXMuX3RyYW5zcG9ydC5zZW5kKGVudmVsb3BlKS50aGVuKG51bGwsIHJlYXNvbiA9PiB7XG4gICAgICAgIGRlYnVnQnVpbGQuREVCVUdfQlVJTEQgJiYgZGVidWdMb2dnZXIuZGVidWcuZXJyb3IoJ0Vycm9yIHdoaWxlIHNlbmRpbmcgZW52ZWxvcGU6JywgcmVhc29uKTtcbiAgICAgICAgcmV0dXJuIHJlYXNvbjtcbiAgICAgIH0pO1xuICAgIH1cblxuICAgIGRlYnVnQnVpbGQuREVCVUdfQlVJTEQgJiYgZGVidWdMb2dnZXIuZGVidWcuZXJyb3IoJ1RyYW5zcG9ydCBkaXNhYmxlZCcpO1xuXG4gICAgcmV0dXJuIHN5bmNwcm9taXNlLnJlc29sdmVkU3luY1Byb21pc2Uoe30pO1xuICB9XG5cbiAgLyogZXNsaW50LWVuYWJsZSBAdHlwZXNjcmlwdC1lc2xpbnQvdW5pZmllZC1zaWduYXR1cmVzICovXG5cbiAgLyoqIFNldHVwIGludGVncmF0aW9ucyBmb3IgdGhpcyBjbGllbnQuICovXG4gICBfc2V0dXBJbnRlZ3JhdGlvbnMoKSB7XG4gICAgY29uc3QgeyBpbnRlZ3JhdGlvbnMgfSA9IHRoaXMuX29wdGlvbnM7XG4gICAgdGhpcy5faW50ZWdyYXRpb25zID0gaW50ZWdyYXRpb24uc2V0dXBJbnRlZ3JhdGlvbnModGhpcywgaW50ZWdyYXRpb25zKTtcbiAgICBpbnRlZ3JhdGlvbi5hZnRlclNldHVwSW50ZWdyYXRpb25zKHRoaXMsIGludGVncmF0aW9ucyk7XG4gIH1cblxuICAvKiogVXBkYXRlcyBleGlzdGluZyBzZXNzaW9uIGJhc2VkIG9uIHRoZSBwcm92aWRlZCBldmVudCAqL1xuICAgX3VwZGF0ZVNlc3Npb25Gcm9tRXZlbnQoc2Vzc2lvbiQxLCBldmVudCkge1xuICAgIGxldCBjcmFzaGVkID0gZXZlbnQubGV2ZWwgPT09ICdmYXRhbCc7XG4gICAgbGV0IGVycm9yZWQgPSBmYWxzZTtcbiAgICBjb25zdCBleGNlcHRpb25zID0gZXZlbnQuZXhjZXB0aW9uPy52YWx1ZXM7XG5cbiAgICBpZiAoZXhjZXB0aW9ucykge1xuICAgICAgZXJyb3JlZCA9IHRydWU7XG5cbiAgICAgIGZvciAoY29uc3QgZXggb2YgZXhjZXB0aW9ucykge1xuICAgICAgICBjb25zdCBtZWNoYW5pc20gPSBleC5tZWNoYW5pc207XG4gICAgICAgIGlmIChtZWNoYW5pc20/LmhhbmRsZWQgPT09IGZhbHNlKSB7XG4gICAgICAgICAgY3Jhc2hlZCA9IHRydWU7XG4gICAgICAgICAgYnJlYWs7XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9XG5cbiAgICAvLyBBIHNlc3Npb24gaXMgdXBkYXRlZCBhbmQgdGhhdCBzZXNzaW9uIHVwZGF0ZSBpcyBzZW50IGluIG9ubHkgb25lIG9mIHRoZSB0d28gZm9sbG93aW5nIHNjZW5hcmlvczpcbiAgICAvLyAxLiBTZXNzaW9uIHdpdGggbm9uIHRlcm1pbmFsIHN0YXR1cyBhbmQgMCBlcnJvcnMgKyBhbiBlcnJvciBvY2N1cnJlZCAtPiBXaWxsIHNldCBlcnJvciBjb3VudCB0byAxIGFuZCBzZW5kIHVwZGF0ZVxuICAgIC8vIDIuIFNlc3Npb24gd2l0aCBub24gdGVybWluYWwgc3RhdHVzIGFuZCAxIGVycm9yICsgYSBjcmFzaCBvY2N1cnJlZCAtPiBXaWxsIHNldCBzdGF0dXMgY3Jhc2hlZCBhbmQgc2VuZCB1cGRhdGVcbiAgICBjb25zdCBzZXNzaW9uTm9uVGVybWluYWwgPSBzZXNzaW9uJDEuc3RhdHVzID09PSAnb2snO1xuICAgIGNvbnN0IHNob3VsZFVwZGF0ZUFuZFNlbmQgPSAoc2Vzc2lvbk5vblRlcm1pbmFsICYmIHNlc3Npb24kMS5lcnJvcnMgPT09IDApIHx8IChzZXNzaW9uTm9uVGVybWluYWwgJiYgY3Jhc2hlZCk7XG5cbiAgICBpZiAoc2hvdWxkVXBkYXRlQW5kU2VuZCkge1xuICAgICAgc2Vzc2lvbi51cGRhdGVTZXNzaW9uKHNlc3Npb24kMSwge1xuICAgICAgICAuLi4oY3Jhc2hlZCAmJiB7IHN0YXR1czogJ2NyYXNoZWQnIH0pLFxuICAgICAgICBlcnJvcnM6IHNlc3Npb24kMS5lcnJvcnMgfHwgTnVtYmVyKGVycm9yZWQgfHwgY3Jhc2hlZCksXG4gICAgICB9KTtcbiAgICAgIHRoaXMuY2FwdHVyZVNlc3Npb24oc2Vzc2lvbiQxKTtcbiAgICB9XG4gIH1cblxuICAvKipcbiAgICogRGV0ZXJtaW5lIGlmIHRoZSBjbGllbnQgaXMgZmluaXNoZWQgcHJvY2Vzc2luZy4gUmV0dXJucyBhIHByb21pc2UgYmVjYXVzZSBpdCB3aWxsIHdhaXQgYHRpbWVvdXRgIG1zIGJlZm9yZSBzYXlpbmdcbiAgICogXCJub1wiIChyZXNvbHZpbmcgdG8gYGZhbHNlYCkgaW4gb3JkZXIgdG8gZ2l2ZSB0aGUgY2xpZW50IGEgY2hhbmNlIHRvIHBvdGVudGlhbGx5IGZpbmlzaCBmaXJzdC5cbiAgICpcbiAgICogQHBhcmFtIHRpbWVvdXQgVGhlIHRpbWUsIGluIG1zLCBhZnRlciB3aGljaCB0byByZXNvbHZlIHRvIGBmYWxzZWAgaWYgdGhlIGNsaWVudCBpcyBzdGlsbCBidXN5LiBQYXNzaW5nIGAwYCAob3Igbm90XG4gICAqIHBhc3NpbmcgYW55dGhpbmcpIHdpbGwgbWFrZSB0aGUgcHJvbWlzZSB3YWl0IGFzIGxvbmcgYXMgaXQgdGFrZXMgZm9yIHByb2Nlc3NpbmcgdG8gZmluaXNoIGJlZm9yZSByZXNvbHZpbmcgdG9cbiAgICogYHRydWVgLlxuICAgKiBAcmV0dXJucyBBIHByb21pc2Ugd2hpY2ggd2lsbCByZXNvbHZlIHRvIGB0cnVlYCBpZiBwcm9jZXNzaW5nIGlzIGFscmVhZHkgZG9uZSBvciBmaW5pc2hlcyBiZWZvcmUgdGhlIHRpbWVvdXQsIGFuZFxuICAgKiBgZmFsc2VgIG90aGVyd2lzZVxuICAgKi9cbiAgIF9pc0NsaWVudERvbmVQcm9jZXNzaW5nKHRpbWVvdXQpIHtcbiAgICByZXR1cm4gbmV3IHN5bmNwcm9taXNlLlN5bmNQcm9taXNlKHJlc29sdmUgPT4ge1xuICAgICAgbGV0IHRpY2tlZCA9IDA7XG4gICAgICBjb25zdCB0aWNrID0gMTtcblxuICAgICAgY29uc3QgaW50ZXJ2YWwgPSBzZXRJbnRlcnZhbCgoKSA9PiB7XG4gICAgICAgIGlmICh0aGlzLl9udW1Qcm9jZXNzaW5nID09IDApIHtcbiAgICAgICAgICBjbGVhckludGVydmFsKGludGVydmFsKTtcbiAgICAgICAgICByZXNvbHZlKHRydWUpO1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgIHRpY2tlZCArPSB0aWNrO1xuICAgICAgICAgIGlmICh0aW1lb3V0ICYmIHRpY2tlZCA+PSB0aW1lb3V0KSB7XG4gICAgICAgICAgICBjbGVhckludGVydmFsKGludGVydmFsKTtcbiAgICAgICAgICAgIHJlc29sdmUoZmFsc2UpO1xuICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgfSwgdGljayk7XG4gICAgfSk7XG4gIH1cblxuICAvKiogRGV0ZXJtaW5lcyB3aGV0aGVyIHRoaXMgU0RLIGlzIGVuYWJsZWQgYW5kIGEgdHJhbnNwb3J0IGlzIHByZXNlbnQuICovXG4gICBfaXNFbmFibGVkKCkge1xuICAgIHJldHVybiB0aGlzLmdldE9wdGlvbnMoKS5lbmFibGVkICE9PSBmYWxzZSAmJiB0aGlzLl90cmFuc3BvcnQgIT09IHVuZGVmaW5lZDtcbiAgfVxuXG4gIC8qKlxuICAgKiBBZGRzIGNvbW1vbiBpbmZvcm1hdGlvbiB0byBldmVudHMuXG4gICAqXG4gICAqIFRoZSBpbmZvcm1hdGlvbiBpbmNsdWRlcyByZWxlYXNlIGFuZCBlbnZpcm9ubWVudCBmcm9tIGBvcHRpb25zYCxcbiAgICogYnJlYWRjcnVtYnMgYW5kIGNvbnRleHQgKGV4dHJhLCB0YWdzIGFuZCB1c2VyKSBmcm9tIHRoZSBzY29wZS5cbiAgICpcbiAgICogSW5mb3JtYXRpb24gdGhhdCBpcyBhbHJlYWR5IHByZXNlbnQgaW4gdGhlIGV2ZW50IGlzIG5ldmVyIG92ZXJ3cml0dGVuLiBGb3JcbiAgICogbmVzdGVkIG9iamVjdHMsIHN1Y2ggYXMgdGhlIGNvbnRleHQsIGtleXMgYXJlIG1lcmdlZC5cbiAgICpcbiAgICogQHBhcmFtIGV2ZW50IFRoZSBvcmlnaW5hbCBldmVudC5cbiAgICogQHBhcmFtIGhpbnQgTWF5IGNvbnRhaW4gYWRkaXRpb25hbCBpbmZvcm1hdGlvbiBhYm91dCB0aGUgb3JpZ2luYWwgZXhjZXB0aW9uLlxuICAgKiBAcGFyYW0gY3VycmVudFNjb3BlIEEgc2NvcGUgY29udGFpbmluZyBldmVudCBtZXRhZGF0YS5cbiAgICogQHJldHVybnMgQSBuZXcgZXZlbnQgd2l0aCBtb3JlIGluZm9ybWF0aW9uLlxuICAgKi9cbiAgIF9wcmVwYXJlRXZlbnQoXG4gICAgZXZlbnQsXG4gICAgaGludCxcbiAgICBjdXJyZW50U2NvcGUsXG4gICAgaXNvbGF0aW9uU2NvcGUsXG4gICkge1xuICAgIGNvbnN0IG9wdGlvbnMgPSB0aGlzLmdldE9wdGlvbnMoKTtcbiAgICBjb25zdCBpbnRlZ3JhdGlvbnMgPSBPYmplY3Qua2V5cyh0aGlzLl9pbnRlZ3JhdGlvbnMpO1xuICAgIGlmICghaGludC5pbnRlZ3JhdGlvbnMgJiYgaW50ZWdyYXRpb25zPy5sZW5ndGgpIHtcbiAgICAgIGhpbnQuaW50ZWdyYXRpb25zID0gaW50ZWdyYXRpb25zO1xuICAgIH1cblxuICAgIHRoaXMuZW1pdCgncHJlcHJvY2Vzc0V2ZW50JywgZXZlbnQsIGhpbnQpO1xuXG4gICAgaWYgKCFldmVudC50eXBlKSB7XG4gICAgICBpc29sYXRpb25TY29wZS5zZXRMYXN0RXZlbnRJZChldmVudC5ldmVudF9pZCB8fCBoaW50LmV2ZW50X2lkKTtcbiAgICB9XG5cbiAgICByZXR1cm4gcHJlcGFyZUV2ZW50LnByZXBhcmVFdmVudChvcHRpb25zLCBldmVudCwgaGludCwgY3VycmVudFNjb3BlLCB0aGlzLCBpc29sYXRpb25TY29wZSkudGhlbihldnQgPT4ge1xuICAgICAgaWYgKGV2dCA9PT0gbnVsbCkge1xuICAgICAgICByZXR1cm4gZXZ0O1xuICAgICAgfVxuXG4gICAgICB0aGlzLmVtaXQoJ3Bvc3Rwcm9jZXNzRXZlbnQnLCBldnQsIGhpbnQpO1xuXG4gICAgICBldnQuY29udGV4dHMgPSB7XG4gICAgICAgIHRyYWNlOiBjdXJyZW50U2NvcGVzLmdldFRyYWNlQ29udGV4dEZyb21TY29wZShjdXJyZW50U2NvcGUpLFxuICAgICAgICAuLi5ldnQuY29udGV4dHMsXG4gICAgICB9O1xuXG4gICAgICBjb25zdCBkeW5hbWljU2FtcGxpbmdDb250ZXh0JDEgPSBkeW5hbWljU2FtcGxpbmdDb250ZXh0LmdldER5bmFtaWNTYW1wbGluZ0NvbnRleHRGcm9tU2NvcGUodGhpcywgY3VycmVudFNjb3BlKTtcblxuICAgICAgZXZ0LnNka1Byb2Nlc3NpbmdNZXRhZGF0YSA9IHtcbiAgICAgICAgZHluYW1pY1NhbXBsaW5nQ29udGV4dDogZHluYW1pY1NhbXBsaW5nQ29udGV4dCQxLFxuICAgICAgICAuLi5ldnQuc2RrUHJvY2Vzc2luZ01ldGFkYXRhLFxuICAgICAgfTtcblxuICAgICAgcmV0dXJuIGV2dDtcbiAgICB9KTtcbiAgfVxuXG4gIC8qKlxuICAgKiBQcm9jZXNzZXMgdGhlIGV2ZW50IGFuZCBsb2dzIGFuIGVycm9yIGluIGNhc2Ugb2YgcmVqZWN0aW9uXG4gICAqIEBwYXJhbSBldmVudFxuICAgKiBAcGFyYW0gaGludFxuICAgKiBAcGFyYW0gc2NvcGVcbiAgICovXG4gICBfY2FwdHVyZUV2ZW50KFxuICAgIGV2ZW50LFxuICAgIGhpbnQgPSB7fSxcbiAgICBjdXJyZW50U2NvcGUgPSBjdXJyZW50U2NvcGVzLmdldEN1cnJlbnRTY29wZSgpLFxuICAgIGlzb2xhdGlvblNjb3BlID0gY3VycmVudFNjb3Blcy5nZXRJc29sYXRpb25TY29wZSgpLFxuICApIHtcbiAgICBpZiAoZGVidWdCdWlsZC5ERUJVR19CVUlMRCAmJiBpc0Vycm9yRXZlbnQoZXZlbnQpKSB7XG4gICAgICBkZWJ1Z0xvZ2dlci5kZWJ1Zy5sb2coYENhcHR1cmVkIGVycm9yIGV2ZW50IFxcYCR7ZXZlbnRVdGlscy5nZXRQb3NzaWJsZUV2ZW50TWVzc2FnZXMoZXZlbnQpWzBdIHx8ICc8dW5rbm93bj4nfVxcYGApO1xuICAgIH1cblxuICAgIHJldHVybiB0aGlzLl9wcm9jZXNzRXZlbnQoZXZlbnQsIGhpbnQsIGN1cnJlbnRTY29wZSwgaXNvbGF0aW9uU2NvcGUpLnRoZW4oXG4gICAgICBmaW5hbEV2ZW50ID0+IHtcbiAgICAgICAgcmV0dXJuIGZpbmFsRXZlbnQuZXZlbnRfaWQ7XG4gICAgICB9LFxuICAgICAgcmVhc29uID0+IHtcbiAgICAgICAgaWYgKGRlYnVnQnVpbGQuREVCVUdfQlVJTEQpIHtcbiAgICAgICAgICBpZiAoX2lzRG9Ob3RTZW5kRXZlbnRFcnJvcihyZWFzb24pKSB7XG4gICAgICAgICAgICBkZWJ1Z0xvZ2dlci5kZWJ1Zy5sb2cocmVhc29uLm1lc3NhZ2UpO1xuICAgICAgICAgIH0gZWxzZSBpZiAoX2lzSW50ZXJuYWxFcnJvcihyZWFzb24pKSB7XG4gICAgICAgICAgICBkZWJ1Z0xvZ2dlci5kZWJ1Zy53YXJuKHJlYXNvbi5tZXNzYWdlKTtcbiAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgZGVidWdMb2dnZXIuZGVidWcud2FybihyZWFzb24pO1xuICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gdW5kZWZpbmVkO1xuICAgICAgfSxcbiAgICApO1xuICB9XG5cbiAgLyoqXG4gICAqIFByb2Nlc3NlcyBhbiBldmVudCAoZWl0aGVyIGVycm9yIG9yIG1lc3NhZ2UpIGFuZCBzZW5kcyBpdCB0byBTZW50cnkuXG4gICAqXG4gICAqIFRoaXMgYWxzbyBhZGRzIGJyZWFkY3J1bWJzIGFuZCBjb250ZXh0IGluZm9ybWF0aW9uIHRvIHRoZSBldmVudC4gSG93ZXZlcixcbiAgICogcGxhdGZvcm0gc3BlY2lmaWMgbWV0YSBkYXRhIChzdWNoIGFzIHRoZSBVc2VyJ3MgSVAgYWRkcmVzcykgbXVzdCBiZSBhZGRlZFxuICAgKiBieSB0aGUgU0RLIGltcGxlbWVudG9yLlxuICAgKlxuICAgKlxuICAgKiBAcGFyYW0gZXZlbnQgVGhlIGV2ZW50IHRvIHNlbmQgdG8gU2VudHJ5LlxuICAgKiBAcGFyYW0gaGludCBNYXkgY29udGFpbiBhZGRpdGlvbmFsIGluZm9ybWF0aW9uIGFib3V0IHRoZSBvcmlnaW5hbCBleGNlcHRpb24uXG4gICAqIEBwYXJhbSBjdXJyZW50U2NvcGUgQSBzY29wZSBjb250YWluaW5nIGV2ZW50IG1ldGFkYXRhLlxuICAgKiBAcmV0dXJucyBBIFN5bmNQcm9taXNlIHRoYXQgcmVzb2x2ZXMgd2l0aCB0aGUgZXZlbnQgb3IgcmVqZWN0cyBpbiBjYXNlIGV2ZW50IHdhcy93aWxsIG5vdCBiZSBzZW5kLlxuICAgKi9cbiAgIF9wcm9jZXNzRXZlbnQoXG4gICAgZXZlbnQsXG4gICAgaGludCxcbiAgICBjdXJyZW50U2NvcGUsXG4gICAgaXNvbGF0aW9uU2NvcGUsXG4gICkge1xuICAgIGNvbnN0IG9wdGlvbnMgPSB0aGlzLmdldE9wdGlvbnMoKTtcbiAgICBjb25zdCB7IHNhbXBsZVJhdGUgfSA9IG9wdGlvbnM7XG5cbiAgICBjb25zdCBpc1RyYW5zYWN0aW9uID0gaXNUcmFuc2FjdGlvbkV2ZW50KGV2ZW50KTtcbiAgICBjb25zdCBpc0Vycm9yID0gaXNFcnJvckV2ZW50KGV2ZW50KTtcbiAgICBjb25zdCBldmVudFR5cGUgPSBldmVudC50eXBlIHx8ICdlcnJvcic7XG4gICAgY29uc3QgYmVmb3JlU2VuZExhYmVsID0gYGJlZm9yZSBzZW5kIGZvciB0eXBlIFxcYCR7ZXZlbnRUeXBlfVxcYGA7XG5cbiAgICAvLyAxLjAgPT09IDEwMCUgZXZlbnRzIGFyZSBzZW50XG4gICAgLy8gMC4wID09PSAwJSBldmVudHMgYXJlIHNlbnRcbiAgICAvLyBTYW1wbGluZyBmb3IgdHJhbnNhY3Rpb24gaGFwcGVucyBzb21ld2hlcmUgZWxzZVxuICAgIGNvbnN0IHBhcnNlZFNhbXBsZVJhdGUgPSB0eXBlb2Ygc2FtcGxlUmF0ZSA9PT0gJ3VuZGVmaW5lZCcgPyB1bmRlZmluZWQgOiBwYXJzZVNhbXBsZVJhdGUucGFyc2VTYW1wbGVSYXRlKHNhbXBsZVJhdGUpO1xuICAgIGlmIChpc0Vycm9yICYmIHR5cGVvZiBwYXJzZWRTYW1wbGVSYXRlID09PSAnbnVtYmVyJyAmJiBNYXRoLnJhbmRvbSgpID4gcGFyc2VkU2FtcGxlUmF0ZSkge1xuICAgICAgdGhpcy5yZWNvcmREcm9wcGVkRXZlbnQoJ3NhbXBsZV9yYXRlJywgJ2Vycm9yJyk7XG4gICAgICByZXR1cm4gc3luY3Byb21pc2UucmVqZWN0ZWRTeW5jUHJvbWlzZShcbiAgICAgICAgX21ha2VEb05vdFNlbmRFdmVudEVycm9yKFxuICAgICAgICAgIGBEaXNjYXJkaW5nIGV2ZW50IGJlY2F1c2UgaXQncyBub3QgaW5jbHVkZWQgaW4gdGhlIHJhbmRvbSBzYW1wbGUgKHNhbXBsaW5nIHJhdGUgPSAke3NhbXBsZVJhdGV9KWAsXG4gICAgICAgICksXG4gICAgICApO1xuICAgIH1cblxuICAgIGNvbnN0IGRhdGFDYXRlZ29yeSA9IChldmVudFR5cGUgPT09ICdyZXBsYXlfZXZlbnQnID8gJ3JlcGxheScgOiBldmVudFR5cGUpIDtcblxuICAgIHJldHVybiB0aGlzLl9wcmVwYXJlRXZlbnQoZXZlbnQsIGhpbnQsIGN1cnJlbnRTY29wZSwgaXNvbGF0aW9uU2NvcGUpXG4gICAgICAudGhlbihwcmVwYXJlZCA9PiB7XG4gICAgICAgIGlmIChwcmVwYXJlZCA9PT0gbnVsbCkge1xuICAgICAgICAgIHRoaXMucmVjb3JkRHJvcHBlZEV2ZW50KCdldmVudF9wcm9jZXNzb3InLCBkYXRhQ2F0ZWdvcnkpO1xuICAgICAgICAgIHRocm93IF9tYWtlRG9Ob3RTZW5kRXZlbnRFcnJvcignQW4gZXZlbnQgcHJvY2Vzc29yIHJldHVybmVkIGBudWxsYCwgd2lsbCBub3Qgc2VuZCBldmVudC4nKTtcbiAgICAgICAgfVxuXG4gICAgICAgIGNvbnN0IGlzSW50ZXJuYWxFeGNlcHRpb24gPSBoaW50LmRhdGEgJiYgKGhpbnQuZGF0YSApLl9fc2VudHJ5X18gPT09IHRydWU7XG4gICAgICAgIGlmIChpc0ludGVybmFsRXhjZXB0aW9uKSB7XG4gICAgICAgICAgcmV0dXJuIHByZXBhcmVkO1xuICAgICAgICB9XG5cbiAgICAgICAgY29uc3QgcmVzdWx0ID0gcHJvY2Vzc0JlZm9yZVNlbmQodGhpcywgb3B0aW9ucywgcHJlcGFyZWQsIGhpbnQpO1xuICAgICAgICByZXR1cm4gX3ZhbGlkYXRlQmVmb3JlU2VuZFJlc3VsdChyZXN1bHQsIGJlZm9yZVNlbmRMYWJlbCk7XG4gICAgICB9KVxuICAgICAgLnRoZW4ocHJvY2Vzc2VkRXZlbnQgPT4ge1xuICAgICAgICBpZiAocHJvY2Vzc2VkRXZlbnQgPT09IG51bGwpIHtcbiAgICAgICAgICB0aGlzLnJlY29yZERyb3BwZWRFdmVudCgnYmVmb3JlX3NlbmQnLCBkYXRhQ2F0ZWdvcnkpO1xuICAgICAgICAgIGlmIChpc1RyYW5zYWN0aW9uKSB7XG4gICAgICAgICAgICBjb25zdCBzcGFucyA9IGV2ZW50LnNwYW5zIHx8IFtdO1xuICAgICAgICAgICAgLy8gdGhlIHRyYW5zYWN0aW9uIGl0c2VsZiBjb3VudHMgYXMgb25lIHNwYW4sIHBsdXMgYWxsIHRoZSBjaGlsZCBzcGFucyB0aGF0IGFyZSBhZGRlZFxuICAgICAgICAgICAgY29uc3Qgc3BhbkNvdW50ID0gMSArIHNwYW5zLmxlbmd0aDtcbiAgICAgICAgICAgIHRoaXMucmVjb3JkRHJvcHBlZEV2ZW50KCdiZWZvcmVfc2VuZCcsICdzcGFuJywgc3BhbkNvdW50KTtcbiAgICAgICAgICB9XG4gICAgICAgICAgdGhyb3cgX21ha2VEb05vdFNlbmRFdmVudEVycm9yKGAke2JlZm9yZVNlbmRMYWJlbH0gcmV0dXJuZWQgXFxgbnVsbFxcYCwgd2lsbCBub3Qgc2VuZCBldmVudC5gKTtcbiAgICAgICAgfVxuXG4gICAgICAgIGNvbnN0IHNlc3Npb24gPSBjdXJyZW50U2NvcGUuZ2V0U2Vzc2lvbigpIHx8IGlzb2xhdGlvblNjb3BlLmdldFNlc3Npb24oKTtcbiAgICAgICAgaWYgKGlzRXJyb3IgJiYgc2Vzc2lvbikge1xuICAgICAgICAgIHRoaXMuX3VwZGF0ZVNlc3Npb25Gcm9tRXZlbnQoc2Vzc2lvbiwgcHJvY2Vzc2VkRXZlbnQpO1xuICAgICAgICB9XG5cbiAgICAgICAgaWYgKGlzVHJhbnNhY3Rpb24pIHtcbiAgICAgICAgICBjb25zdCBzcGFuQ291bnRCZWZvcmUgPSBwcm9jZXNzZWRFdmVudC5zZGtQcm9jZXNzaW5nTWV0YWRhdGE/LnNwYW5Db3VudEJlZm9yZVByb2Nlc3NpbmcgfHwgMDtcbiAgICAgICAgICBjb25zdCBzcGFuQ291bnRBZnRlciA9IHByb2Nlc3NlZEV2ZW50LnNwYW5zID8gcHJvY2Vzc2VkRXZlbnQuc3BhbnMubGVuZ3RoIDogMDtcblxuICAgICAgICAgIGNvbnN0IGRyb3BwZWRTcGFuQ291bnQgPSBzcGFuQ291bnRCZWZvcmUgLSBzcGFuQ291bnRBZnRlcjtcbiAgICAgICAgICBpZiAoZHJvcHBlZFNwYW5Db3VudCA+IDApIHtcbiAgICAgICAgICAgIHRoaXMucmVjb3JkRHJvcHBlZEV2ZW50KCdiZWZvcmVfc2VuZCcsICdzcGFuJywgZHJvcHBlZFNwYW5Db3VudCk7XG4gICAgICAgICAgfVxuICAgICAgICB9XG5cbiAgICAgICAgLy8gTm9uZSBvZiB0aGUgU2VudHJ5IGJ1aWx0IGV2ZW50IHByb2Nlc3NvciB3aWxsIHVwZGF0ZSB0cmFuc2FjdGlvbiBuYW1lLFxuICAgICAgICAvLyBzbyBpZiB0aGUgdHJhbnNhY3Rpb24gbmFtZSBoYXMgYmVlbiBjaGFuZ2VkIGJ5IGFuIGV2ZW50IHByb2Nlc3Nvciwgd2Uga25vd1xuICAgICAgICAvLyBpdCBoYXMgdG8gY29tZSBmcm9tIGN1c3RvbSBldmVudCBwcm9jZXNzb3IgYWRkZWQgYnkgYSB1c2VyXG4gICAgICAgIGNvbnN0IHRyYW5zYWN0aW9uSW5mbyA9IHByb2Nlc3NlZEV2ZW50LnRyYW5zYWN0aW9uX2luZm87XG4gICAgICAgIGlmIChpc1RyYW5zYWN0aW9uICYmIHRyYW5zYWN0aW9uSW5mbyAmJiBwcm9jZXNzZWRFdmVudC50cmFuc2FjdGlvbiAhPT0gZXZlbnQudHJhbnNhY3Rpb24pIHtcbiAgICAgICAgICBjb25zdCBzb3VyY2UgPSAnY3VzdG9tJztcbiAgICAgICAgICBwcm9jZXNzZWRFdmVudC50cmFuc2FjdGlvbl9pbmZvID0ge1xuICAgICAgICAgICAgLi4udHJhbnNhY3Rpb25JbmZvLFxuICAgICAgICAgICAgc291cmNlLFxuICAgICAgICAgIH07XG4gICAgICAgIH1cblxuICAgICAgICB0aGlzLnNlbmRFdmVudChwcm9jZXNzZWRFdmVudCwgaGludCk7XG4gICAgICAgIHJldHVybiBwcm9jZXNzZWRFdmVudDtcbiAgICAgIH0pXG4gICAgICAudGhlbihudWxsLCByZWFzb24gPT4ge1xuICAgICAgICBpZiAoX2lzRG9Ob3RTZW5kRXZlbnRFcnJvcihyZWFzb24pIHx8IF9pc0ludGVybmFsRXJyb3IocmVhc29uKSkge1xuICAgICAgICAgIHRocm93IHJlYXNvbjtcbiAgICAgICAgfVxuXG4gICAgICAgIHRoaXMuY2FwdHVyZUV4Y2VwdGlvbihyZWFzb24sIHtcbiAgICAgICAgICBkYXRhOiB7XG4gICAgICAgICAgICBfX3NlbnRyeV9fOiB0cnVlLFxuICAgICAgICAgIH0sXG4gICAgICAgICAgb3JpZ2luYWxFeGNlcHRpb246IHJlYXNvbixcbiAgICAgICAgfSk7XG4gICAgICAgIHRocm93IF9tYWtlSW50ZXJuYWxFcnJvcihcbiAgICAgICAgICBgRXZlbnQgcHJvY2Vzc2luZyBwaXBlbGluZSB0aHJldyBhbiBlcnJvciwgb3JpZ2luYWwgZXZlbnQgd2lsbCBub3QgYmUgc2VudC4gRGV0YWlscyBoYXZlIGJlZW4gc2VudCBhcyBhIG5ldyBldmVudC5cXG5SZWFzb246ICR7cmVhc29ufWAsXG4gICAgICAgICk7XG4gICAgICB9KTtcbiAgfVxuXG4gIC8qKlxuICAgKiBPY2N1cGllcyB0aGUgY2xpZW50IHdpdGggcHJvY2Vzc2luZyBhbmQgZXZlbnRcbiAgICovXG4gICBfcHJvY2Vzcyhwcm9taXNlKSB7XG4gICAgdGhpcy5fbnVtUHJvY2Vzc2luZysrO1xuICAgIHZvaWQgcHJvbWlzZS50aGVuKFxuICAgICAgdmFsdWUgPT4ge1xuICAgICAgICB0aGlzLl9udW1Qcm9jZXNzaW5nLS07XG4gICAgICAgIHJldHVybiB2YWx1ZTtcbiAgICAgIH0sXG4gICAgICByZWFzb24gPT4ge1xuICAgICAgICB0aGlzLl9udW1Qcm9jZXNzaW5nLS07XG4gICAgICAgIHJldHVybiByZWFzb247XG4gICAgICB9LFxuICAgICk7XG4gIH1cblxuICAvKipcbiAgICogQ2xlYXJzIG91dGNvbWVzIG9uIHRoaXMgY2xpZW50IGFuZCByZXR1cm5zIHRoZW0uXG4gICAqL1xuICAgX2NsZWFyT3V0Y29tZXMoKSB7XG4gICAgY29uc3Qgb3V0Y29tZXMgPSB0aGlzLl9vdXRjb21lcztcbiAgICB0aGlzLl9vdXRjb21lcyA9IHt9O1xuICAgIHJldHVybiBPYmplY3QuZW50cmllcyhvdXRjb21lcykubWFwKChba2V5LCBxdWFudGl0eV0pID0+IHtcbiAgICAgIGNvbnN0IFtyZWFzb24sIGNhdGVnb3J5XSA9IGtleS5zcGxpdCgnOicpIDtcbiAgICAgIHJldHVybiB7XG4gICAgICAgIHJlYXNvbixcbiAgICAgICAgY2F0ZWdvcnksXG4gICAgICAgIHF1YW50aXR5LFxuICAgICAgfTtcbiAgICB9KTtcbiAgfVxuXG4gIC8qKlxuICAgKiBTZW5kcyBjbGllbnQgcmVwb3J0cyBhcyBhbiBlbnZlbG9wZS5cbiAgICovXG4gICBfZmx1c2hPdXRjb21lcygpIHtcbiAgICBkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEICYmIGRlYnVnTG9nZ2VyLmRlYnVnLmxvZygnRmx1c2hpbmcgb3V0Y29tZXMuLi4nKTtcblxuICAgIGNvbnN0IG91dGNvbWVzID0gdGhpcy5fY2xlYXJPdXRjb21lcygpO1xuXG4gICAgaWYgKG91dGNvbWVzLmxlbmd0aCA9PT0gMCkge1xuICAgICAgZGVidWdCdWlsZC5ERUJVR19CVUlMRCAmJiBkZWJ1Z0xvZ2dlci5kZWJ1Zy5sb2coJ05vIG91dGNvbWVzIHRvIHNlbmQnKTtcbiAgICAgIHJldHVybjtcbiAgICB9XG5cbiAgICAvLyBUaGlzIGlzIHJlYWxseSB0aGUgb25seSBwbGFjZSB3aGVyZSB3ZSB3YW50IHRvIGNoZWNrIGZvciBhIERTTiBhbmQgb25seSBzZW5kIG91dGNvbWVzIHRoZW5cbiAgICBpZiAoIXRoaXMuX2Rzbikge1xuICAgICAgZGVidWdCdWlsZC5ERUJVR19CVUlMRCAmJiBkZWJ1Z0xvZ2dlci5kZWJ1Zy5sb2coJ05vIGRzbiBwcm92aWRlZCwgd2lsbCBub3Qgc2VuZCBvdXRjb21lcycpO1xuICAgICAgcmV0dXJuO1xuICAgIH1cblxuICAgIGRlYnVnQnVpbGQuREVCVUdfQlVJTEQgJiYgZGVidWdMb2dnZXIuZGVidWcubG9nKCdTZW5kaW5nIG91dGNvbWVzOicsIG91dGNvbWVzKTtcblxuICAgIGNvbnN0IGVudmVsb3BlID0gY2xpZW50cmVwb3J0LmNyZWF0ZUNsaWVudFJlcG9ydEVudmVsb3BlKG91dGNvbWVzLCB0aGlzLl9vcHRpb25zLnR1bm5lbCAmJiBkc24uZHNuVG9TdHJpbmcodGhpcy5fZHNuKSk7XG5cbiAgICAvLyBzZW5kRW52ZWxvcGUgc2hvdWxkIG5vdCB0aHJvd1xuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tZmxvYXRpbmctcHJvbWlzZXNcbiAgICB0aGlzLnNlbmRFbnZlbG9wZShlbnZlbG9wZSk7XG4gIH1cblxuICAvKipcbiAgICogQ3JlYXRlcyBhbiB7QGxpbmsgRXZlbnR9IGZyb20gYWxsIGlucHV0cyB0byBgY2FwdHVyZUV4Y2VwdGlvbmAgYW5kIG5vbi1wcmltaXRpdmUgaW5wdXRzIHRvIGBjYXB0dXJlTWVzc2FnZWAuXG4gICAqL1xuXG59XG5cbi8qKlxuICogQGRlcHJlY2F0ZWQgVXNlIGBDbGllbnRgIGluc3RlYWQuIFRoaXMgYWxpYXMgbWF5IGJlIHJlbW92ZWQgaW4gYSBmdXR1cmUgbWFqb3IgdmVyc2lvbi5cbiAqL1xuLy8gVE9ETyh2MTApOiBSZW1vdmVcblxuLyoqXG4gKiBAZGVwcmVjYXRlZCBVc2UgYENsaWVudGAgaW5zdGVhZC4gVGhpcyBhbGlhcyBtYXkgYmUgcmVtb3ZlZCBpbiBhIGZ1dHVyZSBtYWpvciB2ZXJzaW9uLlxuICovXG4vLyBUT0RPKHYxMCk6IFJlbW92ZVxuY29uc3QgQmFzZUNsaWVudCA9IENsaWVudDtcblxuLyoqXG4gKiBWZXJpZmllcyB0aGF0IHJldHVybiB2YWx1ZSBvZiBjb25maWd1cmVkIGBiZWZvcmVTZW5kYCBvciBgYmVmb3JlU2VuZFRyYW5zYWN0aW9uYCBpcyBvZiBleHBlY3RlZCB0eXBlLCBhbmQgcmV0dXJucyB0aGUgdmFsdWUgaWYgc28uXG4gKi9cbmZ1bmN0aW9uIF92YWxpZGF0ZUJlZm9yZVNlbmRSZXN1bHQoXG4gIGJlZm9yZVNlbmRSZXN1bHQsXG4gIGJlZm9yZVNlbmRMYWJlbCxcbikge1xuICBjb25zdCBpbnZhbGlkVmFsdWVFcnJvciA9IGAke2JlZm9yZVNlbmRMYWJlbH0gbXVzdCByZXR1cm4gXFxgbnVsbFxcYCBvciBhIHZhbGlkIGV2ZW50LmA7XG4gIGlmIChpcy5pc1RoZW5hYmxlKGJlZm9yZVNlbmRSZXN1bHQpKSB7XG4gICAgcmV0dXJuIGJlZm9yZVNlbmRSZXN1bHQudGhlbihcbiAgICAgIGV2ZW50ID0+IHtcbiAgICAgICAgaWYgKCFpcy5pc1BsYWluT2JqZWN0KGV2ZW50KSAmJiBldmVudCAhPT0gbnVsbCkge1xuICAgICAgICAgIHRocm93IF9tYWtlSW50ZXJuYWxFcnJvcihpbnZhbGlkVmFsdWVFcnJvcik7XG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuIGV2ZW50O1xuICAgICAgfSxcbiAgICAgIGUgPT4ge1xuICAgICAgICB0aHJvdyBfbWFrZUludGVybmFsRXJyb3IoYCR7YmVmb3JlU2VuZExhYmVsfSByZWplY3RlZCB3aXRoICR7ZX1gKTtcbiAgICAgIH0sXG4gICAgKTtcbiAgfSBlbHNlIGlmICghaXMuaXNQbGFpbk9iamVjdChiZWZvcmVTZW5kUmVzdWx0KSAmJiBiZWZvcmVTZW5kUmVzdWx0ICE9PSBudWxsKSB7XG4gICAgdGhyb3cgX21ha2VJbnRlcm5hbEVycm9yKGludmFsaWRWYWx1ZUVycm9yKTtcbiAgfVxuICByZXR1cm4gYmVmb3JlU2VuZFJlc3VsdDtcbn1cblxuLyoqXG4gKiBQcm9jZXNzIHRoZSBtYXRjaGluZyBgYmVmb3JlU2VuZFhYWGAgY2FsbGJhY2suXG4gKi9cbmZ1bmN0aW9uIHByb2Nlc3NCZWZvcmVTZW5kKFxuICBjbGllbnQsXG4gIG9wdGlvbnMsXG4gIGV2ZW50LFxuICBoaW50LFxuKSB7XG4gIGNvbnN0IHsgYmVmb3JlU2VuZCwgYmVmb3JlU2VuZFRyYW5zYWN0aW9uLCBiZWZvcmVTZW5kU3BhbiB9ID0gb3B0aW9ucztcbiAgbGV0IHByb2Nlc3NlZEV2ZW50ID0gZXZlbnQ7XG5cbiAgaWYgKGlzRXJyb3JFdmVudChwcm9jZXNzZWRFdmVudCkgJiYgYmVmb3JlU2VuZCkge1xuICAgIHJldHVybiBiZWZvcmVTZW5kKHByb2Nlc3NlZEV2ZW50LCBoaW50KTtcbiAgfVxuXG4gIGlmIChpc1RyYW5zYWN0aW9uRXZlbnQocHJvY2Vzc2VkRXZlbnQpKSB7XG4gICAgaWYgKGJlZm9yZVNlbmRTcGFuKSB7XG4gICAgICAvLyBwcm9jZXNzIHJvb3Qgc3BhblxuICAgICAgY29uc3QgcHJvY2Vzc2VkUm9vdFNwYW5Kc29uID0gYmVmb3JlU2VuZFNwYW4odHJhbnNhY3Rpb25FdmVudC5jb252ZXJ0VHJhbnNhY3Rpb25FdmVudFRvU3Bhbkpzb24ocHJvY2Vzc2VkRXZlbnQpKTtcbiAgICAgIGlmICghcHJvY2Vzc2VkUm9vdFNwYW5Kc29uKSB7XG4gICAgICAgIHNwYW5VdGlscy5zaG93U3BhbkRyb3BXYXJuaW5nKCk7XG4gICAgICB9IGVsc2Uge1xuICAgICAgICAvLyB1cGRhdGUgZXZlbnQgd2l0aCBwcm9jZXNzZWQgcm9vdCBzcGFuIHZhbHVlc1xuICAgICAgICBwcm9jZXNzZWRFdmVudCA9IG1lcmdlLm1lcmdlKGV2ZW50LCB0cmFuc2FjdGlvbkV2ZW50LmNvbnZlcnRTcGFuSnNvblRvVHJhbnNhY3Rpb25FdmVudChwcm9jZXNzZWRSb290U3Bhbkpzb24pKTtcbiAgICAgIH1cblxuICAgICAgLy8gcHJvY2VzcyBjaGlsZCBzcGFuc1xuICAgICAgaWYgKHByb2Nlc3NlZEV2ZW50LnNwYW5zKSB7XG4gICAgICAgIGNvbnN0IHByb2Nlc3NlZFNwYW5zID0gW107XG4gICAgICAgIGZvciAoY29uc3Qgc3BhbiBvZiBwcm9jZXNzZWRFdmVudC5zcGFucykge1xuICAgICAgICAgIGNvbnN0IHByb2Nlc3NlZFNwYW4gPSBiZWZvcmVTZW5kU3BhbihzcGFuKTtcbiAgICAgICAgICBpZiAoIXByb2Nlc3NlZFNwYW4pIHtcbiAgICAgICAgICAgIHNwYW5VdGlscy5zaG93U3BhbkRyb3BXYXJuaW5nKCk7XG4gICAgICAgICAgICBwcm9jZXNzZWRTcGFucy5wdXNoKHNwYW4pO1xuICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICBwcm9jZXNzZWRTcGFucy5wdXNoKHByb2Nlc3NlZFNwYW4pO1xuICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgICBwcm9jZXNzZWRFdmVudC5zcGFucyA9IHByb2Nlc3NlZFNwYW5zO1xuICAgICAgfVxuICAgIH1cblxuICAgIGlmIChiZWZvcmVTZW5kVHJhbnNhY3Rpb24pIHtcbiAgICAgIGlmIChwcm9jZXNzZWRFdmVudC5zcGFucykge1xuICAgICAgICAvLyBXZSBzdG9yZSB0aGUgIyBvZiBzcGFucyBiZWZvcmUgcHJvY2Vzc2luZyBpbiBTREsgbWV0YWRhdGEsXG4gICAgICAgIC8vIHNvIHdlIGNhbiBjb21wYXJlIGl0IGFmdGVyd2FyZHMgdG8gZGV0ZXJtaW5lIGhvdyBtYW55IHNwYW5zIHdlcmUgZHJvcHBlZFxuICAgICAgICBjb25zdCBzcGFuQ291bnRCZWZvcmUgPSBwcm9jZXNzZWRFdmVudC5zcGFucy5sZW5ndGg7XG4gICAgICAgIHByb2Nlc3NlZEV2ZW50LnNka1Byb2Nlc3NpbmdNZXRhZGF0YSA9IHtcbiAgICAgICAgICAuLi5ldmVudC5zZGtQcm9jZXNzaW5nTWV0YWRhdGEsXG4gICAgICAgICAgc3BhbkNvdW50QmVmb3JlUHJvY2Vzc2luZzogc3BhbkNvdW50QmVmb3JlLFxuICAgICAgICB9O1xuICAgICAgfVxuICAgICAgcmV0dXJuIGJlZm9yZVNlbmRUcmFuc2FjdGlvbihwcm9jZXNzZWRFdmVudCAsIGhpbnQpO1xuICAgIH1cbiAgfVxuXG4gIHJldHVybiBwcm9jZXNzZWRFdmVudDtcbn1cblxuZnVuY3Rpb24gaXNFcnJvckV2ZW50KGV2ZW50KSB7XG4gIHJldHVybiBldmVudC50eXBlID09PSB1bmRlZmluZWQ7XG59XG5cbmZ1bmN0aW9uIGlzVHJhbnNhY3Rpb25FdmVudChldmVudCkge1xuICByZXR1cm4gZXZlbnQudHlwZSA9PT0gJ3RyYW5zYWN0aW9uJztcbn1cblxuLyoqIEV4dHJhY3QgdHJhY2UgaW5mb3JtYXRpb24gZnJvbSBzY29wZSAqL1xuZnVuY3Rpb24gX2dldFRyYWNlSW5mb0Zyb21TY29wZShcbiAgY2xpZW50LFxuICBzY29wZSxcbikge1xuICBpZiAoIXNjb3BlKSB7XG4gICAgcmV0dXJuIFt1bmRlZmluZWQsIHVuZGVmaW5lZF07XG4gIH1cblxuICByZXR1cm4gY3VycmVudFNjb3Blcy53aXRoU2NvcGUoc2NvcGUsICgpID0+IHtcbiAgICBjb25zdCBzcGFuID0gc3BhblV0aWxzLmdldEFjdGl2ZVNwYW4oKTtcbiAgICBjb25zdCB0cmFjZUNvbnRleHQgPSBzcGFuID8gc3BhblV0aWxzLnNwYW5Ub1RyYWNlQ29udGV4dChzcGFuKSA6IGN1cnJlbnRTY29wZXMuZ2V0VHJhY2VDb250ZXh0RnJvbVNjb3BlKHNjb3BlKTtcbiAgICBjb25zdCBkeW5hbWljU2FtcGxpbmdDb250ZXh0JDEgPSBzcGFuXG4gICAgICA/IGR5bmFtaWNTYW1wbGluZ0NvbnRleHQuZ2V0RHluYW1pY1NhbXBsaW5nQ29udGV4dEZyb21TcGFuKHNwYW4pXG4gICAgICA6IGR5bmFtaWNTYW1wbGluZ0NvbnRleHQuZ2V0RHluYW1pY1NhbXBsaW5nQ29udGV4dEZyb21TY29wZShjbGllbnQsIHNjb3BlKTtcbiAgICByZXR1cm4gW2R5bmFtaWNTYW1wbGluZ0NvbnRleHQkMSwgdHJhY2VDb250ZXh0XTtcbiAgfSk7XG59XG5cbmV4cG9ydHMuQmFzZUNsaWVudCA9IEJhc2VDbGllbnQ7XG5leHBvcnRzLkNsaWVudCA9IENsaWVudDtcbmV4cG9ydHMuX2dldFRyYWNlSW5mb0Zyb21TY29wZSA9IF9nZXRUcmFjZUluZm9Gcm9tU2NvcGU7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1jbGllbnQuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/client.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/constants.js":
/*!*************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/constants.js ***!
  \*************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst DEFAULT_ENVIRONMENT = 'production';\n\nexports.DEFAULT_ENVIRONMENT = DEFAULT_ENVIRONMENT;\n//# sourceMappingURL=constants.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9jb25zdGFudHMuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEU7O0FBRUEsMkJBQTJCO0FBQzNCIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvY29uc3RhbnRzLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBERUZBVUxUX0VOVklST05NRU5UID0gJ3Byb2R1Y3Rpb24nO1xuXG5leHBvcnRzLkRFRkFVTFRfRU5WSVJPTk1FTlQgPSBERUZBVUxUX0VOVklST05NRU5UO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9Y29uc3RhbnRzLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/constants.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js":
/*!*****************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js ***!
  \*****************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst index = __webpack_require__(/*! ./asyncContext/index.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/asyncContext/index.js\");\nconst carrier = __webpack_require__(/*! ./carrier.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/carrier.js\");\nconst scope = __webpack_require__(/*! ./scope.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/scope.js\");\nconst propagationContext = __webpack_require__(/*! ./utils/propagationContext.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/propagationContext.js\");\n\n/**\n * Get the currently active scope.\n */\nfunction getCurrentScope() {\n  const carrier$1 = carrier.getMainCarrier();\n  const acs = index.getAsyncContextStrategy(carrier$1);\n  return acs.getCurrentScope();\n}\n\n/**\n * Get the currently active isolation scope.\n * The isolation scope is active for the current execution context.\n */\nfunction getIsolationScope() {\n  const carrier$1 = carrier.getMainCarrier();\n  const acs = index.getAsyncContextStrategy(carrier$1);\n  return acs.getIsolationScope();\n}\n\n/**\n * Get the global scope.\n * This scope is applied to _all_ events.\n */\nfunction getGlobalScope() {\n  return carrier.getGlobalSingleton('globalScope', () => new scope.Scope());\n}\n\n/**\n * Creates a new scope with and executes the given operation within.\n * The scope is automatically removed once the operation\n * finishes or throws.\n */\n\n/**\n * Either creates a new active scope, or sets the given scope as active scope in the given callback.\n */\nfunction withScope(\n  ...rest\n) {\n  const carrier$1 = carrier.getMainCarrier();\n  const acs = index.getAsyncContextStrategy(carrier$1);\n\n  // If a scope is defined, we want to make this the active scope instead of the default one\n  if (rest.length === 2) {\n    const [scope, callback] = rest;\n\n    if (!scope) {\n      return acs.withScope(callback);\n    }\n\n    return acs.withSetScope(scope, callback);\n  }\n\n  return acs.withScope(rest[0]);\n}\n\n/**\n * Attempts to fork the current isolation scope and the current scope based on the current async context strategy. If no\n * async context strategy is set, the isolation scope and the current scope will not be forked (this is currently the\n * case, for example, in the browser).\n *\n * Usage of this function in environments without async context strategy is discouraged and may lead to unexpected behaviour.\n *\n * This function is intended for Sentry SDK and SDK integration development. It is not recommended to be used in \"normal\"\n * applications directly because it comes with pitfalls. Use at your own risk!\n */\n\n/**\n * Either creates a new active isolation scope, or sets the given isolation scope as active scope in the given callback.\n */\nfunction withIsolationScope(\n  ...rest\n\n) {\n  const carrier$1 = carrier.getMainCarrier();\n  const acs = index.getAsyncContextStrategy(carrier$1);\n\n  // If a scope is defined, we want to make this the active scope instead of the default one\n  if (rest.length === 2) {\n    const [isolationScope, callback] = rest;\n\n    if (!isolationScope) {\n      return acs.withIsolationScope(callback);\n    }\n\n    return acs.withSetIsolationScope(isolationScope, callback);\n  }\n\n  return acs.withIsolationScope(rest[0]);\n}\n\n/**\n * Get the currently active client.\n */\nfunction getClient() {\n  return getCurrentScope().getClient();\n}\n\n/**\n * Get a trace context for the given scope.\n */\nfunction getTraceContextFromScope(scope) {\n  const propagationContext$1 = scope.getPropagationContext();\n\n  const { traceId, parentSpanId, propagationSpanId } = propagationContext$1;\n\n  const traceContext = {\n    trace_id: traceId,\n    span_id: propagationSpanId || propagationContext.generateSpanId(),\n  };\n\n  if (parentSpanId) {\n    traceContext.parent_span_id = parentSpanId;\n  }\n\n  return traceContext;\n}\n\nexports.getClient = getClient;\nexports.getCurrentScope = getCurrentScope;\nexports.getGlobalScope = getGlobalScope;\nexports.getIsolationScope = getIsolationScope;\nexports.getTraceContextFromScope = getTraceContextFromScope;\nexports.withIsolationScope = withIsolationScope;\nexports.withScope = withScope;\n//# sourceMappingURL=currentScopes.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9jdXJyZW50U2NvcGVzLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLGNBQWMsbUJBQU8sQ0FBQyx5SUFBeUI7QUFDL0MsZ0JBQWdCLG1CQUFPLENBQUMsbUhBQWM7QUFDdEMsY0FBYyxtQkFBTyxDQUFDLCtHQUFZO0FBQ2xDLDJCQUEyQixtQkFBTyxDQUFDLHFKQUErQjs7QUFFbEU7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLFVBQVUsMkNBQTJDOztBQUVyRDtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQSxpQkFBaUI7QUFDakIsdUJBQXVCO0FBQ3ZCLHNCQUFzQjtBQUN0Qix5QkFBeUI7QUFDekIsZ0NBQWdDO0FBQ2hDLDBCQUEwQjtBQUMxQixpQkFBaUI7QUFDakIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9jdXJyZW50U2NvcGVzLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBpbmRleCA9IHJlcXVpcmUoJy4vYXN5bmNDb250ZXh0L2luZGV4LmpzJyk7XG5jb25zdCBjYXJyaWVyID0gcmVxdWlyZSgnLi9jYXJyaWVyLmpzJyk7XG5jb25zdCBzY29wZSA9IHJlcXVpcmUoJy4vc2NvcGUuanMnKTtcbmNvbnN0IHByb3BhZ2F0aW9uQ29udGV4dCA9IHJlcXVpcmUoJy4vdXRpbHMvcHJvcGFnYXRpb25Db250ZXh0LmpzJyk7XG5cbi8qKlxuICogR2V0IHRoZSBjdXJyZW50bHkgYWN0aXZlIHNjb3BlLlxuICovXG5mdW5jdGlvbiBnZXRDdXJyZW50U2NvcGUoKSB7XG4gIGNvbnN0IGNhcnJpZXIkMSA9IGNhcnJpZXIuZ2V0TWFpbkNhcnJpZXIoKTtcbiAgY29uc3QgYWNzID0gaW5kZXguZ2V0QXN5bmNDb250ZXh0U3RyYXRlZ3koY2FycmllciQxKTtcbiAgcmV0dXJuIGFjcy5nZXRDdXJyZW50U2NvcGUoKTtcbn1cblxuLyoqXG4gKiBHZXQgdGhlIGN1cnJlbnRseSBhY3RpdmUgaXNvbGF0aW9uIHNjb3BlLlxuICogVGhlIGlzb2xhdGlvbiBzY29wZSBpcyBhY3RpdmUgZm9yIHRoZSBjdXJyZW50IGV4ZWN1dGlvbiBjb250ZXh0LlxuICovXG5mdW5jdGlvbiBnZXRJc29sYXRpb25TY29wZSgpIHtcbiAgY29uc3QgY2FycmllciQxID0gY2Fycmllci5nZXRNYWluQ2FycmllcigpO1xuICBjb25zdCBhY3MgPSBpbmRleC5nZXRBc3luY0NvbnRleHRTdHJhdGVneShjYXJyaWVyJDEpO1xuICByZXR1cm4gYWNzLmdldElzb2xhdGlvblNjb3BlKCk7XG59XG5cbi8qKlxuICogR2V0IHRoZSBnbG9iYWwgc2NvcGUuXG4gKiBUaGlzIHNjb3BlIGlzIGFwcGxpZWQgdG8gX2FsbF8gZXZlbnRzLlxuICovXG5mdW5jdGlvbiBnZXRHbG9iYWxTY29wZSgpIHtcbiAgcmV0dXJuIGNhcnJpZXIuZ2V0R2xvYmFsU2luZ2xldG9uKCdnbG9iYWxTY29wZScsICgpID0+IG5ldyBzY29wZS5TY29wZSgpKTtcbn1cblxuLyoqXG4gKiBDcmVhdGVzIGEgbmV3IHNjb3BlIHdpdGggYW5kIGV4ZWN1dGVzIHRoZSBnaXZlbiBvcGVyYXRpb24gd2l0aGluLlxuICogVGhlIHNjb3BlIGlzIGF1dG9tYXRpY2FsbHkgcmVtb3ZlZCBvbmNlIHRoZSBvcGVyYXRpb25cbiAqIGZpbmlzaGVzIG9yIHRocm93cy5cbiAqL1xuXG4vKipcbiAqIEVpdGhlciBjcmVhdGVzIGEgbmV3IGFjdGl2ZSBzY29wZSwgb3Igc2V0cyB0aGUgZ2l2ZW4gc2NvcGUgYXMgYWN0aXZlIHNjb3BlIGluIHRoZSBnaXZlbiBjYWxsYmFjay5cbiAqL1xuZnVuY3Rpb24gd2l0aFNjb3BlKFxuICAuLi5yZXN0XG4pIHtcbiAgY29uc3QgY2FycmllciQxID0gY2Fycmllci5nZXRNYWluQ2FycmllcigpO1xuICBjb25zdCBhY3MgPSBpbmRleC5nZXRBc3luY0NvbnRleHRTdHJhdGVneShjYXJyaWVyJDEpO1xuXG4gIC8vIElmIGEgc2NvcGUgaXMgZGVmaW5lZCwgd2Ugd2FudCB0byBtYWtlIHRoaXMgdGhlIGFjdGl2ZSBzY29wZSBpbnN0ZWFkIG9mIHRoZSBkZWZhdWx0IG9uZVxuICBpZiAocmVzdC5sZW5ndGggPT09IDIpIHtcbiAgICBjb25zdCBbc2NvcGUsIGNhbGxiYWNrXSA9IHJlc3Q7XG5cbiAgICBpZiAoIXNjb3BlKSB7XG4gICAgICByZXR1cm4gYWNzLndpdGhTY29wZShjYWxsYmFjayk7XG4gICAgfVxuXG4gICAgcmV0dXJuIGFjcy53aXRoU2V0U2NvcGUoc2NvcGUsIGNhbGxiYWNrKTtcbiAgfVxuXG4gIHJldHVybiBhY3Mud2l0aFNjb3BlKHJlc3RbMF0pO1xufVxuXG4vKipcbiAqIEF0dGVtcHRzIHRvIGZvcmsgdGhlIGN1cnJlbnQgaXNvbGF0aW9uIHNjb3BlIGFuZCB0aGUgY3VycmVudCBzY29wZSBiYXNlZCBvbiB0aGUgY3VycmVudCBhc3luYyBjb250ZXh0IHN0cmF0ZWd5LiBJZiBub1xuICogYXN5bmMgY29udGV4dCBzdHJhdGVneSBpcyBzZXQsIHRoZSBpc29sYXRpb24gc2NvcGUgYW5kIHRoZSBjdXJyZW50IHNjb3BlIHdpbGwgbm90IGJlIGZvcmtlZCAodGhpcyBpcyBjdXJyZW50bHkgdGhlXG4gKiBjYXNlLCBmb3IgZXhhbXBsZSwgaW4gdGhlIGJyb3dzZXIpLlxuICpcbiAqIFVzYWdlIG9mIHRoaXMgZnVuY3Rpb24gaW4gZW52aXJvbm1lbnRzIHdpdGhvdXQgYXN5bmMgY29udGV4dCBzdHJhdGVneSBpcyBkaXNjb3VyYWdlZCBhbmQgbWF5IGxlYWQgdG8gdW5leHBlY3RlZCBiZWhhdmlvdXIuXG4gKlxuICogVGhpcyBmdW5jdGlvbiBpcyBpbnRlbmRlZCBmb3IgU2VudHJ5IFNESyBhbmQgU0RLIGludGVncmF0aW9uIGRldmVsb3BtZW50LiBJdCBpcyBub3QgcmVjb21tZW5kZWQgdG8gYmUgdXNlZCBpbiBcIm5vcm1hbFwiXG4gKiBhcHBsaWNhdGlvbnMgZGlyZWN0bHkgYmVjYXVzZSBpdCBjb21lcyB3aXRoIHBpdGZhbGxzLiBVc2UgYXQgeW91ciBvd24gcmlzayFcbiAqL1xuXG4vKipcbiAqIEVpdGhlciBjcmVhdGVzIGEgbmV3IGFjdGl2ZSBpc29sYXRpb24gc2NvcGUsIG9yIHNldHMgdGhlIGdpdmVuIGlzb2xhdGlvbiBzY29wZSBhcyBhY3RpdmUgc2NvcGUgaW4gdGhlIGdpdmVuIGNhbGxiYWNrLlxuICovXG5mdW5jdGlvbiB3aXRoSXNvbGF0aW9uU2NvcGUoXG4gIC4uLnJlc3RcblxuKSB7XG4gIGNvbnN0IGNhcnJpZXIkMSA9IGNhcnJpZXIuZ2V0TWFpbkNhcnJpZXIoKTtcbiAgY29uc3QgYWNzID0gaW5kZXguZ2V0QXN5bmNDb250ZXh0U3RyYXRlZ3koY2FycmllciQxKTtcblxuICAvLyBJZiBhIHNjb3BlIGlzIGRlZmluZWQsIHdlIHdhbnQgdG8gbWFrZSB0aGlzIHRoZSBhY3RpdmUgc2NvcGUgaW5zdGVhZCBvZiB0aGUgZGVmYXVsdCBvbmVcbiAgaWYgKHJlc3QubGVuZ3RoID09PSAyKSB7XG4gICAgY29uc3QgW2lzb2xhdGlvblNjb3BlLCBjYWxsYmFja10gPSByZXN0O1xuXG4gICAgaWYgKCFpc29sYXRpb25TY29wZSkge1xuICAgICAgcmV0dXJuIGFjcy53aXRoSXNvbGF0aW9uU2NvcGUoY2FsbGJhY2spO1xuICAgIH1cblxuICAgIHJldHVybiBhY3Mud2l0aFNldElzb2xhdGlvblNjb3BlKGlzb2xhdGlvblNjb3BlLCBjYWxsYmFjayk7XG4gIH1cblxuICByZXR1cm4gYWNzLndpdGhJc29sYXRpb25TY29wZShyZXN0WzBdKTtcbn1cblxuLyoqXG4gKiBHZXQgdGhlIGN1cnJlbnRseSBhY3RpdmUgY2xpZW50LlxuICovXG5mdW5jdGlvbiBnZXRDbGllbnQoKSB7XG4gIHJldHVybiBnZXRDdXJyZW50U2NvcGUoKS5nZXRDbGllbnQoKTtcbn1cblxuLyoqXG4gKiBHZXQgYSB0cmFjZSBjb250ZXh0IGZvciB0aGUgZ2l2ZW4gc2NvcGUuXG4gKi9cbmZ1bmN0aW9uIGdldFRyYWNlQ29udGV4dEZyb21TY29wZShzY29wZSkge1xuICBjb25zdCBwcm9wYWdhdGlvbkNvbnRleHQkMSA9IHNjb3BlLmdldFByb3BhZ2F0aW9uQ29udGV4dCgpO1xuXG4gIGNvbnN0IHsgdHJhY2VJZCwgcGFyZW50U3BhbklkLCBwcm9wYWdhdGlvblNwYW5JZCB9ID0gcHJvcGFnYXRpb25Db250ZXh0JDE7XG5cbiAgY29uc3QgdHJhY2VDb250ZXh0ID0ge1xuICAgIHRyYWNlX2lkOiB0cmFjZUlkLFxuICAgIHNwYW5faWQ6IHByb3BhZ2F0aW9uU3BhbklkIHx8IHByb3BhZ2F0aW9uQ29udGV4dC5nZW5lcmF0ZVNwYW5JZCgpLFxuICB9O1xuXG4gIGlmIChwYXJlbnRTcGFuSWQpIHtcbiAgICB0cmFjZUNvbnRleHQucGFyZW50X3NwYW5faWQgPSBwYXJlbnRTcGFuSWQ7XG4gIH1cblxuICByZXR1cm4gdHJhY2VDb250ZXh0O1xufVxuXG5leHBvcnRzLmdldENsaWVudCA9IGdldENsaWVudDtcbmV4cG9ydHMuZ2V0Q3VycmVudFNjb3BlID0gZ2V0Q3VycmVudFNjb3BlO1xuZXhwb3J0cy5nZXRHbG9iYWxTY29wZSA9IGdldEdsb2JhbFNjb3BlO1xuZXhwb3J0cy5nZXRJc29sYXRpb25TY29wZSA9IGdldElzb2xhdGlvblNjb3BlO1xuZXhwb3J0cy5nZXRUcmFjZUNvbnRleHRGcm9tU2NvcGUgPSBnZXRUcmFjZUNvbnRleHRGcm9tU2NvcGU7XG5leHBvcnRzLndpdGhJc29sYXRpb25TY29wZSA9IHdpdGhJc29sYXRpb25TY29wZTtcbmV4cG9ydHMud2l0aFNjb3BlID0gd2l0aFNjb3BlO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9Y3VycmVudFNjb3Blcy5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js":
/*!***************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js ***!
  \***************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n/**\n * This serves as a build time flag that will be true by default, but false in non-debug builds or if users replace `__SENTRY_DEBUG__` in their generated code.\n *\n * ATTENTION: This constant must never cross package boundaries (i.e. be exported) to guarantee that it can be used for tree shaking.\n */\nconst DEBUG_BUILD = ( false || false);\n\nexports.DEBUG_BUILD = DEBUG_BUILD;\n//# sourceMappingURL=debug-build.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9kZWJ1Zy1idWlsZC5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EscUJBQXFCLE1BQXVDLElBQUksS0FBZ0I7O0FBRWhGLG1CQUFtQjtBQUNuQiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL2RlYnVnLWJ1aWxkLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG4vKipcbiAqIFRoaXMgc2VydmVzIGFzIGEgYnVpbGQgdGltZSBmbGFnIHRoYXQgd2lsbCBiZSB0cnVlIGJ5IGRlZmF1bHQsIGJ1dCBmYWxzZSBpbiBub24tZGVidWcgYnVpbGRzIG9yIGlmIHVzZXJzIHJlcGxhY2UgYF9fU0VOVFJZX0RFQlVHX19gIGluIHRoZWlyIGdlbmVyYXRlZCBjb2RlLlxuICpcbiAqIEFUVEVOVElPTjogVGhpcyBjb25zdGFudCBtdXN0IG5ldmVyIGNyb3NzIHBhY2thZ2UgYm91bmRhcmllcyAoaS5lLiBiZSBleHBvcnRlZCkgdG8gZ3VhcmFudGVlIHRoYXQgaXQgY2FuIGJlIHVzZWQgZm9yIHRyZWUgc2hha2luZy5cbiAqL1xuY29uc3QgREVCVUdfQlVJTEQgPSAodHlwZW9mIF9fU0VOVFJZX0RFQlVHX18gPT09ICd1bmRlZmluZWQnIHx8IF9fU0VOVFJZX0RFQlVHX18pO1xuXG5leHBvcnRzLkRFQlVHX0JVSUxEID0gREVCVUdfQlVJTEQ7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1kZWJ1Zy1idWlsZC5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/defaultScopes.js":
/*!*****************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/defaultScopes.js ***!
  \*****************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst carrier = __webpack_require__(/*! ./carrier.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/carrier.js\");\nconst scope = __webpack_require__(/*! ./scope.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/scope.js\");\n\n/** Get the default current scope. */\nfunction getDefaultCurrentScope() {\n  return carrier.getGlobalSingleton('defaultCurrentScope', () => new scope.Scope());\n}\n\n/** Get the default isolation scope. */\nfunction getDefaultIsolationScope() {\n  return carrier.getGlobalSingleton('defaultIsolationScope', () => new scope.Scope());\n}\n\nexports.getDefaultCurrentScope = getDefaultCurrentScope;\nexports.getDefaultIsolationScope = getDefaultIsolationScope;\n//# sourceMappingURL=defaultScopes.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9kZWZhdWx0U2NvcGVzLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLGdCQUFnQixtQkFBTyxDQUFDLG1IQUFjO0FBQ3RDLGNBQWMsbUJBQU8sQ0FBQywrR0FBWTs7QUFFbEM7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsOEJBQThCO0FBQzlCLGdDQUFnQztBQUNoQyIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL2RlZmF1bHRTY29wZXMuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGNhcnJpZXIgPSByZXF1aXJlKCcuL2NhcnJpZXIuanMnKTtcbmNvbnN0IHNjb3BlID0gcmVxdWlyZSgnLi9zY29wZS5qcycpO1xuXG4vKiogR2V0IHRoZSBkZWZhdWx0IGN1cnJlbnQgc2NvcGUuICovXG5mdW5jdGlvbiBnZXREZWZhdWx0Q3VycmVudFNjb3BlKCkge1xuICByZXR1cm4gY2Fycmllci5nZXRHbG9iYWxTaW5nbGV0b24oJ2RlZmF1bHRDdXJyZW50U2NvcGUnLCAoKSA9PiBuZXcgc2NvcGUuU2NvcGUoKSk7XG59XG5cbi8qKiBHZXQgdGhlIGRlZmF1bHQgaXNvbGF0aW9uIHNjb3BlLiAqL1xuZnVuY3Rpb24gZ2V0RGVmYXVsdElzb2xhdGlvblNjb3BlKCkge1xuICByZXR1cm4gY2Fycmllci5nZXRHbG9iYWxTaW5nbGV0b24oJ2RlZmF1bHRJc29sYXRpb25TY29wZScsICgpID0+IG5ldyBzY29wZS5TY29wZSgpKTtcbn1cblxuZXhwb3J0cy5nZXREZWZhdWx0Q3VycmVudFNjb3BlID0gZ2V0RGVmYXVsdEN1cnJlbnRTY29wZTtcbmV4cG9ydHMuZ2V0RGVmYXVsdElzb2xhdGlvblNjb3BlID0gZ2V0RGVmYXVsdElzb2xhdGlvblNjb3BlO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9ZGVmYXVsdFNjb3Blcy5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/defaultScopes.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/envelope.js":
/*!************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/envelope.js ***!
  \************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst dynamicSamplingContext = __webpack_require__(/*! ./tracing/dynamicSamplingContext.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/dynamicSamplingContext.js\");\nconst dsn = __webpack_require__(/*! ./utils/dsn.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/dsn.js\");\nconst envelope = __webpack_require__(/*! ./utils/envelope.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/envelope.js\");\nconst spanUtils = __webpack_require__(/*! ./utils/spanUtils.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanUtils.js\");\n\n/**\n * Apply SdkInfo (name, version, packages, integrations) to the corresponding event key.\n * Merge with existing data if any.\n **/\nfunction enhanceEventWithSdkInfo(event, sdkInfo) {\n  if (!sdkInfo) {\n    return event;\n  }\n  event.sdk = event.sdk || {};\n  event.sdk.name = event.sdk.name || sdkInfo.name;\n  event.sdk.version = event.sdk.version || sdkInfo.version;\n  event.sdk.integrations = [...(event.sdk.integrations || []), ...(sdkInfo.integrations || [])];\n  event.sdk.packages = [...(event.sdk.packages || []), ...(sdkInfo.packages || [])];\n  return event;\n}\n\n/** Creates an envelope from a Session */\nfunction createSessionEnvelope(\n  session,\n  dsn$1,\n  metadata,\n  tunnel,\n) {\n  const sdkInfo = envelope.getSdkMetadataForEnvelopeHeader(metadata);\n  const envelopeHeaders = {\n    sent_at: new Date().toISOString(),\n    ...(sdkInfo && { sdk: sdkInfo }),\n    ...(!!tunnel && dsn$1 && { dsn: dsn.dsnToString(dsn$1) }),\n  };\n\n  const envelopeItem =\n    'aggregates' in session ? [{ type: 'sessions' }, session] : [{ type: 'session' }, session.toJSON()];\n\n  return envelope.createEnvelope(envelopeHeaders, [envelopeItem]);\n}\n\n/**\n * Create an Envelope from an event.\n */\nfunction createEventEnvelope(\n  event,\n  dsn,\n  metadata,\n  tunnel,\n) {\n  const sdkInfo = envelope.getSdkMetadataForEnvelopeHeader(metadata);\n\n  /*\n    Note: Due to TS, event.type may be `replay_event`, theoretically.\n    In practice, we never call `createEventEnvelope` with `replay_event` type,\n    and we'd have to adjust a looot of types to make this work properly.\n    We want to avoid casting this around, as that could lead to bugs (e.g. when we add another type)\n    So the safe choice is to really guard against the replay_event type here.\n  */\n  const eventType = event.type && event.type !== 'replay_event' ? event.type : 'event';\n\n  enhanceEventWithSdkInfo(event, metadata?.sdk);\n\n  const envelopeHeaders = envelope.createEventEnvelopeHeaders(event, sdkInfo, tunnel, dsn);\n\n  // Prevent this data (which, if it exists, was used in earlier steps in the processing pipeline) from being sent to\n  // sentry. (Note: Our use of this property comes and goes with whatever we might be debugging, whatever hacks we may\n  // have temporarily added, etc. Even if we don't happen to be using it at some point in the future, let's not get rid\n  // of this `delete`, lest we miss putting it back in the next time the property is in use.)\n  delete event.sdkProcessingMetadata;\n\n  const eventItem = [{ type: eventType }, event];\n  return envelope.createEnvelope(envelopeHeaders, [eventItem]);\n}\n\n/**\n * Create envelope from Span item.\n *\n * Takes an optional client and runs spans through `beforeSendSpan` if available.\n */\nfunction createSpanEnvelope(spans, client) {\n  function dscHasRequiredProps(dsc) {\n    return !!dsc.trace_id && !!dsc.public_key;\n  }\n\n  // For the moment we'll obtain the DSC from the first span in the array\n  // This might need to be changed if we permit sending multiple spans from\n  // different segments in one envelope\n  const dsc = dynamicSamplingContext.getDynamicSamplingContextFromSpan(spans[0]);\n\n  const dsn$1 = client?.getDsn();\n  const tunnel = client?.getOptions().tunnel;\n\n  const headers = {\n    sent_at: new Date().toISOString(),\n    ...(dscHasRequiredProps(dsc) && { trace: dsc }),\n    ...(!!tunnel && dsn$1 && { dsn: dsn.dsnToString(dsn$1) }),\n  };\n\n  const beforeSendSpan = client?.getOptions().beforeSendSpan;\n  const convertToSpanJSON = beforeSendSpan\n    ? (span) => {\n        const spanJson = spanUtils.spanToJSON(span);\n        const processedSpan = beforeSendSpan(spanJson);\n\n        if (!processedSpan) {\n          spanUtils.showSpanDropWarning();\n          return spanJson;\n        }\n\n        return processedSpan;\n      }\n    : spanUtils.spanToJSON;\n\n  const items = [];\n  for (const span of spans) {\n    const spanJson = convertToSpanJSON(span);\n    if (spanJson) {\n      items.push(envelope.createSpanEnvelopeItem(spanJson));\n    }\n  }\n\n  return envelope.createEnvelope(headers, items);\n}\n\nexports.createEventEnvelope = createEventEnvelope;\nexports.createSessionEnvelope = createSessionEnvelope;\nexports.createSpanEnvelope = createSpanEnvelope;\n//# sourceMappingURL=envelope.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9lbnZlbG9wZS5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSwrQkFBK0IsbUJBQU8sQ0FBQyxpS0FBcUM7QUFDNUUsWUFBWSxtQkFBTyxDQUFDLHVIQUFnQjtBQUNwQyxpQkFBaUIsbUJBQU8sQ0FBQyxpSUFBcUI7QUFDOUMsa0JBQWtCLG1CQUFPLENBQUMsbUlBQXNCOztBQUVoRDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxxQkFBcUIsY0FBYztBQUNuQywrQkFBK0IsNkJBQTZCO0FBQzVEOztBQUVBO0FBQ0EsaUNBQWlDLGtCQUFrQixnQkFBZ0IsaUJBQWlCOztBQUVwRjtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSx1QkFBdUIsaUJBQWlCO0FBQ3hDO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLHNDQUFzQyxZQUFZO0FBQ2xELCtCQUErQiw2QkFBNkI7QUFDNUQ7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQSwyQkFBMkI7QUFDM0IsNkJBQTZCO0FBQzdCLDBCQUEwQjtBQUMxQiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL2VudmVsb3BlLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBkeW5hbWljU2FtcGxpbmdDb250ZXh0ID0gcmVxdWlyZSgnLi90cmFjaW5nL2R5bmFtaWNTYW1wbGluZ0NvbnRleHQuanMnKTtcbmNvbnN0IGRzbiA9IHJlcXVpcmUoJy4vdXRpbHMvZHNuLmpzJyk7XG5jb25zdCBlbnZlbG9wZSA9IHJlcXVpcmUoJy4vdXRpbHMvZW52ZWxvcGUuanMnKTtcbmNvbnN0IHNwYW5VdGlscyA9IHJlcXVpcmUoJy4vdXRpbHMvc3BhblV0aWxzLmpzJyk7XG5cbi8qKlxuICogQXBwbHkgU2RrSW5mbyAobmFtZSwgdmVyc2lvbiwgcGFja2FnZXMsIGludGVncmF0aW9ucykgdG8gdGhlIGNvcnJlc3BvbmRpbmcgZXZlbnQga2V5LlxuICogTWVyZ2Ugd2l0aCBleGlzdGluZyBkYXRhIGlmIGFueS5cbiAqKi9cbmZ1bmN0aW9uIGVuaGFuY2VFdmVudFdpdGhTZGtJbmZvKGV2ZW50LCBzZGtJbmZvKSB7XG4gIGlmICghc2RrSW5mbykge1xuICAgIHJldHVybiBldmVudDtcbiAgfVxuICBldmVudC5zZGsgPSBldmVudC5zZGsgfHwge307XG4gIGV2ZW50LnNkay5uYW1lID0gZXZlbnQuc2RrLm5hbWUgfHwgc2RrSW5mby5uYW1lO1xuICBldmVudC5zZGsudmVyc2lvbiA9IGV2ZW50LnNkay52ZXJzaW9uIHx8IHNka0luZm8udmVyc2lvbjtcbiAgZXZlbnQuc2RrLmludGVncmF0aW9ucyA9IFsuLi4oZXZlbnQuc2RrLmludGVncmF0aW9ucyB8fCBbXSksIC4uLihzZGtJbmZvLmludGVncmF0aW9ucyB8fCBbXSldO1xuICBldmVudC5zZGsucGFja2FnZXMgPSBbLi4uKGV2ZW50LnNkay5wYWNrYWdlcyB8fCBbXSksIC4uLihzZGtJbmZvLnBhY2thZ2VzIHx8IFtdKV07XG4gIHJldHVybiBldmVudDtcbn1cblxuLyoqIENyZWF0ZXMgYW4gZW52ZWxvcGUgZnJvbSBhIFNlc3Npb24gKi9cbmZ1bmN0aW9uIGNyZWF0ZVNlc3Npb25FbnZlbG9wZShcbiAgc2Vzc2lvbixcbiAgZHNuJDEsXG4gIG1ldGFkYXRhLFxuICB0dW5uZWwsXG4pIHtcbiAgY29uc3Qgc2RrSW5mbyA9IGVudmVsb3BlLmdldFNka01ldGFkYXRhRm9yRW52ZWxvcGVIZWFkZXIobWV0YWRhdGEpO1xuICBjb25zdCBlbnZlbG9wZUhlYWRlcnMgPSB7XG4gICAgc2VudF9hdDogbmV3IERhdGUoKS50b0lTT1N0cmluZygpLFxuICAgIC4uLihzZGtJbmZvICYmIHsgc2RrOiBzZGtJbmZvIH0pLFxuICAgIC4uLighIXR1bm5lbCAmJiBkc24kMSAmJiB7IGRzbjogZHNuLmRzblRvU3RyaW5nKGRzbiQxKSB9KSxcbiAgfTtcblxuICBjb25zdCBlbnZlbG9wZUl0ZW0gPVxuICAgICdhZ2dyZWdhdGVzJyBpbiBzZXNzaW9uID8gW3sgdHlwZTogJ3Nlc3Npb25zJyB9LCBzZXNzaW9uXSA6IFt7IHR5cGU6ICdzZXNzaW9uJyB9LCBzZXNzaW9uLnRvSlNPTigpXTtcblxuICByZXR1cm4gZW52ZWxvcGUuY3JlYXRlRW52ZWxvcGUoZW52ZWxvcGVIZWFkZXJzLCBbZW52ZWxvcGVJdGVtXSk7XG59XG5cbi8qKlxuICogQ3JlYXRlIGFuIEVudmVsb3BlIGZyb20gYW4gZXZlbnQuXG4gKi9cbmZ1bmN0aW9uIGNyZWF0ZUV2ZW50RW52ZWxvcGUoXG4gIGV2ZW50LFxuICBkc24sXG4gIG1ldGFkYXRhLFxuICB0dW5uZWwsXG4pIHtcbiAgY29uc3Qgc2RrSW5mbyA9IGVudmVsb3BlLmdldFNka01ldGFkYXRhRm9yRW52ZWxvcGVIZWFkZXIobWV0YWRhdGEpO1xuXG4gIC8qXG4gICAgTm90ZTogRHVlIHRvIFRTLCBldmVudC50eXBlIG1heSBiZSBgcmVwbGF5X2V2ZW50YCwgdGhlb3JldGljYWxseS5cbiAgICBJbiBwcmFjdGljZSwgd2UgbmV2ZXIgY2FsbCBgY3JlYXRlRXZlbnRFbnZlbG9wZWAgd2l0aCBgcmVwbGF5X2V2ZW50YCB0eXBlLFxuICAgIGFuZCB3ZSdkIGhhdmUgdG8gYWRqdXN0IGEgbG9vb3Qgb2YgdHlwZXMgdG8gbWFrZSB0aGlzIHdvcmsgcHJvcGVybHkuXG4gICAgV2Ugd2FudCB0byBhdm9pZCBjYXN0aW5nIHRoaXMgYXJvdW5kLCBhcyB0aGF0IGNvdWxkIGxlYWQgdG8gYnVncyAoZS5nLiB3aGVuIHdlIGFkZCBhbm90aGVyIHR5cGUpXG4gICAgU28gdGhlIHNhZmUgY2hvaWNlIGlzIHRvIHJlYWxseSBndWFyZCBhZ2FpbnN0IHRoZSByZXBsYXlfZXZlbnQgdHlwZSBoZXJlLlxuICAqL1xuICBjb25zdCBldmVudFR5cGUgPSBldmVudC50eXBlICYmIGV2ZW50LnR5cGUgIT09ICdyZXBsYXlfZXZlbnQnID8gZXZlbnQudHlwZSA6ICdldmVudCc7XG5cbiAgZW5oYW5jZUV2ZW50V2l0aFNka0luZm8oZXZlbnQsIG1ldGFkYXRhPy5zZGspO1xuXG4gIGNvbnN0IGVudmVsb3BlSGVhZGVycyA9IGVudmVsb3BlLmNyZWF0ZUV2ZW50RW52ZWxvcGVIZWFkZXJzKGV2ZW50LCBzZGtJbmZvLCB0dW5uZWwsIGRzbik7XG5cbiAgLy8gUHJldmVudCB0aGlzIGRhdGEgKHdoaWNoLCBpZiBpdCBleGlzdHMsIHdhcyB1c2VkIGluIGVhcmxpZXIgc3RlcHMgaW4gdGhlIHByb2Nlc3NpbmcgcGlwZWxpbmUpIGZyb20gYmVpbmcgc2VudCB0b1xuICAvLyBzZW50cnkuIChOb3RlOiBPdXIgdXNlIG9mIHRoaXMgcHJvcGVydHkgY29tZXMgYW5kIGdvZXMgd2l0aCB3aGF0ZXZlciB3ZSBtaWdodCBiZSBkZWJ1Z2dpbmcsIHdoYXRldmVyIGhhY2tzIHdlIG1heVxuICAvLyBoYXZlIHRlbXBvcmFyaWx5IGFkZGVkLCBldGMuIEV2ZW4gaWYgd2UgZG9uJ3QgaGFwcGVuIHRvIGJlIHVzaW5nIGl0IGF0IHNvbWUgcG9pbnQgaW4gdGhlIGZ1dHVyZSwgbGV0J3Mgbm90IGdldCByaWRcbiAgLy8gb2YgdGhpcyBgZGVsZXRlYCwgbGVzdCB3ZSBtaXNzIHB1dHRpbmcgaXQgYmFjayBpbiB0aGUgbmV4dCB0aW1lIHRoZSBwcm9wZXJ0eSBpcyBpbiB1c2UuKVxuICBkZWxldGUgZXZlbnQuc2RrUHJvY2Vzc2luZ01ldGFkYXRhO1xuXG4gIGNvbnN0IGV2ZW50SXRlbSA9IFt7IHR5cGU6IGV2ZW50VHlwZSB9LCBldmVudF07XG4gIHJldHVybiBlbnZlbG9wZS5jcmVhdGVFbnZlbG9wZShlbnZlbG9wZUhlYWRlcnMsIFtldmVudEl0ZW1dKTtcbn1cblxuLyoqXG4gKiBDcmVhdGUgZW52ZWxvcGUgZnJvbSBTcGFuIGl0ZW0uXG4gKlxuICogVGFrZXMgYW4gb3B0aW9uYWwgY2xpZW50IGFuZCBydW5zIHNwYW5zIHRocm91Z2ggYGJlZm9yZVNlbmRTcGFuYCBpZiBhdmFpbGFibGUuXG4gKi9cbmZ1bmN0aW9uIGNyZWF0ZVNwYW5FbnZlbG9wZShzcGFucywgY2xpZW50KSB7XG4gIGZ1bmN0aW9uIGRzY0hhc1JlcXVpcmVkUHJvcHMoZHNjKSB7XG4gICAgcmV0dXJuICEhZHNjLnRyYWNlX2lkICYmICEhZHNjLnB1YmxpY19rZXk7XG4gIH1cblxuICAvLyBGb3IgdGhlIG1vbWVudCB3ZSdsbCBvYnRhaW4gdGhlIERTQyBmcm9tIHRoZSBmaXJzdCBzcGFuIGluIHRoZSBhcnJheVxuICAvLyBUaGlzIG1pZ2h0IG5lZWQgdG8gYmUgY2hhbmdlZCBpZiB3ZSBwZXJtaXQgc2VuZGluZyBtdWx0aXBsZSBzcGFucyBmcm9tXG4gIC8vIGRpZmZlcmVudCBzZWdtZW50cyBpbiBvbmUgZW52ZWxvcGVcbiAgY29uc3QgZHNjID0gZHluYW1pY1NhbXBsaW5nQ29udGV4dC5nZXREeW5hbWljU2FtcGxpbmdDb250ZXh0RnJvbVNwYW4oc3BhbnNbMF0pO1xuXG4gIGNvbnN0IGRzbiQxID0gY2xpZW50Py5nZXREc24oKTtcbiAgY29uc3QgdHVubmVsID0gY2xpZW50Py5nZXRPcHRpb25zKCkudHVubmVsO1xuXG4gIGNvbnN0IGhlYWRlcnMgPSB7XG4gICAgc2VudF9hdDogbmV3IERhdGUoKS50b0lTT1N0cmluZygpLFxuICAgIC4uLihkc2NIYXNSZXF1aXJlZFByb3BzKGRzYykgJiYgeyB0cmFjZTogZHNjIH0pLFxuICAgIC4uLighIXR1bm5lbCAmJiBkc24kMSAmJiB7IGRzbjogZHNuLmRzblRvU3RyaW5nKGRzbiQxKSB9KSxcbiAgfTtcblxuICBjb25zdCBiZWZvcmVTZW5kU3BhbiA9IGNsaWVudD8uZ2V0T3B0aW9ucygpLmJlZm9yZVNlbmRTcGFuO1xuICBjb25zdCBjb252ZXJ0VG9TcGFuSlNPTiA9IGJlZm9yZVNlbmRTcGFuXG4gICAgPyAoc3BhbikgPT4ge1xuICAgICAgICBjb25zdCBzcGFuSnNvbiA9IHNwYW5VdGlscy5zcGFuVG9KU09OKHNwYW4pO1xuICAgICAgICBjb25zdCBwcm9jZXNzZWRTcGFuID0gYmVmb3JlU2VuZFNwYW4oc3Bhbkpzb24pO1xuXG4gICAgICAgIGlmICghcHJvY2Vzc2VkU3Bhbikge1xuICAgICAgICAgIHNwYW5VdGlscy5zaG93U3BhbkRyb3BXYXJuaW5nKCk7XG4gICAgICAgICAgcmV0dXJuIHNwYW5Kc29uO1xuICAgICAgICB9XG5cbiAgICAgICAgcmV0dXJuIHByb2Nlc3NlZFNwYW47XG4gICAgICB9XG4gICAgOiBzcGFuVXRpbHMuc3BhblRvSlNPTjtcblxuICBjb25zdCBpdGVtcyA9IFtdO1xuICBmb3IgKGNvbnN0IHNwYW4gb2Ygc3BhbnMpIHtcbiAgICBjb25zdCBzcGFuSnNvbiA9IGNvbnZlcnRUb1NwYW5KU09OKHNwYW4pO1xuICAgIGlmIChzcGFuSnNvbikge1xuICAgICAgaXRlbXMucHVzaChlbnZlbG9wZS5jcmVhdGVTcGFuRW52ZWxvcGVJdGVtKHNwYW5Kc29uKSk7XG4gICAgfVxuICB9XG5cbiAgcmV0dXJuIGVudmVsb3BlLmNyZWF0ZUVudmVsb3BlKGhlYWRlcnMsIGl0ZW1zKTtcbn1cblxuZXhwb3J0cy5jcmVhdGVFdmVudEVudmVsb3BlID0gY3JlYXRlRXZlbnRFbnZlbG9wZTtcbmV4cG9ydHMuY3JlYXRlU2Vzc2lvbkVudmVsb3BlID0gY3JlYXRlU2Vzc2lvbkVudmVsb3BlO1xuZXhwb3J0cy5jcmVhdGVTcGFuRW52ZWxvcGUgPSBjcmVhdGVTcGFuRW52ZWxvcGU7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1lbnZlbG9wZS5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/envelope.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/eventProcessors.js":
/*!*******************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/eventProcessors.js ***!
  \*******************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst debugBuild = __webpack_require__(/*! ./debug-build.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst debugLogger = __webpack_require__(/*! ./utils/debug-logger.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst is = __webpack_require__(/*! ./utils/is.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js\");\nconst syncpromise = __webpack_require__(/*! ./utils/syncpromise.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/syncpromise.js\");\n\n/**\n * Process an array of event processors, returning the processed event (or `null` if the event was dropped).\n */\nfunction notifyEventProcessors(\n  processors,\n  event,\n  hint,\n  index = 0,\n) {\n  return new syncpromise.SyncPromise((resolve, reject) => {\n    const processor = processors[index];\n    if (event === null || typeof processor !== 'function') {\n      resolve(event);\n    } else {\n      const result = processor({ ...event }, hint) ;\n\n      debugBuild.DEBUG_BUILD && processor.id && result === null && debugLogger.debug.log(`Event processor \"${processor.id}\" dropped event`);\n\n      if (is.isThenable(result)) {\n        void result\n          .then(final => notifyEventProcessors(processors, final, hint, index + 1).then(resolve))\n          .then(null, reject);\n      } else {\n        void notifyEventProcessors(processors, result, hint, index + 1)\n          .then(resolve)\n          .then(null, reject);\n      }\n    }\n  });\n}\n\nexports.notifyEventProcessors = notifyEventProcessors;\n//# sourceMappingURL=eventProcessors.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9ldmVudFByb2Nlc3NvcnMuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsbUJBQW1CLG1CQUFPLENBQUMsMkhBQWtCO0FBQzdDLG9CQUFvQixtQkFBTyxDQUFDLHlJQUF5QjtBQUNyRCxXQUFXLG1CQUFPLENBQUMscUhBQWU7QUFDbEMsb0JBQW9CLG1CQUFPLENBQUMsdUlBQXdCOztBQUVwRDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLE1BQU07QUFDTixpQ0FBaUMsVUFBVTs7QUFFM0MsNkdBQTZHLGFBQWE7O0FBRTFIO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsUUFBUTtBQUNSO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxHQUFHO0FBQ0g7O0FBRUEsNkJBQTZCO0FBQzdCIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvZXZlbnRQcm9jZXNzb3JzLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBkZWJ1Z0J1aWxkID0gcmVxdWlyZSgnLi9kZWJ1Zy1idWlsZC5qcycpO1xuY29uc3QgZGVidWdMb2dnZXIgPSByZXF1aXJlKCcuL3V0aWxzL2RlYnVnLWxvZ2dlci5qcycpO1xuY29uc3QgaXMgPSByZXF1aXJlKCcuL3V0aWxzL2lzLmpzJyk7XG5jb25zdCBzeW5jcHJvbWlzZSA9IHJlcXVpcmUoJy4vdXRpbHMvc3luY3Byb21pc2UuanMnKTtcblxuLyoqXG4gKiBQcm9jZXNzIGFuIGFycmF5IG9mIGV2ZW50IHByb2Nlc3NvcnMsIHJldHVybmluZyB0aGUgcHJvY2Vzc2VkIGV2ZW50IChvciBgbnVsbGAgaWYgdGhlIGV2ZW50IHdhcyBkcm9wcGVkKS5cbiAqL1xuZnVuY3Rpb24gbm90aWZ5RXZlbnRQcm9jZXNzb3JzKFxuICBwcm9jZXNzb3JzLFxuICBldmVudCxcbiAgaGludCxcbiAgaW5kZXggPSAwLFxuKSB7XG4gIHJldHVybiBuZXcgc3luY3Byb21pc2UuU3luY1Byb21pc2UoKHJlc29sdmUsIHJlamVjdCkgPT4ge1xuICAgIGNvbnN0IHByb2Nlc3NvciA9IHByb2Nlc3NvcnNbaW5kZXhdO1xuICAgIGlmIChldmVudCA9PT0gbnVsbCB8fCB0eXBlb2YgcHJvY2Vzc29yICE9PSAnZnVuY3Rpb24nKSB7XG4gICAgICByZXNvbHZlKGV2ZW50KTtcbiAgICB9IGVsc2Uge1xuICAgICAgY29uc3QgcmVzdWx0ID0gcHJvY2Vzc29yKHsgLi4uZXZlbnQgfSwgaGludCkgO1xuXG4gICAgICBkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEICYmIHByb2Nlc3Nvci5pZCAmJiByZXN1bHQgPT09IG51bGwgJiYgZGVidWdMb2dnZXIuZGVidWcubG9nKGBFdmVudCBwcm9jZXNzb3IgXCIke3Byb2Nlc3Nvci5pZH1cIiBkcm9wcGVkIGV2ZW50YCk7XG5cbiAgICAgIGlmIChpcy5pc1RoZW5hYmxlKHJlc3VsdCkpIHtcbiAgICAgICAgdm9pZCByZXN1bHRcbiAgICAgICAgICAudGhlbihmaW5hbCA9PiBub3RpZnlFdmVudFByb2Nlc3NvcnMocHJvY2Vzc29ycywgZmluYWwsIGhpbnQsIGluZGV4ICsgMSkudGhlbihyZXNvbHZlKSlcbiAgICAgICAgICAudGhlbihudWxsLCByZWplY3QpO1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgdm9pZCBub3RpZnlFdmVudFByb2Nlc3NvcnMocHJvY2Vzc29ycywgcmVzdWx0LCBoaW50LCBpbmRleCArIDEpXG4gICAgICAgICAgLnRoZW4ocmVzb2x2ZSlcbiAgICAgICAgICAudGhlbihudWxsLCByZWplY3QpO1xuICAgICAgfVxuICAgIH1cbiAgfSk7XG59XG5cbmV4cG9ydHMubm90aWZ5RXZlbnRQcm9jZXNzb3JzID0gbm90aWZ5RXZlbnRQcm9jZXNzb3JzO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9ZXZlbnRQcm9jZXNzb3JzLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/eventProcessors.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/exports.js":
/*!***********************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/exports.js ***!
  \***********************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst currentScopes = __webpack_require__(/*! ./currentScopes.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst debugBuild = __webpack_require__(/*! ./debug-build.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst session = __webpack_require__(/*! ./session.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/session.js\");\nconst debugLogger = __webpack_require__(/*! ./utils/debug-logger.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst is = __webpack_require__(/*! ./utils/is.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js\");\nconst misc = __webpack_require__(/*! ./utils/misc.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/misc.js\");\nconst prepareEvent = __webpack_require__(/*! ./utils/prepareEvent.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/prepareEvent.js\");\nconst time = __webpack_require__(/*! ./utils/time.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/time.js\");\nconst worldwide = __webpack_require__(/*! ./utils/worldwide.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/worldwide.js\");\n\n/**\n * Captures an exception event and sends it to Sentry.\n *\n * @param exception The exception to capture.\n * @param hint Optional additional data to attach to the Sentry event.\n * @returns the id of the captured Sentry event.\n */\nfunction captureException(exception, hint) {\n  return currentScopes.getCurrentScope().captureException(exception, prepareEvent.parseEventHintOrCaptureContext(hint));\n}\n\n/**\n * Captures a message event and sends it to Sentry.\n *\n * @param message The message to send to Sentry.\n * @param captureContext Define the level of the message or pass in additional data to attach to the message.\n * @returns the id of the captured message.\n */\nfunction captureMessage(message, captureContext) {\n  // This is necessary to provide explicit scopes upgrade, without changing the original\n  // arity of the `captureMessage(message, level)` method.\n  const level = typeof captureContext === 'string' ? captureContext : undefined;\n  const context = typeof captureContext !== 'string' ? { captureContext } : undefined;\n  return currentScopes.getCurrentScope().captureMessage(message, level, context);\n}\n\n/**\n * Captures a manually created event and sends it to Sentry.\n *\n * @param event The event to send to Sentry.\n * @param hint Optional additional data to attach to the Sentry event.\n * @returns the id of the captured event.\n */\nfunction captureEvent(event, hint) {\n  return currentScopes.getCurrentScope().captureEvent(event, hint);\n}\n\n/**\n * Sets context data with the given name.\n * @param name of the context\n * @param context Any kind of data. This data will be normalized.\n */\nfunction setContext(name, context) {\n  currentScopes.getIsolationScope().setContext(name, context);\n}\n\n/**\n * Set an object that will be merged sent as extra data with the event.\n * @param extras Extras object to merge into current context.\n */\nfunction setExtras(extras) {\n  currentScopes.getIsolationScope().setExtras(extras);\n}\n\n/**\n * Set key:value that will be sent as extra data with the event.\n * @param key String of extra\n * @param extra Any kind of data. This data will be normalized.\n */\nfunction setExtra(key, extra) {\n  currentScopes.getIsolationScope().setExtra(key, extra);\n}\n\n/**\n * Set an object that will be merged sent as tags data with the event.\n * @param tags Tags context object to merge into current context.\n */\nfunction setTags(tags) {\n  currentScopes.getIsolationScope().setTags(tags);\n}\n\n/**\n * Set key:value that will be sent as tags data with the event.\n *\n * Can also be used to unset a tag, by passing `undefined`.\n *\n * @param key String key of tag\n * @param value Value of tag\n */\nfunction setTag(key, value) {\n  currentScopes.getIsolationScope().setTag(key, value);\n}\n\n/**\n * Updates user context information for future events.\n *\n * @param user User context object to be set in the current context. Pass `null` to unset the user.\n */\nfunction setUser(user) {\n  currentScopes.getIsolationScope().setUser(user);\n}\n\n/**\n * The last error event id of the isolation scope.\n *\n * Warning: This function really returns the last recorded error event id on the current\n * isolation scope. If you call this function after handling a certain error and another error\n * is captured in between, the last one is returned instead of the one you might expect.\n * Also, ids of events that were never sent to Sentry (for example because\n * they were dropped in `beforeSend`) could be returned.\n *\n * @returns The last event id of the isolation scope.\n */\nfunction lastEventId() {\n  return currentScopes.getIsolationScope().lastEventId();\n}\n\n/**\n * Create a cron monitor check in and send it to Sentry.\n *\n * @param checkIn An object that describes a check in.\n * @param upsertMonitorConfig An optional object that describes a monitor config. Use this if you want\n * to create a monitor automatically when sending a check in.\n */\nfunction captureCheckIn(checkIn, upsertMonitorConfig) {\n  const scope = currentScopes.getCurrentScope();\n  const client = currentScopes.getClient();\n  if (!client) {\n    debugBuild.DEBUG_BUILD && debugLogger.debug.warn('Cannot capture check-in. No client defined.');\n  } else if (!client.captureCheckIn) {\n    debugBuild.DEBUG_BUILD && debugLogger.debug.warn('Cannot capture check-in. Client does not support sending check-ins.');\n  } else {\n    return client.captureCheckIn(checkIn, upsertMonitorConfig, scope);\n  }\n\n  return misc.uuid4();\n}\n\n/**\n * Wraps a callback with a cron monitor check in. The check in will be sent to Sentry when the callback finishes.\n *\n * @param monitorSlug The distinct slug of the monitor.\n * @param callback Callback to be monitored\n * @param upsertMonitorConfig An optional object that describes a monitor config. Use this if you want\n * to create a monitor automatically when sending a check in.\n */\nfunction withMonitor(\n  monitorSlug,\n  callback,\n  upsertMonitorConfig,\n) {\n  const checkInId = captureCheckIn({ monitorSlug, status: 'in_progress' }, upsertMonitorConfig);\n  const now = time.timestampInSeconds();\n\n  function finishCheckIn(status) {\n    captureCheckIn({ monitorSlug, status, checkInId, duration: time.timestampInSeconds() - now });\n  }\n\n  return currentScopes.withIsolationScope(() => {\n    let maybePromiseResult;\n    try {\n      maybePromiseResult = callback();\n    } catch (e) {\n      finishCheckIn('error');\n      throw e;\n    }\n\n    if (is.isThenable(maybePromiseResult)) {\n      return maybePromiseResult.then(\n        r => {\n          finishCheckIn('ok');\n          return r;\n        },\n        e => {\n          finishCheckIn('error');\n          throw e;\n        },\n      ) ;\n    }\n    finishCheckIn('ok');\n\n    return maybePromiseResult;\n  });\n}\n\n/**\n * Call `flush()` on the current client, if there is one. See {@link Client.flush}.\n *\n * @param timeout Maximum time in ms the client should wait to flush its event queue. Omitting this parameter will cause\n * the client to wait until all events are sent before resolving the promise.\n * @returns A promise which resolves to `true` if the queue successfully drains before the timeout, or `false` if it\n * doesn't (or if there's no client defined).\n */\nasync function flush(timeout) {\n  const client = currentScopes.getClient();\n  if (client) {\n    return client.flush(timeout);\n  }\n  debugBuild.DEBUG_BUILD && debugLogger.debug.warn('Cannot flush events. No client defined.');\n  return Promise.resolve(false);\n}\n\n/**\n * Call `close()` on the current client, if there is one. See {@link Client.close}.\n *\n * @param timeout Maximum time in ms the client should wait to flush its event queue before shutting down. Omitting this\n * parameter will cause the client to wait until all events are sent before disabling itself.\n * @returns A promise which resolves to `true` if the queue successfully drains before the timeout, or `false` if it\n * doesn't (or if there's no client defined).\n */\nasync function close(timeout) {\n  const client = currentScopes.getClient();\n  if (client) {\n    return client.close(timeout);\n  }\n  debugBuild.DEBUG_BUILD && debugLogger.debug.warn('Cannot flush events and disable SDK. No client defined.');\n  return Promise.resolve(false);\n}\n\n/**\n * Returns true if Sentry has been properly initialized.\n */\nfunction isInitialized() {\n  return !!currentScopes.getClient();\n}\n\n/** If the SDK is initialized & enabled. */\nfunction isEnabled() {\n  const client = currentScopes.getClient();\n  return client?.getOptions().enabled !== false && !!client?.getTransport();\n}\n\n/**\n * Add an event processor.\n * This will be added to the current isolation scope, ensuring any event that is processed in the current execution\n * context will have the processor applied.\n */\nfunction addEventProcessor(callback) {\n  currentScopes.getIsolationScope().addEventProcessor(callback);\n}\n\n/**\n * Start a session on the current isolation scope.\n *\n * @param context (optional) additional properties to be applied to the returned session object\n *\n * @returns the new active session\n */\nfunction startSession(context) {\n  const isolationScope = currentScopes.getIsolationScope();\n  const currentScope = currentScopes.getCurrentScope();\n\n  // Will fetch userAgent if called from browser sdk\n  const { userAgent } = worldwide.GLOBAL_OBJ.navigator || {};\n\n  const session$1 = session.makeSession({\n    user: currentScope.getUser() || isolationScope.getUser(),\n    ...(userAgent && { userAgent }),\n    ...context,\n  });\n\n  // End existing session if there's one\n  const currentSession = isolationScope.getSession();\n  if (currentSession?.status === 'ok') {\n    session.updateSession(currentSession, { status: 'exited' });\n  }\n\n  endSession();\n\n  // Afterwards we set the new session on the scope\n  isolationScope.setSession(session$1);\n\n  return session$1;\n}\n\n/**\n * End the session on the current isolation scope.\n */\nfunction endSession() {\n  const isolationScope = currentScopes.getIsolationScope();\n  const currentScope = currentScopes.getCurrentScope();\n\n  const session$1 = currentScope.getSession() || isolationScope.getSession();\n  if (session$1) {\n    session.closeSession(session$1);\n  }\n  _sendSessionUpdate();\n\n  // the session is over; take it off of the scope\n  isolationScope.setSession();\n}\n\n/**\n * Sends the current Session on the scope\n */\nfunction _sendSessionUpdate() {\n  const isolationScope = currentScopes.getIsolationScope();\n  const client = currentScopes.getClient();\n  const session = isolationScope.getSession();\n  if (session && client) {\n    client.captureSession(session);\n  }\n}\n\n/**\n * Sends the current session on the scope to Sentry\n *\n * @param end If set the session will be marked as exited and removed from the scope.\n *            Defaults to `false`.\n */\nfunction captureSession(end = false) {\n  // both send the update and pull the session from the scope\n  if (end) {\n    endSession();\n    return;\n  }\n\n  // only send the update\n  _sendSessionUpdate();\n}\n\nexports.addEventProcessor = addEventProcessor;\nexports.captureCheckIn = captureCheckIn;\nexports.captureEvent = captureEvent;\nexports.captureException = captureException;\nexports.captureMessage = captureMessage;\nexports.captureSession = captureSession;\nexports.close = close;\nexports.endSession = endSession;\nexports.flush = flush;\nexports.isEnabled = isEnabled;\nexports.isInitialized = isInitialized;\nexports.lastEventId = lastEventId;\nexports.setContext = setContext;\nexports.setExtra = setExtra;\nexports.setExtras = setExtras;\nexports.setTag = setTag;\nexports.setTags = setTags;\nexports.setUser = setUser;\nexports.startSession = startSession;\nexports.withMonitor = withMonitor;\n//# sourceMappingURL=exports.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9leHBvcnRzLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLHNCQUFzQixtQkFBTyxDQUFDLCtIQUFvQjtBQUNsRCxtQkFBbUIsbUJBQU8sQ0FBQywySEFBa0I7QUFDN0MsZ0JBQWdCLG1CQUFPLENBQUMsbUhBQWM7QUFDdEMsb0JBQW9CLG1CQUFPLENBQUMseUlBQXlCO0FBQ3JELFdBQVcsbUJBQU8sQ0FBQyxxSEFBZTtBQUNsQyxhQUFhLG1CQUFPLENBQUMseUhBQWlCO0FBQ3RDLHFCQUFxQixtQkFBTyxDQUFDLHlJQUF5QjtBQUN0RCxhQUFhLG1CQUFPLENBQUMseUhBQWlCO0FBQ3RDLGtCQUFrQixtQkFBTyxDQUFDLG1JQUFzQjs7QUFFaEQ7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLHlEQUF5RCxpQkFBaUI7QUFDMUU7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsSUFBSTtBQUNKO0FBQ0EsSUFBSTtBQUNKO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLHFDQUFxQyxvQ0FBb0M7QUFDekU7O0FBRUE7QUFDQSxxQkFBcUIsMkVBQTJFO0FBQ2hHOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsTUFBTTtBQUNOO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsU0FBUztBQUNUO0FBQ0E7QUFDQTtBQUNBLFNBQVM7QUFDVDtBQUNBO0FBQ0E7O0FBRUE7QUFDQSxHQUFHO0FBQ0g7O0FBRUE7QUFDQSwrREFBK0QsbUJBQW1CO0FBQ2xGO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQSwrREFBK0QsbUJBQW1CO0FBQ2xGO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBLFVBQVUsWUFBWTs7QUFFdEI7QUFDQTtBQUNBLHVCQUF1QixXQUFXO0FBQ2xDO0FBQ0EsR0FBRzs7QUFFSDtBQUNBO0FBQ0E7QUFDQSw0Q0FBNEMsa0JBQWtCO0FBQzlEOztBQUVBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSwwQkFBMEI7QUFDMUI7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUEseUJBQXlCO0FBQ3pCLHNCQUFzQjtBQUN0QixvQkFBb0I7QUFDcEIsd0JBQXdCO0FBQ3hCLHNCQUFzQjtBQUN0QixzQkFBc0I7QUFDdEIsYUFBYTtBQUNiLGtCQUFrQjtBQUNsQixhQUFhO0FBQ2IsaUJBQWlCO0FBQ2pCLHFCQUFxQjtBQUNyQixtQkFBbUI7QUFDbkIsa0JBQWtCO0FBQ2xCLGdCQUFnQjtBQUNoQixpQkFBaUI7QUFDakIsY0FBYztBQUNkLGVBQWU7QUFDZixlQUFlO0FBQ2Ysb0JBQW9CO0FBQ3BCLG1CQUFtQjtBQUNuQiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL2V4cG9ydHMuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGN1cnJlbnRTY29wZXMgPSByZXF1aXJlKCcuL2N1cnJlbnRTY29wZXMuanMnKTtcbmNvbnN0IGRlYnVnQnVpbGQgPSByZXF1aXJlKCcuL2RlYnVnLWJ1aWxkLmpzJyk7XG5jb25zdCBzZXNzaW9uID0gcmVxdWlyZSgnLi9zZXNzaW9uLmpzJyk7XG5jb25zdCBkZWJ1Z0xvZ2dlciA9IHJlcXVpcmUoJy4vdXRpbHMvZGVidWctbG9nZ2VyLmpzJyk7XG5jb25zdCBpcyA9IHJlcXVpcmUoJy4vdXRpbHMvaXMuanMnKTtcbmNvbnN0IG1pc2MgPSByZXF1aXJlKCcuL3V0aWxzL21pc2MuanMnKTtcbmNvbnN0IHByZXBhcmVFdmVudCA9IHJlcXVpcmUoJy4vdXRpbHMvcHJlcGFyZUV2ZW50LmpzJyk7XG5jb25zdCB0aW1lID0gcmVxdWlyZSgnLi91dGlscy90aW1lLmpzJyk7XG5jb25zdCB3b3JsZHdpZGUgPSByZXF1aXJlKCcuL3V0aWxzL3dvcmxkd2lkZS5qcycpO1xuXG4vKipcbiAqIENhcHR1cmVzIGFuIGV4Y2VwdGlvbiBldmVudCBhbmQgc2VuZHMgaXQgdG8gU2VudHJ5LlxuICpcbiAqIEBwYXJhbSBleGNlcHRpb24gVGhlIGV4Y2VwdGlvbiB0byBjYXB0dXJlLlxuICogQHBhcmFtIGhpbnQgT3B0aW9uYWwgYWRkaXRpb25hbCBkYXRhIHRvIGF0dGFjaCB0byB0aGUgU2VudHJ5IGV2ZW50LlxuICogQHJldHVybnMgdGhlIGlkIG9mIHRoZSBjYXB0dXJlZCBTZW50cnkgZXZlbnQuXG4gKi9cbmZ1bmN0aW9uIGNhcHR1cmVFeGNlcHRpb24oZXhjZXB0aW9uLCBoaW50KSB7XG4gIHJldHVybiBjdXJyZW50U2NvcGVzLmdldEN1cnJlbnRTY29wZSgpLmNhcHR1cmVFeGNlcHRpb24oZXhjZXB0aW9uLCBwcmVwYXJlRXZlbnQucGFyc2VFdmVudEhpbnRPckNhcHR1cmVDb250ZXh0KGhpbnQpKTtcbn1cblxuLyoqXG4gKiBDYXB0dXJlcyBhIG1lc3NhZ2UgZXZlbnQgYW5kIHNlbmRzIGl0IHRvIFNlbnRyeS5cbiAqXG4gKiBAcGFyYW0gbWVzc2FnZSBUaGUgbWVzc2FnZSB0byBzZW5kIHRvIFNlbnRyeS5cbiAqIEBwYXJhbSBjYXB0dXJlQ29udGV4dCBEZWZpbmUgdGhlIGxldmVsIG9mIHRoZSBtZXNzYWdlIG9yIHBhc3MgaW4gYWRkaXRpb25hbCBkYXRhIHRvIGF0dGFjaCB0byB0aGUgbWVzc2FnZS5cbiAqIEByZXR1cm5zIHRoZSBpZCBvZiB0aGUgY2FwdHVyZWQgbWVzc2FnZS5cbiAqL1xuZnVuY3Rpb24gY2FwdHVyZU1lc3NhZ2UobWVzc2FnZSwgY2FwdHVyZUNvbnRleHQpIHtcbiAgLy8gVGhpcyBpcyBuZWNlc3NhcnkgdG8gcHJvdmlkZSBleHBsaWNpdCBzY29wZXMgdXBncmFkZSwgd2l0aG91dCBjaGFuZ2luZyB0aGUgb3JpZ2luYWxcbiAgLy8gYXJpdHkgb2YgdGhlIGBjYXB0dXJlTWVzc2FnZShtZXNzYWdlLCBsZXZlbClgIG1ldGhvZC5cbiAgY29uc3QgbGV2ZWwgPSB0eXBlb2YgY2FwdHVyZUNvbnRleHQgPT09ICdzdHJpbmcnID8gY2FwdHVyZUNvbnRleHQgOiB1bmRlZmluZWQ7XG4gIGNvbnN0IGNvbnRleHQgPSB0eXBlb2YgY2FwdHVyZUNvbnRleHQgIT09ICdzdHJpbmcnID8geyBjYXB0dXJlQ29udGV4dCB9IDogdW5kZWZpbmVkO1xuICByZXR1cm4gY3VycmVudFNjb3Blcy5nZXRDdXJyZW50U2NvcGUoKS5jYXB0dXJlTWVzc2FnZShtZXNzYWdlLCBsZXZlbCwgY29udGV4dCk7XG59XG5cbi8qKlxuICogQ2FwdHVyZXMgYSBtYW51YWxseSBjcmVhdGVkIGV2ZW50IGFuZCBzZW5kcyBpdCB0byBTZW50cnkuXG4gKlxuICogQHBhcmFtIGV2ZW50IFRoZSBldmVudCB0byBzZW5kIHRvIFNlbnRyeS5cbiAqIEBwYXJhbSBoaW50IE9wdGlvbmFsIGFkZGl0aW9uYWwgZGF0YSB0byBhdHRhY2ggdG8gdGhlIFNlbnRyeSBldmVudC5cbiAqIEByZXR1cm5zIHRoZSBpZCBvZiB0aGUgY2FwdHVyZWQgZXZlbnQuXG4gKi9cbmZ1bmN0aW9uIGNhcHR1cmVFdmVudChldmVudCwgaGludCkge1xuICByZXR1cm4gY3VycmVudFNjb3Blcy5nZXRDdXJyZW50U2NvcGUoKS5jYXB0dXJlRXZlbnQoZXZlbnQsIGhpbnQpO1xufVxuXG4vKipcbiAqIFNldHMgY29udGV4dCBkYXRhIHdpdGggdGhlIGdpdmVuIG5hbWUuXG4gKiBAcGFyYW0gbmFtZSBvZiB0aGUgY29udGV4dFxuICogQHBhcmFtIGNvbnRleHQgQW55IGtpbmQgb2YgZGF0YS4gVGhpcyBkYXRhIHdpbGwgYmUgbm9ybWFsaXplZC5cbiAqL1xuZnVuY3Rpb24gc2V0Q29udGV4dChuYW1lLCBjb250ZXh0KSB7XG4gIGN1cnJlbnRTY29wZXMuZ2V0SXNvbGF0aW9uU2NvcGUoKS5zZXRDb250ZXh0KG5hbWUsIGNvbnRleHQpO1xufVxuXG4vKipcbiAqIFNldCBhbiBvYmplY3QgdGhhdCB3aWxsIGJlIG1lcmdlZCBzZW50IGFzIGV4dHJhIGRhdGEgd2l0aCB0aGUgZXZlbnQuXG4gKiBAcGFyYW0gZXh0cmFzIEV4dHJhcyBvYmplY3QgdG8gbWVyZ2UgaW50byBjdXJyZW50IGNvbnRleHQuXG4gKi9cbmZ1bmN0aW9uIHNldEV4dHJhcyhleHRyYXMpIHtcbiAgY3VycmVudFNjb3Blcy5nZXRJc29sYXRpb25TY29wZSgpLnNldEV4dHJhcyhleHRyYXMpO1xufVxuXG4vKipcbiAqIFNldCBrZXk6dmFsdWUgdGhhdCB3aWxsIGJlIHNlbnQgYXMgZXh0cmEgZGF0YSB3aXRoIHRoZSBldmVudC5cbiAqIEBwYXJhbSBrZXkgU3RyaW5nIG9mIGV4dHJhXG4gKiBAcGFyYW0gZXh0cmEgQW55IGtpbmQgb2YgZGF0YS4gVGhpcyBkYXRhIHdpbGwgYmUgbm9ybWFsaXplZC5cbiAqL1xuZnVuY3Rpb24gc2V0RXh0cmEoa2V5LCBleHRyYSkge1xuICBjdXJyZW50U2NvcGVzLmdldElzb2xhdGlvblNjb3BlKCkuc2V0RXh0cmEoa2V5LCBleHRyYSk7XG59XG5cbi8qKlxuICogU2V0IGFuIG9iamVjdCB0aGF0IHdpbGwgYmUgbWVyZ2VkIHNlbnQgYXMgdGFncyBkYXRhIHdpdGggdGhlIGV2ZW50LlxuICogQHBhcmFtIHRhZ3MgVGFncyBjb250ZXh0IG9iamVjdCB0byBtZXJnZSBpbnRvIGN1cnJlbnQgY29udGV4dC5cbiAqL1xuZnVuY3Rpb24gc2V0VGFncyh0YWdzKSB7XG4gIGN1cnJlbnRTY29wZXMuZ2V0SXNvbGF0aW9uU2NvcGUoKS5zZXRUYWdzKHRhZ3MpO1xufVxuXG4vKipcbiAqIFNldCBrZXk6dmFsdWUgdGhhdCB3aWxsIGJlIHNlbnQgYXMgdGFncyBkYXRhIHdpdGggdGhlIGV2ZW50LlxuICpcbiAqIENhbiBhbHNvIGJlIHVzZWQgdG8gdW5zZXQgYSB0YWcsIGJ5IHBhc3NpbmcgYHVuZGVmaW5lZGAuXG4gKlxuICogQHBhcmFtIGtleSBTdHJpbmcga2V5IG9mIHRhZ1xuICogQHBhcmFtIHZhbHVlIFZhbHVlIG9mIHRhZ1xuICovXG5mdW5jdGlvbiBzZXRUYWcoa2V5LCB2YWx1ZSkge1xuICBjdXJyZW50U2NvcGVzLmdldElzb2xhdGlvblNjb3BlKCkuc2V0VGFnKGtleSwgdmFsdWUpO1xufVxuXG4vKipcbiAqIFVwZGF0ZXMgdXNlciBjb250ZXh0IGluZm9ybWF0aW9uIGZvciBmdXR1cmUgZXZlbnRzLlxuICpcbiAqIEBwYXJhbSB1c2VyIFVzZXIgY29udGV4dCBvYmplY3QgdG8gYmUgc2V0IGluIHRoZSBjdXJyZW50IGNvbnRleHQuIFBhc3MgYG51bGxgIHRvIHVuc2V0IHRoZSB1c2VyLlxuICovXG5mdW5jdGlvbiBzZXRVc2VyKHVzZXIpIHtcbiAgY3VycmVudFNjb3Blcy5nZXRJc29sYXRpb25TY29wZSgpLnNldFVzZXIodXNlcik7XG59XG5cbi8qKlxuICogVGhlIGxhc3QgZXJyb3IgZXZlbnQgaWQgb2YgdGhlIGlzb2xhdGlvbiBzY29wZS5cbiAqXG4gKiBXYXJuaW5nOiBUaGlzIGZ1bmN0aW9uIHJlYWxseSByZXR1cm5zIHRoZSBsYXN0IHJlY29yZGVkIGVycm9yIGV2ZW50IGlkIG9uIHRoZSBjdXJyZW50XG4gKiBpc29sYXRpb24gc2NvcGUuIElmIHlvdSBjYWxsIHRoaXMgZnVuY3Rpb24gYWZ0ZXIgaGFuZGxpbmcgYSBjZXJ0YWluIGVycm9yIGFuZCBhbm90aGVyIGVycm9yXG4gKiBpcyBjYXB0dXJlZCBpbiBiZXR3ZWVuLCB0aGUgbGFzdCBvbmUgaXMgcmV0dXJuZWQgaW5zdGVhZCBvZiB0aGUgb25lIHlvdSBtaWdodCBleHBlY3QuXG4gKiBBbHNvLCBpZHMgb2YgZXZlbnRzIHRoYXQgd2VyZSBuZXZlciBzZW50IHRvIFNlbnRyeSAoZm9yIGV4YW1wbGUgYmVjYXVzZVxuICogdGhleSB3ZXJlIGRyb3BwZWQgaW4gYGJlZm9yZVNlbmRgKSBjb3VsZCBiZSByZXR1cm5lZC5cbiAqXG4gKiBAcmV0dXJucyBUaGUgbGFzdCBldmVudCBpZCBvZiB0aGUgaXNvbGF0aW9uIHNjb3BlLlxuICovXG5mdW5jdGlvbiBsYXN0RXZlbnRJZCgpIHtcbiAgcmV0dXJuIGN1cnJlbnRTY29wZXMuZ2V0SXNvbGF0aW9uU2NvcGUoKS5sYXN0RXZlbnRJZCgpO1xufVxuXG4vKipcbiAqIENyZWF0ZSBhIGNyb24gbW9uaXRvciBjaGVjayBpbiBhbmQgc2VuZCBpdCB0byBTZW50cnkuXG4gKlxuICogQHBhcmFtIGNoZWNrSW4gQW4gb2JqZWN0IHRoYXQgZGVzY3JpYmVzIGEgY2hlY2sgaW4uXG4gKiBAcGFyYW0gdXBzZXJ0TW9uaXRvckNvbmZpZyBBbiBvcHRpb25hbCBvYmplY3QgdGhhdCBkZXNjcmliZXMgYSBtb25pdG9yIGNvbmZpZy4gVXNlIHRoaXMgaWYgeW91IHdhbnRcbiAqIHRvIGNyZWF0ZSBhIG1vbml0b3IgYXV0b21hdGljYWxseSB3aGVuIHNlbmRpbmcgYSBjaGVjayBpbi5cbiAqL1xuZnVuY3Rpb24gY2FwdHVyZUNoZWNrSW4oY2hlY2tJbiwgdXBzZXJ0TW9uaXRvckNvbmZpZykge1xuICBjb25zdCBzY29wZSA9IGN1cnJlbnRTY29wZXMuZ2V0Q3VycmVudFNjb3BlKCk7XG4gIGNvbnN0IGNsaWVudCA9IGN1cnJlbnRTY29wZXMuZ2V0Q2xpZW50KCk7XG4gIGlmICghY2xpZW50KSB7XG4gICAgZGVidWdCdWlsZC5ERUJVR19CVUlMRCAmJiBkZWJ1Z0xvZ2dlci5kZWJ1Zy53YXJuKCdDYW5ub3QgY2FwdHVyZSBjaGVjay1pbi4gTm8gY2xpZW50IGRlZmluZWQuJyk7XG4gIH0gZWxzZSBpZiAoIWNsaWVudC5jYXB0dXJlQ2hlY2tJbikge1xuICAgIGRlYnVnQnVpbGQuREVCVUdfQlVJTEQgJiYgZGVidWdMb2dnZXIuZGVidWcud2FybignQ2Fubm90IGNhcHR1cmUgY2hlY2staW4uIENsaWVudCBkb2VzIG5vdCBzdXBwb3J0IHNlbmRpbmcgY2hlY2staW5zLicpO1xuICB9IGVsc2Uge1xuICAgIHJldHVybiBjbGllbnQuY2FwdHVyZUNoZWNrSW4oY2hlY2tJbiwgdXBzZXJ0TW9uaXRvckNvbmZpZywgc2NvcGUpO1xuICB9XG5cbiAgcmV0dXJuIG1pc2MudXVpZDQoKTtcbn1cblxuLyoqXG4gKiBXcmFwcyBhIGNhbGxiYWNrIHdpdGggYSBjcm9uIG1vbml0b3IgY2hlY2sgaW4uIFRoZSBjaGVjayBpbiB3aWxsIGJlIHNlbnQgdG8gU2VudHJ5IHdoZW4gdGhlIGNhbGxiYWNrIGZpbmlzaGVzLlxuICpcbiAqIEBwYXJhbSBtb25pdG9yU2x1ZyBUaGUgZGlzdGluY3Qgc2x1ZyBvZiB0aGUgbW9uaXRvci5cbiAqIEBwYXJhbSBjYWxsYmFjayBDYWxsYmFjayB0byBiZSBtb25pdG9yZWRcbiAqIEBwYXJhbSB1cHNlcnRNb25pdG9yQ29uZmlnIEFuIG9wdGlvbmFsIG9iamVjdCB0aGF0IGRlc2NyaWJlcyBhIG1vbml0b3IgY29uZmlnLiBVc2UgdGhpcyBpZiB5b3Ugd2FudFxuICogdG8gY3JlYXRlIGEgbW9uaXRvciBhdXRvbWF0aWNhbGx5IHdoZW4gc2VuZGluZyBhIGNoZWNrIGluLlxuICovXG5mdW5jdGlvbiB3aXRoTW9uaXRvcihcbiAgbW9uaXRvclNsdWcsXG4gIGNhbGxiYWNrLFxuICB1cHNlcnRNb25pdG9yQ29uZmlnLFxuKSB7XG4gIGNvbnN0IGNoZWNrSW5JZCA9IGNhcHR1cmVDaGVja0luKHsgbW9uaXRvclNsdWcsIHN0YXR1czogJ2luX3Byb2dyZXNzJyB9LCB1cHNlcnRNb25pdG9yQ29uZmlnKTtcbiAgY29uc3Qgbm93ID0gdGltZS50aW1lc3RhbXBJblNlY29uZHMoKTtcblxuICBmdW5jdGlvbiBmaW5pc2hDaGVja0luKHN0YXR1cykge1xuICAgIGNhcHR1cmVDaGVja0luKHsgbW9uaXRvclNsdWcsIHN0YXR1cywgY2hlY2tJbklkLCBkdXJhdGlvbjogdGltZS50aW1lc3RhbXBJblNlY29uZHMoKSAtIG5vdyB9KTtcbiAgfVxuXG4gIHJldHVybiBjdXJyZW50U2NvcGVzLndpdGhJc29sYXRpb25TY29wZSgoKSA9PiB7XG4gICAgbGV0IG1heWJlUHJvbWlzZVJlc3VsdDtcbiAgICB0cnkge1xuICAgICAgbWF5YmVQcm9taXNlUmVzdWx0ID0gY2FsbGJhY2soKTtcbiAgICB9IGNhdGNoIChlKSB7XG4gICAgICBmaW5pc2hDaGVja0luKCdlcnJvcicpO1xuICAgICAgdGhyb3cgZTtcbiAgICB9XG5cbiAgICBpZiAoaXMuaXNUaGVuYWJsZShtYXliZVByb21pc2VSZXN1bHQpKSB7XG4gICAgICByZXR1cm4gbWF5YmVQcm9taXNlUmVzdWx0LnRoZW4oXG4gICAgICAgIHIgPT4ge1xuICAgICAgICAgIGZpbmlzaENoZWNrSW4oJ29rJyk7XG4gICAgICAgICAgcmV0dXJuIHI7XG4gICAgICAgIH0sXG4gICAgICAgIGUgPT4ge1xuICAgICAgICAgIGZpbmlzaENoZWNrSW4oJ2Vycm9yJyk7XG4gICAgICAgICAgdGhyb3cgZTtcbiAgICAgICAgfSxcbiAgICAgICkgO1xuICAgIH1cbiAgICBmaW5pc2hDaGVja0luKCdvaycpO1xuXG4gICAgcmV0dXJuIG1heWJlUHJvbWlzZVJlc3VsdDtcbiAgfSk7XG59XG5cbi8qKlxuICogQ2FsbCBgZmx1c2goKWAgb24gdGhlIGN1cnJlbnQgY2xpZW50LCBpZiB0aGVyZSBpcyBvbmUuIFNlZSB7QGxpbmsgQ2xpZW50LmZsdXNofS5cbiAqXG4gKiBAcGFyYW0gdGltZW91dCBNYXhpbXVtIHRpbWUgaW4gbXMgdGhlIGNsaWVudCBzaG91bGQgd2FpdCB0byBmbHVzaCBpdHMgZXZlbnQgcXVldWUuIE9taXR0aW5nIHRoaXMgcGFyYW1ldGVyIHdpbGwgY2F1c2VcbiAqIHRoZSBjbGllbnQgdG8gd2FpdCB1bnRpbCBhbGwgZXZlbnRzIGFyZSBzZW50IGJlZm9yZSByZXNvbHZpbmcgdGhlIHByb21pc2UuXG4gKiBAcmV0dXJucyBBIHByb21pc2Ugd2hpY2ggcmVzb2x2ZXMgdG8gYHRydWVgIGlmIHRoZSBxdWV1ZSBzdWNjZXNzZnVsbHkgZHJhaW5zIGJlZm9yZSB0aGUgdGltZW91dCwgb3IgYGZhbHNlYCBpZiBpdFxuICogZG9lc24ndCAob3IgaWYgdGhlcmUncyBubyBjbGllbnQgZGVmaW5lZCkuXG4gKi9cbmFzeW5jIGZ1bmN0aW9uIGZsdXNoKHRpbWVvdXQpIHtcbiAgY29uc3QgY2xpZW50ID0gY3VycmVudFNjb3Blcy5nZXRDbGllbnQoKTtcbiAgaWYgKGNsaWVudCkge1xuICAgIHJldHVybiBjbGllbnQuZmx1c2godGltZW91dCk7XG4gIH1cbiAgZGVidWdCdWlsZC5ERUJVR19CVUlMRCAmJiBkZWJ1Z0xvZ2dlci5kZWJ1Zy53YXJuKCdDYW5ub3QgZmx1c2ggZXZlbnRzLiBObyBjbGllbnQgZGVmaW5lZC4nKTtcbiAgcmV0dXJuIFByb21pc2UucmVzb2x2ZShmYWxzZSk7XG59XG5cbi8qKlxuICogQ2FsbCBgY2xvc2UoKWAgb24gdGhlIGN1cnJlbnQgY2xpZW50LCBpZiB0aGVyZSBpcyBvbmUuIFNlZSB7QGxpbmsgQ2xpZW50LmNsb3NlfS5cbiAqXG4gKiBAcGFyYW0gdGltZW91dCBNYXhpbXVtIHRpbWUgaW4gbXMgdGhlIGNsaWVudCBzaG91bGQgd2FpdCB0byBmbHVzaCBpdHMgZXZlbnQgcXVldWUgYmVmb3JlIHNodXR0aW5nIGRvd24uIE9taXR0aW5nIHRoaXNcbiAqIHBhcmFtZXRlciB3aWxsIGNhdXNlIHRoZSBjbGllbnQgdG8gd2FpdCB1bnRpbCBhbGwgZXZlbnRzIGFyZSBzZW50IGJlZm9yZSBkaXNhYmxpbmcgaXRzZWxmLlxuICogQHJldHVybnMgQSBwcm9taXNlIHdoaWNoIHJlc29sdmVzIHRvIGB0cnVlYCBpZiB0aGUgcXVldWUgc3VjY2Vzc2Z1bGx5IGRyYWlucyBiZWZvcmUgdGhlIHRpbWVvdXQsIG9yIGBmYWxzZWAgaWYgaXRcbiAqIGRvZXNuJ3QgKG9yIGlmIHRoZXJlJ3Mgbm8gY2xpZW50IGRlZmluZWQpLlxuICovXG5hc3luYyBmdW5jdGlvbiBjbG9zZSh0aW1lb3V0KSB7XG4gIGNvbnN0IGNsaWVudCA9IGN1cnJlbnRTY29wZXMuZ2V0Q2xpZW50KCk7XG4gIGlmIChjbGllbnQpIHtcbiAgICByZXR1cm4gY2xpZW50LmNsb3NlKHRpbWVvdXQpO1xuICB9XG4gIGRlYnVnQnVpbGQuREVCVUdfQlVJTEQgJiYgZGVidWdMb2dnZXIuZGVidWcud2FybignQ2Fubm90IGZsdXNoIGV2ZW50cyBhbmQgZGlzYWJsZSBTREsuIE5vIGNsaWVudCBkZWZpbmVkLicpO1xuICByZXR1cm4gUHJvbWlzZS5yZXNvbHZlKGZhbHNlKTtcbn1cblxuLyoqXG4gKiBSZXR1cm5zIHRydWUgaWYgU2VudHJ5IGhhcyBiZWVuIHByb3Blcmx5IGluaXRpYWxpemVkLlxuICovXG5mdW5jdGlvbiBpc0luaXRpYWxpemVkKCkge1xuICByZXR1cm4gISFjdXJyZW50U2NvcGVzLmdldENsaWVudCgpO1xufVxuXG4vKiogSWYgdGhlIFNESyBpcyBpbml0aWFsaXplZCAmIGVuYWJsZWQuICovXG5mdW5jdGlvbiBpc0VuYWJsZWQoKSB7XG4gIGNvbnN0IGNsaWVudCA9IGN1cnJlbnRTY29wZXMuZ2V0Q2xpZW50KCk7XG4gIHJldHVybiBjbGllbnQ/LmdldE9wdGlvbnMoKS5lbmFibGVkICE9PSBmYWxzZSAmJiAhIWNsaWVudD8uZ2V0VHJhbnNwb3J0KCk7XG59XG5cbi8qKlxuICogQWRkIGFuIGV2ZW50IHByb2Nlc3Nvci5cbiAqIFRoaXMgd2lsbCBiZSBhZGRlZCB0byB0aGUgY3VycmVudCBpc29sYXRpb24gc2NvcGUsIGVuc3VyaW5nIGFueSBldmVudCB0aGF0IGlzIHByb2Nlc3NlZCBpbiB0aGUgY3VycmVudCBleGVjdXRpb25cbiAqIGNvbnRleHQgd2lsbCBoYXZlIHRoZSBwcm9jZXNzb3IgYXBwbGllZC5cbiAqL1xuZnVuY3Rpb24gYWRkRXZlbnRQcm9jZXNzb3IoY2FsbGJhY2spIHtcbiAgY3VycmVudFNjb3Blcy5nZXRJc29sYXRpb25TY29wZSgpLmFkZEV2ZW50UHJvY2Vzc29yKGNhbGxiYWNrKTtcbn1cblxuLyoqXG4gKiBTdGFydCBhIHNlc3Npb24gb24gdGhlIGN1cnJlbnQgaXNvbGF0aW9uIHNjb3BlLlxuICpcbiAqIEBwYXJhbSBjb250ZXh0IChvcHRpb25hbCkgYWRkaXRpb25hbCBwcm9wZXJ0aWVzIHRvIGJlIGFwcGxpZWQgdG8gdGhlIHJldHVybmVkIHNlc3Npb24gb2JqZWN0XG4gKlxuICogQHJldHVybnMgdGhlIG5ldyBhY3RpdmUgc2Vzc2lvblxuICovXG5mdW5jdGlvbiBzdGFydFNlc3Npb24oY29udGV4dCkge1xuICBjb25zdCBpc29sYXRpb25TY29wZSA9IGN1cnJlbnRTY29wZXMuZ2V0SXNvbGF0aW9uU2NvcGUoKTtcbiAgY29uc3QgY3VycmVudFNjb3BlID0gY3VycmVudFNjb3Blcy5nZXRDdXJyZW50U2NvcGUoKTtcblxuICAvLyBXaWxsIGZldGNoIHVzZXJBZ2VudCBpZiBjYWxsZWQgZnJvbSBicm93c2VyIHNka1xuICBjb25zdCB7IHVzZXJBZ2VudCB9ID0gd29ybGR3aWRlLkdMT0JBTF9PQkoubmF2aWdhdG9yIHx8IHt9O1xuXG4gIGNvbnN0IHNlc3Npb24kMSA9IHNlc3Npb24ubWFrZVNlc3Npb24oe1xuICAgIHVzZXI6IGN1cnJlbnRTY29wZS5nZXRVc2VyKCkgfHwgaXNvbGF0aW9uU2NvcGUuZ2V0VXNlcigpLFxuICAgIC4uLih1c2VyQWdlbnQgJiYgeyB1c2VyQWdlbnQgfSksXG4gICAgLi4uY29udGV4dCxcbiAgfSk7XG5cbiAgLy8gRW5kIGV4aXN0aW5nIHNlc3Npb24gaWYgdGhlcmUncyBvbmVcbiAgY29uc3QgY3VycmVudFNlc3Npb24gPSBpc29sYXRpb25TY29wZS5nZXRTZXNzaW9uKCk7XG4gIGlmIChjdXJyZW50U2Vzc2lvbj8uc3RhdHVzID09PSAnb2snKSB7XG4gICAgc2Vzc2lvbi51cGRhdGVTZXNzaW9uKGN1cnJlbnRTZXNzaW9uLCB7IHN0YXR1czogJ2V4aXRlZCcgfSk7XG4gIH1cblxuICBlbmRTZXNzaW9uKCk7XG5cbiAgLy8gQWZ0ZXJ3YXJkcyB3ZSBzZXQgdGhlIG5ldyBzZXNzaW9uIG9uIHRoZSBzY29wZVxuICBpc29sYXRpb25TY29wZS5zZXRTZXNzaW9uKHNlc3Npb24kMSk7XG5cbiAgcmV0dXJuIHNlc3Npb24kMTtcbn1cblxuLyoqXG4gKiBFbmQgdGhlIHNlc3Npb24gb24gdGhlIGN1cnJlbnQgaXNvbGF0aW9uIHNjb3BlLlxuICovXG5mdW5jdGlvbiBlbmRTZXNzaW9uKCkge1xuICBjb25zdCBpc29sYXRpb25TY29wZSA9IGN1cnJlbnRTY29wZXMuZ2V0SXNvbGF0aW9uU2NvcGUoKTtcbiAgY29uc3QgY3VycmVudFNjb3BlID0gY3VycmVudFNjb3Blcy5nZXRDdXJyZW50U2NvcGUoKTtcblxuICBjb25zdCBzZXNzaW9uJDEgPSBjdXJyZW50U2NvcGUuZ2V0U2Vzc2lvbigpIHx8IGlzb2xhdGlvblNjb3BlLmdldFNlc3Npb24oKTtcbiAgaWYgKHNlc3Npb24kMSkge1xuICAgIHNlc3Npb24uY2xvc2VTZXNzaW9uKHNlc3Npb24kMSk7XG4gIH1cbiAgX3NlbmRTZXNzaW9uVXBkYXRlKCk7XG5cbiAgLy8gdGhlIHNlc3Npb24gaXMgb3ZlcjsgdGFrZSBpdCBvZmYgb2YgdGhlIHNjb3BlXG4gIGlzb2xhdGlvblNjb3BlLnNldFNlc3Npb24oKTtcbn1cblxuLyoqXG4gKiBTZW5kcyB0aGUgY3VycmVudCBTZXNzaW9uIG9uIHRoZSBzY29wZVxuICovXG5mdW5jdGlvbiBfc2VuZFNlc3Npb25VcGRhdGUoKSB7XG4gIGNvbnN0IGlzb2xhdGlvblNjb3BlID0gY3VycmVudFNjb3Blcy5nZXRJc29sYXRpb25TY29wZSgpO1xuICBjb25zdCBjbGllbnQgPSBjdXJyZW50U2NvcGVzLmdldENsaWVudCgpO1xuICBjb25zdCBzZXNzaW9uID0gaXNvbGF0aW9uU2NvcGUuZ2V0U2Vzc2lvbigpO1xuICBpZiAoc2Vzc2lvbiAmJiBjbGllbnQpIHtcbiAgICBjbGllbnQuY2FwdHVyZVNlc3Npb24oc2Vzc2lvbik7XG4gIH1cbn1cblxuLyoqXG4gKiBTZW5kcyB0aGUgY3VycmVudCBzZXNzaW9uIG9uIHRoZSBzY29wZSB0byBTZW50cnlcbiAqXG4gKiBAcGFyYW0gZW5kIElmIHNldCB0aGUgc2Vzc2lvbiB3aWxsIGJlIG1hcmtlZCBhcyBleGl0ZWQgYW5kIHJlbW92ZWQgZnJvbSB0aGUgc2NvcGUuXG4gKiAgICAgICAgICAgIERlZmF1bHRzIHRvIGBmYWxzZWAuXG4gKi9cbmZ1bmN0aW9uIGNhcHR1cmVTZXNzaW9uKGVuZCA9IGZhbHNlKSB7XG4gIC8vIGJvdGggc2VuZCB0aGUgdXBkYXRlIGFuZCBwdWxsIHRoZSBzZXNzaW9uIGZyb20gdGhlIHNjb3BlXG4gIGlmIChlbmQpIHtcbiAgICBlbmRTZXNzaW9uKCk7XG4gICAgcmV0dXJuO1xuICB9XG5cbiAgLy8gb25seSBzZW5kIHRoZSB1cGRhdGVcbiAgX3NlbmRTZXNzaW9uVXBkYXRlKCk7XG59XG5cbmV4cG9ydHMuYWRkRXZlbnRQcm9jZXNzb3IgPSBhZGRFdmVudFByb2Nlc3NvcjtcbmV4cG9ydHMuY2FwdHVyZUNoZWNrSW4gPSBjYXB0dXJlQ2hlY2tJbjtcbmV4cG9ydHMuY2FwdHVyZUV2ZW50ID0gY2FwdHVyZUV2ZW50O1xuZXhwb3J0cy5jYXB0dXJlRXhjZXB0aW9uID0gY2FwdHVyZUV4Y2VwdGlvbjtcbmV4cG9ydHMuY2FwdHVyZU1lc3NhZ2UgPSBjYXB0dXJlTWVzc2FnZTtcbmV4cG9ydHMuY2FwdHVyZVNlc3Npb24gPSBjYXB0dXJlU2Vzc2lvbjtcbmV4cG9ydHMuY2xvc2UgPSBjbG9zZTtcbmV4cG9ydHMuZW5kU2Vzc2lvbiA9IGVuZFNlc3Npb247XG5leHBvcnRzLmZsdXNoID0gZmx1c2g7XG5leHBvcnRzLmlzRW5hYmxlZCA9IGlzRW5hYmxlZDtcbmV4cG9ydHMuaXNJbml0aWFsaXplZCA9IGlzSW5pdGlhbGl6ZWQ7XG5leHBvcnRzLmxhc3RFdmVudElkID0gbGFzdEV2ZW50SWQ7XG5leHBvcnRzLnNldENvbnRleHQgPSBzZXRDb250ZXh0O1xuZXhwb3J0cy5zZXRFeHRyYSA9IHNldEV4dHJhO1xuZXhwb3J0cy5zZXRFeHRyYXMgPSBzZXRFeHRyYXM7XG5leHBvcnRzLnNldFRhZyA9IHNldFRhZztcbmV4cG9ydHMuc2V0VGFncyA9IHNldFRhZ3M7XG5leHBvcnRzLnNldFVzZXIgPSBzZXRVc2VyO1xuZXhwb3J0cy5zdGFydFNlc3Npb24gPSBzdGFydFNlc3Npb247XG5leHBvcnRzLndpdGhNb25pdG9yID0gd2l0aE1vbml0b3I7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1leHBvcnRzLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/exports.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/feedback.js":
/*!************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/feedback.js ***!
  \************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst currentScopes = __webpack_require__(/*! ./currentScopes.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\n\n/**\n * Send user feedback to Sentry.\n */\nfunction captureFeedback(\n  params,\n  hint = {},\n  scope = currentScopes.getCurrentScope(),\n) {\n  const { message, name, email, url, source, associatedEventId, tags } = params;\n\n  const feedbackEvent = {\n    contexts: {\n      feedback: {\n        contact_email: email,\n        name,\n        message,\n        url,\n        source,\n        associated_event_id: associatedEventId,\n      },\n    },\n    type: 'feedback',\n    level: 'info',\n    tags,\n  };\n\n  const client = scope?.getClient() || currentScopes.getClient();\n\n  if (client) {\n    client.emit('beforeSendFeedback', feedbackEvent, hint);\n  }\n\n  const eventId = scope.captureEvent(feedbackEvent, hint);\n\n  return eventId;\n}\n\nexports.captureFeedback = captureFeedback;\n//# sourceMappingURL=feedback.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9mZWVkYmFjay5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxzQkFBc0IsbUJBQU8sQ0FBQywrSEFBb0I7O0FBRWxEO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxXQUFXO0FBQ1g7QUFDQTtBQUNBLFVBQVUsNkRBQTZEOztBQUV2RTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxPQUFPO0FBQ1AsS0FBSztBQUNMO0FBQ0E7QUFDQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBOztBQUVBLHVCQUF1QjtBQUN2QiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL2ZlZWRiYWNrLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBjdXJyZW50U2NvcGVzID0gcmVxdWlyZSgnLi9jdXJyZW50U2NvcGVzLmpzJyk7XG5cbi8qKlxuICogU2VuZCB1c2VyIGZlZWRiYWNrIHRvIFNlbnRyeS5cbiAqL1xuZnVuY3Rpb24gY2FwdHVyZUZlZWRiYWNrKFxuICBwYXJhbXMsXG4gIGhpbnQgPSB7fSxcbiAgc2NvcGUgPSBjdXJyZW50U2NvcGVzLmdldEN1cnJlbnRTY29wZSgpLFxuKSB7XG4gIGNvbnN0IHsgbWVzc2FnZSwgbmFtZSwgZW1haWwsIHVybCwgc291cmNlLCBhc3NvY2lhdGVkRXZlbnRJZCwgdGFncyB9ID0gcGFyYW1zO1xuXG4gIGNvbnN0IGZlZWRiYWNrRXZlbnQgPSB7XG4gICAgY29udGV4dHM6IHtcbiAgICAgIGZlZWRiYWNrOiB7XG4gICAgICAgIGNvbnRhY3RfZW1haWw6IGVtYWlsLFxuICAgICAgICBuYW1lLFxuICAgICAgICBtZXNzYWdlLFxuICAgICAgICB1cmwsXG4gICAgICAgIHNvdXJjZSxcbiAgICAgICAgYXNzb2NpYXRlZF9ldmVudF9pZDogYXNzb2NpYXRlZEV2ZW50SWQsXG4gICAgICB9LFxuICAgIH0sXG4gICAgdHlwZTogJ2ZlZWRiYWNrJyxcbiAgICBsZXZlbDogJ2luZm8nLFxuICAgIHRhZ3MsXG4gIH07XG5cbiAgY29uc3QgY2xpZW50ID0gc2NvcGU/LmdldENsaWVudCgpIHx8IGN1cnJlbnRTY29wZXMuZ2V0Q2xpZW50KCk7XG5cbiAgaWYgKGNsaWVudCkge1xuICAgIGNsaWVudC5lbWl0KCdiZWZvcmVTZW5kRmVlZGJhY2snLCBmZWVkYmFja0V2ZW50LCBoaW50KTtcbiAgfVxuXG4gIGNvbnN0IGV2ZW50SWQgPSBzY29wZS5jYXB0dXJlRXZlbnQoZmVlZGJhY2tFdmVudCwgaGludCk7XG5cbiAgcmV0dXJuIGV2ZW50SWQ7XG59XG5cbmV4cG9ydHMuY2FwdHVyZUZlZWRiYWNrID0gY2FwdHVyZUZlZWRiYWNrO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9ZmVlZGJhY2suanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/feedback.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/fetch.js":
/*!*********************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/fetch.js ***!
  \*********************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst currentScopes = __webpack_require__(/*! ./currentScopes.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst semanticAttributes = __webpack_require__(/*! ./semanticAttributes.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/semanticAttributes.js\");\nconst spanUtils = __webpack_require__(/*! ./utils/spanUtils.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanUtils.js\");\nconst spanstatus = __webpack_require__(/*! ./tracing/spanstatus.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/spanstatus.js\");\nconst is = __webpack_require__(/*! ./utils/is.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js\");\nconst hasSpansEnabled = __webpack_require__(/*! ./utils/hasSpansEnabled.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/hasSpansEnabled.js\");\nconst baggage = __webpack_require__(/*! ./utils/baggage.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/baggage.js\");\nconst sentryNonRecordingSpan = __webpack_require__(/*! ./tracing/sentryNonRecordingSpan.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/sentryNonRecordingSpan.js\");\nconst trace = __webpack_require__(/*! ./tracing/trace.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/trace.js\");\nconst traceData = __webpack_require__(/*! ./utils/traceData.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/traceData.js\");\nconst url = __webpack_require__(/*! ./utils/url.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/url.js\");\n\n/**\n * Create and track fetch request spans for usage in combination with `addFetchInstrumentationHandler`.\n *\n * @returns Span if a span was created, otherwise void.\n */\nfunction instrumentFetchRequest(\n  handlerData,\n  shouldCreateSpan,\n  shouldAttachHeaders,\n  spans,\n  spanOrigin = 'auto.http.browser',\n) {\n  if (!handlerData.fetchData) {\n    return undefined;\n  }\n\n  const { method, url } = handlerData.fetchData;\n\n  const shouldCreateSpanResult = hasSpansEnabled.hasSpansEnabled() && shouldCreateSpan(url);\n\n  if (handlerData.endTimestamp && shouldCreateSpanResult) {\n    const spanId = handlerData.fetchData.__span;\n    if (!spanId) return;\n\n    const span = spans[spanId];\n    if (span) {\n      endSpan(span, handlerData);\n\n      // eslint-disable-next-line @typescript-eslint/no-dynamic-delete\n      delete spans[spanId];\n    }\n    return undefined;\n  }\n\n  const hasParent = !!spanUtils.getActiveSpan();\n\n  const span =\n    shouldCreateSpanResult && hasParent\n      ? trace.startInactiveSpan(getSpanStartOptions(url, method, spanOrigin))\n      : new sentryNonRecordingSpan.SentryNonRecordingSpan();\n\n  handlerData.fetchData.__span = span.spanContext().spanId;\n  spans[span.spanContext().spanId] = span;\n\n  if (shouldAttachHeaders(handlerData.fetchData.url)) {\n    const request = handlerData.args[0];\n\n    const options = handlerData.args[1] || {};\n\n    const headers = _addTracingHeadersToFetchRequest(\n      request,\n      options,\n      // If performance is disabled (TWP) or there's no active root span (pageload/navigation/interaction),\n      // we do not want to use the span as base for the trace headers,\n      // which means that the headers will be generated from the scope and the sampling decision is deferred\n      hasSpansEnabled.hasSpansEnabled() && hasParent ? span : undefined,\n    );\n    if (headers) {\n      // Ensure this is actually set, if no options have been passed previously\n      handlerData.args[1] = options;\n      options.headers = headers;\n    }\n  }\n\n  const client = currentScopes.getClient();\n\n  if (client) {\n    const fetchHint = {\n      input: handlerData.args,\n      response: handlerData.response,\n      startTimestamp: handlerData.startTimestamp,\n      endTimestamp: handlerData.endTimestamp,\n    } ;\n\n    client.emit('beforeOutgoingRequestSpan', span, fetchHint);\n  }\n\n  return span;\n}\n\n/**\n * Adds sentry-trace and baggage headers to the various forms of fetch headers.\n * exported only for testing purposes\n *\n * When we determine if we should add a baggage header, there are 3 cases:\n * 1. No previous baggage header -> add baggage\n * 2. Previous baggage header has no sentry baggage values -> add our baggage\n * 3. Previous baggage header has sentry baggage values -> do nothing (might have been added manually by users)\n */\n// eslint-disable-next-line complexity -- yup it's this complicated :(\nfunction _addTracingHeadersToFetchRequest(\n  request,\n  fetchOptionsObj\n\n,\n  span,\n) {\n  const traceHeaders = traceData.getTraceData({ span });\n  const sentryTrace = traceHeaders['sentry-trace'];\n  const baggage = traceHeaders.baggage;\n\n  // Nothing to do, when we return undefined here, the original headers will be used\n  if (!sentryTrace) {\n    return undefined;\n  }\n\n  const originalHeaders = fetchOptionsObj.headers || (is.isRequest(request) ? request.headers : undefined);\n\n  if (!originalHeaders) {\n    return { ...traceHeaders };\n  } else if (isHeaders(originalHeaders)) {\n    const newHeaders = new Headers(originalHeaders);\n\n    // We don't want to override manually added sentry headers\n    if (!newHeaders.get('sentry-trace')) {\n      newHeaders.set('sentry-trace', sentryTrace);\n    }\n\n    if (baggage) {\n      const prevBaggageHeader = newHeaders.get('baggage');\n\n      if (!prevBaggageHeader) {\n        newHeaders.set('baggage', baggage);\n      } else if (!baggageHeaderHasSentryBaggageValues(prevBaggageHeader)) {\n        newHeaders.set('baggage', `${prevBaggageHeader},${baggage}`);\n      }\n    }\n\n    return newHeaders;\n  } else if (Array.isArray(originalHeaders)) {\n    const newHeaders = [...originalHeaders];\n\n    if (!originalHeaders.find(header => header[0] === 'sentry-trace')) {\n      newHeaders.push(['sentry-trace', sentryTrace]);\n    }\n\n    const prevBaggageHeaderWithSentryValues = originalHeaders.find(\n      header => header[0] === 'baggage' && baggageHeaderHasSentryBaggageValues(header[1]),\n    );\n\n    if (baggage && !prevBaggageHeaderWithSentryValues) {\n      // If there are multiple entries with the same key, the browser will merge the values into a single request header.\n      // Its therefore safe to simply push a \"baggage\" entry, even though there might already be another baggage header.\n      newHeaders.push(['baggage', baggage]);\n    }\n\n    return newHeaders ;\n  } else {\n    const existingSentryTraceHeader = 'sentry-trace' in originalHeaders ? originalHeaders['sentry-trace'] : undefined;\n\n    const existingBaggageHeader = 'baggage' in originalHeaders ? originalHeaders.baggage : undefined;\n    const newBaggageHeaders = existingBaggageHeader\n      ? Array.isArray(existingBaggageHeader)\n        ? [...existingBaggageHeader]\n        : [existingBaggageHeader]\n      : [];\n\n    const prevBaggageHeaderWithSentryValues =\n      existingBaggageHeader &&\n      (Array.isArray(existingBaggageHeader)\n        ? existingBaggageHeader.find(headerItem => baggageHeaderHasSentryBaggageValues(headerItem))\n        : baggageHeaderHasSentryBaggageValues(existingBaggageHeader));\n\n    if (baggage && !prevBaggageHeaderWithSentryValues) {\n      newBaggageHeaders.push(baggage);\n    }\n\n    return {\n      ...(originalHeaders ),\n      'sentry-trace': (existingSentryTraceHeader ) ?? sentryTrace,\n      baggage: newBaggageHeaders.length > 0 ? newBaggageHeaders.join(',') : undefined,\n    };\n  }\n}\n\nfunction endSpan(span, handlerData) {\n  if (handlerData.response) {\n    spanstatus.setHttpStatus(span, handlerData.response.status);\n\n    const contentLength = handlerData.response?.headers?.get('content-length');\n\n    if (contentLength) {\n      const contentLengthNum = parseInt(contentLength);\n      if (contentLengthNum > 0) {\n        span.setAttribute('http.response_content_length', contentLengthNum);\n      }\n    }\n  } else if (handlerData.error) {\n    span.setStatus({ code: spanstatus.SPAN_STATUS_ERROR, message: 'internal_error' });\n  }\n  span.end();\n}\n\nfunction baggageHeaderHasSentryBaggageValues(baggageHeader) {\n  return baggageHeader.split(',').some(baggageEntry => baggageEntry.trim().startsWith(baggage.SENTRY_BAGGAGE_KEY_PREFIX));\n}\n\nfunction isHeaders(headers) {\n  return typeof Headers !== 'undefined' && is.isInstanceOf(headers, Headers);\n}\n\nfunction getSpanStartOptions(\n  url$1,\n  method,\n  spanOrigin,\n) {\n  const parsedUrl = url.parseStringToURLObject(url$1);\n  return {\n    name: parsedUrl ? `${method} ${url.getSanitizedUrlStringFromUrlObject(parsedUrl)}` : method,\n    attributes: getFetchSpanAttributes(url$1, parsedUrl, method, spanOrigin),\n  };\n}\n\nfunction getFetchSpanAttributes(\n  url$1,\n  parsedUrl,\n  method,\n  spanOrigin,\n) {\n  const attributes = {\n    url: url$1,\n    type: 'fetch',\n    'http.method': method,\n    [semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_ORIGIN]: spanOrigin,\n    [semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_OP]: 'http.client',\n  };\n  if (parsedUrl) {\n    if (!url.isURLObjectRelative(parsedUrl)) {\n      attributes['http.url'] = parsedUrl.href;\n      attributes['server.address'] = parsedUrl.host;\n    }\n    if (parsedUrl.search) {\n      attributes['http.query'] = parsedUrl.search;\n    }\n    if (parsedUrl.hash) {\n      attributes['http.fragment'] = parsedUrl.hash;\n    }\n  }\n  return attributes;\n}\n\nexports._addTracingHeadersToFetchRequest = _addTracingHeadersToFetchRequest;\nexports.instrumentFetchRequest = instrumentFetchRequest;\n//# sourceMappingURL=fetch.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9mZXRjaC5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxzQkFBc0IsbUJBQU8sQ0FBQywrSEFBb0I7QUFDbEQsMkJBQTJCLG1CQUFPLENBQUMseUlBQXlCO0FBQzVELGtCQUFrQixtQkFBTyxDQUFDLG1JQUFzQjtBQUNoRCxtQkFBbUIsbUJBQU8sQ0FBQyx5SUFBeUI7QUFDcEQsV0FBVyxtQkFBTyxDQUFDLHFIQUFlO0FBQ2xDLHdCQUF3QixtQkFBTyxDQUFDLCtJQUE0QjtBQUM1RCxnQkFBZ0IsbUJBQU8sQ0FBQywrSEFBb0I7QUFDNUMsK0JBQStCLG1CQUFPLENBQUMsaUtBQXFDO0FBQzVFLGNBQWMsbUJBQU8sQ0FBQywrSEFBb0I7QUFDMUMsa0JBQWtCLG1CQUFPLENBQUMsbUlBQXNCO0FBQ2hELFlBQVksbUJBQU8sQ0FBQyx1SEFBZ0I7O0FBRXBDO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSxVQUFVLGNBQWM7O0FBRXhCOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0EsZ0RBQWdELE1BQU07QUFDdEQ7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBLGFBQWE7QUFDYixJQUFJO0FBQ0o7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsUUFBUTtBQUNSLHFDQUFxQyxrQkFBa0IsR0FBRyxRQUFRO0FBQ2xFO0FBQ0E7O0FBRUE7QUFDQSxJQUFJO0FBQ0o7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0EsSUFBSTtBQUNKOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsSUFBSTtBQUNKLHFCQUFxQiwrREFBK0Q7QUFDcEY7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSx5QkFBeUIsUUFBUSxFQUFFLGtEQUFrRDtBQUNyRjtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLHdDQUF3QztBQUN4Qyw4QkFBOEI7QUFDOUIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9mZXRjaC5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgY3VycmVudFNjb3BlcyA9IHJlcXVpcmUoJy4vY3VycmVudFNjb3Blcy5qcycpO1xuY29uc3Qgc2VtYW50aWNBdHRyaWJ1dGVzID0gcmVxdWlyZSgnLi9zZW1hbnRpY0F0dHJpYnV0ZXMuanMnKTtcbmNvbnN0IHNwYW5VdGlscyA9IHJlcXVpcmUoJy4vdXRpbHMvc3BhblV0aWxzLmpzJyk7XG5jb25zdCBzcGFuc3RhdHVzID0gcmVxdWlyZSgnLi90cmFjaW5nL3NwYW5zdGF0dXMuanMnKTtcbmNvbnN0IGlzID0gcmVxdWlyZSgnLi91dGlscy9pcy5qcycpO1xuY29uc3QgaGFzU3BhbnNFbmFibGVkID0gcmVxdWlyZSgnLi91dGlscy9oYXNTcGFuc0VuYWJsZWQuanMnKTtcbmNvbnN0IGJhZ2dhZ2UgPSByZXF1aXJlKCcuL3V0aWxzL2JhZ2dhZ2UuanMnKTtcbmNvbnN0IHNlbnRyeU5vblJlY29yZGluZ1NwYW4gPSByZXF1aXJlKCcuL3RyYWNpbmcvc2VudHJ5Tm9uUmVjb3JkaW5nU3Bhbi5qcycpO1xuY29uc3QgdHJhY2UgPSByZXF1aXJlKCcuL3RyYWNpbmcvdHJhY2UuanMnKTtcbmNvbnN0IHRyYWNlRGF0YSA9IHJlcXVpcmUoJy4vdXRpbHMvdHJhY2VEYXRhLmpzJyk7XG5jb25zdCB1cmwgPSByZXF1aXJlKCcuL3V0aWxzL3VybC5qcycpO1xuXG4vKipcbiAqIENyZWF0ZSBhbmQgdHJhY2sgZmV0Y2ggcmVxdWVzdCBzcGFucyBmb3IgdXNhZ2UgaW4gY29tYmluYXRpb24gd2l0aCBgYWRkRmV0Y2hJbnN0cnVtZW50YXRpb25IYW5kbGVyYC5cbiAqXG4gKiBAcmV0dXJucyBTcGFuIGlmIGEgc3BhbiB3YXMgY3JlYXRlZCwgb3RoZXJ3aXNlIHZvaWQuXG4gKi9cbmZ1bmN0aW9uIGluc3RydW1lbnRGZXRjaFJlcXVlc3QoXG4gIGhhbmRsZXJEYXRhLFxuICBzaG91bGRDcmVhdGVTcGFuLFxuICBzaG91bGRBdHRhY2hIZWFkZXJzLFxuICBzcGFucyxcbiAgc3Bhbk9yaWdpbiA9ICdhdXRvLmh0dHAuYnJvd3NlcicsXG4pIHtcbiAgaWYgKCFoYW5kbGVyRGF0YS5mZXRjaERhdGEpIHtcbiAgICByZXR1cm4gdW5kZWZpbmVkO1xuICB9XG5cbiAgY29uc3QgeyBtZXRob2QsIHVybCB9ID0gaGFuZGxlckRhdGEuZmV0Y2hEYXRhO1xuXG4gIGNvbnN0IHNob3VsZENyZWF0ZVNwYW5SZXN1bHQgPSBoYXNTcGFuc0VuYWJsZWQuaGFzU3BhbnNFbmFibGVkKCkgJiYgc2hvdWxkQ3JlYXRlU3Bhbih1cmwpO1xuXG4gIGlmIChoYW5kbGVyRGF0YS5lbmRUaW1lc3RhbXAgJiYgc2hvdWxkQ3JlYXRlU3BhblJlc3VsdCkge1xuICAgIGNvbnN0IHNwYW5JZCA9IGhhbmRsZXJEYXRhLmZldGNoRGF0YS5fX3NwYW47XG4gICAgaWYgKCFzcGFuSWQpIHJldHVybjtcblxuICAgIGNvbnN0IHNwYW4gPSBzcGFuc1tzcGFuSWRdO1xuICAgIGlmIChzcGFuKSB7XG4gICAgICBlbmRTcGFuKHNwYW4sIGhhbmRsZXJEYXRhKTtcblxuICAgICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uby1keW5hbWljLWRlbGV0ZVxuICAgICAgZGVsZXRlIHNwYW5zW3NwYW5JZF07XG4gICAgfVxuICAgIHJldHVybiB1bmRlZmluZWQ7XG4gIH1cblxuICBjb25zdCBoYXNQYXJlbnQgPSAhIXNwYW5VdGlscy5nZXRBY3RpdmVTcGFuKCk7XG5cbiAgY29uc3Qgc3BhbiA9XG4gICAgc2hvdWxkQ3JlYXRlU3BhblJlc3VsdCAmJiBoYXNQYXJlbnRcbiAgICAgID8gdHJhY2Uuc3RhcnRJbmFjdGl2ZVNwYW4oZ2V0U3BhblN0YXJ0T3B0aW9ucyh1cmwsIG1ldGhvZCwgc3Bhbk9yaWdpbikpXG4gICAgICA6IG5ldyBzZW50cnlOb25SZWNvcmRpbmdTcGFuLlNlbnRyeU5vblJlY29yZGluZ1NwYW4oKTtcblxuICBoYW5kbGVyRGF0YS5mZXRjaERhdGEuX19zcGFuID0gc3Bhbi5zcGFuQ29udGV4dCgpLnNwYW5JZDtcbiAgc3BhbnNbc3Bhbi5zcGFuQ29udGV4dCgpLnNwYW5JZF0gPSBzcGFuO1xuXG4gIGlmIChzaG91bGRBdHRhY2hIZWFkZXJzKGhhbmRsZXJEYXRhLmZldGNoRGF0YS51cmwpKSB7XG4gICAgY29uc3QgcmVxdWVzdCA9IGhhbmRsZXJEYXRhLmFyZ3NbMF07XG5cbiAgICBjb25zdCBvcHRpb25zID0gaGFuZGxlckRhdGEuYXJnc1sxXSB8fCB7fTtcblxuICAgIGNvbnN0IGhlYWRlcnMgPSBfYWRkVHJhY2luZ0hlYWRlcnNUb0ZldGNoUmVxdWVzdChcbiAgICAgIHJlcXVlc3QsXG4gICAgICBvcHRpb25zLFxuICAgICAgLy8gSWYgcGVyZm9ybWFuY2UgaXMgZGlzYWJsZWQgKFRXUCkgb3IgdGhlcmUncyBubyBhY3RpdmUgcm9vdCBzcGFuIChwYWdlbG9hZC9uYXZpZ2F0aW9uL2ludGVyYWN0aW9uKSxcbiAgICAgIC8vIHdlIGRvIG5vdCB3YW50IHRvIHVzZSB0aGUgc3BhbiBhcyBiYXNlIGZvciB0aGUgdHJhY2UgaGVhZGVycyxcbiAgICAgIC8vIHdoaWNoIG1lYW5zIHRoYXQgdGhlIGhlYWRlcnMgd2lsbCBiZSBnZW5lcmF0ZWQgZnJvbSB0aGUgc2NvcGUgYW5kIHRoZSBzYW1wbGluZyBkZWNpc2lvbiBpcyBkZWZlcnJlZFxuICAgICAgaGFzU3BhbnNFbmFibGVkLmhhc1NwYW5zRW5hYmxlZCgpICYmIGhhc1BhcmVudCA/IHNwYW4gOiB1bmRlZmluZWQsXG4gICAgKTtcbiAgICBpZiAoaGVhZGVycykge1xuICAgICAgLy8gRW5zdXJlIHRoaXMgaXMgYWN0dWFsbHkgc2V0LCBpZiBubyBvcHRpb25zIGhhdmUgYmVlbiBwYXNzZWQgcHJldmlvdXNseVxuICAgICAgaGFuZGxlckRhdGEuYXJnc1sxXSA9IG9wdGlvbnM7XG4gICAgICBvcHRpb25zLmhlYWRlcnMgPSBoZWFkZXJzO1xuICAgIH1cbiAgfVxuXG4gIGNvbnN0IGNsaWVudCA9IGN1cnJlbnRTY29wZXMuZ2V0Q2xpZW50KCk7XG5cbiAgaWYgKGNsaWVudCkge1xuICAgIGNvbnN0IGZldGNoSGludCA9IHtcbiAgICAgIGlucHV0OiBoYW5kbGVyRGF0YS5hcmdzLFxuICAgICAgcmVzcG9uc2U6IGhhbmRsZXJEYXRhLnJlc3BvbnNlLFxuICAgICAgc3RhcnRUaW1lc3RhbXA6IGhhbmRsZXJEYXRhLnN0YXJ0VGltZXN0YW1wLFxuICAgICAgZW5kVGltZXN0YW1wOiBoYW5kbGVyRGF0YS5lbmRUaW1lc3RhbXAsXG4gICAgfSA7XG5cbiAgICBjbGllbnQuZW1pdCgnYmVmb3JlT3V0Z29pbmdSZXF1ZXN0U3BhbicsIHNwYW4sIGZldGNoSGludCk7XG4gIH1cblxuICByZXR1cm4gc3Bhbjtcbn1cblxuLyoqXG4gKiBBZGRzIHNlbnRyeS10cmFjZSBhbmQgYmFnZ2FnZSBoZWFkZXJzIHRvIHRoZSB2YXJpb3VzIGZvcm1zIG9mIGZldGNoIGhlYWRlcnMuXG4gKiBleHBvcnRlZCBvbmx5IGZvciB0ZXN0aW5nIHB1cnBvc2VzXG4gKlxuICogV2hlbiB3ZSBkZXRlcm1pbmUgaWYgd2Ugc2hvdWxkIGFkZCBhIGJhZ2dhZ2UgaGVhZGVyLCB0aGVyZSBhcmUgMyBjYXNlczpcbiAqIDEuIE5vIHByZXZpb3VzIGJhZ2dhZ2UgaGVhZGVyIC0+IGFkZCBiYWdnYWdlXG4gKiAyLiBQcmV2aW91cyBiYWdnYWdlIGhlYWRlciBoYXMgbm8gc2VudHJ5IGJhZ2dhZ2UgdmFsdWVzIC0+IGFkZCBvdXIgYmFnZ2FnZVxuICogMy4gUHJldmlvdXMgYmFnZ2FnZSBoZWFkZXIgaGFzIHNlbnRyeSBiYWdnYWdlIHZhbHVlcyAtPiBkbyBub3RoaW5nIChtaWdodCBoYXZlIGJlZW4gYWRkZWQgbWFudWFsbHkgYnkgdXNlcnMpXG4gKi9cbi8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBjb21wbGV4aXR5IC0tIHl1cCBpdCdzIHRoaXMgY29tcGxpY2F0ZWQgOihcbmZ1bmN0aW9uIF9hZGRUcmFjaW5nSGVhZGVyc1RvRmV0Y2hSZXF1ZXN0KFxuICByZXF1ZXN0LFxuICBmZXRjaE9wdGlvbnNPYmpcblxuLFxuICBzcGFuLFxuKSB7XG4gIGNvbnN0IHRyYWNlSGVhZGVycyA9IHRyYWNlRGF0YS5nZXRUcmFjZURhdGEoeyBzcGFuIH0pO1xuICBjb25zdCBzZW50cnlUcmFjZSA9IHRyYWNlSGVhZGVyc1snc2VudHJ5LXRyYWNlJ107XG4gIGNvbnN0IGJhZ2dhZ2UgPSB0cmFjZUhlYWRlcnMuYmFnZ2FnZTtcblxuICAvLyBOb3RoaW5nIHRvIGRvLCB3aGVuIHdlIHJldHVybiB1bmRlZmluZWQgaGVyZSwgdGhlIG9yaWdpbmFsIGhlYWRlcnMgd2lsbCBiZSB1c2VkXG4gIGlmICghc2VudHJ5VHJhY2UpIHtcbiAgICByZXR1cm4gdW5kZWZpbmVkO1xuICB9XG5cbiAgY29uc3Qgb3JpZ2luYWxIZWFkZXJzID0gZmV0Y2hPcHRpb25zT2JqLmhlYWRlcnMgfHwgKGlzLmlzUmVxdWVzdChyZXF1ZXN0KSA/IHJlcXVlc3QuaGVhZGVycyA6IHVuZGVmaW5lZCk7XG5cbiAgaWYgKCFvcmlnaW5hbEhlYWRlcnMpIHtcbiAgICByZXR1cm4geyAuLi50cmFjZUhlYWRlcnMgfTtcbiAgfSBlbHNlIGlmIChpc0hlYWRlcnMob3JpZ2luYWxIZWFkZXJzKSkge1xuICAgIGNvbnN0IG5ld0hlYWRlcnMgPSBuZXcgSGVhZGVycyhvcmlnaW5hbEhlYWRlcnMpO1xuXG4gICAgLy8gV2UgZG9uJ3Qgd2FudCB0byBvdmVycmlkZSBtYW51YWxseSBhZGRlZCBzZW50cnkgaGVhZGVyc1xuICAgIGlmICghbmV3SGVhZGVycy5nZXQoJ3NlbnRyeS10cmFjZScpKSB7XG4gICAgICBuZXdIZWFkZXJzLnNldCgnc2VudHJ5LXRyYWNlJywgc2VudHJ5VHJhY2UpO1xuICAgIH1cblxuICAgIGlmIChiYWdnYWdlKSB7XG4gICAgICBjb25zdCBwcmV2QmFnZ2FnZUhlYWRlciA9IG5ld0hlYWRlcnMuZ2V0KCdiYWdnYWdlJyk7XG5cbiAgICAgIGlmICghcHJldkJhZ2dhZ2VIZWFkZXIpIHtcbiAgICAgICAgbmV3SGVhZGVycy5zZXQoJ2JhZ2dhZ2UnLCBiYWdnYWdlKTtcbiAgICAgIH0gZWxzZSBpZiAoIWJhZ2dhZ2VIZWFkZXJIYXNTZW50cnlCYWdnYWdlVmFsdWVzKHByZXZCYWdnYWdlSGVhZGVyKSkge1xuICAgICAgICBuZXdIZWFkZXJzLnNldCgnYmFnZ2FnZScsIGAke3ByZXZCYWdnYWdlSGVhZGVyfSwke2JhZ2dhZ2V9YCk7XG4gICAgICB9XG4gICAgfVxuXG4gICAgcmV0dXJuIG5ld0hlYWRlcnM7XG4gIH0gZWxzZSBpZiAoQXJyYXkuaXNBcnJheShvcmlnaW5hbEhlYWRlcnMpKSB7XG4gICAgY29uc3QgbmV3SGVhZGVycyA9IFsuLi5vcmlnaW5hbEhlYWRlcnNdO1xuXG4gICAgaWYgKCFvcmlnaW5hbEhlYWRlcnMuZmluZChoZWFkZXIgPT4gaGVhZGVyWzBdID09PSAnc2VudHJ5LXRyYWNlJykpIHtcbiAgICAgIG5ld0hlYWRlcnMucHVzaChbJ3NlbnRyeS10cmFjZScsIHNlbnRyeVRyYWNlXSk7XG4gICAgfVxuXG4gICAgY29uc3QgcHJldkJhZ2dhZ2VIZWFkZXJXaXRoU2VudHJ5VmFsdWVzID0gb3JpZ2luYWxIZWFkZXJzLmZpbmQoXG4gICAgICBoZWFkZXIgPT4gaGVhZGVyWzBdID09PSAnYmFnZ2FnZScgJiYgYmFnZ2FnZUhlYWRlckhhc1NlbnRyeUJhZ2dhZ2VWYWx1ZXMoaGVhZGVyWzFdKSxcbiAgICApO1xuXG4gICAgaWYgKGJhZ2dhZ2UgJiYgIXByZXZCYWdnYWdlSGVhZGVyV2l0aFNlbnRyeVZhbHVlcykge1xuICAgICAgLy8gSWYgdGhlcmUgYXJlIG11bHRpcGxlIGVudHJpZXMgd2l0aCB0aGUgc2FtZSBrZXksIHRoZSBicm93c2VyIHdpbGwgbWVyZ2UgdGhlIHZhbHVlcyBpbnRvIGEgc2luZ2xlIHJlcXVlc3QgaGVhZGVyLlxuICAgICAgLy8gSXRzIHRoZXJlZm9yZSBzYWZlIHRvIHNpbXBseSBwdXNoIGEgXCJiYWdnYWdlXCIgZW50cnksIGV2ZW4gdGhvdWdoIHRoZXJlIG1pZ2h0IGFscmVhZHkgYmUgYW5vdGhlciBiYWdnYWdlIGhlYWRlci5cbiAgICAgIG5ld0hlYWRlcnMucHVzaChbJ2JhZ2dhZ2UnLCBiYWdnYWdlXSk7XG4gICAgfVxuXG4gICAgcmV0dXJuIG5ld0hlYWRlcnMgO1xuICB9IGVsc2Uge1xuICAgIGNvbnN0IGV4aXN0aW5nU2VudHJ5VHJhY2VIZWFkZXIgPSAnc2VudHJ5LXRyYWNlJyBpbiBvcmlnaW5hbEhlYWRlcnMgPyBvcmlnaW5hbEhlYWRlcnNbJ3NlbnRyeS10cmFjZSddIDogdW5kZWZpbmVkO1xuXG4gICAgY29uc3QgZXhpc3RpbmdCYWdnYWdlSGVhZGVyID0gJ2JhZ2dhZ2UnIGluIG9yaWdpbmFsSGVhZGVycyA/IG9yaWdpbmFsSGVhZGVycy5iYWdnYWdlIDogdW5kZWZpbmVkO1xuICAgIGNvbnN0IG5ld0JhZ2dhZ2VIZWFkZXJzID0gZXhpc3RpbmdCYWdnYWdlSGVhZGVyXG4gICAgICA/IEFycmF5LmlzQXJyYXkoZXhpc3RpbmdCYWdnYWdlSGVhZGVyKVxuICAgICAgICA/IFsuLi5leGlzdGluZ0JhZ2dhZ2VIZWFkZXJdXG4gICAgICAgIDogW2V4aXN0aW5nQmFnZ2FnZUhlYWRlcl1cbiAgICAgIDogW107XG5cbiAgICBjb25zdCBwcmV2QmFnZ2FnZUhlYWRlcldpdGhTZW50cnlWYWx1ZXMgPVxuICAgICAgZXhpc3RpbmdCYWdnYWdlSGVhZGVyICYmXG4gICAgICAoQXJyYXkuaXNBcnJheShleGlzdGluZ0JhZ2dhZ2VIZWFkZXIpXG4gICAgICAgID8gZXhpc3RpbmdCYWdnYWdlSGVhZGVyLmZpbmQoaGVhZGVySXRlbSA9PiBiYWdnYWdlSGVhZGVySGFzU2VudHJ5QmFnZ2FnZVZhbHVlcyhoZWFkZXJJdGVtKSlcbiAgICAgICAgOiBiYWdnYWdlSGVhZGVySGFzU2VudHJ5QmFnZ2FnZVZhbHVlcyhleGlzdGluZ0JhZ2dhZ2VIZWFkZXIpKTtcblxuICAgIGlmIChiYWdnYWdlICYmICFwcmV2QmFnZ2FnZUhlYWRlcldpdGhTZW50cnlWYWx1ZXMpIHtcbiAgICAgIG5ld0JhZ2dhZ2VIZWFkZXJzLnB1c2goYmFnZ2FnZSk7XG4gICAgfVxuXG4gICAgcmV0dXJuIHtcbiAgICAgIC4uLihvcmlnaW5hbEhlYWRlcnMgKSxcbiAgICAgICdzZW50cnktdHJhY2UnOiAoZXhpc3RpbmdTZW50cnlUcmFjZUhlYWRlciApID8/IHNlbnRyeVRyYWNlLFxuICAgICAgYmFnZ2FnZTogbmV3QmFnZ2FnZUhlYWRlcnMubGVuZ3RoID4gMCA/IG5ld0JhZ2dhZ2VIZWFkZXJzLmpvaW4oJywnKSA6IHVuZGVmaW5lZCxcbiAgICB9O1xuICB9XG59XG5cbmZ1bmN0aW9uIGVuZFNwYW4oc3BhbiwgaGFuZGxlckRhdGEpIHtcbiAgaWYgKGhhbmRsZXJEYXRhLnJlc3BvbnNlKSB7XG4gICAgc3BhbnN0YXR1cy5zZXRIdHRwU3RhdHVzKHNwYW4sIGhhbmRsZXJEYXRhLnJlc3BvbnNlLnN0YXR1cyk7XG5cbiAgICBjb25zdCBjb250ZW50TGVuZ3RoID0gaGFuZGxlckRhdGEucmVzcG9uc2U/LmhlYWRlcnM/LmdldCgnY29udGVudC1sZW5ndGgnKTtcblxuICAgIGlmIChjb250ZW50TGVuZ3RoKSB7XG4gICAgICBjb25zdCBjb250ZW50TGVuZ3RoTnVtID0gcGFyc2VJbnQoY29udGVudExlbmd0aCk7XG4gICAgICBpZiAoY29udGVudExlbmd0aE51bSA+IDApIHtcbiAgICAgICAgc3Bhbi5zZXRBdHRyaWJ1dGUoJ2h0dHAucmVzcG9uc2VfY29udGVudF9sZW5ndGgnLCBjb250ZW50TGVuZ3RoTnVtKTtcbiAgICAgIH1cbiAgICB9XG4gIH0gZWxzZSBpZiAoaGFuZGxlckRhdGEuZXJyb3IpIHtcbiAgICBzcGFuLnNldFN0YXR1cyh7IGNvZGU6IHNwYW5zdGF0dXMuU1BBTl9TVEFUVVNfRVJST1IsIG1lc3NhZ2U6ICdpbnRlcm5hbF9lcnJvcicgfSk7XG4gIH1cbiAgc3Bhbi5lbmQoKTtcbn1cblxuZnVuY3Rpb24gYmFnZ2FnZUhlYWRlckhhc1NlbnRyeUJhZ2dhZ2VWYWx1ZXMoYmFnZ2FnZUhlYWRlcikge1xuICByZXR1cm4gYmFnZ2FnZUhlYWRlci5zcGxpdCgnLCcpLnNvbWUoYmFnZ2FnZUVudHJ5ID0+IGJhZ2dhZ2VFbnRyeS50cmltKCkuc3RhcnRzV2l0aChiYWdnYWdlLlNFTlRSWV9CQUdHQUdFX0tFWV9QUkVGSVgpKTtcbn1cblxuZnVuY3Rpb24gaXNIZWFkZXJzKGhlYWRlcnMpIHtcbiAgcmV0dXJuIHR5cGVvZiBIZWFkZXJzICE9PSAndW5kZWZpbmVkJyAmJiBpcy5pc0luc3RhbmNlT2YoaGVhZGVycywgSGVhZGVycyk7XG59XG5cbmZ1bmN0aW9uIGdldFNwYW5TdGFydE9wdGlvbnMoXG4gIHVybCQxLFxuICBtZXRob2QsXG4gIHNwYW5PcmlnaW4sXG4pIHtcbiAgY29uc3QgcGFyc2VkVXJsID0gdXJsLnBhcnNlU3RyaW5nVG9VUkxPYmplY3QodXJsJDEpO1xuICByZXR1cm4ge1xuICAgIG5hbWU6IHBhcnNlZFVybCA/IGAke21ldGhvZH0gJHt1cmwuZ2V0U2FuaXRpemVkVXJsU3RyaW5nRnJvbVVybE9iamVjdChwYXJzZWRVcmwpfWAgOiBtZXRob2QsXG4gICAgYXR0cmlidXRlczogZ2V0RmV0Y2hTcGFuQXR0cmlidXRlcyh1cmwkMSwgcGFyc2VkVXJsLCBtZXRob2QsIHNwYW5PcmlnaW4pLFxuICB9O1xufVxuXG5mdW5jdGlvbiBnZXRGZXRjaFNwYW5BdHRyaWJ1dGVzKFxuICB1cmwkMSxcbiAgcGFyc2VkVXJsLFxuICBtZXRob2QsXG4gIHNwYW5PcmlnaW4sXG4pIHtcbiAgY29uc3QgYXR0cmlidXRlcyA9IHtcbiAgICB1cmw6IHVybCQxLFxuICAgIHR5cGU6ICdmZXRjaCcsXG4gICAgJ2h0dHAubWV0aG9kJzogbWV0aG9kLFxuICAgIFtzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9PUklHSU5dOiBzcGFuT3JpZ2luLFxuICAgIFtzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9PUF06ICdodHRwLmNsaWVudCcsXG4gIH07XG4gIGlmIChwYXJzZWRVcmwpIHtcbiAgICBpZiAoIXVybC5pc1VSTE9iamVjdFJlbGF0aXZlKHBhcnNlZFVybCkpIHtcbiAgICAgIGF0dHJpYnV0ZXNbJ2h0dHAudXJsJ10gPSBwYXJzZWRVcmwuaHJlZjtcbiAgICAgIGF0dHJpYnV0ZXNbJ3NlcnZlci5hZGRyZXNzJ10gPSBwYXJzZWRVcmwuaG9zdDtcbiAgICB9XG4gICAgaWYgKHBhcnNlZFVybC5zZWFyY2gpIHtcbiAgICAgIGF0dHJpYnV0ZXNbJ2h0dHAucXVlcnknXSA9IHBhcnNlZFVybC5zZWFyY2g7XG4gICAgfVxuICAgIGlmIChwYXJzZWRVcmwuaGFzaCkge1xuICAgICAgYXR0cmlidXRlc1snaHR0cC5mcmFnbWVudCddID0gcGFyc2VkVXJsLmhhc2g7XG4gICAgfVxuICB9XG4gIHJldHVybiBhdHRyaWJ1dGVzO1xufVxuXG5leHBvcnRzLl9hZGRUcmFjaW5nSGVhZGVyc1RvRmV0Y2hSZXF1ZXN0ID0gX2FkZFRyYWNpbmdIZWFkZXJzVG9GZXRjaFJlcXVlc3Q7XG5leHBvcnRzLmluc3RydW1lbnRGZXRjaFJlcXVlc3QgPSBpbnN0cnVtZW50RmV0Y2hSZXF1ZXN0O1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9ZmV0Y2guanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/fetch.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/index.js":
/*!*********************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/index.js ***!
  \*********************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst errors = __webpack_require__(/*! ./tracing/errors.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/errors.js\");\nconst utils = __webpack_require__(/*! ./tracing/utils.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/utils.js\");\nconst idleSpan = __webpack_require__(/*! ./tracing/idleSpan.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/idleSpan.js\");\nconst sentrySpan = __webpack_require__(/*! ./tracing/sentrySpan.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/sentrySpan.js\");\nconst sentryNonRecordingSpan = __webpack_require__(/*! ./tracing/sentryNonRecordingSpan.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/sentryNonRecordingSpan.js\");\nconst spanstatus = __webpack_require__(/*! ./tracing/spanstatus.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/spanstatus.js\");\nconst trace = __webpack_require__(/*! ./tracing/trace.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/trace.js\");\nconst dynamicSamplingContext = __webpack_require__(/*! ./tracing/dynamicSamplingContext.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/dynamicSamplingContext.js\");\nconst measurement = __webpack_require__(/*! ./tracing/measurement.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/measurement.js\");\nconst sampling = __webpack_require__(/*! ./tracing/sampling.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/sampling.js\");\nconst logSpans = __webpack_require__(/*! ./tracing/logSpans.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/logSpans.js\");\nconst semanticAttributes = __webpack_require__(/*! ./semanticAttributes.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/semanticAttributes.js\");\nconst envelope = __webpack_require__(/*! ./envelope.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/envelope.js\");\nconst exports$1 = __webpack_require__(/*! ./exports.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/exports.js\");\nconst currentScopes = __webpack_require__(/*! ./currentScopes.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst defaultScopes = __webpack_require__(/*! ./defaultScopes.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/defaultScopes.js\");\nconst index = __webpack_require__(/*! ./asyncContext/index.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/asyncContext/index.js\");\nconst carrier = __webpack_require__(/*! ./carrier.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/carrier.js\");\nconst session = __webpack_require__(/*! ./session.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/session.js\");\nconst scope = __webpack_require__(/*! ./scope.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/scope.js\");\nconst eventProcessors = __webpack_require__(/*! ./eventProcessors.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/eventProcessors.js\");\nconst api = __webpack_require__(/*! ./api.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/api.js\");\nconst client = __webpack_require__(/*! ./client.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/client.js\");\nconst serverRuntimeClient = __webpack_require__(/*! ./server-runtime-client.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/server-runtime-client.js\");\nconst sdk = __webpack_require__(/*! ./sdk.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/sdk.js\");\nconst base = __webpack_require__(/*! ./transports/base.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/transports/base.js\");\nconst offline = __webpack_require__(/*! ./transports/offline.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/transports/offline.js\");\nconst multiplexed = __webpack_require__(/*! ./transports/multiplexed.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/transports/multiplexed.js\");\nconst integration = __webpack_require__(/*! ./integration.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integration.js\");\nconst applyScopeDataToEvent = __webpack_require__(/*! ./utils/applyScopeDataToEvent.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/applyScopeDataToEvent.js\");\nconst prepareEvent = __webpack_require__(/*! ./utils/prepareEvent.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/prepareEvent.js\");\nconst checkin = __webpack_require__(/*! ./checkin.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/checkin.js\");\nconst hasSpansEnabled = __webpack_require__(/*! ./utils/hasSpansEnabled.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/hasSpansEnabled.js\");\nconst isSentryRequestUrl = __webpack_require__(/*! ./utils/isSentryRequestUrl.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/isSentryRequestUrl.js\");\nconst handleCallbackErrors = __webpack_require__(/*! ./utils/handleCallbackErrors.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/handleCallbackErrors.js\");\nconst parameterize = __webpack_require__(/*! ./utils/parameterize.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/parameterize.js\");\nconst ipAddress = __webpack_require__(/*! ./utils/ipAddress.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/ipAddress.js\");\nconst spanUtils = __webpack_require__(/*! ./utils/spanUtils.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanUtils.js\");\nconst parseSampleRate = __webpack_require__(/*! ./utils/parseSampleRate.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/parseSampleRate.js\");\nconst sdkMetadata = __webpack_require__(/*! ./utils/sdkMetadata.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/sdkMetadata.js\");\nconst traceData = __webpack_require__(/*! ./utils/traceData.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/traceData.js\");\nconst meta = __webpack_require__(/*! ./utils/meta.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/meta.js\");\nconst debounce = __webpack_require__(/*! ./utils/debounce.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debounce.js\");\nconst request = __webpack_require__(/*! ./utils/request.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/request.js\");\nconst constants = __webpack_require__(/*! ./constants.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/constants.js\");\nconst breadcrumbs = __webpack_require__(/*! ./breadcrumbs.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/breadcrumbs.js\");\nconst functiontostring = __webpack_require__(/*! ./integrations/functiontostring.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/functiontostring.js\");\nconst eventFilters = __webpack_require__(/*! ./integrations/eventFilters.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/eventFilters.js\");\nconst linkederrors = __webpack_require__(/*! ./integrations/linkederrors.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/linkederrors.js\");\nconst metadata = __webpack_require__(/*! ./integrations/metadata.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/metadata.js\");\nconst requestdata = __webpack_require__(/*! ./integrations/requestdata.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/requestdata.js\");\nconst captureconsole = __webpack_require__(/*! ./integrations/captureconsole.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/captureconsole.js\");\nconst dedupe = __webpack_require__(/*! ./integrations/dedupe.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/dedupe.js\");\nconst extraerrordata = __webpack_require__(/*! ./integrations/extraerrordata.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/extraerrordata.js\");\nconst rewriteframes = __webpack_require__(/*! ./integrations/rewriteframes.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/rewriteframes.js\");\nconst supabase = __webpack_require__(/*! ./integrations/supabase.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/supabase.js\");\nconst zoderrors = __webpack_require__(/*! ./integrations/zoderrors.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/zoderrors.js\");\nconst thirdPartyErrorsFilter = __webpack_require__(/*! ./integrations/third-party-errors-filter.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/third-party-errors-filter.js\");\nconst console = __webpack_require__(/*! ./integrations/console.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/console.js\");\nconst featureFlagsIntegration = __webpack_require__(/*! ./integrations/featureFlags/featureFlagsIntegration.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/featureFlags/featureFlagsIntegration.js\");\nconst profiling = __webpack_require__(/*! ./profiling.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/profiling.js\");\nconst fetch = __webpack_require__(/*! ./fetch.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/fetch.js\");\nconst trpc = __webpack_require__(/*! ./trpc.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/trpc.js\");\nconst index$1 = __webpack_require__(/*! ./integrations/mcp-server/index.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/index.js\");\nconst feedback = __webpack_require__(/*! ./feedback.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/feedback.js\");\nconst exports$2 = __webpack_require__(/*! ./logs/exports.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/logs/exports.js\");\nconst consoleIntegration = __webpack_require__(/*! ./logs/console-integration.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/logs/console-integration.js\");\nconst vercelAi = __webpack_require__(/*! ./utils/vercel-ai.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/vercel-ai.js\");\nconst index$2 = __webpack_require__(/*! ./utils/openai/index.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/openai/index.js\");\nconst constants$1 = __webpack_require__(/*! ./utils/openai/constants.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/openai/constants.js\");\nconst featureFlags = __webpack_require__(/*! ./utils/featureFlags.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/featureFlags.js\");\nconst aggregateErrors = __webpack_require__(/*! ./utils/aggregate-errors.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/aggregate-errors.js\");\nconst breadcrumbLogLevel = __webpack_require__(/*! ./utils/breadcrumb-log-level.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/breadcrumb-log-level.js\");\nconst browser = __webpack_require__(/*! ./utils/browser.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/browser.js\");\nconst dsn = __webpack_require__(/*! ./utils/dsn.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/dsn.js\");\nconst error = __webpack_require__(/*! ./utils/error.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/error.js\");\nconst worldwide = __webpack_require__(/*! ./utils/worldwide.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/worldwide.js\");\nconst console$1 = __webpack_require__(/*! ./instrument/console.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/console.js\");\nconst fetch$1 = __webpack_require__(/*! ./instrument/fetch.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/fetch.js\");\nconst globalError = __webpack_require__(/*! ./instrument/globalError.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/globalError.js\");\nconst globalUnhandledRejection = __webpack_require__(/*! ./instrument/globalUnhandledRejection.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/globalUnhandledRejection.js\");\nconst handlers = __webpack_require__(/*! ./instrument/handlers.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/handlers.js\");\nconst is = __webpack_require__(/*! ./utils/is.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js\");\nconst isBrowser = __webpack_require__(/*! ./utils/isBrowser.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/isBrowser.js\");\nconst debugLogger = __webpack_require__(/*! ./utils/debug-logger.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst misc = __webpack_require__(/*! ./utils/misc.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/misc.js\");\nconst node = __webpack_require__(/*! ./utils/node.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/node.js\");\nconst normalize = __webpack_require__(/*! ./utils/normalize.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/normalize.js\");\nconst object = __webpack_require__(/*! ./utils/object.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/object.js\");\nconst path = __webpack_require__(/*! ./utils/path.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/path.js\");\nconst promisebuffer = __webpack_require__(/*! ./utils/promisebuffer.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/promisebuffer.js\");\nconst severity = __webpack_require__(/*! ./utils/severity.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/severity.js\");\nconst stacktrace = __webpack_require__(/*! ./utils/stacktrace.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/stacktrace.js\");\nconst nodeStackTrace = __webpack_require__(/*! ./utils/node-stack-trace.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/node-stack-trace.js\");\nconst string = __webpack_require__(/*! ./utils/string.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/string.js\");\nconst supports = __webpack_require__(/*! ./utils/supports.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/supports.js\");\nconst syncpromise = __webpack_require__(/*! ./utils/syncpromise.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/syncpromise.js\");\nconst time = __webpack_require__(/*! ./utils/time.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/time.js\");\nconst tracing = __webpack_require__(/*! ./utils/tracing.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/tracing.js\");\nconst env = __webpack_require__(/*! ./utils/env.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/env.js\");\nconst envelope$1 = __webpack_require__(/*! ./utils/envelope.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/envelope.js\");\nconst clientreport = __webpack_require__(/*! ./utils/clientreport.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/clientreport.js\");\nconst ratelimit = __webpack_require__(/*! ./utils/ratelimit.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/ratelimit.js\");\nconst baggage = __webpack_require__(/*! ./utils/baggage.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/baggage.js\");\nconst url = __webpack_require__(/*! ./utils/url.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/url.js\");\nconst eventbuilder = __webpack_require__(/*! ./utils/eventbuilder.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/eventbuilder.js\");\nconst anr = __webpack_require__(/*! ./utils/anr.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/anr.js\");\nconst lru = __webpack_require__(/*! ./utils/lru.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/lru.js\");\nconst propagationContext = __webpack_require__(/*! ./utils/propagationContext.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/propagationContext.js\");\nconst vercelWaitUntil = __webpack_require__(/*! ./utils/vercelWaitUntil.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/vercelWaitUntil.js\");\nconst flushIfServerless = __webpack_require__(/*! ./utils/flushIfServerless.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/flushIfServerless.js\");\nconst version = __webpack_require__(/*! ./utils/version.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/version.js\");\nconst debugIds = __webpack_require__(/*! ./utils/debug-ids.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-ids.js\");\nconst escapeStringForRegex = __webpack_require__(/*! ./vendor/escapeStringForRegex.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/vendor/escapeStringForRegex.js\");\n\n\n\nexports.registerSpanErrorInstrumentation = errors.registerSpanErrorInstrumentation;\nexports.getCapturedScopesOnSpan = utils.getCapturedScopesOnSpan;\nexports.setCapturedScopesOnSpan = utils.setCapturedScopesOnSpan;\nexports.TRACING_DEFAULTS = idleSpan.TRACING_DEFAULTS;\nexports.startIdleSpan = idleSpan.startIdleSpan;\nexports.SentrySpan = sentrySpan.SentrySpan;\nexports.SentryNonRecordingSpan = sentryNonRecordingSpan.SentryNonRecordingSpan;\nexports.SPAN_STATUS_ERROR = spanstatus.SPAN_STATUS_ERROR;\nexports.SPAN_STATUS_OK = spanstatus.SPAN_STATUS_OK;\nexports.SPAN_STATUS_UNSET = spanstatus.SPAN_STATUS_UNSET;\nexports.getSpanStatusFromHttpCode = spanstatus.getSpanStatusFromHttpCode;\nexports.setHttpStatus = spanstatus.setHttpStatus;\nexports.continueTrace = trace.continueTrace;\nexports.startInactiveSpan = trace.startInactiveSpan;\nexports.startNewTrace = trace.startNewTrace;\nexports.startSpan = trace.startSpan;\nexports.startSpanManual = trace.startSpanManual;\nexports.suppressTracing = trace.suppressTracing;\nexports.withActiveSpan = trace.withActiveSpan;\nexports.getDynamicSamplingContextFromClient = dynamicSamplingContext.getDynamicSamplingContextFromClient;\nexports.getDynamicSamplingContextFromScope = dynamicSamplingContext.getDynamicSamplingContextFromScope;\nexports.getDynamicSamplingContextFromSpan = dynamicSamplingContext.getDynamicSamplingContextFromSpan;\nexports.spanToBaggageHeader = dynamicSamplingContext.spanToBaggageHeader;\nexports.setMeasurement = measurement.setMeasurement;\nexports.timedEventsToMeasurements = measurement.timedEventsToMeasurements;\nexports.sampleSpan = sampling.sampleSpan;\nexports.logSpanEnd = logSpans.logSpanEnd;\nexports.logSpanStart = logSpans.logSpanStart;\nexports.SEMANTIC_ATTRIBUTE_CACHE_HIT = semanticAttributes.SEMANTIC_ATTRIBUTE_CACHE_HIT;\nexports.SEMANTIC_ATTRIBUTE_CACHE_ITEM_SIZE = semanticAttributes.SEMANTIC_ATTRIBUTE_CACHE_ITEM_SIZE;\nexports.SEMANTIC_ATTRIBUTE_CACHE_KEY = semanticAttributes.SEMANTIC_ATTRIBUTE_CACHE_KEY;\nexports.SEMANTIC_ATTRIBUTE_EXCLUSIVE_TIME = semanticAttributes.SEMANTIC_ATTRIBUTE_EXCLUSIVE_TIME;\nexports.SEMANTIC_ATTRIBUTE_HTTP_REQUEST_METHOD = semanticAttributes.SEMANTIC_ATTRIBUTE_HTTP_REQUEST_METHOD;\nexports.SEMANTIC_ATTRIBUTE_PROFILE_ID = semanticAttributes.SEMANTIC_ATTRIBUTE_PROFILE_ID;\nexports.SEMANTIC_ATTRIBUTE_SENTRY_CUSTOM_SPAN_NAME = semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_CUSTOM_SPAN_NAME;\nexports.SEMANTIC_ATTRIBUTE_SENTRY_IDLE_SPAN_FINISH_REASON = semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_IDLE_SPAN_FINISH_REASON;\nexports.SEMANTIC_ATTRIBUTE_SENTRY_MEASUREMENT_UNIT = semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_MEASUREMENT_UNIT;\nexports.SEMANTIC_ATTRIBUTE_SENTRY_MEASUREMENT_VALUE = semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_MEASUREMENT_VALUE;\nexports.SEMANTIC_ATTRIBUTE_SENTRY_OP = semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_OP;\nexports.SEMANTIC_ATTRIBUTE_SENTRY_ORIGIN = semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_ORIGIN;\nexports.SEMANTIC_ATTRIBUTE_SENTRY_PREVIOUS_TRACE_SAMPLE_RATE = semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_PREVIOUS_TRACE_SAMPLE_RATE;\nexports.SEMANTIC_ATTRIBUTE_SENTRY_SAMPLE_RATE = semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_SAMPLE_RATE;\nexports.SEMANTIC_ATTRIBUTE_SENTRY_SOURCE = semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_SOURCE;\nexports.SEMANTIC_ATTRIBUTE_URL_FULL = semanticAttributes.SEMANTIC_ATTRIBUTE_URL_FULL;\nexports.SEMANTIC_LINK_ATTRIBUTE_LINK_TYPE = semanticAttributes.SEMANTIC_LINK_ATTRIBUTE_LINK_TYPE;\nexports.createEventEnvelope = envelope.createEventEnvelope;\nexports.createSessionEnvelope = envelope.createSessionEnvelope;\nexports.createSpanEnvelope = envelope.createSpanEnvelope;\nexports.addEventProcessor = exports$1.addEventProcessor;\nexports.captureCheckIn = exports$1.captureCheckIn;\nexports.captureEvent = exports$1.captureEvent;\nexports.captureException = exports$1.captureException;\nexports.captureMessage = exports$1.captureMessage;\nexports.captureSession = exports$1.captureSession;\nexports.close = exports$1.close;\nexports.endSession = exports$1.endSession;\nexports.flush = exports$1.flush;\nexports.isEnabled = exports$1.isEnabled;\nexports.isInitialized = exports$1.isInitialized;\nexports.lastEventId = exports$1.lastEventId;\nexports.setContext = exports$1.setContext;\nexports.setExtra = exports$1.setExtra;\nexports.setExtras = exports$1.setExtras;\nexports.setTag = exports$1.setTag;\nexports.setTags = exports$1.setTags;\nexports.setUser = exports$1.setUser;\nexports.startSession = exports$1.startSession;\nexports.withMonitor = exports$1.withMonitor;\nexports.getClient = currentScopes.getClient;\nexports.getCurrentScope = currentScopes.getCurrentScope;\nexports.getGlobalScope = currentScopes.getGlobalScope;\nexports.getIsolationScope = currentScopes.getIsolationScope;\nexports.getTraceContextFromScope = currentScopes.getTraceContextFromScope;\nexports.withIsolationScope = currentScopes.withIsolationScope;\nexports.withScope = currentScopes.withScope;\nexports.getDefaultCurrentScope = defaultScopes.getDefaultCurrentScope;\nexports.getDefaultIsolationScope = defaultScopes.getDefaultIsolationScope;\nexports.setAsyncContextStrategy = index.setAsyncContextStrategy;\nexports.getGlobalSingleton = carrier.getGlobalSingleton;\nexports.getMainCarrier = carrier.getMainCarrier;\nexports.closeSession = session.closeSession;\nexports.makeSession = session.makeSession;\nexports.updateSession = session.updateSession;\nexports.Scope = scope.Scope;\nexports.notifyEventProcessors = eventProcessors.notifyEventProcessors;\nexports.getEnvelopeEndpointWithUrlEncodedAuth = api.getEnvelopeEndpointWithUrlEncodedAuth;\nexports.getReportDialogEndpoint = api.getReportDialogEndpoint;\nexports.BaseClient = client.BaseClient;\nexports.Client = client.Client;\nexports.ServerRuntimeClient = serverRuntimeClient.ServerRuntimeClient;\nexports.initAndBind = sdk.initAndBind;\nexports.setCurrentClient = sdk.setCurrentClient;\nexports.createTransport = base.createTransport;\nexports.makeOfflineTransport = offline.makeOfflineTransport;\nexports.makeMultiplexedTransport = multiplexed.makeMultiplexedTransport;\nexports.addIntegration = integration.addIntegration;\nexports.defineIntegration = integration.defineIntegration;\nexports.getIntegrationsToSetup = integration.getIntegrationsToSetup;\nexports.applyScopeDataToEvent = applyScopeDataToEvent.applyScopeDataToEvent;\nexports.mergeScopeData = applyScopeDataToEvent.mergeScopeData;\nexports.prepareEvent = prepareEvent.prepareEvent;\nexports.createCheckInEnvelope = checkin.createCheckInEnvelope;\nexports.hasSpansEnabled = hasSpansEnabled.hasSpansEnabled;\nexports.hasTracingEnabled = hasSpansEnabled.hasTracingEnabled;\nexports.isSentryRequestUrl = isSentryRequestUrl.isSentryRequestUrl;\nexports.handleCallbackErrors = handleCallbackErrors.handleCallbackErrors;\nexports.fmt = parameterize.fmt;\nexports.parameterize = parameterize.parameterize;\nexports.addAutoIpAddressToSession = ipAddress.addAutoIpAddressToSession;\nexports.addAutoIpAddressToUser = ipAddress.addAutoIpAddressToUser;\nexports.addChildSpanToSpan = spanUtils.addChildSpanToSpan;\nexports.convertSpanLinksForEnvelope = spanUtils.convertSpanLinksForEnvelope;\nexports.getActiveSpan = spanUtils.getActiveSpan;\nexports.getRootSpan = spanUtils.getRootSpan;\nexports.getSpanDescendants = spanUtils.getSpanDescendants;\nexports.getStatusMessage = spanUtils.getStatusMessage;\nexports.spanIsSampled = spanUtils.spanIsSampled;\nexports.spanTimeInputToSeconds = spanUtils.spanTimeInputToSeconds;\nexports.spanToJSON = spanUtils.spanToJSON;\nexports.spanToTraceContext = spanUtils.spanToTraceContext;\nexports.spanToTraceHeader = spanUtils.spanToTraceHeader;\nexports.updateSpanName = spanUtils.updateSpanName;\nexports.parseSampleRate = parseSampleRate.parseSampleRate;\nexports.applySdkMetadata = sdkMetadata.applySdkMetadata;\nexports.getTraceData = traceData.getTraceData;\nexports.getTraceMetaTags = meta.getTraceMetaTags;\nexports.debounce = debounce.debounce;\nexports.extractQueryParamsFromUrl = request.extractQueryParamsFromUrl;\nexports.headersToDict = request.headersToDict;\nexports.httpRequestToRequestData = request.httpRequestToRequestData;\nexports.winterCGHeadersToDict = request.winterCGHeadersToDict;\nexports.winterCGRequestToRequestData = request.winterCGRequestToRequestData;\nexports.DEFAULT_ENVIRONMENT = constants.DEFAULT_ENVIRONMENT;\nexports.addBreadcrumb = breadcrumbs.addBreadcrumb;\nexports.functionToStringIntegration = functiontostring.functionToStringIntegration;\nexports.eventFiltersIntegration = eventFilters.eventFiltersIntegration;\nexports.inboundFiltersIntegration = eventFilters.inboundFiltersIntegration;\nexports.linkedErrorsIntegration = linkederrors.linkedErrorsIntegration;\nexports.moduleMetadataIntegration = metadata.moduleMetadataIntegration;\nexports.requestDataIntegration = requestdata.requestDataIntegration;\nexports.captureConsoleIntegration = captureconsole.captureConsoleIntegration;\nexports.dedupeIntegration = dedupe.dedupeIntegration;\nexports.extraErrorDataIntegration = extraerrordata.extraErrorDataIntegration;\nexports.rewriteFramesIntegration = rewriteframes.rewriteFramesIntegration;\nexports.instrumentSupabaseClient = supabase.instrumentSupabaseClient;\nexports.supabaseIntegration = supabase.supabaseIntegration;\nexports.zodErrorsIntegration = zoderrors.zodErrorsIntegration;\nexports.thirdPartyErrorFilterIntegration = thirdPartyErrorsFilter.thirdPartyErrorFilterIntegration;\nexports.consoleIntegration = console.consoleIntegration;\nexports.featureFlagsIntegration = featureFlagsIntegration.featureFlagsIntegration;\nexports.profiler = profiling.profiler;\nexports.instrumentFetchRequest = fetch.instrumentFetchRequest;\nexports.trpcMiddleware = trpc.trpcMiddleware;\nexports.wrapMcpServerWithSentry = index$1.wrapMcpServerWithSentry;\nexports.captureFeedback = feedback.captureFeedback;\nexports._INTERNAL_captureLog = exports$2._INTERNAL_captureLog;\nexports._INTERNAL_captureSerializedLog = exports$2._INTERNAL_captureSerializedLog;\nexports._INTERNAL_flushLogsBuffer = exports$2._INTERNAL_flushLogsBuffer;\nexports.consoleLoggingIntegration = consoleIntegration.consoleLoggingIntegration;\nexports.addVercelAiProcessors = vercelAi.addVercelAiProcessors;\nexports.instrumentOpenAiClient = index$2.instrumentOpenAiClient;\nexports.OPENAI_INTEGRATION_NAME = constants$1.OPENAI_INTEGRATION_NAME;\nexports._INTERNAL_FLAG_BUFFER_SIZE = featureFlags._INTERNAL_FLAG_BUFFER_SIZE;\nexports._INTERNAL_MAX_FLAGS_PER_SPAN = featureFlags._INTERNAL_MAX_FLAGS_PER_SPAN;\nexports._INTERNAL_addFeatureFlagToActiveSpan = featureFlags._INTERNAL_addFeatureFlagToActiveSpan;\nexports._INTERNAL_copyFlagsFromScopeToEvent = featureFlags._INTERNAL_copyFlagsFromScopeToEvent;\nexports._INTERNAL_insertFlagToScope = featureFlags._INTERNAL_insertFlagToScope;\nexports.applyAggregateErrorsToEvent = aggregateErrors.applyAggregateErrorsToEvent;\nexports.getBreadcrumbLogLevelFromHttpStatusCode = breadcrumbLogLevel.getBreadcrumbLogLevelFromHttpStatusCode;\nexports.getComponentName = browser.getComponentName;\nexports.getLocationHref = browser.getLocationHref;\nexports.htmlTreeAsString = browser.htmlTreeAsString;\nexports.dsnFromString = dsn.dsnFromString;\nexports.dsnToString = dsn.dsnToString;\nexports.makeDsn = dsn.makeDsn;\nexports.SentryError = error.SentryError;\nexports.GLOBAL_OBJ = worldwide.GLOBAL_OBJ;\nexports.addConsoleInstrumentationHandler = console$1.addConsoleInstrumentationHandler;\nexports.addFetchEndInstrumentationHandler = fetch$1.addFetchEndInstrumentationHandler;\nexports.addFetchInstrumentationHandler = fetch$1.addFetchInstrumentationHandler;\nexports.addGlobalErrorInstrumentationHandler = globalError.addGlobalErrorInstrumentationHandler;\nexports.addGlobalUnhandledRejectionInstrumentationHandler = globalUnhandledRejection.addGlobalUnhandledRejectionInstrumentationHandler;\nexports.addHandler = handlers.addHandler;\nexports.maybeInstrument = handlers.maybeInstrument;\nexports.resetInstrumentationHandlers = handlers.resetInstrumentationHandlers;\nexports.triggerHandlers = handlers.triggerHandlers;\nexports.isDOMError = is.isDOMError;\nexports.isDOMException = is.isDOMException;\nexports.isElement = is.isElement;\nexports.isError = is.isError;\nexports.isErrorEvent = is.isErrorEvent;\nexports.isEvent = is.isEvent;\nexports.isInstanceOf = is.isInstanceOf;\nexports.isParameterizedString = is.isParameterizedString;\nexports.isPlainObject = is.isPlainObject;\nexports.isPrimitive = is.isPrimitive;\nexports.isRegExp = is.isRegExp;\nexports.isString = is.isString;\nexports.isSyntheticEvent = is.isSyntheticEvent;\nexports.isThenable = is.isThenable;\nexports.isVueViewModel = is.isVueViewModel;\nexports.isBrowser = isBrowser.isBrowser;\nexports.CONSOLE_LEVELS = debugLogger.CONSOLE_LEVELS;\nexports.consoleSandbox = debugLogger.consoleSandbox;\nexports.debug = debugLogger.debug;\nexports.logger = debugLogger.logger;\nexports.originalConsoleMethods = debugLogger.originalConsoleMethods;\nexports.addContextToFrame = misc.addContextToFrame;\nexports.addExceptionMechanism = misc.addExceptionMechanism;\nexports.addExceptionTypeValue = misc.addExceptionTypeValue;\nexports.checkOrSetAlreadyCaught = misc.checkOrSetAlreadyCaught;\nexports.getEventDescription = misc.getEventDescription;\nexports.parseSemver = misc.parseSemver;\nexports.uuid4 = misc.uuid4;\nexports.isNodeEnv = node.isNodeEnv;\nexports.loadModule = node.loadModule;\nexports.normalize = normalize.normalize;\nexports.normalizeToSize = normalize.normalizeToSize;\nexports.normalizeUrlToBase = normalize.normalizeUrlToBase;\nexports.addNonEnumerableProperty = object.addNonEnumerableProperty;\nexports.convertToPlainObject = object.convertToPlainObject;\nexports.dropUndefinedKeys = object.dropUndefinedKeys;\nexports.extractExceptionKeysForMessage = object.extractExceptionKeysForMessage;\nexports.fill = object.fill;\nexports.getOriginalFunction = object.getOriginalFunction;\nexports.markFunctionWrapped = object.markFunctionWrapped;\nexports.objectify = object.objectify;\nexports.basename = path.basename;\nexports.dirname = path.dirname;\nexports.isAbsolute = path.isAbsolute;\nexports.join = path.join;\nexports.normalizePath = path.normalizePath;\nexports.relative = path.relative;\nexports.resolve = path.resolve;\nexports.SENTRY_BUFFER_FULL_ERROR = promisebuffer.SENTRY_BUFFER_FULL_ERROR;\nexports.makePromiseBuffer = promisebuffer.makePromiseBuffer;\nexports.severityLevelFromString = severity.severityLevelFromString;\nexports.UNKNOWN_FUNCTION = stacktrace.UNKNOWN_FUNCTION;\nexports.createStackParser = stacktrace.createStackParser;\nexports.getFramesFromEvent = stacktrace.getFramesFromEvent;\nexports.getFunctionName = stacktrace.getFunctionName;\nexports.stackParserFromStackParserOptions = stacktrace.stackParserFromStackParserOptions;\nexports.stripSentryFramesAndReverse = stacktrace.stripSentryFramesAndReverse;\nexports.filenameIsInApp = nodeStackTrace.filenameIsInApp;\nexports.node = nodeStackTrace.node;\nexports.nodeStackLineParser = nodeStackTrace.nodeStackLineParser;\nexports.isMatchingPattern = string.isMatchingPattern;\nexports.safeJoin = string.safeJoin;\nexports.snipLine = string.snipLine;\nexports.stringMatchesSomePattern = string.stringMatchesSomePattern;\nexports.truncate = string.truncate;\nexports.isNativeFunction = supports.isNativeFunction;\nexports.supportsDOMError = supports.supportsDOMError;\nexports.supportsDOMException = supports.supportsDOMException;\nexports.supportsErrorEvent = supports.supportsErrorEvent;\nexports.supportsFetch = supports.supportsFetch;\nexports.supportsHistory = supports.supportsHistory;\nexports.supportsNativeFetch = supports.supportsNativeFetch;\nexports.supportsReferrerPolicy = supports.supportsReferrerPolicy;\nexports.supportsReportingObserver = supports.supportsReportingObserver;\nexports.SyncPromise = syncpromise.SyncPromise;\nexports.rejectedSyncPromise = syncpromise.rejectedSyncPromise;\nexports.resolvedSyncPromise = syncpromise.resolvedSyncPromise;\nexports.browserPerformanceTimeOrigin = time.browserPerformanceTimeOrigin;\nexports.dateTimestampInSeconds = time.dateTimestampInSeconds;\nexports.timestampInSeconds = time.timestampInSeconds;\nexports.TRACEPARENT_REGEXP = tracing.TRACEPARENT_REGEXP;\nexports.extractTraceparentData = tracing.extractTraceparentData;\nexports.generateSentryTraceHeader = tracing.generateSentryTraceHeader;\nexports.propagationContextFromHeaders = tracing.propagationContextFromHeaders;\nexports.getSDKSource = env.getSDKSource;\nexports.isBrowserBundle = env.isBrowserBundle;\nexports.addItemToEnvelope = envelope$1.addItemToEnvelope;\nexports.createAttachmentEnvelopeItem = envelope$1.createAttachmentEnvelopeItem;\nexports.createEnvelope = envelope$1.createEnvelope;\nexports.createEventEnvelopeHeaders = envelope$1.createEventEnvelopeHeaders;\nexports.createSpanEnvelopeItem = envelope$1.createSpanEnvelopeItem;\nexports.envelopeContainsItemType = envelope$1.envelopeContainsItemType;\nexports.envelopeItemTypeToDataCategory = envelope$1.envelopeItemTypeToDataCategory;\nexports.forEachEnvelopeItem = envelope$1.forEachEnvelopeItem;\nexports.getSdkMetadataForEnvelopeHeader = envelope$1.getSdkMetadataForEnvelopeHeader;\nexports.parseEnvelope = envelope$1.parseEnvelope;\nexports.serializeEnvelope = envelope$1.serializeEnvelope;\nexports.createClientReportEnvelope = clientreport.createClientReportEnvelope;\nexports.DEFAULT_RETRY_AFTER = ratelimit.DEFAULT_RETRY_AFTER;\nexports.disabledUntil = ratelimit.disabledUntil;\nexports.isRateLimited = ratelimit.isRateLimited;\nexports.parseRetryAfterHeader = ratelimit.parseRetryAfterHeader;\nexports.updateRateLimits = ratelimit.updateRateLimits;\nexports.MAX_BAGGAGE_STRING_LENGTH = baggage.MAX_BAGGAGE_STRING_LENGTH;\nexports.SENTRY_BAGGAGE_KEY_PREFIX = baggage.SENTRY_BAGGAGE_KEY_PREFIX;\nexports.SENTRY_BAGGAGE_KEY_PREFIX_REGEX = baggage.SENTRY_BAGGAGE_KEY_PREFIX_REGEX;\nexports.baggageHeaderToDynamicSamplingContext = baggage.baggageHeaderToDynamicSamplingContext;\nexports.dynamicSamplingContextToSentryBaggageHeader = baggage.dynamicSamplingContextToSentryBaggageHeader;\nexports.objectToBaggageHeader = baggage.objectToBaggageHeader;\nexports.parseBaggageHeader = baggage.parseBaggageHeader;\nexports.getHttpSpanDetailsFromUrlObject = url.getHttpSpanDetailsFromUrlObject;\nexports.getSanitizedUrlString = url.getSanitizedUrlString;\nexports.getSanitizedUrlStringFromUrlObject = url.getSanitizedUrlStringFromUrlObject;\nexports.isURLObjectRelative = url.isURLObjectRelative;\nexports.parseStringToURLObject = url.parseStringToURLObject;\nexports.parseUrl = url.parseUrl;\nexports.stripUrlQueryAndFragment = url.stripUrlQueryAndFragment;\nexports.eventFromMessage = eventbuilder.eventFromMessage;\nexports.eventFromUnknownInput = eventbuilder.eventFromUnknownInput;\nexports.exceptionFromError = eventbuilder.exceptionFromError;\nexports.parseStackFrames = eventbuilder.parseStackFrames;\nexports.callFrameToStackFrame = anr.callFrameToStackFrame;\nexports.watchdogTimer = anr.watchdogTimer;\nexports.LRUMap = lru.LRUMap;\nexports.generateSpanId = propagationContext.generateSpanId;\nexports.generateTraceId = propagationContext.generateTraceId;\nexports.vercelWaitUntil = vercelWaitUntil.vercelWaitUntil;\nexports.flushIfServerless = flushIfServerless.flushIfServerless;\nexports.SDK_VERSION = version.SDK_VERSION;\nexports.getDebugImagesForResources = debugIds.getDebugImagesForResources;\nexports.getFilenameToDebugIdMap = debugIds.getFilenameToDebugIdMap;\nexports.escapeStringForRegex = escapeStringForRegex.escapeStringForRegex;\n//# sourceMappingURL=index.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbmRleC5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxlQUFlLG1CQUFPLENBQUMsaUlBQXFCO0FBQzVDLGNBQWMsbUJBQU8sQ0FBQywrSEFBb0I7QUFDMUMsaUJBQWlCLG1CQUFPLENBQUMscUlBQXVCO0FBQ2hELG1CQUFtQixtQkFBTyxDQUFDLHlJQUF5QjtBQUNwRCwrQkFBK0IsbUJBQU8sQ0FBQyxpS0FBcUM7QUFDNUUsbUJBQW1CLG1CQUFPLENBQUMseUlBQXlCO0FBQ3BELGNBQWMsbUJBQU8sQ0FBQywrSEFBb0I7QUFDMUMsK0JBQStCLG1CQUFPLENBQUMsaUtBQXFDO0FBQzVFLG9CQUFvQixtQkFBTyxDQUFDLDJJQUEwQjtBQUN0RCxpQkFBaUIsbUJBQU8sQ0FBQyxxSUFBdUI7QUFDaEQsaUJBQWlCLG1CQUFPLENBQUMscUlBQXVCO0FBQ2hELDJCQUEyQixtQkFBTyxDQUFDLHlJQUF5QjtBQUM1RCxpQkFBaUIsbUJBQU8sQ0FBQyxxSEFBZTtBQUN4QyxrQkFBa0IsbUJBQU8sQ0FBQyxtSEFBYztBQUN4QyxzQkFBc0IsbUJBQU8sQ0FBQywrSEFBb0I7QUFDbEQsc0JBQXNCLG1CQUFPLENBQUMsK0hBQW9CO0FBQ2xELGNBQWMsbUJBQU8sQ0FBQyx5SUFBeUI7QUFDL0MsZ0JBQWdCLG1CQUFPLENBQUMsbUhBQWM7QUFDdEMsZ0JBQWdCLG1CQUFPLENBQUMsbUhBQWM7QUFDdEMsY0FBYyxtQkFBTyxDQUFDLCtHQUFZO0FBQ2xDLHdCQUF3QixtQkFBTyxDQUFDLG1JQUFzQjtBQUN0RCxZQUFZLG1CQUFPLENBQUMsMkdBQVU7QUFDOUIsZUFBZSxtQkFBTyxDQUFDLGlIQUFhO0FBQ3BDLDRCQUE0QixtQkFBTyxDQUFDLCtJQUE0QjtBQUNoRSxZQUFZLG1CQUFPLENBQUMsMkdBQVU7QUFDOUIsYUFBYSxtQkFBTyxDQUFDLG1JQUFzQjtBQUMzQyxnQkFBZ0IsbUJBQU8sQ0FBQyx5SUFBeUI7QUFDakQsb0JBQW9CLG1CQUFPLENBQUMsaUpBQTZCO0FBQ3pELG9CQUFvQixtQkFBTyxDQUFDLDJIQUFrQjtBQUM5Qyw4QkFBOEIsbUJBQU8sQ0FBQywySkFBa0M7QUFDeEUscUJBQXFCLG1CQUFPLENBQUMseUlBQXlCO0FBQ3RELGdCQUFnQixtQkFBTyxDQUFDLG1IQUFjO0FBQ3RDLHdCQUF3QixtQkFBTyxDQUFDLCtJQUE0QjtBQUM1RCwyQkFBMkIsbUJBQU8sQ0FBQyxxSkFBK0I7QUFDbEUsNkJBQTZCLG1CQUFPLENBQUMseUpBQWlDO0FBQ3RFLHFCQUFxQixtQkFBTyxDQUFDLHlJQUF5QjtBQUN0RCxrQkFBa0IsbUJBQU8sQ0FBQyxtSUFBc0I7QUFDaEQsa0JBQWtCLG1CQUFPLENBQUMsbUlBQXNCO0FBQ2hELHdCQUF3QixtQkFBTyxDQUFDLCtJQUE0QjtBQUM1RCxvQkFBb0IsbUJBQU8sQ0FBQyx1SUFBd0I7QUFDcEQsa0JBQWtCLG1CQUFPLENBQUMsbUlBQXNCO0FBQ2hELGFBQWEsbUJBQU8sQ0FBQyx5SEFBaUI7QUFDdEMsaUJBQWlCLG1CQUFPLENBQUMsaUlBQXFCO0FBQzlDLGdCQUFnQixtQkFBTyxDQUFDLCtIQUFvQjtBQUM1QyxrQkFBa0IsbUJBQU8sQ0FBQyx1SEFBZ0I7QUFDMUMsb0JBQW9CLG1CQUFPLENBQUMsMkhBQWtCO0FBQzlDLHlCQUF5QixtQkFBTyxDQUFDLCtKQUFvQztBQUNyRSxxQkFBcUIsbUJBQU8sQ0FBQyx1SkFBZ0M7QUFDN0QscUJBQXFCLG1CQUFPLENBQUMsdUpBQWdDO0FBQzdELGlCQUFpQixtQkFBTyxDQUFDLCtJQUE0QjtBQUNyRCxvQkFBb0IsbUJBQU8sQ0FBQyxxSkFBK0I7QUFDM0QsdUJBQXVCLG1CQUFPLENBQUMsMkpBQWtDO0FBQ2pFLGVBQWUsbUJBQU8sQ0FBQywySUFBMEI7QUFDakQsdUJBQXVCLG1CQUFPLENBQUMsMkpBQWtDO0FBQ2pFLHNCQUFzQixtQkFBTyxDQUFDLHlKQUFpQztBQUMvRCxpQkFBaUIsbUJBQU8sQ0FBQywrSUFBNEI7QUFDckQsa0JBQWtCLG1CQUFPLENBQUMsaUpBQTZCO0FBQ3ZELCtCQUErQixtQkFBTyxDQUFDLGlMQUE2QztBQUNwRixnQkFBZ0IsbUJBQU8sQ0FBQyw2SUFBMkI7QUFDbkQsZ0NBQWdDLG1CQUFPLENBQUMsdU1BQXdEO0FBQ2hHLGtCQUFrQixtQkFBTyxDQUFDLHVIQUFnQjtBQUMxQyxjQUFjLG1CQUFPLENBQUMsK0dBQVk7QUFDbEMsYUFBYSxtQkFBTyxDQUFDLDZHQUFXO0FBQ2hDLGdCQUFnQixtQkFBTyxDQUFDLCtKQUFvQztBQUM1RCxpQkFBaUIsbUJBQU8sQ0FBQyxxSEFBZTtBQUN4QyxrQkFBa0IsbUJBQU8sQ0FBQyw2SEFBbUI7QUFDN0MsMkJBQTJCLG1CQUFPLENBQUMscUpBQStCO0FBQ2xFLGlCQUFpQixtQkFBTyxDQUFDLG1JQUFzQjtBQUMvQyxnQkFBZ0IsbUJBQU8sQ0FBQyx5SUFBeUI7QUFDakQsb0JBQW9CLG1CQUFPLENBQUMsaUpBQTZCO0FBQ3pELHFCQUFxQixtQkFBTyxDQUFDLHlJQUF5QjtBQUN0RCx3QkFBd0IsbUJBQU8sQ0FBQyxpSkFBNkI7QUFDN0QsMkJBQTJCLG1CQUFPLENBQUMseUpBQWlDO0FBQ3BFLGdCQUFnQixtQkFBTyxDQUFDLCtIQUFvQjtBQUM1QyxZQUFZLG1CQUFPLENBQUMsdUhBQWdCO0FBQ3BDLGNBQWMsbUJBQU8sQ0FBQywySEFBa0I7QUFDeEMsa0JBQWtCLG1CQUFPLENBQUMsbUlBQXNCO0FBQ2hELGtCQUFrQixtQkFBTyxDQUFDLHlJQUF5QjtBQUNuRCxnQkFBZ0IsbUJBQU8sQ0FBQyxxSUFBdUI7QUFDL0Msb0JBQW9CLG1CQUFPLENBQUMsaUpBQTZCO0FBQ3pELGlDQUFpQyxtQkFBTyxDQUFDLDJLQUEwQztBQUNuRixpQkFBaUIsbUJBQU8sQ0FBQywySUFBMEI7QUFDbkQsV0FBVyxtQkFBTyxDQUFDLHFIQUFlO0FBQ2xDLGtCQUFrQixtQkFBTyxDQUFDLG1JQUFzQjtBQUNoRCxvQkFBb0IsbUJBQU8sQ0FBQyx5SUFBeUI7QUFDckQsYUFBYSxtQkFBTyxDQUFDLHlIQUFpQjtBQUN0QyxhQUFhLG1CQUFPLENBQUMseUhBQWlCO0FBQ3RDLGtCQUFrQixtQkFBTyxDQUFDLG1JQUFzQjtBQUNoRCxlQUFlLG1CQUFPLENBQUMsNkhBQW1CO0FBQzFDLGFBQWEsbUJBQU8sQ0FBQyx5SEFBaUI7QUFDdEMsc0JBQXNCLG1CQUFPLENBQUMsMklBQTBCO0FBQ3hELGlCQUFpQixtQkFBTyxDQUFDLGlJQUFxQjtBQUM5QyxtQkFBbUIsbUJBQU8sQ0FBQyxxSUFBdUI7QUFDbEQsdUJBQXVCLG1CQUFPLENBQUMsaUpBQTZCO0FBQzVELGVBQWUsbUJBQU8sQ0FBQyw2SEFBbUI7QUFDMUMsaUJBQWlCLG1CQUFPLENBQUMsaUlBQXFCO0FBQzlDLG9CQUFvQixtQkFBTyxDQUFDLHVJQUF3QjtBQUNwRCxhQUFhLG1CQUFPLENBQUMseUhBQWlCO0FBQ3RDLGdCQUFnQixtQkFBTyxDQUFDLCtIQUFvQjtBQUM1QyxZQUFZLG1CQUFPLENBQUMsdUhBQWdCO0FBQ3BDLG1CQUFtQixtQkFBTyxDQUFDLGlJQUFxQjtBQUNoRCxxQkFBcUIsbUJBQU8sQ0FBQyx5SUFBeUI7QUFDdEQsa0JBQWtCLG1CQUFPLENBQUMsbUlBQXNCO0FBQ2hELGdCQUFnQixtQkFBTyxDQUFDLCtIQUFvQjtBQUM1QyxZQUFZLG1CQUFPLENBQUMsdUhBQWdCO0FBQ3BDLHFCQUFxQixtQkFBTyxDQUFDLHlJQUF5QjtBQUN0RCxZQUFZLG1CQUFPLENBQUMsdUhBQWdCO0FBQ3BDLFlBQVksbUJBQU8sQ0FBQyx1SEFBZ0I7QUFDcEMsMkJBQTJCLG1CQUFPLENBQUMscUpBQStCO0FBQ2xFLHdCQUF3QixtQkFBTyxDQUFDLCtJQUE0QjtBQUM1RCwwQkFBMEIsbUJBQU8sQ0FBQyxtSkFBOEI7QUFDaEUsZ0JBQWdCLG1CQUFPLENBQUMsK0hBQW9CO0FBQzVDLGlCQUFpQixtQkFBTyxDQUFDLG1JQUFzQjtBQUMvQyw2QkFBNkIsbUJBQU8sQ0FBQywySkFBa0M7Ozs7QUFJdkUsd0NBQXdDO0FBQ3hDLCtCQUErQjtBQUMvQiwrQkFBK0I7QUFDL0Isd0JBQXdCO0FBQ3hCLHFCQUFxQjtBQUNyQixrQkFBa0I7QUFDbEIsOEJBQThCO0FBQzlCLHlCQUF5QjtBQUN6QixzQkFBc0I7QUFDdEIseUJBQXlCO0FBQ3pCLGlDQUFpQztBQUNqQyxxQkFBcUI7QUFDckIscUJBQXFCO0FBQ3JCLHlCQUF5QjtBQUN6QixxQkFBcUI7QUFDckIsaUJBQWlCO0FBQ2pCLHVCQUF1QjtBQUN2Qix1QkFBdUI7QUFDdkIsc0JBQXNCO0FBQ3RCLDJDQUEyQztBQUMzQywwQ0FBMEM7QUFDMUMseUNBQXlDO0FBQ3pDLDJCQUEyQjtBQUMzQixzQkFBc0I7QUFDdEIsaUNBQWlDO0FBQ2pDLGtCQUFrQjtBQUNsQixrQkFBa0I7QUFDbEIsb0JBQW9CO0FBQ3BCLG9DQUFvQztBQUNwQywwQ0FBMEM7QUFDMUMsb0NBQW9DO0FBQ3BDLHlDQUF5QztBQUN6Qyw4Q0FBOEM7QUFDOUMscUNBQXFDO0FBQ3JDLGtEQUFrRDtBQUNsRCx5REFBeUQ7QUFDekQsa0RBQWtEO0FBQ2xELG1EQUFtRDtBQUNuRCxvQ0FBb0M7QUFDcEMsd0NBQXdDO0FBQ3hDLDREQUE0RDtBQUM1RCw2Q0FBNkM7QUFDN0Msd0NBQXdDO0FBQ3hDLG1DQUFtQztBQUNuQyx5Q0FBeUM7QUFDekMsMkJBQTJCO0FBQzNCLDZCQUE2QjtBQUM3QiwwQkFBMEI7QUFDMUIseUJBQXlCO0FBQ3pCLHNCQUFzQjtBQUN0QixvQkFBb0I7QUFDcEIsd0JBQXdCO0FBQ3hCLHNCQUFzQjtBQUN0QixzQkFBc0I7QUFDdEIsYUFBYTtBQUNiLGtCQUFrQjtBQUNsQixhQUFhO0FBQ2IsaUJBQWlCO0FBQ2pCLHFCQUFxQjtBQUNyQixtQkFBbUI7QUFDbkIsa0JBQWtCO0FBQ2xCLGdCQUFnQjtBQUNoQixpQkFBaUI7QUFDakIsY0FBYztBQUNkLGVBQWU7QUFDZixlQUFlO0FBQ2Ysb0JBQW9CO0FBQ3BCLG1CQUFtQjtBQUNuQixpQkFBaUI7QUFDakIsdUJBQXVCO0FBQ3ZCLHNCQUFzQjtBQUN0Qix5QkFBeUI7QUFDekIsZ0NBQWdDO0FBQ2hDLDBCQUEwQjtBQUMxQixpQkFBaUI7QUFDakIsOEJBQThCO0FBQzlCLGdDQUFnQztBQUNoQywrQkFBK0I7QUFDL0IsMEJBQTBCO0FBQzFCLHNCQUFzQjtBQUN0QixvQkFBb0I7QUFDcEIsbUJBQW1CO0FBQ25CLHFCQUFxQjtBQUNyQixhQUFhO0FBQ2IsNkJBQTZCO0FBQzdCLDZDQUE2QztBQUM3QywrQkFBK0I7QUFDL0Isa0JBQWtCO0FBQ2xCLGNBQWM7QUFDZCwyQkFBMkI7QUFDM0IsbUJBQW1CO0FBQ25CLHdCQUF3QjtBQUN4Qix1QkFBdUI7QUFDdkIsNEJBQTRCO0FBQzVCLGdDQUFnQztBQUNoQyxzQkFBc0I7QUFDdEIseUJBQXlCO0FBQ3pCLDhCQUE4QjtBQUM5Qiw2QkFBNkI7QUFDN0Isc0JBQXNCO0FBQ3RCLG9CQUFvQjtBQUNwQiw2QkFBNkI7QUFDN0IsdUJBQXVCO0FBQ3ZCLHlCQUF5QjtBQUN6QiwwQkFBMEI7QUFDMUIsNEJBQTRCO0FBQzVCLFdBQVc7QUFDWCxvQkFBb0I7QUFDcEIsaUNBQWlDO0FBQ2pDLDhCQUE4QjtBQUM5QiwwQkFBMEI7QUFDMUIsbUNBQW1DO0FBQ25DLHFCQUFxQjtBQUNyQixtQkFBbUI7QUFDbkIsMEJBQTBCO0FBQzFCLHdCQUF3QjtBQUN4QixxQkFBcUI7QUFDckIsOEJBQThCO0FBQzlCLGtCQUFrQjtBQUNsQiwwQkFBMEI7QUFDMUIseUJBQXlCO0FBQ3pCLHNCQUFzQjtBQUN0Qix1QkFBdUI7QUFDdkIsd0JBQXdCO0FBQ3hCLG9CQUFvQjtBQUNwQix3QkFBd0I7QUFDeEIsZ0JBQWdCO0FBQ2hCLGlDQUFpQztBQUNqQyxxQkFBcUI7QUFDckIsZ0NBQWdDO0FBQ2hDLDZCQUE2QjtBQUM3QixvQ0FBb0M7QUFDcEMsMkJBQTJCO0FBQzNCLHFCQUFxQjtBQUNyQixtQ0FBbUM7QUFDbkMsK0JBQStCO0FBQy9CLGlDQUFpQztBQUNqQywrQkFBK0I7QUFDL0IsaUNBQWlDO0FBQ2pDLDhCQUE4QjtBQUM5QixpQ0FBaUM7QUFDakMseUJBQXlCO0FBQ3pCLGlDQUFpQztBQUNqQyxnQ0FBZ0M7QUFDaEMsZ0NBQWdDO0FBQ2hDLDJCQUEyQjtBQUMzQiw0QkFBNEI7QUFDNUIsd0NBQXdDO0FBQ3hDLDBCQUEwQjtBQUMxQiwrQkFBK0I7QUFDL0IsZ0JBQWdCO0FBQ2hCLDhCQUE4QjtBQUM5QixzQkFBc0I7QUFDdEIsK0JBQStCO0FBQy9CLHVCQUF1QjtBQUN2Qiw0QkFBNEI7QUFDNUIsc0NBQXNDO0FBQ3RDLGlDQUFpQztBQUNqQyxpQ0FBaUM7QUFDakMsNkJBQTZCO0FBQzdCLDhCQUE4QjtBQUM5QiwrQkFBK0I7QUFDL0Isa0NBQWtDO0FBQ2xDLG9DQUFvQztBQUNwQyw0Q0FBNEM7QUFDNUMsMkNBQTJDO0FBQzNDLG1DQUFtQztBQUNuQyxtQ0FBbUM7QUFDbkMsK0NBQStDO0FBQy9DLHdCQUF3QjtBQUN4Qix1QkFBdUI7QUFDdkIsd0JBQXdCO0FBQ3hCLHFCQUFxQjtBQUNyQixtQkFBbUI7QUFDbkIsZUFBZTtBQUNmLG1CQUFtQjtBQUNuQixrQkFBa0I7QUFDbEIsd0NBQXdDO0FBQ3hDLHlDQUF5QztBQUN6QyxzQ0FBc0M7QUFDdEMsNENBQTRDO0FBQzVDLHlEQUF5RDtBQUN6RCxrQkFBa0I7QUFDbEIsdUJBQXVCO0FBQ3ZCLG9DQUFvQztBQUNwQyx1QkFBdUI7QUFDdkIsa0JBQWtCO0FBQ2xCLHNCQUFzQjtBQUN0QixpQkFBaUI7QUFDakIsZUFBZTtBQUNmLG9CQUFvQjtBQUNwQixlQUFlO0FBQ2Ysb0JBQW9CO0FBQ3BCLDZCQUE2QjtBQUM3QixxQkFBcUI7QUFDckIsbUJBQW1CO0FBQ25CLGdCQUFnQjtBQUNoQixnQkFBZ0I7QUFDaEIsd0JBQXdCO0FBQ3hCLGtCQUFrQjtBQUNsQixzQkFBc0I7QUFDdEIsaUJBQWlCO0FBQ2pCLHNCQUFzQjtBQUN0QixzQkFBc0I7QUFDdEIsYUFBYTtBQUNiLGNBQWM7QUFDZCw4QkFBOEI7QUFDOUIseUJBQXlCO0FBQ3pCLDZCQUE2QjtBQUM3Qiw2QkFBNkI7QUFDN0IsK0JBQStCO0FBQy9CLDJCQUEyQjtBQUMzQixtQkFBbUI7QUFDbkIsYUFBYTtBQUNiLGlCQUFpQjtBQUNqQixrQkFBa0I7QUFDbEIsaUJBQWlCO0FBQ2pCLHVCQUF1QjtBQUN2QiwwQkFBMEI7QUFDMUIsZ0NBQWdDO0FBQ2hDLDRCQUE0QjtBQUM1Qix5QkFBeUI7QUFDekIsc0NBQXNDO0FBQ3RDLFlBQVk7QUFDWiwyQkFBMkI7QUFDM0IsMkJBQTJCO0FBQzNCLGlCQUFpQjtBQUNqQixnQkFBZ0I7QUFDaEIsZUFBZTtBQUNmLGtCQUFrQjtBQUNsQixZQUFZO0FBQ1oscUJBQXFCO0FBQ3JCLGdCQUFnQjtBQUNoQixlQUFlO0FBQ2YsZ0NBQWdDO0FBQ2hDLHlCQUF5QjtBQUN6QiwrQkFBK0I7QUFDL0Isd0JBQXdCO0FBQ3hCLHlCQUF5QjtBQUN6QiwwQkFBMEI7QUFDMUIsdUJBQXVCO0FBQ3ZCLHlDQUF5QztBQUN6QyxtQ0FBbUM7QUFDbkMsdUJBQXVCO0FBQ3ZCLFlBQVk7QUFDWiwyQkFBMkI7QUFDM0IseUJBQXlCO0FBQ3pCLGdCQUFnQjtBQUNoQixnQkFBZ0I7QUFDaEIsZ0NBQWdDO0FBQ2hDLGdCQUFnQjtBQUNoQix3QkFBd0I7QUFDeEIsd0JBQXdCO0FBQ3hCLDRCQUE0QjtBQUM1QiwwQkFBMEI7QUFDMUIscUJBQXFCO0FBQ3JCLHVCQUF1QjtBQUN2QiwyQkFBMkI7QUFDM0IsOEJBQThCO0FBQzlCLGlDQUFpQztBQUNqQyxtQkFBbUI7QUFDbkIsMkJBQTJCO0FBQzNCLDJCQUEyQjtBQUMzQixvQ0FBb0M7QUFDcEMsOEJBQThCO0FBQzlCLDBCQUEwQjtBQUMxQiwwQkFBMEI7QUFDMUIsOEJBQThCO0FBQzlCLGlDQUFpQztBQUNqQyxxQ0FBcUM7QUFDckMsb0JBQW9CO0FBQ3BCLHVCQUF1QjtBQUN2Qix5QkFBeUI7QUFDekIsb0NBQW9DO0FBQ3BDLHNCQUFzQjtBQUN0QixrQ0FBa0M7QUFDbEMsOEJBQThCO0FBQzlCLGdDQUFnQztBQUNoQyxzQ0FBc0M7QUFDdEMsMkJBQTJCO0FBQzNCLHVDQUF1QztBQUN2QyxxQkFBcUI7QUFDckIseUJBQXlCO0FBQ3pCLGtDQUFrQztBQUNsQywyQkFBMkI7QUFDM0IscUJBQXFCO0FBQ3JCLHFCQUFxQjtBQUNyQiw2QkFBNkI7QUFDN0Isd0JBQXdCO0FBQ3hCLGlDQUFpQztBQUNqQyxpQ0FBaUM7QUFDakMsdUNBQXVDO0FBQ3ZDLDZDQUE2QztBQUM3QyxtREFBbUQ7QUFDbkQsNkJBQTZCO0FBQzdCLDBCQUEwQjtBQUMxQix1Q0FBdUM7QUFDdkMsNkJBQTZCO0FBQzdCLDBDQUEwQztBQUMxQywyQkFBMkI7QUFDM0IsOEJBQThCO0FBQzlCLGdCQUFnQjtBQUNoQixnQ0FBZ0M7QUFDaEMsd0JBQXdCO0FBQ3hCLDZCQUE2QjtBQUM3QiwwQkFBMEI7QUFDMUIsd0JBQXdCO0FBQ3hCLDZCQUE2QjtBQUM3QixxQkFBcUI7QUFDckIsY0FBYztBQUNkLHNCQUFzQjtBQUN0Qix1QkFBdUI7QUFDdkIsdUJBQXVCO0FBQ3ZCLHlCQUF5QjtBQUN6QixtQkFBbUI7QUFDbkIsa0NBQWtDO0FBQ2xDLCtCQUErQjtBQUMvQiw0QkFBNEI7QUFDNUIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbmRleC5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgZXJyb3JzID0gcmVxdWlyZSgnLi90cmFjaW5nL2Vycm9ycy5qcycpO1xuY29uc3QgdXRpbHMgPSByZXF1aXJlKCcuL3RyYWNpbmcvdXRpbHMuanMnKTtcbmNvbnN0IGlkbGVTcGFuID0gcmVxdWlyZSgnLi90cmFjaW5nL2lkbGVTcGFuLmpzJyk7XG5jb25zdCBzZW50cnlTcGFuID0gcmVxdWlyZSgnLi90cmFjaW5nL3NlbnRyeVNwYW4uanMnKTtcbmNvbnN0IHNlbnRyeU5vblJlY29yZGluZ1NwYW4gPSByZXF1aXJlKCcuL3RyYWNpbmcvc2VudHJ5Tm9uUmVjb3JkaW5nU3Bhbi5qcycpO1xuY29uc3Qgc3BhbnN0YXR1cyA9IHJlcXVpcmUoJy4vdHJhY2luZy9zcGFuc3RhdHVzLmpzJyk7XG5jb25zdCB0cmFjZSA9IHJlcXVpcmUoJy4vdHJhY2luZy90cmFjZS5qcycpO1xuY29uc3QgZHluYW1pY1NhbXBsaW5nQ29udGV4dCA9IHJlcXVpcmUoJy4vdHJhY2luZy9keW5hbWljU2FtcGxpbmdDb250ZXh0LmpzJyk7XG5jb25zdCBtZWFzdXJlbWVudCA9IHJlcXVpcmUoJy4vdHJhY2luZy9tZWFzdXJlbWVudC5qcycpO1xuY29uc3Qgc2FtcGxpbmcgPSByZXF1aXJlKCcuL3RyYWNpbmcvc2FtcGxpbmcuanMnKTtcbmNvbnN0IGxvZ1NwYW5zID0gcmVxdWlyZSgnLi90cmFjaW5nL2xvZ1NwYW5zLmpzJyk7XG5jb25zdCBzZW1hbnRpY0F0dHJpYnV0ZXMgPSByZXF1aXJlKCcuL3NlbWFudGljQXR0cmlidXRlcy5qcycpO1xuY29uc3QgZW52ZWxvcGUgPSByZXF1aXJlKCcuL2VudmVsb3BlLmpzJyk7XG5jb25zdCBleHBvcnRzJDEgPSByZXF1aXJlKCcuL2V4cG9ydHMuanMnKTtcbmNvbnN0IGN1cnJlbnRTY29wZXMgPSByZXF1aXJlKCcuL2N1cnJlbnRTY29wZXMuanMnKTtcbmNvbnN0IGRlZmF1bHRTY29wZXMgPSByZXF1aXJlKCcuL2RlZmF1bHRTY29wZXMuanMnKTtcbmNvbnN0IGluZGV4ID0gcmVxdWlyZSgnLi9hc3luY0NvbnRleHQvaW5kZXguanMnKTtcbmNvbnN0IGNhcnJpZXIgPSByZXF1aXJlKCcuL2NhcnJpZXIuanMnKTtcbmNvbnN0IHNlc3Npb24gPSByZXF1aXJlKCcuL3Nlc3Npb24uanMnKTtcbmNvbnN0IHNjb3BlID0gcmVxdWlyZSgnLi9zY29wZS5qcycpO1xuY29uc3QgZXZlbnRQcm9jZXNzb3JzID0gcmVxdWlyZSgnLi9ldmVudFByb2Nlc3NvcnMuanMnKTtcbmNvbnN0IGFwaSA9IHJlcXVpcmUoJy4vYXBpLmpzJyk7XG5jb25zdCBjbGllbnQgPSByZXF1aXJlKCcuL2NsaWVudC5qcycpO1xuY29uc3Qgc2VydmVyUnVudGltZUNsaWVudCA9IHJlcXVpcmUoJy4vc2VydmVyLXJ1bnRpbWUtY2xpZW50LmpzJyk7XG5jb25zdCBzZGsgPSByZXF1aXJlKCcuL3Nkay5qcycpO1xuY29uc3QgYmFzZSA9IHJlcXVpcmUoJy4vdHJhbnNwb3J0cy9iYXNlLmpzJyk7XG5jb25zdCBvZmZsaW5lID0gcmVxdWlyZSgnLi90cmFuc3BvcnRzL29mZmxpbmUuanMnKTtcbmNvbnN0IG11bHRpcGxleGVkID0gcmVxdWlyZSgnLi90cmFuc3BvcnRzL211bHRpcGxleGVkLmpzJyk7XG5jb25zdCBpbnRlZ3JhdGlvbiA9IHJlcXVpcmUoJy4vaW50ZWdyYXRpb24uanMnKTtcbmNvbnN0IGFwcGx5U2NvcGVEYXRhVG9FdmVudCA9IHJlcXVpcmUoJy4vdXRpbHMvYXBwbHlTY29wZURhdGFUb0V2ZW50LmpzJyk7XG5jb25zdCBwcmVwYXJlRXZlbnQgPSByZXF1aXJlKCcuL3V0aWxzL3ByZXBhcmVFdmVudC5qcycpO1xuY29uc3QgY2hlY2tpbiA9IHJlcXVpcmUoJy4vY2hlY2tpbi5qcycpO1xuY29uc3QgaGFzU3BhbnNFbmFibGVkID0gcmVxdWlyZSgnLi91dGlscy9oYXNTcGFuc0VuYWJsZWQuanMnKTtcbmNvbnN0IGlzU2VudHJ5UmVxdWVzdFVybCA9IHJlcXVpcmUoJy4vdXRpbHMvaXNTZW50cnlSZXF1ZXN0VXJsLmpzJyk7XG5jb25zdCBoYW5kbGVDYWxsYmFja0Vycm9ycyA9IHJlcXVpcmUoJy4vdXRpbHMvaGFuZGxlQ2FsbGJhY2tFcnJvcnMuanMnKTtcbmNvbnN0IHBhcmFtZXRlcml6ZSA9IHJlcXVpcmUoJy4vdXRpbHMvcGFyYW1ldGVyaXplLmpzJyk7XG5jb25zdCBpcEFkZHJlc3MgPSByZXF1aXJlKCcuL3V0aWxzL2lwQWRkcmVzcy5qcycpO1xuY29uc3Qgc3BhblV0aWxzID0gcmVxdWlyZSgnLi91dGlscy9zcGFuVXRpbHMuanMnKTtcbmNvbnN0IHBhcnNlU2FtcGxlUmF0ZSA9IHJlcXVpcmUoJy4vdXRpbHMvcGFyc2VTYW1wbGVSYXRlLmpzJyk7XG5jb25zdCBzZGtNZXRhZGF0YSA9IHJlcXVpcmUoJy4vdXRpbHMvc2RrTWV0YWRhdGEuanMnKTtcbmNvbnN0IHRyYWNlRGF0YSA9IHJlcXVpcmUoJy4vdXRpbHMvdHJhY2VEYXRhLmpzJyk7XG5jb25zdCBtZXRhID0gcmVxdWlyZSgnLi91dGlscy9tZXRhLmpzJyk7XG5jb25zdCBkZWJvdW5jZSA9IHJlcXVpcmUoJy4vdXRpbHMvZGVib3VuY2UuanMnKTtcbmNvbnN0IHJlcXVlc3QgPSByZXF1aXJlKCcuL3V0aWxzL3JlcXVlc3QuanMnKTtcbmNvbnN0IGNvbnN0YW50cyA9IHJlcXVpcmUoJy4vY29uc3RhbnRzLmpzJyk7XG5jb25zdCBicmVhZGNydW1icyA9IHJlcXVpcmUoJy4vYnJlYWRjcnVtYnMuanMnKTtcbmNvbnN0IGZ1bmN0aW9udG9zdHJpbmcgPSByZXF1aXJlKCcuL2ludGVncmF0aW9ucy9mdW5jdGlvbnRvc3RyaW5nLmpzJyk7XG5jb25zdCBldmVudEZpbHRlcnMgPSByZXF1aXJlKCcuL2ludGVncmF0aW9ucy9ldmVudEZpbHRlcnMuanMnKTtcbmNvbnN0IGxpbmtlZGVycm9ycyA9IHJlcXVpcmUoJy4vaW50ZWdyYXRpb25zL2xpbmtlZGVycm9ycy5qcycpO1xuY29uc3QgbWV0YWRhdGEgPSByZXF1aXJlKCcuL2ludGVncmF0aW9ucy9tZXRhZGF0YS5qcycpO1xuY29uc3QgcmVxdWVzdGRhdGEgPSByZXF1aXJlKCcuL2ludGVncmF0aW9ucy9yZXF1ZXN0ZGF0YS5qcycpO1xuY29uc3QgY2FwdHVyZWNvbnNvbGUgPSByZXF1aXJlKCcuL2ludGVncmF0aW9ucy9jYXB0dXJlY29uc29sZS5qcycpO1xuY29uc3QgZGVkdXBlID0gcmVxdWlyZSgnLi9pbnRlZ3JhdGlvbnMvZGVkdXBlLmpzJyk7XG5jb25zdCBleHRyYWVycm9yZGF0YSA9IHJlcXVpcmUoJy4vaW50ZWdyYXRpb25zL2V4dHJhZXJyb3JkYXRhLmpzJyk7XG5jb25zdCByZXdyaXRlZnJhbWVzID0gcmVxdWlyZSgnLi9pbnRlZ3JhdGlvbnMvcmV3cml0ZWZyYW1lcy5qcycpO1xuY29uc3Qgc3VwYWJhc2UgPSByZXF1aXJlKCcuL2ludGVncmF0aW9ucy9zdXBhYmFzZS5qcycpO1xuY29uc3Qgem9kZXJyb3JzID0gcmVxdWlyZSgnLi9pbnRlZ3JhdGlvbnMvem9kZXJyb3JzLmpzJyk7XG5jb25zdCB0aGlyZFBhcnR5RXJyb3JzRmlsdGVyID0gcmVxdWlyZSgnLi9pbnRlZ3JhdGlvbnMvdGhpcmQtcGFydHktZXJyb3JzLWZpbHRlci5qcycpO1xuY29uc3QgY29uc29sZSA9IHJlcXVpcmUoJy4vaW50ZWdyYXRpb25zL2NvbnNvbGUuanMnKTtcbmNvbnN0IGZlYXR1cmVGbGFnc0ludGVncmF0aW9uID0gcmVxdWlyZSgnLi9pbnRlZ3JhdGlvbnMvZmVhdHVyZUZsYWdzL2ZlYXR1cmVGbGFnc0ludGVncmF0aW9uLmpzJyk7XG5jb25zdCBwcm9maWxpbmcgPSByZXF1aXJlKCcuL3Byb2ZpbGluZy5qcycpO1xuY29uc3QgZmV0Y2ggPSByZXF1aXJlKCcuL2ZldGNoLmpzJyk7XG5jb25zdCB0cnBjID0gcmVxdWlyZSgnLi90cnBjLmpzJyk7XG5jb25zdCBpbmRleCQxID0gcmVxdWlyZSgnLi9pbnRlZ3JhdGlvbnMvbWNwLXNlcnZlci9pbmRleC5qcycpO1xuY29uc3QgZmVlZGJhY2sgPSByZXF1aXJlKCcuL2ZlZWRiYWNrLmpzJyk7XG5jb25zdCBleHBvcnRzJDIgPSByZXF1aXJlKCcuL2xvZ3MvZXhwb3J0cy5qcycpO1xuY29uc3QgY29uc29sZUludGVncmF0aW9uID0gcmVxdWlyZSgnLi9sb2dzL2NvbnNvbGUtaW50ZWdyYXRpb24uanMnKTtcbmNvbnN0IHZlcmNlbEFpID0gcmVxdWlyZSgnLi91dGlscy92ZXJjZWwtYWkuanMnKTtcbmNvbnN0IGluZGV4JDIgPSByZXF1aXJlKCcuL3V0aWxzL29wZW5haS9pbmRleC5qcycpO1xuY29uc3QgY29uc3RhbnRzJDEgPSByZXF1aXJlKCcuL3V0aWxzL29wZW5haS9jb25zdGFudHMuanMnKTtcbmNvbnN0IGZlYXR1cmVGbGFncyA9IHJlcXVpcmUoJy4vdXRpbHMvZmVhdHVyZUZsYWdzLmpzJyk7XG5jb25zdCBhZ2dyZWdhdGVFcnJvcnMgPSByZXF1aXJlKCcuL3V0aWxzL2FnZ3JlZ2F0ZS1lcnJvcnMuanMnKTtcbmNvbnN0IGJyZWFkY3J1bWJMb2dMZXZlbCA9IHJlcXVpcmUoJy4vdXRpbHMvYnJlYWRjcnVtYi1sb2ctbGV2ZWwuanMnKTtcbmNvbnN0IGJyb3dzZXIgPSByZXF1aXJlKCcuL3V0aWxzL2Jyb3dzZXIuanMnKTtcbmNvbnN0IGRzbiA9IHJlcXVpcmUoJy4vdXRpbHMvZHNuLmpzJyk7XG5jb25zdCBlcnJvciA9IHJlcXVpcmUoJy4vdXRpbHMvZXJyb3IuanMnKTtcbmNvbnN0IHdvcmxkd2lkZSA9IHJlcXVpcmUoJy4vdXRpbHMvd29ybGR3aWRlLmpzJyk7XG5jb25zdCBjb25zb2xlJDEgPSByZXF1aXJlKCcuL2luc3RydW1lbnQvY29uc29sZS5qcycpO1xuY29uc3QgZmV0Y2gkMSA9IHJlcXVpcmUoJy4vaW5zdHJ1bWVudC9mZXRjaC5qcycpO1xuY29uc3QgZ2xvYmFsRXJyb3IgPSByZXF1aXJlKCcuL2luc3RydW1lbnQvZ2xvYmFsRXJyb3IuanMnKTtcbmNvbnN0IGdsb2JhbFVuaGFuZGxlZFJlamVjdGlvbiA9IHJlcXVpcmUoJy4vaW5zdHJ1bWVudC9nbG9iYWxVbmhhbmRsZWRSZWplY3Rpb24uanMnKTtcbmNvbnN0IGhhbmRsZXJzID0gcmVxdWlyZSgnLi9pbnN0cnVtZW50L2hhbmRsZXJzLmpzJyk7XG5jb25zdCBpcyA9IHJlcXVpcmUoJy4vdXRpbHMvaXMuanMnKTtcbmNvbnN0IGlzQnJvd3NlciA9IHJlcXVpcmUoJy4vdXRpbHMvaXNCcm93c2VyLmpzJyk7XG5jb25zdCBkZWJ1Z0xvZ2dlciA9IHJlcXVpcmUoJy4vdXRpbHMvZGVidWctbG9nZ2VyLmpzJyk7XG5jb25zdCBtaXNjID0gcmVxdWlyZSgnLi91dGlscy9taXNjLmpzJyk7XG5jb25zdCBub2RlID0gcmVxdWlyZSgnLi91dGlscy9ub2RlLmpzJyk7XG5jb25zdCBub3JtYWxpemUgPSByZXF1aXJlKCcuL3V0aWxzL25vcm1hbGl6ZS5qcycpO1xuY29uc3Qgb2JqZWN0ID0gcmVxdWlyZSgnLi91dGlscy9vYmplY3QuanMnKTtcbmNvbnN0IHBhdGggPSByZXF1aXJlKCcuL3V0aWxzL3BhdGguanMnKTtcbmNvbnN0IHByb21pc2VidWZmZXIgPSByZXF1aXJlKCcuL3V0aWxzL3Byb21pc2VidWZmZXIuanMnKTtcbmNvbnN0IHNldmVyaXR5ID0gcmVxdWlyZSgnLi91dGlscy9zZXZlcml0eS5qcycpO1xuY29uc3Qgc3RhY2t0cmFjZSA9IHJlcXVpcmUoJy4vdXRpbHMvc3RhY2t0cmFjZS5qcycpO1xuY29uc3Qgbm9kZVN0YWNrVHJhY2UgPSByZXF1aXJlKCcuL3V0aWxzL25vZGUtc3RhY2stdHJhY2UuanMnKTtcbmNvbnN0IHN0cmluZyA9IHJlcXVpcmUoJy4vdXRpbHMvc3RyaW5nLmpzJyk7XG5jb25zdCBzdXBwb3J0cyA9IHJlcXVpcmUoJy4vdXRpbHMvc3VwcG9ydHMuanMnKTtcbmNvbnN0IHN5bmNwcm9taXNlID0gcmVxdWlyZSgnLi91dGlscy9zeW5jcHJvbWlzZS5qcycpO1xuY29uc3QgdGltZSA9IHJlcXVpcmUoJy4vdXRpbHMvdGltZS5qcycpO1xuY29uc3QgdHJhY2luZyA9IHJlcXVpcmUoJy4vdXRpbHMvdHJhY2luZy5qcycpO1xuY29uc3QgZW52ID0gcmVxdWlyZSgnLi91dGlscy9lbnYuanMnKTtcbmNvbnN0IGVudmVsb3BlJDEgPSByZXF1aXJlKCcuL3V0aWxzL2VudmVsb3BlLmpzJyk7XG5jb25zdCBjbGllbnRyZXBvcnQgPSByZXF1aXJlKCcuL3V0aWxzL2NsaWVudHJlcG9ydC5qcycpO1xuY29uc3QgcmF0ZWxpbWl0ID0gcmVxdWlyZSgnLi91dGlscy9yYXRlbGltaXQuanMnKTtcbmNvbnN0IGJhZ2dhZ2UgPSByZXF1aXJlKCcuL3V0aWxzL2JhZ2dhZ2UuanMnKTtcbmNvbnN0IHVybCA9IHJlcXVpcmUoJy4vdXRpbHMvdXJsLmpzJyk7XG5jb25zdCBldmVudGJ1aWxkZXIgPSByZXF1aXJlKCcuL3V0aWxzL2V2ZW50YnVpbGRlci5qcycpO1xuY29uc3QgYW5yID0gcmVxdWlyZSgnLi91dGlscy9hbnIuanMnKTtcbmNvbnN0IGxydSA9IHJlcXVpcmUoJy4vdXRpbHMvbHJ1LmpzJyk7XG5jb25zdCBwcm9wYWdhdGlvbkNvbnRleHQgPSByZXF1aXJlKCcuL3V0aWxzL3Byb3BhZ2F0aW9uQ29udGV4dC5qcycpO1xuY29uc3QgdmVyY2VsV2FpdFVudGlsID0gcmVxdWlyZSgnLi91dGlscy92ZXJjZWxXYWl0VW50aWwuanMnKTtcbmNvbnN0IGZsdXNoSWZTZXJ2ZXJsZXNzID0gcmVxdWlyZSgnLi91dGlscy9mbHVzaElmU2VydmVybGVzcy5qcycpO1xuY29uc3QgdmVyc2lvbiA9IHJlcXVpcmUoJy4vdXRpbHMvdmVyc2lvbi5qcycpO1xuY29uc3QgZGVidWdJZHMgPSByZXF1aXJlKCcuL3V0aWxzL2RlYnVnLWlkcy5qcycpO1xuY29uc3QgZXNjYXBlU3RyaW5nRm9yUmVnZXggPSByZXF1aXJlKCcuL3ZlbmRvci9lc2NhcGVTdHJpbmdGb3JSZWdleC5qcycpO1xuXG5cblxuZXhwb3J0cy5yZWdpc3RlclNwYW5FcnJvckluc3RydW1lbnRhdGlvbiA9IGVycm9ycy5yZWdpc3RlclNwYW5FcnJvckluc3RydW1lbnRhdGlvbjtcbmV4cG9ydHMuZ2V0Q2FwdHVyZWRTY29wZXNPblNwYW4gPSB1dGlscy5nZXRDYXB0dXJlZFNjb3Blc09uU3BhbjtcbmV4cG9ydHMuc2V0Q2FwdHVyZWRTY29wZXNPblNwYW4gPSB1dGlscy5zZXRDYXB0dXJlZFNjb3Blc09uU3BhbjtcbmV4cG9ydHMuVFJBQ0lOR19ERUZBVUxUUyA9IGlkbGVTcGFuLlRSQUNJTkdfREVGQVVMVFM7XG5leHBvcnRzLnN0YXJ0SWRsZVNwYW4gPSBpZGxlU3Bhbi5zdGFydElkbGVTcGFuO1xuZXhwb3J0cy5TZW50cnlTcGFuID0gc2VudHJ5U3Bhbi5TZW50cnlTcGFuO1xuZXhwb3J0cy5TZW50cnlOb25SZWNvcmRpbmdTcGFuID0gc2VudHJ5Tm9uUmVjb3JkaW5nU3Bhbi5TZW50cnlOb25SZWNvcmRpbmdTcGFuO1xuZXhwb3J0cy5TUEFOX1NUQVRVU19FUlJPUiA9IHNwYW5zdGF0dXMuU1BBTl9TVEFUVVNfRVJST1I7XG5leHBvcnRzLlNQQU5fU1RBVFVTX09LID0gc3BhbnN0YXR1cy5TUEFOX1NUQVRVU19PSztcbmV4cG9ydHMuU1BBTl9TVEFUVVNfVU5TRVQgPSBzcGFuc3RhdHVzLlNQQU5fU1RBVFVTX1VOU0VUO1xuZXhwb3J0cy5nZXRTcGFuU3RhdHVzRnJvbUh0dHBDb2RlID0gc3BhbnN0YXR1cy5nZXRTcGFuU3RhdHVzRnJvbUh0dHBDb2RlO1xuZXhwb3J0cy5zZXRIdHRwU3RhdHVzID0gc3BhbnN0YXR1cy5zZXRIdHRwU3RhdHVzO1xuZXhwb3J0cy5jb250aW51ZVRyYWNlID0gdHJhY2UuY29udGludWVUcmFjZTtcbmV4cG9ydHMuc3RhcnRJbmFjdGl2ZVNwYW4gPSB0cmFjZS5zdGFydEluYWN0aXZlU3BhbjtcbmV4cG9ydHMuc3RhcnROZXdUcmFjZSA9IHRyYWNlLnN0YXJ0TmV3VHJhY2U7XG5leHBvcnRzLnN0YXJ0U3BhbiA9IHRyYWNlLnN0YXJ0U3BhbjtcbmV4cG9ydHMuc3RhcnRTcGFuTWFudWFsID0gdHJhY2Uuc3RhcnRTcGFuTWFudWFsO1xuZXhwb3J0cy5zdXBwcmVzc1RyYWNpbmcgPSB0cmFjZS5zdXBwcmVzc1RyYWNpbmc7XG5leHBvcnRzLndpdGhBY3RpdmVTcGFuID0gdHJhY2Uud2l0aEFjdGl2ZVNwYW47XG5leHBvcnRzLmdldER5bmFtaWNTYW1wbGluZ0NvbnRleHRGcm9tQ2xpZW50ID0gZHluYW1pY1NhbXBsaW5nQ29udGV4dC5nZXREeW5hbWljU2FtcGxpbmdDb250ZXh0RnJvbUNsaWVudDtcbmV4cG9ydHMuZ2V0RHluYW1pY1NhbXBsaW5nQ29udGV4dEZyb21TY29wZSA9IGR5bmFtaWNTYW1wbGluZ0NvbnRleHQuZ2V0RHluYW1pY1NhbXBsaW5nQ29udGV4dEZyb21TY29wZTtcbmV4cG9ydHMuZ2V0RHluYW1pY1NhbXBsaW5nQ29udGV4dEZyb21TcGFuID0gZHluYW1pY1NhbXBsaW5nQ29udGV4dC5nZXREeW5hbWljU2FtcGxpbmdDb250ZXh0RnJvbVNwYW47XG5leHBvcnRzLnNwYW5Ub0JhZ2dhZ2VIZWFkZXIgPSBkeW5hbWljU2FtcGxpbmdDb250ZXh0LnNwYW5Ub0JhZ2dhZ2VIZWFkZXI7XG5leHBvcnRzLnNldE1lYXN1cmVtZW50ID0gbWVhc3VyZW1lbnQuc2V0TWVhc3VyZW1lbnQ7XG5leHBvcnRzLnRpbWVkRXZlbnRzVG9NZWFzdXJlbWVudHMgPSBtZWFzdXJlbWVudC50aW1lZEV2ZW50c1RvTWVhc3VyZW1lbnRzO1xuZXhwb3J0cy5zYW1wbGVTcGFuID0gc2FtcGxpbmcuc2FtcGxlU3BhbjtcbmV4cG9ydHMubG9nU3BhbkVuZCA9IGxvZ1NwYW5zLmxvZ1NwYW5FbmQ7XG5leHBvcnRzLmxvZ1NwYW5TdGFydCA9IGxvZ1NwYW5zLmxvZ1NwYW5TdGFydDtcbmV4cG9ydHMuU0VNQU5USUNfQVRUUklCVVRFX0NBQ0hFX0hJVCA9IHNlbWFudGljQXR0cmlidXRlcy5TRU1BTlRJQ19BVFRSSUJVVEVfQ0FDSEVfSElUO1xuZXhwb3J0cy5TRU1BTlRJQ19BVFRSSUJVVEVfQ0FDSEVfSVRFTV9TSVpFID0gc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9DQUNIRV9JVEVNX1NJWkU7XG5leHBvcnRzLlNFTUFOVElDX0FUVFJJQlVURV9DQUNIRV9LRVkgPSBzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX0NBQ0hFX0tFWTtcbmV4cG9ydHMuU0VNQU5USUNfQVRUUklCVVRFX0VYQ0xVU0lWRV9USU1FID0gc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9FWENMVVNJVkVfVElNRTtcbmV4cG9ydHMuU0VNQU5USUNfQVRUUklCVVRFX0hUVFBfUkVRVUVTVF9NRVRIT0QgPSBzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX0hUVFBfUkVRVUVTVF9NRVRIT0Q7XG5leHBvcnRzLlNFTUFOVElDX0FUVFJJQlVURV9QUk9GSUxFX0lEID0gc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9QUk9GSUxFX0lEO1xuZXhwb3J0cy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX0NVU1RPTV9TUEFOX05BTUUgPSBzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9DVVNUT01fU1BBTl9OQU1FO1xuZXhwb3J0cy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX0lETEVfU1BBTl9GSU5JU0hfUkVBU09OID0gc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfSURMRV9TUEFOX0ZJTklTSF9SRUFTT047XG5leHBvcnRzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfTUVBU1VSRU1FTlRfVU5JVCA9IHNlbWFudGljQXR0cmlidXRlcy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX01FQVNVUkVNRU5UX1VOSVQ7XG5leHBvcnRzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfTUVBU1VSRU1FTlRfVkFMVUUgPSBzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9NRUFTVVJFTUVOVF9WQUxVRTtcbmV4cG9ydHMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9PUCA9IHNlbWFudGljQXR0cmlidXRlcy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX09QO1xuZXhwb3J0cy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX09SSUdJTiA9IHNlbWFudGljQXR0cmlidXRlcy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX09SSUdJTjtcbmV4cG9ydHMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9QUkVWSU9VU19UUkFDRV9TQU1QTEVfUkFURSA9IHNlbWFudGljQXR0cmlidXRlcy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX1BSRVZJT1VTX1RSQUNFX1NBTVBMRV9SQVRFO1xuZXhwb3J0cy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX1NBTVBMRV9SQVRFID0gc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfU0FNUExFX1JBVEU7XG5leHBvcnRzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfU09VUkNFID0gc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfU09VUkNFO1xuZXhwb3J0cy5TRU1BTlRJQ19BVFRSSUJVVEVfVVJMX0ZVTEwgPSBzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX1VSTF9GVUxMO1xuZXhwb3J0cy5TRU1BTlRJQ19MSU5LX0FUVFJJQlVURV9MSU5LX1RZUEUgPSBzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfTElOS19BVFRSSUJVVEVfTElOS19UWVBFO1xuZXhwb3J0cy5jcmVhdGVFdmVudEVudmVsb3BlID0gZW52ZWxvcGUuY3JlYXRlRXZlbnRFbnZlbG9wZTtcbmV4cG9ydHMuY3JlYXRlU2Vzc2lvbkVudmVsb3BlID0gZW52ZWxvcGUuY3JlYXRlU2Vzc2lvbkVudmVsb3BlO1xuZXhwb3J0cy5jcmVhdGVTcGFuRW52ZWxvcGUgPSBlbnZlbG9wZS5jcmVhdGVTcGFuRW52ZWxvcGU7XG5leHBvcnRzLmFkZEV2ZW50UHJvY2Vzc29yID0gZXhwb3J0cyQxLmFkZEV2ZW50UHJvY2Vzc29yO1xuZXhwb3J0cy5jYXB0dXJlQ2hlY2tJbiA9IGV4cG9ydHMkMS5jYXB0dXJlQ2hlY2tJbjtcbmV4cG9ydHMuY2FwdHVyZUV2ZW50ID0gZXhwb3J0cyQxLmNhcHR1cmVFdmVudDtcbmV4cG9ydHMuY2FwdHVyZUV4Y2VwdGlvbiA9IGV4cG9ydHMkMS5jYXB0dXJlRXhjZXB0aW9uO1xuZXhwb3J0cy5jYXB0dXJlTWVzc2FnZSA9IGV4cG9ydHMkMS5jYXB0dXJlTWVzc2FnZTtcbmV4cG9ydHMuY2FwdHVyZVNlc3Npb24gPSBleHBvcnRzJDEuY2FwdHVyZVNlc3Npb247XG5leHBvcnRzLmNsb3NlID0gZXhwb3J0cyQxLmNsb3NlO1xuZXhwb3J0cy5lbmRTZXNzaW9uID0gZXhwb3J0cyQxLmVuZFNlc3Npb247XG5leHBvcnRzLmZsdXNoID0gZXhwb3J0cyQxLmZsdXNoO1xuZXhwb3J0cy5pc0VuYWJsZWQgPSBleHBvcnRzJDEuaXNFbmFibGVkO1xuZXhwb3J0cy5pc0luaXRpYWxpemVkID0gZXhwb3J0cyQxLmlzSW5pdGlhbGl6ZWQ7XG5leHBvcnRzLmxhc3RFdmVudElkID0gZXhwb3J0cyQxLmxhc3RFdmVudElkO1xuZXhwb3J0cy5zZXRDb250ZXh0ID0gZXhwb3J0cyQxLnNldENvbnRleHQ7XG5leHBvcnRzLnNldEV4dHJhID0gZXhwb3J0cyQxLnNldEV4dHJhO1xuZXhwb3J0cy5zZXRFeHRyYXMgPSBleHBvcnRzJDEuc2V0RXh0cmFzO1xuZXhwb3J0cy5zZXRUYWcgPSBleHBvcnRzJDEuc2V0VGFnO1xuZXhwb3J0cy5zZXRUYWdzID0gZXhwb3J0cyQxLnNldFRhZ3M7XG5leHBvcnRzLnNldFVzZXIgPSBleHBvcnRzJDEuc2V0VXNlcjtcbmV4cG9ydHMuc3RhcnRTZXNzaW9uID0gZXhwb3J0cyQxLnN0YXJ0U2Vzc2lvbjtcbmV4cG9ydHMud2l0aE1vbml0b3IgPSBleHBvcnRzJDEud2l0aE1vbml0b3I7XG5leHBvcnRzLmdldENsaWVudCA9IGN1cnJlbnRTY29wZXMuZ2V0Q2xpZW50O1xuZXhwb3J0cy5nZXRDdXJyZW50U2NvcGUgPSBjdXJyZW50U2NvcGVzLmdldEN1cnJlbnRTY29wZTtcbmV4cG9ydHMuZ2V0R2xvYmFsU2NvcGUgPSBjdXJyZW50U2NvcGVzLmdldEdsb2JhbFNjb3BlO1xuZXhwb3J0cy5nZXRJc29sYXRpb25TY29wZSA9IGN1cnJlbnRTY29wZXMuZ2V0SXNvbGF0aW9uU2NvcGU7XG5leHBvcnRzLmdldFRyYWNlQ29udGV4dEZyb21TY29wZSA9IGN1cnJlbnRTY29wZXMuZ2V0VHJhY2VDb250ZXh0RnJvbVNjb3BlO1xuZXhwb3J0cy53aXRoSXNvbGF0aW9uU2NvcGUgPSBjdXJyZW50U2NvcGVzLndpdGhJc29sYXRpb25TY29wZTtcbmV4cG9ydHMud2l0aFNjb3BlID0gY3VycmVudFNjb3Blcy53aXRoU2NvcGU7XG5leHBvcnRzLmdldERlZmF1bHRDdXJyZW50U2NvcGUgPSBkZWZhdWx0U2NvcGVzLmdldERlZmF1bHRDdXJyZW50U2NvcGU7XG5leHBvcnRzLmdldERlZmF1bHRJc29sYXRpb25TY29wZSA9IGRlZmF1bHRTY29wZXMuZ2V0RGVmYXVsdElzb2xhdGlvblNjb3BlO1xuZXhwb3J0cy5zZXRBc3luY0NvbnRleHRTdHJhdGVneSA9IGluZGV4LnNldEFzeW5jQ29udGV4dFN0cmF0ZWd5O1xuZXhwb3J0cy5nZXRHbG9iYWxTaW5nbGV0b24gPSBjYXJyaWVyLmdldEdsb2JhbFNpbmdsZXRvbjtcbmV4cG9ydHMuZ2V0TWFpbkNhcnJpZXIgPSBjYXJyaWVyLmdldE1haW5DYXJyaWVyO1xuZXhwb3J0cy5jbG9zZVNlc3Npb24gPSBzZXNzaW9uLmNsb3NlU2Vzc2lvbjtcbmV4cG9ydHMubWFrZVNlc3Npb24gPSBzZXNzaW9uLm1ha2VTZXNzaW9uO1xuZXhwb3J0cy51cGRhdGVTZXNzaW9uID0gc2Vzc2lvbi51cGRhdGVTZXNzaW9uO1xuZXhwb3J0cy5TY29wZSA9IHNjb3BlLlNjb3BlO1xuZXhwb3J0cy5ub3RpZnlFdmVudFByb2Nlc3NvcnMgPSBldmVudFByb2Nlc3NvcnMubm90aWZ5RXZlbnRQcm9jZXNzb3JzO1xuZXhwb3J0cy5nZXRFbnZlbG9wZUVuZHBvaW50V2l0aFVybEVuY29kZWRBdXRoID0gYXBpLmdldEVudmVsb3BlRW5kcG9pbnRXaXRoVXJsRW5jb2RlZEF1dGg7XG5leHBvcnRzLmdldFJlcG9ydERpYWxvZ0VuZHBvaW50ID0gYXBpLmdldFJlcG9ydERpYWxvZ0VuZHBvaW50O1xuZXhwb3J0cy5CYXNlQ2xpZW50ID0gY2xpZW50LkJhc2VDbGllbnQ7XG5leHBvcnRzLkNsaWVudCA9IGNsaWVudC5DbGllbnQ7XG5leHBvcnRzLlNlcnZlclJ1bnRpbWVDbGllbnQgPSBzZXJ2ZXJSdW50aW1lQ2xpZW50LlNlcnZlclJ1bnRpbWVDbGllbnQ7XG5leHBvcnRzLmluaXRBbmRCaW5kID0gc2RrLmluaXRBbmRCaW5kO1xuZXhwb3J0cy5zZXRDdXJyZW50Q2xpZW50ID0gc2RrLnNldEN1cnJlbnRDbGllbnQ7XG5leHBvcnRzLmNyZWF0ZVRyYW5zcG9ydCA9IGJhc2UuY3JlYXRlVHJhbnNwb3J0O1xuZXhwb3J0cy5tYWtlT2ZmbGluZVRyYW5zcG9ydCA9IG9mZmxpbmUubWFrZU9mZmxpbmVUcmFuc3BvcnQ7XG5leHBvcnRzLm1ha2VNdWx0aXBsZXhlZFRyYW5zcG9ydCA9IG11bHRpcGxleGVkLm1ha2VNdWx0aXBsZXhlZFRyYW5zcG9ydDtcbmV4cG9ydHMuYWRkSW50ZWdyYXRpb24gPSBpbnRlZ3JhdGlvbi5hZGRJbnRlZ3JhdGlvbjtcbmV4cG9ydHMuZGVmaW5lSW50ZWdyYXRpb24gPSBpbnRlZ3JhdGlvbi5kZWZpbmVJbnRlZ3JhdGlvbjtcbmV4cG9ydHMuZ2V0SW50ZWdyYXRpb25zVG9TZXR1cCA9IGludGVncmF0aW9uLmdldEludGVncmF0aW9uc1RvU2V0dXA7XG5leHBvcnRzLmFwcGx5U2NvcGVEYXRhVG9FdmVudCA9IGFwcGx5U2NvcGVEYXRhVG9FdmVudC5hcHBseVNjb3BlRGF0YVRvRXZlbnQ7XG5leHBvcnRzLm1lcmdlU2NvcGVEYXRhID0gYXBwbHlTY29wZURhdGFUb0V2ZW50Lm1lcmdlU2NvcGVEYXRhO1xuZXhwb3J0cy5wcmVwYXJlRXZlbnQgPSBwcmVwYXJlRXZlbnQucHJlcGFyZUV2ZW50O1xuZXhwb3J0cy5jcmVhdGVDaGVja0luRW52ZWxvcGUgPSBjaGVja2luLmNyZWF0ZUNoZWNrSW5FbnZlbG9wZTtcbmV4cG9ydHMuaGFzU3BhbnNFbmFibGVkID0gaGFzU3BhbnNFbmFibGVkLmhhc1NwYW5zRW5hYmxlZDtcbmV4cG9ydHMuaGFzVHJhY2luZ0VuYWJsZWQgPSBoYXNTcGFuc0VuYWJsZWQuaGFzVHJhY2luZ0VuYWJsZWQ7XG5leHBvcnRzLmlzU2VudHJ5UmVxdWVzdFVybCA9IGlzU2VudHJ5UmVxdWVzdFVybC5pc1NlbnRyeVJlcXVlc3RVcmw7XG5leHBvcnRzLmhhbmRsZUNhbGxiYWNrRXJyb3JzID0gaGFuZGxlQ2FsbGJhY2tFcnJvcnMuaGFuZGxlQ2FsbGJhY2tFcnJvcnM7XG5leHBvcnRzLmZtdCA9IHBhcmFtZXRlcml6ZS5mbXQ7XG5leHBvcnRzLnBhcmFtZXRlcml6ZSA9IHBhcmFtZXRlcml6ZS5wYXJhbWV0ZXJpemU7XG5leHBvcnRzLmFkZEF1dG9JcEFkZHJlc3NUb1Nlc3Npb24gPSBpcEFkZHJlc3MuYWRkQXV0b0lwQWRkcmVzc1RvU2Vzc2lvbjtcbmV4cG9ydHMuYWRkQXV0b0lwQWRkcmVzc1RvVXNlciA9IGlwQWRkcmVzcy5hZGRBdXRvSXBBZGRyZXNzVG9Vc2VyO1xuZXhwb3J0cy5hZGRDaGlsZFNwYW5Ub1NwYW4gPSBzcGFuVXRpbHMuYWRkQ2hpbGRTcGFuVG9TcGFuO1xuZXhwb3J0cy5jb252ZXJ0U3BhbkxpbmtzRm9yRW52ZWxvcGUgPSBzcGFuVXRpbHMuY29udmVydFNwYW5MaW5rc0ZvckVudmVsb3BlO1xuZXhwb3J0cy5nZXRBY3RpdmVTcGFuID0gc3BhblV0aWxzLmdldEFjdGl2ZVNwYW47XG5leHBvcnRzLmdldFJvb3RTcGFuID0gc3BhblV0aWxzLmdldFJvb3RTcGFuO1xuZXhwb3J0cy5nZXRTcGFuRGVzY2VuZGFudHMgPSBzcGFuVXRpbHMuZ2V0U3BhbkRlc2NlbmRhbnRzO1xuZXhwb3J0cy5nZXRTdGF0dXNNZXNzYWdlID0gc3BhblV0aWxzLmdldFN0YXR1c01lc3NhZ2U7XG5leHBvcnRzLnNwYW5Jc1NhbXBsZWQgPSBzcGFuVXRpbHMuc3BhbklzU2FtcGxlZDtcbmV4cG9ydHMuc3BhblRpbWVJbnB1dFRvU2Vjb25kcyA9IHNwYW5VdGlscy5zcGFuVGltZUlucHV0VG9TZWNvbmRzO1xuZXhwb3J0cy5zcGFuVG9KU09OID0gc3BhblV0aWxzLnNwYW5Ub0pTT047XG5leHBvcnRzLnNwYW5Ub1RyYWNlQ29udGV4dCA9IHNwYW5VdGlscy5zcGFuVG9UcmFjZUNvbnRleHQ7XG5leHBvcnRzLnNwYW5Ub1RyYWNlSGVhZGVyID0gc3BhblV0aWxzLnNwYW5Ub1RyYWNlSGVhZGVyO1xuZXhwb3J0cy51cGRhdGVTcGFuTmFtZSA9IHNwYW5VdGlscy51cGRhdGVTcGFuTmFtZTtcbmV4cG9ydHMucGFyc2VTYW1wbGVSYXRlID0gcGFyc2VTYW1wbGVSYXRlLnBhcnNlU2FtcGxlUmF0ZTtcbmV4cG9ydHMuYXBwbHlTZGtNZXRhZGF0YSA9IHNka01ldGFkYXRhLmFwcGx5U2RrTWV0YWRhdGE7XG5leHBvcnRzLmdldFRyYWNlRGF0YSA9IHRyYWNlRGF0YS5nZXRUcmFjZURhdGE7XG5leHBvcnRzLmdldFRyYWNlTWV0YVRhZ3MgPSBtZXRhLmdldFRyYWNlTWV0YVRhZ3M7XG5leHBvcnRzLmRlYm91bmNlID0gZGVib3VuY2UuZGVib3VuY2U7XG5leHBvcnRzLmV4dHJhY3RRdWVyeVBhcmFtc0Zyb21VcmwgPSByZXF1ZXN0LmV4dHJhY3RRdWVyeVBhcmFtc0Zyb21Vcmw7XG5leHBvcnRzLmhlYWRlcnNUb0RpY3QgPSByZXF1ZXN0LmhlYWRlcnNUb0RpY3Q7XG5leHBvcnRzLmh0dHBSZXF1ZXN0VG9SZXF1ZXN0RGF0YSA9IHJlcXVlc3QuaHR0cFJlcXVlc3RUb1JlcXVlc3REYXRhO1xuZXhwb3J0cy53aW50ZXJDR0hlYWRlcnNUb0RpY3QgPSByZXF1ZXN0LndpbnRlckNHSGVhZGVyc1RvRGljdDtcbmV4cG9ydHMud2ludGVyQ0dSZXF1ZXN0VG9SZXF1ZXN0RGF0YSA9IHJlcXVlc3Qud2ludGVyQ0dSZXF1ZXN0VG9SZXF1ZXN0RGF0YTtcbmV4cG9ydHMuREVGQVVMVF9FTlZJUk9OTUVOVCA9IGNvbnN0YW50cy5ERUZBVUxUX0VOVklST05NRU5UO1xuZXhwb3J0cy5hZGRCcmVhZGNydW1iID0gYnJlYWRjcnVtYnMuYWRkQnJlYWRjcnVtYjtcbmV4cG9ydHMuZnVuY3Rpb25Ub1N0cmluZ0ludGVncmF0aW9uID0gZnVuY3Rpb250b3N0cmluZy5mdW5jdGlvblRvU3RyaW5nSW50ZWdyYXRpb247XG5leHBvcnRzLmV2ZW50RmlsdGVyc0ludGVncmF0aW9uID0gZXZlbnRGaWx0ZXJzLmV2ZW50RmlsdGVyc0ludGVncmF0aW9uO1xuZXhwb3J0cy5pbmJvdW5kRmlsdGVyc0ludGVncmF0aW9uID0gZXZlbnRGaWx0ZXJzLmluYm91bmRGaWx0ZXJzSW50ZWdyYXRpb247XG5leHBvcnRzLmxpbmtlZEVycm9yc0ludGVncmF0aW9uID0gbGlua2VkZXJyb3JzLmxpbmtlZEVycm9yc0ludGVncmF0aW9uO1xuZXhwb3J0cy5tb2R1bGVNZXRhZGF0YUludGVncmF0aW9uID0gbWV0YWRhdGEubW9kdWxlTWV0YWRhdGFJbnRlZ3JhdGlvbjtcbmV4cG9ydHMucmVxdWVzdERhdGFJbnRlZ3JhdGlvbiA9IHJlcXVlc3RkYXRhLnJlcXVlc3REYXRhSW50ZWdyYXRpb247XG5leHBvcnRzLmNhcHR1cmVDb25zb2xlSW50ZWdyYXRpb24gPSBjYXB0dXJlY29uc29sZS5jYXB0dXJlQ29uc29sZUludGVncmF0aW9uO1xuZXhwb3J0cy5kZWR1cGVJbnRlZ3JhdGlvbiA9IGRlZHVwZS5kZWR1cGVJbnRlZ3JhdGlvbjtcbmV4cG9ydHMuZXh0cmFFcnJvckRhdGFJbnRlZ3JhdGlvbiA9IGV4dHJhZXJyb3JkYXRhLmV4dHJhRXJyb3JEYXRhSW50ZWdyYXRpb247XG5leHBvcnRzLnJld3JpdGVGcmFtZXNJbnRlZ3JhdGlvbiA9IHJld3JpdGVmcmFtZXMucmV3cml0ZUZyYW1lc0ludGVncmF0aW9uO1xuZXhwb3J0cy5pbnN0cnVtZW50U3VwYWJhc2VDbGllbnQgPSBzdXBhYmFzZS5pbnN0cnVtZW50U3VwYWJhc2VDbGllbnQ7XG5leHBvcnRzLnN1cGFiYXNlSW50ZWdyYXRpb24gPSBzdXBhYmFzZS5zdXBhYmFzZUludGVncmF0aW9uO1xuZXhwb3J0cy56b2RFcnJvcnNJbnRlZ3JhdGlvbiA9IHpvZGVycm9ycy56b2RFcnJvcnNJbnRlZ3JhdGlvbjtcbmV4cG9ydHMudGhpcmRQYXJ0eUVycm9yRmlsdGVySW50ZWdyYXRpb24gPSB0aGlyZFBhcnR5RXJyb3JzRmlsdGVyLnRoaXJkUGFydHlFcnJvckZpbHRlckludGVncmF0aW9uO1xuZXhwb3J0cy5jb25zb2xlSW50ZWdyYXRpb24gPSBjb25zb2xlLmNvbnNvbGVJbnRlZ3JhdGlvbjtcbmV4cG9ydHMuZmVhdHVyZUZsYWdzSW50ZWdyYXRpb24gPSBmZWF0dXJlRmxhZ3NJbnRlZ3JhdGlvbi5mZWF0dXJlRmxhZ3NJbnRlZ3JhdGlvbjtcbmV4cG9ydHMucHJvZmlsZXIgPSBwcm9maWxpbmcucHJvZmlsZXI7XG5leHBvcnRzLmluc3RydW1lbnRGZXRjaFJlcXVlc3QgPSBmZXRjaC5pbnN0cnVtZW50RmV0Y2hSZXF1ZXN0O1xuZXhwb3J0cy50cnBjTWlkZGxld2FyZSA9IHRycGMudHJwY01pZGRsZXdhcmU7XG5leHBvcnRzLndyYXBNY3BTZXJ2ZXJXaXRoU2VudHJ5ID0gaW5kZXgkMS53cmFwTWNwU2VydmVyV2l0aFNlbnRyeTtcbmV4cG9ydHMuY2FwdHVyZUZlZWRiYWNrID0gZmVlZGJhY2suY2FwdHVyZUZlZWRiYWNrO1xuZXhwb3J0cy5fSU5URVJOQUxfY2FwdHVyZUxvZyA9IGV4cG9ydHMkMi5fSU5URVJOQUxfY2FwdHVyZUxvZztcbmV4cG9ydHMuX0lOVEVSTkFMX2NhcHR1cmVTZXJpYWxpemVkTG9nID0gZXhwb3J0cyQyLl9JTlRFUk5BTF9jYXB0dXJlU2VyaWFsaXplZExvZztcbmV4cG9ydHMuX0lOVEVSTkFMX2ZsdXNoTG9nc0J1ZmZlciA9IGV4cG9ydHMkMi5fSU5URVJOQUxfZmx1c2hMb2dzQnVmZmVyO1xuZXhwb3J0cy5jb25zb2xlTG9nZ2luZ0ludGVncmF0aW9uID0gY29uc29sZUludGVncmF0aW9uLmNvbnNvbGVMb2dnaW5nSW50ZWdyYXRpb247XG5leHBvcnRzLmFkZFZlcmNlbEFpUHJvY2Vzc29ycyA9IHZlcmNlbEFpLmFkZFZlcmNlbEFpUHJvY2Vzc29ycztcbmV4cG9ydHMuaW5zdHJ1bWVudE9wZW5BaUNsaWVudCA9IGluZGV4JDIuaW5zdHJ1bWVudE9wZW5BaUNsaWVudDtcbmV4cG9ydHMuT1BFTkFJX0lOVEVHUkFUSU9OX05BTUUgPSBjb25zdGFudHMkMS5PUEVOQUlfSU5URUdSQVRJT05fTkFNRTtcbmV4cG9ydHMuX0lOVEVSTkFMX0ZMQUdfQlVGRkVSX1NJWkUgPSBmZWF0dXJlRmxhZ3MuX0lOVEVSTkFMX0ZMQUdfQlVGRkVSX1NJWkU7XG5leHBvcnRzLl9JTlRFUk5BTF9NQVhfRkxBR1NfUEVSX1NQQU4gPSBmZWF0dXJlRmxhZ3MuX0lOVEVSTkFMX01BWF9GTEFHU19QRVJfU1BBTjtcbmV4cG9ydHMuX0lOVEVSTkFMX2FkZEZlYXR1cmVGbGFnVG9BY3RpdmVTcGFuID0gZmVhdHVyZUZsYWdzLl9JTlRFUk5BTF9hZGRGZWF0dXJlRmxhZ1RvQWN0aXZlU3BhbjtcbmV4cG9ydHMuX0lOVEVSTkFMX2NvcHlGbGFnc0Zyb21TY29wZVRvRXZlbnQgPSBmZWF0dXJlRmxhZ3MuX0lOVEVSTkFMX2NvcHlGbGFnc0Zyb21TY29wZVRvRXZlbnQ7XG5leHBvcnRzLl9JTlRFUk5BTF9pbnNlcnRGbGFnVG9TY29wZSA9IGZlYXR1cmVGbGFncy5fSU5URVJOQUxfaW5zZXJ0RmxhZ1RvU2NvcGU7XG5leHBvcnRzLmFwcGx5QWdncmVnYXRlRXJyb3JzVG9FdmVudCA9IGFnZ3JlZ2F0ZUVycm9ycy5hcHBseUFnZ3JlZ2F0ZUVycm9yc1RvRXZlbnQ7XG5leHBvcnRzLmdldEJyZWFkY3J1bWJMb2dMZXZlbEZyb21IdHRwU3RhdHVzQ29kZSA9IGJyZWFkY3J1bWJMb2dMZXZlbC5nZXRCcmVhZGNydW1iTG9nTGV2ZWxGcm9tSHR0cFN0YXR1c0NvZGU7XG5leHBvcnRzLmdldENvbXBvbmVudE5hbWUgPSBicm93c2VyLmdldENvbXBvbmVudE5hbWU7XG5leHBvcnRzLmdldExvY2F0aW9uSHJlZiA9IGJyb3dzZXIuZ2V0TG9jYXRpb25IcmVmO1xuZXhwb3J0cy5odG1sVHJlZUFzU3RyaW5nID0gYnJvd3Nlci5odG1sVHJlZUFzU3RyaW5nO1xuZXhwb3J0cy5kc25Gcm9tU3RyaW5nID0gZHNuLmRzbkZyb21TdHJpbmc7XG5leHBvcnRzLmRzblRvU3RyaW5nID0gZHNuLmRzblRvU3RyaW5nO1xuZXhwb3J0cy5tYWtlRHNuID0gZHNuLm1ha2VEc247XG5leHBvcnRzLlNlbnRyeUVycm9yID0gZXJyb3IuU2VudHJ5RXJyb3I7XG5leHBvcnRzLkdMT0JBTF9PQkogPSB3b3JsZHdpZGUuR0xPQkFMX09CSjtcbmV4cG9ydHMuYWRkQ29uc29sZUluc3RydW1lbnRhdGlvbkhhbmRsZXIgPSBjb25zb2xlJDEuYWRkQ29uc29sZUluc3RydW1lbnRhdGlvbkhhbmRsZXI7XG5leHBvcnRzLmFkZEZldGNoRW5kSW5zdHJ1bWVudGF0aW9uSGFuZGxlciA9IGZldGNoJDEuYWRkRmV0Y2hFbmRJbnN0cnVtZW50YXRpb25IYW5kbGVyO1xuZXhwb3J0cy5hZGRGZXRjaEluc3RydW1lbnRhdGlvbkhhbmRsZXIgPSBmZXRjaCQxLmFkZEZldGNoSW5zdHJ1bWVudGF0aW9uSGFuZGxlcjtcbmV4cG9ydHMuYWRkR2xvYmFsRXJyb3JJbnN0cnVtZW50YXRpb25IYW5kbGVyID0gZ2xvYmFsRXJyb3IuYWRkR2xvYmFsRXJyb3JJbnN0cnVtZW50YXRpb25IYW5kbGVyO1xuZXhwb3J0cy5hZGRHbG9iYWxVbmhhbmRsZWRSZWplY3Rpb25JbnN0cnVtZW50YXRpb25IYW5kbGVyID0gZ2xvYmFsVW5oYW5kbGVkUmVqZWN0aW9uLmFkZEdsb2JhbFVuaGFuZGxlZFJlamVjdGlvbkluc3RydW1lbnRhdGlvbkhhbmRsZXI7XG5leHBvcnRzLmFkZEhhbmRsZXIgPSBoYW5kbGVycy5hZGRIYW5kbGVyO1xuZXhwb3J0cy5tYXliZUluc3RydW1lbnQgPSBoYW5kbGVycy5tYXliZUluc3RydW1lbnQ7XG5leHBvcnRzLnJlc2V0SW5zdHJ1bWVudGF0aW9uSGFuZGxlcnMgPSBoYW5kbGVycy5yZXNldEluc3RydW1lbnRhdGlvbkhhbmRsZXJzO1xuZXhwb3J0cy50cmlnZ2VySGFuZGxlcnMgPSBoYW5kbGVycy50cmlnZ2VySGFuZGxlcnM7XG5leHBvcnRzLmlzRE9NRXJyb3IgPSBpcy5pc0RPTUVycm9yO1xuZXhwb3J0cy5pc0RPTUV4Y2VwdGlvbiA9IGlzLmlzRE9NRXhjZXB0aW9uO1xuZXhwb3J0cy5pc0VsZW1lbnQgPSBpcy5pc0VsZW1lbnQ7XG5leHBvcnRzLmlzRXJyb3IgPSBpcy5pc0Vycm9yO1xuZXhwb3J0cy5pc0Vycm9yRXZlbnQgPSBpcy5pc0Vycm9yRXZlbnQ7XG5leHBvcnRzLmlzRXZlbnQgPSBpcy5pc0V2ZW50O1xuZXhwb3J0cy5pc0luc3RhbmNlT2YgPSBpcy5pc0luc3RhbmNlT2Y7XG5leHBvcnRzLmlzUGFyYW1ldGVyaXplZFN0cmluZyA9IGlzLmlzUGFyYW1ldGVyaXplZFN0cmluZztcbmV4cG9ydHMuaXNQbGFpbk9iamVjdCA9IGlzLmlzUGxhaW5PYmplY3Q7XG5leHBvcnRzLmlzUHJpbWl0aXZlID0gaXMuaXNQcmltaXRpdmU7XG5leHBvcnRzLmlzUmVnRXhwID0gaXMuaXNSZWdFeHA7XG5leHBvcnRzLmlzU3RyaW5nID0gaXMuaXNTdHJpbmc7XG5leHBvcnRzLmlzU3ludGhldGljRXZlbnQgPSBpcy5pc1N5bnRoZXRpY0V2ZW50O1xuZXhwb3J0cy5pc1RoZW5hYmxlID0gaXMuaXNUaGVuYWJsZTtcbmV4cG9ydHMuaXNWdWVWaWV3TW9kZWwgPSBpcy5pc1Z1ZVZpZXdNb2RlbDtcbmV4cG9ydHMuaXNCcm93c2VyID0gaXNCcm93c2VyLmlzQnJvd3NlcjtcbmV4cG9ydHMuQ09OU09MRV9MRVZFTFMgPSBkZWJ1Z0xvZ2dlci5DT05TT0xFX0xFVkVMUztcbmV4cG9ydHMuY29uc29sZVNhbmRib3ggPSBkZWJ1Z0xvZ2dlci5jb25zb2xlU2FuZGJveDtcbmV4cG9ydHMuZGVidWcgPSBkZWJ1Z0xvZ2dlci5kZWJ1ZztcbmV4cG9ydHMubG9nZ2VyID0gZGVidWdMb2dnZXIubG9nZ2VyO1xuZXhwb3J0cy5vcmlnaW5hbENvbnNvbGVNZXRob2RzID0gZGVidWdMb2dnZXIub3JpZ2luYWxDb25zb2xlTWV0aG9kcztcbmV4cG9ydHMuYWRkQ29udGV4dFRvRnJhbWUgPSBtaXNjLmFkZENvbnRleHRUb0ZyYW1lO1xuZXhwb3J0cy5hZGRFeGNlcHRpb25NZWNoYW5pc20gPSBtaXNjLmFkZEV4Y2VwdGlvbk1lY2hhbmlzbTtcbmV4cG9ydHMuYWRkRXhjZXB0aW9uVHlwZVZhbHVlID0gbWlzYy5hZGRFeGNlcHRpb25UeXBlVmFsdWU7XG5leHBvcnRzLmNoZWNrT3JTZXRBbHJlYWR5Q2F1Z2h0ID0gbWlzYy5jaGVja09yU2V0QWxyZWFkeUNhdWdodDtcbmV4cG9ydHMuZ2V0RXZlbnREZXNjcmlwdGlvbiA9IG1pc2MuZ2V0RXZlbnREZXNjcmlwdGlvbjtcbmV4cG9ydHMucGFyc2VTZW12ZXIgPSBtaXNjLnBhcnNlU2VtdmVyO1xuZXhwb3J0cy51dWlkNCA9IG1pc2MudXVpZDQ7XG5leHBvcnRzLmlzTm9kZUVudiA9IG5vZGUuaXNOb2RlRW52O1xuZXhwb3J0cy5sb2FkTW9kdWxlID0gbm9kZS5sb2FkTW9kdWxlO1xuZXhwb3J0cy5ub3JtYWxpemUgPSBub3JtYWxpemUubm9ybWFsaXplO1xuZXhwb3J0cy5ub3JtYWxpemVUb1NpemUgPSBub3JtYWxpemUubm9ybWFsaXplVG9TaXplO1xuZXhwb3J0cy5ub3JtYWxpemVVcmxUb0Jhc2UgPSBub3JtYWxpemUubm9ybWFsaXplVXJsVG9CYXNlO1xuZXhwb3J0cy5hZGROb25FbnVtZXJhYmxlUHJvcGVydHkgPSBvYmplY3QuYWRkTm9uRW51bWVyYWJsZVByb3BlcnR5O1xuZXhwb3J0cy5jb252ZXJ0VG9QbGFpbk9iamVjdCA9IG9iamVjdC5jb252ZXJ0VG9QbGFpbk9iamVjdDtcbmV4cG9ydHMuZHJvcFVuZGVmaW5lZEtleXMgPSBvYmplY3QuZHJvcFVuZGVmaW5lZEtleXM7XG5leHBvcnRzLmV4dHJhY3RFeGNlcHRpb25LZXlzRm9yTWVzc2FnZSA9IG9iamVjdC5leHRyYWN0RXhjZXB0aW9uS2V5c0Zvck1lc3NhZ2U7XG5leHBvcnRzLmZpbGwgPSBvYmplY3QuZmlsbDtcbmV4cG9ydHMuZ2V0T3JpZ2luYWxGdW5jdGlvbiA9IG9iamVjdC5nZXRPcmlnaW5hbEZ1bmN0aW9uO1xuZXhwb3J0cy5tYXJrRnVuY3Rpb25XcmFwcGVkID0gb2JqZWN0Lm1hcmtGdW5jdGlvbldyYXBwZWQ7XG5leHBvcnRzLm9iamVjdGlmeSA9IG9iamVjdC5vYmplY3RpZnk7XG5leHBvcnRzLmJhc2VuYW1lID0gcGF0aC5iYXNlbmFtZTtcbmV4cG9ydHMuZGlybmFtZSA9IHBhdGguZGlybmFtZTtcbmV4cG9ydHMuaXNBYnNvbHV0ZSA9IHBhdGguaXNBYnNvbHV0ZTtcbmV4cG9ydHMuam9pbiA9IHBhdGguam9pbjtcbmV4cG9ydHMubm9ybWFsaXplUGF0aCA9IHBhdGgubm9ybWFsaXplUGF0aDtcbmV4cG9ydHMucmVsYXRpdmUgPSBwYXRoLnJlbGF0aXZlO1xuZXhwb3J0cy5yZXNvbHZlID0gcGF0aC5yZXNvbHZlO1xuZXhwb3J0cy5TRU5UUllfQlVGRkVSX0ZVTExfRVJST1IgPSBwcm9taXNlYnVmZmVyLlNFTlRSWV9CVUZGRVJfRlVMTF9FUlJPUjtcbmV4cG9ydHMubWFrZVByb21pc2VCdWZmZXIgPSBwcm9taXNlYnVmZmVyLm1ha2VQcm9taXNlQnVmZmVyO1xuZXhwb3J0cy5zZXZlcml0eUxldmVsRnJvbVN0cmluZyA9IHNldmVyaXR5LnNldmVyaXR5TGV2ZWxGcm9tU3RyaW5nO1xuZXhwb3J0cy5VTktOT1dOX0ZVTkNUSU9OID0gc3RhY2t0cmFjZS5VTktOT1dOX0ZVTkNUSU9OO1xuZXhwb3J0cy5jcmVhdGVTdGFja1BhcnNlciA9IHN0YWNrdHJhY2UuY3JlYXRlU3RhY2tQYXJzZXI7XG5leHBvcnRzLmdldEZyYW1lc0Zyb21FdmVudCA9IHN0YWNrdHJhY2UuZ2V0RnJhbWVzRnJvbUV2ZW50O1xuZXhwb3J0cy5nZXRGdW5jdGlvbk5hbWUgPSBzdGFja3RyYWNlLmdldEZ1bmN0aW9uTmFtZTtcbmV4cG9ydHMuc3RhY2tQYXJzZXJGcm9tU3RhY2tQYXJzZXJPcHRpb25zID0gc3RhY2t0cmFjZS5zdGFja1BhcnNlckZyb21TdGFja1BhcnNlck9wdGlvbnM7XG5leHBvcnRzLnN0cmlwU2VudHJ5RnJhbWVzQW5kUmV2ZXJzZSA9IHN0YWNrdHJhY2Uuc3RyaXBTZW50cnlGcmFtZXNBbmRSZXZlcnNlO1xuZXhwb3J0cy5maWxlbmFtZUlzSW5BcHAgPSBub2RlU3RhY2tUcmFjZS5maWxlbmFtZUlzSW5BcHA7XG5leHBvcnRzLm5vZGUgPSBub2RlU3RhY2tUcmFjZS5ub2RlO1xuZXhwb3J0cy5ub2RlU3RhY2tMaW5lUGFyc2VyID0gbm9kZVN0YWNrVHJhY2Uubm9kZVN0YWNrTGluZVBhcnNlcjtcbmV4cG9ydHMuaXNNYXRjaGluZ1BhdHRlcm4gPSBzdHJpbmcuaXNNYXRjaGluZ1BhdHRlcm47XG5leHBvcnRzLnNhZmVKb2luID0gc3RyaW5nLnNhZmVKb2luO1xuZXhwb3J0cy5zbmlwTGluZSA9IHN0cmluZy5zbmlwTGluZTtcbmV4cG9ydHMuc3RyaW5nTWF0Y2hlc1NvbWVQYXR0ZXJuID0gc3RyaW5nLnN0cmluZ01hdGNoZXNTb21lUGF0dGVybjtcbmV4cG9ydHMudHJ1bmNhdGUgPSBzdHJpbmcudHJ1bmNhdGU7XG5leHBvcnRzLmlzTmF0aXZlRnVuY3Rpb24gPSBzdXBwb3J0cy5pc05hdGl2ZUZ1bmN0aW9uO1xuZXhwb3J0cy5zdXBwb3J0c0RPTUVycm9yID0gc3VwcG9ydHMuc3VwcG9ydHNET01FcnJvcjtcbmV4cG9ydHMuc3VwcG9ydHNET01FeGNlcHRpb24gPSBzdXBwb3J0cy5zdXBwb3J0c0RPTUV4Y2VwdGlvbjtcbmV4cG9ydHMuc3VwcG9ydHNFcnJvckV2ZW50ID0gc3VwcG9ydHMuc3VwcG9ydHNFcnJvckV2ZW50O1xuZXhwb3J0cy5zdXBwb3J0c0ZldGNoID0gc3VwcG9ydHMuc3VwcG9ydHNGZXRjaDtcbmV4cG9ydHMuc3VwcG9ydHNIaXN0b3J5ID0gc3VwcG9ydHMuc3VwcG9ydHNIaXN0b3J5O1xuZXhwb3J0cy5zdXBwb3J0c05hdGl2ZUZldGNoID0gc3VwcG9ydHMuc3VwcG9ydHNOYXRpdmVGZXRjaDtcbmV4cG9ydHMuc3VwcG9ydHNSZWZlcnJlclBvbGljeSA9IHN1cHBvcnRzLnN1cHBvcnRzUmVmZXJyZXJQb2xpY3k7XG5leHBvcnRzLnN1cHBvcnRzUmVwb3J0aW5nT2JzZXJ2ZXIgPSBzdXBwb3J0cy5zdXBwb3J0c1JlcG9ydGluZ09ic2VydmVyO1xuZXhwb3J0cy5TeW5jUHJvbWlzZSA9IHN5bmNwcm9taXNlLlN5bmNQcm9taXNlO1xuZXhwb3J0cy5yZWplY3RlZFN5bmNQcm9taXNlID0gc3luY3Byb21pc2UucmVqZWN0ZWRTeW5jUHJvbWlzZTtcbmV4cG9ydHMucmVzb2x2ZWRTeW5jUHJvbWlzZSA9IHN5bmNwcm9taXNlLnJlc29sdmVkU3luY1Byb21pc2U7XG5leHBvcnRzLmJyb3dzZXJQZXJmb3JtYW5jZVRpbWVPcmlnaW4gPSB0aW1lLmJyb3dzZXJQZXJmb3JtYW5jZVRpbWVPcmlnaW47XG5leHBvcnRzLmRhdGVUaW1lc3RhbXBJblNlY29uZHMgPSB0aW1lLmRhdGVUaW1lc3RhbXBJblNlY29uZHM7XG5leHBvcnRzLnRpbWVzdGFtcEluU2Vjb25kcyA9IHRpbWUudGltZXN0YW1wSW5TZWNvbmRzO1xuZXhwb3J0cy5UUkFDRVBBUkVOVF9SRUdFWFAgPSB0cmFjaW5nLlRSQUNFUEFSRU5UX1JFR0VYUDtcbmV4cG9ydHMuZXh0cmFjdFRyYWNlcGFyZW50RGF0YSA9IHRyYWNpbmcuZXh0cmFjdFRyYWNlcGFyZW50RGF0YTtcbmV4cG9ydHMuZ2VuZXJhdGVTZW50cnlUcmFjZUhlYWRlciA9IHRyYWNpbmcuZ2VuZXJhdGVTZW50cnlUcmFjZUhlYWRlcjtcbmV4cG9ydHMucHJvcGFnYXRpb25Db250ZXh0RnJvbUhlYWRlcnMgPSB0cmFjaW5nLnByb3BhZ2F0aW9uQ29udGV4dEZyb21IZWFkZXJzO1xuZXhwb3J0cy5nZXRTREtTb3VyY2UgPSBlbnYuZ2V0U0RLU291cmNlO1xuZXhwb3J0cy5pc0Jyb3dzZXJCdW5kbGUgPSBlbnYuaXNCcm93c2VyQnVuZGxlO1xuZXhwb3J0cy5hZGRJdGVtVG9FbnZlbG9wZSA9IGVudmVsb3BlJDEuYWRkSXRlbVRvRW52ZWxvcGU7XG5leHBvcnRzLmNyZWF0ZUF0dGFjaG1lbnRFbnZlbG9wZUl0ZW0gPSBlbnZlbG9wZSQxLmNyZWF0ZUF0dGFjaG1lbnRFbnZlbG9wZUl0ZW07XG5leHBvcnRzLmNyZWF0ZUVudmVsb3BlID0gZW52ZWxvcGUkMS5jcmVhdGVFbnZlbG9wZTtcbmV4cG9ydHMuY3JlYXRlRXZlbnRFbnZlbG9wZUhlYWRlcnMgPSBlbnZlbG9wZSQxLmNyZWF0ZUV2ZW50RW52ZWxvcGVIZWFkZXJzO1xuZXhwb3J0cy5jcmVhdGVTcGFuRW52ZWxvcGVJdGVtID0gZW52ZWxvcGUkMS5jcmVhdGVTcGFuRW52ZWxvcGVJdGVtO1xuZXhwb3J0cy5lbnZlbG9wZUNvbnRhaW5zSXRlbVR5cGUgPSBlbnZlbG9wZSQxLmVudmVsb3BlQ29udGFpbnNJdGVtVHlwZTtcbmV4cG9ydHMuZW52ZWxvcGVJdGVtVHlwZVRvRGF0YUNhdGVnb3J5ID0gZW52ZWxvcGUkMS5lbnZlbG9wZUl0ZW1UeXBlVG9EYXRhQ2F0ZWdvcnk7XG5leHBvcnRzLmZvckVhY2hFbnZlbG9wZUl0ZW0gPSBlbnZlbG9wZSQxLmZvckVhY2hFbnZlbG9wZUl0ZW07XG5leHBvcnRzLmdldFNka01ldGFkYXRhRm9yRW52ZWxvcGVIZWFkZXIgPSBlbnZlbG9wZSQxLmdldFNka01ldGFkYXRhRm9yRW52ZWxvcGVIZWFkZXI7XG5leHBvcnRzLnBhcnNlRW52ZWxvcGUgPSBlbnZlbG9wZSQxLnBhcnNlRW52ZWxvcGU7XG5leHBvcnRzLnNlcmlhbGl6ZUVudmVsb3BlID0gZW52ZWxvcGUkMS5zZXJpYWxpemVFbnZlbG9wZTtcbmV4cG9ydHMuY3JlYXRlQ2xpZW50UmVwb3J0RW52ZWxvcGUgPSBjbGllbnRyZXBvcnQuY3JlYXRlQ2xpZW50UmVwb3J0RW52ZWxvcGU7XG5leHBvcnRzLkRFRkFVTFRfUkVUUllfQUZURVIgPSByYXRlbGltaXQuREVGQVVMVF9SRVRSWV9BRlRFUjtcbmV4cG9ydHMuZGlzYWJsZWRVbnRpbCA9IHJhdGVsaW1pdC5kaXNhYmxlZFVudGlsO1xuZXhwb3J0cy5pc1JhdGVMaW1pdGVkID0gcmF0ZWxpbWl0LmlzUmF0ZUxpbWl0ZWQ7XG5leHBvcnRzLnBhcnNlUmV0cnlBZnRlckhlYWRlciA9IHJhdGVsaW1pdC5wYXJzZVJldHJ5QWZ0ZXJIZWFkZXI7XG5leHBvcnRzLnVwZGF0ZVJhdGVMaW1pdHMgPSByYXRlbGltaXQudXBkYXRlUmF0ZUxpbWl0cztcbmV4cG9ydHMuTUFYX0JBR0dBR0VfU1RSSU5HX0xFTkdUSCA9IGJhZ2dhZ2UuTUFYX0JBR0dBR0VfU1RSSU5HX0xFTkdUSDtcbmV4cG9ydHMuU0VOVFJZX0JBR0dBR0VfS0VZX1BSRUZJWCA9IGJhZ2dhZ2UuU0VOVFJZX0JBR0dBR0VfS0VZX1BSRUZJWDtcbmV4cG9ydHMuU0VOVFJZX0JBR0dBR0VfS0VZX1BSRUZJWF9SRUdFWCA9IGJhZ2dhZ2UuU0VOVFJZX0JBR0dBR0VfS0VZX1BSRUZJWF9SRUdFWDtcbmV4cG9ydHMuYmFnZ2FnZUhlYWRlclRvRHluYW1pY1NhbXBsaW5nQ29udGV4dCA9IGJhZ2dhZ2UuYmFnZ2FnZUhlYWRlclRvRHluYW1pY1NhbXBsaW5nQ29udGV4dDtcbmV4cG9ydHMuZHluYW1pY1NhbXBsaW5nQ29udGV4dFRvU2VudHJ5QmFnZ2FnZUhlYWRlciA9IGJhZ2dhZ2UuZHluYW1pY1NhbXBsaW5nQ29udGV4dFRvU2VudHJ5QmFnZ2FnZUhlYWRlcjtcbmV4cG9ydHMub2JqZWN0VG9CYWdnYWdlSGVhZGVyID0gYmFnZ2FnZS5vYmplY3RUb0JhZ2dhZ2VIZWFkZXI7XG5leHBvcnRzLnBhcnNlQmFnZ2FnZUhlYWRlciA9IGJhZ2dhZ2UucGFyc2VCYWdnYWdlSGVhZGVyO1xuZXhwb3J0cy5nZXRIdHRwU3BhbkRldGFpbHNGcm9tVXJsT2JqZWN0ID0gdXJsLmdldEh0dHBTcGFuRGV0YWlsc0Zyb21VcmxPYmplY3Q7XG5leHBvcnRzLmdldFNhbml0aXplZFVybFN0cmluZyA9IHVybC5nZXRTYW5pdGl6ZWRVcmxTdHJpbmc7XG5leHBvcnRzLmdldFNhbml0aXplZFVybFN0cmluZ0Zyb21VcmxPYmplY3QgPSB1cmwuZ2V0U2FuaXRpemVkVXJsU3RyaW5nRnJvbVVybE9iamVjdDtcbmV4cG9ydHMuaXNVUkxPYmplY3RSZWxhdGl2ZSA9IHVybC5pc1VSTE9iamVjdFJlbGF0aXZlO1xuZXhwb3J0cy5wYXJzZVN0cmluZ1RvVVJMT2JqZWN0ID0gdXJsLnBhcnNlU3RyaW5nVG9VUkxPYmplY3Q7XG5leHBvcnRzLnBhcnNlVXJsID0gdXJsLnBhcnNlVXJsO1xuZXhwb3J0cy5zdHJpcFVybFF1ZXJ5QW5kRnJhZ21lbnQgPSB1cmwuc3RyaXBVcmxRdWVyeUFuZEZyYWdtZW50O1xuZXhwb3J0cy5ldmVudEZyb21NZXNzYWdlID0gZXZlbnRidWlsZGVyLmV2ZW50RnJvbU1lc3NhZ2U7XG5leHBvcnRzLmV2ZW50RnJvbVVua25vd25JbnB1dCA9IGV2ZW50YnVpbGRlci5ldmVudEZyb21Vbmtub3duSW5wdXQ7XG5leHBvcnRzLmV4Y2VwdGlvbkZyb21FcnJvciA9IGV2ZW50YnVpbGRlci5leGNlcHRpb25Gcm9tRXJyb3I7XG5leHBvcnRzLnBhcnNlU3RhY2tGcmFtZXMgPSBldmVudGJ1aWxkZXIucGFyc2VTdGFja0ZyYW1lcztcbmV4cG9ydHMuY2FsbEZyYW1lVG9TdGFja0ZyYW1lID0gYW5yLmNhbGxGcmFtZVRvU3RhY2tGcmFtZTtcbmV4cG9ydHMud2F0Y2hkb2dUaW1lciA9IGFuci53YXRjaGRvZ1RpbWVyO1xuZXhwb3J0cy5MUlVNYXAgPSBscnUuTFJVTWFwO1xuZXhwb3J0cy5nZW5lcmF0ZVNwYW5JZCA9IHByb3BhZ2F0aW9uQ29udGV4dC5nZW5lcmF0ZVNwYW5JZDtcbmV4cG9ydHMuZ2VuZXJhdGVUcmFjZUlkID0gcHJvcGFnYXRpb25Db250ZXh0LmdlbmVyYXRlVHJhY2VJZDtcbmV4cG9ydHMudmVyY2VsV2FpdFVudGlsID0gdmVyY2VsV2FpdFVudGlsLnZlcmNlbFdhaXRVbnRpbDtcbmV4cG9ydHMuZmx1c2hJZlNlcnZlcmxlc3MgPSBmbHVzaElmU2VydmVybGVzcy5mbHVzaElmU2VydmVybGVzcztcbmV4cG9ydHMuU0RLX1ZFUlNJT04gPSB2ZXJzaW9uLlNES19WRVJTSU9OO1xuZXhwb3J0cy5nZXREZWJ1Z0ltYWdlc0ZvclJlc291cmNlcyA9IGRlYnVnSWRzLmdldERlYnVnSW1hZ2VzRm9yUmVzb3VyY2VzO1xuZXhwb3J0cy5nZXRGaWxlbmFtZVRvRGVidWdJZE1hcCA9IGRlYnVnSWRzLmdldEZpbGVuYW1lVG9EZWJ1Z0lkTWFwO1xuZXhwb3J0cy5lc2NhcGVTdHJpbmdGb3JSZWdleCA9IGVzY2FwZVN0cmluZ0ZvclJlZ2V4LmVzY2FwZVN0cmluZ0ZvclJlZ2V4O1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9aW5kZXguanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/index.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/console.js":
/*!**********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/console.js ***!
  \**********************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst debugLogger = __webpack_require__(/*! ../utils/debug-logger.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst object = __webpack_require__(/*! ../utils/object.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/object.js\");\nconst worldwide = __webpack_require__(/*! ../utils/worldwide.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/worldwide.js\");\nconst handlers = __webpack_require__(/*! ./handlers.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/handlers.js\");\n\n/**\n * Add an instrumentation handler for when a console.xxx method is called.\n *\n * Use at your own risk, this might break without changelog notice, only used internally.\n * @hidden\n */\nfunction addConsoleInstrumentationHandler(handler) {\n  const type = 'console';\n  handlers.addHandler(type, handler);\n  handlers.maybeInstrument(type, instrumentConsole);\n}\n\nfunction instrumentConsole() {\n  if (!('console' in worldwide.GLOBAL_OBJ)) {\n    return;\n  }\n\n  debugLogger.CONSOLE_LEVELS.forEach(function (level) {\n    if (!(level in worldwide.GLOBAL_OBJ.console)) {\n      return;\n    }\n\n    object.fill(worldwide.GLOBAL_OBJ.console, level, function (originalConsoleMethod) {\n      debugLogger.originalConsoleMethods[level] = originalConsoleMethod;\n\n      return function (...args) {\n        const handlerData = { args, level };\n        handlers.triggerHandlers('console', handlerData);\n\n        const log = debugLogger.originalConsoleMethods[level];\n        log?.apply(worldwide.GLOBAL_OBJ.console, args);\n      };\n    });\n  });\n}\n\nexports.addConsoleInstrumentationHandler = addConsoleInstrumentationHandler;\n//# sourceMappingURL=console.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnN0cnVtZW50L2NvbnNvbGUuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsb0JBQW9CLG1CQUFPLENBQUMsMElBQTBCO0FBQ3RELGVBQWUsbUJBQU8sQ0FBQyw4SEFBb0I7QUFDM0Msa0JBQWtCLG1CQUFPLENBQUMsb0lBQXVCO0FBQ2pELGlCQUFpQixtQkFBTyxDQUFDLGdJQUFlOztBQUV4QztBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQSw4QkFBOEI7QUFDOUI7O0FBRUE7QUFDQTtBQUNBO0FBQ0EsS0FBSztBQUNMLEdBQUc7QUFDSDs7QUFFQSx3Q0FBd0M7QUFDeEMiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnN0cnVtZW50L2NvbnNvbGUuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGRlYnVnTG9nZ2VyID0gcmVxdWlyZSgnLi4vdXRpbHMvZGVidWctbG9nZ2VyLmpzJyk7XG5jb25zdCBvYmplY3QgPSByZXF1aXJlKCcuLi91dGlscy9vYmplY3QuanMnKTtcbmNvbnN0IHdvcmxkd2lkZSA9IHJlcXVpcmUoJy4uL3V0aWxzL3dvcmxkd2lkZS5qcycpO1xuY29uc3QgaGFuZGxlcnMgPSByZXF1aXJlKCcuL2hhbmRsZXJzLmpzJyk7XG5cbi8qKlxuICogQWRkIGFuIGluc3RydW1lbnRhdGlvbiBoYW5kbGVyIGZvciB3aGVuIGEgY29uc29sZS54eHggbWV0aG9kIGlzIGNhbGxlZC5cbiAqXG4gKiBVc2UgYXQgeW91ciBvd24gcmlzaywgdGhpcyBtaWdodCBicmVhayB3aXRob3V0IGNoYW5nZWxvZyBub3RpY2UsIG9ubHkgdXNlZCBpbnRlcm5hbGx5LlxuICogQGhpZGRlblxuICovXG5mdW5jdGlvbiBhZGRDb25zb2xlSW5zdHJ1bWVudGF0aW9uSGFuZGxlcihoYW5kbGVyKSB7XG4gIGNvbnN0IHR5cGUgPSAnY29uc29sZSc7XG4gIGhhbmRsZXJzLmFkZEhhbmRsZXIodHlwZSwgaGFuZGxlcik7XG4gIGhhbmRsZXJzLm1heWJlSW5zdHJ1bWVudCh0eXBlLCBpbnN0cnVtZW50Q29uc29sZSk7XG59XG5cbmZ1bmN0aW9uIGluc3RydW1lbnRDb25zb2xlKCkge1xuICBpZiAoISgnY29uc29sZScgaW4gd29ybGR3aWRlLkdMT0JBTF9PQkopKSB7XG4gICAgcmV0dXJuO1xuICB9XG5cbiAgZGVidWdMb2dnZXIuQ09OU09MRV9MRVZFTFMuZm9yRWFjaChmdW5jdGlvbiAobGV2ZWwpIHtcbiAgICBpZiAoIShsZXZlbCBpbiB3b3JsZHdpZGUuR0xPQkFMX09CSi5jb25zb2xlKSkge1xuICAgICAgcmV0dXJuO1xuICAgIH1cblxuICAgIG9iamVjdC5maWxsKHdvcmxkd2lkZS5HTE9CQUxfT0JKLmNvbnNvbGUsIGxldmVsLCBmdW5jdGlvbiAob3JpZ2luYWxDb25zb2xlTWV0aG9kKSB7XG4gICAgICBkZWJ1Z0xvZ2dlci5vcmlnaW5hbENvbnNvbGVNZXRob2RzW2xldmVsXSA9IG9yaWdpbmFsQ29uc29sZU1ldGhvZDtcblxuICAgICAgcmV0dXJuIGZ1bmN0aW9uICguLi5hcmdzKSB7XG4gICAgICAgIGNvbnN0IGhhbmRsZXJEYXRhID0geyBhcmdzLCBsZXZlbCB9O1xuICAgICAgICBoYW5kbGVycy50cmlnZ2VySGFuZGxlcnMoJ2NvbnNvbGUnLCBoYW5kbGVyRGF0YSk7XG5cbiAgICAgICAgY29uc3QgbG9nID0gZGVidWdMb2dnZXIub3JpZ2luYWxDb25zb2xlTWV0aG9kc1tsZXZlbF07XG4gICAgICAgIGxvZz8uYXBwbHkod29ybGR3aWRlLkdMT0JBTF9PQkouY29uc29sZSwgYXJncyk7XG4gICAgICB9O1xuICAgIH0pO1xuICB9KTtcbn1cblxuZXhwb3J0cy5hZGRDb25zb2xlSW5zdHJ1bWVudGF0aW9uSGFuZGxlciA9IGFkZENvbnNvbGVJbnN0cnVtZW50YXRpb25IYW5kbGVyO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9Y29uc29sZS5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/console.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/fetch.js":
/*!********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/fetch.js ***!
  \********************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst is = __webpack_require__(/*! ../utils/is.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js\");\nconst object = __webpack_require__(/*! ../utils/object.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/object.js\");\nconst supports = __webpack_require__(/*! ../utils/supports.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/supports.js\");\nconst time = __webpack_require__(/*! ../utils/time.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/time.js\");\nconst worldwide = __webpack_require__(/*! ../utils/worldwide.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/worldwide.js\");\nconst handlers = __webpack_require__(/*! ./handlers.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/handlers.js\");\n\n/**\n * Add an instrumentation handler for when a fetch request happens.\n * The handler function is called once when the request starts and once when it ends,\n * which can be identified by checking if it has an `endTimestamp`.\n *\n * Use at your own risk, this might break without changelog notice, only used internally.\n * @hidden\n */\nfunction addFetchInstrumentationHandler(\n  handler,\n  skipNativeFetchCheck,\n) {\n  const type = 'fetch';\n  handlers.addHandler(type, handler);\n  handlers.maybeInstrument(type, () => instrumentFetch(undefined, skipNativeFetchCheck));\n}\n\n/**\n * Add an instrumentation handler for long-lived fetch requests, like consuming server-sent events (SSE) via fetch.\n * The handler will resolve the request body and emit the actual `endTimestamp`, so that the\n * span can be updated accordingly.\n *\n * Only used internally\n * @hidden\n */\nfunction addFetchEndInstrumentationHandler(handler) {\n  const type = 'fetch-body-resolved';\n  handlers.addHandler(type, handler);\n  handlers.maybeInstrument(type, () => instrumentFetch(streamHandler));\n}\n\nfunction instrumentFetch(onFetchResolved, skipNativeFetchCheck = false) {\n  if (skipNativeFetchCheck && !supports.supportsNativeFetch()) {\n    return;\n  }\n\n  object.fill(worldwide.GLOBAL_OBJ, 'fetch', function (originalFetch) {\n    return function (...args) {\n      // We capture the error right here and not in the Promise error callback because Safari (and probably other\n      // browsers too) will wipe the stack trace up to this point, only leaving us with this file which is useless.\n\n      // NOTE: If you are a Sentry user, and you are seeing this stack frame,\n      //       it means the error, that was caused by your fetch call did not\n      //       have a stack trace, so the SDK backfilled the stack trace so\n      //       you can see which fetch call failed.\n      const virtualError = new Error();\n\n      const { method, url } = parseFetchArgs(args);\n      const handlerData = {\n        args,\n        fetchData: {\n          method,\n          url,\n        },\n        startTimestamp: time.timestampInSeconds() * 1000,\n        // // Adding the error to be able to fingerprint the failed fetch event in HttpClient instrumentation\n        virtualError,\n        headers: getHeadersFromFetchArgs(args),\n      };\n\n      // if there is no callback, fetch is instrumented directly\n      if (!onFetchResolved) {\n        handlers.triggerHandlers('fetch', {\n          ...handlerData,\n        });\n      }\n\n      // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n      return originalFetch.apply(worldwide.GLOBAL_OBJ, args).then(\n        async (response) => {\n          if (onFetchResolved) {\n            onFetchResolved(response);\n          } else {\n            handlers.triggerHandlers('fetch', {\n              ...handlerData,\n              endTimestamp: time.timestampInSeconds() * 1000,\n              response,\n            });\n          }\n\n          return response;\n        },\n        (error) => {\n          handlers.triggerHandlers('fetch', {\n            ...handlerData,\n            endTimestamp: time.timestampInSeconds() * 1000,\n            error,\n          });\n\n          if (is.isError(error) && error.stack === undefined) {\n            // NOTE: If you are a Sentry user, and you are seeing this stack frame,\n            //       it means the error, that was caused by your fetch call did not\n            //       have a stack trace, so the SDK backfilled the stack trace so\n            //       you can see which fetch call failed.\n            error.stack = virtualError.stack;\n            object.addNonEnumerableProperty(error, 'framesToPop', 1);\n          }\n\n          // We enhance the not-so-helpful \"Failed to fetch\" error messages with the host\n          // Possible messages we handle here:\n          // * \"Failed to fetch\" (chromium)\n          // * \"Load failed\" (webkit)\n          // * \"NetworkError when attempting to fetch resource.\" (firefox)\n          if (\n            error instanceof TypeError &&\n            (error.message === 'Failed to fetch' ||\n              error.message === 'Load failed' ||\n              error.message === 'NetworkError when attempting to fetch resource.')\n          ) {\n            try {\n              const url = new URL(handlerData.fetchData.url);\n              error.message = `${error.message} (${url.host})`;\n            } catch {\n              // ignore it if errors happen here\n            }\n          }\n\n          // NOTE: If you are a Sentry user, and you are seeing this stack frame,\n          //       it means the sentry.javascript SDK caught an error invoking your application code.\n          //       This is expected behavior and NOT indicative of a bug with sentry.javascript.\n          throw error;\n        },\n      );\n    };\n  });\n}\n\nasync function resolveResponse(res, onFinishedResolving) {\n  if (res?.body) {\n    const body = res.body;\n    const responseReader = body.getReader();\n\n    // Define a maximum duration after which we just cancel\n    const maxFetchDurationTimeout = setTimeout(\n      () => {\n        body.cancel().then(null, () => {\n          // noop\n        });\n      },\n      90 * 1000, // 90s\n    );\n\n    let readingActive = true;\n    while (readingActive) {\n      let chunkTimeout;\n      try {\n        // abort reading if read op takes more than 5s\n        chunkTimeout = setTimeout(() => {\n          body.cancel().then(null, () => {\n            // noop on error\n          });\n        }, 5000);\n\n        // This .read() call will reject/throw when we abort due to timeouts through `body.cancel()`\n        const { done } = await responseReader.read();\n\n        clearTimeout(chunkTimeout);\n\n        if (done) {\n          onFinishedResolving();\n          readingActive = false;\n        }\n      } catch {\n        readingActive = false;\n      } finally {\n        clearTimeout(chunkTimeout);\n      }\n    }\n\n    clearTimeout(maxFetchDurationTimeout);\n\n    responseReader.releaseLock();\n    body.cancel().then(null, () => {\n      // noop on error\n    });\n  }\n}\n\nfunction streamHandler(response) {\n  // clone response for awaiting stream\n  let clonedResponseForResolving;\n  try {\n    clonedResponseForResolving = response.clone();\n  } catch {\n    return;\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-floating-promises\n  resolveResponse(clonedResponseForResolving, () => {\n    handlers.triggerHandlers('fetch-body-resolved', {\n      endTimestamp: time.timestampInSeconds() * 1000,\n      response,\n    });\n  });\n}\n\nfunction hasProp(obj, prop) {\n  return !!obj && typeof obj === 'object' && !!(obj )[prop];\n}\n\nfunction getUrlFromResource(resource) {\n  if (typeof resource === 'string') {\n    return resource;\n  }\n\n  if (!resource) {\n    return '';\n  }\n\n  if (hasProp(resource, 'url')) {\n    return resource.url;\n  }\n\n  if (resource.toString) {\n    return resource.toString();\n  }\n\n  return '';\n}\n\n/**\n * Parses the fetch arguments to find the used Http method and the url of the request.\n * Exported for tests only.\n */\nfunction parseFetchArgs(fetchArgs) {\n  if (fetchArgs.length === 0) {\n    return { method: 'GET', url: '' };\n  }\n\n  if (fetchArgs.length === 2) {\n    const [url, options] = fetchArgs ;\n\n    return {\n      url: getUrlFromResource(url),\n      method: hasProp(options, 'method') ? String(options.method).toUpperCase() : 'GET',\n    };\n  }\n\n  const arg = fetchArgs[0];\n  return {\n    url: getUrlFromResource(arg ),\n    method: hasProp(arg, 'method') ? String(arg.method).toUpperCase() : 'GET',\n  };\n}\n\nfunction getHeadersFromFetchArgs(fetchArgs) {\n  const [requestArgument, optionsArgument] = fetchArgs;\n\n  try {\n    if (\n      typeof optionsArgument === 'object' &&\n      optionsArgument !== null &&\n      'headers' in optionsArgument &&\n      optionsArgument.headers\n    ) {\n      return new Headers(optionsArgument.headers );\n    }\n\n    if (is.isRequest(requestArgument)) {\n      return new Headers(requestArgument.headers);\n    }\n  } catch {\n    // noop\n  }\n\n  return;\n}\n\nexports.addFetchEndInstrumentationHandler = addFetchEndInstrumentationHandler;\nexports.addFetchInstrumentationHandler = addFetchInstrumentationHandler;\nexports.parseFetchArgs = parseFetchArgs;\n//# sourceMappingURL=fetch.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnN0cnVtZW50L2ZldGNoLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLFdBQVcsbUJBQU8sQ0FBQyxzSEFBZ0I7QUFDbkMsZUFBZSxtQkFBTyxDQUFDLDhIQUFvQjtBQUMzQyxpQkFBaUIsbUJBQU8sQ0FBQyxrSUFBc0I7QUFDL0MsYUFBYSxtQkFBTyxDQUFDLDBIQUFrQjtBQUN2QyxrQkFBa0IsbUJBQU8sQ0FBQyxvSUFBdUI7QUFDakQsaUJBQWlCLG1CQUFPLENBQUMsZ0lBQWU7O0FBRXhDO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsY0FBYyxjQUFjO0FBQzVCO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxTQUFTO0FBQ1Q7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFNBQVM7QUFDVDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsWUFBWTtBQUNaO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsYUFBYTtBQUNiOztBQUVBO0FBQ0EsU0FBUztBQUNUO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxXQUFXOztBQUVYO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxpQ0FBaUMsZUFBZSxHQUFHLFNBQVM7QUFDNUQsY0FBYztBQUNkO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFNBQVM7QUFDVDtBQUNBO0FBQ0EsR0FBRztBQUNIOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxTQUFTO0FBQ1QsT0FBTztBQUNQO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFdBQVc7QUFDWCxTQUFTOztBQUVUO0FBQ0EsZ0JBQWdCLE9BQU87O0FBRXZCOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsUUFBUTtBQUNSO0FBQ0EsUUFBUTtBQUNSO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQSxLQUFLO0FBQ0w7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsSUFBSTtBQUNKO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEtBQUs7QUFDTCxHQUFHO0FBQ0g7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsYUFBYTtBQUNiOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0EsSUFBSTtBQUNKO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQSx5Q0FBeUM7QUFDekMsc0NBQXNDO0FBQ3RDLHNCQUFzQjtBQUN0QiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL2luc3RydW1lbnQvZmV0Y2guanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGlzID0gcmVxdWlyZSgnLi4vdXRpbHMvaXMuanMnKTtcbmNvbnN0IG9iamVjdCA9IHJlcXVpcmUoJy4uL3V0aWxzL29iamVjdC5qcycpO1xuY29uc3Qgc3VwcG9ydHMgPSByZXF1aXJlKCcuLi91dGlscy9zdXBwb3J0cy5qcycpO1xuY29uc3QgdGltZSA9IHJlcXVpcmUoJy4uL3V0aWxzL3RpbWUuanMnKTtcbmNvbnN0IHdvcmxkd2lkZSA9IHJlcXVpcmUoJy4uL3V0aWxzL3dvcmxkd2lkZS5qcycpO1xuY29uc3QgaGFuZGxlcnMgPSByZXF1aXJlKCcuL2hhbmRsZXJzLmpzJyk7XG5cbi8qKlxuICogQWRkIGFuIGluc3RydW1lbnRhdGlvbiBoYW5kbGVyIGZvciB3aGVuIGEgZmV0Y2ggcmVxdWVzdCBoYXBwZW5zLlxuICogVGhlIGhhbmRsZXIgZnVuY3Rpb24gaXMgY2FsbGVkIG9uY2Ugd2hlbiB0aGUgcmVxdWVzdCBzdGFydHMgYW5kIG9uY2Ugd2hlbiBpdCBlbmRzLFxuICogd2hpY2ggY2FuIGJlIGlkZW50aWZpZWQgYnkgY2hlY2tpbmcgaWYgaXQgaGFzIGFuIGBlbmRUaW1lc3RhbXBgLlxuICpcbiAqIFVzZSBhdCB5b3VyIG93biByaXNrLCB0aGlzIG1pZ2h0IGJyZWFrIHdpdGhvdXQgY2hhbmdlbG9nIG5vdGljZSwgb25seSB1c2VkIGludGVybmFsbHkuXG4gKiBAaGlkZGVuXG4gKi9cbmZ1bmN0aW9uIGFkZEZldGNoSW5zdHJ1bWVudGF0aW9uSGFuZGxlcihcbiAgaGFuZGxlcixcbiAgc2tpcE5hdGl2ZUZldGNoQ2hlY2ssXG4pIHtcbiAgY29uc3QgdHlwZSA9ICdmZXRjaCc7XG4gIGhhbmRsZXJzLmFkZEhhbmRsZXIodHlwZSwgaGFuZGxlcik7XG4gIGhhbmRsZXJzLm1heWJlSW5zdHJ1bWVudCh0eXBlLCAoKSA9PiBpbnN0cnVtZW50RmV0Y2godW5kZWZpbmVkLCBza2lwTmF0aXZlRmV0Y2hDaGVjaykpO1xufVxuXG4vKipcbiAqIEFkZCBhbiBpbnN0cnVtZW50YXRpb24gaGFuZGxlciBmb3IgbG9uZy1saXZlZCBmZXRjaCByZXF1ZXN0cywgbGlrZSBjb25zdW1pbmcgc2VydmVyLXNlbnQgZXZlbnRzIChTU0UpIHZpYSBmZXRjaC5cbiAqIFRoZSBoYW5kbGVyIHdpbGwgcmVzb2x2ZSB0aGUgcmVxdWVzdCBib2R5IGFuZCBlbWl0IHRoZSBhY3R1YWwgYGVuZFRpbWVzdGFtcGAsIHNvIHRoYXQgdGhlXG4gKiBzcGFuIGNhbiBiZSB1cGRhdGVkIGFjY29yZGluZ2x5LlxuICpcbiAqIE9ubHkgdXNlZCBpbnRlcm5hbGx5XG4gKiBAaGlkZGVuXG4gKi9cbmZ1bmN0aW9uIGFkZEZldGNoRW5kSW5zdHJ1bWVudGF0aW9uSGFuZGxlcihoYW5kbGVyKSB7XG4gIGNvbnN0IHR5cGUgPSAnZmV0Y2gtYm9keS1yZXNvbHZlZCc7XG4gIGhhbmRsZXJzLmFkZEhhbmRsZXIodHlwZSwgaGFuZGxlcik7XG4gIGhhbmRsZXJzLm1heWJlSW5zdHJ1bWVudCh0eXBlLCAoKSA9PiBpbnN0cnVtZW50RmV0Y2goc3RyZWFtSGFuZGxlcikpO1xufVxuXG5mdW5jdGlvbiBpbnN0cnVtZW50RmV0Y2gob25GZXRjaFJlc29sdmVkLCBza2lwTmF0aXZlRmV0Y2hDaGVjayA9IGZhbHNlKSB7XG4gIGlmIChza2lwTmF0aXZlRmV0Y2hDaGVjayAmJiAhc3VwcG9ydHMuc3VwcG9ydHNOYXRpdmVGZXRjaCgpKSB7XG4gICAgcmV0dXJuO1xuICB9XG5cbiAgb2JqZWN0LmZpbGwod29ybGR3aWRlLkdMT0JBTF9PQkosICdmZXRjaCcsIGZ1bmN0aW9uIChvcmlnaW5hbEZldGNoKSB7XG4gICAgcmV0dXJuIGZ1bmN0aW9uICguLi5hcmdzKSB7XG4gICAgICAvLyBXZSBjYXB0dXJlIHRoZSBlcnJvciByaWdodCBoZXJlIGFuZCBub3QgaW4gdGhlIFByb21pc2UgZXJyb3IgY2FsbGJhY2sgYmVjYXVzZSBTYWZhcmkgKGFuZCBwcm9iYWJseSBvdGhlclxuICAgICAgLy8gYnJvd3NlcnMgdG9vKSB3aWxsIHdpcGUgdGhlIHN0YWNrIHRyYWNlIHVwIHRvIHRoaXMgcG9pbnQsIG9ubHkgbGVhdmluZyB1cyB3aXRoIHRoaXMgZmlsZSB3aGljaCBpcyB1c2VsZXNzLlxuXG4gICAgICAvLyBOT1RFOiBJZiB5b3UgYXJlIGEgU2VudHJ5IHVzZXIsIGFuZCB5b3UgYXJlIHNlZWluZyB0aGlzIHN0YWNrIGZyYW1lLFxuICAgICAgLy8gICAgICAgaXQgbWVhbnMgdGhlIGVycm9yLCB0aGF0IHdhcyBjYXVzZWQgYnkgeW91ciBmZXRjaCBjYWxsIGRpZCBub3RcbiAgICAgIC8vICAgICAgIGhhdmUgYSBzdGFjayB0cmFjZSwgc28gdGhlIFNESyBiYWNrZmlsbGVkIHRoZSBzdGFjayB0cmFjZSBzb1xuICAgICAgLy8gICAgICAgeW91IGNhbiBzZWUgd2hpY2ggZmV0Y2ggY2FsbCBmYWlsZWQuXG4gICAgICBjb25zdCB2aXJ0dWFsRXJyb3IgPSBuZXcgRXJyb3IoKTtcblxuICAgICAgY29uc3QgeyBtZXRob2QsIHVybCB9ID0gcGFyc2VGZXRjaEFyZ3MoYXJncyk7XG4gICAgICBjb25zdCBoYW5kbGVyRGF0YSA9IHtcbiAgICAgICAgYXJncyxcbiAgICAgICAgZmV0Y2hEYXRhOiB7XG4gICAgICAgICAgbWV0aG9kLFxuICAgICAgICAgIHVybCxcbiAgICAgICAgfSxcbiAgICAgICAgc3RhcnRUaW1lc3RhbXA6IHRpbWUudGltZXN0YW1wSW5TZWNvbmRzKCkgKiAxMDAwLFxuICAgICAgICAvLyAvLyBBZGRpbmcgdGhlIGVycm9yIHRvIGJlIGFibGUgdG8gZmluZ2VycHJpbnQgdGhlIGZhaWxlZCBmZXRjaCBldmVudCBpbiBIdHRwQ2xpZW50IGluc3RydW1lbnRhdGlvblxuICAgICAgICB2aXJ0dWFsRXJyb3IsXG4gICAgICAgIGhlYWRlcnM6IGdldEhlYWRlcnNGcm9tRmV0Y2hBcmdzKGFyZ3MpLFxuICAgICAgfTtcblxuICAgICAgLy8gaWYgdGhlcmUgaXMgbm8gY2FsbGJhY2ssIGZldGNoIGlzIGluc3RydW1lbnRlZCBkaXJlY3RseVxuICAgICAgaWYgKCFvbkZldGNoUmVzb2x2ZWQpIHtcbiAgICAgICAgaGFuZGxlcnMudHJpZ2dlckhhbmRsZXJzKCdmZXRjaCcsIHtcbiAgICAgICAgICAuLi5oYW5kbGVyRGF0YSxcbiAgICAgICAgfSk7XG4gICAgICB9XG5cbiAgICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tdW5zYWZlLW1lbWJlci1hY2Nlc3NcbiAgICAgIHJldHVybiBvcmlnaW5hbEZldGNoLmFwcGx5KHdvcmxkd2lkZS5HTE9CQUxfT0JKLCBhcmdzKS50aGVuKFxuICAgICAgICBhc3luYyAocmVzcG9uc2UpID0+IHtcbiAgICAgICAgICBpZiAob25GZXRjaFJlc29sdmVkKSB7XG4gICAgICAgICAgICBvbkZldGNoUmVzb2x2ZWQocmVzcG9uc2UpO1xuICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICBoYW5kbGVycy50cmlnZ2VySGFuZGxlcnMoJ2ZldGNoJywge1xuICAgICAgICAgICAgICAuLi5oYW5kbGVyRGF0YSxcbiAgICAgICAgICAgICAgZW5kVGltZXN0YW1wOiB0aW1lLnRpbWVzdGFtcEluU2Vjb25kcygpICogMTAwMCxcbiAgICAgICAgICAgICAgcmVzcG9uc2UsXG4gICAgICAgICAgICB9KTtcbiAgICAgICAgICB9XG5cbiAgICAgICAgICByZXR1cm4gcmVzcG9uc2U7XG4gICAgICAgIH0sXG4gICAgICAgIChlcnJvcikgPT4ge1xuICAgICAgICAgIGhhbmRsZXJzLnRyaWdnZXJIYW5kbGVycygnZmV0Y2gnLCB7XG4gICAgICAgICAgICAuLi5oYW5kbGVyRGF0YSxcbiAgICAgICAgICAgIGVuZFRpbWVzdGFtcDogdGltZS50aW1lc3RhbXBJblNlY29uZHMoKSAqIDEwMDAsXG4gICAgICAgICAgICBlcnJvcixcbiAgICAgICAgICB9KTtcblxuICAgICAgICAgIGlmIChpcy5pc0Vycm9yKGVycm9yKSAmJiBlcnJvci5zdGFjayA9PT0gdW5kZWZpbmVkKSB7XG4gICAgICAgICAgICAvLyBOT1RFOiBJZiB5b3UgYXJlIGEgU2VudHJ5IHVzZXIsIGFuZCB5b3UgYXJlIHNlZWluZyB0aGlzIHN0YWNrIGZyYW1lLFxuICAgICAgICAgICAgLy8gICAgICAgaXQgbWVhbnMgdGhlIGVycm9yLCB0aGF0IHdhcyBjYXVzZWQgYnkgeW91ciBmZXRjaCBjYWxsIGRpZCBub3RcbiAgICAgICAgICAgIC8vICAgICAgIGhhdmUgYSBzdGFjayB0cmFjZSwgc28gdGhlIFNESyBiYWNrZmlsbGVkIHRoZSBzdGFjayB0cmFjZSBzb1xuICAgICAgICAgICAgLy8gICAgICAgeW91IGNhbiBzZWUgd2hpY2ggZmV0Y2ggY2FsbCBmYWlsZWQuXG4gICAgICAgICAgICBlcnJvci5zdGFjayA9IHZpcnR1YWxFcnJvci5zdGFjaztcbiAgICAgICAgICAgIG9iamVjdC5hZGROb25FbnVtZXJhYmxlUHJvcGVydHkoZXJyb3IsICdmcmFtZXNUb1BvcCcsIDEpO1xuICAgICAgICAgIH1cblxuICAgICAgICAgIC8vIFdlIGVuaGFuY2UgdGhlIG5vdC1zby1oZWxwZnVsIFwiRmFpbGVkIHRvIGZldGNoXCIgZXJyb3IgbWVzc2FnZXMgd2l0aCB0aGUgaG9zdFxuICAgICAgICAgIC8vIFBvc3NpYmxlIG1lc3NhZ2VzIHdlIGhhbmRsZSBoZXJlOlxuICAgICAgICAgIC8vICogXCJGYWlsZWQgdG8gZmV0Y2hcIiAoY2hyb21pdW0pXG4gICAgICAgICAgLy8gKiBcIkxvYWQgZmFpbGVkXCIgKHdlYmtpdClcbiAgICAgICAgICAvLyAqIFwiTmV0d29ya0Vycm9yIHdoZW4gYXR0ZW1wdGluZyB0byBmZXRjaCByZXNvdXJjZS5cIiAoZmlyZWZveClcbiAgICAgICAgICBpZiAoXG4gICAgICAgICAgICBlcnJvciBpbnN0YW5jZW9mIFR5cGVFcnJvciAmJlxuICAgICAgICAgICAgKGVycm9yLm1lc3NhZ2UgPT09ICdGYWlsZWQgdG8gZmV0Y2gnIHx8XG4gICAgICAgICAgICAgIGVycm9yLm1lc3NhZ2UgPT09ICdMb2FkIGZhaWxlZCcgfHxcbiAgICAgICAgICAgICAgZXJyb3IubWVzc2FnZSA9PT0gJ05ldHdvcmtFcnJvciB3aGVuIGF0dGVtcHRpbmcgdG8gZmV0Y2ggcmVzb3VyY2UuJylcbiAgICAgICAgICApIHtcbiAgICAgICAgICAgIHRyeSB7XG4gICAgICAgICAgICAgIGNvbnN0IHVybCA9IG5ldyBVUkwoaGFuZGxlckRhdGEuZmV0Y2hEYXRhLnVybCk7XG4gICAgICAgICAgICAgIGVycm9yLm1lc3NhZ2UgPSBgJHtlcnJvci5tZXNzYWdlfSAoJHt1cmwuaG9zdH0pYDtcbiAgICAgICAgICAgIH0gY2F0Y2gge1xuICAgICAgICAgICAgICAvLyBpZ25vcmUgaXQgaWYgZXJyb3JzIGhhcHBlbiBoZXJlXG4gICAgICAgICAgICB9XG4gICAgICAgICAgfVxuXG4gICAgICAgICAgLy8gTk9URTogSWYgeW91IGFyZSBhIFNlbnRyeSB1c2VyLCBhbmQgeW91IGFyZSBzZWVpbmcgdGhpcyBzdGFjayBmcmFtZSxcbiAgICAgICAgICAvLyAgICAgICBpdCBtZWFucyB0aGUgc2VudHJ5LmphdmFzY3JpcHQgU0RLIGNhdWdodCBhbiBlcnJvciBpbnZva2luZyB5b3VyIGFwcGxpY2F0aW9uIGNvZGUuXG4gICAgICAgICAgLy8gICAgICAgVGhpcyBpcyBleHBlY3RlZCBiZWhhdmlvciBhbmQgTk9UIGluZGljYXRpdmUgb2YgYSBidWcgd2l0aCBzZW50cnkuamF2YXNjcmlwdC5cbiAgICAgICAgICB0aHJvdyBlcnJvcjtcbiAgICAgICAgfSxcbiAgICAgICk7XG4gICAgfTtcbiAgfSk7XG59XG5cbmFzeW5jIGZ1bmN0aW9uIHJlc29sdmVSZXNwb25zZShyZXMsIG9uRmluaXNoZWRSZXNvbHZpbmcpIHtcbiAgaWYgKHJlcz8uYm9keSkge1xuICAgIGNvbnN0IGJvZHkgPSByZXMuYm9keTtcbiAgICBjb25zdCByZXNwb25zZVJlYWRlciA9IGJvZHkuZ2V0UmVhZGVyKCk7XG5cbiAgICAvLyBEZWZpbmUgYSBtYXhpbXVtIGR1cmF0aW9uIGFmdGVyIHdoaWNoIHdlIGp1c3QgY2FuY2VsXG4gICAgY29uc3QgbWF4RmV0Y2hEdXJhdGlvblRpbWVvdXQgPSBzZXRUaW1lb3V0KFxuICAgICAgKCkgPT4ge1xuICAgICAgICBib2R5LmNhbmNlbCgpLnRoZW4obnVsbCwgKCkgPT4ge1xuICAgICAgICAgIC8vIG5vb3BcbiAgICAgICAgfSk7XG4gICAgICB9LFxuICAgICAgOTAgKiAxMDAwLCAvLyA5MHNcbiAgICApO1xuXG4gICAgbGV0IHJlYWRpbmdBY3RpdmUgPSB0cnVlO1xuICAgIHdoaWxlIChyZWFkaW5nQWN0aXZlKSB7XG4gICAgICBsZXQgY2h1bmtUaW1lb3V0O1xuICAgICAgdHJ5IHtcbiAgICAgICAgLy8gYWJvcnQgcmVhZGluZyBpZiByZWFkIG9wIHRha2VzIG1vcmUgdGhhbiA1c1xuICAgICAgICBjaHVua1RpbWVvdXQgPSBzZXRUaW1lb3V0KCgpID0+IHtcbiAgICAgICAgICBib2R5LmNhbmNlbCgpLnRoZW4obnVsbCwgKCkgPT4ge1xuICAgICAgICAgICAgLy8gbm9vcCBvbiBlcnJvclxuICAgICAgICAgIH0pO1xuICAgICAgICB9LCA1MDAwKTtcblxuICAgICAgICAvLyBUaGlzIC5yZWFkKCkgY2FsbCB3aWxsIHJlamVjdC90aHJvdyB3aGVuIHdlIGFib3J0IGR1ZSB0byB0aW1lb3V0cyB0aHJvdWdoIGBib2R5LmNhbmNlbCgpYFxuICAgICAgICBjb25zdCB7IGRvbmUgfSA9IGF3YWl0IHJlc3BvbnNlUmVhZGVyLnJlYWQoKTtcblxuICAgICAgICBjbGVhclRpbWVvdXQoY2h1bmtUaW1lb3V0KTtcblxuICAgICAgICBpZiAoZG9uZSkge1xuICAgICAgICAgIG9uRmluaXNoZWRSZXNvbHZpbmcoKTtcbiAgICAgICAgICByZWFkaW5nQWN0aXZlID0gZmFsc2U7XG4gICAgICAgIH1cbiAgICAgIH0gY2F0Y2gge1xuICAgICAgICByZWFkaW5nQWN0aXZlID0gZmFsc2U7XG4gICAgICB9IGZpbmFsbHkge1xuICAgICAgICBjbGVhclRpbWVvdXQoY2h1bmtUaW1lb3V0KTtcbiAgICAgIH1cbiAgICB9XG5cbiAgICBjbGVhclRpbWVvdXQobWF4RmV0Y2hEdXJhdGlvblRpbWVvdXQpO1xuXG4gICAgcmVzcG9uc2VSZWFkZXIucmVsZWFzZUxvY2soKTtcbiAgICBib2R5LmNhbmNlbCgpLnRoZW4obnVsbCwgKCkgPT4ge1xuICAgICAgLy8gbm9vcCBvbiBlcnJvclxuICAgIH0pO1xuICB9XG59XG5cbmZ1bmN0aW9uIHN0cmVhbUhhbmRsZXIocmVzcG9uc2UpIHtcbiAgLy8gY2xvbmUgcmVzcG9uc2UgZm9yIGF3YWl0aW5nIHN0cmVhbVxuICBsZXQgY2xvbmVkUmVzcG9uc2VGb3JSZXNvbHZpbmc7XG4gIHRyeSB7XG4gICAgY2xvbmVkUmVzcG9uc2VGb3JSZXNvbHZpbmcgPSByZXNwb25zZS5jbG9uZSgpO1xuICB9IGNhdGNoIHtcbiAgICByZXR1cm47XG4gIH1cblxuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25vLWZsb2F0aW5nLXByb21pc2VzXG4gIHJlc29sdmVSZXNwb25zZShjbG9uZWRSZXNwb25zZUZvclJlc29sdmluZywgKCkgPT4ge1xuICAgIGhhbmRsZXJzLnRyaWdnZXJIYW5kbGVycygnZmV0Y2gtYm9keS1yZXNvbHZlZCcsIHtcbiAgICAgIGVuZFRpbWVzdGFtcDogdGltZS50aW1lc3RhbXBJblNlY29uZHMoKSAqIDEwMDAsXG4gICAgICByZXNwb25zZSxcbiAgICB9KTtcbiAgfSk7XG59XG5cbmZ1bmN0aW9uIGhhc1Byb3Aob2JqLCBwcm9wKSB7XG4gIHJldHVybiAhIW9iaiAmJiB0eXBlb2Ygb2JqID09PSAnb2JqZWN0JyAmJiAhIShvYmogKVtwcm9wXTtcbn1cblxuZnVuY3Rpb24gZ2V0VXJsRnJvbVJlc291cmNlKHJlc291cmNlKSB7XG4gIGlmICh0eXBlb2YgcmVzb3VyY2UgPT09ICdzdHJpbmcnKSB7XG4gICAgcmV0dXJuIHJlc291cmNlO1xuICB9XG5cbiAgaWYgKCFyZXNvdXJjZSkge1xuICAgIHJldHVybiAnJztcbiAgfVxuXG4gIGlmIChoYXNQcm9wKHJlc291cmNlLCAndXJsJykpIHtcbiAgICByZXR1cm4gcmVzb3VyY2UudXJsO1xuICB9XG5cbiAgaWYgKHJlc291cmNlLnRvU3RyaW5nKSB7XG4gICAgcmV0dXJuIHJlc291cmNlLnRvU3RyaW5nKCk7XG4gIH1cblxuICByZXR1cm4gJyc7XG59XG5cbi8qKlxuICogUGFyc2VzIHRoZSBmZXRjaCBhcmd1bWVudHMgdG8gZmluZCB0aGUgdXNlZCBIdHRwIG1ldGhvZCBhbmQgdGhlIHVybCBvZiB0aGUgcmVxdWVzdC5cbiAqIEV4cG9ydGVkIGZvciB0ZXN0cyBvbmx5LlxuICovXG5mdW5jdGlvbiBwYXJzZUZldGNoQXJncyhmZXRjaEFyZ3MpIHtcbiAgaWYgKGZldGNoQXJncy5sZW5ndGggPT09IDApIHtcbiAgICByZXR1cm4geyBtZXRob2Q6ICdHRVQnLCB1cmw6ICcnIH07XG4gIH1cblxuICBpZiAoZmV0Y2hBcmdzLmxlbmd0aCA9PT0gMikge1xuICAgIGNvbnN0IFt1cmwsIG9wdGlvbnNdID0gZmV0Y2hBcmdzIDtcblxuICAgIHJldHVybiB7XG4gICAgICB1cmw6IGdldFVybEZyb21SZXNvdXJjZSh1cmwpLFxuICAgICAgbWV0aG9kOiBoYXNQcm9wKG9wdGlvbnMsICdtZXRob2QnKSA/IFN0cmluZyhvcHRpb25zLm1ldGhvZCkudG9VcHBlckNhc2UoKSA6ICdHRVQnLFxuICAgIH07XG4gIH1cblxuICBjb25zdCBhcmcgPSBmZXRjaEFyZ3NbMF07XG4gIHJldHVybiB7XG4gICAgdXJsOiBnZXRVcmxGcm9tUmVzb3VyY2UoYXJnICksXG4gICAgbWV0aG9kOiBoYXNQcm9wKGFyZywgJ21ldGhvZCcpID8gU3RyaW5nKGFyZy5tZXRob2QpLnRvVXBwZXJDYXNlKCkgOiAnR0VUJyxcbiAgfTtcbn1cblxuZnVuY3Rpb24gZ2V0SGVhZGVyc0Zyb21GZXRjaEFyZ3MoZmV0Y2hBcmdzKSB7XG4gIGNvbnN0IFtyZXF1ZXN0QXJndW1lbnQsIG9wdGlvbnNBcmd1bWVudF0gPSBmZXRjaEFyZ3M7XG5cbiAgdHJ5IHtcbiAgICBpZiAoXG4gICAgICB0eXBlb2Ygb3B0aW9uc0FyZ3VtZW50ID09PSAnb2JqZWN0JyAmJlxuICAgICAgb3B0aW9uc0FyZ3VtZW50ICE9PSBudWxsICYmXG4gICAgICAnaGVhZGVycycgaW4gb3B0aW9uc0FyZ3VtZW50ICYmXG4gICAgICBvcHRpb25zQXJndW1lbnQuaGVhZGVyc1xuICAgICkge1xuICAgICAgcmV0dXJuIG5ldyBIZWFkZXJzKG9wdGlvbnNBcmd1bWVudC5oZWFkZXJzICk7XG4gICAgfVxuXG4gICAgaWYgKGlzLmlzUmVxdWVzdChyZXF1ZXN0QXJndW1lbnQpKSB7XG4gICAgICByZXR1cm4gbmV3IEhlYWRlcnMocmVxdWVzdEFyZ3VtZW50LmhlYWRlcnMpO1xuICAgIH1cbiAgfSBjYXRjaCB7XG4gICAgLy8gbm9vcFxuICB9XG5cbiAgcmV0dXJuO1xufVxuXG5leHBvcnRzLmFkZEZldGNoRW5kSW5zdHJ1bWVudGF0aW9uSGFuZGxlciA9IGFkZEZldGNoRW5kSW5zdHJ1bWVudGF0aW9uSGFuZGxlcjtcbmV4cG9ydHMuYWRkRmV0Y2hJbnN0cnVtZW50YXRpb25IYW5kbGVyID0gYWRkRmV0Y2hJbnN0cnVtZW50YXRpb25IYW5kbGVyO1xuZXhwb3J0cy5wYXJzZUZldGNoQXJncyA9IHBhcnNlRmV0Y2hBcmdzO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9ZmV0Y2guanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/fetch.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/globalError.js":
/*!**************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/globalError.js ***!
  \**************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst worldwide = __webpack_require__(/*! ../utils/worldwide.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/worldwide.js\");\nconst handlers = __webpack_require__(/*! ./handlers.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/handlers.js\");\n\nlet _oldOnErrorHandler = null;\n\n/**\n * Add an instrumentation handler for when an error is captured by the global error handler.\n *\n * Use at your own risk, this might break without changelog notice, only used internally.\n * @hidden\n */\nfunction addGlobalErrorInstrumentationHandler(handler) {\n  const type = 'error';\n  handlers.addHandler(type, handler);\n  handlers.maybeInstrument(type, instrumentError);\n}\n\nfunction instrumentError() {\n  _oldOnErrorHandler = worldwide.GLOBAL_OBJ.onerror;\n\n  // Note: The reason we are doing window.onerror instead of window.addEventListener('error')\n  // is that we are using this handler in the Loader Script, to handle buffered errors consistently\n  worldwide.GLOBAL_OBJ.onerror = function (\n    msg,\n    url,\n    line,\n    column,\n    error,\n  ) {\n    const handlerData = {\n      column,\n      error,\n      line,\n      msg,\n      url,\n    };\n    handlers.triggerHandlers('error', handlerData);\n\n    if (_oldOnErrorHandler) {\n      // eslint-disable-next-line prefer-rest-params\n      return _oldOnErrorHandler.apply(this, arguments);\n    }\n\n    return false;\n  };\n\n  worldwide.GLOBAL_OBJ.onerror.__SENTRY_INSTRUMENTED__ = true;\n}\n\nexports.addGlobalErrorInstrumentationHandler = addGlobalErrorInstrumentationHandler;\n//# sourceMappingURL=globalError.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnN0cnVtZW50L2dsb2JhbEVycm9yLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLGtCQUFrQixtQkFBTyxDQUFDLG9JQUF1QjtBQUNqRCxpQkFBaUIsbUJBQU8sQ0FBQyxnSUFBZTs7QUFFeEM7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBOztBQUVBLDRDQUE0QztBQUM1QyIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL2luc3RydW1lbnQvZ2xvYmFsRXJyb3IuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IHdvcmxkd2lkZSA9IHJlcXVpcmUoJy4uL3V0aWxzL3dvcmxkd2lkZS5qcycpO1xuY29uc3QgaGFuZGxlcnMgPSByZXF1aXJlKCcuL2hhbmRsZXJzLmpzJyk7XG5cbmxldCBfb2xkT25FcnJvckhhbmRsZXIgPSBudWxsO1xuXG4vKipcbiAqIEFkZCBhbiBpbnN0cnVtZW50YXRpb24gaGFuZGxlciBmb3Igd2hlbiBhbiBlcnJvciBpcyBjYXB0dXJlZCBieSB0aGUgZ2xvYmFsIGVycm9yIGhhbmRsZXIuXG4gKlxuICogVXNlIGF0IHlvdXIgb3duIHJpc2ssIHRoaXMgbWlnaHQgYnJlYWsgd2l0aG91dCBjaGFuZ2Vsb2cgbm90aWNlLCBvbmx5IHVzZWQgaW50ZXJuYWxseS5cbiAqIEBoaWRkZW5cbiAqL1xuZnVuY3Rpb24gYWRkR2xvYmFsRXJyb3JJbnN0cnVtZW50YXRpb25IYW5kbGVyKGhhbmRsZXIpIHtcbiAgY29uc3QgdHlwZSA9ICdlcnJvcic7XG4gIGhhbmRsZXJzLmFkZEhhbmRsZXIodHlwZSwgaGFuZGxlcik7XG4gIGhhbmRsZXJzLm1heWJlSW5zdHJ1bWVudCh0eXBlLCBpbnN0cnVtZW50RXJyb3IpO1xufVxuXG5mdW5jdGlvbiBpbnN0cnVtZW50RXJyb3IoKSB7XG4gIF9vbGRPbkVycm9ySGFuZGxlciA9IHdvcmxkd2lkZS5HTE9CQUxfT0JKLm9uZXJyb3I7XG5cbiAgLy8gTm90ZTogVGhlIHJlYXNvbiB3ZSBhcmUgZG9pbmcgd2luZG93Lm9uZXJyb3IgaW5zdGVhZCBvZiB3aW5kb3cuYWRkRXZlbnRMaXN0ZW5lcignZXJyb3InKVxuICAvLyBpcyB0aGF0IHdlIGFyZSB1c2luZyB0aGlzIGhhbmRsZXIgaW4gdGhlIExvYWRlciBTY3JpcHQsIHRvIGhhbmRsZSBidWZmZXJlZCBlcnJvcnMgY29uc2lzdGVudGx5XG4gIHdvcmxkd2lkZS5HTE9CQUxfT0JKLm9uZXJyb3IgPSBmdW5jdGlvbiAoXG4gICAgbXNnLFxuICAgIHVybCxcbiAgICBsaW5lLFxuICAgIGNvbHVtbixcbiAgICBlcnJvcixcbiAgKSB7XG4gICAgY29uc3QgaGFuZGxlckRhdGEgPSB7XG4gICAgICBjb2x1bW4sXG4gICAgICBlcnJvcixcbiAgICAgIGxpbmUsXG4gICAgICBtc2csXG4gICAgICB1cmwsXG4gICAgfTtcbiAgICBoYW5kbGVycy50cmlnZ2VySGFuZGxlcnMoJ2Vycm9yJywgaGFuZGxlckRhdGEpO1xuXG4gICAgaWYgKF9vbGRPbkVycm9ySGFuZGxlcikge1xuICAgICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIHByZWZlci1yZXN0LXBhcmFtc1xuICAgICAgcmV0dXJuIF9vbGRPbkVycm9ySGFuZGxlci5hcHBseSh0aGlzLCBhcmd1bWVudHMpO1xuICAgIH1cblxuICAgIHJldHVybiBmYWxzZTtcbiAgfTtcblxuICB3b3JsZHdpZGUuR0xPQkFMX09CSi5vbmVycm9yLl9fU0VOVFJZX0lOU1RSVU1FTlRFRF9fID0gdHJ1ZTtcbn1cblxuZXhwb3J0cy5hZGRHbG9iYWxFcnJvckluc3RydW1lbnRhdGlvbkhhbmRsZXIgPSBhZGRHbG9iYWxFcnJvckluc3RydW1lbnRhdGlvbkhhbmRsZXI7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1nbG9iYWxFcnJvci5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/globalError.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/globalUnhandledRejection.js":
/*!***************************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/globalUnhandledRejection.js ***!
  \***************************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst worldwide = __webpack_require__(/*! ../utils/worldwide.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/worldwide.js\");\nconst handlers = __webpack_require__(/*! ./handlers.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/handlers.js\");\n\nlet _oldOnUnhandledRejectionHandler = null;\n\n/**\n * Add an instrumentation handler for when an unhandled promise rejection is captured.\n *\n * Use at your own risk, this might break without changelog notice, only used internally.\n * @hidden\n */\nfunction addGlobalUnhandledRejectionInstrumentationHandler(\n  handler,\n) {\n  const type = 'unhandledrejection';\n  handlers.addHandler(type, handler);\n  handlers.maybeInstrument(type, instrumentUnhandledRejection);\n}\n\nfunction instrumentUnhandledRejection() {\n  _oldOnUnhandledRejectionHandler = worldwide.GLOBAL_OBJ.onunhandledrejection;\n\n  // Note: The reason we are doing window.onunhandledrejection instead of window.addEventListener('unhandledrejection')\n  // is that we are using this handler in the Loader Script, to handle buffered rejections consistently\n  worldwide.GLOBAL_OBJ.onunhandledrejection = function (e) {\n    const handlerData = e;\n    handlers.triggerHandlers('unhandledrejection', handlerData);\n\n    if (_oldOnUnhandledRejectionHandler) {\n      // eslint-disable-next-line prefer-rest-params\n      return _oldOnUnhandledRejectionHandler.apply(this, arguments);\n    }\n\n    return true;\n  };\n\n  worldwide.GLOBAL_OBJ.onunhandledrejection.__SENTRY_INSTRUMENTED__ = true;\n}\n\nexports.addGlobalUnhandledRejectionInstrumentationHandler = addGlobalUnhandledRejectionInstrumentationHandler;\n//# sourceMappingURL=globalUnhandledRejection.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnN0cnVtZW50L2dsb2JhbFVuaGFuZGxlZFJlamVjdGlvbi5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxrQkFBa0IsbUJBQU8sQ0FBQyxvSUFBdUI7QUFDakQsaUJBQWlCLG1CQUFPLENBQUMsZ0lBQWU7O0FBRXhDOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUEseURBQXlEO0FBQ3pEIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvaW5zdHJ1bWVudC9nbG9iYWxVbmhhbmRsZWRSZWplY3Rpb24uanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IHdvcmxkd2lkZSA9IHJlcXVpcmUoJy4uL3V0aWxzL3dvcmxkd2lkZS5qcycpO1xuY29uc3QgaGFuZGxlcnMgPSByZXF1aXJlKCcuL2hhbmRsZXJzLmpzJyk7XG5cbmxldCBfb2xkT25VbmhhbmRsZWRSZWplY3Rpb25IYW5kbGVyID0gbnVsbDtcblxuLyoqXG4gKiBBZGQgYW4gaW5zdHJ1bWVudGF0aW9uIGhhbmRsZXIgZm9yIHdoZW4gYW4gdW5oYW5kbGVkIHByb21pc2UgcmVqZWN0aW9uIGlzIGNhcHR1cmVkLlxuICpcbiAqIFVzZSBhdCB5b3VyIG93biByaXNrLCB0aGlzIG1pZ2h0IGJyZWFrIHdpdGhvdXQgY2hhbmdlbG9nIG5vdGljZSwgb25seSB1c2VkIGludGVybmFsbHkuXG4gKiBAaGlkZGVuXG4gKi9cbmZ1bmN0aW9uIGFkZEdsb2JhbFVuaGFuZGxlZFJlamVjdGlvbkluc3RydW1lbnRhdGlvbkhhbmRsZXIoXG4gIGhhbmRsZXIsXG4pIHtcbiAgY29uc3QgdHlwZSA9ICd1bmhhbmRsZWRyZWplY3Rpb24nO1xuICBoYW5kbGVycy5hZGRIYW5kbGVyKHR5cGUsIGhhbmRsZXIpO1xuICBoYW5kbGVycy5tYXliZUluc3RydW1lbnQodHlwZSwgaW5zdHJ1bWVudFVuaGFuZGxlZFJlamVjdGlvbik7XG59XG5cbmZ1bmN0aW9uIGluc3RydW1lbnRVbmhhbmRsZWRSZWplY3Rpb24oKSB7XG4gIF9vbGRPblVuaGFuZGxlZFJlamVjdGlvbkhhbmRsZXIgPSB3b3JsZHdpZGUuR0xPQkFMX09CSi5vbnVuaGFuZGxlZHJlamVjdGlvbjtcblxuICAvLyBOb3RlOiBUaGUgcmVhc29uIHdlIGFyZSBkb2luZyB3aW5kb3cub251bmhhbmRsZWRyZWplY3Rpb24gaW5zdGVhZCBvZiB3aW5kb3cuYWRkRXZlbnRMaXN0ZW5lcigndW5oYW5kbGVkcmVqZWN0aW9uJylcbiAgLy8gaXMgdGhhdCB3ZSBhcmUgdXNpbmcgdGhpcyBoYW5kbGVyIGluIHRoZSBMb2FkZXIgU2NyaXB0LCB0byBoYW5kbGUgYnVmZmVyZWQgcmVqZWN0aW9ucyBjb25zaXN0ZW50bHlcbiAgd29ybGR3aWRlLkdMT0JBTF9PQkoub251bmhhbmRsZWRyZWplY3Rpb24gPSBmdW5jdGlvbiAoZSkge1xuICAgIGNvbnN0IGhhbmRsZXJEYXRhID0gZTtcbiAgICBoYW5kbGVycy50cmlnZ2VySGFuZGxlcnMoJ3VuaGFuZGxlZHJlamVjdGlvbicsIGhhbmRsZXJEYXRhKTtcblxuICAgIGlmIChfb2xkT25VbmhhbmRsZWRSZWplY3Rpb25IYW5kbGVyKSB7XG4gICAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgcHJlZmVyLXJlc3QtcGFyYW1zXG4gICAgICByZXR1cm4gX29sZE9uVW5oYW5kbGVkUmVqZWN0aW9uSGFuZGxlci5hcHBseSh0aGlzLCBhcmd1bWVudHMpO1xuICAgIH1cblxuICAgIHJldHVybiB0cnVlO1xuICB9O1xuXG4gIHdvcmxkd2lkZS5HTE9CQUxfT0JKLm9udW5oYW5kbGVkcmVqZWN0aW9uLl9fU0VOVFJZX0lOU1RSVU1FTlRFRF9fID0gdHJ1ZTtcbn1cblxuZXhwb3J0cy5hZGRHbG9iYWxVbmhhbmRsZWRSZWplY3Rpb25JbnN0cnVtZW50YXRpb25IYW5kbGVyID0gYWRkR2xvYmFsVW5oYW5kbGVkUmVqZWN0aW9uSW5zdHJ1bWVudGF0aW9uSGFuZGxlcjtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWdsb2JhbFVuaGFuZGxlZFJlamVjdGlvbi5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/globalUnhandledRejection.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/handlers.js":
/*!***********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/handlers.js ***!
  \***********************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst debugBuild = __webpack_require__(/*! ../debug-build.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst debugLogger = __webpack_require__(/*! ../utils/debug-logger.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst stacktrace = __webpack_require__(/*! ../utils/stacktrace.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/stacktrace.js\");\n\n// We keep the handlers globally\nconst handlers = {};\nconst instrumented = {};\n\n/** Add a handler function. */\nfunction addHandler(type, handler) {\n  handlers[type] = handlers[type] || [];\n  (handlers[type] ).push(handler);\n}\n\n/**\n * Reset all instrumentation handlers.\n * This can be used by tests to ensure we have a clean slate of instrumentation handlers.\n */\nfunction resetInstrumentationHandlers() {\n  Object.keys(handlers).forEach(key => {\n    handlers[key ] = undefined;\n  });\n}\n\n/** Maybe run an instrumentation function, unless it was already called. */\nfunction maybeInstrument(type, instrumentFn) {\n  if (!instrumented[type]) {\n    instrumented[type] = true;\n    try {\n      instrumentFn();\n    } catch (e) {\n      debugBuild.DEBUG_BUILD && debugLogger.debug.error(`Error while instrumenting ${type}`, e);\n    }\n  }\n}\n\n/** Trigger handlers for a given instrumentation type. */\nfunction triggerHandlers(type, data) {\n  const typeHandlers = type && handlers[type];\n  if (!typeHandlers) {\n    return;\n  }\n\n  for (const handler of typeHandlers) {\n    try {\n      handler(data);\n    } catch (e) {\n      debugBuild.DEBUG_BUILD &&\n        debugLogger.debug.error(\n          `Error while triggering instrumentation handler.\\nType: ${type}\\nName: ${stacktrace.getFunctionName(handler)}\\nError:`,\n          e,\n        );\n    }\n  }\n}\n\nexports.addHandler = addHandler;\nexports.maybeInstrument = maybeInstrument;\nexports.resetInstrumentationHandlers = resetInstrumentationHandlers;\nexports.triggerHandlers = triggerHandlers;\n//# sourceMappingURL=handlers.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnN0cnVtZW50L2hhbmRsZXJzLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLG1CQUFtQixtQkFBTyxDQUFDLDRIQUFtQjtBQUM5QyxvQkFBb0IsbUJBQU8sQ0FBQywwSUFBMEI7QUFDdEQsbUJBQW1CLG1CQUFPLENBQUMsc0lBQXdCOztBQUVuRDtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEdBQUc7QUFDSDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxNQUFNO0FBQ04scUZBQXFGLEtBQUs7QUFDMUY7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQSxNQUFNO0FBQ047QUFDQTtBQUNBLG9FQUFvRSxLQUFLLFVBQVUsb0NBQW9DO0FBQ3ZIO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsa0JBQWtCO0FBQ2xCLHVCQUF1QjtBQUN2QixvQ0FBb0M7QUFDcEMsdUJBQXVCO0FBQ3ZCIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvaW5zdHJ1bWVudC9oYW5kbGVycy5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgZGVidWdCdWlsZCA9IHJlcXVpcmUoJy4uL2RlYnVnLWJ1aWxkLmpzJyk7XG5jb25zdCBkZWJ1Z0xvZ2dlciA9IHJlcXVpcmUoJy4uL3V0aWxzL2RlYnVnLWxvZ2dlci5qcycpO1xuY29uc3Qgc3RhY2t0cmFjZSA9IHJlcXVpcmUoJy4uL3V0aWxzL3N0YWNrdHJhY2UuanMnKTtcblxuLy8gV2Uga2VlcCB0aGUgaGFuZGxlcnMgZ2xvYmFsbHlcbmNvbnN0IGhhbmRsZXJzID0ge307XG5jb25zdCBpbnN0cnVtZW50ZWQgPSB7fTtcblxuLyoqIEFkZCBhIGhhbmRsZXIgZnVuY3Rpb24uICovXG5mdW5jdGlvbiBhZGRIYW5kbGVyKHR5cGUsIGhhbmRsZXIpIHtcbiAgaGFuZGxlcnNbdHlwZV0gPSBoYW5kbGVyc1t0eXBlXSB8fCBbXTtcbiAgKGhhbmRsZXJzW3R5cGVdICkucHVzaChoYW5kbGVyKTtcbn1cblxuLyoqXG4gKiBSZXNldCBhbGwgaW5zdHJ1bWVudGF0aW9uIGhhbmRsZXJzLlxuICogVGhpcyBjYW4gYmUgdXNlZCBieSB0ZXN0cyB0byBlbnN1cmUgd2UgaGF2ZSBhIGNsZWFuIHNsYXRlIG9mIGluc3RydW1lbnRhdGlvbiBoYW5kbGVycy5cbiAqL1xuZnVuY3Rpb24gcmVzZXRJbnN0cnVtZW50YXRpb25IYW5kbGVycygpIHtcbiAgT2JqZWN0LmtleXMoaGFuZGxlcnMpLmZvckVhY2goa2V5ID0+IHtcbiAgICBoYW5kbGVyc1trZXkgXSA9IHVuZGVmaW5lZDtcbiAgfSk7XG59XG5cbi8qKiBNYXliZSBydW4gYW4gaW5zdHJ1bWVudGF0aW9uIGZ1bmN0aW9uLCB1bmxlc3MgaXQgd2FzIGFscmVhZHkgY2FsbGVkLiAqL1xuZnVuY3Rpb24gbWF5YmVJbnN0cnVtZW50KHR5cGUsIGluc3RydW1lbnRGbikge1xuICBpZiAoIWluc3RydW1lbnRlZFt0eXBlXSkge1xuICAgIGluc3RydW1lbnRlZFt0eXBlXSA9IHRydWU7XG4gICAgdHJ5IHtcbiAgICAgIGluc3RydW1lbnRGbigpO1xuICAgIH0gY2F0Y2ggKGUpIHtcbiAgICAgIGRlYnVnQnVpbGQuREVCVUdfQlVJTEQgJiYgZGVidWdMb2dnZXIuZGVidWcuZXJyb3IoYEVycm9yIHdoaWxlIGluc3RydW1lbnRpbmcgJHt0eXBlfWAsIGUpO1xuICAgIH1cbiAgfVxufVxuXG4vKiogVHJpZ2dlciBoYW5kbGVycyBmb3IgYSBnaXZlbiBpbnN0cnVtZW50YXRpb24gdHlwZS4gKi9cbmZ1bmN0aW9uIHRyaWdnZXJIYW5kbGVycyh0eXBlLCBkYXRhKSB7XG4gIGNvbnN0IHR5cGVIYW5kbGVycyA9IHR5cGUgJiYgaGFuZGxlcnNbdHlwZV07XG4gIGlmICghdHlwZUhhbmRsZXJzKSB7XG4gICAgcmV0dXJuO1xuICB9XG5cbiAgZm9yIChjb25zdCBoYW5kbGVyIG9mIHR5cGVIYW5kbGVycykge1xuICAgIHRyeSB7XG4gICAgICBoYW5kbGVyKGRhdGEpO1xuICAgIH0gY2F0Y2ggKGUpIHtcbiAgICAgIGRlYnVnQnVpbGQuREVCVUdfQlVJTEQgJiZcbiAgICAgICAgZGVidWdMb2dnZXIuZGVidWcuZXJyb3IoXG4gICAgICAgICAgYEVycm9yIHdoaWxlIHRyaWdnZXJpbmcgaW5zdHJ1bWVudGF0aW9uIGhhbmRsZXIuXFxuVHlwZTogJHt0eXBlfVxcbk5hbWU6ICR7c3RhY2t0cmFjZS5nZXRGdW5jdGlvbk5hbWUoaGFuZGxlcil9XFxuRXJyb3I6YCxcbiAgICAgICAgICBlLFxuICAgICAgICApO1xuICAgIH1cbiAgfVxufVxuXG5leHBvcnRzLmFkZEhhbmRsZXIgPSBhZGRIYW5kbGVyO1xuZXhwb3J0cy5tYXliZUluc3RydW1lbnQgPSBtYXliZUluc3RydW1lbnQ7XG5leHBvcnRzLnJlc2V0SW5zdHJ1bWVudGF0aW9uSGFuZGxlcnMgPSByZXNldEluc3RydW1lbnRhdGlvbkhhbmRsZXJzO1xuZXhwb3J0cy50cmlnZ2VySGFuZGxlcnMgPSB0cmlnZ2VySGFuZGxlcnM7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1oYW5kbGVycy5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/handlers.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integration.js":
/*!***************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integration.js ***!
  \***************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst currentScopes = __webpack_require__(/*! ./currentScopes.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst debugBuild = __webpack_require__(/*! ./debug-build.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst debugLogger = __webpack_require__(/*! ./utils/debug-logger.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\n\nconst installedIntegrations = [];\n\n/** Map of integrations assigned to a client */\n\n/**\n * Remove duplicates from the given array, preferring the last instance of any duplicate. Not guaranteed to\n * preserve the order of integrations in the array.\n *\n * @private\n */\nfunction filterDuplicates(integrations) {\n  const integrationsByName = {};\n\n  integrations.forEach((currentInstance) => {\n    const { name } = currentInstance;\n\n    const existingInstance = integrationsByName[name];\n\n    // We want integrations later in the array to overwrite earlier ones of the same type, except that we never want a\n    // default instance to overwrite an existing user instance\n    if (existingInstance && !existingInstance.isDefaultInstance && currentInstance.isDefaultInstance) {\n      return;\n    }\n\n    integrationsByName[name] = currentInstance;\n  });\n\n  return Object.values(integrationsByName);\n}\n\n/** Gets integrations to install */\nfunction getIntegrationsToSetup(options) {\n  const defaultIntegrations = options.defaultIntegrations || [];\n  const userIntegrations = options.integrations;\n\n  // We flag default instances, so that later we can tell them apart from any user-created instances of the same class\n  defaultIntegrations.forEach((integration) => {\n    integration.isDefaultInstance = true;\n  });\n\n  let integrations;\n\n  if (Array.isArray(userIntegrations)) {\n    integrations = [...defaultIntegrations, ...userIntegrations];\n  } else if (typeof userIntegrations === 'function') {\n    const resolvedUserIntegrations = userIntegrations(defaultIntegrations);\n    integrations = Array.isArray(resolvedUserIntegrations) ? resolvedUserIntegrations : [resolvedUserIntegrations];\n  } else {\n    integrations = defaultIntegrations;\n  }\n\n  return filterDuplicates(integrations);\n}\n\n/**\n * Given a list of integration instances this installs them all. When `withDefaults` is set to `true` then all default\n * integrations are added unless they were already provided before.\n * @param integrations array of integration instances\n * @param withDefault should enable default integrations\n */\nfunction setupIntegrations(client, integrations) {\n  const integrationIndex = {};\n\n  integrations.forEach((integration) => {\n    // guard against empty provided integrations\n    if (integration) {\n      setupIntegration(client, integration, integrationIndex);\n    }\n  });\n\n  return integrationIndex;\n}\n\n/**\n * Execute the `afterAllSetup` hooks of the given integrations.\n */\nfunction afterSetupIntegrations(client, integrations) {\n  for (const integration of integrations) {\n    // guard against empty provided integrations\n    if (integration?.afterAllSetup) {\n      integration.afterAllSetup(client);\n    }\n  }\n}\n\n/** Setup a single integration.  */\nfunction setupIntegration(client, integration, integrationIndex) {\n  if (integrationIndex[integration.name]) {\n    debugBuild.DEBUG_BUILD && debugLogger.debug.log(`Integration skipped because it was already installed: ${integration.name}`);\n    return;\n  }\n  integrationIndex[integration.name] = integration;\n\n  // `setupOnce` is only called the first time\n  if (installedIntegrations.indexOf(integration.name) === -1 && typeof integration.setupOnce === 'function') {\n    integration.setupOnce();\n    installedIntegrations.push(integration.name);\n  }\n\n  // `setup` is run for each client\n  if (integration.setup && typeof integration.setup === 'function') {\n    integration.setup(client);\n  }\n\n  if (typeof integration.preprocessEvent === 'function') {\n    const callback = integration.preprocessEvent.bind(integration) ;\n    client.on('preprocessEvent', (event, hint) => callback(event, hint, client));\n  }\n\n  if (typeof integration.processEvent === 'function') {\n    const callback = integration.processEvent.bind(integration) ;\n\n    const processor = Object.assign((event, hint) => callback(event, hint, client), {\n      id: integration.name,\n    });\n\n    client.addEventProcessor(processor);\n  }\n\n  debugBuild.DEBUG_BUILD && debugLogger.debug.log(`Integration installed: ${integration.name}`);\n}\n\n/** Add an integration to the current scope's client. */\nfunction addIntegration(integration) {\n  const client = currentScopes.getClient();\n\n  if (!client) {\n    debugBuild.DEBUG_BUILD && debugLogger.debug.warn(`Cannot add integration \"${integration.name}\" because no SDK Client is available.`);\n    return;\n  }\n\n  client.addIntegration(integration);\n}\n\n/**\n * Define an integration function that can be used to create an integration instance.\n * Note that this by design hides the implementation details of the integration, as they are considered internal.\n */\nfunction defineIntegration(fn) {\n  return fn;\n}\n\nexports.addIntegration = addIntegration;\nexports.afterSetupIntegrations = afterSetupIntegrations;\nexports.defineIntegration = defineIntegration;\nexports.getIntegrationsToSetup = getIntegrationsToSetup;\nexports.installedIntegrations = installedIntegrations;\nexports.setupIntegration = setupIntegration;\nexports.setupIntegrations = setupIntegrations;\n//# sourceMappingURL=integration.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbi5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxzQkFBc0IsbUJBQU8sQ0FBQywrSEFBb0I7QUFDbEQsbUJBQW1CLG1CQUFPLENBQUMsMkhBQWtCO0FBQzdDLG9CQUFvQixtQkFBTyxDQUFDLHlJQUF5Qjs7QUFFckQ7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBLFlBQVksT0FBTzs7QUFFbkI7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBLEdBQUc7O0FBRUg7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQSxHQUFHOztBQUVIOztBQUVBO0FBQ0E7QUFDQSxJQUFJO0FBQ0o7QUFDQTtBQUNBLElBQUk7QUFDSjtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsR0FBRzs7QUFFSDtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0EsNkdBQTZHLGlCQUFpQjtBQUM5SDtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQSxLQUFLOztBQUVMO0FBQ0E7O0FBRUEsNEVBQTRFLGlCQUFpQjtBQUM3Rjs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQSxnRkFBZ0YsaUJBQWlCO0FBQ2pHO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSxzQkFBc0I7QUFDdEIsOEJBQThCO0FBQzlCLHlCQUF5QjtBQUN6Qiw4QkFBOEI7QUFDOUIsNkJBQTZCO0FBQzdCLHdCQUF3QjtBQUN4Qix5QkFBeUI7QUFDekIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbi5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgY3VycmVudFNjb3BlcyA9IHJlcXVpcmUoJy4vY3VycmVudFNjb3Blcy5qcycpO1xuY29uc3QgZGVidWdCdWlsZCA9IHJlcXVpcmUoJy4vZGVidWctYnVpbGQuanMnKTtcbmNvbnN0IGRlYnVnTG9nZ2VyID0gcmVxdWlyZSgnLi91dGlscy9kZWJ1Zy1sb2dnZXIuanMnKTtcblxuY29uc3QgaW5zdGFsbGVkSW50ZWdyYXRpb25zID0gW107XG5cbi8qKiBNYXAgb2YgaW50ZWdyYXRpb25zIGFzc2lnbmVkIHRvIGEgY2xpZW50ICovXG5cbi8qKlxuICogUmVtb3ZlIGR1cGxpY2F0ZXMgZnJvbSB0aGUgZ2l2ZW4gYXJyYXksIHByZWZlcnJpbmcgdGhlIGxhc3QgaW5zdGFuY2Ugb2YgYW55IGR1cGxpY2F0ZS4gTm90IGd1YXJhbnRlZWQgdG9cbiAqIHByZXNlcnZlIHRoZSBvcmRlciBvZiBpbnRlZ3JhdGlvbnMgaW4gdGhlIGFycmF5LlxuICpcbiAqIEBwcml2YXRlXG4gKi9cbmZ1bmN0aW9uIGZpbHRlckR1cGxpY2F0ZXMoaW50ZWdyYXRpb25zKSB7XG4gIGNvbnN0IGludGVncmF0aW9uc0J5TmFtZSA9IHt9O1xuXG4gIGludGVncmF0aW9ucy5mb3JFYWNoKChjdXJyZW50SW5zdGFuY2UpID0+IHtcbiAgICBjb25zdCB7IG5hbWUgfSA9IGN1cnJlbnRJbnN0YW5jZTtcblxuICAgIGNvbnN0IGV4aXN0aW5nSW5zdGFuY2UgPSBpbnRlZ3JhdGlvbnNCeU5hbWVbbmFtZV07XG5cbiAgICAvLyBXZSB3YW50IGludGVncmF0aW9ucyBsYXRlciBpbiB0aGUgYXJyYXkgdG8gb3ZlcndyaXRlIGVhcmxpZXIgb25lcyBvZiB0aGUgc2FtZSB0eXBlLCBleGNlcHQgdGhhdCB3ZSBuZXZlciB3YW50IGFcbiAgICAvLyBkZWZhdWx0IGluc3RhbmNlIHRvIG92ZXJ3cml0ZSBhbiBleGlzdGluZyB1c2VyIGluc3RhbmNlXG4gICAgaWYgKGV4aXN0aW5nSW5zdGFuY2UgJiYgIWV4aXN0aW5nSW5zdGFuY2UuaXNEZWZhdWx0SW5zdGFuY2UgJiYgY3VycmVudEluc3RhbmNlLmlzRGVmYXVsdEluc3RhbmNlKSB7XG4gICAgICByZXR1cm47XG4gICAgfVxuXG4gICAgaW50ZWdyYXRpb25zQnlOYW1lW25hbWVdID0gY3VycmVudEluc3RhbmNlO1xuICB9KTtcblxuICByZXR1cm4gT2JqZWN0LnZhbHVlcyhpbnRlZ3JhdGlvbnNCeU5hbWUpO1xufVxuXG4vKiogR2V0cyBpbnRlZ3JhdGlvbnMgdG8gaW5zdGFsbCAqL1xuZnVuY3Rpb24gZ2V0SW50ZWdyYXRpb25zVG9TZXR1cChvcHRpb25zKSB7XG4gIGNvbnN0IGRlZmF1bHRJbnRlZ3JhdGlvbnMgPSBvcHRpb25zLmRlZmF1bHRJbnRlZ3JhdGlvbnMgfHwgW107XG4gIGNvbnN0IHVzZXJJbnRlZ3JhdGlvbnMgPSBvcHRpb25zLmludGVncmF0aW9ucztcblxuICAvLyBXZSBmbGFnIGRlZmF1bHQgaW5zdGFuY2VzLCBzbyB0aGF0IGxhdGVyIHdlIGNhbiB0ZWxsIHRoZW0gYXBhcnQgZnJvbSBhbnkgdXNlci1jcmVhdGVkIGluc3RhbmNlcyBvZiB0aGUgc2FtZSBjbGFzc1xuICBkZWZhdWx0SW50ZWdyYXRpb25zLmZvckVhY2goKGludGVncmF0aW9uKSA9PiB7XG4gICAgaW50ZWdyYXRpb24uaXNEZWZhdWx0SW5zdGFuY2UgPSB0cnVlO1xuICB9KTtcblxuICBsZXQgaW50ZWdyYXRpb25zO1xuXG4gIGlmIChBcnJheS5pc0FycmF5KHVzZXJJbnRlZ3JhdGlvbnMpKSB7XG4gICAgaW50ZWdyYXRpb25zID0gWy4uLmRlZmF1bHRJbnRlZ3JhdGlvbnMsIC4uLnVzZXJJbnRlZ3JhdGlvbnNdO1xuICB9IGVsc2UgaWYgKHR5cGVvZiB1c2VySW50ZWdyYXRpb25zID09PSAnZnVuY3Rpb24nKSB7XG4gICAgY29uc3QgcmVzb2x2ZWRVc2VySW50ZWdyYXRpb25zID0gdXNlckludGVncmF0aW9ucyhkZWZhdWx0SW50ZWdyYXRpb25zKTtcbiAgICBpbnRlZ3JhdGlvbnMgPSBBcnJheS5pc0FycmF5KHJlc29sdmVkVXNlckludGVncmF0aW9ucykgPyByZXNvbHZlZFVzZXJJbnRlZ3JhdGlvbnMgOiBbcmVzb2x2ZWRVc2VySW50ZWdyYXRpb25zXTtcbiAgfSBlbHNlIHtcbiAgICBpbnRlZ3JhdGlvbnMgPSBkZWZhdWx0SW50ZWdyYXRpb25zO1xuICB9XG5cbiAgcmV0dXJuIGZpbHRlckR1cGxpY2F0ZXMoaW50ZWdyYXRpb25zKTtcbn1cblxuLyoqXG4gKiBHaXZlbiBhIGxpc3Qgb2YgaW50ZWdyYXRpb24gaW5zdGFuY2VzIHRoaXMgaW5zdGFsbHMgdGhlbSBhbGwuIFdoZW4gYHdpdGhEZWZhdWx0c2AgaXMgc2V0IHRvIGB0cnVlYCB0aGVuIGFsbCBkZWZhdWx0XG4gKiBpbnRlZ3JhdGlvbnMgYXJlIGFkZGVkIHVubGVzcyB0aGV5IHdlcmUgYWxyZWFkeSBwcm92aWRlZCBiZWZvcmUuXG4gKiBAcGFyYW0gaW50ZWdyYXRpb25zIGFycmF5IG9mIGludGVncmF0aW9uIGluc3RhbmNlc1xuICogQHBhcmFtIHdpdGhEZWZhdWx0IHNob3VsZCBlbmFibGUgZGVmYXVsdCBpbnRlZ3JhdGlvbnNcbiAqL1xuZnVuY3Rpb24gc2V0dXBJbnRlZ3JhdGlvbnMoY2xpZW50LCBpbnRlZ3JhdGlvbnMpIHtcbiAgY29uc3QgaW50ZWdyYXRpb25JbmRleCA9IHt9O1xuXG4gIGludGVncmF0aW9ucy5mb3JFYWNoKChpbnRlZ3JhdGlvbikgPT4ge1xuICAgIC8vIGd1YXJkIGFnYWluc3QgZW1wdHkgcHJvdmlkZWQgaW50ZWdyYXRpb25zXG4gICAgaWYgKGludGVncmF0aW9uKSB7XG4gICAgICBzZXR1cEludGVncmF0aW9uKGNsaWVudCwgaW50ZWdyYXRpb24sIGludGVncmF0aW9uSW5kZXgpO1xuICAgIH1cbiAgfSk7XG5cbiAgcmV0dXJuIGludGVncmF0aW9uSW5kZXg7XG59XG5cbi8qKlxuICogRXhlY3V0ZSB0aGUgYGFmdGVyQWxsU2V0dXBgIGhvb2tzIG9mIHRoZSBnaXZlbiBpbnRlZ3JhdGlvbnMuXG4gKi9cbmZ1bmN0aW9uIGFmdGVyU2V0dXBJbnRlZ3JhdGlvbnMoY2xpZW50LCBpbnRlZ3JhdGlvbnMpIHtcbiAgZm9yIChjb25zdCBpbnRlZ3JhdGlvbiBvZiBpbnRlZ3JhdGlvbnMpIHtcbiAgICAvLyBndWFyZCBhZ2FpbnN0IGVtcHR5IHByb3ZpZGVkIGludGVncmF0aW9uc1xuICAgIGlmIChpbnRlZ3JhdGlvbj8uYWZ0ZXJBbGxTZXR1cCkge1xuICAgICAgaW50ZWdyYXRpb24uYWZ0ZXJBbGxTZXR1cChjbGllbnQpO1xuICAgIH1cbiAgfVxufVxuXG4vKiogU2V0dXAgYSBzaW5nbGUgaW50ZWdyYXRpb24uICAqL1xuZnVuY3Rpb24gc2V0dXBJbnRlZ3JhdGlvbihjbGllbnQsIGludGVncmF0aW9uLCBpbnRlZ3JhdGlvbkluZGV4KSB7XG4gIGlmIChpbnRlZ3JhdGlvbkluZGV4W2ludGVncmF0aW9uLm5hbWVdKSB7XG4gICAgZGVidWdCdWlsZC5ERUJVR19CVUlMRCAmJiBkZWJ1Z0xvZ2dlci5kZWJ1Zy5sb2coYEludGVncmF0aW9uIHNraXBwZWQgYmVjYXVzZSBpdCB3YXMgYWxyZWFkeSBpbnN0YWxsZWQ6ICR7aW50ZWdyYXRpb24ubmFtZX1gKTtcbiAgICByZXR1cm47XG4gIH1cbiAgaW50ZWdyYXRpb25JbmRleFtpbnRlZ3JhdGlvbi5uYW1lXSA9IGludGVncmF0aW9uO1xuXG4gIC8vIGBzZXR1cE9uY2VgIGlzIG9ubHkgY2FsbGVkIHRoZSBmaXJzdCB0aW1lXG4gIGlmIChpbnN0YWxsZWRJbnRlZ3JhdGlvbnMuaW5kZXhPZihpbnRlZ3JhdGlvbi5uYW1lKSA9PT0gLTEgJiYgdHlwZW9mIGludGVncmF0aW9uLnNldHVwT25jZSA9PT0gJ2Z1bmN0aW9uJykge1xuICAgIGludGVncmF0aW9uLnNldHVwT25jZSgpO1xuICAgIGluc3RhbGxlZEludGVncmF0aW9ucy5wdXNoKGludGVncmF0aW9uLm5hbWUpO1xuICB9XG5cbiAgLy8gYHNldHVwYCBpcyBydW4gZm9yIGVhY2ggY2xpZW50XG4gIGlmIChpbnRlZ3JhdGlvbi5zZXR1cCAmJiB0eXBlb2YgaW50ZWdyYXRpb24uc2V0dXAgPT09ICdmdW5jdGlvbicpIHtcbiAgICBpbnRlZ3JhdGlvbi5zZXR1cChjbGllbnQpO1xuICB9XG5cbiAgaWYgKHR5cGVvZiBpbnRlZ3JhdGlvbi5wcmVwcm9jZXNzRXZlbnQgPT09ICdmdW5jdGlvbicpIHtcbiAgICBjb25zdCBjYWxsYmFjayA9IGludGVncmF0aW9uLnByZXByb2Nlc3NFdmVudC5iaW5kKGludGVncmF0aW9uKSA7XG4gICAgY2xpZW50Lm9uKCdwcmVwcm9jZXNzRXZlbnQnLCAoZXZlbnQsIGhpbnQpID0+IGNhbGxiYWNrKGV2ZW50LCBoaW50LCBjbGllbnQpKTtcbiAgfVxuXG4gIGlmICh0eXBlb2YgaW50ZWdyYXRpb24ucHJvY2Vzc0V2ZW50ID09PSAnZnVuY3Rpb24nKSB7XG4gICAgY29uc3QgY2FsbGJhY2sgPSBpbnRlZ3JhdGlvbi5wcm9jZXNzRXZlbnQuYmluZChpbnRlZ3JhdGlvbikgO1xuXG4gICAgY29uc3QgcHJvY2Vzc29yID0gT2JqZWN0LmFzc2lnbigoZXZlbnQsIGhpbnQpID0+IGNhbGxiYWNrKGV2ZW50LCBoaW50LCBjbGllbnQpLCB7XG4gICAgICBpZDogaW50ZWdyYXRpb24ubmFtZSxcbiAgICB9KTtcblxuICAgIGNsaWVudC5hZGRFdmVudFByb2Nlc3Nvcihwcm9jZXNzb3IpO1xuICB9XG5cbiAgZGVidWdCdWlsZC5ERUJVR19CVUlMRCAmJiBkZWJ1Z0xvZ2dlci5kZWJ1Zy5sb2coYEludGVncmF0aW9uIGluc3RhbGxlZDogJHtpbnRlZ3JhdGlvbi5uYW1lfWApO1xufVxuXG4vKiogQWRkIGFuIGludGVncmF0aW9uIHRvIHRoZSBjdXJyZW50IHNjb3BlJ3MgY2xpZW50LiAqL1xuZnVuY3Rpb24gYWRkSW50ZWdyYXRpb24oaW50ZWdyYXRpb24pIHtcbiAgY29uc3QgY2xpZW50ID0gY3VycmVudFNjb3Blcy5nZXRDbGllbnQoKTtcblxuICBpZiAoIWNsaWVudCkge1xuICAgIGRlYnVnQnVpbGQuREVCVUdfQlVJTEQgJiYgZGVidWdMb2dnZXIuZGVidWcud2FybihgQ2Fubm90IGFkZCBpbnRlZ3JhdGlvbiBcIiR7aW50ZWdyYXRpb24ubmFtZX1cIiBiZWNhdXNlIG5vIFNESyBDbGllbnQgaXMgYXZhaWxhYmxlLmApO1xuICAgIHJldHVybjtcbiAgfVxuXG4gIGNsaWVudC5hZGRJbnRlZ3JhdGlvbihpbnRlZ3JhdGlvbik7XG59XG5cbi8qKlxuICogRGVmaW5lIGFuIGludGVncmF0aW9uIGZ1bmN0aW9uIHRoYXQgY2FuIGJlIHVzZWQgdG8gY3JlYXRlIGFuIGludGVncmF0aW9uIGluc3RhbmNlLlxuICogTm90ZSB0aGF0IHRoaXMgYnkgZGVzaWduIGhpZGVzIHRoZSBpbXBsZW1lbnRhdGlvbiBkZXRhaWxzIG9mIHRoZSBpbnRlZ3JhdGlvbiwgYXMgdGhleSBhcmUgY29uc2lkZXJlZCBpbnRlcm5hbC5cbiAqL1xuZnVuY3Rpb24gZGVmaW5lSW50ZWdyYXRpb24oZm4pIHtcbiAgcmV0dXJuIGZuO1xufVxuXG5leHBvcnRzLmFkZEludGVncmF0aW9uID0gYWRkSW50ZWdyYXRpb247XG5leHBvcnRzLmFmdGVyU2V0dXBJbnRlZ3JhdGlvbnMgPSBhZnRlclNldHVwSW50ZWdyYXRpb25zO1xuZXhwb3J0cy5kZWZpbmVJbnRlZ3JhdGlvbiA9IGRlZmluZUludGVncmF0aW9uO1xuZXhwb3J0cy5nZXRJbnRlZ3JhdGlvbnNUb1NldHVwID0gZ2V0SW50ZWdyYXRpb25zVG9TZXR1cDtcbmV4cG9ydHMuaW5zdGFsbGVkSW50ZWdyYXRpb25zID0gaW5zdGFsbGVkSW50ZWdyYXRpb25zO1xuZXhwb3J0cy5zZXR1cEludGVncmF0aW9uID0gc2V0dXBJbnRlZ3JhdGlvbjtcbmV4cG9ydHMuc2V0dXBJbnRlZ3JhdGlvbnMgPSBzZXR1cEludGVncmF0aW9ucztcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWludGVncmF0aW9uLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integration.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/captureconsole.js":
/*!*******************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/captureconsole.js ***!
  \*******************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst currentScopes = __webpack_require__(/*! ../currentScopes.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst exports$1 = __webpack_require__(/*! ../exports.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/exports.js\");\nconst console = __webpack_require__(/*! ../instrument/console.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/console.js\");\nconst integration = __webpack_require__(/*! ../integration.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integration.js\");\nconst debugLogger = __webpack_require__(/*! ../utils/debug-logger.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst misc = __webpack_require__(/*! ../utils/misc.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/misc.js\");\nconst severity = __webpack_require__(/*! ../utils/severity.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/severity.js\");\nconst string = __webpack_require__(/*! ../utils/string.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/string.js\");\nconst worldwide = __webpack_require__(/*! ../utils/worldwide.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/worldwide.js\");\n\nconst INTEGRATION_NAME = 'CaptureConsole';\n\nconst _captureConsoleIntegration = ((options = {}) => {\n  const levels = options.levels || debugLogger.CONSOLE_LEVELS;\n  const handled = options.handled ?? true;\n\n  return {\n    name: INTEGRATION_NAME,\n    setup(client) {\n      if (!('console' in worldwide.GLOBAL_OBJ)) {\n        return;\n      }\n\n      console.addConsoleInstrumentationHandler(({ args, level }) => {\n        if (currentScopes.getClient() !== client || !levels.includes(level)) {\n          return;\n        }\n\n        consoleHandler(args, level, handled);\n      });\n    },\n  };\n}) ;\n\n/**\n * Send Console API calls as Sentry Events.\n */\nconst captureConsoleIntegration = integration.defineIntegration(_captureConsoleIntegration);\n\nfunction consoleHandler(args, level, handled) {\n  const captureContext = {\n    level: severity.severityLevelFromString(level),\n    extra: {\n      arguments: args,\n    },\n  };\n\n  currentScopes.withScope(scope => {\n    scope.addEventProcessor(event => {\n      event.logger = 'console';\n\n      misc.addExceptionMechanism(event, {\n        handled,\n        type: 'console',\n      });\n\n      return event;\n    });\n\n    if (level === 'assert') {\n      if (!args[0]) {\n        const message = `Assertion failed: ${string.safeJoin(args.slice(1), ' ') || 'console.assert'}`;\n        scope.setExtra('arguments', args.slice(1));\n        exports$1.captureMessage(message, captureContext);\n      }\n      return;\n    }\n\n    const error = args.find(arg => arg instanceof Error);\n    if (error) {\n      exports$1.captureException(error, captureContext);\n      return;\n    }\n\n    const message = string.safeJoin(args, ' ');\n    exports$1.captureMessage(message, captureContext);\n  });\n}\n\nexports.captureConsoleIntegration = captureConsoleIntegration;\n//# sourceMappingURL=captureconsole.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvY2FwdHVyZWNvbnNvbGUuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsc0JBQXNCLG1CQUFPLENBQUMsZ0lBQXFCO0FBQ25ELGtCQUFrQixtQkFBTyxDQUFDLG9IQUFlO0FBQ3pDLGdCQUFnQixtQkFBTyxDQUFDLDBJQUEwQjtBQUNsRCxvQkFBb0IsbUJBQU8sQ0FBQyw0SEFBbUI7QUFDL0Msb0JBQW9CLG1CQUFPLENBQUMsMElBQTBCO0FBQ3RELGFBQWEsbUJBQU8sQ0FBQywwSEFBa0I7QUFDdkMsaUJBQWlCLG1CQUFPLENBQUMsa0lBQXNCO0FBQy9DLGVBQWUsbUJBQU8sQ0FBQyw4SEFBb0I7QUFDM0Msa0JBQWtCLG1CQUFPLENBQUMsb0lBQXVCOztBQUVqRDs7QUFFQSxpREFBaUQ7QUFDakQ7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsa0RBQWtELGFBQWE7QUFDL0Q7QUFDQTtBQUNBOztBQUVBO0FBQ0EsT0FBTztBQUNQLEtBQUs7QUFDTDtBQUNBLENBQUM7O0FBRUQ7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEtBQUs7QUFDTDs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0EsT0FBTzs7QUFFUDtBQUNBLEtBQUs7O0FBRUw7QUFDQTtBQUNBLDZDQUE2Qyx3REFBd0Q7QUFDckc7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQSxHQUFHO0FBQ0g7O0FBRUEsaUNBQWlDO0FBQ2pDIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvaW50ZWdyYXRpb25zL2NhcHR1cmVjb25zb2xlLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBjdXJyZW50U2NvcGVzID0gcmVxdWlyZSgnLi4vY3VycmVudFNjb3Blcy5qcycpO1xuY29uc3QgZXhwb3J0cyQxID0gcmVxdWlyZSgnLi4vZXhwb3J0cy5qcycpO1xuY29uc3QgY29uc29sZSA9IHJlcXVpcmUoJy4uL2luc3RydW1lbnQvY29uc29sZS5qcycpO1xuY29uc3QgaW50ZWdyYXRpb24gPSByZXF1aXJlKCcuLi9pbnRlZ3JhdGlvbi5qcycpO1xuY29uc3QgZGVidWdMb2dnZXIgPSByZXF1aXJlKCcuLi91dGlscy9kZWJ1Zy1sb2dnZXIuanMnKTtcbmNvbnN0IG1pc2MgPSByZXF1aXJlKCcuLi91dGlscy9taXNjLmpzJyk7XG5jb25zdCBzZXZlcml0eSA9IHJlcXVpcmUoJy4uL3V0aWxzL3NldmVyaXR5LmpzJyk7XG5jb25zdCBzdHJpbmcgPSByZXF1aXJlKCcuLi91dGlscy9zdHJpbmcuanMnKTtcbmNvbnN0IHdvcmxkd2lkZSA9IHJlcXVpcmUoJy4uL3V0aWxzL3dvcmxkd2lkZS5qcycpO1xuXG5jb25zdCBJTlRFR1JBVElPTl9OQU1FID0gJ0NhcHR1cmVDb25zb2xlJztcblxuY29uc3QgX2NhcHR1cmVDb25zb2xlSW50ZWdyYXRpb24gPSAoKG9wdGlvbnMgPSB7fSkgPT4ge1xuICBjb25zdCBsZXZlbHMgPSBvcHRpb25zLmxldmVscyB8fCBkZWJ1Z0xvZ2dlci5DT05TT0xFX0xFVkVMUztcbiAgY29uc3QgaGFuZGxlZCA9IG9wdGlvbnMuaGFuZGxlZCA/PyB0cnVlO1xuXG4gIHJldHVybiB7XG4gICAgbmFtZTogSU5URUdSQVRJT05fTkFNRSxcbiAgICBzZXR1cChjbGllbnQpIHtcbiAgICAgIGlmICghKCdjb25zb2xlJyBpbiB3b3JsZHdpZGUuR0xPQkFMX09CSikpIHtcbiAgICAgICAgcmV0dXJuO1xuICAgICAgfVxuXG4gICAgICBjb25zb2xlLmFkZENvbnNvbGVJbnN0cnVtZW50YXRpb25IYW5kbGVyKCh7IGFyZ3MsIGxldmVsIH0pID0+IHtcbiAgICAgICAgaWYgKGN1cnJlbnRTY29wZXMuZ2V0Q2xpZW50KCkgIT09IGNsaWVudCB8fCAhbGV2ZWxzLmluY2x1ZGVzKGxldmVsKSkge1xuICAgICAgICAgIHJldHVybjtcbiAgICAgICAgfVxuXG4gICAgICAgIGNvbnNvbGVIYW5kbGVyKGFyZ3MsIGxldmVsLCBoYW5kbGVkKTtcbiAgICAgIH0pO1xuICAgIH0sXG4gIH07XG59KSA7XG5cbi8qKlxuICogU2VuZCBDb25zb2xlIEFQSSBjYWxscyBhcyBTZW50cnkgRXZlbnRzLlxuICovXG5jb25zdCBjYXB0dXJlQ29uc29sZUludGVncmF0aW9uID0gaW50ZWdyYXRpb24uZGVmaW5lSW50ZWdyYXRpb24oX2NhcHR1cmVDb25zb2xlSW50ZWdyYXRpb24pO1xuXG5mdW5jdGlvbiBjb25zb2xlSGFuZGxlcihhcmdzLCBsZXZlbCwgaGFuZGxlZCkge1xuICBjb25zdCBjYXB0dXJlQ29udGV4dCA9IHtcbiAgICBsZXZlbDogc2V2ZXJpdHkuc2V2ZXJpdHlMZXZlbEZyb21TdHJpbmcobGV2ZWwpLFxuICAgIGV4dHJhOiB7XG4gICAgICBhcmd1bWVudHM6IGFyZ3MsXG4gICAgfSxcbiAgfTtcblxuICBjdXJyZW50U2NvcGVzLndpdGhTY29wZShzY29wZSA9PiB7XG4gICAgc2NvcGUuYWRkRXZlbnRQcm9jZXNzb3IoZXZlbnQgPT4ge1xuICAgICAgZXZlbnQubG9nZ2VyID0gJ2NvbnNvbGUnO1xuXG4gICAgICBtaXNjLmFkZEV4Y2VwdGlvbk1lY2hhbmlzbShldmVudCwge1xuICAgICAgICBoYW5kbGVkLFxuICAgICAgICB0eXBlOiAnY29uc29sZScsXG4gICAgICB9KTtcblxuICAgICAgcmV0dXJuIGV2ZW50O1xuICAgIH0pO1xuXG4gICAgaWYgKGxldmVsID09PSAnYXNzZXJ0Jykge1xuICAgICAgaWYgKCFhcmdzWzBdKSB7XG4gICAgICAgIGNvbnN0IG1lc3NhZ2UgPSBgQXNzZXJ0aW9uIGZhaWxlZDogJHtzdHJpbmcuc2FmZUpvaW4oYXJncy5zbGljZSgxKSwgJyAnKSB8fCAnY29uc29sZS5hc3NlcnQnfWA7XG4gICAgICAgIHNjb3BlLnNldEV4dHJhKCdhcmd1bWVudHMnLCBhcmdzLnNsaWNlKDEpKTtcbiAgICAgICAgZXhwb3J0cyQxLmNhcHR1cmVNZXNzYWdlKG1lc3NhZ2UsIGNhcHR1cmVDb250ZXh0KTtcbiAgICAgIH1cbiAgICAgIHJldHVybjtcbiAgICB9XG5cbiAgICBjb25zdCBlcnJvciA9IGFyZ3MuZmluZChhcmcgPT4gYXJnIGluc3RhbmNlb2YgRXJyb3IpO1xuICAgIGlmIChlcnJvcikge1xuICAgICAgZXhwb3J0cyQxLmNhcHR1cmVFeGNlcHRpb24oZXJyb3IsIGNhcHR1cmVDb250ZXh0KTtcbiAgICAgIHJldHVybjtcbiAgICB9XG5cbiAgICBjb25zdCBtZXNzYWdlID0gc3RyaW5nLnNhZmVKb2luKGFyZ3MsICcgJyk7XG4gICAgZXhwb3J0cyQxLmNhcHR1cmVNZXNzYWdlKG1lc3NhZ2UsIGNhcHR1cmVDb250ZXh0KTtcbiAgfSk7XG59XG5cbmV4cG9ydHMuY2FwdHVyZUNvbnNvbGVJbnRlZ3JhdGlvbiA9IGNhcHR1cmVDb25zb2xlSW50ZWdyYXRpb247XG4vLyMgc291cmNlTWFwcGluZ1VSTD1jYXB0dXJlY29uc29sZS5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/captureconsole.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/console.js":
/*!************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/console.js ***!
  \************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst breadcrumbs = __webpack_require__(/*! ../breadcrumbs.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/breadcrumbs.js\");\nconst currentScopes = __webpack_require__(/*! ../currentScopes.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst console = __webpack_require__(/*! ../instrument/console.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/console.js\");\nconst integration = __webpack_require__(/*! ../integration.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integration.js\");\nconst debugLogger = __webpack_require__(/*! ../utils/debug-logger.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst severity = __webpack_require__(/*! ../utils/severity.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/severity.js\");\nconst string = __webpack_require__(/*! ../utils/string.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/string.js\");\nconst worldwide = __webpack_require__(/*! ../utils/worldwide.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/worldwide.js\");\n\nconst INTEGRATION_NAME = 'Console';\n\n/**\n * Captures calls to the `console` API as breadcrumbs in Sentry.\n *\n * By default the integration instruments `console.debug`, `console.info`, `console.warn`, `console.error`,\n * `console.log`, `console.trace`, and `console.assert`. You can use the `levels` option to customize which\n * levels are captured.\n *\n * @example\n *\n * ```js\n * Sentry.init({\n *   integrations: [Sentry.consoleIntegration({ levels: ['error', 'warn'] })],\n * });\n * ```\n */\nconst consoleIntegration = integration.defineIntegration((options = {}) => {\n  const levels = new Set(options.levels || debugLogger.CONSOLE_LEVELS);\n\n  return {\n    name: INTEGRATION_NAME,\n    setup(client) {\n      console.addConsoleInstrumentationHandler(({ args, level }) => {\n        if (currentScopes.getClient() !== client || !levels.has(level)) {\n          return;\n        }\n\n        addConsoleBreadcrumb(level, args);\n      });\n    },\n  };\n});\n\n/**\n * Capture a console breadcrumb.\n *\n * Exported just for tests.\n */\nfunction addConsoleBreadcrumb(level, args) {\n  const breadcrumb = {\n    category: 'console',\n    data: {\n      arguments: args,\n      logger: 'console',\n    },\n    level: severity.severityLevelFromString(level),\n    message: formatConsoleArgs(args),\n  };\n\n  if (level === 'assert') {\n    if (args[0] === false) {\n      const assertionArgs = args.slice(1);\n      breadcrumb.message =\n        assertionArgs.length > 0 ? `Assertion failed: ${formatConsoleArgs(assertionArgs)}` : 'Assertion failed';\n      breadcrumb.data.arguments = assertionArgs;\n    } else {\n      // Don't capture a breadcrumb for passed assertions\n      return;\n    }\n  }\n\n  breadcrumbs.addBreadcrumb(breadcrumb, {\n    input: args,\n    level,\n  });\n}\n\nfunction formatConsoleArgs(values) {\n  return 'util' in worldwide.GLOBAL_OBJ && typeof (worldwide.GLOBAL_OBJ ).util.format === 'function'\n    ? (worldwide.GLOBAL_OBJ ).util.format(...values)\n    : string.safeJoin(values, ' ');\n}\n\nexports.addConsoleBreadcrumb = addConsoleBreadcrumb;\nexports.consoleIntegration = consoleIntegration;\n//# sourceMappingURL=console.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvY29uc29sZS5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxvQkFBb0IsbUJBQU8sQ0FBQyw0SEFBbUI7QUFDL0Msc0JBQXNCLG1CQUFPLENBQUMsZ0lBQXFCO0FBQ25ELGdCQUFnQixtQkFBTyxDQUFDLDBJQUEwQjtBQUNsRCxvQkFBb0IsbUJBQU8sQ0FBQyw0SEFBbUI7QUFDL0Msb0JBQW9CLG1CQUFPLENBQUMsMElBQTBCO0FBQ3RELGlCQUFpQixtQkFBTyxDQUFDLGtJQUFzQjtBQUMvQyxlQUFlLG1CQUFPLENBQUMsOEhBQW9CO0FBQzNDLGtCQUFrQixtQkFBTyxDQUFDLG9JQUF1Qjs7QUFFakQ7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGdEQUFnRCwyQkFBMkI7QUFDM0UsSUFBSTtBQUNKO0FBQ0E7QUFDQSxzRUFBc0U7QUFDdEU7O0FBRUE7QUFDQTtBQUNBO0FBQ0Esa0RBQWtELGFBQWE7QUFDL0Q7QUFDQTtBQUNBOztBQUVBO0FBQ0EsT0FBTztBQUNQLEtBQUs7QUFDTDtBQUNBLENBQUM7O0FBRUQ7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEtBQUs7QUFDTDtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQSx3REFBd0QsaUNBQWlDO0FBQ3pGO0FBQ0EsTUFBTTtBQUNOO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBLEdBQUc7QUFDSDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLDRCQUE0QjtBQUM1QiwwQkFBMEI7QUFDMUIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvY29uc29sZS5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgYnJlYWRjcnVtYnMgPSByZXF1aXJlKCcuLi9icmVhZGNydW1icy5qcycpO1xuY29uc3QgY3VycmVudFNjb3BlcyA9IHJlcXVpcmUoJy4uL2N1cnJlbnRTY29wZXMuanMnKTtcbmNvbnN0IGNvbnNvbGUgPSByZXF1aXJlKCcuLi9pbnN0cnVtZW50L2NvbnNvbGUuanMnKTtcbmNvbnN0IGludGVncmF0aW9uID0gcmVxdWlyZSgnLi4vaW50ZWdyYXRpb24uanMnKTtcbmNvbnN0IGRlYnVnTG9nZ2VyID0gcmVxdWlyZSgnLi4vdXRpbHMvZGVidWctbG9nZ2VyLmpzJyk7XG5jb25zdCBzZXZlcml0eSA9IHJlcXVpcmUoJy4uL3V0aWxzL3NldmVyaXR5LmpzJyk7XG5jb25zdCBzdHJpbmcgPSByZXF1aXJlKCcuLi91dGlscy9zdHJpbmcuanMnKTtcbmNvbnN0IHdvcmxkd2lkZSA9IHJlcXVpcmUoJy4uL3V0aWxzL3dvcmxkd2lkZS5qcycpO1xuXG5jb25zdCBJTlRFR1JBVElPTl9OQU1FID0gJ0NvbnNvbGUnO1xuXG4vKipcbiAqIENhcHR1cmVzIGNhbGxzIHRvIHRoZSBgY29uc29sZWAgQVBJIGFzIGJyZWFkY3J1bWJzIGluIFNlbnRyeS5cbiAqXG4gKiBCeSBkZWZhdWx0IHRoZSBpbnRlZ3JhdGlvbiBpbnN0cnVtZW50cyBgY29uc29sZS5kZWJ1Z2AsIGBjb25zb2xlLmluZm9gLCBgY29uc29sZS53YXJuYCwgYGNvbnNvbGUuZXJyb3JgLFxuICogYGNvbnNvbGUubG9nYCwgYGNvbnNvbGUudHJhY2VgLCBhbmQgYGNvbnNvbGUuYXNzZXJ0YC4gWW91IGNhbiB1c2UgdGhlIGBsZXZlbHNgIG9wdGlvbiB0byBjdXN0b21pemUgd2hpY2hcbiAqIGxldmVscyBhcmUgY2FwdHVyZWQuXG4gKlxuICogQGV4YW1wbGVcbiAqXG4gKiBgYGBqc1xuICogU2VudHJ5LmluaXQoe1xuICogICBpbnRlZ3JhdGlvbnM6IFtTZW50cnkuY29uc29sZUludGVncmF0aW9uKHsgbGV2ZWxzOiBbJ2Vycm9yJywgJ3dhcm4nXSB9KV0sXG4gKiB9KTtcbiAqIGBgYFxuICovXG5jb25zdCBjb25zb2xlSW50ZWdyYXRpb24gPSBpbnRlZ3JhdGlvbi5kZWZpbmVJbnRlZ3JhdGlvbigob3B0aW9ucyA9IHt9KSA9PiB7XG4gIGNvbnN0IGxldmVscyA9IG5ldyBTZXQob3B0aW9ucy5sZXZlbHMgfHwgZGVidWdMb2dnZXIuQ09OU09MRV9MRVZFTFMpO1xuXG4gIHJldHVybiB7XG4gICAgbmFtZTogSU5URUdSQVRJT05fTkFNRSxcbiAgICBzZXR1cChjbGllbnQpIHtcbiAgICAgIGNvbnNvbGUuYWRkQ29uc29sZUluc3RydW1lbnRhdGlvbkhhbmRsZXIoKHsgYXJncywgbGV2ZWwgfSkgPT4ge1xuICAgICAgICBpZiAoY3VycmVudFNjb3Blcy5nZXRDbGllbnQoKSAhPT0gY2xpZW50IHx8ICFsZXZlbHMuaGFzKGxldmVsKSkge1xuICAgICAgICAgIHJldHVybjtcbiAgICAgICAgfVxuXG4gICAgICAgIGFkZENvbnNvbGVCcmVhZGNydW1iKGxldmVsLCBhcmdzKTtcbiAgICAgIH0pO1xuICAgIH0sXG4gIH07XG59KTtcblxuLyoqXG4gKiBDYXB0dXJlIGEgY29uc29sZSBicmVhZGNydW1iLlxuICpcbiAqIEV4cG9ydGVkIGp1c3QgZm9yIHRlc3RzLlxuICovXG5mdW5jdGlvbiBhZGRDb25zb2xlQnJlYWRjcnVtYihsZXZlbCwgYXJncykge1xuICBjb25zdCBicmVhZGNydW1iID0ge1xuICAgIGNhdGVnb3J5OiAnY29uc29sZScsXG4gICAgZGF0YToge1xuICAgICAgYXJndW1lbnRzOiBhcmdzLFxuICAgICAgbG9nZ2VyOiAnY29uc29sZScsXG4gICAgfSxcbiAgICBsZXZlbDogc2V2ZXJpdHkuc2V2ZXJpdHlMZXZlbEZyb21TdHJpbmcobGV2ZWwpLFxuICAgIG1lc3NhZ2U6IGZvcm1hdENvbnNvbGVBcmdzKGFyZ3MpLFxuICB9O1xuXG4gIGlmIChsZXZlbCA9PT0gJ2Fzc2VydCcpIHtcbiAgICBpZiAoYXJnc1swXSA9PT0gZmFsc2UpIHtcbiAgICAgIGNvbnN0IGFzc2VydGlvbkFyZ3MgPSBhcmdzLnNsaWNlKDEpO1xuICAgICAgYnJlYWRjcnVtYi5tZXNzYWdlID1cbiAgICAgICAgYXNzZXJ0aW9uQXJncy5sZW5ndGggPiAwID8gYEFzc2VydGlvbiBmYWlsZWQ6ICR7Zm9ybWF0Q29uc29sZUFyZ3MoYXNzZXJ0aW9uQXJncyl9YCA6ICdBc3NlcnRpb24gZmFpbGVkJztcbiAgICAgIGJyZWFkY3J1bWIuZGF0YS5hcmd1bWVudHMgPSBhc3NlcnRpb25BcmdzO1xuICAgIH0gZWxzZSB7XG4gICAgICAvLyBEb24ndCBjYXB0dXJlIGEgYnJlYWRjcnVtYiBmb3IgcGFzc2VkIGFzc2VydGlvbnNcbiAgICAgIHJldHVybjtcbiAgICB9XG4gIH1cblxuICBicmVhZGNydW1icy5hZGRCcmVhZGNydW1iKGJyZWFkY3J1bWIsIHtcbiAgICBpbnB1dDogYXJncyxcbiAgICBsZXZlbCxcbiAgfSk7XG59XG5cbmZ1bmN0aW9uIGZvcm1hdENvbnNvbGVBcmdzKHZhbHVlcykge1xuICByZXR1cm4gJ3V0aWwnIGluIHdvcmxkd2lkZS5HTE9CQUxfT0JKICYmIHR5cGVvZiAod29ybGR3aWRlLkdMT0JBTF9PQkogKS51dGlsLmZvcm1hdCA9PT0gJ2Z1bmN0aW9uJ1xuICAgID8gKHdvcmxkd2lkZS5HTE9CQUxfT0JKICkudXRpbC5mb3JtYXQoLi4udmFsdWVzKVxuICAgIDogc3RyaW5nLnNhZmVKb2luKHZhbHVlcywgJyAnKTtcbn1cblxuZXhwb3J0cy5hZGRDb25zb2xlQnJlYWRjcnVtYiA9IGFkZENvbnNvbGVCcmVhZGNydW1iO1xuZXhwb3J0cy5jb25zb2xlSW50ZWdyYXRpb24gPSBjb25zb2xlSW50ZWdyYXRpb247XG4vLyMgc291cmNlTWFwcGluZ1VSTD1jb25zb2xlLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/console.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/dedupe.js":
/*!***********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/dedupe.js ***!
  \***********************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst debugBuild = __webpack_require__(/*! ../debug-build.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst integration = __webpack_require__(/*! ../integration.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integration.js\");\nconst debugLogger = __webpack_require__(/*! ../utils/debug-logger.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst stacktrace = __webpack_require__(/*! ../utils/stacktrace.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/stacktrace.js\");\n\nconst INTEGRATION_NAME = 'Dedupe';\n\nconst _dedupeIntegration = (() => {\n  let previousEvent;\n\n  return {\n    name: INTEGRATION_NAME,\n    processEvent(currentEvent) {\n      // We want to ignore any non-error type events, e.g. transactions or replays\n      // These should never be deduped, and also not be compared against as _previousEvent.\n      if (currentEvent.type) {\n        return currentEvent;\n      }\n\n      // Juuust in case something goes wrong\n      try {\n        if (_shouldDropEvent(currentEvent, previousEvent)) {\n          debugBuild.DEBUG_BUILD && debugLogger.debug.warn('Event dropped due to being a duplicate of previously captured event.');\n          return null;\n        }\n      } catch {} // eslint-disable-line no-empty\n\n      return (previousEvent = currentEvent);\n    },\n  };\n}) ;\n\n/**\n * Deduplication filter.\n */\nconst dedupeIntegration = integration.defineIntegration(_dedupeIntegration);\n\n/** only exported for tests. */\nfunction _shouldDropEvent(currentEvent, previousEvent) {\n  if (!previousEvent) {\n    return false;\n  }\n\n  if (_isSameMessageEvent(currentEvent, previousEvent)) {\n    return true;\n  }\n\n  if (_isSameExceptionEvent(currentEvent, previousEvent)) {\n    return true;\n  }\n\n  return false;\n}\n\nfunction _isSameMessageEvent(currentEvent, previousEvent) {\n  const currentMessage = currentEvent.message;\n  const previousMessage = previousEvent.message;\n\n  // If neither event has a message property, they were both exceptions, so bail out\n  if (!currentMessage && !previousMessage) {\n    return false;\n  }\n\n  // If only one event has a stacktrace, but not the other one, they are not the same\n  if ((currentMessage && !previousMessage) || (!currentMessage && previousMessage)) {\n    return false;\n  }\n\n  if (currentMessage !== previousMessage) {\n    return false;\n  }\n\n  if (!_isSameFingerprint(currentEvent, previousEvent)) {\n    return false;\n  }\n\n  if (!_isSameStacktrace(currentEvent, previousEvent)) {\n    return false;\n  }\n\n  return true;\n}\n\nfunction _isSameExceptionEvent(currentEvent, previousEvent) {\n  const previousException = _getExceptionFromEvent(previousEvent);\n  const currentException = _getExceptionFromEvent(currentEvent);\n\n  if (!previousException || !currentException) {\n    return false;\n  }\n\n  if (previousException.type !== currentException.type || previousException.value !== currentException.value) {\n    return false;\n  }\n\n  if (!_isSameFingerprint(currentEvent, previousEvent)) {\n    return false;\n  }\n\n  if (!_isSameStacktrace(currentEvent, previousEvent)) {\n    return false;\n  }\n\n  return true;\n}\n\nfunction _isSameStacktrace(currentEvent, previousEvent) {\n  let currentFrames = stacktrace.getFramesFromEvent(currentEvent);\n  let previousFrames = stacktrace.getFramesFromEvent(previousEvent);\n\n  // If neither event has a stacktrace, they are assumed to be the same\n  if (!currentFrames && !previousFrames) {\n    return true;\n  }\n\n  // If only one event has a stacktrace, but not the other one, they are not the same\n  if ((currentFrames && !previousFrames) || (!currentFrames && previousFrames)) {\n    return false;\n  }\n\n  currentFrames = currentFrames ;\n  previousFrames = previousFrames ;\n\n  // If number of frames differ, they are not the same\n  if (previousFrames.length !== currentFrames.length) {\n    return false;\n  }\n\n  // Otherwise, compare the two\n  for (let i = 0; i < previousFrames.length; i++) {\n    // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n    const frameA = previousFrames[i];\n    // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n    const frameB = currentFrames[i];\n\n    if (\n      frameA.filename !== frameB.filename ||\n      frameA.lineno !== frameB.lineno ||\n      frameA.colno !== frameB.colno ||\n      frameA.function !== frameB.function\n    ) {\n      return false;\n    }\n  }\n\n  return true;\n}\n\nfunction _isSameFingerprint(currentEvent, previousEvent) {\n  let currentFingerprint = currentEvent.fingerprint;\n  let previousFingerprint = previousEvent.fingerprint;\n\n  // If neither event has a fingerprint, they are assumed to be the same\n  if (!currentFingerprint && !previousFingerprint) {\n    return true;\n  }\n\n  // If only one event has a fingerprint, but not the other one, they are not the same\n  if ((currentFingerprint && !previousFingerprint) || (!currentFingerprint && previousFingerprint)) {\n    return false;\n  }\n\n  currentFingerprint = currentFingerprint ;\n  previousFingerprint = previousFingerprint ;\n\n  // Otherwise, compare the two\n  try {\n    return !!(currentFingerprint.join('') === previousFingerprint.join(''));\n  } catch {\n    return false;\n  }\n}\n\nfunction _getExceptionFromEvent(event) {\n  return event.exception?.values?.[0];\n}\n\nexports._shouldDropEvent = _shouldDropEvent;\nexports.dedupeIntegration = dedupeIntegration;\n//# sourceMappingURL=dedupe.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvZGVkdXBlLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLG1CQUFtQixtQkFBTyxDQUFDLDRIQUFtQjtBQUM5QyxvQkFBb0IsbUJBQU8sQ0FBQyw0SEFBbUI7QUFDL0Msb0JBQW9CLG1CQUFPLENBQUMsMElBQTBCO0FBQ3RELG1CQUFtQixtQkFBTyxDQUFDLHNJQUF3Qjs7QUFFbkQ7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFFBQVEsU0FBUzs7QUFFakI7QUFDQSxLQUFLO0FBQ0w7QUFDQSxDQUFDOztBQUVEO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBLGtCQUFrQiwyQkFBMkI7QUFDN0M7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0EsSUFBSTtBQUNKO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUEsd0JBQXdCO0FBQ3hCLHlCQUF5QjtBQUN6QiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL2ludGVncmF0aW9ucy9kZWR1cGUuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGRlYnVnQnVpbGQgPSByZXF1aXJlKCcuLi9kZWJ1Zy1idWlsZC5qcycpO1xuY29uc3QgaW50ZWdyYXRpb24gPSByZXF1aXJlKCcuLi9pbnRlZ3JhdGlvbi5qcycpO1xuY29uc3QgZGVidWdMb2dnZXIgPSByZXF1aXJlKCcuLi91dGlscy9kZWJ1Zy1sb2dnZXIuanMnKTtcbmNvbnN0IHN0YWNrdHJhY2UgPSByZXF1aXJlKCcuLi91dGlscy9zdGFja3RyYWNlLmpzJyk7XG5cbmNvbnN0IElOVEVHUkFUSU9OX05BTUUgPSAnRGVkdXBlJztcblxuY29uc3QgX2RlZHVwZUludGVncmF0aW9uID0gKCgpID0+IHtcbiAgbGV0IHByZXZpb3VzRXZlbnQ7XG5cbiAgcmV0dXJuIHtcbiAgICBuYW1lOiBJTlRFR1JBVElPTl9OQU1FLFxuICAgIHByb2Nlc3NFdmVudChjdXJyZW50RXZlbnQpIHtcbiAgICAgIC8vIFdlIHdhbnQgdG8gaWdub3JlIGFueSBub24tZXJyb3IgdHlwZSBldmVudHMsIGUuZy4gdHJhbnNhY3Rpb25zIG9yIHJlcGxheXNcbiAgICAgIC8vIFRoZXNlIHNob3VsZCBuZXZlciBiZSBkZWR1cGVkLCBhbmQgYWxzbyBub3QgYmUgY29tcGFyZWQgYWdhaW5zdCBhcyBfcHJldmlvdXNFdmVudC5cbiAgICAgIGlmIChjdXJyZW50RXZlbnQudHlwZSkge1xuICAgICAgICByZXR1cm4gY3VycmVudEV2ZW50O1xuICAgICAgfVxuXG4gICAgICAvLyBKdXV1c3QgaW4gY2FzZSBzb21ldGhpbmcgZ29lcyB3cm9uZ1xuICAgICAgdHJ5IHtcbiAgICAgICAgaWYgKF9zaG91bGREcm9wRXZlbnQoY3VycmVudEV2ZW50LCBwcmV2aW91c0V2ZW50KSkge1xuICAgICAgICAgIGRlYnVnQnVpbGQuREVCVUdfQlVJTEQgJiYgZGVidWdMb2dnZXIuZGVidWcud2FybignRXZlbnQgZHJvcHBlZCBkdWUgdG8gYmVpbmcgYSBkdXBsaWNhdGUgb2YgcHJldmlvdXNseSBjYXB0dXJlZCBldmVudC4nKTtcbiAgICAgICAgICByZXR1cm4gbnVsbDtcbiAgICAgICAgfVxuICAgICAgfSBjYXRjaCB7fSAvLyBlc2xpbnQtZGlzYWJsZS1saW5lIG5vLWVtcHR5XG5cbiAgICAgIHJldHVybiAocHJldmlvdXNFdmVudCA9IGN1cnJlbnRFdmVudCk7XG4gICAgfSxcbiAgfTtcbn0pIDtcblxuLyoqXG4gKiBEZWR1cGxpY2F0aW9uIGZpbHRlci5cbiAqL1xuY29uc3QgZGVkdXBlSW50ZWdyYXRpb24gPSBpbnRlZ3JhdGlvbi5kZWZpbmVJbnRlZ3JhdGlvbihfZGVkdXBlSW50ZWdyYXRpb24pO1xuXG4vKiogb25seSBleHBvcnRlZCBmb3IgdGVzdHMuICovXG5mdW5jdGlvbiBfc2hvdWxkRHJvcEV2ZW50KGN1cnJlbnRFdmVudCwgcHJldmlvdXNFdmVudCkge1xuICBpZiAoIXByZXZpb3VzRXZlbnQpIHtcbiAgICByZXR1cm4gZmFsc2U7XG4gIH1cblxuICBpZiAoX2lzU2FtZU1lc3NhZ2VFdmVudChjdXJyZW50RXZlbnQsIHByZXZpb3VzRXZlbnQpKSB7XG4gICAgcmV0dXJuIHRydWU7XG4gIH1cblxuICBpZiAoX2lzU2FtZUV4Y2VwdGlvbkV2ZW50KGN1cnJlbnRFdmVudCwgcHJldmlvdXNFdmVudCkpIHtcbiAgICByZXR1cm4gdHJ1ZTtcbiAgfVxuXG4gIHJldHVybiBmYWxzZTtcbn1cblxuZnVuY3Rpb24gX2lzU2FtZU1lc3NhZ2VFdmVudChjdXJyZW50RXZlbnQsIHByZXZpb3VzRXZlbnQpIHtcbiAgY29uc3QgY3VycmVudE1lc3NhZ2UgPSBjdXJyZW50RXZlbnQubWVzc2FnZTtcbiAgY29uc3QgcHJldmlvdXNNZXNzYWdlID0gcHJldmlvdXNFdmVudC5tZXNzYWdlO1xuXG4gIC8vIElmIG5laXRoZXIgZXZlbnQgaGFzIGEgbWVzc2FnZSBwcm9wZXJ0eSwgdGhleSB3ZXJlIGJvdGggZXhjZXB0aW9ucywgc28gYmFpbCBvdXRcbiAgaWYgKCFjdXJyZW50TWVzc2FnZSAmJiAhcHJldmlvdXNNZXNzYWdlKSB7XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG5cbiAgLy8gSWYgb25seSBvbmUgZXZlbnQgaGFzIGEgc3RhY2t0cmFjZSwgYnV0IG5vdCB0aGUgb3RoZXIgb25lLCB0aGV5IGFyZSBub3QgdGhlIHNhbWVcbiAgaWYgKChjdXJyZW50TWVzc2FnZSAmJiAhcHJldmlvdXNNZXNzYWdlKSB8fCAoIWN1cnJlbnRNZXNzYWdlICYmIHByZXZpb3VzTWVzc2FnZSkpIHtcbiAgICByZXR1cm4gZmFsc2U7XG4gIH1cblxuICBpZiAoY3VycmVudE1lc3NhZ2UgIT09IHByZXZpb3VzTWVzc2FnZSkge1xuICAgIHJldHVybiBmYWxzZTtcbiAgfVxuXG4gIGlmICghX2lzU2FtZUZpbmdlcnByaW50KGN1cnJlbnRFdmVudCwgcHJldmlvdXNFdmVudCkpIHtcbiAgICByZXR1cm4gZmFsc2U7XG4gIH1cblxuICBpZiAoIV9pc1NhbWVTdGFja3RyYWNlKGN1cnJlbnRFdmVudCwgcHJldmlvdXNFdmVudCkpIHtcbiAgICByZXR1cm4gZmFsc2U7XG4gIH1cblxuICByZXR1cm4gdHJ1ZTtcbn1cblxuZnVuY3Rpb24gX2lzU2FtZUV4Y2VwdGlvbkV2ZW50KGN1cnJlbnRFdmVudCwgcHJldmlvdXNFdmVudCkge1xuICBjb25zdCBwcmV2aW91c0V4Y2VwdGlvbiA9IF9nZXRFeGNlcHRpb25Gcm9tRXZlbnQocHJldmlvdXNFdmVudCk7XG4gIGNvbnN0IGN1cnJlbnRFeGNlcHRpb24gPSBfZ2V0RXhjZXB0aW9uRnJvbUV2ZW50KGN1cnJlbnRFdmVudCk7XG5cbiAgaWYgKCFwcmV2aW91c0V4Y2VwdGlvbiB8fCAhY3VycmVudEV4Y2VwdGlvbikge1xuICAgIHJldHVybiBmYWxzZTtcbiAgfVxuXG4gIGlmIChwcmV2aW91c0V4Y2VwdGlvbi50eXBlICE9PSBjdXJyZW50RXhjZXB0aW9uLnR5cGUgfHwgcHJldmlvdXNFeGNlcHRpb24udmFsdWUgIT09IGN1cnJlbnRFeGNlcHRpb24udmFsdWUpIHtcbiAgICByZXR1cm4gZmFsc2U7XG4gIH1cblxuICBpZiAoIV9pc1NhbWVGaW5nZXJwcmludChjdXJyZW50RXZlbnQsIHByZXZpb3VzRXZlbnQpKSB7XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG5cbiAgaWYgKCFfaXNTYW1lU3RhY2t0cmFjZShjdXJyZW50RXZlbnQsIHByZXZpb3VzRXZlbnQpKSB7XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG5cbiAgcmV0dXJuIHRydWU7XG59XG5cbmZ1bmN0aW9uIF9pc1NhbWVTdGFja3RyYWNlKGN1cnJlbnRFdmVudCwgcHJldmlvdXNFdmVudCkge1xuICBsZXQgY3VycmVudEZyYW1lcyA9IHN0YWNrdHJhY2UuZ2V0RnJhbWVzRnJvbUV2ZW50KGN1cnJlbnRFdmVudCk7XG4gIGxldCBwcmV2aW91c0ZyYW1lcyA9IHN0YWNrdHJhY2UuZ2V0RnJhbWVzRnJvbUV2ZW50KHByZXZpb3VzRXZlbnQpO1xuXG4gIC8vIElmIG5laXRoZXIgZXZlbnQgaGFzIGEgc3RhY2t0cmFjZSwgdGhleSBhcmUgYXNzdW1lZCB0byBiZSB0aGUgc2FtZVxuICBpZiAoIWN1cnJlbnRGcmFtZXMgJiYgIXByZXZpb3VzRnJhbWVzKSB7XG4gICAgcmV0dXJuIHRydWU7XG4gIH1cblxuICAvLyBJZiBvbmx5IG9uZSBldmVudCBoYXMgYSBzdGFja3RyYWNlLCBidXQgbm90IHRoZSBvdGhlciBvbmUsIHRoZXkgYXJlIG5vdCB0aGUgc2FtZVxuICBpZiAoKGN1cnJlbnRGcmFtZXMgJiYgIXByZXZpb3VzRnJhbWVzKSB8fCAoIWN1cnJlbnRGcmFtZXMgJiYgcHJldmlvdXNGcmFtZXMpKSB7XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG5cbiAgY3VycmVudEZyYW1lcyA9IGN1cnJlbnRGcmFtZXMgO1xuICBwcmV2aW91c0ZyYW1lcyA9IHByZXZpb3VzRnJhbWVzIDtcblxuICAvLyBJZiBudW1iZXIgb2YgZnJhbWVzIGRpZmZlciwgdGhleSBhcmUgbm90IHRoZSBzYW1lXG4gIGlmIChwcmV2aW91c0ZyYW1lcy5sZW5ndGggIT09IGN1cnJlbnRGcmFtZXMubGVuZ3RoKSB7XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG5cbiAgLy8gT3RoZXJ3aXNlLCBjb21wYXJlIHRoZSB0d29cbiAgZm9yIChsZXQgaSA9IDA7IGkgPCBwcmV2aW91c0ZyYW1lcy5sZW5ndGg7IGkrKykge1xuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tbm9uLW51bGwtYXNzZXJ0aW9uXG4gICAgY29uc3QgZnJhbWVBID0gcHJldmlvdXNGcmFtZXNbaV07XG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uby1ub24tbnVsbC1hc3NlcnRpb25cbiAgICBjb25zdCBmcmFtZUIgPSBjdXJyZW50RnJhbWVzW2ldO1xuXG4gICAgaWYgKFxuICAgICAgZnJhbWVBLmZpbGVuYW1lICE9PSBmcmFtZUIuZmlsZW5hbWUgfHxcbiAgICAgIGZyYW1lQS5saW5lbm8gIT09IGZyYW1lQi5saW5lbm8gfHxcbiAgICAgIGZyYW1lQS5jb2xubyAhPT0gZnJhbWVCLmNvbG5vIHx8XG4gICAgICBmcmFtZUEuZnVuY3Rpb24gIT09IGZyYW1lQi5mdW5jdGlvblxuICAgICkge1xuICAgICAgcmV0dXJuIGZhbHNlO1xuICAgIH1cbiAgfVxuXG4gIHJldHVybiB0cnVlO1xufVxuXG5mdW5jdGlvbiBfaXNTYW1lRmluZ2VycHJpbnQoY3VycmVudEV2ZW50LCBwcmV2aW91c0V2ZW50KSB7XG4gIGxldCBjdXJyZW50RmluZ2VycHJpbnQgPSBjdXJyZW50RXZlbnQuZmluZ2VycHJpbnQ7XG4gIGxldCBwcmV2aW91c0ZpbmdlcnByaW50ID0gcHJldmlvdXNFdmVudC5maW5nZXJwcmludDtcblxuICAvLyBJZiBuZWl0aGVyIGV2ZW50IGhhcyBhIGZpbmdlcnByaW50LCB0aGV5IGFyZSBhc3N1bWVkIHRvIGJlIHRoZSBzYW1lXG4gIGlmICghY3VycmVudEZpbmdlcnByaW50ICYmICFwcmV2aW91c0ZpbmdlcnByaW50KSB7XG4gICAgcmV0dXJuIHRydWU7XG4gIH1cblxuICAvLyBJZiBvbmx5IG9uZSBldmVudCBoYXMgYSBmaW5nZXJwcmludCwgYnV0IG5vdCB0aGUgb3RoZXIgb25lLCB0aGV5IGFyZSBub3QgdGhlIHNhbWVcbiAgaWYgKChjdXJyZW50RmluZ2VycHJpbnQgJiYgIXByZXZpb3VzRmluZ2VycHJpbnQpIHx8ICghY3VycmVudEZpbmdlcnByaW50ICYmIHByZXZpb3VzRmluZ2VycHJpbnQpKSB7XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG5cbiAgY3VycmVudEZpbmdlcnByaW50ID0gY3VycmVudEZpbmdlcnByaW50IDtcbiAgcHJldmlvdXNGaW5nZXJwcmludCA9IHByZXZpb3VzRmluZ2VycHJpbnQgO1xuXG4gIC8vIE90aGVyd2lzZSwgY29tcGFyZSB0aGUgdHdvXG4gIHRyeSB7XG4gICAgcmV0dXJuICEhKGN1cnJlbnRGaW5nZXJwcmludC5qb2luKCcnKSA9PT0gcHJldmlvdXNGaW5nZXJwcmludC5qb2luKCcnKSk7XG4gIH0gY2F0Y2gge1xuICAgIHJldHVybiBmYWxzZTtcbiAgfVxufVxuXG5mdW5jdGlvbiBfZ2V0RXhjZXB0aW9uRnJvbUV2ZW50KGV2ZW50KSB7XG4gIHJldHVybiBldmVudC5leGNlcHRpb24/LnZhbHVlcz8uWzBdO1xufVxuXG5leHBvcnRzLl9zaG91bGREcm9wRXZlbnQgPSBfc2hvdWxkRHJvcEV2ZW50O1xuZXhwb3J0cy5kZWR1cGVJbnRlZ3JhdGlvbiA9IGRlZHVwZUludGVncmF0aW9uO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9ZGVkdXBlLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/dedupe.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/eventFilters.js":
/*!*****************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/eventFilters.js ***!
  \*****************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst debugBuild = __webpack_require__(/*! ../debug-build.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst integration = __webpack_require__(/*! ../integration.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integration.js\");\nconst debugLogger = __webpack_require__(/*! ../utils/debug-logger.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst eventUtils = __webpack_require__(/*! ../utils/eventUtils.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/eventUtils.js\");\nconst misc = __webpack_require__(/*! ../utils/misc.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/misc.js\");\nconst string = __webpack_require__(/*! ../utils/string.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/string.js\");\n\n// \"Script error.\" is hard coded into browsers for errors that it can't read.\n// this is the result of a script being pulled in from an external domain and CORS.\nconst DEFAULT_IGNORE_ERRORS = [\n  /^Script error\\.?$/,\n  /^Javascript error: Script error\\.? on line 0$/,\n  /^ResizeObserver loop completed with undelivered notifications.$/, // The browser logs this when a ResizeObserver handler takes a bit longer. Usually this is not an actual issue though. It indicates slowness.\n  /^Cannot redefine property: googletag$/, // This is thrown when google tag manager is used in combination with an ad blocker\n  /^Can't find variable: gmo$/, // Error from Google Search App https://issuetracker.google.com/issues/396043331\n  /^undefined is not an object \\(evaluating 'a\\.[A-Z]'\\)$/, // Random error that happens but not actionable or noticeable to end-users.\n  'can\\'t redefine non-configurable property \"solana\"', // Probably a browser extension or custom browser (Brave) throwing this error\n  \"vv().getRestrictions is not a function. (In 'vv().getRestrictions(1,a)', 'vv().getRestrictions' is undefined)\", // Error thrown by GTM, seemingly not affecting end-users\n  \"Can't find variable: _AutofillCallbackHandler\", // Unactionable error in instagram webview https://developers.facebook.com/community/threads/320013549791141/\n  /^Non-Error promise rejection captured with value: Object Not Found Matching Id:\\d+, MethodName:simulateEvent, ParamCount:\\d+$/, // unactionable error from CEFSharp, a .NET library that embeds chromium in .NET apps\n  /^Java exception was raised during method invocation$/, // error from Facebook Mobile browser (https://github.com/getsentry/sentry-javascript/issues/15065)\n];\n\n/** Options for the EventFilters integration */\n\nconst INTEGRATION_NAME = 'EventFilters';\n\n/**\n * An integration that filters out events (errors and transactions) based on:\n *\n * - (Errors) A curated list of known low-value or irrelevant errors (see {@link DEFAULT_IGNORE_ERRORS})\n * - (Errors) A list of error messages or urls/filenames passed in via\n *   - Top level Sentry.init options (`ignoreErrors`, `denyUrls`, `allowUrls`)\n *   - The same options passed to the integration directly via @param options\n * - (Transactions/Spans) A list of root span (transaction) names passed in via\n *   - Top level Sentry.init option (`ignoreTransactions`)\n *   - The same option passed to the integration directly via @param options\n *\n * Events filtered by this integration will not be sent to Sentry.\n */\nconst eventFiltersIntegration = integration.defineIntegration((options = {}) => {\n  let mergedOptions;\n  return {\n    name: INTEGRATION_NAME,\n    setup(client) {\n      const clientOptions = client.getOptions();\n      mergedOptions = _mergeOptions(options, clientOptions);\n    },\n    processEvent(event, _hint, client) {\n      if (!mergedOptions) {\n        const clientOptions = client.getOptions();\n        mergedOptions = _mergeOptions(options, clientOptions);\n      }\n      return _shouldDropEvent(event, mergedOptions) ? null : event;\n    },\n  };\n});\n\n/**\n * An integration that filters out events (errors and transactions) based on:\n *\n * - (Errors) A curated list of known low-value or irrelevant errors (see {@link DEFAULT_IGNORE_ERRORS})\n * - (Errors) A list of error messages or urls/filenames passed in via\n *   - Top level Sentry.init options (`ignoreErrors`, `denyUrls`, `allowUrls`)\n *   - The same options passed to the integration directly via @param options\n * - (Transactions/Spans) A list of root span (transaction) names passed in via\n *   - Top level Sentry.init option (`ignoreTransactions`)\n *   - The same option passed to the integration directly via @param options\n *\n * Events filtered by this integration will not be sent to Sentry.\n *\n * @deprecated this integration was renamed and will be removed in a future major version.\n * Use `eventFiltersIntegration` instead.\n */\nconst inboundFiltersIntegration = integration.defineIntegration(((options = {}) => {\n  return {\n    ...eventFiltersIntegration(options),\n    name: 'InboundFilters',\n  };\n}) );\n\nfunction _mergeOptions(\n  internalOptions = {},\n  clientOptions = {},\n) {\n  return {\n    allowUrls: [...(internalOptions.allowUrls || []), ...(clientOptions.allowUrls || [])],\n    denyUrls: [...(internalOptions.denyUrls || []), ...(clientOptions.denyUrls || [])],\n    ignoreErrors: [\n      ...(internalOptions.ignoreErrors || []),\n      ...(clientOptions.ignoreErrors || []),\n      ...(internalOptions.disableErrorDefaults ? [] : DEFAULT_IGNORE_ERRORS),\n    ],\n    ignoreTransactions: [...(internalOptions.ignoreTransactions || []), ...(clientOptions.ignoreTransactions || [])],\n  };\n}\n\nfunction _shouldDropEvent(event, options) {\n  if (!event.type) {\n    // Filter errors\n    if (_isIgnoredError(event, options.ignoreErrors)) {\n      debugBuild.DEBUG_BUILD &&\n        debugLogger.debug.warn(\n          `Event dropped due to being matched by \\`ignoreErrors\\` option.\\nEvent: ${misc.getEventDescription(event)}`,\n        );\n      return true;\n    }\n    if (_isUselessError(event)) {\n      debugBuild.DEBUG_BUILD &&\n        debugLogger.debug.warn(\n          `Event dropped due to not having an error message, error type or stacktrace.\\nEvent: ${misc.getEventDescription(\n            event,\n          )}`,\n        );\n      return true;\n    }\n    if (_isDeniedUrl(event, options.denyUrls)) {\n      debugBuild.DEBUG_BUILD &&\n        debugLogger.debug.warn(\n          `Event dropped due to being matched by \\`denyUrls\\` option.\\nEvent: ${misc.getEventDescription(\n            event,\n          )}.\\nUrl: ${_getEventFilterUrl(event)}`,\n        );\n      return true;\n    }\n    if (!_isAllowedUrl(event, options.allowUrls)) {\n      debugBuild.DEBUG_BUILD &&\n        debugLogger.debug.warn(\n          `Event dropped due to not being matched by \\`allowUrls\\` option.\\nEvent: ${misc.getEventDescription(\n            event,\n          )}.\\nUrl: ${_getEventFilterUrl(event)}`,\n        );\n      return true;\n    }\n  } else if (event.type === 'transaction') {\n    // Filter transactions\n\n    if (_isIgnoredTransaction(event, options.ignoreTransactions)) {\n      debugBuild.DEBUG_BUILD &&\n        debugLogger.debug.warn(\n          `Event dropped due to being matched by \\`ignoreTransactions\\` option.\\nEvent: ${misc.getEventDescription(event)}`,\n        );\n      return true;\n    }\n  }\n  return false;\n}\n\nfunction _isIgnoredError(event, ignoreErrors) {\n  if (!ignoreErrors?.length) {\n    return false;\n  }\n\n  return eventUtils.getPossibleEventMessages(event).some(message => string.stringMatchesSomePattern(message, ignoreErrors));\n}\n\nfunction _isIgnoredTransaction(event, ignoreTransactions) {\n  if (!ignoreTransactions?.length) {\n    return false;\n  }\n\n  const name = event.transaction;\n  return name ? string.stringMatchesSomePattern(name, ignoreTransactions) : false;\n}\n\nfunction _isDeniedUrl(event, denyUrls) {\n  if (!denyUrls?.length) {\n    return false;\n  }\n  const url = _getEventFilterUrl(event);\n  return !url ? false : string.stringMatchesSomePattern(url, denyUrls);\n}\n\nfunction _isAllowedUrl(event, allowUrls) {\n  if (!allowUrls?.length) {\n    return true;\n  }\n  const url = _getEventFilterUrl(event);\n  return !url ? true : string.stringMatchesSomePattern(url, allowUrls);\n}\n\nfunction _getLastValidUrl(frames = []) {\n  for (let i = frames.length - 1; i >= 0; i--) {\n    const frame = frames[i];\n\n    if (frame && frame.filename !== '<anonymous>' && frame.filename !== '[native code]') {\n      return frame.filename || null;\n    }\n  }\n\n  return null;\n}\n\nfunction _getEventFilterUrl(event) {\n  try {\n    // If there are linked exceptions or exception aggregates we only want to match against the top frame of the \"root\" (the main exception)\n    // The root always comes last in linked exceptions\n    const rootException = [...(event.exception?.values ?? [])]\n      .reverse()\n      .find(value => value.mechanism?.parent_id === undefined && value.stacktrace?.frames?.length);\n    const frames = rootException?.stacktrace?.frames;\n    return frames ? _getLastValidUrl(frames) : null;\n  } catch {\n    debugBuild.DEBUG_BUILD && debugLogger.debug.error(`Cannot extract url for event ${misc.getEventDescription(event)}`);\n    return null;\n  }\n}\n\nfunction _isUselessError(event) {\n  // We only want to consider events for dropping that actually have recorded exception values.\n  if (!event.exception?.values?.length) {\n    return false;\n  }\n\n  return (\n    // No top-level message\n    !event.message &&\n    // There are no exception values that have a stacktrace, a non-generic-Error type or value\n    !event.exception.values.some(value => value.stacktrace || (value.type && value.type !== 'Error') || value.value)\n  );\n}\n\nexports.eventFiltersIntegration = eventFiltersIntegration;\nexports.inboundFiltersIntegration = inboundFiltersIntegration;\n//# sourceMappingURL=eventFilters.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvZXZlbnRGaWx0ZXJzLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLG1CQUFtQixtQkFBTyxDQUFDLDRIQUFtQjtBQUM5QyxvQkFBb0IsbUJBQU8sQ0FBQyw0SEFBbUI7QUFDL0Msb0JBQW9CLG1CQUFPLENBQUMsMElBQTBCO0FBQ3RELG1CQUFtQixtQkFBTyxDQUFDLHNJQUF3QjtBQUNuRCxhQUFhLG1CQUFPLENBQUMsMEhBQWtCO0FBQ3ZDLGVBQWUsbUJBQU8sQ0FBQyw4SEFBb0I7O0FBRTNDO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQSwyRUFBMkUsNEJBQTRCO0FBQ3ZHO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLDJFQUEyRTtBQUMzRTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxLQUFLO0FBQ0w7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsS0FBSztBQUNMO0FBQ0EsQ0FBQzs7QUFFRDtBQUNBO0FBQ0E7QUFDQSwyRUFBMkUsNEJBQTRCO0FBQ3ZHO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLDhFQUE4RTtBQUM5RTtBQUNBO0FBQ0E7QUFDQTtBQUNBLENBQUM7O0FBRUQ7QUFDQSxzQkFBc0I7QUFDdEIsb0JBQW9CO0FBQ3BCO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxvRkFBb0YsZ0NBQWdDO0FBQ3BIO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGlHQUFpRztBQUNqRztBQUNBLFlBQVk7QUFDWjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxnRkFBZ0Y7QUFDaEY7QUFDQSxZQUFZLFVBQVUsMEJBQTBCO0FBQ2hEO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLHFGQUFxRjtBQUNyRjtBQUNBLFlBQVksVUFBVSwwQkFBMEI7QUFDaEQ7QUFDQTtBQUNBO0FBQ0EsSUFBSTtBQUNKOztBQUVBO0FBQ0E7QUFDQTtBQUNBLDBGQUEwRixnQ0FBZ0M7QUFDMUg7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0Esa0NBQWtDLFFBQVE7QUFDMUM7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxJQUFJO0FBQ0osc0ZBQXNGLGdDQUFnQztBQUN0SDtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSwrQkFBK0I7QUFDL0IsaUNBQWlDO0FBQ2pDIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvaW50ZWdyYXRpb25zL2V2ZW50RmlsdGVycy5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgZGVidWdCdWlsZCA9IHJlcXVpcmUoJy4uL2RlYnVnLWJ1aWxkLmpzJyk7XG5jb25zdCBpbnRlZ3JhdGlvbiA9IHJlcXVpcmUoJy4uL2ludGVncmF0aW9uLmpzJyk7XG5jb25zdCBkZWJ1Z0xvZ2dlciA9IHJlcXVpcmUoJy4uL3V0aWxzL2RlYnVnLWxvZ2dlci5qcycpO1xuY29uc3QgZXZlbnRVdGlscyA9IHJlcXVpcmUoJy4uL3V0aWxzL2V2ZW50VXRpbHMuanMnKTtcbmNvbnN0IG1pc2MgPSByZXF1aXJlKCcuLi91dGlscy9taXNjLmpzJyk7XG5jb25zdCBzdHJpbmcgPSByZXF1aXJlKCcuLi91dGlscy9zdHJpbmcuanMnKTtcblxuLy8gXCJTY3JpcHQgZXJyb3IuXCIgaXMgaGFyZCBjb2RlZCBpbnRvIGJyb3dzZXJzIGZvciBlcnJvcnMgdGhhdCBpdCBjYW4ndCByZWFkLlxuLy8gdGhpcyBpcyB0aGUgcmVzdWx0IG9mIGEgc2NyaXB0IGJlaW5nIHB1bGxlZCBpbiBmcm9tIGFuIGV4dGVybmFsIGRvbWFpbiBhbmQgQ09SUy5cbmNvbnN0IERFRkFVTFRfSUdOT1JFX0VSUk9SUyA9IFtcbiAgL15TY3JpcHQgZXJyb3JcXC4/JC8sXG4gIC9eSmF2YXNjcmlwdCBlcnJvcjogU2NyaXB0IGVycm9yXFwuPyBvbiBsaW5lIDAkLyxcbiAgL15SZXNpemVPYnNlcnZlciBsb29wIGNvbXBsZXRlZCB3aXRoIHVuZGVsaXZlcmVkIG5vdGlmaWNhdGlvbnMuJC8sIC8vIFRoZSBicm93c2VyIGxvZ3MgdGhpcyB3aGVuIGEgUmVzaXplT2JzZXJ2ZXIgaGFuZGxlciB0YWtlcyBhIGJpdCBsb25nZXIuIFVzdWFsbHkgdGhpcyBpcyBub3QgYW4gYWN0dWFsIGlzc3VlIHRob3VnaC4gSXQgaW5kaWNhdGVzIHNsb3duZXNzLlxuICAvXkNhbm5vdCByZWRlZmluZSBwcm9wZXJ0eTogZ29vZ2xldGFnJC8sIC8vIFRoaXMgaXMgdGhyb3duIHdoZW4gZ29vZ2xlIHRhZyBtYW5hZ2VyIGlzIHVzZWQgaW4gY29tYmluYXRpb24gd2l0aCBhbiBhZCBibG9ja2VyXG4gIC9eQ2FuJ3QgZmluZCB2YXJpYWJsZTogZ21vJC8sIC8vIEVycm9yIGZyb20gR29vZ2xlIFNlYXJjaCBBcHAgaHR0cHM6Ly9pc3N1ZXRyYWNrZXIuZ29vZ2xlLmNvbS9pc3N1ZXMvMzk2MDQzMzMxXG4gIC9edW5kZWZpbmVkIGlzIG5vdCBhbiBvYmplY3QgXFwoZXZhbHVhdGluZyAnYVxcLltBLVpdJ1xcKSQvLCAvLyBSYW5kb20gZXJyb3IgdGhhdCBoYXBwZW5zIGJ1dCBub3QgYWN0aW9uYWJsZSBvciBub3RpY2VhYmxlIHRvIGVuZC11c2Vycy5cbiAgJ2NhblxcJ3QgcmVkZWZpbmUgbm9uLWNvbmZpZ3VyYWJsZSBwcm9wZXJ0eSBcInNvbGFuYVwiJywgLy8gUHJvYmFibHkgYSBicm93c2VyIGV4dGVuc2lvbiBvciBjdXN0b20gYnJvd3NlciAoQnJhdmUpIHRocm93aW5nIHRoaXMgZXJyb3JcbiAgXCJ2digpLmdldFJlc3RyaWN0aW9ucyBpcyBub3QgYSBmdW5jdGlvbi4gKEluICd2digpLmdldFJlc3RyaWN0aW9ucygxLGEpJywgJ3Z2KCkuZ2V0UmVzdHJpY3Rpb25zJyBpcyB1bmRlZmluZWQpXCIsIC8vIEVycm9yIHRocm93biBieSBHVE0sIHNlZW1pbmdseSBub3QgYWZmZWN0aW5nIGVuZC11c2Vyc1xuICBcIkNhbid0IGZpbmQgdmFyaWFibGU6IF9BdXRvZmlsbENhbGxiYWNrSGFuZGxlclwiLCAvLyBVbmFjdGlvbmFibGUgZXJyb3IgaW4gaW5zdGFncmFtIHdlYnZpZXcgaHR0cHM6Ly9kZXZlbG9wZXJzLmZhY2Vib29rLmNvbS9jb21tdW5pdHkvdGhyZWFkcy8zMjAwMTM1NDk3OTExNDEvXG4gIC9eTm9uLUVycm9yIHByb21pc2UgcmVqZWN0aW9uIGNhcHR1cmVkIHdpdGggdmFsdWU6IE9iamVjdCBOb3QgRm91bmQgTWF0Y2hpbmcgSWQ6XFxkKywgTWV0aG9kTmFtZTpzaW11bGF0ZUV2ZW50LCBQYXJhbUNvdW50OlxcZCskLywgLy8gdW5hY3Rpb25hYmxlIGVycm9yIGZyb20gQ0VGU2hhcnAsIGEgLk5FVCBsaWJyYXJ5IHRoYXQgZW1iZWRzIGNocm9taXVtIGluIC5ORVQgYXBwc1xuICAvXkphdmEgZXhjZXB0aW9uIHdhcyByYWlzZWQgZHVyaW5nIG1ldGhvZCBpbnZvY2F0aW9uJC8sIC8vIGVycm9yIGZyb20gRmFjZWJvb2sgTW9iaWxlIGJyb3dzZXIgKGh0dHBzOi8vZ2l0aHViLmNvbS9nZXRzZW50cnkvc2VudHJ5LWphdmFzY3JpcHQvaXNzdWVzLzE1MDY1KVxuXTtcblxuLyoqIE9wdGlvbnMgZm9yIHRoZSBFdmVudEZpbHRlcnMgaW50ZWdyYXRpb24gKi9cblxuY29uc3QgSU5URUdSQVRJT05fTkFNRSA9ICdFdmVudEZpbHRlcnMnO1xuXG4vKipcbiAqIEFuIGludGVncmF0aW9uIHRoYXQgZmlsdGVycyBvdXQgZXZlbnRzIChlcnJvcnMgYW5kIHRyYW5zYWN0aW9ucykgYmFzZWQgb246XG4gKlxuICogLSAoRXJyb3JzKSBBIGN1cmF0ZWQgbGlzdCBvZiBrbm93biBsb3ctdmFsdWUgb3IgaXJyZWxldmFudCBlcnJvcnMgKHNlZSB7QGxpbmsgREVGQVVMVF9JR05PUkVfRVJST1JTfSlcbiAqIC0gKEVycm9ycykgQSBsaXN0IG9mIGVycm9yIG1lc3NhZ2VzIG9yIHVybHMvZmlsZW5hbWVzIHBhc3NlZCBpbiB2aWFcbiAqICAgLSBUb3AgbGV2ZWwgU2VudHJ5LmluaXQgb3B0aW9ucyAoYGlnbm9yZUVycm9yc2AsIGBkZW55VXJsc2AsIGBhbGxvd1VybHNgKVxuICogICAtIFRoZSBzYW1lIG9wdGlvbnMgcGFzc2VkIHRvIHRoZSBpbnRlZ3JhdGlvbiBkaXJlY3RseSB2aWEgQHBhcmFtIG9wdGlvbnNcbiAqIC0gKFRyYW5zYWN0aW9ucy9TcGFucykgQSBsaXN0IG9mIHJvb3Qgc3BhbiAodHJhbnNhY3Rpb24pIG5hbWVzIHBhc3NlZCBpbiB2aWFcbiAqICAgLSBUb3AgbGV2ZWwgU2VudHJ5LmluaXQgb3B0aW9uIChgaWdub3JlVHJhbnNhY3Rpb25zYClcbiAqICAgLSBUaGUgc2FtZSBvcHRpb24gcGFzc2VkIHRvIHRoZSBpbnRlZ3JhdGlvbiBkaXJlY3RseSB2aWEgQHBhcmFtIG9wdGlvbnNcbiAqXG4gKiBFdmVudHMgZmlsdGVyZWQgYnkgdGhpcyBpbnRlZ3JhdGlvbiB3aWxsIG5vdCBiZSBzZW50IHRvIFNlbnRyeS5cbiAqL1xuY29uc3QgZXZlbnRGaWx0ZXJzSW50ZWdyYXRpb24gPSBpbnRlZ3JhdGlvbi5kZWZpbmVJbnRlZ3JhdGlvbigob3B0aW9ucyA9IHt9KSA9PiB7XG4gIGxldCBtZXJnZWRPcHRpb25zO1xuICByZXR1cm4ge1xuICAgIG5hbWU6IElOVEVHUkFUSU9OX05BTUUsXG4gICAgc2V0dXAoY2xpZW50KSB7XG4gICAgICBjb25zdCBjbGllbnRPcHRpb25zID0gY2xpZW50LmdldE9wdGlvbnMoKTtcbiAgICAgIG1lcmdlZE9wdGlvbnMgPSBfbWVyZ2VPcHRpb25zKG9wdGlvbnMsIGNsaWVudE9wdGlvbnMpO1xuICAgIH0sXG4gICAgcHJvY2Vzc0V2ZW50KGV2ZW50LCBfaGludCwgY2xpZW50KSB7XG4gICAgICBpZiAoIW1lcmdlZE9wdGlvbnMpIHtcbiAgICAgICAgY29uc3QgY2xpZW50T3B0aW9ucyA9IGNsaWVudC5nZXRPcHRpb25zKCk7XG4gICAgICAgIG1lcmdlZE9wdGlvbnMgPSBfbWVyZ2VPcHRpb25zKG9wdGlvbnMsIGNsaWVudE9wdGlvbnMpO1xuICAgICAgfVxuICAgICAgcmV0dXJuIF9zaG91bGREcm9wRXZlbnQoZXZlbnQsIG1lcmdlZE9wdGlvbnMpID8gbnVsbCA6IGV2ZW50O1xuICAgIH0sXG4gIH07XG59KTtcblxuLyoqXG4gKiBBbiBpbnRlZ3JhdGlvbiB0aGF0IGZpbHRlcnMgb3V0IGV2ZW50cyAoZXJyb3JzIGFuZCB0cmFuc2FjdGlvbnMpIGJhc2VkIG9uOlxuICpcbiAqIC0gKEVycm9ycykgQSBjdXJhdGVkIGxpc3Qgb2Yga25vd24gbG93LXZhbHVlIG9yIGlycmVsZXZhbnQgZXJyb3JzIChzZWUge0BsaW5rIERFRkFVTFRfSUdOT1JFX0VSUk9SU30pXG4gKiAtIChFcnJvcnMpIEEgbGlzdCBvZiBlcnJvciBtZXNzYWdlcyBvciB1cmxzL2ZpbGVuYW1lcyBwYXNzZWQgaW4gdmlhXG4gKiAgIC0gVG9wIGxldmVsIFNlbnRyeS5pbml0IG9wdGlvbnMgKGBpZ25vcmVFcnJvcnNgLCBgZGVueVVybHNgLCBgYWxsb3dVcmxzYClcbiAqICAgLSBUaGUgc2FtZSBvcHRpb25zIHBhc3NlZCB0byB0aGUgaW50ZWdyYXRpb24gZGlyZWN0bHkgdmlhIEBwYXJhbSBvcHRpb25zXG4gKiAtIChUcmFuc2FjdGlvbnMvU3BhbnMpIEEgbGlzdCBvZiByb290IHNwYW4gKHRyYW5zYWN0aW9uKSBuYW1lcyBwYXNzZWQgaW4gdmlhXG4gKiAgIC0gVG9wIGxldmVsIFNlbnRyeS5pbml0IG9wdGlvbiAoYGlnbm9yZVRyYW5zYWN0aW9uc2ApXG4gKiAgIC0gVGhlIHNhbWUgb3B0aW9uIHBhc3NlZCB0byB0aGUgaW50ZWdyYXRpb24gZGlyZWN0bHkgdmlhIEBwYXJhbSBvcHRpb25zXG4gKlxuICogRXZlbnRzIGZpbHRlcmVkIGJ5IHRoaXMgaW50ZWdyYXRpb24gd2lsbCBub3QgYmUgc2VudCB0byBTZW50cnkuXG4gKlxuICogQGRlcHJlY2F0ZWQgdGhpcyBpbnRlZ3JhdGlvbiB3YXMgcmVuYW1lZCBhbmQgd2lsbCBiZSByZW1vdmVkIGluIGEgZnV0dXJlIG1ham9yIHZlcnNpb24uXG4gKiBVc2UgYGV2ZW50RmlsdGVyc0ludGVncmF0aW9uYCBpbnN0ZWFkLlxuICovXG5jb25zdCBpbmJvdW5kRmlsdGVyc0ludGVncmF0aW9uID0gaW50ZWdyYXRpb24uZGVmaW5lSW50ZWdyYXRpb24oKChvcHRpb25zID0ge30pID0+IHtcbiAgcmV0dXJuIHtcbiAgICAuLi5ldmVudEZpbHRlcnNJbnRlZ3JhdGlvbihvcHRpb25zKSxcbiAgICBuYW1lOiAnSW5ib3VuZEZpbHRlcnMnLFxuICB9O1xufSkgKTtcblxuZnVuY3Rpb24gX21lcmdlT3B0aW9ucyhcbiAgaW50ZXJuYWxPcHRpb25zID0ge30sXG4gIGNsaWVudE9wdGlvbnMgPSB7fSxcbikge1xuICByZXR1cm4ge1xuICAgIGFsbG93VXJsczogWy4uLihpbnRlcm5hbE9wdGlvbnMuYWxsb3dVcmxzIHx8IFtdKSwgLi4uKGNsaWVudE9wdGlvbnMuYWxsb3dVcmxzIHx8IFtdKV0sXG4gICAgZGVueVVybHM6IFsuLi4oaW50ZXJuYWxPcHRpb25zLmRlbnlVcmxzIHx8IFtdKSwgLi4uKGNsaWVudE9wdGlvbnMuZGVueVVybHMgfHwgW10pXSxcbiAgICBpZ25vcmVFcnJvcnM6IFtcbiAgICAgIC4uLihpbnRlcm5hbE9wdGlvbnMuaWdub3JlRXJyb3JzIHx8IFtdKSxcbiAgICAgIC4uLihjbGllbnRPcHRpb25zLmlnbm9yZUVycm9ycyB8fCBbXSksXG4gICAgICAuLi4oaW50ZXJuYWxPcHRpb25zLmRpc2FibGVFcnJvckRlZmF1bHRzID8gW10gOiBERUZBVUxUX0lHTk9SRV9FUlJPUlMpLFxuICAgIF0sXG4gICAgaWdub3JlVHJhbnNhY3Rpb25zOiBbLi4uKGludGVybmFsT3B0aW9ucy5pZ25vcmVUcmFuc2FjdGlvbnMgfHwgW10pLCAuLi4oY2xpZW50T3B0aW9ucy5pZ25vcmVUcmFuc2FjdGlvbnMgfHwgW10pXSxcbiAgfTtcbn1cblxuZnVuY3Rpb24gX3Nob3VsZERyb3BFdmVudChldmVudCwgb3B0aW9ucykge1xuICBpZiAoIWV2ZW50LnR5cGUpIHtcbiAgICAvLyBGaWx0ZXIgZXJyb3JzXG4gICAgaWYgKF9pc0lnbm9yZWRFcnJvcihldmVudCwgb3B0aW9ucy5pZ25vcmVFcnJvcnMpKSB7XG4gICAgICBkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEICYmXG4gICAgICAgIGRlYnVnTG9nZ2VyLmRlYnVnLndhcm4oXG4gICAgICAgICAgYEV2ZW50IGRyb3BwZWQgZHVlIHRvIGJlaW5nIG1hdGNoZWQgYnkgXFxgaWdub3JlRXJyb3JzXFxgIG9wdGlvbi5cXG5FdmVudDogJHttaXNjLmdldEV2ZW50RGVzY3JpcHRpb24oZXZlbnQpfWAsXG4gICAgICAgICk7XG4gICAgICByZXR1cm4gdHJ1ZTtcbiAgICB9XG4gICAgaWYgKF9pc1VzZWxlc3NFcnJvcihldmVudCkpIHtcbiAgICAgIGRlYnVnQnVpbGQuREVCVUdfQlVJTEQgJiZcbiAgICAgICAgZGVidWdMb2dnZXIuZGVidWcud2FybihcbiAgICAgICAgICBgRXZlbnQgZHJvcHBlZCBkdWUgdG8gbm90IGhhdmluZyBhbiBlcnJvciBtZXNzYWdlLCBlcnJvciB0eXBlIG9yIHN0YWNrdHJhY2UuXFxuRXZlbnQ6ICR7bWlzYy5nZXRFdmVudERlc2NyaXB0aW9uKFxuICAgICAgICAgICAgZXZlbnQsXG4gICAgICAgICAgKX1gLFxuICAgICAgICApO1xuICAgICAgcmV0dXJuIHRydWU7XG4gICAgfVxuICAgIGlmIChfaXNEZW5pZWRVcmwoZXZlbnQsIG9wdGlvbnMuZGVueVVybHMpKSB7XG4gICAgICBkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEICYmXG4gICAgICAgIGRlYnVnTG9nZ2VyLmRlYnVnLndhcm4oXG4gICAgICAgICAgYEV2ZW50IGRyb3BwZWQgZHVlIHRvIGJlaW5nIG1hdGNoZWQgYnkgXFxgZGVueVVybHNcXGAgb3B0aW9uLlxcbkV2ZW50OiAke21pc2MuZ2V0RXZlbnREZXNjcmlwdGlvbihcbiAgICAgICAgICAgIGV2ZW50LFxuICAgICAgICAgICl9LlxcblVybDogJHtfZ2V0RXZlbnRGaWx0ZXJVcmwoZXZlbnQpfWAsXG4gICAgICAgICk7XG4gICAgICByZXR1cm4gdHJ1ZTtcbiAgICB9XG4gICAgaWYgKCFfaXNBbGxvd2VkVXJsKGV2ZW50LCBvcHRpb25zLmFsbG93VXJscykpIHtcbiAgICAgIGRlYnVnQnVpbGQuREVCVUdfQlVJTEQgJiZcbiAgICAgICAgZGVidWdMb2dnZXIuZGVidWcud2FybihcbiAgICAgICAgICBgRXZlbnQgZHJvcHBlZCBkdWUgdG8gbm90IGJlaW5nIG1hdGNoZWQgYnkgXFxgYWxsb3dVcmxzXFxgIG9wdGlvbi5cXG5FdmVudDogJHttaXNjLmdldEV2ZW50RGVzY3JpcHRpb24oXG4gICAgICAgICAgICBldmVudCxcbiAgICAgICAgICApfS5cXG5Vcmw6ICR7X2dldEV2ZW50RmlsdGVyVXJsKGV2ZW50KX1gLFxuICAgICAgICApO1xuICAgICAgcmV0dXJuIHRydWU7XG4gICAgfVxuICB9IGVsc2UgaWYgKGV2ZW50LnR5cGUgPT09ICd0cmFuc2FjdGlvbicpIHtcbiAgICAvLyBGaWx0ZXIgdHJhbnNhY3Rpb25zXG5cbiAgICBpZiAoX2lzSWdub3JlZFRyYW5zYWN0aW9uKGV2ZW50LCBvcHRpb25zLmlnbm9yZVRyYW5zYWN0aW9ucykpIHtcbiAgICAgIGRlYnVnQnVpbGQuREVCVUdfQlVJTEQgJiZcbiAgICAgICAgZGVidWdMb2dnZXIuZGVidWcud2FybihcbiAgICAgICAgICBgRXZlbnQgZHJvcHBlZCBkdWUgdG8gYmVpbmcgbWF0Y2hlZCBieSBcXGBpZ25vcmVUcmFuc2FjdGlvbnNcXGAgb3B0aW9uLlxcbkV2ZW50OiAke21pc2MuZ2V0RXZlbnREZXNjcmlwdGlvbihldmVudCl9YCxcbiAgICAgICAgKTtcbiAgICAgIHJldHVybiB0cnVlO1xuICAgIH1cbiAgfVxuICByZXR1cm4gZmFsc2U7XG59XG5cbmZ1bmN0aW9uIF9pc0lnbm9yZWRFcnJvcihldmVudCwgaWdub3JlRXJyb3JzKSB7XG4gIGlmICghaWdub3JlRXJyb3JzPy5sZW5ndGgpIHtcbiAgICByZXR1cm4gZmFsc2U7XG4gIH1cblxuICByZXR1cm4gZXZlbnRVdGlscy5nZXRQb3NzaWJsZUV2ZW50TWVzc2FnZXMoZXZlbnQpLnNvbWUobWVzc2FnZSA9PiBzdHJpbmcuc3RyaW5nTWF0Y2hlc1NvbWVQYXR0ZXJuKG1lc3NhZ2UsIGlnbm9yZUVycm9ycykpO1xufVxuXG5mdW5jdGlvbiBfaXNJZ25vcmVkVHJhbnNhY3Rpb24oZXZlbnQsIGlnbm9yZVRyYW5zYWN0aW9ucykge1xuICBpZiAoIWlnbm9yZVRyYW5zYWN0aW9ucz8ubGVuZ3RoKSB7XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG5cbiAgY29uc3QgbmFtZSA9IGV2ZW50LnRyYW5zYWN0aW9uO1xuICByZXR1cm4gbmFtZSA/IHN0cmluZy5zdHJpbmdNYXRjaGVzU29tZVBhdHRlcm4obmFtZSwgaWdub3JlVHJhbnNhY3Rpb25zKSA6IGZhbHNlO1xufVxuXG5mdW5jdGlvbiBfaXNEZW5pZWRVcmwoZXZlbnQsIGRlbnlVcmxzKSB7XG4gIGlmICghZGVueVVybHM/Lmxlbmd0aCkge1xuICAgIHJldHVybiBmYWxzZTtcbiAgfVxuICBjb25zdCB1cmwgPSBfZ2V0RXZlbnRGaWx0ZXJVcmwoZXZlbnQpO1xuICByZXR1cm4gIXVybCA/IGZhbHNlIDogc3RyaW5nLnN0cmluZ01hdGNoZXNTb21lUGF0dGVybih1cmwsIGRlbnlVcmxzKTtcbn1cblxuZnVuY3Rpb24gX2lzQWxsb3dlZFVybChldmVudCwgYWxsb3dVcmxzKSB7XG4gIGlmICghYWxsb3dVcmxzPy5sZW5ndGgpIHtcbiAgICByZXR1cm4gdHJ1ZTtcbiAgfVxuICBjb25zdCB1cmwgPSBfZ2V0RXZlbnRGaWx0ZXJVcmwoZXZlbnQpO1xuICByZXR1cm4gIXVybCA/IHRydWUgOiBzdHJpbmcuc3RyaW5nTWF0Y2hlc1NvbWVQYXR0ZXJuKHVybCwgYWxsb3dVcmxzKTtcbn1cblxuZnVuY3Rpb24gX2dldExhc3RWYWxpZFVybChmcmFtZXMgPSBbXSkge1xuICBmb3IgKGxldCBpID0gZnJhbWVzLmxlbmd0aCAtIDE7IGkgPj0gMDsgaS0tKSB7XG4gICAgY29uc3QgZnJhbWUgPSBmcmFtZXNbaV07XG5cbiAgICBpZiAoZnJhbWUgJiYgZnJhbWUuZmlsZW5hbWUgIT09ICc8YW5vbnltb3VzPicgJiYgZnJhbWUuZmlsZW5hbWUgIT09ICdbbmF0aXZlIGNvZGVdJykge1xuICAgICAgcmV0dXJuIGZyYW1lLmZpbGVuYW1lIHx8IG51bGw7XG4gICAgfVxuICB9XG5cbiAgcmV0dXJuIG51bGw7XG59XG5cbmZ1bmN0aW9uIF9nZXRFdmVudEZpbHRlclVybChldmVudCkge1xuICB0cnkge1xuICAgIC8vIElmIHRoZXJlIGFyZSBsaW5rZWQgZXhjZXB0aW9ucyBvciBleGNlcHRpb24gYWdncmVnYXRlcyB3ZSBvbmx5IHdhbnQgdG8gbWF0Y2ggYWdhaW5zdCB0aGUgdG9wIGZyYW1lIG9mIHRoZSBcInJvb3RcIiAodGhlIG1haW4gZXhjZXB0aW9uKVxuICAgIC8vIFRoZSByb290IGFsd2F5cyBjb21lcyBsYXN0IGluIGxpbmtlZCBleGNlcHRpb25zXG4gICAgY29uc3Qgcm9vdEV4Y2VwdGlvbiA9IFsuLi4oZXZlbnQuZXhjZXB0aW9uPy52YWx1ZXMgPz8gW10pXVxuICAgICAgLnJldmVyc2UoKVxuICAgICAgLmZpbmQodmFsdWUgPT4gdmFsdWUubWVjaGFuaXNtPy5wYXJlbnRfaWQgPT09IHVuZGVmaW5lZCAmJiB2YWx1ZS5zdGFja3RyYWNlPy5mcmFtZXM/Lmxlbmd0aCk7XG4gICAgY29uc3QgZnJhbWVzID0gcm9vdEV4Y2VwdGlvbj8uc3RhY2t0cmFjZT8uZnJhbWVzO1xuICAgIHJldHVybiBmcmFtZXMgPyBfZ2V0TGFzdFZhbGlkVXJsKGZyYW1lcykgOiBudWxsO1xuICB9IGNhdGNoIHtcbiAgICBkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEICYmIGRlYnVnTG9nZ2VyLmRlYnVnLmVycm9yKGBDYW5ub3QgZXh0cmFjdCB1cmwgZm9yIGV2ZW50ICR7bWlzYy5nZXRFdmVudERlc2NyaXB0aW9uKGV2ZW50KX1gKTtcbiAgICByZXR1cm4gbnVsbDtcbiAgfVxufVxuXG5mdW5jdGlvbiBfaXNVc2VsZXNzRXJyb3IoZXZlbnQpIHtcbiAgLy8gV2Ugb25seSB3YW50IHRvIGNvbnNpZGVyIGV2ZW50cyBmb3IgZHJvcHBpbmcgdGhhdCBhY3R1YWxseSBoYXZlIHJlY29yZGVkIGV4Y2VwdGlvbiB2YWx1ZXMuXG4gIGlmICghZXZlbnQuZXhjZXB0aW9uPy52YWx1ZXM/Lmxlbmd0aCkge1xuICAgIHJldHVybiBmYWxzZTtcbiAgfVxuXG4gIHJldHVybiAoXG4gICAgLy8gTm8gdG9wLWxldmVsIG1lc3NhZ2VcbiAgICAhZXZlbnQubWVzc2FnZSAmJlxuICAgIC8vIFRoZXJlIGFyZSBubyBleGNlcHRpb24gdmFsdWVzIHRoYXQgaGF2ZSBhIHN0YWNrdHJhY2UsIGEgbm9uLWdlbmVyaWMtRXJyb3IgdHlwZSBvciB2YWx1ZVxuICAgICFldmVudC5leGNlcHRpb24udmFsdWVzLnNvbWUodmFsdWUgPT4gdmFsdWUuc3RhY2t0cmFjZSB8fCAodmFsdWUudHlwZSAmJiB2YWx1ZS50eXBlICE9PSAnRXJyb3InKSB8fCB2YWx1ZS52YWx1ZSlcbiAgKTtcbn1cblxuZXhwb3J0cy5ldmVudEZpbHRlcnNJbnRlZ3JhdGlvbiA9IGV2ZW50RmlsdGVyc0ludGVncmF0aW9uO1xuZXhwb3J0cy5pbmJvdW5kRmlsdGVyc0ludGVncmF0aW9uID0gaW5ib3VuZEZpbHRlcnNJbnRlZ3JhdGlvbjtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWV2ZW50RmlsdGVycy5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/eventFilters.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/extraerrordata.js":
/*!*******************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/extraerrordata.js ***!
  \*******************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst debugBuild = __webpack_require__(/*! ../debug-build.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst integration = __webpack_require__(/*! ../integration.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integration.js\");\nconst debugLogger = __webpack_require__(/*! ../utils/debug-logger.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst is = __webpack_require__(/*! ../utils/is.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js\");\nconst normalize = __webpack_require__(/*! ../utils/normalize.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/normalize.js\");\nconst object = __webpack_require__(/*! ../utils/object.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/object.js\");\nconst string = __webpack_require__(/*! ../utils/string.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/string.js\");\n\nconst INTEGRATION_NAME = 'ExtraErrorData';\n\n/**\n * Extract additional data for from original exceptions.\n */\nconst _extraErrorDataIntegration = ((options = {}) => {\n  const { depth = 3, captureErrorCause = true } = options;\n  return {\n    name: INTEGRATION_NAME,\n    processEvent(event, hint, client) {\n      const { maxValueLength = 250 } = client.getOptions();\n      return _enhanceEventWithErrorData(event, hint, depth, captureErrorCause, maxValueLength);\n    },\n  };\n}) ;\n\nconst extraErrorDataIntegration = integration.defineIntegration(_extraErrorDataIntegration);\n\nfunction _enhanceEventWithErrorData(\n  event,\n  hint = {},\n  depth,\n  captureErrorCause,\n  maxValueLength,\n) {\n  if (!hint.originalException || !is.isError(hint.originalException)) {\n    return event;\n  }\n  const exceptionName = (hint.originalException ).name || hint.originalException.constructor.name;\n\n  const errorData = _extractErrorData(hint.originalException , captureErrorCause, maxValueLength);\n\n  if (errorData) {\n    const contexts = {\n      ...event.contexts,\n    };\n\n    const normalizedErrorData = normalize.normalize(errorData, depth);\n\n    if (is.isPlainObject(normalizedErrorData)) {\n      // We mark the error data as \"already normalized\" here, because we don't want other normalization procedures to\n      // potentially truncate the data we just already normalized, with a certain depth setting.\n      object.addNonEnumerableProperty(normalizedErrorData, '__sentry_skip_normalization__', true);\n      contexts[exceptionName] = normalizedErrorData;\n    }\n\n    return {\n      ...event,\n      contexts,\n    };\n  }\n\n  return event;\n}\n\n/**\n * Extract extra information from the Error object\n */\nfunction _extractErrorData(\n  error,\n  captureErrorCause,\n  maxValueLength,\n) {\n  // We are trying to enhance already existing event, so no harm done if it won't succeed\n  try {\n    const nativeKeys = [\n      'name',\n      'message',\n      'stack',\n      'line',\n      'column',\n      'fileName',\n      'lineNumber',\n      'columnNumber',\n      'toJSON',\n    ];\n\n    const extraErrorInfo = {};\n\n    // We want only enumerable properties, thus `getOwnPropertyNames` is redundant here, as we filter keys anyway.\n    for (const key of Object.keys(error)) {\n      if (nativeKeys.indexOf(key) !== -1) {\n        continue;\n      }\n      const value = error[key];\n      extraErrorInfo[key] = is.isError(value) || typeof value === 'string' ? string.truncate(`${value}`, maxValueLength) : value;\n    }\n\n    // Error.cause is a standard property that is non enumerable, we therefore need to access it separately.\n    // https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Error/cause\n    if (captureErrorCause && error.cause !== undefined) {\n      extraErrorInfo.cause = is.isError(error.cause) ? error.cause.toString() : error.cause;\n    }\n\n    // Check if someone attached `toJSON` method to grab even more properties (eg. axios is doing that)\n    if (typeof error.toJSON === 'function') {\n      const serializedError = error.toJSON() ;\n\n      for (const key of Object.keys(serializedError)) {\n        const value = serializedError[key];\n        extraErrorInfo[key] = is.isError(value) ? value.toString() : value;\n      }\n    }\n\n    return extraErrorInfo;\n  } catch (oO) {\n    debugBuild.DEBUG_BUILD && debugLogger.debug.error('Unable to extract extra data from the Error object:', oO);\n  }\n\n  return null;\n}\n\nexports.extraErrorDataIntegration = extraErrorDataIntegration;\n//# sourceMappingURL=extraerrordata.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvZXh0cmFlcnJvcmRhdGEuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsbUJBQW1CLG1CQUFPLENBQUMsNEhBQW1CO0FBQzlDLG9CQUFvQixtQkFBTyxDQUFDLDRIQUFtQjtBQUMvQyxvQkFBb0IsbUJBQU8sQ0FBQywwSUFBMEI7QUFDdEQsV0FBVyxtQkFBTyxDQUFDLHNIQUFnQjtBQUNuQyxrQkFBa0IsbUJBQU8sQ0FBQyxvSUFBdUI7QUFDakQsZUFBZSxtQkFBTyxDQUFDLDhIQUFvQjtBQUMzQyxlQUFlLG1CQUFPLENBQUMsOEhBQW9COztBQUUzQzs7QUFFQTtBQUNBO0FBQ0E7QUFDQSxpREFBaUQ7QUFDakQsVUFBVSxzQ0FBc0M7QUFDaEQ7QUFDQTtBQUNBO0FBQ0EsY0FBYyx1QkFBdUI7QUFDckM7QUFDQSxLQUFLO0FBQ0w7QUFDQSxDQUFDOztBQUVEOztBQUVBO0FBQ0E7QUFDQSxXQUFXO0FBQ1g7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxnR0FBZ0csTUFBTTtBQUN0Rzs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0EsSUFBSTtBQUNKO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQSxpQ0FBaUM7QUFDakMiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvZXh0cmFlcnJvcmRhdGEuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGRlYnVnQnVpbGQgPSByZXF1aXJlKCcuLi9kZWJ1Zy1idWlsZC5qcycpO1xuY29uc3QgaW50ZWdyYXRpb24gPSByZXF1aXJlKCcuLi9pbnRlZ3JhdGlvbi5qcycpO1xuY29uc3QgZGVidWdMb2dnZXIgPSByZXF1aXJlKCcuLi91dGlscy9kZWJ1Zy1sb2dnZXIuanMnKTtcbmNvbnN0IGlzID0gcmVxdWlyZSgnLi4vdXRpbHMvaXMuanMnKTtcbmNvbnN0IG5vcm1hbGl6ZSA9IHJlcXVpcmUoJy4uL3V0aWxzL25vcm1hbGl6ZS5qcycpO1xuY29uc3Qgb2JqZWN0ID0gcmVxdWlyZSgnLi4vdXRpbHMvb2JqZWN0LmpzJyk7XG5jb25zdCBzdHJpbmcgPSByZXF1aXJlKCcuLi91dGlscy9zdHJpbmcuanMnKTtcblxuY29uc3QgSU5URUdSQVRJT05fTkFNRSA9ICdFeHRyYUVycm9yRGF0YSc7XG5cbi8qKlxuICogRXh0cmFjdCBhZGRpdGlvbmFsIGRhdGEgZm9yIGZyb20gb3JpZ2luYWwgZXhjZXB0aW9ucy5cbiAqL1xuY29uc3QgX2V4dHJhRXJyb3JEYXRhSW50ZWdyYXRpb24gPSAoKG9wdGlvbnMgPSB7fSkgPT4ge1xuICBjb25zdCB7IGRlcHRoID0gMywgY2FwdHVyZUVycm9yQ2F1c2UgPSB0cnVlIH0gPSBvcHRpb25zO1xuICByZXR1cm4ge1xuICAgIG5hbWU6IElOVEVHUkFUSU9OX05BTUUsXG4gICAgcHJvY2Vzc0V2ZW50KGV2ZW50LCBoaW50LCBjbGllbnQpIHtcbiAgICAgIGNvbnN0IHsgbWF4VmFsdWVMZW5ndGggPSAyNTAgfSA9IGNsaWVudC5nZXRPcHRpb25zKCk7XG4gICAgICByZXR1cm4gX2VuaGFuY2VFdmVudFdpdGhFcnJvckRhdGEoZXZlbnQsIGhpbnQsIGRlcHRoLCBjYXB0dXJlRXJyb3JDYXVzZSwgbWF4VmFsdWVMZW5ndGgpO1xuICAgIH0sXG4gIH07XG59KSA7XG5cbmNvbnN0IGV4dHJhRXJyb3JEYXRhSW50ZWdyYXRpb24gPSBpbnRlZ3JhdGlvbi5kZWZpbmVJbnRlZ3JhdGlvbihfZXh0cmFFcnJvckRhdGFJbnRlZ3JhdGlvbik7XG5cbmZ1bmN0aW9uIF9lbmhhbmNlRXZlbnRXaXRoRXJyb3JEYXRhKFxuICBldmVudCxcbiAgaGludCA9IHt9LFxuICBkZXB0aCxcbiAgY2FwdHVyZUVycm9yQ2F1c2UsXG4gIG1heFZhbHVlTGVuZ3RoLFxuKSB7XG4gIGlmICghaGludC5vcmlnaW5hbEV4Y2VwdGlvbiB8fCAhaXMuaXNFcnJvcihoaW50Lm9yaWdpbmFsRXhjZXB0aW9uKSkge1xuICAgIHJldHVybiBldmVudDtcbiAgfVxuICBjb25zdCBleGNlcHRpb25OYW1lID0gKGhpbnQub3JpZ2luYWxFeGNlcHRpb24gKS5uYW1lIHx8IGhpbnQub3JpZ2luYWxFeGNlcHRpb24uY29uc3RydWN0b3IubmFtZTtcblxuICBjb25zdCBlcnJvckRhdGEgPSBfZXh0cmFjdEVycm9yRGF0YShoaW50Lm9yaWdpbmFsRXhjZXB0aW9uICwgY2FwdHVyZUVycm9yQ2F1c2UsIG1heFZhbHVlTGVuZ3RoKTtcblxuICBpZiAoZXJyb3JEYXRhKSB7XG4gICAgY29uc3QgY29udGV4dHMgPSB7XG4gICAgICAuLi5ldmVudC5jb250ZXh0cyxcbiAgICB9O1xuXG4gICAgY29uc3Qgbm9ybWFsaXplZEVycm9yRGF0YSA9IG5vcm1hbGl6ZS5ub3JtYWxpemUoZXJyb3JEYXRhLCBkZXB0aCk7XG5cbiAgICBpZiAoaXMuaXNQbGFpbk9iamVjdChub3JtYWxpemVkRXJyb3JEYXRhKSkge1xuICAgICAgLy8gV2UgbWFyayB0aGUgZXJyb3IgZGF0YSBhcyBcImFscmVhZHkgbm9ybWFsaXplZFwiIGhlcmUsIGJlY2F1c2Ugd2UgZG9uJ3Qgd2FudCBvdGhlciBub3JtYWxpemF0aW9uIHByb2NlZHVyZXMgdG9cbiAgICAgIC8vIHBvdGVudGlhbGx5IHRydW5jYXRlIHRoZSBkYXRhIHdlIGp1c3QgYWxyZWFkeSBub3JtYWxpemVkLCB3aXRoIGEgY2VydGFpbiBkZXB0aCBzZXR0aW5nLlxuICAgICAgb2JqZWN0LmFkZE5vbkVudW1lcmFibGVQcm9wZXJ0eShub3JtYWxpemVkRXJyb3JEYXRhLCAnX19zZW50cnlfc2tpcF9ub3JtYWxpemF0aW9uX18nLCB0cnVlKTtcbiAgICAgIGNvbnRleHRzW2V4Y2VwdGlvbk5hbWVdID0gbm9ybWFsaXplZEVycm9yRGF0YTtcbiAgICB9XG5cbiAgICByZXR1cm4ge1xuICAgICAgLi4uZXZlbnQsXG4gICAgICBjb250ZXh0cyxcbiAgICB9O1xuICB9XG5cbiAgcmV0dXJuIGV2ZW50O1xufVxuXG4vKipcbiAqIEV4dHJhY3QgZXh0cmEgaW5mb3JtYXRpb24gZnJvbSB0aGUgRXJyb3Igb2JqZWN0XG4gKi9cbmZ1bmN0aW9uIF9leHRyYWN0RXJyb3JEYXRhKFxuICBlcnJvcixcbiAgY2FwdHVyZUVycm9yQ2F1c2UsXG4gIG1heFZhbHVlTGVuZ3RoLFxuKSB7XG4gIC8vIFdlIGFyZSB0cnlpbmcgdG8gZW5oYW5jZSBhbHJlYWR5IGV4aXN0aW5nIGV2ZW50LCBzbyBubyBoYXJtIGRvbmUgaWYgaXQgd29uJ3Qgc3VjY2VlZFxuICB0cnkge1xuICAgIGNvbnN0IG5hdGl2ZUtleXMgPSBbXG4gICAgICAnbmFtZScsXG4gICAgICAnbWVzc2FnZScsXG4gICAgICAnc3RhY2snLFxuICAgICAgJ2xpbmUnLFxuICAgICAgJ2NvbHVtbicsXG4gICAgICAnZmlsZU5hbWUnLFxuICAgICAgJ2xpbmVOdW1iZXInLFxuICAgICAgJ2NvbHVtbk51bWJlcicsXG4gICAgICAndG9KU09OJyxcbiAgICBdO1xuXG4gICAgY29uc3QgZXh0cmFFcnJvckluZm8gPSB7fTtcblxuICAgIC8vIFdlIHdhbnQgb25seSBlbnVtZXJhYmxlIHByb3BlcnRpZXMsIHRodXMgYGdldE93blByb3BlcnR5TmFtZXNgIGlzIHJlZHVuZGFudCBoZXJlLCBhcyB3ZSBmaWx0ZXIga2V5cyBhbnl3YXkuXG4gICAgZm9yIChjb25zdCBrZXkgb2YgT2JqZWN0LmtleXMoZXJyb3IpKSB7XG4gICAgICBpZiAobmF0aXZlS2V5cy5pbmRleE9mKGtleSkgIT09IC0xKSB7XG4gICAgICAgIGNvbnRpbnVlO1xuICAgICAgfVxuICAgICAgY29uc3QgdmFsdWUgPSBlcnJvcltrZXldO1xuICAgICAgZXh0cmFFcnJvckluZm9ba2V5XSA9IGlzLmlzRXJyb3IodmFsdWUpIHx8IHR5cGVvZiB2YWx1ZSA9PT0gJ3N0cmluZycgPyBzdHJpbmcudHJ1bmNhdGUoYCR7dmFsdWV9YCwgbWF4VmFsdWVMZW5ndGgpIDogdmFsdWU7XG4gICAgfVxuXG4gICAgLy8gRXJyb3IuY2F1c2UgaXMgYSBzdGFuZGFyZCBwcm9wZXJ0eSB0aGF0IGlzIG5vbiBlbnVtZXJhYmxlLCB3ZSB0aGVyZWZvcmUgbmVlZCB0byBhY2Nlc3MgaXQgc2VwYXJhdGVseS5cbiAgICAvLyBodHRwczovL2RldmVsb3Blci5tb3ppbGxhLm9yZy9lbi1VUy9kb2NzL1dlYi9KYXZhU2NyaXB0L1JlZmVyZW5jZS9HbG9iYWxfT2JqZWN0cy9FcnJvci9jYXVzZVxuICAgIGlmIChjYXB0dXJlRXJyb3JDYXVzZSAmJiBlcnJvci5jYXVzZSAhPT0gdW5kZWZpbmVkKSB7XG4gICAgICBleHRyYUVycm9ySW5mby5jYXVzZSA9IGlzLmlzRXJyb3IoZXJyb3IuY2F1c2UpID8gZXJyb3IuY2F1c2UudG9TdHJpbmcoKSA6IGVycm9yLmNhdXNlO1xuICAgIH1cblxuICAgIC8vIENoZWNrIGlmIHNvbWVvbmUgYXR0YWNoZWQgYHRvSlNPTmAgbWV0aG9kIHRvIGdyYWIgZXZlbiBtb3JlIHByb3BlcnRpZXMgKGVnLiBheGlvcyBpcyBkb2luZyB0aGF0KVxuICAgIGlmICh0eXBlb2YgZXJyb3IudG9KU09OID09PSAnZnVuY3Rpb24nKSB7XG4gICAgICBjb25zdCBzZXJpYWxpemVkRXJyb3IgPSBlcnJvci50b0pTT04oKSA7XG5cbiAgICAgIGZvciAoY29uc3Qga2V5IG9mIE9iamVjdC5rZXlzKHNlcmlhbGl6ZWRFcnJvcikpIHtcbiAgICAgICAgY29uc3QgdmFsdWUgPSBzZXJpYWxpemVkRXJyb3Jba2V5XTtcbiAgICAgICAgZXh0cmFFcnJvckluZm9ba2V5XSA9IGlzLmlzRXJyb3IodmFsdWUpID8gdmFsdWUudG9TdHJpbmcoKSA6IHZhbHVlO1xuICAgICAgfVxuICAgIH1cblxuICAgIHJldHVybiBleHRyYUVycm9ySW5mbztcbiAgfSBjYXRjaCAob08pIHtcbiAgICBkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEICYmIGRlYnVnTG9nZ2VyLmRlYnVnLmVycm9yKCdVbmFibGUgdG8gZXh0cmFjdCBleHRyYSBkYXRhIGZyb20gdGhlIEVycm9yIG9iamVjdDonLCBvTyk7XG4gIH1cblxuICByZXR1cm4gbnVsbDtcbn1cblxuZXhwb3J0cy5leHRyYUVycm9yRGF0YUludGVncmF0aW9uID0gZXh0cmFFcnJvckRhdGFJbnRlZ3JhdGlvbjtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWV4dHJhZXJyb3JkYXRhLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/extraerrordata.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/featureFlags/featureFlagsIntegration.js":
/*!*****************************************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/featureFlags/featureFlagsIntegration.js ***!
  \*****************************************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst integration = __webpack_require__(/*! ../../integration.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integration.js\");\nconst featureFlags = __webpack_require__(/*! ../../utils/featureFlags.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/featureFlags.js\");\n\n/**\n * Sentry integration for buffering feature flag evaluations manually with an API, and\n * capturing them on error events and spans.\n *\n * See the [feature flag documentation](https://develop.sentry.dev/sdk/expected-features/#feature-flags) for more information.\n *\n * @example\n * ```\n * import * as Sentry from '@sentry/browser';\n * import { type FeatureFlagsIntegration } from '@sentry/browser';\n *\n * // Setup\n * Sentry.init(..., integrations: [Sentry.featureFlagsIntegration()])\n *\n * // Verify\n * const flagsIntegration = Sentry.getClient()?.getIntegrationByName<FeatureFlagsIntegration>('FeatureFlags');\n * if (flagsIntegration) {\n *   flagsIntegration.addFeatureFlag('my-flag', true);\n * } else {\n *   // check your setup\n * }\n * Sentry.captureException(Exception('broke')); // 'my-flag' should be captured to this Sentry event.\n * ```\n */\nconst featureFlagsIntegration = integration.defineIntegration(() => {\n  return {\n    name: 'FeatureFlags',\n\n    processEvent(event, _hint, _client) {\n      return featureFlags._INTERNAL_copyFlagsFromScopeToEvent(event);\n    },\n\n    addFeatureFlag(name, value) {\n      featureFlags._INTERNAL_insertFlagToScope(name, value);\n      featureFlags._INTERNAL_addFeatureFlagToActiveSpan(name, value);\n    },\n  };\n}) ;\n\nexports.featureFlagsIntegration = featureFlagsIntegration;\n//# sourceMappingURL=featureFlagsIntegration.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvZmVhdHVyZUZsYWdzL2ZlYXR1cmVGbGFnc0ludGVncmF0aW9uLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLG9CQUFvQixtQkFBTyxDQUFDLCtIQUFzQjtBQUNsRCxxQkFBcUIsbUJBQU8sQ0FBQyw2SUFBNkI7O0FBRTFEO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFlBQVksK0JBQStCO0FBQzNDO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxLQUFLO0FBQ0w7QUFDQTtBQUNBLGdEQUFnRDtBQUNoRDtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQSxLQUFLOztBQUVMO0FBQ0E7QUFDQTtBQUNBLEtBQUs7QUFDTDtBQUNBLENBQUM7O0FBRUQsK0JBQStCO0FBQy9CIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvaW50ZWdyYXRpb25zL2ZlYXR1cmVGbGFncy9mZWF0dXJlRmxhZ3NJbnRlZ3JhdGlvbi5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgaW50ZWdyYXRpb24gPSByZXF1aXJlKCcuLi8uLi9pbnRlZ3JhdGlvbi5qcycpO1xuY29uc3QgZmVhdHVyZUZsYWdzID0gcmVxdWlyZSgnLi4vLi4vdXRpbHMvZmVhdHVyZUZsYWdzLmpzJyk7XG5cbi8qKlxuICogU2VudHJ5IGludGVncmF0aW9uIGZvciBidWZmZXJpbmcgZmVhdHVyZSBmbGFnIGV2YWx1YXRpb25zIG1hbnVhbGx5IHdpdGggYW4gQVBJLCBhbmRcbiAqIGNhcHR1cmluZyB0aGVtIG9uIGVycm9yIGV2ZW50cyBhbmQgc3BhbnMuXG4gKlxuICogU2VlIHRoZSBbZmVhdHVyZSBmbGFnIGRvY3VtZW50YXRpb25dKGh0dHBzOi8vZGV2ZWxvcC5zZW50cnkuZGV2L3Nkay9leHBlY3RlZC1mZWF0dXJlcy8jZmVhdHVyZS1mbGFncykgZm9yIG1vcmUgaW5mb3JtYXRpb24uXG4gKlxuICogQGV4YW1wbGVcbiAqIGBgYFxuICogaW1wb3J0ICogYXMgU2VudHJ5IGZyb20gJ0BzZW50cnkvYnJvd3Nlcic7XG4gKiBpbXBvcnQgeyB0eXBlIEZlYXR1cmVGbGFnc0ludGVncmF0aW9uIH0gZnJvbSAnQHNlbnRyeS9icm93c2VyJztcbiAqXG4gKiAvLyBTZXR1cFxuICogU2VudHJ5LmluaXQoLi4uLCBpbnRlZ3JhdGlvbnM6IFtTZW50cnkuZmVhdHVyZUZsYWdzSW50ZWdyYXRpb24oKV0pXG4gKlxuICogLy8gVmVyaWZ5XG4gKiBjb25zdCBmbGFnc0ludGVncmF0aW9uID0gU2VudHJ5LmdldENsaWVudCgpPy5nZXRJbnRlZ3JhdGlvbkJ5TmFtZTxGZWF0dXJlRmxhZ3NJbnRlZ3JhdGlvbj4oJ0ZlYXR1cmVGbGFncycpO1xuICogaWYgKGZsYWdzSW50ZWdyYXRpb24pIHtcbiAqICAgZmxhZ3NJbnRlZ3JhdGlvbi5hZGRGZWF0dXJlRmxhZygnbXktZmxhZycsIHRydWUpO1xuICogfSBlbHNlIHtcbiAqICAgLy8gY2hlY2sgeW91ciBzZXR1cFxuICogfVxuICogU2VudHJ5LmNhcHR1cmVFeGNlcHRpb24oRXhjZXB0aW9uKCdicm9rZScpKTsgLy8gJ215LWZsYWcnIHNob3VsZCBiZSBjYXB0dXJlZCB0byB0aGlzIFNlbnRyeSBldmVudC5cbiAqIGBgYFxuICovXG5jb25zdCBmZWF0dXJlRmxhZ3NJbnRlZ3JhdGlvbiA9IGludGVncmF0aW9uLmRlZmluZUludGVncmF0aW9uKCgpID0+IHtcbiAgcmV0dXJuIHtcbiAgICBuYW1lOiAnRmVhdHVyZUZsYWdzJyxcblxuICAgIHByb2Nlc3NFdmVudChldmVudCwgX2hpbnQsIF9jbGllbnQpIHtcbiAgICAgIHJldHVybiBmZWF0dXJlRmxhZ3MuX0lOVEVSTkFMX2NvcHlGbGFnc0Zyb21TY29wZVRvRXZlbnQoZXZlbnQpO1xuICAgIH0sXG5cbiAgICBhZGRGZWF0dXJlRmxhZyhuYW1lLCB2YWx1ZSkge1xuICAgICAgZmVhdHVyZUZsYWdzLl9JTlRFUk5BTF9pbnNlcnRGbGFnVG9TY29wZShuYW1lLCB2YWx1ZSk7XG4gICAgICBmZWF0dXJlRmxhZ3MuX0lOVEVSTkFMX2FkZEZlYXR1cmVGbGFnVG9BY3RpdmVTcGFuKG5hbWUsIHZhbHVlKTtcbiAgICB9LFxuICB9O1xufSkgO1xuXG5leHBvcnRzLmZlYXR1cmVGbGFnc0ludGVncmF0aW9uID0gZmVhdHVyZUZsYWdzSW50ZWdyYXRpb247XG4vLyMgc291cmNlTWFwcGluZ1VSTD1mZWF0dXJlRmxhZ3NJbnRlZ3JhdGlvbi5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/featureFlags/featureFlagsIntegration.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/functiontostring.js":
/*!*********************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/functiontostring.js ***!
  \*********************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst currentScopes = __webpack_require__(/*! ../currentScopes.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst integration = __webpack_require__(/*! ../integration.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integration.js\");\nconst object = __webpack_require__(/*! ../utils/object.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/object.js\");\n\nlet originalFunctionToString;\n\nconst INTEGRATION_NAME = 'FunctionToString';\n\nconst SETUP_CLIENTS = new WeakMap();\n\nconst _functionToStringIntegration = (() => {\n  return {\n    name: INTEGRATION_NAME,\n    setupOnce() {\n      // eslint-disable-next-line @typescript-eslint/unbound-method\n      originalFunctionToString = Function.prototype.toString;\n\n      // intrinsics (like Function.prototype) might be immutable in some environments\n      // e.g. Node with --frozen-intrinsics, XS (an embedded JavaScript engine) or SES (a JavaScript proposal)\n      try {\n        Function.prototype.toString = function ( ...args) {\n          const originalFunction = object.getOriginalFunction(this);\n          const context =\n            SETUP_CLIENTS.has(currentScopes.getClient() ) && originalFunction !== undefined ? originalFunction : this;\n          return originalFunctionToString.apply(context, args);\n        };\n      } catch {\n        // ignore errors here, just don't patch this\n      }\n    },\n    setup(client) {\n      SETUP_CLIENTS.set(client, true);\n    },\n  };\n}) ;\n\n/**\n * Patch toString calls to return proper name for wrapped functions.\n *\n * ```js\n * Sentry.init({\n *   integrations: [\n *     functionToStringIntegration(),\n *   ],\n * });\n * ```\n */\nconst functionToStringIntegration = integration.defineIntegration(_functionToStringIntegration);\n\nexports.functionToStringIntegration = functionToStringIntegration;\n//# sourceMappingURL=functiontostring.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvZnVuY3Rpb250b3N0cmluZy5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxzQkFBc0IsbUJBQU8sQ0FBQyxnSUFBcUI7QUFDbkQsb0JBQW9CLG1CQUFPLENBQUMsNEhBQW1CO0FBQy9DLGVBQWUsbUJBQU8sQ0FBQyw4SEFBb0I7O0FBRTNDOztBQUVBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxRQUFRO0FBQ1I7QUFDQTtBQUNBLEtBQUs7QUFDTDtBQUNBO0FBQ0EsS0FBSztBQUNMO0FBQ0EsQ0FBQzs7QUFFRDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsSUFBSTtBQUNKO0FBQ0E7QUFDQTs7QUFFQSxtQ0FBbUM7QUFDbkMiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvZnVuY3Rpb250b3N0cmluZy5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgY3VycmVudFNjb3BlcyA9IHJlcXVpcmUoJy4uL2N1cnJlbnRTY29wZXMuanMnKTtcbmNvbnN0IGludGVncmF0aW9uID0gcmVxdWlyZSgnLi4vaW50ZWdyYXRpb24uanMnKTtcbmNvbnN0IG9iamVjdCA9IHJlcXVpcmUoJy4uL3V0aWxzL29iamVjdC5qcycpO1xuXG5sZXQgb3JpZ2luYWxGdW5jdGlvblRvU3RyaW5nO1xuXG5jb25zdCBJTlRFR1JBVElPTl9OQU1FID0gJ0Z1bmN0aW9uVG9TdHJpbmcnO1xuXG5jb25zdCBTRVRVUF9DTElFTlRTID0gbmV3IFdlYWtNYXAoKTtcblxuY29uc3QgX2Z1bmN0aW9uVG9TdHJpbmdJbnRlZ3JhdGlvbiA9ICgoKSA9PiB7XG4gIHJldHVybiB7XG4gICAgbmFtZTogSU5URUdSQVRJT05fTkFNRSxcbiAgICBzZXR1cE9uY2UoKSB7XG4gICAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L3VuYm91bmQtbWV0aG9kXG4gICAgICBvcmlnaW5hbEZ1bmN0aW9uVG9TdHJpbmcgPSBGdW5jdGlvbi5wcm90b3R5cGUudG9TdHJpbmc7XG5cbiAgICAgIC8vIGludHJpbnNpY3MgKGxpa2UgRnVuY3Rpb24ucHJvdG90eXBlKSBtaWdodCBiZSBpbW11dGFibGUgaW4gc29tZSBlbnZpcm9ubWVudHNcbiAgICAgIC8vIGUuZy4gTm9kZSB3aXRoIC0tZnJvemVuLWludHJpbnNpY3MsIFhTIChhbiBlbWJlZGRlZCBKYXZhU2NyaXB0IGVuZ2luZSkgb3IgU0VTIChhIEphdmFTY3JpcHQgcHJvcG9zYWwpXG4gICAgICB0cnkge1xuICAgICAgICBGdW5jdGlvbi5wcm90b3R5cGUudG9TdHJpbmcgPSBmdW5jdGlvbiAoIC4uLmFyZ3MpIHtcbiAgICAgICAgICBjb25zdCBvcmlnaW5hbEZ1bmN0aW9uID0gb2JqZWN0LmdldE9yaWdpbmFsRnVuY3Rpb24odGhpcyk7XG4gICAgICAgICAgY29uc3QgY29udGV4dCA9XG4gICAgICAgICAgICBTRVRVUF9DTElFTlRTLmhhcyhjdXJyZW50U2NvcGVzLmdldENsaWVudCgpICkgJiYgb3JpZ2luYWxGdW5jdGlvbiAhPT0gdW5kZWZpbmVkID8gb3JpZ2luYWxGdW5jdGlvbiA6IHRoaXM7XG4gICAgICAgICAgcmV0dXJuIG9yaWdpbmFsRnVuY3Rpb25Ub1N0cmluZy5hcHBseShjb250ZXh0LCBhcmdzKTtcbiAgICAgICAgfTtcbiAgICAgIH0gY2F0Y2gge1xuICAgICAgICAvLyBpZ25vcmUgZXJyb3JzIGhlcmUsIGp1c3QgZG9uJ3QgcGF0Y2ggdGhpc1xuICAgICAgfVxuICAgIH0sXG4gICAgc2V0dXAoY2xpZW50KSB7XG4gICAgICBTRVRVUF9DTElFTlRTLnNldChjbGllbnQsIHRydWUpO1xuICAgIH0sXG4gIH07XG59KSA7XG5cbi8qKlxuICogUGF0Y2ggdG9TdHJpbmcgY2FsbHMgdG8gcmV0dXJuIHByb3BlciBuYW1lIGZvciB3cmFwcGVkIGZ1bmN0aW9ucy5cbiAqXG4gKiBgYGBqc1xuICogU2VudHJ5LmluaXQoe1xuICogICBpbnRlZ3JhdGlvbnM6IFtcbiAqICAgICBmdW5jdGlvblRvU3RyaW5nSW50ZWdyYXRpb24oKSxcbiAqICAgXSxcbiAqIH0pO1xuICogYGBgXG4gKi9cbmNvbnN0IGZ1bmN0aW9uVG9TdHJpbmdJbnRlZ3JhdGlvbiA9IGludGVncmF0aW9uLmRlZmluZUludGVncmF0aW9uKF9mdW5jdGlvblRvU3RyaW5nSW50ZWdyYXRpb24pO1xuXG5leHBvcnRzLmZ1bmN0aW9uVG9TdHJpbmdJbnRlZ3JhdGlvbiA9IGZ1bmN0aW9uVG9TdHJpbmdJbnRlZ3JhdGlvbjtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWZ1bmN0aW9udG9zdHJpbmcuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/functiontostring.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/linkederrors.js":
/*!*****************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/linkederrors.js ***!
  \*****************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst integration = __webpack_require__(/*! ../integration.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integration.js\");\nconst aggregateErrors = __webpack_require__(/*! ../utils/aggregate-errors.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/aggregate-errors.js\");\nconst eventbuilder = __webpack_require__(/*! ../utils/eventbuilder.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/eventbuilder.js\");\n\nconst DEFAULT_KEY = 'cause';\nconst DEFAULT_LIMIT = 5;\n\nconst INTEGRATION_NAME = 'LinkedErrors';\n\nconst _linkedErrorsIntegration = ((options = {}) => {\n  const limit = options.limit || DEFAULT_LIMIT;\n  const key = options.key || DEFAULT_KEY;\n\n  return {\n    name: INTEGRATION_NAME,\n    preprocessEvent(event, hint, client) {\n      const options = client.getOptions();\n\n      aggregateErrors.applyAggregateErrorsToEvent(eventbuilder.exceptionFromError, options.stackParser, key, limit, event, hint);\n    },\n  };\n}) ;\n\nconst linkedErrorsIntegration = integration.defineIntegration(_linkedErrorsIntegration);\n\nexports.linkedErrorsIntegration = linkedErrorsIntegration;\n//# sourceMappingURL=linkederrors.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvbGlua2VkZXJyb3JzLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLG9CQUFvQixtQkFBTyxDQUFDLDRIQUFtQjtBQUMvQyx3QkFBd0IsbUJBQU8sQ0FBQyxrSkFBOEI7QUFDOUQscUJBQXFCLG1CQUFPLENBQUMsMElBQTBCOztBQUV2RDtBQUNBOztBQUVBOztBQUVBLCtDQUErQztBQUMvQztBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0EsS0FBSztBQUNMO0FBQ0EsQ0FBQzs7QUFFRDs7QUFFQSwrQkFBK0I7QUFDL0IiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvbGlua2VkZXJyb3JzLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBpbnRlZ3JhdGlvbiA9IHJlcXVpcmUoJy4uL2ludGVncmF0aW9uLmpzJyk7XG5jb25zdCBhZ2dyZWdhdGVFcnJvcnMgPSByZXF1aXJlKCcuLi91dGlscy9hZ2dyZWdhdGUtZXJyb3JzLmpzJyk7XG5jb25zdCBldmVudGJ1aWxkZXIgPSByZXF1aXJlKCcuLi91dGlscy9ldmVudGJ1aWxkZXIuanMnKTtcblxuY29uc3QgREVGQVVMVF9LRVkgPSAnY2F1c2UnO1xuY29uc3QgREVGQVVMVF9MSU1JVCA9IDU7XG5cbmNvbnN0IElOVEVHUkFUSU9OX05BTUUgPSAnTGlua2VkRXJyb3JzJztcblxuY29uc3QgX2xpbmtlZEVycm9yc0ludGVncmF0aW9uID0gKChvcHRpb25zID0ge30pID0+IHtcbiAgY29uc3QgbGltaXQgPSBvcHRpb25zLmxpbWl0IHx8IERFRkFVTFRfTElNSVQ7XG4gIGNvbnN0IGtleSA9IG9wdGlvbnMua2V5IHx8IERFRkFVTFRfS0VZO1xuXG4gIHJldHVybiB7XG4gICAgbmFtZTogSU5URUdSQVRJT05fTkFNRSxcbiAgICBwcmVwcm9jZXNzRXZlbnQoZXZlbnQsIGhpbnQsIGNsaWVudCkge1xuICAgICAgY29uc3Qgb3B0aW9ucyA9IGNsaWVudC5nZXRPcHRpb25zKCk7XG5cbiAgICAgIGFnZ3JlZ2F0ZUVycm9ycy5hcHBseUFnZ3JlZ2F0ZUVycm9yc1RvRXZlbnQoZXZlbnRidWlsZGVyLmV4Y2VwdGlvbkZyb21FcnJvciwgb3B0aW9ucy5zdGFja1BhcnNlciwga2V5LCBsaW1pdCwgZXZlbnQsIGhpbnQpO1xuICAgIH0sXG4gIH07XG59KSA7XG5cbmNvbnN0IGxpbmtlZEVycm9yc0ludGVncmF0aW9uID0gaW50ZWdyYXRpb24uZGVmaW5lSW50ZWdyYXRpb24oX2xpbmtlZEVycm9yc0ludGVncmF0aW9uKTtcblxuZXhwb3J0cy5saW5rZWRFcnJvcnNJbnRlZ3JhdGlvbiA9IGxpbmtlZEVycm9yc0ludGVncmF0aW9uO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9bGlua2VkZXJyb3JzLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/linkederrors.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/attributeExtraction.js":
/*!***********************************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/attributeExtraction.js ***!
  \***********************************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst url = __webpack_require__(/*! ../../utils/url.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/url.js\");\nconst attributes = __webpack_require__(/*! ./attributes.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/attributes.js\");\nconst methodConfig = __webpack_require__(/*! ./methodConfig.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/methodConfig.js\");\n\n/**\n * Core attribute extraction and building functions for MCP server instrumentation\n */\n\n\n/**\n * Extracts additional attributes for specific notification types\n * @param method - Notification method name\n * @param params - Notification parameters\n * @returns Method-specific attributes for span instrumentation\n */\nfunction getNotificationAttributes(\n  method,\n  params,\n) {\n  const attributes$1 = {};\n\n  switch (method) {\n    case 'notifications/cancelled':\n      if (params?.requestId) {\n        attributes$1['mcp.cancelled.request_id'] = String(params.requestId);\n      }\n      if (params?.reason) {\n        attributes$1['mcp.cancelled.reason'] = String(params.reason);\n      }\n      break;\n\n    case 'notifications/message':\n      if (params?.level) {\n        attributes$1[attributes.MCP_LOGGING_LEVEL_ATTRIBUTE] = String(params.level);\n      }\n      if (params?.logger) {\n        attributes$1[attributes.MCP_LOGGING_LOGGER_ATTRIBUTE] = String(params.logger);\n      }\n      if (params?.data !== undefined) {\n        attributes$1[attributes.MCP_LOGGING_DATA_TYPE_ATTRIBUTE] = typeof params.data;\n        if (typeof params.data === 'string') {\n          attributes$1[attributes.MCP_LOGGING_MESSAGE_ATTRIBUTE] = params.data;\n        } else {\n          attributes$1[attributes.MCP_LOGGING_MESSAGE_ATTRIBUTE] = JSON.stringify(params.data);\n        }\n      }\n      break;\n\n    case 'notifications/progress':\n      if (params?.progressToken) {\n        attributes$1['mcp.progress.token'] = String(params.progressToken);\n      }\n      if (typeof params?.progress === 'number') {\n        attributes$1['mcp.progress.current'] = params.progress;\n      }\n      if (typeof params?.total === 'number') {\n        attributes$1['mcp.progress.total'] = params.total;\n        if (typeof params?.progress === 'number') {\n          attributes$1['mcp.progress.percentage'] = (params.progress / params.total) * 100;\n        }\n      }\n      if (params?.message) {\n        attributes$1['mcp.progress.message'] = String(params.message);\n      }\n      break;\n\n    case 'notifications/resources/updated':\n      if (params?.uri) {\n        attributes$1[attributes.MCP_RESOURCE_URI_ATTRIBUTE] = String(params.uri);\n        const urlObject = url.parseStringToURLObject(String(params.uri));\n        if (urlObject && !url.isURLObjectRelative(urlObject)) {\n          attributes$1['mcp.resource.protocol'] = urlObject.protocol.replace(':', '');\n        }\n      }\n      break;\n\n    case 'notifications/initialized':\n      attributes$1['mcp.lifecycle.phase'] = 'initialization_complete';\n      attributes$1['mcp.protocol.ready'] = 1;\n      break;\n  }\n\n  return attributes$1;\n}\n\n/**\n * Build type-specific attributes based on message type\n * @param type - Span type (request or notification)\n * @param message - JSON-RPC message\n * @param params - Optional parameters for attribute extraction\n * @returns Type-specific attributes for span instrumentation\n */\nfunction buildTypeSpecificAttributes(\n  type,\n  message,\n  params,\n) {\n  if (type === 'request') {\n    const request = message ;\n    const targetInfo = methodConfig.extractTargetInfo(request.method, params || {});\n\n    return {\n      ...(request.id !== undefined && { [attributes.MCP_REQUEST_ID_ATTRIBUTE]: String(request.id) }),\n      ...targetInfo.attributes,\n      ...methodConfig.getRequestArguments(request.method, params || {}),\n    };\n  }\n\n  return getNotificationAttributes(message.method, params || {});\n}\n\nexports.buildTypeSpecificAttributes = buildTypeSpecificAttributes;\nexports.getNotificationAttributes = getNotificationAttributes;\n//# sourceMappingURL=attributeExtraction.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvbWNwLXNlcnZlci9hdHRyaWJ1dGVFeHRyYWN0aW9uLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLFlBQVksbUJBQU8sQ0FBQywySEFBb0I7QUFDeEMsbUJBQW1CLG1CQUFPLENBQUMsaUpBQWlCO0FBQzVDLHFCQUFxQixtQkFBTyxDQUFDLHFKQUFtQjs7QUFFaEQ7QUFDQTtBQUNBOzs7QUFHQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsVUFBVTtBQUNWO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0Esa0ZBQWtGOztBQUVsRjtBQUNBLHdDQUF3QywyREFBMkQ7QUFDbkc7QUFDQSxzRUFBc0U7QUFDdEU7QUFDQTs7QUFFQSwrREFBK0Q7QUFDL0Q7O0FBRUEsbUNBQW1DO0FBQ25DLGlDQUFpQztBQUNqQyIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL2ludGVncmF0aW9ucy9tY3Atc2VydmVyL2F0dHJpYnV0ZUV4dHJhY3Rpb24uanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IHVybCA9IHJlcXVpcmUoJy4uLy4uL3V0aWxzL3VybC5qcycpO1xuY29uc3QgYXR0cmlidXRlcyA9IHJlcXVpcmUoJy4vYXR0cmlidXRlcy5qcycpO1xuY29uc3QgbWV0aG9kQ29uZmlnID0gcmVxdWlyZSgnLi9tZXRob2RDb25maWcuanMnKTtcblxuLyoqXG4gKiBDb3JlIGF0dHJpYnV0ZSBleHRyYWN0aW9uIGFuZCBidWlsZGluZyBmdW5jdGlvbnMgZm9yIE1DUCBzZXJ2ZXIgaW5zdHJ1bWVudGF0aW9uXG4gKi9cblxuXG4vKipcbiAqIEV4dHJhY3RzIGFkZGl0aW9uYWwgYXR0cmlidXRlcyBmb3Igc3BlY2lmaWMgbm90aWZpY2F0aW9uIHR5cGVzXG4gKiBAcGFyYW0gbWV0aG9kIC0gTm90aWZpY2F0aW9uIG1ldGhvZCBuYW1lXG4gKiBAcGFyYW0gcGFyYW1zIC0gTm90aWZpY2F0aW9uIHBhcmFtZXRlcnNcbiAqIEByZXR1cm5zIE1ldGhvZC1zcGVjaWZpYyBhdHRyaWJ1dGVzIGZvciBzcGFuIGluc3RydW1lbnRhdGlvblxuICovXG5mdW5jdGlvbiBnZXROb3RpZmljYXRpb25BdHRyaWJ1dGVzKFxuICBtZXRob2QsXG4gIHBhcmFtcyxcbikge1xuICBjb25zdCBhdHRyaWJ1dGVzJDEgPSB7fTtcblxuICBzd2l0Y2ggKG1ldGhvZCkge1xuICAgIGNhc2UgJ25vdGlmaWNhdGlvbnMvY2FuY2VsbGVkJzpcbiAgICAgIGlmIChwYXJhbXM/LnJlcXVlc3RJZCkge1xuICAgICAgICBhdHRyaWJ1dGVzJDFbJ21jcC5jYW5jZWxsZWQucmVxdWVzdF9pZCddID0gU3RyaW5nKHBhcmFtcy5yZXF1ZXN0SWQpO1xuICAgICAgfVxuICAgICAgaWYgKHBhcmFtcz8ucmVhc29uKSB7XG4gICAgICAgIGF0dHJpYnV0ZXMkMVsnbWNwLmNhbmNlbGxlZC5yZWFzb24nXSA9IFN0cmluZyhwYXJhbXMucmVhc29uKTtcbiAgICAgIH1cbiAgICAgIGJyZWFrO1xuXG4gICAgY2FzZSAnbm90aWZpY2F0aW9ucy9tZXNzYWdlJzpcbiAgICAgIGlmIChwYXJhbXM/LmxldmVsKSB7XG4gICAgICAgIGF0dHJpYnV0ZXMkMVthdHRyaWJ1dGVzLk1DUF9MT0dHSU5HX0xFVkVMX0FUVFJJQlVURV0gPSBTdHJpbmcocGFyYW1zLmxldmVsKTtcbiAgICAgIH1cbiAgICAgIGlmIChwYXJhbXM/LmxvZ2dlcikge1xuICAgICAgICBhdHRyaWJ1dGVzJDFbYXR0cmlidXRlcy5NQ1BfTE9HR0lOR19MT0dHRVJfQVRUUklCVVRFXSA9IFN0cmluZyhwYXJhbXMubG9nZ2VyKTtcbiAgICAgIH1cbiAgICAgIGlmIChwYXJhbXM/LmRhdGEgIT09IHVuZGVmaW5lZCkge1xuICAgICAgICBhdHRyaWJ1dGVzJDFbYXR0cmlidXRlcy5NQ1BfTE9HR0lOR19EQVRBX1RZUEVfQVRUUklCVVRFXSA9IHR5cGVvZiBwYXJhbXMuZGF0YTtcbiAgICAgICAgaWYgKHR5cGVvZiBwYXJhbXMuZGF0YSA9PT0gJ3N0cmluZycpIHtcbiAgICAgICAgICBhdHRyaWJ1dGVzJDFbYXR0cmlidXRlcy5NQ1BfTE9HR0lOR19NRVNTQUdFX0FUVFJJQlVURV0gPSBwYXJhbXMuZGF0YTtcbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICBhdHRyaWJ1dGVzJDFbYXR0cmlidXRlcy5NQ1BfTE9HR0lOR19NRVNTQUdFX0FUVFJJQlVURV0gPSBKU09OLnN0cmluZ2lmeShwYXJhbXMuZGF0YSk7XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICAgIGJyZWFrO1xuXG4gICAgY2FzZSAnbm90aWZpY2F0aW9ucy9wcm9ncmVzcyc6XG4gICAgICBpZiAocGFyYW1zPy5wcm9ncmVzc1Rva2VuKSB7XG4gICAgICAgIGF0dHJpYnV0ZXMkMVsnbWNwLnByb2dyZXNzLnRva2VuJ10gPSBTdHJpbmcocGFyYW1zLnByb2dyZXNzVG9rZW4pO1xuICAgICAgfVxuICAgICAgaWYgKHR5cGVvZiBwYXJhbXM/LnByb2dyZXNzID09PSAnbnVtYmVyJykge1xuICAgICAgICBhdHRyaWJ1dGVzJDFbJ21jcC5wcm9ncmVzcy5jdXJyZW50J10gPSBwYXJhbXMucHJvZ3Jlc3M7XG4gICAgICB9XG4gICAgICBpZiAodHlwZW9mIHBhcmFtcz8udG90YWwgPT09ICdudW1iZXInKSB7XG4gICAgICAgIGF0dHJpYnV0ZXMkMVsnbWNwLnByb2dyZXNzLnRvdGFsJ10gPSBwYXJhbXMudG90YWw7XG4gICAgICAgIGlmICh0eXBlb2YgcGFyYW1zPy5wcm9ncmVzcyA9PT0gJ251bWJlcicpIHtcbiAgICAgICAgICBhdHRyaWJ1dGVzJDFbJ21jcC5wcm9ncmVzcy5wZXJjZW50YWdlJ10gPSAocGFyYW1zLnByb2dyZXNzIC8gcGFyYW1zLnRvdGFsKSAqIDEwMDtcbiAgICAgICAgfVxuICAgICAgfVxuICAgICAgaWYgKHBhcmFtcz8ubWVzc2FnZSkge1xuICAgICAgICBhdHRyaWJ1dGVzJDFbJ21jcC5wcm9ncmVzcy5tZXNzYWdlJ10gPSBTdHJpbmcocGFyYW1zLm1lc3NhZ2UpO1xuICAgICAgfVxuICAgICAgYnJlYWs7XG5cbiAgICBjYXNlICdub3RpZmljYXRpb25zL3Jlc291cmNlcy91cGRhdGVkJzpcbiAgICAgIGlmIChwYXJhbXM/LnVyaSkge1xuICAgICAgICBhdHRyaWJ1dGVzJDFbYXR0cmlidXRlcy5NQ1BfUkVTT1VSQ0VfVVJJX0FUVFJJQlVURV0gPSBTdHJpbmcocGFyYW1zLnVyaSk7XG4gICAgICAgIGNvbnN0IHVybE9iamVjdCA9IHVybC5wYXJzZVN0cmluZ1RvVVJMT2JqZWN0KFN0cmluZyhwYXJhbXMudXJpKSk7XG4gICAgICAgIGlmICh1cmxPYmplY3QgJiYgIXVybC5pc1VSTE9iamVjdFJlbGF0aXZlKHVybE9iamVjdCkpIHtcbiAgICAgICAgICBhdHRyaWJ1dGVzJDFbJ21jcC5yZXNvdXJjZS5wcm90b2NvbCddID0gdXJsT2JqZWN0LnByb3RvY29sLnJlcGxhY2UoJzonLCAnJyk7XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICAgIGJyZWFrO1xuXG4gICAgY2FzZSAnbm90aWZpY2F0aW9ucy9pbml0aWFsaXplZCc6XG4gICAgICBhdHRyaWJ1dGVzJDFbJ21jcC5saWZlY3ljbGUucGhhc2UnXSA9ICdpbml0aWFsaXphdGlvbl9jb21wbGV0ZSc7XG4gICAgICBhdHRyaWJ1dGVzJDFbJ21jcC5wcm90b2NvbC5yZWFkeSddID0gMTtcbiAgICAgIGJyZWFrO1xuICB9XG5cbiAgcmV0dXJuIGF0dHJpYnV0ZXMkMTtcbn1cblxuLyoqXG4gKiBCdWlsZCB0eXBlLXNwZWNpZmljIGF0dHJpYnV0ZXMgYmFzZWQgb24gbWVzc2FnZSB0eXBlXG4gKiBAcGFyYW0gdHlwZSAtIFNwYW4gdHlwZSAocmVxdWVzdCBvciBub3RpZmljYXRpb24pXG4gKiBAcGFyYW0gbWVzc2FnZSAtIEpTT04tUlBDIG1lc3NhZ2VcbiAqIEBwYXJhbSBwYXJhbXMgLSBPcHRpb25hbCBwYXJhbWV0ZXJzIGZvciBhdHRyaWJ1dGUgZXh0cmFjdGlvblxuICogQHJldHVybnMgVHlwZS1zcGVjaWZpYyBhdHRyaWJ1dGVzIGZvciBzcGFuIGluc3RydW1lbnRhdGlvblxuICovXG5mdW5jdGlvbiBidWlsZFR5cGVTcGVjaWZpY0F0dHJpYnV0ZXMoXG4gIHR5cGUsXG4gIG1lc3NhZ2UsXG4gIHBhcmFtcyxcbikge1xuICBpZiAodHlwZSA9PT0gJ3JlcXVlc3QnKSB7XG4gICAgY29uc3QgcmVxdWVzdCA9IG1lc3NhZ2UgO1xuICAgIGNvbnN0IHRhcmdldEluZm8gPSBtZXRob2RDb25maWcuZXh0cmFjdFRhcmdldEluZm8ocmVxdWVzdC5tZXRob2QsIHBhcmFtcyB8fCB7fSk7XG5cbiAgICByZXR1cm4ge1xuICAgICAgLi4uKHJlcXVlc3QuaWQgIT09IHVuZGVmaW5lZCAmJiB7IFthdHRyaWJ1dGVzLk1DUF9SRVFVRVNUX0lEX0FUVFJJQlVURV06IFN0cmluZyhyZXF1ZXN0LmlkKSB9KSxcbiAgICAgIC4uLnRhcmdldEluZm8uYXR0cmlidXRlcyxcbiAgICAgIC4uLm1ldGhvZENvbmZpZy5nZXRSZXF1ZXN0QXJndW1lbnRzKHJlcXVlc3QubWV0aG9kLCBwYXJhbXMgfHwge30pLFxuICAgIH07XG4gIH1cblxuICByZXR1cm4gZ2V0Tm90aWZpY2F0aW9uQXR0cmlidXRlcyhtZXNzYWdlLm1ldGhvZCwgcGFyYW1zIHx8IHt9KTtcbn1cblxuZXhwb3J0cy5idWlsZFR5cGVTcGVjaWZpY0F0dHJpYnV0ZXMgPSBidWlsZFR5cGVTcGVjaWZpY0F0dHJpYnV0ZXM7XG5leHBvcnRzLmdldE5vdGlmaWNhdGlvbkF0dHJpYnV0ZXMgPSBnZXROb3RpZmljYXRpb25BdHRyaWJ1dGVzO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9YXR0cmlidXRlRXh0cmFjdGlvbi5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/attributeExtraction.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/attributes.js":
/*!**************************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/attributes.js ***!
  \**************************************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n/**\n * Essential MCP attribute constants for Sentry instrumentation\n *\n * Based on OpenTelemetry MCP semantic conventions\n * @see https://github.com/open-telemetry/semantic-conventions/blob/3097fb0af5b9492b0e3f55dc5f6c21a3dc2be8df/docs/gen-ai/mcp.md\n */\n\n// =============================================================================\n// CORE MCP ATTRIBUTES\n// =============================================================================\n\n/** The name of the request or notification method */\nconst MCP_METHOD_NAME_ATTRIBUTE = 'mcp.method.name';\n\n/** JSON-RPC request identifier for the request. Unique within the MCP session. */\nconst MCP_REQUEST_ID_ATTRIBUTE = 'mcp.request.id';\n\n/** Identifies the MCP session */\nconst MCP_SESSION_ID_ATTRIBUTE = 'mcp.session.id';\n\n/** Transport method used for MCP communication */\nconst MCP_TRANSPORT_ATTRIBUTE = 'mcp.transport';\n\n// =============================================================================\n// SERVER ATTRIBUTES\n// =============================================================================\n\n/** Name of the MCP server application */\nconst MCP_SERVER_NAME_ATTRIBUTE = 'mcp.server.name';\n\n/** Display title of the MCP server application */\nconst MCP_SERVER_TITLE_ATTRIBUTE = 'mcp.server.title';\n\n/** Version of the MCP server application */\nconst MCP_SERVER_VERSION_ATTRIBUTE = 'mcp.server.version';\n\n/** MCP protocol version used in the session */\nconst MCP_PROTOCOL_VERSION_ATTRIBUTE = 'mcp.protocol.version';\n\n// =============================================================================\n// METHOD-SPECIFIC ATTRIBUTES\n// =============================================================================\n\n/** Name of the tool being called */\nconst MCP_TOOL_NAME_ATTRIBUTE = 'mcp.tool.name';\n\n/** The resource URI being accessed */\nconst MCP_RESOURCE_URI_ATTRIBUTE = 'mcp.resource.uri';\n\n/** Name of the prompt template */\nconst MCP_PROMPT_NAME_ATTRIBUTE = 'mcp.prompt.name';\n\n// =============================================================================\n// TOOL RESULT ATTRIBUTES\n// =============================================================================\n\n/** Whether a tool execution resulted in an error */\nconst MCP_TOOL_RESULT_IS_ERROR_ATTRIBUTE = 'mcp.tool.result.is_error';\n\n/** Number of content items in the tool result */\nconst MCP_TOOL_RESULT_CONTENT_COUNT_ATTRIBUTE = 'mcp.tool.result.content_count';\n\n/** Serialized content of the tool result */\nconst MCP_TOOL_RESULT_CONTENT_ATTRIBUTE = 'mcp.tool.result.content';\n\n/** Prefix for tool result attributes that contain sensitive content */\nconst MCP_TOOL_RESULT_PREFIX = 'mcp.tool.result';\n\n// =============================================================================\n// PROMPT RESULT ATTRIBUTES\n// =============================================================================\n\n/** Description of the prompt result */\nconst MCP_PROMPT_RESULT_DESCRIPTION_ATTRIBUTE = 'mcp.prompt.result.description';\n\n/** Number of messages in the prompt result */\nconst MCP_PROMPT_RESULT_MESSAGE_COUNT_ATTRIBUTE = 'mcp.prompt.result.message_count';\n\n/** Content of the message in the prompt result (for single message results) */\nconst MCP_PROMPT_RESULT_MESSAGE_CONTENT_ATTRIBUTE = 'mcp.prompt.result.message_content';\n\n/** Prefix for prompt result attributes that contain sensitive content */\nconst MCP_PROMPT_RESULT_PREFIX = 'mcp.prompt.result';\n\n// =============================================================================\n// REQUEST ARGUMENT ATTRIBUTES\n// =============================================================================\n\n/** Prefix for MCP request argument prefix for each argument */\nconst MCP_REQUEST_ARGUMENT = 'mcp.request.argument';\n\n// =============================================================================\n// LOGGING ATTRIBUTES\n// =============================================================================\n\n/** Log level for MCP logging operations */\nconst MCP_LOGGING_LEVEL_ATTRIBUTE = 'mcp.logging.level';\n\n/** Logger name for MCP logging operations */\nconst MCP_LOGGING_LOGGER_ATTRIBUTE = 'mcp.logging.logger';\n\n/** Data type of the logged message */\nconst MCP_LOGGING_DATA_TYPE_ATTRIBUTE = 'mcp.logging.data_type';\n\n/** Log message content */\nconst MCP_LOGGING_MESSAGE_ATTRIBUTE = 'mcp.logging.message';\n\n// =============================================================================\n// NETWORK ATTRIBUTES (OpenTelemetry Standard)\n// =============================================================================\n\n/** OSI transport layer protocol */\nconst NETWORK_TRANSPORT_ATTRIBUTE = 'network.transport';\n\n/** The version of JSON RPC protocol used */\nconst NETWORK_PROTOCOL_VERSION_ATTRIBUTE = 'network.protocol.version';\n\n/** Client address - domain name if available without reverse DNS lookup; otherwise, IP address or Unix domain socket name */\nconst CLIENT_ADDRESS_ATTRIBUTE = 'client.address';\n\n/** Client port number */\nconst CLIENT_PORT_ATTRIBUTE = 'client.port';\n\n// =============================================================================\n// SENTRY-SPECIFIC MCP ATTRIBUTE VALUES\n// =============================================================================\n\n/** Sentry operation value for MCP server spans */\nconst MCP_SERVER_OP_VALUE = 'mcp.server';\n\n/**\n * Sentry operation value for client-to-server notifications\n * Following OpenTelemetry MCP semantic conventions\n */\nconst MCP_NOTIFICATION_CLIENT_TO_SERVER_OP_VALUE = 'mcp.notification.client_to_server';\n\n/**\n * Sentry operation value for server-to-client notifications\n * Following OpenTelemetry MCP semantic conventions\n */\nconst MCP_NOTIFICATION_SERVER_TO_CLIENT_OP_VALUE = 'mcp.notification.server_to_client';\n\n/** Sentry origin value for MCP function spans */\nconst MCP_FUNCTION_ORIGIN_VALUE = 'auto.function.mcp_server';\n\n/** Sentry origin value for MCP notification spans */\nconst MCP_NOTIFICATION_ORIGIN_VALUE = 'auto.mcp.notification';\n\n/** Sentry source value for MCP route spans */\nconst MCP_ROUTE_SOURCE_VALUE = 'route';\n\nexports.CLIENT_ADDRESS_ATTRIBUTE = CLIENT_ADDRESS_ATTRIBUTE;\nexports.CLIENT_PORT_ATTRIBUTE = CLIENT_PORT_ATTRIBUTE;\nexports.MCP_FUNCTION_ORIGIN_VALUE = MCP_FUNCTION_ORIGIN_VALUE;\nexports.MCP_LOGGING_DATA_TYPE_ATTRIBUTE = MCP_LOGGING_DATA_TYPE_ATTRIBUTE;\nexports.MCP_LOGGING_LEVEL_ATTRIBUTE = MCP_LOGGING_LEVEL_ATTRIBUTE;\nexports.MCP_LOGGING_LOGGER_ATTRIBUTE = MCP_LOGGING_LOGGER_ATTRIBUTE;\nexports.MCP_LOGGING_MESSAGE_ATTRIBUTE = MCP_LOGGING_MESSAGE_ATTRIBUTE;\nexports.MCP_METHOD_NAME_ATTRIBUTE = MCP_METHOD_NAME_ATTRIBUTE;\nexports.MCP_NOTIFICATION_CLIENT_TO_SERVER_OP_VALUE = MCP_NOTIFICATION_CLIENT_TO_SERVER_OP_VALUE;\nexports.MCP_NOTIFICATION_ORIGIN_VALUE = MCP_NOTIFICATION_ORIGIN_VALUE;\nexports.MCP_NOTIFICATION_SERVER_TO_CLIENT_OP_VALUE = MCP_NOTIFICATION_SERVER_TO_CLIENT_OP_VALUE;\nexports.MCP_PROMPT_NAME_ATTRIBUTE = MCP_PROMPT_NAME_ATTRIBUTE;\nexports.MCP_PROMPT_RESULT_DESCRIPTION_ATTRIBUTE = MCP_PROMPT_RESULT_DESCRIPTION_ATTRIBUTE;\nexports.MCP_PROMPT_RESULT_MESSAGE_CONTENT_ATTRIBUTE = MCP_PROMPT_RESULT_MESSAGE_CONTENT_ATTRIBUTE;\nexports.MCP_PROMPT_RESULT_MESSAGE_COUNT_ATTRIBUTE = MCP_PROMPT_RESULT_MESSAGE_COUNT_ATTRIBUTE;\nexports.MCP_PROMPT_RESULT_PREFIX = MCP_PROMPT_RESULT_PREFIX;\nexports.MCP_PROTOCOL_VERSION_ATTRIBUTE = MCP_PROTOCOL_VERSION_ATTRIBUTE;\nexports.MCP_REQUEST_ARGUMENT = MCP_REQUEST_ARGUMENT;\nexports.MCP_REQUEST_ID_ATTRIBUTE = MCP_REQUEST_ID_ATTRIBUTE;\nexports.MCP_RESOURCE_URI_ATTRIBUTE = MCP_RESOURCE_URI_ATTRIBUTE;\nexports.MCP_ROUTE_SOURCE_VALUE = MCP_ROUTE_SOURCE_VALUE;\nexports.MCP_SERVER_NAME_ATTRIBUTE = MCP_SERVER_NAME_ATTRIBUTE;\nexports.MCP_SERVER_OP_VALUE = MCP_SERVER_OP_VALUE;\nexports.MCP_SERVER_TITLE_ATTRIBUTE = MCP_SERVER_TITLE_ATTRIBUTE;\nexports.MCP_SERVER_VERSION_ATTRIBUTE = MCP_SERVER_VERSION_ATTRIBUTE;\nexports.MCP_SESSION_ID_ATTRIBUTE = MCP_SESSION_ID_ATTRIBUTE;\nexports.MCP_TOOL_NAME_ATTRIBUTE = MCP_TOOL_NAME_ATTRIBUTE;\nexports.MCP_TOOL_RESULT_CONTENT_ATTRIBUTE = MCP_TOOL_RESULT_CONTENT_ATTRIBUTE;\nexports.MCP_TOOL_RESULT_CONTENT_COUNT_ATTRIBUTE = MCP_TOOL_RESULT_CONTENT_COUNT_ATTRIBUTE;\nexports.MCP_TOOL_RESULT_IS_ERROR_ATTRIBUTE = MCP_TOOL_RESULT_IS_ERROR_ATTRIBUTE;\nexports.MCP_TOOL_RESULT_PREFIX = MCP_TOOL_RESULT_PREFIX;\nexports.MCP_TRANSPORT_ATTRIBUTE = MCP_TRANSPORT_ATTRIBUTE;\nexports.NETWORK_PROTOCOL_VERSION_ATTRIBUTE = NETWORK_PROTOCOL_VERSION_ATTRIBUTE;\nexports.NETWORK_TRANSPORT_ATTRIBUTE = NETWORK_TRANSPORT_ATTRIBUTE;\n//# sourceMappingURL=attributes.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvbWNwLXNlcnZlci9hdHRyaWJ1dGVzLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQSwwRUFBMEU7QUFDMUU7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUEsZ0NBQWdDO0FBQ2hDLDZCQUE2QjtBQUM3QixpQ0FBaUM7QUFDakMsdUNBQXVDO0FBQ3ZDLG1DQUFtQztBQUNuQyxvQ0FBb0M7QUFDcEMscUNBQXFDO0FBQ3JDLGlDQUFpQztBQUNqQyxrREFBa0Q7QUFDbEQscUNBQXFDO0FBQ3JDLGtEQUFrRDtBQUNsRCxpQ0FBaUM7QUFDakMsK0NBQStDO0FBQy9DLG1EQUFtRDtBQUNuRCxpREFBaUQ7QUFDakQsZ0NBQWdDO0FBQ2hDLHNDQUFzQztBQUN0Qyw0QkFBNEI7QUFDNUIsZ0NBQWdDO0FBQ2hDLGtDQUFrQztBQUNsQyw4QkFBOEI7QUFDOUIsaUNBQWlDO0FBQ2pDLDJCQUEyQjtBQUMzQixrQ0FBa0M7QUFDbEMsb0NBQW9DO0FBQ3BDLGdDQUFnQztBQUNoQywrQkFBK0I7QUFDL0IseUNBQXlDO0FBQ3pDLCtDQUErQztBQUMvQywwQ0FBMEM7QUFDMUMsOEJBQThCO0FBQzlCLCtCQUErQjtBQUMvQiwwQ0FBMEM7QUFDMUMsbUNBQW1DO0FBQ25DIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvaW50ZWdyYXRpb25zL21jcC1zZXJ2ZXIvYXR0cmlidXRlcy5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuLyoqXG4gKiBFc3NlbnRpYWwgTUNQIGF0dHJpYnV0ZSBjb25zdGFudHMgZm9yIFNlbnRyeSBpbnN0cnVtZW50YXRpb25cbiAqXG4gKiBCYXNlZCBvbiBPcGVuVGVsZW1ldHJ5IE1DUCBzZW1hbnRpYyBjb252ZW50aW9uc1xuICogQHNlZSBodHRwczovL2dpdGh1Yi5jb20vb3Blbi10ZWxlbWV0cnkvc2VtYW50aWMtY29udmVudGlvbnMvYmxvYi8zMDk3ZmIwYWY1Yjk0OTJiMGUzZjU1ZGM1ZjZjMjFhM2RjMmJlOGRmL2RvY3MvZ2VuLWFpL21jcC5tZFxuICovXG5cbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG4vLyBDT1JFIE1DUCBBVFRSSUJVVEVTXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuXG4vKiogVGhlIG5hbWUgb2YgdGhlIHJlcXVlc3Qgb3Igbm90aWZpY2F0aW9uIG1ldGhvZCAqL1xuY29uc3QgTUNQX01FVEhPRF9OQU1FX0FUVFJJQlVURSA9ICdtY3AubWV0aG9kLm5hbWUnO1xuXG4vKiogSlNPTi1SUEMgcmVxdWVzdCBpZGVudGlmaWVyIGZvciB0aGUgcmVxdWVzdC4gVW5pcXVlIHdpdGhpbiB0aGUgTUNQIHNlc3Npb24uICovXG5jb25zdCBNQ1BfUkVRVUVTVF9JRF9BVFRSSUJVVEUgPSAnbWNwLnJlcXVlc3QuaWQnO1xuXG4vKiogSWRlbnRpZmllcyB0aGUgTUNQIHNlc3Npb24gKi9cbmNvbnN0IE1DUF9TRVNTSU9OX0lEX0FUVFJJQlVURSA9ICdtY3Auc2Vzc2lvbi5pZCc7XG5cbi8qKiBUcmFuc3BvcnQgbWV0aG9kIHVzZWQgZm9yIE1DUCBjb21tdW5pY2F0aW9uICovXG5jb25zdCBNQ1BfVFJBTlNQT1JUX0FUVFJJQlVURSA9ICdtY3AudHJhbnNwb3J0JztcblxuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cbi8vIFNFUlZFUiBBVFRSSUJVVEVTXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuXG4vKiogTmFtZSBvZiB0aGUgTUNQIHNlcnZlciBhcHBsaWNhdGlvbiAqL1xuY29uc3QgTUNQX1NFUlZFUl9OQU1FX0FUVFJJQlVURSA9ICdtY3Auc2VydmVyLm5hbWUnO1xuXG4vKiogRGlzcGxheSB0aXRsZSBvZiB0aGUgTUNQIHNlcnZlciBhcHBsaWNhdGlvbiAqL1xuY29uc3QgTUNQX1NFUlZFUl9USVRMRV9BVFRSSUJVVEUgPSAnbWNwLnNlcnZlci50aXRsZSc7XG5cbi8qKiBWZXJzaW9uIG9mIHRoZSBNQ1Agc2VydmVyIGFwcGxpY2F0aW9uICovXG5jb25zdCBNQ1BfU0VSVkVSX1ZFUlNJT05fQVRUUklCVVRFID0gJ21jcC5zZXJ2ZXIudmVyc2lvbic7XG5cbi8qKiBNQ1AgcHJvdG9jb2wgdmVyc2lvbiB1c2VkIGluIHRoZSBzZXNzaW9uICovXG5jb25zdCBNQ1BfUFJPVE9DT0xfVkVSU0lPTl9BVFRSSUJVVEUgPSAnbWNwLnByb3RvY29sLnZlcnNpb24nO1xuXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuLy8gTUVUSE9ELVNQRUNJRklDIEFUVFJJQlVURVNcbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG5cbi8qKiBOYW1lIG9mIHRoZSB0b29sIGJlaW5nIGNhbGxlZCAqL1xuY29uc3QgTUNQX1RPT0xfTkFNRV9BVFRSSUJVVEUgPSAnbWNwLnRvb2wubmFtZSc7XG5cbi8qKiBUaGUgcmVzb3VyY2UgVVJJIGJlaW5nIGFjY2Vzc2VkICovXG5jb25zdCBNQ1BfUkVTT1VSQ0VfVVJJX0FUVFJJQlVURSA9ICdtY3AucmVzb3VyY2UudXJpJztcblxuLyoqIE5hbWUgb2YgdGhlIHByb21wdCB0ZW1wbGF0ZSAqL1xuY29uc3QgTUNQX1BST01QVF9OQU1FX0FUVFJJQlVURSA9ICdtY3AucHJvbXB0Lm5hbWUnO1xuXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuLy8gVE9PTCBSRVNVTFQgQVRUUklCVVRFU1xuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cblxuLyoqIFdoZXRoZXIgYSB0b29sIGV4ZWN1dGlvbiByZXN1bHRlZCBpbiBhbiBlcnJvciAqL1xuY29uc3QgTUNQX1RPT0xfUkVTVUxUX0lTX0VSUk9SX0FUVFJJQlVURSA9ICdtY3AudG9vbC5yZXN1bHQuaXNfZXJyb3InO1xuXG4vKiogTnVtYmVyIG9mIGNvbnRlbnQgaXRlbXMgaW4gdGhlIHRvb2wgcmVzdWx0ICovXG5jb25zdCBNQ1BfVE9PTF9SRVNVTFRfQ09OVEVOVF9DT1VOVF9BVFRSSUJVVEUgPSAnbWNwLnRvb2wucmVzdWx0LmNvbnRlbnRfY291bnQnO1xuXG4vKiogU2VyaWFsaXplZCBjb250ZW50IG9mIHRoZSB0b29sIHJlc3VsdCAqL1xuY29uc3QgTUNQX1RPT0xfUkVTVUxUX0NPTlRFTlRfQVRUUklCVVRFID0gJ21jcC50b29sLnJlc3VsdC5jb250ZW50JztcblxuLyoqIFByZWZpeCBmb3IgdG9vbCByZXN1bHQgYXR0cmlidXRlcyB0aGF0IGNvbnRhaW4gc2Vuc2l0aXZlIGNvbnRlbnQgKi9cbmNvbnN0IE1DUF9UT09MX1JFU1VMVF9QUkVGSVggPSAnbWNwLnRvb2wucmVzdWx0JztcblxuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cbi8vIFBST01QVCBSRVNVTFQgQVRUUklCVVRFU1xuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cblxuLyoqIERlc2NyaXB0aW9uIG9mIHRoZSBwcm9tcHQgcmVzdWx0ICovXG5jb25zdCBNQ1BfUFJPTVBUX1JFU1VMVF9ERVNDUklQVElPTl9BVFRSSUJVVEUgPSAnbWNwLnByb21wdC5yZXN1bHQuZGVzY3JpcHRpb24nO1xuXG4vKiogTnVtYmVyIG9mIG1lc3NhZ2VzIGluIHRoZSBwcm9tcHQgcmVzdWx0ICovXG5jb25zdCBNQ1BfUFJPTVBUX1JFU1VMVF9NRVNTQUdFX0NPVU5UX0FUVFJJQlVURSA9ICdtY3AucHJvbXB0LnJlc3VsdC5tZXNzYWdlX2NvdW50JztcblxuLyoqIENvbnRlbnQgb2YgdGhlIG1lc3NhZ2UgaW4gdGhlIHByb21wdCByZXN1bHQgKGZvciBzaW5nbGUgbWVzc2FnZSByZXN1bHRzKSAqL1xuY29uc3QgTUNQX1BST01QVF9SRVNVTFRfTUVTU0FHRV9DT05URU5UX0FUVFJJQlVURSA9ICdtY3AucHJvbXB0LnJlc3VsdC5tZXNzYWdlX2NvbnRlbnQnO1xuXG4vKiogUHJlZml4IGZvciBwcm9tcHQgcmVzdWx0IGF0dHJpYnV0ZXMgdGhhdCBjb250YWluIHNlbnNpdGl2ZSBjb250ZW50ICovXG5jb25zdCBNQ1BfUFJPTVBUX1JFU1VMVF9QUkVGSVggPSAnbWNwLnByb21wdC5yZXN1bHQnO1xuXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuLy8gUkVRVUVTVCBBUkdVTUVOVCBBVFRSSUJVVEVTXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuXG4vKiogUHJlZml4IGZvciBNQ1AgcmVxdWVzdCBhcmd1bWVudCBwcmVmaXggZm9yIGVhY2ggYXJndW1lbnQgKi9cbmNvbnN0IE1DUF9SRVFVRVNUX0FSR1VNRU5UID0gJ21jcC5yZXF1ZXN0LmFyZ3VtZW50JztcblxuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cbi8vIExPR0dJTkcgQVRUUklCVVRFU1xuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cblxuLyoqIExvZyBsZXZlbCBmb3IgTUNQIGxvZ2dpbmcgb3BlcmF0aW9ucyAqL1xuY29uc3QgTUNQX0xPR0dJTkdfTEVWRUxfQVRUUklCVVRFID0gJ21jcC5sb2dnaW5nLmxldmVsJztcblxuLyoqIExvZ2dlciBuYW1lIGZvciBNQ1AgbG9nZ2luZyBvcGVyYXRpb25zICovXG5jb25zdCBNQ1BfTE9HR0lOR19MT0dHRVJfQVRUUklCVVRFID0gJ21jcC5sb2dnaW5nLmxvZ2dlcic7XG5cbi8qKiBEYXRhIHR5cGUgb2YgdGhlIGxvZ2dlZCBtZXNzYWdlICovXG5jb25zdCBNQ1BfTE9HR0lOR19EQVRBX1RZUEVfQVRUUklCVVRFID0gJ21jcC5sb2dnaW5nLmRhdGFfdHlwZSc7XG5cbi8qKiBMb2cgbWVzc2FnZSBjb250ZW50ICovXG5jb25zdCBNQ1BfTE9HR0lOR19NRVNTQUdFX0FUVFJJQlVURSA9ICdtY3AubG9nZ2luZy5tZXNzYWdlJztcblxuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cbi8vIE5FVFdPUksgQVRUUklCVVRFUyAoT3BlblRlbGVtZXRyeSBTdGFuZGFyZClcbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG5cbi8qKiBPU0kgdHJhbnNwb3J0IGxheWVyIHByb3RvY29sICovXG5jb25zdCBORVRXT1JLX1RSQU5TUE9SVF9BVFRSSUJVVEUgPSAnbmV0d29yay50cmFuc3BvcnQnO1xuXG4vKiogVGhlIHZlcnNpb24gb2YgSlNPTiBSUEMgcHJvdG9jb2wgdXNlZCAqL1xuY29uc3QgTkVUV09SS19QUk9UT0NPTF9WRVJTSU9OX0FUVFJJQlVURSA9ICduZXR3b3JrLnByb3RvY29sLnZlcnNpb24nO1xuXG4vKiogQ2xpZW50IGFkZHJlc3MgLSBkb21haW4gbmFtZSBpZiBhdmFpbGFibGUgd2l0aG91dCByZXZlcnNlIEROUyBsb29rdXA7IG90aGVyd2lzZSwgSVAgYWRkcmVzcyBvciBVbml4IGRvbWFpbiBzb2NrZXQgbmFtZSAqL1xuY29uc3QgQ0xJRU5UX0FERFJFU1NfQVRUUklCVVRFID0gJ2NsaWVudC5hZGRyZXNzJztcblxuLyoqIENsaWVudCBwb3J0IG51bWJlciAqL1xuY29uc3QgQ0xJRU5UX1BPUlRfQVRUUklCVVRFID0gJ2NsaWVudC5wb3J0JztcblxuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cbi8vIFNFTlRSWS1TUEVDSUZJQyBNQ1AgQVRUUklCVVRFIFZBTFVFU1xuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cblxuLyoqIFNlbnRyeSBvcGVyYXRpb24gdmFsdWUgZm9yIE1DUCBzZXJ2ZXIgc3BhbnMgKi9cbmNvbnN0IE1DUF9TRVJWRVJfT1BfVkFMVUUgPSAnbWNwLnNlcnZlcic7XG5cbi8qKlxuICogU2VudHJ5IG9wZXJhdGlvbiB2YWx1ZSBmb3IgY2xpZW50LXRvLXNlcnZlciBub3RpZmljYXRpb25zXG4gKiBGb2xsb3dpbmcgT3BlblRlbGVtZXRyeSBNQ1Agc2VtYW50aWMgY29udmVudGlvbnNcbiAqL1xuY29uc3QgTUNQX05PVElGSUNBVElPTl9DTElFTlRfVE9fU0VSVkVSX09QX1ZBTFVFID0gJ21jcC5ub3RpZmljYXRpb24uY2xpZW50X3RvX3NlcnZlcic7XG5cbi8qKlxuICogU2VudHJ5IG9wZXJhdGlvbiB2YWx1ZSBmb3Igc2VydmVyLXRvLWNsaWVudCBub3RpZmljYXRpb25zXG4gKiBGb2xsb3dpbmcgT3BlblRlbGVtZXRyeSBNQ1Agc2VtYW50aWMgY29udmVudGlvbnNcbiAqL1xuY29uc3QgTUNQX05PVElGSUNBVElPTl9TRVJWRVJfVE9fQ0xJRU5UX09QX1ZBTFVFID0gJ21jcC5ub3RpZmljYXRpb24uc2VydmVyX3RvX2NsaWVudCc7XG5cbi8qKiBTZW50cnkgb3JpZ2luIHZhbHVlIGZvciBNQ1AgZnVuY3Rpb24gc3BhbnMgKi9cbmNvbnN0IE1DUF9GVU5DVElPTl9PUklHSU5fVkFMVUUgPSAnYXV0by5mdW5jdGlvbi5tY3Bfc2VydmVyJztcblxuLyoqIFNlbnRyeSBvcmlnaW4gdmFsdWUgZm9yIE1DUCBub3RpZmljYXRpb24gc3BhbnMgKi9cbmNvbnN0IE1DUF9OT1RJRklDQVRJT05fT1JJR0lOX1ZBTFVFID0gJ2F1dG8ubWNwLm5vdGlmaWNhdGlvbic7XG5cbi8qKiBTZW50cnkgc291cmNlIHZhbHVlIGZvciBNQ1Agcm91dGUgc3BhbnMgKi9cbmNvbnN0IE1DUF9ST1VURV9TT1VSQ0VfVkFMVUUgPSAncm91dGUnO1xuXG5leHBvcnRzLkNMSUVOVF9BRERSRVNTX0FUVFJJQlVURSA9IENMSUVOVF9BRERSRVNTX0FUVFJJQlVURTtcbmV4cG9ydHMuQ0xJRU5UX1BPUlRfQVRUUklCVVRFID0gQ0xJRU5UX1BPUlRfQVRUUklCVVRFO1xuZXhwb3J0cy5NQ1BfRlVOQ1RJT05fT1JJR0lOX1ZBTFVFID0gTUNQX0ZVTkNUSU9OX09SSUdJTl9WQUxVRTtcbmV4cG9ydHMuTUNQX0xPR0dJTkdfREFUQV9UWVBFX0FUVFJJQlVURSA9IE1DUF9MT0dHSU5HX0RBVEFfVFlQRV9BVFRSSUJVVEU7XG5leHBvcnRzLk1DUF9MT0dHSU5HX0xFVkVMX0FUVFJJQlVURSA9IE1DUF9MT0dHSU5HX0xFVkVMX0FUVFJJQlVURTtcbmV4cG9ydHMuTUNQX0xPR0dJTkdfTE9HR0VSX0FUVFJJQlVURSA9IE1DUF9MT0dHSU5HX0xPR0dFUl9BVFRSSUJVVEU7XG5leHBvcnRzLk1DUF9MT0dHSU5HX01FU1NBR0VfQVRUUklCVVRFID0gTUNQX0xPR0dJTkdfTUVTU0FHRV9BVFRSSUJVVEU7XG5leHBvcnRzLk1DUF9NRVRIT0RfTkFNRV9BVFRSSUJVVEUgPSBNQ1BfTUVUSE9EX05BTUVfQVRUUklCVVRFO1xuZXhwb3J0cy5NQ1BfTk9USUZJQ0FUSU9OX0NMSUVOVF9UT19TRVJWRVJfT1BfVkFMVUUgPSBNQ1BfTk9USUZJQ0FUSU9OX0NMSUVOVF9UT19TRVJWRVJfT1BfVkFMVUU7XG5leHBvcnRzLk1DUF9OT1RJRklDQVRJT05fT1JJR0lOX1ZBTFVFID0gTUNQX05PVElGSUNBVElPTl9PUklHSU5fVkFMVUU7XG5leHBvcnRzLk1DUF9OT1RJRklDQVRJT05fU0VSVkVSX1RPX0NMSUVOVF9PUF9WQUxVRSA9IE1DUF9OT1RJRklDQVRJT05fU0VSVkVSX1RPX0NMSUVOVF9PUF9WQUxVRTtcbmV4cG9ydHMuTUNQX1BST01QVF9OQU1FX0FUVFJJQlVURSA9IE1DUF9QUk9NUFRfTkFNRV9BVFRSSUJVVEU7XG5leHBvcnRzLk1DUF9QUk9NUFRfUkVTVUxUX0RFU0NSSVBUSU9OX0FUVFJJQlVURSA9IE1DUF9QUk9NUFRfUkVTVUxUX0RFU0NSSVBUSU9OX0FUVFJJQlVURTtcbmV4cG9ydHMuTUNQX1BST01QVF9SRVNVTFRfTUVTU0FHRV9DT05URU5UX0FUVFJJQlVURSA9IE1DUF9QUk9NUFRfUkVTVUxUX01FU1NBR0VfQ09OVEVOVF9BVFRSSUJVVEU7XG5leHBvcnRzLk1DUF9QUk9NUFRfUkVTVUxUX01FU1NBR0VfQ09VTlRfQVRUUklCVVRFID0gTUNQX1BST01QVF9SRVNVTFRfTUVTU0FHRV9DT1VOVF9BVFRSSUJVVEU7XG5leHBvcnRzLk1DUF9QUk9NUFRfUkVTVUxUX1BSRUZJWCA9IE1DUF9QUk9NUFRfUkVTVUxUX1BSRUZJWDtcbmV4cG9ydHMuTUNQX1BST1RPQ09MX1ZFUlNJT05fQVRUUklCVVRFID0gTUNQX1BST1RPQ09MX1ZFUlNJT05fQVRUUklCVVRFO1xuZXhwb3J0cy5NQ1BfUkVRVUVTVF9BUkdVTUVOVCA9IE1DUF9SRVFVRVNUX0FSR1VNRU5UO1xuZXhwb3J0cy5NQ1BfUkVRVUVTVF9JRF9BVFRSSUJVVEUgPSBNQ1BfUkVRVUVTVF9JRF9BVFRSSUJVVEU7XG5leHBvcnRzLk1DUF9SRVNPVVJDRV9VUklfQVRUUklCVVRFID0gTUNQX1JFU09VUkNFX1VSSV9BVFRSSUJVVEU7XG5leHBvcnRzLk1DUF9ST1VURV9TT1VSQ0VfVkFMVUUgPSBNQ1BfUk9VVEVfU09VUkNFX1ZBTFVFO1xuZXhwb3J0cy5NQ1BfU0VSVkVSX05BTUVfQVRUUklCVVRFID0gTUNQX1NFUlZFUl9OQU1FX0FUVFJJQlVURTtcbmV4cG9ydHMuTUNQX1NFUlZFUl9PUF9WQUxVRSA9IE1DUF9TRVJWRVJfT1BfVkFMVUU7XG5leHBvcnRzLk1DUF9TRVJWRVJfVElUTEVfQVRUUklCVVRFID0gTUNQX1NFUlZFUl9USVRMRV9BVFRSSUJVVEU7XG5leHBvcnRzLk1DUF9TRVJWRVJfVkVSU0lPTl9BVFRSSUJVVEUgPSBNQ1BfU0VSVkVSX1ZFUlNJT05fQVRUUklCVVRFO1xuZXhwb3J0cy5NQ1BfU0VTU0lPTl9JRF9BVFRSSUJVVEUgPSBNQ1BfU0VTU0lPTl9JRF9BVFRSSUJVVEU7XG5leHBvcnRzLk1DUF9UT09MX05BTUVfQVRUUklCVVRFID0gTUNQX1RPT0xfTkFNRV9BVFRSSUJVVEU7XG5leHBvcnRzLk1DUF9UT09MX1JFU1VMVF9DT05URU5UX0FUVFJJQlVURSA9IE1DUF9UT09MX1JFU1VMVF9DT05URU5UX0FUVFJJQlVURTtcbmV4cG9ydHMuTUNQX1RPT0xfUkVTVUxUX0NPTlRFTlRfQ09VTlRfQVRUUklCVVRFID0gTUNQX1RPT0xfUkVTVUxUX0NPTlRFTlRfQ09VTlRfQVRUUklCVVRFO1xuZXhwb3J0cy5NQ1BfVE9PTF9SRVNVTFRfSVNfRVJST1JfQVRUUklCVVRFID0gTUNQX1RPT0xfUkVTVUxUX0lTX0VSUk9SX0FUVFJJQlVURTtcbmV4cG9ydHMuTUNQX1RPT0xfUkVTVUxUX1BSRUZJWCA9IE1DUF9UT09MX1JFU1VMVF9QUkVGSVg7XG5leHBvcnRzLk1DUF9UUkFOU1BPUlRfQVRUUklCVVRFID0gTUNQX1RSQU5TUE9SVF9BVFRSSUJVVEU7XG5leHBvcnRzLk5FVFdPUktfUFJPVE9DT0xfVkVSU0lPTl9BVFRSSUJVVEUgPSBORVRXT1JLX1BST1RPQ09MX1ZFUlNJT05fQVRUUklCVVRFO1xuZXhwb3J0cy5ORVRXT1JLX1RSQU5TUE9SVF9BVFRSSUJVVEUgPSBORVRXT1JLX1RSQU5TUE9SVF9BVFRSSUJVVEU7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1hdHRyaWJ1dGVzLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/attributes.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/correlation.js":
/*!***************************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/correlation.js ***!
  \***************************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst currentScopes = __webpack_require__(/*! ../../currentScopes.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst spanstatus = __webpack_require__(/*! ../../tracing/spanstatus.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/spanstatus.js\");\nconst piiFiltering = __webpack_require__(/*! ./piiFiltering.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/piiFiltering.js\");\nconst resultExtraction = __webpack_require__(/*! ./resultExtraction.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/resultExtraction.js\");\n\n/**\n * Request-span correlation system for MCP server instrumentation\n *\n * Handles mapping requestId to span data for correlation with handler execution.\n * Uses WeakMap to scope correlation maps per transport instance, preventing\n * request ID collisions between different MCP sessions.\n */\n\n\n/**\n * Transport-scoped correlation system that prevents collisions between different MCP sessions\n * @internal Each transport instance gets its own correlation map, eliminating request ID conflicts\n */\nconst transportToSpanMap = new WeakMap();\n\n/**\n * Gets or creates the span map for a specific transport instance\n * @internal\n * @param transport - MCP transport instance\n * @returns Span map for the transport\n */\nfunction getOrCreateSpanMap(transport) {\n  let spanMap = transportToSpanMap.get(transport);\n  if (!spanMap) {\n    spanMap = new Map();\n    transportToSpanMap.set(transport, spanMap);\n  }\n  return spanMap;\n}\n\n/**\n * Stores span context for later correlation with handler execution\n * @param transport - MCP transport instance\n * @param requestId - Request identifier\n * @param span - Active span to correlate\n * @param method - MCP method name\n */\nfunction storeSpanForRequest(transport, requestId, span, method) {\n  const spanMap = getOrCreateSpanMap(transport);\n  spanMap.set(requestId, {\n    span,\n    method,\n    startTime: Date.now(),\n  });\n}\n\n/**\n * Completes span with tool results and cleans up correlation\n * @param transport - MCP transport instance\n * @param requestId - Request identifier\n * @param result - Tool execution result for attribute extraction\n */\nfunction completeSpanWithResults(transport, requestId, result) {\n  const spanMap = getOrCreateSpanMap(transport);\n  const spanData = spanMap.get(requestId);\n  if (spanData) {\n    const { span, method } = spanData;\n\n    if (method === 'tools/call') {\n      const rawToolAttributes = resultExtraction.extractToolResultAttributes(result);\n      const client = currentScopes.getClient();\n      const sendDefaultPii = Boolean(client?.getOptions().sendDefaultPii);\n      const toolAttributes = piiFiltering.filterMcpPiiFromSpanData(rawToolAttributes, sendDefaultPii);\n\n      span.setAttributes(toolAttributes);\n    } else if (method === 'prompts/get') {\n      const rawPromptAttributes = resultExtraction.extractPromptResultAttributes(result);\n      const client = currentScopes.getClient();\n      const sendDefaultPii = Boolean(client?.getOptions().sendDefaultPii);\n      const promptAttributes = piiFiltering.filterMcpPiiFromSpanData(rawPromptAttributes, sendDefaultPii);\n\n      span.setAttributes(promptAttributes);\n    }\n\n    span.end();\n    spanMap.delete(requestId);\n  }\n}\n\n/**\n * Cleans up pending spans for a specific transport (when that transport closes)\n * @param transport - MCP transport instance\n * @returns Number of pending spans that were cleaned up\n */\nfunction cleanupPendingSpansForTransport(transport) {\n  const spanMap = transportToSpanMap.get(transport);\n  if (!spanMap) {\n    return 0;\n  }\n\n  const pendingCount = spanMap.size;\n\n  for (const [, spanData] of spanMap) {\n    spanData.span.setStatus({\n      code: spanstatus.SPAN_STATUS_ERROR,\n      message: 'cancelled',\n    });\n    spanData.span.end();\n  }\n\n  spanMap.clear();\n  return pendingCount;\n}\n\nexports.cleanupPendingSpansForTransport = cleanupPendingSpansForTransport;\nexports.completeSpanWithResults = completeSpanWithResults;\nexports.storeSpanForRequest = storeSpanForRequest;\n//# sourceMappingURL=correlation.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvbWNwLXNlcnZlci9jb3JyZWxhdGlvbi5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxzQkFBc0IsbUJBQU8sQ0FBQyxtSUFBd0I7QUFDdEQsbUJBQW1CLG1CQUFPLENBQUMsNklBQTZCO0FBQ3hELHFCQUFxQixtQkFBTyxDQUFDLHFKQUFtQjtBQUNoRCx5QkFBeUIsbUJBQU8sQ0FBQyw2SkFBdUI7O0FBRXhEO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOzs7QUFHQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxHQUFHO0FBQ0g7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxZQUFZLGVBQWU7O0FBRTNCO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQSxNQUFNO0FBQ047QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEtBQUs7QUFDTDtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQSx1Q0FBdUM7QUFDdkMsK0JBQStCO0FBQy9CLDJCQUEyQjtBQUMzQiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL2ludGVncmF0aW9ucy9tY3Atc2VydmVyL2NvcnJlbGF0aW9uLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBjdXJyZW50U2NvcGVzID0gcmVxdWlyZSgnLi4vLi4vY3VycmVudFNjb3Blcy5qcycpO1xuY29uc3Qgc3BhbnN0YXR1cyA9IHJlcXVpcmUoJy4uLy4uL3RyYWNpbmcvc3BhbnN0YXR1cy5qcycpO1xuY29uc3QgcGlpRmlsdGVyaW5nID0gcmVxdWlyZSgnLi9waWlGaWx0ZXJpbmcuanMnKTtcbmNvbnN0IHJlc3VsdEV4dHJhY3Rpb24gPSByZXF1aXJlKCcuL3Jlc3VsdEV4dHJhY3Rpb24uanMnKTtcblxuLyoqXG4gKiBSZXF1ZXN0LXNwYW4gY29ycmVsYXRpb24gc3lzdGVtIGZvciBNQ1Agc2VydmVyIGluc3RydW1lbnRhdGlvblxuICpcbiAqIEhhbmRsZXMgbWFwcGluZyByZXF1ZXN0SWQgdG8gc3BhbiBkYXRhIGZvciBjb3JyZWxhdGlvbiB3aXRoIGhhbmRsZXIgZXhlY3V0aW9uLlxuICogVXNlcyBXZWFrTWFwIHRvIHNjb3BlIGNvcnJlbGF0aW9uIG1hcHMgcGVyIHRyYW5zcG9ydCBpbnN0YW5jZSwgcHJldmVudGluZ1xuICogcmVxdWVzdCBJRCBjb2xsaXNpb25zIGJldHdlZW4gZGlmZmVyZW50IE1DUCBzZXNzaW9ucy5cbiAqL1xuXG5cbi8qKlxuICogVHJhbnNwb3J0LXNjb3BlZCBjb3JyZWxhdGlvbiBzeXN0ZW0gdGhhdCBwcmV2ZW50cyBjb2xsaXNpb25zIGJldHdlZW4gZGlmZmVyZW50IE1DUCBzZXNzaW9uc1xuICogQGludGVybmFsIEVhY2ggdHJhbnNwb3J0IGluc3RhbmNlIGdldHMgaXRzIG93biBjb3JyZWxhdGlvbiBtYXAsIGVsaW1pbmF0aW5nIHJlcXVlc3QgSUQgY29uZmxpY3RzXG4gKi9cbmNvbnN0IHRyYW5zcG9ydFRvU3Bhbk1hcCA9IG5ldyBXZWFrTWFwKCk7XG5cbi8qKlxuICogR2V0cyBvciBjcmVhdGVzIHRoZSBzcGFuIG1hcCBmb3IgYSBzcGVjaWZpYyB0cmFuc3BvcnQgaW5zdGFuY2VcbiAqIEBpbnRlcm5hbFxuICogQHBhcmFtIHRyYW5zcG9ydCAtIE1DUCB0cmFuc3BvcnQgaW5zdGFuY2VcbiAqIEByZXR1cm5zIFNwYW4gbWFwIGZvciB0aGUgdHJhbnNwb3J0XG4gKi9cbmZ1bmN0aW9uIGdldE9yQ3JlYXRlU3Bhbk1hcCh0cmFuc3BvcnQpIHtcbiAgbGV0IHNwYW5NYXAgPSB0cmFuc3BvcnRUb1NwYW5NYXAuZ2V0KHRyYW5zcG9ydCk7XG4gIGlmICghc3Bhbk1hcCkge1xuICAgIHNwYW5NYXAgPSBuZXcgTWFwKCk7XG4gICAgdHJhbnNwb3J0VG9TcGFuTWFwLnNldCh0cmFuc3BvcnQsIHNwYW5NYXApO1xuICB9XG4gIHJldHVybiBzcGFuTWFwO1xufVxuXG4vKipcbiAqIFN0b3JlcyBzcGFuIGNvbnRleHQgZm9yIGxhdGVyIGNvcnJlbGF0aW9uIHdpdGggaGFuZGxlciBleGVjdXRpb25cbiAqIEBwYXJhbSB0cmFuc3BvcnQgLSBNQ1AgdHJhbnNwb3J0IGluc3RhbmNlXG4gKiBAcGFyYW0gcmVxdWVzdElkIC0gUmVxdWVzdCBpZGVudGlmaWVyXG4gKiBAcGFyYW0gc3BhbiAtIEFjdGl2ZSBzcGFuIHRvIGNvcnJlbGF0ZVxuICogQHBhcmFtIG1ldGhvZCAtIE1DUCBtZXRob2QgbmFtZVxuICovXG5mdW5jdGlvbiBzdG9yZVNwYW5Gb3JSZXF1ZXN0KHRyYW5zcG9ydCwgcmVxdWVzdElkLCBzcGFuLCBtZXRob2QpIHtcbiAgY29uc3Qgc3Bhbk1hcCA9IGdldE9yQ3JlYXRlU3Bhbk1hcCh0cmFuc3BvcnQpO1xuICBzcGFuTWFwLnNldChyZXF1ZXN0SWQsIHtcbiAgICBzcGFuLFxuICAgIG1ldGhvZCxcbiAgICBzdGFydFRpbWU6IERhdGUubm93KCksXG4gIH0pO1xufVxuXG4vKipcbiAqIENvbXBsZXRlcyBzcGFuIHdpdGggdG9vbCByZXN1bHRzIGFuZCBjbGVhbnMgdXAgY29ycmVsYXRpb25cbiAqIEBwYXJhbSB0cmFuc3BvcnQgLSBNQ1AgdHJhbnNwb3J0IGluc3RhbmNlXG4gKiBAcGFyYW0gcmVxdWVzdElkIC0gUmVxdWVzdCBpZGVudGlmaWVyXG4gKiBAcGFyYW0gcmVzdWx0IC0gVG9vbCBleGVjdXRpb24gcmVzdWx0IGZvciBhdHRyaWJ1dGUgZXh0cmFjdGlvblxuICovXG5mdW5jdGlvbiBjb21wbGV0ZVNwYW5XaXRoUmVzdWx0cyh0cmFuc3BvcnQsIHJlcXVlc3RJZCwgcmVzdWx0KSB7XG4gIGNvbnN0IHNwYW5NYXAgPSBnZXRPckNyZWF0ZVNwYW5NYXAodHJhbnNwb3J0KTtcbiAgY29uc3Qgc3BhbkRhdGEgPSBzcGFuTWFwLmdldChyZXF1ZXN0SWQpO1xuICBpZiAoc3BhbkRhdGEpIHtcbiAgICBjb25zdCB7IHNwYW4sIG1ldGhvZCB9ID0gc3BhbkRhdGE7XG5cbiAgICBpZiAobWV0aG9kID09PSAndG9vbHMvY2FsbCcpIHtcbiAgICAgIGNvbnN0IHJhd1Rvb2xBdHRyaWJ1dGVzID0gcmVzdWx0RXh0cmFjdGlvbi5leHRyYWN0VG9vbFJlc3VsdEF0dHJpYnV0ZXMocmVzdWx0KTtcbiAgICAgIGNvbnN0IGNsaWVudCA9IGN1cnJlbnRTY29wZXMuZ2V0Q2xpZW50KCk7XG4gICAgICBjb25zdCBzZW5kRGVmYXVsdFBpaSA9IEJvb2xlYW4oY2xpZW50Py5nZXRPcHRpb25zKCkuc2VuZERlZmF1bHRQaWkpO1xuICAgICAgY29uc3QgdG9vbEF0dHJpYnV0ZXMgPSBwaWlGaWx0ZXJpbmcuZmlsdGVyTWNwUGlpRnJvbVNwYW5EYXRhKHJhd1Rvb2xBdHRyaWJ1dGVzLCBzZW5kRGVmYXVsdFBpaSk7XG5cbiAgICAgIHNwYW4uc2V0QXR0cmlidXRlcyh0b29sQXR0cmlidXRlcyk7XG4gICAgfSBlbHNlIGlmIChtZXRob2QgPT09ICdwcm9tcHRzL2dldCcpIHtcbiAgICAgIGNvbnN0IHJhd1Byb21wdEF0dHJpYnV0ZXMgPSByZXN1bHRFeHRyYWN0aW9uLmV4dHJhY3RQcm9tcHRSZXN1bHRBdHRyaWJ1dGVzKHJlc3VsdCk7XG4gICAgICBjb25zdCBjbGllbnQgPSBjdXJyZW50U2NvcGVzLmdldENsaWVudCgpO1xuICAgICAgY29uc3Qgc2VuZERlZmF1bHRQaWkgPSBCb29sZWFuKGNsaWVudD8uZ2V0T3B0aW9ucygpLnNlbmREZWZhdWx0UGlpKTtcbiAgICAgIGNvbnN0IHByb21wdEF0dHJpYnV0ZXMgPSBwaWlGaWx0ZXJpbmcuZmlsdGVyTWNwUGlpRnJvbVNwYW5EYXRhKHJhd1Byb21wdEF0dHJpYnV0ZXMsIHNlbmREZWZhdWx0UGlpKTtcblxuICAgICAgc3Bhbi5zZXRBdHRyaWJ1dGVzKHByb21wdEF0dHJpYnV0ZXMpO1xuICAgIH1cblxuICAgIHNwYW4uZW5kKCk7XG4gICAgc3Bhbk1hcC5kZWxldGUocmVxdWVzdElkKTtcbiAgfVxufVxuXG4vKipcbiAqIENsZWFucyB1cCBwZW5kaW5nIHNwYW5zIGZvciBhIHNwZWNpZmljIHRyYW5zcG9ydCAod2hlbiB0aGF0IHRyYW5zcG9ydCBjbG9zZXMpXG4gKiBAcGFyYW0gdHJhbnNwb3J0IC0gTUNQIHRyYW5zcG9ydCBpbnN0YW5jZVxuICogQHJldHVybnMgTnVtYmVyIG9mIHBlbmRpbmcgc3BhbnMgdGhhdCB3ZXJlIGNsZWFuZWQgdXBcbiAqL1xuZnVuY3Rpb24gY2xlYW51cFBlbmRpbmdTcGFuc0ZvclRyYW5zcG9ydCh0cmFuc3BvcnQpIHtcbiAgY29uc3Qgc3Bhbk1hcCA9IHRyYW5zcG9ydFRvU3Bhbk1hcC5nZXQodHJhbnNwb3J0KTtcbiAgaWYgKCFzcGFuTWFwKSB7XG4gICAgcmV0dXJuIDA7XG4gIH1cblxuICBjb25zdCBwZW5kaW5nQ291bnQgPSBzcGFuTWFwLnNpemU7XG5cbiAgZm9yIChjb25zdCBbLCBzcGFuRGF0YV0gb2Ygc3Bhbk1hcCkge1xuICAgIHNwYW5EYXRhLnNwYW4uc2V0U3RhdHVzKHtcbiAgICAgIGNvZGU6IHNwYW5zdGF0dXMuU1BBTl9TVEFUVVNfRVJST1IsXG4gICAgICBtZXNzYWdlOiAnY2FuY2VsbGVkJyxcbiAgICB9KTtcbiAgICBzcGFuRGF0YS5zcGFuLmVuZCgpO1xuICB9XG5cbiAgc3Bhbk1hcC5jbGVhcigpO1xuICByZXR1cm4gcGVuZGluZ0NvdW50O1xufVxuXG5leHBvcnRzLmNsZWFudXBQZW5kaW5nU3BhbnNGb3JUcmFuc3BvcnQgPSBjbGVhbnVwUGVuZGluZ1NwYW5zRm9yVHJhbnNwb3J0O1xuZXhwb3J0cy5jb21wbGV0ZVNwYW5XaXRoUmVzdWx0cyA9IGNvbXBsZXRlU3BhbldpdGhSZXN1bHRzO1xuZXhwb3J0cy5zdG9yZVNwYW5Gb3JSZXF1ZXN0ID0gc3RvcmVTcGFuRm9yUmVxdWVzdDtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWNvcnJlbGF0aW9uLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/correlation.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/errorCapture.js":
/*!****************************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/errorCapture.js ***!
  \****************************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst currentScopes = __webpack_require__(/*! ../../currentScopes.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst exports$1 = __webpack_require__(/*! ../../exports.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/exports.js\");\nconst spanUtils = __webpack_require__(/*! ../../utils/spanUtils.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanUtils.js\");\nconst spanstatus = __webpack_require__(/*! ../../tracing/spanstatus.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/spanstatus.js\");\n\n/**\n * Safe error capture utilities for MCP server instrumentation\n *\n * Ensures error reporting never interferes with MCP server operation.\n * All capture operations are wrapped in try-catch to prevent side effects.\n */\n\n\n/**\n * Captures an error without affecting MCP server operation.\n *\n * The active span already contains all MCP context (method, tool, arguments, etc.)\n * @param error - Error to capture\n * @param errorType - Classification of error type for filtering\n * @param extraData - Additional context data to include\n */\nfunction captureError(error, errorType, extraData) {\n  try {\n    const client = currentScopes.getClient();\n    if (!client) {\n      return;\n    }\n\n    const activeSpan = spanUtils.getActiveSpan();\n    if (activeSpan?.isRecording()) {\n      activeSpan.setStatus({\n        code: spanstatus.SPAN_STATUS_ERROR,\n        message: 'internal_error',\n      });\n    }\n\n    exports$1.captureException(error, {\n      mechanism: {\n        type: 'mcp_server',\n        handled: false,\n        data: {\n          error_type: errorType || 'handler_execution',\n          ...extraData,\n        },\n      },\n    });\n  } catch {\n    // noop\n  }\n}\n\nexports.captureError = captureError;\n//# sourceMappingURL=errorCapture.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvbWNwLXNlcnZlci9lcnJvckNhcHR1cmUuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsc0JBQXNCLG1CQUFPLENBQUMsbUlBQXdCO0FBQ3RELGtCQUFrQixtQkFBTyxDQUFDLHVIQUFrQjtBQUM1QyxrQkFBa0IsbUJBQU8sQ0FBQyx1SUFBMEI7QUFDcEQsbUJBQW1CLG1CQUFPLENBQUMsNklBQTZCOztBQUV4RDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7OztBQUdBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLE9BQU87QUFDUDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFNBQVM7QUFDVCxPQUFPO0FBQ1AsS0FBSztBQUNMLElBQUk7QUFDSjtBQUNBO0FBQ0E7O0FBRUEsb0JBQW9CO0FBQ3BCIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvaW50ZWdyYXRpb25zL21jcC1zZXJ2ZXIvZXJyb3JDYXB0dXJlLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBjdXJyZW50U2NvcGVzID0gcmVxdWlyZSgnLi4vLi4vY3VycmVudFNjb3Blcy5qcycpO1xuY29uc3QgZXhwb3J0cyQxID0gcmVxdWlyZSgnLi4vLi4vZXhwb3J0cy5qcycpO1xuY29uc3Qgc3BhblV0aWxzID0gcmVxdWlyZSgnLi4vLi4vdXRpbHMvc3BhblV0aWxzLmpzJyk7XG5jb25zdCBzcGFuc3RhdHVzID0gcmVxdWlyZSgnLi4vLi4vdHJhY2luZy9zcGFuc3RhdHVzLmpzJyk7XG5cbi8qKlxuICogU2FmZSBlcnJvciBjYXB0dXJlIHV0aWxpdGllcyBmb3IgTUNQIHNlcnZlciBpbnN0cnVtZW50YXRpb25cbiAqXG4gKiBFbnN1cmVzIGVycm9yIHJlcG9ydGluZyBuZXZlciBpbnRlcmZlcmVzIHdpdGggTUNQIHNlcnZlciBvcGVyYXRpb24uXG4gKiBBbGwgY2FwdHVyZSBvcGVyYXRpb25zIGFyZSB3cmFwcGVkIGluIHRyeS1jYXRjaCB0byBwcmV2ZW50IHNpZGUgZWZmZWN0cy5cbiAqL1xuXG5cbi8qKlxuICogQ2FwdHVyZXMgYW4gZXJyb3Igd2l0aG91dCBhZmZlY3RpbmcgTUNQIHNlcnZlciBvcGVyYXRpb24uXG4gKlxuICogVGhlIGFjdGl2ZSBzcGFuIGFscmVhZHkgY29udGFpbnMgYWxsIE1DUCBjb250ZXh0IChtZXRob2QsIHRvb2wsIGFyZ3VtZW50cywgZXRjLilcbiAqIEBwYXJhbSBlcnJvciAtIEVycm9yIHRvIGNhcHR1cmVcbiAqIEBwYXJhbSBlcnJvclR5cGUgLSBDbGFzc2lmaWNhdGlvbiBvZiBlcnJvciB0eXBlIGZvciBmaWx0ZXJpbmdcbiAqIEBwYXJhbSBleHRyYURhdGEgLSBBZGRpdGlvbmFsIGNvbnRleHQgZGF0YSB0byBpbmNsdWRlXG4gKi9cbmZ1bmN0aW9uIGNhcHR1cmVFcnJvcihlcnJvciwgZXJyb3JUeXBlLCBleHRyYURhdGEpIHtcbiAgdHJ5IHtcbiAgICBjb25zdCBjbGllbnQgPSBjdXJyZW50U2NvcGVzLmdldENsaWVudCgpO1xuICAgIGlmICghY2xpZW50KSB7XG4gICAgICByZXR1cm47XG4gICAgfVxuXG4gICAgY29uc3QgYWN0aXZlU3BhbiA9IHNwYW5VdGlscy5nZXRBY3RpdmVTcGFuKCk7XG4gICAgaWYgKGFjdGl2ZVNwYW4/LmlzUmVjb3JkaW5nKCkpIHtcbiAgICAgIGFjdGl2ZVNwYW4uc2V0U3RhdHVzKHtcbiAgICAgICAgY29kZTogc3BhbnN0YXR1cy5TUEFOX1NUQVRVU19FUlJPUixcbiAgICAgICAgbWVzc2FnZTogJ2ludGVybmFsX2Vycm9yJyxcbiAgICAgIH0pO1xuICAgIH1cblxuICAgIGV4cG9ydHMkMS5jYXB0dXJlRXhjZXB0aW9uKGVycm9yLCB7XG4gICAgICBtZWNoYW5pc206IHtcbiAgICAgICAgdHlwZTogJ21jcF9zZXJ2ZXInLFxuICAgICAgICBoYW5kbGVkOiBmYWxzZSxcbiAgICAgICAgZGF0YToge1xuICAgICAgICAgIGVycm9yX3R5cGU6IGVycm9yVHlwZSB8fCAnaGFuZGxlcl9leGVjdXRpb24nLFxuICAgICAgICAgIC4uLmV4dHJhRGF0YSxcbiAgICAgICAgfSxcbiAgICAgIH0sXG4gICAgfSk7XG4gIH0gY2F0Y2gge1xuICAgIC8vIG5vb3BcbiAgfVxufVxuXG5leHBvcnRzLmNhcHR1cmVFcnJvciA9IGNhcHR1cmVFcnJvcjtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWVycm9yQ2FwdHVyZS5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/errorCapture.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/handlers.js":
/*!************************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/handlers.js ***!
  \************************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst debugBuild = __webpack_require__(/*! ../../debug-build.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst debugLogger = __webpack_require__(/*! ../../utils/debug-logger.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst object = __webpack_require__(/*! ../../utils/object.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/object.js\");\nconst errorCapture = __webpack_require__(/*! ./errorCapture.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/errorCapture.js\");\n\n/**\n * Handler method wrapping for MCP server instrumentation\n *\n * Provides automatic error capture and span correlation for tool, resource,\n * and prompt handlers.\n */\n\n\n/**\n * Generic function to wrap MCP server method handlers\n * @internal\n * @param serverInstance - MCP server instance\n * @param methodName - Method name to wrap (tool, resource, prompt)\n */\nfunction wrapMethodHandler(serverInstance, methodName) {\n  object.fill(serverInstance, methodName, originalMethod => {\n    return function ( name, ...args) {\n      const handler = args[args.length - 1];\n\n      if (typeof handler !== 'function') {\n        return (originalMethod ).call(this, name, ...args);\n      }\n\n      const wrappedHandler = createWrappedHandler(handler , methodName, name);\n      return (originalMethod ).call(this, name, ...args.slice(0, -1), wrappedHandler);\n    };\n  });\n}\n\n/**\n * Creates a wrapped handler with span correlation and error capture\n * @internal\n * @param originalHandler - Original handler function\n * @param methodName - MCP method name\n * @param handlerName - Handler identifier\n * @returns Wrapped handler function\n */\nfunction createWrappedHandler(originalHandler, methodName, handlerName) {\n  return function ( ...handlerArgs) {\n    try {\n      return createErrorCapturingHandler.call(this, originalHandler, methodName, handlerName, handlerArgs);\n    } catch (error) {\n      debugBuild.DEBUG_BUILD && debugLogger.debug.warn('MCP handler wrapping failed:', error);\n      return originalHandler.apply(this, handlerArgs);\n    }\n  };\n}\n\n/**\n * Creates an error-capturing wrapper for handler execution\n * @internal\n * @param originalHandler - Original handler function\n * @param methodName - MCP method name\n * @param handlerName - Handler identifier\n * @param handlerArgs - Handler arguments\n * @param extraHandlerData - Additional handler context\n * @returns Handler execution result\n */\nfunction createErrorCapturingHandler(\n\n  originalHandler,\n  methodName,\n  handlerName,\n  handlerArgs,\n) {\n  try {\n    const result = originalHandler.apply(this, handlerArgs);\n\n    if (result && typeof result === 'object' && typeof (result ).then === 'function') {\n      return Promise.resolve(result).catch(error => {\n        captureHandlerError(error, methodName, handlerName);\n        throw error;\n      });\n    }\n\n    return result;\n  } catch (error) {\n    captureHandlerError(error , methodName, handlerName);\n    throw error;\n  }\n}\n\n/**\n * Captures handler execution errors based on handler type\n * @internal\n * @param error - Error to capture\n * @param methodName - MCP method name\n * @param handlerName - Handler identifier\n */\nfunction captureHandlerError(error, methodName, handlerName) {\n  try {\n    const extraData = {};\n\n    if (methodName === 'tool') {\n      extraData.tool_name = handlerName;\n\n      if (\n        error.name === 'ProtocolValidationError' ||\n        error.message.includes('validation') ||\n        error.message.includes('protocol')\n      ) {\n        errorCapture.captureError(error, 'validation', extraData);\n      } else if (\n        error.name === 'ServerTimeoutError' ||\n        error.message.includes('timed out') ||\n        error.message.includes('timeout')\n      ) {\n        errorCapture.captureError(error, 'timeout', extraData);\n      } else {\n        errorCapture.captureError(error, 'tool_execution', extraData);\n      }\n    } else if (methodName === 'resource') {\n      extraData.resource_uri = handlerName;\n      errorCapture.captureError(error, 'resource_execution', extraData);\n    } else if (methodName === 'prompt') {\n      extraData.prompt_name = handlerName;\n      errorCapture.captureError(error, 'prompt_execution', extraData);\n    }\n  } catch (captureErr) {\n    // noop\n  }\n}\n\n/**\n * Wraps tool handlers to associate them with request spans\n * @param serverInstance - MCP server instance\n */\nfunction wrapToolHandlers(serverInstance) {\n  wrapMethodHandler(serverInstance, 'tool');\n}\n\n/**\n * Wraps resource handlers to associate them with request spans\n * @param serverInstance - MCP server instance\n */\nfunction wrapResourceHandlers(serverInstance) {\n  wrapMethodHandler(serverInstance, 'resource');\n}\n\n/**\n * Wraps prompt handlers to associate them with request spans\n * @param serverInstance - MCP server instance\n */\nfunction wrapPromptHandlers(serverInstance) {\n  wrapMethodHandler(serverInstance, 'prompt');\n}\n\n/**\n * Wraps all MCP handler types (tool, resource, prompt) for span correlation\n * @param serverInstance - MCP server instance\n */\nfunction wrapAllMCPHandlers(serverInstance) {\n  wrapToolHandlers(serverInstance);\n  wrapResourceHandlers(serverInstance);\n  wrapPromptHandlers(serverInstance);\n}\n\nexports.wrapAllMCPHandlers = wrapAllMCPHandlers;\nexports.wrapPromptHandlers = wrapPromptHandlers;\nexports.wrapResourceHandlers = wrapResourceHandlers;\nexports.wrapToolHandlers = wrapToolHandlers;\n//# sourceMappingURL=handlers.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvbWNwLXNlcnZlci9oYW5kbGVycy5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxtQkFBbUIsbUJBQU8sQ0FBQywrSEFBc0I7QUFDakQsb0JBQW9CLG1CQUFPLENBQUMsNklBQTZCO0FBQ3pELGVBQWUsbUJBQU8sQ0FBQyxpSUFBdUI7QUFDOUMscUJBQXFCLG1CQUFPLENBQUMscUpBQW1COztBQUVoRDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7OztBQUdBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQSxHQUFHO0FBQ0g7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsTUFBTTtBQUNOO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLE9BQU87QUFDUDs7QUFFQTtBQUNBLElBQUk7QUFDSjtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFFBQVE7QUFDUjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsUUFBUTtBQUNSO0FBQ0E7QUFDQSxNQUFNO0FBQ047QUFDQTtBQUNBLE1BQU07QUFDTjtBQUNBO0FBQ0E7QUFDQSxJQUFJO0FBQ0o7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSwwQkFBMEI7QUFDMUIsMEJBQTBCO0FBQzFCLDRCQUE0QjtBQUM1Qix3QkFBd0I7QUFDeEIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvbWNwLXNlcnZlci9oYW5kbGVycy5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgZGVidWdCdWlsZCA9IHJlcXVpcmUoJy4uLy4uL2RlYnVnLWJ1aWxkLmpzJyk7XG5jb25zdCBkZWJ1Z0xvZ2dlciA9IHJlcXVpcmUoJy4uLy4uL3V0aWxzL2RlYnVnLWxvZ2dlci5qcycpO1xuY29uc3Qgb2JqZWN0ID0gcmVxdWlyZSgnLi4vLi4vdXRpbHMvb2JqZWN0LmpzJyk7XG5jb25zdCBlcnJvckNhcHR1cmUgPSByZXF1aXJlKCcuL2Vycm9yQ2FwdHVyZS5qcycpO1xuXG4vKipcbiAqIEhhbmRsZXIgbWV0aG9kIHdyYXBwaW5nIGZvciBNQ1Agc2VydmVyIGluc3RydW1lbnRhdGlvblxuICpcbiAqIFByb3ZpZGVzIGF1dG9tYXRpYyBlcnJvciBjYXB0dXJlIGFuZCBzcGFuIGNvcnJlbGF0aW9uIGZvciB0b29sLCByZXNvdXJjZSxcbiAqIGFuZCBwcm9tcHQgaGFuZGxlcnMuXG4gKi9cblxuXG4vKipcbiAqIEdlbmVyaWMgZnVuY3Rpb24gdG8gd3JhcCBNQ1Agc2VydmVyIG1ldGhvZCBoYW5kbGVyc1xuICogQGludGVybmFsXG4gKiBAcGFyYW0gc2VydmVySW5zdGFuY2UgLSBNQ1Agc2VydmVyIGluc3RhbmNlXG4gKiBAcGFyYW0gbWV0aG9kTmFtZSAtIE1ldGhvZCBuYW1lIHRvIHdyYXAgKHRvb2wsIHJlc291cmNlLCBwcm9tcHQpXG4gKi9cbmZ1bmN0aW9uIHdyYXBNZXRob2RIYW5kbGVyKHNlcnZlckluc3RhbmNlLCBtZXRob2ROYW1lKSB7XG4gIG9iamVjdC5maWxsKHNlcnZlckluc3RhbmNlLCBtZXRob2ROYW1lLCBvcmlnaW5hbE1ldGhvZCA9PiB7XG4gICAgcmV0dXJuIGZ1bmN0aW9uICggbmFtZSwgLi4uYXJncykge1xuICAgICAgY29uc3QgaGFuZGxlciA9IGFyZ3NbYXJncy5sZW5ndGggLSAxXTtcblxuICAgICAgaWYgKHR5cGVvZiBoYW5kbGVyICE9PSAnZnVuY3Rpb24nKSB7XG4gICAgICAgIHJldHVybiAob3JpZ2luYWxNZXRob2QgKS5jYWxsKHRoaXMsIG5hbWUsIC4uLmFyZ3MpO1xuICAgICAgfVxuXG4gICAgICBjb25zdCB3cmFwcGVkSGFuZGxlciA9IGNyZWF0ZVdyYXBwZWRIYW5kbGVyKGhhbmRsZXIgLCBtZXRob2ROYW1lLCBuYW1lKTtcbiAgICAgIHJldHVybiAob3JpZ2luYWxNZXRob2QgKS5jYWxsKHRoaXMsIG5hbWUsIC4uLmFyZ3Muc2xpY2UoMCwgLTEpLCB3cmFwcGVkSGFuZGxlcik7XG4gICAgfTtcbiAgfSk7XG59XG5cbi8qKlxuICogQ3JlYXRlcyBhIHdyYXBwZWQgaGFuZGxlciB3aXRoIHNwYW4gY29ycmVsYXRpb24gYW5kIGVycm9yIGNhcHR1cmVcbiAqIEBpbnRlcm5hbFxuICogQHBhcmFtIG9yaWdpbmFsSGFuZGxlciAtIE9yaWdpbmFsIGhhbmRsZXIgZnVuY3Rpb25cbiAqIEBwYXJhbSBtZXRob2ROYW1lIC0gTUNQIG1ldGhvZCBuYW1lXG4gKiBAcGFyYW0gaGFuZGxlck5hbWUgLSBIYW5kbGVyIGlkZW50aWZpZXJcbiAqIEByZXR1cm5zIFdyYXBwZWQgaGFuZGxlciBmdW5jdGlvblxuICovXG5mdW5jdGlvbiBjcmVhdGVXcmFwcGVkSGFuZGxlcihvcmlnaW5hbEhhbmRsZXIsIG1ldGhvZE5hbWUsIGhhbmRsZXJOYW1lKSB7XG4gIHJldHVybiBmdW5jdGlvbiAoIC4uLmhhbmRsZXJBcmdzKSB7XG4gICAgdHJ5IHtcbiAgICAgIHJldHVybiBjcmVhdGVFcnJvckNhcHR1cmluZ0hhbmRsZXIuY2FsbCh0aGlzLCBvcmlnaW5hbEhhbmRsZXIsIG1ldGhvZE5hbWUsIGhhbmRsZXJOYW1lLCBoYW5kbGVyQXJncyk7XG4gICAgfSBjYXRjaCAoZXJyb3IpIHtcbiAgICAgIGRlYnVnQnVpbGQuREVCVUdfQlVJTEQgJiYgZGVidWdMb2dnZXIuZGVidWcud2FybignTUNQIGhhbmRsZXIgd3JhcHBpbmcgZmFpbGVkOicsIGVycm9yKTtcbiAgICAgIHJldHVybiBvcmlnaW5hbEhhbmRsZXIuYXBwbHkodGhpcywgaGFuZGxlckFyZ3MpO1xuICAgIH1cbiAgfTtcbn1cblxuLyoqXG4gKiBDcmVhdGVzIGFuIGVycm9yLWNhcHR1cmluZyB3cmFwcGVyIGZvciBoYW5kbGVyIGV4ZWN1dGlvblxuICogQGludGVybmFsXG4gKiBAcGFyYW0gb3JpZ2luYWxIYW5kbGVyIC0gT3JpZ2luYWwgaGFuZGxlciBmdW5jdGlvblxuICogQHBhcmFtIG1ldGhvZE5hbWUgLSBNQ1AgbWV0aG9kIG5hbWVcbiAqIEBwYXJhbSBoYW5kbGVyTmFtZSAtIEhhbmRsZXIgaWRlbnRpZmllclxuICogQHBhcmFtIGhhbmRsZXJBcmdzIC0gSGFuZGxlciBhcmd1bWVudHNcbiAqIEBwYXJhbSBleHRyYUhhbmRsZXJEYXRhIC0gQWRkaXRpb25hbCBoYW5kbGVyIGNvbnRleHRcbiAqIEByZXR1cm5zIEhhbmRsZXIgZXhlY3V0aW9uIHJlc3VsdFxuICovXG5mdW5jdGlvbiBjcmVhdGVFcnJvckNhcHR1cmluZ0hhbmRsZXIoXG5cbiAgb3JpZ2luYWxIYW5kbGVyLFxuICBtZXRob2ROYW1lLFxuICBoYW5kbGVyTmFtZSxcbiAgaGFuZGxlckFyZ3MsXG4pIHtcbiAgdHJ5IHtcbiAgICBjb25zdCByZXN1bHQgPSBvcmlnaW5hbEhhbmRsZXIuYXBwbHkodGhpcywgaGFuZGxlckFyZ3MpO1xuXG4gICAgaWYgKHJlc3VsdCAmJiB0eXBlb2YgcmVzdWx0ID09PSAnb2JqZWN0JyAmJiB0eXBlb2YgKHJlc3VsdCApLnRoZW4gPT09ICdmdW5jdGlvbicpIHtcbiAgICAgIHJldHVybiBQcm9taXNlLnJlc29sdmUocmVzdWx0KS5jYXRjaChlcnJvciA9PiB7XG4gICAgICAgIGNhcHR1cmVIYW5kbGVyRXJyb3IoZXJyb3IsIG1ldGhvZE5hbWUsIGhhbmRsZXJOYW1lKTtcbiAgICAgICAgdGhyb3cgZXJyb3I7XG4gICAgICB9KTtcbiAgICB9XG5cbiAgICByZXR1cm4gcmVzdWx0O1xuICB9IGNhdGNoIChlcnJvcikge1xuICAgIGNhcHR1cmVIYW5kbGVyRXJyb3IoZXJyb3IgLCBtZXRob2ROYW1lLCBoYW5kbGVyTmFtZSk7XG4gICAgdGhyb3cgZXJyb3I7XG4gIH1cbn1cblxuLyoqXG4gKiBDYXB0dXJlcyBoYW5kbGVyIGV4ZWN1dGlvbiBlcnJvcnMgYmFzZWQgb24gaGFuZGxlciB0eXBlXG4gKiBAaW50ZXJuYWxcbiAqIEBwYXJhbSBlcnJvciAtIEVycm9yIHRvIGNhcHR1cmVcbiAqIEBwYXJhbSBtZXRob2ROYW1lIC0gTUNQIG1ldGhvZCBuYW1lXG4gKiBAcGFyYW0gaGFuZGxlck5hbWUgLSBIYW5kbGVyIGlkZW50aWZpZXJcbiAqL1xuZnVuY3Rpb24gY2FwdHVyZUhhbmRsZXJFcnJvcihlcnJvciwgbWV0aG9kTmFtZSwgaGFuZGxlck5hbWUpIHtcbiAgdHJ5IHtcbiAgICBjb25zdCBleHRyYURhdGEgPSB7fTtcblxuICAgIGlmIChtZXRob2ROYW1lID09PSAndG9vbCcpIHtcbiAgICAgIGV4dHJhRGF0YS50b29sX25hbWUgPSBoYW5kbGVyTmFtZTtcblxuICAgICAgaWYgKFxuICAgICAgICBlcnJvci5uYW1lID09PSAnUHJvdG9jb2xWYWxpZGF0aW9uRXJyb3InIHx8XG4gICAgICAgIGVycm9yLm1lc3NhZ2UuaW5jbHVkZXMoJ3ZhbGlkYXRpb24nKSB8fFxuICAgICAgICBlcnJvci5tZXNzYWdlLmluY2x1ZGVzKCdwcm90b2NvbCcpXG4gICAgICApIHtcbiAgICAgICAgZXJyb3JDYXB0dXJlLmNhcHR1cmVFcnJvcihlcnJvciwgJ3ZhbGlkYXRpb24nLCBleHRyYURhdGEpO1xuICAgICAgfSBlbHNlIGlmIChcbiAgICAgICAgZXJyb3IubmFtZSA9PT0gJ1NlcnZlclRpbWVvdXRFcnJvcicgfHxcbiAgICAgICAgZXJyb3IubWVzc2FnZS5pbmNsdWRlcygndGltZWQgb3V0JykgfHxcbiAgICAgICAgZXJyb3IubWVzc2FnZS5pbmNsdWRlcygndGltZW91dCcpXG4gICAgICApIHtcbiAgICAgICAgZXJyb3JDYXB0dXJlLmNhcHR1cmVFcnJvcihlcnJvciwgJ3RpbWVvdXQnLCBleHRyYURhdGEpO1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgZXJyb3JDYXB0dXJlLmNhcHR1cmVFcnJvcihlcnJvciwgJ3Rvb2xfZXhlY3V0aW9uJywgZXh0cmFEYXRhKTtcbiAgICAgIH1cbiAgICB9IGVsc2UgaWYgKG1ldGhvZE5hbWUgPT09ICdyZXNvdXJjZScpIHtcbiAgICAgIGV4dHJhRGF0YS5yZXNvdXJjZV91cmkgPSBoYW5kbGVyTmFtZTtcbiAgICAgIGVycm9yQ2FwdHVyZS5jYXB0dXJlRXJyb3IoZXJyb3IsICdyZXNvdXJjZV9leGVjdXRpb24nLCBleHRyYURhdGEpO1xuICAgIH0gZWxzZSBpZiAobWV0aG9kTmFtZSA9PT0gJ3Byb21wdCcpIHtcbiAgICAgIGV4dHJhRGF0YS5wcm9tcHRfbmFtZSA9IGhhbmRsZXJOYW1lO1xuICAgICAgZXJyb3JDYXB0dXJlLmNhcHR1cmVFcnJvcihlcnJvciwgJ3Byb21wdF9leGVjdXRpb24nLCBleHRyYURhdGEpO1xuICAgIH1cbiAgfSBjYXRjaCAoY2FwdHVyZUVycikge1xuICAgIC8vIG5vb3BcbiAgfVxufVxuXG4vKipcbiAqIFdyYXBzIHRvb2wgaGFuZGxlcnMgdG8gYXNzb2NpYXRlIHRoZW0gd2l0aCByZXF1ZXN0IHNwYW5zXG4gKiBAcGFyYW0gc2VydmVySW5zdGFuY2UgLSBNQ1Agc2VydmVyIGluc3RhbmNlXG4gKi9cbmZ1bmN0aW9uIHdyYXBUb29sSGFuZGxlcnMoc2VydmVySW5zdGFuY2UpIHtcbiAgd3JhcE1ldGhvZEhhbmRsZXIoc2VydmVySW5zdGFuY2UsICd0b29sJyk7XG59XG5cbi8qKlxuICogV3JhcHMgcmVzb3VyY2UgaGFuZGxlcnMgdG8gYXNzb2NpYXRlIHRoZW0gd2l0aCByZXF1ZXN0IHNwYW5zXG4gKiBAcGFyYW0gc2VydmVySW5zdGFuY2UgLSBNQ1Agc2VydmVyIGluc3RhbmNlXG4gKi9cbmZ1bmN0aW9uIHdyYXBSZXNvdXJjZUhhbmRsZXJzKHNlcnZlckluc3RhbmNlKSB7XG4gIHdyYXBNZXRob2RIYW5kbGVyKHNlcnZlckluc3RhbmNlLCAncmVzb3VyY2UnKTtcbn1cblxuLyoqXG4gKiBXcmFwcyBwcm9tcHQgaGFuZGxlcnMgdG8gYXNzb2NpYXRlIHRoZW0gd2l0aCByZXF1ZXN0IHNwYW5zXG4gKiBAcGFyYW0gc2VydmVySW5zdGFuY2UgLSBNQ1Agc2VydmVyIGluc3RhbmNlXG4gKi9cbmZ1bmN0aW9uIHdyYXBQcm9tcHRIYW5kbGVycyhzZXJ2ZXJJbnN0YW5jZSkge1xuICB3cmFwTWV0aG9kSGFuZGxlcihzZXJ2ZXJJbnN0YW5jZSwgJ3Byb21wdCcpO1xufVxuXG4vKipcbiAqIFdyYXBzIGFsbCBNQ1AgaGFuZGxlciB0eXBlcyAodG9vbCwgcmVzb3VyY2UsIHByb21wdCkgZm9yIHNwYW4gY29ycmVsYXRpb25cbiAqIEBwYXJhbSBzZXJ2ZXJJbnN0YW5jZSAtIE1DUCBzZXJ2ZXIgaW5zdGFuY2VcbiAqL1xuZnVuY3Rpb24gd3JhcEFsbE1DUEhhbmRsZXJzKHNlcnZlckluc3RhbmNlKSB7XG4gIHdyYXBUb29sSGFuZGxlcnMoc2VydmVySW5zdGFuY2UpO1xuICB3cmFwUmVzb3VyY2VIYW5kbGVycyhzZXJ2ZXJJbnN0YW5jZSk7XG4gIHdyYXBQcm9tcHRIYW5kbGVycyhzZXJ2ZXJJbnN0YW5jZSk7XG59XG5cbmV4cG9ydHMud3JhcEFsbE1DUEhhbmRsZXJzID0gd3JhcEFsbE1DUEhhbmRsZXJzO1xuZXhwb3J0cy53cmFwUHJvbXB0SGFuZGxlcnMgPSB3cmFwUHJvbXB0SGFuZGxlcnM7XG5leHBvcnRzLndyYXBSZXNvdXJjZUhhbmRsZXJzID0gd3JhcFJlc291cmNlSGFuZGxlcnM7XG5leHBvcnRzLndyYXBUb29sSGFuZGxlcnMgPSB3cmFwVG9vbEhhbmRsZXJzO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9aGFuZGxlcnMuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/handlers.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/index.js":
/*!*********************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/index.js ***!
  \*********************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst object = __webpack_require__(/*! ../../utils/object.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/object.js\");\nconst handlers = __webpack_require__(/*! ./handlers.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/handlers.js\");\nconst transport = __webpack_require__(/*! ./transport.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/transport.js\");\nconst validation = __webpack_require__(/*! ./validation.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/validation.js\");\n\n/**\n * Tracks wrapped MCP server instances to prevent double-wrapping\n * @internal\n */\nconst wrappedMcpServerInstances = new WeakSet();\n\n/**\n * Wraps a MCP Server instance from the `@modelcontextprotocol/sdk` package with Sentry instrumentation.\n *\n * Compatible with versions `^1.9.0` of the `@modelcontextprotocol/sdk` package.\n * Automatically instruments transport methods and handler functions for comprehensive monitoring.\n *\n * @example\n * ```typescript\n * import * as Sentry from '@sentry/core';\n * import { McpServer } from '@modelcontextprotocol/sdk/server/mcp.js';\n * import { StreamableHTTPServerTransport } from '@modelcontextprotocol/sdk/server/streamableHttp.js';\n *\n * const server = Sentry.wrapMcpServerWithSentry(\n *   new McpServer({ name: \"my-server\", version: \"1.0.0\" })\n * );\n *\n * const transport = new StreamableHTTPServerTransport();\n * await server.connect(transport);\n * ```\n *\n * @param mcpServerInstance - MCP server instance to instrument\n * @returns Instrumented server instance (same reference)\n */\nfunction wrapMcpServerWithSentry(mcpServerInstance) {\n  if (wrappedMcpServerInstances.has(mcpServerInstance)) {\n    return mcpServerInstance;\n  }\n\n  if (!validation.validateMcpServerInstance(mcpServerInstance)) {\n    return mcpServerInstance;\n  }\n\n  const serverInstance = mcpServerInstance ;\n\n  object.fill(serverInstance, 'connect', originalConnect => {\n    return async function ( transport$1, ...restArgs) {\n      const result = await (originalConnect ).call(\n        this,\n        transport$1,\n        ...restArgs,\n      );\n\n      transport.wrapTransportOnMessage(transport$1);\n      transport.wrapTransportSend(transport$1);\n      transport.wrapTransportOnClose(transport$1);\n      transport.wrapTransportError(transport$1);\n\n      return result;\n    };\n  });\n\n  handlers.wrapAllMCPHandlers(serverInstance);\n\n  wrappedMcpServerInstances.add(mcpServerInstance);\n  return mcpServerInstance ;\n}\n\nexports.wrapMcpServerWithSentry = wrapMcpServerWithSentry;\n//# sourceMappingURL=index.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvbWNwLXNlcnZlci9pbmRleC5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxlQUFlLG1CQUFPLENBQUMsaUlBQXVCO0FBQzlDLGlCQUFpQixtQkFBTyxDQUFDLDZJQUFlO0FBQ3hDLGtCQUFrQixtQkFBTyxDQUFDLCtJQUFnQjtBQUMxQyxtQkFBbUIsbUJBQU8sQ0FBQyxpSkFBaUI7O0FBRTVDO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsWUFBWSxZQUFZO0FBQ3hCLFlBQVksZ0NBQWdDO0FBQzVDO0FBQ0E7QUFDQSxxQkFBcUIscUNBQXFDO0FBQzFEO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsR0FBRzs7QUFFSDs7QUFFQTtBQUNBO0FBQ0E7O0FBRUEsK0JBQStCO0FBQy9CIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvaW50ZWdyYXRpb25zL21jcC1zZXJ2ZXIvaW5kZXguanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IG9iamVjdCA9IHJlcXVpcmUoJy4uLy4uL3V0aWxzL29iamVjdC5qcycpO1xuY29uc3QgaGFuZGxlcnMgPSByZXF1aXJlKCcuL2hhbmRsZXJzLmpzJyk7XG5jb25zdCB0cmFuc3BvcnQgPSByZXF1aXJlKCcuL3RyYW5zcG9ydC5qcycpO1xuY29uc3QgdmFsaWRhdGlvbiA9IHJlcXVpcmUoJy4vdmFsaWRhdGlvbi5qcycpO1xuXG4vKipcbiAqIFRyYWNrcyB3cmFwcGVkIE1DUCBzZXJ2ZXIgaW5zdGFuY2VzIHRvIHByZXZlbnQgZG91YmxlLXdyYXBwaW5nXG4gKiBAaW50ZXJuYWxcbiAqL1xuY29uc3Qgd3JhcHBlZE1jcFNlcnZlckluc3RhbmNlcyA9IG5ldyBXZWFrU2V0KCk7XG5cbi8qKlxuICogV3JhcHMgYSBNQ1AgU2VydmVyIGluc3RhbmNlIGZyb20gdGhlIGBAbW9kZWxjb250ZXh0cHJvdG9jb2wvc2RrYCBwYWNrYWdlIHdpdGggU2VudHJ5IGluc3RydW1lbnRhdGlvbi5cbiAqXG4gKiBDb21wYXRpYmxlIHdpdGggdmVyc2lvbnMgYF4xLjkuMGAgb2YgdGhlIGBAbW9kZWxjb250ZXh0cHJvdG9jb2wvc2RrYCBwYWNrYWdlLlxuICogQXV0b21hdGljYWxseSBpbnN0cnVtZW50cyB0cmFuc3BvcnQgbWV0aG9kcyBhbmQgaGFuZGxlciBmdW5jdGlvbnMgZm9yIGNvbXByZWhlbnNpdmUgbW9uaXRvcmluZy5cbiAqXG4gKiBAZXhhbXBsZVxuICogYGBgdHlwZXNjcmlwdFxuICogaW1wb3J0ICogYXMgU2VudHJ5IGZyb20gJ0BzZW50cnkvY29yZSc7XG4gKiBpbXBvcnQgeyBNY3BTZXJ2ZXIgfSBmcm9tICdAbW9kZWxjb250ZXh0cHJvdG9jb2wvc2RrL3NlcnZlci9tY3AuanMnO1xuICogaW1wb3J0IHsgU3RyZWFtYWJsZUhUVFBTZXJ2ZXJUcmFuc3BvcnQgfSBmcm9tICdAbW9kZWxjb250ZXh0cHJvdG9jb2wvc2RrL3NlcnZlci9zdHJlYW1hYmxlSHR0cC5qcyc7XG4gKlxuICogY29uc3Qgc2VydmVyID0gU2VudHJ5LndyYXBNY3BTZXJ2ZXJXaXRoU2VudHJ5KFxuICogICBuZXcgTWNwU2VydmVyKHsgbmFtZTogXCJteS1zZXJ2ZXJcIiwgdmVyc2lvbjogXCIxLjAuMFwiIH0pXG4gKiApO1xuICpcbiAqIGNvbnN0IHRyYW5zcG9ydCA9IG5ldyBTdHJlYW1hYmxlSFRUUFNlcnZlclRyYW5zcG9ydCgpO1xuICogYXdhaXQgc2VydmVyLmNvbm5lY3QodHJhbnNwb3J0KTtcbiAqIGBgYFxuICpcbiAqIEBwYXJhbSBtY3BTZXJ2ZXJJbnN0YW5jZSAtIE1DUCBzZXJ2ZXIgaW5zdGFuY2UgdG8gaW5zdHJ1bWVudFxuICogQHJldHVybnMgSW5zdHJ1bWVudGVkIHNlcnZlciBpbnN0YW5jZSAoc2FtZSByZWZlcmVuY2UpXG4gKi9cbmZ1bmN0aW9uIHdyYXBNY3BTZXJ2ZXJXaXRoU2VudHJ5KG1jcFNlcnZlckluc3RhbmNlKSB7XG4gIGlmICh3cmFwcGVkTWNwU2VydmVySW5zdGFuY2VzLmhhcyhtY3BTZXJ2ZXJJbnN0YW5jZSkpIHtcbiAgICByZXR1cm4gbWNwU2VydmVySW5zdGFuY2U7XG4gIH1cblxuICBpZiAoIXZhbGlkYXRpb24udmFsaWRhdGVNY3BTZXJ2ZXJJbnN0YW5jZShtY3BTZXJ2ZXJJbnN0YW5jZSkpIHtcbiAgICByZXR1cm4gbWNwU2VydmVySW5zdGFuY2U7XG4gIH1cblxuICBjb25zdCBzZXJ2ZXJJbnN0YW5jZSA9IG1jcFNlcnZlckluc3RhbmNlIDtcblxuICBvYmplY3QuZmlsbChzZXJ2ZXJJbnN0YW5jZSwgJ2Nvbm5lY3QnLCBvcmlnaW5hbENvbm5lY3QgPT4ge1xuICAgIHJldHVybiBhc3luYyBmdW5jdGlvbiAoIHRyYW5zcG9ydCQxLCAuLi5yZXN0QXJncykge1xuICAgICAgY29uc3QgcmVzdWx0ID0gYXdhaXQgKG9yaWdpbmFsQ29ubmVjdCApLmNhbGwoXG4gICAgICAgIHRoaXMsXG4gICAgICAgIHRyYW5zcG9ydCQxLFxuICAgICAgICAuLi5yZXN0QXJncyxcbiAgICAgICk7XG5cbiAgICAgIHRyYW5zcG9ydC53cmFwVHJhbnNwb3J0T25NZXNzYWdlKHRyYW5zcG9ydCQxKTtcbiAgICAgIHRyYW5zcG9ydC53cmFwVHJhbnNwb3J0U2VuZCh0cmFuc3BvcnQkMSk7XG4gICAgICB0cmFuc3BvcnQud3JhcFRyYW5zcG9ydE9uQ2xvc2UodHJhbnNwb3J0JDEpO1xuICAgICAgdHJhbnNwb3J0LndyYXBUcmFuc3BvcnRFcnJvcih0cmFuc3BvcnQkMSk7XG5cbiAgICAgIHJldHVybiByZXN1bHQ7XG4gICAgfTtcbiAgfSk7XG5cbiAgaGFuZGxlcnMud3JhcEFsbE1DUEhhbmRsZXJzKHNlcnZlckluc3RhbmNlKTtcblxuICB3cmFwcGVkTWNwU2VydmVySW5zdGFuY2VzLmFkZChtY3BTZXJ2ZXJJbnN0YW5jZSk7XG4gIHJldHVybiBtY3BTZXJ2ZXJJbnN0YW5jZSA7XG59XG5cbmV4cG9ydHMud3JhcE1jcFNlcnZlcldpdGhTZW50cnkgPSB3cmFwTWNwU2VydmVyV2l0aFNlbnRyeTtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWluZGV4LmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/index.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/methodConfig.js":
/*!****************************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/methodConfig.js ***!
  \****************************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst attributes = __webpack_require__(/*! ./attributes.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/attributes.js\");\n\n/**\n * Method configuration and request processing for MCP server instrumentation\n */\n\n\n/**\n * Configuration for MCP methods to extract targets and arguments\n * @internal Maps method names to their extraction configuration\n */\nconst METHOD_CONFIGS = {\n  'tools/call': {\n    targetField: 'name',\n    targetAttribute: attributes.MCP_TOOL_NAME_ATTRIBUTE,\n    captureArguments: true,\n    argumentsField: 'arguments',\n  },\n  'resources/read': {\n    targetField: 'uri',\n    targetAttribute: attributes.MCP_RESOURCE_URI_ATTRIBUTE,\n    captureUri: true,\n  },\n  'resources/subscribe': {\n    targetField: 'uri',\n    targetAttribute: attributes.MCP_RESOURCE_URI_ATTRIBUTE,\n  },\n  'resources/unsubscribe': {\n    targetField: 'uri',\n    targetAttribute: attributes.MCP_RESOURCE_URI_ATTRIBUTE,\n  },\n  'prompts/get': {\n    targetField: 'name',\n    targetAttribute: attributes.MCP_PROMPT_NAME_ATTRIBUTE,\n    captureName: true,\n    captureArguments: true,\n    argumentsField: 'arguments',\n  },\n};\n\n/**\n * Extracts target info from method and params based on method type\n * @param method - MCP method name\n * @param params - Method parameters\n * @returns Target name and attributes for span instrumentation\n */\nfunction extractTargetInfo(\n  method,\n  params,\n)\n\n {\n  const config = METHOD_CONFIGS[method ];\n  if (!config) {\n    return { attributes: {} };\n  }\n\n  const target =\n    config.targetField && typeof params?.[config.targetField] === 'string'\n      ? (params[config.targetField] )\n      : undefined;\n\n  return {\n    target,\n    attributes: target && config.targetAttribute ? { [config.targetAttribute]: target } : {},\n  };\n}\n\n/**\n * Extracts request arguments based on method type\n * @param method - MCP method name\n * @param params - Method parameters\n * @returns Arguments as span attributes with mcp.request.argument prefix\n */\nfunction getRequestArguments(method, params) {\n  const args = {};\n  const config = METHOD_CONFIGS[method ];\n\n  if (!config) {\n    return args;\n  }\n\n  if (config.captureArguments && config.argumentsField && params?.[config.argumentsField]) {\n    const argumentsObj = params[config.argumentsField];\n    if (typeof argumentsObj === 'object' && argumentsObj !== null) {\n      for (const [key, value] of Object.entries(argumentsObj )) {\n        args[`${attributes.MCP_REQUEST_ARGUMENT}.${key.toLowerCase()}`] = JSON.stringify(value);\n      }\n    }\n  }\n\n  if (config.captureUri && params?.uri) {\n    args[`${attributes.MCP_REQUEST_ARGUMENT}.uri`] = JSON.stringify(params.uri);\n  }\n\n  if (config.captureName && params?.name) {\n    args[`${attributes.MCP_REQUEST_ARGUMENT}.name`] = JSON.stringify(params.name);\n  }\n\n  return args;\n}\n\nexports.extractTargetInfo = extractTargetInfo;\nexports.getRequestArguments = getRequestArguments;\n//# sourceMappingURL=methodConfig.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvbWNwLXNlcnZlci9tZXRob2RDb25maWcuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsbUJBQW1CLG1CQUFPLENBQUMsaUpBQWlCOztBQUU1QztBQUNBO0FBQ0E7OztBQUdBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsR0FBRztBQUNIO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsR0FBRztBQUNIO0FBQ0E7QUFDQTtBQUNBLEdBQUc7QUFDSDtBQUNBO0FBQ0E7QUFDQSxHQUFHO0FBQ0g7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsR0FBRztBQUNIOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBLGFBQWE7QUFDYjs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0EscURBQXFELG1DQUFtQyxJQUFJO0FBQzVGO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGdCQUFnQixnQ0FBZ0MsR0FBRyxrQkFBa0I7QUFDckU7QUFDQTtBQUNBOztBQUVBO0FBQ0EsWUFBWSxnQ0FBZ0M7QUFDNUM7O0FBRUE7QUFDQSxZQUFZLGdDQUFnQztBQUM1Qzs7QUFFQTtBQUNBOztBQUVBLHlCQUF5QjtBQUN6QiwyQkFBMkI7QUFDM0IiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvbWNwLXNlcnZlci9tZXRob2RDb25maWcuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGF0dHJpYnV0ZXMgPSByZXF1aXJlKCcuL2F0dHJpYnV0ZXMuanMnKTtcblxuLyoqXG4gKiBNZXRob2QgY29uZmlndXJhdGlvbiBhbmQgcmVxdWVzdCBwcm9jZXNzaW5nIGZvciBNQ1Agc2VydmVyIGluc3RydW1lbnRhdGlvblxuICovXG5cblxuLyoqXG4gKiBDb25maWd1cmF0aW9uIGZvciBNQ1AgbWV0aG9kcyB0byBleHRyYWN0IHRhcmdldHMgYW5kIGFyZ3VtZW50c1xuICogQGludGVybmFsIE1hcHMgbWV0aG9kIG5hbWVzIHRvIHRoZWlyIGV4dHJhY3Rpb24gY29uZmlndXJhdGlvblxuICovXG5jb25zdCBNRVRIT0RfQ09ORklHUyA9IHtcbiAgJ3Rvb2xzL2NhbGwnOiB7XG4gICAgdGFyZ2V0RmllbGQ6ICduYW1lJyxcbiAgICB0YXJnZXRBdHRyaWJ1dGU6IGF0dHJpYnV0ZXMuTUNQX1RPT0xfTkFNRV9BVFRSSUJVVEUsXG4gICAgY2FwdHVyZUFyZ3VtZW50czogdHJ1ZSxcbiAgICBhcmd1bWVudHNGaWVsZDogJ2FyZ3VtZW50cycsXG4gIH0sXG4gICdyZXNvdXJjZXMvcmVhZCc6IHtcbiAgICB0YXJnZXRGaWVsZDogJ3VyaScsXG4gICAgdGFyZ2V0QXR0cmlidXRlOiBhdHRyaWJ1dGVzLk1DUF9SRVNPVVJDRV9VUklfQVRUUklCVVRFLFxuICAgIGNhcHR1cmVVcmk6IHRydWUsXG4gIH0sXG4gICdyZXNvdXJjZXMvc3Vic2NyaWJlJzoge1xuICAgIHRhcmdldEZpZWxkOiAndXJpJyxcbiAgICB0YXJnZXRBdHRyaWJ1dGU6IGF0dHJpYnV0ZXMuTUNQX1JFU09VUkNFX1VSSV9BVFRSSUJVVEUsXG4gIH0sXG4gICdyZXNvdXJjZXMvdW5zdWJzY3JpYmUnOiB7XG4gICAgdGFyZ2V0RmllbGQ6ICd1cmknLFxuICAgIHRhcmdldEF0dHJpYnV0ZTogYXR0cmlidXRlcy5NQ1BfUkVTT1VSQ0VfVVJJX0FUVFJJQlVURSxcbiAgfSxcbiAgJ3Byb21wdHMvZ2V0Jzoge1xuICAgIHRhcmdldEZpZWxkOiAnbmFtZScsXG4gICAgdGFyZ2V0QXR0cmlidXRlOiBhdHRyaWJ1dGVzLk1DUF9QUk9NUFRfTkFNRV9BVFRSSUJVVEUsXG4gICAgY2FwdHVyZU5hbWU6IHRydWUsXG4gICAgY2FwdHVyZUFyZ3VtZW50czogdHJ1ZSxcbiAgICBhcmd1bWVudHNGaWVsZDogJ2FyZ3VtZW50cycsXG4gIH0sXG59O1xuXG4vKipcbiAqIEV4dHJhY3RzIHRhcmdldCBpbmZvIGZyb20gbWV0aG9kIGFuZCBwYXJhbXMgYmFzZWQgb24gbWV0aG9kIHR5cGVcbiAqIEBwYXJhbSBtZXRob2QgLSBNQ1AgbWV0aG9kIG5hbWVcbiAqIEBwYXJhbSBwYXJhbXMgLSBNZXRob2QgcGFyYW1ldGVyc1xuICogQHJldHVybnMgVGFyZ2V0IG5hbWUgYW5kIGF0dHJpYnV0ZXMgZm9yIHNwYW4gaW5zdHJ1bWVudGF0aW9uXG4gKi9cbmZ1bmN0aW9uIGV4dHJhY3RUYXJnZXRJbmZvKFxuICBtZXRob2QsXG4gIHBhcmFtcyxcbilcblxuIHtcbiAgY29uc3QgY29uZmlnID0gTUVUSE9EX0NPTkZJR1NbbWV0aG9kIF07XG4gIGlmICghY29uZmlnKSB7XG4gICAgcmV0dXJuIHsgYXR0cmlidXRlczoge30gfTtcbiAgfVxuXG4gIGNvbnN0IHRhcmdldCA9XG4gICAgY29uZmlnLnRhcmdldEZpZWxkICYmIHR5cGVvZiBwYXJhbXM/Lltjb25maWcudGFyZ2V0RmllbGRdID09PSAnc3RyaW5nJ1xuICAgICAgPyAocGFyYW1zW2NvbmZpZy50YXJnZXRGaWVsZF0gKVxuICAgICAgOiB1bmRlZmluZWQ7XG5cbiAgcmV0dXJuIHtcbiAgICB0YXJnZXQsXG4gICAgYXR0cmlidXRlczogdGFyZ2V0ICYmIGNvbmZpZy50YXJnZXRBdHRyaWJ1dGUgPyB7IFtjb25maWcudGFyZ2V0QXR0cmlidXRlXTogdGFyZ2V0IH0gOiB7fSxcbiAgfTtcbn1cblxuLyoqXG4gKiBFeHRyYWN0cyByZXF1ZXN0IGFyZ3VtZW50cyBiYXNlZCBvbiBtZXRob2QgdHlwZVxuICogQHBhcmFtIG1ldGhvZCAtIE1DUCBtZXRob2QgbmFtZVxuICogQHBhcmFtIHBhcmFtcyAtIE1ldGhvZCBwYXJhbWV0ZXJzXG4gKiBAcmV0dXJucyBBcmd1bWVudHMgYXMgc3BhbiBhdHRyaWJ1dGVzIHdpdGggbWNwLnJlcXVlc3QuYXJndW1lbnQgcHJlZml4XG4gKi9cbmZ1bmN0aW9uIGdldFJlcXVlc3RBcmd1bWVudHMobWV0aG9kLCBwYXJhbXMpIHtcbiAgY29uc3QgYXJncyA9IHt9O1xuICBjb25zdCBjb25maWcgPSBNRVRIT0RfQ09ORklHU1ttZXRob2QgXTtcblxuICBpZiAoIWNvbmZpZykge1xuICAgIHJldHVybiBhcmdzO1xuICB9XG5cbiAgaWYgKGNvbmZpZy5jYXB0dXJlQXJndW1lbnRzICYmIGNvbmZpZy5hcmd1bWVudHNGaWVsZCAmJiBwYXJhbXM/Lltjb25maWcuYXJndW1lbnRzRmllbGRdKSB7XG4gICAgY29uc3QgYXJndW1lbnRzT2JqID0gcGFyYW1zW2NvbmZpZy5hcmd1bWVudHNGaWVsZF07XG4gICAgaWYgKHR5cGVvZiBhcmd1bWVudHNPYmogPT09ICdvYmplY3QnICYmIGFyZ3VtZW50c09iaiAhPT0gbnVsbCkge1xuICAgICAgZm9yIChjb25zdCBba2V5LCB2YWx1ZV0gb2YgT2JqZWN0LmVudHJpZXMoYXJndW1lbnRzT2JqICkpIHtcbiAgICAgICAgYXJnc1tgJHthdHRyaWJ1dGVzLk1DUF9SRVFVRVNUX0FSR1VNRU5UfS4ke2tleS50b0xvd2VyQ2FzZSgpfWBdID0gSlNPTi5zdHJpbmdpZnkodmFsdWUpO1xuICAgICAgfVxuICAgIH1cbiAgfVxuXG4gIGlmIChjb25maWcuY2FwdHVyZVVyaSAmJiBwYXJhbXM/LnVyaSkge1xuICAgIGFyZ3NbYCR7YXR0cmlidXRlcy5NQ1BfUkVRVUVTVF9BUkdVTUVOVH0udXJpYF0gPSBKU09OLnN0cmluZ2lmeShwYXJhbXMudXJpKTtcbiAgfVxuXG4gIGlmIChjb25maWcuY2FwdHVyZU5hbWUgJiYgcGFyYW1zPy5uYW1lKSB7XG4gICAgYXJnc1tgJHthdHRyaWJ1dGVzLk1DUF9SRVFVRVNUX0FSR1VNRU5UfS5uYW1lYF0gPSBKU09OLnN0cmluZ2lmeShwYXJhbXMubmFtZSk7XG4gIH1cblxuICByZXR1cm4gYXJncztcbn1cblxuZXhwb3J0cy5leHRyYWN0VGFyZ2V0SW5mbyA9IGV4dHJhY3RUYXJnZXRJbmZvO1xuZXhwb3J0cy5nZXRSZXF1ZXN0QXJndW1lbnRzID0gZ2V0UmVxdWVzdEFyZ3VtZW50cztcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPW1ldGhvZENvbmZpZy5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/methodConfig.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/piiFiltering.js":
/*!****************************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/piiFiltering.js ***!
  \****************************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst attributes = __webpack_require__(/*! ./attributes.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/attributes.js\");\n\n/**\n * PII attributes that should be removed when sendDefaultPii is false\n * @internal\n */\nconst PII_ATTRIBUTES = new Set([\n  attributes.CLIENT_ADDRESS_ATTRIBUTE,\n  attributes.CLIENT_PORT_ATTRIBUTE,\n  attributes.MCP_LOGGING_MESSAGE_ATTRIBUTE,\n  attributes.MCP_PROMPT_RESULT_DESCRIPTION_ATTRIBUTE,\n  attributes.MCP_PROMPT_RESULT_MESSAGE_CONTENT_ATTRIBUTE,\n  attributes.MCP_RESOURCE_URI_ATTRIBUTE,\n  attributes.MCP_TOOL_RESULT_CONTENT_ATTRIBUTE,\n]);\n\n/**\n * Checks if an attribute key should be considered PII.\n *\n * Returns true for:\n * - Explicit PII attributes (client.address, client.port, mcp.logging.message, etc.)\n * - All request arguments (mcp.request.argument.*)\n * - Tool and prompt result content (mcp.tool.result.*, mcp.prompt.result.*) except metadata\n *\n * Preserves metadata attributes ending with _count, _error, or .is_error as they don't contain sensitive data.\n *\n * @param key - Attribute key to evaluate\n * @returns true if the attribute should be filtered out (is PII), false if it should be preserved\n * @internal\n */\nfunction isPiiAttribute(key) {\n  if (PII_ATTRIBUTES.has(key)) {\n    return true;\n  }\n\n  if (key.startsWith(`${attributes.MCP_REQUEST_ARGUMENT}.`)) {\n    return true;\n  }\n\n  if (key.startsWith(`${attributes.MCP_TOOL_RESULT_PREFIX}.`) || key.startsWith(`${attributes.MCP_PROMPT_RESULT_PREFIX}.`)) {\n    if (!key.endsWith('_count') && !key.endsWith('_error') && !key.endsWith('.is_error')) {\n      return true;\n    }\n  }\n\n  return false;\n}\n\n/**\n * Removes PII attributes from span data when sendDefaultPii is false\n * @param spanData - Raw span attributes\n * @param sendDefaultPii - Whether to include PII data\n * @returns Filtered span attributes\n */\nfunction filterMcpPiiFromSpanData(\n  spanData,\n  sendDefaultPii,\n) {\n  if (sendDefaultPii) {\n    return spanData ;\n  }\n\n  return Object.entries(spanData).reduce(\n    (acc, [key, value]) => {\n      if (!isPiiAttribute(key)) {\n        acc[key] = value ;\n      }\n      return acc;\n    },\n    {} ,\n  );\n}\n\nexports.filterMcpPiiFromSpanData = filterMcpPiiFromSpanData;\n//# sourceMappingURL=piiFiltering.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvbWNwLXNlcnZlci9waWlGaWx0ZXJpbmcuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsbUJBQW1CLG1CQUFPLENBQUMsaUpBQWlCOztBQUU1QztBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsd0JBQXdCLGdDQUFnQztBQUN4RDtBQUNBOztBQUVBLHdCQUF3QixrQ0FBa0MseUJBQXlCLG9DQUFvQztBQUN2SDtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEtBQUs7QUFDTCxPQUFPO0FBQ1A7QUFDQTs7QUFFQSxnQ0FBZ0M7QUFDaEMiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvbWNwLXNlcnZlci9waWlGaWx0ZXJpbmcuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGF0dHJpYnV0ZXMgPSByZXF1aXJlKCcuL2F0dHJpYnV0ZXMuanMnKTtcblxuLyoqXG4gKiBQSUkgYXR0cmlidXRlcyB0aGF0IHNob3VsZCBiZSByZW1vdmVkIHdoZW4gc2VuZERlZmF1bHRQaWkgaXMgZmFsc2VcbiAqIEBpbnRlcm5hbFxuICovXG5jb25zdCBQSUlfQVRUUklCVVRFUyA9IG5ldyBTZXQoW1xuICBhdHRyaWJ1dGVzLkNMSUVOVF9BRERSRVNTX0FUVFJJQlVURSxcbiAgYXR0cmlidXRlcy5DTElFTlRfUE9SVF9BVFRSSUJVVEUsXG4gIGF0dHJpYnV0ZXMuTUNQX0xPR0dJTkdfTUVTU0FHRV9BVFRSSUJVVEUsXG4gIGF0dHJpYnV0ZXMuTUNQX1BST01QVF9SRVNVTFRfREVTQ1JJUFRJT05fQVRUUklCVVRFLFxuICBhdHRyaWJ1dGVzLk1DUF9QUk9NUFRfUkVTVUxUX01FU1NBR0VfQ09OVEVOVF9BVFRSSUJVVEUsXG4gIGF0dHJpYnV0ZXMuTUNQX1JFU09VUkNFX1VSSV9BVFRSSUJVVEUsXG4gIGF0dHJpYnV0ZXMuTUNQX1RPT0xfUkVTVUxUX0NPTlRFTlRfQVRUUklCVVRFLFxuXSk7XG5cbi8qKlxuICogQ2hlY2tzIGlmIGFuIGF0dHJpYnV0ZSBrZXkgc2hvdWxkIGJlIGNvbnNpZGVyZWQgUElJLlxuICpcbiAqIFJldHVybnMgdHJ1ZSBmb3I6XG4gKiAtIEV4cGxpY2l0IFBJSSBhdHRyaWJ1dGVzIChjbGllbnQuYWRkcmVzcywgY2xpZW50LnBvcnQsIG1jcC5sb2dnaW5nLm1lc3NhZ2UsIGV0Yy4pXG4gKiAtIEFsbCByZXF1ZXN0IGFyZ3VtZW50cyAobWNwLnJlcXVlc3QuYXJndW1lbnQuKilcbiAqIC0gVG9vbCBhbmQgcHJvbXB0IHJlc3VsdCBjb250ZW50IChtY3AudG9vbC5yZXN1bHQuKiwgbWNwLnByb21wdC5yZXN1bHQuKikgZXhjZXB0IG1ldGFkYXRhXG4gKlxuICogUHJlc2VydmVzIG1ldGFkYXRhIGF0dHJpYnV0ZXMgZW5kaW5nIHdpdGggX2NvdW50LCBfZXJyb3IsIG9yIC5pc19lcnJvciBhcyB0aGV5IGRvbid0IGNvbnRhaW4gc2Vuc2l0aXZlIGRhdGEuXG4gKlxuICogQHBhcmFtIGtleSAtIEF0dHJpYnV0ZSBrZXkgdG8gZXZhbHVhdGVcbiAqIEByZXR1cm5zIHRydWUgaWYgdGhlIGF0dHJpYnV0ZSBzaG91bGQgYmUgZmlsdGVyZWQgb3V0IChpcyBQSUkpLCBmYWxzZSBpZiBpdCBzaG91bGQgYmUgcHJlc2VydmVkXG4gKiBAaW50ZXJuYWxcbiAqL1xuZnVuY3Rpb24gaXNQaWlBdHRyaWJ1dGUoa2V5KSB7XG4gIGlmIChQSUlfQVRUUklCVVRFUy5oYXMoa2V5KSkge1xuICAgIHJldHVybiB0cnVlO1xuICB9XG5cbiAgaWYgKGtleS5zdGFydHNXaXRoKGAke2F0dHJpYnV0ZXMuTUNQX1JFUVVFU1RfQVJHVU1FTlR9LmApKSB7XG4gICAgcmV0dXJuIHRydWU7XG4gIH1cblxuICBpZiAoa2V5LnN0YXJ0c1dpdGgoYCR7YXR0cmlidXRlcy5NQ1BfVE9PTF9SRVNVTFRfUFJFRklYfS5gKSB8fCBrZXkuc3RhcnRzV2l0aChgJHthdHRyaWJ1dGVzLk1DUF9QUk9NUFRfUkVTVUxUX1BSRUZJWH0uYCkpIHtcbiAgICBpZiAoIWtleS5lbmRzV2l0aCgnX2NvdW50JykgJiYgIWtleS5lbmRzV2l0aCgnX2Vycm9yJykgJiYgIWtleS5lbmRzV2l0aCgnLmlzX2Vycm9yJykpIHtcbiAgICAgIHJldHVybiB0cnVlO1xuICAgIH1cbiAgfVxuXG4gIHJldHVybiBmYWxzZTtcbn1cblxuLyoqXG4gKiBSZW1vdmVzIFBJSSBhdHRyaWJ1dGVzIGZyb20gc3BhbiBkYXRhIHdoZW4gc2VuZERlZmF1bHRQaWkgaXMgZmFsc2VcbiAqIEBwYXJhbSBzcGFuRGF0YSAtIFJhdyBzcGFuIGF0dHJpYnV0ZXNcbiAqIEBwYXJhbSBzZW5kRGVmYXVsdFBpaSAtIFdoZXRoZXIgdG8gaW5jbHVkZSBQSUkgZGF0YVxuICogQHJldHVybnMgRmlsdGVyZWQgc3BhbiBhdHRyaWJ1dGVzXG4gKi9cbmZ1bmN0aW9uIGZpbHRlck1jcFBpaUZyb21TcGFuRGF0YShcbiAgc3BhbkRhdGEsXG4gIHNlbmREZWZhdWx0UGlpLFxuKSB7XG4gIGlmIChzZW5kRGVmYXVsdFBpaSkge1xuICAgIHJldHVybiBzcGFuRGF0YSA7XG4gIH1cblxuICByZXR1cm4gT2JqZWN0LmVudHJpZXMoc3BhbkRhdGEpLnJlZHVjZShcbiAgICAoYWNjLCBba2V5LCB2YWx1ZV0pID0+IHtcbiAgICAgIGlmICghaXNQaWlBdHRyaWJ1dGUoa2V5KSkge1xuICAgICAgICBhY2Nba2V5XSA9IHZhbHVlIDtcbiAgICAgIH1cbiAgICAgIHJldHVybiBhY2M7XG4gICAgfSxcbiAgICB7fSAsXG4gICk7XG59XG5cbmV4cG9ydHMuZmlsdGVyTWNwUGlpRnJvbVNwYW5EYXRhID0gZmlsdGVyTWNwUGlpRnJvbVNwYW5EYXRhO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9cGlpRmlsdGVyaW5nLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/piiFiltering.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/resultExtraction.js":
/*!********************************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/resultExtraction.js ***!
  \********************************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst attributes = __webpack_require__(/*! ./attributes.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/attributes.js\");\nconst validation = __webpack_require__(/*! ./validation.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/validation.js\");\n\n/**\n * Result extraction functions for MCP server instrumentation\n *\n * Handles extraction of attributes from tool and prompt execution results.\n */\n\n\n/**\n * Build attributes for tool result content items\n * @param content - Array of content items from tool result\n * @returns Attributes extracted from each content item including type, text, mime type, URI, and resource info\n */\nfunction buildAllContentItemAttributes(content) {\n  const attributes$1 = {\n    [attributes.MCP_TOOL_RESULT_CONTENT_COUNT_ATTRIBUTE]: content.length,\n  };\n\n  for (const [i, item] of content.entries()) {\n    if (!validation.isValidContentItem(item)) {\n      continue;\n    }\n\n    const prefix = content.length === 1 ? 'mcp.tool.result' : `mcp.tool.result.${i}`;\n\n    const safeSet = (key, value) => {\n      if (typeof value === 'string') {\n        attributes$1[`${prefix}.${key}`] = value;\n      }\n    };\n\n    safeSet('content_type', item.type);\n    safeSet('mime_type', item.mimeType);\n    safeSet('uri', item.uri);\n    safeSet('name', item.name);\n\n    if (typeof item.text === 'string') {\n      attributes$1[`${prefix}.content`] = item.text;\n    }\n\n    if (typeof item.data === 'string') {\n      attributes$1[`${prefix}.data_size`] = item.data.length;\n    }\n\n    const resource = item.resource;\n    if (validation.isValidContentItem(resource)) {\n      safeSet('resource_uri', resource.uri);\n      safeSet('resource_mime_type', resource.mimeType);\n    }\n  }\n\n  return attributes$1;\n}\n\n/**\n * Extract tool result attributes for span instrumentation\n * @param result - Tool execution result\n * @returns Attributes extracted from tool result content\n */\nfunction extractToolResultAttributes(result) {\n  if (!validation.isValidContentItem(result)) {\n    return {};\n  }\n\n  const attributes$1 = Array.isArray(result.content) ? buildAllContentItemAttributes(result.content) : {};\n\n  if (typeof result.isError === 'boolean') {\n    attributes$1[attributes.MCP_TOOL_RESULT_IS_ERROR_ATTRIBUTE] = result.isError;\n  }\n\n  return attributes$1;\n}\n\n/**\n * Extract prompt result attributes for span instrumentation\n * @param result - Prompt execution result\n * @returns Attributes extracted from prompt result\n */\nfunction extractPromptResultAttributes(result) {\n  const attributes$1 = {};\n  if (!validation.isValidContentItem(result)) {\n    return attributes$1;\n  }\n\n  if (typeof result.description === 'string') {\n    attributes$1[attributes.MCP_PROMPT_RESULT_DESCRIPTION_ATTRIBUTE] = result.description;\n  }\n\n  if (Array.isArray(result.messages)) {\n    attributes$1[attributes.MCP_PROMPT_RESULT_MESSAGE_COUNT_ATTRIBUTE] = result.messages.length;\n\n    const messages = result.messages;\n    for (const [i, message] of messages.entries()) {\n      if (!validation.isValidContentItem(message)) {\n        continue;\n      }\n\n      const prefix = messages.length === 1 ? 'mcp.prompt.result' : `mcp.prompt.result.${i}`;\n\n      const safeSet = (key, value) => {\n        if (typeof value === 'string') {\n          const attrName = messages.length === 1 ? `${prefix}.message_${key}` : `${prefix}.${key}`;\n          attributes$1[attrName] = value;\n        }\n      };\n\n      safeSet('role', message.role);\n\n      if (validation.isValidContentItem(message.content)) {\n        const content = message.content;\n        if (typeof content.text === 'string') {\n          const attrName = messages.length === 1 ? `${prefix}.message_content` : `${prefix}.content`;\n          attributes$1[attrName] = content.text;\n        }\n      }\n    }\n  }\n\n  return attributes$1;\n}\n\nexports.extractPromptResultAttributes = extractPromptResultAttributes;\nexports.extractToolResultAttributes = extractToolResultAttributes;\n//# sourceMappingURL=resultExtraction.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvbWNwLXNlcnZlci9yZXN1bHRFeHRyYWN0aW9uLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLG1CQUFtQixtQkFBTyxDQUFDLGlKQUFpQjtBQUM1QyxtQkFBbUIsbUJBQU8sQ0FBQyxpSkFBaUI7O0FBRTVDO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7OztBQUdBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSxpRkFBaUYsRUFBRTs7QUFFbkY7QUFDQTtBQUNBLHdCQUF3QixPQUFPLEdBQUcsSUFBSTtBQUN0QztBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0Esc0JBQXNCLE9BQU87QUFDN0I7O0FBRUE7QUFDQSxzQkFBc0IsT0FBTztBQUM3Qjs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSx3RkFBd0YsRUFBRTs7QUFFMUY7QUFDQTtBQUNBLHNEQUFzRCxPQUFPLFdBQVcsSUFBSSxPQUFPLE9BQU8sR0FBRyxJQUFJO0FBQ2pHO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQSxzREFBc0QsT0FBTyx1QkFBdUIsT0FBTztBQUMzRjtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUEscUNBQXFDO0FBQ3JDLG1DQUFtQztBQUNuQyIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL2ludGVncmF0aW9ucy9tY3Atc2VydmVyL3Jlc3VsdEV4dHJhY3Rpb24uanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGF0dHJpYnV0ZXMgPSByZXF1aXJlKCcuL2F0dHJpYnV0ZXMuanMnKTtcbmNvbnN0IHZhbGlkYXRpb24gPSByZXF1aXJlKCcuL3ZhbGlkYXRpb24uanMnKTtcblxuLyoqXG4gKiBSZXN1bHQgZXh0cmFjdGlvbiBmdW5jdGlvbnMgZm9yIE1DUCBzZXJ2ZXIgaW5zdHJ1bWVudGF0aW9uXG4gKlxuICogSGFuZGxlcyBleHRyYWN0aW9uIG9mIGF0dHJpYnV0ZXMgZnJvbSB0b29sIGFuZCBwcm9tcHQgZXhlY3V0aW9uIHJlc3VsdHMuXG4gKi9cblxuXG4vKipcbiAqIEJ1aWxkIGF0dHJpYnV0ZXMgZm9yIHRvb2wgcmVzdWx0IGNvbnRlbnQgaXRlbXNcbiAqIEBwYXJhbSBjb250ZW50IC0gQXJyYXkgb2YgY29udGVudCBpdGVtcyBmcm9tIHRvb2wgcmVzdWx0XG4gKiBAcmV0dXJucyBBdHRyaWJ1dGVzIGV4dHJhY3RlZCBmcm9tIGVhY2ggY29udGVudCBpdGVtIGluY2x1ZGluZyB0eXBlLCB0ZXh0LCBtaW1lIHR5cGUsIFVSSSwgYW5kIHJlc291cmNlIGluZm9cbiAqL1xuZnVuY3Rpb24gYnVpbGRBbGxDb250ZW50SXRlbUF0dHJpYnV0ZXMoY29udGVudCkge1xuICBjb25zdCBhdHRyaWJ1dGVzJDEgPSB7XG4gICAgW2F0dHJpYnV0ZXMuTUNQX1RPT0xfUkVTVUxUX0NPTlRFTlRfQ09VTlRfQVRUUklCVVRFXTogY29udGVudC5sZW5ndGgsXG4gIH07XG5cbiAgZm9yIChjb25zdCBbaSwgaXRlbV0gb2YgY29udGVudC5lbnRyaWVzKCkpIHtcbiAgICBpZiAoIXZhbGlkYXRpb24uaXNWYWxpZENvbnRlbnRJdGVtKGl0ZW0pKSB7XG4gICAgICBjb250aW51ZTtcbiAgICB9XG5cbiAgICBjb25zdCBwcmVmaXggPSBjb250ZW50Lmxlbmd0aCA9PT0gMSA/ICdtY3AudG9vbC5yZXN1bHQnIDogYG1jcC50b29sLnJlc3VsdC4ke2l9YDtcblxuICAgIGNvbnN0IHNhZmVTZXQgPSAoa2V5LCB2YWx1ZSkgPT4ge1xuICAgICAgaWYgKHR5cGVvZiB2YWx1ZSA9PT0gJ3N0cmluZycpIHtcbiAgICAgICAgYXR0cmlidXRlcyQxW2Ake3ByZWZpeH0uJHtrZXl9YF0gPSB2YWx1ZTtcbiAgICAgIH1cbiAgICB9O1xuXG4gICAgc2FmZVNldCgnY29udGVudF90eXBlJywgaXRlbS50eXBlKTtcbiAgICBzYWZlU2V0KCdtaW1lX3R5cGUnLCBpdGVtLm1pbWVUeXBlKTtcbiAgICBzYWZlU2V0KCd1cmknLCBpdGVtLnVyaSk7XG4gICAgc2FmZVNldCgnbmFtZScsIGl0ZW0ubmFtZSk7XG5cbiAgICBpZiAodHlwZW9mIGl0ZW0udGV4dCA9PT0gJ3N0cmluZycpIHtcbiAgICAgIGF0dHJpYnV0ZXMkMVtgJHtwcmVmaXh9LmNvbnRlbnRgXSA9IGl0ZW0udGV4dDtcbiAgICB9XG5cbiAgICBpZiAodHlwZW9mIGl0ZW0uZGF0YSA9PT0gJ3N0cmluZycpIHtcbiAgICAgIGF0dHJpYnV0ZXMkMVtgJHtwcmVmaXh9LmRhdGFfc2l6ZWBdID0gaXRlbS5kYXRhLmxlbmd0aDtcbiAgICB9XG5cbiAgICBjb25zdCByZXNvdXJjZSA9IGl0ZW0ucmVzb3VyY2U7XG4gICAgaWYgKHZhbGlkYXRpb24uaXNWYWxpZENvbnRlbnRJdGVtKHJlc291cmNlKSkge1xuICAgICAgc2FmZVNldCgncmVzb3VyY2VfdXJpJywgcmVzb3VyY2UudXJpKTtcbiAgICAgIHNhZmVTZXQoJ3Jlc291cmNlX21pbWVfdHlwZScsIHJlc291cmNlLm1pbWVUeXBlKTtcbiAgICB9XG4gIH1cblxuICByZXR1cm4gYXR0cmlidXRlcyQxO1xufVxuXG4vKipcbiAqIEV4dHJhY3QgdG9vbCByZXN1bHQgYXR0cmlidXRlcyBmb3Igc3BhbiBpbnN0cnVtZW50YXRpb25cbiAqIEBwYXJhbSByZXN1bHQgLSBUb29sIGV4ZWN1dGlvbiByZXN1bHRcbiAqIEByZXR1cm5zIEF0dHJpYnV0ZXMgZXh0cmFjdGVkIGZyb20gdG9vbCByZXN1bHQgY29udGVudFxuICovXG5mdW5jdGlvbiBleHRyYWN0VG9vbFJlc3VsdEF0dHJpYnV0ZXMocmVzdWx0KSB7XG4gIGlmICghdmFsaWRhdGlvbi5pc1ZhbGlkQ29udGVudEl0ZW0ocmVzdWx0KSkge1xuICAgIHJldHVybiB7fTtcbiAgfVxuXG4gIGNvbnN0IGF0dHJpYnV0ZXMkMSA9IEFycmF5LmlzQXJyYXkocmVzdWx0LmNvbnRlbnQpID8gYnVpbGRBbGxDb250ZW50SXRlbUF0dHJpYnV0ZXMocmVzdWx0LmNvbnRlbnQpIDoge307XG5cbiAgaWYgKHR5cGVvZiByZXN1bHQuaXNFcnJvciA9PT0gJ2Jvb2xlYW4nKSB7XG4gICAgYXR0cmlidXRlcyQxW2F0dHJpYnV0ZXMuTUNQX1RPT0xfUkVTVUxUX0lTX0VSUk9SX0FUVFJJQlVURV0gPSByZXN1bHQuaXNFcnJvcjtcbiAgfVxuXG4gIHJldHVybiBhdHRyaWJ1dGVzJDE7XG59XG5cbi8qKlxuICogRXh0cmFjdCBwcm9tcHQgcmVzdWx0IGF0dHJpYnV0ZXMgZm9yIHNwYW4gaW5zdHJ1bWVudGF0aW9uXG4gKiBAcGFyYW0gcmVzdWx0IC0gUHJvbXB0IGV4ZWN1dGlvbiByZXN1bHRcbiAqIEByZXR1cm5zIEF0dHJpYnV0ZXMgZXh0cmFjdGVkIGZyb20gcHJvbXB0IHJlc3VsdFxuICovXG5mdW5jdGlvbiBleHRyYWN0UHJvbXB0UmVzdWx0QXR0cmlidXRlcyhyZXN1bHQpIHtcbiAgY29uc3QgYXR0cmlidXRlcyQxID0ge307XG4gIGlmICghdmFsaWRhdGlvbi5pc1ZhbGlkQ29udGVudEl0ZW0ocmVzdWx0KSkge1xuICAgIHJldHVybiBhdHRyaWJ1dGVzJDE7XG4gIH1cblxuICBpZiAodHlwZW9mIHJlc3VsdC5kZXNjcmlwdGlvbiA9PT0gJ3N0cmluZycpIHtcbiAgICBhdHRyaWJ1dGVzJDFbYXR0cmlidXRlcy5NQ1BfUFJPTVBUX1JFU1VMVF9ERVNDUklQVElPTl9BVFRSSUJVVEVdID0gcmVzdWx0LmRlc2NyaXB0aW9uO1xuICB9XG5cbiAgaWYgKEFycmF5LmlzQXJyYXkocmVzdWx0Lm1lc3NhZ2VzKSkge1xuICAgIGF0dHJpYnV0ZXMkMVthdHRyaWJ1dGVzLk1DUF9QUk9NUFRfUkVTVUxUX01FU1NBR0VfQ09VTlRfQVRUUklCVVRFXSA9IHJlc3VsdC5tZXNzYWdlcy5sZW5ndGg7XG5cbiAgICBjb25zdCBtZXNzYWdlcyA9IHJlc3VsdC5tZXNzYWdlcztcbiAgICBmb3IgKGNvbnN0IFtpLCBtZXNzYWdlXSBvZiBtZXNzYWdlcy5lbnRyaWVzKCkpIHtcbiAgICAgIGlmICghdmFsaWRhdGlvbi5pc1ZhbGlkQ29udGVudEl0ZW0obWVzc2FnZSkpIHtcbiAgICAgICAgY29udGludWU7XG4gICAgICB9XG5cbiAgICAgIGNvbnN0IHByZWZpeCA9IG1lc3NhZ2VzLmxlbmd0aCA9PT0gMSA/ICdtY3AucHJvbXB0LnJlc3VsdCcgOiBgbWNwLnByb21wdC5yZXN1bHQuJHtpfWA7XG5cbiAgICAgIGNvbnN0IHNhZmVTZXQgPSAoa2V5LCB2YWx1ZSkgPT4ge1xuICAgICAgICBpZiAodHlwZW9mIHZhbHVlID09PSAnc3RyaW5nJykge1xuICAgICAgICAgIGNvbnN0IGF0dHJOYW1lID0gbWVzc2FnZXMubGVuZ3RoID09PSAxID8gYCR7cHJlZml4fS5tZXNzYWdlXyR7a2V5fWAgOiBgJHtwcmVmaXh9LiR7a2V5fWA7XG4gICAgICAgICAgYXR0cmlidXRlcyQxW2F0dHJOYW1lXSA9IHZhbHVlO1xuICAgICAgICB9XG4gICAgICB9O1xuXG4gICAgICBzYWZlU2V0KCdyb2xlJywgbWVzc2FnZS5yb2xlKTtcblxuICAgICAgaWYgKHZhbGlkYXRpb24uaXNWYWxpZENvbnRlbnRJdGVtKG1lc3NhZ2UuY29udGVudCkpIHtcbiAgICAgICAgY29uc3QgY29udGVudCA9IG1lc3NhZ2UuY29udGVudDtcbiAgICAgICAgaWYgKHR5cGVvZiBjb250ZW50LnRleHQgPT09ICdzdHJpbmcnKSB7XG4gICAgICAgICAgY29uc3QgYXR0ck5hbWUgPSBtZXNzYWdlcy5sZW5ndGggPT09IDEgPyBgJHtwcmVmaXh9Lm1lc3NhZ2VfY29udGVudGAgOiBgJHtwcmVmaXh9LmNvbnRlbnRgO1xuICAgICAgICAgIGF0dHJpYnV0ZXMkMVthdHRyTmFtZV0gPSBjb250ZW50LnRleHQ7XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9XG4gIH1cblxuICByZXR1cm4gYXR0cmlidXRlcyQxO1xufVxuXG5leHBvcnRzLmV4dHJhY3RQcm9tcHRSZXN1bHRBdHRyaWJ1dGVzID0gZXh0cmFjdFByb21wdFJlc3VsdEF0dHJpYnV0ZXM7XG5leHBvcnRzLmV4dHJhY3RUb29sUmVzdWx0QXR0cmlidXRlcyA9IGV4dHJhY3RUb29sUmVzdWx0QXR0cmlidXRlcztcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPXJlc3VsdEV4dHJhY3Rpb24uanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/resultExtraction.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/sessionExtraction.js":
/*!*********************************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/sessionExtraction.js ***!
  \*********************************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst attributes = __webpack_require__(/*! ./attributes.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/attributes.js\");\nconst sessionManagement = __webpack_require__(/*! ./sessionManagement.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/sessionManagement.js\");\nconst validation = __webpack_require__(/*! ./validation.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/validation.js\");\n\n/**\n * Session and party info extraction functions for MCP server instrumentation\n *\n * Handles extraction of client/server info and session data from MCP messages.\n */\n\n\n/**\n * Extracts and validates PartyInfo from an unknown object\n * @param obj - Unknown object that might contain party info\n * @returns Validated PartyInfo object with only string properties\n */\nfunction extractPartyInfo(obj) {\n  const partyInfo = {};\n\n  if (validation.isValidContentItem(obj)) {\n    if (typeof obj.name === 'string') {\n      partyInfo.name = obj.name;\n    }\n    if (typeof obj.title === 'string') {\n      partyInfo.title = obj.title;\n    }\n    if (typeof obj.version === 'string') {\n      partyInfo.version = obj.version;\n    }\n  }\n\n  return partyInfo;\n}\n\n/**\n * Extracts session data from \"initialize\" requests\n * @param request - JSON-RPC \"initialize\" request containing client info and protocol version\n * @returns Session data extracted from request parameters including protocol version and client info\n */\nfunction extractSessionDataFromInitializeRequest(request) {\n  const sessionData = {};\n  if (validation.isValidContentItem(request.params)) {\n    if (typeof request.params.protocolVersion === 'string') {\n      sessionData.protocolVersion = request.params.protocolVersion;\n    }\n    if (request.params.clientInfo) {\n      sessionData.clientInfo = extractPartyInfo(request.params.clientInfo);\n    }\n  }\n  return sessionData;\n}\n\n/**\n * Extracts session data from \"initialize\" response\n * @param result - \"initialize\" response result containing server info and protocol version\n * @returns Partial session data extracted from response including protocol version and server info\n */\nfunction extractSessionDataFromInitializeResponse(result) {\n  const sessionData = {};\n  if (validation.isValidContentItem(result)) {\n    if (typeof result.protocolVersion === 'string') {\n      sessionData.protocolVersion = result.protocolVersion;\n    }\n    if (result.serverInfo) {\n      sessionData.serverInfo = extractPartyInfo(result.serverInfo);\n    }\n  }\n  return sessionData;\n}\n\n/**\n * Build client attributes from stored client info\n * @param transport - MCP transport instance\n * @returns Client attributes for span instrumentation\n */\nfunction getClientAttributes(transport) {\n  const clientInfo = sessionManagement.getClientInfoForTransport(transport);\n  const attributes = {};\n\n  if (clientInfo?.name) {\n    attributes['mcp.client.name'] = clientInfo.name;\n  }\n  if (clientInfo?.title) {\n    attributes['mcp.client.title'] = clientInfo.title;\n  }\n  if (clientInfo?.version) {\n    attributes['mcp.client.version'] = clientInfo.version;\n  }\n\n  return attributes;\n}\n\n/**\n * Build server attributes from stored server info\n * @param transport - MCP transport instance\n * @returns Server attributes for span instrumentation\n */\nfunction getServerAttributes(transport) {\n  const serverInfo = sessionManagement.getSessionDataForTransport(transport)?.serverInfo;\n  const attributes$1 = {};\n\n  if (serverInfo?.name) {\n    attributes$1[attributes.MCP_SERVER_NAME_ATTRIBUTE] = serverInfo.name;\n  }\n  if (serverInfo?.title) {\n    attributes$1[attributes.MCP_SERVER_TITLE_ATTRIBUTE] = serverInfo.title;\n  }\n  if (serverInfo?.version) {\n    attributes$1[attributes.MCP_SERVER_VERSION_ATTRIBUTE] = serverInfo.version;\n  }\n\n  return attributes$1;\n}\n\n/**\n * Extracts client connection info from extra handler data\n * @param extra - Extra handler data containing connection info\n * @returns Client address and port information\n */\nfunction extractClientInfo(extra)\n\n {\n  return {\n    address:\n      extra?.requestInfo?.remoteAddress ||\n      extra?.clientAddress ||\n      extra?.request?.ip ||\n      extra?.request?.connection?.remoteAddress,\n    port: extra?.requestInfo?.remotePort || extra?.clientPort || extra?.request?.connection?.remotePort,\n  };\n}\n\n/**\n * Extracts transport types based on transport constructor name\n * @param transport - MCP transport instance\n * @returns Transport type mapping for span attributes\n */\nfunction getTransportTypes(transport) {\n  const transportName = transport.constructor?.name?.toLowerCase() || '';\n\n  if (transportName.includes('stdio')) {\n    return { mcpTransport: 'stdio', networkTransport: 'pipe' };\n  }\n\n  if (transportName.includes('streamablehttp') || transportName.includes('streamable')) {\n    return { mcpTransport: 'http', networkTransport: 'tcp' };\n  }\n\n  if (transportName.includes('sse')) {\n    return { mcpTransport: 'sse', networkTransport: 'tcp' };\n  }\n\n  return { mcpTransport: 'unknown', networkTransport: 'unknown' };\n}\n\n/**\n * Build transport and network attributes\n * @param transport - MCP transport instance\n * @param extra - Optional extra handler data\n * @returns Transport attributes for span instrumentation\n */\nfunction buildTransportAttributes(\n  transport,\n  extra,\n) {\n  const sessionId = transport.sessionId;\n  const clientInfo = extra ? extractClientInfo(extra) : {};\n  const { mcpTransport, networkTransport } = getTransportTypes(transport);\n  const clientAttributes = getClientAttributes(transport);\n  const serverAttributes = getServerAttributes(transport);\n  const protocolVersion = sessionManagement.getProtocolVersionForTransport(transport);\n\n  const attributes$1 = {\n    ...(sessionId && { [attributes.MCP_SESSION_ID_ATTRIBUTE]: sessionId }),\n    ...(clientInfo.address && { [attributes.CLIENT_ADDRESS_ATTRIBUTE]: clientInfo.address }),\n    ...(clientInfo.port && { [attributes.CLIENT_PORT_ATTRIBUTE]: clientInfo.port }),\n    [attributes.MCP_TRANSPORT_ATTRIBUTE]: mcpTransport,\n    [attributes.NETWORK_TRANSPORT_ATTRIBUTE]: networkTransport,\n    [attributes.NETWORK_PROTOCOL_VERSION_ATTRIBUTE]: '2.0',\n    ...(protocolVersion && { [attributes.MCP_PROTOCOL_VERSION_ATTRIBUTE]: protocolVersion }),\n    ...clientAttributes,\n    ...serverAttributes,\n  };\n\n  return attributes$1;\n}\n\nexports.buildTransportAttributes = buildTransportAttributes;\nexports.extractClientInfo = extractClientInfo;\nexports.extractSessionDataFromInitializeRequest = extractSessionDataFromInitializeRequest;\nexports.extractSessionDataFromInitializeResponse = extractSessionDataFromInitializeResponse;\nexports.getClientAttributes = getClientAttributes;\nexports.getServerAttributes = getServerAttributes;\nexports.getTransportTypes = getTransportTypes;\n//# sourceMappingURL=sessionExtraction.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvbWNwLXNlcnZlci9zZXNzaW9uRXh0cmFjdGlvbi5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxtQkFBbUIsbUJBQU8sQ0FBQyxpSkFBaUI7QUFDNUMsMEJBQTBCLG1CQUFPLENBQUMsK0pBQXdCO0FBQzFELG1CQUFtQixtQkFBTyxDQUFDLGlKQUFpQjs7QUFFNUM7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7O0FBR0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0EsYUFBYTtBQUNiOztBQUVBO0FBQ0EsYUFBYTtBQUNiOztBQUVBO0FBQ0EsYUFBYTtBQUNiOztBQUVBLFdBQVc7QUFDWDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxVQUFVLGlDQUFpQztBQUMzQztBQUNBO0FBQ0E7O0FBRUE7QUFDQSx1QkFBdUIsa0RBQWtEO0FBQ3pFLGdDQUFnQywyREFBMkQ7QUFDM0YsNkJBQTZCLHFEQUFxRDtBQUNsRjtBQUNBO0FBQ0E7QUFDQSw2QkFBNkIsOERBQThEO0FBQzNGO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBLGdDQUFnQztBQUNoQyx5QkFBeUI7QUFDekIsK0NBQStDO0FBQy9DLGdEQUFnRDtBQUNoRCwyQkFBMkI7QUFDM0IsMkJBQTJCO0FBQzNCLHlCQUF5QjtBQUN6QiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL2ludGVncmF0aW9ucy9tY3Atc2VydmVyL3Nlc3Npb25FeHRyYWN0aW9uLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBhdHRyaWJ1dGVzID0gcmVxdWlyZSgnLi9hdHRyaWJ1dGVzLmpzJyk7XG5jb25zdCBzZXNzaW9uTWFuYWdlbWVudCA9IHJlcXVpcmUoJy4vc2Vzc2lvbk1hbmFnZW1lbnQuanMnKTtcbmNvbnN0IHZhbGlkYXRpb24gPSByZXF1aXJlKCcuL3ZhbGlkYXRpb24uanMnKTtcblxuLyoqXG4gKiBTZXNzaW9uIGFuZCBwYXJ0eSBpbmZvIGV4dHJhY3Rpb24gZnVuY3Rpb25zIGZvciBNQ1Agc2VydmVyIGluc3RydW1lbnRhdGlvblxuICpcbiAqIEhhbmRsZXMgZXh0cmFjdGlvbiBvZiBjbGllbnQvc2VydmVyIGluZm8gYW5kIHNlc3Npb24gZGF0YSBmcm9tIE1DUCBtZXNzYWdlcy5cbiAqL1xuXG5cbi8qKlxuICogRXh0cmFjdHMgYW5kIHZhbGlkYXRlcyBQYXJ0eUluZm8gZnJvbSBhbiB1bmtub3duIG9iamVjdFxuICogQHBhcmFtIG9iaiAtIFVua25vd24gb2JqZWN0IHRoYXQgbWlnaHQgY29udGFpbiBwYXJ0eSBpbmZvXG4gKiBAcmV0dXJucyBWYWxpZGF0ZWQgUGFydHlJbmZvIG9iamVjdCB3aXRoIG9ubHkgc3RyaW5nIHByb3BlcnRpZXNcbiAqL1xuZnVuY3Rpb24gZXh0cmFjdFBhcnR5SW5mbyhvYmopIHtcbiAgY29uc3QgcGFydHlJbmZvID0ge307XG5cbiAgaWYgKHZhbGlkYXRpb24uaXNWYWxpZENvbnRlbnRJdGVtKG9iaikpIHtcbiAgICBpZiAodHlwZW9mIG9iai5uYW1lID09PSAnc3RyaW5nJykge1xuICAgICAgcGFydHlJbmZvLm5hbWUgPSBvYmoubmFtZTtcbiAgICB9XG4gICAgaWYgKHR5cGVvZiBvYmoudGl0bGUgPT09ICdzdHJpbmcnKSB7XG4gICAgICBwYXJ0eUluZm8udGl0bGUgPSBvYmoudGl0bGU7XG4gICAgfVxuICAgIGlmICh0eXBlb2Ygb2JqLnZlcnNpb24gPT09ICdzdHJpbmcnKSB7XG4gICAgICBwYXJ0eUluZm8udmVyc2lvbiA9IG9iai52ZXJzaW9uO1xuICAgIH1cbiAgfVxuXG4gIHJldHVybiBwYXJ0eUluZm87XG59XG5cbi8qKlxuICogRXh0cmFjdHMgc2Vzc2lvbiBkYXRhIGZyb20gXCJpbml0aWFsaXplXCIgcmVxdWVzdHNcbiAqIEBwYXJhbSByZXF1ZXN0IC0gSlNPTi1SUEMgXCJpbml0aWFsaXplXCIgcmVxdWVzdCBjb250YWluaW5nIGNsaWVudCBpbmZvIGFuZCBwcm90b2NvbCB2ZXJzaW9uXG4gKiBAcmV0dXJucyBTZXNzaW9uIGRhdGEgZXh0cmFjdGVkIGZyb20gcmVxdWVzdCBwYXJhbWV0ZXJzIGluY2x1ZGluZyBwcm90b2NvbCB2ZXJzaW9uIGFuZCBjbGllbnQgaW5mb1xuICovXG5mdW5jdGlvbiBleHRyYWN0U2Vzc2lvbkRhdGFGcm9tSW5pdGlhbGl6ZVJlcXVlc3QocmVxdWVzdCkge1xuICBjb25zdCBzZXNzaW9uRGF0YSA9IHt9O1xuICBpZiAodmFsaWRhdGlvbi5pc1ZhbGlkQ29udGVudEl0ZW0ocmVxdWVzdC5wYXJhbXMpKSB7XG4gICAgaWYgKHR5cGVvZiByZXF1ZXN0LnBhcmFtcy5wcm90b2NvbFZlcnNpb24gPT09ICdzdHJpbmcnKSB7XG4gICAgICBzZXNzaW9uRGF0YS5wcm90b2NvbFZlcnNpb24gPSByZXF1ZXN0LnBhcmFtcy5wcm90b2NvbFZlcnNpb247XG4gICAgfVxuICAgIGlmIChyZXF1ZXN0LnBhcmFtcy5jbGllbnRJbmZvKSB7XG4gICAgICBzZXNzaW9uRGF0YS5jbGllbnRJbmZvID0gZXh0cmFjdFBhcnR5SW5mbyhyZXF1ZXN0LnBhcmFtcy5jbGllbnRJbmZvKTtcbiAgICB9XG4gIH1cbiAgcmV0dXJuIHNlc3Npb25EYXRhO1xufVxuXG4vKipcbiAqIEV4dHJhY3RzIHNlc3Npb24gZGF0YSBmcm9tIFwiaW5pdGlhbGl6ZVwiIHJlc3BvbnNlXG4gKiBAcGFyYW0gcmVzdWx0IC0gXCJpbml0aWFsaXplXCIgcmVzcG9uc2UgcmVzdWx0IGNvbnRhaW5pbmcgc2VydmVyIGluZm8gYW5kIHByb3RvY29sIHZlcnNpb25cbiAqIEByZXR1cm5zIFBhcnRpYWwgc2Vzc2lvbiBkYXRhIGV4dHJhY3RlZCBmcm9tIHJlc3BvbnNlIGluY2x1ZGluZyBwcm90b2NvbCB2ZXJzaW9uIGFuZCBzZXJ2ZXIgaW5mb1xuICovXG5mdW5jdGlvbiBleHRyYWN0U2Vzc2lvbkRhdGFGcm9tSW5pdGlhbGl6ZVJlc3BvbnNlKHJlc3VsdCkge1xuICBjb25zdCBzZXNzaW9uRGF0YSA9IHt9O1xuICBpZiAodmFsaWRhdGlvbi5pc1ZhbGlkQ29udGVudEl0ZW0ocmVzdWx0KSkge1xuICAgIGlmICh0eXBlb2YgcmVzdWx0LnByb3RvY29sVmVyc2lvbiA9PT0gJ3N0cmluZycpIHtcbiAgICAgIHNlc3Npb25EYXRhLnByb3RvY29sVmVyc2lvbiA9IHJlc3VsdC5wcm90b2NvbFZlcnNpb247XG4gICAgfVxuICAgIGlmIChyZXN1bHQuc2VydmVySW5mbykge1xuICAgICAgc2Vzc2lvbkRhdGEuc2VydmVySW5mbyA9IGV4dHJhY3RQYXJ0eUluZm8ocmVzdWx0LnNlcnZlckluZm8pO1xuICAgIH1cbiAgfVxuICByZXR1cm4gc2Vzc2lvbkRhdGE7XG59XG5cbi8qKlxuICogQnVpbGQgY2xpZW50IGF0dHJpYnV0ZXMgZnJvbSBzdG9yZWQgY2xpZW50IGluZm9cbiAqIEBwYXJhbSB0cmFuc3BvcnQgLSBNQ1AgdHJhbnNwb3J0IGluc3RhbmNlXG4gKiBAcmV0dXJucyBDbGllbnQgYXR0cmlidXRlcyBmb3Igc3BhbiBpbnN0cnVtZW50YXRpb25cbiAqL1xuZnVuY3Rpb24gZ2V0Q2xpZW50QXR0cmlidXRlcyh0cmFuc3BvcnQpIHtcbiAgY29uc3QgY2xpZW50SW5mbyA9IHNlc3Npb25NYW5hZ2VtZW50LmdldENsaWVudEluZm9Gb3JUcmFuc3BvcnQodHJhbnNwb3J0KTtcbiAgY29uc3QgYXR0cmlidXRlcyA9IHt9O1xuXG4gIGlmIChjbGllbnRJbmZvPy5uYW1lKSB7XG4gICAgYXR0cmlidXRlc1snbWNwLmNsaWVudC5uYW1lJ10gPSBjbGllbnRJbmZvLm5hbWU7XG4gIH1cbiAgaWYgKGNsaWVudEluZm8/LnRpdGxlKSB7XG4gICAgYXR0cmlidXRlc1snbWNwLmNsaWVudC50aXRsZSddID0gY2xpZW50SW5mby50aXRsZTtcbiAgfVxuICBpZiAoY2xpZW50SW5mbz8udmVyc2lvbikge1xuICAgIGF0dHJpYnV0ZXNbJ21jcC5jbGllbnQudmVyc2lvbiddID0gY2xpZW50SW5mby52ZXJzaW9uO1xuICB9XG5cbiAgcmV0dXJuIGF0dHJpYnV0ZXM7XG59XG5cbi8qKlxuICogQnVpbGQgc2VydmVyIGF0dHJpYnV0ZXMgZnJvbSBzdG9yZWQgc2VydmVyIGluZm9cbiAqIEBwYXJhbSB0cmFuc3BvcnQgLSBNQ1AgdHJhbnNwb3J0IGluc3RhbmNlXG4gKiBAcmV0dXJucyBTZXJ2ZXIgYXR0cmlidXRlcyBmb3Igc3BhbiBpbnN0cnVtZW50YXRpb25cbiAqL1xuZnVuY3Rpb24gZ2V0U2VydmVyQXR0cmlidXRlcyh0cmFuc3BvcnQpIHtcbiAgY29uc3Qgc2VydmVySW5mbyA9IHNlc3Npb25NYW5hZ2VtZW50LmdldFNlc3Npb25EYXRhRm9yVHJhbnNwb3J0KHRyYW5zcG9ydCk/LnNlcnZlckluZm87XG4gIGNvbnN0IGF0dHJpYnV0ZXMkMSA9IHt9O1xuXG4gIGlmIChzZXJ2ZXJJbmZvPy5uYW1lKSB7XG4gICAgYXR0cmlidXRlcyQxW2F0dHJpYnV0ZXMuTUNQX1NFUlZFUl9OQU1FX0FUVFJJQlVURV0gPSBzZXJ2ZXJJbmZvLm5hbWU7XG4gIH1cbiAgaWYgKHNlcnZlckluZm8/LnRpdGxlKSB7XG4gICAgYXR0cmlidXRlcyQxW2F0dHJpYnV0ZXMuTUNQX1NFUlZFUl9USVRMRV9BVFRSSUJVVEVdID0gc2VydmVySW5mby50aXRsZTtcbiAgfVxuICBpZiAoc2VydmVySW5mbz8udmVyc2lvbikge1xuICAgIGF0dHJpYnV0ZXMkMVthdHRyaWJ1dGVzLk1DUF9TRVJWRVJfVkVSU0lPTl9BVFRSSUJVVEVdID0gc2VydmVySW5mby52ZXJzaW9uO1xuICB9XG5cbiAgcmV0dXJuIGF0dHJpYnV0ZXMkMTtcbn1cblxuLyoqXG4gKiBFeHRyYWN0cyBjbGllbnQgY29ubmVjdGlvbiBpbmZvIGZyb20gZXh0cmEgaGFuZGxlciBkYXRhXG4gKiBAcGFyYW0gZXh0cmEgLSBFeHRyYSBoYW5kbGVyIGRhdGEgY29udGFpbmluZyBjb25uZWN0aW9uIGluZm9cbiAqIEByZXR1cm5zIENsaWVudCBhZGRyZXNzIGFuZCBwb3J0IGluZm9ybWF0aW9uXG4gKi9cbmZ1bmN0aW9uIGV4dHJhY3RDbGllbnRJbmZvKGV4dHJhKVxuXG4ge1xuICByZXR1cm4ge1xuICAgIGFkZHJlc3M6XG4gICAgICBleHRyYT8ucmVxdWVzdEluZm8/LnJlbW90ZUFkZHJlc3MgfHxcbiAgICAgIGV4dHJhPy5jbGllbnRBZGRyZXNzIHx8XG4gICAgICBleHRyYT8ucmVxdWVzdD8uaXAgfHxcbiAgICAgIGV4dHJhPy5yZXF1ZXN0Py5jb25uZWN0aW9uPy5yZW1vdGVBZGRyZXNzLFxuICAgIHBvcnQ6IGV4dHJhPy5yZXF1ZXN0SW5mbz8ucmVtb3RlUG9ydCB8fCBleHRyYT8uY2xpZW50UG9ydCB8fCBleHRyYT8ucmVxdWVzdD8uY29ubmVjdGlvbj8ucmVtb3RlUG9ydCxcbiAgfTtcbn1cblxuLyoqXG4gKiBFeHRyYWN0cyB0cmFuc3BvcnQgdHlwZXMgYmFzZWQgb24gdHJhbnNwb3J0IGNvbnN0cnVjdG9yIG5hbWVcbiAqIEBwYXJhbSB0cmFuc3BvcnQgLSBNQ1AgdHJhbnNwb3J0IGluc3RhbmNlXG4gKiBAcmV0dXJucyBUcmFuc3BvcnQgdHlwZSBtYXBwaW5nIGZvciBzcGFuIGF0dHJpYnV0ZXNcbiAqL1xuZnVuY3Rpb24gZ2V0VHJhbnNwb3J0VHlwZXModHJhbnNwb3J0KSB7XG4gIGNvbnN0IHRyYW5zcG9ydE5hbWUgPSB0cmFuc3BvcnQuY29uc3RydWN0b3I/Lm5hbWU/LnRvTG93ZXJDYXNlKCkgfHwgJyc7XG5cbiAgaWYgKHRyYW5zcG9ydE5hbWUuaW5jbHVkZXMoJ3N0ZGlvJykpIHtcbiAgICByZXR1cm4geyBtY3BUcmFuc3BvcnQ6ICdzdGRpbycsIG5ldHdvcmtUcmFuc3BvcnQ6ICdwaXBlJyB9O1xuICB9XG5cbiAgaWYgKHRyYW5zcG9ydE5hbWUuaW5jbHVkZXMoJ3N0cmVhbWFibGVodHRwJykgfHwgdHJhbnNwb3J0TmFtZS5pbmNsdWRlcygnc3RyZWFtYWJsZScpKSB7XG4gICAgcmV0dXJuIHsgbWNwVHJhbnNwb3J0OiAnaHR0cCcsIG5ldHdvcmtUcmFuc3BvcnQ6ICd0Y3AnIH07XG4gIH1cblxuICBpZiAodHJhbnNwb3J0TmFtZS5pbmNsdWRlcygnc3NlJykpIHtcbiAgICByZXR1cm4geyBtY3BUcmFuc3BvcnQ6ICdzc2UnLCBuZXR3b3JrVHJhbnNwb3J0OiAndGNwJyB9O1xuICB9XG5cbiAgcmV0dXJuIHsgbWNwVHJhbnNwb3J0OiAndW5rbm93bicsIG5ldHdvcmtUcmFuc3BvcnQ6ICd1bmtub3duJyB9O1xufVxuXG4vKipcbiAqIEJ1aWxkIHRyYW5zcG9ydCBhbmQgbmV0d29yayBhdHRyaWJ1dGVzXG4gKiBAcGFyYW0gdHJhbnNwb3J0IC0gTUNQIHRyYW5zcG9ydCBpbnN0YW5jZVxuICogQHBhcmFtIGV4dHJhIC0gT3B0aW9uYWwgZXh0cmEgaGFuZGxlciBkYXRhXG4gKiBAcmV0dXJucyBUcmFuc3BvcnQgYXR0cmlidXRlcyBmb3Igc3BhbiBpbnN0cnVtZW50YXRpb25cbiAqL1xuZnVuY3Rpb24gYnVpbGRUcmFuc3BvcnRBdHRyaWJ1dGVzKFxuICB0cmFuc3BvcnQsXG4gIGV4dHJhLFxuKSB7XG4gIGNvbnN0IHNlc3Npb25JZCA9IHRyYW5zcG9ydC5zZXNzaW9uSWQ7XG4gIGNvbnN0IGNsaWVudEluZm8gPSBleHRyYSA/IGV4dHJhY3RDbGllbnRJbmZvKGV4dHJhKSA6IHt9O1xuICBjb25zdCB7IG1jcFRyYW5zcG9ydCwgbmV0d29ya1RyYW5zcG9ydCB9ID0gZ2V0VHJhbnNwb3J0VHlwZXModHJhbnNwb3J0KTtcbiAgY29uc3QgY2xpZW50QXR0cmlidXRlcyA9IGdldENsaWVudEF0dHJpYnV0ZXModHJhbnNwb3J0KTtcbiAgY29uc3Qgc2VydmVyQXR0cmlidXRlcyA9IGdldFNlcnZlckF0dHJpYnV0ZXModHJhbnNwb3J0KTtcbiAgY29uc3QgcHJvdG9jb2xWZXJzaW9uID0gc2Vzc2lvbk1hbmFnZW1lbnQuZ2V0UHJvdG9jb2xWZXJzaW9uRm9yVHJhbnNwb3J0KHRyYW5zcG9ydCk7XG5cbiAgY29uc3QgYXR0cmlidXRlcyQxID0ge1xuICAgIC4uLihzZXNzaW9uSWQgJiYgeyBbYXR0cmlidXRlcy5NQ1BfU0VTU0lPTl9JRF9BVFRSSUJVVEVdOiBzZXNzaW9uSWQgfSksXG4gICAgLi4uKGNsaWVudEluZm8uYWRkcmVzcyAmJiB7IFthdHRyaWJ1dGVzLkNMSUVOVF9BRERSRVNTX0FUVFJJQlVURV06IGNsaWVudEluZm8uYWRkcmVzcyB9KSxcbiAgICAuLi4oY2xpZW50SW5mby5wb3J0ICYmIHsgW2F0dHJpYnV0ZXMuQ0xJRU5UX1BPUlRfQVRUUklCVVRFXTogY2xpZW50SW5mby5wb3J0IH0pLFxuICAgIFthdHRyaWJ1dGVzLk1DUF9UUkFOU1BPUlRfQVRUUklCVVRFXTogbWNwVHJhbnNwb3J0LFxuICAgIFthdHRyaWJ1dGVzLk5FVFdPUktfVFJBTlNQT1JUX0FUVFJJQlVURV06IG5ldHdvcmtUcmFuc3BvcnQsXG4gICAgW2F0dHJpYnV0ZXMuTkVUV09SS19QUk9UT0NPTF9WRVJTSU9OX0FUVFJJQlVURV06ICcyLjAnLFxuICAgIC4uLihwcm90b2NvbFZlcnNpb24gJiYgeyBbYXR0cmlidXRlcy5NQ1BfUFJPVE9DT0xfVkVSU0lPTl9BVFRSSUJVVEVdOiBwcm90b2NvbFZlcnNpb24gfSksXG4gICAgLi4uY2xpZW50QXR0cmlidXRlcyxcbiAgICAuLi5zZXJ2ZXJBdHRyaWJ1dGVzLFxuICB9O1xuXG4gIHJldHVybiBhdHRyaWJ1dGVzJDE7XG59XG5cbmV4cG9ydHMuYnVpbGRUcmFuc3BvcnRBdHRyaWJ1dGVzID0gYnVpbGRUcmFuc3BvcnRBdHRyaWJ1dGVzO1xuZXhwb3J0cy5leHRyYWN0Q2xpZW50SW5mbyA9IGV4dHJhY3RDbGllbnRJbmZvO1xuZXhwb3J0cy5leHRyYWN0U2Vzc2lvbkRhdGFGcm9tSW5pdGlhbGl6ZVJlcXVlc3QgPSBleHRyYWN0U2Vzc2lvbkRhdGFGcm9tSW5pdGlhbGl6ZVJlcXVlc3Q7XG5leHBvcnRzLmV4dHJhY3RTZXNzaW9uRGF0YUZyb21Jbml0aWFsaXplUmVzcG9uc2UgPSBleHRyYWN0U2Vzc2lvbkRhdGFGcm9tSW5pdGlhbGl6ZVJlc3BvbnNlO1xuZXhwb3J0cy5nZXRDbGllbnRBdHRyaWJ1dGVzID0gZ2V0Q2xpZW50QXR0cmlidXRlcztcbmV4cG9ydHMuZ2V0U2VydmVyQXR0cmlidXRlcyA9IGdldFNlcnZlckF0dHJpYnV0ZXM7XG5leHBvcnRzLmdldFRyYW5zcG9ydFR5cGVzID0gZ2V0VHJhbnNwb3J0VHlwZXM7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1zZXNzaW9uRXh0cmFjdGlvbi5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/sessionExtraction.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/sessionManagement.js":
/*!*********************************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/sessionManagement.js ***!
  \*********************************************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n/**\n * Transport-scoped session data storage (only for transports with sessionId)\n * @internal Maps transport instances to session-level data\n */\nconst transportToSessionData = new WeakMap();\n\n/**\n * Stores session data for a transport with sessionId\n * @param transport - MCP transport instance\n * @param sessionData - Session data to store\n */\nfunction storeSessionDataForTransport(transport, sessionData) {\n  if (transport.sessionId) {\n    transportToSessionData.set(transport, sessionData);\n  }\n}\n\n/**\n * Updates session data for a transport with sessionId (merges with existing data)\n * @param transport - MCP transport instance\n * @param partialSessionData - Partial session data to merge with existing data\n */\nfunction updateSessionDataForTransport(transport, partialSessionData) {\n  if (transport.sessionId) {\n    const existingData = transportToSessionData.get(transport) || {};\n    transportToSessionData.set(transport, { ...existingData, ...partialSessionData });\n  }\n}\n\n/**\n * Retrieves client information for a transport\n * @param transport - MCP transport instance\n * @returns Client information if available\n */\nfunction getClientInfoForTransport(transport) {\n  return transportToSessionData.get(transport)?.clientInfo;\n}\n\n/**\n * Retrieves protocol version for a transport\n * @param transport - MCP transport instance\n * @returns Protocol version if available\n */\nfunction getProtocolVersionForTransport(transport) {\n  return transportToSessionData.get(transport)?.protocolVersion;\n}\n\n/**\n * Retrieves full session data for a transport\n * @param transport - MCP transport instance\n * @returns Complete session data if available\n */\nfunction getSessionDataForTransport(transport) {\n  return transportToSessionData.get(transport);\n}\n\n/**\n * Cleans up session data for a specific transport (when that transport closes)\n * @param transport - MCP transport instance\n */\nfunction cleanupSessionDataForTransport(transport) {\n  transportToSessionData.delete(transport);\n}\n\nexports.cleanupSessionDataForTransport = cleanupSessionDataForTransport;\nexports.getClientInfoForTransport = getClientInfoForTransport;\nexports.getProtocolVersionForTransport = getProtocolVersionForTransport;\nexports.getSessionDataForTransport = getSessionDataForTransport;\nexports.storeSessionDataForTransport = storeSessionDataForTransport;\nexports.updateSessionDataForTransport = updateSessionDataForTransport;\n//# sourceMappingURL=sessionManagement.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvbWNwLXNlcnZlci9zZXNzaW9uTWFuYWdlbWVudC5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSw0Q0FBNEMsd0NBQXdDO0FBQ3BGO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsc0NBQXNDO0FBQ3RDLGlDQUFpQztBQUNqQyxzQ0FBc0M7QUFDdEMsa0NBQWtDO0FBQ2xDLG9DQUFvQztBQUNwQyxxQ0FBcUM7QUFDckMiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvbWNwLXNlcnZlci9zZXNzaW9uTWFuYWdlbWVudC5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuLyoqXG4gKiBUcmFuc3BvcnQtc2NvcGVkIHNlc3Npb24gZGF0YSBzdG9yYWdlIChvbmx5IGZvciB0cmFuc3BvcnRzIHdpdGggc2Vzc2lvbklkKVxuICogQGludGVybmFsIE1hcHMgdHJhbnNwb3J0IGluc3RhbmNlcyB0byBzZXNzaW9uLWxldmVsIGRhdGFcbiAqL1xuY29uc3QgdHJhbnNwb3J0VG9TZXNzaW9uRGF0YSA9IG5ldyBXZWFrTWFwKCk7XG5cbi8qKlxuICogU3RvcmVzIHNlc3Npb24gZGF0YSBmb3IgYSB0cmFuc3BvcnQgd2l0aCBzZXNzaW9uSWRcbiAqIEBwYXJhbSB0cmFuc3BvcnQgLSBNQ1AgdHJhbnNwb3J0IGluc3RhbmNlXG4gKiBAcGFyYW0gc2Vzc2lvbkRhdGEgLSBTZXNzaW9uIGRhdGEgdG8gc3RvcmVcbiAqL1xuZnVuY3Rpb24gc3RvcmVTZXNzaW9uRGF0YUZvclRyYW5zcG9ydCh0cmFuc3BvcnQsIHNlc3Npb25EYXRhKSB7XG4gIGlmICh0cmFuc3BvcnQuc2Vzc2lvbklkKSB7XG4gICAgdHJhbnNwb3J0VG9TZXNzaW9uRGF0YS5zZXQodHJhbnNwb3J0LCBzZXNzaW9uRGF0YSk7XG4gIH1cbn1cblxuLyoqXG4gKiBVcGRhdGVzIHNlc3Npb24gZGF0YSBmb3IgYSB0cmFuc3BvcnQgd2l0aCBzZXNzaW9uSWQgKG1lcmdlcyB3aXRoIGV4aXN0aW5nIGRhdGEpXG4gKiBAcGFyYW0gdHJhbnNwb3J0IC0gTUNQIHRyYW5zcG9ydCBpbnN0YW5jZVxuICogQHBhcmFtIHBhcnRpYWxTZXNzaW9uRGF0YSAtIFBhcnRpYWwgc2Vzc2lvbiBkYXRhIHRvIG1lcmdlIHdpdGggZXhpc3RpbmcgZGF0YVxuICovXG5mdW5jdGlvbiB1cGRhdGVTZXNzaW9uRGF0YUZvclRyYW5zcG9ydCh0cmFuc3BvcnQsIHBhcnRpYWxTZXNzaW9uRGF0YSkge1xuICBpZiAodHJhbnNwb3J0LnNlc3Npb25JZCkge1xuICAgIGNvbnN0IGV4aXN0aW5nRGF0YSA9IHRyYW5zcG9ydFRvU2Vzc2lvbkRhdGEuZ2V0KHRyYW5zcG9ydCkgfHwge307XG4gICAgdHJhbnNwb3J0VG9TZXNzaW9uRGF0YS5zZXQodHJhbnNwb3J0LCB7IC4uLmV4aXN0aW5nRGF0YSwgLi4ucGFydGlhbFNlc3Npb25EYXRhIH0pO1xuICB9XG59XG5cbi8qKlxuICogUmV0cmlldmVzIGNsaWVudCBpbmZvcm1hdGlvbiBmb3IgYSB0cmFuc3BvcnRcbiAqIEBwYXJhbSB0cmFuc3BvcnQgLSBNQ1AgdHJhbnNwb3J0IGluc3RhbmNlXG4gKiBAcmV0dXJucyBDbGllbnQgaW5mb3JtYXRpb24gaWYgYXZhaWxhYmxlXG4gKi9cbmZ1bmN0aW9uIGdldENsaWVudEluZm9Gb3JUcmFuc3BvcnQodHJhbnNwb3J0KSB7XG4gIHJldHVybiB0cmFuc3BvcnRUb1Nlc3Npb25EYXRhLmdldCh0cmFuc3BvcnQpPy5jbGllbnRJbmZvO1xufVxuXG4vKipcbiAqIFJldHJpZXZlcyBwcm90b2NvbCB2ZXJzaW9uIGZvciBhIHRyYW5zcG9ydFxuICogQHBhcmFtIHRyYW5zcG9ydCAtIE1DUCB0cmFuc3BvcnQgaW5zdGFuY2VcbiAqIEByZXR1cm5zIFByb3RvY29sIHZlcnNpb24gaWYgYXZhaWxhYmxlXG4gKi9cbmZ1bmN0aW9uIGdldFByb3RvY29sVmVyc2lvbkZvclRyYW5zcG9ydCh0cmFuc3BvcnQpIHtcbiAgcmV0dXJuIHRyYW5zcG9ydFRvU2Vzc2lvbkRhdGEuZ2V0KHRyYW5zcG9ydCk/LnByb3RvY29sVmVyc2lvbjtcbn1cblxuLyoqXG4gKiBSZXRyaWV2ZXMgZnVsbCBzZXNzaW9uIGRhdGEgZm9yIGEgdHJhbnNwb3J0XG4gKiBAcGFyYW0gdHJhbnNwb3J0IC0gTUNQIHRyYW5zcG9ydCBpbnN0YW5jZVxuICogQHJldHVybnMgQ29tcGxldGUgc2Vzc2lvbiBkYXRhIGlmIGF2YWlsYWJsZVxuICovXG5mdW5jdGlvbiBnZXRTZXNzaW9uRGF0YUZvclRyYW5zcG9ydCh0cmFuc3BvcnQpIHtcbiAgcmV0dXJuIHRyYW5zcG9ydFRvU2Vzc2lvbkRhdGEuZ2V0KHRyYW5zcG9ydCk7XG59XG5cbi8qKlxuICogQ2xlYW5zIHVwIHNlc3Npb24gZGF0YSBmb3IgYSBzcGVjaWZpYyB0cmFuc3BvcnQgKHdoZW4gdGhhdCB0cmFuc3BvcnQgY2xvc2VzKVxuICogQHBhcmFtIHRyYW5zcG9ydCAtIE1DUCB0cmFuc3BvcnQgaW5zdGFuY2VcbiAqL1xuZnVuY3Rpb24gY2xlYW51cFNlc3Npb25EYXRhRm9yVHJhbnNwb3J0KHRyYW5zcG9ydCkge1xuICB0cmFuc3BvcnRUb1Nlc3Npb25EYXRhLmRlbGV0ZSh0cmFuc3BvcnQpO1xufVxuXG5leHBvcnRzLmNsZWFudXBTZXNzaW9uRGF0YUZvclRyYW5zcG9ydCA9IGNsZWFudXBTZXNzaW9uRGF0YUZvclRyYW5zcG9ydDtcbmV4cG9ydHMuZ2V0Q2xpZW50SW5mb0ZvclRyYW5zcG9ydCA9IGdldENsaWVudEluZm9Gb3JUcmFuc3BvcnQ7XG5leHBvcnRzLmdldFByb3RvY29sVmVyc2lvbkZvclRyYW5zcG9ydCA9IGdldFByb3RvY29sVmVyc2lvbkZvclRyYW5zcG9ydDtcbmV4cG9ydHMuZ2V0U2Vzc2lvbkRhdGFGb3JUcmFuc3BvcnQgPSBnZXRTZXNzaW9uRGF0YUZvclRyYW5zcG9ydDtcbmV4cG9ydHMuc3RvcmVTZXNzaW9uRGF0YUZvclRyYW5zcG9ydCA9IHN0b3JlU2Vzc2lvbkRhdGFGb3JUcmFuc3BvcnQ7XG5leHBvcnRzLnVwZGF0ZVNlc3Npb25EYXRhRm9yVHJhbnNwb3J0ID0gdXBkYXRlU2Vzc2lvbkRhdGFGb3JUcmFuc3BvcnQ7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1zZXNzaW9uTWFuYWdlbWVudC5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/sessionManagement.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/spans.js":
/*!*********************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/spans.js ***!
  \*********************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst currentScopes = __webpack_require__(/*! ../../currentScopes.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst semanticAttributes = __webpack_require__(/*! ../../semanticAttributes.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/semanticAttributes.js\");\nconst trace = __webpack_require__(/*! ../../tracing/trace.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/trace.js\");\nconst attributeExtraction = __webpack_require__(/*! ./attributeExtraction.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/attributeExtraction.js\");\nconst attributes = __webpack_require__(/*! ./attributes.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/attributes.js\");\nconst methodConfig = __webpack_require__(/*! ./methodConfig.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/methodConfig.js\");\nconst piiFiltering = __webpack_require__(/*! ./piiFiltering.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/piiFiltering.js\");\nconst sessionExtraction = __webpack_require__(/*! ./sessionExtraction.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/sessionExtraction.js\");\n\n/**\n * Span creation and management functions for MCP server instrumentation\n *\n * Provides unified span creation following OpenTelemetry MCP semantic conventions and our opinitionated take on MCP.\n * Handles both request and notification spans with attribute extraction.\n */\n\n\n/**\n * Creates a span name based on the method and target\n * @internal\n * @param method - MCP method name\n * @param target - Optional target identifier\n * @returns Formatted span name\n */\nfunction createSpanName(method, target) {\n  return target ? `${method} ${target}` : method;\n}\n\n/**\n * Build Sentry-specific attributes based on span type\n * @internal\n * @param type - Span type configuration\n * @returns Sentry-specific attributes\n */\nfunction buildSentryAttributes(type) {\n  let op;\n  let origin;\n\n  switch (type) {\n    case 'request':\n      op = attributes.MCP_SERVER_OP_VALUE;\n      origin = attributes.MCP_FUNCTION_ORIGIN_VALUE;\n      break;\n    case 'notification-incoming':\n      op = attributes.MCP_NOTIFICATION_CLIENT_TO_SERVER_OP_VALUE;\n      origin = attributes.MCP_NOTIFICATION_ORIGIN_VALUE;\n      break;\n    case 'notification-outgoing':\n      op = attributes.MCP_NOTIFICATION_SERVER_TO_CLIENT_OP_VALUE;\n      origin = attributes.MCP_NOTIFICATION_ORIGIN_VALUE;\n      break;\n  }\n\n  return {\n    [semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_OP]: op,\n    [semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_ORIGIN]: origin,\n    [semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_SOURCE]: attributes.MCP_ROUTE_SOURCE_VALUE,\n  };\n}\n\n/**\n * Unified builder for creating MCP spans\n * @internal\n * @param config - Span configuration\n * @returns Created span\n */\nfunction createMcpSpan(config) {\n  const { type, message, transport, extra, callback } = config;\n  const { method } = message;\n  const params = message.params ;\n\n  // Determine span name based on type and OTEL conventions\n  let spanName;\n  if (type === 'request') {\n    const targetInfo = methodConfig.extractTargetInfo(method, params || {});\n    spanName = createSpanName(method, targetInfo.target);\n  } else {\n    // For notifications, use method name directly per OpenTelemetry conventions\n    spanName = method;\n  }\n\n  const rawAttributes = {\n    ...sessionExtraction.buildTransportAttributes(transport, extra),\n    [attributes.MCP_METHOD_NAME_ATTRIBUTE]: method,\n    ...attributeExtraction.buildTypeSpecificAttributes(type, message, params),\n    ...buildSentryAttributes(type),\n  };\n\n  const client = currentScopes.getClient();\n  const sendDefaultPii = Boolean(client?.getOptions().sendDefaultPii);\n  const attributes$1 = piiFiltering.filterMcpPiiFromSpanData(rawAttributes, sendDefaultPii) ;\n\n  return trace.startSpan(\n    {\n      name: spanName,\n      forceTransaction: true,\n      attributes: attributes$1,\n    },\n    callback,\n  );\n}\n\n/**\n * Creates a span for incoming MCP notifications\n * @param jsonRpcMessage - Notification message\n * @param transport - MCP transport instance\n * @param extra - Extra handler data\n * @param callback - Span execution callback\n * @returns Span execution result\n */\nfunction createMcpNotificationSpan(\n  jsonRpcMessage,\n  transport,\n  extra,\n  callback,\n) {\n  return createMcpSpan({\n    type: 'notification-incoming',\n    message: jsonRpcMessage,\n    transport,\n    extra,\n    callback,\n  });\n}\n\n/**\n * Creates a span for outgoing MCP notifications\n * @param jsonRpcMessage - Notification message\n * @param transport - MCP transport instance\n * @param callback - Span execution callback\n * @returns Span execution result\n */\nfunction createMcpOutgoingNotificationSpan(\n  jsonRpcMessage,\n  transport,\n  callback,\n) {\n  return createMcpSpan({\n    type: 'notification-outgoing',\n    message: jsonRpcMessage,\n    transport,\n    callback,\n  });\n}\n\n/**\n * Builds span configuration for MCP server requests\n * @param jsonRpcMessage - Request message\n * @param transport - MCP transport instance\n * @param extra - Optional extra handler data\n * @returns Span configuration object\n */\nfunction buildMcpServerSpanConfig(\n  jsonRpcMessage,\n  transport,\n  extra,\n)\n\n {\n  const { method } = jsonRpcMessage;\n  const params = jsonRpcMessage.params ;\n\n  const targetInfo = methodConfig.extractTargetInfo(method, params || {});\n  const spanName = createSpanName(method, targetInfo.target);\n\n  const rawAttributes = {\n    ...sessionExtraction.buildTransportAttributes(transport, extra),\n    [attributes.MCP_METHOD_NAME_ATTRIBUTE]: method,\n    ...attributeExtraction.buildTypeSpecificAttributes('request', jsonRpcMessage, params),\n    ...buildSentryAttributes('request'),\n  };\n\n  const client = currentScopes.getClient();\n  const sendDefaultPii = Boolean(client?.getOptions().sendDefaultPii);\n  const attributes$1 = piiFiltering.filterMcpPiiFromSpanData(rawAttributes, sendDefaultPii) ;\n\n  return {\n    name: spanName,\n    op: attributes.MCP_SERVER_OP_VALUE,\n    forceTransaction: true,\n    attributes: attributes$1,\n  };\n}\n\nexports.buildMcpServerSpanConfig = buildMcpServerSpanConfig;\nexports.createMcpNotificationSpan = createMcpNotificationSpan;\nexports.createMcpOutgoingNotificationSpan = createMcpOutgoingNotificationSpan;\n//# sourceMappingURL=spans.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvbWNwLXNlcnZlci9zcGFucy5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxzQkFBc0IsbUJBQU8sQ0FBQyxtSUFBd0I7QUFDdEQsMkJBQTJCLG1CQUFPLENBQUMsNklBQTZCO0FBQ2hFLGNBQWMsbUJBQU8sQ0FBQyxtSUFBd0I7QUFDOUMsNEJBQTRCLG1CQUFPLENBQUMsbUtBQTBCO0FBQzlELG1CQUFtQixtQkFBTyxDQUFDLGlKQUFpQjtBQUM1QyxxQkFBcUIsbUJBQU8sQ0FBQyxxSkFBbUI7QUFDaEQscUJBQXFCLG1CQUFPLENBQUMscUpBQW1CO0FBQ2hELDBCQUEwQixtQkFBTyxDQUFDLCtKQUF3Qjs7QUFFMUQ7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOzs7QUFHQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EscUJBQXFCLFFBQVEsRUFBRSxPQUFPO0FBQ3RDOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFVBQVUsNENBQTRDO0FBQ3RELFVBQVUsU0FBUztBQUNuQjs7QUFFQTtBQUNBO0FBQ0E7QUFDQSwwRUFBMEU7QUFDMUU7QUFDQSxJQUFJO0FBQ0o7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEtBQUs7QUFDTDtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEdBQUc7QUFDSDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsR0FBRztBQUNIOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBLFVBQVUsU0FBUztBQUNuQjs7QUFFQSx3RUFBd0U7QUFDeEU7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSxnQ0FBZ0M7QUFDaEMsaUNBQWlDO0FBQ2pDLHlDQUF5QztBQUN6QyIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL2ludGVncmF0aW9ucy9tY3Atc2VydmVyL3NwYW5zLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBjdXJyZW50U2NvcGVzID0gcmVxdWlyZSgnLi4vLi4vY3VycmVudFNjb3Blcy5qcycpO1xuY29uc3Qgc2VtYW50aWNBdHRyaWJ1dGVzID0gcmVxdWlyZSgnLi4vLi4vc2VtYW50aWNBdHRyaWJ1dGVzLmpzJyk7XG5jb25zdCB0cmFjZSA9IHJlcXVpcmUoJy4uLy4uL3RyYWNpbmcvdHJhY2UuanMnKTtcbmNvbnN0IGF0dHJpYnV0ZUV4dHJhY3Rpb24gPSByZXF1aXJlKCcuL2F0dHJpYnV0ZUV4dHJhY3Rpb24uanMnKTtcbmNvbnN0IGF0dHJpYnV0ZXMgPSByZXF1aXJlKCcuL2F0dHJpYnV0ZXMuanMnKTtcbmNvbnN0IG1ldGhvZENvbmZpZyA9IHJlcXVpcmUoJy4vbWV0aG9kQ29uZmlnLmpzJyk7XG5jb25zdCBwaWlGaWx0ZXJpbmcgPSByZXF1aXJlKCcuL3BpaUZpbHRlcmluZy5qcycpO1xuY29uc3Qgc2Vzc2lvbkV4dHJhY3Rpb24gPSByZXF1aXJlKCcuL3Nlc3Npb25FeHRyYWN0aW9uLmpzJyk7XG5cbi8qKlxuICogU3BhbiBjcmVhdGlvbiBhbmQgbWFuYWdlbWVudCBmdW5jdGlvbnMgZm9yIE1DUCBzZXJ2ZXIgaW5zdHJ1bWVudGF0aW9uXG4gKlxuICogUHJvdmlkZXMgdW5pZmllZCBzcGFuIGNyZWF0aW9uIGZvbGxvd2luZyBPcGVuVGVsZW1ldHJ5IE1DUCBzZW1hbnRpYyBjb252ZW50aW9ucyBhbmQgb3VyIG9waW5pdGlvbmF0ZWQgdGFrZSBvbiBNQ1AuXG4gKiBIYW5kbGVzIGJvdGggcmVxdWVzdCBhbmQgbm90aWZpY2F0aW9uIHNwYW5zIHdpdGggYXR0cmlidXRlIGV4dHJhY3Rpb24uXG4gKi9cblxuXG4vKipcbiAqIENyZWF0ZXMgYSBzcGFuIG5hbWUgYmFzZWQgb24gdGhlIG1ldGhvZCBhbmQgdGFyZ2V0XG4gKiBAaW50ZXJuYWxcbiAqIEBwYXJhbSBtZXRob2QgLSBNQ1AgbWV0aG9kIG5hbWVcbiAqIEBwYXJhbSB0YXJnZXQgLSBPcHRpb25hbCB0YXJnZXQgaWRlbnRpZmllclxuICogQHJldHVybnMgRm9ybWF0dGVkIHNwYW4gbmFtZVxuICovXG5mdW5jdGlvbiBjcmVhdGVTcGFuTmFtZShtZXRob2QsIHRhcmdldCkge1xuICByZXR1cm4gdGFyZ2V0ID8gYCR7bWV0aG9kfSAke3RhcmdldH1gIDogbWV0aG9kO1xufVxuXG4vKipcbiAqIEJ1aWxkIFNlbnRyeS1zcGVjaWZpYyBhdHRyaWJ1dGVzIGJhc2VkIG9uIHNwYW4gdHlwZVxuICogQGludGVybmFsXG4gKiBAcGFyYW0gdHlwZSAtIFNwYW4gdHlwZSBjb25maWd1cmF0aW9uXG4gKiBAcmV0dXJucyBTZW50cnktc3BlY2lmaWMgYXR0cmlidXRlc1xuICovXG5mdW5jdGlvbiBidWlsZFNlbnRyeUF0dHJpYnV0ZXModHlwZSkge1xuICBsZXQgb3A7XG4gIGxldCBvcmlnaW47XG5cbiAgc3dpdGNoICh0eXBlKSB7XG4gICAgY2FzZSAncmVxdWVzdCc6XG4gICAgICBvcCA9IGF0dHJpYnV0ZXMuTUNQX1NFUlZFUl9PUF9WQUxVRTtcbiAgICAgIG9yaWdpbiA9IGF0dHJpYnV0ZXMuTUNQX0ZVTkNUSU9OX09SSUdJTl9WQUxVRTtcbiAgICAgIGJyZWFrO1xuICAgIGNhc2UgJ25vdGlmaWNhdGlvbi1pbmNvbWluZyc6XG4gICAgICBvcCA9IGF0dHJpYnV0ZXMuTUNQX05PVElGSUNBVElPTl9DTElFTlRfVE9fU0VSVkVSX09QX1ZBTFVFO1xuICAgICAgb3JpZ2luID0gYXR0cmlidXRlcy5NQ1BfTk9USUZJQ0FUSU9OX09SSUdJTl9WQUxVRTtcbiAgICAgIGJyZWFrO1xuICAgIGNhc2UgJ25vdGlmaWNhdGlvbi1vdXRnb2luZyc6XG4gICAgICBvcCA9IGF0dHJpYnV0ZXMuTUNQX05PVElGSUNBVElPTl9TRVJWRVJfVE9fQ0xJRU5UX09QX1ZBTFVFO1xuICAgICAgb3JpZ2luID0gYXR0cmlidXRlcy5NQ1BfTk9USUZJQ0FUSU9OX09SSUdJTl9WQUxVRTtcbiAgICAgIGJyZWFrO1xuICB9XG5cbiAgcmV0dXJuIHtcbiAgICBbc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfT1BdOiBvcCxcbiAgICBbc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfT1JJR0lOXTogb3JpZ2luLFxuICAgIFtzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9TT1VSQ0VdOiBhdHRyaWJ1dGVzLk1DUF9ST1VURV9TT1VSQ0VfVkFMVUUsXG4gIH07XG59XG5cbi8qKlxuICogVW5pZmllZCBidWlsZGVyIGZvciBjcmVhdGluZyBNQ1Agc3BhbnNcbiAqIEBpbnRlcm5hbFxuICogQHBhcmFtIGNvbmZpZyAtIFNwYW4gY29uZmlndXJhdGlvblxuICogQHJldHVybnMgQ3JlYXRlZCBzcGFuXG4gKi9cbmZ1bmN0aW9uIGNyZWF0ZU1jcFNwYW4oY29uZmlnKSB7XG4gIGNvbnN0IHsgdHlwZSwgbWVzc2FnZSwgdHJhbnNwb3J0LCBleHRyYSwgY2FsbGJhY2sgfSA9IGNvbmZpZztcbiAgY29uc3QgeyBtZXRob2QgfSA9IG1lc3NhZ2U7XG4gIGNvbnN0IHBhcmFtcyA9IG1lc3NhZ2UucGFyYW1zIDtcblxuICAvLyBEZXRlcm1pbmUgc3BhbiBuYW1lIGJhc2VkIG9uIHR5cGUgYW5kIE9URUwgY29udmVudGlvbnNcbiAgbGV0IHNwYW5OYW1lO1xuICBpZiAodHlwZSA9PT0gJ3JlcXVlc3QnKSB7XG4gICAgY29uc3QgdGFyZ2V0SW5mbyA9IG1ldGhvZENvbmZpZy5leHRyYWN0VGFyZ2V0SW5mbyhtZXRob2QsIHBhcmFtcyB8fCB7fSk7XG4gICAgc3Bhbk5hbWUgPSBjcmVhdGVTcGFuTmFtZShtZXRob2QsIHRhcmdldEluZm8udGFyZ2V0KTtcbiAgfSBlbHNlIHtcbiAgICAvLyBGb3Igbm90aWZpY2F0aW9ucywgdXNlIG1ldGhvZCBuYW1lIGRpcmVjdGx5IHBlciBPcGVuVGVsZW1ldHJ5IGNvbnZlbnRpb25zXG4gICAgc3Bhbk5hbWUgPSBtZXRob2Q7XG4gIH1cblxuICBjb25zdCByYXdBdHRyaWJ1dGVzID0ge1xuICAgIC4uLnNlc3Npb25FeHRyYWN0aW9uLmJ1aWxkVHJhbnNwb3J0QXR0cmlidXRlcyh0cmFuc3BvcnQsIGV4dHJhKSxcbiAgICBbYXR0cmlidXRlcy5NQ1BfTUVUSE9EX05BTUVfQVRUUklCVVRFXTogbWV0aG9kLFxuICAgIC4uLmF0dHJpYnV0ZUV4dHJhY3Rpb24uYnVpbGRUeXBlU3BlY2lmaWNBdHRyaWJ1dGVzKHR5cGUsIG1lc3NhZ2UsIHBhcmFtcyksXG4gICAgLi4uYnVpbGRTZW50cnlBdHRyaWJ1dGVzKHR5cGUpLFxuICB9O1xuXG4gIGNvbnN0IGNsaWVudCA9IGN1cnJlbnRTY29wZXMuZ2V0Q2xpZW50KCk7XG4gIGNvbnN0IHNlbmREZWZhdWx0UGlpID0gQm9vbGVhbihjbGllbnQ/LmdldE9wdGlvbnMoKS5zZW5kRGVmYXVsdFBpaSk7XG4gIGNvbnN0IGF0dHJpYnV0ZXMkMSA9IHBpaUZpbHRlcmluZy5maWx0ZXJNY3BQaWlGcm9tU3BhbkRhdGEocmF3QXR0cmlidXRlcywgc2VuZERlZmF1bHRQaWkpIDtcblxuICByZXR1cm4gdHJhY2Uuc3RhcnRTcGFuKFxuICAgIHtcbiAgICAgIG5hbWU6IHNwYW5OYW1lLFxuICAgICAgZm9yY2VUcmFuc2FjdGlvbjogdHJ1ZSxcbiAgICAgIGF0dHJpYnV0ZXM6IGF0dHJpYnV0ZXMkMSxcbiAgICB9LFxuICAgIGNhbGxiYWNrLFxuICApO1xufVxuXG4vKipcbiAqIENyZWF0ZXMgYSBzcGFuIGZvciBpbmNvbWluZyBNQ1Agbm90aWZpY2F0aW9uc1xuICogQHBhcmFtIGpzb25ScGNNZXNzYWdlIC0gTm90aWZpY2F0aW9uIG1lc3NhZ2VcbiAqIEBwYXJhbSB0cmFuc3BvcnQgLSBNQ1AgdHJhbnNwb3J0IGluc3RhbmNlXG4gKiBAcGFyYW0gZXh0cmEgLSBFeHRyYSBoYW5kbGVyIGRhdGFcbiAqIEBwYXJhbSBjYWxsYmFjayAtIFNwYW4gZXhlY3V0aW9uIGNhbGxiYWNrXG4gKiBAcmV0dXJucyBTcGFuIGV4ZWN1dGlvbiByZXN1bHRcbiAqL1xuZnVuY3Rpb24gY3JlYXRlTWNwTm90aWZpY2F0aW9uU3BhbihcbiAganNvblJwY01lc3NhZ2UsXG4gIHRyYW5zcG9ydCxcbiAgZXh0cmEsXG4gIGNhbGxiYWNrLFxuKSB7XG4gIHJldHVybiBjcmVhdGVNY3BTcGFuKHtcbiAgICB0eXBlOiAnbm90aWZpY2F0aW9uLWluY29taW5nJyxcbiAgICBtZXNzYWdlOiBqc29uUnBjTWVzc2FnZSxcbiAgICB0cmFuc3BvcnQsXG4gICAgZXh0cmEsXG4gICAgY2FsbGJhY2ssXG4gIH0pO1xufVxuXG4vKipcbiAqIENyZWF0ZXMgYSBzcGFuIGZvciBvdXRnb2luZyBNQ1Agbm90aWZpY2F0aW9uc1xuICogQHBhcmFtIGpzb25ScGNNZXNzYWdlIC0gTm90aWZpY2F0aW9uIG1lc3NhZ2VcbiAqIEBwYXJhbSB0cmFuc3BvcnQgLSBNQ1AgdHJhbnNwb3J0IGluc3RhbmNlXG4gKiBAcGFyYW0gY2FsbGJhY2sgLSBTcGFuIGV4ZWN1dGlvbiBjYWxsYmFja1xuICogQHJldHVybnMgU3BhbiBleGVjdXRpb24gcmVzdWx0XG4gKi9cbmZ1bmN0aW9uIGNyZWF0ZU1jcE91dGdvaW5nTm90aWZpY2F0aW9uU3BhbihcbiAganNvblJwY01lc3NhZ2UsXG4gIHRyYW5zcG9ydCxcbiAgY2FsbGJhY2ssXG4pIHtcbiAgcmV0dXJuIGNyZWF0ZU1jcFNwYW4oe1xuICAgIHR5cGU6ICdub3RpZmljYXRpb24tb3V0Z29pbmcnLFxuICAgIG1lc3NhZ2U6IGpzb25ScGNNZXNzYWdlLFxuICAgIHRyYW5zcG9ydCxcbiAgICBjYWxsYmFjayxcbiAgfSk7XG59XG5cbi8qKlxuICogQnVpbGRzIHNwYW4gY29uZmlndXJhdGlvbiBmb3IgTUNQIHNlcnZlciByZXF1ZXN0c1xuICogQHBhcmFtIGpzb25ScGNNZXNzYWdlIC0gUmVxdWVzdCBtZXNzYWdlXG4gKiBAcGFyYW0gdHJhbnNwb3J0IC0gTUNQIHRyYW5zcG9ydCBpbnN0YW5jZVxuICogQHBhcmFtIGV4dHJhIC0gT3B0aW9uYWwgZXh0cmEgaGFuZGxlciBkYXRhXG4gKiBAcmV0dXJucyBTcGFuIGNvbmZpZ3VyYXRpb24gb2JqZWN0XG4gKi9cbmZ1bmN0aW9uIGJ1aWxkTWNwU2VydmVyU3BhbkNvbmZpZyhcbiAganNvblJwY01lc3NhZ2UsXG4gIHRyYW5zcG9ydCxcbiAgZXh0cmEsXG4pXG5cbiB7XG4gIGNvbnN0IHsgbWV0aG9kIH0gPSBqc29uUnBjTWVzc2FnZTtcbiAgY29uc3QgcGFyYW1zID0ganNvblJwY01lc3NhZ2UucGFyYW1zIDtcblxuICBjb25zdCB0YXJnZXRJbmZvID0gbWV0aG9kQ29uZmlnLmV4dHJhY3RUYXJnZXRJbmZvKG1ldGhvZCwgcGFyYW1zIHx8IHt9KTtcbiAgY29uc3Qgc3Bhbk5hbWUgPSBjcmVhdGVTcGFuTmFtZShtZXRob2QsIHRhcmdldEluZm8udGFyZ2V0KTtcblxuICBjb25zdCByYXdBdHRyaWJ1dGVzID0ge1xuICAgIC4uLnNlc3Npb25FeHRyYWN0aW9uLmJ1aWxkVHJhbnNwb3J0QXR0cmlidXRlcyh0cmFuc3BvcnQsIGV4dHJhKSxcbiAgICBbYXR0cmlidXRlcy5NQ1BfTUVUSE9EX05BTUVfQVRUUklCVVRFXTogbWV0aG9kLFxuICAgIC4uLmF0dHJpYnV0ZUV4dHJhY3Rpb24uYnVpbGRUeXBlU3BlY2lmaWNBdHRyaWJ1dGVzKCdyZXF1ZXN0JywganNvblJwY01lc3NhZ2UsIHBhcmFtcyksXG4gICAgLi4uYnVpbGRTZW50cnlBdHRyaWJ1dGVzKCdyZXF1ZXN0JyksXG4gIH07XG5cbiAgY29uc3QgY2xpZW50ID0gY3VycmVudFNjb3Blcy5nZXRDbGllbnQoKTtcbiAgY29uc3Qgc2VuZERlZmF1bHRQaWkgPSBCb29sZWFuKGNsaWVudD8uZ2V0T3B0aW9ucygpLnNlbmREZWZhdWx0UGlpKTtcbiAgY29uc3QgYXR0cmlidXRlcyQxID0gcGlpRmlsdGVyaW5nLmZpbHRlck1jcFBpaUZyb21TcGFuRGF0YShyYXdBdHRyaWJ1dGVzLCBzZW5kRGVmYXVsdFBpaSkgO1xuXG4gIHJldHVybiB7XG4gICAgbmFtZTogc3Bhbk5hbWUsXG4gICAgb3A6IGF0dHJpYnV0ZXMuTUNQX1NFUlZFUl9PUF9WQUxVRSxcbiAgICBmb3JjZVRyYW5zYWN0aW9uOiB0cnVlLFxuICAgIGF0dHJpYnV0ZXM6IGF0dHJpYnV0ZXMkMSxcbiAgfTtcbn1cblxuZXhwb3J0cy5idWlsZE1jcFNlcnZlclNwYW5Db25maWcgPSBidWlsZE1jcFNlcnZlclNwYW5Db25maWc7XG5leHBvcnRzLmNyZWF0ZU1jcE5vdGlmaWNhdGlvblNwYW4gPSBjcmVhdGVNY3BOb3RpZmljYXRpb25TcGFuO1xuZXhwb3J0cy5jcmVhdGVNY3BPdXRnb2luZ05vdGlmaWNhdGlvblNwYW4gPSBjcmVhdGVNY3BPdXRnb2luZ05vdGlmaWNhdGlvblNwYW47XG4vLyMgc291cmNlTWFwcGluZ1VSTD1zcGFucy5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/spans.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/transport.js":
/*!*************************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/transport.js ***!
  \*************************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst currentScopes = __webpack_require__(/*! ../../currentScopes.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst object = __webpack_require__(/*! ../../utils/object.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/object.js\");\nconst trace = __webpack_require__(/*! ../../tracing/trace.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/trace.js\");\nconst correlation = __webpack_require__(/*! ./correlation.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/correlation.js\");\nconst errorCapture = __webpack_require__(/*! ./errorCapture.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/errorCapture.js\");\nconst sessionExtraction = __webpack_require__(/*! ./sessionExtraction.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/sessionExtraction.js\");\nconst sessionManagement = __webpack_require__(/*! ./sessionManagement.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/sessionManagement.js\");\nconst spans = __webpack_require__(/*! ./spans.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/spans.js\");\nconst validation = __webpack_require__(/*! ./validation.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/validation.js\");\n\n/**\n * Transport layer instrumentation for MCP server\n *\n * Handles message interception and response correlation.\n * @see https://modelcontextprotocol.io/specification/2025-06-18/basic/transports\n */\n\n\n/**\n * Wraps transport.onmessage to create spans for incoming messages.\n * For \"initialize\" requests, extracts and stores client info and protocol version\n * in the session data for the transport.\n * @param transport - MCP transport instance to wrap\n */\nfunction wrapTransportOnMessage(transport) {\n  if (transport.onmessage) {\n    object.fill(transport, 'onmessage', originalOnMessage => {\n      return function ( message, extra) {\n        if (validation.isJsonRpcRequest(message)) {\n          if (message.method === 'initialize') {\n            try {\n              const sessionData = sessionExtraction.extractSessionDataFromInitializeRequest(message);\n              sessionManagement.storeSessionDataForTransport(this, sessionData);\n            } catch {\n              // noop\n            }\n          }\n\n          const isolationScope = currentScopes.getIsolationScope().clone();\n\n          return currentScopes.withIsolationScope(isolationScope, () => {\n            const spanConfig = spans.buildMcpServerSpanConfig(message, this, extra );\n            const span = trace.startInactiveSpan(spanConfig);\n\n            correlation.storeSpanForRequest(this, message.id, span, message.method);\n\n            return trace.withActiveSpan(span, () => {\n              return (originalOnMessage ).call(this, message, extra);\n            });\n          });\n        }\n\n        if (validation.isJsonRpcNotification(message)) {\n          return spans.createMcpNotificationSpan(message, this, extra , () => {\n            return (originalOnMessage ).call(this, message, extra);\n          });\n        }\n\n        return (originalOnMessage ).call(this, message, extra);\n      };\n    });\n  }\n}\n\n/**\n * Wraps transport.send to handle outgoing messages and response correlation.\n * For \"initialize\" responses, extracts and stores protocol version and server info\n * in the session data for the transport.\n * @param transport - MCP transport instance to wrap\n */\nfunction wrapTransportSend(transport) {\n  if (transport.send) {\n    object.fill(transport, 'send', originalSend => {\n      return async function ( ...args) {\n        const [message] = args;\n\n        if (validation.isJsonRpcNotification(message)) {\n          return spans.createMcpOutgoingNotificationSpan(message, this, () => {\n            return (originalSend ).call(this, ...args);\n          });\n        }\n\n        if (validation.isJsonRpcResponse(message)) {\n          if (message.id !== null && message.id !== undefined) {\n            if (message.error) {\n              captureJsonRpcErrorResponse(message.error);\n            }\n\n            if (validation.isValidContentItem(message.result)) {\n              if (message.result.protocolVersion || message.result.serverInfo) {\n                try {\n                  const serverData = sessionExtraction.extractSessionDataFromInitializeResponse(message.result);\n                  sessionManagement.updateSessionDataForTransport(this, serverData);\n                } catch {\n                  // noop\n                }\n              }\n            }\n\n            correlation.completeSpanWithResults(this, message.id, message.result);\n          }\n        }\n\n        return (originalSend ).call(this, ...args);\n      };\n    });\n  }\n}\n\n/**\n * Wraps transport.onclose to clean up pending spans for this transport only\n * @param transport - MCP transport instance to wrap\n */\nfunction wrapTransportOnClose(transport) {\n  if (transport.onclose) {\n    object.fill(transport, 'onclose', originalOnClose => {\n      return function ( ...args) {\n        correlation.cleanupPendingSpansForTransport(this);\n        sessionManagement.cleanupSessionDataForTransport(this);\n        return (originalOnClose ).call(this, ...args);\n      };\n    });\n  }\n}\n\n/**\n * Wraps transport error handlers to capture connection errors\n * @param transport - MCP transport instance to wrap\n */\nfunction wrapTransportError(transport) {\n  if (transport.onerror) {\n    object.fill(transport, 'onerror', (originalOnError) => {\n      return function ( error) {\n        captureTransportError(error);\n        return originalOnError.call(this, error);\n      };\n    });\n  }\n}\n\n/**\n * Captures JSON-RPC error responses for server-side errors.\n * @see https://www.jsonrpc.org/specification#error_object\n * @internal\n * @param errorResponse - JSON-RPC error response\n */\nfunction captureJsonRpcErrorResponse(errorResponse) {\n  try {\n    if (errorResponse && typeof errorResponse === 'object' && 'code' in errorResponse && 'message' in errorResponse) {\n      const jsonRpcError = errorResponse ;\n\n      const isServerError =\n        jsonRpcError.code === -32603 || (jsonRpcError.code >= -32099 && jsonRpcError.code <= -32000);\n\n      if (isServerError) {\n        const error = new Error(jsonRpcError.message);\n        error.name = `JsonRpcError_${jsonRpcError.code}`;\n\n        errorCapture.captureError(error, 'protocol');\n      }\n    }\n  } catch {\n    // noop\n  }\n}\n\n/**\n * Captures transport connection errors\n * @internal\n * @param error - Transport error\n */\nfunction captureTransportError(error) {\n  try {\n    errorCapture.captureError(error, 'transport');\n  } catch {\n    // noop\n  }\n}\n\nexports.wrapTransportError = wrapTransportError;\nexports.wrapTransportOnClose = wrapTransportOnClose;\nexports.wrapTransportOnMessage = wrapTransportOnMessage;\nexports.wrapTransportSend = wrapTransportSend;\n//# sourceMappingURL=transport.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvbWNwLXNlcnZlci90cmFuc3BvcnQuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsc0JBQXNCLG1CQUFPLENBQUMsbUlBQXdCO0FBQ3RELGVBQWUsbUJBQU8sQ0FBQyxpSUFBdUI7QUFDOUMsY0FBYyxtQkFBTyxDQUFDLG1JQUF3QjtBQUM5QyxvQkFBb0IsbUJBQU8sQ0FBQyxtSkFBa0I7QUFDOUMscUJBQXFCLG1CQUFPLENBQUMscUpBQW1CO0FBQ2hELDBCQUEwQixtQkFBTyxDQUFDLCtKQUF3QjtBQUMxRCwwQkFBMEIsbUJBQU8sQ0FBQywrSkFBd0I7QUFDMUQsY0FBYyxtQkFBTyxDQUFDLHVJQUFZO0FBQ2xDLG1CQUFtQixtQkFBTyxDQUFDLGlKQUFpQjs7QUFFNUM7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOzs7QUFHQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxjQUFjO0FBQ2Q7QUFDQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0EsYUFBYTtBQUNiLFdBQVc7QUFDWDs7QUFFQTtBQUNBO0FBQ0E7QUFDQSxXQUFXO0FBQ1g7O0FBRUE7QUFDQTtBQUNBLEtBQUs7QUFDTDtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0EsV0FBVztBQUNYOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGtCQUFrQjtBQUNsQjtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLEtBQUs7QUFDTDtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEtBQUs7QUFDTDtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxLQUFLO0FBQ0w7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQSxxQ0FBcUMsa0JBQWtCOztBQUV2RDtBQUNBO0FBQ0E7QUFDQSxJQUFJO0FBQ0o7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxJQUFJO0FBQ0o7QUFDQTtBQUNBOztBQUVBLDBCQUEwQjtBQUMxQiw0QkFBNEI7QUFDNUIsOEJBQThCO0FBQzlCLHlCQUF5QjtBQUN6QiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL2ludGVncmF0aW9ucy9tY3Atc2VydmVyL3RyYW5zcG9ydC5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgY3VycmVudFNjb3BlcyA9IHJlcXVpcmUoJy4uLy4uL2N1cnJlbnRTY29wZXMuanMnKTtcbmNvbnN0IG9iamVjdCA9IHJlcXVpcmUoJy4uLy4uL3V0aWxzL29iamVjdC5qcycpO1xuY29uc3QgdHJhY2UgPSByZXF1aXJlKCcuLi8uLi90cmFjaW5nL3RyYWNlLmpzJyk7XG5jb25zdCBjb3JyZWxhdGlvbiA9IHJlcXVpcmUoJy4vY29ycmVsYXRpb24uanMnKTtcbmNvbnN0IGVycm9yQ2FwdHVyZSA9IHJlcXVpcmUoJy4vZXJyb3JDYXB0dXJlLmpzJyk7XG5jb25zdCBzZXNzaW9uRXh0cmFjdGlvbiA9IHJlcXVpcmUoJy4vc2Vzc2lvbkV4dHJhY3Rpb24uanMnKTtcbmNvbnN0IHNlc3Npb25NYW5hZ2VtZW50ID0gcmVxdWlyZSgnLi9zZXNzaW9uTWFuYWdlbWVudC5qcycpO1xuY29uc3Qgc3BhbnMgPSByZXF1aXJlKCcuL3NwYW5zLmpzJyk7XG5jb25zdCB2YWxpZGF0aW9uID0gcmVxdWlyZSgnLi92YWxpZGF0aW9uLmpzJyk7XG5cbi8qKlxuICogVHJhbnNwb3J0IGxheWVyIGluc3RydW1lbnRhdGlvbiBmb3IgTUNQIHNlcnZlclxuICpcbiAqIEhhbmRsZXMgbWVzc2FnZSBpbnRlcmNlcHRpb24gYW5kIHJlc3BvbnNlIGNvcnJlbGF0aW9uLlxuICogQHNlZSBodHRwczovL21vZGVsY29udGV4dHByb3RvY29sLmlvL3NwZWNpZmljYXRpb24vMjAyNS0wNi0xOC9iYXNpYy90cmFuc3BvcnRzXG4gKi9cblxuXG4vKipcbiAqIFdyYXBzIHRyYW5zcG9ydC5vbm1lc3NhZ2UgdG8gY3JlYXRlIHNwYW5zIGZvciBpbmNvbWluZyBtZXNzYWdlcy5cbiAqIEZvciBcImluaXRpYWxpemVcIiByZXF1ZXN0cywgZXh0cmFjdHMgYW5kIHN0b3JlcyBjbGllbnQgaW5mbyBhbmQgcHJvdG9jb2wgdmVyc2lvblxuICogaW4gdGhlIHNlc3Npb24gZGF0YSBmb3IgdGhlIHRyYW5zcG9ydC5cbiAqIEBwYXJhbSB0cmFuc3BvcnQgLSBNQ1AgdHJhbnNwb3J0IGluc3RhbmNlIHRvIHdyYXBcbiAqL1xuZnVuY3Rpb24gd3JhcFRyYW5zcG9ydE9uTWVzc2FnZSh0cmFuc3BvcnQpIHtcbiAgaWYgKHRyYW5zcG9ydC5vbm1lc3NhZ2UpIHtcbiAgICBvYmplY3QuZmlsbCh0cmFuc3BvcnQsICdvbm1lc3NhZ2UnLCBvcmlnaW5hbE9uTWVzc2FnZSA9PiB7XG4gICAgICByZXR1cm4gZnVuY3Rpb24gKCBtZXNzYWdlLCBleHRyYSkge1xuICAgICAgICBpZiAodmFsaWRhdGlvbi5pc0pzb25ScGNSZXF1ZXN0KG1lc3NhZ2UpKSB7XG4gICAgICAgICAgaWYgKG1lc3NhZ2UubWV0aG9kID09PSAnaW5pdGlhbGl6ZScpIHtcbiAgICAgICAgICAgIHRyeSB7XG4gICAgICAgICAgICAgIGNvbnN0IHNlc3Npb25EYXRhID0gc2Vzc2lvbkV4dHJhY3Rpb24uZXh0cmFjdFNlc3Npb25EYXRhRnJvbUluaXRpYWxpemVSZXF1ZXN0KG1lc3NhZ2UpO1xuICAgICAgICAgICAgICBzZXNzaW9uTWFuYWdlbWVudC5zdG9yZVNlc3Npb25EYXRhRm9yVHJhbnNwb3J0KHRoaXMsIHNlc3Npb25EYXRhKTtcbiAgICAgICAgICAgIH0gY2F0Y2gge1xuICAgICAgICAgICAgICAvLyBub29wXG4gICAgICAgICAgICB9XG4gICAgICAgICAgfVxuXG4gICAgICAgICAgY29uc3QgaXNvbGF0aW9uU2NvcGUgPSBjdXJyZW50U2NvcGVzLmdldElzb2xhdGlvblNjb3BlKCkuY2xvbmUoKTtcblxuICAgICAgICAgIHJldHVybiBjdXJyZW50U2NvcGVzLndpdGhJc29sYXRpb25TY29wZShpc29sYXRpb25TY29wZSwgKCkgPT4ge1xuICAgICAgICAgICAgY29uc3Qgc3BhbkNvbmZpZyA9IHNwYW5zLmJ1aWxkTWNwU2VydmVyU3BhbkNvbmZpZyhtZXNzYWdlLCB0aGlzLCBleHRyYSApO1xuICAgICAgICAgICAgY29uc3Qgc3BhbiA9IHRyYWNlLnN0YXJ0SW5hY3RpdmVTcGFuKHNwYW5Db25maWcpO1xuXG4gICAgICAgICAgICBjb3JyZWxhdGlvbi5zdG9yZVNwYW5Gb3JSZXF1ZXN0KHRoaXMsIG1lc3NhZ2UuaWQsIHNwYW4sIG1lc3NhZ2UubWV0aG9kKTtcblxuICAgICAgICAgICAgcmV0dXJuIHRyYWNlLndpdGhBY3RpdmVTcGFuKHNwYW4sICgpID0+IHtcbiAgICAgICAgICAgICAgcmV0dXJuIChvcmlnaW5hbE9uTWVzc2FnZSApLmNhbGwodGhpcywgbWVzc2FnZSwgZXh0cmEpO1xuICAgICAgICAgICAgfSk7XG4gICAgICAgICAgfSk7XG4gICAgICAgIH1cblxuICAgICAgICBpZiAodmFsaWRhdGlvbi5pc0pzb25ScGNOb3RpZmljYXRpb24obWVzc2FnZSkpIHtcbiAgICAgICAgICByZXR1cm4gc3BhbnMuY3JlYXRlTWNwTm90aWZpY2F0aW9uU3BhbihtZXNzYWdlLCB0aGlzLCBleHRyYSAsICgpID0+IHtcbiAgICAgICAgICAgIHJldHVybiAob3JpZ2luYWxPbk1lc3NhZ2UgKS5jYWxsKHRoaXMsIG1lc3NhZ2UsIGV4dHJhKTtcbiAgICAgICAgICB9KTtcbiAgICAgICAgfVxuXG4gICAgICAgIHJldHVybiAob3JpZ2luYWxPbk1lc3NhZ2UgKS5jYWxsKHRoaXMsIG1lc3NhZ2UsIGV4dHJhKTtcbiAgICAgIH07XG4gICAgfSk7XG4gIH1cbn1cblxuLyoqXG4gKiBXcmFwcyB0cmFuc3BvcnQuc2VuZCB0byBoYW5kbGUgb3V0Z29pbmcgbWVzc2FnZXMgYW5kIHJlc3BvbnNlIGNvcnJlbGF0aW9uLlxuICogRm9yIFwiaW5pdGlhbGl6ZVwiIHJlc3BvbnNlcywgZXh0cmFjdHMgYW5kIHN0b3JlcyBwcm90b2NvbCB2ZXJzaW9uIGFuZCBzZXJ2ZXIgaW5mb1xuICogaW4gdGhlIHNlc3Npb24gZGF0YSBmb3IgdGhlIHRyYW5zcG9ydC5cbiAqIEBwYXJhbSB0cmFuc3BvcnQgLSBNQ1AgdHJhbnNwb3J0IGluc3RhbmNlIHRvIHdyYXBcbiAqL1xuZnVuY3Rpb24gd3JhcFRyYW5zcG9ydFNlbmQodHJhbnNwb3J0KSB7XG4gIGlmICh0cmFuc3BvcnQuc2VuZCkge1xuICAgIG9iamVjdC5maWxsKHRyYW5zcG9ydCwgJ3NlbmQnLCBvcmlnaW5hbFNlbmQgPT4ge1xuICAgICAgcmV0dXJuIGFzeW5jIGZ1bmN0aW9uICggLi4uYXJncykge1xuICAgICAgICBjb25zdCBbbWVzc2FnZV0gPSBhcmdzO1xuXG4gICAgICAgIGlmICh2YWxpZGF0aW9uLmlzSnNvblJwY05vdGlmaWNhdGlvbihtZXNzYWdlKSkge1xuICAgICAgICAgIHJldHVybiBzcGFucy5jcmVhdGVNY3BPdXRnb2luZ05vdGlmaWNhdGlvblNwYW4obWVzc2FnZSwgdGhpcywgKCkgPT4ge1xuICAgICAgICAgICAgcmV0dXJuIChvcmlnaW5hbFNlbmQgKS5jYWxsKHRoaXMsIC4uLmFyZ3MpO1xuICAgICAgICAgIH0pO1xuICAgICAgICB9XG5cbiAgICAgICAgaWYgKHZhbGlkYXRpb24uaXNKc29uUnBjUmVzcG9uc2UobWVzc2FnZSkpIHtcbiAgICAgICAgICBpZiAobWVzc2FnZS5pZCAhPT0gbnVsbCAmJiBtZXNzYWdlLmlkICE9PSB1bmRlZmluZWQpIHtcbiAgICAgICAgICAgIGlmIChtZXNzYWdlLmVycm9yKSB7XG4gICAgICAgICAgICAgIGNhcHR1cmVKc29uUnBjRXJyb3JSZXNwb25zZShtZXNzYWdlLmVycm9yKTtcbiAgICAgICAgICAgIH1cblxuICAgICAgICAgICAgaWYgKHZhbGlkYXRpb24uaXNWYWxpZENvbnRlbnRJdGVtKG1lc3NhZ2UucmVzdWx0KSkge1xuICAgICAgICAgICAgICBpZiAobWVzc2FnZS5yZXN1bHQucHJvdG9jb2xWZXJzaW9uIHx8IG1lc3NhZ2UucmVzdWx0LnNlcnZlckluZm8pIHtcbiAgICAgICAgICAgICAgICB0cnkge1xuICAgICAgICAgICAgICAgICAgY29uc3Qgc2VydmVyRGF0YSA9IHNlc3Npb25FeHRyYWN0aW9uLmV4dHJhY3RTZXNzaW9uRGF0YUZyb21Jbml0aWFsaXplUmVzcG9uc2UobWVzc2FnZS5yZXN1bHQpO1xuICAgICAgICAgICAgICAgICAgc2Vzc2lvbk1hbmFnZW1lbnQudXBkYXRlU2Vzc2lvbkRhdGFGb3JUcmFuc3BvcnQodGhpcywgc2VydmVyRGF0YSk7XG4gICAgICAgICAgICAgICAgfSBjYXRjaCB7XG4gICAgICAgICAgICAgICAgICAvLyBub29wXG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICB9XG4gICAgICAgICAgICB9XG5cbiAgICAgICAgICAgIGNvcnJlbGF0aW9uLmNvbXBsZXRlU3BhbldpdGhSZXN1bHRzKHRoaXMsIG1lc3NhZ2UuaWQsIG1lc3NhZ2UucmVzdWx0KTtcbiAgICAgICAgICB9XG4gICAgICAgIH1cblxuICAgICAgICByZXR1cm4gKG9yaWdpbmFsU2VuZCApLmNhbGwodGhpcywgLi4uYXJncyk7XG4gICAgICB9O1xuICAgIH0pO1xuICB9XG59XG5cbi8qKlxuICogV3JhcHMgdHJhbnNwb3J0Lm9uY2xvc2UgdG8gY2xlYW4gdXAgcGVuZGluZyBzcGFucyBmb3IgdGhpcyB0cmFuc3BvcnQgb25seVxuICogQHBhcmFtIHRyYW5zcG9ydCAtIE1DUCB0cmFuc3BvcnQgaW5zdGFuY2UgdG8gd3JhcFxuICovXG5mdW5jdGlvbiB3cmFwVHJhbnNwb3J0T25DbG9zZSh0cmFuc3BvcnQpIHtcbiAgaWYgKHRyYW5zcG9ydC5vbmNsb3NlKSB7XG4gICAgb2JqZWN0LmZpbGwodHJhbnNwb3J0LCAnb25jbG9zZScsIG9yaWdpbmFsT25DbG9zZSA9PiB7XG4gICAgICByZXR1cm4gZnVuY3Rpb24gKCAuLi5hcmdzKSB7XG4gICAgICAgIGNvcnJlbGF0aW9uLmNsZWFudXBQZW5kaW5nU3BhbnNGb3JUcmFuc3BvcnQodGhpcyk7XG4gICAgICAgIHNlc3Npb25NYW5hZ2VtZW50LmNsZWFudXBTZXNzaW9uRGF0YUZvclRyYW5zcG9ydCh0aGlzKTtcbiAgICAgICAgcmV0dXJuIChvcmlnaW5hbE9uQ2xvc2UgKS5jYWxsKHRoaXMsIC4uLmFyZ3MpO1xuICAgICAgfTtcbiAgICB9KTtcbiAgfVxufVxuXG4vKipcbiAqIFdyYXBzIHRyYW5zcG9ydCBlcnJvciBoYW5kbGVycyB0byBjYXB0dXJlIGNvbm5lY3Rpb24gZXJyb3JzXG4gKiBAcGFyYW0gdHJhbnNwb3J0IC0gTUNQIHRyYW5zcG9ydCBpbnN0YW5jZSB0byB3cmFwXG4gKi9cbmZ1bmN0aW9uIHdyYXBUcmFuc3BvcnRFcnJvcih0cmFuc3BvcnQpIHtcbiAgaWYgKHRyYW5zcG9ydC5vbmVycm9yKSB7XG4gICAgb2JqZWN0LmZpbGwodHJhbnNwb3J0LCAnb25lcnJvcicsIChvcmlnaW5hbE9uRXJyb3IpID0+IHtcbiAgICAgIHJldHVybiBmdW5jdGlvbiAoIGVycm9yKSB7XG4gICAgICAgIGNhcHR1cmVUcmFuc3BvcnRFcnJvcihlcnJvcik7XG4gICAgICAgIHJldHVybiBvcmlnaW5hbE9uRXJyb3IuY2FsbCh0aGlzLCBlcnJvcik7XG4gICAgICB9O1xuICAgIH0pO1xuICB9XG59XG5cbi8qKlxuICogQ2FwdHVyZXMgSlNPTi1SUEMgZXJyb3IgcmVzcG9uc2VzIGZvciBzZXJ2ZXItc2lkZSBlcnJvcnMuXG4gKiBAc2VlIGh0dHBzOi8vd3d3Lmpzb25ycGMub3JnL3NwZWNpZmljYXRpb24jZXJyb3Jfb2JqZWN0XG4gKiBAaW50ZXJuYWxcbiAqIEBwYXJhbSBlcnJvclJlc3BvbnNlIC0gSlNPTi1SUEMgZXJyb3IgcmVzcG9uc2VcbiAqL1xuZnVuY3Rpb24gY2FwdHVyZUpzb25ScGNFcnJvclJlc3BvbnNlKGVycm9yUmVzcG9uc2UpIHtcbiAgdHJ5IHtcbiAgICBpZiAoZXJyb3JSZXNwb25zZSAmJiB0eXBlb2YgZXJyb3JSZXNwb25zZSA9PT0gJ29iamVjdCcgJiYgJ2NvZGUnIGluIGVycm9yUmVzcG9uc2UgJiYgJ21lc3NhZ2UnIGluIGVycm9yUmVzcG9uc2UpIHtcbiAgICAgIGNvbnN0IGpzb25ScGNFcnJvciA9IGVycm9yUmVzcG9uc2UgO1xuXG4gICAgICBjb25zdCBpc1NlcnZlckVycm9yID1cbiAgICAgICAganNvblJwY0Vycm9yLmNvZGUgPT09IC0zMjYwMyB8fCAoanNvblJwY0Vycm9yLmNvZGUgPj0gLTMyMDk5ICYmIGpzb25ScGNFcnJvci5jb2RlIDw9IC0zMjAwMCk7XG5cbiAgICAgIGlmIChpc1NlcnZlckVycm9yKSB7XG4gICAgICAgIGNvbnN0IGVycm9yID0gbmV3IEVycm9yKGpzb25ScGNFcnJvci5tZXNzYWdlKTtcbiAgICAgICAgZXJyb3IubmFtZSA9IGBKc29uUnBjRXJyb3JfJHtqc29uUnBjRXJyb3IuY29kZX1gO1xuXG4gICAgICAgIGVycm9yQ2FwdHVyZS5jYXB0dXJlRXJyb3IoZXJyb3IsICdwcm90b2NvbCcpO1xuICAgICAgfVxuICAgIH1cbiAgfSBjYXRjaCB7XG4gICAgLy8gbm9vcFxuICB9XG59XG5cbi8qKlxuICogQ2FwdHVyZXMgdHJhbnNwb3J0IGNvbm5lY3Rpb24gZXJyb3JzXG4gKiBAaW50ZXJuYWxcbiAqIEBwYXJhbSBlcnJvciAtIFRyYW5zcG9ydCBlcnJvclxuICovXG5mdW5jdGlvbiBjYXB0dXJlVHJhbnNwb3J0RXJyb3IoZXJyb3IpIHtcbiAgdHJ5IHtcbiAgICBlcnJvckNhcHR1cmUuY2FwdHVyZUVycm9yKGVycm9yLCAndHJhbnNwb3J0Jyk7XG4gIH0gY2F0Y2gge1xuICAgIC8vIG5vb3BcbiAgfVxufVxuXG5leHBvcnRzLndyYXBUcmFuc3BvcnRFcnJvciA9IHdyYXBUcmFuc3BvcnRFcnJvcjtcbmV4cG9ydHMud3JhcFRyYW5zcG9ydE9uQ2xvc2UgPSB3cmFwVHJhbnNwb3J0T25DbG9zZTtcbmV4cG9ydHMud3JhcFRyYW5zcG9ydE9uTWVzc2FnZSA9IHdyYXBUcmFuc3BvcnRPbk1lc3NhZ2U7XG5leHBvcnRzLndyYXBUcmFuc3BvcnRTZW5kID0gd3JhcFRyYW5zcG9ydFNlbmQ7XG4vLyMgc291cmNlTWFwcGluZ1VSTD10cmFuc3BvcnQuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/transport.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/validation.js":
/*!**************************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/validation.js ***!
  \**************************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst debugBuild = __webpack_require__(/*! ../../debug-build.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst debugLogger = __webpack_require__(/*! ../../utils/debug-logger.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\n\n/**\n * Message validation functions for MCP server instrumentation\n *\n * Provides JSON-RPC 2.0 message type validation and MCP server instance validation.\n */\n\n\n/**\n * Validates if a message is a JSON-RPC request\n * @param message - Message to validate\n * @returns True if message is a JSON-RPC request\n */\nfunction isJsonRpcRequest(message) {\n  return (\n    typeof message === 'object' &&\n    message !== null &&\n    'jsonrpc' in message &&\n    (message ).jsonrpc === '2.0' &&\n    'method' in message &&\n    'id' in message\n  );\n}\n\n/**\n * Validates if a message is a JSON-RPC notification\n * @param message - Message to validate\n * @returns True if message is a JSON-RPC notification\n */\nfunction isJsonRpcNotification(message) {\n  return (\n    typeof message === 'object' &&\n    message !== null &&\n    'jsonrpc' in message &&\n    (message ).jsonrpc === '2.0' &&\n    'method' in message &&\n    !('id' in message)\n  );\n}\n\n/**\n * Validates if a message is a JSON-RPC response\n * @param message - Message to validate\n * @returns True if message is a JSON-RPC response\n */\nfunction isJsonRpcResponse(message) {\n  return (\n    typeof message === 'object' &&\n    message !== null &&\n    'jsonrpc' in message &&\n    (message ).jsonrpc === '2.0' &&\n    'id' in message &&\n    ('result' in message || 'error' in message)\n  );\n}\n\n/**\n * Validates MCP server instance with type checking\n * @param instance - Object to validate as MCP server instance\n * @returns True if instance has required MCP server methods\n */\nfunction validateMcpServerInstance(instance) {\n  if (\n    typeof instance === 'object' &&\n    instance !== null &&\n    'resource' in instance &&\n    'tool' in instance &&\n    'prompt' in instance &&\n    'connect' in instance\n  ) {\n    return true;\n  }\n  debugBuild.DEBUG_BUILD && debugLogger.debug.warn('Did not patch MCP server. Interface is incompatible.');\n  return false;\n}\n\n/**\n * Check if the item is a valid content item\n * @param item - The item to check\n * @returns True if the item is a valid content item, false otherwise\n */\nfunction isValidContentItem(item) {\n  return item != null && typeof item === 'object';\n}\n\nexports.isJsonRpcNotification = isJsonRpcNotification;\nexports.isJsonRpcRequest = isJsonRpcRequest;\nexports.isJsonRpcResponse = isJsonRpcResponse;\nexports.isValidContentItem = isValidContentItem;\nexports.validateMcpServerInstance = validateMcpServerInstance;\n//# sourceMappingURL=validation.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvbWNwLXNlcnZlci92YWxpZGF0aW9uLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLG1CQUFtQixtQkFBTyxDQUFDLCtIQUFzQjtBQUNqRCxvQkFBb0IsbUJBQU8sQ0FBQyw2SUFBNkI7O0FBRXpEO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7OztBQUdBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsNkJBQTZCO0FBQzdCLHdCQUF3QjtBQUN4Qix5QkFBeUI7QUFDekIsMEJBQTBCO0FBQzFCLGlDQUFpQztBQUNqQyIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL2ludGVncmF0aW9ucy9tY3Atc2VydmVyL3ZhbGlkYXRpb24uanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGRlYnVnQnVpbGQgPSByZXF1aXJlKCcuLi8uLi9kZWJ1Zy1idWlsZC5qcycpO1xuY29uc3QgZGVidWdMb2dnZXIgPSByZXF1aXJlKCcuLi8uLi91dGlscy9kZWJ1Zy1sb2dnZXIuanMnKTtcblxuLyoqXG4gKiBNZXNzYWdlIHZhbGlkYXRpb24gZnVuY3Rpb25zIGZvciBNQ1Agc2VydmVyIGluc3RydW1lbnRhdGlvblxuICpcbiAqIFByb3ZpZGVzIEpTT04tUlBDIDIuMCBtZXNzYWdlIHR5cGUgdmFsaWRhdGlvbiBhbmQgTUNQIHNlcnZlciBpbnN0YW5jZSB2YWxpZGF0aW9uLlxuICovXG5cblxuLyoqXG4gKiBWYWxpZGF0ZXMgaWYgYSBtZXNzYWdlIGlzIGEgSlNPTi1SUEMgcmVxdWVzdFxuICogQHBhcmFtIG1lc3NhZ2UgLSBNZXNzYWdlIHRvIHZhbGlkYXRlXG4gKiBAcmV0dXJucyBUcnVlIGlmIG1lc3NhZ2UgaXMgYSBKU09OLVJQQyByZXF1ZXN0XG4gKi9cbmZ1bmN0aW9uIGlzSnNvblJwY1JlcXVlc3QobWVzc2FnZSkge1xuICByZXR1cm4gKFxuICAgIHR5cGVvZiBtZXNzYWdlID09PSAnb2JqZWN0JyAmJlxuICAgIG1lc3NhZ2UgIT09IG51bGwgJiZcbiAgICAnanNvbnJwYycgaW4gbWVzc2FnZSAmJlxuICAgIChtZXNzYWdlICkuanNvbnJwYyA9PT0gJzIuMCcgJiZcbiAgICAnbWV0aG9kJyBpbiBtZXNzYWdlICYmXG4gICAgJ2lkJyBpbiBtZXNzYWdlXG4gICk7XG59XG5cbi8qKlxuICogVmFsaWRhdGVzIGlmIGEgbWVzc2FnZSBpcyBhIEpTT04tUlBDIG5vdGlmaWNhdGlvblxuICogQHBhcmFtIG1lc3NhZ2UgLSBNZXNzYWdlIHRvIHZhbGlkYXRlXG4gKiBAcmV0dXJucyBUcnVlIGlmIG1lc3NhZ2UgaXMgYSBKU09OLVJQQyBub3RpZmljYXRpb25cbiAqL1xuZnVuY3Rpb24gaXNKc29uUnBjTm90aWZpY2F0aW9uKG1lc3NhZ2UpIHtcbiAgcmV0dXJuIChcbiAgICB0eXBlb2YgbWVzc2FnZSA9PT0gJ29iamVjdCcgJiZcbiAgICBtZXNzYWdlICE9PSBudWxsICYmXG4gICAgJ2pzb25ycGMnIGluIG1lc3NhZ2UgJiZcbiAgICAobWVzc2FnZSApLmpzb25ycGMgPT09ICcyLjAnICYmXG4gICAgJ21ldGhvZCcgaW4gbWVzc2FnZSAmJlxuICAgICEoJ2lkJyBpbiBtZXNzYWdlKVxuICApO1xufVxuXG4vKipcbiAqIFZhbGlkYXRlcyBpZiBhIG1lc3NhZ2UgaXMgYSBKU09OLVJQQyByZXNwb25zZVxuICogQHBhcmFtIG1lc3NhZ2UgLSBNZXNzYWdlIHRvIHZhbGlkYXRlXG4gKiBAcmV0dXJucyBUcnVlIGlmIG1lc3NhZ2UgaXMgYSBKU09OLVJQQyByZXNwb25zZVxuICovXG5mdW5jdGlvbiBpc0pzb25ScGNSZXNwb25zZShtZXNzYWdlKSB7XG4gIHJldHVybiAoXG4gICAgdHlwZW9mIG1lc3NhZ2UgPT09ICdvYmplY3QnICYmXG4gICAgbWVzc2FnZSAhPT0gbnVsbCAmJlxuICAgICdqc29ucnBjJyBpbiBtZXNzYWdlICYmXG4gICAgKG1lc3NhZ2UgKS5qc29ucnBjID09PSAnMi4wJyAmJlxuICAgICdpZCcgaW4gbWVzc2FnZSAmJlxuICAgICgncmVzdWx0JyBpbiBtZXNzYWdlIHx8ICdlcnJvcicgaW4gbWVzc2FnZSlcbiAgKTtcbn1cblxuLyoqXG4gKiBWYWxpZGF0ZXMgTUNQIHNlcnZlciBpbnN0YW5jZSB3aXRoIHR5cGUgY2hlY2tpbmdcbiAqIEBwYXJhbSBpbnN0YW5jZSAtIE9iamVjdCB0byB2YWxpZGF0ZSBhcyBNQ1Agc2VydmVyIGluc3RhbmNlXG4gKiBAcmV0dXJucyBUcnVlIGlmIGluc3RhbmNlIGhhcyByZXF1aXJlZCBNQ1Agc2VydmVyIG1ldGhvZHNcbiAqL1xuZnVuY3Rpb24gdmFsaWRhdGVNY3BTZXJ2ZXJJbnN0YW5jZShpbnN0YW5jZSkge1xuICBpZiAoXG4gICAgdHlwZW9mIGluc3RhbmNlID09PSAnb2JqZWN0JyAmJlxuICAgIGluc3RhbmNlICE9PSBudWxsICYmXG4gICAgJ3Jlc291cmNlJyBpbiBpbnN0YW5jZSAmJlxuICAgICd0b29sJyBpbiBpbnN0YW5jZSAmJlxuICAgICdwcm9tcHQnIGluIGluc3RhbmNlICYmXG4gICAgJ2Nvbm5lY3QnIGluIGluc3RhbmNlXG4gICkge1xuICAgIHJldHVybiB0cnVlO1xuICB9XG4gIGRlYnVnQnVpbGQuREVCVUdfQlVJTEQgJiYgZGVidWdMb2dnZXIuZGVidWcud2FybignRGlkIG5vdCBwYXRjaCBNQ1Agc2VydmVyLiBJbnRlcmZhY2UgaXMgaW5jb21wYXRpYmxlLicpO1xuICByZXR1cm4gZmFsc2U7XG59XG5cbi8qKlxuICogQ2hlY2sgaWYgdGhlIGl0ZW0gaXMgYSB2YWxpZCBjb250ZW50IGl0ZW1cbiAqIEBwYXJhbSBpdGVtIC0gVGhlIGl0ZW0gdG8gY2hlY2tcbiAqIEByZXR1cm5zIFRydWUgaWYgdGhlIGl0ZW0gaXMgYSB2YWxpZCBjb250ZW50IGl0ZW0sIGZhbHNlIG90aGVyd2lzZVxuICovXG5mdW5jdGlvbiBpc1ZhbGlkQ29udGVudEl0ZW0oaXRlbSkge1xuICByZXR1cm4gaXRlbSAhPSBudWxsICYmIHR5cGVvZiBpdGVtID09PSAnb2JqZWN0Jztcbn1cblxuZXhwb3J0cy5pc0pzb25ScGNOb3RpZmljYXRpb24gPSBpc0pzb25ScGNOb3RpZmljYXRpb247XG5leHBvcnRzLmlzSnNvblJwY1JlcXVlc3QgPSBpc0pzb25ScGNSZXF1ZXN0O1xuZXhwb3J0cy5pc0pzb25ScGNSZXNwb25zZSA9IGlzSnNvblJwY1Jlc3BvbnNlO1xuZXhwb3J0cy5pc1ZhbGlkQ29udGVudEl0ZW0gPSBpc1ZhbGlkQ29udGVudEl0ZW07XG5leHBvcnRzLnZhbGlkYXRlTWNwU2VydmVySW5zdGFuY2UgPSB2YWxpZGF0ZU1jcFNlcnZlckluc3RhbmNlO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9dmFsaWRhdGlvbi5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/mcp-server/validation.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/metadata.js":
/*!*************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/metadata.js ***!
  \*************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst integration = __webpack_require__(/*! ../integration.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integration.js\");\nconst metadata = __webpack_require__(/*! ../metadata.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/metadata.js\");\nconst envelope = __webpack_require__(/*! ../utils/envelope.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/envelope.js\");\n\n/**\n * Adds module metadata to stack frames.\n *\n * Metadata can be injected by the Sentry bundler plugins using the `moduleMetadata` config option.\n *\n * When this integration is added, the metadata passed to the bundler plugin is added to the stack frames of all events\n * under the `module_metadata` property. This can be used to help in tagging or routing of events from different teams\n * our sources\n */\nconst moduleMetadataIntegration = integration.defineIntegration(() => {\n  return {\n    name: 'ModuleMetadata',\n    setup(client) {\n      // We need to strip metadata from stack frames before sending them to Sentry since these are client side only.\n      client.on('beforeEnvelope', envelope$1 => {\n        envelope.forEachEnvelopeItem(envelope$1, (item, type) => {\n          if (type === 'event') {\n            const event = Array.isArray(item) ? (item )[1] : undefined;\n\n            if (event) {\n              metadata.stripMetadataFromStackFrames(event);\n              item[1] = event;\n            }\n          }\n        });\n      });\n\n      client.on('applyFrameMetadata', event => {\n        // Only apply stack frame metadata to error events\n        if (event.type) {\n          return;\n        }\n\n        const stackParser = client.getOptions().stackParser;\n        metadata.addMetadataToStackFrames(stackParser, event);\n      });\n    },\n  };\n});\n\nexports.moduleMetadataIntegration = moduleMetadataIntegration;\n//# sourceMappingURL=metadata.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvbWV0YWRhdGEuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsb0JBQW9CLG1CQUFPLENBQUMsNEhBQW1CO0FBQy9DLGlCQUFpQixtQkFBTyxDQUFDLHNIQUFnQjtBQUN6QyxpQkFBaUIsbUJBQU8sQ0FBQyxrSUFBc0I7O0FBRS9DO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsU0FBUztBQUNULE9BQU87O0FBRVA7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsT0FBTztBQUNQLEtBQUs7QUFDTDtBQUNBLENBQUM7O0FBRUQsaUNBQWlDO0FBQ2pDIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvaW50ZWdyYXRpb25zL21ldGFkYXRhLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBpbnRlZ3JhdGlvbiA9IHJlcXVpcmUoJy4uL2ludGVncmF0aW9uLmpzJyk7XG5jb25zdCBtZXRhZGF0YSA9IHJlcXVpcmUoJy4uL21ldGFkYXRhLmpzJyk7XG5jb25zdCBlbnZlbG9wZSA9IHJlcXVpcmUoJy4uL3V0aWxzL2VudmVsb3BlLmpzJyk7XG5cbi8qKlxuICogQWRkcyBtb2R1bGUgbWV0YWRhdGEgdG8gc3RhY2sgZnJhbWVzLlxuICpcbiAqIE1ldGFkYXRhIGNhbiBiZSBpbmplY3RlZCBieSB0aGUgU2VudHJ5IGJ1bmRsZXIgcGx1Z2lucyB1c2luZyB0aGUgYG1vZHVsZU1ldGFkYXRhYCBjb25maWcgb3B0aW9uLlxuICpcbiAqIFdoZW4gdGhpcyBpbnRlZ3JhdGlvbiBpcyBhZGRlZCwgdGhlIG1ldGFkYXRhIHBhc3NlZCB0byB0aGUgYnVuZGxlciBwbHVnaW4gaXMgYWRkZWQgdG8gdGhlIHN0YWNrIGZyYW1lcyBvZiBhbGwgZXZlbnRzXG4gKiB1bmRlciB0aGUgYG1vZHVsZV9tZXRhZGF0YWAgcHJvcGVydHkuIFRoaXMgY2FuIGJlIHVzZWQgdG8gaGVscCBpbiB0YWdnaW5nIG9yIHJvdXRpbmcgb2YgZXZlbnRzIGZyb20gZGlmZmVyZW50IHRlYW1zXG4gKiBvdXIgc291cmNlc1xuICovXG5jb25zdCBtb2R1bGVNZXRhZGF0YUludGVncmF0aW9uID0gaW50ZWdyYXRpb24uZGVmaW5lSW50ZWdyYXRpb24oKCkgPT4ge1xuICByZXR1cm4ge1xuICAgIG5hbWU6ICdNb2R1bGVNZXRhZGF0YScsXG4gICAgc2V0dXAoY2xpZW50KSB7XG4gICAgICAvLyBXZSBuZWVkIHRvIHN0cmlwIG1ldGFkYXRhIGZyb20gc3RhY2sgZnJhbWVzIGJlZm9yZSBzZW5kaW5nIHRoZW0gdG8gU2VudHJ5IHNpbmNlIHRoZXNlIGFyZSBjbGllbnQgc2lkZSBvbmx5LlxuICAgICAgY2xpZW50Lm9uKCdiZWZvcmVFbnZlbG9wZScsIGVudmVsb3BlJDEgPT4ge1xuICAgICAgICBlbnZlbG9wZS5mb3JFYWNoRW52ZWxvcGVJdGVtKGVudmVsb3BlJDEsIChpdGVtLCB0eXBlKSA9PiB7XG4gICAgICAgICAgaWYgKHR5cGUgPT09ICdldmVudCcpIHtcbiAgICAgICAgICAgIGNvbnN0IGV2ZW50ID0gQXJyYXkuaXNBcnJheShpdGVtKSA/IChpdGVtIClbMV0gOiB1bmRlZmluZWQ7XG5cbiAgICAgICAgICAgIGlmIChldmVudCkge1xuICAgICAgICAgICAgICBtZXRhZGF0YS5zdHJpcE1ldGFkYXRhRnJvbVN0YWNrRnJhbWVzKGV2ZW50KTtcbiAgICAgICAgICAgICAgaXRlbVsxXSA9IGV2ZW50O1xuICAgICAgICAgICAgfVxuICAgICAgICAgIH1cbiAgICAgICAgfSk7XG4gICAgICB9KTtcblxuICAgICAgY2xpZW50Lm9uKCdhcHBseUZyYW1lTWV0YWRhdGEnLCBldmVudCA9PiB7XG4gICAgICAgIC8vIE9ubHkgYXBwbHkgc3RhY2sgZnJhbWUgbWV0YWRhdGEgdG8gZXJyb3IgZXZlbnRzXG4gICAgICAgIGlmIChldmVudC50eXBlKSB7XG4gICAgICAgICAgcmV0dXJuO1xuICAgICAgICB9XG5cbiAgICAgICAgY29uc3Qgc3RhY2tQYXJzZXIgPSBjbGllbnQuZ2V0T3B0aW9ucygpLnN0YWNrUGFyc2VyO1xuICAgICAgICBtZXRhZGF0YS5hZGRNZXRhZGF0YVRvU3RhY2tGcmFtZXMoc3RhY2tQYXJzZXIsIGV2ZW50KTtcbiAgICAgIH0pO1xuICAgIH0sXG4gIH07XG59KTtcblxuZXhwb3J0cy5tb2R1bGVNZXRhZGF0YUludGVncmF0aW9uID0gbW9kdWxlTWV0YWRhdGFJbnRlZ3JhdGlvbjtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPW1ldGFkYXRhLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/metadata.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/requestdata.js":
/*!****************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/requestdata.js ***!
  \****************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst integration = __webpack_require__(/*! ../integration.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integration.js\");\nconst cookie = __webpack_require__(/*! ../utils/cookie.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/cookie.js\");\nconst getIpAddress = __webpack_require__(/*! ../vendor/getIpAddress.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/vendor/getIpAddress.js\");\n\n// TODO(v10): Change defaults based on `sendDefaultPii`\nconst DEFAULT_INCLUDE = {\n  cookies: true,\n  data: true,\n  headers: true,\n  query_string: true,\n  url: true,\n};\n\nconst INTEGRATION_NAME = 'RequestData';\n\nconst _requestDataIntegration = ((options = {}) => {\n  const include = {\n    ...DEFAULT_INCLUDE,\n    ...options.include,\n  };\n\n  return {\n    name: INTEGRATION_NAME,\n    processEvent(event, _hint, client) {\n      const { sdkProcessingMetadata = {} } = event;\n      const { normalizedRequest, ipAddress } = sdkProcessingMetadata;\n\n      const includeWithDefaultPiiApplied = {\n        ...include,\n        ip: include.ip ?? client.getOptions().sendDefaultPii,\n      };\n\n      if (normalizedRequest) {\n        addNormalizedRequestDataToEvent(event, normalizedRequest, { ipAddress }, includeWithDefaultPiiApplied);\n      }\n\n      return event;\n    },\n  };\n}) ;\n\n/**\n * Add data about a request to an event. Primarily for use in Node-based SDKs, but included in `@sentry/core`\n * so it can be used in cross-platform SDKs like `@sentry/nextjs`.\n */\nconst requestDataIntegration = integration.defineIntegration(_requestDataIntegration);\n\n/**\n * Add already normalized request data to an event.\n * This mutates the passed in event.\n */\nfunction addNormalizedRequestDataToEvent(\n  event,\n  req,\n  // Data that should not go into `event.request` but is somehow related to requests\n  additionalData,\n  include,\n) {\n  event.request = {\n    ...event.request,\n    ...extractNormalizedRequestData(req, include),\n  };\n\n  if (include.ip) {\n    const ip = (req.headers && getIpAddress.getClientIPAddress(req.headers)) || additionalData.ipAddress;\n    if (ip) {\n      event.user = {\n        ...event.user,\n        ip_address: ip,\n      };\n    }\n  }\n}\n\nfunction extractNormalizedRequestData(\n  normalizedRequest,\n  include,\n) {\n  const requestData = {};\n  const headers = { ...normalizedRequest.headers };\n\n  if (include.headers) {\n    requestData.headers = headers;\n\n    // Remove the Cookie header in case cookie data should not be included in the event\n    if (!include.cookies) {\n      delete (headers ).cookie;\n    }\n\n    // Remove IP headers in case IP data should not be included in the event\n    if (!include.ip) {\n      getIpAddress.ipHeaderNames.forEach(ipHeaderName => {\n        // eslint-disable-next-line @typescript-eslint/no-dynamic-delete\n        delete (headers )[ipHeaderName];\n      });\n    }\n  }\n\n  requestData.method = normalizedRequest.method;\n\n  if (include.url) {\n    requestData.url = normalizedRequest.url;\n  }\n\n  if (include.cookies) {\n    const cookies = normalizedRequest.cookies || (headers?.cookie ? cookie.parseCookie(headers.cookie) : undefined);\n    requestData.cookies = cookies || {};\n  }\n\n  if (include.query_string) {\n    requestData.query_string = normalizedRequest.query_string;\n  }\n\n  if (include.data) {\n    requestData.data = normalizedRequest.data;\n  }\n\n  return requestData;\n}\n\nexports.requestDataIntegration = requestDataIntegration;\n//# sourceMappingURL=requestdata.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvcmVxdWVzdGRhdGEuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsb0JBQW9CLG1CQUFPLENBQUMsNEhBQW1CO0FBQy9DLGVBQWUsbUJBQU8sQ0FBQyw4SEFBb0I7QUFDM0MscUJBQXFCLG1CQUFPLENBQUMsNElBQTJCOztBQUV4RDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBOztBQUVBLDhDQUE4QztBQUM5QztBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQSxjQUFjLDZCQUE2QjtBQUMzQyxjQUFjLCtCQUErQjs7QUFFN0M7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQSxvRUFBb0UsV0FBVztBQUMvRTs7QUFFQTtBQUNBLEtBQUs7QUFDTDtBQUNBLENBQUM7O0FBRUQ7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLG9CQUFvQjs7QUFFcEI7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsT0FBTztBQUNQO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQSw4QkFBOEI7QUFDOUIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvcmVxdWVzdGRhdGEuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGludGVncmF0aW9uID0gcmVxdWlyZSgnLi4vaW50ZWdyYXRpb24uanMnKTtcbmNvbnN0IGNvb2tpZSA9IHJlcXVpcmUoJy4uL3V0aWxzL2Nvb2tpZS5qcycpO1xuY29uc3QgZ2V0SXBBZGRyZXNzID0gcmVxdWlyZSgnLi4vdmVuZG9yL2dldElwQWRkcmVzcy5qcycpO1xuXG4vLyBUT0RPKHYxMCk6IENoYW5nZSBkZWZhdWx0cyBiYXNlZCBvbiBgc2VuZERlZmF1bHRQaWlgXG5jb25zdCBERUZBVUxUX0lOQ0xVREUgPSB7XG4gIGNvb2tpZXM6IHRydWUsXG4gIGRhdGE6IHRydWUsXG4gIGhlYWRlcnM6IHRydWUsXG4gIHF1ZXJ5X3N0cmluZzogdHJ1ZSxcbiAgdXJsOiB0cnVlLFxufTtcblxuY29uc3QgSU5URUdSQVRJT05fTkFNRSA9ICdSZXF1ZXN0RGF0YSc7XG5cbmNvbnN0IF9yZXF1ZXN0RGF0YUludGVncmF0aW9uID0gKChvcHRpb25zID0ge30pID0+IHtcbiAgY29uc3QgaW5jbHVkZSA9IHtcbiAgICAuLi5ERUZBVUxUX0lOQ0xVREUsXG4gICAgLi4ub3B0aW9ucy5pbmNsdWRlLFxuICB9O1xuXG4gIHJldHVybiB7XG4gICAgbmFtZTogSU5URUdSQVRJT05fTkFNRSxcbiAgICBwcm9jZXNzRXZlbnQoZXZlbnQsIF9oaW50LCBjbGllbnQpIHtcbiAgICAgIGNvbnN0IHsgc2RrUHJvY2Vzc2luZ01ldGFkYXRhID0ge30gfSA9IGV2ZW50O1xuICAgICAgY29uc3QgeyBub3JtYWxpemVkUmVxdWVzdCwgaXBBZGRyZXNzIH0gPSBzZGtQcm9jZXNzaW5nTWV0YWRhdGE7XG5cbiAgICAgIGNvbnN0IGluY2x1ZGVXaXRoRGVmYXVsdFBpaUFwcGxpZWQgPSB7XG4gICAgICAgIC4uLmluY2x1ZGUsXG4gICAgICAgIGlwOiBpbmNsdWRlLmlwID8/IGNsaWVudC5nZXRPcHRpb25zKCkuc2VuZERlZmF1bHRQaWksXG4gICAgICB9O1xuXG4gICAgICBpZiAobm9ybWFsaXplZFJlcXVlc3QpIHtcbiAgICAgICAgYWRkTm9ybWFsaXplZFJlcXVlc3REYXRhVG9FdmVudChldmVudCwgbm9ybWFsaXplZFJlcXVlc3QsIHsgaXBBZGRyZXNzIH0sIGluY2x1ZGVXaXRoRGVmYXVsdFBpaUFwcGxpZWQpO1xuICAgICAgfVxuXG4gICAgICByZXR1cm4gZXZlbnQ7XG4gICAgfSxcbiAgfTtcbn0pIDtcblxuLyoqXG4gKiBBZGQgZGF0YSBhYm91dCBhIHJlcXVlc3QgdG8gYW4gZXZlbnQuIFByaW1hcmlseSBmb3IgdXNlIGluIE5vZGUtYmFzZWQgU0RLcywgYnV0IGluY2x1ZGVkIGluIGBAc2VudHJ5L2NvcmVgXG4gKiBzbyBpdCBjYW4gYmUgdXNlZCBpbiBjcm9zcy1wbGF0Zm9ybSBTREtzIGxpa2UgYEBzZW50cnkvbmV4dGpzYC5cbiAqL1xuY29uc3QgcmVxdWVzdERhdGFJbnRlZ3JhdGlvbiA9IGludGVncmF0aW9uLmRlZmluZUludGVncmF0aW9uKF9yZXF1ZXN0RGF0YUludGVncmF0aW9uKTtcblxuLyoqXG4gKiBBZGQgYWxyZWFkeSBub3JtYWxpemVkIHJlcXVlc3QgZGF0YSB0byBhbiBldmVudC5cbiAqIFRoaXMgbXV0YXRlcyB0aGUgcGFzc2VkIGluIGV2ZW50LlxuICovXG5mdW5jdGlvbiBhZGROb3JtYWxpemVkUmVxdWVzdERhdGFUb0V2ZW50KFxuICBldmVudCxcbiAgcmVxLFxuICAvLyBEYXRhIHRoYXQgc2hvdWxkIG5vdCBnbyBpbnRvIGBldmVudC5yZXF1ZXN0YCBidXQgaXMgc29tZWhvdyByZWxhdGVkIHRvIHJlcXVlc3RzXG4gIGFkZGl0aW9uYWxEYXRhLFxuICBpbmNsdWRlLFxuKSB7XG4gIGV2ZW50LnJlcXVlc3QgPSB7XG4gICAgLi4uZXZlbnQucmVxdWVzdCxcbiAgICAuLi5leHRyYWN0Tm9ybWFsaXplZFJlcXVlc3REYXRhKHJlcSwgaW5jbHVkZSksXG4gIH07XG5cbiAgaWYgKGluY2x1ZGUuaXApIHtcbiAgICBjb25zdCBpcCA9IChyZXEuaGVhZGVycyAmJiBnZXRJcEFkZHJlc3MuZ2V0Q2xpZW50SVBBZGRyZXNzKHJlcS5oZWFkZXJzKSkgfHwgYWRkaXRpb25hbERhdGEuaXBBZGRyZXNzO1xuICAgIGlmIChpcCkge1xuICAgICAgZXZlbnQudXNlciA9IHtcbiAgICAgICAgLi4uZXZlbnQudXNlcixcbiAgICAgICAgaXBfYWRkcmVzczogaXAsXG4gICAgICB9O1xuICAgIH1cbiAgfVxufVxuXG5mdW5jdGlvbiBleHRyYWN0Tm9ybWFsaXplZFJlcXVlc3REYXRhKFxuICBub3JtYWxpemVkUmVxdWVzdCxcbiAgaW5jbHVkZSxcbikge1xuICBjb25zdCByZXF1ZXN0RGF0YSA9IHt9O1xuICBjb25zdCBoZWFkZXJzID0geyAuLi5ub3JtYWxpemVkUmVxdWVzdC5oZWFkZXJzIH07XG5cbiAgaWYgKGluY2x1ZGUuaGVhZGVycykge1xuICAgIHJlcXVlc3REYXRhLmhlYWRlcnMgPSBoZWFkZXJzO1xuXG4gICAgLy8gUmVtb3ZlIHRoZSBDb29raWUgaGVhZGVyIGluIGNhc2UgY29va2llIGRhdGEgc2hvdWxkIG5vdCBiZSBpbmNsdWRlZCBpbiB0aGUgZXZlbnRcbiAgICBpZiAoIWluY2x1ZGUuY29va2llcykge1xuICAgICAgZGVsZXRlIChoZWFkZXJzICkuY29va2llO1xuICAgIH1cblxuICAgIC8vIFJlbW92ZSBJUCBoZWFkZXJzIGluIGNhc2UgSVAgZGF0YSBzaG91bGQgbm90IGJlIGluY2x1ZGVkIGluIHRoZSBldmVudFxuICAgIGlmICghaW5jbHVkZS5pcCkge1xuICAgICAgZ2V0SXBBZGRyZXNzLmlwSGVhZGVyTmFtZXMuZm9yRWFjaChpcEhlYWRlck5hbWUgPT4ge1xuICAgICAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25vLWR5bmFtaWMtZGVsZXRlXG4gICAgICAgIGRlbGV0ZSAoaGVhZGVycyApW2lwSGVhZGVyTmFtZV07XG4gICAgICB9KTtcbiAgICB9XG4gIH1cblxuICByZXF1ZXN0RGF0YS5tZXRob2QgPSBub3JtYWxpemVkUmVxdWVzdC5tZXRob2Q7XG5cbiAgaWYgKGluY2x1ZGUudXJsKSB7XG4gICAgcmVxdWVzdERhdGEudXJsID0gbm9ybWFsaXplZFJlcXVlc3QudXJsO1xuICB9XG5cbiAgaWYgKGluY2x1ZGUuY29va2llcykge1xuICAgIGNvbnN0IGNvb2tpZXMgPSBub3JtYWxpemVkUmVxdWVzdC5jb29raWVzIHx8IChoZWFkZXJzPy5jb29raWUgPyBjb29raWUucGFyc2VDb29raWUoaGVhZGVycy5jb29raWUpIDogdW5kZWZpbmVkKTtcbiAgICByZXF1ZXN0RGF0YS5jb29raWVzID0gY29va2llcyB8fCB7fTtcbiAgfVxuXG4gIGlmIChpbmNsdWRlLnF1ZXJ5X3N0cmluZykge1xuICAgIHJlcXVlc3REYXRhLnF1ZXJ5X3N0cmluZyA9IG5vcm1hbGl6ZWRSZXF1ZXN0LnF1ZXJ5X3N0cmluZztcbiAgfVxuXG4gIGlmIChpbmNsdWRlLmRhdGEpIHtcbiAgICByZXF1ZXN0RGF0YS5kYXRhID0gbm9ybWFsaXplZFJlcXVlc3QuZGF0YTtcbiAgfVxuXG4gIHJldHVybiByZXF1ZXN0RGF0YTtcbn1cblxuZXhwb3J0cy5yZXF1ZXN0RGF0YUludGVncmF0aW9uID0gcmVxdWVzdERhdGFJbnRlZ3JhdGlvbjtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPXJlcXVlc3RkYXRhLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/requestdata.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/rewriteframes.js":
/*!******************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/rewriteframes.js ***!
  \******************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst integration = __webpack_require__(/*! ../integration.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integration.js\");\nconst path = __webpack_require__(/*! ../utils/path.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/path.js\");\nconst worldwide = __webpack_require__(/*! ../utils/worldwide.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/worldwide.js\");\n\nconst INTEGRATION_NAME = 'RewriteFrames';\n\n/**\n * Rewrite event frames paths.\n */\nconst rewriteFramesIntegration = integration.defineIntegration((options = {}) => {\n  const root = options.root;\n  const prefix = options.prefix || 'app:///';\n\n  const isBrowser = 'window' in worldwide.GLOBAL_OBJ && !!worldwide.GLOBAL_OBJ.window;\n\n  const iteratee = options.iteratee || generateIteratee({ isBrowser, root, prefix });\n\n  /** Process an exception event. */\n  function _processExceptionsEvent(event) {\n    try {\n      return {\n        ...event,\n        exception: {\n          ...event.exception,\n          // The check for this is performed inside `process` call itself, safe to skip here\n          // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n          values: event.exception.values.map(value => ({\n            ...value,\n            ...(value.stacktrace && { stacktrace: _processStacktrace(value.stacktrace) }),\n          })),\n        },\n      };\n    } catch {\n      return event;\n    }\n  }\n\n  /** Process a stack trace. */\n  function _processStacktrace(stacktrace) {\n    return {\n      ...stacktrace,\n      frames: stacktrace?.frames?.map(f => iteratee(f)),\n    };\n  }\n\n  return {\n    name: INTEGRATION_NAME,\n    processEvent(originalEvent) {\n      let processedEvent = originalEvent;\n\n      if (originalEvent.exception && Array.isArray(originalEvent.exception.values)) {\n        processedEvent = _processExceptionsEvent(processedEvent);\n      }\n\n      return processedEvent;\n    },\n  };\n});\n\n/**\n * Exported only for tests.\n */\nfunction generateIteratee({\n  isBrowser,\n  root,\n  prefix,\n}\n\n) {\n  return (frame) => {\n    if (!frame.filename) {\n      return frame;\n    }\n\n    // Determine if this is a Windows frame by checking for a Windows-style prefix such as `C:\\`\n    const isWindowsFrame =\n      /^[a-zA-Z]:\\\\/.test(frame.filename) ||\n      // or the presence of a backslash without a forward slash (which are not allowed on Windows)\n      (frame.filename.includes('\\\\') && !frame.filename.includes('/'));\n\n    // Check if the frame filename begins with `/`\n    const startsWithSlash = /^\\//.test(frame.filename);\n\n    if (isBrowser) {\n      if (root) {\n        const oldFilename = frame.filename;\n        if (oldFilename.indexOf(root) === 0) {\n          frame.filename = oldFilename.replace(root, prefix);\n        }\n      }\n    } else {\n      if (isWindowsFrame || startsWithSlash) {\n        const filename = isWindowsFrame\n          ? frame.filename\n              .replace(/^[a-zA-Z]:/, '') // remove Windows-style prefix\n              .replace(/\\\\/g, '/') // replace all `\\\\` instances with `/`\n          : frame.filename;\n        const base = root ? path.relative(root, filename) : path.basename(filename);\n        frame.filename = `${prefix}${base}`;\n      }\n    }\n\n    return frame;\n  };\n}\n\nexports.generateIteratee = generateIteratee;\nexports.rewriteFramesIntegration = rewriteFramesIntegration;\n//# sourceMappingURL=rewriteframes.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvcmV3cml0ZWZyYW1lcy5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxvQkFBb0IsbUJBQU8sQ0FBQyw0SEFBbUI7QUFDL0MsYUFBYSxtQkFBTyxDQUFDLDBIQUFrQjtBQUN2QyxrQkFBa0IsbUJBQU8sQ0FBQyxvSUFBdUI7O0FBRWpEOztBQUVBO0FBQ0E7QUFDQTtBQUNBLDRFQUE0RTtBQUM1RTtBQUNBOztBQUVBOztBQUVBLDBEQUEwRCx5QkFBeUI7O0FBRW5GO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxzQ0FBc0Msa0RBQWtEO0FBQ3hGLFdBQVc7QUFDWCxTQUFTO0FBQ1Q7QUFDQSxNQUFNO0FBQ047QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBLEtBQUs7QUFDTDtBQUNBLENBQUM7O0FBRUQ7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLE1BQU07QUFDTjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLDRCQUE0QixPQUFPLEVBQUUsS0FBSztBQUMxQztBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQSx3QkFBd0I7QUFDeEIsZ0NBQWdDO0FBQ2hDIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvaW50ZWdyYXRpb25zL3Jld3JpdGVmcmFtZXMuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGludGVncmF0aW9uID0gcmVxdWlyZSgnLi4vaW50ZWdyYXRpb24uanMnKTtcbmNvbnN0IHBhdGggPSByZXF1aXJlKCcuLi91dGlscy9wYXRoLmpzJyk7XG5jb25zdCB3b3JsZHdpZGUgPSByZXF1aXJlKCcuLi91dGlscy93b3JsZHdpZGUuanMnKTtcblxuY29uc3QgSU5URUdSQVRJT05fTkFNRSA9ICdSZXdyaXRlRnJhbWVzJztcblxuLyoqXG4gKiBSZXdyaXRlIGV2ZW50IGZyYW1lcyBwYXRocy5cbiAqL1xuY29uc3QgcmV3cml0ZUZyYW1lc0ludGVncmF0aW9uID0gaW50ZWdyYXRpb24uZGVmaW5lSW50ZWdyYXRpb24oKG9wdGlvbnMgPSB7fSkgPT4ge1xuICBjb25zdCByb290ID0gb3B0aW9ucy5yb290O1xuICBjb25zdCBwcmVmaXggPSBvcHRpb25zLnByZWZpeCB8fCAnYXBwOi8vLyc7XG5cbiAgY29uc3QgaXNCcm93c2VyID0gJ3dpbmRvdycgaW4gd29ybGR3aWRlLkdMT0JBTF9PQkogJiYgISF3b3JsZHdpZGUuR0xPQkFMX09CSi53aW5kb3c7XG5cbiAgY29uc3QgaXRlcmF0ZWUgPSBvcHRpb25zLml0ZXJhdGVlIHx8IGdlbmVyYXRlSXRlcmF0ZWUoeyBpc0Jyb3dzZXIsIHJvb3QsIHByZWZpeCB9KTtcblxuICAvKiogUHJvY2VzcyBhbiBleGNlcHRpb24gZXZlbnQuICovXG4gIGZ1bmN0aW9uIF9wcm9jZXNzRXhjZXB0aW9uc0V2ZW50KGV2ZW50KSB7XG4gICAgdHJ5IHtcbiAgICAgIHJldHVybiB7XG4gICAgICAgIC4uLmV2ZW50LFxuICAgICAgICBleGNlcHRpb246IHtcbiAgICAgICAgICAuLi5ldmVudC5leGNlcHRpb24sXG4gICAgICAgICAgLy8gVGhlIGNoZWNrIGZvciB0aGlzIGlzIHBlcmZvcm1lZCBpbnNpZGUgYHByb2Nlc3NgIGNhbGwgaXRzZWxmLCBzYWZlIHRvIHNraXAgaGVyZVxuICAgICAgICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tbm9uLW51bGwtYXNzZXJ0aW9uXG4gICAgICAgICAgdmFsdWVzOiBldmVudC5leGNlcHRpb24udmFsdWVzLm1hcCh2YWx1ZSA9PiAoe1xuICAgICAgICAgICAgLi4udmFsdWUsXG4gICAgICAgICAgICAuLi4odmFsdWUuc3RhY2t0cmFjZSAmJiB7IHN0YWNrdHJhY2U6IF9wcm9jZXNzU3RhY2t0cmFjZSh2YWx1ZS5zdGFja3RyYWNlKSB9KSxcbiAgICAgICAgICB9KSksXG4gICAgICAgIH0sXG4gICAgICB9O1xuICAgIH0gY2F0Y2gge1xuICAgICAgcmV0dXJuIGV2ZW50O1xuICAgIH1cbiAgfVxuXG4gIC8qKiBQcm9jZXNzIGEgc3RhY2sgdHJhY2UuICovXG4gIGZ1bmN0aW9uIF9wcm9jZXNzU3RhY2t0cmFjZShzdGFja3RyYWNlKSB7XG4gICAgcmV0dXJuIHtcbiAgICAgIC4uLnN0YWNrdHJhY2UsXG4gICAgICBmcmFtZXM6IHN0YWNrdHJhY2U/LmZyYW1lcz8ubWFwKGYgPT4gaXRlcmF0ZWUoZikpLFxuICAgIH07XG4gIH1cblxuICByZXR1cm4ge1xuICAgIG5hbWU6IElOVEVHUkFUSU9OX05BTUUsXG4gICAgcHJvY2Vzc0V2ZW50KG9yaWdpbmFsRXZlbnQpIHtcbiAgICAgIGxldCBwcm9jZXNzZWRFdmVudCA9IG9yaWdpbmFsRXZlbnQ7XG5cbiAgICAgIGlmIChvcmlnaW5hbEV2ZW50LmV4Y2VwdGlvbiAmJiBBcnJheS5pc0FycmF5KG9yaWdpbmFsRXZlbnQuZXhjZXB0aW9uLnZhbHVlcykpIHtcbiAgICAgICAgcHJvY2Vzc2VkRXZlbnQgPSBfcHJvY2Vzc0V4Y2VwdGlvbnNFdmVudChwcm9jZXNzZWRFdmVudCk7XG4gICAgICB9XG5cbiAgICAgIHJldHVybiBwcm9jZXNzZWRFdmVudDtcbiAgICB9LFxuICB9O1xufSk7XG5cbi8qKlxuICogRXhwb3J0ZWQgb25seSBmb3IgdGVzdHMuXG4gKi9cbmZ1bmN0aW9uIGdlbmVyYXRlSXRlcmF0ZWUoe1xuICBpc0Jyb3dzZXIsXG4gIHJvb3QsXG4gIHByZWZpeCxcbn1cblxuKSB7XG4gIHJldHVybiAoZnJhbWUpID0+IHtcbiAgICBpZiAoIWZyYW1lLmZpbGVuYW1lKSB7XG4gICAgICByZXR1cm4gZnJhbWU7XG4gICAgfVxuXG4gICAgLy8gRGV0ZXJtaW5lIGlmIHRoaXMgaXMgYSBXaW5kb3dzIGZyYW1lIGJ5IGNoZWNraW5nIGZvciBhIFdpbmRvd3Mtc3R5bGUgcHJlZml4IHN1Y2ggYXMgYEM6XFxgXG4gICAgY29uc3QgaXNXaW5kb3dzRnJhbWUgPVxuICAgICAgL15bYS16QS1aXTpcXFxcLy50ZXN0KGZyYW1lLmZpbGVuYW1lKSB8fFxuICAgICAgLy8gb3IgdGhlIHByZXNlbmNlIG9mIGEgYmFja3NsYXNoIHdpdGhvdXQgYSBmb3J3YXJkIHNsYXNoICh3aGljaCBhcmUgbm90IGFsbG93ZWQgb24gV2luZG93cylcbiAgICAgIChmcmFtZS5maWxlbmFtZS5pbmNsdWRlcygnXFxcXCcpICYmICFmcmFtZS5maWxlbmFtZS5pbmNsdWRlcygnLycpKTtcblxuICAgIC8vIENoZWNrIGlmIHRoZSBmcmFtZSBmaWxlbmFtZSBiZWdpbnMgd2l0aCBgL2BcbiAgICBjb25zdCBzdGFydHNXaXRoU2xhc2ggPSAvXlxcLy8udGVzdChmcmFtZS5maWxlbmFtZSk7XG5cbiAgICBpZiAoaXNCcm93c2VyKSB7XG4gICAgICBpZiAocm9vdCkge1xuICAgICAgICBjb25zdCBvbGRGaWxlbmFtZSA9IGZyYW1lLmZpbGVuYW1lO1xuICAgICAgICBpZiAob2xkRmlsZW5hbWUuaW5kZXhPZihyb290KSA9PT0gMCkge1xuICAgICAgICAgIGZyYW1lLmZpbGVuYW1lID0gb2xkRmlsZW5hbWUucmVwbGFjZShyb290LCBwcmVmaXgpO1xuICAgICAgICB9XG4gICAgICB9XG4gICAgfSBlbHNlIHtcbiAgICAgIGlmIChpc1dpbmRvd3NGcmFtZSB8fCBzdGFydHNXaXRoU2xhc2gpIHtcbiAgICAgICAgY29uc3QgZmlsZW5hbWUgPSBpc1dpbmRvd3NGcmFtZVxuICAgICAgICAgID8gZnJhbWUuZmlsZW5hbWVcbiAgICAgICAgICAgICAgLnJlcGxhY2UoL15bYS16QS1aXTovLCAnJykgLy8gcmVtb3ZlIFdpbmRvd3Mtc3R5bGUgcHJlZml4XG4gICAgICAgICAgICAgIC5yZXBsYWNlKC9cXFxcL2csICcvJykgLy8gcmVwbGFjZSBhbGwgYFxcXFxgIGluc3RhbmNlcyB3aXRoIGAvYFxuICAgICAgICAgIDogZnJhbWUuZmlsZW5hbWU7XG4gICAgICAgIGNvbnN0IGJhc2UgPSByb290ID8gcGF0aC5yZWxhdGl2ZShyb290LCBmaWxlbmFtZSkgOiBwYXRoLmJhc2VuYW1lKGZpbGVuYW1lKTtcbiAgICAgICAgZnJhbWUuZmlsZW5hbWUgPSBgJHtwcmVmaXh9JHtiYXNlfWA7XG4gICAgICB9XG4gICAgfVxuXG4gICAgcmV0dXJuIGZyYW1lO1xuICB9O1xufVxuXG5leHBvcnRzLmdlbmVyYXRlSXRlcmF0ZWUgPSBnZW5lcmF0ZUl0ZXJhdGVlO1xuZXhwb3J0cy5yZXdyaXRlRnJhbWVzSW50ZWdyYXRpb24gPSByZXdyaXRlRnJhbWVzSW50ZWdyYXRpb247XG4vLyMgc291cmNlTWFwcGluZ1VSTD1yZXdyaXRlZnJhbWVzLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/rewriteframes.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/supabase.js":
/*!*************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/supabase.js ***!
  \*************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst breadcrumbs = __webpack_require__(/*! ../breadcrumbs.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/breadcrumbs.js\");\nconst debugBuild = __webpack_require__(/*! ../debug-build.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst exports$1 = __webpack_require__(/*! ../exports.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/exports.js\");\nconst integration = __webpack_require__(/*! ../integration.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integration.js\");\nconst semanticAttributes = __webpack_require__(/*! ../semanticAttributes.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/semanticAttributes.js\");\nconst debugLogger = __webpack_require__(/*! ../utils/debug-logger.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst is = __webpack_require__(/*! ../utils/is.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js\");\nconst spanstatus = __webpack_require__(/*! ../tracing/spanstatus.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/spanstatus.js\");\nconst trace = __webpack_require__(/*! ../tracing/trace.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/trace.js\");\n\n// Based on Kamil Ogórek's work on:\n// https://github.com/supabase-community/sentry-integration-js\n\n\nconst AUTH_OPERATIONS_TO_INSTRUMENT = [\n  'reauthenticate',\n  'signInAnonymously',\n  'signInWithOAuth',\n  'signInWithIdToken',\n  'signInWithOtp',\n  'signInWithPassword',\n  'signInWithSSO',\n  'signOut',\n  'signUp',\n  'verifyOtp',\n];\n\nconst AUTH_ADMIN_OPERATIONS_TO_INSTRUMENT = [\n  'createUser',\n  'deleteUser',\n  'listUsers',\n  'getUserById',\n  'updateUserById',\n  'inviteUserByEmail',\n];\n\nconst FILTER_MAPPINGS = {\n  eq: 'eq',\n  neq: 'neq',\n  gt: 'gt',\n  gte: 'gte',\n  lt: 'lt',\n  lte: 'lte',\n  like: 'like',\n  'like(all)': 'likeAllOf',\n  'like(any)': 'likeAnyOf',\n  ilike: 'ilike',\n  'ilike(all)': 'ilikeAllOf',\n  'ilike(any)': 'ilikeAnyOf',\n  is: 'is',\n  in: 'in',\n  cs: 'contains',\n  cd: 'containedBy',\n  sr: 'rangeGt',\n  nxl: 'rangeGte',\n  sl: 'rangeLt',\n  nxr: 'rangeLte',\n  adj: 'rangeAdjacent',\n  ov: 'overlaps',\n  fts: '',\n  plfts: 'plain',\n  phfts: 'phrase',\n  wfts: 'websearch',\n  not: 'not',\n};\n\nconst DB_OPERATIONS_TO_INSTRUMENT = ['select', 'insert', 'upsert', 'update', 'delete'];\n\nfunction markAsInstrumented(fn) {\n  try {\n    (fn ).__SENTRY_INSTRUMENTED__ = true;\n  } catch {\n    // ignore errors here\n  }\n}\n\nfunction isInstrumented(fn) {\n  try {\n    return (fn ).__SENTRY_INSTRUMENTED__;\n  } catch {\n    return false;\n  }\n}\n\n/**\n * Extracts the database operation type from the HTTP method and headers\n * @param method - The HTTP method of the request\n * @param headers - The request headers\n * @returns The database operation type ('select', 'insert', 'upsert', 'update', or 'delete')\n */\nfunction extractOperation(method, headers = {}) {\n  switch (method) {\n    case 'GET': {\n      return 'select';\n    }\n    case 'POST': {\n      if (headers['Prefer']?.includes('resolution=')) {\n        return 'upsert';\n      } else {\n        return 'insert';\n      }\n    }\n    case 'PATCH': {\n      return 'update';\n    }\n    case 'DELETE': {\n      return 'delete';\n    }\n    default: {\n      return '<unknown-op>';\n    }\n  }\n}\n\n/**\n * Translates Supabase filter parameters into readable method names for tracing\n * @param key - The filter key from the URL search parameters\n * @param query - The filter value from the URL search parameters\n * @returns A string representation of the filter as a method call\n */\nfunction translateFiltersIntoMethods(key, query) {\n  if (query === '' || query === '*') {\n    return 'select(*)';\n  }\n\n  if (key === 'select') {\n    return `select(${query})`;\n  }\n\n  if (key === 'or' || key.endsWith('.or')) {\n    return `${key}${query}`;\n  }\n\n  const [filter, ...value] = query.split('.');\n\n  let method;\n  // Handle optional `configPart` of the filter\n  if (filter?.startsWith('fts')) {\n    method = 'textSearch';\n  } else if (filter?.startsWith('plfts')) {\n    method = 'textSearch[plain]';\n  } else if (filter?.startsWith('phfts')) {\n    method = 'textSearch[phrase]';\n  } else if (filter?.startsWith('wfts')) {\n    method = 'textSearch[websearch]';\n  } else {\n    method = (filter && FILTER_MAPPINGS[filter ]) || 'filter';\n  }\n\n  return `${method}(${key}, ${value.join('.')})`;\n}\n\nfunction instrumentAuthOperation(operation, isAdmin = false) {\n  return new Proxy(operation, {\n    apply(target, thisArg, argumentsList) {\n      return trace.startSpan(\n        {\n          name: `auth ${isAdmin ? '(admin) ' : ''}${operation.name}`,\n          attributes: {\n            [semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_ORIGIN]: 'auto.db.supabase',\n            [semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_OP]: 'db',\n            'db.system': 'postgresql',\n            'db.operation': `auth.${isAdmin ? 'admin.' : ''}${operation.name}`,\n          },\n        },\n        span => {\n          return Reflect.apply(target, thisArg, argumentsList)\n            .then((res) => {\n              if (res && typeof res === 'object' && 'error' in res && res.error) {\n                span.setStatus({ code: spanstatus.SPAN_STATUS_ERROR });\n\n                exports$1.captureException(res.error, {\n                  mechanism: {\n                    handled: false,\n                  },\n                });\n              } else {\n                span.setStatus({ code: spanstatus.SPAN_STATUS_OK });\n              }\n\n              span.end();\n              return res;\n            })\n            .catch((err) => {\n              span.setStatus({ code: spanstatus.SPAN_STATUS_ERROR });\n              span.end();\n\n              exports$1.captureException(err, {\n                mechanism: {\n                  handled: false,\n                },\n              });\n\n              throw err;\n            })\n            .then(...argumentsList);\n        },\n      );\n    },\n  });\n}\n\nfunction instrumentSupabaseAuthClient(supabaseClientInstance) {\n  const auth = supabaseClientInstance.auth;\n\n  if (!auth || isInstrumented(supabaseClientInstance.auth)) {\n    return;\n  }\n\n  for (const operation of AUTH_OPERATIONS_TO_INSTRUMENT) {\n    const authOperation = auth[operation];\n\n    if (!authOperation) {\n      continue;\n    }\n\n    if (typeof supabaseClientInstance.auth[operation] === 'function') {\n      supabaseClientInstance.auth[operation] = instrumentAuthOperation(authOperation);\n    }\n  }\n\n  for (const operation of AUTH_ADMIN_OPERATIONS_TO_INSTRUMENT) {\n    const authOperation = auth.admin[operation];\n\n    if (!authOperation) {\n      continue;\n    }\n\n    if (typeof supabaseClientInstance.auth.admin[operation] === 'function') {\n      supabaseClientInstance.auth.admin[operation] = instrumentAuthOperation(authOperation, true);\n    }\n  }\n\n  markAsInstrumented(supabaseClientInstance.auth);\n}\n\nfunction instrumentSupabaseClientConstructor(SupabaseClient) {\n  if (isInstrumented((SupabaseClient ).prototype.from)) {\n    return;\n  }\n\n  (SupabaseClient ).prototype.from = new Proxy(\n    (SupabaseClient ).prototype.from,\n    {\n      apply(target, thisArg, argumentsList) {\n        const rv = Reflect.apply(target, thisArg, argumentsList);\n        const PostgRESTQueryBuilder = (rv ).constructor;\n\n        instrumentPostgRESTQueryBuilder(PostgRESTQueryBuilder );\n\n        return rv;\n      },\n    },\n  );\n\n  markAsInstrumented((SupabaseClient ).prototype.from);\n}\n\nfunction instrumentPostgRESTFilterBuilder(PostgRESTFilterBuilder) {\n  if (isInstrumented((PostgRESTFilterBuilder.prototype ).then)) {\n    return;\n  }\n\n  (PostgRESTFilterBuilder.prototype ).then = new Proxy(\n    (PostgRESTFilterBuilder.prototype ).then,\n    {\n      apply(target, thisArg, argumentsList) {\n        const operations = DB_OPERATIONS_TO_INSTRUMENT;\n        const typedThis = thisArg ;\n        const operation = extractOperation(typedThis.method, typedThis.headers);\n\n        if (!operations.includes(operation)) {\n          return Reflect.apply(target, thisArg, argumentsList);\n        }\n\n        if (!typedThis?.url?.pathname || typeof typedThis.url.pathname !== 'string') {\n          return Reflect.apply(target, thisArg, argumentsList);\n        }\n\n        const pathParts = typedThis.url.pathname.split('/');\n        const table = pathParts.length > 0 ? pathParts[pathParts.length - 1] : '';\n\n        const queryItems = [];\n        for (const [key, value] of typedThis.url.searchParams.entries()) {\n          // It's possible to have multiple entries for the same key, eg. `id=eq.7&id=eq.3`,\n          // so we need to use array instead of object to collect them.\n          queryItems.push(translateFiltersIntoMethods(key, value));\n        }\n        const body = Object.create(null);\n        if (is.isPlainObject(typedThis.body)) {\n          for (const [key, value] of Object.entries(typedThis.body)) {\n            body[key] = value;\n          }\n        }\n\n        // Adding operation to the beginning of the description if it's not a `select` operation\n        // For example, it can be an `insert` or `update` operation but the query can be `select(...)`\n        // For `select` operations, we don't need repeat it in the description\n        const description = `${operation === 'select' ? '' : `${operation}${body ? '(...) ' : ''}`}${queryItems.join(\n          ' ',\n        )} from(${table})`;\n\n        const attributes = {\n          'db.table': table,\n          'db.schema': typedThis.schema,\n          'db.url': typedThis.url.origin,\n          'db.sdk': typedThis.headers['X-Client-Info'],\n          'db.system': 'postgresql',\n          'db.operation': operation,\n          [semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_ORIGIN]: 'auto.db.supabase',\n          [semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_OP]: 'db',\n        };\n\n        if (queryItems.length) {\n          attributes['db.query'] = queryItems;\n        }\n\n        if (Object.keys(body).length) {\n          attributes['db.body'] = body;\n        }\n\n        return trace.startSpan(\n          {\n            name: description,\n            attributes,\n          },\n          span => {\n            return (Reflect.apply(target, thisArg, []) )\n              .then(\n                (res) => {\n                  if (span) {\n                    if (res && typeof res === 'object' && 'status' in res) {\n                      spanstatus.setHttpStatus(span, res.status || 500);\n                    }\n                    span.end();\n                  }\n\n                  if (res.error) {\n                    const err = new Error(res.error.message) ;\n                    if (res.error.code) {\n                      err.code = res.error.code;\n                    }\n                    if (res.error.details) {\n                      err.details = res.error.details;\n                    }\n\n                    const supabaseContext = {};\n                    if (queryItems.length) {\n                      supabaseContext.query = queryItems;\n                    }\n                    if (Object.keys(body).length) {\n                      supabaseContext.body = body;\n                    }\n\n                    exports$1.captureException(err, {\n                      contexts: {\n                        supabase: supabaseContext,\n                      },\n                    });\n                  }\n\n                  const breadcrumb = {\n                    type: 'supabase',\n                    category: `db.${operation}`,\n                    message: description,\n                  };\n\n                  const data = {};\n\n                  if (queryItems.length) {\n                    data.query = queryItems;\n                  }\n\n                  if (Object.keys(body).length) {\n                    data.body = body;\n                  }\n\n                  if (Object.keys(data).length) {\n                    breadcrumb.data = data;\n                  }\n\n                  breadcrumbs.addBreadcrumb(breadcrumb);\n\n                  return res;\n                },\n                (err) => {\n                  if (span) {\n                    spanstatus.setHttpStatus(span, 500);\n                    span.end();\n                  }\n                  throw err;\n                },\n              )\n              .then(...argumentsList);\n          },\n        );\n      },\n    },\n  );\n\n  markAsInstrumented((PostgRESTFilterBuilder.prototype ).then);\n}\n\nfunction instrumentPostgRESTQueryBuilder(PostgRESTQueryBuilder) {\n  // We need to wrap _all_ operations despite them sharing the same `PostgRESTFilterBuilder`\n  // constructor, as we don't know which method will be called first, and we don't want to miss any calls.\n  for (const operation of DB_OPERATIONS_TO_INSTRUMENT) {\n    if (isInstrumented((PostgRESTQueryBuilder.prototype )[operation])) {\n      continue;\n    }\n\n    (PostgRESTQueryBuilder.prototype )[operation ] = new Proxy(\n      (PostgRESTQueryBuilder.prototype )[operation ],\n      {\n        apply(target, thisArg, argumentsList) {\n          const rv = Reflect.apply(target, thisArg, argumentsList);\n          const PostgRESTFilterBuilder = (rv ).constructor;\n\n          debugBuild.DEBUG_BUILD && debugLogger.debug.log(`Instrumenting ${operation} operation's PostgRESTFilterBuilder`);\n\n          instrumentPostgRESTFilterBuilder(PostgRESTFilterBuilder);\n\n          return rv;\n        },\n      },\n    );\n\n    markAsInstrumented((PostgRESTQueryBuilder.prototype )[operation]);\n  }\n}\n\nconst instrumentSupabaseClient = (supabaseClient) => {\n  if (!supabaseClient) {\n    debugBuild.DEBUG_BUILD && debugLogger.debug.warn('Supabase integration was not installed because no Supabase client was provided.');\n    return;\n  }\n  const SupabaseClientConstructor =\n    supabaseClient.constructor === Function ? supabaseClient : supabaseClient.constructor;\n\n  instrumentSupabaseClientConstructor(SupabaseClientConstructor);\n  instrumentSupabaseAuthClient(supabaseClient );\n};\n\nconst INTEGRATION_NAME = 'Supabase';\n\nconst _supabaseIntegration = ((supabaseClient) => {\n  return {\n    setupOnce() {\n      instrumentSupabaseClient(supabaseClient);\n    },\n    name: INTEGRATION_NAME,\n  };\n}) ;\n\nconst supabaseIntegration = integration.defineIntegration((options) => {\n  return _supabaseIntegration(options.supabaseClient);\n}) ;\n\nexports.DB_OPERATIONS_TO_INSTRUMENT = DB_OPERATIONS_TO_INSTRUMENT;\nexports.FILTER_MAPPINGS = FILTER_MAPPINGS;\nexports.extractOperation = extractOperation;\nexports.instrumentSupabaseClient = instrumentSupabaseClient;\nexports.supabaseIntegration = supabaseIntegration;\nexports.translateFiltersIntoMethods = translateFiltersIntoMethods;\n//# sourceMappingURL=supabase.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvc3VwYWJhc2UuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsb0JBQW9CLG1CQUFPLENBQUMsNEhBQW1CO0FBQy9DLG1CQUFtQixtQkFBTyxDQUFDLDRIQUFtQjtBQUM5QyxrQkFBa0IsbUJBQU8sQ0FBQyxvSEFBZTtBQUN6QyxvQkFBb0IsbUJBQU8sQ0FBQyw0SEFBbUI7QUFDL0MsMkJBQTJCLG1CQUFPLENBQUMsMElBQTBCO0FBQzdELG9CQUFvQixtQkFBTyxDQUFDLDBJQUEwQjtBQUN0RCxXQUFXLG1CQUFPLENBQUMsc0hBQWdCO0FBQ25DLG1CQUFtQixtQkFBTyxDQUFDLDBJQUEwQjtBQUNyRCxjQUFjLG1CQUFPLENBQUMsZ0lBQXFCOztBQUUzQztBQUNBOzs7QUFHQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBLElBQUk7QUFDSjtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0EsSUFBSTtBQUNKO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSw4Q0FBOEM7QUFDOUM7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxRQUFRO0FBQ1I7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBLHFCQUFxQixNQUFNO0FBQzNCOztBQUVBO0FBQ0EsY0FBYyxJQUFJLEVBQUUsTUFBTTtBQUMxQjs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLElBQUk7QUFDSjtBQUNBLElBQUk7QUFDSjtBQUNBLElBQUk7QUFDSjtBQUNBLElBQUk7QUFDSjtBQUNBOztBQUVBLFlBQVksT0FBTyxHQUFHLElBQUksSUFBSSxnQkFBZ0I7QUFDOUM7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLHdCQUF3QiwwQkFBMEIsRUFBRSxlQUFlO0FBQ25FO0FBQ0E7QUFDQTtBQUNBO0FBQ0Esb0NBQW9DLHdCQUF3QixFQUFFLGVBQWU7QUFDN0UsV0FBVztBQUNYLFNBQVM7QUFDVDtBQUNBO0FBQ0E7QUFDQTtBQUNBLGlDQUFpQyxvQ0FBb0M7O0FBRXJFO0FBQ0E7QUFDQTtBQUNBLG1CQUFtQjtBQUNuQixpQkFBaUI7QUFDakIsZ0JBQWdCO0FBQ2hCLGlDQUFpQyxpQ0FBaUM7QUFDbEU7O0FBRUE7QUFDQTtBQUNBLGFBQWE7QUFDYjtBQUNBLCtCQUErQixvQ0FBb0M7QUFDbkU7O0FBRUE7QUFDQTtBQUNBO0FBQ0EsaUJBQWlCO0FBQ2pCLGVBQWU7O0FBRWY7QUFDQSxhQUFhO0FBQ2I7QUFDQSxTQUFTO0FBQ1Q7QUFDQSxLQUFLO0FBQ0wsR0FBRztBQUNIOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBOztBQUVBO0FBQ0EsT0FBTztBQUNQLEtBQUs7QUFDTDs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0EsK0JBQStCLGlDQUFpQyxVQUFVLEVBQUUscUJBQXFCLEVBQUUsRUFBRTtBQUNyRztBQUNBLFdBQVcsT0FBTyxNQUFNOztBQUV4QjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsV0FBVztBQUNYO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0EsdUJBQXVCO0FBQ3ZCLHFCQUFxQjtBQUNyQjs7QUFFQTtBQUNBO0FBQ0Esb0NBQW9DLFVBQVU7QUFDOUM7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBLGlCQUFpQjtBQUNqQjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxpQkFBaUI7QUFDakI7QUFDQTtBQUNBLFdBQVc7QUFDWDtBQUNBLE9BQU87QUFDUCxLQUFLO0FBQ0w7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsMkVBQTJFLFdBQVc7O0FBRXRGOztBQUVBO0FBQ0EsU0FBUztBQUNULE9BQU87QUFDUDs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsS0FBSztBQUNMO0FBQ0E7QUFDQSxDQUFDOztBQUVEO0FBQ0E7QUFDQSxDQUFDOztBQUVELG1DQUFtQztBQUNuQyx1QkFBdUI7QUFDdkIsd0JBQXdCO0FBQ3hCLGdDQUFnQztBQUNoQywyQkFBMkI7QUFDM0IsbUNBQW1DO0FBQ25DIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvaW50ZWdyYXRpb25zL3N1cGFiYXNlLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBicmVhZGNydW1icyA9IHJlcXVpcmUoJy4uL2JyZWFkY3J1bWJzLmpzJyk7XG5jb25zdCBkZWJ1Z0J1aWxkID0gcmVxdWlyZSgnLi4vZGVidWctYnVpbGQuanMnKTtcbmNvbnN0IGV4cG9ydHMkMSA9IHJlcXVpcmUoJy4uL2V4cG9ydHMuanMnKTtcbmNvbnN0IGludGVncmF0aW9uID0gcmVxdWlyZSgnLi4vaW50ZWdyYXRpb24uanMnKTtcbmNvbnN0IHNlbWFudGljQXR0cmlidXRlcyA9IHJlcXVpcmUoJy4uL3NlbWFudGljQXR0cmlidXRlcy5qcycpO1xuY29uc3QgZGVidWdMb2dnZXIgPSByZXF1aXJlKCcuLi91dGlscy9kZWJ1Zy1sb2dnZXIuanMnKTtcbmNvbnN0IGlzID0gcmVxdWlyZSgnLi4vdXRpbHMvaXMuanMnKTtcbmNvbnN0IHNwYW5zdGF0dXMgPSByZXF1aXJlKCcuLi90cmFjaW5nL3NwYW5zdGF0dXMuanMnKTtcbmNvbnN0IHRyYWNlID0gcmVxdWlyZSgnLi4vdHJhY2luZy90cmFjZS5qcycpO1xuXG4vLyBCYXNlZCBvbiBLYW1pbCBPZ8OzcmVrJ3Mgd29yayBvbjpcbi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9zdXBhYmFzZS1jb21tdW5pdHkvc2VudHJ5LWludGVncmF0aW9uLWpzXG5cblxuY29uc3QgQVVUSF9PUEVSQVRJT05TX1RPX0lOU1RSVU1FTlQgPSBbXG4gICdyZWF1dGhlbnRpY2F0ZScsXG4gICdzaWduSW5Bbm9ueW1vdXNseScsXG4gICdzaWduSW5XaXRoT0F1dGgnLFxuICAnc2lnbkluV2l0aElkVG9rZW4nLFxuICAnc2lnbkluV2l0aE90cCcsXG4gICdzaWduSW5XaXRoUGFzc3dvcmQnLFxuICAnc2lnbkluV2l0aFNTTycsXG4gICdzaWduT3V0JyxcbiAgJ3NpZ25VcCcsXG4gICd2ZXJpZnlPdHAnLFxuXTtcblxuY29uc3QgQVVUSF9BRE1JTl9PUEVSQVRJT05TX1RPX0lOU1RSVU1FTlQgPSBbXG4gICdjcmVhdGVVc2VyJyxcbiAgJ2RlbGV0ZVVzZXInLFxuICAnbGlzdFVzZXJzJyxcbiAgJ2dldFVzZXJCeUlkJyxcbiAgJ3VwZGF0ZVVzZXJCeUlkJyxcbiAgJ2ludml0ZVVzZXJCeUVtYWlsJyxcbl07XG5cbmNvbnN0IEZJTFRFUl9NQVBQSU5HUyA9IHtcbiAgZXE6ICdlcScsXG4gIG5lcTogJ25lcScsXG4gIGd0OiAnZ3QnLFxuICBndGU6ICdndGUnLFxuICBsdDogJ2x0JyxcbiAgbHRlOiAnbHRlJyxcbiAgbGlrZTogJ2xpa2UnLFxuICAnbGlrZShhbGwpJzogJ2xpa2VBbGxPZicsXG4gICdsaWtlKGFueSknOiAnbGlrZUFueU9mJyxcbiAgaWxpa2U6ICdpbGlrZScsXG4gICdpbGlrZShhbGwpJzogJ2lsaWtlQWxsT2YnLFxuICAnaWxpa2UoYW55KSc6ICdpbGlrZUFueU9mJyxcbiAgaXM6ICdpcycsXG4gIGluOiAnaW4nLFxuICBjczogJ2NvbnRhaW5zJyxcbiAgY2Q6ICdjb250YWluZWRCeScsXG4gIHNyOiAncmFuZ2VHdCcsXG4gIG54bDogJ3JhbmdlR3RlJyxcbiAgc2w6ICdyYW5nZUx0JyxcbiAgbnhyOiAncmFuZ2VMdGUnLFxuICBhZGo6ICdyYW5nZUFkamFjZW50JyxcbiAgb3Y6ICdvdmVybGFwcycsXG4gIGZ0czogJycsXG4gIHBsZnRzOiAncGxhaW4nLFxuICBwaGZ0czogJ3BocmFzZScsXG4gIHdmdHM6ICd3ZWJzZWFyY2gnLFxuICBub3Q6ICdub3QnLFxufTtcblxuY29uc3QgREJfT1BFUkFUSU9OU19UT19JTlNUUlVNRU5UID0gWydzZWxlY3QnLCAnaW5zZXJ0JywgJ3Vwc2VydCcsICd1cGRhdGUnLCAnZGVsZXRlJ107XG5cbmZ1bmN0aW9uIG1hcmtBc0luc3RydW1lbnRlZChmbikge1xuICB0cnkge1xuICAgIChmbiApLl9fU0VOVFJZX0lOU1RSVU1FTlRFRF9fID0gdHJ1ZTtcbiAgfSBjYXRjaCB7XG4gICAgLy8gaWdub3JlIGVycm9ycyBoZXJlXG4gIH1cbn1cblxuZnVuY3Rpb24gaXNJbnN0cnVtZW50ZWQoZm4pIHtcbiAgdHJ5IHtcbiAgICByZXR1cm4gKGZuICkuX19TRU5UUllfSU5TVFJVTUVOVEVEX187XG4gIH0gY2F0Y2gge1xuICAgIHJldHVybiBmYWxzZTtcbiAgfVxufVxuXG4vKipcbiAqIEV4dHJhY3RzIHRoZSBkYXRhYmFzZSBvcGVyYXRpb24gdHlwZSBmcm9tIHRoZSBIVFRQIG1ldGhvZCBhbmQgaGVhZGVyc1xuICogQHBhcmFtIG1ldGhvZCAtIFRoZSBIVFRQIG1ldGhvZCBvZiB0aGUgcmVxdWVzdFxuICogQHBhcmFtIGhlYWRlcnMgLSBUaGUgcmVxdWVzdCBoZWFkZXJzXG4gKiBAcmV0dXJucyBUaGUgZGF0YWJhc2Ugb3BlcmF0aW9uIHR5cGUgKCdzZWxlY3QnLCAnaW5zZXJ0JywgJ3Vwc2VydCcsICd1cGRhdGUnLCBvciAnZGVsZXRlJylcbiAqL1xuZnVuY3Rpb24gZXh0cmFjdE9wZXJhdGlvbihtZXRob2QsIGhlYWRlcnMgPSB7fSkge1xuICBzd2l0Y2ggKG1ldGhvZCkge1xuICAgIGNhc2UgJ0dFVCc6IHtcbiAgICAgIHJldHVybiAnc2VsZWN0JztcbiAgICB9XG4gICAgY2FzZSAnUE9TVCc6IHtcbiAgICAgIGlmIChoZWFkZXJzWydQcmVmZXInXT8uaW5jbHVkZXMoJ3Jlc29sdXRpb249JykpIHtcbiAgICAgICAgcmV0dXJuICd1cHNlcnQnO1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgcmV0dXJuICdpbnNlcnQnO1xuICAgICAgfVxuICAgIH1cbiAgICBjYXNlICdQQVRDSCc6IHtcbiAgICAgIHJldHVybiAndXBkYXRlJztcbiAgICB9XG4gICAgY2FzZSAnREVMRVRFJzoge1xuICAgICAgcmV0dXJuICdkZWxldGUnO1xuICAgIH1cbiAgICBkZWZhdWx0OiB7XG4gICAgICByZXR1cm4gJzx1bmtub3duLW9wPic7XG4gICAgfVxuICB9XG59XG5cbi8qKlxuICogVHJhbnNsYXRlcyBTdXBhYmFzZSBmaWx0ZXIgcGFyYW1ldGVycyBpbnRvIHJlYWRhYmxlIG1ldGhvZCBuYW1lcyBmb3IgdHJhY2luZ1xuICogQHBhcmFtIGtleSAtIFRoZSBmaWx0ZXIga2V5IGZyb20gdGhlIFVSTCBzZWFyY2ggcGFyYW1ldGVyc1xuICogQHBhcmFtIHF1ZXJ5IC0gVGhlIGZpbHRlciB2YWx1ZSBmcm9tIHRoZSBVUkwgc2VhcmNoIHBhcmFtZXRlcnNcbiAqIEByZXR1cm5zIEEgc3RyaW5nIHJlcHJlc2VudGF0aW9uIG9mIHRoZSBmaWx0ZXIgYXMgYSBtZXRob2QgY2FsbFxuICovXG5mdW5jdGlvbiB0cmFuc2xhdGVGaWx0ZXJzSW50b01ldGhvZHMoa2V5LCBxdWVyeSkge1xuICBpZiAocXVlcnkgPT09ICcnIHx8IHF1ZXJ5ID09PSAnKicpIHtcbiAgICByZXR1cm4gJ3NlbGVjdCgqKSc7XG4gIH1cblxuICBpZiAoa2V5ID09PSAnc2VsZWN0Jykge1xuICAgIHJldHVybiBgc2VsZWN0KCR7cXVlcnl9KWA7XG4gIH1cblxuICBpZiAoa2V5ID09PSAnb3InIHx8IGtleS5lbmRzV2l0aCgnLm9yJykpIHtcbiAgICByZXR1cm4gYCR7a2V5fSR7cXVlcnl9YDtcbiAgfVxuXG4gIGNvbnN0IFtmaWx0ZXIsIC4uLnZhbHVlXSA9IHF1ZXJ5LnNwbGl0KCcuJyk7XG5cbiAgbGV0IG1ldGhvZDtcbiAgLy8gSGFuZGxlIG9wdGlvbmFsIGBjb25maWdQYXJ0YCBvZiB0aGUgZmlsdGVyXG4gIGlmIChmaWx0ZXI/LnN0YXJ0c1dpdGgoJ2Z0cycpKSB7XG4gICAgbWV0aG9kID0gJ3RleHRTZWFyY2gnO1xuICB9IGVsc2UgaWYgKGZpbHRlcj8uc3RhcnRzV2l0aCgncGxmdHMnKSkge1xuICAgIG1ldGhvZCA9ICd0ZXh0U2VhcmNoW3BsYWluXSc7XG4gIH0gZWxzZSBpZiAoZmlsdGVyPy5zdGFydHNXaXRoKCdwaGZ0cycpKSB7XG4gICAgbWV0aG9kID0gJ3RleHRTZWFyY2hbcGhyYXNlXSc7XG4gIH0gZWxzZSBpZiAoZmlsdGVyPy5zdGFydHNXaXRoKCd3ZnRzJykpIHtcbiAgICBtZXRob2QgPSAndGV4dFNlYXJjaFt3ZWJzZWFyY2hdJztcbiAgfSBlbHNlIHtcbiAgICBtZXRob2QgPSAoZmlsdGVyICYmIEZJTFRFUl9NQVBQSU5HU1tmaWx0ZXIgXSkgfHwgJ2ZpbHRlcic7XG4gIH1cblxuICByZXR1cm4gYCR7bWV0aG9kfSgke2tleX0sICR7dmFsdWUuam9pbignLicpfSlgO1xufVxuXG5mdW5jdGlvbiBpbnN0cnVtZW50QXV0aE9wZXJhdGlvbihvcGVyYXRpb24sIGlzQWRtaW4gPSBmYWxzZSkge1xuICByZXR1cm4gbmV3IFByb3h5KG9wZXJhdGlvbiwge1xuICAgIGFwcGx5KHRhcmdldCwgdGhpc0FyZywgYXJndW1lbnRzTGlzdCkge1xuICAgICAgcmV0dXJuIHRyYWNlLnN0YXJ0U3BhbihcbiAgICAgICAge1xuICAgICAgICAgIG5hbWU6IGBhdXRoICR7aXNBZG1pbiA/ICcoYWRtaW4pICcgOiAnJ30ke29wZXJhdGlvbi5uYW1lfWAsXG4gICAgICAgICAgYXR0cmlidXRlczoge1xuICAgICAgICAgICAgW3NlbWFudGljQXR0cmlidXRlcy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX09SSUdJTl06ICdhdXRvLmRiLnN1cGFiYXNlJyxcbiAgICAgICAgICAgIFtzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9PUF06ICdkYicsXG4gICAgICAgICAgICAnZGIuc3lzdGVtJzogJ3Bvc3RncmVzcWwnLFxuICAgICAgICAgICAgJ2RiLm9wZXJhdGlvbic6IGBhdXRoLiR7aXNBZG1pbiA/ICdhZG1pbi4nIDogJyd9JHtvcGVyYXRpb24ubmFtZX1gLFxuICAgICAgICAgIH0sXG4gICAgICAgIH0sXG4gICAgICAgIHNwYW4gPT4ge1xuICAgICAgICAgIHJldHVybiBSZWZsZWN0LmFwcGx5KHRhcmdldCwgdGhpc0FyZywgYXJndW1lbnRzTGlzdClcbiAgICAgICAgICAgIC50aGVuKChyZXMpID0+IHtcbiAgICAgICAgICAgICAgaWYgKHJlcyAmJiB0eXBlb2YgcmVzID09PSAnb2JqZWN0JyAmJiAnZXJyb3InIGluIHJlcyAmJiByZXMuZXJyb3IpIHtcbiAgICAgICAgICAgICAgICBzcGFuLnNldFN0YXR1cyh7IGNvZGU6IHNwYW5zdGF0dXMuU1BBTl9TVEFUVVNfRVJST1IgfSk7XG5cbiAgICAgICAgICAgICAgICBleHBvcnRzJDEuY2FwdHVyZUV4Y2VwdGlvbihyZXMuZXJyb3IsIHtcbiAgICAgICAgICAgICAgICAgIG1lY2hhbmlzbToge1xuICAgICAgICAgICAgICAgICAgICBoYW5kbGVkOiBmYWxzZSxcbiAgICAgICAgICAgICAgICAgIH0sXG4gICAgICAgICAgICAgICAgfSk7XG4gICAgICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICAgICAgc3Bhbi5zZXRTdGF0dXMoeyBjb2RlOiBzcGFuc3RhdHVzLlNQQU5fU1RBVFVTX09LIH0pO1xuICAgICAgICAgICAgICB9XG5cbiAgICAgICAgICAgICAgc3Bhbi5lbmQoKTtcbiAgICAgICAgICAgICAgcmV0dXJuIHJlcztcbiAgICAgICAgICAgIH0pXG4gICAgICAgICAgICAuY2F0Y2goKGVycikgPT4ge1xuICAgICAgICAgICAgICBzcGFuLnNldFN0YXR1cyh7IGNvZGU6IHNwYW5zdGF0dXMuU1BBTl9TVEFUVVNfRVJST1IgfSk7XG4gICAgICAgICAgICAgIHNwYW4uZW5kKCk7XG5cbiAgICAgICAgICAgICAgZXhwb3J0cyQxLmNhcHR1cmVFeGNlcHRpb24oZXJyLCB7XG4gICAgICAgICAgICAgICAgbWVjaGFuaXNtOiB7XG4gICAgICAgICAgICAgICAgICBoYW5kbGVkOiBmYWxzZSxcbiAgICAgICAgICAgICAgICB9LFxuICAgICAgICAgICAgICB9KTtcblxuICAgICAgICAgICAgICB0aHJvdyBlcnI7XG4gICAgICAgICAgICB9KVxuICAgICAgICAgICAgLnRoZW4oLi4uYXJndW1lbnRzTGlzdCk7XG4gICAgICAgIH0sXG4gICAgICApO1xuICAgIH0sXG4gIH0pO1xufVxuXG5mdW5jdGlvbiBpbnN0cnVtZW50U3VwYWJhc2VBdXRoQ2xpZW50KHN1cGFiYXNlQ2xpZW50SW5zdGFuY2UpIHtcbiAgY29uc3QgYXV0aCA9IHN1cGFiYXNlQ2xpZW50SW5zdGFuY2UuYXV0aDtcblxuICBpZiAoIWF1dGggfHwgaXNJbnN0cnVtZW50ZWQoc3VwYWJhc2VDbGllbnRJbnN0YW5jZS5hdXRoKSkge1xuICAgIHJldHVybjtcbiAgfVxuXG4gIGZvciAoY29uc3Qgb3BlcmF0aW9uIG9mIEFVVEhfT1BFUkFUSU9OU19UT19JTlNUUlVNRU5UKSB7XG4gICAgY29uc3QgYXV0aE9wZXJhdGlvbiA9IGF1dGhbb3BlcmF0aW9uXTtcblxuICAgIGlmICghYXV0aE9wZXJhdGlvbikge1xuICAgICAgY29udGludWU7XG4gICAgfVxuXG4gICAgaWYgKHR5cGVvZiBzdXBhYmFzZUNsaWVudEluc3RhbmNlLmF1dGhbb3BlcmF0aW9uXSA9PT0gJ2Z1bmN0aW9uJykge1xuICAgICAgc3VwYWJhc2VDbGllbnRJbnN0YW5jZS5hdXRoW29wZXJhdGlvbl0gPSBpbnN0cnVtZW50QXV0aE9wZXJhdGlvbihhdXRoT3BlcmF0aW9uKTtcbiAgICB9XG4gIH1cblxuICBmb3IgKGNvbnN0IG9wZXJhdGlvbiBvZiBBVVRIX0FETUlOX09QRVJBVElPTlNfVE9fSU5TVFJVTUVOVCkge1xuICAgIGNvbnN0IGF1dGhPcGVyYXRpb24gPSBhdXRoLmFkbWluW29wZXJhdGlvbl07XG5cbiAgICBpZiAoIWF1dGhPcGVyYXRpb24pIHtcbiAgICAgIGNvbnRpbnVlO1xuICAgIH1cblxuICAgIGlmICh0eXBlb2Ygc3VwYWJhc2VDbGllbnRJbnN0YW5jZS5hdXRoLmFkbWluW29wZXJhdGlvbl0gPT09ICdmdW5jdGlvbicpIHtcbiAgICAgIHN1cGFiYXNlQ2xpZW50SW5zdGFuY2UuYXV0aC5hZG1pbltvcGVyYXRpb25dID0gaW5zdHJ1bWVudEF1dGhPcGVyYXRpb24oYXV0aE9wZXJhdGlvbiwgdHJ1ZSk7XG4gICAgfVxuICB9XG5cbiAgbWFya0FzSW5zdHJ1bWVudGVkKHN1cGFiYXNlQ2xpZW50SW5zdGFuY2UuYXV0aCk7XG59XG5cbmZ1bmN0aW9uIGluc3RydW1lbnRTdXBhYmFzZUNsaWVudENvbnN0cnVjdG9yKFN1cGFiYXNlQ2xpZW50KSB7XG4gIGlmIChpc0luc3RydW1lbnRlZCgoU3VwYWJhc2VDbGllbnQgKS5wcm90b3R5cGUuZnJvbSkpIHtcbiAgICByZXR1cm47XG4gIH1cblxuICAoU3VwYWJhc2VDbGllbnQgKS5wcm90b3R5cGUuZnJvbSA9IG5ldyBQcm94eShcbiAgICAoU3VwYWJhc2VDbGllbnQgKS5wcm90b3R5cGUuZnJvbSxcbiAgICB7XG4gICAgICBhcHBseSh0YXJnZXQsIHRoaXNBcmcsIGFyZ3VtZW50c0xpc3QpIHtcbiAgICAgICAgY29uc3QgcnYgPSBSZWZsZWN0LmFwcGx5KHRhcmdldCwgdGhpc0FyZywgYXJndW1lbnRzTGlzdCk7XG4gICAgICAgIGNvbnN0IFBvc3RnUkVTVFF1ZXJ5QnVpbGRlciA9IChydiApLmNvbnN0cnVjdG9yO1xuXG4gICAgICAgIGluc3RydW1lbnRQb3N0Z1JFU1RRdWVyeUJ1aWxkZXIoUG9zdGdSRVNUUXVlcnlCdWlsZGVyICk7XG5cbiAgICAgICAgcmV0dXJuIHJ2O1xuICAgICAgfSxcbiAgICB9LFxuICApO1xuXG4gIG1hcmtBc0luc3RydW1lbnRlZCgoU3VwYWJhc2VDbGllbnQgKS5wcm90b3R5cGUuZnJvbSk7XG59XG5cbmZ1bmN0aW9uIGluc3RydW1lbnRQb3N0Z1JFU1RGaWx0ZXJCdWlsZGVyKFBvc3RnUkVTVEZpbHRlckJ1aWxkZXIpIHtcbiAgaWYgKGlzSW5zdHJ1bWVudGVkKChQb3N0Z1JFU1RGaWx0ZXJCdWlsZGVyLnByb3RvdHlwZSApLnRoZW4pKSB7XG4gICAgcmV0dXJuO1xuICB9XG5cbiAgKFBvc3RnUkVTVEZpbHRlckJ1aWxkZXIucHJvdG90eXBlICkudGhlbiA9IG5ldyBQcm94eShcbiAgICAoUG9zdGdSRVNURmlsdGVyQnVpbGRlci5wcm90b3R5cGUgKS50aGVuLFxuICAgIHtcbiAgICAgIGFwcGx5KHRhcmdldCwgdGhpc0FyZywgYXJndW1lbnRzTGlzdCkge1xuICAgICAgICBjb25zdCBvcGVyYXRpb25zID0gREJfT1BFUkFUSU9OU19UT19JTlNUUlVNRU5UO1xuICAgICAgICBjb25zdCB0eXBlZFRoaXMgPSB0aGlzQXJnIDtcbiAgICAgICAgY29uc3Qgb3BlcmF0aW9uID0gZXh0cmFjdE9wZXJhdGlvbih0eXBlZFRoaXMubWV0aG9kLCB0eXBlZFRoaXMuaGVhZGVycyk7XG5cbiAgICAgICAgaWYgKCFvcGVyYXRpb25zLmluY2x1ZGVzKG9wZXJhdGlvbikpIHtcbiAgICAgICAgICByZXR1cm4gUmVmbGVjdC5hcHBseSh0YXJnZXQsIHRoaXNBcmcsIGFyZ3VtZW50c0xpc3QpO1xuICAgICAgICB9XG5cbiAgICAgICAgaWYgKCF0eXBlZFRoaXM/LnVybD8ucGF0aG5hbWUgfHwgdHlwZW9mIHR5cGVkVGhpcy51cmwucGF0aG5hbWUgIT09ICdzdHJpbmcnKSB7XG4gICAgICAgICAgcmV0dXJuIFJlZmxlY3QuYXBwbHkodGFyZ2V0LCB0aGlzQXJnLCBhcmd1bWVudHNMaXN0KTtcbiAgICAgICAgfVxuXG4gICAgICAgIGNvbnN0IHBhdGhQYXJ0cyA9IHR5cGVkVGhpcy51cmwucGF0aG5hbWUuc3BsaXQoJy8nKTtcbiAgICAgICAgY29uc3QgdGFibGUgPSBwYXRoUGFydHMubGVuZ3RoID4gMCA/IHBhdGhQYXJ0c1twYXRoUGFydHMubGVuZ3RoIC0gMV0gOiAnJztcblxuICAgICAgICBjb25zdCBxdWVyeUl0ZW1zID0gW107XG4gICAgICAgIGZvciAoY29uc3QgW2tleSwgdmFsdWVdIG9mIHR5cGVkVGhpcy51cmwuc2VhcmNoUGFyYW1zLmVudHJpZXMoKSkge1xuICAgICAgICAgIC8vIEl0J3MgcG9zc2libGUgdG8gaGF2ZSBtdWx0aXBsZSBlbnRyaWVzIGZvciB0aGUgc2FtZSBrZXksIGVnLiBgaWQ9ZXEuNyZpZD1lcS4zYCxcbiAgICAgICAgICAvLyBzbyB3ZSBuZWVkIHRvIHVzZSBhcnJheSBpbnN0ZWFkIG9mIG9iamVjdCB0byBjb2xsZWN0IHRoZW0uXG4gICAgICAgICAgcXVlcnlJdGVtcy5wdXNoKHRyYW5zbGF0ZUZpbHRlcnNJbnRvTWV0aG9kcyhrZXksIHZhbHVlKSk7XG4gICAgICAgIH1cbiAgICAgICAgY29uc3QgYm9keSA9IE9iamVjdC5jcmVhdGUobnVsbCk7XG4gICAgICAgIGlmIChpcy5pc1BsYWluT2JqZWN0KHR5cGVkVGhpcy5ib2R5KSkge1xuICAgICAgICAgIGZvciAoY29uc3QgW2tleSwgdmFsdWVdIG9mIE9iamVjdC5lbnRyaWVzKHR5cGVkVGhpcy5ib2R5KSkge1xuICAgICAgICAgICAgYm9keVtrZXldID0gdmFsdWU7XG4gICAgICAgICAgfVxuICAgICAgICB9XG5cbiAgICAgICAgLy8gQWRkaW5nIG9wZXJhdGlvbiB0byB0aGUgYmVnaW5uaW5nIG9mIHRoZSBkZXNjcmlwdGlvbiBpZiBpdCdzIG5vdCBhIGBzZWxlY3RgIG9wZXJhdGlvblxuICAgICAgICAvLyBGb3IgZXhhbXBsZSwgaXQgY2FuIGJlIGFuIGBpbnNlcnRgIG9yIGB1cGRhdGVgIG9wZXJhdGlvbiBidXQgdGhlIHF1ZXJ5IGNhbiBiZSBgc2VsZWN0KC4uLilgXG4gICAgICAgIC8vIEZvciBgc2VsZWN0YCBvcGVyYXRpb25zLCB3ZSBkb24ndCBuZWVkIHJlcGVhdCBpdCBpbiB0aGUgZGVzY3JpcHRpb25cbiAgICAgICAgY29uc3QgZGVzY3JpcHRpb24gPSBgJHtvcGVyYXRpb24gPT09ICdzZWxlY3QnID8gJycgOiBgJHtvcGVyYXRpb259JHtib2R5ID8gJyguLi4pICcgOiAnJ31gfSR7cXVlcnlJdGVtcy5qb2luKFxuICAgICAgICAgICcgJyxcbiAgICAgICAgKX0gZnJvbSgke3RhYmxlfSlgO1xuXG4gICAgICAgIGNvbnN0IGF0dHJpYnV0ZXMgPSB7XG4gICAgICAgICAgJ2RiLnRhYmxlJzogdGFibGUsXG4gICAgICAgICAgJ2RiLnNjaGVtYSc6IHR5cGVkVGhpcy5zY2hlbWEsXG4gICAgICAgICAgJ2RiLnVybCc6IHR5cGVkVGhpcy51cmwub3JpZ2luLFxuICAgICAgICAgICdkYi5zZGsnOiB0eXBlZFRoaXMuaGVhZGVyc1snWC1DbGllbnQtSW5mbyddLFxuICAgICAgICAgICdkYi5zeXN0ZW0nOiAncG9zdGdyZXNxbCcsXG4gICAgICAgICAgJ2RiLm9wZXJhdGlvbic6IG9wZXJhdGlvbixcbiAgICAgICAgICBbc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfT1JJR0lOXTogJ2F1dG8uZGIuc3VwYWJhc2UnLFxuICAgICAgICAgIFtzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9PUF06ICdkYicsXG4gICAgICAgIH07XG5cbiAgICAgICAgaWYgKHF1ZXJ5SXRlbXMubGVuZ3RoKSB7XG4gICAgICAgICAgYXR0cmlidXRlc1snZGIucXVlcnknXSA9IHF1ZXJ5SXRlbXM7XG4gICAgICAgIH1cblxuICAgICAgICBpZiAoT2JqZWN0LmtleXMoYm9keSkubGVuZ3RoKSB7XG4gICAgICAgICAgYXR0cmlidXRlc1snZGIuYm9keSddID0gYm9keTtcbiAgICAgICAgfVxuXG4gICAgICAgIHJldHVybiB0cmFjZS5zdGFydFNwYW4oXG4gICAgICAgICAge1xuICAgICAgICAgICAgbmFtZTogZGVzY3JpcHRpb24sXG4gICAgICAgICAgICBhdHRyaWJ1dGVzLFxuICAgICAgICAgIH0sXG4gICAgICAgICAgc3BhbiA9PiB7XG4gICAgICAgICAgICByZXR1cm4gKFJlZmxlY3QuYXBwbHkodGFyZ2V0LCB0aGlzQXJnLCBbXSkgKVxuICAgICAgICAgICAgICAudGhlbihcbiAgICAgICAgICAgICAgICAocmVzKSA9PiB7XG4gICAgICAgICAgICAgICAgICBpZiAoc3Bhbikge1xuICAgICAgICAgICAgICAgICAgICBpZiAocmVzICYmIHR5cGVvZiByZXMgPT09ICdvYmplY3QnICYmICdzdGF0dXMnIGluIHJlcykge1xuICAgICAgICAgICAgICAgICAgICAgIHNwYW5zdGF0dXMuc2V0SHR0cFN0YXR1cyhzcGFuLCByZXMuc3RhdHVzIHx8IDUwMCk7XG4gICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICAgICAgc3Bhbi5lbmQoKTtcbiAgICAgICAgICAgICAgICAgIH1cblxuICAgICAgICAgICAgICAgICAgaWYgKHJlcy5lcnJvcikge1xuICAgICAgICAgICAgICAgICAgICBjb25zdCBlcnIgPSBuZXcgRXJyb3IocmVzLmVycm9yLm1lc3NhZ2UpIDtcbiAgICAgICAgICAgICAgICAgICAgaWYgKHJlcy5lcnJvci5jb2RlKSB7XG4gICAgICAgICAgICAgICAgICAgICAgZXJyLmNvZGUgPSByZXMuZXJyb3IuY29kZTtcbiAgICAgICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgICAgICBpZiAocmVzLmVycm9yLmRldGFpbHMpIHtcbiAgICAgICAgICAgICAgICAgICAgICBlcnIuZGV0YWlscyA9IHJlcy5lcnJvci5kZXRhaWxzO1xuICAgICAgICAgICAgICAgICAgICB9XG5cbiAgICAgICAgICAgICAgICAgICAgY29uc3Qgc3VwYWJhc2VDb250ZXh0ID0ge307XG4gICAgICAgICAgICAgICAgICAgIGlmIChxdWVyeUl0ZW1zLmxlbmd0aCkge1xuICAgICAgICAgICAgICAgICAgICAgIHN1cGFiYXNlQ29udGV4dC5xdWVyeSA9IHF1ZXJ5SXRlbXM7XG4gICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICAgICAgaWYgKE9iamVjdC5rZXlzKGJvZHkpLmxlbmd0aCkge1xuICAgICAgICAgICAgICAgICAgICAgIHN1cGFiYXNlQ29udGV4dC5ib2R5ID0gYm9keTtcbiAgICAgICAgICAgICAgICAgICAgfVxuXG4gICAgICAgICAgICAgICAgICAgIGV4cG9ydHMkMS5jYXB0dXJlRXhjZXB0aW9uKGVyciwge1xuICAgICAgICAgICAgICAgICAgICAgIGNvbnRleHRzOiB7XG4gICAgICAgICAgICAgICAgICAgICAgICBzdXBhYmFzZTogc3VwYWJhc2VDb250ZXh0LFxuICAgICAgICAgICAgICAgICAgICAgIH0sXG4gICAgICAgICAgICAgICAgICAgIH0pO1xuICAgICAgICAgICAgICAgICAgfVxuXG4gICAgICAgICAgICAgICAgICBjb25zdCBicmVhZGNydW1iID0ge1xuICAgICAgICAgICAgICAgICAgICB0eXBlOiAnc3VwYWJhc2UnLFxuICAgICAgICAgICAgICAgICAgICBjYXRlZ29yeTogYGRiLiR7b3BlcmF0aW9ufWAsXG4gICAgICAgICAgICAgICAgICAgIG1lc3NhZ2U6IGRlc2NyaXB0aW9uLFxuICAgICAgICAgICAgICAgICAgfTtcblxuICAgICAgICAgICAgICAgICAgY29uc3QgZGF0YSA9IHt9O1xuXG4gICAgICAgICAgICAgICAgICBpZiAocXVlcnlJdGVtcy5sZW5ndGgpIHtcbiAgICAgICAgICAgICAgICAgICAgZGF0YS5xdWVyeSA9IHF1ZXJ5SXRlbXM7XG4gICAgICAgICAgICAgICAgICB9XG5cbiAgICAgICAgICAgICAgICAgIGlmIChPYmplY3Qua2V5cyhib2R5KS5sZW5ndGgpIHtcbiAgICAgICAgICAgICAgICAgICAgZGF0YS5ib2R5ID0gYm9keTtcbiAgICAgICAgICAgICAgICAgIH1cblxuICAgICAgICAgICAgICAgICAgaWYgKE9iamVjdC5rZXlzKGRhdGEpLmxlbmd0aCkge1xuICAgICAgICAgICAgICAgICAgICBicmVhZGNydW1iLmRhdGEgPSBkYXRhO1xuICAgICAgICAgICAgICAgICAgfVxuXG4gICAgICAgICAgICAgICAgICBicmVhZGNydW1icy5hZGRCcmVhZGNydW1iKGJyZWFkY3J1bWIpO1xuXG4gICAgICAgICAgICAgICAgICByZXR1cm4gcmVzO1xuICAgICAgICAgICAgICAgIH0sXG4gICAgICAgICAgICAgICAgKGVycikgPT4ge1xuICAgICAgICAgICAgICAgICAgaWYgKHNwYW4pIHtcbiAgICAgICAgICAgICAgICAgICAgc3BhbnN0YXR1cy5zZXRIdHRwU3RhdHVzKHNwYW4sIDUwMCk7XG4gICAgICAgICAgICAgICAgICAgIHNwYW4uZW5kKCk7XG4gICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgICB0aHJvdyBlcnI7XG4gICAgICAgICAgICAgICAgfSxcbiAgICAgICAgICAgICAgKVxuICAgICAgICAgICAgICAudGhlbiguLi5hcmd1bWVudHNMaXN0KTtcbiAgICAgICAgICB9LFxuICAgICAgICApO1xuICAgICAgfSxcbiAgICB9LFxuICApO1xuXG4gIG1hcmtBc0luc3RydW1lbnRlZCgoUG9zdGdSRVNURmlsdGVyQnVpbGRlci5wcm90b3R5cGUgKS50aGVuKTtcbn1cblxuZnVuY3Rpb24gaW5zdHJ1bWVudFBvc3RnUkVTVFF1ZXJ5QnVpbGRlcihQb3N0Z1JFU1RRdWVyeUJ1aWxkZXIpIHtcbiAgLy8gV2UgbmVlZCB0byB3cmFwIF9hbGxfIG9wZXJhdGlvbnMgZGVzcGl0ZSB0aGVtIHNoYXJpbmcgdGhlIHNhbWUgYFBvc3RnUkVTVEZpbHRlckJ1aWxkZXJgXG4gIC8vIGNvbnN0cnVjdG9yLCBhcyB3ZSBkb24ndCBrbm93IHdoaWNoIG1ldGhvZCB3aWxsIGJlIGNhbGxlZCBmaXJzdCwgYW5kIHdlIGRvbid0IHdhbnQgdG8gbWlzcyBhbnkgY2FsbHMuXG4gIGZvciAoY29uc3Qgb3BlcmF0aW9uIG9mIERCX09QRVJBVElPTlNfVE9fSU5TVFJVTUVOVCkge1xuICAgIGlmIChpc0luc3RydW1lbnRlZCgoUG9zdGdSRVNUUXVlcnlCdWlsZGVyLnByb3RvdHlwZSApW29wZXJhdGlvbl0pKSB7XG4gICAgICBjb250aW51ZTtcbiAgICB9XG5cbiAgICAoUG9zdGdSRVNUUXVlcnlCdWlsZGVyLnByb3RvdHlwZSApW29wZXJhdGlvbiBdID0gbmV3IFByb3h5KFxuICAgICAgKFBvc3RnUkVTVFF1ZXJ5QnVpbGRlci5wcm90b3R5cGUgKVtvcGVyYXRpb24gXSxcbiAgICAgIHtcbiAgICAgICAgYXBwbHkodGFyZ2V0LCB0aGlzQXJnLCBhcmd1bWVudHNMaXN0KSB7XG4gICAgICAgICAgY29uc3QgcnYgPSBSZWZsZWN0LmFwcGx5KHRhcmdldCwgdGhpc0FyZywgYXJndW1lbnRzTGlzdCk7XG4gICAgICAgICAgY29uc3QgUG9zdGdSRVNURmlsdGVyQnVpbGRlciA9IChydiApLmNvbnN0cnVjdG9yO1xuXG4gICAgICAgICAgZGVidWdCdWlsZC5ERUJVR19CVUlMRCAmJiBkZWJ1Z0xvZ2dlci5kZWJ1Zy5sb2coYEluc3RydW1lbnRpbmcgJHtvcGVyYXRpb259IG9wZXJhdGlvbidzIFBvc3RnUkVTVEZpbHRlckJ1aWxkZXJgKTtcblxuICAgICAgICAgIGluc3RydW1lbnRQb3N0Z1JFU1RGaWx0ZXJCdWlsZGVyKFBvc3RnUkVTVEZpbHRlckJ1aWxkZXIpO1xuXG4gICAgICAgICAgcmV0dXJuIHJ2O1xuICAgICAgICB9LFxuICAgICAgfSxcbiAgICApO1xuXG4gICAgbWFya0FzSW5zdHJ1bWVudGVkKChQb3N0Z1JFU1RRdWVyeUJ1aWxkZXIucHJvdG90eXBlIClbb3BlcmF0aW9uXSk7XG4gIH1cbn1cblxuY29uc3QgaW5zdHJ1bWVudFN1cGFiYXNlQ2xpZW50ID0gKHN1cGFiYXNlQ2xpZW50KSA9PiB7XG4gIGlmICghc3VwYWJhc2VDbGllbnQpIHtcbiAgICBkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEICYmIGRlYnVnTG9nZ2VyLmRlYnVnLndhcm4oJ1N1cGFiYXNlIGludGVncmF0aW9uIHdhcyBub3QgaW5zdGFsbGVkIGJlY2F1c2Ugbm8gU3VwYWJhc2UgY2xpZW50IHdhcyBwcm92aWRlZC4nKTtcbiAgICByZXR1cm47XG4gIH1cbiAgY29uc3QgU3VwYWJhc2VDbGllbnRDb25zdHJ1Y3RvciA9XG4gICAgc3VwYWJhc2VDbGllbnQuY29uc3RydWN0b3IgPT09IEZ1bmN0aW9uID8gc3VwYWJhc2VDbGllbnQgOiBzdXBhYmFzZUNsaWVudC5jb25zdHJ1Y3RvcjtcblxuICBpbnN0cnVtZW50U3VwYWJhc2VDbGllbnRDb25zdHJ1Y3RvcihTdXBhYmFzZUNsaWVudENvbnN0cnVjdG9yKTtcbiAgaW5zdHJ1bWVudFN1cGFiYXNlQXV0aENsaWVudChzdXBhYmFzZUNsaWVudCApO1xufTtcblxuY29uc3QgSU5URUdSQVRJT05fTkFNRSA9ICdTdXBhYmFzZSc7XG5cbmNvbnN0IF9zdXBhYmFzZUludGVncmF0aW9uID0gKChzdXBhYmFzZUNsaWVudCkgPT4ge1xuICByZXR1cm4ge1xuICAgIHNldHVwT25jZSgpIHtcbiAgICAgIGluc3RydW1lbnRTdXBhYmFzZUNsaWVudChzdXBhYmFzZUNsaWVudCk7XG4gICAgfSxcbiAgICBuYW1lOiBJTlRFR1JBVElPTl9OQU1FLFxuICB9O1xufSkgO1xuXG5jb25zdCBzdXBhYmFzZUludGVncmF0aW9uID0gaW50ZWdyYXRpb24uZGVmaW5lSW50ZWdyYXRpb24oKG9wdGlvbnMpID0+IHtcbiAgcmV0dXJuIF9zdXBhYmFzZUludGVncmF0aW9uKG9wdGlvbnMuc3VwYWJhc2VDbGllbnQpO1xufSkgO1xuXG5leHBvcnRzLkRCX09QRVJBVElPTlNfVE9fSU5TVFJVTUVOVCA9IERCX09QRVJBVElPTlNfVE9fSU5TVFJVTUVOVDtcbmV4cG9ydHMuRklMVEVSX01BUFBJTkdTID0gRklMVEVSX01BUFBJTkdTO1xuZXhwb3J0cy5leHRyYWN0T3BlcmF0aW9uID0gZXh0cmFjdE9wZXJhdGlvbjtcbmV4cG9ydHMuaW5zdHJ1bWVudFN1cGFiYXNlQ2xpZW50ID0gaW5zdHJ1bWVudFN1cGFiYXNlQ2xpZW50O1xuZXhwb3J0cy5zdXBhYmFzZUludGVncmF0aW9uID0gc3VwYWJhc2VJbnRlZ3JhdGlvbjtcbmV4cG9ydHMudHJhbnNsYXRlRmlsdGVyc0ludG9NZXRob2RzID0gdHJhbnNsYXRlRmlsdGVyc0ludG9NZXRob2RzO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9c3VwYWJhc2UuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/supabase.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/third-party-errors-filter.js":
/*!******************************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/third-party-errors-filter.js ***!
  \******************************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst integration = __webpack_require__(/*! ../integration.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integration.js\");\nconst metadata = __webpack_require__(/*! ../metadata.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/metadata.js\");\nconst envelope = __webpack_require__(/*! ../utils/envelope.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/envelope.js\");\nconst stacktrace = __webpack_require__(/*! ../utils/stacktrace.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/stacktrace.js\");\n\n/**\n * This integration allows you to filter out, or tag error events that do not come from user code marked with a bundle key via the Sentry bundler plugins.\n */\nconst thirdPartyErrorFilterIntegration = integration.defineIntegration((options) => {\n  return {\n    name: 'ThirdPartyErrorsFilter',\n    setup(client) {\n      // We need to strip metadata from stack frames before sending them to Sentry since these are client side only.\n      // TODO(lforst): Move this cleanup logic into a more central place in the SDK.\n      client.on('beforeEnvelope', envelope$1 => {\n        envelope.forEachEnvelopeItem(envelope$1, (item, type) => {\n          if (type === 'event') {\n            const event = Array.isArray(item) ? (item )[1] : undefined;\n\n            if (event) {\n              metadata.stripMetadataFromStackFrames(event);\n              item[1] = event;\n            }\n          }\n        });\n      });\n\n      client.on('applyFrameMetadata', event => {\n        // Only apply stack frame metadata to error events\n        if (event.type) {\n          return;\n        }\n\n        const stackParser = client.getOptions().stackParser;\n        metadata.addMetadataToStackFrames(stackParser, event);\n      });\n    },\n\n    processEvent(event) {\n      const frameKeys = getBundleKeysForAllFramesWithFilenames(event);\n\n      if (frameKeys) {\n        const arrayMethod =\n          options.behaviour === 'drop-error-if-contains-third-party-frames' ||\n          options.behaviour === 'apply-tag-if-contains-third-party-frames'\n            ? 'some'\n            : 'every';\n\n        const behaviourApplies = frameKeys[arrayMethod](keys => !keys.some(key => options.filterKeys.includes(key)));\n\n        if (behaviourApplies) {\n          const shouldDrop =\n            options.behaviour === 'drop-error-if-contains-third-party-frames' ||\n            options.behaviour === 'drop-error-if-exclusively-contains-third-party-frames';\n          if (shouldDrop) {\n            return null;\n          } else {\n            event.tags = {\n              ...event.tags,\n              third_party_code: true,\n            };\n          }\n        }\n      }\n\n      return event;\n    },\n  };\n});\n\nfunction getBundleKeysForAllFramesWithFilenames(event) {\n  const frames = stacktrace.getFramesFromEvent(event);\n\n  if (!frames) {\n    return undefined;\n  }\n\n  return (\n    frames\n      // Exclude frames without a filename since these are likely native code or built-ins\n      .filter(frame => !!frame.filename)\n      .map(frame => {\n        if (frame.module_metadata) {\n          return Object.keys(frame.module_metadata)\n            .filter(key => key.startsWith(BUNDLER_PLUGIN_APP_KEY_PREFIX))\n            .map(key => key.slice(BUNDLER_PLUGIN_APP_KEY_PREFIX.length));\n        }\n        return [];\n      })\n  );\n}\n\nconst BUNDLER_PLUGIN_APP_KEY_PREFIX = '_sentryBundlerPluginAppKey:';\n\nexports.thirdPartyErrorFilterIntegration = thirdPartyErrorFilterIntegration;\n//# sourceMappingURL=third-party-errors-filter.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvdGhpcmQtcGFydHktZXJyb3JzLWZpbHRlci5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxvQkFBb0IsbUJBQU8sQ0FBQyw0SEFBbUI7QUFDL0MsaUJBQWlCLG1CQUFPLENBQUMsc0hBQWdCO0FBQ3pDLGlCQUFpQixtQkFBTyxDQUFDLGtJQUFzQjtBQUMvQyxtQkFBbUIsbUJBQU8sQ0FBQyxzSUFBd0I7O0FBRW5EO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxTQUFTO0FBQ1QsT0FBTzs7QUFFUDtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQSxPQUFPO0FBQ1AsS0FBSzs7QUFFTDtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxZQUFZO0FBQ1o7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQSxLQUFLO0FBQ0w7QUFDQSxDQUFDOztBQUVEO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxPQUFPO0FBQ1A7QUFDQTs7QUFFQTs7QUFFQSx3Q0FBd0M7QUFDeEMiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvdGhpcmQtcGFydHktZXJyb3JzLWZpbHRlci5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgaW50ZWdyYXRpb24gPSByZXF1aXJlKCcuLi9pbnRlZ3JhdGlvbi5qcycpO1xuY29uc3QgbWV0YWRhdGEgPSByZXF1aXJlKCcuLi9tZXRhZGF0YS5qcycpO1xuY29uc3QgZW52ZWxvcGUgPSByZXF1aXJlKCcuLi91dGlscy9lbnZlbG9wZS5qcycpO1xuY29uc3Qgc3RhY2t0cmFjZSA9IHJlcXVpcmUoJy4uL3V0aWxzL3N0YWNrdHJhY2UuanMnKTtcblxuLyoqXG4gKiBUaGlzIGludGVncmF0aW9uIGFsbG93cyB5b3UgdG8gZmlsdGVyIG91dCwgb3IgdGFnIGVycm9yIGV2ZW50cyB0aGF0IGRvIG5vdCBjb21lIGZyb20gdXNlciBjb2RlIG1hcmtlZCB3aXRoIGEgYnVuZGxlIGtleSB2aWEgdGhlIFNlbnRyeSBidW5kbGVyIHBsdWdpbnMuXG4gKi9cbmNvbnN0IHRoaXJkUGFydHlFcnJvckZpbHRlckludGVncmF0aW9uID0gaW50ZWdyYXRpb24uZGVmaW5lSW50ZWdyYXRpb24oKG9wdGlvbnMpID0+IHtcbiAgcmV0dXJuIHtcbiAgICBuYW1lOiAnVGhpcmRQYXJ0eUVycm9yc0ZpbHRlcicsXG4gICAgc2V0dXAoY2xpZW50KSB7XG4gICAgICAvLyBXZSBuZWVkIHRvIHN0cmlwIG1ldGFkYXRhIGZyb20gc3RhY2sgZnJhbWVzIGJlZm9yZSBzZW5kaW5nIHRoZW0gdG8gU2VudHJ5IHNpbmNlIHRoZXNlIGFyZSBjbGllbnQgc2lkZSBvbmx5LlxuICAgICAgLy8gVE9ETyhsZm9yc3QpOiBNb3ZlIHRoaXMgY2xlYW51cCBsb2dpYyBpbnRvIGEgbW9yZSBjZW50cmFsIHBsYWNlIGluIHRoZSBTREsuXG4gICAgICBjbGllbnQub24oJ2JlZm9yZUVudmVsb3BlJywgZW52ZWxvcGUkMSA9PiB7XG4gICAgICAgIGVudmVsb3BlLmZvckVhY2hFbnZlbG9wZUl0ZW0oZW52ZWxvcGUkMSwgKGl0ZW0sIHR5cGUpID0+IHtcbiAgICAgICAgICBpZiAodHlwZSA9PT0gJ2V2ZW50Jykge1xuICAgICAgICAgICAgY29uc3QgZXZlbnQgPSBBcnJheS5pc0FycmF5KGl0ZW0pID8gKGl0ZW0gKVsxXSA6IHVuZGVmaW5lZDtcblxuICAgICAgICAgICAgaWYgKGV2ZW50KSB7XG4gICAgICAgICAgICAgIG1ldGFkYXRhLnN0cmlwTWV0YWRhdGFGcm9tU3RhY2tGcmFtZXMoZXZlbnQpO1xuICAgICAgICAgICAgICBpdGVtWzFdID0gZXZlbnQ7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgfVxuICAgICAgICB9KTtcbiAgICAgIH0pO1xuXG4gICAgICBjbGllbnQub24oJ2FwcGx5RnJhbWVNZXRhZGF0YScsIGV2ZW50ID0+IHtcbiAgICAgICAgLy8gT25seSBhcHBseSBzdGFjayBmcmFtZSBtZXRhZGF0YSB0byBlcnJvciBldmVudHNcbiAgICAgICAgaWYgKGV2ZW50LnR5cGUpIHtcbiAgICAgICAgICByZXR1cm47XG4gICAgICAgIH1cblxuICAgICAgICBjb25zdCBzdGFja1BhcnNlciA9IGNsaWVudC5nZXRPcHRpb25zKCkuc3RhY2tQYXJzZXI7XG4gICAgICAgIG1ldGFkYXRhLmFkZE1ldGFkYXRhVG9TdGFja0ZyYW1lcyhzdGFja1BhcnNlciwgZXZlbnQpO1xuICAgICAgfSk7XG4gICAgfSxcblxuICAgIHByb2Nlc3NFdmVudChldmVudCkge1xuICAgICAgY29uc3QgZnJhbWVLZXlzID0gZ2V0QnVuZGxlS2V5c0ZvckFsbEZyYW1lc1dpdGhGaWxlbmFtZXMoZXZlbnQpO1xuXG4gICAgICBpZiAoZnJhbWVLZXlzKSB7XG4gICAgICAgIGNvbnN0IGFycmF5TWV0aG9kID1cbiAgICAgICAgICBvcHRpb25zLmJlaGF2aW91ciA9PT0gJ2Ryb3AtZXJyb3ItaWYtY29udGFpbnMtdGhpcmQtcGFydHktZnJhbWVzJyB8fFxuICAgICAgICAgIG9wdGlvbnMuYmVoYXZpb3VyID09PSAnYXBwbHktdGFnLWlmLWNvbnRhaW5zLXRoaXJkLXBhcnR5LWZyYW1lcydcbiAgICAgICAgICAgID8gJ3NvbWUnXG4gICAgICAgICAgICA6ICdldmVyeSc7XG5cbiAgICAgICAgY29uc3QgYmVoYXZpb3VyQXBwbGllcyA9IGZyYW1lS2V5c1thcnJheU1ldGhvZF0oa2V5cyA9PiAha2V5cy5zb21lKGtleSA9PiBvcHRpb25zLmZpbHRlcktleXMuaW5jbHVkZXMoa2V5KSkpO1xuXG4gICAgICAgIGlmIChiZWhhdmlvdXJBcHBsaWVzKSB7XG4gICAgICAgICAgY29uc3Qgc2hvdWxkRHJvcCA9XG4gICAgICAgICAgICBvcHRpb25zLmJlaGF2aW91ciA9PT0gJ2Ryb3AtZXJyb3ItaWYtY29udGFpbnMtdGhpcmQtcGFydHktZnJhbWVzJyB8fFxuICAgICAgICAgICAgb3B0aW9ucy5iZWhhdmlvdXIgPT09ICdkcm9wLWVycm9yLWlmLWV4Y2x1c2l2ZWx5LWNvbnRhaW5zLXRoaXJkLXBhcnR5LWZyYW1lcyc7XG4gICAgICAgICAgaWYgKHNob3VsZERyb3ApIHtcbiAgICAgICAgICAgIHJldHVybiBudWxsO1xuICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICBldmVudC50YWdzID0ge1xuICAgICAgICAgICAgICAuLi5ldmVudC50YWdzLFxuICAgICAgICAgICAgICB0aGlyZF9wYXJ0eV9jb2RlOiB0cnVlLFxuICAgICAgICAgICAgfTtcbiAgICAgICAgICB9XG4gICAgICAgIH1cbiAgICAgIH1cblxuICAgICAgcmV0dXJuIGV2ZW50O1xuICAgIH0sXG4gIH07XG59KTtcblxuZnVuY3Rpb24gZ2V0QnVuZGxlS2V5c0ZvckFsbEZyYW1lc1dpdGhGaWxlbmFtZXMoZXZlbnQpIHtcbiAgY29uc3QgZnJhbWVzID0gc3RhY2t0cmFjZS5nZXRGcmFtZXNGcm9tRXZlbnQoZXZlbnQpO1xuXG4gIGlmICghZnJhbWVzKSB7XG4gICAgcmV0dXJuIHVuZGVmaW5lZDtcbiAgfVxuXG4gIHJldHVybiAoXG4gICAgZnJhbWVzXG4gICAgICAvLyBFeGNsdWRlIGZyYW1lcyB3aXRob3V0IGEgZmlsZW5hbWUgc2luY2UgdGhlc2UgYXJlIGxpa2VseSBuYXRpdmUgY29kZSBvciBidWlsdC1pbnNcbiAgICAgIC5maWx0ZXIoZnJhbWUgPT4gISFmcmFtZS5maWxlbmFtZSlcbiAgICAgIC5tYXAoZnJhbWUgPT4ge1xuICAgICAgICBpZiAoZnJhbWUubW9kdWxlX21ldGFkYXRhKSB7XG4gICAgICAgICAgcmV0dXJuIE9iamVjdC5rZXlzKGZyYW1lLm1vZHVsZV9tZXRhZGF0YSlcbiAgICAgICAgICAgIC5maWx0ZXIoa2V5ID0+IGtleS5zdGFydHNXaXRoKEJVTkRMRVJfUExVR0lOX0FQUF9LRVlfUFJFRklYKSlcbiAgICAgICAgICAgIC5tYXAoa2V5ID0+IGtleS5zbGljZShCVU5ETEVSX1BMVUdJTl9BUFBfS0VZX1BSRUZJWC5sZW5ndGgpKTtcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gW107XG4gICAgICB9KVxuICApO1xufVxuXG5jb25zdCBCVU5ETEVSX1BMVUdJTl9BUFBfS0VZX1BSRUZJWCA9ICdfc2VudHJ5QnVuZGxlclBsdWdpbkFwcEtleTonO1xuXG5leHBvcnRzLnRoaXJkUGFydHlFcnJvckZpbHRlckludGVncmF0aW9uID0gdGhpcmRQYXJ0eUVycm9yRmlsdGVySW50ZWdyYXRpb247XG4vLyMgc291cmNlTWFwcGluZ1VSTD10aGlyZC1wYXJ0eS1lcnJvcnMtZmlsdGVyLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/third-party-errors-filter.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/zoderrors.js":
/*!**************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/zoderrors.js ***!
  \**************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst integration = __webpack_require__(/*! ../integration.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integration.js\");\nconst is = __webpack_require__(/*! ../utils/is.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js\");\nconst string = __webpack_require__(/*! ../utils/string.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/string.js\");\n\nconst DEFAULT_LIMIT = 10;\nconst INTEGRATION_NAME = 'ZodErrors';\n\n/**\n * Simplified ZodIssue type definition\n */\n\nfunction originalExceptionIsZodError(originalException) {\n  return (\n    is.isError(originalException) &&\n    originalException.name === 'ZodError' &&\n    Array.isArray((originalException ).issues)\n  );\n}\n\n/**\n * Formats child objects or arrays to a string\n * that is preserved when sent to Sentry.\n *\n * Without this, we end up with something like this in Sentry:\n *\n * [\n *  [Object],\n *  [Object],\n *  [Object],\n *  [Object]\n * ]\n */\nfunction flattenIssue(issue) {\n  return {\n    ...issue,\n    path: 'path' in issue && Array.isArray(issue.path) ? issue.path.join('.') : undefined,\n    keys: 'keys' in issue ? JSON.stringify(issue.keys) : undefined,\n    unionErrors: 'unionErrors' in issue ? JSON.stringify(issue.unionErrors) : undefined,\n  };\n}\n\n/**\n * Takes ZodError issue path array and returns a flattened version as a string.\n * This makes it easier to display paths within a Sentry error message.\n *\n * Array indexes are normalized to reduce duplicate entries\n *\n * @param path ZodError issue path\n * @returns flattened path\n *\n * @example\n * flattenIssuePath([0, 'foo', 1, 'bar']) // -> '<array>.foo.<array>.bar'\n */\nfunction flattenIssuePath(path) {\n  return path\n    .map(p => {\n      if (typeof p === 'number') {\n        return '<array>';\n      } else {\n        return p;\n      }\n    })\n    .join('.');\n}\n\n/**\n * Zod error message is a stringified version of ZodError.issues\n * This doesn't display well in the Sentry UI. Replace it with something shorter.\n */\nfunction formatIssueMessage(zodError) {\n  const errorKeyMap = new Set();\n  for (const iss of zodError.issues) {\n    const issuePath = flattenIssuePath(iss.path);\n    if (issuePath.length > 0) {\n      errorKeyMap.add(issuePath);\n    }\n  }\n\n  const errorKeys = Array.from(errorKeyMap);\n  if (errorKeys.length === 0) {\n    // If there are no keys, then we're likely validating the root\n    // variable rather than a key within an object. This attempts\n    // to extract what type it was that failed to validate.\n    // For example, z.string().parse(123) would return \"string\" here.\n    let rootExpectedType = 'variable';\n    if (zodError.issues.length > 0) {\n      const iss = zodError.issues[0];\n      if (iss !== undefined && 'expected' in iss && typeof iss.expected === 'string') {\n        rootExpectedType = iss.expected;\n      }\n    }\n    return `Failed to validate ${rootExpectedType}`;\n  }\n  return `Failed to validate keys: ${string.truncate(errorKeys.join(', '), 100)}`;\n}\n\n/**\n * Applies ZodError issues to an event extra and replaces the error message\n */\nfunction applyZodErrorsToEvent(\n  limit,\n  saveZodIssuesAsAttachment = false,\n  event,\n  hint,\n) {\n  if (\n    !event.exception?.values ||\n    !hint.originalException ||\n    !originalExceptionIsZodError(hint.originalException) ||\n    hint.originalException.issues.length === 0\n  ) {\n    return event;\n  }\n\n  try {\n    const issuesToFlatten = saveZodIssuesAsAttachment\n      ? hint.originalException.issues\n      : hint.originalException.issues.slice(0, limit);\n    const flattenedIssues = issuesToFlatten.map(flattenIssue);\n\n    if (saveZodIssuesAsAttachment) {\n      // Sometimes having the full error details can be helpful.\n      // Attachments have much higher limits, so we can include the full list of issues.\n      if (!Array.isArray(hint.attachments)) {\n        hint.attachments = [];\n      }\n      hint.attachments.push({\n        filename: 'zod_issues.json',\n        data: JSON.stringify({\n          issues: flattenedIssues,\n        }),\n      });\n    }\n\n    return {\n      ...event,\n      exception: {\n        ...event.exception,\n        values: [\n          {\n            ...event.exception.values[0],\n            value: formatIssueMessage(hint.originalException),\n          },\n          ...event.exception.values.slice(1),\n        ],\n      },\n      extra: {\n        ...event.extra,\n        'zoderror.issues': flattenedIssues.slice(0, limit),\n      },\n    };\n  } catch (e) {\n    // Hopefully we never throw errors here, but record it\n    // with the event just in case.\n    return {\n      ...event,\n      extra: {\n        ...event.extra,\n        'zoderrors sentry integration parse error': {\n          message: 'an exception was thrown while processing ZodError within applyZodErrorsToEvent()',\n          error: e instanceof Error ? `${e.name}: ${e.message}\\n${e.stack}` : 'unknown',\n        },\n      },\n    };\n  }\n}\n\nconst _zodErrorsIntegration = ((options = {}) => {\n  const limit = options.limit ?? DEFAULT_LIMIT;\n\n  return {\n    name: INTEGRATION_NAME,\n    processEvent(originalEvent, hint) {\n      const processedEvent = applyZodErrorsToEvent(limit, options.saveZodIssuesAsAttachment, originalEvent, hint);\n      return processedEvent;\n    },\n  };\n}) ;\n\n/**\n * Sentry integration to process Zod errors, making them easier to work with in Sentry.\n */\nconst zodErrorsIntegration = integration.defineIntegration(_zodErrorsIntegration);\n\nexports.applyZodErrorsToEvent = applyZodErrorsToEvent;\nexports.flattenIssue = flattenIssue;\nexports.flattenIssuePath = flattenIssuePath;\nexports.formatIssueMessage = formatIssueMessage;\nexports.zodErrorsIntegration = zodErrorsIntegration;\n//# sourceMappingURL=zoderrors.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvem9kZXJyb3JzLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLG9CQUFvQixtQkFBTyxDQUFDLDRIQUFtQjtBQUMvQyxXQUFXLG1CQUFPLENBQUMsc0hBQWdCO0FBQ25DLGVBQWUsbUJBQU8sQ0FBQyw4SEFBb0I7O0FBRTNDO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsUUFBUTtBQUNSO0FBQ0E7QUFDQSxLQUFLO0FBQ0w7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxpQ0FBaUMsaUJBQWlCO0FBQ2xEO0FBQ0EscUNBQXFDLDJDQUEyQztBQUNoRjs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxTQUFTO0FBQ1QsT0FBTztBQUNQOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxXQUFXO0FBQ1g7QUFDQTtBQUNBLE9BQU87QUFDUDtBQUNBO0FBQ0E7QUFDQSxPQUFPO0FBQ1A7QUFDQSxJQUFJO0FBQ0o7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLHlDQUF5QyxPQUFPLElBQUksVUFBVSxJQUFJLFFBQVE7QUFDMUUsU0FBUztBQUNULE9BQU87QUFDUDtBQUNBO0FBQ0E7O0FBRUEsNENBQTRDO0FBQzVDOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxLQUFLO0FBQ0w7QUFDQSxDQUFDOztBQUVEO0FBQ0E7QUFDQTtBQUNBOztBQUVBLDZCQUE2QjtBQUM3QixvQkFBb0I7QUFDcEIsd0JBQXdCO0FBQ3hCLDBCQUEwQjtBQUMxQiw0QkFBNEI7QUFDNUIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9pbnRlZ3JhdGlvbnMvem9kZXJyb3JzLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBpbnRlZ3JhdGlvbiA9IHJlcXVpcmUoJy4uL2ludGVncmF0aW9uLmpzJyk7XG5jb25zdCBpcyA9IHJlcXVpcmUoJy4uL3V0aWxzL2lzLmpzJyk7XG5jb25zdCBzdHJpbmcgPSByZXF1aXJlKCcuLi91dGlscy9zdHJpbmcuanMnKTtcblxuY29uc3QgREVGQVVMVF9MSU1JVCA9IDEwO1xuY29uc3QgSU5URUdSQVRJT05fTkFNRSA9ICdab2RFcnJvcnMnO1xuXG4vKipcbiAqIFNpbXBsaWZpZWQgWm9kSXNzdWUgdHlwZSBkZWZpbml0aW9uXG4gKi9cblxuZnVuY3Rpb24gb3JpZ2luYWxFeGNlcHRpb25Jc1pvZEVycm9yKG9yaWdpbmFsRXhjZXB0aW9uKSB7XG4gIHJldHVybiAoXG4gICAgaXMuaXNFcnJvcihvcmlnaW5hbEV4Y2VwdGlvbikgJiZcbiAgICBvcmlnaW5hbEV4Y2VwdGlvbi5uYW1lID09PSAnWm9kRXJyb3InICYmXG4gICAgQXJyYXkuaXNBcnJheSgob3JpZ2luYWxFeGNlcHRpb24gKS5pc3N1ZXMpXG4gICk7XG59XG5cbi8qKlxuICogRm9ybWF0cyBjaGlsZCBvYmplY3RzIG9yIGFycmF5cyB0byBhIHN0cmluZ1xuICogdGhhdCBpcyBwcmVzZXJ2ZWQgd2hlbiBzZW50IHRvIFNlbnRyeS5cbiAqXG4gKiBXaXRob3V0IHRoaXMsIHdlIGVuZCB1cCB3aXRoIHNvbWV0aGluZyBsaWtlIHRoaXMgaW4gU2VudHJ5OlxuICpcbiAqIFtcbiAqICBbT2JqZWN0XSxcbiAqICBbT2JqZWN0XSxcbiAqICBbT2JqZWN0XSxcbiAqICBbT2JqZWN0XVxuICogXVxuICovXG5mdW5jdGlvbiBmbGF0dGVuSXNzdWUoaXNzdWUpIHtcbiAgcmV0dXJuIHtcbiAgICAuLi5pc3N1ZSxcbiAgICBwYXRoOiAncGF0aCcgaW4gaXNzdWUgJiYgQXJyYXkuaXNBcnJheShpc3N1ZS5wYXRoKSA/IGlzc3VlLnBhdGguam9pbignLicpIDogdW5kZWZpbmVkLFxuICAgIGtleXM6ICdrZXlzJyBpbiBpc3N1ZSA/IEpTT04uc3RyaW5naWZ5KGlzc3VlLmtleXMpIDogdW5kZWZpbmVkLFxuICAgIHVuaW9uRXJyb3JzOiAndW5pb25FcnJvcnMnIGluIGlzc3VlID8gSlNPTi5zdHJpbmdpZnkoaXNzdWUudW5pb25FcnJvcnMpIDogdW5kZWZpbmVkLFxuICB9O1xufVxuXG4vKipcbiAqIFRha2VzIFpvZEVycm9yIGlzc3VlIHBhdGggYXJyYXkgYW5kIHJldHVybnMgYSBmbGF0dGVuZWQgdmVyc2lvbiBhcyBhIHN0cmluZy5cbiAqIFRoaXMgbWFrZXMgaXQgZWFzaWVyIHRvIGRpc3BsYXkgcGF0aHMgd2l0aGluIGEgU2VudHJ5IGVycm9yIG1lc3NhZ2UuXG4gKlxuICogQXJyYXkgaW5kZXhlcyBhcmUgbm9ybWFsaXplZCB0byByZWR1Y2UgZHVwbGljYXRlIGVudHJpZXNcbiAqXG4gKiBAcGFyYW0gcGF0aCBab2RFcnJvciBpc3N1ZSBwYXRoXG4gKiBAcmV0dXJucyBmbGF0dGVuZWQgcGF0aFxuICpcbiAqIEBleGFtcGxlXG4gKiBmbGF0dGVuSXNzdWVQYXRoKFswLCAnZm9vJywgMSwgJ2JhciddKSAvLyAtPiAnPGFycmF5Pi5mb28uPGFycmF5Pi5iYXInXG4gKi9cbmZ1bmN0aW9uIGZsYXR0ZW5Jc3N1ZVBhdGgocGF0aCkge1xuICByZXR1cm4gcGF0aFxuICAgIC5tYXAocCA9PiB7XG4gICAgICBpZiAodHlwZW9mIHAgPT09ICdudW1iZXInKSB7XG4gICAgICAgIHJldHVybiAnPGFycmF5Pic7XG4gICAgICB9IGVsc2Uge1xuICAgICAgICByZXR1cm4gcDtcbiAgICAgIH1cbiAgICB9KVxuICAgIC5qb2luKCcuJyk7XG59XG5cbi8qKlxuICogWm9kIGVycm9yIG1lc3NhZ2UgaXMgYSBzdHJpbmdpZmllZCB2ZXJzaW9uIG9mIFpvZEVycm9yLmlzc3Vlc1xuICogVGhpcyBkb2Vzbid0IGRpc3BsYXkgd2VsbCBpbiB0aGUgU2VudHJ5IFVJLiBSZXBsYWNlIGl0IHdpdGggc29tZXRoaW5nIHNob3J0ZXIuXG4gKi9cbmZ1bmN0aW9uIGZvcm1hdElzc3VlTWVzc2FnZSh6b2RFcnJvcikge1xuICBjb25zdCBlcnJvcktleU1hcCA9IG5ldyBTZXQoKTtcbiAgZm9yIChjb25zdCBpc3Mgb2Ygem9kRXJyb3IuaXNzdWVzKSB7XG4gICAgY29uc3QgaXNzdWVQYXRoID0gZmxhdHRlbklzc3VlUGF0aChpc3MucGF0aCk7XG4gICAgaWYgKGlzc3VlUGF0aC5sZW5ndGggPiAwKSB7XG4gICAgICBlcnJvcktleU1hcC5hZGQoaXNzdWVQYXRoKTtcbiAgICB9XG4gIH1cblxuICBjb25zdCBlcnJvcktleXMgPSBBcnJheS5mcm9tKGVycm9yS2V5TWFwKTtcbiAgaWYgKGVycm9yS2V5cy5sZW5ndGggPT09IDApIHtcbiAgICAvLyBJZiB0aGVyZSBhcmUgbm8ga2V5cywgdGhlbiB3ZSdyZSBsaWtlbHkgdmFsaWRhdGluZyB0aGUgcm9vdFxuICAgIC8vIHZhcmlhYmxlIHJhdGhlciB0aGFuIGEga2V5IHdpdGhpbiBhbiBvYmplY3QuIFRoaXMgYXR0ZW1wdHNcbiAgICAvLyB0byBleHRyYWN0IHdoYXQgdHlwZSBpdCB3YXMgdGhhdCBmYWlsZWQgdG8gdmFsaWRhdGUuXG4gICAgLy8gRm9yIGV4YW1wbGUsIHouc3RyaW5nKCkucGFyc2UoMTIzKSB3b3VsZCByZXR1cm4gXCJzdHJpbmdcIiBoZXJlLlxuICAgIGxldCByb290RXhwZWN0ZWRUeXBlID0gJ3ZhcmlhYmxlJztcbiAgICBpZiAoem9kRXJyb3IuaXNzdWVzLmxlbmd0aCA+IDApIHtcbiAgICAgIGNvbnN0IGlzcyA9IHpvZEVycm9yLmlzc3Vlc1swXTtcbiAgICAgIGlmIChpc3MgIT09IHVuZGVmaW5lZCAmJiAnZXhwZWN0ZWQnIGluIGlzcyAmJiB0eXBlb2YgaXNzLmV4cGVjdGVkID09PSAnc3RyaW5nJykge1xuICAgICAgICByb290RXhwZWN0ZWRUeXBlID0gaXNzLmV4cGVjdGVkO1xuICAgICAgfVxuICAgIH1cbiAgICByZXR1cm4gYEZhaWxlZCB0byB2YWxpZGF0ZSAke3Jvb3RFeHBlY3RlZFR5cGV9YDtcbiAgfVxuICByZXR1cm4gYEZhaWxlZCB0byB2YWxpZGF0ZSBrZXlzOiAke3N0cmluZy50cnVuY2F0ZShlcnJvcktleXMuam9pbignLCAnKSwgMTAwKX1gO1xufVxuXG4vKipcbiAqIEFwcGxpZXMgWm9kRXJyb3IgaXNzdWVzIHRvIGFuIGV2ZW50IGV4dHJhIGFuZCByZXBsYWNlcyB0aGUgZXJyb3IgbWVzc2FnZVxuICovXG5mdW5jdGlvbiBhcHBseVpvZEVycm9yc1RvRXZlbnQoXG4gIGxpbWl0LFxuICBzYXZlWm9kSXNzdWVzQXNBdHRhY2htZW50ID0gZmFsc2UsXG4gIGV2ZW50LFxuICBoaW50LFxuKSB7XG4gIGlmIChcbiAgICAhZXZlbnQuZXhjZXB0aW9uPy52YWx1ZXMgfHxcbiAgICAhaGludC5vcmlnaW5hbEV4Y2VwdGlvbiB8fFxuICAgICFvcmlnaW5hbEV4Y2VwdGlvbklzWm9kRXJyb3IoaGludC5vcmlnaW5hbEV4Y2VwdGlvbikgfHxcbiAgICBoaW50Lm9yaWdpbmFsRXhjZXB0aW9uLmlzc3Vlcy5sZW5ndGggPT09IDBcbiAgKSB7XG4gICAgcmV0dXJuIGV2ZW50O1xuICB9XG5cbiAgdHJ5IHtcbiAgICBjb25zdCBpc3N1ZXNUb0ZsYXR0ZW4gPSBzYXZlWm9kSXNzdWVzQXNBdHRhY2htZW50XG4gICAgICA/IGhpbnQub3JpZ2luYWxFeGNlcHRpb24uaXNzdWVzXG4gICAgICA6IGhpbnQub3JpZ2luYWxFeGNlcHRpb24uaXNzdWVzLnNsaWNlKDAsIGxpbWl0KTtcbiAgICBjb25zdCBmbGF0dGVuZWRJc3N1ZXMgPSBpc3N1ZXNUb0ZsYXR0ZW4ubWFwKGZsYXR0ZW5Jc3N1ZSk7XG5cbiAgICBpZiAoc2F2ZVpvZElzc3Vlc0FzQXR0YWNobWVudCkge1xuICAgICAgLy8gU29tZXRpbWVzIGhhdmluZyB0aGUgZnVsbCBlcnJvciBkZXRhaWxzIGNhbiBiZSBoZWxwZnVsLlxuICAgICAgLy8gQXR0YWNobWVudHMgaGF2ZSBtdWNoIGhpZ2hlciBsaW1pdHMsIHNvIHdlIGNhbiBpbmNsdWRlIHRoZSBmdWxsIGxpc3Qgb2YgaXNzdWVzLlxuICAgICAgaWYgKCFBcnJheS5pc0FycmF5KGhpbnQuYXR0YWNobWVudHMpKSB7XG4gICAgICAgIGhpbnQuYXR0YWNobWVudHMgPSBbXTtcbiAgICAgIH1cbiAgICAgIGhpbnQuYXR0YWNobWVudHMucHVzaCh7XG4gICAgICAgIGZpbGVuYW1lOiAnem9kX2lzc3Vlcy5qc29uJyxcbiAgICAgICAgZGF0YTogSlNPTi5zdHJpbmdpZnkoe1xuICAgICAgICAgIGlzc3VlczogZmxhdHRlbmVkSXNzdWVzLFxuICAgICAgICB9KSxcbiAgICAgIH0pO1xuICAgIH1cblxuICAgIHJldHVybiB7XG4gICAgICAuLi5ldmVudCxcbiAgICAgIGV4Y2VwdGlvbjoge1xuICAgICAgICAuLi5ldmVudC5leGNlcHRpb24sXG4gICAgICAgIHZhbHVlczogW1xuICAgICAgICAgIHtcbiAgICAgICAgICAgIC4uLmV2ZW50LmV4Y2VwdGlvbi52YWx1ZXNbMF0sXG4gICAgICAgICAgICB2YWx1ZTogZm9ybWF0SXNzdWVNZXNzYWdlKGhpbnQub3JpZ2luYWxFeGNlcHRpb24pLFxuICAgICAgICAgIH0sXG4gICAgICAgICAgLi4uZXZlbnQuZXhjZXB0aW9uLnZhbHVlcy5zbGljZSgxKSxcbiAgICAgICAgXSxcbiAgICAgIH0sXG4gICAgICBleHRyYToge1xuICAgICAgICAuLi5ldmVudC5leHRyYSxcbiAgICAgICAgJ3pvZGVycm9yLmlzc3Vlcyc6IGZsYXR0ZW5lZElzc3Vlcy5zbGljZSgwLCBsaW1pdCksXG4gICAgICB9LFxuICAgIH07XG4gIH0gY2F0Y2ggKGUpIHtcbiAgICAvLyBIb3BlZnVsbHkgd2UgbmV2ZXIgdGhyb3cgZXJyb3JzIGhlcmUsIGJ1dCByZWNvcmQgaXRcbiAgICAvLyB3aXRoIHRoZSBldmVudCBqdXN0IGluIGNhc2UuXG4gICAgcmV0dXJuIHtcbiAgICAgIC4uLmV2ZW50LFxuICAgICAgZXh0cmE6IHtcbiAgICAgICAgLi4uZXZlbnQuZXh0cmEsXG4gICAgICAgICd6b2RlcnJvcnMgc2VudHJ5IGludGVncmF0aW9uIHBhcnNlIGVycm9yJzoge1xuICAgICAgICAgIG1lc3NhZ2U6ICdhbiBleGNlcHRpb24gd2FzIHRocm93biB3aGlsZSBwcm9jZXNzaW5nIFpvZEVycm9yIHdpdGhpbiBhcHBseVpvZEVycm9yc1RvRXZlbnQoKScsXG4gICAgICAgICAgZXJyb3I6IGUgaW5zdGFuY2VvZiBFcnJvciA/IGAke2UubmFtZX06ICR7ZS5tZXNzYWdlfVxcbiR7ZS5zdGFja31gIDogJ3Vua25vd24nLFxuICAgICAgICB9LFxuICAgICAgfSxcbiAgICB9O1xuICB9XG59XG5cbmNvbnN0IF96b2RFcnJvcnNJbnRlZ3JhdGlvbiA9ICgob3B0aW9ucyA9IHt9KSA9PiB7XG4gIGNvbnN0IGxpbWl0ID0gb3B0aW9ucy5saW1pdCA/PyBERUZBVUxUX0xJTUlUO1xuXG4gIHJldHVybiB7XG4gICAgbmFtZTogSU5URUdSQVRJT05fTkFNRSxcbiAgICBwcm9jZXNzRXZlbnQob3JpZ2luYWxFdmVudCwgaGludCkge1xuICAgICAgY29uc3QgcHJvY2Vzc2VkRXZlbnQgPSBhcHBseVpvZEVycm9yc1RvRXZlbnQobGltaXQsIG9wdGlvbnMuc2F2ZVpvZElzc3Vlc0FzQXR0YWNobWVudCwgb3JpZ2luYWxFdmVudCwgaGludCk7XG4gICAgICByZXR1cm4gcHJvY2Vzc2VkRXZlbnQ7XG4gICAgfSxcbiAgfTtcbn0pIDtcblxuLyoqXG4gKiBTZW50cnkgaW50ZWdyYXRpb24gdG8gcHJvY2VzcyBab2QgZXJyb3JzLCBtYWtpbmcgdGhlbSBlYXNpZXIgdG8gd29yayB3aXRoIGluIFNlbnRyeS5cbiAqL1xuY29uc3Qgem9kRXJyb3JzSW50ZWdyYXRpb24gPSBpbnRlZ3JhdGlvbi5kZWZpbmVJbnRlZ3JhdGlvbihfem9kRXJyb3JzSW50ZWdyYXRpb24pO1xuXG5leHBvcnRzLmFwcGx5Wm9kRXJyb3JzVG9FdmVudCA9IGFwcGx5Wm9kRXJyb3JzVG9FdmVudDtcbmV4cG9ydHMuZmxhdHRlbklzc3VlID0gZmxhdHRlbklzc3VlO1xuZXhwb3J0cy5mbGF0dGVuSXNzdWVQYXRoID0gZmxhdHRlbklzc3VlUGF0aDtcbmV4cG9ydHMuZm9ybWF0SXNzdWVNZXNzYWdlID0gZm9ybWF0SXNzdWVNZXNzYWdlO1xuZXhwb3J0cy56b2RFcnJvcnNJbnRlZ3JhdGlvbiA9IHpvZEVycm9yc0ludGVncmF0aW9uO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9em9kZXJyb3JzLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integrations/zoderrors.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/logs/console-integration.js":
/*!****************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/logs/console-integration.js ***!
  \****************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst currentScopes = __webpack_require__(/*! ../currentScopes.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst debugBuild = __webpack_require__(/*! ../debug-build.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst console = __webpack_require__(/*! ../instrument/console.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/console.js\");\nconst integration = __webpack_require__(/*! ../integration.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/integration.js\");\nconst semanticAttributes = __webpack_require__(/*! ../semanticAttributes.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/semanticAttributes.js\");\nconst debugLogger = __webpack_require__(/*! ../utils/debug-logger.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst is = __webpack_require__(/*! ../utils/is.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js\");\nconst normalize = __webpack_require__(/*! ../utils/normalize.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/normalize.js\");\nconst worldwide = __webpack_require__(/*! ../utils/worldwide.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/worldwide.js\");\nconst exports$1 = __webpack_require__(/*! ./exports.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/logs/exports.js\");\n\nconst INTEGRATION_NAME = 'ConsoleLogs';\n\nconst DEFAULT_ATTRIBUTES = {\n  [semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_ORIGIN]: 'auto.console.logging',\n};\n\nconst _consoleLoggingIntegration = ((options = {}) => {\n  const levels = options.levels || debugLogger.CONSOLE_LEVELS;\n\n  return {\n    name: INTEGRATION_NAME,\n    setup(client) {\n      const { enableLogs, _experiments, normalizeDepth = 3, normalizeMaxBreadth = 1000 } = client.getOptions();\n      // eslint-disable-next-line deprecation/deprecation\n      const shouldEnableLogs = enableLogs ?? _experiments?.enableLogs;\n      if (!shouldEnableLogs) {\n        debugBuild.DEBUG_BUILD && debugLogger.debug.warn('`enableLogs` is not enabled, ConsoleLogs integration disabled');\n        return;\n      }\n\n      console.addConsoleInstrumentationHandler(({ args, level }) => {\n        if (currentScopes.getClient() !== client || !levels.includes(level)) {\n          return;\n        }\n\n        if (level === 'assert') {\n          if (!args[0]) {\n            const followingArgs = args.slice(1);\n            const assertionMessage =\n              followingArgs.length > 0\n                ? `Assertion failed: ${formatConsoleArgs(followingArgs, normalizeDepth, normalizeMaxBreadth)}`\n                : 'Assertion failed';\n            exports$1._INTERNAL_captureLog({ level: 'error', message: assertionMessage, attributes: DEFAULT_ATTRIBUTES });\n          }\n          return;\n        }\n\n        const isLevelLog = level === 'log';\n        exports$1._INTERNAL_captureLog({\n          level: isLevelLog ? 'info' : level,\n          message: formatConsoleArgs(args, normalizeDepth, normalizeMaxBreadth),\n          severityNumber: isLevelLog ? 10 : undefined,\n          attributes: DEFAULT_ATTRIBUTES,\n        });\n      });\n    },\n  };\n}) ;\n\n/**\n * Captures calls to the `console` API as logs in Sentry. Requires the `enableLogs` option to be enabled.\n *\n * @experimental This feature is experimental and may be changed or removed in future versions.\n *\n * By default the integration instruments `console.debug`, `console.info`, `console.warn`, `console.error`,\n * `console.log`, `console.trace`, and `console.assert`. You can use the `levels` option to customize which\n * levels are captured.\n *\n * @example\n *\n * ```ts\n * import * as Sentry from '@sentry/browser';\n *\n * Sentry.init({\n *   enableLogs: true,\n *   integrations: [Sentry.consoleLoggingIntegration({ levels: ['error', 'warn'] })],\n * });\n * ```\n */\nconst consoleLoggingIntegration = integration.defineIntegration(_consoleLoggingIntegration);\n\nfunction formatConsoleArgs(values, normalizeDepth, normalizeMaxBreadth) {\n  return 'util' in worldwide.GLOBAL_OBJ && typeof (worldwide.GLOBAL_OBJ ).util.format === 'function'\n    ? (worldwide.GLOBAL_OBJ ).util.format(...values)\n    : safeJoinConsoleArgs(values, normalizeDepth, normalizeMaxBreadth);\n}\n\nfunction safeJoinConsoleArgs(values, normalizeDepth, normalizeMaxBreadth) {\n  return values\n    .map(value =>\n      is.isPrimitive(value) ? String(value) : JSON.stringify(normalize.normalize(value, normalizeDepth, normalizeMaxBreadth)),\n    )\n    .join(' ');\n}\n\nexports.consoleLoggingIntegration = consoleLoggingIntegration;\n//# sourceMappingURL=console-integration.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9sb2dzL2NvbnNvbGUtaW50ZWdyYXRpb24uanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsc0JBQXNCLG1CQUFPLENBQUMsZ0lBQXFCO0FBQ25ELG1CQUFtQixtQkFBTyxDQUFDLDRIQUFtQjtBQUM5QyxnQkFBZ0IsbUJBQU8sQ0FBQywwSUFBMEI7QUFDbEQsb0JBQW9CLG1CQUFPLENBQUMsNEhBQW1CO0FBQy9DLDJCQUEyQixtQkFBTyxDQUFDLDBJQUEwQjtBQUM3RCxvQkFBb0IsbUJBQU8sQ0FBQywwSUFBMEI7QUFDdEQsV0FBVyxtQkFBTyxDQUFDLHNIQUFnQjtBQUNuQyxrQkFBa0IsbUJBQU8sQ0FBQyxvSUFBdUI7QUFDakQsa0JBQWtCLG1CQUFPLENBQUMsb0lBQXVCO0FBQ2pELGtCQUFrQixtQkFBTyxDQUFDLHdIQUFjOztBQUV4Qzs7QUFFQTtBQUNBO0FBQ0E7O0FBRUEsaURBQWlEO0FBQ2pEOztBQUVBO0FBQ0E7QUFDQTtBQUNBLGNBQWMsMkVBQTJFO0FBQ3pGO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSxrREFBa0QsYUFBYTtBQUMvRDtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLHVDQUF1QyxzRUFBc0U7QUFDN0c7QUFDQSw2Q0FBNkMsMkVBQTJFO0FBQ3hIO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxTQUFTO0FBQ1QsT0FBTztBQUNQLEtBQUs7QUFDTDtBQUNBLENBQUM7O0FBRUQ7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSx1REFBdUQsMkJBQTJCO0FBQ2xGLElBQUk7QUFDSjtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSxpQ0FBaUM7QUFDakMiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9sb2dzL2NvbnNvbGUtaW50ZWdyYXRpb24uanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGN1cnJlbnRTY29wZXMgPSByZXF1aXJlKCcuLi9jdXJyZW50U2NvcGVzLmpzJyk7XG5jb25zdCBkZWJ1Z0J1aWxkID0gcmVxdWlyZSgnLi4vZGVidWctYnVpbGQuanMnKTtcbmNvbnN0IGNvbnNvbGUgPSByZXF1aXJlKCcuLi9pbnN0cnVtZW50L2NvbnNvbGUuanMnKTtcbmNvbnN0IGludGVncmF0aW9uID0gcmVxdWlyZSgnLi4vaW50ZWdyYXRpb24uanMnKTtcbmNvbnN0IHNlbWFudGljQXR0cmlidXRlcyA9IHJlcXVpcmUoJy4uL3NlbWFudGljQXR0cmlidXRlcy5qcycpO1xuY29uc3QgZGVidWdMb2dnZXIgPSByZXF1aXJlKCcuLi91dGlscy9kZWJ1Zy1sb2dnZXIuanMnKTtcbmNvbnN0IGlzID0gcmVxdWlyZSgnLi4vdXRpbHMvaXMuanMnKTtcbmNvbnN0IG5vcm1hbGl6ZSA9IHJlcXVpcmUoJy4uL3V0aWxzL25vcm1hbGl6ZS5qcycpO1xuY29uc3Qgd29ybGR3aWRlID0gcmVxdWlyZSgnLi4vdXRpbHMvd29ybGR3aWRlLmpzJyk7XG5jb25zdCBleHBvcnRzJDEgPSByZXF1aXJlKCcuL2V4cG9ydHMuanMnKTtcblxuY29uc3QgSU5URUdSQVRJT05fTkFNRSA9ICdDb25zb2xlTG9ncyc7XG5cbmNvbnN0IERFRkFVTFRfQVRUUklCVVRFUyA9IHtcbiAgW3NlbWFudGljQXR0cmlidXRlcy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX09SSUdJTl06ICdhdXRvLmNvbnNvbGUubG9nZ2luZycsXG59O1xuXG5jb25zdCBfY29uc29sZUxvZ2dpbmdJbnRlZ3JhdGlvbiA9ICgob3B0aW9ucyA9IHt9KSA9PiB7XG4gIGNvbnN0IGxldmVscyA9IG9wdGlvbnMubGV2ZWxzIHx8IGRlYnVnTG9nZ2VyLkNPTlNPTEVfTEVWRUxTO1xuXG4gIHJldHVybiB7XG4gICAgbmFtZTogSU5URUdSQVRJT05fTkFNRSxcbiAgICBzZXR1cChjbGllbnQpIHtcbiAgICAgIGNvbnN0IHsgZW5hYmxlTG9ncywgX2V4cGVyaW1lbnRzLCBub3JtYWxpemVEZXB0aCA9IDMsIG5vcm1hbGl6ZU1heEJyZWFkdGggPSAxMDAwIH0gPSBjbGllbnQuZ2V0T3B0aW9ucygpO1xuICAgICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIGRlcHJlY2F0aW9uL2RlcHJlY2F0aW9uXG4gICAgICBjb25zdCBzaG91bGRFbmFibGVMb2dzID0gZW5hYmxlTG9ncyA/PyBfZXhwZXJpbWVudHM/LmVuYWJsZUxvZ3M7XG4gICAgICBpZiAoIXNob3VsZEVuYWJsZUxvZ3MpIHtcbiAgICAgICAgZGVidWdCdWlsZC5ERUJVR19CVUlMRCAmJiBkZWJ1Z0xvZ2dlci5kZWJ1Zy53YXJuKCdgZW5hYmxlTG9nc2AgaXMgbm90IGVuYWJsZWQsIENvbnNvbGVMb2dzIGludGVncmF0aW9uIGRpc2FibGVkJyk7XG4gICAgICAgIHJldHVybjtcbiAgICAgIH1cblxuICAgICAgY29uc29sZS5hZGRDb25zb2xlSW5zdHJ1bWVudGF0aW9uSGFuZGxlcigoeyBhcmdzLCBsZXZlbCB9KSA9PiB7XG4gICAgICAgIGlmIChjdXJyZW50U2NvcGVzLmdldENsaWVudCgpICE9PSBjbGllbnQgfHwgIWxldmVscy5pbmNsdWRlcyhsZXZlbCkpIHtcbiAgICAgICAgICByZXR1cm47XG4gICAgICAgIH1cblxuICAgICAgICBpZiAobGV2ZWwgPT09ICdhc3NlcnQnKSB7XG4gICAgICAgICAgaWYgKCFhcmdzWzBdKSB7XG4gICAgICAgICAgICBjb25zdCBmb2xsb3dpbmdBcmdzID0gYXJncy5zbGljZSgxKTtcbiAgICAgICAgICAgIGNvbnN0IGFzc2VydGlvbk1lc3NhZ2UgPVxuICAgICAgICAgICAgICBmb2xsb3dpbmdBcmdzLmxlbmd0aCA+IDBcbiAgICAgICAgICAgICAgICA/IGBBc3NlcnRpb24gZmFpbGVkOiAke2Zvcm1hdENvbnNvbGVBcmdzKGZvbGxvd2luZ0FyZ3MsIG5vcm1hbGl6ZURlcHRoLCBub3JtYWxpemVNYXhCcmVhZHRoKX1gXG4gICAgICAgICAgICAgICAgOiAnQXNzZXJ0aW9uIGZhaWxlZCc7XG4gICAgICAgICAgICBleHBvcnRzJDEuX0lOVEVSTkFMX2NhcHR1cmVMb2coeyBsZXZlbDogJ2Vycm9yJywgbWVzc2FnZTogYXNzZXJ0aW9uTWVzc2FnZSwgYXR0cmlidXRlczogREVGQVVMVF9BVFRSSUJVVEVTIH0pO1xuICAgICAgICAgIH1cbiAgICAgICAgICByZXR1cm47XG4gICAgICAgIH1cblxuICAgICAgICBjb25zdCBpc0xldmVsTG9nID0gbGV2ZWwgPT09ICdsb2cnO1xuICAgICAgICBleHBvcnRzJDEuX0lOVEVSTkFMX2NhcHR1cmVMb2coe1xuICAgICAgICAgIGxldmVsOiBpc0xldmVsTG9nID8gJ2luZm8nIDogbGV2ZWwsXG4gICAgICAgICAgbWVzc2FnZTogZm9ybWF0Q29uc29sZUFyZ3MoYXJncywgbm9ybWFsaXplRGVwdGgsIG5vcm1hbGl6ZU1heEJyZWFkdGgpLFxuICAgICAgICAgIHNldmVyaXR5TnVtYmVyOiBpc0xldmVsTG9nID8gMTAgOiB1bmRlZmluZWQsXG4gICAgICAgICAgYXR0cmlidXRlczogREVGQVVMVF9BVFRSSUJVVEVTLFxuICAgICAgICB9KTtcbiAgICAgIH0pO1xuICAgIH0sXG4gIH07XG59KSA7XG5cbi8qKlxuICogQ2FwdHVyZXMgY2FsbHMgdG8gdGhlIGBjb25zb2xlYCBBUEkgYXMgbG9ncyBpbiBTZW50cnkuIFJlcXVpcmVzIHRoZSBgZW5hYmxlTG9nc2Agb3B0aW9uIHRvIGJlIGVuYWJsZWQuXG4gKlxuICogQGV4cGVyaW1lbnRhbCBUaGlzIGZlYXR1cmUgaXMgZXhwZXJpbWVudGFsIGFuZCBtYXkgYmUgY2hhbmdlZCBvciByZW1vdmVkIGluIGZ1dHVyZSB2ZXJzaW9ucy5cbiAqXG4gKiBCeSBkZWZhdWx0IHRoZSBpbnRlZ3JhdGlvbiBpbnN0cnVtZW50cyBgY29uc29sZS5kZWJ1Z2AsIGBjb25zb2xlLmluZm9gLCBgY29uc29sZS53YXJuYCwgYGNvbnNvbGUuZXJyb3JgLFxuICogYGNvbnNvbGUubG9nYCwgYGNvbnNvbGUudHJhY2VgLCBhbmQgYGNvbnNvbGUuYXNzZXJ0YC4gWW91IGNhbiB1c2UgdGhlIGBsZXZlbHNgIG9wdGlvbiB0byBjdXN0b21pemUgd2hpY2hcbiAqIGxldmVscyBhcmUgY2FwdHVyZWQuXG4gKlxuICogQGV4YW1wbGVcbiAqXG4gKiBgYGB0c1xuICogaW1wb3J0ICogYXMgU2VudHJ5IGZyb20gJ0BzZW50cnkvYnJvd3Nlcic7XG4gKlxuICogU2VudHJ5LmluaXQoe1xuICogICBlbmFibGVMb2dzOiB0cnVlLFxuICogICBpbnRlZ3JhdGlvbnM6IFtTZW50cnkuY29uc29sZUxvZ2dpbmdJbnRlZ3JhdGlvbih7IGxldmVsczogWydlcnJvcicsICd3YXJuJ10gfSldLFxuICogfSk7XG4gKiBgYGBcbiAqL1xuY29uc3QgY29uc29sZUxvZ2dpbmdJbnRlZ3JhdGlvbiA9IGludGVncmF0aW9uLmRlZmluZUludGVncmF0aW9uKF9jb25zb2xlTG9nZ2luZ0ludGVncmF0aW9uKTtcblxuZnVuY3Rpb24gZm9ybWF0Q29uc29sZUFyZ3ModmFsdWVzLCBub3JtYWxpemVEZXB0aCwgbm9ybWFsaXplTWF4QnJlYWR0aCkge1xuICByZXR1cm4gJ3V0aWwnIGluIHdvcmxkd2lkZS5HTE9CQUxfT0JKICYmIHR5cGVvZiAod29ybGR3aWRlLkdMT0JBTF9PQkogKS51dGlsLmZvcm1hdCA9PT0gJ2Z1bmN0aW9uJ1xuICAgID8gKHdvcmxkd2lkZS5HTE9CQUxfT0JKICkudXRpbC5mb3JtYXQoLi4udmFsdWVzKVxuICAgIDogc2FmZUpvaW5Db25zb2xlQXJncyh2YWx1ZXMsIG5vcm1hbGl6ZURlcHRoLCBub3JtYWxpemVNYXhCcmVhZHRoKTtcbn1cblxuZnVuY3Rpb24gc2FmZUpvaW5Db25zb2xlQXJncyh2YWx1ZXMsIG5vcm1hbGl6ZURlcHRoLCBub3JtYWxpemVNYXhCcmVhZHRoKSB7XG4gIHJldHVybiB2YWx1ZXNcbiAgICAubWFwKHZhbHVlID0+XG4gICAgICBpcy5pc1ByaW1pdGl2ZSh2YWx1ZSkgPyBTdHJpbmcodmFsdWUpIDogSlNPTi5zdHJpbmdpZnkobm9ybWFsaXplLm5vcm1hbGl6ZSh2YWx1ZSwgbm9ybWFsaXplRGVwdGgsIG5vcm1hbGl6ZU1heEJyZWFkdGgpKSxcbiAgICApXG4gICAgLmpvaW4oJyAnKTtcbn1cblxuZXhwb3J0cy5jb25zb2xlTG9nZ2luZ0ludGVncmF0aW9uID0gY29uc29sZUxvZ2dpbmdJbnRlZ3JhdGlvbjtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWNvbnNvbGUtaW50ZWdyYXRpb24uanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/logs/console-integration.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/logs/constants.js":
/*!******************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/logs/constants.js ***!
  \******************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n/**\n * Maps a log severity level to a log severity number.\n *\n * @see LogSeverityLevel\n */\nconst SEVERITY_TEXT_TO_SEVERITY_NUMBER = {\n  trace: 1,\n  debug: 5,\n  info: 9,\n  warn: 13,\n  error: 17,\n  fatal: 21,\n};\n\nexports.SEVERITY_TEXT_TO_SEVERITY_NUMBER = SEVERITY_TEXT_TO_SEVERITY_NUMBER;\n//# sourceMappingURL=constants.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9sb2dzL2NvbnN0YW50cy5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSx3Q0FBd0M7QUFDeEMiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9sb2dzL2NvbnN0YW50cy5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuLyoqXG4gKiBNYXBzIGEgbG9nIHNldmVyaXR5IGxldmVsIHRvIGEgbG9nIHNldmVyaXR5IG51bWJlci5cbiAqXG4gKiBAc2VlIExvZ1NldmVyaXR5TGV2ZWxcbiAqL1xuY29uc3QgU0VWRVJJVFlfVEVYVF9UT19TRVZFUklUWV9OVU1CRVIgPSB7XG4gIHRyYWNlOiAxLFxuICBkZWJ1ZzogNSxcbiAgaW5mbzogOSxcbiAgd2FybjogMTMsXG4gIGVycm9yOiAxNyxcbiAgZmF0YWw6IDIxLFxufTtcblxuZXhwb3J0cy5TRVZFUklUWV9URVhUX1RPX1NFVkVSSVRZX05VTUJFUiA9IFNFVkVSSVRZX1RFWFRfVE9fU0VWRVJJVFlfTlVNQkVSO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9Y29uc3RhbnRzLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/logs/constants.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/logs/envelope.js":
/*!*****************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/logs/envelope.js ***!
  \*****************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst dsn = __webpack_require__(/*! ../utils/dsn.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/dsn.js\");\nconst envelope = __webpack_require__(/*! ../utils/envelope.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/envelope.js\");\n\n/**\n * Creates a log container envelope item for a list of logs.\n *\n * @param items - The logs to include in the envelope.\n * @returns The created log container envelope item.\n */\nfunction createLogContainerEnvelopeItem(items) {\n  return [\n    {\n      type: 'log',\n      item_count: items.length,\n      content_type: 'application/vnd.sentry.items.log+json',\n    },\n    {\n      items,\n    },\n  ];\n}\n\n/**\n * Creates an envelope for a list of logs.\n *\n * Logs from multiple traces can be included in the same envelope.\n *\n * @param logs - The logs to include in the envelope.\n * @param metadata - The metadata to include in the envelope.\n * @param tunnel - The tunnel to include in the envelope.\n * @param dsn - The DSN to include in the envelope.\n * @returns The created envelope.\n */\nfunction createLogEnvelope(\n  logs,\n  metadata,\n  tunnel,\n  dsn$1,\n) {\n  const headers = {};\n\n  if (metadata?.sdk) {\n    headers.sdk = {\n      name: metadata.sdk.name,\n      version: metadata.sdk.version,\n    };\n  }\n\n  if (!!tunnel && !!dsn$1) {\n    headers.dsn = dsn.dsnToString(dsn$1);\n  }\n\n  return envelope.createEnvelope(headers, [createLogContainerEnvelopeItem(logs)]);\n}\n\nexports.createLogContainerEnvelopeItem = createLogContainerEnvelopeItem;\nexports.createLogEnvelope = createLogEnvelope;\n//# sourceMappingURL=envelope.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9sb2dzL2VudmVsb3BlLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLFlBQVksbUJBQU8sQ0FBQyx3SEFBaUI7QUFDckMsaUJBQWlCLG1CQUFPLENBQUMsa0lBQXNCOztBQUUvQztBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxLQUFLO0FBQ0w7QUFDQTtBQUNBLEtBQUs7QUFDTDtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUEsc0NBQXNDO0FBQ3RDLHlCQUF5QjtBQUN6QiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL2xvZ3MvZW52ZWxvcGUuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGRzbiA9IHJlcXVpcmUoJy4uL3V0aWxzL2Rzbi5qcycpO1xuY29uc3QgZW52ZWxvcGUgPSByZXF1aXJlKCcuLi91dGlscy9lbnZlbG9wZS5qcycpO1xuXG4vKipcbiAqIENyZWF0ZXMgYSBsb2cgY29udGFpbmVyIGVudmVsb3BlIGl0ZW0gZm9yIGEgbGlzdCBvZiBsb2dzLlxuICpcbiAqIEBwYXJhbSBpdGVtcyAtIFRoZSBsb2dzIHRvIGluY2x1ZGUgaW4gdGhlIGVudmVsb3BlLlxuICogQHJldHVybnMgVGhlIGNyZWF0ZWQgbG9nIGNvbnRhaW5lciBlbnZlbG9wZSBpdGVtLlxuICovXG5mdW5jdGlvbiBjcmVhdGVMb2dDb250YWluZXJFbnZlbG9wZUl0ZW0oaXRlbXMpIHtcbiAgcmV0dXJuIFtcbiAgICB7XG4gICAgICB0eXBlOiAnbG9nJyxcbiAgICAgIGl0ZW1fY291bnQ6IGl0ZW1zLmxlbmd0aCxcbiAgICAgIGNvbnRlbnRfdHlwZTogJ2FwcGxpY2F0aW9uL3ZuZC5zZW50cnkuaXRlbXMubG9nK2pzb24nLFxuICAgIH0sXG4gICAge1xuICAgICAgaXRlbXMsXG4gICAgfSxcbiAgXTtcbn1cblxuLyoqXG4gKiBDcmVhdGVzIGFuIGVudmVsb3BlIGZvciBhIGxpc3Qgb2YgbG9ncy5cbiAqXG4gKiBMb2dzIGZyb20gbXVsdGlwbGUgdHJhY2VzIGNhbiBiZSBpbmNsdWRlZCBpbiB0aGUgc2FtZSBlbnZlbG9wZS5cbiAqXG4gKiBAcGFyYW0gbG9ncyAtIFRoZSBsb2dzIHRvIGluY2x1ZGUgaW4gdGhlIGVudmVsb3BlLlxuICogQHBhcmFtIG1ldGFkYXRhIC0gVGhlIG1ldGFkYXRhIHRvIGluY2x1ZGUgaW4gdGhlIGVudmVsb3BlLlxuICogQHBhcmFtIHR1bm5lbCAtIFRoZSB0dW5uZWwgdG8gaW5jbHVkZSBpbiB0aGUgZW52ZWxvcGUuXG4gKiBAcGFyYW0gZHNuIC0gVGhlIERTTiB0byBpbmNsdWRlIGluIHRoZSBlbnZlbG9wZS5cbiAqIEByZXR1cm5zIFRoZSBjcmVhdGVkIGVudmVsb3BlLlxuICovXG5mdW5jdGlvbiBjcmVhdGVMb2dFbnZlbG9wZShcbiAgbG9ncyxcbiAgbWV0YWRhdGEsXG4gIHR1bm5lbCxcbiAgZHNuJDEsXG4pIHtcbiAgY29uc3QgaGVhZGVycyA9IHt9O1xuXG4gIGlmIChtZXRhZGF0YT8uc2RrKSB7XG4gICAgaGVhZGVycy5zZGsgPSB7XG4gICAgICBuYW1lOiBtZXRhZGF0YS5zZGsubmFtZSxcbiAgICAgIHZlcnNpb246IG1ldGFkYXRhLnNkay52ZXJzaW9uLFxuICAgIH07XG4gIH1cblxuICBpZiAoISF0dW5uZWwgJiYgISFkc24kMSkge1xuICAgIGhlYWRlcnMuZHNuID0gZHNuLmRzblRvU3RyaW5nKGRzbiQxKTtcbiAgfVxuXG4gIHJldHVybiBlbnZlbG9wZS5jcmVhdGVFbnZlbG9wZShoZWFkZXJzLCBbY3JlYXRlTG9nQ29udGFpbmVyRW52ZWxvcGVJdGVtKGxvZ3MpXSk7XG59XG5cbmV4cG9ydHMuY3JlYXRlTG9nQ29udGFpbmVyRW52ZWxvcGVJdGVtID0gY3JlYXRlTG9nQ29udGFpbmVyRW52ZWxvcGVJdGVtO1xuZXhwb3J0cy5jcmVhdGVMb2dFbnZlbG9wZSA9IGNyZWF0ZUxvZ0VudmVsb3BlO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9ZW52ZWxvcGUuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/logs/envelope.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/logs/exports.js":
/*!****************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/logs/exports.js ***!
  \****************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst carrier = __webpack_require__(/*! ../carrier.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/carrier.js\");\nconst client = __webpack_require__(/*! ../client.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/client.js\");\nconst currentScopes = __webpack_require__(/*! ../currentScopes.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst debugBuild = __webpack_require__(/*! ../debug-build.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst applyScopeDataToEvent = __webpack_require__(/*! ../utils/applyScopeDataToEvent.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/applyScopeDataToEvent.js\");\nconst debugLogger = __webpack_require__(/*! ../utils/debug-logger.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst is = __webpack_require__(/*! ../utils/is.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js\");\nconst spanOnScope = __webpack_require__(/*! ../utils/spanOnScope.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanOnScope.js\");\nconst time = __webpack_require__(/*! ../utils/time.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/time.js\");\nconst constants = __webpack_require__(/*! ./constants.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/logs/constants.js\");\nconst envelope = __webpack_require__(/*! ./envelope.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/logs/envelope.js\");\n\nconst MAX_LOG_BUFFER_SIZE = 100;\n\n/**\n * Converts a log attribute to a serialized log attribute.\n *\n * @param key - The key of the log attribute.\n * @param value - The value of the log attribute.\n * @returns The serialized log attribute.\n */\nfunction logAttributeToSerializedLogAttribute(value) {\n  switch (typeof value) {\n    case 'number':\n      if (Number.isInteger(value)) {\n        return {\n          value,\n          type: 'integer',\n        };\n      }\n      return {\n        value,\n        type: 'double',\n      };\n    case 'boolean':\n      return {\n        value,\n        type: 'boolean',\n      };\n    case 'string':\n      return {\n        value,\n        type: 'string',\n      };\n    default: {\n      let stringValue = '';\n      try {\n        stringValue = JSON.stringify(value) ?? '';\n      } catch {\n        // Do nothing\n      }\n      return {\n        value: stringValue,\n        type: 'string',\n      };\n    }\n  }\n}\n\n/**\n * Sets a log attribute if the value exists and the attribute key is not already present.\n *\n * @param logAttributes - The log attributes object to modify.\n * @param key - The attribute key to set.\n * @param value - The value to set (only sets if truthy and key not present).\n * @param setEvenIfPresent - Whether to set the attribute if it is present. Defaults to true.\n */\nfunction setLogAttribute(\n  logAttributes,\n  key,\n  value,\n  setEvenIfPresent = true,\n) {\n  if (value && (!logAttributes[key] || setEvenIfPresent)) {\n    logAttributes[key] = value;\n  }\n}\n\n/**\n * Captures a serialized log event and adds it to the log buffer for the given client.\n *\n * @param client - A client. Uses the current client if not provided.\n * @param serializedLog - The serialized log event to capture.\n *\n * @experimental This method will experience breaking changes. This is not yet part of\n * the stable Sentry SDK API and can be changed or removed without warning.\n */\nfunction _INTERNAL_captureSerializedLog(client, serializedLog) {\n  const bufferMap = _getBufferMap();\n\n  const logBuffer = _INTERNAL_getLogBuffer(client);\n  if (logBuffer === undefined) {\n    bufferMap.set(client, [serializedLog]);\n  } else {\n    bufferMap.set(client, [...logBuffer, serializedLog]);\n    if (logBuffer.length >= MAX_LOG_BUFFER_SIZE) {\n      _INTERNAL_flushLogsBuffer(client, logBuffer);\n    }\n  }\n}\n\n/**\n * Captures a log event and sends it to Sentry.\n *\n * @param log - The log event to capture.\n * @param scope - A scope. Uses the current scope if not provided.\n * @param client - A client. Uses the current client if not provided.\n * @param captureSerializedLog - A function to capture the serialized log.\n *\n * @experimental This method will experience breaking changes. This is not yet part of\n * the stable Sentry SDK API and can be changed or removed without warning.\n */\nfunction _INTERNAL_captureLog(\n  beforeLog,\n  client$1 = currentScopes.getClient(),\n  currentScope = currentScopes.getCurrentScope(),\n  captureSerializedLog = _INTERNAL_captureSerializedLog,\n) {\n  if (!client$1) {\n    debugBuild.DEBUG_BUILD && debugLogger.debug.warn('No client available to capture log.');\n    return;\n  }\n\n  const { release, environment, enableLogs, beforeSendLog, _experiments } = client$1.getOptions();\n  // eslint-disable-next-line deprecation/deprecation\n  const shouldEnableLogs = enableLogs ?? _experiments?.enableLogs;\n  if (!shouldEnableLogs) {\n    debugBuild.DEBUG_BUILD && debugLogger.debug.warn('logging option not enabled, log will not be captured.');\n    return;\n  }\n  // eslint-disable-next-line deprecation/deprecation\n  const actualBeforeSendLog = beforeSendLog ?? _experiments?.beforeSendLog;\n\n  const [, traceContext] = client._getTraceInfoFromScope(client$1, currentScope);\n\n  const processedLogAttributes = {\n    ...beforeLog.attributes,\n  };\n\n  const {\n    user: { id, email, username },\n  } = getMergedScopeData(currentScope);\n  setLogAttribute(processedLogAttributes, 'user.id', id, false);\n  setLogAttribute(processedLogAttributes, 'user.email', email, false);\n  setLogAttribute(processedLogAttributes, 'user.name', username, false);\n\n  setLogAttribute(processedLogAttributes, 'sentry.release', release);\n  setLogAttribute(processedLogAttributes, 'sentry.environment', environment);\n\n  const { name, version } = client$1.getSdkMetadata()?.sdk ?? {};\n  setLogAttribute(processedLogAttributes, 'sentry.sdk.name', name);\n  setLogAttribute(processedLogAttributes, 'sentry.sdk.version', version);\n\n  const beforeLogMessage = beforeLog.message;\n  if (is.isParameterizedString(beforeLogMessage)) {\n    const { __sentry_template_string__, __sentry_template_values__ = [] } = beforeLogMessage;\n    processedLogAttributes['sentry.message.template'] = __sentry_template_string__;\n    __sentry_template_values__.forEach((param, index) => {\n      processedLogAttributes[`sentry.message.parameter.${index}`] = param;\n    });\n  }\n\n  const span = spanOnScope._getSpanForScope(currentScope);\n  // Add the parent span ID to the log attributes for trace context\n  setLogAttribute(processedLogAttributes, 'sentry.trace.parent_span_id', span?.spanContext().spanId);\n\n  const processedLog = { ...beforeLog, attributes: processedLogAttributes };\n\n  client$1.emit('beforeCaptureLog', processedLog);\n\n  // We need to wrap this in `consoleSandbox` to avoid recursive calls to `beforeSendLog`\n  const log = actualBeforeSendLog ? debugLogger.consoleSandbox(() => actualBeforeSendLog(processedLog)) : processedLog;\n  if (!log) {\n    client$1.recordDroppedEvent('before_send', 'log_item', 1);\n    debugBuild.DEBUG_BUILD && debugLogger.debug.warn('beforeSendLog returned null, log will not be captured.');\n    return;\n  }\n\n  const { level, message, attributes = {}, severityNumber } = log;\n\n  const serializedLog = {\n    timestamp: time.timestampInSeconds(),\n    level,\n    body: message,\n    trace_id: traceContext?.trace_id,\n    severity_number: severityNumber ?? constants.SEVERITY_TEXT_TO_SEVERITY_NUMBER[level],\n    attributes: Object.keys(attributes).reduce(\n      (acc, key) => {\n        acc[key] = logAttributeToSerializedLogAttribute(attributes[key]);\n        return acc;\n      },\n      {} ,\n    ),\n  };\n\n  captureSerializedLog(client$1, serializedLog);\n\n  client$1.emit('afterCaptureLog', log);\n}\n\n/**\n * Flushes the logs buffer to Sentry.\n *\n * @param client - A client.\n * @param maybeLogBuffer - A log buffer. Uses the log buffer for the given client if not provided.\n *\n * @experimental This method will experience breaking changes. This is not yet part of\n * the stable Sentry SDK API and can be changed or removed without warning.\n */\nfunction _INTERNAL_flushLogsBuffer(client, maybeLogBuffer) {\n  const logBuffer = maybeLogBuffer ?? _INTERNAL_getLogBuffer(client) ?? [];\n  if (logBuffer.length === 0) {\n    return;\n  }\n\n  const clientOptions = client.getOptions();\n  const envelope$1 = envelope.createLogEnvelope(logBuffer, clientOptions._metadata, clientOptions.tunnel, client.getDsn());\n\n  // Clear the log buffer after envelopes have been constructed.\n  _getBufferMap().set(client, []);\n\n  client.emit('flushLogs');\n\n  // sendEnvelope should not throw\n  // eslint-disable-next-line @typescript-eslint/no-floating-promises\n  client.sendEnvelope(envelope$1);\n}\n\n/**\n * Returns the log buffer for a given client.\n *\n * Exported for testing purposes.\n *\n * @param client - The client to get the log buffer for.\n * @returns The log buffer for the given client.\n */\nfunction _INTERNAL_getLogBuffer(client) {\n  return _getBufferMap().get(client);\n}\n\n/**\n * Get the scope data for the current scope after merging with the\n * global scope and isolation scope.\n *\n * @param currentScope - The current scope.\n * @returns The scope data.\n */\nfunction getMergedScopeData(currentScope) {\n  const scopeData = currentScopes.getGlobalScope().getScopeData();\n  applyScopeDataToEvent.mergeScopeData(scopeData, currentScopes.getIsolationScope().getScopeData());\n  applyScopeDataToEvent.mergeScopeData(scopeData, currentScope.getScopeData());\n  return scopeData;\n}\n\nfunction _getBufferMap() {\n  // The reference to the Client <> LogBuffer map is stored on the carrier to ensure it's always the same\n  return carrier.getGlobalSingleton('clientToLogBufferMap', () => new WeakMap());\n}\n\nexports._INTERNAL_captureLog = _INTERNAL_captureLog;\nexports._INTERNAL_captureSerializedLog = _INTERNAL_captureSerializedLog;\nexports._INTERNAL_flushLogsBuffer = _INTERNAL_flushLogsBuffer;\nexports._INTERNAL_getLogBuffer = _INTERNAL_getLogBuffer;\nexports.logAttributeToSerializedLogAttribute = logAttributeToSerializedLogAttribute;\n//# sourceMappingURL=exports.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9sb2dzL2V4cG9ydHMuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsZ0JBQWdCLG1CQUFPLENBQUMsb0hBQWU7QUFDdkMsZUFBZSxtQkFBTyxDQUFDLGtIQUFjO0FBQ3JDLHNCQUFzQixtQkFBTyxDQUFDLGdJQUFxQjtBQUNuRCxtQkFBbUIsbUJBQU8sQ0FBQyw0SEFBbUI7QUFDOUMsOEJBQThCLG1CQUFPLENBQUMsNEpBQW1DO0FBQ3pFLG9CQUFvQixtQkFBTyxDQUFDLDBJQUEwQjtBQUN0RCxXQUFXLG1CQUFPLENBQUMsc0hBQWdCO0FBQ25DLG9CQUFvQixtQkFBTyxDQUFDLHdJQUF5QjtBQUNyRCxhQUFhLG1CQUFPLENBQUMsMEhBQWtCO0FBQ3ZDLGtCQUFrQixtQkFBTyxDQUFDLDRIQUFnQjtBQUMxQyxpQkFBaUIsbUJBQU8sQ0FBQywwSEFBZTs7QUFFeEM7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxRQUFRO0FBQ1I7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBLElBQUk7QUFDSjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLFVBQVUsZ0VBQWdFO0FBQzFFO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0EsWUFBWSxxQkFBcUI7QUFDakMsSUFBSTtBQUNKO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBLFVBQVUsZ0JBQWdCO0FBQzFCO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLFlBQVksOERBQThEO0FBQzFFO0FBQ0E7QUFDQSx5REFBeUQsTUFBTTtBQUMvRCxLQUFLO0FBQ0w7O0FBRUE7QUFDQTtBQUNBOztBQUVBLHlCQUF5Qjs7QUFFekI7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsVUFBVSwrQkFBK0IsbUJBQW1COztBQUU1RDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLE9BQU87QUFDUCxTQUFTO0FBQ1Q7QUFDQTs7QUFFQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsNEJBQTRCO0FBQzVCLHNDQUFzQztBQUN0QyxpQ0FBaUM7QUFDakMsOEJBQThCO0FBQzlCLDRDQUE0QztBQUM1QyIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL2xvZ3MvZXhwb3J0cy5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgY2FycmllciA9IHJlcXVpcmUoJy4uL2NhcnJpZXIuanMnKTtcbmNvbnN0IGNsaWVudCA9IHJlcXVpcmUoJy4uL2NsaWVudC5qcycpO1xuY29uc3QgY3VycmVudFNjb3BlcyA9IHJlcXVpcmUoJy4uL2N1cnJlbnRTY29wZXMuanMnKTtcbmNvbnN0IGRlYnVnQnVpbGQgPSByZXF1aXJlKCcuLi9kZWJ1Zy1idWlsZC5qcycpO1xuY29uc3QgYXBwbHlTY29wZURhdGFUb0V2ZW50ID0gcmVxdWlyZSgnLi4vdXRpbHMvYXBwbHlTY29wZURhdGFUb0V2ZW50LmpzJyk7XG5jb25zdCBkZWJ1Z0xvZ2dlciA9IHJlcXVpcmUoJy4uL3V0aWxzL2RlYnVnLWxvZ2dlci5qcycpO1xuY29uc3QgaXMgPSByZXF1aXJlKCcuLi91dGlscy9pcy5qcycpO1xuY29uc3Qgc3Bhbk9uU2NvcGUgPSByZXF1aXJlKCcuLi91dGlscy9zcGFuT25TY29wZS5qcycpO1xuY29uc3QgdGltZSA9IHJlcXVpcmUoJy4uL3V0aWxzL3RpbWUuanMnKTtcbmNvbnN0IGNvbnN0YW50cyA9IHJlcXVpcmUoJy4vY29uc3RhbnRzLmpzJyk7XG5jb25zdCBlbnZlbG9wZSA9IHJlcXVpcmUoJy4vZW52ZWxvcGUuanMnKTtcblxuY29uc3QgTUFYX0xPR19CVUZGRVJfU0laRSA9IDEwMDtcblxuLyoqXG4gKiBDb252ZXJ0cyBhIGxvZyBhdHRyaWJ1dGUgdG8gYSBzZXJpYWxpemVkIGxvZyBhdHRyaWJ1dGUuXG4gKlxuICogQHBhcmFtIGtleSAtIFRoZSBrZXkgb2YgdGhlIGxvZyBhdHRyaWJ1dGUuXG4gKiBAcGFyYW0gdmFsdWUgLSBUaGUgdmFsdWUgb2YgdGhlIGxvZyBhdHRyaWJ1dGUuXG4gKiBAcmV0dXJucyBUaGUgc2VyaWFsaXplZCBsb2cgYXR0cmlidXRlLlxuICovXG5mdW5jdGlvbiBsb2dBdHRyaWJ1dGVUb1NlcmlhbGl6ZWRMb2dBdHRyaWJ1dGUodmFsdWUpIHtcbiAgc3dpdGNoICh0eXBlb2YgdmFsdWUpIHtcbiAgICBjYXNlICdudW1iZXInOlxuICAgICAgaWYgKE51bWJlci5pc0ludGVnZXIodmFsdWUpKSB7XG4gICAgICAgIHJldHVybiB7XG4gICAgICAgICAgdmFsdWUsXG4gICAgICAgICAgdHlwZTogJ2ludGVnZXInLFxuICAgICAgICB9O1xuICAgICAgfVxuICAgICAgcmV0dXJuIHtcbiAgICAgICAgdmFsdWUsXG4gICAgICAgIHR5cGU6ICdkb3VibGUnLFxuICAgICAgfTtcbiAgICBjYXNlICdib29sZWFuJzpcbiAgICAgIHJldHVybiB7XG4gICAgICAgIHZhbHVlLFxuICAgICAgICB0eXBlOiAnYm9vbGVhbicsXG4gICAgICB9O1xuICAgIGNhc2UgJ3N0cmluZyc6XG4gICAgICByZXR1cm4ge1xuICAgICAgICB2YWx1ZSxcbiAgICAgICAgdHlwZTogJ3N0cmluZycsXG4gICAgICB9O1xuICAgIGRlZmF1bHQ6IHtcbiAgICAgIGxldCBzdHJpbmdWYWx1ZSA9ICcnO1xuICAgICAgdHJ5IHtcbiAgICAgICAgc3RyaW5nVmFsdWUgPSBKU09OLnN0cmluZ2lmeSh2YWx1ZSkgPz8gJyc7XG4gICAgICB9IGNhdGNoIHtcbiAgICAgICAgLy8gRG8gbm90aGluZ1xuICAgICAgfVxuICAgICAgcmV0dXJuIHtcbiAgICAgICAgdmFsdWU6IHN0cmluZ1ZhbHVlLFxuICAgICAgICB0eXBlOiAnc3RyaW5nJyxcbiAgICAgIH07XG4gICAgfVxuICB9XG59XG5cbi8qKlxuICogU2V0cyBhIGxvZyBhdHRyaWJ1dGUgaWYgdGhlIHZhbHVlIGV4aXN0cyBhbmQgdGhlIGF0dHJpYnV0ZSBrZXkgaXMgbm90IGFscmVhZHkgcHJlc2VudC5cbiAqXG4gKiBAcGFyYW0gbG9nQXR0cmlidXRlcyAtIFRoZSBsb2cgYXR0cmlidXRlcyBvYmplY3QgdG8gbW9kaWZ5LlxuICogQHBhcmFtIGtleSAtIFRoZSBhdHRyaWJ1dGUga2V5IHRvIHNldC5cbiAqIEBwYXJhbSB2YWx1ZSAtIFRoZSB2YWx1ZSB0byBzZXQgKG9ubHkgc2V0cyBpZiB0cnV0aHkgYW5kIGtleSBub3QgcHJlc2VudCkuXG4gKiBAcGFyYW0gc2V0RXZlbklmUHJlc2VudCAtIFdoZXRoZXIgdG8gc2V0IHRoZSBhdHRyaWJ1dGUgaWYgaXQgaXMgcHJlc2VudC4gRGVmYXVsdHMgdG8gdHJ1ZS5cbiAqL1xuZnVuY3Rpb24gc2V0TG9nQXR0cmlidXRlKFxuICBsb2dBdHRyaWJ1dGVzLFxuICBrZXksXG4gIHZhbHVlLFxuICBzZXRFdmVuSWZQcmVzZW50ID0gdHJ1ZSxcbikge1xuICBpZiAodmFsdWUgJiYgKCFsb2dBdHRyaWJ1dGVzW2tleV0gfHwgc2V0RXZlbklmUHJlc2VudCkpIHtcbiAgICBsb2dBdHRyaWJ1dGVzW2tleV0gPSB2YWx1ZTtcbiAgfVxufVxuXG4vKipcbiAqIENhcHR1cmVzIGEgc2VyaWFsaXplZCBsb2cgZXZlbnQgYW5kIGFkZHMgaXQgdG8gdGhlIGxvZyBidWZmZXIgZm9yIHRoZSBnaXZlbiBjbGllbnQuXG4gKlxuICogQHBhcmFtIGNsaWVudCAtIEEgY2xpZW50LiBVc2VzIHRoZSBjdXJyZW50IGNsaWVudCBpZiBub3QgcHJvdmlkZWQuXG4gKiBAcGFyYW0gc2VyaWFsaXplZExvZyAtIFRoZSBzZXJpYWxpemVkIGxvZyBldmVudCB0byBjYXB0dXJlLlxuICpcbiAqIEBleHBlcmltZW50YWwgVGhpcyBtZXRob2Qgd2lsbCBleHBlcmllbmNlIGJyZWFraW5nIGNoYW5nZXMuIFRoaXMgaXMgbm90IHlldCBwYXJ0IG9mXG4gKiB0aGUgc3RhYmxlIFNlbnRyeSBTREsgQVBJIGFuZCBjYW4gYmUgY2hhbmdlZCBvciByZW1vdmVkIHdpdGhvdXQgd2FybmluZy5cbiAqL1xuZnVuY3Rpb24gX0lOVEVSTkFMX2NhcHR1cmVTZXJpYWxpemVkTG9nKGNsaWVudCwgc2VyaWFsaXplZExvZykge1xuICBjb25zdCBidWZmZXJNYXAgPSBfZ2V0QnVmZmVyTWFwKCk7XG5cbiAgY29uc3QgbG9nQnVmZmVyID0gX0lOVEVSTkFMX2dldExvZ0J1ZmZlcihjbGllbnQpO1xuICBpZiAobG9nQnVmZmVyID09PSB1bmRlZmluZWQpIHtcbiAgICBidWZmZXJNYXAuc2V0KGNsaWVudCwgW3NlcmlhbGl6ZWRMb2ddKTtcbiAgfSBlbHNlIHtcbiAgICBidWZmZXJNYXAuc2V0KGNsaWVudCwgWy4uLmxvZ0J1ZmZlciwgc2VyaWFsaXplZExvZ10pO1xuICAgIGlmIChsb2dCdWZmZXIubGVuZ3RoID49IE1BWF9MT0dfQlVGRkVSX1NJWkUpIHtcbiAgICAgIF9JTlRFUk5BTF9mbHVzaExvZ3NCdWZmZXIoY2xpZW50LCBsb2dCdWZmZXIpO1xuICAgIH1cbiAgfVxufVxuXG4vKipcbiAqIENhcHR1cmVzIGEgbG9nIGV2ZW50IGFuZCBzZW5kcyBpdCB0byBTZW50cnkuXG4gKlxuICogQHBhcmFtIGxvZyAtIFRoZSBsb2cgZXZlbnQgdG8gY2FwdHVyZS5cbiAqIEBwYXJhbSBzY29wZSAtIEEgc2NvcGUuIFVzZXMgdGhlIGN1cnJlbnQgc2NvcGUgaWYgbm90IHByb3ZpZGVkLlxuICogQHBhcmFtIGNsaWVudCAtIEEgY2xpZW50LiBVc2VzIHRoZSBjdXJyZW50IGNsaWVudCBpZiBub3QgcHJvdmlkZWQuXG4gKiBAcGFyYW0gY2FwdHVyZVNlcmlhbGl6ZWRMb2cgLSBBIGZ1bmN0aW9uIHRvIGNhcHR1cmUgdGhlIHNlcmlhbGl6ZWQgbG9nLlxuICpcbiAqIEBleHBlcmltZW50YWwgVGhpcyBtZXRob2Qgd2lsbCBleHBlcmllbmNlIGJyZWFraW5nIGNoYW5nZXMuIFRoaXMgaXMgbm90IHlldCBwYXJ0IG9mXG4gKiB0aGUgc3RhYmxlIFNlbnRyeSBTREsgQVBJIGFuZCBjYW4gYmUgY2hhbmdlZCBvciByZW1vdmVkIHdpdGhvdXQgd2FybmluZy5cbiAqL1xuZnVuY3Rpb24gX0lOVEVSTkFMX2NhcHR1cmVMb2coXG4gIGJlZm9yZUxvZyxcbiAgY2xpZW50JDEgPSBjdXJyZW50U2NvcGVzLmdldENsaWVudCgpLFxuICBjdXJyZW50U2NvcGUgPSBjdXJyZW50U2NvcGVzLmdldEN1cnJlbnRTY29wZSgpLFxuICBjYXB0dXJlU2VyaWFsaXplZExvZyA9IF9JTlRFUk5BTF9jYXB0dXJlU2VyaWFsaXplZExvZyxcbikge1xuICBpZiAoIWNsaWVudCQxKSB7XG4gICAgZGVidWdCdWlsZC5ERUJVR19CVUlMRCAmJiBkZWJ1Z0xvZ2dlci5kZWJ1Zy53YXJuKCdObyBjbGllbnQgYXZhaWxhYmxlIHRvIGNhcHR1cmUgbG9nLicpO1xuICAgIHJldHVybjtcbiAgfVxuXG4gIGNvbnN0IHsgcmVsZWFzZSwgZW52aXJvbm1lbnQsIGVuYWJsZUxvZ3MsIGJlZm9yZVNlbmRMb2csIF9leHBlcmltZW50cyB9ID0gY2xpZW50JDEuZ2V0T3B0aW9ucygpO1xuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgZGVwcmVjYXRpb24vZGVwcmVjYXRpb25cbiAgY29uc3Qgc2hvdWxkRW5hYmxlTG9ncyA9IGVuYWJsZUxvZ3MgPz8gX2V4cGVyaW1lbnRzPy5lbmFibGVMb2dzO1xuICBpZiAoIXNob3VsZEVuYWJsZUxvZ3MpIHtcbiAgICBkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEICYmIGRlYnVnTG9nZ2VyLmRlYnVnLndhcm4oJ2xvZ2dpbmcgb3B0aW9uIG5vdCBlbmFibGVkLCBsb2cgd2lsbCBub3QgYmUgY2FwdHVyZWQuJyk7XG4gICAgcmV0dXJuO1xuICB9XG4gIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBkZXByZWNhdGlvbi9kZXByZWNhdGlvblxuICBjb25zdCBhY3R1YWxCZWZvcmVTZW5kTG9nID0gYmVmb3JlU2VuZExvZyA/PyBfZXhwZXJpbWVudHM/LmJlZm9yZVNlbmRMb2c7XG5cbiAgY29uc3QgWywgdHJhY2VDb250ZXh0XSA9IGNsaWVudC5fZ2V0VHJhY2VJbmZvRnJvbVNjb3BlKGNsaWVudCQxLCBjdXJyZW50U2NvcGUpO1xuXG4gIGNvbnN0IHByb2Nlc3NlZExvZ0F0dHJpYnV0ZXMgPSB7XG4gICAgLi4uYmVmb3JlTG9nLmF0dHJpYnV0ZXMsXG4gIH07XG5cbiAgY29uc3Qge1xuICAgIHVzZXI6IHsgaWQsIGVtYWlsLCB1c2VybmFtZSB9LFxuICB9ID0gZ2V0TWVyZ2VkU2NvcGVEYXRhKGN1cnJlbnRTY29wZSk7XG4gIHNldExvZ0F0dHJpYnV0ZShwcm9jZXNzZWRMb2dBdHRyaWJ1dGVzLCAndXNlci5pZCcsIGlkLCBmYWxzZSk7XG4gIHNldExvZ0F0dHJpYnV0ZShwcm9jZXNzZWRMb2dBdHRyaWJ1dGVzLCAndXNlci5lbWFpbCcsIGVtYWlsLCBmYWxzZSk7XG4gIHNldExvZ0F0dHJpYnV0ZShwcm9jZXNzZWRMb2dBdHRyaWJ1dGVzLCAndXNlci5uYW1lJywgdXNlcm5hbWUsIGZhbHNlKTtcblxuICBzZXRMb2dBdHRyaWJ1dGUocHJvY2Vzc2VkTG9nQXR0cmlidXRlcywgJ3NlbnRyeS5yZWxlYXNlJywgcmVsZWFzZSk7XG4gIHNldExvZ0F0dHJpYnV0ZShwcm9jZXNzZWRMb2dBdHRyaWJ1dGVzLCAnc2VudHJ5LmVudmlyb25tZW50JywgZW52aXJvbm1lbnQpO1xuXG4gIGNvbnN0IHsgbmFtZSwgdmVyc2lvbiB9ID0gY2xpZW50JDEuZ2V0U2RrTWV0YWRhdGEoKT8uc2RrID8/IHt9O1xuICBzZXRMb2dBdHRyaWJ1dGUocHJvY2Vzc2VkTG9nQXR0cmlidXRlcywgJ3NlbnRyeS5zZGsubmFtZScsIG5hbWUpO1xuICBzZXRMb2dBdHRyaWJ1dGUocHJvY2Vzc2VkTG9nQXR0cmlidXRlcywgJ3NlbnRyeS5zZGsudmVyc2lvbicsIHZlcnNpb24pO1xuXG4gIGNvbnN0IGJlZm9yZUxvZ01lc3NhZ2UgPSBiZWZvcmVMb2cubWVzc2FnZTtcbiAgaWYgKGlzLmlzUGFyYW1ldGVyaXplZFN0cmluZyhiZWZvcmVMb2dNZXNzYWdlKSkge1xuICAgIGNvbnN0IHsgX19zZW50cnlfdGVtcGxhdGVfc3RyaW5nX18sIF9fc2VudHJ5X3RlbXBsYXRlX3ZhbHVlc19fID0gW10gfSA9IGJlZm9yZUxvZ01lc3NhZ2U7XG4gICAgcHJvY2Vzc2VkTG9nQXR0cmlidXRlc1snc2VudHJ5Lm1lc3NhZ2UudGVtcGxhdGUnXSA9IF9fc2VudHJ5X3RlbXBsYXRlX3N0cmluZ19fO1xuICAgIF9fc2VudHJ5X3RlbXBsYXRlX3ZhbHVlc19fLmZvckVhY2goKHBhcmFtLCBpbmRleCkgPT4ge1xuICAgICAgcHJvY2Vzc2VkTG9nQXR0cmlidXRlc1tgc2VudHJ5Lm1lc3NhZ2UucGFyYW1ldGVyLiR7aW5kZXh9YF0gPSBwYXJhbTtcbiAgICB9KTtcbiAgfVxuXG4gIGNvbnN0IHNwYW4gPSBzcGFuT25TY29wZS5fZ2V0U3BhbkZvclNjb3BlKGN1cnJlbnRTY29wZSk7XG4gIC8vIEFkZCB0aGUgcGFyZW50IHNwYW4gSUQgdG8gdGhlIGxvZyBhdHRyaWJ1dGVzIGZvciB0cmFjZSBjb250ZXh0XG4gIHNldExvZ0F0dHJpYnV0ZShwcm9jZXNzZWRMb2dBdHRyaWJ1dGVzLCAnc2VudHJ5LnRyYWNlLnBhcmVudF9zcGFuX2lkJywgc3Bhbj8uc3BhbkNvbnRleHQoKS5zcGFuSWQpO1xuXG4gIGNvbnN0IHByb2Nlc3NlZExvZyA9IHsgLi4uYmVmb3JlTG9nLCBhdHRyaWJ1dGVzOiBwcm9jZXNzZWRMb2dBdHRyaWJ1dGVzIH07XG5cbiAgY2xpZW50JDEuZW1pdCgnYmVmb3JlQ2FwdHVyZUxvZycsIHByb2Nlc3NlZExvZyk7XG5cbiAgLy8gV2UgbmVlZCB0byB3cmFwIHRoaXMgaW4gYGNvbnNvbGVTYW5kYm94YCB0byBhdm9pZCByZWN1cnNpdmUgY2FsbHMgdG8gYGJlZm9yZVNlbmRMb2dgXG4gIGNvbnN0IGxvZyA9IGFjdHVhbEJlZm9yZVNlbmRMb2cgPyBkZWJ1Z0xvZ2dlci5jb25zb2xlU2FuZGJveCgoKSA9PiBhY3R1YWxCZWZvcmVTZW5kTG9nKHByb2Nlc3NlZExvZykpIDogcHJvY2Vzc2VkTG9nO1xuICBpZiAoIWxvZykge1xuICAgIGNsaWVudCQxLnJlY29yZERyb3BwZWRFdmVudCgnYmVmb3JlX3NlbmQnLCAnbG9nX2l0ZW0nLCAxKTtcbiAgICBkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEICYmIGRlYnVnTG9nZ2VyLmRlYnVnLndhcm4oJ2JlZm9yZVNlbmRMb2cgcmV0dXJuZWQgbnVsbCwgbG9nIHdpbGwgbm90IGJlIGNhcHR1cmVkLicpO1xuICAgIHJldHVybjtcbiAgfVxuXG4gIGNvbnN0IHsgbGV2ZWwsIG1lc3NhZ2UsIGF0dHJpYnV0ZXMgPSB7fSwgc2V2ZXJpdHlOdW1iZXIgfSA9IGxvZztcblxuICBjb25zdCBzZXJpYWxpemVkTG9nID0ge1xuICAgIHRpbWVzdGFtcDogdGltZS50aW1lc3RhbXBJblNlY29uZHMoKSxcbiAgICBsZXZlbCxcbiAgICBib2R5OiBtZXNzYWdlLFxuICAgIHRyYWNlX2lkOiB0cmFjZUNvbnRleHQ/LnRyYWNlX2lkLFxuICAgIHNldmVyaXR5X251bWJlcjogc2V2ZXJpdHlOdW1iZXIgPz8gY29uc3RhbnRzLlNFVkVSSVRZX1RFWFRfVE9fU0VWRVJJVFlfTlVNQkVSW2xldmVsXSxcbiAgICBhdHRyaWJ1dGVzOiBPYmplY3Qua2V5cyhhdHRyaWJ1dGVzKS5yZWR1Y2UoXG4gICAgICAoYWNjLCBrZXkpID0+IHtcbiAgICAgICAgYWNjW2tleV0gPSBsb2dBdHRyaWJ1dGVUb1NlcmlhbGl6ZWRMb2dBdHRyaWJ1dGUoYXR0cmlidXRlc1trZXldKTtcbiAgICAgICAgcmV0dXJuIGFjYztcbiAgICAgIH0sXG4gICAgICB7fSAsXG4gICAgKSxcbiAgfTtcblxuICBjYXB0dXJlU2VyaWFsaXplZExvZyhjbGllbnQkMSwgc2VyaWFsaXplZExvZyk7XG5cbiAgY2xpZW50JDEuZW1pdCgnYWZ0ZXJDYXB0dXJlTG9nJywgbG9nKTtcbn1cblxuLyoqXG4gKiBGbHVzaGVzIHRoZSBsb2dzIGJ1ZmZlciB0byBTZW50cnkuXG4gKlxuICogQHBhcmFtIGNsaWVudCAtIEEgY2xpZW50LlxuICogQHBhcmFtIG1heWJlTG9nQnVmZmVyIC0gQSBsb2cgYnVmZmVyLiBVc2VzIHRoZSBsb2cgYnVmZmVyIGZvciB0aGUgZ2l2ZW4gY2xpZW50IGlmIG5vdCBwcm92aWRlZC5cbiAqXG4gKiBAZXhwZXJpbWVudGFsIFRoaXMgbWV0aG9kIHdpbGwgZXhwZXJpZW5jZSBicmVha2luZyBjaGFuZ2VzLiBUaGlzIGlzIG5vdCB5ZXQgcGFydCBvZlxuICogdGhlIHN0YWJsZSBTZW50cnkgU0RLIEFQSSBhbmQgY2FuIGJlIGNoYW5nZWQgb3IgcmVtb3ZlZCB3aXRob3V0IHdhcm5pbmcuXG4gKi9cbmZ1bmN0aW9uIF9JTlRFUk5BTF9mbHVzaExvZ3NCdWZmZXIoY2xpZW50LCBtYXliZUxvZ0J1ZmZlcikge1xuICBjb25zdCBsb2dCdWZmZXIgPSBtYXliZUxvZ0J1ZmZlciA/PyBfSU5URVJOQUxfZ2V0TG9nQnVmZmVyKGNsaWVudCkgPz8gW107XG4gIGlmIChsb2dCdWZmZXIubGVuZ3RoID09PSAwKSB7XG4gICAgcmV0dXJuO1xuICB9XG5cbiAgY29uc3QgY2xpZW50T3B0aW9ucyA9IGNsaWVudC5nZXRPcHRpb25zKCk7XG4gIGNvbnN0IGVudmVsb3BlJDEgPSBlbnZlbG9wZS5jcmVhdGVMb2dFbnZlbG9wZShsb2dCdWZmZXIsIGNsaWVudE9wdGlvbnMuX21ldGFkYXRhLCBjbGllbnRPcHRpb25zLnR1bm5lbCwgY2xpZW50LmdldERzbigpKTtcblxuICAvLyBDbGVhciB0aGUgbG9nIGJ1ZmZlciBhZnRlciBlbnZlbG9wZXMgaGF2ZSBiZWVuIGNvbnN0cnVjdGVkLlxuICBfZ2V0QnVmZmVyTWFwKCkuc2V0KGNsaWVudCwgW10pO1xuXG4gIGNsaWVudC5lbWl0KCdmbHVzaExvZ3MnKTtcblxuICAvLyBzZW5kRW52ZWxvcGUgc2hvdWxkIG5vdCB0aHJvd1xuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25vLWZsb2F0aW5nLXByb21pc2VzXG4gIGNsaWVudC5zZW5kRW52ZWxvcGUoZW52ZWxvcGUkMSk7XG59XG5cbi8qKlxuICogUmV0dXJucyB0aGUgbG9nIGJ1ZmZlciBmb3IgYSBnaXZlbiBjbGllbnQuXG4gKlxuICogRXhwb3J0ZWQgZm9yIHRlc3RpbmcgcHVycG9zZXMuXG4gKlxuICogQHBhcmFtIGNsaWVudCAtIFRoZSBjbGllbnQgdG8gZ2V0IHRoZSBsb2cgYnVmZmVyIGZvci5cbiAqIEByZXR1cm5zIFRoZSBsb2cgYnVmZmVyIGZvciB0aGUgZ2l2ZW4gY2xpZW50LlxuICovXG5mdW5jdGlvbiBfSU5URVJOQUxfZ2V0TG9nQnVmZmVyKGNsaWVudCkge1xuICByZXR1cm4gX2dldEJ1ZmZlck1hcCgpLmdldChjbGllbnQpO1xufVxuXG4vKipcbiAqIEdldCB0aGUgc2NvcGUgZGF0YSBmb3IgdGhlIGN1cnJlbnQgc2NvcGUgYWZ0ZXIgbWVyZ2luZyB3aXRoIHRoZVxuICogZ2xvYmFsIHNjb3BlIGFuZCBpc29sYXRpb24gc2NvcGUuXG4gKlxuICogQHBhcmFtIGN1cnJlbnRTY29wZSAtIFRoZSBjdXJyZW50IHNjb3BlLlxuICogQHJldHVybnMgVGhlIHNjb3BlIGRhdGEuXG4gKi9cbmZ1bmN0aW9uIGdldE1lcmdlZFNjb3BlRGF0YShjdXJyZW50U2NvcGUpIHtcbiAgY29uc3Qgc2NvcGVEYXRhID0gY3VycmVudFNjb3Blcy5nZXRHbG9iYWxTY29wZSgpLmdldFNjb3BlRGF0YSgpO1xuICBhcHBseVNjb3BlRGF0YVRvRXZlbnQubWVyZ2VTY29wZURhdGEoc2NvcGVEYXRhLCBjdXJyZW50U2NvcGVzLmdldElzb2xhdGlvblNjb3BlKCkuZ2V0U2NvcGVEYXRhKCkpO1xuICBhcHBseVNjb3BlRGF0YVRvRXZlbnQubWVyZ2VTY29wZURhdGEoc2NvcGVEYXRhLCBjdXJyZW50U2NvcGUuZ2V0U2NvcGVEYXRhKCkpO1xuICByZXR1cm4gc2NvcGVEYXRhO1xufVxuXG5mdW5jdGlvbiBfZ2V0QnVmZmVyTWFwKCkge1xuICAvLyBUaGUgcmVmZXJlbmNlIHRvIHRoZSBDbGllbnQgPD4gTG9nQnVmZmVyIG1hcCBpcyBzdG9yZWQgb24gdGhlIGNhcnJpZXIgdG8gZW5zdXJlIGl0J3MgYWx3YXlzIHRoZSBzYW1lXG4gIHJldHVybiBjYXJyaWVyLmdldEdsb2JhbFNpbmdsZXRvbignY2xpZW50VG9Mb2dCdWZmZXJNYXAnLCAoKSA9PiBuZXcgV2Vha01hcCgpKTtcbn1cblxuZXhwb3J0cy5fSU5URVJOQUxfY2FwdHVyZUxvZyA9IF9JTlRFUk5BTF9jYXB0dXJlTG9nO1xuZXhwb3J0cy5fSU5URVJOQUxfY2FwdHVyZVNlcmlhbGl6ZWRMb2cgPSBfSU5URVJOQUxfY2FwdHVyZVNlcmlhbGl6ZWRMb2c7XG5leHBvcnRzLl9JTlRFUk5BTF9mbHVzaExvZ3NCdWZmZXIgPSBfSU5URVJOQUxfZmx1c2hMb2dzQnVmZmVyO1xuZXhwb3J0cy5fSU5URVJOQUxfZ2V0TG9nQnVmZmVyID0gX0lOVEVSTkFMX2dldExvZ0J1ZmZlcjtcbmV4cG9ydHMubG9nQXR0cmlidXRlVG9TZXJpYWxpemVkTG9nQXR0cmlidXRlID0gbG9nQXR0cmlidXRlVG9TZXJpYWxpemVkTG9nQXR0cmlidXRlO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9ZXhwb3J0cy5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/logs/exports.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/metadata.js":
/*!************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/metadata.js ***!
  \************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst worldwide = __webpack_require__(/*! ./utils/worldwide.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/worldwide.js\");\n\n/** Keys are source filename/url, values are metadata objects. */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nconst filenameMetadataMap = new Map();\n/** Set of stack strings that have already been parsed. */\nconst parsedStacks = new Set();\n\nfunction ensureMetadataStacksAreParsed(parser) {\n  if (!worldwide.GLOBAL_OBJ._sentryModuleMetadata) {\n    return;\n  }\n\n  for (const stack of Object.keys(worldwide.GLOBAL_OBJ._sentryModuleMetadata)) {\n    const metadata = worldwide.GLOBAL_OBJ._sentryModuleMetadata[stack];\n\n    if (parsedStacks.has(stack)) {\n      continue;\n    }\n\n    // Ensure this stack doesn't get parsed again\n    parsedStacks.add(stack);\n\n    const frames = parser(stack);\n\n    // Go through the frames starting from the top of the stack and find the first one with a filename\n    for (const frame of frames.reverse()) {\n      if (frame.filename) {\n        // Save the metadata for this filename\n        filenameMetadataMap.set(frame.filename, metadata);\n        break;\n      }\n    }\n  }\n}\n\n/**\n * Retrieve metadata for a specific JavaScript file URL.\n *\n * Metadata is injected by the Sentry bundler plugins using the `_experiments.moduleMetadata` config option.\n */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction getMetadataForUrl(parser, filename) {\n  ensureMetadataStacksAreParsed(parser);\n  return filenameMetadataMap.get(filename);\n}\n\n/**\n * Adds metadata to stack frames.\n *\n * Metadata is injected by the Sentry bundler plugins using the `_experiments.moduleMetadata` config option.\n */\nfunction addMetadataToStackFrames(parser, event) {\n  try {\n    // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n    event.exception.values.forEach(exception => {\n      if (!exception.stacktrace) {\n        return;\n      }\n\n      for (const frame of exception.stacktrace.frames || []) {\n        if (!frame.filename || frame.module_metadata) {\n          continue;\n        }\n\n        const metadata = getMetadataForUrl(parser, frame.filename);\n\n        if (metadata) {\n          frame.module_metadata = metadata;\n        }\n      }\n    });\n  } catch {\n    // To save bundle size we're just try catching here instead of checking for the existence of all the different objects.\n  }\n}\n\n/**\n * Strips metadata from stack frames.\n */\nfunction stripMetadataFromStackFrames(event) {\n  try {\n    // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n    event.exception.values.forEach(exception => {\n      if (!exception.stacktrace) {\n        return;\n      }\n\n      for (const frame of exception.stacktrace.frames || []) {\n        delete frame.module_metadata;\n      }\n    });\n  } catch {\n    // To save bundle size we're just try catching here instead of checking for the existence of all the different objects.\n  }\n}\n\nexports.addMetadataToStackFrames = addMetadataToStackFrames;\nexports.getMetadataForUrl = getMetadataForUrl;\nexports.stripMetadataFromStackFrames = stripMetadataFromStackFrames;\n//# sourceMappingURL=metadata.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9tZXRhZGF0YS5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxrQkFBa0IsbUJBQU8sQ0FBQyxtSUFBc0I7O0FBRWhEO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQSxLQUFLO0FBQ0wsSUFBSTtBQUNKO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQSxLQUFLO0FBQ0wsSUFBSTtBQUNKO0FBQ0E7QUFDQTs7QUFFQSxnQ0FBZ0M7QUFDaEMseUJBQXlCO0FBQ3pCLG9DQUFvQztBQUNwQyIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL21ldGFkYXRhLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCB3b3JsZHdpZGUgPSByZXF1aXJlKCcuL3V0aWxzL3dvcmxkd2lkZS5qcycpO1xuXG4vKiogS2V5cyBhcmUgc291cmNlIGZpbGVuYW1lL3VybCwgdmFsdWVzIGFyZSBtZXRhZGF0YSBvYmplY3RzLiAqL1xuLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uby1leHBsaWNpdC1hbnlcbmNvbnN0IGZpbGVuYW1lTWV0YWRhdGFNYXAgPSBuZXcgTWFwKCk7XG4vKiogU2V0IG9mIHN0YWNrIHN0cmluZ3MgdGhhdCBoYXZlIGFscmVhZHkgYmVlbiBwYXJzZWQuICovXG5jb25zdCBwYXJzZWRTdGFja3MgPSBuZXcgU2V0KCk7XG5cbmZ1bmN0aW9uIGVuc3VyZU1ldGFkYXRhU3RhY2tzQXJlUGFyc2VkKHBhcnNlcikge1xuICBpZiAoIXdvcmxkd2lkZS5HTE9CQUxfT0JKLl9zZW50cnlNb2R1bGVNZXRhZGF0YSkge1xuICAgIHJldHVybjtcbiAgfVxuXG4gIGZvciAoY29uc3Qgc3RhY2sgb2YgT2JqZWN0LmtleXMod29ybGR3aWRlLkdMT0JBTF9PQkouX3NlbnRyeU1vZHVsZU1ldGFkYXRhKSkge1xuICAgIGNvbnN0IG1ldGFkYXRhID0gd29ybGR3aWRlLkdMT0JBTF9PQkouX3NlbnRyeU1vZHVsZU1ldGFkYXRhW3N0YWNrXTtcblxuICAgIGlmIChwYXJzZWRTdGFja3MuaGFzKHN0YWNrKSkge1xuICAgICAgY29udGludWU7XG4gICAgfVxuXG4gICAgLy8gRW5zdXJlIHRoaXMgc3RhY2sgZG9lc24ndCBnZXQgcGFyc2VkIGFnYWluXG4gICAgcGFyc2VkU3RhY2tzLmFkZChzdGFjayk7XG5cbiAgICBjb25zdCBmcmFtZXMgPSBwYXJzZXIoc3RhY2spO1xuXG4gICAgLy8gR28gdGhyb3VnaCB0aGUgZnJhbWVzIHN0YXJ0aW5nIGZyb20gdGhlIHRvcCBvZiB0aGUgc3RhY2sgYW5kIGZpbmQgdGhlIGZpcnN0IG9uZSB3aXRoIGEgZmlsZW5hbWVcbiAgICBmb3IgKGNvbnN0IGZyYW1lIG9mIGZyYW1lcy5yZXZlcnNlKCkpIHtcbiAgICAgIGlmIChmcmFtZS5maWxlbmFtZSkge1xuICAgICAgICAvLyBTYXZlIHRoZSBtZXRhZGF0YSBmb3IgdGhpcyBmaWxlbmFtZVxuICAgICAgICBmaWxlbmFtZU1ldGFkYXRhTWFwLnNldChmcmFtZS5maWxlbmFtZSwgbWV0YWRhdGEpO1xuICAgICAgICBicmVhaztcbiAgICAgIH1cbiAgICB9XG4gIH1cbn1cblxuLyoqXG4gKiBSZXRyaWV2ZSBtZXRhZGF0YSBmb3IgYSBzcGVjaWZpYyBKYXZhU2NyaXB0IGZpbGUgVVJMLlxuICpcbiAqIE1ldGFkYXRhIGlzIGluamVjdGVkIGJ5IHRoZSBTZW50cnkgYnVuZGxlciBwbHVnaW5zIHVzaW5nIHRoZSBgX2V4cGVyaW1lbnRzLm1vZHVsZU1ldGFkYXRhYCBjb25maWcgb3B0aW9uLlxuICovXG4vLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25vLWV4cGxpY2l0LWFueVxuZnVuY3Rpb24gZ2V0TWV0YWRhdGFGb3JVcmwocGFyc2VyLCBmaWxlbmFtZSkge1xuICBlbnN1cmVNZXRhZGF0YVN0YWNrc0FyZVBhcnNlZChwYXJzZXIpO1xuICByZXR1cm4gZmlsZW5hbWVNZXRhZGF0YU1hcC5nZXQoZmlsZW5hbWUpO1xufVxuXG4vKipcbiAqIEFkZHMgbWV0YWRhdGEgdG8gc3RhY2sgZnJhbWVzLlxuICpcbiAqIE1ldGFkYXRhIGlzIGluamVjdGVkIGJ5IHRoZSBTZW50cnkgYnVuZGxlciBwbHVnaW5zIHVzaW5nIHRoZSBgX2V4cGVyaW1lbnRzLm1vZHVsZU1ldGFkYXRhYCBjb25maWcgb3B0aW9uLlxuICovXG5mdW5jdGlvbiBhZGRNZXRhZGF0YVRvU3RhY2tGcmFtZXMocGFyc2VyLCBldmVudCkge1xuICB0cnkge1xuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tbm9uLW51bGwtYXNzZXJ0aW9uXG4gICAgZXZlbnQuZXhjZXB0aW9uLnZhbHVlcy5mb3JFYWNoKGV4Y2VwdGlvbiA9PiB7XG4gICAgICBpZiAoIWV4Y2VwdGlvbi5zdGFja3RyYWNlKSB7XG4gICAgICAgIHJldHVybjtcbiAgICAgIH1cblxuICAgICAgZm9yIChjb25zdCBmcmFtZSBvZiBleGNlcHRpb24uc3RhY2t0cmFjZS5mcmFtZXMgfHwgW10pIHtcbiAgICAgICAgaWYgKCFmcmFtZS5maWxlbmFtZSB8fCBmcmFtZS5tb2R1bGVfbWV0YWRhdGEpIHtcbiAgICAgICAgICBjb250aW51ZTtcbiAgICAgICAgfVxuXG4gICAgICAgIGNvbnN0IG1ldGFkYXRhID0gZ2V0TWV0YWRhdGFGb3JVcmwocGFyc2VyLCBmcmFtZS5maWxlbmFtZSk7XG5cbiAgICAgICAgaWYgKG1ldGFkYXRhKSB7XG4gICAgICAgICAgZnJhbWUubW9kdWxlX21ldGFkYXRhID0gbWV0YWRhdGE7XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9KTtcbiAgfSBjYXRjaCB7XG4gICAgLy8gVG8gc2F2ZSBidW5kbGUgc2l6ZSB3ZSdyZSBqdXN0IHRyeSBjYXRjaGluZyBoZXJlIGluc3RlYWQgb2YgY2hlY2tpbmcgZm9yIHRoZSBleGlzdGVuY2Ugb2YgYWxsIHRoZSBkaWZmZXJlbnQgb2JqZWN0cy5cbiAgfVxufVxuXG4vKipcbiAqIFN0cmlwcyBtZXRhZGF0YSBmcm9tIHN0YWNrIGZyYW1lcy5cbiAqL1xuZnVuY3Rpb24gc3RyaXBNZXRhZGF0YUZyb21TdGFja0ZyYW1lcyhldmVudCkge1xuICB0cnkge1xuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tbm9uLW51bGwtYXNzZXJ0aW9uXG4gICAgZXZlbnQuZXhjZXB0aW9uLnZhbHVlcy5mb3JFYWNoKGV4Y2VwdGlvbiA9PiB7XG4gICAgICBpZiAoIWV4Y2VwdGlvbi5zdGFja3RyYWNlKSB7XG4gICAgICAgIHJldHVybjtcbiAgICAgIH1cblxuICAgICAgZm9yIChjb25zdCBmcmFtZSBvZiBleGNlcHRpb24uc3RhY2t0cmFjZS5mcmFtZXMgfHwgW10pIHtcbiAgICAgICAgZGVsZXRlIGZyYW1lLm1vZHVsZV9tZXRhZGF0YTtcbiAgICAgIH1cbiAgICB9KTtcbiAgfSBjYXRjaCB7XG4gICAgLy8gVG8gc2F2ZSBidW5kbGUgc2l6ZSB3ZSdyZSBqdXN0IHRyeSBjYXRjaGluZyBoZXJlIGluc3RlYWQgb2YgY2hlY2tpbmcgZm9yIHRoZSBleGlzdGVuY2Ugb2YgYWxsIHRoZSBkaWZmZXJlbnQgb2JqZWN0cy5cbiAgfVxufVxuXG5leHBvcnRzLmFkZE1ldGFkYXRhVG9TdGFja0ZyYW1lcyA9IGFkZE1ldGFkYXRhVG9TdGFja0ZyYW1lcztcbmV4cG9ydHMuZ2V0TWV0YWRhdGFGb3JVcmwgPSBnZXRNZXRhZGF0YUZvclVybDtcbmV4cG9ydHMuc3RyaXBNZXRhZGF0YUZyb21TdGFja0ZyYW1lcyA9IHN0cmlwTWV0YWRhdGFGcm9tU3RhY2tGcmFtZXM7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1tZXRhZGF0YS5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/metadata.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/profiling.js":
/*!*************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/profiling.js ***!
  \*************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst currentScopes = __webpack_require__(/*! ./currentScopes.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst debugBuild = __webpack_require__(/*! ./debug-build.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst debugLogger = __webpack_require__(/*! ./utils/debug-logger.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\n\nfunction isProfilingIntegrationWithProfiler(\n  integration,\n) {\n  return (\n    !!integration &&\n    typeof integration['_profiler'] !== 'undefined' &&\n    typeof integration['_profiler']['start'] === 'function' &&\n    typeof integration['_profiler']['stop'] === 'function'\n  );\n}\n/**\n * Starts the Sentry continuous profiler.\n * This mode is exclusive with the transaction profiler and will only work if the profilesSampleRate is set to a falsy value.\n * In continuous profiling mode, the profiler will keep reporting profile chunks to Sentry until it is stopped, which allows for continuous profiling of the application.\n */\nfunction startProfiler() {\n  const client = currentScopes.getClient();\n  if (!client) {\n    debugBuild.DEBUG_BUILD && debugLogger.debug.warn('No Sentry client available, profiling is not started');\n    return;\n  }\n\n  const integration = client.getIntegrationByName('ProfilingIntegration');\n\n  if (!integration) {\n    debugBuild.DEBUG_BUILD && debugLogger.debug.warn('ProfilingIntegration is not available');\n    return;\n  }\n\n  if (!isProfilingIntegrationWithProfiler(integration)) {\n    debugBuild.DEBUG_BUILD && debugLogger.debug.warn('Profiler is not available on profiling integration.');\n    return;\n  }\n\n  integration._profiler.start();\n}\n\n/**\n * Stops the Sentry continuous profiler.\n * Calls to stop will stop the profiler and flush the currently collected profile data to Sentry.\n */\nfunction stopProfiler() {\n  const client = currentScopes.getClient();\n  if (!client) {\n    debugBuild.DEBUG_BUILD && debugLogger.debug.warn('No Sentry client available, profiling is not started');\n    return;\n  }\n\n  const integration = client.getIntegrationByName('ProfilingIntegration');\n  if (!integration) {\n    debugBuild.DEBUG_BUILD && debugLogger.debug.warn('ProfilingIntegration is not available');\n    return;\n  }\n\n  if (!isProfilingIntegrationWithProfiler(integration)) {\n    debugBuild.DEBUG_BUILD && debugLogger.debug.warn('Profiler is not available on profiling integration.');\n    return;\n  }\n\n  integration._profiler.stop();\n}\n\nconst profiler = {\n  startProfiler,\n  stopProfiler,\n};\n\nexports.profiler = profiler;\n//# sourceMappingURL=profiling.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9wcm9maWxpbmcuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsc0JBQXNCLG1CQUFPLENBQUMsK0hBQW9CO0FBQ2xELG1CQUFtQixtQkFBTyxDQUFDLDJIQUFrQjtBQUM3QyxvQkFBb0IsbUJBQU8sQ0FBQyx5SUFBeUI7O0FBRXJEO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSxnQkFBZ0I7QUFDaEIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9wcm9maWxpbmcuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGN1cnJlbnRTY29wZXMgPSByZXF1aXJlKCcuL2N1cnJlbnRTY29wZXMuanMnKTtcbmNvbnN0IGRlYnVnQnVpbGQgPSByZXF1aXJlKCcuL2RlYnVnLWJ1aWxkLmpzJyk7XG5jb25zdCBkZWJ1Z0xvZ2dlciA9IHJlcXVpcmUoJy4vdXRpbHMvZGVidWctbG9nZ2VyLmpzJyk7XG5cbmZ1bmN0aW9uIGlzUHJvZmlsaW5nSW50ZWdyYXRpb25XaXRoUHJvZmlsZXIoXG4gIGludGVncmF0aW9uLFxuKSB7XG4gIHJldHVybiAoXG4gICAgISFpbnRlZ3JhdGlvbiAmJlxuICAgIHR5cGVvZiBpbnRlZ3JhdGlvblsnX3Byb2ZpbGVyJ10gIT09ICd1bmRlZmluZWQnICYmXG4gICAgdHlwZW9mIGludGVncmF0aW9uWydfcHJvZmlsZXInXVsnc3RhcnQnXSA9PT0gJ2Z1bmN0aW9uJyAmJlxuICAgIHR5cGVvZiBpbnRlZ3JhdGlvblsnX3Byb2ZpbGVyJ11bJ3N0b3AnXSA9PT0gJ2Z1bmN0aW9uJ1xuICApO1xufVxuLyoqXG4gKiBTdGFydHMgdGhlIFNlbnRyeSBjb250aW51b3VzIHByb2ZpbGVyLlxuICogVGhpcyBtb2RlIGlzIGV4Y2x1c2l2ZSB3aXRoIHRoZSB0cmFuc2FjdGlvbiBwcm9maWxlciBhbmQgd2lsbCBvbmx5IHdvcmsgaWYgdGhlIHByb2ZpbGVzU2FtcGxlUmF0ZSBpcyBzZXQgdG8gYSBmYWxzeSB2YWx1ZS5cbiAqIEluIGNvbnRpbnVvdXMgcHJvZmlsaW5nIG1vZGUsIHRoZSBwcm9maWxlciB3aWxsIGtlZXAgcmVwb3J0aW5nIHByb2ZpbGUgY2h1bmtzIHRvIFNlbnRyeSB1bnRpbCBpdCBpcyBzdG9wcGVkLCB3aGljaCBhbGxvd3MgZm9yIGNvbnRpbnVvdXMgcHJvZmlsaW5nIG9mIHRoZSBhcHBsaWNhdGlvbi5cbiAqL1xuZnVuY3Rpb24gc3RhcnRQcm9maWxlcigpIHtcbiAgY29uc3QgY2xpZW50ID0gY3VycmVudFNjb3Blcy5nZXRDbGllbnQoKTtcbiAgaWYgKCFjbGllbnQpIHtcbiAgICBkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEICYmIGRlYnVnTG9nZ2VyLmRlYnVnLndhcm4oJ05vIFNlbnRyeSBjbGllbnQgYXZhaWxhYmxlLCBwcm9maWxpbmcgaXMgbm90IHN0YXJ0ZWQnKTtcbiAgICByZXR1cm47XG4gIH1cblxuICBjb25zdCBpbnRlZ3JhdGlvbiA9IGNsaWVudC5nZXRJbnRlZ3JhdGlvbkJ5TmFtZSgnUHJvZmlsaW5nSW50ZWdyYXRpb24nKTtcblxuICBpZiAoIWludGVncmF0aW9uKSB7XG4gICAgZGVidWdCdWlsZC5ERUJVR19CVUlMRCAmJiBkZWJ1Z0xvZ2dlci5kZWJ1Zy53YXJuKCdQcm9maWxpbmdJbnRlZ3JhdGlvbiBpcyBub3QgYXZhaWxhYmxlJyk7XG4gICAgcmV0dXJuO1xuICB9XG5cbiAgaWYgKCFpc1Byb2ZpbGluZ0ludGVncmF0aW9uV2l0aFByb2ZpbGVyKGludGVncmF0aW9uKSkge1xuICAgIGRlYnVnQnVpbGQuREVCVUdfQlVJTEQgJiYgZGVidWdMb2dnZXIuZGVidWcud2FybignUHJvZmlsZXIgaXMgbm90IGF2YWlsYWJsZSBvbiBwcm9maWxpbmcgaW50ZWdyYXRpb24uJyk7XG4gICAgcmV0dXJuO1xuICB9XG5cbiAgaW50ZWdyYXRpb24uX3Byb2ZpbGVyLnN0YXJ0KCk7XG59XG5cbi8qKlxuICogU3RvcHMgdGhlIFNlbnRyeSBjb250aW51b3VzIHByb2ZpbGVyLlxuICogQ2FsbHMgdG8gc3RvcCB3aWxsIHN0b3AgdGhlIHByb2ZpbGVyIGFuZCBmbHVzaCB0aGUgY3VycmVudGx5IGNvbGxlY3RlZCBwcm9maWxlIGRhdGEgdG8gU2VudHJ5LlxuICovXG5mdW5jdGlvbiBzdG9wUHJvZmlsZXIoKSB7XG4gIGNvbnN0IGNsaWVudCA9IGN1cnJlbnRTY29wZXMuZ2V0Q2xpZW50KCk7XG4gIGlmICghY2xpZW50KSB7XG4gICAgZGVidWdCdWlsZC5ERUJVR19CVUlMRCAmJiBkZWJ1Z0xvZ2dlci5kZWJ1Zy53YXJuKCdObyBTZW50cnkgY2xpZW50IGF2YWlsYWJsZSwgcHJvZmlsaW5nIGlzIG5vdCBzdGFydGVkJyk7XG4gICAgcmV0dXJuO1xuICB9XG5cbiAgY29uc3QgaW50ZWdyYXRpb24gPSBjbGllbnQuZ2V0SW50ZWdyYXRpb25CeU5hbWUoJ1Byb2ZpbGluZ0ludGVncmF0aW9uJyk7XG4gIGlmICghaW50ZWdyYXRpb24pIHtcbiAgICBkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEICYmIGRlYnVnTG9nZ2VyLmRlYnVnLndhcm4oJ1Byb2ZpbGluZ0ludGVncmF0aW9uIGlzIG5vdCBhdmFpbGFibGUnKTtcbiAgICByZXR1cm47XG4gIH1cblxuICBpZiAoIWlzUHJvZmlsaW5nSW50ZWdyYXRpb25XaXRoUHJvZmlsZXIoaW50ZWdyYXRpb24pKSB7XG4gICAgZGVidWdCdWlsZC5ERUJVR19CVUlMRCAmJiBkZWJ1Z0xvZ2dlci5kZWJ1Zy53YXJuKCdQcm9maWxlciBpcyBub3QgYXZhaWxhYmxlIG9uIHByb2ZpbGluZyBpbnRlZ3JhdGlvbi4nKTtcbiAgICByZXR1cm47XG4gIH1cblxuICBpbnRlZ3JhdGlvbi5fcHJvZmlsZXIuc3RvcCgpO1xufVxuXG5jb25zdCBwcm9maWxlciA9IHtcbiAgc3RhcnRQcm9maWxlcixcbiAgc3RvcFByb2ZpbGVyLFxufTtcblxuZXhwb3J0cy5wcm9maWxlciA9IHByb2ZpbGVyO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9cHJvZmlsaW5nLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/profiling.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/scope.js":
/*!*********************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/scope.js ***!
  \*********************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst debugBuild = __webpack_require__(/*! ./debug-build.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst session = __webpack_require__(/*! ./session.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/session.js\");\nconst debugLogger = __webpack_require__(/*! ./utils/debug-logger.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst is = __webpack_require__(/*! ./utils/is.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js\");\nconst merge = __webpack_require__(/*! ./utils/merge.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/merge.js\");\nconst misc = __webpack_require__(/*! ./utils/misc.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/misc.js\");\nconst propagationContext = __webpack_require__(/*! ./utils/propagationContext.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/propagationContext.js\");\nconst spanOnScope = __webpack_require__(/*! ./utils/spanOnScope.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanOnScope.js\");\nconst string = __webpack_require__(/*! ./utils/string.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/string.js\");\nconst time = __webpack_require__(/*! ./utils/time.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/time.js\");\n\n/**\n * Default value for maximum number of breadcrumbs added to an event.\n */\nconst DEFAULT_MAX_BREADCRUMBS = 100;\n\n/**\n * A context to be used for capturing an event.\n * This can either be a Scope, or a partial ScopeContext,\n * or a callback that receives the current scope and returns a new scope to use.\n */\n\n/**\n * Holds additional event information.\n */\nclass Scope {\n  /** Flag if notifying is happening. */\n\n  /** Callback for client to receive scope changes. */\n\n  /** Callback list that will be called during event processing. */\n\n  /** Array of breadcrumbs. */\n\n  /** User */\n\n  /** Tags */\n\n  /** Extra */\n\n  /** Contexts */\n\n  /** Attachments */\n\n  /** Propagation Context for distributed tracing */\n\n  /**\n   * A place to stash data which is needed at some point in the SDK's event processing pipeline but which shouldn't get\n   * sent to Sentry\n   */\n\n  /** Fingerprint */\n\n  /** Severity */\n\n  /**\n   * Transaction Name\n   *\n   * IMPORTANT: The transaction name on the scope has nothing to do with root spans/transaction objects.\n   * It's purpose is to assign a transaction to the scope that's added to non-transaction events.\n   */\n\n  /** Session */\n\n  /** The client on this scope */\n\n  /** Contains the last event id of a captured event.  */\n\n  // NOTE: Any field which gets added here should get added not only to the constructor but also to the `clone` method.\n\n   constructor() {\n    this._notifyingListeners = false;\n    this._scopeListeners = [];\n    this._eventProcessors = [];\n    this._breadcrumbs = [];\n    this._attachments = [];\n    this._user = {};\n    this._tags = {};\n    this._extra = {};\n    this._contexts = {};\n    this._sdkProcessingMetadata = {};\n    this._propagationContext = {\n      traceId: propagationContext.generateTraceId(),\n      sampleRand: Math.random(),\n    };\n  }\n\n  /**\n   * Clone all data from this scope into a new scope.\n   */\n   clone() {\n    const newScope = new Scope();\n    newScope._breadcrumbs = [...this._breadcrumbs];\n    newScope._tags = { ...this._tags };\n    newScope._extra = { ...this._extra };\n    newScope._contexts = { ...this._contexts };\n    if (this._contexts.flags) {\n      // We need to copy the `values` array so insertions on a cloned scope\n      // won't affect the original array.\n      newScope._contexts.flags = {\n        values: [...this._contexts.flags.values],\n      };\n    }\n\n    newScope._user = this._user;\n    newScope._level = this._level;\n    newScope._session = this._session;\n    newScope._transactionName = this._transactionName;\n    newScope._fingerprint = this._fingerprint;\n    newScope._eventProcessors = [...this._eventProcessors];\n    newScope._attachments = [...this._attachments];\n    newScope._sdkProcessingMetadata = { ...this._sdkProcessingMetadata };\n    newScope._propagationContext = { ...this._propagationContext };\n    newScope._client = this._client;\n    newScope._lastEventId = this._lastEventId;\n\n    spanOnScope._setSpanForScope(newScope, spanOnScope._getSpanForScope(this));\n\n    return newScope;\n  }\n\n  /**\n   * Update the client assigned to this scope.\n   * Note that not every scope will have a client assigned - isolation scopes & the global scope will generally not have a client,\n   * as well as manually created scopes.\n   */\n   setClient(client) {\n    this._client = client;\n  }\n\n  /**\n   * Set the ID of the last captured error event.\n   * This is generally only captured on the isolation scope.\n   */\n   setLastEventId(lastEventId) {\n    this._lastEventId = lastEventId;\n  }\n\n  /**\n   * Get the client assigned to this scope.\n   */\n   getClient() {\n    return this._client ;\n  }\n\n  /**\n   * Get the ID of the last captured error event.\n   * This is generally only available on the isolation scope.\n   */\n   lastEventId() {\n    return this._lastEventId;\n  }\n\n  /**\n   * @inheritDoc\n   */\n   addScopeListener(callback) {\n    this._scopeListeners.push(callback);\n  }\n\n  /**\n   * Add an event processor that will be called before an event is sent.\n   */\n   addEventProcessor(callback) {\n    this._eventProcessors.push(callback);\n    return this;\n  }\n\n  /**\n   * Set the user for this scope.\n   * Set to `null` to unset the user.\n   */\n   setUser(user) {\n    // If null is passed we want to unset everything, but still define keys,\n    // so that later down in the pipeline any existing values are cleared.\n    this._user = user || {\n      email: undefined,\n      id: undefined,\n      ip_address: undefined,\n      username: undefined,\n    };\n\n    if (this._session) {\n      session.updateSession(this._session, { user });\n    }\n\n    this._notifyScopeListeners();\n    return this;\n  }\n\n  /**\n   * Get the user from this scope.\n   */\n   getUser() {\n    return this._user;\n  }\n\n  /**\n   * Set an object that will be merged into existing tags on the scope,\n   * and will be sent as tags data with the event.\n   */\n   setTags(tags) {\n    this._tags = {\n      ...this._tags,\n      ...tags,\n    };\n    this._notifyScopeListeners();\n    return this;\n  }\n\n  /**\n   * Set a single tag that will be sent as tags data with the event.\n   */\n   setTag(key, value) {\n    this._tags = { ...this._tags, [key]: value };\n    this._notifyScopeListeners();\n    return this;\n  }\n\n  /**\n   * Set an object that will be merged into existing extra on the scope,\n   * and will be sent as extra data with the event.\n   */\n   setExtras(extras) {\n    this._extra = {\n      ...this._extra,\n      ...extras,\n    };\n    this._notifyScopeListeners();\n    return this;\n  }\n\n  /**\n   * Set a single key:value extra entry that will be sent as extra data with the event.\n   */\n   setExtra(key, extra) {\n    this._extra = { ...this._extra, [key]: extra };\n    this._notifyScopeListeners();\n    return this;\n  }\n\n  /**\n   * Sets the fingerprint on the scope to send with the events.\n   * @param {string[]} fingerprint Fingerprint to group events in Sentry.\n   */\n   setFingerprint(fingerprint) {\n    this._fingerprint = fingerprint;\n    this._notifyScopeListeners();\n    return this;\n  }\n\n  /**\n   * Sets the level on the scope for future events.\n   */\n   setLevel(level) {\n    this._level = level;\n    this._notifyScopeListeners();\n    return this;\n  }\n\n  /**\n   * Sets the transaction name on the scope so that the name of e.g. taken server route or\n   * the page location is attached to future events.\n   *\n   * IMPORTANT: Calling this function does NOT change the name of the currently active\n   * root span. If you want to change the name of the active root span, use\n   * `Sentry.updateSpanName(rootSpan, 'new name')` instead.\n   *\n   * By default, the SDK updates the scope's transaction name automatically on sensible\n   * occasions, such as a page navigation or when handling a new request on the server.\n   */\n   setTransactionName(name) {\n    this._transactionName = name;\n    this._notifyScopeListeners();\n    return this;\n  }\n\n  /**\n   * Sets context data with the given name.\n   * Data passed as context will be normalized. You can also pass `null` to unset the context.\n   * Note that context data will not be merged - calling `setContext` will overwrite an existing context with the same key.\n   */\n   setContext(key, context) {\n    if (context === null) {\n      // eslint-disable-next-line @typescript-eslint/no-dynamic-delete\n      delete this._contexts[key];\n    } else {\n      this._contexts[key] = context;\n    }\n\n    this._notifyScopeListeners();\n    return this;\n  }\n\n  /**\n   * Set the session for the scope.\n   */\n   setSession(session) {\n    if (!session) {\n      delete this._session;\n    } else {\n      this._session = session;\n    }\n    this._notifyScopeListeners();\n    return this;\n  }\n\n  /**\n   * Get the session from the scope.\n   */\n   getSession() {\n    return this._session;\n  }\n\n  /**\n   * Updates the scope with provided data. Can work in three variations:\n   * - plain object containing updatable attributes\n   * - Scope instance that'll extract the attributes from\n   * - callback function that'll receive the current scope as an argument and allow for modifications\n   */\n   update(captureContext) {\n    if (!captureContext) {\n      return this;\n    }\n\n    const scopeToMerge = typeof captureContext === 'function' ? captureContext(this) : captureContext;\n\n    const scopeInstance =\n      scopeToMerge instanceof Scope\n        ? scopeToMerge.getScopeData()\n        : is.isPlainObject(scopeToMerge)\n          ? (captureContext )\n          : undefined;\n\n    const { tags, extra, user, contexts, level, fingerprint = [], propagationContext } = scopeInstance || {};\n\n    this._tags = { ...this._tags, ...tags };\n    this._extra = { ...this._extra, ...extra };\n    this._contexts = { ...this._contexts, ...contexts };\n\n    if (user && Object.keys(user).length) {\n      this._user = user;\n    }\n\n    if (level) {\n      this._level = level;\n    }\n\n    if (fingerprint.length) {\n      this._fingerprint = fingerprint;\n    }\n\n    if (propagationContext) {\n      this._propagationContext = propagationContext;\n    }\n\n    return this;\n  }\n\n  /**\n   * Clears the current scope and resets its properties.\n   * Note: The client will not be cleared.\n   */\n   clear() {\n    // client is not cleared here on purpose!\n    this._breadcrumbs = [];\n    this._tags = {};\n    this._extra = {};\n    this._user = {};\n    this._contexts = {};\n    this._level = undefined;\n    this._transactionName = undefined;\n    this._fingerprint = undefined;\n    this._session = undefined;\n    spanOnScope._setSpanForScope(this, undefined);\n    this._attachments = [];\n    this.setPropagationContext({ traceId: propagationContext.generateTraceId(), sampleRand: Math.random() });\n\n    this._notifyScopeListeners();\n    return this;\n  }\n\n  /**\n   * Adds a breadcrumb to the scope.\n   * By default, the last 100 breadcrumbs are kept.\n   */\n   addBreadcrumb(breadcrumb, maxBreadcrumbs) {\n    const maxCrumbs = typeof maxBreadcrumbs === 'number' ? maxBreadcrumbs : DEFAULT_MAX_BREADCRUMBS;\n\n    // No data has been changed, so don't notify scope listeners\n    if (maxCrumbs <= 0) {\n      return this;\n    }\n\n    const mergedBreadcrumb = {\n      timestamp: time.dateTimestampInSeconds(),\n      ...breadcrumb,\n      // Breadcrumb messages can theoretically be infinitely large and they're held in memory so we truncate them not to leak (too much) memory\n      message: breadcrumb.message ? string.truncate(breadcrumb.message, 2048) : breadcrumb.message,\n    };\n\n    this._breadcrumbs.push(mergedBreadcrumb);\n    if (this._breadcrumbs.length > maxCrumbs) {\n      this._breadcrumbs = this._breadcrumbs.slice(-maxCrumbs);\n      this._client?.recordDroppedEvent('buffer_overflow', 'log_item');\n    }\n\n    this._notifyScopeListeners();\n\n    return this;\n  }\n\n  /**\n   * Get the last breadcrumb of the scope.\n   */\n   getLastBreadcrumb() {\n    return this._breadcrumbs[this._breadcrumbs.length - 1];\n  }\n\n  /**\n   * Clear all breadcrumbs from the scope.\n   */\n   clearBreadcrumbs() {\n    this._breadcrumbs = [];\n    this._notifyScopeListeners();\n    return this;\n  }\n\n  /**\n   * Add an attachment to the scope.\n   */\n   addAttachment(attachment) {\n    this._attachments.push(attachment);\n    return this;\n  }\n\n  /**\n   * Clear all attachments from the scope.\n   */\n   clearAttachments() {\n    this._attachments = [];\n    return this;\n  }\n\n  /**\n   * Get the data of this scope, which should be applied to an event during processing.\n   */\n   getScopeData() {\n    return {\n      breadcrumbs: this._breadcrumbs,\n      attachments: this._attachments,\n      contexts: this._contexts,\n      tags: this._tags,\n      extra: this._extra,\n      user: this._user,\n      level: this._level,\n      fingerprint: this._fingerprint || [],\n      eventProcessors: this._eventProcessors,\n      propagationContext: this._propagationContext,\n      sdkProcessingMetadata: this._sdkProcessingMetadata,\n      transactionName: this._transactionName,\n      span: spanOnScope._getSpanForScope(this),\n    };\n  }\n\n  /**\n   * Add data which will be accessible during event processing but won't get sent to Sentry.\n   */\n   setSDKProcessingMetadata(newData) {\n    this._sdkProcessingMetadata = merge.merge(this._sdkProcessingMetadata, newData, 2);\n    return this;\n  }\n\n  /**\n   * Add propagation context to the scope, used for distributed tracing\n   */\n   setPropagationContext(context) {\n    this._propagationContext = context;\n    return this;\n  }\n\n  /**\n   * Get propagation context from the scope, used for distributed tracing\n   */\n   getPropagationContext() {\n    return this._propagationContext;\n  }\n\n  /**\n   * Capture an exception for this scope.\n   *\n   * @returns {string} The id of the captured Sentry event.\n   */\n   captureException(exception, hint) {\n    const eventId = hint?.event_id || misc.uuid4();\n\n    if (!this._client) {\n      debugBuild.DEBUG_BUILD && debugLogger.debug.warn('No client configured on scope - will not capture exception!');\n      return eventId;\n    }\n\n    const syntheticException = new Error('Sentry syntheticException');\n\n    this._client.captureException(\n      exception,\n      {\n        originalException: exception,\n        syntheticException,\n        ...hint,\n        event_id: eventId,\n      },\n      this,\n    );\n\n    return eventId;\n  }\n\n  /**\n   * Capture a message for this scope.\n   *\n   * @returns {string} The id of the captured message.\n   */\n   captureMessage(message, level, hint) {\n    const eventId = hint?.event_id || misc.uuid4();\n\n    if (!this._client) {\n      debugBuild.DEBUG_BUILD && debugLogger.debug.warn('No client configured on scope - will not capture message!');\n      return eventId;\n    }\n\n    const syntheticException = new Error(message);\n\n    this._client.captureMessage(\n      message,\n      level,\n      {\n        originalException: message,\n        syntheticException,\n        ...hint,\n        event_id: eventId,\n      },\n      this,\n    );\n\n    return eventId;\n  }\n\n  /**\n   * Capture a Sentry event for this scope.\n   *\n   * @returns {string} The id of the captured event.\n   */\n   captureEvent(event, hint) {\n    const eventId = hint?.event_id || misc.uuid4();\n\n    if (!this._client) {\n      debugBuild.DEBUG_BUILD && debugLogger.debug.warn('No client configured on scope - will not capture event!');\n      return eventId;\n    }\n\n    this._client.captureEvent(event, { ...hint, event_id: eventId }, this);\n\n    return eventId;\n  }\n\n  /**\n   * This will be called on every set call.\n   */\n   _notifyScopeListeners() {\n    // We need this check for this._notifyingListeners to be able to work on scope during updates\n    // If this check is not here we'll produce endless recursion when something is done with the scope\n    // during the callback.\n    if (!this._notifyingListeners) {\n      this._notifyingListeners = true;\n      this._scopeListeners.forEach(callback => {\n        callback(this);\n      });\n      this._notifyingListeners = false;\n    }\n  }\n}\n\nexports.Scope = Scope;\n//# sourceMappingURL=scope.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9zY29wZS5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxtQkFBbUIsbUJBQU8sQ0FBQywySEFBa0I7QUFDN0MsZ0JBQWdCLG1CQUFPLENBQUMsbUhBQWM7QUFDdEMsb0JBQW9CLG1CQUFPLENBQUMseUlBQXlCO0FBQ3JELFdBQVcsbUJBQU8sQ0FBQyxxSEFBZTtBQUNsQyxjQUFjLG1CQUFPLENBQUMsMkhBQWtCO0FBQ3hDLGFBQWEsbUJBQU8sQ0FBQyx5SEFBaUI7QUFDdEMsMkJBQTJCLG1CQUFPLENBQUMscUpBQStCO0FBQ2xFLG9CQUFvQixtQkFBTyxDQUFDLHVJQUF3QjtBQUNwRCxlQUFlLG1CQUFPLENBQUMsNkhBQW1CO0FBQzFDLGFBQWEsbUJBQU8sQ0FBQyx5SEFBaUI7O0FBRXRDO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTs7QUFFQTs7QUFFQTs7QUFFQTs7QUFFQTs7QUFFQTs7QUFFQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7O0FBRUE7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsdUJBQXVCO0FBQ3ZCLHdCQUF3QjtBQUN4QiwyQkFBMkI7QUFDM0I7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSx3Q0FBd0M7QUFDeEMscUNBQXFDO0FBQ3JDO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQSw2Q0FBNkMsTUFBTTtBQUNuRDs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLG1CQUFtQjtBQUNuQjtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0Esb0JBQW9CO0FBQ3BCO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsYUFBYSxVQUFVO0FBQ3ZCO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLE1BQU07QUFDTjtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxNQUFNO0FBQ047QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLFlBQVksMkVBQTJFOztBQUV2RixtQkFBbUI7QUFDbkIsb0JBQW9CO0FBQ3BCLHVCQUF1Qjs7QUFFdkI7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGlDQUFpQywwRUFBMEU7O0FBRTNHO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQSxlQUFlLFFBQVE7QUFDdkI7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsT0FBTztBQUNQO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQSxlQUFlLFFBQVE7QUFDdkI7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxPQUFPO0FBQ1A7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBLGVBQWUsUUFBUTtBQUN2QjtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsdUNBQXVDLDRCQUE0Qjs7QUFFbkU7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsT0FBTztBQUNQO0FBQ0E7QUFDQTtBQUNBOztBQUVBLGFBQWE7QUFDYiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3Njb3BlLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBkZWJ1Z0J1aWxkID0gcmVxdWlyZSgnLi9kZWJ1Zy1idWlsZC5qcycpO1xuY29uc3Qgc2Vzc2lvbiA9IHJlcXVpcmUoJy4vc2Vzc2lvbi5qcycpO1xuY29uc3QgZGVidWdMb2dnZXIgPSByZXF1aXJlKCcuL3V0aWxzL2RlYnVnLWxvZ2dlci5qcycpO1xuY29uc3QgaXMgPSByZXF1aXJlKCcuL3V0aWxzL2lzLmpzJyk7XG5jb25zdCBtZXJnZSA9IHJlcXVpcmUoJy4vdXRpbHMvbWVyZ2UuanMnKTtcbmNvbnN0IG1pc2MgPSByZXF1aXJlKCcuL3V0aWxzL21pc2MuanMnKTtcbmNvbnN0IHByb3BhZ2F0aW9uQ29udGV4dCA9IHJlcXVpcmUoJy4vdXRpbHMvcHJvcGFnYXRpb25Db250ZXh0LmpzJyk7XG5jb25zdCBzcGFuT25TY29wZSA9IHJlcXVpcmUoJy4vdXRpbHMvc3Bhbk9uU2NvcGUuanMnKTtcbmNvbnN0IHN0cmluZyA9IHJlcXVpcmUoJy4vdXRpbHMvc3RyaW5nLmpzJyk7XG5jb25zdCB0aW1lID0gcmVxdWlyZSgnLi91dGlscy90aW1lLmpzJyk7XG5cbi8qKlxuICogRGVmYXVsdCB2YWx1ZSBmb3IgbWF4aW11bSBudW1iZXIgb2YgYnJlYWRjcnVtYnMgYWRkZWQgdG8gYW4gZXZlbnQuXG4gKi9cbmNvbnN0IERFRkFVTFRfTUFYX0JSRUFEQ1JVTUJTID0gMTAwO1xuXG4vKipcbiAqIEEgY29udGV4dCB0byBiZSB1c2VkIGZvciBjYXB0dXJpbmcgYW4gZXZlbnQuXG4gKiBUaGlzIGNhbiBlaXRoZXIgYmUgYSBTY29wZSwgb3IgYSBwYXJ0aWFsIFNjb3BlQ29udGV4dCxcbiAqIG9yIGEgY2FsbGJhY2sgdGhhdCByZWNlaXZlcyB0aGUgY3VycmVudCBzY29wZSBhbmQgcmV0dXJucyBhIG5ldyBzY29wZSB0byB1c2UuXG4gKi9cblxuLyoqXG4gKiBIb2xkcyBhZGRpdGlvbmFsIGV2ZW50IGluZm9ybWF0aW9uLlxuICovXG5jbGFzcyBTY29wZSB7XG4gIC8qKiBGbGFnIGlmIG5vdGlmeWluZyBpcyBoYXBwZW5pbmcuICovXG5cbiAgLyoqIENhbGxiYWNrIGZvciBjbGllbnQgdG8gcmVjZWl2ZSBzY29wZSBjaGFuZ2VzLiAqL1xuXG4gIC8qKiBDYWxsYmFjayBsaXN0IHRoYXQgd2lsbCBiZSBjYWxsZWQgZHVyaW5nIGV2ZW50IHByb2Nlc3NpbmcuICovXG5cbiAgLyoqIEFycmF5IG9mIGJyZWFkY3J1bWJzLiAqL1xuXG4gIC8qKiBVc2VyICovXG5cbiAgLyoqIFRhZ3MgKi9cblxuICAvKiogRXh0cmEgKi9cblxuICAvKiogQ29udGV4dHMgKi9cblxuICAvKiogQXR0YWNobWVudHMgKi9cblxuICAvKiogUHJvcGFnYXRpb24gQ29udGV4dCBmb3IgZGlzdHJpYnV0ZWQgdHJhY2luZyAqL1xuXG4gIC8qKlxuICAgKiBBIHBsYWNlIHRvIHN0YXNoIGRhdGEgd2hpY2ggaXMgbmVlZGVkIGF0IHNvbWUgcG9pbnQgaW4gdGhlIFNESydzIGV2ZW50IHByb2Nlc3NpbmcgcGlwZWxpbmUgYnV0IHdoaWNoIHNob3VsZG4ndCBnZXRcbiAgICogc2VudCB0byBTZW50cnlcbiAgICovXG5cbiAgLyoqIEZpbmdlcnByaW50ICovXG5cbiAgLyoqIFNldmVyaXR5ICovXG5cbiAgLyoqXG4gICAqIFRyYW5zYWN0aW9uIE5hbWVcbiAgICpcbiAgICogSU1QT1JUQU5UOiBUaGUgdHJhbnNhY3Rpb24gbmFtZSBvbiB0aGUgc2NvcGUgaGFzIG5vdGhpbmcgdG8gZG8gd2l0aCByb290IHNwYW5zL3RyYW5zYWN0aW9uIG9iamVjdHMuXG4gICAqIEl0J3MgcHVycG9zZSBpcyB0byBhc3NpZ24gYSB0cmFuc2FjdGlvbiB0byB0aGUgc2NvcGUgdGhhdCdzIGFkZGVkIHRvIG5vbi10cmFuc2FjdGlvbiBldmVudHMuXG4gICAqL1xuXG4gIC8qKiBTZXNzaW9uICovXG5cbiAgLyoqIFRoZSBjbGllbnQgb24gdGhpcyBzY29wZSAqL1xuXG4gIC8qKiBDb250YWlucyB0aGUgbGFzdCBldmVudCBpZCBvZiBhIGNhcHR1cmVkIGV2ZW50LiAgKi9cblxuICAvLyBOT1RFOiBBbnkgZmllbGQgd2hpY2ggZ2V0cyBhZGRlZCBoZXJlIHNob3VsZCBnZXQgYWRkZWQgbm90IG9ubHkgdG8gdGhlIGNvbnN0cnVjdG9yIGJ1dCBhbHNvIHRvIHRoZSBgY2xvbmVgIG1ldGhvZC5cblxuICAgY29uc3RydWN0b3IoKSB7XG4gICAgdGhpcy5fbm90aWZ5aW5nTGlzdGVuZXJzID0gZmFsc2U7XG4gICAgdGhpcy5fc2NvcGVMaXN0ZW5lcnMgPSBbXTtcbiAgICB0aGlzLl9ldmVudFByb2Nlc3NvcnMgPSBbXTtcbiAgICB0aGlzLl9icmVhZGNydW1icyA9IFtdO1xuICAgIHRoaXMuX2F0dGFjaG1lbnRzID0gW107XG4gICAgdGhpcy5fdXNlciA9IHt9O1xuICAgIHRoaXMuX3RhZ3MgPSB7fTtcbiAgICB0aGlzLl9leHRyYSA9IHt9O1xuICAgIHRoaXMuX2NvbnRleHRzID0ge307XG4gICAgdGhpcy5fc2RrUHJvY2Vzc2luZ01ldGFkYXRhID0ge307XG4gICAgdGhpcy5fcHJvcGFnYXRpb25Db250ZXh0ID0ge1xuICAgICAgdHJhY2VJZDogcHJvcGFnYXRpb25Db250ZXh0LmdlbmVyYXRlVHJhY2VJZCgpLFxuICAgICAgc2FtcGxlUmFuZDogTWF0aC5yYW5kb20oKSxcbiAgICB9O1xuICB9XG5cbiAgLyoqXG4gICAqIENsb25lIGFsbCBkYXRhIGZyb20gdGhpcyBzY29wZSBpbnRvIGEgbmV3IHNjb3BlLlxuICAgKi9cbiAgIGNsb25lKCkge1xuICAgIGNvbnN0IG5ld1Njb3BlID0gbmV3IFNjb3BlKCk7XG4gICAgbmV3U2NvcGUuX2JyZWFkY3J1bWJzID0gWy4uLnRoaXMuX2JyZWFkY3J1bWJzXTtcbiAgICBuZXdTY29wZS5fdGFncyA9IHsgLi4udGhpcy5fdGFncyB9O1xuICAgIG5ld1Njb3BlLl9leHRyYSA9IHsgLi4udGhpcy5fZXh0cmEgfTtcbiAgICBuZXdTY29wZS5fY29udGV4dHMgPSB7IC4uLnRoaXMuX2NvbnRleHRzIH07XG4gICAgaWYgKHRoaXMuX2NvbnRleHRzLmZsYWdzKSB7XG4gICAgICAvLyBXZSBuZWVkIHRvIGNvcHkgdGhlIGB2YWx1ZXNgIGFycmF5IHNvIGluc2VydGlvbnMgb24gYSBjbG9uZWQgc2NvcGVcbiAgICAgIC8vIHdvbid0IGFmZmVjdCB0aGUgb3JpZ2luYWwgYXJyYXkuXG4gICAgICBuZXdTY29wZS5fY29udGV4dHMuZmxhZ3MgPSB7XG4gICAgICAgIHZhbHVlczogWy4uLnRoaXMuX2NvbnRleHRzLmZsYWdzLnZhbHVlc10sXG4gICAgICB9O1xuICAgIH1cblxuICAgIG5ld1Njb3BlLl91c2VyID0gdGhpcy5fdXNlcjtcbiAgICBuZXdTY29wZS5fbGV2ZWwgPSB0aGlzLl9sZXZlbDtcbiAgICBuZXdTY29wZS5fc2Vzc2lvbiA9IHRoaXMuX3Nlc3Npb247XG4gICAgbmV3U2NvcGUuX3RyYW5zYWN0aW9uTmFtZSA9IHRoaXMuX3RyYW5zYWN0aW9uTmFtZTtcbiAgICBuZXdTY29wZS5fZmluZ2VycHJpbnQgPSB0aGlzLl9maW5nZXJwcmludDtcbiAgICBuZXdTY29wZS5fZXZlbnRQcm9jZXNzb3JzID0gWy4uLnRoaXMuX2V2ZW50UHJvY2Vzc29yc107XG4gICAgbmV3U2NvcGUuX2F0dGFjaG1lbnRzID0gWy4uLnRoaXMuX2F0dGFjaG1lbnRzXTtcbiAgICBuZXdTY29wZS5fc2RrUHJvY2Vzc2luZ01ldGFkYXRhID0geyAuLi50aGlzLl9zZGtQcm9jZXNzaW5nTWV0YWRhdGEgfTtcbiAgICBuZXdTY29wZS5fcHJvcGFnYXRpb25Db250ZXh0ID0geyAuLi50aGlzLl9wcm9wYWdhdGlvbkNvbnRleHQgfTtcbiAgICBuZXdTY29wZS5fY2xpZW50ID0gdGhpcy5fY2xpZW50O1xuICAgIG5ld1Njb3BlLl9sYXN0RXZlbnRJZCA9IHRoaXMuX2xhc3RFdmVudElkO1xuXG4gICAgc3Bhbk9uU2NvcGUuX3NldFNwYW5Gb3JTY29wZShuZXdTY29wZSwgc3Bhbk9uU2NvcGUuX2dldFNwYW5Gb3JTY29wZSh0aGlzKSk7XG5cbiAgICByZXR1cm4gbmV3U2NvcGU7XG4gIH1cblxuICAvKipcbiAgICogVXBkYXRlIHRoZSBjbGllbnQgYXNzaWduZWQgdG8gdGhpcyBzY29wZS5cbiAgICogTm90ZSB0aGF0IG5vdCBldmVyeSBzY29wZSB3aWxsIGhhdmUgYSBjbGllbnQgYXNzaWduZWQgLSBpc29sYXRpb24gc2NvcGVzICYgdGhlIGdsb2JhbCBzY29wZSB3aWxsIGdlbmVyYWxseSBub3QgaGF2ZSBhIGNsaWVudCxcbiAgICogYXMgd2VsbCBhcyBtYW51YWxseSBjcmVhdGVkIHNjb3Blcy5cbiAgICovXG4gICBzZXRDbGllbnQoY2xpZW50KSB7XG4gICAgdGhpcy5fY2xpZW50ID0gY2xpZW50O1xuICB9XG5cbiAgLyoqXG4gICAqIFNldCB0aGUgSUQgb2YgdGhlIGxhc3QgY2FwdHVyZWQgZXJyb3IgZXZlbnQuXG4gICAqIFRoaXMgaXMgZ2VuZXJhbGx5IG9ubHkgY2FwdHVyZWQgb24gdGhlIGlzb2xhdGlvbiBzY29wZS5cbiAgICovXG4gICBzZXRMYXN0RXZlbnRJZChsYXN0RXZlbnRJZCkge1xuICAgIHRoaXMuX2xhc3RFdmVudElkID0gbGFzdEV2ZW50SWQ7XG4gIH1cblxuICAvKipcbiAgICogR2V0IHRoZSBjbGllbnQgYXNzaWduZWQgdG8gdGhpcyBzY29wZS5cbiAgICovXG4gICBnZXRDbGllbnQoKSB7XG4gICAgcmV0dXJuIHRoaXMuX2NsaWVudCA7XG4gIH1cblxuICAvKipcbiAgICogR2V0IHRoZSBJRCBvZiB0aGUgbGFzdCBjYXB0dXJlZCBlcnJvciBldmVudC5cbiAgICogVGhpcyBpcyBnZW5lcmFsbHkgb25seSBhdmFpbGFibGUgb24gdGhlIGlzb2xhdGlvbiBzY29wZS5cbiAgICovXG4gICBsYXN0RXZlbnRJZCgpIHtcbiAgICByZXR1cm4gdGhpcy5fbGFzdEV2ZW50SWQ7XG4gIH1cblxuICAvKipcbiAgICogQGluaGVyaXREb2NcbiAgICovXG4gICBhZGRTY29wZUxpc3RlbmVyKGNhbGxiYWNrKSB7XG4gICAgdGhpcy5fc2NvcGVMaXN0ZW5lcnMucHVzaChjYWxsYmFjayk7XG4gIH1cblxuICAvKipcbiAgICogQWRkIGFuIGV2ZW50IHByb2Nlc3NvciB0aGF0IHdpbGwgYmUgY2FsbGVkIGJlZm9yZSBhbiBldmVudCBpcyBzZW50LlxuICAgKi9cbiAgIGFkZEV2ZW50UHJvY2Vzc29yKGNhbGxiYWNrKSB7XG4gICAgdGhpcy5fZXZlbnRQcm9jZXNzb3JzLnB1c2goY2FsbGJhY2spO1xuICAgIHJldHVybiB0aGlzO1xuICB9XG5cbiAgLyoqXG4gICAqIFNldCB0aGUgdXNlciBmb3IgdGhpcyBzY29wZS5cbiAgICogU2V0IHRvIGBudWxsYCB0byB1bnNldCB0aGUgdXNlci5cbiAgICovXG4gICBzZXRVc2VyKHVzZXIpIHtcbiAgICAvLyBJZiBudWxsIGlzIHBhc3NlZCB3ZSB3YW50IHRvIHVuc2V0IGV2ZXJ5dGhpbmcsIGJ1dCBzdGlsbCBkZWZpbmUga2V5cyxcbiAgICAvLyBzbyB0aGF0IGxhdGVyIGRvd24gaW4gdGhlIHBpcGVsaW5lIGFueSBleGlzdGluZyB2YWx1ZXMgYXJlIGNsZWFyZWQuXG4gICAgdGhpcy5fdXNlciA9IHVzZXIgfHwge1xuICAgICAgZW1haWw6IHVuZGVmaW5lZCxcbiAgICAgIGlkOiB1bmRlZmluZWQsXG4gICAgICBpcF9hZGRyZXNzOiB1bmRlZmluZWQsXG4gICAgICB1c2VybmFtZTogdW5kZWZpbmVkLFxuICAgIH07XG5cbiAgICBpZiAodGhpcy5fc2Vzc2lvbikge1xuICAgICAgc2Vzc2lvbi51cGRhdGVTZXNzaW9uKHRoaXMuX3Nlc3Npb24sIHsgdXNlciB9KTtcbiAgICB9XG5cbiAgICB0aGlzLl9ub3RpZnlTY29wZUxpc3RlbmVycygpO1xuICAgIHJldHVybiB0aGlzO1xuICB9XG5cbiAgLyoqXG4gICAqIEdldCB0aGUgdXNlciBmcm9tIHRoaXMgc2NvcGUuXG4gICAqL1xuICAgZ2V0VXNlcigpIHtcbiAgICByZXR1cm4gdGhpcy5fdXNlcjtcbiAgfVxuXG4gIC8qKlxuICAgKiBTZXQgYW4gb2JqZWN0IHRoYXQgd2lsbCBiZSBtZXJnZWQgaW50byBleGlzdGluZyB0YWdzIG9uIHRoZSBzY29wZSxcbiAgICogYW5kIHdpbGwgYmUgc2VudCBhcyB0YWdzIGRhdGEgd2l0aCB0aGUgZXZlbnQuXG4gICAqL1xuICAgc2V0VGFncyh0YWdzKSB7XG4gICAgdGhpcy5fdGFncyA9IHtcbiAgICAgIC4uLnRoaXMuX3RhZ3MsXG4gICAgICAuLi50YWdzLFxuICAgIH07XG4gICAgdGhpcy5fbm90aWZ5U2NvcGVMaXN0ZW5lcnMoKTtcbiAgICByZXR1cm4gdGhpcztcbiAgfVxuXG4gIC8qKlxuICAgKiBTZXQgYSBzaW5nbGUgdGFnIHRoYXQgd2lsbCBiZSBzZW50IGFzIHRhZ3MgZGF0YSB3aXRoIHRoZSBldmVudC5cbiAgICovXG4gICBzZXRUYWcoa2V5LCB2YWx1ZSkge1xuICAgIHRoaXMuX3RhZ3MgPSB7IC4uLnRoaXMuX3RhZ3MsIFtrZXldOiB2YWx1ZSB9O1xuICAgIHRoaXMuX25vdGlmeVNjb3BlTGlzdGVuZXJzKCk7XG4gICAgcmV0dXJuIHRoaXM7XG4gIH1cblxuICAvKipcbiAgICogU2V0IGFuIG9iamVjdCB0aGF0IHdpbGwgYmUgbWVyZ2VkIGludG8gZXhpc3RpbmcgZXh0cmEgb24gdGhlIHNjb3BlLFxuICAgKiBhbmQgd2lsbCBiZSBzZW50IGFzIGV4dHJhIGRhdGEgd2l0aCB0aGUgZXZlbnQuXG4gICAqL1xuICAgc2V0RXh0cmFzKGV4dHJhcykge1xuICAgIHRoaXMuX2V4dHJhID0ge1xuICAgICAgLi4udGhpcy5fZXh0cmEsXG4gICAgICAuLi5leHRyYXMsXG4gICAgfTtcbiAgICB0aGlzLl9ub3RpZnlTY29wZUxpc3RlbmVycygpO1xuICAgIHJldHVybiB0aGlzO1xuICB9XG5cbiAgLyoqXG4gICAqIFNldCBhIHNpbmdsZSBrZXk6dmFsdWUgZXh0cmEgZW50cnkgdGhhdCB3aWxsIGJlIHNlbnQgYXMgZXh0cmEgZGF0YSB3aXRoIHRoZSBldmVudC5cbiAgICovXG4gICBzZXRFeHRyYShrZXksIGV4dHJhKSB7XG4gICAgdGhpcy5fZXh0cmEgPSB7IC4uLnRoaXMuX2V4dHJhLCBba2V5XTogZXh0cmEgfTtcbiAgICB0aGlzLl9ub3RpZnlTY29wZUxpc3RlbmVycygpO1xuICAgIHJldHVybiB0aGlzO1xuICB9XG5cbiAgLyoqXG4gICAqIFNldHMgdGhlIGZpbmdlcnByaW50IG9uIHRoZSBzY29wZSB0byBzZW5kIHdpdGggdGhlIGV2ZW50cy5cbiAgICogQHBhcmFtIHtzdHJpbmdbXX0gZmluZ2VycHJpbnQgRmluZ2VycHJpbnQgdG8gZ3JvdXAgZXZlbnRzIGluIFNlbnRyeS5cbiAgICovXG4gICBzZXRGaW5nZXJwcmludChmaW5nZXJwcmludCkge1xuICAgIHRoaXMuX2ZpbmdlcnByaW50ID0gZmluZ2VycHJpbnQ7XG4gICAgdGhpcy5fbm90aWZ5U2NvcGVMaXN0ZW5lcnMoKTtcbiAgICByZXR1cm4gdGhpcztcbiAgfVxuXG4gIC8qKlxuICAgKiBTZXRzIHRoZSBsZXZlbCBvbiB0aGUgc2NvcGUgZm9yIGZ1dHVyZSBldmVudHMuXG4gICAqL1xuICAgc2V0TGV2ZWwobGV2ZWwpIHtcbiAgICB0aGlzLl9sZXZlbCA9IGxldmVsO1xuICAgIHRoaXMuX25vdGlmeVNjb3BlTGlzdGVuZXJzKCk7XG4gICAgcmV0dXJuIHRoaXM7XG4gIH1cblxuICAvKipcbiAgICogU2V0cyB0aGUgdHJhbnNhY3Rpb24gbmFtZSBvbiB0aGUgc2NvcGUgc28gdGhhdCB0aGUgbmFtZSBvZiBlLmcuIHRha2VuIHNlcnZlciByb3V0ZSBvclxuICAgKiB0aGUgcGFnZSBsb2NhdGlvbiBpcyBhdHRhY2hlZCB0byBmdXR1cmUgZXZlbnRzLlxuICAgKlxuICAgKiBJTVBPUlRBTlQ6IENhbGxpbmcgdGhpcyBmdW5jdGlvbiBkb2VzIE5PVCBjaGFuZ2UgdGhlIG5hbWUgb2YgdGhlIGN1cnJlbnRseSBhY3RpdmVcbiAgICogcm9vdCBzcGFuLiBJZiB5b3Ugd2FudCB0byBjaGFuZ2UgdGhlIG5hbWUgb2YgdGhlIGFjdGl2ZSByb290IHNwYW4sIHVzZVxuICAgKiBgU2VudHJ5LnVwZGF0ZVNwYW5OYW1lKHJvb3RTcGFuLCAnbmV3IG5hbWUnKWAgaW5zdGVhZC5cbiAgICpcbiAgICogQnkgZGVmYXVsdCwgdGhlIFNESyB1cGRhdGVzIHRoZSBzY29wZSdzIHRyYW5zYWN0aW9uIG5hbWUgYXV0b21hdGljYWxseSBvbiBzZW5zaWJsZVxuICAgKiBvY2Nhc2lvbnMsIHN1Y2ggYXMgYSBwYWdlIG5hdmlnYXRpb24gb3Igd2hlbiBoYW5kbGluZyBhIG5ldyByZXF1ZXN0IG9uIHRoZSBzZXJ2ZXIuXG4gICAqL1xuICAgc2V0VHJhbnNhY3Rpb25OYW1lKG5hbWUpIHtcbiAgICB0aGlzLl90cmFuc2FjdGlvbk5hbWUgPSBuYW1lO1xuICAgIHRoaXMuX25vdGlmeVNjb3BlTGlzdGVuZXJzKCk7XG4gICAgcmV0dXJuIHRoaXM7XG4gIH1cblxuICAvKipcbiAgICogU2V0cyBjb250ZXh0IGRhdGEgd2l0aCB0aGUgZ2l2ZW4gbmFtZS5cbiAgICogRGF0YSBwYXNzZWQgYXMgY29udGV4dCB3aWxsIGJlIG5vcm1hbGl6ZWQuIFlvdSBjYW4gYWxzbyBwYXNzIGBudWxsYCB0byB1bnNldCB0aGUgY29udGV4dC5cbiAgICogTm90ZSB0aGF0IGNvbnRleHQgZGF0YSB3aWxsIG5vdCBiZSBtZXJnZWQgLSBjYWxsaW5nIGBzZXRDb250ZXh0YCB3aWxsIG92ZXJ3cml0ZSBhbiBleGlzdGluZyBjb250ZXh0IHdpdGggdGhlIHNhbWUga2V5LlxuICAgKi9cbiAgIHNldENvbnRleHQoa2V5LCBjb250ZXh0KSB7XG4gICAgaWYgKGNvbnRleHQgPT09IG51bGwpIHtcbiAgICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tZHluYW1pYy1kZWxldGVcbiAgICAgIGRlbGV0ZSB0aGlzLl9jb250ZXh0c1trZXldO1xuICAgIH0gZWxzZSB7XG4gICAgICB0aGlzLl9jb250ZXh0c1trZXldID0gY29udGV4dDtcbiAgICB9XG5cbiAgICB0aGlzLl9ub3RpZnlTY29wZUxpc3RlbmVycygpO1xuICAgIHJldHVybiB0aGlzO1xuICB9XG5cbiAgLyoqXG4gICAqIFNldCB0aGUgc2Vzc2lvbiBmb3IgdGhlIHNjb3BlLlxuICAgKi9cbiAgIHNldFNlc3Npb24oc2Vzc2lvbikge1xuICAgIGlmICghc2Vzc2lvbikge1xuICAgICAgZGVsZXRlIHRoaXMuX3Nlc3Npb247XG4gICAgfSBlbHNlIHtcbiAgICAgIHRoaXMuX3Nlc3Npb24gPSBzZXNzaW9uO1xuICAgIH1cbiAgICB0aGlzLl9ub3RpZnlTY29wZUxpc3RlbmVycygpO1xuICAgIHJldHVybiB0aGlzO1xuICB9XG5cbiAgLyoqXG4gICAqIEdldCB0aGUgc2Vzc2lvbiBmcm9tIHRoZSBzY29wZS5cbiAgICovXG4gICBnZXRTZXNzaW9uKCkge1xuICAgIHJldHVybiB0aGlzLl9zZXNzaW9uO1xuICB9XG5cbiAgLyoqXG4gICAqIFVwZGF0ZXMgdGhlIHNjb3BlIHdpdGggcHJvdmlkZWQgZGF0YS4gQ2FuIHdvcmsgaW4gdGhyZWUgdmFyaWF0aW9uczpcbiAgICogLSBwbGFpbiBvYmplY3QgY29udGFpbmluZyB1cGRhdGFibGUgYXR0cmlidXRlc1xuICAgKiAtIFNjb3BlIGluc3RhbmNlIHRoYXQnbGwgZXh0cmFjdCB0aGUgYXR0cmlidXRlcyBmcm9tXG4gICAqIC0gY2FsbGJhY2sgZnVuY3Rpb24gdGhhdCdsbCByZWNlaXZlIHRoZSBjdXJyZW50IHNjb3BlIGFzIGFuIGFyZ3VtZW50IGFuZCBhbGxvdyBmb3IgbW9kaWZpY2F0aW9uc1xuICAgKi9cbiAgIHVwZGF0ZShjYXB0dXJlQ29udGV4dCkge1xuICAgIGlmICghY2FwdHVyZUNvbnRleHQpIHtcbiAgICAgIHJldHVybiB0aGlzO1xuICAgIH1cblxuICAgIGNvbnN0IHNjb3BlVG9NZXJnZSA9IHR5cGVvZiBjYXB0dXJlQ29udGV4dCA9PT0gJ2Z1bmN0aW9uJyA/IGNhcHR1cmVDb250ZXh0KHRoaXMpIDogY2FwdHVyZUNvbnRleHQ7XG5cbiAgICBjb25zdCBzY29wZUluc3RhbmNlID1cbiAgICAgIHNjb3BlVG9NZXJnZSBpbnN0YW5jZW9mIFNjb3BlXG4gICAgICAgID8gc2NvcGVUb01lcmdlLmdldFNjb3BlRGF0YSgpXG4gICAgICAgIDogaXMuaXNQbGFpbk9iamVjdChzY29wZVRvTWVyZ2UpXG4gICAgICAgICAgPyAoY2FwdHVyZUNvbnRleHQgKVxuICAgICAgICAgIDogdW5kZWZpbmVkO1xuXG4gICAgY29uc3QgeyB0YWdzLCBleHRyYSwgdXNlciwgY29udGV4dHMsIGxldmVsLCBmaW5nZXJwcmludCA9IFtdLCBwcm9wYWdhdGlvbkNvbnRleHQgfSA9IHNjb3BlSW5zdGFuY2UgfHwge307XG5cbiAgICB0aGlzLl90YWdzID0geyAuLi50aGlzLl90YWdzLCAuLi50YWdzIH07XG4gICAgdGhpcy5fZXh0cmEgPSB7IC4uLnRoaXMuX2V4dHJhLCAuLi5leHRyYSB9O1xuICAgIHRoaXMuX2NvbnRleHRzID0geyAuLi50aGlzLl9jb250ZXh0cywgLi4uY29udGV4dHMgfTtcblxuICAgIGlmICh1c2VyICYmIE9iamVjdC5rZXlzKHVzZXIpLmxlbmd0aCkge1xuICAgICAgdGhpcy5fdXNlciA9IHVzZXI7XG4gICAgfVxuXG4gICAgaWYgKGxldmVsKSB7XG4gICAgICB0aGlzLl9sZXZlbCA9IGxldmVsO1xuICAgIH1cblxuICAgIGlmIChmaW5nZXJwcmludC5sZW5ndGgpIHtcbiAgICAgIHRoaXMuX2ZpbmdlcnByaW50ID0gZmluZ2VycHJpbnQ7XG4gICAgfVxuXG4gICAgaWYgKHByb3BhZ2F0aW9uQ29udGV4dCkge1xuICAgICAgdGhpcy5fcHJvcGFnYXRpb25Db250ZXh0ID0gcHJvcGFnYXRpb25Db250ZXh0O1xuICAgIH1cblxuICAgIHJldHVybiB0aGlzO1xuICB9XG5cbiAgLyoqXG4gICAqIENsZWFycyB0aGUgY3VycmVudCBzY29wZSBhbmQgcmVzZXRzIGl0cyBwcm9wZXJ0aWVzLlxuICAgKiBOb3RlOiBUaGUgY2xpZW50IHdpbGwgbm90IGJlIGNsZWFyZWQuXG4gICAqL1xuICAgY2xlYXIoKSB7XG4gICAgLy8gY2xpZW50IGlzIG5vdCBjbGVhcmVkIGhlcmUgb24gcHVycG9zZSFcbiAgICB0aGlzLl9icmVhZGNydW1icyA9IFtdO1xuICAgIHRoaXMuX3RhZ3MgPSB7fTtcbiAgICB0aGlzLl9leHRyYSA9IHt9O1xuICAgIHRoaXMuX3VzZXIgPSB7fTtcbiAgICB0aGlzLl9jb250ZXh0cyA9IHt9O1xuICAgIHRoaXMuX2xldmVsID0gdW5kZWZpbmVkO1xuICAgIHRoaXMuX3RyYW5zYWN0aW9uTmFtZSA9IHVuZGVmaW5lZDtcbiAgICB0aGlzLl9maW5nZXJwcmludCA9IHVuZGVmaW5lZDtcbiAgICB0aGlzLl9zZXNzaW9uID0gdW5kZWZpbmVkO1xuICAgIHNwYW5PblNjb3BlLl9zZXRTcGFuRm9yU2NvcGUodGhpcywgdW5kZWZpbmVkKTtcbiAgICB0aGlzLl9hdHRhY2htZW50cyA9IFtdO1xuICAgIHRoaXMuc2V0UHJvcGFnYXRpb25Db250ZXh0KHsgdHJhY2VJZDogcHJvcGFnYXRpb25Db250ZXh0LmdlbmVyYXRlVHJhY2VJZCgpLCBzYW1wbGVSYW5kOiBNYXRoLnJhbmRvbSgpIH0pO1xuXG4gICAgdGhpcy5fbm90aWZ5U2NvcGVMaXN0ZW5lcnMoKTtcbiAgICByZXR1cm4gdGhpcztcbiAgfVxuXG4gIC8qKlxuICAgKiBBZGRzIGEgYnJlYWRjcnVtYiB0byB0aGUgc2NvcGUuXG4gICAqIEJ5IGRlZmF1bHQsIHRoZSBsYXN0IDEwMCBicmVhZGNydW1icyBhcmUga2VwdC5cbiAgICovXG4gICBhZGRCcmVhZGNydW1iKGJyZWFkY3J1bWIsIG1heEJyZWFkY3J1bWJzKSB7XG4gICAgY29uc3QgbWF4Q3J1bWJzID0gdHlwZW9mIG1heEJyZWFkY3J1bWJzID09PSAnbnVtYmVyJyA/IG1heEJyZWFkY3J1bWJzIDogREVGQVVMVF9NQVhfQlJFQURDUlVNQlM7XG5cbiAgICAvLyBObyBkYXRhIGhhcyBiZWVuIGNoYW5nZWQsIHNvIGRvbid0IG5vdGlmeSBzY29wZSBsaXN0ZW5lcnNcbiAgICBpZiAobWF4Q3J1bWJzIDw9IDApIHtcbiAgICAgIHJldHVybiB0aGlzO1xuICAgIH1cblxuICAgIGNvbnN0IG1lcmdlZEJyZWFkY3J1bWIgPSB7XG4gICAgICB0aW1lc3RhbXA6IHRpbWUuZGF0ZVRpbWVzdGFtcEluU2Vjb25kcygpLFxuICAgICAgLi4uYnJlYWRjcnVtYixcbiAgICAgIC8vIEJyZWFkY3J1bWIgbWVzc2FnZXMgY2FuIHRoZW9yZXRpY2FsbHkgYmUgaW5maW5pdGVseSBsYXJnZSBhbmQgdGhleSdyZSBoZWxkIGluIG1lbW9yeSBzbyB3ZSB0cnVuY2F0ZSB0aGVtIG5vdCB0byBsZWFrICh0b28gbXVjaCkgbWVtb3J5XG4gICAgICBtZXNzYWdlOiBicmVhZGNydW1iLm1lc3NhZ2UgPyBzdHJpbmcudHJ1bmNhdGUoYnJlYWRjcnVtYi5tZXNzYWdlLCAyMDQ4KSA6IGJyZWFkY3J1bWIubWVzc2FnZSxcbiAgICB9O1xuXG4gICAgdGhpcy5fYnJlYWRjcnVtYnMucHVzaChtZXJnZWRCcmVhZGNydW1iKTtcbiAgICBpZiAodGhpcy5fYnJlYWRjcnVtYnMubGVuZ3RoID4gbWF4Q3J1bWJzKSB7XG4gICAgICB0aGlzLl9icmVhZGNydW1icyA9IHRoaXMuX2JyZWFkY3J1bWJzLnNsaWNlKC1tYXhDcnVtYnMpO1xuICAgICAgdGhpcy5fY2xpZW50Py5yZWNvcmREcm9wcGVkRXZlbnQoJ2J1ZmZlcl9vdmVyZmxvdycsICdsb2dfaXRlbScpO1xuICAgIH1cblxuICAgIHRoaXMuX25vdGlmeVNjb3BlTGlzdGVuZXJzKCk7XG5cbiAgICByZXR1cm4gdGhpcztcbiAgfVxuXG4gIC8qKlxuICAgKiBHZXQgdGhlIGxhc3QgYnJlYWRjcnVtYiBvZiB0aGUgc2NvcGUuXG4gICAqL1xuICAgZ2V0TGFzdEJyZWFkY3J1bWIoKSB7XG4gICAgcmV0dXJuIHRoaXMuX2JyZWFkY3J1bWJzW3RoaXMuX2JyZWFkY3J1bWJzLmxlbmd0aCAtIDFdO1xuICB9XG5cbiAgLyoqXG4gICAqIENsZWFyIGFsbCBicmVhZGNydW1icyBmcm9tIHRoZSBzY29wZS5cbiAgICovXG4gICBjbGVhckJyZWFkY3J1bWJzKCkge1xuICAgIHRoaXMuX2JyZWFkY3J1bWJzID0gW107XG4gICAgdGhpcy5fbm90aWZ5U2NvcGVMaXN0ZW5lcnMoKTtcbiAgICByZXR1cm4gdGhpcztcbiAgfVxuXG4gIC8qKlxuICAgKiBBZGQgYW4gYXR0YWNobWVudCB0byB0aGUgc2NvcGUuXG4gICAqL1xuICAgYWRkQXR0YWNobWVudChhdHRhY2htZW50KSB7XG4gICAgdGhpcy5fYXR0YWNobWVudHMucHVzaChhdHRhY2htZW50KTtcbiAgICByZXR1cm4gdGhpcztcbiAgfVxuXG4gIC8qKlxuICAgKiBDbGVhciBhbGwgYXR0YWNobWVudHMgZnJvbSB0aGUgc2NvcGUuXG4gICAqL1xuICAgY2xlYXJBdHRhY2htZW50cygpIHtcbiAgICB0aGlzLl9hdHRhY2htZW50cyA9IFtdO1xuICAgIHJldHVybiB0aGlzO1xuICB9XG5cbiAgLyoqXG4gICAqIEdldCB0aGUgZGF0YSBvZiB0aGlzIHNjb3BlLCB3aGljaCBzaG91bGQgYmUgYXBwbGllZCB0byBhbiBldmVudCBkdXJpbmcgcHJvY2Vzc2luZy5cbiAgICovXG4gICBnZXRTY29wZURhdGEoKSB7XG4gICAgcmV0dXJuIHtcbiAgICAgIGJyZWFkY3J1bWJzOiB0aGlzLl9icmVhZGNydW1icyxcbiAgICAgIGF0dGFjaG1lbnRzOiB0aGlzLl9hdHRhY2htZW50cyxcbiAgICAgIGNvbnRleHRzOiB0aGlzLl9jb250ZXh0cyxcbiAgICAgIHRhZ3M6IHRoaXMuX3RhZ3MsXG4gICAgICBleHRyYTogdGhpcy5fZXh0cmEsXG4gICAgICB1c2VyOiB0aGlzLl91c2VyLFxuICAgICAgbGV2ZWw6IHRoaXMuX2xldmVsLFxuICAgICAgZmluZ2VycHJpbnQ6IHRoaXMuX2ZpbmdlcnByaW50IHx8IFtdLFxuICAgICAgZXZlbnRQcm9jZXNzb3JzOiB0aGlzLl9ldmVudFByb2Nlc3NvcnMsXG4gICAgICBwcm9wYWdhdGlvbkNvbnRleHQ6IHRoaXMuX3Byb3BhZ2F0aW9uQ29udGV4dCxcbiAgICAgIHNka1Byb2Nlc3NpbmdNZXRhZGF0YTogdGhpcy5fc2RrUHJvY2Vzc2luZ01ldGFkYXRhLFxuICAgICAgdHJhbnNhY3Rpb25OYW1lOiB0aGlzLl90cmFuc2FjdGlvbk5hbWUsXG4gICAgICBzcGFuOiBzcGFuT25TY29wZS5fZ2V0U3BhbkZvclNjb3BlKHRoaXMpLFxuICAgIH07XG4gIH1cblxuICAvKipcbiAgICogQWRkIGRhdGEgd2hpY2ggd2lsbCBiZSBhY2Nlc3NpYmxlIGR1cmluZyBldmVudCBwcm9jZXNzaW5nIGJ1dCB3b24ndCBnZXQgc2VudCB0byBTZW50cnkuXG4gICAqL1xuICAgc2V0U0RLUHJvY2Vzc2luZ01ldGFkYXRhKG5ld0RhdGEpIHtcbiAgICB0aGlzLl9zZGtQcm9jZXNzaW5nTWV0YWRhdGEgPSBtZXJnZS5tZXJnZSh0aGlzLl9zZGtQcm9jZXNzaW5nTWV0YWRhdGEsIG5ld0RhdGEsIDIpO1xuICAgIHJldHVybiB0aGlzO1xuICB9XG5cbiAgLyoqXG4gICAqIEFkZCBwcm9wYWdhdGlvbiBjb250ZXh0IHRvIHRoZSBzY29wZSwgdXNlZCBmb3IgZGlzdHJpYnV0ZWQgdHJhY2luZ1xuICAgKi9cbiAgIHNldFByb3BhZ2F0aW9uQ29udGV4dChjb250ZXh0KSB7XG4gICAgdGhpcy5fcHJvcGFnYXRpb25Db250ZXh0ID0gY29udGV4dDtcbiAgICByZXR1cm4gdGhpcztcbiAgfVxuXG4gIC8qKlxuICAgKiBHZXQgcHJvcGFnYXRpb24gY29udGV4dCBmcm9tIHRoZSBzY29wZSwgdXNlZCBmb3IgZGlzdHJpYnV0ZWQgdHJhY2luZ1xuICAgKi9cbiAgIGdldFByb3BhZ2F0aW9uQ29udGV4dCgpIHtcbiAgICByZXR1cm4gdGhpcy5fcHJvcGFnYXRpb25Db250ZXh0O1xuICB9XG5cbiAgLyoqXG4gICAqIENhcHR1cmUgYW4gZXhjZXB0aW9uIGZvciB0aGlzIHNjb3BlLlxuICAgKlxuICAgKiBAcmV0dXJucyB7c3RyaW5nfSBUaGUgaWQgb2YgdGhlIGNhcHR1cmVkIFNlbnRyeSBldmVudC5cbiAgICovXG4gICBjYXB0dXJlRXhjZXB0aW9uKGV4Y2VwdGlvbiwgaGludCkge1xuICAgIGNvbnN0IGV2ZW50SWQgPSBoaW50Py5ldmVudF9pZCB8fCBtaXNjLnV1aWQ0KCk7XG5cbiAgICBpZiAoIXRoaXMuX2NsaWVudCkge1xuICAgICAgZGVidWdCdWlsZC5ERUJVR19CVUlMRCAmJiBkZWJ1Z0xvZ2dlci5kZWJ1Zy53YXJuKCdObyBjbGllbnQgY29uZmlndXJlZCBvbiBzY29wZSAtIHdpbGwgbm90IGNhcHR1cmUgZXhjZXB0aW9uIScpO1xuICAgICAgcmV0dXJuIGV2ZW50SWQ7XG4gICAgfVxuXG4gICAgY29uc3Qgc3ludGhldGljRXhjZXB0aW9uID0gbmV3IEVycm9yKCdTZW50cnkgc3ludGhldGljRXhjZXB0aW9uJyk7XG5cbiAgICB0aGlzLl9jbGllbnQuY2FwdHVyZUV4Y2VwdGlvbihcbiAgICAgIGV4Y2VwdGlvbixcbiAgICAgIHtcbiAgICAgICAgb3JpZ2luYWxFeGNlcHRpb246IGV4Y2VwdGlvbixcbiAgICAgICAgc3ludGhldGljRXhjZXB0aW9uLFxuICAgICAgICAuLi5oaW50LFxuICAgICAgICBldmVudF9pZDogZXZlbnRJZCxcbiAgICAgIH0sXG4gICAgICB0aGlzLFxuICAgICk7XG5cbiAgICByZXR1cm4gZXZlbnRJZDtcbiAgfVxuXG4gIC8qKlxuICAgKiBDYXB0dXJlIGEgbWVzc2FnZSBmb3IgdGhpcyBzY29wZS5cbiAgICpcbiAgICogQHJldHVybnMge3N0cmluZ30gVGhlIGlkIG9mIHRoZSBjYXB0dXJlZCBtZXNzYWdlLlxuICAgKi9cbiAgIGNhcHR1cmVNZXNzYWdlKG1lc3NhZ2UsIGxldmVsLCBoaW50KSB7XG4gICAgY29uc3QgZXZlbnRJZCA9IGhpbnQ/LmV2ZW50X2lkIHx8IG1pc2MudXVpZDQoKTtcblxuICAgIGlmICghdGhpcy5fY2xpZW50KSB7XG4gICAgICBkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEICYmIGRlYnVnTG9nZ2VyLmRlYnVnLndhcm4oJ05vIGNsaWVudCBjb25maWd1cmVkIG9uIHNjb3BlIC0gd2lsbCBub3QgY2FwdHVyZSBtZXNzYWdlIScpO1xuICAgICAgcmV0dXJuIGV2ZW50SWQ7XG4gICAgfVxuXG4gICAgY29uc3Qgc3ludGhldGljRXhjZXB0aW9uID0gbmV3IEVycm9yKG1lc3NhZ2UpO1xuXG4gICAgdGhpcy5fY2xpZW50LmNhcHR1cmVNZXNzYWdlKFxuICAgICAgbWVzc2FnZSxcbiAgICAgIGxldmVsLFxuICAgICAge1xuICAgICAgICBvcmlnaW5hbEV4Y2VwdGlvbjogbWVzc2FnZSxcbiAgICAgICAgc3ludGhldGljRXhjZXB0aW9uLFxuICAgICAgICAuLi5oaW50LFxuICAgICAgICBldmVudF9pZDogZXZlbnRJZCxcbiAgICAgIH0sXG4gICAgICB0aGlzLFxuICAgICk7XG5cbiAgICByZXR1cm4gZXZlbnRJZDtcbiAgfVxuXG4gIC8qKlxuICAgKiBDYXB0dXJlIGEgU2VudHJ5IGV2ZW50IGZvciB0aGlzIHNjb3BlLlxuICAgKlxuICAgKiBAcmV0dXJucyB7c3RyaW5nfSBUaGUgaWQgb2YgdGhlIGNhcHR1cmVkIGV2ZW50LlxuICAgKi9cbiAgIGNhcHR1cmVFdmVudChldmVudCwgaGludCkge1xuICAgIGNvbnN0IGV2ZW50SWQgPSBoaW50Py5ldmVudF9pZCB8fCBtaXNjLnV1aWQ0KCk7XG5cbiAgICBpZiAoIXRoaXMuX2NsaWVudCkge1xuICAgICAgZGVidWdCdWlsZC5ERUJVR19CVUlMRCAmJiBkZWJ1Z0xvZ2dlci5kZWJ1Zy53YXJuKCdObyBjbGllbnQgY29uZmlndXJlZCBvbiBzY29wZSAtIHdpbGwgbm90IGNhcHR1cmUgZXZlbnQhJyk7XG4gICAgICByZXR1cm4gZXZlbnRJZDtcbiAgICB9XG5cbiAgICB0aGlzLl9jbGllbnQuY2FwdHVyZUV2ZW50KGV2ZW50LCB7IC4uLmhpbnQsIGV2ZW50X2lkOiBldmVudElkIH0sIHRoaXMpO1xuXG4gICAgcmV0dXJuIGV2ZW50SWQ7XG4gIH1cblxuICAvKipcbiAgICogVGhpcyB3aWxsIGJlIGNhbGxlZCBvbiBldmVyeSBzZXQgY2FsbC5cbiAgICovXG4gICBfbm90aWZ5U2NvcGVMaXN0ZW5lcnMoKSB7XG4gICAgLy8gV2UgbmVlZCB0aGlzIGNoZWNrIGZvciB0aGlzLl9ub3RpZnlpbmdMaXN0ZW5lcnMgdG8gYmUgYWJsZSB0byB3b3JrIG9uIHNjb3BlIGR1cmluZyB1cGRhdGVzXG4gICAgLy8gSWYgdGhpcyBjaGVjayBpcyBub3QgaGVyZSB3ZSdsbCBwcm9kdWNlIGVuZGxlc3MgcmVjdXJzaW9uIHdoZW4gc29tZXRoaW5nIGlzIGRvbmUgd2l0aCB0aGUgc2NvcGVcbiAgICAvLyBkdXJpbmcgdGhlIGNhbGxiYWNrLlxuICAgIGlmICghdGhpcy5fbm90aWZ5aW5nTGlzdGVuZXJzKSB7XG4gICAgICB0aGlzLl9ub3RpZnlpbmdMaXN0ZW5lcnMgPSB0cnVlO1xuICAgICAgdGhpcy5fc2NvcGVMaXN0ZW5lcnMuZm9yRWFjaChjYWxsYmFjayA9PiB7XG4gICAgICAgIGNhbGxiYWNrKHRoaXMpO1xuICAgICAgfSk7XG4gICAgICB0aGlzLl9ub3RpZnlpbmdMaXN0ZW5lcnMgPSBmYWxzZTtcbiAgICB9XG4gIH1cbn1cblxuZXhwb3J0cy5TY29wZSA9IFNjb3BlO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9c2NvcGUuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/scope.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/sdk.js":
/*!*******************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/sdk.js ***!
  \*******************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst currentScopes = __webpack_require__(/*! ./currentScopes.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst debugBuild = __webpack_require__(/*! ./debug-build.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst debugLogger = __webpack_require__(/*! ./utils/debug-logger.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\n\n/** A class object that can instantiate Client objects. */\n\n/**\n * Internal function to create a new SDK client instance. The client is\n * installed and then bound to the current scope.\n *\n * @param clientClass The client class to instantiate.\n * @param options Options to pass to the client.\n */\nfunction initAndBind(\n  clientClass,\n  options,\n) {\n  if (options.debug === true) {\n    if (debugBuild.DEBUG_BUILD) {\n      debugLogger.debug.enable();\n    } else {\n      // use `console.warn` rather than `debug.warn` since by non-debug bundles have all `debug.x` statements stripped\n      debugLogger.consoleSandbox(() => {\n        // eslint-disable-next-line no-console\n        console.warn('[Sentry] Cannot initialize SDK with `debug` option using a non-debug bundle.');\n      });\n    }\n  }\n  const scope = currentScopes.getCurrentScope();\n  scope.update(options.initialScope);\n\n  const client = new clientClass(options);\n  setCurrentClient(client);\n  client.init();\n  return client;\n}\n\n/**\n * Make the given client the current client.\n */\nfunction setCurrentClient(client) {\n  currentScopes.getCurrentScope().setClient(client);\n}\n\nexports.initAndBind = initAndBind;\nexports.setCurrentClient = setCurrentClient;\n//# sourceMappingURL=sdk.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9zZGsuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsc0JBQXNCLG1CQUFPLENBQUMsK0hBQW9CO0FBQ2xELG1CQUFtQixtQkFBTyxDQUFDLDJIQUFrQjtBQUM3QyxvQkFBb0IsbUJBQU8sQ0FBQyx5SUFBeUI7O0FBRXJEOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxNQUFNO0FBQ047QUFDQTtBQUNBO0FBQ0E7QUFDQSxPQUFPO0FBQ1A7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsbUJBQW1CO0FBQ25CLHdCQUF3QjtBQUN4QiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3Nkay5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgY3VycmVudFNjb3BlcyA9IHJlcXVpcmUoJy4vY3VycmVudFNjb3Blcy5qcycpO1xuY29uc3QgZGVidWdCdWlsZCA9IHJlcXVpcmUoJy4vZGVidWctYnVpbGQuanMnKTtcbmNvbnN0IGRlYnVnTG9nZ2VyID0gcmVxdWlyZSgnLi91dGlscy9kZWJ1Zy1sb2dnZXIuanMnKTtcblxuLyoqIEEgY2xhc3Mgb2JqZWN0IHRoYXQgY2FuIGluc3RhbnRpYXRlIENsaWVudCBvYmplY3RzLiAqL1xuXG4vKipcbiAqIEludGVybmFsIGZ1bmN0aW9uIHRvIGNyZWF0ZSBhIG5ldyBTREsgY2xpZW50IGluc3RhbmNlLiBUaGUgY2xpZW50IGlzXG4gKiBpbnN0YWxsZWQgYW5kIHRoZW4gYm91bmQgdG8gdGhlIGN1cnJlbnQgc2NvcGUuXG4gKlxuICogQHBhcmFtIGNsaWVudENsYXNzIFRoZSBjbGllbnQgY2xhc3MgdG8gaW5zdGFudGlhdGUuXG4gKiBAcGFyYW0gb3B0aW9ucyBPcHRpb25zIHRvIHBhc3MgdG8gdGhlIGNsaWVudC5cbiAqL1xuZnVuY3Rpb24gaW5pdEFuZEJpbmQoXG4gIGNsaWVudENsYXNzLFxuICBvcHRpb25zLFxuKSB7XG4gIGlmIChvcHRpb25zLmRlYnVnID09PSB0cnVlKSB7XG4gICAgaWYgKGRlYnVnQnVpbGQuREVCVUdfQlVJTEQpIHtcbiAgICAgIGRlYnVnTG9nZ2VyLmRlYnVnLmVuYWJsZSgpO1xuICAgIH0gZWxzZSB7XG4gICAgICAvLyB1c2UgYGNvbnNvbGUud2FybmAgcmF0aGVyIHRoYW4gYGRlYnVnLndhcm5gIHNpbmNlIGJ5IG5vbi1kZWJ1ZyBidW5kbGVzIGhhdmUgYWxsIGBkZWJ1Zy54YCBzdGF0ZW1lbnRzIHN0cmlwcGVkXG4gICAgICBkZWJ1Z0xvZ2dlci5jb25zb2xlU2FuZGJveCgoKSA9PiB7XG4gICAgICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBuby1jb25zb2xlXG4gICAgICAgIGNvbnNvbGUud2FybignW1NlbnRyeV0gQ2Fubm90IGluaXRpYWxpemUgU0RLIHdpdGggYGRlYnVnYCBvcHRpb24gdXNpbmcgYSBub24tZGVidWcgYnVuZGxlLicpO1xuICAgICAgfSk7XG4gICAgfVxuICB9XG4gIGNvbnN0IHNjb3BlID0gY3VycmVudFNjb3Blcy5nZXRDdXJyZW50U2NvcGUoKTtcbiAgc2NvcGUudXBkYXRlKG9wdGlvbnMuaW5pdGlhbFNjb3BlKTtcblxuICBjb25zdCBjbGllbnQgPSBuZXcgY2xpZW50Q2xhc3Mob3B0aW9ucyk7XG4gIHNldEN1cnJlbnRDbGllbnQoY2xpZW50KTtcbiAgY2xpZW50LmluaXQoKTtcbiAgcmV0dXJuIGNsaWVudDtcbn1cblxuLyoqXG4gKiBNYWtlIHRoZSBnaXZlbiBjbGllbnQgdGhlIGN1cnJlbnQgY2xpZW50LlxuICovXG5mdW5jdGlvbiBzZXRDdXJyZW50Q2xpZW50KGNsaWVudCkge1xuICBjdXJyZW50U2NvcGVzLmdldEN1cnJlbnRTY29wZSgpLnNldENsaWVudChjbGllbnQpO1xufVxuXG5leHBvcnRzLmluaXRBbmRCaW5kID0gaW5pdEFuZEJpbmQ7XG5leHBvcnRzLnNldEN1cnJlbnRDbGllbnQgPSBzZXRDdXJyZW50Q2xpZW50O1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9c2RrLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/sdk.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/semanticAttributes.js":
/*!**********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/semanticAttributes.js ***!
  \**********************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n/**\n * Use this attribute to represent the source of a span.\n * Should be one of: custom, url, route, view, component, task, unknown\n *\n */\nconst SEMANTIC_ATTRIBUTE_SENTRY_SOURCE = 'sentry.source';\n\n/**\n * Attributes that holds the sample rate that was locally applied to a span.\n * If this attribute is not defined, it means that the span inherited a sampling decision.\n *\n * NOTE: Is only defined on root spans.\n */\nconst SEMANTIC_ATTRIBUTE_SENTRY_SAMPLE_RATE = 'sentry.sample_rate';\n\n/**\n * Attribute holding the sample rate of the previous trace.\n * This is used to sample consistently across subsequent traces in the browser SDK.\n *\n * Note: Only defined on root spans, if opted into consistent sampling\n */\nconst SEMANTIC_ATTRIBUTE_SENTRY_PREVIOUS_TRACE_SAMPLE_RATE = 'sentry.previous_trace_sample_rate';\n\n/**\n * Use this attribute to represent the operation of a span.\n */\nconst SEMANTIC_ATTRIBUTE_SENTRY_OP = 'sentry.op';\n\n/**\n * Use this attribute to represent the origin of a span.\n */\nconst SEMANTIC_ATTRIBUTE_SENTRY_ORIGIN = 'sentry.origin';\n\n/** The reason why an idle span finished. */\nconst SEMANTIC_ATTRIBUTE_SENTRY_IDLE_SPAN_FINISH_REASON = 'sentry.idle_span_finish_reason';\n\n/** The unit of a measurement, which may be stored as a TimedEvent. */\nconst SEMANTIC_ATTRIBUTE_SENTRY_MEASUREMENT_UNIT = 'sentry.measurement_unit';\n\n/** The value of a measurement, which may be stored as a TimedEvent. */\nconst SEMANTIC_ATTRIBUTE_SENTRY_MEASUREMENT_VALUE = 'sentry.measurement_value';\n\n/**\n * A custom span name set by users guaranteed to be taken over any automatically\n * inferred name. This attribute is removed before the span is sent.\n *\n * @internal only meant for internal SDK usage\n * @hidden\n */\nconst SEMANTIC_ATTRIBUTE_SENTRY_CUSTOM_SPAN_NAME = 'sentry.custom_span_name';\n\n/**\n * The id of the profile that this span occurred in.\n */\nconst SEMANTIC_ATTRIBUTE_PROFILE_ID = 'sentry.profile_id';\n\nconst SEMANTIC_ATTRIBUTE_EXCLUSIVE_TIME = 'sentry.exclusive_time';\n\nconst SEMANTIC_ATTRIBUTE_CACHE_HIT = 'cache.hit';\n\nconst SEMANTIC_ATTRIBUTE_CACHE_KEY = 'cache.key';\n\nconst SEMANTIC_ATTRIBUTE_CACHE_ITEM_SIZE = 'cache.item_size';\n\n/** TODO: Remove these once we update to latest semantic conventions */\nconst SEMANTIC_ATTRIBUTE_HTTP_REQUEST_METHOD = 'http.request.method';\nconst SEMANTIC_ATTRIBUTE_URL_FULL = 'url.full';\n\n/**\n * A span link attribute to mark the link as a special span link.\n *\n * Known values:\n * - `previous_trace`: The span links to the frontend root span of the previous trace.\n * - `next_trace`: The span links to the frontend root span of the next trace. (Not set by the SDK)\n *\n * Other values may be set as appropriate.\n * @see https://develop.sentry.dev/sdk/telemetry/traces/span-links/#link-types\n */\nconst SEMANTIC_LINK_ATTRIBUTE_LINK_TYPE = 'sentry.link.type';\n\nexports.SEMANTIC_ATTRIBUTE_CACHE_HIT = SEMANTIC_ATTRIBUTE_CACHE_HIT;\nexports.SEMANTIC_ATTRIBUTE_CACHE_ITEM_SIZE = SEMANTIC_ATTRIBUTE_CACHE_ITEM_SIZE;\nexports.SEMANTIC_ATTRIBUTE_CACHE_KEY = SEMANTIC_ATTRIBUTE_CACHE_KEY;\nexports.SEMANTIC_ATTRIBUTE_EXCLUSIVE_TIME = SEMANTIC_ATTRIBUTE_EXCLUSIVE_TIME;\nexports.SEMANTIC_ATTRIBUTE_HTTP_REQUEST_METHOD = SEMANTIC_ATTRIBUTE_HTTP_REQUEST_METHOD;\nexports.SEMANTIC_ATTRIBUTE_PROFILE_ID = SEMANTIC_ATTRIBUTE_PROFILE_ID;\nexports.SEMANTIC_ATTRIBUTE_SENTRY_CUSTOM_SPAN_NAME = SEMANTIC_ATTRIBUTE_SENTRY_CUSTOM_SPAN_NAME;\nexports.SEMANTIC_ATTRIBUTE_SENTRY_IDLE_SPAN_FINISH_REASON = SEMANTIC_ATTRIBUTE_SENTRY_IDLE_SPAN_FINISH_REASON;\nexports.SEMANTIC_ATTRIBUTE_SENTRY_MEASUREMENT_UNIT = SEMANTIC_ATTRIBUTE_SENTRY_MEASUREMENT_UNIT;\nexports.SEMANTIC_ATTRIBUTE_SENTRY_MEASUREMENT_VALUE = SEMANTIC_ATTRIBUTE_SENTRY_MEASUREMENT_VALUE;\nexports.SEMANTIC_ATTRIBUTE_SENTRY_OP = SEMANTIC_ATTRIBUTE_SENTRY_OP;\nexports.SEMANTIC_ATTRIBUTE_SENTRY_ORIGIN = SEMANTIC_ATTRIBUTE_SENTRY_ORIGIN;\nexports.SEMANTIC_ATTRIBUTE_SENTRY_PREVIOUS_TRACE_SAMPLE_RATE = SEMANTIC_ATTRIBUTE_SENTRY_PREVIOUS_TRACE_SAMPLE_RATE;\nexports.SEMANTIC_ATTRIBUTE_SENTRY_SAMPLE_RATE = SEMANTIC_ATTRIBUTE_SENTRY_SAMPLE_RATE;\nexports.SEMANTIC_ATTRIBUTE_SENTRY_SOURCE = SEMANTIC_ATTRIBUTE_SENTRY_SOURCE;\nexports.SEMANTIC_ATTRIBUTE_URL_FULL = SEMANTIC_ATTRIBUTE_URL_FULL;\nexports.SEMANTIC_LINK_ATTRIBUTE_LINK_TYPE = SEMANTIC_LINK_ATTRIBUTE_LINK_TYPE;\n//# sourceMappingURL=semanticAttributes.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9zZW1hbnRpY0F0dHJpYnV0ZXMuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEU7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7O0FBRUE7O0FBRUE7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsb0NBQW9DO0FBQ3BDLDBDQUEwQztBQUMxQyxvQ0FBb0M7QUFDcEMseUNBQXlDO0FBQ3pDLDhDQUE4QztBQUM5QyxxQ0FBcUM7QUFDckMsa0RBQWtEO0FBQ2xELHlEQUF5RDtBQUN6RCxrREFBa0Q7QUFDbEQsbURBQW1EO0FBQ25ELG9DQUFvQztBQUNwQyx3Q0FBd0M7QUFDeEMsNERBQTREO0FBQzVELDZDQUE2QztBQUM3Qyx3Q0FBd0M7QUFDeEMsbUNBQW1DO0FBQ25DLHlDQUF5QztBQUN6QyIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3NlbWFudGljQXR0cmlidXRlcy5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuLyoqXG4gKiBVc2UgdGhpcyBhdHRyaWJ1dGUgdG8gcmVwcmVzZW50IHRoZSBzb3VyY2Ugb2YgYSBzcGFuLlxuICogU2hvdWxkIGJlIG9uZSBvZjogY3VzdG9tLCB1cmwsIHJvdXRlLCB2aWV3LCBjb21wb25lbnQsIHRhc2ssIHVua25vd25cbiAqXG4gKi9cbmNvbnN0IFNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfU09VUkNFID0gJ3NlbnRyeS5zb3VyY2UnO1xuXG4vKipcbiAqIEF0dHJpYnV0ZXMgdGhhdCBob2xkcyB0aGUgc2FtcGxlIHJhdGUgdGhhdCB3YXMgbG9jYWxseSBhcHBsaWVkIHRvIGEgc3Bhbi5cbiAqIElmIHRoaXMgYXR0cmlidXRlIGlzIG5vdCBkZWZpbmVkLCBpdCBtZWFucyB0aGF0IHRoZSBzcGFuIGluaGVyaXRlZCBhIHNhbXBsaW5nIGRlY2lzaW9uLlxuICpcbiAqIE5PVEU6IElzIG9ubHkgZGVmaW5lZCBvbiByb290IHNwYW5zLlxuICovXG5jb25zdCBTRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX1NBTVBMRV9SQVRFID0gJ3NlbnRyeS5zYW1wbGVfcmF0ZSc7XG5cbi8qKlxuICogQXR0cmlidXRlIGhvbGRpbmcgdGhlIHNhbXBsZSByYXRlIG9mIHRoZSBwcmV2aW91cyB0cmFjZS5cbiAqIFRoaXMgaXMgdXNlZCB0byBzYW1wbGUgY29uc2lzdGVudGx5IGFjcm9zcyBzdWJzZXF1ZW50IHRyYWNlcyBpbiB0aGUgYnJvd3NlciBTREsuXG4gKlxuICogTm90ZTogT25seSBkZWZpbmVkIG9uIHJvb3Qgc3BhbnMsIGlmIG9wdGVkIGludG8gY29uc2lzdGVudCBzYW1wbGluZ1xuICovXG5jb25zdCBTRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX1BSRVZJT1VTX1RSQUNFX1NBTVBMRV9SQVRFID0gJ3NlbnRyeS5wcmV2aW91c190cmFjZV9zYW1wbGVfcmF0ZSc7XG5cbi8qKlxuICogVXNlIHRoaXMgYXR0cmlidXRlIHRvIHJlcHJlc2VudCB0aGUgb3BlcmF0aW9uIG9mIGEgc3Bhbi5cbiAqL1xuY29uc3QgU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9PUCA9ICdzZW50cnkub3AnO1xuXG4vKipcbiAqIFVzZSB0aGlzIGF0dHJpYnV0ZSB0byByZXByZXNlbnQgdGhlIG9yaWdpbiBvZiBhIHNwYW4uXG4gKi9cbmNvbnN0IFNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfT1JJR0lOID0gJ3NlbnRyeS5vcmlnaW4nO1xuXG4vKiogVGhlIHJlYXNvbiB3aHkgYW4gaWRsZSBzcGFuIGZpbmlzaGVkLiAqL1xuY29uc3QgU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9JRExFX1NQQU5fRklOSVNIX1JFQVNPTiA9ICdzZW50cnkuaWRsZV9zcGFuX2ZpbmlzaF9yZWFzb24nO1xuXG4vKiogVGhlIHVuaXQgb2YgYSBtZWFzdXJlbWVudCwgd2hpY2ggbWF5IGJlIHN0b3JlZCBhcyBhIFRpbWVkRXZlbnQuICovXG5jb25zdCBTRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX01FQVNVUkVNRU5UX1VOSVQgPSAnc2VudHJ5Lm1lYXN1cmVtZW50X3VuaXQnO1xuXG4vKiogVGhlIHZhbHVlIG9mIGEgbWVhc3VyZW1lbnQsIHdoaWNoIG1heSBiZSBzdG9yZWQgYXMgYSBUaW1lZEV2ZW50LiAqL1xuY29uc3QgU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9NRUFTVVJFTUVOVF9WQUxVRSA9ICdzZW50cnkubWVhc3VyZW1lbnRfdmFsdWUnO1xuXG4vKipcbiAqIEEgY3VzdG9tIHNwYW4gbmFtZSBzZXQgYnkgdXNlcnMgZ3VhcmFudGVlZCB0byBiZSB0YWtlbiBvdmVyIGFueSBhdXRvbWF0aWNhbGx5XG4gKiBpbmZlcnJlZCBuYW1lLiBUaGlzIGF0dHJpYnV0ZSBpcyByZW1vdmVkIGJlZm9yZSB0aGUgc3BhbiBpcyBzZW50LlxuICpcbiAqIEBpbnRlcm5hbCBvbmx5IG1lYW50IGZvciBpbnRlcm5hbCBTREsgdXNhZ2VcbiAqIEBoaWRkZW5cbiAqL1xuY29uc3QgU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9DVVNUT01fU1BBTl9OQU1FID0gJ3NlbnRyeS5jdXN0b21fc3Bhbl9uYW1lJztcblxuLyoqXG4gKiBUaGUgaWQgb2YgdGhlIHByb2ZpbGUgdGhhdCB0aGlzIHNwYW4gb2NjdXJyZWQgaW4uXG4gKi9cbmNvbnN0IFNFTUFOVElDX0FUVFJJQlVURV9QUk9GSUxFX0lEID0gJ3NlbnRyeS5wcm9maWxlX2lkJztcblxuY29uc3QgU0VNQU5USUNfQVRUUklCVVRFX0VYQ0xVU0lWRV9USU1FID0gJ3NlbnRyeS5leGNsdXNpdmVfdGltZSc7XG5cbmNvbnN0IFNFTUFOVElDX0FUVFJJQlVURV9DQUNIRV9ISVQgPSAnY2FjaGUuaGl0JztcblxuY29uc3QgU0VNQU5USUNfQVRUUklCVVRFX0NBQ0hFX0tFWSA9ICdjYWNoZS5rZXknO1xuXG5jb25zdCBTRU1BTlRJQ19BVFRSSUJVVEVfQ0FDSEVfSVRFTV9TSVpFID0gJ2NhY2hlLml0ZW1fc2l6ZSc7XG5cbi8qKiBUT0RPOiBSZW1vdmUgdGhlc2Ugb25jZSB3ZSB1cGRhdGUgdG8gbGF0ZXN0IHNlbWFudGljIGNvbnZlbnRpb25zICovXG5jb25zdCBTRU1BTlRJQ19BVFRSSUJVVEVfSFRUUF9SRVFVRVNUX01FVEhPRCA9ICdodHRwLnJlcXVlc3QubWV0aG9kJztcbmNvbnN0IFNFTUFOVElDX0FUVFJJQlVURV9VUkxfRlVMTCA9ICd1cmwuZnVsbCc7XG5cbi8qKlxuICogQSBzcGFuIGxpbmsgYXR0cmlidXRlIHRvIG1hcmsgdGhlIGxpbmsgYXMgYSBzcGVjaWFsIHNwYW4gbGluay5cbiAqXG4gKiBLbm93biB2YWx1ZXM6XG4gKiAtIGBwcmV2aW91c190cmFjZWA6IFRoZSBzcGFuIGxpbmtzIHRvIHRoZSBmcm9udGVuZCByb290IHNwYW4gb2YgdGhlIHByZXZpb3VzIHRyYWNlLlxuICogLSBgbmV4dF90cmFjZWA6IFRoZSBzcGFuIGxpbmtzIHRvIHRoZSBmcm9udGVuZCByb290IHNwYW4gb2YgdGhlIG5leHQgdHJhY2UuIChOb3Qgc2V0IGJ5IHRoZSBTREspXG4gKlxuICogT3RoZXIgdmFsdWVzIG1heSBiZSBzZXQgYXMgYXBwcm9wcmlhdGUuXG4gKiBAc2VlIGh0dHBzOi8vZGV2ZWxvcC5zZW50cnkuZGV2L3Nkay90ZWxlbWV0cnkvdHJhY2VzL3NwYW4tbGlua3MvI2xpbmstdHlwZXNcbiAqL1xuY29uc3QgU0VNQU5USUNfTElOS19BVFRSSUJVVEVfTElOS19UWVBFID0gJ3NlbnRyeS5saW5rLnR5cGUnO1xuXG5leHBvcnRzLlNFTUFOVElDX0FUVFJJQlVURV9DQUNIRV9ISVQgPSBTRU1BTlRJQ19BVFRSSUJVVEVfQ0FDSEVfSElUO1xuZXhwb3J0cy5TRU1BTlRJQ19BVFRSSUJVVEVfQ0FDSEVfSVRFTV9TSVpFID0gU0VNQU5USUNfQVRUUklCVVRFX0NBQ0hFX0lURU1fU0laRTtcbmV4cG9ydHMuU0VNQU5USUNfQVRUUklCVVRFX0NBQ0hFX0tFWSA9IFNFTUFOVElDX0FUVFJJQlVURV9DQUNIRV9LRVk7XG5leHBvcnRzLlNFTUFOVElDX0FUVFJJQlVURV9FWENMVVNJVkVfVElNRSA9IFNFTUFOVElDX0FUVFJJQlVURV9FWENMVVNJVkVfVElNRTtcbmV4cG9ydHMuU0VNQU5USUNfQVRUUklCVVRFX0hUVFBfUkVRVUVTVF9NRVRIT0QgPSBTRU1BTlRJQ19BVFRSSUJVVEVfSFRUUF9SRVFVRVNUX01FVEhPRDtcbmV4cG9ydHMuU0VNQU5USUNfQVRUUklCVVRFX1BST0ZJTEVfSUQgPSBTRU1BTlRJQ19BVFRSSUJVVEVfUFJPRklMRV9JRDtcbmV4cG9ydHMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9DVVNUT01fU1BBTl9OQU1FID0gU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9DVVNUT01fU1BBTl9OQU1FO1xuZXhwb3J0cy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX0lETEVfU1BBTl9GSU5JU0hfUkVBU09OID0gU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9JRExFX1NQQU5fRklOSVNIX1JFQVNPTjtcbmV4cG9ydHMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9NRUFTVVJFTUVOVF9VTklUID0gU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9NRUFTVVJFTUVOVF9VTklUO1xuZXhwb3J0cy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX01FQVNVUkVNRU5UX1ZBTFVFID0gU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9NRUFTVVJFTUVOVF9WQUxVRTtcbmV4cG9ydHMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9PUCA9IFNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfT1A7XG5leHBvcnRzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfT1JJR0lOID0gU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9PUklHSU47XG5leHBvcnRzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfUFJFVklPVVNfVFJBQ0VfU0FNUExFX1JBVEUgPSBTRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX1BSRVZJT1VTX1RSQUNFX1NBTVBMRV9SQVRFO1xuZXhwb3J0cy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX1NBTVBMRV9SQVRFID0gU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9TQU1QTEVfUkFURTtcbmV4cG9ydHMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9TT1VSQ0UgPSBTRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX1NPVVJDRTtcbmV4cG9ydHMuU0VNQU5USUNfQVRUUklCVVRFX1VSTF9GVUxMID0gU0VNQU5USUNfQVRUUklCVVRFX1VSTF9GVUxMO1xuZXhwb3J0cy5TRU1BTlRJQ19MSU5LX0FUVFJJQlVURV9MSU5LX1RZUEUgPSBTRU1BTlRJQ19MSU5LX0FUVFJJQlVURV9MSU5LX1RZUEU7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1zZW1hbnRpY0F0dHJpYnV0ZXMuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/semanticAttributes.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/server-runtime-client.js":
/*!*************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/server-runtime-client.js ***!
  \*************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst checkin = __webpack_require__(/*! ./checkin.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/checkin.js\");\nconst client = __webpack_require__(/*! ./client.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/client.js\");\nconst currentScopes = __webpack_require__(/*! ./currentScopes.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst debugBuild = __webpack_require__(/*! ./debug-build.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst exports$1 = __webpack_require__(/*! ./logs/exports.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/logs/exports.js\");\nconst errors = __webpack_require__(/*! ./tracing/errors.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/errors.js\");\nconst is = __webpack_require__(/*! ./utils/is.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js\");\nconst debugLogger = __webpack_require__(/*! ./utils/debug-logger.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst misc = __webpack_require__(/*! ./utils/misc.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/misc.js\");\nconst eventbuilder = __webpack_require__(/*! ./utils/eventbuilder.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/eventbuilder.js\");\nconst syncpromise = __webpack_require__(/*! ./utils/syncpromise.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/syncpromise.js\");\n\n// TODO: Make this configurable\nconst DEFAULT_LOG_FLUSH_INTERVAL = 5000;\n\n/**\n * The Sentry Server Runtime Client SDK.\n */\nclass ServerRuntimeClient\n\n extends client.Client {\n\n  /**\n   * Creates a new Edge SDK instance.\n   * @param options Configuration options for this SDK.\n   */\n   constructor(options) {\n    // Server clients always support tracing\n    errors.registerSpanErrorInstrumentation();\n\n    super(options);\n\n    this._logWeight = 0;\n\n    // eslint-disable-next-line deprecation/deprecation\n    const shouldEnableLogs = this._options.enableLogs ?? this._options._experiments?.enableLogs;\n    if (shouldEnableLogs) {\n      // eslint-disable-next-line @typescript-eslint/no-this-alias\n      const client = this;\n\n      client.on('flushLogs', () => {\n        client._logWeight = 0;\n        clearTimeout(client._logFlushIdleTimeout);\n      });\n\n      client.on('afterCaptureLog', log => {\n        client._logWeight += estimateLogSizeInBytes(log);\n\n        // We flush the logs buffer if it exceeds 0.8 MB\n        // The log weight is a rough estimate, so we flush way before\n        // the payload gets too big.\n        if (client._logWeight >= 800000) {\n          exports$1._INTERNAL_flushLogsBuffer(client);\n        } else {\n          // start an idle timeout to flush the logs buffer if no logs are captured for a while\n          client._logFlushIdleTimeout = setTimeout(() => {\n            exports$1._INTERNAL_flushLogsBuffer(client);\n          }, DEFAULT_LOG_FLUSH_INTERVAL);\n        }\n      });\n\n      client.on('flush', () => {\n        exports$1._INTERNAL_flushLogsBuffer(client);\n      });\n    }\n  }\n\n  /**\n   * @inheritDoc\n   */\n   eventFromException(exception, hint) {\n    const event = eventbuilder.eventFromUnknownInput(this, this._options.stackParser, exception, hint);\n    event.level = 'error';\n\n    return syncpromise.resolvedSyncPromise(event);\n  }\n\n  /**\n   * @inheritDoc\n   */\n   eventFromMessage(\n    message,\n    level = 'info',\n    hint,\n  ) {\n    return syncpromise.resolvedSyncPromise(\n      eventbuilder.eventFromMessage(this._options.stackParser, message, level, hint, this._options.attachStacktrace),\n    );\n  }\n\n  /**\n   * @inheritDoc\n   */\n   captureException(exception, hint, scope) {\n    setCurrentRequestSessionErroredOrCrashed(hint);\n    return super.captureException(exception, hint, scope);\n  }\n\n  /**\n   * @inheritDoc\n   */\n   captureEvent(event, hint, scope) {\n    // If the event is of type Exception, then a request session should be captured\n    const isException = !event.type && event.exception?.values && event.exception.values.length > 0;\n    if (isException) {\n      setCurrentRequestSessionErroredOrCrashed(hint);\n    }\n\n    return super.captureEvent(event, hint, scope);\n  }\n\n  /**\n   * Create a cron monitor check in and send it to Sentry.\n   *\n   * @param checkIn An object that describes a check in.\n   * @param upsertMonitorConfig An optional object that describes a monitor config. Use this if you want\n   * to create a monitor automatically when sending a check in.\n   */\n   captureCheckIn(checkIn, monitorConfig, scope) {\n    const id = 'checkInId' in checkIn && checkIn.checkInId ? checkIn.checkInId : misc.uuid4();\n    if (!this._isEnabled()) {\n      debugBuild.DEBUG_BUILD && debugLogger.debug.warn('SDK not enabled, will not capture check-in.');\n      return id;\n    }\n\n    const options = this.getOptions();\n    const { release, environment, tunnel } = options;\n\n    const serializedCheckIn = {\n      check_in_id: id,\n      monitor_slug: checkIn.monitorSlug,\n      status: checkIn.status,\n      release,\n      environment,\n    };\n\n    if ('duration' in checkIn) {\n      serializedCheckIn.duration = checkIn.duration;\n    }\n\n    if (monitorConfig) {\n      serializedCheckIn.monitor_config = {\n        schedule: monitorConfig.schedule,\n        checkin_margin: monitorConfig.checkinMargin,\n        max_runtime: monitorConfig.maxRuntime,\n        timezone: monitorConfig.timezone,\n        failure_issue_threshold: monitorConfig.failureIssueThreshold,\n        recovery_threshold: monitorConfig.recoveryThreshold,\n      };\n    }\n\n    const [dynamicSamplingContext, traceContext] = client._getTraceInfoFromScope(this, scope);\n    if (traceContext) {\n      serializedCheckIn.contexts = {\n        trace: traceContext,\n      };\n    }\n\n    const envelope = checkin.createCheckInEnvelope(\n      serializedCheckIn,\n      dynamicSamplingContext,\n      this.getSdkMetadata(),\n      tunnel,\n      this.getDsn(),\n    );\n\n    debugBuild.DEBUG_BUILD && debugLogger.debug.log('Sending checkin:', checkIn.monitorSlug, checkIn.status);\n\n    // sendEnvelope should not throw\n    // eslint-disable-next-line @typescript-eslint/no-floating-promises\n    this.sendEnvelope(envelope);\n\n    return id;\n  }\n\n  /**\n   * @inheritDoc\n   */\n   _prepareEvent(\n    event,\n    hint,\n    currentScope,\n    isolationScope,\n  ) {\n    if (this._options.platform) {\n      event.platform = event.platform || this._options.platform;\n    }\n\n    if (this._options.runtime) {\n      event.contexts = {\n        ...event.contexts,\n        runtime: event.contexts?.runtime || this._options.runtime,\n      };\n    }\n\n    if (this._options.serverName) {\n      event.server_name = event.server_name || this._options.serverName;\n    }\n\n    return super._prepareEvent(event, hint, currentScope, isolationScope);\n  }\n}\n\nfunction setCurrentRequestSessionErroredOrCrashed(eventHint) {\n  const requestSession = currentScopes.getIsolationScope().getScopeData().sdkProcessingMetadata.requestSession;\n  if (requestSession) {\n    // We mutate instead of doing `setSdkProcessingMetadata` because the http integration stores away a particular\n    // isolationScope. If that isolation scope is forked, setting the processing metadata here will not mutate the\n    // original isolation scope that the http integration stored away.\n    const isHandledException = eventHint?.mechanism?.handled ?? true;\n    // A request session can go from \"errored\" -> \"crashed\" but not \"crashed\" -> \"errored\".\n    // Crashed (unhandled exception) is worse than errored (handled exception).\n    if (isHandledException && requestSession.status !== 'crashed') {\n      requestSession.status = 'errored';\n    } else if (!isHandledException) {\n      requestSession.status = 'crashed';\n    }\n  }\n}\n\n/**\n * Estimate the size of a log in bytes.\n *\n * @param log - The log to estimate the size of.\n * @returns The estimated size of the log in bytes.\n */\nfunction estimateLogSizeInBytes(log) {\n  let weight = 0;\n\n  // Estimate byte size of 2 bytes per character. This is a rough estimate JS strings are stored as UTF-16.\n  if (log.message) {\n    weight += log.message.length * 2;\n  }\n\n  if (log.attributes) {\n    Object.values(log.attributes).forEach(value => {\n      if (Array.isArray(value)) {\n        weight += value.length * estimatePrimitiveSizeInBytes(value[0]);\n      } else if (is.isPrimitive(value)) {\n        weight += estimatePrimitiveSizeInBytes(value);\n      } else {\n        // For objects values, we estimate the size of the object as 100 bytes\n        weight += 100;\n      }\n    });\n  }\n\n  return weight;\n}\n\nfunction estimatePrimitiveSizeInBytes(value) {\n  if (typeof value === 'string') {\n    return value.length * 2;\n  } else if (typeof value === 'number') {\n    return 8;\n  } else if (typeof value === 'boolean') {\n    return 4;\n  }\n\n  return 0;\n}\n\nexports.ServerRuntimeClient = ServerRuntimeClient;\n//# sourceMappingURL=server-runtime-client.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9zZXJ2ZXItcnVudGltZS1jbGllbnQuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsZ0JBQWdCLG1CQUFPLENBQUMsbUhBQWM7QUFDdEMsZUFBZSxtQkFBTyxDQUFDLGlIQUFhO0FBQ3BDLHNCQUFzQixtQkFBTyxDQUFDLCtIQUFvQjtBQUNsRCxtQkFBbUIsbUJBQU8sQ0FBQywySEFBa0I7QUFDN0Msa0JBQWtCLG1CQUFPLENBQUMsNkhBQW1CO0FBQzdDLGVBQWUsbUJBQU8sQ0FBQyxpSUFBcUI7QUFDNUMsV0FBVyxtQkFBTyxDQUFDLHFIQUFlO0FBQ2xDLG9CQUFvQixtQkFBTyxDQUFDLHlJQUF5QjtBQUNyRCxhQUFhLG1CQUFPLENBQUMseUhBQWlCO0FBQ3RDLHFCQUFxQixtQkFBTyxDQUFDLHlJQUF5QjtBQUN0RCxvQkFBb0IsbUJBQU8sQ0FBQyx1SUFBd0I7O0FBRXBEO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQSxPQUFPOztBQUVQO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFVBQVU7QUFDVjtBQUNBO0FBQ0E7QUFDQSxXQUFXO0FBQ1g7QUFDQSxPQUFPOztBQUVQO0FBQ0E7QUFDQSxPQUFPO0FBQ1A7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQSxZQUFZLCtCQUErQjs7QUFFM0M7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLE1BQU07QUFDTjtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsUUFBUTtBQUNSO0FBQ0EsUUFBUTtBQUNSO0FBQ0E7QUFDQTtBQUNBLEtBQUs7QUFDTDs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBLElBQUk7QUFDSjtBQUNBLElBQUk7QUFDSjtBQUNBOztBQUVBO0FBQ0E7O0FBRUEsMkJBQTJCO0FBQzNCIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvc2VydmVyLXJ1bnRpbWUtY2xpZW50LmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBjaGVja2luID0gcmVxdWlyZSgnLi9jaGVja2luLmpzJyk7XG5jb25zdCBjbGllbnQgPSByZXF1aXJlKCcuL2NsaWVudC5qcycpO1xuY29uc3QgY3VycmVudFNjb3BlcyA9IHJlcXVpcmUoJy4vY3VycmVudFNjb3Blcy5qcycpO1xuY29uc3QgZGVidWdCdWlsZCA9IHJlcXVpcmUoJy4vZGVidWctYnVpbGQuanMnKTtcbmNvbnN0IGV4cG9ydHMkMSA9IHJlcXVpcmUoJy4vbG9ncy9leHBvcnRzLmpzJyk7XG5jb25zdCBlcnJvcnMgPSByZXF1aXJlKCcuL3RyYWNpbmcvZXJyb3JzLmpzJyk7XG5jb25zdCBpcyA9IHJlcXVpcmUoJy4vdXRpbHMvaXMuanMnKTtcbmNvbnN0IGRlYnVnTG9nZ2VyID0gcmVxdWlyZSgnLi91dGlscy9kZWJ1Zy1sb2dnZXIuanMnKTtcbmNvbnN0IG1pc2MgPSByZXF1aXJlKCcuL3V0aWxzL21pc2MuanMnKTtcbmNvbnN0IGV2ZW50YnVpbGRlciA9IHJlcXVpcmUoJy4vdXRpbHMvZXZlbnRidWlsZGVyLmpzJyk7XG5jb25zdCBzeW5jcHJvbWlzZSA9IHJlcXVpcmUoJy4vdXRpbHMvc3luY3Byb21pc2UuanMnKTtcblxuLy8gVE9ETzogTWFrZSB0aGlzIGNvbmZpZ3VyYWJsZVxuY29uc3QgREVGQVVMVF9MT0dfRkxVU0hfSU5URVJWQUwgPSA1MDAwO1xuXG4vKipcbiAqIFRoZSBTZW50cnkgU2VydmVyIFJ1bnRpbWUgQ2xpZW50IFNESy5cbiAqL1xuY2xhc3MgU2VydmVyUnVudGltZUNsaWVudFxuXG4gZXh0ZW5kcyBjbGllbnQuQ2xpZW50IHtcblxuICAvKipcbiAgICogQ3JlYXRlcyBhIG5ldyBFZGdlIFNESyBpbnN0YW5jZS5cbiAgICogQHBhcmFtIG9wdGlvbnMgQ29uZmlndXJhdGlvbiBvcHRpb25zIGZvciB0aGlzIFNESy5cbiAgICovXG4gICBjb25zdHJ1Y3RvcihvcHRpb25zKSB7XG4gICAgLy8gU2VydmVyIGNsaWVudHMgYWx3YXlzIHN1cHBvcnQgdHJhY2luZ1xuICAgIGVycm9ycy5yZWdpc3RlclNwYW5FcnJvckluc3RydW1lbnRhdGlvbigpO1xuXG4gICAgc3VwZXIob3B0aW9ucyk7XG5cbiAgICB0aGlzLl9sb2dXZWlnaHQgPSAwO1xuXG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIGRlcHJlY2F0aW9uL2RlcHJlY2F0aW9uXG4gICAgY29uc3Qgc2hvdWxkRW5hYmxlTG9ncyA9IHRoaXMuX29wdGlvbnMuZW5hYmxlTG9ncyA/PyB0aGlzLl9vcHRpb25zLl9leHBlcmltZW50cz8uZW5hYmxlTG9ncztcbiAgICBpZiAoc2hvdWxkRW5hYmxlTG9ncykge1xuICAgICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uby10aGlzLWFsaWFzXG4gICAgICBjb25zdCBjbGllbnQgPSB0aGlzO1xuXG4gICAgICBjbGllbnQub24oJ2ZsdXNoTG9ncycsICgpID0+IHtcbiAgICAgICAgY2xpZW50Ll9sb2dXZWlnaHQgPSAwO1xuICAgICAgICBjbGVhclRpbWVvdXQoY2xpZW50Ll9sb2dGbHVzaElkbGVUaW1lb3V0KTtcbiAgICAgIH0pO1xuXG4gICAgICBjbGllbnQub24oJ2FmdGVyQ2FwdHVyZUxvZycsIGxvZyA9PiB7XG4gICAgICAgIGNsaWVudC5fbG9nV2VpZ2h0ICs9IGVzdGltYXRlTG9nU2l6ZUluQnl0ZXMobG9nKTtcblxuICAgICAgICAvLyBXZSBmbHVzaCB0aGUgbG9ncyBidWZmZXIgaWYgaXQgZXhjZWVkcyAwLjggTUJcbiAgICAgICAgLy8gVGhlIGxvZyB3ZWlnaHQgaXMgYSByb3VnaCBlc3RpbWF0ZSwgc28gd2UgZmx1c2ggd2F5IGJlZm9yZVxuICAgICAgICAvLyB0aGUgcGF5bG9hZCBnZXRzIHRvbyBiaWcuXG4gICAgICAgIGlmIChjbGllbnQuX2xvZ1dlaWdodCA+PSA4MDAwMDApIHtcbiAgICAgICAgICBleHBvcnRzJDEuX0lOVEVSTkFMX2ZsdXNoTG9nc0J1ZmZlcihjbGllbnQpO1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgIC8vIHN0YXJ0IGFuIGlkbGUgdGltZW91dCB0byBmbHVzaCB0aGUgbG9ncyBidWZmZXIgaWYgbm8gbG9ncyBhcmUgY2FwdHVyZWQgZm9yIGEgd2hpbGVcbiAgICAgICAgICBjbGllbnQuX2xvZ0ZsdXNoSWRsZVRpbWVvdXQgPSBzZXRUaW1lb3V0KCgpID0+IHtcbiAgICAgICAgICAgIGV4cG9ydHMkMS5fSU5URVJOQUxfZmx1c2hMb2dzQnVmZmVyKGNsaWVudCk7XG4gICAgICAgICAgfSwgREVGQVVMVF9MT0dfRkxVU0hfSU5URVJWQUwpO1xuICAgICAgICB9XG4gICAgICB9KTtcblxuICAgICAgY2xpZW50Lm9uKCdmbHVzaCcsICgpID0+IHtcbiAgICAgICAgZXhwb3J0cyQxLl9JTlRFUk5BTF9mbHVzaExvZ3NCdWZmZXIoY2xpZW50KTtcbiAgICAgIH0pO1xuICAgIH1cbiAgfVxuXG4gIC8qKlxuICAgKiBAaW5oZXJpdERvY1xuICAgKi9cbiAgIGV2ZW50RnJvbUV4Y2VwdGlvbihleGNlcHRpb24sIGhpbnQpIHtcbiAgICBjb25zdCBldmVudCA9IGV2ZW50YnVpbGRlci5ldmVudEZyb21Vbmtub3duSW5wdXQodGhpcywgdGhpcy5fb3B0aW9ucy5zdGFja1BhcnNlciwgZXhjZXB0aW9uLCBoaW50KTtcbiAgICBldmVudC5sZXZlbCA9ICdlcnJvcic7XG5cbiAgICByZXR1cm4gc3luY3Byb21pc2UucmVzb2x2ZWRTeW5jUHJvbWlzZShldmVudCk7XG4gIH1cblxuICAvKipcbiAgICogQGluaGVyaXREb2NcbiAgICovXG4gICBldmVudEZyb21NZXNzYWdlKFxuICAgIG1lc3NhZ2UsXG4gICAgbGV2ZWwgPSAnaW5mbycsXG4gICAgaGludCxcbiAgKSB7XG4gICAgcmV0dXJuIHN5bmNwcm9taXNlLnJlc29sdmVkU3luY1Byb21pc2UoXG4gICAgICBldmVudGJ1aWxkZXIuZXZlbnRGcm9tTWVzc2FnZSh0aGlzLl9vcHRpb25zLnN0YWNrUGFyc2VyLCBtZXNzYWdlLCBsZXZlbCwgaGludCwgdGhpcy5fb3B0aW9ucy5hdHRhY2hTdGFja3RyYWNlKSxcbiAgICApO1xuICB9XG5cbiAgLyoqXG4gICAqIEBpbmhlcml0RG9jXG4gICAqL1xuICAgY2FwdHVyZUV4Y2VwdGlvbihleGNlcHRpb24sIGhpbnQsIHNjb3BlKSB7XG4gICAgc2V0Q3VycmVudFJlcXVlc3RTZXNzaW9uRXJyb3JlZE9yQ3Jhc2hlZChoaW50KTtcbiAgICByZXR1cm4gc3VwZXIuY2FwdHVyZUV4Y2VwdGlvbihleGNlcHRpb24sIGhpbnQsIHNjb3BlKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBAaW5oZXJpdERvY1xuICAgKi9cbiAgIGNhcHR1cmVFdmVudChldmVudCwgaGludCwgc2NvcGUpIHtcbiAgICAvLyBJZiB0aGUgZXZlbnQgaXMgb2YgdHlwZSBFeGNlcHRpb24sIHRoZW4gYSByZXF1ZXN0IHNlc3Npb24gc2hvdWxkIGJlIGNhcHR1cmVkXG4gICAgY29uc3QgaXNFeGNlcHRpb24gPSAhZXZlbnQudHlwZSAmJiBldmVudC5leGNlcHRpb24/LnZhbHVlcyAmJiBldmVudC5leGNlcHRpb24udmFsdWVzLmxlbmd0aCA+IDA7XG4gICAgaWYgKGlzRXhjZXB0aW9uKSB7XG4gICAgICBzZXRDdXJyZW50UmVxdWVzdFNlc3Npb25FcnJvcmVkT3JDcmFzaGVkKGhpbnQpO1xuICAgIH1cblxuICAgIHJldHVybiBzdXBlci5jYXB0dXJlRXZlbnQoZXZlbnQsIGhpbnQsIHNjb3BlKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBDcmVhdGUgYSBjcm9uIG1vbml0b3IgY2hlY2sgaW4gYW5kIHNlbmQgaXQgdG8gU2VudHJ5LlxuICAgKlxuICAgKiBAcGFyYW0gY2hlY2tJbiBBbiBvYmplY3QgdGhhdCBkZXNjcmliZXMgYSBjaGVjayBpbi5cbiAgICogQHBhcmFtIHVwc2VydE1vbml0b3JDb25maWcgQW4gb3B0aW9uYWwgb2JqZWN0IHRoYXQgZGVzY3JpYmVzIGEgbW9uaXRvciBjb25maWcuIFVzZSB0aGlzIGlmIHlvdSB3YW50XG4gICAqIHRvIGNyZWF0ZSBhIG1vbml0b3IgYXV0b21hdGljYWxseSB3aGVuIHNlbmRpbmcgYSBjaGVjayBpbi5cbiAgICovXG4gICBjYXB0dXJlQ2hlY2tJbihjaGVja0luLCBtb25pdG9yQ29uZmlnLCBzY29wZSkge1xuICAgIGNvbnN0IGlkID0gJ2NoZWNrSW5JZCcgaW4gY2hlY2tJbiAmJiBjaGVja0luLmNoZWNrSW5JZCA/IGNoZWNrSW4uY2hlY2tJbklkIDogbWlzYy51dWlkNCgpO1xuICAgIGlmICghdGhpcy5faXNFbmFibGVkKCkpIHtcbiAgICAgIGRlYnVnQnVpbGQuREVCVUdfQlVJTEQgJiYgZGVidWdMb2dnZXIuZGVidWcud2FybignU0RLIG5vdCBlbmFibGVkLCB3aWxsIG5vdCBjYXB0dXJlIGNoZWNrLWluLicpO1xuICAgICAgcmV0dXJuIGlkO1xuICAgIH1cblxuICAgIGNvbnN0IG9wdGlvbnMgPSB0aGlzLmdldE9wdGlvbnMoKTtcbiAgICBjb25zdCB7IHJlbGVhc2UsIGVudmlyb25tZW50LCB0dW5uZWwgfSA9IG9wdGlvbnM7XG5cbiAgICBjb25zdCBzZXJpYWxpemVkQ2hlY2tJbiA9IHtcbiAgICAgIGNoZWNrX2luX2lkOiBpZCxcbiAgICAgIG1vbml0b3Jfc2x1ZzogY2hlY2tJbi5tb25pdG9yU2x1ZyxcbiAgICAgIHN0YXR1czogY2hlY2tJbi5zdGF0dXMsXG4gICAgICByZWxlYXNlLFxuICAgICAgZW52aXJvbm1lbnQsXG4gICAgfTtcblxuICAgIGlmICgnZHVyYXRpb24nIGluIGNoZWNrSW4pIHtcbiAgICAgIHNlcmlhbGl6ZWRDaGVja0luLmR1cmF0aW9uID0gY2hlY2tJbi5kdXJhdGlvbjtcbiAgICB9XG5cbiAgICBpZiAobW9uaXRvckNvbmZpZykge1xuICAgICAgc2VyaWFsaXplZENoZWNrSW4ubW9uaXRvcl9jb25maWcgPSB7XG4gICAgICAgIHNjaGVkdWxlOiBtb25pdG9yQ29uZmlnLnNjaGVkdWxlLFxuICAgICAgICBjaGVja2luX21hcmdpbjogbW9uaXRvckNvbmZpZy5jaGVja2luTWFyZ2luLFxuICAgICAgICBtYXhfcnVudGltZTogbW9uaXRvckNvbmZpZy5tYXhSdW50aW1lLFxuICAgICAgICB0aW1lem9uZTogbW9uaXRvckNvbmZpZy50aW1lem9uZSxcbiAgICAgICAgZmFpbHVyZV9pc3N1ZV90aHJlc2hvbGQ6IG1vbml0b3JDb25maWcuZmFpbHVyZUlzc3VlVGhyZXNob2xkLFxuICAgICAgICByZWNvdmVyeV90aHJlc2hvbGQ6IG1vbml0b3JDb25maWcucmVjb3ZlcnlUaHJlc2hvbGQsXG4gICAgICB9O1xuICAgIH1cblxuICAgIGNvbnN0IFtkeW5hbWljU2FtcGxpbmdDb250ZXh0LCB0cmFjZUNvbnRleHRdID0gY2xpZW50Ll9nZXRUcmFjZUluZm9Gcm9tU2NvcGUodGhpcywgc2NvcGUpO1xuICAgIGlmICh0cmFjZUNvbnRleHQpIHtcbiAgICAgIHNlcmlhbGl6ZWRDaGVja0luLmNvbnRleHRzID0ge1xuICAgICAgICB0cmFjZTogdHJhY2VDb250ZXh0LFxuICAgICAgfTtcbiAgICB9XG5cbiAgICBjb25zdCBlbnZlbG9wZSA9IGNoZWNraW4uY3JlYXRlQ2hlY2tJbkVudmVsb3BlKFxuICAgICAgc2VyaWFsaXplZENoZWNrSW4sXG4gICAgICBkeW5hbWljU2FtcGxpbmdDb250ZXh0LFxuICAgICAgdGhpcy5nZXRTZGtNZXRhZGF0YSgpLFxuICAgICAgdHVubmVsLFxuICAgICAgdGhpcy5nZXREc24oKSxcbiAgICApO1xuXG4gICAgZGVidWdCdWlsZC5ERUJVR19CVUlMRCAmJiBkZWJ1Z0xvZ2dlci5kZWJ1Zy5sb2coJ1NlbmRpbmcgY2hlY2tpbjonLCBjaGVja0luLm1vbml0b3JTbHVnLCBjaGVja0luLnN0YXR1cyk7XG5cbiAgICAvLyBzZW5kRW52ZWxvcGUgc2hvdWxkIG5vdCB0aHJvd1xuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tZmxvYXRpbmctcHJvbWlzZXNcbiAgICB0aGlzLnNlbmRFbnZlbG9wZShlbnZlbG9wZSk7XG5cbiAgICByZXR1cm4gaWQ7XG4gIH1cblxuICAvKipcbiAgICogQGluaGVyaXREb2NcbiAgICovXG4gICBfcHJlcGFyZUV2ZW50KFxuICAgIGV2ZW50LFxuICAgIGhpbnQsXG4gICAgY3VycmVudFNjb3BlLFxuICAgIGlzb2xhdGlvblNjb3BlLFxuICApIHtcbiAgICBpZiAodGhpcy5fb3B0aW9ucy5wbGF0Zm9ybSkge1xuICAgICAgZXZlbnQucGxhdGZvcm0gPSBldmVudC5wbGF0Zm9ybSB8fCB0aGlzLl9vcHRpb25zLnBsYXRmb3JtO1xuICAgIH1cblxuICAgIGlmICh0aGlzLl9vcHRpb25zLnJ1bnRpbWUpIHtcbiAgICAgIGV2ZW50LmNvbnRleHRzID0ge1xuICAgICAgICAuLi5ldmVudC5jb250ZXh0cyxcbiAgICAgICAgcnVudGltZTogZXZlbnQuY29udGV4dHM/LnJ1bnRpbWUgfHwgdGhpcy5fb3B0aW9ucy5ydW50aW1lLFxuICAgICAgfTtcbiAgICB9XG5cbiAgICBpZiAodGhpcy5fb3B0aW9ucy5zZXJ2ZXJOYW1lKSB7XG4gICAgICBldmVudC5zZXJ2ZXJfbmFtZSA9IGV2ZW50LnNlcnZlcl9uYW1lIHx8IHRoaXMuX29wdGlvbnMuc2VydmVyTmFtZTtcbiAgICB9XG5cbiAgICByZXR1cm4gc3VwZXIuX3ByZXBhcmVFdmVudChldmVudCwgaGludCwgY3VycmVudFNjb3BlLCBpc29sYXRpb25TY29wZSk7XG4gIH1cbn1cblxuZnVuY3Rpb24gc2V0Q3VycmVudFJlcXVlc3RTZXNzaW9uRXJyb3JlZE9yQ3Jhc2hlZChldmVudEhpbnQpIHtcbiAgY29uc3QgcmVxdWVzdFNlc3Npb24gPSBjdXJyZW50U2NvcGVzLmdldElzb2xhdGlvblNjb3BlKCkuZ2V0U2NvcGVEYXRhKCkuc2RrUHJvY2Vzc2luZ01ldGFkYXRhLnJlcXVlc3RTZXNzaW9uO1xuICBpZiAocmVxdWVzdFNlc3Npb24pIHtcbiAgICAvLyBXZSBtdXRhdGUgaW5zdGVhZCBvZiBkb2luZyBgc2V0U2RrUHJvY2Vzc2luZ01ldGFkYXRhYCBiZWNhdXNlIHRoZSBodHRwIGludGVncmF0aW9uIHN0b3JlcyBhd2F5IGEgcGFydGljdWxhclxuICAgIC8vIGlzb2xhdGlvblNjb3BlLiBJZiB0aGF0IGlzb2xhdGlvbiBzY29wZSBpcyBmb3JrZWQsIHNldHRpbmcgdGhlIHByb2Nlc3NpbmcgbWV0YWRhdGEgaGVyZSB3aWxsIG5vdCBtdXRhdGUgdGhlXG4gICAgLy8gb3JpZ2luYWwgaXNvbGF0aW9uIHNjb3BlIHRoYXQgdGhlIGh0dHAgaW50ZWdyYXRpb24gc3RvcmVkIGF3YXkuXG4gICAgY29uc3QgaXNIYW5kbGVkRXhjZXB0aW9uID0gZXZlbnRIaW50Py5tZWNoYW5pc20/LmhhbmRsZWQgPz8gdHJ1ZTtcbiAgICAvLyBBIHJlcXVlc3Qgc2Vzc2lvbiBjYW4gZ28gZnJvbSBcImVycm9yZWRcIiAtPiBcImNyYXNoZWRcIiBidXQgbm90IFwiY3Jhc2hlZFwiIC0+IFwiZXJyb3JlZFwiLlxuICAgIC8vIENyYXNoZWQgKHVuaGFuZGxlZCBleGNlcHRpb24pIGlzIHdvcnNlIHRoYW4gZXJyb3JlZCAoaGFuZGxlZCBleGNlcHRpb24pLlxuICAgIGlmIChpc0hhbmRsZWRFeGNlcHRpb24gJiYgcmVxdWVzdFNlc3Npb24uc3RhdHVzICE9PSAnY3Jhc2hlZCcpIHtcbiAgICAgIHJlcXVlc3RTZXNzaW9uLnN0YXR1cyA9ICdlcnJvcmVkJztcbiAgICB9IGVsc2UgaWYgKCFpc0hhbmRsZWRFeGNlcHRpb24pIHtcbiAgICAgIHJlcXVlc3RTZXNzaW9uLnN0YXR1cyA9ICdjcmFzaGVkJztcbiAgICB9XG4gIH1cbn1cblxuLyoqXG4gKiBFc3RpbWF0ZSB0aGUgc2l6ZSBvZiBhIGxvZyBpbiBieXRlcy5cbiAqXG4gKiBAcGFyYW0gbG9nIC0gVGhlIGxvZyB0byBlc3RpbWF0ZSB0aGUgc2l6ZSBvZi5cbiAqIEByZXR1cm5zIFRoZSBlc3RpbWF0ZWQgc2l6ZSBvZiB0aGUgbG9nIGluIGJ5dGVzLlxuICovXG5mdW5jdGlvbiBlc3RpbWF0ZUxvZ1NpemVJbkJ5dGVzKGxvZykge1xuICBsZXQgd2VpZ2h0ID0gMDtcblxuICAvLyBFc3RpbWF0ZSBieXRlIHNpemUgb2YgMiBieXRlcyBwZXIgY2hhcmFjdGVyLiBUaGlzIGlzIGEgcm91Z2ggZXN0aW1hdGUgSlMgc3RyaW5ncyBhcmUgc3RvcmVkIGFzIFVURi0xNi5cbiAgaWYgKGxvZy5tZXNzYWdlKSB7XG4gICAgd2VpZ2h0ICs9IGxvZy5tZXNzYWdlLmxlbmd0aCAqIDI7XG4gIH1cblxuICBpZiAobG9nLmF0dHJpYnV0ZXMpIHtcbiAgICBPYmplY3QudmFsdWVzKGxvZy5hdHRyaWJ1dGVzKS5mb3JFYWNoKHZhbHVlID0+IHtcbiAgICAgIGlmIChBcnJheS5pc0FycmF5KHZhbHVlKSkge1xuICAgICAgICB3ZWlnaHQgKz0gdmFsdWUubGVuZ3RoICogZXN0aW1hdGVQcmltaXRpdmVTaXplSW5CeXRlcyh2YWx1ZVswXSk7XG4gICAgICB9IGVsc2UgaWYgKGlzLmlzUHJpbWl0aXZlKHZhbHVlKSkge1xuICAgICAgICB3ZWlnaHQgKz0gZXN0aW1hdGVQcmltaXRpdmVTaXplSW5CeXRlcyh2YWx1ZSk7XG4gICAgICB9IGVsc2Uge1xuICAgICAgICAvLyBGb3Igb2JqZWN0cyB2YWx1ZXMsIHdlIGVzdGltYXRlIHRoZSBzaXplIG9mIHRoZSBvYmplY3QgYXMgMTAwIGJ5dGVzXG4gICAgICAgIHdlaWdodCArPSAxMDA7XG4gICAgICB9XG4gICAgfSk7XG4gIH1cblxuICByZXR1cm4gd2VpZ2h0O1xufVxuXG5mdW5jdGlvbiBlc3RpbWF0ZVByaW1pdGl2ZVNpemVJbkJ5dGVzKHZhbHVlKSB7XG4gIGlmICh0eXBlb2YgdmFsdWUgPT09ICdzdHJpbmcnKSB7XG4gICAgcmV0dXJuIHZhbHVlLmxlbmd0aCAqIDI7XG4gIH0gZWxzZSBpZiAodHlwZW9mIHZhbHVlID09PSAnbnVtYmVyJykge1xuICAgIHJldHVybiA4O1xuICB9IGVsc2UgaWYgKHR5cGVvZiB2YWx1ZSA9PT0gJ2Jvb2xlYW4nKSB7XG4gICAgcmV0dXJuIDQ7XG4gIH1cblxuICByZXR1cm4gMDtcbn1cblxuZXhwb3J0cy5TZXJ2ZXJSdW50aW1lQ2xpZW50ID0gU2VydmVyUnVudGltZUNsaWVudDtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPXNlcnZlci1ydW50aW1lLWNsaWVudC5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/server-runtime-client.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/session.js":
/*!***********************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/session.js ***!
  \***********************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst misc = __webpack_require__(/*! ./utils/misc.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/misc.js\");\nconst time = __webpack_require__(/*! ./utils/time.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/time.js\");\n\n/**\n * Creates a new `Session` object by setting certain default parameters. If optional @param context\n * is passed, the passed properties are applied to the session object.\n *\n * @param context (optional) additional properties to be applied to the returned session object\n *\n * @returns a new `Session` object\n */\nfunction makeSession(context) {\n  // Both timestamp and started are in seconds since the UNIX epoch.\n  const startingTime = time.timestampInSeconds();\n\n  const session = {\n    sid: misc.uuid4(),\n    init: true,\n    timestamp: startingTime,\n    started: startingTime,\n    duration: 0,\n    status: 'ok',\n    errors: 0,\n    ignoreDuration: false,\n    toJSON: () => sessionToJSON(session),\n  };\n\n  if (context) {\n    updateSession(session, context);\n  }\n\n  return session;\n}\n\n/**\n * Updates a session object with the properties passed in the context.\n *\n * Note that this function mutates the passed object and returns void.\n * (Had to do this instead of returning a new and updated session because closing and sending a session\n * makes an update to the session after it was passed to the sending logic.\n * @see Client.captureSession )\n *\n * @param session the `Session` to update\n * @param context the `SessionContext` holding the properties that should be updated in @param session\n */\n// eslint-disable-next-line complexity\nfunction updateSession(session, context = {}) {\n  if (context.user) {\n    if (!session.ipAddress && context.user.ip_address) {\n      session.ipAddress = context.user.ip_address;\n    }\n\n    if (!session.did && !context.did) {\n      session.did = context.user.id || context.user.email || context.user.username;\n    }\n  }\n\n  session.timestamp = context.timestamp || time.timestampInSeconds();\n\n  if (context.abnormal_mechanism) {\n    session.abnormal_mechanism = context.abnormal_mechanism;\n  }\n\n  if (context.ignoreDuration) {\n    session.ignoreDuration = context.ignoreDuration;\n  }\n  if (context.sid) {\n    // Good enough uuid validation. — Kamil\n    session.sid = context.sid.length === 32 ? context.sid : misc.uuid4();\n  }\n  if (context.init !== undefined) {\n    session.init = context.init;\n  }\n  if (!session.did && context.did) {\n    session.did = `${context.did}`;\n  }\n  if (typeof context.started === 'number') {\n    session.started = context.started;\n  }\n  if (session.ignoreDuration) {\n    session.duration = undefined;\n  } else if (typeof context.duration === 'number') {\n    session.duration = context.duration;\n  } else {\n    const duration = session.timestamp - session.started;\n    session.duration = duration >= 0 ? duration : 0;\n  }\n  if (context.release) {\n    session.release = context.release;\n  }\n  if (context.environment) {\n    session.environment = context.environment;\n  }\n  if (!session.ipAddress && context.ipAddress) {\n    session.ipAddress = context.ipAddress;\n  }\n  if (!session.userAgent && context.userAgent) {\n    session.userAgent = context.userAgent;\n  }\n  if (typeof context.errors === 'number') {\n    session.errors = context.errors;\n  }\n  if (context.status) {\n    session.status = context.status;\n  }\n}\n\n/**\n * Closes a session by setting its status and updating the session object with it.\n * Internally calls `updateSession` to update the passed session object.\n *\n * Note that this function mutates the passed session (@see updateSession for explanation).\n *\n * @param session the `Session` object to be closed\n * @param status the `SessionStatus` with which the session was closed. If you don't pass a status,\n *               this function will keep the previously set status, unless it was `'ok'` in which case\n *               it is changed to `'exited'`.\n */\nfunction closeSession(session, status) {\n  let context = {};\n  if (status) {\n    context = { status };\n  } else if (session.status === 'ok') {\n    context = { status: 'exited' };\n  }\n\n  updateSession(session, context);\n}\n\n/**\n * Serializes a passed session object to a JSON object with a slightly different structure.\n * This is necessary because the Sentry backend requires a slightly different schema of a session\n * than the one the JS SDKs use internally.\n *\n * @param session the session to be converted\n *\n * @returns a JSON object of the passed session\n */\nfunction sessionToJSON(session) {\n  return {\n    sid: `${session.sid}`,\n    init: session.init,\n    // Make sure that sec is converted to ms for date constructor\n    started: new Date(session.started * 1000).toISOString(),\n    timestamp: new Date(session.timestamp * 1000).toISOString(),\n    status: session.status,\n    errors: session.errors,\n    did: typeof session.did === 'number' || typeof session.did === 'string' ? `${session.did}` : undefined,\n    duration: session.duration,\n    abnormal_mechanism: session.abnormal_mechanism,\n    attrs: {\n      release: session.release,\n      environment: session.environment,\n      ip_address: session.ipAddress,\n      user_agent: session.userAgent,\n    },\n  };\n}\n\nexports.closeSession = closeSession;\nexports.makeSession = makeSession;\nexports.updateSession = updateSession;\n//# sourceMappingURL=session.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9zZXNzaW9uLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLGFBQWEsbUJBQU8sQ0FBQyx5SEFBaUI7QUFDdEMsYUFBYSxtQkFBTyxDQUFDLHlIQUFpQjs7QUFFdEM7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLDRDQUE0QztBQUM1QztBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLHFCQUFxQixZQUFZO0FBQ2pDO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLElBQUk7QUFDSjtBQUNBLElBQUk7QUFDSjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsZ0JBQWdCO0FBQ2hCLElBQUk7QUFDSixnQkFBZ0I7QUFDaEI7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsWUFBWSxZQUFZO0FBQ3hCO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGlGQUFpRixZQUFZO0FBQzdGO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsS0FBSztBQUNMO0FBQ0E7O0FBRUEsb0JBQW9CO0FBQ3BCLG1CQUFtQjtBQUNuQixxQkFBcUI7QUFDckIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy9zZXNzaW9uLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBtaXNjID0gcmVxdWlyZSgnLi91dGlscy9taXNjLmpzJyk7XG5jb25zdCB0aW1lID0gcmVxdWlyZSgnLi91dGlscy90aW1lLmpzJyk7XG5cbi8qKlxuICogQ3JlYXRlcyBhIG5ldyBgU2Vzc2lvbmAgb2JqZWN0IGJ5IHNldHRpbmcgY2VydGFpbiBkZWZhdWx0IHBhcmFtZXRlcnMuIElmIG9wdGlvbmFsIEBwYXJhbSBjb250ZXh0XG4gKiBpcyBwYXNzZWQsIHRoZSBwYXNzZWQgcHJvcGVydGllcyBhcmUgYXBwbGllZCB0byB0aGUgc2Vzc2lvbiBvYmplY3QuXG4gKlxuICogQHBhcmFtIGNvbnRleHQgKG9wdGlvbmFsKSBhZGRpdGlvbmFsIHByb3BlcnRpZXMgdG8gYmUgYXBwbGllZCB0byB0aGUgcmV0dXJuZWQgc2Vzc2lvbiBvYmplY3RcbiAqXG4gKiBAcmV0dXJucyBhIG5ldyBgU2Vzc2lvbmAgb2JqZWN0XG4gKi9cbmZ1bmN0aW9uIG1ha2VTZXNzaW9uKGNvbnRleHQpIHtcbiAgLy8gQm90aCB0aW1lc3RhbXAgYW5kIHN0YXJ0ZWQgYXJlIGluIHNlY29uZHMgc2luY2UgdGhlIFVOSVggZXBvY2guXG4gIGNvbnN0IHN0YXJ0aW5nVGltZSA9IHRpbWUudGltZXN0YW1wSW5TZWNvbmRzKCk7XG5cbiAgY29uc3Qgc2Vzc2lvbiA9IHtcbiAgICBzaWQ6IG1pc2MudXVpZDQoKSxcbiAgICBpbml0OiB0cnVlLFxuICAgIHRpbWVzdGFtcDogc3RhcnRpbmdUaW1lLFxuICAgIHN0YXJ0ZWQ6IHN0YXJ0aW5nVGltZSxcbiAgICBkdXJhdGlvbjogMCxcbiAgICBzdGF0dXM6ICdvaycsXG4gICAgZXJyb3JzOiAwLFxuICAgIGlnbm9yZUR1cmF0aW9uOiBmYWxzZSxcbiAgICB0b0pTT046ICgpID0+IHNlc3Npb25Ub0pTT04oc2Vzc2lvbiksXG4gIH07XG5cbiAgaWYgKGNvbnRleHQpIHtcbiAgICB1cGRhdGVTZXNzaW9uKHNlc3Npb24sIGNvbnRleHQpO1xuICB9XG5cbiAgcmV0dXJuIHNlc3Npb247XG59XG5cbi8qKlxuICogVXBkYXRlcyBhIHNlc3Npb24gb2JqZWN0IHdpdGggdGhlIHByb3BlcnRpZXMgcGFzc2VkIGluIHRoZSBjb250ZXh0LlxuICpcbiAqIE5vdGUgdGhhdCB0aGlzIGZ1bmN0aW9uIG11dGF0ZXMgdGhlIHBhc3NlZCBvYmplY3QgYW5kIHJldHVybnMgdm9pZC5cbiAqIChIYWQgdG8gZG8gdGhpcyBpbnN0ZWFkIG9mIHJldHVybmluZyBhIG5ldyBhbmQgdXBkYXRlZCBzZXNzaW9uIGJlY2F1c2UgY2xvc2luZyBhbmQgc2VuZGluZyBhIHNlc3Npb25cbiAqIG1ha2VzIGFuIHVwZGF0ZSB0byB0aGUgc2Vzc2lvbiBhZnRlciBpdCB3YXMgcGFzc2VkIHRvIHRoZSBzZW5kaW5nIGxvZ2ljLlxuICogQHNlZSBDbGllbnQuY2FwdHVyZVNlc3Npb24gKVxuICpcbiAqIEBwYXJhbSBzZXNzaW9uIHRoZSBgU2Vzc2lvbmAgdG8gdXBkYXRlXG4gKiBAcGFyYW0gY29udGV4dCB0aGUgYFNlc3Npb25Db250ZXh0YCBob2xkaW5nIHRoZSBwcm9wZXJ0aWVzIHRoYXQgc2hvdWxkIGJlIHVwZGF0ZWQgaW4gQHBhcmFtIHNlc3Npb25cbiAqL1xuLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIGNvbXBsZXhpdHlcbmZ1bmN0aW9uIHVwZGF0ZVNlc3Npb24oc2Vzc2lvbiwgY29udGV4dCA9IHt9KSB7XG4gIGlmIChjb250ZXh0LnVzZXIpIHtcbiAgICBpZiAoIXNlc3Npb24uaXBBZGRyZXNzICYmIGNvbnRleHQudXNlci5pcF9hZGRyZXNzKSB7XG4gICAgICBzZXNzaW9uLmlwQWRkcmVzcyA9IGNvbnRleHQudXNlci5pcF9hZGRyZXNzO1xuICAgIH1cblxuICAgIGlmICghc2Vzc2lvbi5kaWQgJiYgIWNvbnRleHQuZGlkKSB7XG4gICAgICBzZXNzaW9uLmRpZCA9IGNvbnRleHQudXNlci5pZCB8fCBjb250ZXh0LnVzZXIuZW1haWwgfHwgY29udGV4dC51c2VyLnVzZXJuYW1lO1xuICAgIH1cbiAgfVxuXG4gIHNlc3Npb24udGltZXN0YW1wID0gY29udGV4dC50aW1lc3RhbXAgfHwgdGltZS50aW1lc3RhbXBJblNlY29uZHMoKTtcblxuICBpZiAoY29udGV4dC5hYm5vcm1hbF9tZWNoYW5pc20pIHtcbiAgICBzZXNzaW9uLmFibm9ybWFsX21lY2hhbmlzbSA9IGNvbnRleHQuYWJub3JtYWxfbWVjaGFuaXNtO1xuICB9XG5cbiAgaWYgKGNvbnRleHQuaWdub3JlRHVyYXRpb24pIHtcbiAgICBzZXNzaW9uLmlnbm9yZUR1cmF0aW9uID0gY29udGV4dC5pZ25vcmVEdXJhdGlvbjtcbiAgfVxuICBpZiAoY29udGV4dC5zaWQpIHtcbiAgICAvLyBHb29kIGVub3VnaCB1dWlkIHZhbGlkYXRpb24uIOKAlCBLYW1pbFxuICAgIHNlc3Npb24uc2lkID0gY29udGV4dC5zaWQubGVuZ3RoID09PSAzMiA/IGNvbnRleHQuc2lkIDogbWlzYy51dWlkNCgpO1xuICB9XG4gIGlmIChjb250ZXh0LmluaXQgIT09IHVuZGVmaW5lZCkge1xuICAgIHNlc3Npb24uaW5pdCA9IGNvbnRleHQuaW5pdDtcbiAgfVxuICBpZiAoIXNlc3Npb24uZGlkICYmIGNvbnRleHQuZGlkKSB7XG4gICAgc2Vzc2lvbi5kaWQgPSBgJHtjb250ZXh0LmRpZH1gO1xuICB9XG4gIGlmICh0eXBlb2YgY29udGV4dC5zdGFydGVkID09PSAnbnVtYmVyJykge1xuICAgIHNlc3Npb24uc3RhcnRlZCA9IGNvbnRleHQuc3RhcnRlZDtcbiAgfVxuICBpZiAoc2Vzc2lvbi5pZ25vcmVEdXJhdGlvbikge1xuICAgIHNlc3Npb24uZHVyYXRpb24gPSB1bmRlZmluZWQ7XG4gIH0gZWxzZSBpZiAodHlwZW9mIGNvbnRleHQuZHVyYXRpb24gPT09ICdudW1iZXInKSB7XG4gICAgc2Vzc2lvbi5kdXJhdGlvbiA9IGNvbnRleHQuZHVyYXRpb247XG4gIH0gZWxzZSB7XG4gICAgY29uc3QgZHVyYXRpb24gPSBzZXNzaW9uLnRpbWVzdGFtcCAtIHNlc3Npb24uc3RhcnRlZDtcbiAgICBzZXNzaW9uLmR1cmF0aW9uID0gZHVyYXRpb24gPj0gMCA/IGR1cmF0aW9uIDogMDtcbiAgfVxuICBpZiAoY29udGV4dC5yZWxlYXNlKSB7XG4gICAgc2Vzc2lvbi5yZWxlYXNlID0gY29udGV4dC5yZWxlYXNlO1xuICB9XG4gIGlmIChjb250ZXh0LmVudmlyb25tZW50KSB7XG4gICAgc2Vzc2lvbi5lbnZpcm9ubWVudCA9IGNvbnRleHQuZW52aXJvbm1lbnQ7XG4gIH1cbiAgaWYgKCFzZXNzaW9uLmlwQWRkcmVzcyAmJiBjb250ZXh0LmlwQWRkcmVzcykge1xuICAgIHNlc3Npb24uaXBBZGRyZXNzID0gY29udGV4dC5pcEFkZHJlc3M7XG4gIH1cbiAgaWYgKCFzZXNzaW9uLnVzZXJBZ2VudCAmJiBjb250ZXh0LnVzZXJBZ2VudCkge1xuICAgIHNlc3Npb24udXNlckFnZW50ID0gY29udGV4dC51c2VyQWdlbnQ7XG4gIH1cbiAgaWYgKHR5cGVvZiBjb250ZXh0LmVycm9ycyA9PT0gJ251bWJlcicpIHtcbiAgICBzZXNzaW9uLmVycm9ycyA9IGNvbnRleHQuZXJyb3JzO1xuICB9XG4gIGlmIChjb250ZXh0LnN0YXR1cykge1xuICAgIHNlc3Npb24uc3RhdHVzID0gY29udGV4dC5zdGF0dXM7XG4gIH1cbn1cblxuLyoqXG4gKiBDbG9zZXMgYSBzZXNzaW9uIGJ5IHNldHRpbmcgaXRzIHN0YXR1cyBhbmQgdXBkYXRpbmcgdGhlIHNlc3Npb24gb2JqZWN0IHdpdGggaXQuXG4gKiBJbnRlcm5hbGx5IGNhbGxzIGB1cGRhdGVTZXNzaW9uYCB0byB1cGRhdGUgdGhlIHBhc3NlZCBzZXNzaW9uIG9iamVjdC5cbiAqXG4gKiBOb3RlIHRoYXQgdGhpcyBmdW5jdGlvbiBtdXRhdGVzIHRoZSBwYXNzZWQgc2Vzc2lvbiAoQHNlZSB1cGRhdGVTZXNzaW9uIGZvciBleHBsYW5hdGlvbikuXG4gKlxuICogQHBhcmFtIHNlc3Npb24gdGhlIGBTZXNzaW9uYCBvYmplY3QgdG8gYmUgY2xvc2VkXG4gKiBAcGFyYW0gc3RhdHVzIHRoZSBgU2Vzc2lvblN0YXR1c2Agd2l0aCB3aGljaCB0aGUgc2Vzc2lvbiB3YXMgY2xvc2VkLiBJZiB5b3UgZG9uJ3QgcGFzcyBhIHN0YXR1cyxcbiAqICAgICAgICAgICAgICAgdGhpcyBmdW5jdGlvbiB3aWxsIGtlZXAgdGhlIHByZXZpb3VzbHkgc2V0IHN0YXR1cywgdW5sZXNzIGl0IHdhcyBgJ29rJ2AgaW4gd2hpY2ggY2FzZVxuICogICAgICAgICAgICAgICBpdCBpcyBjaGFuZ2VkIHRvIGAnZXhpdGVkJ2AuXG4gKi9cbmZ1bmN0aW9uIGNsb3NlU2Vzc2lvbihzZXNzaW9uLCBzdGF0dXMpIHtcbiAgbGV0IGNvbnRleHQgPSB7fTtcbiAgaWYgKHN0YXR1cykge1xuICAgIGNvbnRleHQgPSB7IHN0YXR1cyB9O1xuICB9IGVsc2UgaWYgKHNlc3Npb24uc3RhdHVzID09PSAnb2snKSB7XG4gICAgY29udGV4dCA9IHsgc3RhdHVzOiAnZXhpdGVkJyB9O1xuICB9XG5cbiAgdXBkYXRlU2Vzc2lvbihzZXNzaW9uLCBjb250ZXh0KTtcbn1cblxuLyoqXG4gKiBTZXJpYWxpemVzIGEgcGFzc2VkIHNlc3Npb24gb2JqZWN0IHRvIGEgSlNPTiBvYmplY3Qgd2l0aCBhIHNsaWdodGx5IGRpZmZlcmVudCBzdHJ1Y3R1cmUuXG4gKiBUaGlzIGlzIG5lY2Vzc2FyeSBiZWNhdXNlIHRoZSBTZW50cnkgYmFja2VuZCByZXF1aXJlcyBhIHNsaWdodGx5IGRpZmZlcmVudCBzY2hlbWEgb2YgYSBzZXNzaW9uXG4gKiB0aGFuIHRoZSBvbmUgdGhlIEpTIFNES3MgdXNlIGludGVybmFsbHkuXG4gKlxuICogQHBhcmFtIHNlc3Npb24gdGhlIHNlc3Npb24gdG8gYmUgY29udmVydGVkXG4gKlxuICogQHJldHVybnMgYSBKU09OIG9iamVjdCBvZiB0aGUgcGFzc2VkIHNlc3Npb25cbiAqL1xuZnVuY3Rpb24gc2Vzc2lvblRvSlNPTihzZXNzaW9uKSB7XG4gIHJldHVybiB7XG4gICAgc2lkOiBgJHtzZXNzaW9uLnNpZH1gLFxuICAgIGluaXQ6IHNlc3Npb24uaW5pdCxcbiAgICAvLyBNYWtlIHN1cmUgdGhhdCBzZWMgaXMgY29udmVydGVkIHRvIG1zIGZvciBkYXRlIGNvbnN0cnVjdG9yXG4gICAgc3RhcnRlZDogbmV3IERhdGUoc2Vzc2lvbi5zdGFydGVkICogMTAwMCkudG9JU09TdHJpbmcoKSxcbiAgICB0aW1lc3RhbXA6IG5ldyBEYXRlKHNlc3Npb24udGltZXN0YW1wICogMTAwMCkudG9JU09TdHJpbmcoKSxcbiAgICBzdGF0dXM6IHNlc3Npb24uc3RhdHVzLFxuICAgIGVycm9yczogc2Vzc2lvbi5lcnJvcnMsXG4gICAgZGlkOiB0eXBlb2Ygc2Vzc2lvbi5kaWQgPT09ICdudW1iZXInIHx8IHR5cGVvZiBzZXNzaW9uLmRpZCA9PT0gJ3N0cmluZycgPyBgJHtzZXNzaW9uLmRpZH1gIDogdW5kZWZpbmVkLFxuICAgIGR1cmF0aW9uOiBzZXNzaW9uLmR1cmF0aW9uLFxuICAgIGFibm9ybWFsX21lY2hhbmlzbTogc2Vzc2lvbi5hYm5vcm1hbF9tZWNoYW5pc20sXG4gICAgYXR0cnM6IHtcbiAgICAgIHJlbGVhc2U6IHNlc3Npb24ucmVsZWFzZSxcbiAgICAgIGVudmlyb25tZW50OiBzZXNzaW9uLmVudmlyb25tZW50LFxuICAgICAgaXBfYWRkcmVzczogc2Vzc2lvbi5pcEFkZHJlc3MsXG4gICAgICB1c2VyX2FnZW50OiBzZXNzaW9uLnVzZXJBZ2VudCxcbiAgICB9LFxuICB9O1xufVxuXG5leHBvcnRzLmNsb3NlU2Vzc2lvbiA9IGNsb3NlU2Vzc2lvbjtcbmV4cG9ydHMubWFrZVNlc3Npb24gPSBtYWtlU2Vzc2lvbjtcbmV4cG9ydHMudXBkYXRlU2Vzc2lvbiA9IHVwZGF0ZVNlc3Npb247XG4vLyMgc291cmNlTWFwcGluZ1VSTD1zZXNzaW9uLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/session.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/dynamicSamplingContext.js":
/*!**********************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/dynamicSamplingContext.js ***!
  \**********************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst constants = __webpack_require__(/*! ../constants.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/constants.js\");\nconst currentScopes = __webpack_require__(/*! ../currentScopes.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst semanticAttributes = __webpack_require__(/*! ../semanticAttributes.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/semanticAttributes.js\");\nconst baggage = __webpack_require__(/*! ../utils/baggage.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/baggage.js\");\nconst dsn = __webpack_require__(/*! ../utils/dsn.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/dsn.js\");\nconst hasSpansEnabled = __webpack_require__(/*! ../utils/hasSpansEnabled.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/hasSpansEnabled.js\");\nconst object = __webpack_require__(/*! ../utils/object.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/object.js\");\nconst spanUtils = __webpack_require__(/*! ../utils/spanUtils.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanUtils.js\");\nconst utils = __webpack_require__(/*! ./utils.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/utils.js\");\n\n/**\n * If you change this value, also update the terser plugin config to\n * avoid minification of the object property!\n */\nconst FROZEN_DSC_FIELD = '_frozenDsc';\n\n/**\n * Freeze the given DSC on the given span.\n */\nfunction freezeDscOnSpan(span, dsc) {\n  const spanWithMaybeDsc = span ;\n  object.addNonEnumerableProperty(spanWithMaybeDsc, FROZEN_DSC_FIELD, dsc);\n}\n\n/**\n * Creates a dynamic sampling context from a client.\n *\n * Dispatches the `createDsc` lifecycle hook as a side effect.\n */\nfunction getDynamicSamplingContextFromClient(trace_id, client) {\n  const options = client.getOptions();\n\n  const { publicKey: public_key, host } = client.getDsn() || {};\n\n  let org_id;\n  if (options.orgId) {\n    org_id = String(options.orgId);\n  } else if (host) {\n    org_id = dsn.extractOrgIdFromDsnHost(host);\n  }\n\n  // Instead of conditionally adding non-undefined values, we add them and then remove them if needed\n  // otherwise, the order of baggage entries changes, which \"breaks\" a bunch of tests etc.\n  const dsc = {\n    environment: options.environment || constants.DEFAULT_ENVIRONMENT,\n    release: options.release,\n    public_key,\n    trace_id,\n    org_id,\n  };\n\n  client.emit('createDsc', dsc);\n\n  return dsc;\n}\n\n/**\n * Get the dynamic sampling context for the currently active scopes.\n */\nfunction getDynamicSamplingContextFromScope(client, scope) {\n  const propagationContext = scope.getPropagationContext();\n  return propagationContext.dsc || getDynamicSamplingContextFromClient(propagationContext.traceId, client);\n}\n\n/**\n * Creates a dynamic sampling context from a span (and client and scope)\n *\n * @param span the span from which a few values like the root span name and sample rate are extracted.\n *\n * @returns a dynamic sampling context\n */\nfunction getDynamicSamplingContextFromSpan(span) {\n  const client = currentScopes.getClient();\n  if (!client) {\n    return {};\n  }\n\n  const rootSpan = spanUtils.getRootSpan(span);\n  const rootSpanJson = spanUtils.spanToJSON(rootSpan);\n  const rootSpanAttributes = rootSpanJson.data;\n  const traceState = rootSpan.spanContext().traceState;\n\n  // The span sample rate that was locally applied to the root span should also always be applied to the DSC, even if the DSC is frozen.\n  // This is so that the downstream traces/services can use parentSampleRate in their `tracesSampler` to make consistent sampling decisions across the entire trace.\n  const rootSpanSampleRate =\n    traceState?.get('sentry.sample_rate') ??\n    rootSpanAttributes[semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_SAMPLE_RATE] ??\n    rootSpanAttributes[semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_PREVIOUS_TRACE_SAMPLE_RATE];\n\n  function applyLocalSampleRateToDsc(dsc) {\n    if (typeof rootSpanSampleRate === 'number' || typeof rootSpanSampleRate === 'string') {\n      dsc.sample_rate = `${rootSpanSampleRate}`;\n    }\n    return dsc;\n  }\n\n  // For core implementation, we freeze the DSC onto the span as a non-enumerable property\n  const frozenDsc = (rootSpan )[FROZEN_DSC_FIELD];\n  if (frozenDsc) {\n    return applyLocalSampleRateToDsc(frozenDsc);\n  }\n\n  // For OpenTelemetry, we freeze the DSC on the trace state\n  const traceStateDsc = traceState?.get('sentry.dsc');\n\n  // If the span has a DSC, we want it to take precedence\n  const dscOnTraceState = traceStateDsc && baggage.baggageHeaderToDynamicSamplingContext(traceStateDsc);\n\n  if (dscOnTraceState) {\n    return applyLocalSampleRateToDsc(dscOnTraceState);\n  }\n\n  // Else, we generate it from the span\n  const dsc = getDynamicSamplingContextFromClient(span.spanContext().traceId, client);\n\n  // We don't want to have a transaction name in the DSC if the source is \"url\" because URLs might contain PII\n  const source = rootSpanAttributes[semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_SOURCE];\n\n  // after JSON conversion, txn.name becomes jsonSpan.description\n  const name = rootSpanJson.description;\n  if (source !== 'url' && name) {\n    dsc.transaction = name;\n  }\n\n  // How can we even land here with hasSpansEnabled() returning false?\n  // Otel creates a Non-recording span in Tracing Without Performance mode when handling incoming requests\n  // So we end up with an active span that is not sampled (neither positively nor negatively)\n  if (hasSpansEnabled.hasSpansEnabled()) {\n    dsc.sampled = String(spanUtils.spanIsSampled(rootSpan));\n    dsc.sample_rand =\n      // In OTEL we store the sample rand on the trace state because we cannot access scopes for NonRecordingSpans\n      // The Sentry OTEL SpanSampler takes care of writing the sample rand on the root span\n      traceState?.get('sentry.sample_rand') ??\n      // On all other platforms we can actually get the scopes from a root span (we use this as a fallback)\n      utils.getCapturedScopesOnSpan(rootSpan).scope?.getPropagationContext().sampleRand.toString();\n  }\n\n  applyLocalSampleRateToDsc(dsc);\n\n  client.emit('createDsc', dsc, rootSpan);\n\n  return dsc;\n}\n\n/**\n * Convert a Span to a baggage header.\n */\nfunction spanToBaggageHeader(span) {\n  const dsc = getDynamicSamplingContextFromSpan(span);\n  return baggage.dynamicSamplingContextToSentryBaggageHeader(dsc);\n}\n\nexports.freezeDscOnSpan = freezeDscOnSpan;\nexports.getDynamicSamplingContextFromClient = getDynamicSamplingContextFromClient;\nexports.getDynamicSamplingContextFromScope = getDynamicSamplingContextFromScope;\nexports.getDynamicSamplingContextFromSpan = getDynamicSamplingContextFromSpan;\nexports.spanToBaggageHeader = spanToBaggageHeader;\n//# sourceMappingURL=dynamicSamplingContext.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy90cmFjaW5nL2R5bmFtaWNTYW1wbGluZ0NvbnRleHQuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsa0JBQWtCLG1CQUFPLENBQUMsd0hBQWlCO0FBQzNDLHNCQUFzQixtQkFBTyxDQUFDLGdJQUFxQjtBQUNuRCwyQkFBMkIsbUJBQU8sQ0FBQywwSUFBMEI7QUFDN0QsZ0JBQWdCLG1CQUFPLENBQUMsZ0lBQXFCO0FBQzdDLFlBQVksbUJBQU8sQ0FBQyx3SEFBaUI7QUFDckMsd0JBQXdCLG1CQUFPLENBQUMsZ0pBQTZCO0FBQzdELGVBQWUsbUJBQU8sQ0FBQyw4SEFBb0I7QUFDM0Msa0JBQWtCLG1CQUFPLENBQUMsb0lBQXVCO0FBQ2pELGNBQWMsbUJBQU8sQ0FBQyx1SEFBWTs7QUFFbEM7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSxVQUFVLDhCQUE4Qjs7QUFFeEM7QUFDQTtBQUNBO0FBQ0EsSUFBSTtBQUNKO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsMkJBQTJCLG1CQUFtQjtBQUM5QztBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLHVCQUF1QjtBQUN2QiwyQ0FBMkM7QUFDM0MsMENBQTBDO0FBQzFDLHlDQUF5QztBQUN6QywyQkFBMkI7QUFDM0IiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy90cmFjaW5nL2R5bmFtaWNTYW1wbGluZ0NvbnRleHQuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGNvbnN0YW50cyA9IHJlcXVpcmUoJy4uL2NvbnN0YW50cy5qcycpO1xuY29uc3QgY3VycmVudFNjb3BlcyA9IHJlcXVpcmUoJy4uL2N1cnJlbnRTY29wZXMuanMnKTtcbmNvbnN0IHNlbWFudGljQXR0cmlidXRlcyA9IHJlcXVpcmUoJy4uL3NlbWFudGljQXR0cmlidXRlcy5qcycpO1xuY29uc3QgYmFnZ2FnZSA9IHJlcXVpcmUoJy4uL3V0aWxzL2JhZ2dhZ2UuanMnKTtcbmNvbnN0IGRzbiA9IHJlcXVpcmUoJy4uL3V0aWxzL2Rzbi5qcycpO1xuY29uc3QgaGFzU3BhbnNFbmFibGVkID0gcmVxdWlyZSgnLi4vdXRpbHMvaGFzU3BhbnNFbmFibGVkLmpzJyk7XG5jb25zdCBvYmplY3QgPSByZXF1aXJlKCcuLi91dGlscy9vYmplY3QuanMnKTtcbmNvbnN0IHNwYW5VdGlscyA9IHJlcXVpcmUoJy4uL3V0aWxzL3NwYW5VdGlscy5qcycpO1xuY29uc3QgdXRpbHMgPSByZXF1aXJlKCcuL3V0aWxzLmpzJyk7XG5cbi8qKlxuICogSWYgeW91IGNoYW5nZSB0aGlzIHZhbHVlLCBhbHNvIHVwZGF0ZSB0aGUgdGVyc2VyIHBsdWdpbiBjb25maWcgdG9cbiAqIGF2b2lkIG1pbmlmaWNhdGlvbiBvZiB0aGUgb2JqZWN0IHByb3BlcnR5IVxuICovXG5jb25zdCBGUk9aRU5fRFNDX0ZJRUxEID0gJ19mcm96ZW5Ec2MnO1xuXG4vKipcbiAqIEZyZWV6ZSB0aGUgZ2l2ZW4gRFNDIG9uIHRoZSBnaXZlbiBzcGFuLlxuICovXG5mdW5jdGlvbiBmcmVlemVEc2NPblNwYW4oc3BhbiwgZHNjKSB7XG4gIGNvbnN0IHNwYW5XaXRoTWF5YmVEc2MgPSBzcGFuIDtcbiAgb2JqZWN0LmFkZE5vbkVudW1lcmFibGVQcm9wZXJ0eShzcGFuV2l0aE1heWJlRHNjLCBGUk9aRU5fRFNDX0ZJRUxELCBkc2MpO1xufVxuXG4vKipcbiAqIENyZWF0ZXMgYSBkeW5hbWljIHNhbXBsaW5nIGNvbnRleHQgZnJvbSBhIGNsaWVudC5cbiAqXG4gKiBEaXNwYXRjaGVzIHRoZSBgY3JlYXRlRHNjYCBsaWZlY3ljbGUgaG9vayBhcyBhIHNpZGUgZWZmZWN0LlxuICovXG5mdW5jdGlvbiBnZXREeW5hbWljU2FtcGxpbmdDb250ZXh0RnJvbUNsaWVudCh0cmFjZV9pZCwgY2xpZW50KSB7XG4gIGNvbnN0IG9wdGlvbnMgPSBjbGllbnQuZ2V0T3B0aW9ucygpO1xuXG4gIGNvbnN0IHsgcHVibGljS2V5OiBwdWJsaWNfa2V5LCBob3N0IH0gPSBjbGllbnQuZ2V0RHNuKCkgfHwge307XG5cbiAgbGV0IG9yZ19pZDtcbiAgaWYgKG9wdGlvbnMub3JnSWQpIHtcbiAgICBvcmdfaWQgPSBTdHJpbmcob3B0aW9ucy5vcmdJZCk7XG4gIH0gZWxzZSBpZiAoaG9zdCkge1xuICAgIG9yZ19pZCA9IGRzbi5leHRyYWN0T3JnSWRGcm9tRHNuSG9zdChob3N0KTtcbiAgfVxuXG4gIC8vIEluc3RlYWQgb2YgY29uZGl0aW9uYWxseSBhZGRpbmcgbm9uLXVuZGVmaW5lZCB2YWx1ZXMsIHdlIGFkZCB0aGVtIGFuZCB0aGVuIHJlbW92ZSB0aGVtIGlmIG5lZWRlZFxuICAvLyBvdGhlcndpc2UsIHRoZSBvcmRlciBvZiBiYWdnYWdlIGVudHJpZXMgY2hhbmdlcywgd2hpY2ggXCJicmVha3NcIiBhIGJ1bmNoIG9mIHRlc3RzIGV0Yy5cbiAgY29uc3QgZHNjID0ge1xuICAgIGVudmlyb25tZW50OiBvcHRpb25zLmVudmlyb25tZW50IHx8IGNvbnN0YW50cy5ERUZBVUxUX0VOVklST05NRU5ULFxuICAgIHJlbGVhc2U6IG9wdGlvbnMucmVsZWFzZSxcbiAgICBwdWJsaWNfa2V5LFxuICAgIHRyYWNlX2lkLFxuICAgIG9yZ19pZCxcbiAgfTtcblxuICBjbGllbnQuZW1pdCgnY3JlYXRlRHNjJywgZHNjKTtcblxuICByZXR1cm4gZHNjO1xufVxuXG4vKipcbiAqIEdldCB0aGUgZHluYW1pYyBzYW1wbGluZyBjb250ZXh0IGZvciB0aGUgY3VycmVudGx5IGFjdGl2ZSBzY29wZXMuXG4gKi9cbmZ1bmN0aW9uIGdldER5bmFtaWNTYW1wbGluZ0NvbnRleHRGcm9tU2NvcGUoY2xpZW50LCBzY29wZSkge1xuICBjb25zdCBwcm9wYWdhdGlvbkNvbnRleHQgPSBzY29wZS5nZXRQcm9wYWdhdGlvbkNvbnRleHQoKTtcbiAgcmV0dXJuIHByb3BhZ2F0aW9uQ29udGV4dC5kc2MgfHwgZ2V0RHluYW1pY1NhbXBsaW5nQ29udGV4dEZyb21DbGllbnQocHJvcGFnYXRpb25Db250ZXh0LnRyYWNlSWQsIGNsaWVudCk7XG59XG5cbi8qKlxuICogQ3JlYXRlcyBhIGR5bmFtaWMgc2FtcGxpbmcgY29udGV4dCBmcm9tIGEgc3BhbiAoYW5kIGNsaWVudCBhbmQgc2NvcGUpXG4gKlxuICogQHBhcmFtIHNwYW4gdGhlIHNwYW4gZnJvbSB3aGljaCBhIGZldyB2YWx1ZXMgbGlrZSB0aGUgcm9vdCBzcGFuIG5hbWUgYW5kIHNhbXBsZSByYXRlIGFyZSBleHRyYWN0ZWQuXG4gKlxuICogQHJldHVybnMgYSBkeW5hbWljIHNhbXBsaW5nIGNvbnRleHRcbiAqL1xuZnVuY3Rpb24gZ2V0RHluYW1pY1NhbXBsaW5nQ29udGV4dEZyb21TcGFuKHNwYW4pIHtcbiAgY29uc3QgY2xpZW50ID0gY3VycmVudFNjb3Blcy5nZXRDbGllbnQoKTtcbiAgaWYgKCFjbGllbnQpIHtcbiAgICByZXR1cm4ge307XG4gIH1cblxuICBjb25zdCByb290U3BhbiA9IHNwYW5VdGlscy5nZXRSb290U3BhbihzcGFuKTtcbiAgY29uc3Qgcm9vdFNwYW5Kc29uID0gc3BhblV0aWxzLnNwYW5Ub0pTT04ocm9vdFNwYW4pO1xuICBjb25zdCByb290U3BhbkF0dHJpYnV0ZXMgPSByb290U3Bhbkpzb24uZGF0YTtcbiAgY29uc3QgdHJhY2VTdGF0ZSA9IHJvb3RTcGFuLnNwYW5Db250ZXh0KCkudHJhY2VTdGF0ZTtcblxuICAvLyBUaGUgc3BhbiBzYW1wbGUgcmF0ZSB0aGF0IHdhcyBsb2NhbGx5IGFwcGxpZWQgdG8gdGhlIHJvb3Qgc3BhbiBzaG91bGQgYWxzbyBhbHdheXMgYmUgYXBwbGllZCB0byB0aGUgRFNDLCBldmVuIGlmIHRoZSBEU0MgaXMgZnJvemVuLlxuICAvLyBUaGlzIGlzIHNvIHRoYXQgdGhlIGRvd25zdHJlYW0gdHJhY2VzL3NlcnZpY2VzIGNhbiB1c2UgcGFyZW50U2FtcGxlUmF0ZSBpbiB0aGVpciBgdHJhY2VzU2FtcGxlcmAgdG8gbWFrZSBjb25zaXN0ZW50IHNhbXBsaW5nIGRlY2lzaW9ucyBhY3Jvc3MgdGhlIGVudGlyZSB0cmFjZS5cbiAgY29uc3Qgcm9vdFNwYW5TYW1wbGVSYXRlID1cbiAgICB0cmFjZVN0YXRlPy5nZXQoJ3NlbnRyeS5zYW1wbGVfcmF0ZScpID8/XG4gICAgcm9vdFNwYW5BdHRyaWJ1dGVzW3NlbWFudGljQXR0cmlidXRlcy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX1NBTVBMRV9SQVRFXSA/P1xuICAgIHJvb3RTcGFuQXR0cmlidXRlc1tzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9QUkVWSU9VU19UUkFDRV9TQU1QTEVfUkFURV07XG5cbiAgZnVuY3Rpb24gYXBwbHlMb2NhbFNhbXBsZVJhdGVUb0RzYyhkc2MpIHtcbiAgICBpZiAodHlwZW9mIHJvb3RTcGFuU2FtcGxlUmF0ZSA9PT0gJ251bWJlcicgfHwgdHlwZW9mIHJvb3RTcGFuU2FtcGxlUmF0ZSA9PT0gJ3N0cmluZycpIHtcbiAgICAgIGRzYy5zYW1wbGVfcmF0ZSA9IGAke3Jvb3RTcGFuU2FtcGxlUmF0ZX1gO1xuICAgIH1cbiAgICByZXR1cm4gZHNjO1xuICB9XG5cbiAgLy8gRm9yIGNvcmUgaW1wbGVtZW50YXRpb24sIHdlIGZyZWV6ZSB0aGUgRFNDIG9udG8gdGhlIHNwYW4gYXMgYSBub24tZW51bWVyYWJsZSBwcm9wZXJ0eVxuICBjb25zdCBmcm96ZW5Ec2MgPSAocm9vdFNwYW4gKVtGUk9aRU5fRFNDX0ZJRUxEXTtcbiAgaWYgKGZyb3plbkRzYykge1xuICAgIHJldHVybiBhcHBseUxvY2FsU2FtcGxlUmF0ZVRvRHNjKGZyb3plbkRzYyk7XG4gIH1cblxuICAvLyBGb3IgT3BlblRlbGVtZXRyeSwgd2UgZnJlZXplIHRoZSBEU0Mgb24gdGhlIHRyYWNlIHN0YXRlXG4gIGNvbnN0IHRyYWNlU3RhdGVEc2MgPSB0cmFjZVN0YXRlPy5nZXQoJ3NlbnRyeS5kc2MnKTtcblxuICAvLyBJZiB0aGUgc3BhbiBoYXMgYSBEU0MsIHdlIHdhbnQgaXQgdG8gdGFrZSBwcmVjZWRlbmNlXG4gIGNvbnN0IGRzY09uVHJhY2VTdGF0ZSA9IHRyYWNlU3RhdGVEc2MgJiYgYmFnZ2FnZS5iYWdnYWdlSGVhZGVyVG9EeW5hbWljU2FtcGxpbmdDb250ZXh0KHRyYWNlU3RhdGVEc2MpO1xuXG4gIGlmIChkc2NPblRyYWNlU3RhdGUpIHtcbiAgICByZXR1cm4gYXBwbHlMb2NhbFNhbXBsZVJhdGVUb0RzYyhkc2NPblRyYWNlU3RhdGUpO1xuICB9XG5cbiAgLy8gRWxzZSwgd2UgZ2VuZXJhdGUgaXQgZnJvbSB0aGUgc3BhblxuICBjb25zdCBkc2MgPSBnZXREeW5hbWljU2FtcGxpbmdDb250ZXh0RnJvbUNsaWVudChzcGFuLnNwYW5Db250ZXh0KCkudHJhY2VJZCwgY2xpZW50KTtcblxuICAvLyBXZSBkb24ndCB3YW50IHRvIGhhdmUgYSB0cmFuc2FjdGlvbiBuYW1lIGluIHRoZSBEU0MgaWYgdGhlIHNvdXJjZSBpcyBcInVybFwiIGJlY2F1c2UgVVJMcyBtaWdodCBjb250YWluIFBJSVxuICBjb25zdCBzb3VyY2UgPSByb290U3BhbkF0dHJpYnV0ZXNbc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfU09VUkNFXTtcblxuICAvLyBhZnRlciBKU09OIGNvbnZlcnNpb24sIHR4bi5uYW1lIGJlY29tZXMganNvblNwYW4uZGVzY3JpcHRpb25cbiAgY29uc3QgbmFtZSA9IHJvb3RTcGFuSnNvbi5kZXNjcmlwdGlvbjtcbiAgaWYgKHNvdXJjZSAhPT0gJ3VybCcgJiYgbmFtZSkge1xuICAgIGRzYy50cmFuc2FjdGlvbiA9IG5hbWU7XG4gIH1cblxuICAvLyBIb3cgY2FuIHdlIGV2ZW4gbGFuZCBoZXJlIHdpdGggaGFzU3BhbnNFbmFibGVkKCkgcmV0dXJuaW5nIGZhbHNlP1xuICAvLyBPdGVsIGNyZWF0ZXMgYSBOb24tcmVjb3JkaW5nIHNwYW4gaW4gVHJhY2luZyBXaXRob3V0IFBlcmZvcm1hbmNlIG1vZGUgd2hlbiBoYW5kbGluZyBpbmNvbWluZyByZXF1ZXN0c1xuICAvLyBTbyB3ZSBlbmQgdXAgd2l0aCBhbiBhY3RpdmUgc3BhbiB0aGF0IGlzIG5vdCBzYW1wbGVkIChuZWl0aGVyIHBvc2l0aXZlbHkgbm9yIG5lZ2F0aXZlbHkpXG4gIGlmIChoYXNTcGFuc0VuYWJsZWQuaGFzU3BhbnNFbmFibGVkKCkpIHtcbiAgICBkc2Muc2FtcGxlZCA9IFN0cmluZyhzcGFuVXRpbHMuc3BhbklzU2FtcGxlZChyb290U3BhbikpO1xuICAgIGRzYy5zYW1wbGVfcmFuZCA9XG4gICAgICAvLyBJbiBPVEVMIHdlIHN0b3JlIHRoZSBzYW1wbGUgcmFuZCBvbiB0aGUgdHJhY2Ugc3RhdGUgYmVjYXVzZSB3ZSBjYW5ub3QgYWNjZXNzIHNjb3BlcyBmb3IgTm9uUmVjb3JkaW5nU3BhbnNcbiAgICAgIC8vIFRoZSBTZW50cnkgT1RFTCBTcGFuU2FtcGxlciB0YWtlcyBjYXJlIG9mIHdyaXRpbmcgdGhlIHNhbXBsZSByYW5kIG9uIHRoZSByb290IHNwYW5cbiAgICAgIHRyYWNlU3RhdGU/LmdldCgnc2VudHJ5LnNhbXBsZV9yYW5kJykgPz9cbiAgICAgIC8vIE9uIGFsbCBvdGhlciBwbGF0Zm9ybXMgd2UgY2FuIGFjdHVhbGx5IGdldCB0aGUgc2NvcGVzIGZyb20gYSByb290IHNwYW4gKHdlIHVzZSB0aGlzIGFzIGEgZmFsbGJhY2spXG4gICAgICB1dGlscy5nZXRDYXB0dXJlZFNjb3Blc09uU3Bhbihyb290U3Bhbikuc2NvcGU/LmdldFByb3BhZ2F0aW9uQ29udGV4dCgpLnNhbXBsZVJhbmQudG9TdHJpbmcoKTtcbiAgfVxuXG4gIGFwcGx5TG9jYWxTYW1wbGVSYXRlVG9Ec2MoZHNjKTtcblxuICBjbGllbnQuZW1pdCgnY3JlYXRlRHNjJywgZHNjLCByb290U3Bhbik7XG5cbiAgcmV0dXJuIGRzYztcbn1cblxuLyoqXG4gKiBDb252ZXJ0IGEgU3BhbiB0byBhIGJhZ2dhZ2UgaGVhZGVyLlxuICovXG5mdW5jdGlvbiBzcGFuVG9CYWdnYWdlSGVhZGVyKHNwYW4pIHtcbiAgY29uc3QgZHNjID0gZ2V0RHluYW1pY1NhbXBsaW5nQ29udGV4dEZyb21TcGFuKHNwYW4pO1xuICByZXR1cm4gYmFnZ2FnZS5keW5hbWljU2FtcGxpbmdDb250ZXh0VG9TZW50cnlCYWdnYWdlSGVhZGVyKGRzYyk7XG59XG5cbmV4cG9ydHMuZnJlZXplRHNjT25TcGFuID0gZnJlZXplRHNjT25TcGFuO1xuZXhwb3J0cy5nZXREeW5hbWljU2FtcGxpbmdDb250ZXh0RnJvbUNsaWVudCA9IGdldER5bmFtaWNTYW1wbGluZ0NvbnRleHRGcm9tQ2xpZW50O1xuZXhwb3J0cy5nZXREeW5hbWljU2FtcGxpbmdDb250ZXh0RnJvbVNjb3BlID0gZ2V0RHluYW1pY1NhbXBsaW5nQ29udGV4dEZyb21TY29wZTtcbmV4cG9ydHMuZ2V0RHluYW1pY1NhbXBsaW5nQ29udGV4dEZyb21TcGFuID0gZ2V0RHluYW1pY1NhbXBsaW5nQ29udGV4dEZyb21TcGFuO1xuZXhwb3J0cy5zcGFuVG9CYWdnYWdlSGVhZGVyID0gc3BhblRvQmFnZ2FnZUhlYWRlcjtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWR5bmFtaWNTYW1wbGluZ0NvbnRleHQuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/dynamicSamplingContext.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/errors.js":
/*!******************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/errors.js ***!
  \******************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst debugBuild = __webpack_require__(/*! ../debug-build.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst globalError = __webpack_require__(/*! ../instrument/globalError.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/globalError.js\");\nconst globalUnhandledRejection = __webpack_require__(/*! ../instrument/globalUnhandledRejection.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/instrument/globalUnhandledRejection.js\");\nconst debugLogger = __webpack_require__(/*! ../utils/debug-logger.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst spanUtils = __webpack_require__(/*! ../utils/spanUtils.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanUtils.js\");\nconst spanstatus = __webpack_require__(/*! ./spanstatus.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/spanstatus.js\");\n\nlet errorsInstrumented = false;\n\n/**\n * Ensure that global errors automatically set the active span status.\n */\nfunction registerSpanErrorInstrumentation() {\n  if (errorsInstrumented) {\n    return;\n  }\n\n  /**\n   * If an error or unhandled promise occurs, we mark the active root span as failed\n   */\n  function errorCallback() {\n    const activeSpan = spanUtils.getActiveSpan();\n    const rootSpan = activeSpan && spanUtils.getRootSpan(activeSpan);\n    if (rootSpan) {\n      const message = 'internal_error';\n      debugBuild.DEBUG_BUILD && debugLogger.debug.log(`[Tracing] Root span: ${message} -> Global error occurred`);\n      rootSpan.setStatus({ code: spanstatus.SPAN_STATUS_ERROR, message });\n    }\n  }\n\n  // The function name will be lost when bundling but we need to be able to identify this listener later to maintain the\n  // node.js default exit behaviour\n  errorCallback.tag = 'sentry_tracingErrorCallback';\n\n  errorsInstrumented = true;\n  globalError.addGlobalErrorInstrumentationHandler(errorCallback);\n  globalUnhandledRejection.addGlobalUnhandledRejectionInstrumentationHandler(errorCallback);\n}\n\nexports.registerSpanErrorInstrumentation = registerSpanErrorInstrumentation;\n//# sourceMappingURL=errors.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy90cmFjaW5nL2Vycm9ycy5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxtQkFBbUIsbUJBQU8sQ0FBQyw0SEFBbUI7QUFDOUMsb0JBQW9CLG1CQUFPLENBQUMsa0pBQThCO0FBQzFELGlDQUFpQyxtQkFBTyxDQUFDLDRLQUEyQztBQUNwRixvQkFBb0IsbUJBQU8sQ0FBQywwSUFBMEI7QUFDdEQsa0JBQWtCLG1CQUFPLENBQUMsb0lBQXVCO0FBQ2pELG1CQUFtQixtQkFBTyxDQUFDLGlJQUFpQjs7QUFFNUM7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLDhFQUE4RSxTQUFTO0FBQ3ZGLDJCQUEyQiw2Q0FBNkM7QUFDeEU7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsd0NBQXdDO0FBQ3hDIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdHJhY2luZy9lcnJvcnMuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGRlYnVnQnVpbGQgPSByZXF1aXJlKCcuLi9kZWJ1Zy1idWlsZC5qcycpO1xuY29uc3QgZ2xvYmFsRXJyb3IgPSByZXF1aXJlKCcuLi9pbnN0cnVtZW50L2dsb2JhbEVycm9yLmpzJyk7XG5jb25zdCBnbG9iYWxVbmhhbmRsZWRSZWplY3Rpb24gPSByZXF1aXJlKCcuLi9pbnN0cnVtZW50L2dsb2JhbFVuaGFuZGxlZFJlamVjdGlvbi5qcycpO1xuY29uc3QgZGVidWdMb2dnZXIgPSByZXF1aXJlKCcuLi91dGlscy9kZWJ1Zy1sb2dnZXIuanMnKTtcbmNvbnN0IHNwYW5VdGlscyA9IHJlcXVpcmUoJy4uL3V0aWxzL3NwYW5VdGlscy5qcycpO1xuY29uc3Qgc3BhbnN0YXR1cyA9IHJlcXVpcmUoJy4vc3BhbnN0YXR1cy5qcycpO1xuXG5sZXQgZXJyb3JzSW5zdHJ1bWVudGVkID0gZmFsc2U7XG5cbi8qKlxuICogRW5zdXJlIHRoYXQgZ2xvYmFsIGVycm9ycyBhdXRvbWF0aWNhbGx5IHNldCB0aGUgYWN0aXZlIHNwYW4gc3RhdHVzLlxuICovXG5mdW5jdGlvbiByZWdpc3RlclNwYW5FcnJvckluc3RydW1lbnRhdGlvbigpIHtcbiAgaWYgKGVycm9yc0luc3RydW1lbnRlZCkge1xuICAgIHJldHVybjtcbiAgfVxuXG4gIC8qKlxuICAgKiBJZiBhbiBlcnJvciBvciB1bmhhbmRsZWQgcHJvbWlzZSBvY2N1cnMsIHdlIG1hcmsgdGhlIGFjdGl2ZSByb290IHNwYW4gYXMgZmFpbGVkXG4gICAqL1xuICBmdW5jdGlvbiBlcnJvckNhbGxiYWNrKCkge1xuICAgIGNvbnN0IGFjdGl2ZVNwYW4gPSBzcGFuVXRpbHMuZ2V0QWN0aXZlU3BhbigpO1xuICAgIGNvbnN0IHJvb3RTcGFuID0gYWN0aXZlU3BhbiAmJiBzcGFuVXRpbHMuZ2V0Um9vdFNwYW4oYWN0aXZlU3Bhbik7XG4gICAgaWYgKHJvb3RTcGFuKSB7XG4gICAgICBjb25zdCBtZXNzYWdlID0gJ2ludGVybmFsX2Vycm9yJztcbiAgICAgIGRlYnVnQnVpbGQuREVCVUdfQlVJTEQgJiYgZGVidWdMb2dnZXIuZGVidWcubG9nKGBbVHJhY2luZ10gUm9vdCBzcGFuOiAke21lc3NhZ2V9IC0+IEdsb2JhbCBlcnJvciBvY2N1cnJlZGApO1xuICAgICAgcm9vdFNwYW4uc2V0U3RhdHVzKHsgY29kZTogc3BhbnN0YXR1cy5TUEFOX1NUQVRVU19FUlJPUiwgbWVzc2FnZSB9KTtcbiAgICB9XG4gIH1cblxuICAvLyBUaGUgZnVuY3Rpb24gbmFtZSB3aWxsIGJlIGxvc3Qgd2hlbiBidW5kbGluZyBidXQgd2UgbmVlZCB0byBiZSBhYmxlIHRvIGlkZW50aWZ5IHRoaXMgbGlzdGVuZXIgbGF0ZXIgdG8gbWFpbnRhaW4gdGhlXG4gIC8vIG5vZGUuanMgZGVmYXVsdCBleGl0IGJlaGF2aW91clxuICBlcnJvckNhbGxiYWNrLnRhZyA9ICdzZW50cnlfdHJhY2luZ0Vycm9yQ2FsbGJhY2snO1xuXG4gIGVycm9yc0luc3RydW1lbnRlZCA9IHRydWU7XG4gIGdsb2JhbEVycm9yLmFkZEdsb2JhbEVycm9ySW5zdHJ1bWVudGF0aW9uSGFuZGxlcihlcnJvckNhbGxiYWNrKTtcbiAgZ2xvYmFsVW5oYW5kbGVkUmVqZWN0aW9uLmFkZEdsb2JhbFVuaGFuZGxlZFJlamVjdGlvbkluc3RydW1lbnRhdGlvbkhhbmRsZXIoZXJyb3JDYWxsYmFjayk7XG59XG5cbmV4cG9ydHMucmVnaXN0ZXJTcGFuRXJyb3JJbnN0cnVtZW50YXRpb24gPSByZWdpc3RlclNwYW5FcnJvckluc3RydW1lbnRhdGlvbjtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWVycm9ycy5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/errors.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/idleSpan.js":
/*!********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/idleSpan.js ***!
  \********************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst currentScopes = __webpack_require__(/*! ../currentScopes.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst debugBuild = __webpack_require__(/*! ../debug-build.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst semanticAttributes = __webpack_require__(/*! ../semanticAttributes.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/semanticAttributes.js\");\nconst debugLogger = __webpack_require__(/*! ../utils/debug-logger.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst hasSpansEnabled = __webpack_require__(/*! ../utils/hasSpansEnabled.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/hasSpansEnabled.js\");\nconst spanOnScope = __webpack_require__(/*! ../utils/spanOnScope.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanOnScope.js\");\nconst spanUtils = __webpack_require__(/*! ../utils/spanUtils.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanUtils.js\");\nconst time = __webpack_require__(/*! ../utils/time.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/time.js\");\nconst dynamicSamplingContext = __webpack_require__(/*! ./dynamicSamplingContext.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/dynamicSamplingContext.js\");\nconst sentryNonRecordingSpan = __webpack_require__(/*! ./sentryNonRecordingSpan.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/sentryNonRecordingSpan.js\");\nconst sentrySpan = __webpack_require__(/*! ./sentrySpan.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/sentrySpan.js\");\nconst spanstatus = __webpack_require__(/*! ./spanstatus.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/spanstatus.js\");\nconst trace = __webpack_require__(/*! ./trace.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/trace.js\");\n\nconst TRACING_DEFAULTS = {\n  idleTimeout: 1000,\n  finalTimeout: 30000,\n  childSpanTimeout: 15000,\n};\n\nconst FINISH_REASON_HEARTBEAT_FAILED = 'heartbeatFailed';\nconst FINISH_REASON_IDLE_TIMEOUT = 'idleTimeout';\nconst FINISH_REASON_FINAL_TIMEOUT = 'finalTimeout';\nconst FINISH_REASON_EXTERNAL_FINISH = 'externalFinish';\n\n/**\n * An idle span is a span that automatically finishes. It does this by tracking child spans as activities.\n * An idle span is always the active span.\n */\nfunction startIdleSpan(startSpanOptions, options = {}) {\n  // Activities store a list of active spans\n  const activities = new Map();\n\n  // We should not use heartbeat if we finished a span\n  let _finished = false;\n\n  // Timer that tracks idleTimeout\n  let _idleTimeoutID;\n\n  // The reason why the span was finished\n  let _finishReason = FINISH_REASON_EXTERNAL_FINISH;\n\n  let _autoFinishAllowed = !options.disableAutoFinish;\n\n  const _cleanupHooks = [];\n\n  const {\n    idleTimeout = TRACING_DEFAULTS.idleTimeout,\n    finalTimeout = TRACING_DEFAULTS.finalTimeout,\n    childSpanTimeout = TRACING_DEFAULTS.childSpanTimeout,\n    beforeSpanEnd,\n  } = options;\n\n  const client = currentScopes.getClient();\n\n  if (!client || !hasSpansEnabled.hasSpansEnabled()) {\n    const span = new sentryNonRecordingSpan.SentryNonRecordingSpan();\n\n    const dsc = {\n      sample_rate: '0',\n      sampled: 'false',\n      ...dynamicSamplingContext.getDynamicSamplingContextFromSpan(span),\n    } ;\n    dynamicSamplingContext.freezeDscOnSpan(span, dsc);\n\n    return span;\n  }\n\n  const scope = currentScopes.getCurrentScope();\n  const previousActiveSpan = spanUtils.getActiveSpan();\n  const span = _startIdleSpan(startSpanOptions);\n\n  // We patch span.end to ensure we can run some things before the span is ended\n  // eslint-disable-next-line @typescript-eslint/unbound-method\n  span.end = new Proxy(span.end, {\n    apply(target, thisArg, args) {\n      if (beforeSpanEnd) {\n        beforeSpanEnd(span);\n      }\n\n      // If the span is non-recording, nothing more to do here...\n      // This is the case if tracing is enabled but this specific span was not sampled\n      if (thisArg instanceof sentryNonRecordingSpan.SentryNonRecordingSpan) {\n        return;\n      }\n\n      // Just ensuring that this keeps working, even if we ever have more arguments here\n      const [definedEndTimestamp, ...rest] = args;\n      const timestamp = definedEndTimestamp || time.timestampInSeconds();\n      const spanEndTimestamp = spanUtils.spanTimeInputToSeconds(timestamp);\n\n      // Ensure we end with the last span timestamp, if possible\n      const spans = spanUtils.getSpanDescendants(span).filter(child => child !== span);\n\n      // If we have no spans, we just end, nothing else to do here\n      if (!spans.length) {\n        onIdleSpanEnded(spanEndTimestamp);\n        return Reflect.apply(target, thisArg, [spanEndTimestamp, ...rest]);\n      }\n\n      const childEndTimestamps = spans\n        .map(span => spanUtils.spanToJSON(span).timestamp)\n        .filter(timestamp => !!timestamp) ;\n      const latestSpanEndTimestamp = childEndTimestamps.length ? Math.max(...childEndTimestamps) : undefined;\n\n      // In reality this should always exist here, but type-wise it may be undefined...\n      const spanStartTimestamp = spanUtils.spanToJSON(span).start_timestamp;\n\n      // The final endTimestamp should:\n      // * Never be before the span start timestamp\n      // * Be the latestSpanEndTimestamp, if there is one, and it is smaller than the passed span end timestamp\n      // * Otherwise be the passed end timestamp\n      // Final timestamp can never be after finalTimeout\n      const endTimestamp = Math.min(\n        spanStartTimestamp ? spanStartTimestamp + finalTimeout / 1000 : Infinity,\n        Math.max(spanStartTimestamp || -Infinity, Math.min(spanEndTimestamp, latestSpanEndTimestamp || Infinity)),\n      );\n\n      onIdleSpanEnded(endTimestamp);\n      return Reflect.apply(target, thisArg, [endTimestamp, ...rest]);\n    },\n  });\n\n  /**\n   * Cancels the existing idle timeout, if there is one.\n   */\n  function _cancelIdleTimeout() {\n    if (_idleTimeoutID) {\n      clearTimeout(_idleTimeoutID);\n      _idleTimeoutID = undefined;\n    }\n  }\n\n  /**\n   * Restarts idle timeout, if there is no running idle timeout it will start one.\n   */\n  function _restartIdleTimeout(endTimestamp) {\n    _cancelIdleTimeout();\n    _idleTimeoutID = setTimeout(() => {\n      if (!_finished && activities.size === 0 && _autoFinishAllowed) {\n        _finishReason = FINISH_REASON_IDLE_TIMEOUT;\n        span.end(endTimestamp);\n      }\n    }, idleTimeout);\n  }\n\n  /**\n   * Restarts child span timeout, if there is none running it will start one.\n   */\n  function _restartChildSpanTimeout(endTimestamp) {\n    _idleTimeoutID = setTimeout(() => {\n      if (!_finished && _autoFinishAllowed) {\n        _finishReason = FINISH_REASON_HEARTBEAT_FAILED;\n        span.end(endTimestamp);\n      }\n    }, childSpanTimeout);\n  }\n\n  /**\n   * Start tracking a specific activity.\n   * @param spanId The span id that represents the activity\n   */\n  function _pushActivity(spanId) {\n    _cancelIdleTimeout();\n    activities.set(spanId, true);\n\n    const endTimestamp = time.timestampInSeconds();\n    // We need to add the timeout here to have the real endtimestamp of the idle span\n    // Remember timestampInSeconds is in seconds, timeout is in ms\n    _restartChildSpanTimeout(endTimestamp + childSpanTimeout / 1000);\n  }\n\n  /**\n   * Remove an activity from usage\n   * @param spanId The span id that represents the activity\n   */\n  function _popActivity(spanId) {\n    if (activities.has(spanId)) {\n      activities.delete(spanId);\n    }\n\n    if (activities.size === 0) {\n      const endTimestamp = time.timestampInSeconds();\n      // We need to add the timeout here to have the real endtimestamp of the idle span\n      // Remember timestampInSeconds is in seconds, timeout is in ms\n      _restartIdleTimeout(endTimestamp + idleTimeout / 1000);\n    }\n  }\n\n  function onIdleSpanEnded(endTimestamp) {\n    _finished = true;\n    activities.clear();\n\n    _cleanupHooks.forEach(cleanup => cleanup());\n\n    spanOnScope._setSpanForScope(scope, previousActiveSpan);\n\n    const spanJSON = spanUtils.spanToJSON(span);\n\n    const { start_timestamp: startTimestamp } = spanJSON;\n    // This should never happen, but to make TS happy...\n    if (!startTimestamp) {\n      return;\n    }\n\n    const attributes = spanJSON.data;\n    if (!attributes[semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_IDLE_SPAN_FINISH_REASON]) {\n      span.setAttribute(semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_IDLE_SPAN_FINISH_REASON, _finishReason);\n    }\n\n    debugLogger.debug.log(`[Tracing] Idle span \"${spanJSON.op}\" finished`);\n\n    const childSpans = spanUtils.getSpanDescendants(span).filter(child => child !== span);\n\n    let discardedSpans = 0;\n    childSpans.forEach(childSpan => {\n      // We cancel all pending spans with status \"cancelled\" to indicate the idle span was finished early\n      if (childSpan.isRecording()) {\n        childSpan.setStatus({ code: spanstatus.SPAN_STATUS_ERROR, message: 'cancelled' });\n        childSpan.end(endTimestamp);\n        debugBuild.DEBUG_BUILD &&\n          debugLogger.debug.log('[Tracing] Cancelling span since span ended early', JSON.stringify(childSpan, undefined, 2));\n      }\n\n      const childSpanJSON = spanUtils.spanToJSON(childSpan);\n      const { timestamp: childEndTimestamp = 0, start_timestamp: childStartTimestamp = 0 } = childSpanJSON;\n\n      const spanStartedBeforeIdleSpanEnd = childStartTimestamp <= endTimestamp;\n\n      // Add a delta with idle timeout so that we prevent false positives\n      const timeoutWithMarginOfError = (finalTimeout + idleTimeout) / 1000;\n      const spanEndedBeforeFinalTimeout = childEndTimestamp - childStartTimestamp <= timeoutWithMarginOfError;\n\n      if (debugBuild.DEBUG_BUILD) {\n        const stringifiedSpan = JSON.stringify(childSpan, undefined, 2);\n        if (!spanStartedBeforeIdleSpanEnd) {\n          debugLogger.debug.log('[Tracing] Discarding span since it happened after idle span was finished', stringifiedSpan);\n        } else if (!spanEndedBeforeFinalTimeout) {\n          debugLogger.debug.log('[Tracing] Discarding span since it finished after idle span final timeout', stringifiedSpan);\n        }\n      }\n\n      if (!spanEndedBeforeFinalTimeout || !spanStartedBeforeIdleSpanEnd) {\n        spanUtils.removeChildSpanFromSpan(span, childSpan);\n        discardedSpans++;\n      }\n    });\n\n    if (discardedSpans > 0) {\n      span.setAttribute('sentry.idle_span_discarded_spans', discardedSpans);\n    }\n  }\n\n  _cleanupHooks.push(\n    client.on('spanStart', startedSpan => {\n      // If we already finished the idle span,\n      // or if this is the idle span itself being started,\n      // or if the started span has already been closed,\n      // we don't care about it for activity\n      if (\n        _finished ||\n        startedSpan === span ||\n        !!spanUtils.spanToJSON(startedSpan).timestamp ||\n        (startedSpan instanceof sentrySpan.SentrySpan && startedSpan.isStandaloneSpan())\n      ) {\n        return;\n      }\n\n      const allSpans = spanUtils.getSpanDescendants(span);\n\n      // If the span that was just started is a child of the idle span, we should track it\n      if (allSpans.includes(startedSpan)) {\n        _pushActivity(startedSpan.spanContext().spanId);\n      }\n    }),\n  );\n\n  _cleanupHooks.push(\n    client.on('spanEnd', endedSpan => {\n      if (_finished) {\n        return;\n      }\n\n      _popActivity(endedSpan.spanContext().spanId);\n    }),\n  );\n\n  _cleanupHooks.push(\n    client.on('idleSpanEnableAutoFinish', spanToAllowAutoFinish => {\n      if (spanToAllowAutoFinish === span) {\n        _autoFinishAllowed = true;\n        _restartIdleTimeout();\n\n        if (activities.size) {\n          _restartChildSpanTimeout();\n        }\n      }\n    }),\n  );\n\n  // We only start the initial idle timeout if we are not delaying the auto finish\n  if (!options.disableAutoFinish) {\n    _restartIdleTimeout();\n  }\n\n  setTimeout(() => {\n    if (!_finished) {\n      span.setStatus({ code: spanstatus.SPAN_STATUS_ERROR, message: 'deadline_exceeded' });\n      _finishReason = FINISH_REASON_FINAL_TIMEOUT;\n      span.end();\n    }\n  }, finalTimeout);\n\n  return span;\n}\n\nfunction _startIdleSpan(options) {\n  const span = trace.startInactiveSpan(options);\n\n  spanOnScope._setSpanForScope(currentScopes.getCurrentScope(), span);\n\n  debugBuild.DEBUG_BUILD && debugLogger.debug.log('[Tracing] Started span is an idle span');\n\n  return span;\n}\n\nexports.TRACING_DEFAULTS = TRACING_DEFAULTS;\nexports.startIdleSpan = startIdleSpan;\n//# sourceMappingURL=idleSpan.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy90cmFjaW5nL2lkbGVTcGFuLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLHNCQUFzQixtQkFBTyxDQUFDLGdJQUFxQjtBQUNuRCxtQkFBbUIsbUJBQU8sQ0FBQyw0SEFBbUI7QUFDOUMsMkJBQTJCLG1CQUFPLENBQUMsMElBQTBCO0FBQzdELG9CQUFvQixtQkFBTyxDQUFDLDBJQUEwQjtBQUN0RCx3QkFBd0IsbUJBQU8sQ0FBQyxnSkFBNkI7QUFDN0Qsb0JBQW9CLG1CQUFPLENBQUMsd0lBQXlCO0FBQ3JELGtCQUFrQixtQkFBTyxDQUFDLG9JQUF1QjtBQUNqRCxhQUFhLG1CQUFPLENBQUMsMEhBQWtCO0FBQ3ZDLCtCQUErQixtQkFBTyxDQUFDLHlKQUE2QjtBQUNwRSwrQkFBK0IsbUJBQU8sQ0FBQyx5SkFBNkI7QUFDcEUsbUJBQW1CLG1CQUFPLENBQUMsaUlBQWlCO0FBQzVDLG1CQUFtQixtQkFBTyxDQUFDLGlJQUFpQjtBQUM1QyxjQUFjLG1CQUFPLENBQUMsdUhBQVk7O0FBRWxDO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQSxxREFBcUQ7QUFDckQ7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsSUFBSTs7QUFFSjs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsS0FBSztBQUNMLEdBQUc7O0FBRUg7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsS0FBSztBQUNMOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEtBQUs7QUFDTDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBOztBQUVBOztBQUVBOztBQUVBLFlBQVksa0NBQWtDO0FBQzlDO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLGtEQUFrRCxZQUFZOztBQUU5RDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLDhCQUE4QiwwREFBMEQ7QUFDeEY7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQSxjQUFjLDZFQUE2RTs7QUFFM0Y7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsVUFBVTtBQUNWO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEtBQUs7O0FBRUw7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEtBQUs7QUFDTDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0EsS0FBSztBQUNMOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQSxLQUFLO0FBQ0w7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLHVCQUF1QixrRUFBa0U7QUFDekY7QUFDQTtBQUNBO0FBQ0EsR0FBRzs7QUFFSDtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7O0FBRUE7O0FBRUE7QUFDQTs7QUFFQSx3QkFBd0I7QUFDeEIscUJBQXFCO0FBQ3JCIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdHJhY2luZy9pZGxlU3Bhbi5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgY3VycmVudFNjb3BlcyA9IHJlcXVpcmUoJy4uL2N1cnJlbnRTY29wZXMuanMnKTtcbmNvbnN0IGRlYnVnQnVpbGQgPSByZXF1aXJlKCcuLi9kZWJ1Zy1idWlsZC5qcycpO1xuY29uc3Qgc2VtYW50aWNBdHRyaWJ1dGVzID0gcmVxdWlyZSgnLi4vc2VtYW50aWNBdHRyaWJ1dGVzLmpzJyk7XG5jb25zdCBkZWJ1Z0xvZ2dlciA9IHJlcXVpcmUoJy4uL3V0aWxzL2RlYnVnLWxvZ2dlci5qcycpO1xuY29uc3QgaGFzU3BhbnNFbmFibGVkID0gcmVxdWlyZSgnLi4vdXRpbHMvaGFzU3BhbnNFbmFibGVkLmpzJyk7XG5jb25zdCBzcGFuT25TY29wZSA9IHJlcXVpcmUoJy4uL3V0aWxzL3NwYW5PblNjb3BlLmpzJyk7XG5jb25zdCBzcGFuVXRpbHMgPSByZXF1aXJlKCcuLi91dGlscy9zcGFuVXRpbHMuanMnKTtcbmNvbnN0IHRpbWUgPSByZXF1aXJlKCcuLi91dGlscy90aW1lLmpzJyk7XG5jb25zdCBkeW5hbWljU2FtcGxpbmdDb250ZXh0ID0gcmVxdWlyZSgnLi9keW5hbWljU2FtcGxpbmdDb250ZXh0LmpzJyk7XG5jb25zdCBzZW50cnlOb25SZWNvcmRpbmdTcGFuID0gcmVxdWlyZSgnLi9zZW50cnlOb25SZWNvcmRpbmdTcGFuLmpzJyk7XG5jb25zdCBzZW50cnlTcGFuID0gcmVxdWlyZSgnLi9zZW50cnlTcGFuLmpzJyk7XG5jb25zdCBzcGFuc3RhdHVzID0gcmVxdWlyZSgnLi9zcGFuc3RhdHVzLmpzJyk7XG5jb25zdCB0cmFjZSA9IHJlcXVpcmUoJy4vdHJhY2UuanMnKTtcblxuY29uc3QgVFJBQ0lOR19ERUZBVUxUUyA9IHtcbiAgaWRsZVRpbWVvdXQ6IDEwMDAsXG4gIGZpbmFsVGltZW91dDogMzAwMDAsXG4gIGNoaWxkU3BhblRpbWVvdXQ6IDE1MDAwLFxufTtcblxuY29uc3QgRklOSVNIX1JFQVNPTl9IRUFSVEJFQVRfRkFJTEVEID0gJ2hlYXJ0YmVhdEZhaWxlZCc7XG5jb25zdCBGSU5JU0hfUkVBU09OX0lETEVfVElNRU9VVCA9ICdpZGxlVGltZW91dCc7XG5jb25zdCBGSU5JU0hfUkVBU09OX0ZJTkFMX1RJTUVPVVQgPSAnZmluYWxUaW1lb3V0JztcbmNvbnN0IEZJTklTSF9SRUFTT05fRVhURVJOQUxfRklOSVNIID0gJ2V4dGVybmFsRmluaXNoJztcblxuLyoqXG4gKiBBbiBpZGxlIHNwYW4gaXMgYSBzcGFuIHRoYXQgYXV0b21hdGljYWxseSBmaW5pc2hlcy4gSXQgZG9lcyB0aGlzIGJ5IHRyYWNraW5nIGNoaWxkIHNwYW5zIGFzIGFjdGl2aXRpZXMuXG4gKiBBbiBpZGxlIHNwYW4gaXMgYWx3YXlzIHRoZSBhY3RpdmUgc3Bhbi5cbiAqL1xuZnVuY3Rpb24gc3RhcnRJZGxlU3BhbihzdGFydFNwYW5PcHRpb25zLCBvcHRpb25zID0ge30pIHtcbiAgLy8gQWN0aXZpdGllcyBzdG9yZSBhIGxpc3Qgb2YgYWN0aXZlIHNwYW5zXG4gIGNvbnN0IGFjdGl2aXRpZXMgPSBuZXcgTWFwKCk7XG5cbiAgLy8gV2Ugc2hvdWxkIG5vdCB1c2UgaGVhcnRiZWF0IGlmIHdlIGZpbmlzaGVkIGEgc3BhblxuICBsZXQgX2ZpbmlzaGVkID0gZmFsc2U7XG5cbiAgLy8gVGltZXIgdGhhdCB0cmFja3MgaWRsZVRpbWVvdXRcbiAgbGV0IF9pZGxlVGltZW91dElEO1xuXG4gIC8vIFRoZSByZWFzb24gd2h5IHRoZSBzcGFuIHdhcyBmaW5pc2hlZFxuICBsZXQgX2ZpbmlzaFJlYXNvbiA9IEZJTklTSF9SRUFTT05fRVhURVJOQUxfRklOSVNIO1xuXG4gIGxldCBfYXV0b0ZpbmlzaEFsbG93ZWQgPSAhb3B0aW9ucy5kaXNhYmxlQXV0b0ZpbmlzaDtcblxuICBjb25zdCBfY2xlYW51cEhvb2tzID0gW107XG5cbiAgY29uc3Qge1xuICAgIGlkbGVUaW1lb3V0ID0gVFJBQ0lOR19ERUZBVUxUUy5pZGxlVGltZW91dCxcbiAgICBmaW5hbFRpbWVvdXQgPSBUUkFDSU5HX0RFRkFVTFRTLmZpbmFsVGltZW91dCxcbiAgICBjaGlsZFNwYW5UaW1lb3V0ID0gVFJBQ0lOR19ERUZBVUxUUy5jaGlsZFNwYW5UaW1lb3V0LFxuICAgIGJlZm9yZVNwYW5FbmQsXG4gIH0gPSBvcHRpb25zO1xuXG4gIGNvbnN0IGNsaWVudCA9IGN1cnJlbnRTY29wZXMuZ2V0Q2xpZW50KCk7XG5cbiAgaWYgKCFjbGllbnQgfHwgIWhhc1NwYW5zRW5hYmxlZC5oYXNTcGFuc0VuYWJsZWQoKSkge1xuICAgIGNvbnN0IHNwYW4gPSBuZXcgc2VudHJ5Tm9uUmVjb3JkaW5nU3Bhbi5TZW50cnlOb25SZWNvcmRpbmdTcGFuKCk7XG5cbiAgICBjb25zdCBkc2MgPSB7XG4gICAgICBzYW1wbGVfcmF0ZTogJzAnLFxuICAgICAgc2FtcGxlZDogJ2ZhbHNlJyxcbiAgICAgIC4uLmR5bmFtaWNTYW1wbGluZ0NvbnRleHQuZ2V0RHluYW1pY1NhbXBsaW5nQ29udGV4dEZyb21TcGFuKHNwYW4pLFxuICAgIH0gO1xuICAgIGR5bmFtaWNTYW1wbGluZ0NvbnRleHQuZnJlZXplRHNjT25TcGFuKHNwYW4sIGRzYyk7XG5cbiAgICByZXR1cm4gc3BhbjtcbiAgfVxuXG4gIGNvbnN0IHNjb3BlID0gY3VycmVudFNjb3Blcy5nZXRDdXJyZW50U2NvcGUoKTtcbiAgY29uc3QgcHJldmlvdXNBY3RpdmVTcGFuID0gc3BhblV0aWxzLmdldEFjdGl2ZVNwYW4oKTtcbiAgY29uc3Qgc3BhbiA9IF9zdGFydElkbGVTcGFuKHN0YXJ0U3Bhbk9wdGlvbnMpO1xuXG4gIC8vIFdlIHBhdGNoIHNwYW4uZW5kIHRvIGVuc3VyZSB3ZSBjYW4gcnVuIHNvbWUgdGhpbmdzIGJlZm9yZSB0aGUgc3BhbiBpcyBlbmRlZFxuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L3VuYm91bmQtbWV0aG9kXG4gIHNwYW4uZW5kID0gbmV3IFByb3h5KHNwYW4uZW5kLCB7XG4gICAgYXBwbHkodGFyZ2V0LCB0aGlzQXJnLCBhcmdzKSB7XG4gICAgICBpZiAoYmVmb3JlU3BhbkVuZCkge1xuICAgICAgICBiZWZvcmVTcGFuRW5kKHNwYW4pO1xuICAgICAgfVxuXG4gICAgICAvLyBJZiB0aGUgc3BhbiBpcyBub24tcmVjb3JkaW5nLCBub3RoaW5nIG1vcmUgdG8gZG8gaGVyZS4uLlxuICAgICAgLy8gVGhpcyBpcyB0aGUgY2FzZSBpZiB0cmFjaW5nIGlzIGVuYWJsZWQgYnV0IHRoaXMgc3BlY2lmaWMgc3BhbiB3YXMgbm90IHNhbXBsZWRcbiAgICAgIGlmICh0aGlzQXJnIGluc3RhbmNlb2Ygc2VudHJ5Tm9uUmVjb3JkaW5nU3Bhbi5TZW50cnlOb25SZWNvcmRpbmdTcGFuKSB7XG4gICAgICAgIHJldHVybjtcbiAgICAgIH1cblxuICAgICAgLy8gSnVzdCBlbnN1cmluZyB0aGF0IHRoaXMga2VlcHMgd29ya2luZywgZXZlbiBpZiB3ZSBldmVyIGhhdmUgbW9yZSBhcmd1bWVudHMgaGVyZVxuICAgICAgY29uc3QgW2RlZmluZWRFbmRUaW1lc3RhbXAsIC4uLnJlc3RdID0gYXJncztcbiAgICAgIGNvbnN0IHRpbWVzdGFtcCA9IGRlZmluZWRFbmRUaW1lc3RhbXAgfHwgdGltZS50aW1lc3RhbXBJblNlY29uZHMoKTtcbiAgICAgIGNvbnN0IHNwYW5FbmRUaW1lc3RhbXAgPSBzcGFuVXRpbHMuc3BhblRpbWVJbnB1dFRvU2Vjb25kcyh0aW1lc3RhbXApO1xuXG4gICAgICAvLyBFbnN1cmUgd2UgZW5kIHdpdGggdGhlIGxhc3Qgc3BhbiB0aW1lc3RhbXAsIGlmIHBvc3NpYmxlXG4gICAgICBjb25zdCBzcGFucyA9IHNwYW5VdGlscy5nZXRTcGFuRGVzY2VuZGFudHMoc3BhbikuZmlsdGVyKGNoaWxkID0+IGNoaWxkICE9PSBzcGFuKTtcblxuICAgICAgLy8gSWYgd2UgaGF2ZSBubyBzcGFucywgd2UganVzdCBlbmQsIG5vdGhpbmcgZWxzZSB0byBkbyBoZXJlXG4gICAgICBpZiAoIXNwYW5zLmxlbmd0aCkge1xuICAgICAgICBvbklkbGVTcGFuRW5kZWQoc3BhbkVuZFRpbWVzdGFtcCk7XG4gICAgICAgIHJldHVybiBSZWZsZWN0LmFwcGx5KHRhcmdldCwgdGhpc0FyZywgW3NwYW5FbmRUaW1lc3RhbXAsIC4uLnJlc3RdKTtcbiAgICAgIH1cblxuICAgICAgY29uc3QgY2hpbGRFbmRUaW1lc3RhbXBzID0gc3BhbnNcbiAgICAgICAgLm1hcChzcGFuID0+IHNwYW5VdGlscy5zcGFuVG9KU09OKHNwYW4pLnRpbWVzdGFtcClcbiAgICAgICAgLmZpbHRlcih0aW1lc3RhbXAgPT4gISF0aW1lc3RhbXApIDtcbiAgICAgIGNvbnN0IGxhdGVzdFNwYW5FbmRUaW1lc3RhbXAgPSBjaGlsZEVuZFRpbWVzdGFtcHMubGVuZ3RoID8gTWF0aC5tYXgoLi4uY2hpbGRFbmRUaW1lc3RhbXBzKSA6IHVuZGVmaW5lZDtcblxuICAgICAgLy8gSW4gcmVhbGl0eSB0aGlzIHNob3VsZCBhbHdheXMgZXhpc3QgaGVyZSwgYnV0IHR5cGUtd2lzZSBpdCBtYXkgYmUgdW5kZWZpbmVkLi4uXG4gICAgICBjb25zdCBzcGFuU3RhcnRUaW1lc3RhbXAgPSBzcGFuVXRpbHMuc3BhblRvSlNPTihzcGFuKS5zdGFydF90aW1lc3RhbXA7XG5cbiAgICAgIC8vIFRoZSBmaW5hbCBlbmRUaW1lc3RhbXAgc2hvdWxkOlxuICAgICAgLy8gKiBOZXZlciBiZSBiZWZvcmUgdGhlIHNwYW4gc3RhcnQgdGltZXN0YW1wXG4gICAgICAvLyAqIEJlIHRoZSBsYXRlc3RTcGFuRW5kVGltZXN0YW1wLCBpZiB0aGVyZSBpcyBvbmUsIGFuZCBpdCBpcyBzbWFsbGVyIHRoYW4gdGhlIHBhc3NlZCBzcGFuIGVuZCB0aW1lc3RhbXBcbiAgICAgIC8vICogT3RoZXJ3aXNlIGJlIHRoZSBwYXNzZWQgZW5kIHRpbWVzdGFtcFxuICAgICAgLy8gRmluYWwgdGltZXN0YW1wIGNhbiBuZXZlciBiZSBhZnRlciBmaW5hbFRpbWVvdXRcbiAgICAgIGNvbnN0IGVuZFRpbWVzdGFtcCA9IE1hdGgubWluKFxuICAgICAgICBzcGFuU3RhcnRUaW1lc3RhbXAgPyBzcGFuU3RhcnRUaW1lc3RhbXAgKyBmaW5hbFRpbWVvdXQgLyAxMDAwIDogSW5maW5pdHksXG4gICAgICAgIE1hdGgubWF4KHNwYW5TdGFydFRpbWVzdGFtcCB8fCAtSW5maW5pdHksIE1hdGgubWluKHNwYW5FbmRUaW1lc3RhbXAsIGxhdGVzdFNwYW5FbmRUaW1lc3RhbXAgfHwgSW5maW5pdHkpKSxcbiAgICAgICk7XG5cbiAgICAgIG9uSWRsZVNwYW5FbmRlZChlbmRUaW1lc3RhbXApO1xuICAgICAgcmV0dXJuIFJlZmxlY3QuYXBwbHkodGFyZ2V0LCB0aGlzQXJnLCBbZW5kVGltZXN0YW1wLCAuLi5yZXN0XSk7XG4gICAgfSxcbiAgfSk7XG5cbiAgLyoqXG4gICAqIENhbmNlbHMgdGhlIGV4aXN0aW5nIGlkbGUgdGltZW91dCwgaWYgdGhlcmUgaXMgb25lLlxuICAgKi9cbiAgZnVuY3Rpb24gX2NhbmNlbElkbGVUaW1lb3V0KCkge1xuICAgIGlmIChfaWRsZVRpbWVvdXRJRCkge1xuICAgICAgY2xlYXJUaW1lb3V0KF9pZGxlVGltZW91dElEKTtcbiAgICAgIF9pZGxlVGltZW91dElEID0gdW5kZWZpbmVkO1xuICAgIH1cbiAgfVxuXG4gIC8qKlxuICAgKiBSZXN0YXJ0cyBpZGxlIHRpbWVvdXQsIGlmIHRoZXJlIGlzIG5vIHJ1bm5pbmcgaWRsZSB0aW1lb3V0IGl0IHdpbGwgc3RhcnQgb25lLlxuICAgKi9cbiAgZnVuY3Rpb24gX3Jlc3RhcnRJZGxlVGltZW91dChlbmRUaW1lc3RhbXApIHtcbiAgICBfY2FuY2VsSWRsZVRpbWVvdXQoKTtcbiAgICBfaWRsZVRpbWVvdXRJRCA9IHNldFRpbWVvdXQoKCkgPT4ge1xuICAgICAgaWYgKCFfZmluaXNoZWQgJiYgYWN0aXZpdGllcy5zaXplID09PSAwICYmIF9hdXRvRmluaXNoQWxsb3dlZCkge1xuICAgICAgICBfZmluaXNoUmVhc29uID0gRklOSVNIX1JFQVNPTl9JRExFX1RJTUVPVVQ7XG4gICAgICAgIHNwYW4uZW5kKGVuZFRpbWVzdGFtcCk7XG4gICAgICB9XG4gICAgfSwgaWRsZVRpbWVvdXQpO1xuICB9XG5cbiAgLyoqXG4gICAqIFJlc3RhcnRzIGNoaWxkIHNwYW4gdGltZW91dCwgaWYgdGhlcmUgaXMgbm9uZSBydW5uaW5nIGl0IHdpbGwgc3RhcnQgb25lLlxuICAgKi9cbiAgZnVuY3Rpb24gX3Jlc3RhcnRDaGlsZFNwYW5UaW1lb3V0KGVuZFRpbWVzdGFtcCkge1xuICAgIF9pZGxlVGltZW91dElEID0gc2V0VGltZW91dCgoKSA9PiB7XG4gICAgICBpZiAoIV9maW5pc2hlZCAmJiBfYXV0b0ZpbmlzaEFsbG93ZWQpIHtcbiAgICAgICAgX2ZpbmlzaFJlYXNvbiA9IEZJTklTSF9SRUFTT05fSEVBUlRCRUFUX0ZBSUxFRDtcbiAgICAgICAgc3Bhbi5lbmQoZW5kVGltZXN0YW1wKTtcbiAgICAgIH1cbiAgICB9LCBjaGlsZFNwYW5UaW1lb3V0KTtcbiAgfVxuXG4gIC8qKlxuICAgKiBTdGFydCB0cmFja2luZyBhIHNwZWNpZmljIGFjdGl2aXR5LlxuICAgKiBAcGFyYW0gc3BhbklkIFRoZSBzcGFuIGlkIHRoYXQgcmVwcmVzZW50cyB0aGUgYWN0aXZpdHlcbiAgICovXG4gIGZ1bmN0aW9uIF9wdXNoQWN0aXZpdHkoc3BhbklkKSB7XG4gICAgX2NhbmNlbElkbGVUaW1lb3V0KCk7XG4gICAgYWN0aXZpdGllcy5zZXQoc3BhbklkLCB0cnVlKTtcblxuICAgIGNvbnN0IGVuZFRpbWVzdGFtcCA9IHRpbWUudGltZXN0YW1wSW5TZWNvbmRzKCk7XG4gICAgLy8gV2UgbmVlZCB0byBhZGQgdGhlIHRpbWVvdXQgaGVyZSB0byBoYXZlIHRoZSByZWFsIGVuZHRpbWVzdGFtcCBvZiB0aGUgaWRsZSBzcGFuXG4gICAgLy8gUmVtZW1iZXIgdGltZXN0YW1wSW5TZWNvbmRzIGlzIGluIHNlY29uZHMsIHRpbWVvdXQgaXMgaW4gbXNcbiAgICBfcmVzdGFydENoaWxkU3BhblRpbWVvdXQoZW5kVGltZXN0YW1wICsgY2hpbGRTcGFuVGltZW91dCAvIDEwMDApO1xuICB9XG5cbiAgLyoqXG4gICAqIFJlbW92ZSBhbiBhY3Rpdml0eSBmcm9tIHVzYWdlXG4gICAqIEBwYXJhbSBzcGFuSWQgVGhlIHNwYW4gaWQgdGhhdCByZXByZXNlbnRzIHRoZSBhY3Rpdml0eVxuICAgKi9cbiAgZnVuY3Rpb24gX3BvcEFjdGl2aXR5KHNwYW5JZCkge1xuICAgIGlmIChhY3Rpdml0aWVzLmhhcyhzcGFuSWQpKSB7XG4gICAgICBhY3Rpdml0aWVzLmRlbGV0ZShzcGFuSWQpO1xuICAgIH1cblxuICAgIGlmIChhY3Rpdml0aWVzLnNpemUgPT09IDApIHtcbiAgICAgIGNvbnN0IGVuZFRpbWVzdGFtcCA9IHRpbWUudGltZXN0YW1wSW5TZWNvbmRzKCk7XG4gICAgICAvLyBXZSBuZWVkIHRvIGFkZCB0aGUgdGltZW91dCBoZXJlIHRvIGhhdmUgdGhlIHJlYWwgZW5kdGltZXN0YW1wIG9mIHRoZSBpZGxlIHNwYW5cbiAgICAgIC8vIFJlbWVtYmVyIHRpbWVzdGFtcEluU2Vjb25kcyBpcyBpbiBzZWNvbmRzLCB0aW1lb3V0IGlzIGluIG1zXG4gICAgICBfcmVzdGFydElkbGVUaW1lb3V0KGVuZFRpbWVzdGFtcCArIGlkbGVUaW1lb3V0IC8gMTAwMCk7XG4gICAgfVxuICB9XG5cbiAgZnVuY3Rpb24gb25JZGxlU3BhbkVuZGVkKGVuZFRpbWVzdGFtcCkge1xuICAgIF9maW5pc2hlZCA9IHRydWU7XG4gICAgYWN0aXZpdGllcy5jbGVhcigpO1xuXG4gICAgX2NsZWFudXBIb29rcy5mb3JFYWNoKGNsZWFudXAgPT4gY2xlYW51cCgpKTtcblxuICAgIHNwYW5PblNjb3BlLl9zZXRTcGFuRm9yU2NvcGUoc2NvcGUsIHByZXZpb3VzQWN0aXZlU3Bhbik7XG5cbiAgICBjb25zdCBzcGFuSlNPTiA9IHNwYW5VdGlscy5zcGFuVG9KU09OKHNwYW4pO1xuXG4gICAgY29uc3QgeyBzdGFydF90aW1lc3RhbXA6IHN0YXJ0VGltZXN0YW1wIH0gPSBzcGFuSlNPTjtcbiAgICAvLyBUaGlzIHNob3VsZCBuZXZlciBoYXBwZW4sIGJ1dCB0byBtYWtlIFRTIGhhcHB5Li4uXG4gICAgaWYgKCFzdGFydFRpbWVzdGFtcCkge1xuICAgICAgcmV0dXJuO1xuICAgIH1cblxuICAgIGNvbnN0IGF0dHJpYnV0ZXMgPSBzcGFuSlNPTi5kYXRhO1xuICAgIGlmICghYXR0cmlidXRlc1tzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9JRExFX1NQQU5fRklOSVNIX1JFQVNPTl0pIHtcbiAgICAgIHNwYW4uc2V0QXR0cmlidXRlKHNlbWFudGljQXR0cmlidXRlcy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX0lETEVfU1BBTl9GSU5JU0hfUkVBU09OLCBfZmluaXNoUmVhc29uKTtcbiAgICB9XG5cbiAgICBkZWJ1Z0xvZ2dlci5kZWJ1Zy5sb2coYFtUcmFjaW5nXSBJZGxlIHNwYW4gXCIke3NwYW5KU09OLm9wfVwiIGZpbmlzaGVkYCk7XG5cbiAgICBjb25zdCBjaGlsZFNwYW5zID0gc3BhblV0aWxzLmdldFNwYW5EZXNjZW5kYW50cyhzcGFuKS5maWx0ZXIoY2hpbGQgPT4gY2hpbGQgIT09IHNwYW4pO1xuXG4gICAgbGV0IGRpc2NhcmRlZFNwYW5zID0gMDtcbiAgICBjaGlsZFNwYW5zLmZvckVhY2goY2hpbGRTcGFuID0+IHtcbiAgICAgIC8vIFdlIGNhbmNlbCBhbGwgcGVuZGluZyBzcGFucyB3aXRoIHN0YXR1cyBcImNhbmNlbGxlZFwiIHRvIGluZGljYXRlIHRoZSBpZGxlIHNwYW4gd2FzIGZpbmlzaGVkIGVhcmx5XG4gICAgICBpZiAoY2hpbGRTcGFuLmlzUmVjb3JkaW5nKCkpIHtcbiAgICAgICAgY2hpbGRTcGFuLnNldFN0YXR1cyh7IGNvZGU6IHNwYW5zdGF0dXMuU1BBTl9TVEFUVVNfRVJST1IsIG1lc3NhZ2U6ICdjYW5jZWxsZWQnIH0pO1xuICAgICAgICBjaGlsZFNwYW4uZW5kKGVuZFRpbWVzdGFtcCk7XG4gICAgICAgIGRlYnVnQnVpbGQuREVCVUdfQlVJTEQgJiZcbiAgICAgICAgICBkZWJ1Z0xvZ2dlci5kZWJ1Zy5sb2coJ1tUcmFjaW5nXSBDYW5jZWxsaW5nIHNwYW4gc2luY2Ugc3BhbiBlbmRlZCBlYXJseScsIEpTT04uc3RyaW5naWZ5KGNoaWxkU3BhbiwgdW5kZWZpbmVkLCAyKSk7XG4gICAgICB9XG5cbiAgICAgIGNvbnN0IGNoaWxkU3BhbkpTT04gPSBzcGFuVXRpbHMuc3BhblRvSlNPTihjaGlsZFNwYW4pO1xuICAgICAgY29uc3QgeyB0aW1lc3RhbXA6IGNoaWxkRW5kVGltZXN0YW1wID0gMCwgc3RhcnRfdGltZXN0YW1wOiBjaGlsZFN0YXJ0VGltZXN0YW1wID0gMCB9ID0gY2hpbGRTcGFuSlNPTjtcblxuICAgICAgY29uc3Qgc3BhblN0YXJ0ZWRCZWZvcmVJZGxlU3BhbkVuZCA9IGNoaWxkU3RhcnRUaW1lc3RhbXAgPD0gZW5kVGltZXN0YW1wO1xuXG4gICAgICAvLyBBZGQgYSBkZWx0YSB3aXRoIGlkbGUgdGltZW91dCBzbyB0aGF0IHdlIHByZXZlbnQgZmFsc2UgcG9zaXRpdmVzXG4gICAgICBjb25zdCB0aW1lb3V0V2l0aE1hcmdpbk9mRXJyb3IgPSAoZmluYWxUaW1lb3V0ICsgaWRsZVRpbWVvdXQpIC8gMTAwMDtcbiAgICAgIGNvbnN0IHNwYW5FbmRlZEJlZm9yZUZpbmFsVGltZW91dCA9IGNoaWxkRW5kVGltZXN0YW1wIC0gY2hpbGRTdGFydFRpbWVzdGFtcCA8PSB0aW1lb3V0V2l0aE1hcmdpbk9mRXJyb3I7XG5cbiAgICAgIGlmIChkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEKSB7XG4gICAgICAgIGNvbnN0IHN0cmluZ2lmaWVkU3BhbiA9IEpTT04uc3RyaW5naWZ5KGNoaWxkU3BhbiwgdW5kZWZpbmVkLCAyKTtcbiAgICAgICAgaWYgKCFzcGFuU3RhcnRlZEJlZm9yZUlkbGVTcGFuRW5kKSB7XG4gICAgICAgICAgZGVidWdMb2dnZXIuZGVidWcubG9nKCdbVHJhY2luZ10gRGlzY2FyZGluZyBzcGFuIHNpbmNlIGl0IGhhcHBlbmVkIGFmdGVyIGlkbGUgc3BhbiB3YXMgZmluaXNoZWQnLCBzdHJpbmdpZmllZFNwYW4pO1xuICAgICAgICB9IGVsc2UgaWYgKCFzcGFuRW5kZWRCZWZvcmVGaW5hbFRpbWVvdXQpIHtcbiAgICAgICAgICBkZWJ1Z0xvZ2dlci5kZWJ1Zy5sb2coJ1tUcmFjaW5nXSBEaXNjYXJkaW5nIHNwYW4gc2luY2UgaXQgZmluaXNoZWQgYWZ0ZXIgaWRsZSBzcGFuIGZpbmFsIHRpbWVvdXQnLCBzdHJpbmdpZmllZFNwYW4pO1xuICAgICAgICB9XG4gICAgICB9XG5cbiAgICAgIGlmICghc3BhbkVuZGVkQmVmb3JlRmluYWxUaW1lb3V0IHx8ICFzcGFuU3RhcnRlZEJlZm9yZUlkbGVTcGFuRW5kKSB7XG4gICAgICAgIHNwYW5VdGlscy5yZW1vdmVDaGlsZFNwYW5Gcm9tU3BhbihzcGFuLCBjaGlsZFNwYW4pO1xuICAgICAgICBkaXNjYXJkZWRTcGFucysrO1xuICAgICAgfVxuICAgIH0pO1xuXG4gICAgaWYgKGRpc2NhcmRlZFNwYW5zID4gMCkge1xuICAgICAgc3Bhbi5zZXRBdHRyaWJ1dGUoJ3NlbnRyeS5pZGxlX3NwYW5fZGlzY2FyZGVkX3NwYW5zJywgZGlzY2FyZGVkU3BhbnMpO1xuICAgIH1cbiAgfVxuXG4gIF9jbGVhbnVwSG9va3MucHVzaChcbiAgICBjbGllbnQub24oJ3NwYW5TdGFydCcsIHN0YXJ0ZWRTcGFuID0+IHtcbiAgICAgIC8vIElmIHdlIGFscmVhZHkgZmluaXNoZWQgdGhlIGlkbGUgc3BhbixcbiAgICAgIC8vIG9yIGlmIHRoaXMgaXMgdGhlIGlkbGUgc3BhbiBpdHNlbGYgYmVpbmcgc3RhcnRlZCxcbiAgICAgIC8vIG9yIGlmIHRoZSBzdGFydGVkIHNwYW4gaGFzIGFscmVhZHkgYmVlbiBjbG9zZWQsXG4gICAgICAvLyB3ZSBkb24ndCBjYXJlIGFib3V0IGl0IGZvciBhY3Rpdml0eVxuICAgICAgaWYgKFxuICAgICAgICBfZmluaXNoZWQgfHxcbiAgICAgICAgc3RhcnRlZFNwYW4gPT09IHNwYW4gfHxcbiAgICAgICAgISFzcGFuVXRpbHMuc3BhblRvSlNPTihzdGFydGVkU3BhbikudGltZXN0YW1wIHx8XG4gICAgICAgIChzdGFydGVkU3BhbiBpbnN0YW5jZW9mIHNlbnRyeVNwYW4uU2VudHJ5U3BhbiAmJiBzdGFydGVkU3Bhbi5pc1N0YW5kYWxvbmVTcGFuKCkpXG4gICAgICApIHtcbiAgICAgICAgcmV0dXJuO1xuICAgICAgfVxuXG4gICAgICBjb25zdCBhbGxTcGFucyA9IHNwYW5VdGlscy5nZXRTcGFuRGVzY2VuZGFudHMoc3Bhbik7XG5cbiAgICAgIC8vIElmIHRoZSBzcGFuIHRoYXQgd2FzIGp1c3Qgc3RhcnRlZCBpcyBhIGNoaWxkIG9mIHRoZSBpZGxlIHNwYW4sIHdlIHNob3VsZCB0cmFjayBpdFxuICAgICAgaWYgKGFsbFNwYW5zLmluY2x1ZGVzKHN0YXJ0ZWRTcGFuKSkge1xuICAgICAgICBfcHVzaEFjdGl2aXR5KHN0YXJ0ZWRTcGFuLnNwYW5Db250ZXh0KCkuc3BhbklkKTtcbiAgICAgIH1cbiAgICB9KSxcbiAgKTtcblxuICBfY2xlYW51cEhvb2tzLnB1c2goXG4gICAgY2xpZW50Lm9uKCdzcGFuRW5kJywgZW5kZWRTcGFuID0+IHtcbiAgICAgIGlmIChfZmluaXNoZWQpIHtcbiAgICAgICAgcmV0dXJuO1xuICAgICAgfVxuXG4gICAgICBfcG9wQWN0aXZpdHkoZW5kZWRTcGFuLnNwYW5Db250ZXh0KCkuc3BhbklkKTtcbiAgICB9KSxcbiAgKTtcblxuICBfY2xlYW51cEhvb2tzLnB1c2goXG4gICAgY2xpZW50Lm9uKCdpZGxlU3BhbkVuYWJsZUF1dG9GaW5pc2gnLCBzcGFuVG9BbGxvd0F1dG9GaW5pc2ggPT4ge1xuICAgICAgaWYgKHNwYW5Ub0FsbG93QXV0b0ZpbmlzaCA9PT0gc3Bhbikge1xuICAgICAgICBfYXV0b0ZpbmlzaEFsbG93ZWQgPSB0cnVlO1xuICAgICAgICBfcmVzdGFydElkbGVUaW1lb3V0KCk7XG5cbiAgICAgICAgaWYgKGFjdGl2aXRpZXMuc2l6ZSkge1xuICAgICAgICAgIF9yZXN0YXJ0Q2hpbGRTcGFuVGltZW91dCgpO1xuICAgICAgICB9XG4gICAgICB9XG4gICAgfSksXG4gICk7XG5cbiAgLy8gV2Ugb25seSBzdGFydCB0aGUgaW5pdGlhbCBpZGxlIHRpbWVvdXQgaWYgd2UgYXJlIG5vdCBkZWxheWluZyB0aGUgYXV0byBmaW5pc2hcbiAgaWYgKCFvcHRpb25zLmRpc2FibGVBdXRvRmluaXNoKSB7XG4gICAgX3Jlc3RhcnRJZGxlVGltZW91dCgpO1xuICB9XG5cbiAgc2V0VGltZW91dCgoKSA9PiB7XG4gICAgaWYgKCFfZmluaXNoZWQpIHtcbiAgICAgIHNwYW4uc2V0U3RhdHVzKHsgY29kZTogc3BhbnN0YXR1cy5TUEFOX1NUQVRVU19FUlJPUiwgbWVzc2FnZTogJ2RlYWRsaW5lX2V4Y2VlZGVkJyB9KTtcbiAgICAgIF9maW5pc2hSZWFzb24gPSBGSU5JU0hfUkVBU09OX0ZJTkFMX1RJTUVPVVQ7XG4gICAgICBzcGFuLmVuZCgpO1xuICAgIH1cbiAgfSwgZmluYWxUaW1lb3V0KTtcblxuICByZXR1cm4gc3Bhbjtcbn1cblxuZnVuY3Rpb24gX3N0YXJ0SWRsZVNwYW4ob3B0aW9ucykge1xuICBjb25zdCBzcGFuID0gdHJhY2Uuc3RhcnRJbmFjdGl2ZVNwYW4ob3B0aW9ucyk7XG5cbiAgc3Bhbk9uU2NvcGUuX3NldFNwYW5Gb3JTY29wZShjdXJyZW50U2NvcGVzLmdldEN1cnJlbnRTY29wZSgpLCBzcGFuKTtcblxuICBkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEICYmIGRlYnVnTG9nZ2VyLmRlYnVnLmxvZygnW1RyYWNpbmddIFN0YXJ0ZWQgc3BhbiBpcyBhbiBpZGxlIHNwYW4nKTtcblxuICByZXR1cm4gc3Bhbjtcbn1cblxuZXhwb3J0cy5UUkFDSU5HX0RFRkFVTFRTID0gVFJBQ0lOR19ERUZBVUxUUztcbmV4cG9ydHMuc3RhcnRJZGxlU3BhbiA9IHN0YXJ0SWRsZVNwYW47XG4vLyMgc291cmNlTWFwcGluZ1VSTD1pZGxlU3Bhbi5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/idleSpan.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/logSpans.js":
/*!********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/logSpans.js ***!
  \********************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst debugBuild = __webpack_require__(/*! ../debug-build.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst debugLogger = __webpack_require__(/*! ../utils/debug-logger.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst spanUtils = __webpack_require__(/*! ../utils/spanUtils.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanUtils.js\");\n\n/**\n * Print a log message for a started span.\n */\nfunction logSpanStart(span) {\n  if (!debugBuild.DEBUG_BUILD) return;\n\n  const { description = '< unknown name >', op = '< unknown op >', parent_span_id: parentSpanId } = spanUtils.spanToJSON(span);\n  const { spanId } = span.spanContext();\n\n  const sampled = spanUtils.spanIsSampled(span);\n  const rootSpan = spanUtils.getRootSpan(span);\n  const isRootSpan = rootSpan === span;\n\n  const header = `[Tracing] Starting ${sampled ? 'sampled' : 'unsampled'} ${isRootSpan ? 'root ' : ''}span`;\n\n  const infoParts = [`op: ${op}`, `name: ${description}`, `ID: ${spanId}`];\n\n  if (parentSpanId) {\n    infoParts.push(`parent ID: ${parentSpanId}`);\n  }\n\n  if (!isRootSpan) {\n    const { op, description } = spanUtils.spanToJSON(rootSpan);\n    infoParts.push(`root ID: ${rootSpan.spanContext().spanId}`);\n    if (op) {\n      infoParts.push(`root op: ${op}`);\n    }\n    if (description) {\n      infoParts.push(`root description: ${description}`);\n    }\n  }\n\n  debugLogger.debug.log(`${header}\n  ${infoParts.join('\\n  ')}`);\n}\n\n/**\n * Print a log message for an ended span.\n */\nfunction logSpanEnd(span) {\n  if (!debugBuild.DEBUG_BUILD) return;\n\n  const { description = '< unknown name >', op = '< unknown op >' } = spanUtils.spanToJSON(span);\n  const { spanId } = span.spanContext();\n  const rootSpan = spanUtils.getRootSpan(span);\n  const isRootSpan = rootSpan === span;\n\n  const msg = `[Tracing] Finishing \"${op}\" ${isRootSpan ? 'root ' : ''}span \"${description}\" with ID ${spanId}`;\n  debugLogger.debug.log(msg);\n}\n\nexports.logSpanEnd = logSpanEnd;\nexports.logSpanStart = logSpanStart;\n//# sourceMappingURL=logSpans.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy90cmFjaW5nL2xvZ1NwYW5zLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLG1CQUFtQixtQkFBTyxDQUFDLDRIQUFtQjtBQUM5QyxvQkFBb0IsbUJBQU8sQ0FBQywwSUFBMEI7QUFDdEQsa0JBQWtCLG1CQUFPLENBQUMsb0lBQXVCOztBQUVqRDtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLFVBQVUsd0ZBQXdGO0FBQ2xHLFVBQVUsU0FBUzs7QUFFbkI7QUFDQTtBQUNBOztBQUVBLHVDQUF1QyxtQ0FBbUMsRUFBRSwwQkFBMEI7O0FBRXRHLDRCQUE0QixHQUFHLFlBQVksWUFBWSxVQUFVLE9BQU87O0FBRXhFO0FBQ0EsaUNBQWlDLGFBQWE7QUFDOUM7O0FBRUE7QUFDQSxZQUFZLGtCQUFrQjtBQUM5QiwrQkFBK0IsOEJBQThCO0FBQzdEO0FBQ0EsaUNBQWlDLEdBQUc7QUFDcEM7QUFDQTtBQUNBLDBDQUEwQyxZQUFZO0FBQ3REO0FBQ0E7O0FBRUEsMkJBQTJCO0FBQzNCLElBQUksdUJBQXVCO0FBQzNCOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsVUFBVSwwREFBMEQ7QUFDcEUsVUFBVSxTQUFTO0FBQ25CO0FBQ0E7O0FBRUEsc0NBQXNDLEdBQUcsSUFBSSwwQkFBMEIsUUFBUSxZQUFZLFlBQVksT0FBTztBQUM5RztBQUNBOztBQUVBLGtCQUFrQjtBQUNsQixvQkFBb0I7QUFDcEIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy90cmFjaW5nL2xvZ1NwYW5zLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBkZWJ1Z0J1aWxkID0gcmVxdWlyZSgnLi4vZGVidWctYnVpbGQuanMnKTtcbmNvbnN0IGRlYnVnTG9nZ2VyID0gcmVxdWlyZSgnLi4vdXRpbHMvZGVidWctbG9nZ2VyLmpzJyk7XG5jb25zdCBzcGFuVXRpbHMgPSByZXF1aXJlKCcuLi91dGlscy9zcGFuVXRpbHMuanMnKTtcblxuLyoqXG4gKiBQcmludCBhIGxvZyBtZXNzYWdlIGZvciBhIHN0YXJ0ZWQgc3Bhbi5cbiAqL1xuZnVuY3Rpb24gbG9nU3BhblN0YXJ0KHNwYW4pIHtcbiAgaWYgKCFkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEKSByZXR1cm47XG5cbiAgY29uc3QgeyBkZXNjcmlwdGlvbiA9ICc8IHVua25vd24gbmFtZSA+Jywgb3AgPSAnPCB1bmtub3duIG9wID4nLCBwYXJlbnRfc3Bhbl9pZDogcGFyZW50U3BhbklkIH0gPSBzcGFuVXRpbHMuc3BhblRvSlNPTihzcGFuKTtcbiAgY29uc3QgeyBzcGFuSWQgfSA9IHNwYW4uc3BhbkNvbnRleHQoKTtcblxuICBjb25zdCBzYW1wbGVkID0gc3BhblV0aWxzLnNwYW5Jc1NhbXBsZWQoc3Bhbik7XG4gIGNvbnN0IHJvb3RTcGFuID0gc3BhblV0aWxzLmdldFJvb3RTcGFuKHNwYW4pO1xuICBjb25zdCBpc1Jvb3RTcGFuID0gcm9vdFNwYW4gPT09IHNwYW47XG5cbiAgY29uc3QgaGVhZGVyID0gYFtUcmFjaW5nXSBTdGFydGluZyAke3NhbXBsZWQgPyAnc2FtcGxlZCcgOiAndW5zYW1wbGVkJ30gJHtpc1Jvb3RTcGFuID8gJ3Jvb3QgJyA6ICcnfXNwYW5gO1xuXG4gIGNvbnN0IGluZm9QYXJ0cyA9IFtgb3A6ICR7b3B9YCwgYG5hbWU6ICR7ZGVzY3JpcHRpb259YCwgYElEOiAke3NwYW5JZH1gXTtcblxuICBpZiAocGFyZW50U3BhbklkKSB7XG4gICAgaW5mb1BhcnRzLnB1c2goYHBhcmVudCBJRDogJHtwYXJlbnRTcGFuSWR9YCk7XG4gIH1cblxuICBpZiAoIWlzUm9vdFNwYW4pIHtcbiAgICBjb25zdCB7IG9wLCBkZXNjcmlwdGlvbiB9ID0gc3BhblV0aWxzLnNwYW5Ub0pTT04ocm9vdFNwYW4pO1xuICAgIGluZm9QYXJ0cy5wdXNoKGByb290IElEOiAke3Jvb3RTcGFuLnNwYW5Db250ZXh0KCkuc3BhbklkfWApO1xuICAgIGlmIChvcCkge1xuICAgICAgaW5mb1BhcnRzLnB1c2goYHJvb3Qgb3A6ICR7b3B9YCk7XG4gICAgfVxuICAgIGlmIChkZXNjcmlwdGlvbikge1xuICAgICAgaW5mb1BhcnRzLnB1c2goYHJvb3QgZGVzY3JpcHRpb246ICR7ZGVzY3JpcHRpb259YCk7XG4gICAgfVxuICB9XG5cbiAgZGVidWdMb2dnZXIuZGVidWcubG9nKGAke2hlYWRlcn1cbiAgJHtpbmZvUGFydHMuam9pbignXFxuICAnKX1gKTtcbn1cblxuLyoqXG4gKiBQcmludCBhIGxvZyBtZXNzYWdlIGZvciBhbiBlbmRlZCBzcGFuLlxuICovXG5mdW5jdGlvbiBsb2dTcGFuRW5kKHNwYW4pIHtcbiAgaWYgKCFkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEKSByZXR1cm47XG5cbiAgY29uc3QgeyBkZXNjcmlwdGlvbiA9ICc8IHVua25vd24gbmFtZSA+Jywgb3AgPSAnPCB1bmtub3duIG9wID4nIH0gPSBzcGFuVXRpbHMuc3BhblRvSlNPTihzcGFuKTtcbiAgY29uc3QgeyBzcGFuSWQgfSA9IHNwYW4uc3BhbkNvbnRleHQoKTtcbiAgY29uc3Qgcm9vdFNwYW4gPSBzcGFuVXRpbHMuZ2V0Um9vdFNwYW4oc3Bhbik7XG4gIGNvbnN0IGlzUm9vdFNwYW4gPSByb290U3BhbiA9PT0gc3BhbjtcblxuICBjb25zdCBtc2cgPSBgW1RyYWNpbmddIEZpbmlzaGluZyBcIiR7b3B9XCIgJHtpc1Jvb3RTcGFuID8gJ3Jvb3QgJyA6ICcnfXNwYW4gXCIke2Rlc2NyaXB0aW9ufVwiIHdpdGggSUQgJHtzcGFuSWR9YDtcbiAgZGVidWdMb2dnZXIuZGVidWcubG9nKG1zZyk7XG59XG5cbmV4cG9ydHMubG9nU3BhbkVuZCA9IGxvZ1NwYW5FbmQ7XG5leHBvcnRzLmxvZ1NwYW5TdGFydCA9IGxvZ1NwYW5TdGFydDtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWxvZ1NwYW5zLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/logSpans.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/measurement.js":
/*!***********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/measurement.js ***!
  \***********************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst debugBuild = __webpack_require__(/*! ../debug-build.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst semanticAttributes = __webpack_require__(/*! ../semanticAttributes.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/semanticAttributes.js\");\nconst debugLogger = __webpack_require__(/*! ../utils/debug-logger.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst spanUtils = __webpack_require__(/*! ../utils/spanUtils.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanUtils.js\");\n\n/**\n * Adds a measurement to the active transaction on the current global scope. You can optionally pass in a different span\n * as the 4th parameter.\n */\nfunction setMeasurement(name, value, unit, activeSpan = spanUtils.getActiveSpan()) {\n  const rootSpan = activeSpan && spanUtils.getRootSpan(activeSpan);\n\n  if (rootSpan) {\n    debugBuild.DEBUG_BUILD && debugLogger.debug.log(`[Measurement] Setting measurement on root span: ${name} = ${value} ${unit}`);\n    rootSpan.addEvent(name, {\n      [semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_MEASUREMENT_VALUE]: value,\n      [semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_MEASUREMENT_UNIT]: unit ,\n    });\n  }\n}\n\n/**\n * Convert timed events to measurements.\n */\nfunction timedEventsToMeasurements(events) {\n  if (!events || events.length === 0) {\n    return undefined;\n  }\n\n  const measurements = {};\n  events.forEach(event => {\n    const attributes = event.attributes || {};\n    const unit = attributes[semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_MEASUREMENT_UNIT] ;\n    const value = attributes[semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_MEASUREMENT_VALUE] ;\n\n    if (typeof unit === 'string' && typeof value === 'number') {\n      measurements[event.name] = { value, unit };\n    }\n  });\n\n  return measurements;\n}\n\nexports.setMeasurement = setMeasurement;\nexports.timedEventsToMeasurements = timedEventsToMeasurements;\n//# sourceMappingURL=measurement.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy90cmFjaW5nL21lYXN1cmVtZW50LmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLG1CQUFtQixtQkFBTyxDQUFDLDRIQUFtQjtBQUM5QywyQkFBMkIsbUJBQU8sQ0FBQywwSUFBMEI7QUFDN0Qsb0JBQW9CLG1CQUFPLENBQUMsMElBQTBCO0FBQ3RELGtCQUFrQixtQkFBTyxDQUFDLG9JQUF1Qjs7QUFFakQ7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0EsdUdBQXVHLE1BQU0sSUFBSSxPQUFPLEVBQUUsS0FBSztBQUMvSDtBQUNBO0FBQ0E7QUFDQSxLQUFLO0FBQ0w7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0EsbUNBQW1DO0FBQ25DO0FBQ0EsR0FBRzs7QUFFSDtBQUNBOztBQUVBLHNCQUFzQjtBQUN0QixpQ0FBaUM7QUFDakMiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy90cmFjaW5nL21lYXN1cmVtZW50LmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBkZWJ1Z0J1aWxkID0gcmVxdWlyZSgnLi4vZGVidWctYnVpbGQuanMnKTtcbmNvbnN0IHNlbWFudGljQXR0cmlidXRlcyA9IHJlcXVpcmUoJy4uL3NlbWFudGljQXR0cmlidXRlcy5qcycpO1xuY29uc3QgZGVidWdMb2dnZXIgPSByZXF1aXJlKCcuLi91dGlscy9kZWJ1Zy1sb2dnZXIuanMnKTtcbmNvbnN0IHNwYW5VdGlscyA9IHJlcXVpcmUoJy4uL3V0aWxzL3NwYW5VdGlscy5qcycpO1xuXG4vKipcbiAqIEFkZHMgYSBtZWFzdXJlbWVudCB0byB0aGUgYWN0aXZlIHRyYW5zYWN0aW9uIG9uIHRoZSBjdXJyZW50IGdsb2JhbCBzY29wZS4gWW91IGNhbiBvcHRpb25hbGx5IHBhc3MgaW4gYSBkaWZmZXJlbnQgc3BhblxuICogYXMgdGhlIDR0aCBwYXJhbWV0ZXIuXG4gKi9cbmZ1bmN0aW9uIHNldE1lYXN1cmVtZW50KG5hbWUsIHZhbHVlLCB1bml0LCBhY3RpdmVTcGFuID0gc3BhblV0aWxzLmdldEFjdGl2ZVNwYW4oKSkge1xuICBjb25zdCByb290U3BhbiA9IGFjdGl2ZVNwYW4gJiYgc3BhblV0aWxzLmdldFJvb3RTcGFuKGFjdGl2ZVNwYW4pO1xuXG4gIGlmIChyb290U3Bhbikge1xuICAgIGRlYnVnQnVpbGQuREVCVUdfQlVJTEQgJiYgZGVidWdMb2dnZXIuZGVidWcubG9nKGBbTWVhc3VyZW1lbnRdIFNldHRpbmcgbWVhc3VyZW1lbnQgb24gcm9vdCBzcGFuOiAke25hbWV9ID0gJHt2YWx1ZX0gJHt1bml0fWApO1xuICAgIHJvb3RTcGFuLmFkZEV2ZW50KG5hbWUsIHtcbiAgICAgIFtzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9NRUFTVVJFTUVOVF9WQUxVRV06IHZhbHVlLFxuICAgICAgW3NlbWFudGljQXR0cmlidXRlcy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX01FQVNVUkVNRU5UX1VOSVRdOiB1bml0ICxcbiAgICB9KTtcbiAgfVxufVxuXG4vKipcbiAqIENvbnZlcnQgdGltZWQgZXZlbnRzIHRvIG1lYXN1cmVtZW50cy5cbiAqL1xuZnVuY3Rpb24gdGltZWRFdmVudHNUb01lYXN1cmVtZW50cyhldmVudHMpIHtcbiAgaWYgKCFldmVudHMgfHwgZXZlbnRzLmxlbmd0aCA9PT0gMCkge1xuICAgIHJldHVybiB1bmRlZmluZWQ7XG4gIH1cblxuICBjb25zdCBtZWFzdXJlbWVudHMgPSB7fTtcbiAgZXZlbnRzLmZvckVhY2goZXZlbnQgPT4ge1xuICAgIGNvbnN0IGF0dHJpYnV0ZXMgPSBldmVudC5hdHRyaWJ1dGVzIHx8IHt9O1xuICAgIGNvbnN0IHVuaXQgPSBhdHRyaWJ1dGVzW3NlbWFudGljQXR0cmlidXRlcy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX01FQVNVUkVNRU5UX1VOSVRdIDtcbiAgICBjb25zdCB2YWx1ZSA9IGF0dHJpYnV0ZXNbc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfTUVBU1VSRU1FTlRfVkFMVUVdIDtcblxuICAgIGlmICh0eXBlb2YgdW5pdCA9PT0gJ3N0cmluZycgJiYgdHlwZW9mIHZhbHVlID09PSAnbnVtYmVyJykge1xuICAgICAgbWVhc3VyZW1lbnRzW2V2ZW50Lm5hbWVdID0geyB2YWx1ZSwgdW5pdCB9O1xuICAgIH1cbiAgfSk7XG5cbiAgcmV0dXJuIG1lYXN1cmVtZW50cztcbn1cblxuZXhwb3J0cy5zZXRNZWFzdXJlbWVudCA9IHNldE1lYXN1cmVtZW50O1xuZXhwb3J0cy50aW1lZEV2ZW50c1RvTWVhc3VyZW1lbnRzID0gdGltZWRFdmVudHNUb01lYXN1cmVtZW50cztcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPW1lYXN1cmVtZW50LmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/measurement.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/sampling.js":
/*!********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/sampling.js ***!
  \********************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst debugBuild = __webpack_require__(/*! ../debug-build.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst debugLogger = __webpack_require__(/*! ../utils/debug-logger.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst hasSpansEnabled = __webpack_require__(/*! ../utils/hasSpansEnabled.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/hasSpansEnabled.js\");\nconst parseSampleRate = __webpack_require__(/*! ../utils/parseSampleRate.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/parseSampleRate.js\");\n\n/**\n * Makes a sampling decision for the given options.\n *\n * Called every time a root span is created. Only root spans which emerge with a `sampled` value of `true` will be\n * sent to Sentry.\n */\nfunction sampleSpan(\n  options,\n  samplingContext,\n  sampleRand,\n) {\n  // nothing to do if span recording is not enabled\n  if (!hasSpansEnabled.hasSpansEnabled(options)) {\n    return [false];\n  }\n\n  let localSampleRateWasApplied = undefined;\n\n  // we would have bailed already if neither `tracesSampler` nor `tracesSampleRate` were defined, so one of these should\n  // work; prefer the hook if so\n  let sampleRate;\n  if (typeof options.tracesSampler === 'function') {\n    sampleRate = options.tracesSampler({\n      ...samplingContext,\n      inheritOrSampleWith: fallbackSampleRate => {\n        // If we have an incoming parent sample rate, we'll just use that one.\n        // The sampling decision will be inherited because of the sample_rand that was generated when the trace reached the incoming boundaries of the SDK.\n        if (typeof samplingContext.parentSampleRate === 'number') {\n          return samplingContext.parentSampleRate;\n        }\n\n        // Fallback if parent sample rate is not on the incoming trace (e.g. if there is no baggage)\n        // This is to provide backwards compatibility if there are incoming traces from older SDKs that don't send a parent sample rate or a sample rand. In these cases we just want to force either a sampling decision on the downstream traces via the sample rate.\n        if (typeof samplingContext.parentSampled === 'boolean') {\n          return Number(samplingContext.parentSampled);\n        }\n\n        return fallbackSampleRate;\n      },\n    });\n    localSampleRateWasApplied = true;\n  } else if (samplingContext.parentSampled !== undefined) {\n    sampleRate = samplingContext.parentSampled;\n  } else if (typeof options.tracesSampleRate !== 'undefined') {\n    sampleRate = options.tracesSampleRate;\n    localSampleRateWasApplied = true;\n  }\n\n  // Since this is coming from the user (or from a function provided by the user), who knows what we might get.\n  // (The only valid values are booleans or numbers between 0 and 1.)\n  const parsedSampleRate = parseSampleRate.parseSampleRate(sampleRate);\n\n  if (parsedSampleRate === undefined) {\n    debugBuild.DEBUG_BUILD &&\n      debugLogger.debug.warn(\n        `[Tracing] Discarding root span because of invalid sample rate. Sample rate must be a boolean or a number between 0 and 1. Got ${JSON.stringify(\n          sampleRate,\n        )} of type ${JSON.stringify(typeof sampleRate)}.`,\n      );\n    return [false];\n  }\n\n  // if the function returned 0 (or false), or if `tracesSampleRate` is 0, it's a sign the transaction should be dropped\n  if (!parsedSampleRate) {\n    debugBuild.DEBUG_BUILD &&\n      debugLogger.debug.log(\n        `[Tracing] Discarding transaction because ${\n          typeof options.tracesSampler === 'function'\n            ? 'tracesSampler returned 0 or false'\n            : 'a negative sampling decision was inherited or tracesSampleRate is set to 0'\n        }`,\n      );\n    return [false, parsedSampleRate, localSampleRateWasApplied];\n  }\n\n  // We always compare the sample rand for the current execution context against the chosen sample rate.\n  // Read more: https://develop.sentry.dev/sdk/telemetry/traces/#propagated-random-value\n  const shouldSample = sampleRand < parsedSampleRate;\n\n  // if we're not going to keep it, we're done\n  if (!shouldSample) {\n    debugBuild.DEBUG_BUILD &&\n      debugLogger.debug.log(\n        `[Tracing] Discarding transaction because it's not included in the random sample (sampling rate = ${Number(\n          sampleRate,\n        )})`,\n      );\n  }\n\n  return [shouldSample, parsedSampleRate, localSampleRateWasApplied];\n}\n\nexports.sampleSpan = sampleSpan;\n//# sourceMappingURL=sampling.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy90cmFjaW5nL3NhbXBsaW5nLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLG1CQUFtQixtQkFBTyxDQUFDLDRIQUFtQjtBQUM5QyxvQkFBb0IsbUJBQU8sQ0FBQywwSUFBMEI7QUFDdEQsd0JBQXdCLG1CQUFPLENBQUMsZ0pBQTZCO0FBQzdELHdCQUF3QixtQkFBTyxDQUFDLGdKQUE2Qjs7QUFFN0Q7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBOztBQUVBO0FBQ0EsV0FBVztBQUNYO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQSxPQUFPO0FBQ1AsS0FBSztBQUNMO0FBQ0EsSUFBSTtBQUNKO0FBQ0EsSUFBSTtBQUNKO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0EseUlBQXlJO0FBQ3pJO0FBQ0EsV0FBVyxVQUFVLGtDQUFrQztBQUN2RDtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFNBQVM7QUFDVDtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsNEdBQTRHO0FBQzVHO0FBQ0EsVUFBVTtBQUNWO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQSxrQkFBa0I7QUFDbEIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy90cmFjaW5nL3NhbXBsaW5nLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBkZWJ1Z0J1aWxkID0gcmVxdWlyZSgnLi4vZGVidWctYnVpbGQuanMnKTtcbmNvbnN0IGRlYnVnTG9nZ2VyID0gcmVxdWlyZSgnLi4vdXRpbHMvZGVidWctbG9nZ2VyLmpzJyk7XG5jb25zdCBoYXNTcGFuc0VuYWJsZWQgPSByZXF1aXJlKCcuLi91dGlscy9oYXNTcGFuc0VuYWJsZWQuanMnKTtcbmNvbnN0IHBhcnNlU2FtcGxlUmF0ZSA9IHJlcXVpcmUoJy4uL3V0aWxzL3BhcnNlU2FtcGxlUmF0ZS5qcycpO1xuXG4vKipcbiAqIE1ha2VzIGEgc2FtcGxpbmcgZGVjaXNpb24gZm9yIHRoZSBnaXZlbiBvcHRpb25zLlxuICpcbiAqIENhbGxlZCBldmVyeSB0aW1lIGEgcm9vdCBzcGFuIGlzIGNyZWF0ZWQuIE9ubHkgcm9vdCBzcGFucyB3aGljaCBlbWVyZ2Ugd2l0aCBhIGBzYW1wbGVkYCB2YWx1ZSBvZiBgdHJ1ZWAgd2lsbCBiZVxuICogc2VudCB0byBTZW50cnkuXG4gKi9cbmZ1bmN0aW9uIHNhbXBsZVNwYW4oXG4gIG9wdGlvbnMsXG4gIHNhbXBsaW5nQ29udGV4dCxcbiAgc2FtcGxlUmFuZCxcbikge1xuICAvLyBub3RoaW5nIHRvIGRvIGlmIHNwYW4gcmVjb3JkaW5nIGlzIG5vdCBlbmFibGVkXG4gIGlmICghaGFzU3BhbnNFbmFibGVkLmhhc1NwYW5zRW5hYmxlZChvcHRpb25zKSkge1xuICAgIHJldHVybiBbZmFsc2VdO1xuICB9XG5cbiAgbGV0IGxvY2FsU2FtcGxlUmF0ZVdhc0FwcGxpZWQgPSB1bmRlZmluZWQ7XG5cbiAgLy8gd2Ugd291bGQgaGF2ZSBiYWlsZWQgYWxyZWFkeSBpZiBuZWl0aGVyIGB0cmFjZXNTYW1wbGVyYCBub3IgYHRyYWNlc1NhbXBsZVJhdGVgIHdlcmUgZGVmaW5lZCwgc28gb25lIG9mIHRoZXNlIHNob3VsZFxuICAvLyB3b3JrOyBwcmVmZXIgdGhlIGhvb2sgaWYgc29cbiAgbGV0IHNhbXBsZVJhdGU7XG4gIGlmICh0eXBlb2Ygb3B0aW9ucy50cmFjZXNTYW1wbGVyID09PSAnZnVuY3Rpb24nKSB7XG4gICAgc2FtcGxlUmF0ZSA9IG9wdGlvbnMudHJhY2VzU2FtcGxlcih7XG4gICAgICAuLi5zYW1wbGluZ0NvbnRleHQsXG4gICAgICBpbmhlcml0T3JTYW1wbGVXaXRoOiBmYWxsYmFja1NhbXBsZVJhdGUgPT4ge1xuICAgICAgICAvLyBJZiB3ZSBoYXZlIGFuIGluY29taW5nIHBhcmVudCBzYW1wbGUgcmF0ZSwgd2UnbGwganVzdCB1c2UgdGhhdCBvbmUuXG4gICAgICAgIC8vIFRoZSBzYW1wbGluZyBkZWNpc2lvbiB3aWxsIGJlIGluaGVyaXRlZCBiZWNhdXNlIG9mIHRoZSBzYW1wbGVfcmFuZCB0aGF0IHdhcyBnZW5lcmF0ZWQgd2hlbiB0aGUgdHJhY2UgcmVhY2hlZCB0aGUgaW5jb21pbmcgYm91bmRhcmllcyBvZiB0aGUgU0RLLlxuICAgICAgICBpZiAodHlwZW9mIHNhbXBsaW5nQ29udGV4dC5wYXJlbnRTYW1wbGVSYXRlID09PSAnbnVtYmVyJykge1xuICAgICAgICAgIHJldHVybiBzYW1wbGluZ0NvbnRleHQucGFyZW50U2FtcGxlUmF0ZTtcbiAgICAgICAgfVxuXG4gICAgICAgIC8vIEZhbGxiYWNrIGlmIHBhcmVudCBzYW1wbGUgcmF0ZSBpcyBub3Qgb24gdGhlIGluY29taW5nIHRyYWNlIChlLmcuIGlmIHRoZXJlIGlzIG5vIGJhZ2dhZ2UpXG4gICAgICAgIC8vIFRoaXMgaXMgdG8gcHJvdmlkZSBiYWNrd2FyZHMgY29tcGF0aWJpbGl0eSBpZiB0aGVyZSBhcmUgaW5jb21pbmcgdHJhY2VzIGZyb20gb2xkZXIgU0RLcyB0aGF0IGRvbid0IHNlbmQgYSBwYXJlbnQgc2FtcGxlIHJhdGUgb3IgYSBzYW1wbGUgcmFuZC4gSW4gdGhlc2UgY2FzZXMgd2UganVzdCB3YW50IHRvIGZvcmNlIGVpdGhlciBhIHNhbXBsaW5nIGRlY2lzaW9uIG9uIHRoZSBkb3duc3RyZWFtIHRyYWNlcyB2aWEgdGhlIHNhbXBsZSByYXRlLlxuICAgICAgICBpZiAodHlwZW9mIHNhbXBsaW5nQ29udGV4dC5wYXJlbnRTYW1wbGVkID09PSAnYm9vbGVhbicpIHtcbiAgICAgICAgICByZXR1cm4gTnVtYmVyKHNhbXBsaW5nQ29udGV4dC5wYXJlbnRTYW1wbGVkKTtcbiAgICAgICAgfVxuXG4gICAgICAgIHJldHVybiBmYWxsYmFja1NhbXBsZVJhdGU7XG4gICAgICB9LFxuICAgIH0pO1xuICAgIGxvY2FsU2FtcGxlUmF0ZVdhc0FwcGxpZWQgPSB0cnVlO1xuICB9IGVsc2UgaWYgKHNhbXBsaW5nQ29udGV4dC5wYXJlbnRTYW1wbGVkICE9PSB1bmRlZmluZWQpIHtcbiAgICBzYW1wbGVSYXRlID0gc2FtcGxpbmdDb250ZXh0LnBhcmVudFNhbXBsZWQ7XG4gIH0gZWxzZSBpZiAodHlwZW9mIG9wdGlvbnMudHJhY2VzU2FtcGxlUmF0ZSAhPT0gJ3VuZGVmaW5lZCcpIHtcbiAgICBzYW1wbGVSYXRlID0gb3B0aW9ucy50cmFjZXNTYW1wbGVSYXRlO1xuICAgIGxvY2FsU2FtcGxlUmF0ZVdhc0FwcGxpZWQgPSB0cnVlO1xuICB9XG5cbiAgLy8gU2luY2UgdGhpcyBpcyBjb21pbmcgZnJvbSB0aGUgdXNlciAob3IgZnJvbSBhIGZ1bmN0aW9uIHByb3ZpZGVkIGJ5IHRoZSB1c2VyKSwgd2hvIGtub3dzIHdoYXQgd2UgbWlnaHQgZ2V0LlxuICAvLyAoVGhlIG9ubHkgdmFsaWQgdmFsdWVzIGFyZSBib29sZWFucyBvciBudW1iZXJzIGJldHdlZW4gMCBhbmQgMS4pXG4gIGNvbnN0IHBhcnNlZFNhbXBsZVJhdGUgPSBwYXJzZVNhbXBsZVJhdGUucGFyc2VTYW1wbGVSYXRlKHNhbXBsZVJhdGUpO1xuXG4gIGlmIChwYXJzZWRTYW1wbGVSYXRlID09PSB1bmRlZmluZWQpIHtcbiAgICBkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEICYmXG4gICAgICBkZWJ1Z0xvZ2dlci5kZWJ1Zy53YXJuKFxuICAgICAgICBgW1RyYWNpbmddIERpc2NhcmRpbmcgcm9vdCBzcGFuIGJlY2F1c2Ugb2YgaW52YWxpZCBzYW1wbGUgcmF0ZS4gU2FtcGxlIHJhdGUgbXVzdCBiZSBhIGJvb2xlYW4gb3IgYSBudW1iZXIgYmV0d2VlbiAwIGFuZCAxLiBHb3QgJHtKU09OLnN0cmluZ2lmeShcbiAgICAgICAgICBzYW1wbGVSYXRlLFxuICAgICAgICApfSBvZiB0eXBlICR7SlNPTi5zdHJpbmdpZnkodHlwZW9mIHNhbXBsZVJhdGUpfS5gLFxuICAgICAgKTtcbiAgICByZXR1cm4gW2ZhbHNlXTtcbiAgfVxuXG4gIC8vIGlmIHRoZSBmdW5jdGlvbiByZXR1cm5lZCAwIChvciBmYWxzZSksIG9yIGlmIGB0cmFjZXNTYW1wbGVSYXRlYCBpcyAwLCBpdCdzIGEgc2lnbiB0aGUgdHJhbnNhY3Rpb24gc2hvdWxkIGJlIGRyb3BwZWRcbiAgaWYgKCFwYXJzZWRTYW1wbGVSYXRlKSB7XG4gICAgZGVidWdCdWlsZC5ERUJVR19CVUlMRCAmJlxuICAgICAgZGVidWdMb2dnZXIuZGVidWcubG9nKFxuICAgICAgICBgW1RyYWNpbmddIERpc2NhcmRpbmcgdHJhbnNhY3Rpb24gYmVjYXVzZSAke1xuICAgICAgICAgIHR5cGVvZiBvcHRpb25zLnRyYWNlc1NhbXBsZXIgPT09ICdmdW5jdGlvbidcbiAgICAgICAgICAgID8gJ3RyYWNlc1NhbXBsZXIgcmV0dXJuZWQgMCBvciBmYWxzZSdcbiAgICAgICAgICAgIDogJ2EgbmVnYXRpdmUgc2FtcGxpbmcgZGVjaXNpb24gd2FzIGluaGVyaXRlZCBvciB0cmFjZXNTYW1wbGVSYXRlIGlzIHNldCB0byAwJ1xuICAgICAgICB9YCxcbiAgICAgICk7XG4gICAgcmV0dXJuIFtmYWxzZSwgcGFyc2VkU2FtcGxlUmF0ZSwgbG9jYWxTYW1wbGVSYXRlV2FzQXBwbGllZF07XG4gIH1cblxuICAvLyBXZSBhbHdheXMgY29tcGFyZSB0aGUgc2FtcGxlIHJhbmQgZm9yIHRoZSBjdXJyZW50IGV4ZWN1dGlvbiBjb250ZXh0IGFnYWluc3QgdGhlIGNob3NlbiBzYW1wbGUgcmF0ZS5cbiAgLy8gUmVhZCBtb3JlOiBodHRwczovL2RldmVsb3Auc2VudHJ5LmRldi9zZGsvdGVsZW1ldHJ5L3RyYWNlcy8jcHJvcGFnYXRlZC1yYW5kb20tdmFsdWVcbiAgY29uc3Qgc2hvdWxkU2FtcGxlID0gc2FtcGxlUmFuZCA8IHBhcnNlZFNhbXBsZVJhdGU7XG5cbiAgLy8gaWYgd2UncmUgbm90IGdvaW5nIHRvIGtlZXAgaXQsIHdlJ3JlIGRvbmVcbiAgaWYgKCFzaG91bGRTYW1wbGUpIHtcbiAgICBkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEICYmXG4gICAgICBkZWJ1Z0xvZ2dlci5kZWJ1Zy5sb2coXG4gICAgICAgIGBbVHJhY2luZ10gRGlzY2FyZGluZyB0cmFuc2FjdGlvbiBiZWNhdXNlIGl0J3Mgbm90IGluY2x1ZGVkIGluIHRoZSByYW5kb20gc2FtcGxlIChzYW1wbGluZyByYXRlID0gJHtOdW1iZXIoXG4gICAgICAgICAgc2FtcGxlUmF0ZSxcbiAgICAgICAgKX0pYCxcbiAgICAgICk7XG4gIH1cblxuICByZXR1cm4gW3Nob3VsZFNhbXBsZSwgcGFyc2VkU2FtcGxlUmF0ZSwgbG9jYWxTYW1wbGVSYXRlV2FzQXBwbGllZF07XG59XG5cbmV4cG9ydHMuc2FtcGxlU3BhbiA9IHNhbXBsZVNwYW47XG4vLyMgc291cmNlTWFwcGluZ1VSTD1zYW1wbGluZy5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/sampling.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/sentryNonRecordingSpan.js":
/*!**********************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/sentryNonRecordingSpan.js ***!
  \**********************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst propagationContext = __webpack_require__(/*! ../utils/propagationContext.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/propagationContext.js\");\nconst spanUtils = __webpack_require__(/*! ../utils/spanUtils.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanUtils.js\");\n\n/**\n * A Sentry Span that is non-recording, meaning it will not be sent to Sentry.\n */\nclass SentryNonRecordingSpan  {\n\n   constructor(spanContext = {}) {\n    this._traceId = spanContext.traceId || propagationContext.generateTraceId();\n    this._spanId = spanContext.spanId || propagationContext.generateSpanId();\n  }\n\n  /** @inheritdoc */\n   spanContext() {\n    return {\n      spanId: this._spanId,\n      traceId: this._traceId,\n      traceFlags: spanUtils.TRACE_FLAG_NONE,\n    };\n  }\n\n  /** @inheritdoc */\n   end(_timestamp) {}\n\n  /** @inheritdoc */\n   setAttribute(_key, _value) {\n    return this;\n  }\n\n  /** @inheritdoc */\n   setAttributes(_values) {\n    return this;\n  }\n\n  /** @inheritdoc */\n   setStatus(_status) {\n    return this;\n  }\n\n  /** @inheritdoc */\n   updateName(_name) {\n    return this;\n  }\n\n  /** @inheritdoc */\n   isRecording() {\n    return false;\n  }\n\n  /** @inheritdoc */\n   addEvent(\n    _name,\n    _attributesOrStartTime,\n    _startTime,\n  ) {\n    return this;\n  }\n\n  /** @inheritDoc */\n   addLink(_link) {\n    return this;\n  }\n\n  /** @inheritDoc */\n   addLinks(_links) {\n    return this;\n  }\n\n  /**\n   * This should generally not be used,\n   * but we need it for being compliant with the OTEL Span interface.\n   *\n   * @hidden\n   * @internal\n   */\n   recordException(_exception, _time) {\n    // noop\n  }\n}\n\nexports.SentryNonRecordingSpan = SentryNonRecordingSpan;\n//# sourceMappingURL=sentryNonRecordingSpan.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy90cmFjaW5nL3NlbnRyeU5vblJlY29yZGluZ1NwYW4uanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsMkJBQTJCLG1CQUFPLENBQUMsc0pBQWdDO0FBQ25FLGtCQUFrQixtQkFBTyxDQUFDLG9JQUF1Qjs7QUFFakQ7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsK0JBQStCO0FBQy9CO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLDhCQUE4QjtBQUM5QiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3RyYWNpbmcvc2VudHJ5Tm9uUmVjb3JkaW5nU3Bhbi5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgcHJvcGFnYXRpb25Db250ZXh0ID0gcmVxdWlyZSgnLi4vdXRpbHMvcHJvcGFnYXRpb25Db250ZXh0LmpzJyk7XG5jb25zdCBzcGFuVXRpbHMgPSByZXF1aXJlKCcuLi91dGlscy9zcGFuVXRpbHMuanMnKTtcblxuLyoqXG4gKiBBIFNlbnRyeSBTcGFuIHRoYXQgaXMgbm9uLXJlY29yZGluZywgbWVhbmluZyBpdCB3aWxsIG5vdCBiZSBzZW50IHRvIFNlbnRyeS5cbiAqL1xuY2xhc3MgU2VudHJ5Tm9uUmVjb3JkaW5nU3BhbiAge1xuXG4gICBjb25zdHJ1Y3RvcihzcGFuQ29udGV4dCA9IHt9KSB7XG4gICAgdGhpcy5fdHJhY2VJZCA9IHNwYW5Db250ZXh0LnRyYWNlSWQgfHwgcHJvcGFnYXRpb25Db250ZXh0LmdlbmVyYXRlVHJhY2VJZCgpO1xuICAgIHRoaXMuX3NwYW5JZCA9IHNwYW5Db250ZXh0LnNwYW5JZCB8fCBwcm9wYWdhdGlvbkNvbnRleHQuZ2VuZXJhdGVTcGFuSWQoKTtcbiAgfVxuXG4gIC8qKiBAaW5oZXJpdGRvYyAqL1xuICAgc3BhbkNvbnRleHQoKSB7XG4gICAgcmV0dXJuIHtcbiAgICAgIHNwYW5JZDogdGhpcy5fc3BhbklkLFxuICAgICAgdHJhY2VJZDogdGhpcy5fdHJhY2VJZCxcbiAgICAgIHRyYWNlRmxhZ3M6IHNwYW5VdGlscy5UUkFDRV9GTEFHX05PTkUsXG4gICAgfTtcbiAgfVxuXG4gIC8qKiBAaW5oZXJpdGRvYyAqL1xuICAgZW5kKF90aW1lc3RhbXApIHt9XG5cbiAgLyoqIEBpbmhlcml0ZG9jICovXG4gICBzZXRBdHRyaWJ1dGUoX2tleSwgX3ZhbHVlKSB7XG4gICAgcmV0dXJuIHRoaXM7XG4gIH1cblxuICAvKiogQGluaGVyaXRkb2MgKi9cbiAgIHNldEF0dHJpYnV0ZXMoX3ZhbHVlcykge1xuICAgIHJldHVybiB0aGlzO1xuICB9XG5cbiAgLyoqIEBpbmhlcml0ZG9jICovXG4gICBzZXRTdGF0dXMoX3N0YXR1cykge1xuICAgIHJldHVybiB0aGlzO1xuICB9XG5cbiAgLyoqIEBpbmhlcml0ZG9jICovXG4gICB1cGRhdGVOYW1lKF9uYW1lKSB7XG4gICAgcmV0dXJuIHRoaXM7XG4gIH1cblxuICAvKiogQGluaGVyaXRkb2MgKi9cbiAgIGlzUmVjb3JkaW5nKCkge1xuICAgIHJldHVybiBmYWxzZTtcbiAgfVxuXG4gIC8qKiBAaW5oZXJpdGRvYyAqL1xuICAgYWRkRXZlbnQoXG4gICAgX25hbWUsXG4gICAgX2F0dHJpYnV0ZXNPclN0YXJ0VGltZSxcbiAgICBfc3RhcnRUaW1lLFxuICApIHtcbiAgICByZXR1cm4gdGhpcztcbiAgfVxuXG4gIC8qKiBAaW5oZXJpdERvYyAqL1xuICAgYWRkTGluayhfbGluaykge1xuICAgIHJldHVybiB0aGlzO1xuICB9XG5cbiAgLyoqIEBpbmhlcml0RG9jICovXG4gICBhZGRMaW5rcyhfbGlua3MpIHtcbiAgICByZXR1cm4gdGhpcztcbiAgfVxuXG4gIC8qKlxuICAgKiBUaGlzIHNob3VsZCBnZW5lcmFsbHkgbm90IGJlIHVzZWQsXG4gICAqIGJ1dCB3ZSBuZWVkIGl0IGZvciBiZWluZyBjb21wbGlhbnQgd2l0aCB0aGUgT1RFTCBTcGFuIGludGVyZmFjZS5cbiAgICpcbiAgICogQGhpZGRlblxuICAgKiBAaW50ZXJuYWxcbiAgICovXG4gICByZWNvcmRFeGNlcHRpb24oX2V4Y2VwdGlvbiwgX3RpbWUpIHtcbiAgICAvLyBub29wXG4gIH1cbn1cblxuZXhwb3J0cy5TZW50cnlOb25SZWNvcmRpbmdTcGFuID0gU2VudHJ5Tm9uUmVjb3JkaW5nU3Bhbjtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPXNlbnRyeU5vblJlY29yZGluZ1NwYW4uanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/sentryNonRecordingSpan.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/sentrySpan.js":
/*!**********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/sentrySpan.js ***!
  \**********************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst currentScopes = __webpack_require__(/*! ../currentScopes.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst debugBuild = __webpack_require__(/*! ../debug-build.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst envelope = __webpack_require__(/*! ../envelope.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/envelope.js\");\nconst semanticAttributes = __webpack_require__(/*! ../semanticAttributes.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/semanticAttributes.js\");\nconst debugLogger = __webpack_require__(/*! ../utils/debug-logger.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst propagationContext = __webpack_require__(/*! ../utils/propagationContext.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/propagationContext.js\");\nconst spanUtils = __webpack_require__(/*! ../utils/spanUtils.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanUtils.js\");\nconst time = __webpack_require__(/*! ../utils/time.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/time.js\");\nconst dynamicSamplingContext = __webpack_require__(/*! ./dynamicSamplingContext.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/dynamicSamplingContext.js\");\nconst logSpans = __webpack_require__(/*! ./logSpans.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/logSpans.js\");\nconst measurement = __webpack_require__(/*! ./measurement.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/measurement.js\");\nconst utils = __webpack_require__(/*! ./utils.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/utils.js\");\n\nconst MAX_SPAN_COUNT = 1000;\n\n/**\n * Span contains all data about a span\n */\nclass SentrySpan  {\n\n  /** Epoch timestamp in seconds when the span started. */\n\n  /** Epoch timestamp in seconds when the span ended. */\n\n  /** Internal keeper of the status */\n\n  /** The timed events added to this span. */\n\n  /** if true, treat span as a standalone span (not part of a transaction) */\n\n  /**\n   * You should never call the constructor manually, always use `Sentry.startSpan()`\n   * or other span methods.\n   * @internal\n   * @hideconstructor\n   * @hidden\n   */\n   constructor(spanContext = {}) {\n    this._traceId = spanContext.traceId || propagationContext.generateTraceId();\n    this._spanId = spanContext.spanId || propagationContext.generateSpanId();\n    this._startTime = spanContext.startTimestamp || time.timestampInSeconds();\n    this._links = spanContext.links;\n\n    this._attributes = {};\n    this.setAttributes({\n      [semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_ORIGIN]: 'manual',\n      [semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_OP]: spanContext.op,\n      ...spanContext.attributes,\n    });\n\n    this._name = spanContext.name;\n\n    if (spanContext.parentSpanId) {\n      this._parentSpanId = spanContext.parentSpanId;\n    }\n    // We want to include booleans as well here\n    if ('sampled' in spanContext) {\n      this._sampled = spanContext.sampled;\n    }\n    if (spanContext.endTimestamp) {\n      this._endTime = spanContext.endTimestamp;\n    }\n\n    this._events = [];\n\n    this._isStandaloneSpan = spanContext.isStandalone;\n\n    // If the span is already ended, ensure we finalize the span immediately\n    if (this._endTime) {\n      this._onSpanEnded();\n    }\n  }\n\n  /** @inheritDoc */\n   addLink(link) {\n    if (this._links) {\n      this._links.push(link);\n    } else {\n      this._links = [link];\n    }\n    return this;\n  }\n\n  /** @inheritDoc */\n   addLinks(links) {\n    if (this._links) {\n      this._links.push(...links);\n    } else {\n      this._links = links;\n    }\n    return this;\n  }\n\n  /**\n   * This should generally not be used,\n   * but it is needed for being compliant with the OTEL Span interface.\n   *\n   * @hidden\n   * @internal\n   */\n   recordException(_exception, _time) {\n    // noop\n  }\n\n  /** @inheritdoc */\n   spanContext() {\n    const { _spanId: spanId, _traceId: traceId, _sampled: sampled } = this;\n    return {\n      spanId,\n      traceId,\n      traceFlags: sampled ? spanUtils.TRACE_FLAG_SAMPLED : spanUtils.TRACE_FLAG_NONE,\n    };\n  }\n\n  /** @inheritdoc */\n   setAttribute(key, value) {\n    if (value === undefined) {\n      // eslint-disable-next-line @typescript-eslint/no-dynamic-delete\n      delete this._attributes[key];\n    } else {\n      this._attributes[key] = value;\n    }\n\n    return this;\n  }\n\n  /** @inheritdoc */\n   setAttributes(attributes) {\n    Object.keys(attributes).forEach(key => this.setAttribute(key, attributes[key]));\n    return this;\n  }\n\n  /**\n   * This should generally not be used,\n   * but we need it for browser tracing where we want to adjust the start time afterwards.\n   * USE THIS WITH CAUTION!\n   *\n   * @hidden\n   * @internal\n   */\n   updateStartTime(timeInput) {\n    this._startTime = spanUtils.spanTimeInputToSeconds(timeInput);\n  }\n\n  /**\n   * @inheritDoc\n   */\n   setStatus(value) {\n    this._status = value;\n    return this;\n  }\n\n  /**\n   * @inheritDoc\n   */\n   updateName(name) {\n    this._name = name;\n    this.setAttribute(semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_SOURCE, 'custom');\n    return this;\n  }\n\n  /** @inheritdoc */\n   end(endTimestamp) {\n    // If already ended, skip\n    if (this._endTime) {\n      return;\n    }\n\n    this._endTime = spanUtils.spanTimeInputToSeconds(endTimestamp);\n    logSpans.logSpanEnd(this);\n\n    this._onSpanEnded();\n  }\n\n  /**\n   * Get JSON representation of this span.\n   *\n   * @hidden\n   * @internal This method is purely for internal purposes and should not be used outside\n   * of SDK code. If you need to get a JSON representation of a span,\n   * use `spanToJSON(span)` instead.\n   */\n   getSpanJSON() {\n    return {\n      data: this._attributes,\n      description: this._name,\n      op: this._attributes[semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_OP],\n      parent_span_id: this._parentSpanId,\n      span_id: this._spanId,\n      start_timestamp: this._startTime,\n      status: spanUtils.getStatusMessage(this._status),\n      timestamp: this._endTime,\n      trace_id: this._traceId,\n      origin: this._attributes[semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_ORIGIN] ,\n      profile_id: this._attributes[semanticAttributes.SEMANTIC_ATTRIBUTE_PROFILE_ID] ,\n      exclusive_time: this._attributes[semanticAttributes.SEMANTIC_ATTRIBUTE_EXCLUSIVE_TIME] ,\n      measurements: measurement.timedEventsToMeasurements(this._events),\n      is_segment: (this._isStandaloneSpan && spanUtils.getRootSpan(this) === this) || undefined,\n      segment_id: this._isStandaloneSpan ? spanUtils.getRootSpan(this).spanContext().spanId : undefined,\n      links: spanUtils.convertSpanLinksForEnvelope(this._links),\n    };\n  }\n\n  /** @inheritdoc */\n   isRecording() {\n    return !this._endTime && !!this._sampled;\n  }\n\n  /**\n   * @inheritdoc\n   */\n   addEvent(\n    name,\n    attributesOrStartTime,\n    startTime,\n  ) {\n    debugBuild.DEBUG_BUILD && debugLogger.debug.log('[Tracing] Adding an event to span:', name);\n\n    const time$1 = isSpanTimeInput(attributesOrStartTime) ? attributesOrStartTime : startTime || time.timestampInSeconds();\n    const attributes = isSpanTimeInput(attributesOrStartTime) ? {} : attributesOrStartTime || {};\n\n    const event = {\n      name,\n      time: spanUtils.spanTimeInputToSeconds(time$1),\n      attributes,\n    };\n\n    this._events.push(event);\n\n    return this;\n  }\n\n  /**\n   * This method should generally not be used,\n   * but for now we need a way to publicly check if the `_isStandaloneSpan` flag is set.\n   * USE THIS WITH CAUTION!\n   * @internal\n   * @hidden\n   * @experimental\n   */\n   isStandaloneSpan() {\n    return !!this._isStandaloneSpan;\n  }\n\n  /** Emit `spanEnd` when the span is ended. */\n   _onSpanEnded() {\n    const client = currentScopes.getClient();\n    if (client) {\n      client.emit('spanEnd', this);\n    }\n\n    // A segment span is basically the root span of a local span tree.\n    // So for now, this is either what we previously refer to as the root span,\n    // or a standalone span.\n    const isSegmentSpan = this._isStandaloneSpan || this === spanUtils.getRootSpan(this);\n\n    if (!isSegmentSpan) {\n      return;\n    }\n\n    // if this is a standalone span, we send it immediately\n    if (this._isStandaloneSpan) {\n      if (this._sampled) {\n        sendSpanEnvelope(envelope.createSpanEnvelope([this], client));\n      } else {\n        debugBuild.DEBUG_BUILD &&\n          debugLogger.debug.log('[Tracing] Discarding standalone span because its trace was not chosen to be sampled.');\n        if (client) {\n          client.recordDroppedEvent('sample_rate', 'span');\n        }\n      }\n      return;\n    }\n\n    const transactionEvent = this._convertSpanToTransaction();\n    if (transactionEvent) {\n      const scope = utils.getCapturedScopesOnSpan(this).scope || currentScopes.getCurrentScope();\n      scope.captureEvent(transactionEvent);\n    }\n  }\n\n  /**\n   * Finish the transaction & prepare the event to send to Sentry.\n   */\n   _convertSpanToTransaction() {\n    // We can only convert finished spans\n    if (!isFullFinishedSpan(spanUtils.spanToJSON(this))) {\n      return undefined;\n    }\n\n    if (!this._name) {\n      debugBuild.DEBUG_BUILD && debugLogger.debug.warn('Transaction has no name, falling back to `<unlabeled transaction>`.');\n      this._name = '<unlabeled transaction>';\n    }\n\n    const { scope: capturedSpanScope, isolationScope: capturedSpanIsolationScope } = utils.getCapturedScopesOnSpan(this);\n\n    const normalizedRequest = capturedSpanScope?.getScopeData().sdkProcessingMetadata?.normalizedRequest;\n\n    if (this._sampled !== true) {\n      return undefined;\n    }\n\n    // The transaction span itself as well as any potential standalone spans should be filtered out\n    const finishedSpans = spanUtils.getSpanDescendants(this).filter(span => span !== this && !isStandaloneSpan(span));\n\n    const spans = finishedSpans.map(span => spanUtils.spanToJSON(span)).filter(isFullFinishedSpan);\n\n    const source = this._attributes[semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_SOURCE] ;\n\n    // remove internal root span attributes we don't need to send.\n    /* eslint-disable @typescript-eslint/no-dynamic-delete */\n    delete this._attributes[semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_CUSTOM_SPAN_NAME];\n    spans.forEach(span => {\n      delete span.data[semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_CUSTOM_SPAN_NAME];\n    });\n    // eslint-enabled-next-line @typescript-eslint/no-dynamic-delete\n\n    const transaction = {\n      contexts: {\n        trace: spanUtils.spanToTransactionTraceContext(this),\n      },\n      spans:\n        // spans.sort() mutates the array, but `spans` is already a copy so we can safely do this here\n        // we do not use spans anymore after this point\n        spans.length > MAX_SPAN_COUNT\n          ? spans.sort((a, b) => a.start_timestamp - b.start_timestamp).slice(0, MAX_SPAN_COUNT)\n          : spans,\n      start_timestamp: this._startTime,\n      timestamp: this._endTime,\n      transaction: this._name,\n      type: 'transaction',\n      sdkProcessingMetadata: {\n        capturedSpanScope,\n        capturedSpanIsolationScope,\n        dynamicSamplingContext: dynamicSamplingContext.getDynamicSamplingContextFromSpan(this),\n      },\n      request: normalizedRequest,\n      ...(source && {\n        transaction_info: {\n          source,\n        },\n      }),\n    };\n\n    const measurements = measurement.timedEventsToMeasurements(this._events);\n    const hasMeasurements = measurements && Object.keys(measurements).length;\n\n    if (hasMeasurements) {\n      debugBuild.DEBUG_BUILD &&\n        debugLogger.debug.log(\n          '[Measurements] Adding measurements to transaction event',\n          JSON.stringify(measurements, undefined, 2),\n        );\n      transaction.measurements = measurements;\n    }\n\n    return transaction;\n  }\n}\n\nfunction isSpanTimeInput(value) {\n  return (value && typeof value === 'number') || value instanceof Date || Array.isArray(value);\n}\n\n// We want to filter out any incomplete SpanJSON objects\nfunction isFullFinishedSpan(input) {\n  return !!input.start_timestamp && !!input.timestamp && !!input.span_id && !!input.trace_id;\n}\n\n/** `SentrySpan`s can be sent as a standalone span rather than belonging to a transaction */\nfunction isStandaloneSpan(span) {\n  return span instanceof SentrySpan && span.isStandaloneSpan();\n}\n\n/**\n * Sends a `SpanEnvelope`.\n *\n * Note: If the envelope's spans are dropped, e.g. via `beforeSendSpan`,\n * the envelope will not be sent either.\n */\nfunction sendSpanEnvelope(envelope) {\n  const client = currentScopes.getClient();\n  if (!client) {\n    return;\n  }\n\n  const spanItems = envelope[1];\n  if (!spanItems || spanItems.length === 0) {\n    client.recordDroppedEvent('before_send', 'span');\n    return;\n  }\n\n  // sendEnvelope should not throw\n  // eslint-disable-next-line @typescript-eslint/no-floating-promises\n  client.sendEnvelope(envelope);\n}\n\nexports.SentrySpan = SentrySpan;\n//# sourceMappingURL=sentrySpan.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy90cmFjaW5nL3NlbnRyeVNwYW4uanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsc0JBQXNCLG1CQUFPLENBQUMsZ0lBQXFCO0FBQ25ELG1CQUFtQixtQkFBTyxDQUFDLDRIQUFtQjtBQUM5QyxpQkFBaUIsbUJBQU8sQ0FBQyxzSEFBZ0I7QUFDekMsMkJBQTJCLG1CQUFPLENBQUMsMElBQTBCO0FBQzdELG9CQUFvQixtQkFBTyxDQUFDLDBJQUEwQjtBQUN0RCwyQkFBMkIsbUJBQU8sQ0FBQyxzSkFBZ0M7QUFDbkUsa0JBQWtCLG1CQUFPLENBQUMsb0lBQXVCO0FBQ2pELGFBQWEsbUJBQU8sQ0FBQywwSEFBa0I7QUFDdkMsK0JBQStCLG1CQUFPLENBQUMseUpBQTZCO0FBQ3BFLGlCQUFpQixtQkFBTyxDQUFDLDZIQUFlO0FBQ3hDLG9CQUFvQixtQkFBTyxDQUFDLG1JQUFrQjtBQUM5QyxjQUFjLG1CQUFPLENBQUMsdUhBQVk7O0FBRWxDOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBOztBQUVBOztBQUVBOztBQUVBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsK0JBQStCO0FBQy9CO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxLQUFLOztBQUVMOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQSxNQUFNO0FBQ047QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQSxNQUFNO0FBQ047QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLFlBQVksd0RBQXdEO0FBQ3BFO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsTUFBTTtBQUNOO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBLG1FQUFtRTs7QUFFbkU7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFFBQVE7QUFDUjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLFlBQVksdUVBQXVFOztBQUVuRjs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsS0FBSztBQUNMOztBQUVBO0FBQ0E7QUFDQTtBQUNBLE9BQU87QUFDUDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsT0FBTztBQUNQO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsU0FBUztBQUNULE9BQU87QUFDUDs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsa0JBQWtCO0FBQ2xCIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdHJhY2luZy9zZW50cnlTcGFuLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBjdXJyZW50U2NvcGVzID0gcmVxdWlyZSgnLi4vY3VycmVudFNjb3Blcy5qcycpO1xuY29uc3QgZGVidWdCdWlsZCA9IHJlcXVpcmUoJy4uL2RlYnVnLWJ1aWxkLmpzJyk7XG5jb25zdCBlbnZlbG9wZSA9IHJlcXVpcmUoJy4uL2VudmVsb3BlLmpzJyk7XG5jb25zdCBzZW1hbnRpY0F0dHJpYnV0ZXMgPSByZXF1aXJlKCcuLi9zZW1hbnRpY0F0dHJpYnV0ZXMuanMnKTtcbmNvbnN0IGRlYnVnTG9nZ2VyID0gcmVxdWlyZSgnLi4vdXRpbHMvZGVidWctbG9nZ2VyLmpzJyk7XG5jb25zdCBwcm9wYWdhdGlvbkNvbnRleHQgPSByZXF1aXJlKCcuLi91dGlscy9wcm9wYWdhdGlvbkNvbnRleHQuanMnKTtcbmNvbnN0IHNwYW5VdGlscyA9IHJlcXVpcmUoJy4uL3V0aWxzL3NwYW5VdGlscy5qcycpO1xuY29uc3QgdGltZSA9IHJlcXVpcmUoJy4uL3V0aWxzL3RpbWUuanMnKTtcbmNvbnN0IGR5bmFtaWNTYW1wbGluZ0NvbnRleHQgPSByZXF1aXJlKCcuL2R5bmFtaWNTYW1wbGluZ0NvbnRleHQuanMnKTtcbmNvbnN0IGxvZ1NwYW5zID0gcmVxdWlyZSgnLi9sb2dTcGFucy5qcycpO1xuY29uc3QgbWVhc3VyZW1lbnQgPSByZXF1aXJlKCcuL21lYXN1cmVtZW50LmpzJyk7XG5jb25zdCB1dGlscyA9IHJlcXVpcmUoJy4vdXRpbHMuanMnKTtcblxuY29uc3QgTUFYX1NQQU5fQ09VTlQgPSAxMDAwO1xuXG4vKipcbiAqIFNwYW4gY29udGFpbnMgYWxsIGRhdGEgYWJvdXQgYSBzcGFuXG4gKi9cbmNsYXNzIFNlbnRyeVNwYW4gIHtcblxuICAvKiogRXBvY2ggdGltZXN0YW1wIGluIHNlY29uZHMgd2hlbiB0aGUgc3BhbiBzdGFydGVkLiAqL1xuXG4gIC8qKiBFcG9jaCB0aW1lc3RhbXAgaW4gc2Vjb25kcyB3aGVuIHRoZSBzcGFuIGVuZGVkLiAqL1xuXG4gIC8qKiBJbnRlcm5hbCBrZWVwZXIgb2YgdGhlIHN0YXR1cyAqL1xuXG4gIC8qKiBUaGUgdGltZWQgZXZlbnRzIGFkZGVkIHRvIHRoaXMgc3Bhbi4gKi9cblxuICAvKiogaWYgdHJ1ZSwgdHJlYXQgc3BhbiBhcyBhIHN0YW5kYWxvbmUgc3BhbiAobm90IHBhcnQgb2YgYSB0cmFuc2FjdGlvbikgKi9cblxuICAvKipcbiAgICogWW91IHNob3VsZCBuZXZlciBjYWxsIHRoZSBjb25zdHJ1Y3RvciBtYW51YWxseSwgYWx3YXlzIHVzZSBgU2VudHJ5LnN0YXJ0U3BhbigpYFxuICAgKiBvciBvdGhlciBzcGFuIG1ldGhvZHMuXG4gICAqIEBpbnRlcm5hbFxuICAgKiBAaGlkZWNvbnN0cnVjdG9yXG4gICAqIEBoaWRkZW5cbiAgICovXG4gICBjb25zdHJ1Y3RvcihzcGFuQ29udGV4dCA9IHt9KSB7XG4gICAgdGhpcy5fdHJhY2VJZCA9IHNwYW5Db250ZXh0LnRyYWNlSWQgfHwgcHJvcGFnYXRpb25Db250ZXh0LmdlbmVyYXRlVHJhY2VJZCgpO1xuICAgIHRoaXMuX3NwYW5JZCA9IHNwYW5Db250ZXh0LnNwYW5JZCB8fCBwcm9wYWdhdGlvbkNvbnRleHQuZ2VuZXJhdGVTcGFuSWQoKTtcbiAgICB0aGlzLl9zdGFydFRpbWUgPSBzcGFuQ29udGV4dC5zdGFydFRpbWVzdGFtcCB8fCB0aW1lLnRpbWVzdGFtcEluU2Vjb25kcygpO1xuICAgIHRoaXMuX2xpbmtzID0gc3BhbkNvbnRleHQubGlua3M7XG5cbiAgICB0aGlzLl9hdHRyaWJ1dGVzID0ge307XG4gICAgdGhpcy5zZXRBdHRyaWJ1dGVzKHtcbiAgICAgIFtzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9PUklHSU5dOiAnbWFudWFsJyxcbiAgICAgIFtzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9PUF06IHNwYW5Db250ZXh0Lm9wLFxuICAgICAgLi4uc3BhbkNvbnRleHQuYXR0cmlidXRlcyxcbiAgICB9KTtcblxuICAgIHRoaXMuX25hbWUgPSBzcGFuQ29udGV4dC5uYW1lO1xuXG4gICAgaWYgKHNwYW5Db250ZXh0LnBhcmVudFNwYW5JZCkge1xuICAgICAgdGhpcy5fcGFyZW50U3BhbklkID0gc3BhbkNvbnRleHQucGFyZW50U3BhbklkO1xuICAgIH1cbiAgICAvLyBXZSB3YW50IHRvIGluY2x1ZGUgYm9vbGVhbnMgYXMgd2VsbCBoZXJlXG4gICAgaWYgKCdzYW1wbGVkJyBpbiBzcGFuQ29udGV4dCkge1xuICAgICAgdGhpcy5fc2FtcGxlZCA9IHNwYW5Db250ZXh0LnNhbXBsZWQ7XG4gICAgfVxuICAgIGlmIChzcGFuQ29udGV4dC5lbmRUaW1lc3RhbXApIHtcbiAgICAgIHRoaXMuX2VuZFRpbWUgPSBzcGFuQ29udGV4dC5lbmRUaW1lc3RhbXA7XG4gICAgfVxuXG4gICAgdGhpcy5fZXZlbnRzID0gW107XG5cbiAgICB0aGlzLl9pc1N0YW5kYWxvbmVTcGFuID0gc3BhbkNvbnRleHQuaXNTdGFuZGFsb25lO1xuXG4gICAgLy8gSWYgdGhlIHNwYW4gaXMgYWxyZWFkeSBlbmRlZCwgZW5zdXJlIHdlIGZpbmFsaXplIHRoZSBzcGFuIGltbWVkaWF0ZWx5XG4gICAgaWYgKHRoaXMuX2VuZFRpbWUpIHtcbiAgICAgIHRoaXMuX29uU3BhbkVuZGVkKCk7XG4gICAgfVxuICB9XG5cbiAgLyoqIEBpbmhlcml0RG9jICovXG4gICBhZGRMaW5rKGxpbmspIHtcbiAgICBpZiAodGhpcy5fbGlua3MpIHtcbiAgICAgIHRoaXMuX2xpbmtzLnB1c2gobGluayk7XG4gICAgfSBlbHNlIHtcbiAgICAgIHRoaXMuX2xpbmtzID0gW2xpbmtdO1xuICAgIH1cbiAgICByZXR1cm4gdGhpcztcbiAgfVxuXG4gIC8qKiBAaW5oZXJpdERvYyAqL1xuICAgYWRkTGlua3MobGlua3MpIHtcbiAgICBpZiAodGhpcy5fbGlua3MpIHtcbiAgICAgIHRoaXMuX2xpbmtzLnB1c2goLi4ubGlua3MpO1xuICAgIH0gZWxzZSB7XG4gICAgICB0aGlzLl9saW5rcyA9IGxpbmtzO1xuICAgIH1cbiAgICByZXR1cm4gdGhpcztcbiAgfVxuXG4gIC8qKlxuICAgKiBUaGlzIHNob3VsZCBnZW5lcmFsbHkgbm90IGJlIHVzZWQsXG4gICAqIGJ1dCBpdCBpcyBuZWVkZWQgZm9yIGJlaW5nIGNvbXBsaWFudCB3aXRoIHRoZSBPVEVMIFNwYW4gaW50ZXJmYWNlLlxuICAgKlxuICAgKiBAaGlkZGVuXG4gICAqIEBpbnRlcm5hbFxuICAgKi9cbiAgIHJlY29yZEV4Y2VwdGlvbihfZXhjZXB0aW9uLCBfdGltZSkge1xuICAgIC8vIG5vb3BcbiAgfVxuXG4gIC8qKiBAaW5oZXJpdGRvYyAqL1xuICAgc3BhbkNvbnRleHQoKSB7XG4gICAgY29uc3QgeyBfc3BhbklkOiBzcGFuSWQsIF90cmFjZUlkOiB0cmFjZUlkLCBfc2FtcGxlZDogc2FtcGxlZCB9ID0gdGhpcztcbiAgICByZXR1cm4ge1xuICAgICAgc3BhbklkLFxuICAgICAgdHJhY2VJZCxcbiAgICAgIHRyYWNlRmxhZ3M6IHNhbXBsZWQgPyBzcGFuVXRpbHMuVFJBQ0VfRkxBR19TQU1QTEVEIDogc3BhblV0aWxzLlRSQUNFX0ZMQUdfTk9ORSxcbiAgICB9O1xuICB9XG5cbiAgLyoqIEBpbmhlcml0ZG9jICovXG4gICBzZXRBdHRyaWJ1dGUoa2V5LCB2YWx1ZSkge1xuICAgIGlmICh2YWx1ZSA9PT0gdW5kZWZpbmVkKSB7XG4gICAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25vLWR5bmFtaWMtZGVsZXRlXG4gICAgICBkZWxldGUgdGhpcy5fYXR0cmlidXRlc1trZXldO1xuICAgIH0gZWxzZSB7XG4gICAgICB0aGlzLl9hdHRyaWJ1dGVzW2tleV0gPSB2YWx1ZTtcbiAgICB9XG5cbiAgICByZXR1cm4gdGhpcztcbiAgfVxuXG4gIC8qKiBAaW5oZXJpdGRvYyAqL1xuICAgc2V0QXR0cmlidXRlcyhhdHRyaWJ1dGVzKSB7XG4gICAgT2JqZWN0LmtleXMoYXR0cmlidXRlcykuZm9yRWFjaChrZXkgPT4gdGhpcy5zZXRBdHRyaWJ1dGUoa2V5LCBhdHRyaWJ1dGVzW2tleV0pKTtcbiAgICByZXR1cm4gdGhpcztcbiAgfVxuXG4gIC8qKlxuICAgKiBUaGlzIHNob3VsZCBnZW5lcmFsbHkgbm90IGJlIHVzZWQsXG4gICAqIGJ1dCB3ZSBuZWVkIGl0IGZvciBicm93c2VyIHRyYWNpbmcgd2hlcmUgd2Ugd2FudCB0byBhZGp1c3QgdGhlIHN0YXJ0IHRpbWUgYWZ0ZXJ3YXJkcy5cbiAgICogVVNFIFRISVMgV0lUSCBDQVVUSU9OIVxuICAgKlxuICAgKiBAaGlkZGVuXG4gICAqIEBpbnRlcm5hbFxuICAgKi9cbiAgIHVwZGF0ZVN0YXJ0VGltZSh0aW1lSW5wdXQpIHtcbiAgICB0aGlzLl9zdGFydFRpbWUgPSBzcGFuVXRpbHMuc3BhblRpbWVJbnB1dFRvU2Vjb25kcyh0aW1lSW5wdXQpO1xuICB9XG5cbiAgLyoqXG4gICAqIEBpbmhlcml0RG9jXG4gICAqL1xuICAgc2V0U3RhdHVzKHZhbHVlKSB7XG4gICAgdGhpcy5fc3RhdHVzID0gdmFsdWU7XG4gICAgcmV0dXJuIHRoaXM7XG4gIH1cblxuICAvKipcbiAgICogQGluaGVyaXREb2NcbiAgICovXG4gICB1cGRhdGVOYW1lKG5hbWUpIHtcbiAgICB0aGlzLl9uYW1lID0gbmFtZTtcbiAgICB0aGlzLnNldEF0dHJpYnV0ZShzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9TT1VSQ0UsICdjdXN0b20nKTtcbiAgICByZXR1cm4gdGhpcztcbiAgfVxuXG4gIC8qKiBAaW5oZXJpdGRvYyAqL1xuICAgZW5kKGVuZFRpbWVzdGFtcCkge1xuICAgIC8vIElmIGFscmVhZHkgZW5kZWQsIHNraXBcbiAgICBpZiAodGhpcy5fZW5kVGltZSkge1xuICAgICAgcmV0dXJuO1xuICAgIH1cblxuICAgIHRoaXMuX2VuZFRpbWUgPSBzcGFuVXRpbHMuc3BhblRpbWVJbnB1dFRvU2Vjb25kcyhlbmRUaW1lc3RhbXApO1xuICAgIGxvZ1NwYW5zLmxvZ1NwYW5FbmQodGhpcyk7XG5cbiAgICB0aGlzLl9vblNwYW5FbmRlZCgpO1xuICB9XG5cbiAgLyoqXG4gICAqIEdldCBKU09OIHJlcHJlc2VudGF0aW9uIG9mIHRoaXMgc3Bhbi5cbiAgICpcbiAgICogQGhpZGRlblxuICAgKiBAaW50ZXJuYWwgVGhpcyBtZXRob2QgaXMgcHVyZWx5IGZvciBpbnRlcm5hbCBwdXJwb3NlcyBhbmQgc2hvdWxkIG5vdCBiZSB1c2VkIG91dHNpZGVcbiAgICogb2YgU0RLIGNvZGUuIElmIHlvdSBuZWVkIHRvIGdldCBhIEpTT04gcmVwcmVzZW50YXRpb24gb2YgYSBzcGFuLFxuICAgKiB1c2UgYHNwYW5Ub0pTT04oc3BhbilgIGluc3RlYWQuXG4gICAqL1xuICAgZ2V0U3BhbkpTT04oKSB7XG4gICAgcmV0dXJuIHtcbiAgICAgIGRhdGE6IHRoaXMuX2F0dHJpYnV0ZXMsXG4gICAgICBkZXNjcmlwdGlvbjogdGhpcy5fbmFtZSxcbiAgICAgIG9wOiB0aGlzLl9hdHRyaWJ1dGVzW3NlbWFudGljQXR0cmlidXRlcy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX09QXSxcbiAgICAgIHBhcmVudF9zcGFuX2lkOiB0aGlzLl9wYXJlbnRTcGFuSWQsXG4gICAgICBzcGFuX2lkOiB0aGlzLl9zcGFuSWQsXG4gICAgICBzdGFydF90aW1lc3RhbXA6IHRoaXMuX3N0YXJ0VGltZSxcbiAgICAgIHN0YXR1czogc3BhblV0aWxzLmdldFN0YXR1c01lc3NhZ2UodGhpcy5fc3RhdHVzKSxcbiAgICAgIHRpbWVzdGFtcDogdGhpcy5fZW5kVGltZSxcbiAgICAgIHRyYWNlX2lkOiB0aGlzLl90cmFjZUlkLFxuICAgICAgb3JpZ2luOiB0aGlzLl9hdHRyaWJ1dGVzW3NlbWFudGljQXR0cmlidXRlcy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX09SSUdJTl0gLFxuICAgICAgcHJvZmlsZV9pZDogdGhpcy5fYXR0cmlidXRlc1tzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX1BST0ZJTEVfSURdICxcbiAgICAgIGV4Y2x1c2l2ZV90aW1lOiB0aGlzLl9hdHRyaWJ1dGVzW3NlbWFudGljQXR0cmlidXRlcy5TRU1BTlRJQ19BVFRSSUJVVEVfRVhDTFVTSVZFX1RJTUVdICxcbiAgICAgIG1lYXN1cmVtZW50czogbWVhc3VyZW1lbnQudGltZWRFdmVudHNUb01lYXN1cmVtZW50cyh0aGlzLl9ldmVudHMpLFxuICAgICAgaXNfc2VnbWVudDogKHRoaXMuX2lzU3RhbmRhbG9uZVNwYW4gJiYgc3BhblV0aWxzLmdldFJvb3RTcGFuKHRoaXMpID09PSB0aGlzKSB8fCB1bmRlZmluZWQsXG4gICAgICBzZWdtZW50X2lkOiB0aGlzLl9pc1N0YW5kYWxvbmVTcGFuID8gc3BhblV0aWxzLmdldFJvb3RTcGFuKHRoaXMpLnNwYW5Db250ZXh0KCkuc3BhbklkIDogdW5kZWZpbmVkLFxuICAgICAgbGlua3M6IHNwYW5VdGlscy5jb252ZXJ0U3BhbkxpbmtzRm9yRW52ZWxvcGUodGhpcy5fbGlua3MpLFxuICAgIH07XG4gIH1cblxuICAvKiogQGluaGVyaXRkb2MgKi9cbiAgIGlzUmVjb3JkaW5nKCkge1xuICAgIHJldHVybiAhdGhpcy5fZW5kVGltZSAmJiAhIXRoaXMuX3NhbXBsZWQ7XG4gIH1cblxuICAvKipcbiAgICogQGluaGVyaXRkb2NcbiAgICovXG4gICBhZGRFdmVudChcbiAgICBuYW1lLFxuICAgIGF0dHJpYnV0ZXNPclN0YXJ0VGltZSxcbiAgICBzdGFydFRpbWUsXG4gICkge1xuICAgIGRlYnVnQnVpbGQuREVCVUdfQlVJTEQgJiYgZGVidWdMb2dnZXIuZGVidWcubG9nKCdbVHJhY2luZ10gQWRkaW5nIGFuIGV2ZW50IHRvIHNwYW46JywgbmFtZSk7XG5cbiAgICBjb25zdCB0aW1lJDEgPSBpc1NwYW5UaW1lSW5wdXQoYXR0cmlidXRlc09yU3RhcnRUaW1lKSA/IGF0dHJpYnV0ZXNPclN0YXJ0VGltZSA6IHN0YXJ0VGltZSB8fCB0aW1lLnRpbWVzdGFtcEluU2Vjb25kcygpO1xuICAgIGNvbnN0IGF0dHJpYnV0ZXMgPSBpc1NwYW5UaW1lSW5wdXQoYXR0cmlidXRlc09yU3RhcnRUaW1lKSA/IHt9IDogYXR0cmlidXRlc09yU3RhcnRUaW1lIHx8IHt9O1xuXG4gICAgY29uc3QgZXZlbnQgPSB7XG4gICAgICBuYW1lLFxuICAgICAgdGltZTogc3BhblV0aWxzLnNwYW5UaW1lSW5wdXRUb1NlY29uZHModGltZSQxKSxcbiAgICAgIGF0dHJpYnV0ZXMsXG4gICAgfTtcblxuICAgIHRoaXMuX2V2ZW50cy5wdXNoKGV2ZW50KTtcblxuICAgIHJldHVybiB0aGlzO1xuICB9XG5cbiAgLyoqXG4gICAqIFRoaXMgbWV0aG9kIHNob3VsZCBnZW5lcmFsbHkgbm90IGJlIHVzZWQsXG4gICAqIGJ1dCBmb3Igbm93IHdlIG5lZWQgYSB3YXkgdG8gcHVibGljbHkgY2hlY2sgaWYgdGhlIGBfaXNTdGFuZGFsb25lU3BhbmAgZmxhZyBpcyBzZXQuXG4gICAqIFVTRSBUSElTIFdJVEggQ0FVVElPTiFcbiAgICogQGludGVybmFsXG4gICAqIEBoaWRkZW5cbiAgICogQGV4cGVyaW1lbnRhbFxuICAgKi9cbiAgIGlzU3RhbmRhbG9uZVNwYW4oKSB7XG4gICAgcmV0dXJuICEhdGhpcy5faXNTdGFuZGFsb25lU3BhbjtcbiAgfVxuXG4gIC8qKiBFbWl0IGBzcGFuRW5kYCB3aGVuIHRoZSBzcGFuIGlzIGVuZGVkLiAqL1xuICAgX29uU3BhbkVuZGVkKCkge1xuICAgIGNvbnN0IGNsaWVudCA9IGN1cnJlbnRTY29wZXMuZ2V0Q2xpZW50KCk7XG4gICAgaWYgKGNsaWVudCkge1xuICAgICAgY2xpZW50LmVtaXQoJ3NwYW5FbmQnLCB0aGlzKTtcbiAgICB9XG5cbiAgICAvLyBBIHNlZ21lbnQgc3BhbiBpcyBiYXNpY2FsbHkgdGhlIHJvb3Qgc3BhbiBvZiBhIGxvY2FsIHNwYW4gdHJlZS5cbiAgICAvLyBTbyBmb3Igbm93LCB0aGlzIGlzIGVpdGhlciB3aGF0IHdlIHByZXZpb3VzbHkgcmVmZXIgdG8gYXMgdGhlIHJvb3Qgc3BhbixcbiAgICAvLyBvciBhIHN0YW5kYWxvbmUgc3Bhbi5cbiAgICBjb25zdCBpc1NlZ21lbnRTcGFuID0gdGhpcy5faXNTdGFuZGFsb25lU3BhbiB8fCB0aGlzID09PSBzcGFuVXRpbHMuZ2V0Um9vdFNwYW4odGhpcyk7XG5cbiAgICBpZiAoIWlzU2VnbWVudFNwYW4pIHtcbiAgICAgIHJldHVybjtcbiAgICB9XG5cbiAgICAvLyBpZiB0aGlzIGlzIGEgc3RhbmRhbG9uZSBzcGFuLCB3ZSBzZW5kIGl0IGltbWVkaWF0ZWx5XG4gICAgaWYgKHRoaXMuX2lzU3RhbmRhbG9uZVNwYW4pIHtcbiAgICAgIGlmICh0aGlzLl9zYW1wbGVkKSB7XG4gICAgICAgIHNlbmRTcGFuRW52ZWxvcGUoZW52ZWxvcGUuY3JlYXRlU3BhbkVudmVsb3BlKFt0aGlzXSwgY2xpZW50KSk7XG4gICAgICB9IGVsc2Uge1xuICAgICAgICBkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEICYmXG4gICAgICAgICAgZGVidWdMb2dnZXIuZGVidWcubG9nKCdbVHJhY2luZ10gRGlzY2FyZGluZyBzdGFuZGFsb25lIHNwYW4gYmVjYXVzZSBpdHMgdHJhY2Ugd2FzIG5vdCBjaG9zZW4gdG8gYmUgc2FtcGxlZC4nKTtcbiAgICAgICAgaWYgKGNsaWVudCkge1xuICAgICAgICAgIGNsaWVudC5yZWNvcmREcm9wcGVkRXZlbnQoJ3NhbXBsZV9yYXRlJywgJ3NwYW4nKTtcbiAgICAgICAgfVxuICAgICAgfVxuICAgICAgcmV0dXJuO1xuICAgIH1cblxuICAgIGNvbnN0IHRyYW5zYWN0aW9uRXZlbnQgPSB0aGlzLl9jb252ZXJ0U3BhblRvVHJhbnNhY3Rpb24oKTtcbiAgICBpZiAodHJhbnNhY3Rpb25FdmVudCkge1xuICAgICAgY29uc3Qgc2NvcGUgPSB1dGlscy5nZXRDYXB0dXJlZFNjb3Blc09uU3Bhbih0aGlzKS5zY29wZSB8fCBjdXJyZW50U2NvcGVzLmdldEN1cnJlbnRTY29wZSgpO1xuICAgICAgc2NvcGUuY2FwdHVyZUV2ZW50KHRyYW5zYWN0aW9uRXZlbnQpO1xuICAgIH1cbiAgfVxuXG4gIC8qKlxuICAgKiBGaW5pc2ggdGhlIHRyYW5zYWN0aW9uICYgcHJlcGFyZSB0aGUgZXZlbnQgdG8gc2VuZCB0byBTZW50cnkuXG4gICAqL1xuICAgX2NvbnZlcnRTcGFuVG9UcmFuc2FjdGlvbigpIHtcbiAgICAvLyBXZSBjYW4gb25seSBjb252ZXJ0IGZpbmlzaGVkIHNwYW5zXG4gICAgaWYgKCFpc0Z1bGxGaW5pc2hlZFNwYW4oc3BhblV0aWxzLnNwYW5Ub0pTT04odGhpcykpKSB7XG4gICAgICByZXR1cm4gdW5kZWZpbmVkO1xuICAgIH1cblxuICAgIGlmICghdGhpcy5fbmFtZSkge1xuICAgICAgZGVidWdCdWlsZC5ERUJVR19CVUlMRCAmJiBkZWJ1Z0xvZ2dlci5kZWJ1Zy53YXJuKCdUcmFuc2FjdGlvbiBoYXMgbm8gbmFtZSwgZmFsbGluZyBiYWNrIHRvIGA8dW5sYWJlbGVkIHRyYW5zYWN0aW9uPmAuJyk7XG4gICAgICB0aGlzLl9uYW1lID0gJzx1bmxhYmVsZWQgdHJhbnNhY3Rpb24+JztcbiAgICB9XG5cbiAgICBjb25zdCB7IHNjb3BlOiBjYXB0dXJlZFNwYW5TY29wZSwgaXNvbGF0aW9uU2NvcGU6IGNhcHR1cmVkU3Bhbklzb2xhdGlvblNjb3BlIH0gPSB1dGlscy5nZXRDYXB0dXJlZFNjb3Blc09uU3Bhbih0aGlzKTtcblxuICAgIGNvbnN0IG5vcm1hbGl6ZWRSZXF1ZXN0ID0gY2FwdHVyZWRTcGFuU2NvcGU/LmdldFNjb3BlRGF0YSgpLnNka1Byb2Nlc3NpbmdNZXRhZGF0YT8ubm9ybWFsaXplZFJlcXVlc3Q7XG5cbiAgICBpZiAodGhpcy5fc2FtcGxlZCAhPT0gdHJ1ZSkge1xuICAgICAgcmV0dXJuIHVuZGVmaW5lZDtcbiAgICB9XG5cbiAgICAvLyBUaGUgdHJhbnNhY3Rpb24gc3BhbiBpdHNlbGYgYXMgd2VsbCBhcyBhbnkgcG90ZW50aWFsIHN0YW5kYWxvbmUgc3BhbnMgc2hvdWxkIGJlIGZpbHRlcmVkIG91dFxuICAgIGNvbnN0IGZpbmlzaGVkU3BhbnMgPSBzcGFuVXRpbHMuZ2V0U3BhbkRlc2NlbmRhbnRzKHRoaXMpLmZpbHRlcihzcGFuID0+IHNwYW4gIT09IHRoaXMgJiYgIWlzU3RhbmRhbG9uZVNwYW4oc3BhbikpO1xuXG4gICAgY29uc3Qgc3BhbnMgPSBmaW5pc2hlZFNwYW5zLm1hcChzcGFuID0+IHNwYW5VdGlscy5zcGFuVG9KU09OKHNwYW4pKS5maWx0ZXIoaXNGdWxsRmluaXNoZWRTcGFuKTtcblxuICAgIGNvbnN0IHNvdXJjZSA9IHRoaXMuX2F0dHJpYnV0ZXNbc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfU09VUkNFXSA7XG5cbiAgICAvLyByZW1vdmUgaW50ZXJuYWwgcm9vdCBzcGFuIGF0dHJpYnV0ZXMgd2UgZG9uJ3QgbmVlZCB0byBzZW5kLlxuICAgIC8qIGVzbGludC1kaXNhYmxlIEB0eXBlc2NyaXB0LWVzbGludC9uby1keW5hbWljLWRlbGV0ZSAqL1xuICAgIGRlbGV0ZSB0aGlzLl9hdHRyaWJ1dGVzW3NlbWFudGljQXR0cmlidXRlcy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX0NVU1RPTV9TUEFOX05BTUVdO1xuICAgIHNwYW5zLmZvckVhY2goc3BhbiA9PiB7XG4gICAgICBkZWxldGUgc3Bhbi5kYXRhW3NlbWFudGljQXR0cmlidXRlcy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX0NVU1RPTV9TUEFOX05BTUVdO1xuICAgIH0pO1xuICAgIC8vIGVzbGludC1lbmFibGVkLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tZHluYW1pYy1kZWxldGVcblxuICAgIGNvbnN0IHRyYW5zYWN0aW9uID0ge1xuICAgICAgY29udGV4dHM6IHtcbiAgICAgICAgdHJhY2U6IHNwYW5VdGlscy5zcGFuVG9UcmFuc2FjdGlvblRyYWNlQ29udGV4dCh0aGlzKSxcbiAgICAgIH0sXG4gICAgICBzcGFuczpcbiAgICAgICAgLy8gc3BhbnMuc29ydCgpIG11dGF0ZXMgdGhlIGFycmF5LCBidXQgYHNwYW5zYCBpcyBhbHJlYWR5IGEgY29weSBzbyB3ZSBjYW4gc2FmZWx5IGRvIHRoaXMgaGVyZVxuICAgICAgICAvLyB3ZSBkbyBub3QgdXNlIHNwYW5zIGFueW1vcmUgYWZ0ZXIgdGhpcyBwb2ludFxuICAgICAgICBzcGFucy5sZW5ndGggPiBNQVhfU1BBTl9DT1VOVFxuICAgICAgICAgID8gc3BhbnMuc29ydCgoYSwgYikgPT4gYS5zdGFydF90aW1lc3RhbXAgLSBiLnN0YXJ0X3RpbWVzdGFtcCkuc2xpY2UoMCwgTUFYX1NQQU5fQ09VTlQpXG4gICAgICAgICAgOiBzcGFucyxcbiAgICAgIHN0YXJ0X3RpbWVzdGFtcDogdGhpcy5fc3RhcnRUaW1lLFxuICAgICAgdGltZXN0YW1wOiB0aGlzLl9lbmRUaW1lLFxuICAgICAgdHJhbnNhY3Rpb246IHRoaXMuX25hbWUsXG4gICAgICB0eXBlOiAndHJhbnNhY3Rpb24nLFxuICAgICAgc2RrUHJvY2Vzc2luZ01ldGFkYXRhOiB7XG4gICAgICAgIGNhcHR1cmVkU3BhblNjb3BlLFxuICAgICAgICBjYXB0dXJlZFNwYW5Jc29sYXRpb25TY29wZSxcbiAgICAgICAgZHluYW1pY1NhbXBsaW5nQ29udGV4dDogZHluYW1pY1NhbXBsaW5nQ29udGV4dC5nZXREeW5hbWljU2FtcGxpbmdDb250ZXh0RnJvbVNwYW4odGhpcyksXG4gICAgICB9LFxuICAgICAgcmVxdWVzdDogbm9ybWFsaXplZFJlcXVlc3QsXG4gICAgICAuLi4oc291cmNlICYmIHtcbiAgICAgICAgdHJhbnNhY3Rpb25faW5mbzoge1xuICAgICAgICAgIHNvdXJjZSxcbiAgICAgICAgfSxcbiAgICAgIH0pLFxuICAgIH07XG5cbiAgICBjb25zdCBtZWFzdXJlbWVudHMgPSBtZWFzdXJlbWVudC50aW1lZEV2ZW50c1RvTWVhc3VyZW1lbnRzKHRoaXMuX2V2ZW50cyk7XG4gICAgY29uc3QgaGFzTWVhc3VyZW1lbnRzID0gbWVhc3VyZW1lbnRzICYmIE9iamVjdC5rZXlzKG1lYXN1cmVtZW50cykubGVuZ3RoO1xuXG4gICAgaWYgKGhhc01lYXN1cmVtZW50cykge1xuICAgICAgZGVidWdCdWlsZC5ERUJVR19CVUlMRCAmJlxuICAgICAgICBkZWJ1Z0xvZ2dlci5kZWJ1Zy5sb2coXG4gICAgICAgICAgJ1tNZWFzdXJlbWVudHNdIEFkZGluZyBtZWFzdXJlbWVudHMgdG8gdHJhbnNhY3Rpb24gZXZlbnQnLFxuICAgICAgICAgIEpTT04uc3RyaW5naWZ5KG1lYXN1cmVtZW50cywgdW5kZWZpbmVkLCAyKSxcbiAgICAgICAgKTtcbiAgICAgIHRyYW5zYWN0aW9uLm1lYXN1cmVtZW50cyA9IG1lYXN1cmVtZW50cztcbiAgICB9XG5cbiAgICByZXR1cm4gdHJhbnNhY3Rpb247XG4gIH1cbn1cblxuZnVuY3Rpb24gaXNTcGFuVGltZUlucHV0KHZhbHVlKSB7XG4gIHJldHVybiAodmFsdWUgJiYgdHlwZW9mIHZhbHVlID09PSAnbnVtYmVyJykgfHwgdmFsdWUgaW5zdGFuY2VvZiBEYXRlIHx8IEFycmF5LmlzQXJyYXkodmFsdWUpO1xufVxuXG4vLyBXZSB3YW50IHRvIGZpbHRlciBvdXQgYW55IGluY29tcGxldGUgU3BhbkpTT04gb2JqZWN0c1xuZnVuY3Rpb24gaXNGdWxsRmluaXNoZWRTcGFuKGlucHV0KSB7XG4gIHJldHVybiAhIWlucHV0LnN0YXJ0X3RpbWVzdGFtcCAmJiAhIWlucHV0LnRpbWVzdGFtcCAmJiAhIWlucHV0LnNwYW5faWQgJiYgISFpbnB1dC50cmFjZV9pZDtcbn1cblxuLyoqIGBTZW50cnlTcGFuYHMgY2FuIGJlIHNlbnQgYXMgYSBzdGFuZGFsb25lIHNwYW4gcmF0aGVyIHRoYW4gYmVsb25naW5nIHRvIGEgdHJhbnNhY3Rpb24gKi9cbmZ1bmN0aW9uIGlzU3RhbmRhbG9uZVNwYW4oc3Bhbikge1xuICByZXR1cm4gc3BhbiBpbnN0YW5jZW9mIFNlbnRyeVNwYW4gJiYgc3Bhbi5pc1N0YW5kYWxvbmVTcGFuKCk7XG59XG5cbi8qKlxuICogU2VuZHMgYSBgU3BhbkVudmVsb3BlYC5cbiAqXG4gKiBOb3RlOiBJZiB0aGUgZW52ZWxvcGUncyBzcGFucyBhcmUgZHJvcHBlZCwgZS5nLiB2aWEgYGJlZm9yZVNlbmRTcGFuYCxcbiAqIHRoZSBlbnZlbG9wZSB3aWxsIG5vdCBiZSBzZW50IGVpdGhlci5cbiAqL1xuZnVuY3Rpb24gc2VuZFNwYW5FbnZlbG9wZShlbnZlbG9wZSkge1xuICBjb25zdCBjbGllbnQgPSBjdXJyZW50U2NvcGVzLmdldENsaWVudCgpO1xuICBpZiAoIWNsaWVudCkge1xuICAgIHJldHVybjtcbiAgfVxuXG4gIGNvbnN0IHNwYW5JdGVtcyA9IGVudmVsb3BlWzFdO1xuICBpZiAoIXNwYW5JdGVtcyB8fCBzcGFuSXRlbXMubGVuZ3RoID09PSAwKSB7XG4gICAgY2xpZW50LnJlY29yZERyb3BwZWRFdmVudCgnYmVmb3JlX3NlbmQnLCAnc3BhbicpO1xuICAgIHJldHVybjtcbiAgfVxuXG4gIC8vIHNlbmRFbnZlbG9wZSBzaG91bGQgbm90IHRocm93XG4gIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tZmxvYXRpbmctcHJvbWlzZXNcbiAgY2xpZW50LnNlbmRFbnZlbG9wZShlbnZlbG9wZSk7XG59XG5cbmV4cG9ydHMuU2VudHJ5U3BhbiA9IFNlbnRyeVNwYW47XG4vLyMgc291cmNlTWFwcGluZ1VSTD1zZW50cnlTcGFuLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/sentrySpan.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/spanstatus.js":
/*!**********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/spanstatus.js ***!
  \**********************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst SPAN_STATUS_UNSET = 0;\nconst SPAN_STATUS_OK = 1;\nconst SPAN_STATUS_ERROR = 2;\n\n/**\n * Converts a HTTP status code into a sentry status with a message.\n *\n * @param httpStatus The HTTP response status code.\n * @returns The span status or unknown_error.\n */\n// https://develop.sentry.dev/sdk/event-payloads/span/\nfunction getSpanStatusFromHttpCode(httpStatus) {\n  if (httpStatus < 400 && httpStatus >= 100) {\n    return { code: SPAN_STATUS_OK };\n  }\n\n  if (httpStatus >= 400 && httpStatus < 500) {\n    switch (httpStatus) {\n      case 401:\n        return { code: SPAN_STATUS_ERROR, message: 'unauthenticated' };\n      case 403:\n        return { code: SPAN_STATUS_ERROR, message: 'permission_denied' };\n      case 404:\n        return { code: SPAN_STATUS_ERROR, message: 'not_found' };\n      case 409:\n        return { code: SPAN_STATUS_ERROR, message: 'already_exists' };\n      case 413:\n        return { code: SPAN_STATUS_ERROR, message: 'failed_precondition' };\n      case 429:\n        return { code: SPAN_STATUS_ERROR, message: 'resource_exhausted' };\n      case 499:\n        return { code: SPAN_STATUS_ERROR, message: 'cancelled' };\n      default:\n        return { code: SPAN_STATUS_ERROR, message: 'invalid_argument' };\n    }\n  }\n\n  if (httpStatus >= 500 && httpStatus < 600) {\n    switch (httpStatus) {\n      case 501:\n        return { code: SPAN_STATUS_ERROR, message: 'unimplemented' };\n      case 503:\n        return { code: SPAN_STATUS_ERROR, message: 'unavailable' };\n      case 504:\n        return { code: SPAN_STATUS_ERROR, message: 'deadline_exceeded' };\n      default:\n        return { code: SPAN_STATUS_ERROR, message: 'internal_error' };\n    }\n  }\n\n  return { code: SPAN_STATUS_ERROR, message: 'unknown_error' };\n}\n\n/**\n * Sets the Http status attributes on the current span based on the http code.\n * Additionally, the span's status is updated, depending on the http code.\n */\nfunction setHttpStatus(span, httpStatus) {\n  span.setAttribute('http.response.status_code', httpStatus);\n\n  const spanStatus = getSpanStatusFromHttpCode(httpStatus);\n  if (spanStatus.message !== 'unknown_error') {\n    span.setStatus(spanStatus);\n  }\n}\n\nexports.SPAN_STATUS_ERROR = SPAN_STATUS_ERROR;\nexports.SPAN_STATUS_OK = SPAN_STATUS_OK;\nexports.SPAN_STATUS_UNSET = SPAN_STATUS_UNSET;\nexports.getSpanStatusFromHttpCode = getSpanStatusFromHttpCode;\nexports.setHttpStatus = setHttpStatus;\n//# sourceMappingURL=spanstatus.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy90cmFjaW5nL3NwYW5zdGF0dXMuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEU7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGFBQWE7QUFDYjs7QUFFQTtBQUNBO0FBQ0E7QUFDQSxpQkFBaUI7QUFDakI7QUFDQSxpQkFBaUI7QUFDakI7QUFDQSxpQkFBaUI7QUFDakI7QUFDQSxpQkFBaUI7QUFDakI7QUFDQSxpQkFBaUI7QUFDakI7QUFDQSxpQkFBaUI7QUFDakI7QUFDQSxpQkFBaUI7QUFDakI7QUFDQSxpQkFBaUI7QUFDakI7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQSxpQkFBaUI7QUFDakI7QUFDQSxpQkFBaUI7QUFDakI7QUFDQSxpQkFBaUI7QUFDakI7QUFDQSxpQkFBaUI7QUFDakI7QUFDQTs7QUFFQSxXQUFXO0FBQ1g7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEseUJBQXlCO0FBQ3pCLHNCQUFzQjtBQUN0Qix5QkFBeUI7QUFDekIsaUNBQWlDO0FBQ2pDLHFCQUFxQjtBQUNyQiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3RyYWNpbmcvc3BhbnN0YXR1cy5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgU1BBTl9TVEFUVVNfVU5TRVQgPSAwO1xuY29uc3QgU1BBTl9TVEFUVVNfT0sgPSAxO1xuY29uc3QgU1BBTl9TVEFUVVNfRVJST1IgPSAyO1xuXG4vKipcbiAqIENvbnZlcnRzIGEgSFRUUCBzdGF0dXMgY29kZSBpbnRvIGEgc2VudHJ5IHN0YXR1cyB3aXRoIGEgbWVzc2FnZS5cbiAqXG4gKiBAcGFyYW0gaHR0cFN0YXR1cyBUaGUgSFRUUCByZXNwb25zZSBzdGF0dXMgY29kZS5cbiAqIEByZXR1cm5zIFRoZSBzcGFuIHN0YXR1cyBvciB1bmtub3duX2Vycm9yLlxuICovXG4vLyBodHRwczovL2RldmVsb3Auc2VudHJ5LmRldi9zZGsvZXZlbnQtcGF5bG9hZHMvc3Bhbi9cbmZ1bmN0aW9uIGdldFNwYW5TdGF0dXNGcm9tSHR0cENvZGUoaHR0cFN0YXR1cykge1xuICBpZiAoaHR0cFN0YXR1cyA8IDQwMCAmJiBodHRwU3RhdHVzID49IDEwMCkge1xuICAgIHJldHVybiB7IGNvZGU6IFNQQU5fU1RBVFVTX09LIH07XG4gIH1cblxuICBpZiAoaHR0cFN0YXR1cyA+PSA0MDAgJiYgaHR0cFN0YXR1cyA8IDUwMCkge1xuICAgIHN3aXRjaCAoaHR0cFN0YXR1cykge1xuICAgICAgY2FzZSA0MDE6XG4gICAgICAgIHJldHVybiB7IGNvZGU6IFNQQU5fU1RBVFVTX0VSUk9SLCBtZXNzYWdlOiAndW5hdXRoZW50aWNhdGVkJyB9O1xuICAgICAgY2FzZSA0MDM6XG4gICAgICAgIHJldHVybiB7IGNvZGU6IFNQQU5fU1RBVFVTX0VSUk9SLCBtZXNzYWdlOiAncGVybWlzc2lvbl9kZW5pZWQnIH07XG4gICAgICBjYXNlIDQwNDpcbiAgICAgICAgcmV0dXJuIHsgY29kZTogU1BBTl9TVEFUVVNfRVJST1IsIG1lc3NhZ2U6ICdub3RfZm91bmQnIH07XG4gICAgICBjYXNlIDQwOTpcbiAgICAgICAgcmV0dXJuIHsgY29kZTogU1BBTl9TVEFUVVNfRVJST1IsIG1lc3NhZ2U6ICdhbHJlYWR5X2V4aXN0cycgfTtcbiAgICAgIGNhc2UgNDEzOlxuICAgICAgICByZXR1cm4geyBjb2RlOiBTUEFOX1NUQVRVU19FUlJPUiwgbWVzc2FnZTogJ2ZhaWxlZF9wcmVjb25kaXRpb24nIH07XG4gICAgICBjYXNlIDQyOTpcbiAgICAgICAgcmV0dXJuIHsgY29kZTogU1BBTl9TVEFUVVNfRVJST1IsIG1lc3NhZ2U6ICdyZXNvdXJjZV9leGhhdXN0ZWQnIH07XG4gICAgICBjYXNlIDQ5OTpcbiAgICAgICAgcmV0dXJuIHsgY29kZTogU1BBTl9TVEFUVVNfRVJST1IsIG1lc3NhZ2U6ICdjYW5jZWxsZWQnIH07XG4gICAgICBkZWZhdWx0OlxuICAgICAgICByZXR1cm4geyBjb2RlOiBTUEFOX1NUQVRVU19FUlJPUiwgbWVzc2FnZTogJ2ludmFsaWRfYXJndW1lbnQnIH07XG4gICAgfVxuICB9XG5cbiAgaWYgKGh0dHBTdGF0dXMgPj0gNTAwICYmIGh0dHBTdGF0dXMgPCA2MDApIHtcbiAgICBzd2l0Y2ggKGh0dHBTdGF0dXMpIHtcbiAgICAgIGNhc2UgNTAxOlxuICAgICAgICByZXR1cm4geyBjb2RlOiBTUEFOX1NUQVRVU19FUlJPUiwgbWVzc2FnZTogJ3VuaW1wbGVtZW50ZWQnIH07XG4gICAgICBjYXNlIDUwMzpcbiAgICAgICAgcmV0dXJuIHsgY29kZTogU1BBTl9TVEFUVVNfRVJST1IsIG1lc3NhZ2U6ICd1bmF2YWlsYWJsZScgfTtcbiAgICAgIGNhc2UgNTA0OlxuICAgICAgICByZXR1cm4geyBjb2RlOiBTUEFOX1NUQVRVU19FUlJPUiwgbWVzc2FnZTogJ2RlYWRsaW5lX2V4Y2VlZGVkJyB9O1xuICAgICAgZGVmYXVsdDpcbiAgICAgICAgcmV0dXJuIHsgY29kZTogU1BBTl9TVEFUVVNfRVJST1IsIG1lc3NhZ2U6ICdpbnRlcm5hbF9lcnJvcicgfTtcbiAgICB9XG4gIH1cblxuICByZXR1cm4geyBjb2RlOiBTUEFOX1NUQVRVU19FUlJPUiwgbWVzc2FnZTogJ3Vua25vd25fZXJyb3InIH07XG59XG5cbi8qKlxuICogU2V0cyB0aGUgSHR0cCBzdGF0dXMgYXR0cmlidXRlcyBvbiB0aGUgY3VycmVudCBzcGFuIGJhc2VkIG9uIHRoZSBodHRwIGNvZGUuXG4gKiBBZGRpdGlvbmFsbHksIHRoZSBzcGFuJ3Mgc3RhdHVzIGlzIHVwZGF0ZWQsIGRlcGVuZGluZyBvbiB0aGUgaHR0cCBjb2RlLlxuICovXG5mdW5jdGlvbiBzZXRIdHRwU3RhdHVzKHNwYW4sIGh0dHBTdGF0dXMpIHtcbiAgc3Bhbi5zZXRBdHRyaWJ1dGUoJ2h0dHAucmVzcG9uc2Uuc3RhdHVzX2NvZGUnLCBodHRwU3RhdHVzKTtcblxuICBjb25zdCBzcGFuU3RhdHVzID0gZ2V0U3BhblN0YXR1c0Zyb21IdHRwQ29kZShodHRwU3RhdHVzKTtcbiAgaWYgKHNwYW5TdGF0dXMubWVzc2FnZSAhPT0gJ3Vua25vd25fZXJyb3InKSB7XG4gICAgc3Bhbi5zZXRTdGF0dXMoc3BhblN0YXR1cyk7XG4gIH1cbn1cblxuZXhwb3J0cy5TUEFOX1NUQVRVU19FUlJPUiA9IFNQQU5fU1RBVFVTX0VSUk9SO1xuZXhwb3J0cy5TUEFOX1NUQVRVU19PSyA9IFNQQU5fU1RBVFVTX09LO1xuZXhwb3J0cy5TUEFOX1NUQVRVU19VTlNFVCA9IFNQQU5fU1RBVFVTX1VOU0VUO1xuZXhwb3J0cy5nZXRTcGFuU3RhdHVzRnJvbUh0dHBDb2RlID0gZ2V0U3BhblN0YXR1c0Zyb21IdHRwQ29kZTtcbmV4cG9ydHMuc2V0SHR0cFN0YXR1cyA9IHNldEh0dHBTdGF0dXM7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1zcGFuc3RhdHVzLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/spanstatus.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/trace.js":
/*!*****************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/trace.js ***!
  \*****************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst index = __webpack_require__(/*! ../asyncContext/index.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/asyncContext/index.js\");\nconst carrier = __webpack_require__(/*! ../carrier.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/carrier.js\");\nconst currentScopes = __webpack_require__(/*! ../currentScopes.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst debugBuild = __webpack_require__(/*! ../debug-build.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst semanticAttributes = __webpack_require__(/*! ../semanticAttributes.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/semanticAttributes.js\");\nconst debugLogger = __webpack_require__(/*! ../utils/debug-logger.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst handleCallbackErrors = __webpack_require__(/*! ../utils/handleCallbackErrors.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/handleCallbackErrors.js\");\nconst hasSpansEnabled = __webpack_require__(/*! ../utils/hasSpansEnabled.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/hasSpansEnabled.js\");\nconst parseSampleRate = __webpack_require__(/*! ../utils/parseSampleRate.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/parseSampleRate.js\");\nconst propagationContext = __webpack_require__(/*! ../utils/propagationContext.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/propagationContext.js\");\nconst spanOnScope = __webpack_require__(/*! ../utils/spanOnScope.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanOnScope.js\");\nconst spanUtils = __webpack_require__(/*! ../utils/spanUtils.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanUtils.js\");\nconst tracing = __webpack_require__(/*! ../utils/tracing.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/tracing.js\");\nconst dynamicSamplingContext = __webpack_require__(/*! ./dynamicSamplingContext.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/dynamicSamplingContext.js\");\nconst logSpans = __webpack_require__(/*! ./logSpans.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/logSpans.js\");\nconst sampling = __webpack_require__(/*! ./sampling.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/sampling.js\");\nconst sentryNonRecordingSpan = __webpack_require__(/*! ./sentryNonRecordingSpan.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/sentryNonRecordingSpan.js\");\nconst sentrySpan = __webpack_require__(/*! ./sentrySpan.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/sentrySpan.js\");\nconst spanstatus = __webpack_require__(/*! ./spanstatus.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/spanstatus.js\");\nconst utils = __webpack_require__(/*! ./utils.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/utils.js\");\n\n/* eslint-disable max-lines */\n\n\nconst SUPPRESS_TRACING_KEY = '__SENTRY_SUPPRESS_TRACING__';\n\n/**\n * Wraps a function with a transaction/span and finishes the span after the function is done.\n * The created span is the active span and will be used as parent by other spans created inside the function\n * and can be accessed via `Sentry.getActiveSpan()`, as long as the function is executed while the scope is active.\n *\n * If you want to create a span that is not set as active, use {@link startInactiveSpan}.\n *\n * You'll always get a span passed to the callback,\n * it may just be a non-recording span if the span is not sampled or if tracing is disabled.\n */\nfunction startSpan(options, callback) {\n  const acs = getAcs();\n  if (acs.startSpan) {\n    return acs.startSpan(options, callback);\n  }\n\n  const spanArguments = parseSentrySpanArguments(options);\n  const { forceTransaction, parentSpan: customParentSpan, scope: customScope } = options;\n\n  // We still need to fork a potentially passed scope, as we set the active span on it\n  // and we need to ensure that it is cleaned up properly once the span ends.\n  const customForkedScope = customScope?.clone();\n\n  return currentScopes.withScope(customForkedScope, () => {\n    // If `options.parentSpan` is defined, we want to wrap the callback in `withActiveSpan`\n    const wrapper = getActiveSpanWrapper(customParentSpan);\n\n    return wrapper(() => {\n      const scope = currentScopes.getCurrentScope();\n      const parentSpan = getParentSpan(scope, customParentSpan);\n\n      const shouldSkipSpan = options.onlyIfParent && !parentSpan;\n      const activeSpan = shouldSkipSpan\n        ? new sentryNonRecordingSpan.SentryNonRecordingSpan()\n        : createChildOrRootSpan({\n            parentSpan,\n            spanArguments,\n            forceTransaction,\n            scope,\n          });\n\n      spanOnScope._setSpanForScope(scope, activeSpan);\n\n      return handleCallbackErrors.handleCallbackErrors(\n        () => callback(activeSpan),\n        () => {\n          // Only update the span status if it hasn't been changed yet, and the span is not yet finished\n          const { status } = spanUtils.spanToJSON(activeSpan);\n          if (activeSpan.isRecording() && (!status || status === 'ok')) {\n            activeSpan.setStatus({ code: spanstatus.SPAN_STATUS_ERROR, message: 'internal_error' });\n          }\n        },\n        () => {\n          activeSpan.end();\n        },\n      );\n    });\n  });\n}\n\n/**\n * Similar to `Sentry.startSpan`. Wraps a function with a transaction/span, but does not finish the span\n * after the function is done automatically. Use `span.end()` to end the span.\n *\n * The created span is the active span and will be used as parent by other spans created inside the function\n * and can be accessed via `Sentry.getActiveSpan()`, as long as the function is executed while the scope is active.\n *\n * You'll always get a span passed to the callback,\n * it may just be a non-recording span if the span is not sampled or if tracing is disabled.\n */\nfunction startSpanManual(options, callback) {\n  const acs = getAcs();\n  if (acs.startSpanManual) {\n    return acs.startSpanManual(options, callback);\n  }\n\n  const spanArguments = parseSentrySpanArguments(options);\n  const { forceTransaction, parentSpan: customParentSpan, scope: customScope } = options;\n\n  const customForkedScope = customScope?.clone();\n\n  return currentScopes.withScope(customForkedScope, () => {\n    // If `options.parentSpan` is defined, we want to wrap the callback in `withActiveSpan`\n    const wrapper = getActiveSpanWrapper(customParentSpan);\n\n    return wrapper(() => {\n      const scope = currentScopes.getCurrentScope();\n      const parentSpan = getParentSpan(scope, customParentSpan);\n\n      const shouldSkipSpan = options.onlyIfParent && !parentSpan;\n      const activeSpan = shouldSkipSpan\n        ? new sentryNonRecordingSpan.SentryNonRecordingSpan()\n        : createChildOrRootSpan({\n            parentSpan,\n            spanArguments,\n            forceTransaction,\n            scope,\n          });\n\n      spanOnScope._setSpanForScope(scope, activeSpan);\n\n      return handleCallbackErrors.handleCallbackErrors(\n        // We pass the `finish` function to the callback, so the user can finish the span manually\n        // this is mainly here for historic purposes because previously, we instructed users to call\n        // `finish` instead of `span.end()` to also clean up the scope. Nowadays, calling `span.end()`\n        // or `finish` has the same effect and we simply leave it here to avoid breaking user code.\n        () => callback(activeSpan, () => activeSpan.end()),\n        () => {\n          // Only update the span status if it hasn't been changed yet, and the span is not yet finished\n          const { status } = spanUtils.spanToJSON(activeSpan);\n          if (activeSpan.isRecording() && (!status || status === 'ok')) {\n            activeSpan.setStatus({ code: spanstatus.SPAN_STATUS_ERROR, message: 'internal_error' });\n          }\n        },\n      );\n    });\n  });\n}\n\n/**\n * Creates a span. This span is not set as active, so will not get automatic instrumentation spans\n * as children or be able to be accessed via `Sentry.getActiveSpan()`.\n *\n * If you want to create a span that is set as active, use {@link startSpan}.\n *\n * This function will always return a span,\n * it may just be a non-recording span if the span is not sampled or if tracing is disabled.\n */\nfunction startInactiveSpan(options) {\n  const acs = getAcs();\n  if (acs.startInactiveSpan) {\n    return acs.startInactiveSpan(options);\n  }\n\n  const spanArguments = parseSentrySpanArguments(options);\n  const { forceTransaction, parentSpan: customParentSpan } = options;\n\n  // If `options.scope` is defined, we use this as as a wrapper,\n  // If `options.parentSpan` is defined, we want to wrap the callback in `withActiveSpan`\n  const wrapper = options.scope\n    ? (callback) => currentScopes.withScope(options.scope, callback)\n    : customParentSpan !== undefined\n      ? (callback) => withActiveSpan(customParentSpan, callback)\n      : (callback) => callback();\n\n  return wrapper(() => {\n    const scope = currentScopes.getCurrentScope();\n    const parentSpan = getParentSpan(scope, customParentSpan);\n\n    const shouldSkipSpan = options.onlyIfParent && !parentSpan;\n\n    if (shouldSkipSpan) {\n      return new sentryNonRecordingSpan.SentryNonRecordingSpan();\n    }\n\n    return createChildOrRootSpan({\n      parentSpan,\n      spanArguments,\n      forceTransaction,\n      scope,\n    });\n  });\n}\n\n/**\n * Continue a trace from `sentry-trace` and `baggage` values.\n * These values can be obtained from incoming request headers, or in the browser from `<meta name=\"sentry-trace\">`\n * and `<meta name=\"baggage\">` HTML tags.\n *\n * Spans started with `startSpan`, `startSpanManual` and `startInactiveSpan`, within the callback will automatically\n * be attached to the incoming trace.\n */\nconst continueTrace = (\n  options\n\n,\n  callback,\n) => {\n  const carrier$1 = carrier.getMainCarrier();\n  const acs = index.getAsyncContextStrategy(carrier$1);\n  if (acs.continueTrace) {\n    return acs.continueTrace(options, callback);\n  }\n\n  const { sentryTrace, baggage } = options;\n\n  return currentScopes.withScope(scope => {\n    const propagationContext = tracing.propagationContextFromHeaders(sentryTrace, baggage);\n    scope.setPropagationContext(propagationContext);\n    return callback();\n  });\n};\n\n/**\n * Forks the current scope and sets the provided span as active span in the context of the provided callback. Can be\n * passed `null` to start an entirely new span tree.\n *\n * @param span Spans started in the context of the provided callback will be children of this span. If `null` is passed,\n * spans started within the callback will not be attached to a parent span.\n * @param callback Execution context in which the provided span will be active. Is passed the newly forked scope.\n * @returns the value returned from the provided callback function.\n */\nfunction withActiveSpan(span, callback) {\n  const acs = getAcs();\n  if (acs.withActiveSpan) {\n    return acs.withActiveSpan(span, callback);\n  }\n\n  return currentScopes.withScope(scope => {\n    spanOnScope._setSpanForScope(scope, span || undefined);\n    return callback(scope);\n  });\n}\n\n/** Suppress tracing in the given callback, ensuring no spans are generated inside of it. */\nfunction suppressTracing(callback) {\n  const acs = getAcs();\n\n  if (acs.suppressTracing) {\n    return acs.suppressTracing(callback);\n  }\n\n  return currentScopes.withScope(scope => {\n    // Note: We do not wait for the callback to finish before we reset the metadata\n    // the reason for this is that otherwise, in the browser this can lead to very weird behavior\n    // as there is only a single top scope, if the callback takes longer to finish,\n    // other, unrelated spans may also be suppressed, which we do not want\n    // so instead, we only suppress tracing synchronoysly in the browser\n    scope.setSDKProcessingMetadata({ [SUPPRESS_TRACING_KEY]: true });\n    const res = callback();\n    scope.setSDKProcessingMetadata({ [SUPPRESS_TRACING_KEY]: undefined });\n    return res;\n  });\n}\n\n/**\n * Starts a new trace for the duration of the provided callback. Spans started within the\n * callback will be part of the new trace instead of a potentially previously started trace.\n *\n * Important: Only use this function if you want to override the default trace lifetime and\n * propagation mechanism of the SDK for the duration and scope of the provided callback.\n * The newly created trace will also be the root of a new distributed trace, for example if\n * you make http requests within the callback.\n * This function might be useful if the operation you want to instrument should not be part\n * of a potentially ongoing trace.\n *\n * Default behavior:\n * - Server-side: A new trace is started for each incoming request.\n * - Browser: A new trace is started for each page our route. Navigating to a new route\n *            or page will automatically create a new trace.\n */\nfunction startNewTrace(callback) {\n  return currentScopes.withScope(scope => {\n    scope.setPropagationContext({\n      traceId: propagationContext.generateTraceId(),\n      sampleRand: Math.random(),\n    });\n    debugBuild.DEBUG_BUILD && debugLogger.debug.log(`Starting a new trace with id ${scope.getPropagationContext().traceId}`);\n    return withActiveSpan(null, callback);\n  });\n}\n\nfunction createChildOrRootSpan({\n  parentSpan,\n  spanArguments,\n  forceTransaction,\n  scope,\n}\n\n) {\n  if (!hasSpansEnabled.hasSpansEnabled()) {\n    const span = new sentryNonRecordingSpan.SentryNonRecordingSpan();\n\n    // If this is a root span, we ensure to freeze a DSC\n    // So we can have at least partial data here\n    if (forceTransaction || !parentSpan) {\n      const dsc = {\n        sampled: 'false',\n        sample_rate: '0',\n        transaction: spanArguments.name,\n        ...dynamicSamplingContext.getDynamicSamplingContextFromSpan(span),\n      } ;\n      dynamicSamplingContext.freezeDscOnSpan(span, dsc);\n    }\n\n    return span;\n  }\n\n  const isolationScope = currentScopes.getIsolationScope();\n\n  let span;\n  if (parentSpan && !forceTransaction) {\n    span = _startChildSpan(parentSpan, scope, spanArguments);\n    spanUtils.addChildSpanToSpan(parentSpan, span);\n  } else if (parentSpan) {\n    // If we forced a transaction but have a parent span, make sure to continue from the parent span, not the scope\n    const dsc = dynamicSamplingContext.getDynamicSamplingContextFromSpan(parentSpan);\n    const { traceId, spanId: parentSpanId } = parentSpan.spanContext();\n    const parentSampled = spanUtils.spanIsSampled(parentSpan);\n\n    span = _startRootSpan(\n      {\n        traceId,\n        parentSpanId,\n        ...spanArguments,\n      },\n      scope,\n      parentSampled,\n    );\n\n    dynamicSamplingContext.freezeDscOnSpan(span, dsc);\n  } else {\n    const {\n      traceId,\n      dsc,\n      parentSpanId,\n      sampled: parentSampled,\n    } = {\n      ...isolationScope.getPropagationContext(),\n      ...scope.getPropagationContext(),\n    };\n\n    span = _startRootSpan(\n      {\n        traceId,\n        parentSpanId,\n        ...spanArguments,\n      },\n      scope,\n      parentSampled,\n    );\n\n    if (dsc) {\n      dynamicSamplingContext.freezeDscOnSpan(span, dsc);\n    }\n  }\n\n  logSpans.logSpanStart(span);\n\n  utils.setCapturedScopesOnSpan(span, scope, isolationScope);\n\n  return span;\n}\n\n/**\n * This converts StartSpanOptions to SentrySpanArguments.\n * For the most part (for now) we accept the same options,\n * but some of them need to be transformed.\n */\nfunction parseSentrySpanArguments(options) {\n  const exp = options.experimental || {};\n  const initialCtx = {\n    isStandalone: exp.standalone,\n    ...options,\n  };\n\n  if (options.startTime) {\n    const ctx = { ...initialCtx };\n    ctx.startTimestamp = spanUtils.spanTimeInputToSeconds(options.startTime);\n    delete ctx.startTime;\n    return ctx;\n  }\n\n  return initialCtx;\n}\n\nfunction getAcs() {\n  const carrier$1 = carrier.getMainCarrier();\n  return index.getAsyncContextStrategy(carrier$1);\n}\n\nfunction _startRootSpan(spanArguments, scope, parentSampled) {\n  const client = currentScopes.getClient();\n  const options = client?.getOptions() || {};\n\n  const { name = '' } = spanArguments;\n\n  const mutableSpanSamplingData = { spanAttributes: { ...spanArguments.attributes }, spanName: name, parentSampled };\n\n  // we don't care about the decision for the moment; this is just a placeholder\n  client?.emit('beforeSampling', mutableSpanSamplingData, { decision: false });\n\n  // If hook consumers override the parentSampled flag, we will use that value instead of the actual one\n  const finalParentSampled = mutableSpanSamplingData.parentSampled ?? parentSampled;\n  const finalAttributes = mutableSpanSamplingData.spanAttributes;\n\n  const currentPropagationContext = scope.getPropagationContext();\n  const [sampled, sampleRate, localSampleRateWasApplied] = scope.getScopeData().sdkProcessingMetadata[\n    SUPPRESS_TRACING_KEY\n  ]\n    ? [false]\n    : sampling.sampleSpan(\n        options,\n        {\n          name,\n          parentSampled: finalParentSampled,\n          attributes: finalAttributes,\n          parentSampleRate: parseSampleRate.parseSampleRate(currentPropagationContext.dsc?.sample_rate),\n        },\n        currentPropagationContext.sampleRand,\n      );\n\n  const rootSpan = new sentrySpan.SentrySpan({\n    ...spanArguments,\n    attributes: {\n      [semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_SOURCE]: 'custom',\n      [semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_SAMPLE_RATE]:\n        sampleRate !== undefined && localSampleRateWasApplied ? sampleRate : undefined,\n      ...finalAttributes,\n    },\n    sampled,\n  });\n\n  if (!sampled && client) {\n    debugBuild.DEBUG_BUILD && debugLogger.debug.log('[Tracing] Discarding root span because its trace was not chosen to be sampled.');\n    client.recordDroppedEvent('sample_rate', 'transaction');\n  }\n\n  if (client) {\n    client.emit('spanStart', rootSpan);\n  }\n\n  return rootSpan;\n}\n\n/**\n * Creates a new `Span` while setting the current `Span.id` as `parentSpanId`.\n * This inherits the sampling decision from the parent span.\n */\nfunction _startChildSpan(parentSpan, scope, spanArguments) {\n  const { spanId, traceId } = parentSpan.spanContext();\n  const sampled = scope.getScopeData().sdkProcessingMetadata[SUPPRESS_TRACING_KEY] ? false : spanUtils.spanIsSampled(parentSpan);\n\n  const childSpan = sampled\n    ? new sentrySpan.SentrySpan({\n        ...spanArguments,\n        parentSpanId: spanId,\n        traceId,\n        sampled,\n      })\n    : new sentryNonRecordingSpan.SentryNonRecordingSpan({ traceId });\n\n  spanUtils.addChildSpanToSpan(parentSpan, childSpan);\n\n  const client = currentScopes.getClient();\n  if (client) {\n    client.emit('spanStart', childSpan);\n    // If it has an endTimestamp, it's already ended\n    if (spanArguments.endTimestamp) {\n      client.emit('spanEnd', childSpan);\n    }\n  }\n\n  return childSpan;\n}\n\nfunction getParentSpan(scope, customParentSpan) {\n  // always use the passed in span directly\n  if (customParentSpan) {\n    return customParentSpan ;\n  }\n\n  // This is different from `undefined` as it means the user explicitly wants no parent span\n  if (customParentSpan === null) {\n    return undefined;\n  }\n\n  const span = spanOnScope._getSpanForScope(scope) ;\n\n  if (!span) {\n    return undefined;\n  }\n\n  const client = currentScopes.getClient();\n  const options = client ? client.getOptions() : {};\n  if (options.parentSpanIsAlwaysRootSpan) {\n    return spanUtils.getRootSpan(span) ;\n  }\n\n  return span;\n}\n\nfunction getActiveSpanWrapper(parentSpan) {\n  return parentSpan !== undefined\n    ? (callback) => {\n        return withActiveSpan(parentSpan, callback);\n      }\n    : (callback) => callback();\n}\n\nexports.continueTrace = continueTrace;\nexports.startInactiveSpan = startInactiveSpan;\nexports.startNewTrace = startNewTrace;\nexports.startSpan = startSpan;\nexports.startSpanManual = startSpanManual;\nexports.suppressTracing = suppressTracing;\nexports.withActiveSpan = withActiveSpan;\n//# sourceMappingURL=trace.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy90cmFjaW5nL3RyYWNlLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLGNBQWMsbUJBQU8sQ0FBQywwSUFBMEI7QUFDaEQsZ0JBQWdCLG1CQUFPLENBQUMsb0hBQWU7QUFDdkMsc0JBQXNCLG1CQUFPLENBQUMsZ0lBQXFCO0FBQ25ELG1CQUFtQixtQkFBTyxDQUFDLDRIQUFtQjtBQUM5QywyQkFBMkIsbUJBQU8sQ0FBQywwSUFBMEI7QUFDN0Qsb0JBQW9CLG1CQUFPLENBQUMsMElBQTBCO0FBQ3RELDZCQUE2QixtQkFBTyxDQUFDLDBKQUFrQztBQUN2RSx3QkFBd0IsbUJBQU8sQ0FBQyxnSkFBNkI7QUFDN0Qsd0JBQXdCLG1CQUFPLENBQUMsZ0pBQTZCO0FBQzdELDJCQUEyQixtQkFBTyxDQUFDLHNKQUFnQztBQUNuRSxvQkFBb0IsbUJBQU8sQ0FBQyx3SUFBeUI7QUFDckQsa0JBQWtCLG1CQUFPLENBQUMsb0lBQXVCO0FBQ2pELGdCQUFnQixtQkFBTyxDQUFDLGdJQUFxQjtBQUM3QywrQkFBK0IsbUJBQU8sQ0FBQyx5SkFBNkI7QUFDcEUsaUJBQWlCLG1CQUFPLENBQUMsNkhBQWU7QUFDeEMsaUJBQWlCLG1CQUFPLENBQUMsNkhBQWU7QUFDeEMsK0JBQStCLG1CQUFPLENBQUMseUpBQTZCO0FBQ3BFLG1CQUFtQixtQkFBTyxDQUFDLGlJQUFpQjtBQUM1QyxtQkFBbUIsbUJBQU8sQ0FBQyxpSUFBaUI7QUFDNUMsY0FBYyxtQkFBTyxDQUFDLHVIQUFZOztBQUVsQzs7O0FBR0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGdFQUFnRSx3QkFBd0I7QUFDeEY7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0EsVUFBVSxxRUFBcUU7O0FBRS9FO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxXQUFXOztBQUVYOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0Esa0JBQWtCLFNBQVM7QUFDM0I7QUFDQSxtQ0FBbUMsK0RBQStEO0FBQ2xHO0FBQ0EsU0FBUztBQUNUO0FBQ0E7QUFDQSxTQUFTO0FBQ1Q7QUFDQSxLQUFLO0FBQ0wsR0FBRztBQUNIOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBLFVBQVUscUVBQXFFOztBQUUvRTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxXQUFXOztBQUVYOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxrQkFBa0IsU0FBUztBQUMzQjtBQUNBLG1DQUFtQywrREFBK0Q7QUFDbEc7QUFDQSxTQUFTO0FBQ1Q7QUFDQSxLQUFLO0FBQ0wsR0FBRztBQUNIOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsNERBQTRELGdCQUFnQjtBQUM1RTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQSxVQUFVLGlEQUFpRDs7QUFFM0Q7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsS0FBSztBQUNMLEdBQUc7QUFDSDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLFVBQVUsdUJBQXVCOztBQUVqQztBQUNBO0FBQ0E7QUFDQTtBQUNBLEdBQUc7QUFDSDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBLEdBQUc7QUFDSDs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLHFDQUFxQyw4QkFBOEI7QUFDbkU7QUFDQSxxQ0FBcUMsbUNBQW1DO0FBQ3hFO0FBQ0EsR0FBRztBQUNIOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEtBQUs7QUFDTCxvRkFBb0Ysc0NBQXNDO0FBQzFIO0FBQ0EsR0FBRztBQUNIOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsSUFBSTtBQUNKO0FBQ0E7QUFDQSxZQUFZLGdDQUFnQztBQUM1Qzs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsT0FBTztBQUNQO0FBQ0E7QUFDQTs7QUFFQTtBQUNBLElBQUk7QUFDSjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsTUFBTTtBQUNOO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsT0FBTztBQUNQO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQSxrQkFBa0I7QUFDbEI7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUEsVUFBVSxZQUFZOztBQUV0QixvQ0FBb0Msa0JBQWtCLDZCQUE2Qjs7QUFFbkYsc0RBQXNEO0FBQ3RELDREQUE0RCxpQkFBaUI7O0FBRTdFO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxTQUFTO0FBQ1Q7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEtBQUs7QUFDTDtBQUNBLEdBQUc7O0FBRUg7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFVBQVUsa0JBQWtCO0FBQzVCOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLE9BQU87QUFDUCwwREFBMEQsU0FBUzs7QUFFbkU7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSxxQkFBcUI7QUFDckIseUJBQXlCO0FBQ3pCLHFCQUFxQjtBQUNyQixpQkFBaUI7QUFDakIsdUJBQXVCO0FBQ3ZCLHVCQUF1QjtBQUN2QixzQkFBc0I7QUFDdEIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy90cmFjaW5nL3RyYWNlLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBpbmRleCA9IHJlcXVpcmUoJy4uL2FzeW5jQ29udGV4dC9pbmRleC5qcycpO1xuY29uc3QgY2FycmllciA9IHJlcXVpcmUoJy4uL2NhcnJpZXIuanMnKTtcbmNvbnN0IGN1cnJlbnRTY29wZXMgPSByZXF1aXJlKCcuLi9jdXJyZW50U2NvcGVzLmpzJyk7XG5jb25zdCBkZWJ1Z0J1aWxkID0gcmVxdWlyZSgnLi4vZGVidWctYnVpbGQuanMnKTtcbmNvbnN0IHNlbWFudGljQXR0cmlidXRlcyA9IHJlcXVpcmUoJy4uL3NlbWFudGljQXR0cmlidXRlcy5qcycpO1xuY29uc3QgZGVidWdMb2dnZXIgPSByZXF1aXJlKCcuLi91dGlscy9kZWJ1Zy1sb2dnZXIuanMnKTtcbmNvbnN0IGhhbmRsZUNhbGxiYWNrRXJyb3JzID0gcmVxdWlyZSgnLi4vdXRpbHMvaGFuZGxlQ2FsbGJhY2tFcnJvcnMuanMnKTtcbmNvbnN0IGhhc1NwYW5zRW5hYmxlZCA9IHJlcXVpcmUoJy4uL3V0aWxzL2hhc1NwYW5zRW5hYmxlZC5qcycpO1xuY29uc3QgcGFyc2VTYW1wbGVSYXRlID0gcmVxdWlyZSgnLi4vdXRpbHMvcGFyc2VTYW1wbGVSYXRlLmpzJyk7XG5jb25zdCBwcm9wYWdhdGlvbkNvbnRleHQgPSByZXF1aXJlKCcuLi91dGlscy9wcm9wYWdhdGlvbkNvbnRleHQuanMnKTtcbmNvbnN0IHNwYW5PblNjb3BlID0gcmVxdWlyZSgnLi4vdXRpbHMvc3Bhbk9uU2NvcGUuanMnKTtcbmNvbnN0IHNwYW5VdGlscyA9IHJlcXVpcmUoJy4uL3V0aWxzL3NwYW5VdGlscy5qcycpO1xuY29uc3QgdHJhY2luZyA9IHJlcXVpcmUoJy4uL3V0aWxzL3RyYWNpbmcuanMnKTtcbmNvbnN0IGR5bmFtaWNTYW1wbGluZ0NvbnRleHQgPSByZXF1aXJlKCcuL2R5bmFtaWNTYW1wbGluZ0NvbnRleHQuanMnKTtcbmNvbnN0IGxvZ1NwYW5zID0gcmVxdWlyZSgnLi9sb2dTcGFucy5qcycpO1xuY29uc3Qgc2FtcGxpbmcgPSByZXF1aXJlKCcuL3NhbXBsaW5nLmpzJyk7XG5jb25zdCBzZW50cnlOb25SZWNvcmRpbmdTcGFuID0gcmVxdWlyZSgnLi9zZW50cnlOb25SZWNvcmRpbmdTcGFuLmpzJyk7XG5jb25zdCBzZW50cnlTcGFuID0gcmVxdWlyZSgnLi9zZW50cnlTcGFuLmpzJyk7XG5jb25zdCBzcGFuc3RhdHVzID0gcmVxdWlyZSgnLi9zcGFuc3RhdHVzLmpzJyk7XG5jb25zdCB1dGlscyA9IHJlcXVpcmUoJy4vdXRpbHMuanMnKTtcblxuLyogZXNsaW50LWRpc2FibGUgbWF4LWxpbmVzICovXG5cblxuY29uc3QgU1VQUFJFU1NfVFJBQ0lOR19LRVkgPSAnX19TRU5UUllfU1VQUFJFU1NfVFJBQ0lOR19fJztcblxuLyoqXG4gKiBXcmFwcyBhIGZ1bmN0aW9uIHdpdGggYSB0cmFuc2FjdGlvbi9zcGFuIGFuZCBmaW5pc2hlcyB0aGUgc3BhbiBhZnRlciB0aGUgZnVuY3Rpb24gaXMgZG9uZS5cbiAqIFRoZSBjcmVhdGVkIHNwYW4gaXMgdGhlIGFjdGl2ZSBzcGFuIGFuZCB3aWxsIGJlIHVzZWQgYXMgcGFyZW50IGJ5IG90aGVyIHNwYW5zIGNyZWF0ZWQgaW5zaWRlIHRoZSBmdW5jdGlvblxuICogYW5kIGNhbiBiZSBhY2Nlc3NlZCB2aWEgYFNlbnRyeS5nZXRBY3RpdmVTcGFuKClgLCBhcyBsb25nIGFzIHRoZSBmdW5jdGlvbiBpcyBleGVjdXRlZCB3aGlsZSB0aGUgc2NvcGUgaXMgYWN0aXZlLlxuICpcbiAqIElmIHlvdSB3YW50IHRvIGNyZWF0ZSBhIHNwYW4gdGhhdCBpcyBub3Qgc2V0IGFzIGFjdGl2ZSwgdXNlIHtAbGluayBzdGFydEluYWN0aXZlU3Bhbn0uXG4gKlxuICogWW91J2xsIGFsd2F5cyBnZXQgYSBzcGFuIHBhc3NlZCB0byB0aGUgY2FsbGJhY2ssXG4gKiBpdCBtYXkganVzdCBiZSBhIG5vbi1yZWNvcmRpbmcgc3BhbiBpZiB0aGUgc3BhbiBpcyBub3Qgc2FtcGxlZCBvciBpZiB0cmFjaW5nIGlzIGRpc2FibGVkLlxuICovXG5mdW5jdGlvbiBzdGFydFNwYW4ob3B0aW9ucywgY2FsbGJhY2spIHtcbiAgY29uc3QgYWNzID0gZ2V0QWNzKCk7XG4gIGlmIChhY3Muc3RhcnRTcGFuKSB7XG4gICAgcmV0dXJuIGFjcy5zdGFydFNwYW4ob3B0aW9ucywgY2FsbGJhY2spO1xuICB9XG5cbiAgY29uc3Qgc3BhbkFyZ3VtZW50cyA9IHBhcnNlU2VudHJ5U3BhbkFyZ3VtZW50cyhvcHRpb25zKTtcbiAgY29uc3QgeyBmb3JjZVRyYW5zYWN0aW9uLCBwYXJlbnRTcGFuOiBjdXN0b21QYXJlbnRTcGFuLCBzY29wZTogY3VzdG9tU2NvcGUgfSA9IG9wdGlvbnM7XG5cbiAgLy8gV2Ugc3RpbGwgbmVlZCB0byBmb3JrIGEgcG90ZW50aWFsbHkgcGFzc2VkIHNjb3BlLCBhcyB3ZSBzZXQgdGhlIGFjdGl2ZSBzcGFuIG9uIGl0XG4gIC8vIGFuZCB3ZSBuZWVkIHRvIGVuc3VyZSB0aGF0IGl0IGlzIGNsZWFuZWQgdXAgcHJvcGVybHkgb25jZSB0aGUgc3BhbiBlbmRzLlxuICBjb25zdCBjdXN0b21Gb3JrZWRTY29wZSA9IGN1c3RvbVNjb3BlPy5jbG9uZSgpO1xuXG4gIHJldHVybiBjdXJyZW50U2NvcGVzLndpdGhTY29wZShjdXN0b21Gb3JrZWRTY29wZSwgKCkgPT4ge1xuICAgIC8vIElmIGBvcHRpb25zLnBhcmVudFNwYW5gIGlzIGRlZmluZWQsIHdlIHdhbnQgdG8gd3JhcCB0aGUgY2FsbGJhY2sgaW4gYHdpdGhBY3RpdmVTcGFuYFxuICAgIGNvbnN0IHdyYXBwZXIgPSBnZXRBY3RpdmVTcGFuV3JhcHBlcihjdXN0b21QYXJlbnRTcGFuKTtcblxuICAgIHJldHVybiB3cmFwcGVyKCgpID0+IHtcbiAgICAgIGNvbnN0IHNjb3BlID0gY3VycmVudFNjb3Blcy5nZXRDdXJyZW50U2NvcGUoKTtcbiAgICAgIGNvbnN0IHBhcmVudFNwYW4gPSBnZXRQYXJlbnRTcGFuKHNjb3BlLCBjdXN0b21QYXJlbnRTcGFuKTtcblxuICAgICAgY29uc3Qgc2hvdWxkU2tpcFNwYW4gPSBvcHRpb25zLm9ubHlJZlBhcmVudCAmJiAhcGFyZW50U3BhbjtcbiAgICAgIGNvbnN0IGFjdGl2ZVNwYW4gPSBzaG91bGRTa2lwU3BhblxuICAgICAgICA/IG5ldyBzZW50cnlOb25SZWNvcmRpbmdTcGFuLlNlbnRyeU5vblJlY29yZGluZ1NwYW4oKVxuICAgICAgICA6IGNyZWF0ZUNoaWxkT3JSb290U3Bhbih7XG4gICAgICAgICAgICBwYXJlbnRTcGFuLFxuICAgICAgICAgICAgc3BhbkFyZ3VtZW50cyxcbiAgICAgICAgICAgIGZvcmNlVHJhbnNhY3Rpb24sXG4gICAgICAgICAgICBzY29wZSxcbiAgICAgICAgICB9KTtcblxuICAgICAgc3Bhbk9uU2NvcGUuX3NldFNwYW5Gb3JTY29wZShzY29wZSwgYWN0aXZlU3Bhbik7XG5cbiAgICAgIHJldHVybiBoYW5kbGVDYWxsYmFja0Vycm9ycy5oYW5kbGVDYWxsYmFja0Vycm9ycyhcbiAgICAgICAgKCkgPT4gY2FsbGJhY2soYWN0aXZlU3BhbiksXG4gICAgICAgICgpID0+IHtcbiAgICAgICAgICAvLyBPbmx5IHVwZGF0ZSB0aGUgc3BhbiBzdGF0dXMgaWYgaXQgaGFzbid0IGJlZW4gY2hhbmdlZCB5ZXQsIGFuZCB0aGUgc3BhbiBpcyBub3QgeWV0IGZpbmlzaGVkXG4gICAgICAgICAgY29uc3QgeyBzdGF0dXMgfSA9IHNwYW5VdGlscy5zcGFuVG9KU09OKGFjdGl2ZVNwYW4pO1xuICAgICAgICAgIGlmIChhY3RpdmVTcGFuLmlzUmVjb3JkaW5nKCkgJiYgKCFzdGF0dXMgfHwgc3RhdHVzID09PSAnb2snKSkge1xuICAgICAgICAgICAgYWN0aXZlU3Bhbi5zZXRTdGF0dXMoeyBjb2RlOiBzcGFuc3RhdHVzLlNQQU5fU1RBVFVTX0VSUk9SLCBtZXNzYWdlOiAnaW50ZXJuYWxfZXJyb3InIH0pO1xuICAgICAgICAgIH1cbiAgICAgICAgfSxcbiAgICAgICAgKCkgPT4ge1xuICAgICAgICAgIGFjdGl2ZVNwYW4uZW5kKCk7XG4gICAgICAgIH0sXG4gICAgICApO1xuICAgIH0pO1xuICB9KTtcbn1cblxuLyoqXG4gKiBTaW1pbGFyIHRvIGBTZW50cnkuc3RhcnRTcGFuYC4gV3JhcHMgYSBmdW5jdGlvbiB3aXRoIGEgdHJhbnNhY3Rpb24vc3BhbiwgYnV0IGRvZXMgbm90IGZpbmlzaCB0aGUgc3BhblxuICogYWZ0ZXIgdGhlIGZ1bmN0aW9uIGlzIGRvbmUgYXV0b21hdGljYWxseS4gVXNlIGBzcGFuLmVuZCgpYCB0byBlbmQgdGhlIHNwYW4uXG4gKlxuICogVGhlIGNyZWF0ZWQgc3BhbiBpcyB0aGUgYWN0aXZlIHNwYW4gYW5kIHdpbGwgYmUgdXNlZCBhcyBwYXJlbnQgYnkgb3RoZXIgc3BhbnMgY3JlYXRlZCBpbnNpZGUgdGhlIGZ1bmN0aW9uXG4gKiBhbmQgY2FuIGJlIGFjY2Vzc2VkIHZpYSBgU2VudHJ5LmdldEFjdGl2ZVNwYW4oKWAsIGFzIGxvbmcgYXMgdGhlIGZ1bmN0aW9uIGlzIGV4ZWN1dGVkIHdoaWxlIHRoZSBzY29wZSBpcyBhY3RpdmUuXG4gKlxuICogWW91J2xsIGFsd2F5cyBnZXQgYSBzcGFuIHBhc3NlZCB0byB0aGUgY2FsbGJhY2ssXG4gKiBpdCBtYXkganVzdCBiZSBhIG5vbi1yZWNvcmRpbmcgc3BhbiBpZiB0aGUgc3BhbiBpcyBub3Qgc2FtcGxlZCBvciBpZiB0cmFjaW5nIGlzIGRpc2FibGVkLlxuICovXG5mdW5jdGlvbiBzdGFydFNwYW5NYW51YWwob3B0aW9ucywgY2FsbGJhY2spIHtcbiAgY29uc3QgYWNzID0gZ2V0QWNzKCk7XG4gIGlmIChhY3Muc3RhcnRTcGFuTWFudWFsKSB7XG4gICAgcmV0dXJuIGFjcy5zdGFydFNwYW5NYW51YWwob3B0aW9ucywgY2FsbGJhY2spO1xuICB9XG5cbiAgY29uc3Qgc3BhbkFyZ3VtZW50cyA9IHBhcnNlU2VudHJ5U3BhbkFyZ3VtZW50cyhvcHRpb25zKTtcbiAgY29uc3QgeyBmb3JjZVRyYW5zYWN0aW9uLCBwYXJlbnRTcGFuOiBjdXN0b21QYXJlbnRTcGFuLCBzY29wZTogY3VzdG9tU2NvcGUgfSA9IG9wdGlvbnM7XG5cbiAgY29uc3QgY3VzdG9tRm9ya2VkU2NvcGUgPSBjdXN0b21TY29wZT8uY2xvbmUoKTtcblxuICByZXR1cm4gY3VycmVudFNjb3Blcy53aXRoU2NvcGUoY3VzdG9tRm9ya2VkU2NvcGUsICgpID0+IHtcbiAgICAvLyBJZiBgb3B0aW9ucy5wYXJlbnRTcGFuYCBpcyBkZWZpbmVkLCB3ZSB3YW50IHRvIHdyYXAgdGhlIGNhbGxiYWNrIGluIGB3aXRoQWN0aXZlU3BhbmBcbiAgICBjb25zdCB3cmFwcGVyID0gZ2V0QWN0aXZlU3BhbldyYXBwZXIoY3VzdG9tUGFyZW50U3Bhbik7XG5cbiAgICByZXR1cm4gd3JhcHBlcigoKSA9PiB7XG4gICAgICBjb25zdCBzY29wZSA9IGN1cnJlbnRTY29wZXMuZ2V0Q3VycmVudFNjb3BlKCk7XG4gICAgICBjb25zdCBwYXJlbnRTcGFuID0gZ2V0UGFyZW50U3BhbihzY29wZSwgY3VzdG9tUGFyZW50U3Bhbik7XG5cbiAgICAgIGNvbnN0IHNob3VsZFNraXBTcGFuID0gb3B0aW9ucy5vbmx5SWZQYXJlbnQgJiYgIXBhcmVudFNwYW47XG4gICAgICBjb25zdCBhY3RpdmVTcGFuID0gc2hvdWxkU2tpcFNwYW5cbiAgICAgICAgPyBuZXcgc2VudHJ5Tm9uUmVjb3JkaW5nU3Bhbi5TZW50cnlOb25SZWNvcmRpbmdTcGFuKClcbiAgICAgICAgOiBjcmVhdGVDaGlsZE9yUm9vdFNwYW4oe1xuICAgICAgICAgICAgcGFyZW50U3BhbixcbiAgICAgICAgICAgIHNwYW5Bcmd1bWVudHMsXG4gICAgICAgICAgICBmb3JjZVRyYW5zYWN0aW9uLFxuICAgICAgICAgICAgc2NvcGUsXG4gICAgICAgICAgfSk7XG5cbiAgICAgIHNwYW5PblNjb3BlLl9zZXRTcGFuRm9yU2NvcGUoc2NvcGUsIGFjdGl2ZVNwYW4pO1xuXG4gICAgICByZXR1cm4gaGFuZGxlQ2FsbGJhY2tFcnJvcnMuaGFuZGxlQ2FsbGJhY2tFcnJvcnMoXG4gICAgICAgIC8vIFdlIHBhc3MgdGhlIGBmaW5pc2hgIGZ1bmN0aW9uIHRvIHRoZSBjYWxsYmFjaywgc28gdGhlIHVzZXIgY2FuIGZpbmlzaCB0aGUgc3BhbiBtYW51YWxseVxuICAgICAgICAvLyB0aGlzIGlzIG1haW5seSBoZXJlIGZvciBoaXN0b3JpYyBwdXJwb3NlcyBiZWNhdXNlIHByZXZpb3VzbHksIHdlIGluc3RydWN0ZWQgdXNlcnMgdG8gY2FsbFxuICAgICAgICAvLyBgZmluaXNoYCBpbnN0ZWFkIG9mIGBzcGFuLmVuZCgpYCB0byBhbHNvIGNsZWFuIHVwIHRoZSBzY29wZS4gTm93YWRheXMsIGNhbGxpbmcgYHNwYW4uZW5kKClgXG4gICAgICAgIC8vIG9yIGBmaW5pc2hgIGhhcyB0aGUgc2FtZSBlZmZlY3QgYW5kIHdlIHNpbXBseSBsZWF2ZSBpdCBoZXJlIHRvIGF2b2lkIGJyZWFraW5nIHVzZXIgY29kZS5cbiAgICAgICAgKCkgPT4gY2FsbGJhY2soYWN0aXZlU3BhbiwgKCkgPT4gYWN0aXZlU3Bhbi5lbmQoKSksXG4gICAgICAgICgpID0+IHtcbiAgICAgICAgICAvLyBPbmx5IHVwZGF0ZSB0aGUgc3BhbiBzdGF0dXMgaWYgaXQgaGFzbid0IGJlZW4gY2hhbmdlZCB5ZXQsIGFuZCB0aGUgc3BhbiBpcyBub3QgeWV0IGZpbmlzaGVkXG4gICAgICAgICAgY29uc3QgeyBzdGF0dXMgfSA9IHNwYW5VdGlscy5zcGFuVG9KU09OKGFjdGl2ZVNwYW4pO1xuICAgICAgICAgIGlmIChhY3RpdmVTcGFuLmlzUmVjb3JkaW5nKCkgJiYgKCFzdGF0dXMgfHwgc3RhdHVzID09PSAnb2snKSkge1xuICAgICAgICAgICAgYWN0aXZlU3Bhbi5zZXRTdGF0dXMoeyBjb2RlOiBzcGFuc3RhdHVzLlNQQU5fU1RBVFVTX0VSUk9SLCBtZXNzYWdlOiAnaW50ZXJuYWxfZXJyb3InIH0pO1xuICAgICAgICAgIH1cbiAgICAgICAgfSxcbiAgICAgICk7XG4gICAgfSk7XG4gIH0pO1xufVxuXG4vKipcbiAqIENyZWF0ZXMgYSBzcGFuLiBUaGlzIHNwYW4gaXMgbm90IHNldCBhcyBhY3RpdmUsIHNvIHdpbGwgbm90IGdldCBhdXRvbWF0aWMgaW5zdHJ1bWVudGF0aW9uIHNwYW5zXG4gKiBhcyBjaGlsZHJlbiBvciBiZSBhYmxlIHRvIGJlIGFjY2Vzc2VkIHZpYSBgU2VudHJ5LmdldEFjdGl2ZVNwYW4oKWAuXG4gKlxuICogSWYgeW91IHdhbnQgdG8gY3JlYXRlIGEgc3BhbiB0aGF0IGlzIHNldCBhcyBhY3RpdmUsIHVzZSB7QGxpbmsgc3RhcnRTcGFufS5cbiAqXG4gKiBUaGlzIGZ1bmN0aW9uIHdpbGwgYWx3YXlzIHJldHVybiBhIHNwYW4sXG4gKiBpdCBtYXkganVzdCBiZSBhIG5vbi1yZWNvcmRpbmcgc3BhbiBpZiB0aGUgc3BhbiBpcyBub3Qgc2FtcGxlZCBvciBpZiB0cmFjaW5nIGlzIGRpc2FibGVkLlxuICovXG5mdW5jdGlvbiBzdGFydEluYWN0aXZlU3BhbihvcHRpb25zKSB7XG4gIGNvbnN0IGFjcyA9IGdldEFjcygpO1xuICBpZiAoYWNzLnN0YXJ0SW5hY3RpdmVTcGFuKSB7XG4gICAgcmV0dXJuIGFjcy5zdGFydEluYWN0aXZlU3BhbihvcHRpb25zKTtcbiAgfVxuXG4gIGNvbnN0IHNwYW5Bcmd1bWVudHMgPSBwYXJzZVNlbnRyeVNwYW5Bcmd1bWVudHMob3B0aW9ucyk7XG4gIGNvbnN0IHsgZm9yY2VUcmFuc2FjdGlvbiwgcGFyZW50U3BhbjogY3VzdG9tUGFyZW50U3BhbiB9ID0gb3B0aW9ucztcblxuICAvLyBJZiBgb3B0aW9ucy5zY29wZWAgaXMgZGVmaW5lZCwgd2UgdXNlIHRoaXMgYXMgYXMgYSB3cmFwcGVyLFxuICAvLyBJZiBgb3B0aW9ucy5wYXJlbnRTcGFuYCBpcyBkZWZpbmVkLCB3ZSB3YW50IHRvIHdyYXAgdGhlIGNhbGxiYWNrIGluIGB3aXRoQWN0aXZlU3BhbmBcbiAgY29uc3Qgd3JhcHBlciA9IG9wdGlvbnMuc2NvcGVcbiAgICA/IChjYWxsYmFjaykgPT4gY3VycmVudFNjb3Blcy53aXRoU2NvcGUob3B0aW9ucy5zY29wZSwgY2FsbGJhY2spXG4gICAgOiBjdXN0b21QYXJlbnRTcGFuICE9PSB1bmRlZmluZWRcbiAgICAgID8gKGNhbGxiYWNrKSA9PiB3aXRoQWN0aXZlU3BhbihjdXN0b21QYXJlbnRTcGFuLCBjYWxsYmFjaylcbiAgICAgIDogKGNhbGxiYWNrKSA9PiBjYWxsYmFjaygpO1xuXG4gIHJldHVybiB3cmFwcGVyKCgpID0+IHtcbiAgICBjb25zdCBzY29wZSA9IGN1cnJlbnRTY29wZXMuZ2V0Q3VycmVudFNjb3BlKCk7XG4gICAgY29uc3QgcGFyZW50U3BhbiA9IGdldFBhcmVudFNwYW4oc2NvcGUsIGN1c3RvbVBhcmVudFNwYW4pO1xuXG4gICAgY29uc3Qgc2hvdWxkU2tpcFNwYW4gPSBvcHRpb25zLm9ubHlJZlBhcmVudCAmJiAhcGFyZW50U3BhbjtcblxuICAgIGlmIChzaG91bGRTa2lwU3Bhbikge1xuICAgICAgcmV0dXJuIG5ldyBzZW50cnlOb25SZWNvcmRpbmdTcGFuLlNlbnRyeU5vblJlY29yZGluZ1NwYW4oKTtcbiAgICB9XG5cbiAgICByZXR1cm4gY3JlYXRlQ2hpbGRPclJvb3RTcGFuKHtcbiAgICAgIHBhcmVudFNwYW4sXG4gICAgICBzcGFuQXJndW1lbnRzLFxuICAgICAgZm9yY2VUcmFuc2FjdGlvbixcbiAgICAgIHNjb3BlLFxuICAgIH0pO1xuICB9KTtcbn1cblxuLyoqXG4gKiBDb250aW51ZSBhIHRyYWNlIGZyb20gYHNlbnRyeS10cmFjZWAgYW5kIGBiYWdnYWdlYCB2YWx1ZXMuXG4gKiBUaGVzZSB2YWx1ZXMgY2FuIGJlIG9idGFpbmVkIGZyb20gaW5jb21pbmcgcmVxdWVzdCBoZWFkZXJzLCBvciBpbiB0aGUgYnJvd3NlciBmcm9tIGA8bWV0YSBuYW1lPVwic2VudHJ5LXRyYWNlXCI+YFxuICogYW5kIGA8bWV0YSBuYW1lPVwiYmFnZ2FnZVwiPmAgSFRNTCB0YWdzLlxuICpcbiAqIFNwYW5zIHN0YXJ0ZWQgd2l0aCBgc3RhcnRTcGFuYCwgYHN0YXJ0U3Bhbk1hbnVhbGAgYW5kIGBzdGFydEluYWN0aXZlU3BhbmAsIHdpdGhpbiB0aGUgY2FsbGJhY2sgd2lsbCBhdXRvbWF0aWNhbGx5XG4gKiBiZSBhdHRhY2hlZCB0byB0aGUgaW5jb21pbmcgdHJhY2UuXG4gKi9cbmNvbnN0IGNvbnRpbnVlVHJhY2UgPSAoXG4gIG9wdGlvbnNcblxuLFxuICBjYWxsYmFjayxcbikgPT4ge1xuICBjb25zdCBjYXJyaWVyJDEgPSBjYXJyaWVyLmdldE1haW5DYXJyaWVyKCk7XG4gIGNvbnN0IGFjcyA9IGluZGV4LmdldEFzeW5jQ29udGV4dFN0cmF0ZWd5KGNhcnJpZXIkMSk7XG4gIGlmIChhY3MuY29udGludWVUcmFjZSkge1xuICAgIHJldHVybiBhY3MuY29udGludWVUcmFjZShvcHRpb25zLCBjYWxsYmFjayk7XG4gIH1cblxuICBjb25zdCB7IHNlbnRyeVRyYWNlLCBiYWdnYWdlIH0gPSBvcHRpb25zO1xuXG4gIHJldHVybiBjdXJyZW50U2NvcGVzLndpdGhTY29wZShzY29wZSA9PiB7XG4gICAgY29uc3QgcHJvcGFnYXRpb25Db250ZXh0ID0gdHJhY2luZy5wcm9wYWdhdGlvbkNvbnRleHRGcm9tSGVhZGVycyhzZW50cnlUcmFjZSwgYmFnZ2FnZSk7XG4gICAgc2NvcGUuc2V0UHJvcGFnYXRpb25Db250ZXh0KHByb3BhZ2F0aW9uQ29udGV4dCk7XG4gICAgcmV0dXJuIGNhbGxiYWNrKCk7XG4gIH0pO1xufTtcblxuLyoqXG4gKiBGb3JrcyB0aGUgY3VycmVudCBzY29wZSBhbmQgc2V0cyB0aGUgcHJvdmlkZWQgc3BhbiBhcyBhY3RpdmUgc3BhbiBpbiB0aGUgY29udGV4dCBvZiB0aGUgcHJvdmlkZWQgY2FsbGJhY2suIENhbiBiZVxuICogcGFzc2VkIGBudWxsYCB0byBzdGFydCBhbiBlbnRpcmVseSBuZXcgc3BhbiB0cmVlLlxuICpcbiAqIEBwYXJhbSBzcGFuIFNwYW5zIHN0YXJ0ZWQgaW4gdGhlIGNvbnRleHQgb2YgdGhlIHByb3ZpZGVkIGNhbGxiYWNrIHdpbGwgYmUgY2hpbGRyZW4gb2YgdGhpcyBzcGFuLiBJZiBgbnVsbGAgaXMgcGFzc2VkLFxuICogc3BhbnMgc3RhcnRlZCB3aXRoaW4gdGhlIGNhbGxiYWNrIHdpbGwgbm90IGJlIGF0dGFjaGVkIHRvIGEgcGFyZW50IHNwYW4uXG4gKiBAcGFyYW0gY2FsbGJhY2sgRXhlY3V0aW9uIGNvbnRleHQgaW4gd2hpY2ggdGhlIHByb3ZpZGVkIHNwYW4gd2lsbCBiZSBhY3RpdmUuIElzIHBhc3NlZCB0aGUgbmV3bHkgZm9ya2VkIHNjb3BlLlxuICogQHJldHVybnMgdGhlIHZhbHVlIHJldHVybmVkIGZyb20gdGhlIHByb3ZpZGVkIGNhbGxiYWNrIGZ1bmN0aW9uLlxuICovXG5mdW5jdGlvbiB3aXRoQWN0aXZlU3BhbihzcGFuLCBjYWxsYmFjaykge1xuICBjb25zdCBhY3MgPSBnZXRBY3MoKTtcbiAgaWYgKGFjcy53aXRoQWN0aXZlU3Bhbikge1xuICAgIHJldHVybiBhY3Mud2l0aEFjdGl2ZVNwYW4oc3BhbiwgY2FsbGJhY2spO1xuICB9XG5cbiAgcmV0dXJuIGN1cnJlbnRTY29wZXMud2l0aFNjb3BlKHNjb3BlID0+IHtcbiAgICBzcGFuT25TY29wZS5fc2V0U3BhbkZvclNjb3BlKHNjb3BlLCBzcGFuIHx8IHVuZGVmaW5lZCk7XG4gICAgcmV0dXJuIGNhbGxiYWNrKHNjb3BlKTtcbiAgfSk7XG59XG5cbi8qKiBTdXBwcmVzcyB0cmFjaW5nIGluIHRoZSBnaXZlbiBjYWxsYmFjaywgZW5zdXJpbmcgbm8gc3BhbnMgYXJlIGdlbmVyYXRlZCBpbnNpZGUgb2YgaXQuICovXG5mdW5jdGlvbiBzdXBwcmVzc1RyYWNpbmcoY2FsbGJhY2spIHtcbiAgY29uc3QgYWNzID0gZ2V0QWNzKCk7XG5cbiAgaWYgKGFjcy5zdXBwcmVzc1RyYWNpbmcpIHtcbiAgICByZXR1cm4gYWNzLnN1cHByZXNzVHJhY2luZyhjYWxsYmFjayk7XG4gIH1cblxuICByZXR1cm4gY3VycmVudFNjb3Blcy53aXRoU2NvcGUoc2NvcGUgPT4ge1xuICAgIC8vIE5vdGU6IFdlIGRvIG5vdCB3YWl0IGZvciB0aGUgY2FsbGJhY2sgdG8gZmluaXNoIGJlZm9yZSB3ZSByZXNldCB0aGUgbWV0YWRhdGFcbiAgICAvLyB0aGUgcmVhc29uIGZvciB0aGlzIGlzIHRoYXQgb3RoZXJ3aXNlLCBpbiB0aGUgYnJvd3NlciB0aGlzIGNhbiBsZWFkIHRvIHZlcnkgd2VpcmQgYmVoYXZpb3JcbiAgICAvLyBhcyB0aGVyZSBpcyBvbmx5IGEgc2luZ2xlIHRvcCBzY29wZSwgaWYgdGhlIGNhbGxiYWNrIHRha2VzIGxvbmdlciB0byBmaW5pc2gsXG4gICAgLy8gb3RoZXIsIHVucmVsYXRlZCBzcGFucyBtYXkgYWxzbyBiZSBzdXBwcmVzc2VkLCB3aGljaCB3ZSBkbyBub3Qgd2FudFxuICAgIC8vIHNvIGluc3RlYWQsIHdlIG9ubHkgc3VwcHJlc3MgdHJhY2luZyBzeW5jaHJvbm95c2x5IGluIHRoZSBicm93c2VyXG4gICAgc2NvcGUuc2V0U0RLUHJvY2Vzc2luZ01ldGFkYXRhKHsgW1NVUFBSRVNTX1RSQUNJTkdfS0VZXTogdHJ1ZSB9KTtcbiAgICBjb25zdCByZXMgPSBjYWxsYmFjaygpO1xuICAgIHNjb3BlLnNldFNES1Byb2Nlc3NpbmdNZXRhZGF0YSh7IFtTVVBQUkVTU19UUkFDSU5HX0tFWV06IHVuZGVmaW5lZCB9KTtcbiAgICByZXR1cm4gcmVzO1xuICB9KTtcbn1cblxuLyoqXG4gKiBTdGFydHMgYSBuZXcgdHJhY2UgZm9yIHRoZSBkdXJhdGlvbiBvZiB0aGUgcHJvdmlkZWQgY2FsbGJhY2suIFNwYW5zIHN0YXJ0ZWQgd2l0aGluIHRoZVxuICogY2FsbGJhY2sgd2lsbCBiZSBwYXJ0IG9mIHRoZSBuZXcgdHJhY2UgaW5zdGVhZCBvZiBhIHBvdGVudGlhbGx5IHByZXZpb3VzbHkgc3RhcnRlZCB0cmFjZS5cbiAqXG4gKiBJbXBvcnRhbnQ6IE9ubHkgdXNlIHRoaXMgZnVuY3Rpb24gaWYgeW91IHdhbnQgdG8gb3ZlcnJpZGUgdGhlIGRlZmF1bHQgdHJhY2UgbGlmZXRpbWUgYW5kXG4gKiBwcm9wYWdhdGlvbiBtZWNoYW5pc20gb2YgdGhlIFNESyBmb3IgdGhlIGR1cmF0aW9uIGFuZCBzY29wZSBvZiB0aGUgcHJvdmlkZWQgY2FsbGJhY2suXG4gKiBUaGUgbmV3bHkgY3JlYXRlZCB0cmFjZSB3aWxsIGFsc28gYmUgdGhlIHJvb3Qgb2YgYSBuZXcgZGlzdHJpYnV0ZWQgdHJhY2UsIGZvciBleGFtcGxlIGlmXG4gKiB5b3UgbWFrZSBodHRwIHJlcXVlc3RzIHdpdGhpbiB0aGUgY2FsbGJhY2suXG4gKiBUaGlzIGZ1bmN0aW9uIG1pZ2h0IGJlIHVzZWZ1bCBpZiB0aGUgb3BlcmF0aW9uIHlvdSB3YW50IHRvIGluc3RydW1lbnQgc2hvdWxkIG5vdCBiZSBwYXJ0XG4gKiBvZiBhIHBvdGVudGlhbGx5IG9uZ29pbmcgdHJhY2UuXG4gKlxuICogRGVmYXVsdCBiZWhhdmlvcjpcbiAqIC0gU2VydmVyLXNpZGU6IEEgbmV3IHRyYWNlIGlzIHN0YXJ0ZWQgZm9yIGVhY2ggaW5jb21pbmcgcmVxdWVzdC5cbiAqIC0gQnJvd3NlcjogQSBuZXcgdHJhY2UgaXMgc3RhcnRlZCBmb3IgZWFjaCBwYWdlIG91ciByb3V0ZS4gTmF2aWdhdGluZyB0byBhIG5ldyByb3V0ZVxuICogICAgICAgICAgICBvciBwYWdlIHdpbGwgYXV0b21hdGljYWxseSBjcmVhdGUgYSBuZXcgdHJhY2UuXG4gKi9cbmZ1bmN0aW9uIHN0YXJ0TmV3VHJhY2UoY2FsbGJhY2spIHtcbiAgcmV0dXJuIGN1cnJlbnRTY29wZXMud2l0aFNjb3BlKHNjb3BlID0+IHtcbiAgICBzY29wZS5zZXRQcm9wYWdhdGlvbkNvbnRleHQoe1xuICAgICAgdHJhY2VJZDogcHJvcGFnYXRpb25Db250ZXh0LmdlbmVyYXRlVHJhY2VJZCgpLFxuICAgICAgc2FtcGxlUmFuZDogTWF0aC5yYW5kb20oKSxcbiAgICB9KTtcbiAgICBkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEICYmIGRlYnVnTG9nZ2VyLmRlYnVnLmxvZyhgU3RhcnRpbmcgYSBuZXcgdHJhY2Ugd2l0aCBpZCAke3Njb3BlLmdldFByb3BhZ2F0aW9uQ29udGV4dCgpLnRyYWNlSWR9YCk7XG4gICAgcmV0dXJuIHdpdGhBY3RpdmVTcGFuKG51bGwsIGNhbGxiYWNrKTtcbiAgfSk7XG59XG5cbmZ1bmN0aW9uIGNyZWF0ZUNoaWxkT3JSb290U3Bhbih7XG4gIHBhcmVudFNwYW4sXG4gIHNwYW5Bcmd1bWVudHMsXG4gIGZvcmNlVHJhbnNhY3Rpb24sXG4gIHNjb3BlLFxufVxuXG4pIHtcbiAgaWYgKCFoYXNTcGFuc0VuYWJsZWQuaGFzU3BhbnNFbmFibGVkKCkpIHtcbiAgICBjb25zdCBzcGFuID0gbmV3IHNlbnRyeU5vblJlY29yZGluZ1NwYW4uU2VudHJ5Tm9uUmVjb3JkaW5nU3BhbigpO1xuXG4gICAgLy8gSWYgdGhpcyBpcyBhIHJvb3Qgc3Bhbiwgd2UgZW5zdXJlIHRvIGZyZWV6ZSBhIERTQ1xuICAgIC8vIFNvIHdlIGNhbiBoYXZlIGF0IGxlYXN0IHBhcnRpYWwgZGF0YSBoZXJlXG4gICAgaWYgKGZvcmNlVHJhbnNhY3Rpb24gfHwgIXBhcmVudFNwYW4pIHtcbiAgICAgIGNvbnN0IGRzYyA9IHtcbiAgICAgICAgc2FtcGxlZDogJ2ZhbHNlJyxcbiAgICAgICAgc2FtcGxlX3JhdGU6ICcwJyxcbiAgICAgICAgdHJhbnNhY3Rpb246IHNwYW5Bcmd1bWVudHMubmFtZSxcbiAgICAgICAgLi4uZHluYW1pY1NhbXBsaW5nQ29udGV4dC5nZXREeW5hbWljU2FtcGxpbmdDb250ZXh0RnJvbVNwYW4oc3BhbiksXG4gICAgICB9IDtcbiAgICAgIGR5bmFtaWNTYW1wbGluZ0NvbnRleHQuZnJlZXplRHNjT25TcGFuKHNwYW4sIGRzYyk7XG4gICAgfVxuXG4gICAgcmV0dXJuIHNwYW47XG4gIH1cblxuICBjb25zdCBpc29sYXRpb25TY29wZSA9IGN1cnJlbnRTY29wZXMuZ2V0SXNvbGF0aW9uU2NvcGUoKTtcblxuICBsZXQgc3BhbjtcbiAgaWYgKHBhcmVudFNwYW4gJiYgIWZvcmNlVHJhbnNhY3Rpb24pIHtcbiAgICBzcGFuID0gX3N0YXJ0Q2hpbGRTcGFuKHBhcmVudFNwYW4sIHNjb3BlLCBzcGFuQXJndW1lbnRzKTtcbiAgICBzcGFuVXRpbHMuYWRkQ2hpbGRTcGFuVG9TcGFuKHBhcmVudFNwYW4sIHNwYW4pO1xuICB9IGVsc2UgaWYgKHBhcmVudFNwYW4pIHtcbiAgICAvLyBJZiB3ZSBmb3JjZWQgYSB0cmFuc2FjdGlvbiBidXQgaGF2ZSBhIHBhcmVudCBzcGFuLCBtYWtlIHN1cmUgdG8gY29udGludWUgZnJvbSB0aGUgcGFyZW50IHNwYW4sIG5vdCB0aGUgc2NvcGVcbiAgICBjb25zdCBkc2MgPSBkeW5hbWljU2FtcGxpbmdDb250ZXh0LmdldER5bmFtaWNTYW1wbGluZ0NvbnRleHRGcm9tU3BhbihwYXJlbnRTcGFuKTtcbiAgICBjb25zdCB7IHRyYWNlSWQsIHNwYW5JZDogcGFyZW50U3BhbklkIH0gPSBwYXJlbnRTcGFuLnNwYW5Db250ZXh0KCk7XG4gICAgY29uc3QgcGFyZW50U2FtcGxlZCA9IHNwYW5VdGlscy5zcGFuSXNTYW1wbGVkKHBhcmVudFNwYW4pO1xuXG4gICAgc3BhbiA9IF9zdGFydFJvb3RTcGFuKFxuICAgICAge1xuICAgICAgICB0cmFjZUlkLFxuICAgICAgICBwYXJlbnRTcGFuSWQsXG4gICAgICAgIC4uLnNwYW5Bcmd1bWVudHMsXG4gICAgICB9LFxuICAgICAgc2NvcGUsXG4gICAgICBwYXJlbnRTYW1wbGVkLFxuICAgICk7XG5cbiAgICBkeW5hbWljU2FtcGxpbmdDb250ZXh0LmZyZWV6ZURzY09uU3BhbihzcGFuLCBkc2MpO1xuICB9IGVsc2Uge1xuICAgIGNvbnN0IHtcbiAgICAgIHRyYWNlSWQsXG4gICAgICBkc2MsXG4gICAgICBwYXJlbnRTcGFuSWQsXG4gICAgICBzYW1wbGVkOiBwYXJlbnRTYW1wbGVkLFxuICAgIH0gPSB7XG4gICAgICAuLi5pc29sYXRpb25TY29wZS5nZXRQcm9wYWdhdGlvbkNvbnRleHQoKSxcbiAgICAgIC4uLnNjb3BlLmdldFByb3BhZ2F0aW9uQ29udGV4dCgpLFxuICAgIH07XG5cbiAgICBzcGFuID0gX3N0YXJ0Um9vdFNwYW4oXG4gICAgICB7XG4gICAgICAgIHRyYWNlSWQsXG4gICAgICAgIHBhcmVudFNwYW5JZCxcbiAgICAgICAgLi4uc3BhbkFyZ3VtZW50cyxcbiAgICAgIH0sXG4gICAgICBzY29wZSxcbiAgICAgIHBhcmVudFNhbXBsZWQsXG4gICAgKTtcblxuICAgIGlmIChkc2MpIHtcbiAgICAgIGR5bmFtaWNTYW1wbGluZ0NvbnRleHQuZnJlZXplRHNjT25TcGFuKHNwYW4sIGRzYyk7XG4gICAgfVxuICB9XG5cbiAgbG9nU3BhbnMubG9nU3BhblN0YXJ0KHNwYW4pO1xuXG4gIHV0aWxzLnNldENhcHR1cmVkU2NvcGVzT25TcGFuKHNwYW4sIHNjb3BlLCBpc29sYXRpb25TY29wZSk7XG5cbiAgcmV0dXJuIHNwYW47XG59XG5cbi8qKlxuICogVGhpcyBjb252ZXJ0cyBTdGFydFNwYW5PcHRpb25zIHRvIFNlbnRyeVNwYW5Bcmd1bWVudHMuXG4gKiBGb3IgdGhlIG1vc3QgcGFydCAoZm9yIG5vdykgd2UgYWNjZXB0IHRoZSBzYW1lIG9wdGlvbnMsXG4gKiBidXQgc29tZSBvZiB0aGVtIG5lZWQgdG8gYmUgdHJhbnNmb3JtZWQuXG4gKi9cbmZ1bmN0aW9uIHBhcnNlU2VudHJ5U3BhbkFyZ3VtZW50cyhvcHRpb25zKSB7XG4gIGNvbnN0IGV4cCA9IG9wdGlvbnMuZXhwZXJpbWVudGFsIHx8IHt9O1xuICBjb25zdCBpbml0aWFsQ3R4ID0ge1xuICAgIGlzU3RhbmRhbG9uZTogZXhwLnN0YW5kYWxvbmUsXG4gICAgLi4ub3B0aW9ucyxcbiAgfTtcblxuICBpZiAob3B0aW9ucy5zdGFydFRpbWUpIHtcbiAgICBjb25zdCBjdHggPSB7IC4uLmluaXRpYWxDdHggfTtcbiAgICBjdHguc3RhcnRUaW1lc3RhbXAgPSBzcGFuVXRpbHMuc3BhblRpbWVJbnB1dFRvU2Vjb25kcyhvcHRpb25zLnN0YXJ0VGltZSk7XG4gICAgZGVsZXRlIGN0eC5zdGFydFRpbWU7XG4gICAgcmV0dXJuIGN0eDtcbiAgfVxuXG4gIHJldHVybiBpbml0aWFsQ3R4O1xufVxuXG5mdW5jdGlvbiBnZXRBY3MoKSB7XG4gIGNvbnN0IGNhcnJpZXIkMSA9IGNhcnJpZXIuZ2V0TWFpbkNhcnJpZXIoKTtcbiAgcmV0dXJuIGluZGV4LmdldEFzeW5jQ29udGV4dFN0cmF0ZWd5KGNhcnJpZXIkMSk7XG59XG5cbmZ1bmN0aW9uIF9zdGFydFJvb3RTcGFuKHNwYW5Bcmd1bWVudHMsIHNjb3BlLCBwYXJlbnRTYW1wbGVkKSB7XG4gIGNvbnN0IGNsaWVudCA9IGN1cnJlbnRTY29wZXMuZ2V0Q2xpZW50KCk7XG4gIGNvbnN0IG9wdGlvbnMgPSBjbGllbnQ/LmdldE9wdGlvbnMoKSB8fCB7fTtcblxuICBjb25zdCB7IG5hbWUgPSAnJyB9ID0gc3BhbkFyZ3VtZW50cztcblxuICBjb25zdCBtdXRhYmxlU3BhblNhbXBsaW5nRGF0YSA9IHsgc3BhbkF0dHJpYnV0ZXM6IHsgLi4uc3BhbkFyZ3VtZW50cy5hdHRyaWJ1dGVzIH0sIHNwYW5OYW1lOiBuYW1lLCBwYXJlbnRTYW1wbGVkIH07XG5cbiAgLy8gd2UgZG9uJ3QgY2FyZSBhYm91dCB0aGUgZGVjaXNpb24gZm9yIHRoZSBtb21lbnQ7IHRoaXMgaXMganVzdCBhIHBsYWNlaG9sZGVyXG4gIGNsaWVudD8uZW1pdCgnYmVmb3JlU2FtcGxpbmcnLCBtdXRhYmxlU3BhblNhbXBsaW5nRGF0YSwgeyBkZWNpc2lvbjogZmFsc2UgfSk7XG5cbiAgLy8gSWYgaG9vayBjb25zdW1lcnMgb3ZlcnJpZGUgdGhlIHBhcmVudFNhbXBsZWQgZmxhZywgd2Ugd2lsbCB1c2UgdGhhdCB2YWx1ZSBpbnN0ZWFkIG9mIHRoZSBhY3R1YWwgb25lXG4gIGNvbnN0IGZpbmFsUGFyZW50U2FtcGxlZCA9IG11dGFibGVTcGFuU2FtcGxpbmdEYXRhLnBhcmVudFNhbXBsZWQgPz8gcGFyZW50U2FtcGxlZDtcbiAgY29uc3QgZmluYWxBdHRyaWJ1dGVzID0gbXV0YWJsZVNwYW5TYW1wbGluZ0RhdGEuc3BhbkF0dHJpYnV0ZXM7XG5cbiAgY29uc3QgY3VycmVudFByb3BhZ2F0aW9uQ29udGV4dCA9IHNjb3BlLmdldFByb3BhZ2F0aW9uQ29udGV4dCgpO1xuICBjb25zdCBbc2FtcGxlZCwgc2FtcGxlUmF0ZSwgbG9jYWxTYW1wbGVSYXRlV2FzQXBwbGllZF0gPSBzY29wZS5nZXRTY29wZURhdGEoKS5zZGtQcm9jZXNzaW5nTWV0YWRhdGFbXG4gICAgU1VQUFJFU1NfVFJBQ0lOR19LRVlcbiAgXVxuICAgID8gW2ZhbHNlXVxuICAgIDogc2FtcGxpbmcuc2FtcGxlU3BhbihcbiAgICAgICAgb3B0aW9ucyxcbiAgICAgICAge1xuICAgICAgICAgIG5hbWUsXG4gICAgICAgICAgcGFyZW50U2FtcGxlZDogZmluYWxQYXJlbnRTYW1wbGVkLFxuICAgICAgICAgIGF0dHJpYnV0ZXM6IGZpbmFsQXR0cmlidXRlcyxcbiAgICAgICAgICBwYXJlbnRTYW1wbGVSYXRlOiBwYXJzZVNhbXBsZVJhdGUucGFyc2VTYW1wbGVSYXRlKGN1cnJlbnRQcm9wYWdhdGlvbkNvbnRleHQuZHNjPy5zYW1wbGVfcmF0ZSksXG4gICAgICAgIH0sXG4gICAgICAgIGN1cnJlbnRQcm9wYWdhdGlvbkNvbnRleHQuc2FtcGxlUmFuZCxcbiAgICAgICk7XG5cbiAgY29uc3Qgcm9vdFNwYW4gPSBuZXcgc2VudHJ5U3Bhbi5TZW50cnlTcGFuKHtcbiAgICAuLi5zcGFuQXJndW1lbnRzLFxuICAgIGF0dHJpYnV0ZXM6IHtcbiAgICAgIFtzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9TT1VSQ0VdOiAnY3VzdG9tJyxcbiAgICAgIFtzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9TQU1QTEVfUkFURV06XG4gICAgICAgIHNhbXBsZVJhdGUgIT09IHVuZGVmaW5lZCAmJiBsb2NhbFNhbXBsZVJhdGVXYXNBcHBsaWVkID8gc2FtcGxlUmF0ZSA6IHVuZGVmaW5lZCxcbiAgICAgIC4uLmZpbmFsQXR0cmlidXRlcyxcbiAgICB9LFxuICAgIHNhbXBsZWQsXG4gIH0pO1xuXG4gIGlmICghc2FtcGxlZCAmJiBjbGllbnQpIHtcbiAgICBkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEICYmIGRlYnVnTG9nZ2VyLmRlYnVnLmxvZygnW1RyYWNpbmddIERpc2NhcmRpbmcgcm9vdCBzcGFuIGJlY2F1c2UgaXRzIHRyYWNlIHdhcyBub3QgY2hvc2VuIHRvIGJlIHNhbXBsZWQuJyk7XG4gICAgY2xpZW50LnJlY29yZERyb3BwZWRFdmVudCgnc2FtcGxlX3JhdGUnLCAndHJhbnNhY3Rpb24nKTtcbiAgfVxuXG4gIGlmIChjbGllbnQpIHtcbiAgICBjbGllbnQuZW1pdCgnc3BhblN0YXJ0Jywgcm9vdFNwYW4pO1xuICB9XG5cbiAgcmV0dXJuIHJvb3RTcGFuO1xufVxuXG4vKipcbiAqIENyZWF0ZXMgYSBuZXcgYFNwYW5gIHdoaWxlIHNldHRpbmcgdGhlIGN1cnJlbnQgYFNwYW4uaWRgIGFzIGBwYXJlbnRTcGFuSWRgLlxuICogVGhpcyBpbmhlcml0cyB0aGUgc2FtcGxpbmcgZGVjaXNpb24gZnJvbSB0aGUgcGFyZW50IHNwYW4uXG4gKi9cbmZ1bmN0aW9uIF9zdGFydENoaWxkU3BhbihwYXJlbnRTcGFuLCBzY29wZSwgc3BhbkFyZ3VtZW50cykge1xuICBjb25zdCB7IHNwYW5JZCwgdHJhY2VJZCB9ID0gcGFyZW50U3Bhbi5zcGFuQ29udGV4dCgpO1xuICBjb25zdCBzYW1wbGVkID0gc2NvcGUuZ2V0U2NvcGVEYXRhKCkuc2RrUHJvY2Vzc2luZ01ldGFkYXRhW1NVUFBSRVNTX1RSQUNJTkdfS0VZXSA/IGZhbHNlIDogc3BhblV0aWxzLnNwYW5Jc1NhbXBsZWQocGFyZW50U3Bhbik7XG5cbiAgY29uc3QgY2hpbGRTcGFuID0gc2FtcGxlZFxuICAgID8gbmV3IHNlbnRyeVNwYW4uU2VudHJ5U3Bhbih7XG4gICAgICAgIC4uLnNwYW5Bcmd1bWVudHMsXG4gICAgICAgIHBhcmVudFNwYW5JZDogc3BhbklkLFxuICAgICAgICB0cmFjZUlkLFxuICAgICAgICBzYW1wbGVkLFxuICAgICAgfSlcbiAgICA6IG5ldyBzZW50cnlOb25SZWNvcmRpbmdTcGFuLlNlbnRyeU5vblJlY29yZGluZ1NwYW4oeyB0cmFjZUlkIH0pO1xuXG4gIHNwYW5VdGlscy5hZGRDaGlsZFNwYW5Ub1NwYW4ocGFyZW50U3BhbiwgY2hpbGRTcGFuKTtcblxuICBjb25zdCBjbGllbnQgPSBjdXJyZW50U2NvcGVzLmdldENsaWVudCgpO1xuICBpZiAoY2xpZW50KSB7XG4gICAgY2xpZW50LmVtaXQoJ3NwYW5TdGFydCcsIGNoaWxkU3Bhbik7XG4gICAgLy8gSWYgaXQgaGFzIGFuIGVuZFRpbWVzdGFtcCwgaXQncyBhbHJlYWR5IGVuZGVkXG4gICAgaWYgKHNwYW5Bcmd1bWVudHMuZW5kVGltZXN0YW1wKSB7XG4gICAgICBjbGllbnQuZW1pdCgnc3BhbkVuZCcsIGNoaWxkU3Bhbik7XG4gICAgfVxuICB9XG5cbiAgcmV0dXJuIGNoaWxkU3Bhbjtcbn1cblxuZnVuY3Rpb24gZ2V0UGFyZW50U3BhbihzY29wZSwgY3VzdG9tUGFyZW50U3Bhbikge1xuICAvLyBhbHdheXMgdXNlIHRoZSBwYXNzZWQgaW4gc3BhbiBkaXJlY3RseVxuICBpZiAoY3VzdG9tUGFyZW50U3Bhbikge1xuICAgIHJldHVybiBjdXN0b21QYXJlbnRTcGFuIDtcbiAgfVxuXG4gIC8vIFRoaXMgaXMgZGlmZmVyZW50IGZyb20gYHVuZGVmaW5lZGAgYXMgaXQgbWVhbnMgdGhlIHVzZXIgZXhwbGljaXRseSB3YW50cyBubyBwYXJlbnQgc3BhblxuICBpZiAoY3VzdG9tUGFyZW50U3BhbiA9PT0gbnVsbCkge1xuICAgIHJldHVybiB1bmRlZmluZWQ7XG4gIH1cblxuICBjb25zdCBzcGFuID0gc3Bhbk9uU2NvcGUuX2dldFNwYW5Gb3JTY29wZShzY29wZSkgO1xuXG4gIGlmICghc3Bhbikge1xuICAgIHJldHVybiB1bmRlZmluZWQ7XG4gIH1cblxuICBjb25zdCBjbGllbnQgPSBjdXJyZW50U2NvcGVzLmdldENsaWVudCgpO1xuICBjb25zdCBvcHRpb25zID0gY2xpZW50ID8gY2xpZW50LmdldE9wdGlvbnMoKSA6IHt9O1xuICBpZiAob3B0aW9ucy5wYXJlbnRTcGFuSXNBbHdheXNSb290U3Bhbikge1xuICAgIHJldHVybiBzcGFuVXRpbHMuZ2V0Um9vdFNwYW4oc3BhbikgO1xuICB9XG5cbiAgcmV0dXJuIHNwYW47XG59XG5cbmZ1bmN0aW9uIGdldEFjdGl2ZVNwYW5XcmFwcGVyKHBhcmVudFNwYW4pIHtcbiAgcmV0dXJuIHBhcmVudFNwYW4gIT09IHVuZGVmaW5lZFxuICAgID8gKGNhbGxiYWNrKSA9PiB7XG4gICAgICAgIHJldHVybiB3aXRoQWN0aXZlU3BhbihwYXJlbnRTcGFuLCBjYWxsYmFjayk7XG4gICAgICB9XG4gICAgOiAoY2FsbGJhY2spID0+IGNhbGxiYWNrKCk7XG59XG5cbmV4cG9ydHMuY29udGludWVUcmFjZSA9IGNvbnRpbnVlVHJhY2U7XG5leHBvcnRzLnN0YXJ0SW5hY3RpdmVTcGFuID0gc3RhcnRJbmFjdGl2ZVNwYW47XG5leHBvcnRzLnN0YXJ0TmV3VHJhY2UgPSBzdGFydE5ld1RyYWNlO1xuZXhwb3J0cy5zdGFydFNwYW4gPSBzdGFydFNwYW47XG5leHBvcnRzLnN0YXJ0U3Bhbk1hbnVhbCA9IHN0YXJ0U3Bhbk1hbnVhbDtcbmV4cG9ydHMuc3VwcHJlc3NUcmFjaW5nID0gc3VwcHJlc3NUcmFjaW5nO1xuZXhwb3J0cy53aXRoQWN0aXZlU3BhbiA9IHdpdGhBY3RpdmVTcGFuO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9dHJhY2UuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/trace.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/utils.js":
/*!*****************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/utils.js ***!
  \*****************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst object = __webpack_require__(/*! ../utils/object.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/object.js\");\n\nconst SCOPE_ON_START_SPAN_FIELD = '_sentryScope';\nconst ISOLATION_SCOPE_ON_START_SPAN_FIELD = '_sentryIsolationScope';\n\n/** Store the scope & isolation scope for a span, which can the be used when it is finished. */\nfunction setCapturedScopesOnSpan(span, scope, isolationScope) {\n  if (span) {\n    object.addNonEnumerableProperty(span, ISOLATION_SCOPE_ON_START_SPAN_FIELD, isolationScope);\n    object.addNonEnumerableProperty(span, SCOPE_ON_START_SPAN_FIELD, scope);\n  }\n}\n\n/**\n * Grabs the scope and isolation scope off a span that were active when the span was started.\n */\nfunction getCapturedScopesOnSpan(span) {\n  return {\n    scope: (span )[SCOPE_ON_START_SPAN_FIELD],\n    isolationScope: (span )[ISOLATION_SCOPE_ON_START_SPAN_FIELD],\n  };\n}\n\nexports.getCapturedScopesOnSpan = getCapturedScopesOnSpan;\nexports.setCapturedScopesOnSpan = setCapturedScopesOnSpan;\n//# sourceMappingURL=utils.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy90cmFjaW5nL3V0aWxzLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLGVBQWUsbUJBQU8sQ0FBQyw4SEFBb0I7O0FBRTNDO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLCtCQUErQjtBQUMvQiwrQkFBK0I7QUFDL0IiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy90cmFjaW5nL3V0aWxzLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBvYmplY3QgPSByZXF1aXJlKCcuLi91dGlscy9vYmplY3QuanMnKTtcblxuY29uc3QgU0NPUEVfT05fU1RBUlRfU1BBTl9GSUVMRCA9ICdfc2VudHJ5U2NvcGUnO1xuY29uc3QgSVNPTEFUSU9OX1NDT1BFX09OX1NUQVJUX1NQQU5fRklFTEQgPSAnX3NlbnRyeUlzb2xhdGlvblNjb3BlJztcblxuLyoqIFN0b3JlIHRoZSBzY29wZSAmIGlzb2xhdGlvbiBzY29wZSBmb3IgYSBzcGFuLCB3aGljaCBjYW4gdGhlIGJlIHVzZWQgd2hlbiBpdCBpcyBmaW5pc2hlZC4gKi9cbmZ1bmN0aW9uIHNldENhcHR1cmVkU2NvcGVzT25TcGFuKHNwYW4sIHNjb3BlLCBpc29sYXRpb25TY29wZSkge1xuICBpZiAoc3Bhbikge1xuICAgIG9iamVjdC5hZGROb25FbnVtZXJhYmxlUHJvcGVydHkoc3BhbiwgSVNPTEFUSU9OX1NDT1BFX09OX1NUQVJUX1NQQU5fRklFTEQsIGlzb2xhdGlvblNjb3BlKTtcbiAgICBvYmplY3QuYWRkTm9uRW51bWVyYWJsZVByb3BlcnR5KHNwYW4sIFNDT1BFX09OX1NUQVJUX1NQQU5fRklFTEQsIHNjb3BlKTtcbiAgfVxufVxuXG4vKipcbiAqIEdyYWJzIHRoZSBzY29wZSBhbmQgaXNvbGF0aW9uIHNjb3BlIG9mZiBhIHNwYW4gdGhhdCB3ZXJlIGFjdGl2ZSB3aGVuIHRoZSBzcGFuIHdhcyBzdGFydGVkLlxuICovXG5mdW5jdGlvbiBnZXRDYXB0dXJlZFNjb3Blc09uU3BhbihzcGFuKSB7XG4gIHJldHVybiB7XG4gICAgc2NvcGU6IChzcGFuIClbU0NPUEVfT05fU1RBUlRfU1BBTl9GSUVMRF0sXG4gICAgaXNvbGF0aW9uU2NvcGU6IChzcGFuIClbSVNPTEFUSU9OX1NDT1BFX09OX1NUQVJUX1NQQU5fRklFTERdLFxuICB9O1xufVxuXG5leHBvcnRzLmdldENhcHR1cmVkU2NvcGVzT25TcGFuID0gZ2V0Q2FwdHVyZWRTY29wZXNPblNwYW47XG5leHBvcnRzLnNldENhcHR1cmVkU2NvcGVzT25TcGFuID0gc2V0Q2FwdHVyZWRTY29wZXNPblNwYW47XG4vLyMgc291cmNlTWFwcGluZ1VSTD11dGlscy5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/utils.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/transports/base.js":
/*!*******************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/transports/base.js ***!
  \*******************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst debugBuild = __webpack_require__(/*! ../debug-build.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst debugLogger = __webpack_require__(/*! ../utils/debug-logger.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst envelope = __webpack_require__(/*! ../utils/envelope.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/envelope.js\");\nconst promisebuffer = __webpack_require__(/*! ../utils/promisebuffer.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/promisebuffer.js\");\nconst ratelimit = __webpack_require__(/*! ../utils/ratelimit.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/ratelimit.js\");\nconst syncpromise = __webpack_require__(/*! ../utils/syncpromise.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/syncpromise.js\");\n\nconst DEFAULT_TRANSPORT_BUFFER_SIZE = 64;\n\n/**\n * Creates an instance of a Sentry `Transport`\n *\n * @param options\n * @param makeRequest\n */\nfunction createTransport(\n  options,\n  makeRequest,\n  buffer = promisebuffer.makePromiseBuffer(\n    options.bufferSize || DEFAULT_TRANSPORT_BUFFER_SIZE,\n  ),\n) {\n  let rateLimits = {};\n  const flush = (timeout) => buffer.drain(timeout);\n\n  function send(envelope$1) {\n    const filteredEnvelopeItems = [];\n\n    // Drop rate limited items from envelope\n    envelope.forEachEnvelopeItem(envelope$1, (item, type) => {\n      const dataCategory = envelope.envelopeItemTypeToDataCategory(type);\n      if (ratelimit.isRateLimited(rateLimits, dataCategory)) {\n        options.recordDroppedEvent('ratelimit_backoff', dataCategory);\n      } else {\n        filteredEnvelopeItems.push(item);\n      }\n    });\n\n    // Skip sending if envelope is empty after filtering out rate limited events\n    if (filteredEnvelopeItems.length === 0) {\n      return syncpromise.resolvedSyncPromise({});\n    }\n\n    const filteredEnvelope = envelope.createEnvelope(envelope$1[0], filteredEnvelopeItems );\n\n    // Creates client report for each item in an envelope\n    const recordEnvelopeLoss = (reason) => {\n      envelope.forEachEnvelopeItem(filteredEnvelope, (item, type) => {\n        options.recordDroppedEvent(reason, envelope.envelopeItemTypeToDataCategory(type));\n      });\n    };\n\n    const requestTask = () =>\n      makeRequest({ body: envelope.serializeEnvelope(filteredEnvelope) }).then(\n        response => {\n          // We don't want to throw on NOK responses, but we want to at least log them\n          if (response.statusCode !== undefined && (response.statusCode < 200 || response.statusCode >= 300)) {\n            debugBuild.DEBUG_BUILD && debugLogger.debug.warn(`Sentry responded with status code ${response.statusCode} to sent event.`);\n          }\n\n          rateLimits = ratelimit.updateRateLimits(rateLimits, response);\n          return response;\n        },\n        error => {\n          recordEnvelopeLoss('network_error');\n          debugBuild.DEBUG_BUILD && debugLogger.debug.error('Encountered error running transport request:', error);\n          throw error;\n        },\n      );\n\n    return buffer.add(requestTask).then(\n      result => result,\n      error => {\n        if (error === promisebuffer.SENTRY_BUFFER_FULL_ERROR) {\n          debugBuild.DEBUG_BUILD && debugLogger.debug.error('Skipped sending event because buffer is full.');\n          recordEnvelopeLoss('queue_overflow');\n          return syncpromise.resolvedSyncPromise({});\n        } else {\n          throw error;\n        }\n      },\n    );\n  }\n\n  return {\n    send,\n    flush,\n  };\n}\n\nexports.DEFAULT_TRANSPORT_BUFFER_SIZE = DEFAULT_TRANSPORT_BUFFER_SIZE;\nexports.createTransport = createTransport;\n//# sourceMappingURL=base.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy90cmFuc3BvcnRzL2Jhc2UuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsbUJBQW1CLG1CQUFPLENBQUMsNEhBQW1CO0FBQzlDLG9CQUFvQixtQkFBTyxDQUFDLDBJQUEwQjtBQUN0RCxpQkFBaUIsbUJBQU8sQ0FBQyxrSUFBc0I7QUFDL0Msc0JBQXNCLG1CQUFPLENBQUMsNElBQTJCO0FBQ3pELGtCQUFrQixtQkFBTyxDQUFDLG9JQUF1QjtBQUNqRCxvQkFBb0IsbUJBQU8sQ0FBQyx3SUFBeUI7O0FBRXJEOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxRQUFRO0FBQ1I7QUFDQTtBQUNBLEtBQUs7O0FBRUw7QUFDQTtBQUNBLCtDQUErQztBQUMvQzs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLE9BQU87QUFDUDs7QUFFQTtBQUNBLG9CQUFvQixvREFBb0Q7QUFDeEU7QUFDQTtBQUNBO0FBQ0Esa0dBQWtHLHFCQUFxQjtBQUN2SDs7QUFFQTtBQUNBO0FBQ0EsU0FBUztBQUNUO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsU0FBUztBQUNUOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLG1EQUFtRDtBQUNuRCxVQUFVO0FBQ1Y7QUFDQTtBQUNBLE9BQU87QUFDUDtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEscUNBQXFDO0FBQ3JDLHVCQUF1QjtBQUN2QiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3RyYW5zcG9ydHMvYmFzZS5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgZGVidWdCdWlsZCA9IHJlcXVpcmUoJy4uL2RlYnVnLWJ1aWxkLmpzJyk7XG5jb25zdCBkZWJ1Z0xvZ2dlciA9IHJlcXVpcmUoJy4uL3V0aWxzL2RlYnVnLWxvZ2dlci5qcycpO1xuY29uc3QgZW52ZWxvcGUgPSByZXF1aXJlKCcuLi91dGlscy9lbnZlbG9wZS5qcycpO1xuY29uc3QgcHJvbWlzZWJ1ZmZlciA9IHJlcXVpcmUoJy4uL3V0aWxzL3Byb21pc2VidWZmZXIuanMnKTtcbmNvbnN0IHJhdGVsaW1pdCA9IHJlcXVpcmUoJy4uL3V0aWxzL3JhdGVsaW1pdC5qcycpO1xuY29uc3Qgc3luY3Byb21pc2UgPSByZXF1aXJlKCcuLi91dGlscy9zeW5jcHJvbWlzZS5qcycpO1xuXG5jb25zdCBERUZBVUxUX1RSQU5TUE9SVF9CVUZGRVJfU0laRSA9IDY0O1xuXG4vKipcbiAqIENyZWF0ZXMgYW4gaW5zdGFuY2Ugb2YgYSBTZW50cnkgYFRyYW5zcG9ydGBcbiAqXG4gKiBAcGFyYW0gb3B0aW9uc1xuICogQHBhcmFtIG1ha2VSZXF1ZXN0XG4gKi9cbmZ1bmN0aW9uIGNyZWF0ZVRyYW5zcG9ydChcbiAgb3B0aW9ucyxcbiAgbWFrZVJlcXVlc3QsXG4gIGJ1ZmZlciA9IHByb21pc2VidWZmZXIubWFrZVByb21pc2VCdWZmZXIoXG4gICAgb3B0aW9ucy5idWZmZXJTaXplIHx8IERFRkFVTFRfVFJBTlNQT1JUX0JVRkZFUl9TSVpFLFxuICApLFxuKSB7XG4gIGxldCByYXRlTGltaXRzID0ge307XG4gIGNvbnN0IGZsdXNoID0gKHRpbWVvdXQpID0+IGJ1ZmZlci5kcmFpbih0aW1lb3V0KTtcblxuICBmdW5jdGlvbiBzZW5kKGVudmVsb3BlJDEpIHtcbiAgICBjb25zdCBmaWx0ZXJlZEVudmVsb3BlSXRlbXMgPSBbXTtcblxuICAgIC8vIERyb3AgcmF0ZSBsaW1pdGVkIGl0ZW1zIGZyb20gZW52ZWxvcGVcbiAgICBlbnZlbG9wZS5mb3JFYWNoRW52ZWxvcGVJdGVtKGVudmVsb3BlJDEsIChpdGVtLCB0eXBlKSA9PiB7XG4gICAgICBjb25zdCBkYXRhQ2F0ZWdvcnkgPSBlbnZlbG9wZS5lbnZlbG9wZUl0ZW1UeXBlVG9EYXRhQ2F0ZWdvcnkodHlwZSk7XG4gICAgICBpZiAocmF0ZWxpbWl0LmlzUmF0ZUxpbWl0ZWQocmF0ZUxpbWl0cywgZGF0YUNhdGVnb3J5KSkge1xuICAgICAgICBvcHRpb25zLnJlY29yZERyb3BwZWRFdmVudCgncmF0ZWxpbWl0X2JhY2tvZmYnLCBkYXRhQ2F0ZWdvcnkpO1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgZmlsdGVyZWRFbnZlbG9wZUl0ZW1zLnB1c2goaXRlbSk7XG4gICAgICB9XG4gICAgfSk7XG5cbiAgICAvLyBTa2lwIHNlbmRpbmcgaWYgZW52ZWxvcGUgaXMgZW1wdHkgYWZ0ZXIgZmlsdGVyaW5nIG91dCByYXRlIGxpbWl0ZWQgZXZlbnRzXG4gICAgaWYgKGZpbHRlcmVkRW52ZWxvcGVJdGVtcy5sZW5ndGggPT09IDApIHtcbiAgICAgIHJldHVybiBzeW5jcHJvbWlzZS5yZXNvbHZlZFN5bmNQcm9taXNlKHt9KTtcbiAgICB9XG5cbiAgICBjb25zdCBmaWx0ZXJlZEVudmVsb3BlID0gZW52ZWxvcGUuY3JlYXRlRW52ZWxvcGUoZW52ZWxvcGUkMVswXSwgZmlsdGVyZWRFbnZlbG9wZUl0ZW1zICk7XG5cbiAgICAvLyBDcmVhdGVzIGNsaWVudCByZXBvcnQgZm9yIGVhY2ggaXRlbSBpbiBhbiBlbnZlbG9wZVxuICAgIGNvbnN0IHJlY29yZEVudmVsb3BlTG9zcyA9IChyZWFzb24pID0+IHtcbiAgICAgIGVudmVsb3BlLmZvckVhY2hFbnZlbG9wZUl0ZW0oZmlsdGVyZWRFbnZlbG9wZSwgKGl0ZW0sIHR5cGUpID0+IHtcbiAgICAgICAgb3B0aW9ucy5yZWNvcmREcm9wcGVkRXZlbnQocmVhc29uLCBlbnZlbG9wZS5lbnZlbG9wZUl0ZW1UeXBlVG9EYXRhQ2F0ZWdvcnkodHlwZSkpO1xuICAgICAgfSk7XG4gICAgfTtcblxuICAgIGNvbnN0IHJlcXVlc3RUYXNrID0gKCkgPT5cbiAgICAgIG1ha2VSZXF1ZXN0KHsgYm9keTogZW52ZWxvcGUuc2VyaWFsaXplRW52ZWxvcGUoZmlsdGVyZWRFbnZlbG9wZSkgfSkudGhlbihcbiAgICAgICAgcmVzcG9uc2UgPT4ge1xuICAgICAgICAgIC8vIFdlIGRvbid0IHdhbnQgdG8gdGhyb3cgb24gTk9LIHJlc3BvbnNlcywgYnV0IHdlIHdhbnQgdG8gYXQgbGVhc3QgbG9nIHRoZW1cbiAgICAgICAgICBpZiAocmVzcG9uc2Uuc3RhdHVzQ29kZSAhPT0gdW5kZWZpbmVkICYmIChyZXNwb25zZS5zdGF0dXNDb2RlIDwgMjAwIHx8IHJlc3BvbnNlLnN0YXR1c0NvZGUgPj0gMzAwKSkge1xuICAgICAgICAgICAgZGVidWdCdWlsZC5ERUJVR19CVUlMRCAmJiBkZWJ1Z0xvZ2dlci5kZWJ1Zy53YXJuKGBTZW50cnkgcmVzcG9uZGVkIHdpdGggc3RhdHVzIGNvZGUgJHtyZXNwb25zZS5zdGF0dXNDb2RlfSB0byBzZW50IGV2ZW50LmApO1xuICAgICAgICAgIH1cblxuICAgICAgICAgIHJhdGVMaW1pdHMgPSByYXRlbGltaXQudXBkYXRlUmF0ZUxpbWl0cyhyYXRlTGltaXRzLCByZXNwb25zZSk7XG4gICAgICAgICAgcmV0dXJuIHJlc3BvbnNlO1xuICAgICAgICB9LFxuICAgICAgICBlcnJvciA9PiB7XG4gICAgICAgICAgcmVjb3JkRW52ZWxvcGVMb3NzKCduZXR3b3JrX2Vycm9yJyk7XG4gICAgICAgICAgZGVidWdCdWlsZC5ERUJVR19CVUlMRCAmJiBkZWJ1Z0xvZ2dlci5kZWJ1Zy5lcnJvcignRW5jb3VudGVyZWQgZXJyb3IgcnVubmluZyB0cmFuc3BvcnQgcmVxdWVzdDonLCBlcnJvcik7XG4gICAgICAgICAgdGhyb3cgZXJyb3I7XG4gICAgICAgIH0sXG4gICAgICApO1xuXG4gICAgcmV0dXJuIGJ1ZmZlci5hZGQocmVxdWVzdFRhc2spLnRoZW4oXG4gICAgICByZXN1bHQgPT4gcmVzdWx0LFxuICAgICAgZXJyb3IgPT4ge1xuICAgICAgICBpZiAoZXJyb3IgPT09IHByb21pc2VidWZmZXIuU0VOVFJZX0JVRkZFUl9GVUxMX0VSUk9SKSB7XG4gICAgICAgICAgZGVidWdCdWlsZC5ERUJVR19CVUlMRCAmJiBkZWJ1Z0xvZ2dlci5kZWJ1Zy5lcnJvcignU2tpcHBlZCBzZW5kaW5nIGV2ZW50IGJlY2F1c2UgYnVmZmVyIGlzIGZ1bGwuJyk7XG4gICAgICAgICAgcmVjb3JkRW52ZWxvcGVMb3NzKCdxdWV1ZV9vdmVyZmxvdycpO1xuICAgICAgICAgIHJldHVybiBzeW5jcHJvbWlzZS5yZXNvbHZlZFN5bmNQcm9taXNlKHt9KTtcbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICB0aHJvdyBlcnJvcjtcbiAgICAgICAgfVxuICAgICAgfSxcbiAgICApO1xuICB9XG5cbiAgcmV0dXJuIHtcbiAgICBzZW5kLFxuICAgIGZsdXNoLFxuICB9O1xufVxuXG5leHBvcnRzLkRFRkFVTFRfVFJBTlNQT1JUX0JVRkZFUl9TSVpFID0gREVGQVVMVF9UUkFOU1BPUlRfQlVGRkVSX1NJWkU7XG5leHBvcnRzLmNyZWF0ZVRyYW5zcG9ydCA9IGNyZWF0ZVRyYW5zcG9ydDtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWJhc2UuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/transports/base.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/transports/multiplexed.js":
/*!**************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/transports/multiplexed.js ***!
  \**************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst api = __webpack_require__(/*! ../api.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/api.js\");\nconst dsn = __webpack_require__(/*! ../utils/dsn.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/dsn.js\");\nconst envelope = __webpack_require__(/*! ../utils/envelope.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/envelope.js\");\n\n/**\n * Gets an event from an envelope.\n *\n * This is only exported for use in the tests\n */\nfunction eventFromEnvelope(env, types) {\n  let event;\n\n  envelope.forEachEnvelopeItem(env, (item, type) => {\n    if (types.includes(type)) {\n      event = Array.isArray(item) ? (item )[1] : undefined;\n    }\n    // bail out if we found an event\n    return !!event;\n  });\n\n  return event;\n}\n\n/**\n * Creates a transport that overrides the release on all events.\n */\nfunction makeOverrideReleaseTransport(\n  createTransport,\n  release,\n) {\n  return options => {\n    const transport = createTransport(options);\n\n    return {\n      ...transport,\n      send: async (envelope) => {\n        const event = eventFromEnvelope(envelope, ['event', 'transaction', 'profile', 'replay_event']);\n\n        if (event) {\n          event.release = release;\n        }\n        return transport.send(envelope);\n      },\n    };\n  };\n}\n\n/** Overrides the DSN in the envelope header  */\nfunction overrideDsn(envelope$1, dsn) {\n  return envelope.createEnvelope(\n    dsn\n      ? {\n          ...envelope$1[0],\n          dsn,\n        }\n      : envelope$1[0],\n    envelope$1[1],\n  );\n}\n\n/**\n * Creates a transport that can send events to different DSNs depending on the envelope contents.\n */\nfunction makeMultiplexedTransport(\n  createTransport,\n  matcher,\n) {\n  return options => {\n    const fallbackTransport = createTransport(options);\n    const otherTransports = new Map();\n\n    function getTransport(dsn$1, release) {\n      // We create a transport for every unique dsn/release combination as there may be code from multiple releases in\n      // use at the same time\n      const key = release ? `${dsn$1}:${release}` : dsn$1;\n\n      let transport = otherTransports.get(key);\n\n      if (!transport) {\n        const validatedDsn = dsn.dsnFromString(dsn$1);\n        if (!validatedDsn) {\n          return undefined;\n        }\n        const url = api.getEnvelopeEndpointWithUrlEncodedAuth(validatedDsn, options.tunnel);\n\n        transport = release\n          ? makeOverrideReleaseTransport(createTransport, release)({ ...options, url })\n          : createTransport({ ...options, url });\n\n        otherTransports.set(key, transport);\n      }\n\n      return [dsn$1, transport];\n    }\n\n    async function send(envelope) {\n      function getEvent(types) {\n        const eventTypes = types?.length ? types : ['event'];\n        return eventFromEnvelope(envelope, eventTypes);\n      }\n\n      const transports = matcher({ envelope, getEvent })\n        .map(result => {\n          if (typeof result === 'string') {\n            return getTransport(result, undefined);\n          } else {\n            return getTransport(result.dsn, result.release);\n          }\n        })\n        .filter((t) => !!t);\n\n      // If we have no transports to send to, use the fallback transport\n      // Don't override the DSN in the header for the fallback transport. '' is falsy\n      const transportsWithFallback = transports.length ? transports : [['', fallbackTransport]];\n\n      const results = (await Promise.all(\n        transportsWithFallback.map(([dsn, transport]) => transport.send(overrideDsn(envelope, dsn))),\n      )) ;\n\n      return results[0];\n    }\n\n    async function flush(timeout) {\n      const allTransports = [...otherTransports.values(), fallbackTransport];\n      const results = await Promise.all(allTransports.map(transport => transport.flush(timeout)));\n      return results.every(r => r);\n    }\n\n    return {\n      send,\n      flush,\n    };\n  };\n}\n\nexports.eventFromEnvelope = eventFromEnvelope;\nexports.makeMultiplexedTransport = makeMultiplexedTransport;\n//# sourceMappingURL=multiplexed.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy90cmFuc3BvcnRzL211bHRpcGxleGVkLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLFlBQVksbUJBQU8sQ0FBQyw0R0FBVztBQUMvQixZQUFZLG1CQUFPLENBQUMsd0hBQWlCO0FBQ3JDLGlCQUFpQixtQkFBTyxDQUFDLGtJQUFzQjs7QUFFL0M7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsR0FBRzs7QUFFSDtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLE9BQU87QUFDUDtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBLCtCQUErQixNQUFNLEdBQUcsUUFBUTs7QUFFaEQ7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0EscUVBQXFFLGlCQUFpQjtBQUN0Riw4QkFBOEIsaUJBQWlCOztBQUUvQztBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSxtQ0FBbUMsb0JBQW9CO0FBQ3ZEO0FBQ0E7QUFDQTtBQUNBLFlBQVk7QUFDWjtBQUNBO0FBQ0EsU0FBUztBQUNUOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSx5QkFBeUI7QUFDekIsZ0NBQWdDO0FBQ2hDIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdHJhbnNwb3J0cy9tdWx0aXBsZXhlZC5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgYXBpID0gcmVxdWlyZSgnLi4vYXBpLmpzJyk7XG5jb25zdCBkc24gPSByZXF1aXJlKCcuLi91dGlscy9kc24uanMnKTtcbmNvbnN0IGVudmVsb3BlID0gcmVxdWlyZSgnLi4vdXRpbHMvZW52ZWxvcGUuanMnKTtcblxuLyoqXG4gKiBHZXRzIGFuIGV2ZW50IGZyb20gYW4gZW52ZWxvcGUuXG4gKlxuICogVGhpcyBpcyBvbmx5IGV4cG9ydGVkIGZvciB1c2UgaW4gdGhlIHRlc3RzXG4gKi9cbmZ1bmN0aW9uIGV2ZW50RnJvbUVudmVsb3BlKGVudiwgdHlwZXMpIHtcbiAgbGV0IGV2ZW50O1xuXG4gIGVudmVsb3BlLmZvckVhY2hFbnZlbG9wZUl0ZW0oZW52LCAoaXRlbSwgdHlwZSkgPT4ge1xuICAgIGlmICh0eXBlcy5pbmNsdWRlcyh0eXBlKSkge1xuICAgICAgZXZlbnQgPSBBcnJheS5pc0FycmF5KGl0ZW0pID8gKGl0ZW0gKVsxXSA6IHVuZGVmaW5lZDtcbiAgICB9XG4gICAgLy8gYmFpbCBvdXQgaWYgd2UgZm91bmQgYW4gZXZlbnRcbiAgICByZXR1cm4gISFldmVudDtcbiAgfSk7XG5cbiAgcmV0dXJuIGV2ZW50O1xufVxuXG4vKipcbiAqIENyZWF0ZXMgYSB0cmFuc3BvcnQgdGhhdCBvdmVycmlkZXMgdGhlIHJlbGVhc2Ugb24gYWxsIGV2ZW50cy5cbiAqL1xuZnVuY3Rpb24gbWFrZU92ZXJyaWRlUmVsZWFzZVRyYW5zcG9ydChcbiAgY3JlYXRlVHJhbnNwb3J0LFxuICByZWxlYXNlLFxuKSB7XG4gIHJldHVybiBvcHRpb25zID0+IHtcbiAgICBjb25zdCB0cmFuc3BvcnQgPSBjcmVhdGVUcmFuc3BvcnQob3B0aW9ucyk7XG5cbiAgICByZXR1cm4ge1xuICAgICAgLi4udHJhbnNwb3J0LFxuICAgICAgc2VuZDogYXN5bmMgKGVudmVsb3BlKSA9PiB7XG4gICAgICAgIGNvbnN0IGV2ZW50ID0gZXZlbnRGcm9tRW52ZWxvcGUoZW52ZWxvcGUsIFsnZXZlbnQnLCAndHJhbnNhY3Rpb24nLCAncHJvZmlsZScsICdyZXBsYXlfZXZlbnQnXSk7XG5cbiAgICAgICAgaWYgKGV2ZW50KSB7XG4gICAgICAgICAgZXZlbnQucmVsZWFzZSA9IHJlbGVhc2U7XG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuIHRyYW5zcG9ydC5zZW5kKGVudmVsb3BlKTtcbiAgICAgIH0sXG4gICAgfTtcbiAgfTtcbn1cblxuLyoqIE92ZXJyaWRlcyB0aGUgRFNOIGluIHRoZSBlbnZlbG9wZSBoZWFkZXIgICovXG5mdW5jdGlvbiBvdmVycmlkZURzbihlbnZlbG9wZSQxLCBkc24pIHtcbiAgcmV0dXJuIGVudmVsb3BlLmNyZWF0ZUVudmVsb3BlKFxuICAgIGRzblxuICAgICAgPyB7XG4gICAgICAgICAgLi4uZW52ZWxvcGUkMVswXSxcbiAgICAgICAgICBkc24sXG4gICAgICAgIH1cbiAgICAgIDogZW52ZWxvcGUkMVswXSxcbiAgICBlbnZlbG9wZSQxWzFdLFxuICApO1xufVxuXG4vKipcbiAqIENyZWF0ZXMgYSB0cmFuc3BvcnQgdGhhdCBjYW4gc2VuZCBldmVudHMgdG8gZGlmZmVyZW50IERTTnMgZGVwZW5kaW5nIG9uIHRoZSBlbnZlbG9wZSBjb250ZW50cy5cbiAqL1xuZnVuY3Rpb24gbWFrZU11bHRpcGxleGVkVHJhbnNwb3J0KFxuICBjcmVhdGVUcmFuc3BvcnQsXG4gIG1hdGNoZXIsXG4pIHtcbiAgcmV0dXJuIG9wdGlvbnMgPT4ge1xuICAgIGNvbnN0IGZhbGxiYWNrVHJhbnNwb3J0ID0gY3JlYXRlVHJhbnNwb3J0KG9wdGlvbnMpO1xuICAgIGNvbnN0IG90aGVyVHJhbnNwb3J0cyA9IG5ldyBNYXAoKTtcblxuICAgIGZ1bmN0aW9uIGdldFRyYW5zcG9ydChkc24kMSwgcmVsZWFzZSkge1xuICAgICAgLy8gV2UgY3JlYXRlIGEgdHJhbnNwb3J0IGZvciBldmVyeSB1bmlxdWUgZHNuL3JlbGVhc2UgY29tYmluYXRpb24gYXMgdGhlcmUgbWF5IGJlIGNvZGUgZnJvbSBtdWx0aXBsZSByZWxlYXNlcyBpblxuICAgICAgLy8gdXNlIGF0IHRoZSBzYW1lIHRpbWVcbiAgICAgIGNvbnN0IGtleSA9IHJlbGVhc2UgPyBgJHtkc24kMX06JHtyZWxlYXNlfWAgOiBkc24kMTtcblxuICAgICAgbGV0IHRyYW5zcG9ydCA9IG90aGVyVHJhbnNwb3J0cy5nZXQoa2V5KTtcblxuICAgICAgaWYgKCF0cmFuc3BvcnQpIHtcbiAgICAgICAgY29uc3QgdmFsaWRhdGVkRHNuID0gZHNuLmRzbkZyb21TdHJpbmcoZHNuJDEpO1xuICAgICAgICBpZiAoIXZhbGlkYXRlZERzbikge1xuICAgICAgICAgIHJldHVybiB1bmRlZmluZWQ7XG4gICAgICAgIH1cbiAgICAgICAgY29uc3QgdXJsID0gYXBpLmdldEVudmVsb3BlRW5kcG9pbnRXaXRoVXJsRW5jb2RlZEF1dGgodmFsaWRhdGVkRHNuLCBvcHRpb25zLnR1bm5lbCk7XG5cbiAgICAgICAgdHJhbnNwb3J0ID0gcmVsZWFzZVxuICAgICAgICAgID8gbWFrZU92ZXJyaWRlUmVsZWFzZVRyYW5zcG9ydChjcmVhdGVUcmFuc3BvcnQsIHJlbGVhc2UpKHsgLi4ub3B0aW9ucywgdXJsIH0pXG4gICAgICAgICAgOiBjcmVhdGVUcmFuc3BvcnQoeyAuLi5vcHRpb25zLCB1cmwgfSk7XG5cbiAgICAgICAgb3RoZXJUcmFuc3BvcnRzLnNldChrZXksIHRyYW5zcG9ydCk7XG4gICAgICB9XG5cbiAgICAgIHJldHVybiBbZHNuJDEsIHRyYW5zcG9ydF07XG4gICAgfVxuXG4gICAgYXN5bmMgZnVuY3Rpb24gc2VuZChlbnZlbG9wZSkge1xuICAgICAgZnVuY3Rpb24gZ2V0RXZlbnQodHlwZXMpIHtcbiAgICAgICAgY29uc3QgZXZlbnRUeXBlcyA9IHR5cGVzPy5sZW5ndGggPyB0eXBlcyA6IFsnZXZlbnQnXTtcbiAgICAgICAgcmV0dXJuIGV2ZW50RnJvbUVudmVsb3BlKGVudmVsb3BlLCBldmVudFR5cGVzKTtcbiAgICAgIH1cblxuICAgICAgY29uc3QgdHJhbnNwb3J0cyA9IG1hdGNoZXIoeyBlbnZlbG9wZSwgZ2V0RXZlbnQgfSlcbiAgICAgICAgLm1hcChyZXN1bHQgPT4ge1xuICAgICAgICAgIGlmICh0eXBlb2YgcmVzdWx0ID09PSAnc3RyaW5nJykge1xuICAgICAgICAgICAgcmV0dXJuIGdldFRyYW5zcG9ydChyZXN1bHQsIHVuZGVmaW5lZCk7XG4gICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgIHJldHVybiBnZXRUcmFuc3BvcnQocmVzdWx0LmRzbiwgcmVzdWx0LnJlbGVhc2UpO1xuICAgICAgICAgIH1cbiAgICAgICAgfSlcbiAgICAgICAgLmZpbHRlcigodCkgPT4gISF0KTtcblxuICAgICAgLy8gSWYgd2UgaGF2ZSBubyB0cmFuc3BvcnRzIHRvIHNlbmQgdG8sIHVzZSB0aGUgZmFsbGJhY2sgdHJhbnNwb3J0XG4gICAgICAvLyBEb24ndCBvdmVycmlkZSB0aGUgRFNOIGluIHRoZSBoZWFkZXIgZm9yIHRoZSBmYWxsYmFjayB0cmFuc3BvcnQuICcnIGlzIGZhbHN5XG4gICAgICBjb25zdCB0cmFuc3BvcnRzV2l0aEZhbGxiYWNrID0gdHJhbnNwb3J0cy5sZW5ndGggPyB0cmFuc3BvcnRzIDogW1snJywgZmFsbGJhY2tUcmFuc3BvcnRdXTtcblxuICAgICAgY29uc3QgcmVzdWx0cyA9IChhd2FpdCBQcm9taXNlLmFsbChcbiAgICAgICAgdHJhbnNwb3J0c1dpdGhGYWxsYmFjay5tYXAoKFtkc24sIHRyYW5zcG9ydF0pID0+IHRyYW5zcG9ydC5zZW5kKG92ZXJyaWRlRHNuKGVudmVsb3BlLCBkc24pKSksXG4gICAgICApKSA7XG5cbiAgICAgIHJldHVybiByZXN1bHRzWzBdO1xuICAgIH1cblxuICAgIGFzeW5jIGZ1bmN0aW9uIGZsdXNoKHRpbWVvdXQpIHtcbiAgICAgIGNvbnN0IGFsbFRyYW5zcG9ydHMgPSBbLi4ub3RoZXJUcmFuc3BvcnRzLnZhbHVlcygpLCBmYWxsYmFja1RyYW5zcG9ydF07XG4gICAgICBjb25zdCByZXN1bHRzID0gYXdhaXQgUHJvbWlzZS5hbGwoYWxsVHJhbnNwb3J0cy5tYXAodHJhbnNwb3J0ID0+IHRyYW5zcG9ydC5mbHVzaCh0aW1lb3V0KSkpO1xuICAgICAgcmV0dXJuIHJlc3VsdHMuZXZlcnkociA9PiByKTtcbiAgICB9XG5cbiAgICByZXR1cm4ge1xuICAgICAgc2VuZCxcbiAgICAgIGZsdXNoLFxuICAgIH07XG4gIH07XG59XG5cbmV4cG9ydHMuZXZlbnRGcm9tRW52ZWxvcGUgPSBldmVudEZyb21FbnZlbG9wZTtcbmV4cG9ydHMubWFrZU11bHRpcGxleGVkVHJhbnNwb3J0ID0gbWFrZU11bHRpcGxleGVkVHJhbnNwb3J0O1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9bXVsdGlwbGV4ZWQuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/transports/multiplexed.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/transports/offline.js":
/*!**********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/transports/offline.js ***!
  \**********************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst debugBuild = __webpack_require__(/*! ../debug-build.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst debugLogger = __webpack_require__(/*! ../utils/debug-logger.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst envelope = __webpack_require__(/*! ../utils/envelope.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/envelope.js\");\nconst ratelimit = __webpack_require__(/*! ../utils/ratelimit.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/ratelimit.js\");\n\nconst MIN_DELAY = 100; // 100 ms\nconst START_DELAY = 5000; // 5 seconds\nconst MAX_DELAY = 3.6e6; // 1 hour\n\n/**\n * Wraps a transport and stores and retries events when they fail to send.\n *\n * @param createTransport The transport to wrap.\n */\nfunction makeOfflineTransport(\n  createTransport,\n) {\n  function log(...args) {\n    debugBuild.DEBUG_BUILD && debugLogger.debug.log('[Offline]:', ...args);\n  }\n\n  return options => {\n    const transport = createTransport(options);\n\n    if (!options.createStore) {\n      throw new Error('No `createStore` function was provided');\n    }\n\n    const store = options.createStore(options);\n\n    let retryDelay = START_DELAY;\n    let flushTimer;\n\n    function shouldQueue(env, error, retryDelay) {\n      // We want to drop client reports because they can be generated when we retry sending events while offline.\n      if (envelope.envelopeContainsItemType(env, ['client_report'])) {\n        return false;\n      }\n\n      if (options.shouldStore) {\n        return options.shouldStore(env, error, retryDelay);\n      }\n\n      return true;\n    }\n\n    function flushIn(delay) {\n      if (flushTimer) {\n        clearTimeout(flushTimer );\n      }\n\n      flushTimer = setTimeout(async () => {\n        flushTimer = undefined;\n\n        const found = await store.shift();\n        if (found) {\n          log('Attempting to send previously queued event');\n\n          // We should to update the sent_at timestamp to the current time.\n          found[0].sent_at = new Date().toISOString();\n\n          void send(found, true).catch(e => {\n            log('Failed to retry sending', e);\n          });\n        }\n      }, delay) ;\n\n      // We need to unref the timer in node.js, otherwise the node process never exit.\n      if (typeof flushTimer !== 'number' && flushTimer.unref) {\n        flushTimer.unref();\n      }\n    }\n\n    function flushWithBackOff() {\n      if (flushTimer) {\n        return;\n      }\n\n      flushIn(retryDelay);\n\n      retryDelay = Math.min(retryDelay * 2, MAX_DELAY);\n    }\n\n    async function send(envelope$1, isRetry = false) {\n      // We queue all replay envelopes to avoid multiple replay envelopes being sent at the same time. If one fails, we\n      // need to retry them in order.\n      if (!isRetry && envelope.envelopeContainsItemType(envelope$1, ['replay_event', 'replay_recording'])) {\n        await store.push(envelope$1);\n        flushIn(MIN_DELAY);\n        return {};\n      }\n\n      try {\n        if (options.shouldSend && (await options.shouldSend(envelope$1)) === false) {\n          throw new Error('Envelope not sent because `shouldSend` callback returned false');\n        }\n\n        const result = await transport.send(envelope$1);\n\n        let delay = MIN_DELAY;\n\n        if (result) {\n          // If there's a retry-after header, use that as the next delay.\n          if (result.headers?.['retry-after']) {\n            delay = ratelimit.parseRetryAfterHeader(result.headers['retry-after']);\n          } else if (result.headers?.['x-sentry-rate-limits']) {\n            delay = 60000; // 60 seconds\n          } // If we have a server error, return now so we don't flush the queue.\n          else if ((result.statusCode || 0) >= 400) {\n            return result;\n          }\n        }\n\n        flushIn(delay);\n        retryDelay = START_DELAY;\n        return result;\n      } catch (e) {\n        if (await shouldQueue(envelope$1, e , retryDelay)) {\n          // If this envelope was a retry, we want to add it to the front of the queue so it's retried again first.\n          if (isRetry) {\n            await store.unshift(envelope$1);\n          } else {\n            await store.push(envelope$1);\n          }\n          flushWithBackOff();\n          log('Error sending. Event queued.', e );\n          return {};\n        } else {\n          throw e;\n        }\n      }\n    }\n\n    if (options.flushAtStartup) {\n      flushWithBackOff();\n    }\n\n    return {\n      send,\n      flush: timeout => {\n        // If there's no timeout, we should attempt to flush the offline queue.\n        if (timeout === undefined) {\n          retryDelay = START_DELAY;\n          flushIn(MIN_DELAY);\n        }\n\n        return transport.flush(timeout);\n      },\n    };\n  };\n}\n\nexports.MIN_DELAY = MIN_DELAY;\nexports.START_DELAY = START_DELAY;\nexports.makeOfflineTransport = makeOfflineTransport;\n//# sourceMappingURL=offline.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy90cmFuc3BvcnRzL29mZmxpbmUuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsbUJBQW1CLG1CQUFPLENBQUMsNEhBQW1CO0FBQzlDLG9CQUFvQixtQkFBTyxDQUFDLDBJQUEwQjtBQUN0RCxpQkFBaUIsbUJBQU8sQ0FBQyxrSUFBc0I7QUFDL0Msa0JBQWtCLG1CQUFPLENBQUMsb0lBQXVCOztBQUVqRCx1QkFBdUI7QUFDdkIsMEJBQTBCO0FBQzFCLHlCQUF5Qjs7QUFFekI7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsV0FBVztBQUNYO0FBQ0EsT0FBTzs7QUFFUDtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFlBQVk7QUFDWiwyQkFBMkI7QUFDM0IsWUFBWTtBQUNaO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBLFFBQVE7QUFDUjtBQUNBO0FBQ0E7QUFDQTtBQUNBLFlBQVk7QUFDWjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsVUFBVTtBQUNWO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0EsT0FBTztBQUNQO0FBQ0E7QUFDQTs7QUFFQSxpQkFBaUI7QUFDakIsbUJBQW1CO0FBQ25CLDRCQUE0QjtBQUM1QiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3RyYW5zcG9ydHMvb2ZmbGluZS5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgZGVidWdCdWlsZCA9IHJlcXVpcmUoJy4uL2RlYnVnLWJ1aWxkLmpzJyk7XG5jb25zdCBkZWJ1Z0xvZ2dlciA9IHJlcXVpcmUoJy4uL3V0aWxzL2RlYnVnLWxvZ2dlci5qcycpO1xuY29uc3QgZW52ZWxvcGUgPSByZXF1aXJlKCcuLi91dGlscy9lbnZlbG9wZS5qcycpO1xuY29uc3QgcmF0ZWxpbWl0ID0gcmVxdWlyZSgnLi4vdXRpbHMvcmF0ZWxpbWl0LmpzJyk7XG5cbmNvbnN0IE1JTl9ERUxBWSA9IDEwMDsgLy8gMTAwIG1zXG5jb25zdCBTVEFSVF9ERUxBWSA9IDUwMDA7IC8vIDUgc2Vjb25kc1xuY29uc3QgTUFYX0RFTEFZID0gMy42ZTY7IC8vIDEgaG91clxuXG4vKipcbiAqIFdyYXBzIGEgdHJhbnNwb3J0IGFuZCBzdG9yZXMgYW5kIHJldHJpZXMgZXZlbnRzIHdoZW4gdGhleSBmYWlsIHRvIHNlbmQuXG4gKlxuICogQHBhcmFtIGNyZWF0ZVRyYW5zcG9ydCBUaGUgdHJhbnNwb3J0IHRvIHdyYXAuXG4gKi9cbmZ1bmN0aW9uIG1ha2VPZmZsaW5lVHJhbnNwb3J0KFxuICBjcmVhdGVUcmFuc3BvcnQsXG4pIHtcbiAgZnVuY3Rpb24gbG9nKC4uLmFyZ3MpIHtcbiAgICBkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEICYmIGRlYnVnTG9nZ2VyLmRlYnVnLmxvZygnW09mZmxpbmVdOicsIC4uLmFyZ3MpO1xuICB9XG5cbiAgcmV0dXJuIG9wdGlvbnMgPT4ge1xuICAgIGNvbnN0IHRyYW5zcG9ydCA9IGNyZWF0ZVRyYW5zcG9ydChvcHRpb25zKTtcblxuICAgIGlmICghb3B0aW9ucy5jcmVhdGVTdG9yZSkge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKCdObyBgY3JlYXRlU3RvcmVgIGZ1bmN0aW9uIHdhcyBwcm92aWRlZCcpO1xuICAgIH1cblxuICAgIGNvbnN0IHN0b3JlID0gb3B0aW9ucy5jcmVhdGVTdG9yZShvcHRpb25zKTtcblxuICAgIGxldCByZXRyeURlbGF5ID0gU1RBUlRfREVMQVk7XG4gICAgbGV0IGZsdXNoVGltZXI7XG5cbiAgICBmdW5jdGlvbiBzaG91bGRRdWV1ZShlbnYsIGVycm9yLCByZXRyeURlbGF5KSB7XG4gICAgICAvLyBXZSB3YW50IHRvIGRyb3AgY2xpZW50IHJlcG9ydHMgYmVjYXVzZSB0aGV5IGNhbiBiZSBnZW5lcmF0ZWQgd2hlbiB3ZSByZXRyeSBzZW5kaW5nIGV2ZW50cyB3aGlsZSBvZmZsaW5lLlxuICAgICAgaWYgKGVudmVsb3BlLmVudmVsb3BlQ29udGFpbnNJdGVtVHlwZShlbnYsIFsnY2xpZW50X3JlcG9ydCddKSkge1xuICAgICAgICByZXR1cm4gZmFsc2U7XG4gICAgICB9XG5cbiAgICAgIGlmIChvcHRpb25zLnNob3VsZFN0b3JlKSB7XG4gICAgICAgIHJldHVybiBvcHRpb25zLnNob3VsZFN0b3JlKGVudiwgZXJyb3IsIHJldHJ5RGVsYXkpO1xuICAgICAgfVxuXG4gICAgICByZXR1cm4gdHJ1ZTtcbiAgICB9XG5cbiAgICBmdW5jdGlvbiBmbHVzaEluKGRlbGF5KSB7XG4gICAgICBpZiAoZmx1c2hUaW1lcikge1xuICAgICAgICBjbGVhclRpbWVvdXQoZmx1c2hUaW1lciApO1xuICAgICAgfVxuXG4gICAgICBmbHVzaFRpbWVyID0gc2V0VGltZW91dChhc3luYyAoKSA9PiB7XG4gICAgICAgIGZsdXNoVGltZXIgPSB1bmRlZmluZWQ7XG5cbiAgICAgICAgY29uc3QgZm91bmQgPSBhd2FpdCBzdG9yZS5zaGlmdCgpO1xuICAgICAgICBpZiAoZm91bmQpIHtcbiAgICAgICAgICBsb2coJ0F0dGVtcHRpbmcgdG8gc2VuZCBwcmV2aW91c2x5IHF1ZXVlZCBldmVudCcpO1xuXG4gICAgICAgICAgLy8gV2Ugc2hvdWxkIHRvIHVwZGF0ZSB0aGUgc2VudF9hdCB0aW1lc3RhbXAgdG8gdGhlIGN1cnJlbnQgdGltZS5cbiAgICAgICAgICBmb3VuZFswXS5zZW50X2F0ID0gbmV3IERhdGUoKS50b0lTT1N0cmluZygpO1xuXG4gICAgICAgICAgdm9pZCBzZW5kKGZvdW5kLCB0cnVlKS5jYXRjaChlID0+IHtcbiAgICAgICAgICAgIGxvZygnRmFpbGVkIHRvIHJldHJ5IHNlbmRpbmcnLCBlKTtcbiAgICAgICAgICB9KTtcbiAgICAgICAgfVxuICAgICAgfSwgZGVsYXkpIDtcblxuICAgICAgLy8gV2UgbmVlZCB0byB1bnJlZiB0aGUgdGltZXIgaW4gbm9kZS5qcywgb3RoZXJ3aXNlIHRoZSBub2RlIHByb2Nlc3MgbmV2ZXIgZXhpdC5cbiAgICAgIGlmICh0eXBlb2YgZmx1c2hUaW1lciAhPT0gJ251bWJlcicgJiYgZmx1c2hUaW1lci51bnJlZikge1xuICAgICAgICBmbHVzaFRpbWVyLnVucmVmKCk7XG4gICAgICB9XG4gICAgfVxuXG4gICAgZnVuY3Rpb24gZmx1c2hXaXRoQmFja09mZigpIHtcbiAgICAgIGlmIChmbHVzaFRpbWVyKSB7XG4gICAgICAgIHJldHVybjtcbiAgICAgIH1cblxuICAgICAgZmx1c2hJbihyZXRyeURlbGF5KTtcblxuICAgICAgcmV0cnlEZWxheSA9IE1hdGgubWluKHJldHJ5RGVsYXkgKiAyLCBNQVhfREVMQVkpO1xuICAgIH1cblxuICAgIGFzeW5jIGZ1bmN0aW9uIHNlbmQoZW52ZWxvcGUkMSwgaXNSZXRyeSA9IGZhbHNlKSB7XG4gICAgICAvLyBXZSBxdWV1ZSBhbGwgcmVwbGF5IGVudmVsb3BlcyB0byBhdm9pZCBtdWx0aXBsZSByZXBsYXkgZW52ZWxvcGVzIGJlaW5nIHNlbnQgYXQgdGhlIHNhbWUgdGltZS4gSWYgb25lIGZhaWxzLCB3ZVxuICAgICAgLy8gbmVlZCB0byByZXRyeSB0aGVtIGluIG9yZGVyLlxuICAgICAgaWYgKCFpc1JldHJ5ICYmIGVudmVsb3BlLmVudmVsb3BlQ29udGFpbnNJdGVtVHlwZShlbnZlbG9wZSQxLCBbJ3JlcGxheV9ldmVudCcsICdyZXBsYXlfcmVjb3JkaW5nJ10pKSB7XG4gICAgICAgIGF3YWl0IHN0b3JlLnB1c2goZW52ZWxvcGUkMSk7XG4gICAgICAgIGZsdXNoSW4oTUlOX0RFTEFZKTtcbiAgICAgICAgcmV0dXJuIHt9O1xuICAgICAgfVxuXG4gICAgICB0cnkge1xuICAgICAgICBpZiAob3B0aW9ucy5zaG91bGRTZW5kICYmIChhd2FpdCBvcHRpb25zLnNob3VsZFNlbmQoZW52ZWxvcGUkMSkpID09PSBmYWxzZSkge1xuICAgICAgICAgIHRocm93IG5ldyBFcnJvcignRW52ZWxvcGUgbm90IHNlbnQgYmVjYXVzZSBgc2hvdWxkU2VuZGAgY2FsbGJhY2sgcmV0dXJuZWQgZmFsc2UnKTtcbiAgICAgICAgfVxuXG4gICAgICAgIGNvbnN0IHJlc3VsdCA9IGF3YWl0IHRyYW5zcG9ydC5zZW5kKGVudmVsb3BlJDEpO1xuXG4gICAgICAgIGxldCBkZWxheSA9IE1JTl9ERUxBWTtcblxuICAgICAgICBpZiAocmVzdWx0KSB7XG4gICAgICAgICAgLy8gSWYgdGhlcmUncyBhIHJldHJ5LWFmdGVyIGhlYWRlciwgdXNlIHRoYXQgYXMgdGhlIG5leHQgZGVsYXkuXG4gICAgICAgICAgaWYgKHJlc3VsdC5oZWFkZXJzPy5bJ3JldHJ5LWFmdGVyJ10pIHtcbiAgICAgICAgICAgIGRlbGF5ID0gcmF0ZWxpbWl0LnBhcnNlUmV0cnlBZnRlckhlYWRlcihyZXN1bHQuaGVhZGVyc1sncmV0cnktYWZ0ZXInXSk7XG4gICAgICAgICAgfSBlbHNlIGlmIChyZXN1bHQuaGVhZGVycz8uWyd4LXNlbnRyeS1yYXRlLWxpbWl0cyddKSB7XG4gICAgICAgICAgICBkZWxheSA9IDYwMDAwOyAvLyA2MCBzZWNvbmRzXG4gICAgICAgICAgfSAvLyBJZiB3ZSBoYXZlIGEgc2VydmVyIGVycm9yLCByZXR1cm4gbm93IHNvIHdlIGRvbid0IGZsdXNoIHRoZSBxdWV1ZS5cbiAgICAgICAgICBlbHNlIGlmICgocmVzdWx0LnN0YXR1c0NvZGUgfHwgMCkgPj0gNDAwKSB7XG4gICAgICAgICAgICByZXR1cm4gcmVzdWx0O1xuICAgICAgICAgIH1cbiAgICAgICAgfVxuXG4gICAgICAgIGZsdXNoSW4oZGVsYXkpO1xuICAgICAgICByZXRyeURlbGF5ID0gU1RBUlRfREVMQVk7XG4gICAgICAgIHJldHVybiByZXN1bHQ7XG4gICAgICB9IGNhdGNoIChlKSB7XG4gICAgICAgIGlmIChhd2FpdCBzaG91bGRRdWV1ZShlbnZlbG9wZSQxLCBlICwgcmV0cnlEZWxheSkpIHtcbiAgICAgICAgICAvLyBJZiB0aGlzIGVudmVsb3BlIHdhcyBhIHJldHJ5LCB3ZSB3YW50IHRvIGFkZCBpdCB0byB0aGUgZnJvbnQgb2YgdGhlIHF1ZXVlIHNvIGl0J3MgcmV0cmllZCBhZ2FpbiBmaXJzdC5cbiAgICAgICAgICBpZiAoaXNSZXRyeSkge1xuICAgICAgICAgICAgYXdhaXQgc3RvcmUudW5zaGlmdChlbnZlbG9wZSQxKTtcbiAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgYXdhaXQgc3RvcmUucHVzaChlbnZlbG9wZSQxKTtcbiAgICAgICAgICB9XG4gICAgICAgICAgZmx1c2hXaXRoQmFja09mZigpO1xuICAgICAgICAgIGxvZygnRXJyb3Igc2VuZGluZy4gRXZlbnQgcXVldWVkLicsIGUgKTtcbiAgICAgICAgICByZXR1cm4ge307XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgdGhyb3cgZTtcbiAgICAgICAgfVxuICAgICAgfVxuICAgIH1cblxuICAgIGlmIChvcHRpb25zLmZsdXNoQXRTdGFydHVwKSB7XG4gICAgICBmbHVzaFdpdGhCYWNrT2ZmKCk7XG4gICAgfVxuXG4gICAgcmV0dXJuIHtcbiAgICAgIHNlbmQsXG4gICAgICBmbHVzaDogdGltZW91dCA9PiB7XG4gICAgICAgIC8vIElmIHRoZXJlJ3Mgbm8gdGltZW91dCwgd2Ugc2hvdWxkIGF0dGVtcHQgdG8gZmx1c2ggdGhlIG9mZmxpbmUgcXVldWUuXG4gICAgICAgIGlmICh0aW1lb3V0ID09PSB1bmRlZmluZWQpIHtcbiAgICAgICAgICByZXRyeURlbGF5ID0gU1RBUlRfREVMQVk7XG4gICAgICAgICAgZmx1c2hJbihNSU5fREVMQVkpO1xuICAgICAgICB9XG5cbiAgICAgICAgcmV0dXJuIHRyYW5zcG9ydC5mbHVzaCh0aW1lb3V0KTtcbiAgICAgIH0sXG4gICAgfTtcbiAgfTtcbn1cblxuZXhwb3J0cy5NSU5fREVMQVkgPSBNSU5fREVMQVk7XG5leHBvcnRzLlNUQVJUX0RFTEFZID0gU1RBUlRfREVMQVk7XG5leHBvcnRzLm1ha2VPZmZsaW5lVHJhbnNwb3J0ID0gbWFrZU9mZmxpbmVUcmFuc3BvcnQ7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1vZmZsaW5lLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/transports/offline.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/trpc.js":
/*!********************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/trpc.js ***!
  \********************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst currentScopes = __webpack_require__(/*! ./currentScopes.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst exports$1 = __webpack_require__(/*! ./exports.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/exports.js\");\nconst semanticAttributes = __webpack_require__(/*! ./semanticAttributes.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/semanticAttributes.js\");\nconst object = __webpack_require__(/*! ./utils/object.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/object.js\");\nconst normalize = __webpack_require__(/*! ./utils/normalize.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/normalize.js\");\nconst trace = __webpack_require__(/*! ./tracing/trace.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/trace.js\");\n\nconst trpcCaptureContext = { mechanism: { handled: false, data: { function: 'trpcMiddleware' } } };\n\nfunction captureIfError(nextResult) {\n  // TODO: Set span status based on what TRPCError was encountered\n  if (\n    typeof nextResult === 'object' &&\n    nextResult !== null &&\n    'ok' in nextResult &&\n    !nextResult.ok &&\n    'error' in nextResult\n  ) {\n    exports$1.captureException(nextResult.error, trpcCaptureContext);\n  }\n}\n\n/**\n * Sentry tRPC middleware that captures errors and creates spans for tRPC procedures.\n */\nfunction trpcMiddleware(options = {}) {\n  // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n  // @ts-ignore\n  return async function (opts) {\n    const { path, type, next, rawInput, getRawInput } = opts;\n\n    const client = currentScopes.getClient();\n    const clientOptions = client?.getOptions();\n\n    const trpcContext = {\n      procedure_path: path,\n      procedure_type: type,\n    };\n\n    object.addNonEnumerableProperty(\n      trpcContext,\n      '__sentry_override_normalization_depth__',\n      1 + // 1 for context.input + the normal normalization depth\n        (clientOptions?.normalizeDepth ?? 5), // 5 is a sane depth\n    );\n\n    if (options.attachRpcInput !== undefined ? options.attachRpcInput : clientOptions?.sendDefaultPii) {\n      if (rawInput !== undefined) {\n        trpcContext.input = normalize.normalize(rawInput);\n      }\n\n      if (getRawInput !== undefined && typeof getRawInput === 'function') {\n        try {\n          const rawRes = await getRawInput();\n\n          trpcContext.input = normalize.normalize(rawRes);\n        } catch {\n          // noop\n        }\n      }\n    }\n\n    return currentScopes.withIsolationScope(scope => {\n      scope.setContext('trpc', trpcContext);\n      return trace.startSpanManual(\n        {\n          name: `trpc/${path}`,\n          op: 'rpc.server',\n          attributes: {\n            [semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_SOURCE]: 'route',\n            [semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_ORIGIN]: 'auto.rpc.trpc',\n          },\n          forceTransaction: !!options.forceTransaction,\n        },\n        async span => {\n          try {\n            const nextResult = await next();\n            captureIfError(nextResult);\n            span.end();\n            return nextResult;\n          } catch (e) {\n            exports$1.captureException(e, trpcCaptureContext);\n            span.end();\n            throw e;\n          }\n        },\n      ) ;\n    });\n  };\n}\n\nexports.trpcMiddleware = trpcMiddleware;\n//# sourceMappingURL=trpc.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy90cnBjLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLHNCQUFzQixtQkFBTyxDQUFDLCtIQUFvQjtBQUNsRCxrQkFBa0IsbUJBQU8sQ0FBQyxtSEFBYztBQUN4QywyQkFBMkIsbUJBQU8sQ0FBQyx5SUFBeUI7QUFDNUQsZUFBZSxtQkFBTyxDQUFDLDZIQUFtQjtBQUMxQyxrQkFBa0IsbUJBQU8sQ0FBQyxtSUFBc0I7QUFDaEQsY0FBYyxtQkFBTyxDQUFDLCtIQUFvQjs7QUFFMUMsNkJBQTZCLGFBQWEsd0JBQXdCOztBQUVsRTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0Esb0NBQW9DO0FBQ3BDO0FBQ0E7QUFDQTtBQUNBLFlBQVksMENBQTBDOztBQUV0RDtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQSxVQUFVO0FBQ1Y7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQSx3QkFBd0IsS0FBSztBQUM3QjtBQUNBO0FBQ0E7QUFDQTtBQUNBLFdBQVc7QUFDWDtBQUNBLFNBQVM7QUFDVDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxZQUFZO0FBQ1o7QUFDQTtBQUNBO0FBQ0E7QUFDQSxTQUFTO0FBQ1Q7QUFDQSxLQUFLO0FBQ0w7QUFDQTs7QUFFQSxzQkFBc0I7QUFDdEIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy90cnBjLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBjdXJyZW50U2NvcGVzID0gcmVxdWlyZSgnLi9jdXJyZW50U2NvcGVzLmpzJyk7XG5jb25zdCBleHBvcnRzJDEgPSByZXF1aXJlKCcuL2V4cG9ydHMuanMnKTtcbmNvbnN0IHNlbWFudGljQXR0cmlidXRlcyA9IHJlcXVpcmUoJy4vc2VtYW50aWNBdHRyaWJ1dGVzLmpzJyk7XG5jb25zdCBvYmplY3QgPSByZXF1aXJlKCcuL3V0aWxzL29iamVjdC5qcycpO1xuY29uc3Qgbm9ybWFsaXplID0gcmVxdWlyZSgnLi91dGlscy9ub3JtYWxpemUuanMnKTtcbmNvbnN0IHRyYWNlID0gcmVxdWlyZSgnLi90cmFjaW5nL3RyYWNlLmpzJyk7XG5cbmNvbnN0IHRycGNDYXB0dXJlQ29udGV4dCA9IHsgbWVjaGFuaXNtOiB7IGhhbmRsZWQ6IGZhbHNlLCBkYXRhOiB7IGZ1bmN0aW9uOiAndHJwY01pZGRsZXdhcmUnIH0gfSB9O1xuXG5mdW5jdGlvbiBjYXB0dXJlSWZFcnJvcihuZXh0UmVzdWx0KSB7XG4gIC8vIFRPRE86IFNldCBzcGFuIHN0YXR1cyBiYXNlZCBvbiB3aGF0IFRSUENFcnJvciB3YXMgZW5jb3VudGVyZWRcbiAgaWYgKFxuICAgIHR5cGVvZiBuZXh0UmVzdWx0ID09PSAnb2JqZWN0JyAmJlxuICAgIG5leHRSZXN1bHQgIT09IG51bGwgJiZcbiAgICAnb2snIGluIG5leHRSZXN1bHQgJiZcbiAgICAhbmV4dFJlc3VsdC5vayAmJlxuICAgICdlcnJvcicgaW4gbmV4dFJlc3VsdFxuICApIHtcbiAgICBleHBvcnRzJDEuY2FwdHVyZUV4Y2VwdGlvbihuZXh0UmVzdWx0LmVycm9yLCB0cnBjQ2FwdHVyZUNvbnRleHQpO1xuICB9XG59XG5cbi8qKlxuICogU2VudHJ5IHRSUEMgbWlkZGxld2FyZSB0aGF0IGNhcHR1cmVzIGVycm9ycyBhbmQgY3JlYXRlcyBzcGFucyBmb3IgdFJQQyBwcm9jZWR1cmVzLlxuICovXG5mdW5jdGlvbiB0cnBjTWlkZGxld2FyZShvcHRpb25zID0ge30pIHtcbiAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9iYW4tdHMtY29tbWVudFxuICAvLyBAdHMtaWdub3JlXG4gIHJldHVybiBhc3luYyBmdW5jdGlvbiAob3B0cykge1xuICAgIGNvbnN0IHsgcGF0aCwgdHlwZSwgbmV4dCwgcmF3SW5wdXQsIGdldFJhd0lucHV0IH0gPSBvcHRzO1xuXG4gICAgY29uc3QgY2xpZW50ID0gY3VycmVudFNjb3Blcy5nZXRDbGllbnQoKTtcbiAgICBjb25zdCBjbGllbnRPcHRpb25zID0gY2xpZW50Py5nZXRPcHRpb25zKCk7XG5cbiAgICBjb25zdCB0cnBjQ29udGV4dCA9IHtcbiAgICAgIHByb2NlZHVyZV9wYXRoOiBwYXRoLFxuICAgICAgcHJvY2VkdXJlX3R5cGU6IHR5cGUsXG4gICAgfTtcblxuICAgIG9iamVjdC5hZGROb25FbnVtZXJhYmxlUHJvcGVydHkoXG4gICAgICB0cnBjQ29udGV4dCxcbiAgICAgICdfX3NlbnRyeV9vdmVycmlkZV9ub3JtYWxpemF0aW9uX2RlcHRoX18nLFxuICAgICAgMSArIC8vIDEgZm9yIGNvbnRleHQuaW5wdXQgKyB0aGUgbm9ybWFsIG5vcm1hbGl6YXRpb24gZGVwdGhcbiAgICAgICAgKGNsaWVudE9wdGlvbnM/Lm5vcm1hbGl6ZURlcHRoID8/IDUpLCAvLyA1IGlzIGEgc2FuZSBkZXB0aFxuICAgICk7XG5cbiAgICBpZiAob3B0aW9ucy5hdHRhY2hScGNJbnB1dCAhPT0gdW5kZWZpbmVkID8gb3B0aW9ucy5hdHRhY2hScGNJbnB1dCA6IGNsaWVudE9wdGlvbnM/LnNlbmREZWZhdWx0UGlpKSB7XG4gICAgICBpZiAocmF3SW5wdXQgIT09IHVuZGVmaW5lZCkge1xuICAgICAgICB0cnBjQ29udGV4dC5pbnB1dCA9IG5vcm1hbGl6ZS5ub3JtYWxpemUocmF3SW5wdXQpO1xuICAgICAgfVxuXG4gICAgICBpZiAoZ2V0UmF3SW5wdXQgIT09IHVuZGVmaW5lZCAmJiB0eXBlb2YgZ2V0UmF3SW5wdXQgPT09ICdmdW5jdGlvbicpIHtcbiAgICAgICAgdHJ5IHtcbiAgICAgICAgICBjb25zdCByYXdSZXMgPSBhd2FpdCBnZXRSYXdJbnB1dCgpO1xuXG4gICAgICAgICAgdHJwY0NvbnRleHQuaW5wdXQgPSBub3JtYWxpemUubm9ybWFsaXplKHJhd1Jlcyk7XG4gICAgICAgIH0gY2F0Y2gge1xuICAgICAgICAgIC8vIG5vb3BcbiAgICAgICAgfVxuICAgICAgfVxuICAgIH1cblxuICAgIHJldHVybiBjdXJyZW50U2NvcGVzLndpdGhJc29sYXRpb25TY29wZShzY29wZSA9PiB7XG4gICAgICBzY29wZS5zZXRDb250ZXh0KCd0cnBjJywgdHJwY0NvbnRleHQpO1xuICAgICAgcmV0dXJuIHRyYWNlLnN0YXJ0U3Bhbk1hbnVhbChcbiAgICAgICAge1xuICAgICAgICAgIG5hbWU6IGB0cnBjLyR7cGF0aH1gLFxuICAgICAgICAgIG9wOiAncnBjLnNlcnZlcicsXG4gICAgICAgICAgYXR0cmlidXRlczoge1xuICAgICAgICAgICAgW3NlbWFudGljQXR0cmlidXRlcy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX1NPVVJDRV06ICdyb3V0ZScsXG4gICAgICAgICAgICBbc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfT1JJR0lOXTogJ2F1dG8ucnBjLnRycGMnLFxuICAgICAgICAgIH0sXG4gICAgICAgICAgZm9yY2VUcmFuc2FjdGlvbjogISFvcHRpb25zLmZvcmNlVHJhbnNhY3Rpb24sXG4gICAgICAgIH0sXG4gICAgICAgIGFzeW5jIHNwYW4gPT4ge1xuICAgICAgICAgIHRyeSB7XG4gICAgICAgICAgICBjb25zdCBuZXh0UmVzdWx0ID0gYXdhaXQgbmV4dCgpO1xuICAgICAgICAgICAgY2FwdHVyZUlmRXJyb3IobmV4dFJlc3VsdCk7XG4gICAgICAgICAgICBzcGFuLmVuZCgpO1xuICAgICAgICAgICAgcmV0dXJuIG5leHRSZXN1bHQ7XG4gICAgICAgICAgfSBjYXRjaCAoZSkge1xuICAgICAgICAgICAgZXhwb3J0cyQxLmNhcHR1cmVFeGNlcHRpb24oZSwgdHJwY0NhcHR1cmVDb250ZXh0KTtcbiAgICAgICAgICAgIHNwYW4uZW5kKCk7XG4gICAgICAgICAgICB0aHJvdyBlO1xuICAgICAgICAgIH1cbiAgICAgICAgfSxcbiAgICAgICkgO1xuICAgIH0pO1xuICB9O1xufVxuXG5leHBvcnRzLnRycGNNaWRkbGV3YXJlID0gdHJwY01pZGRsZXdhcmU7XG4vLyMgc291cmNlTWFwcGluZ1VSTD10cnBjLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/trpc.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/aggregate-errors.js":
/*!**************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/aggregate-errors.js ***!
  \**************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst is = __webpack_require__(/*! ./is.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js\");\n\n/**\n * Creates exceptions inside `event.exception.values` for errors that are nested on properties based on the `key` parameter.\n */\nfunction applyAggregateErrorsToEvent(\n  exceptionFromErrorImplementation,\n  parser,\n  key,\n  limit,\n  event,\n  hint,\n) {\n  if (!event.exception?.values || !hint || !is.isInstanceOf(hint.originalException, Error)) {\n    return;\n  }\n\n  // Generally speaking the last item in `event.exception.values` is the exception originating from the original Error\n  const originalException =\n    event.exception.values.length > 0 ? event.exception.values[event.exception.values.length - 1] : undefined;\n\n  // We only create exception grouping if there is an exception in the event.\n  if (originalException) {\n    event.exception.values = aggregateExceptionsFromError(\n      exceptionFromErrorImplementation,\n      parser,\n      limit,\n      hint.originalException ,\n      key,\n      event.exception.values,\n      originalException,\n      0,\n    );\n  }\n}\n\nfunction aggregateExceptionsFromError(\n  exceptionFromErrorImplementation,\n  parser,\n  limit,\n  error,\n  key,\n  prevExceptions,\n  exception,\n  exceptionId,\n) {\n  if (prevExceptions.length >= limit + 1) {\n    return prevExceptions;\n  }\n\n  let newExceptions = [...prevExceptions];\n\n  // Recursively call this function in order to walk down a chain of errors\n  if (is.isInstanceOf(error[key], Error)) {\n    applyExceptionGroupFieldsForParentException(exception, exceptionId);\n    const newException = exceptionFromErrorImplementation(parser, error[key]);\n    const newExceptionId = newExceptions.length;\n    applyExceptionGroupFieldsForChildException(newException, key, newExceptionId, exceptionId);\n    newExceptions = aggregateExceptionsFromError(\n      exceptionFromErrorImplementation,\n      parser,\n      limit,\n      error[key],\n      key,\n      [newException, ...newExceptions],\n      newException,\n      newExceptionId,\n    );\n  }\n\n  // This will create exception grouping for AggregateErrors\n  // https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/AggregateError\n  if (Array.isArray(error.errors)) {\n    error.errors.forEach((childError, i) => {\n      if (is.isInstanceOf(childError, Error)) {\n        applyExceptionGroupFieldsForParentException(exception, exceptionId);\n        const newException = exceptionFromErrorImplementation(parser, childError);\n        const newExceptionId = newExceptions.length;\n        applyExceptionGroupFieldsForChildException(newException, `errors[${i}]`, newExceptionId, exceptionId);\n        newExceptions = aggregateExceptionsFromError(\n          exceptionFromErrorImplementation,\n          parser,\n          limit,\n          childError,\n          key,\n          [newException, ...newExceptions],\n          newException,\n          newExceptionId,\n        );\n      }\n    });\n  }\n\n  return newExceptions;\n}\n\nfunction applyExceptionGroupFieldsForParentException(exception, exceptionId) {\n  // Don't know if this default makes sense. The protocol requires us to set these values so we pick *some* default.\n  exception.mechanism = exception.mechanism || { type: 'generic', handled: true };\n\n  exception.mechanism = {\n    ...exception.mechanism,\n    ...(exception.type === 'AggregateError' && { is_exception_group: true }),\n    exception_id: exceptionId,\n  };\n}\n\nfunction applyExceptionGroupFieldsForChildException(\n  exception,\n  source,\n  exceptionId,\n  parentId,\n) {\n  // Don't know if this default makes sense. The protocol requires us to set these values so we pick *some* default.\n  exception.mechanism = exception.mechanism || { type: 'generic', handled: true };\n\n  exception.mechanism = {\n    ...exception.mechanism,\n    type: 'chained',\n    source,\n    exception_id: exceptionId,\n    parent_id: parentId,\n  };\n}\n\nexports.applyAggregateErrorsToEvent = applyAggregateErrorsToEvent;\n//# sourceMappingURL=aggregate-errors.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9hZ2dyZWdhdGUtZXJyb3JzLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLFdBQVcsbUJBQU8sQ0FBQywrR0FBUzs7QUFFNUI7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSwyRUFBMkUsRUFBRTtBQUM3RTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsS0FBSztBQUNMOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLGlEQUFpRDs7QUFFakQ7QUFDQTtBQUNBLGlEQUFpRCwwQkFBMEI7QUFDM0U7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsaURBQWlEOztBQUVqRDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLG1DQUFtQztBQUNuQyIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3V0aWxzL2FnZ3JlZ2F0ZS1lcnJvcnMuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGlzID0gcmVxdWlyZSgnLi9pcy5qcycpO1xuXG4vKipcbiAqIENyZWF0ZXMgZXhjZXB0aW9ucyBpbnNpZGUgYGV2ZW50LmV4Y2VwdGlvbi52YWx1ZXNgIGZvciBlcnJvcnMgdGhhdCBhcmUgbmVzdGVkIG9uIHByb3BlcnRpZXMgYmFzZWQgb24gdGhlIGBrZXlgIHBhcmFtZXRlci5cbiAqL1xuZnVuY3Rpb24gYXBwbHlBZ2dyZWdhdGVFcnJvcnNUb0V2ZW50KFxuICBleGNlcHRpb25Gcm9tRXJyb3JJbXBsZW1lbnRhdGlvbixcbiAgcGFyc2VyLFxuICBrZXksXG4gIGxpbWl0LFxuICBldmVudCxcbiAgaGludCxcbikge1xuICBpZiAoIWV2ZW50LmV4Y2VwdGlvbj8udmFsdWVzIHx8ICFoaW50IHx8ICFpcy5pc0luc3RhbmNlT2YoaGludC5vcmlnaW5hbEV4Y2VwdGlvbiwgRXJyb3IpKSB7XG4gICAgcmV0dXJuO1xuICB9XG5cbiAgLy8gR2VuZXJhbGx5IHNwZWFraW5nIHRoZSBsYXN0IGl0ZW0gaW4gYGV2ZW50LmV4Y2VwdGlvbi52YWx1ZXNgIGlzIHRoZSBleGNlcHRpb24gb3JpZ2luYXRpbmcgZnJvbSB0aGUgb3JpZ2luYWwgRXJyb3JcbiAgY29uc3Qgb3JpZ2luYWxFeGNlcHRpb24gPVxuICAgIGV2ZW50LmV4Y2VwdGlvbi52YWx1ZXMubGVuZ3RoID4gMCA/IGV2ZW50LmV4Y2VwdGlvbi52YWx1ZXNbZXZlbnQuZXhjZXB0aW9uLnZhbHVlcy5sZW5ndGggLSAxXSA6IHVuZGVmaW5lZDtcblxuICAvLyBXZSBvbmx5IGNyZWF0ZSBleGNlcHRpb24gZ3JvdXBpbmcgaWYgdGhlcmUgaXMgYW4gZXhjZXB0aW9uIGluIHRoZSBldmVudC5cbiAgaWYgKG9yaWdpbmFsRXhjZXB0aW9uKSB7XG4gICAgZXZlbnQuZXhjZXB0aW9uLnZhbHVlcyA9IGFnZ3JlZ2F0ZUV4Y2VwdGlvbnNGcm9tRXJyb3IoXG4gICAgICBleGNlcHRpb25Gcm9tRXJyb3JJbXBsZW1lbnRhdGlvbixcbiAgICAgIHBhcnNlcixcbiAgICAgIGxpbWl0LFxuICAgICAgaGludC5vcmlnaW5hbEV4Y2VwdGlvbiAsXG4gICAgICBrZXksXG4gICAgICBldmVudC5leGNlcHRpb24udmFsdWVzLFxuICAgICAgb3JpZ2luYWxFeGNlcHRpb24sXG4gICAgICAwLFxuICAgICk7XG4gIH1cbn1cblxuZnVuY3Rpb24gYWdncmVnYXRlRXhjZXB0aW9uc0Zyb21FcnJvcihcbiAgZXhjZXB0aW9uRnJvbUVycm9ySW1wbGVtZW50YXRpb24sXG4gIHBhcnNlcixcbiAgbGltaXQsXG4gIGVycm9yLFxuICBrZXksXG4gIHByZXZFeGNlcHRpb25zLFxuICBleGNlcHRpb24sXG4gIGV4Y2VwdGlvbklkLFxuKSB7XG4gIGlmIChwcmV2RXhjZXB0aW9ucy5sZW5ndGggPj0gbGltaXQgKyAxKSB7XG4gICAgcmV0dXJuIHByZXZFeGNlcHRpb25zO1xuICB9XG5cbiAgbGV0IG5ld0V4Y2VwdGlvbnMgPSBbLi4ucHJldkV4Y2VwdGlvbnNdO1xuXG4gIC8vIFJlY3Vyc2l2ZWx5IGNhbGwgdGhpcyBmdW5jdGlvbiBpbiBvcmRlciB0byB3YWxrIGRvd24gYSBjaGFpbiBvZiBlcnJvcnNcbiAgaWYgKGlzLmlzSW5zdGFuY2VPZihlcnJvcltrZXldLCBFcnJvcikpIHtcbiAgICBhcHBseUV4Y2VwdGlvbkdyb3VwRmllbGRzRm9yUGFyZW50RXhjZXB0aW9uKGV4Y2VwdGlvbiwgZXhjZXB0aW9uSWQpO1xuICAgIGNvbnN0IG5ld0V4Y2VwdGlvbiA9IGV4Y2VwdGlvbkZyb21FcnJvckltcGxlbWVudGF0aW9uKHBhcnNlciwgZXJyb3Jba2V5XSk7XG4gICAgY29uc3QgbmV3RXhjZXB0aW9uSWQgPSBuZXdFeGNlcHRpb25zLmxlbmd0aDtcbiAgICBhcHBseUV4Y2VwdGlvbkdyb3VwRmllbGRzRm9yQ2hpbGRFeGNlcHRpb24obmV3RXhjZXB0aW9uLCBrZXksIG5ld0V4Y2VwdGlvbklkLCBleGNlcHRpb25JZCk7XG4gICAgbmV3RXhjZXB0aW9ucyA9IGFnZ3JlZ2F0ZUV4Y2VwdGlvbnNGcm9tRXJyb3IoXG4gICAgICBleGNlcHRpb25Gcm9tRXJyb3JJbXBsZW1lbnRhdGlvbixcbiAgICAgIHBhcnNlcixcbiAgICAgIGxpbWl0LFxuICAgICAgZXJyb3Jba2V5XSxcbiAgICAgIGtleSxcbiAgICAgIFtuZXdFeGNlcHRpb24sIC4uLm5ld0V4Y2VwdGlvbnNdLFxuICAgICAgbmV3RXhjZXB0aW9uLFxuICAgICAgbmV3RXhjZXB0aW9uSWQsXG4gICAgKTtcbiAgfVxuXG4gIC8vIFRoaXMgd2lsbCBjcmVhdGUgZXhjZXB0aW9uIGdyb3VwaW5nIGZvciBBZ2dyZWdhdGVFcnJvcnNcbiAgLy8gaHR0cHM6Ly9kZXZlbG9wZXIubW96aWxsYS5vcmcvZW4tVVMvZG9jcy9XZWIvSmF2YVNjcmlwdC9SZWZlcmVuY2UvR2xvYmFsX09iamVjdHMvQWdncmVnYXRlRXJyb3JcbiAgaWYgKEFycmF5LmlzQXJyYXkoZXJyb3IuZXJyb3JzKSkge1xuICAgIGVycm9yLmVycm9ycy5mb3JFYWNoKChjaGlsZEVycm9yLCBpKSA9PiB7XG4gICAgICBpZiAoaXMuaXNJbnN0YW5jZU9mKGNoaWxkRXJyb3IsIEVycm9yKSkge1xuICAgICAgICBhcHBseUV4Y2VwdGlvbkdyb3VwRmllbGRzRm9yUGFyZW50RXhjZXB0aW9uKGV4Y2VwdGlvbiwgZXhjZXB0aW9uSWQpO1xuICAgICAgICBjb25zdCBuZXdFeGNlcHRpb24gPSBleGNlcHRpb25Gcm9tRXJyb3JJbXBsZW1lbnRhdGlvbihwYXJzZXIsIGNoaWxkRXJyb3IpO1xuICAgICAgICBjb25zdCBuZXdFeGNlcHRpb25JZCA9IG5ld0V4Y2VwdGlvbnMubGVuZ3RoO1xuICAgICAgICBhcHBseUV4Y2VwdGlvbkdyb3VwRmllbGRzRm9yQ2hpbGRFeGNlcHRpb24obmV3RXhjZXB0aW9uLCBgZXJyb3JzWyR7aX1dYCwgbmV3RXhjZXB0aW9uSWQsIGV4Y2VwdGlvbklkKTtcbiAgICAgICAgbmV3RXhjZXB0aW9ucyA9IGFnZ3JlZ2F0ZUV4Y2VwdGlvbnNGcm9tRXJyb3IoXG4gICAgICAgICAgZXhjZXB0aW9uRnJvbUVycm9ySW1wbGVtZW50YXRpb24sXG4gICAgICAgICAgcGFyc2VyLFxuICAgICAgICAgIGxpbWl0LFxuICAgICAgICAgIGNoaWxkRXJyb3IsXG4gICAgICAgICAga2V5LFxuICAgICAgICAgIFtuZXdFeGNlcHRpb24sIC4uLm5ld0V4Y2VwdGlvbnNdLFxuICAgICAgICAgIG5ld0V4Y2VwdGlvbixcbiAgICAgICAgICBuZXdFeGNlcHRpb25JZCxcbiAgICAgICAgKTtcbiAgICAgIH1cbiAgICB9KTtcbiAgfVxuXG4gIHJldHVybiBuZXdFeGNlcHRpb25zO1xufVxuXG5mdW5jdGlvbiBhcHBseUV4Y2VwdGlvbkdyb3VwRmllbGRzRm9yUGFyZW50RXhjZXB0aW9uKGV4Y2VwdGlvbiwgZXhjZXB0aW9uSWQpIHtcbiAgLy8gRG9uJ3Qga25vdyBpZiB0aGlzIGRlZmF1bHQgbWFrZXMgc2Vuc2UuIFRoZSBwcm90b2NvbCByZXF1aXJlcyB1cyB0byBzZXQgdGhlc2UgdmFsdWVzIHNvIHdlIHBpY2sgKnNvbWUqIGRlZmF1bHQuXG4gIGV4Y2VwdGlvbi5tZWNoYW5pc20gPSBleGNlcHRpb24ubWVjaGFuaXNtIHx8IHsgdHlwZTogJ2dlbmVyaWMnLCBoYW5kbGVkOiB0cnVlIH07XG5cbiAgZXhjZXB0aW9uLm1lY2hhbmlzbSA9IHtcbiAgICAuLi5leGNlcHRpb24ubWVjaGFuaXNtLFxuICAgIC4uLihleGNlcHRpb24udHlwZSA9PT0gJ0FnZ3JlZ2F0ZUVycm9yJyAmJiB7IGlzX2V4Y2VwdGlvbl9ncm91cDogdHJ1ZSB9KSxcbiAgICBleGNlcHRpb25faWQ6IGV4Y2VwdGlvbklkLFxuICB9O1xufVxuXG5mdW5jdGlvbiBhcHBseUV4Y2VwdGlvbkdyb3VwRmllbGRzRm9yQ2hpbGRFeGNlcHRpb24oXG4gIGV4Y2VwdGlvbixcbiAgc291cmNlLFxuICBleGNlcHRpb25JZCxcbiAgcGFyZW50SWQsXG4pIHtcbiAgLy8gRG9uJ3Qga25vdyBpZiB0aGlzIGRlZmF1bHQgbWFrZXMgc2Vuc2UuIFRoZSBwcm90b2NvbCByZXF1aXJlcyB1cyB0byBzZXQgdGhlc2UgdmFsdWVzIHNvIHdlIHBpY2sgKnNvbWUqIGRlZmF1bHQuXG4gIGV4Y2VwdGlvbi5tZWNoYW5pc20gPSBleGNlcHRpb24ubWVjaGFuaXNtIHx8IHsgdHlwZTogJ2dlbmVyaWMnLCBoYW5kbGVkOiB0cnVlIH07XG5cbiAgZXhjZXB0aW9uLm1lY2hhbmlzbSA9IHtcbiAgICAuLi5leGNlcHRpb24ubWVjaGFuaXNtLFxuICAgIHR5cGU6ICdjaGFpbmVkJyxcbiAgICBzb3VyY2UsXG4gICAgZXhjZXB0aW9uX2lkOiBleGNlcHRpb25JZCxcbiAgICBwYXJlbnRfaWQ6IHBhcmVudElkLFxuICB9O1xufVxuXG5leHBvcnRzLmFwcGx5QWdncmVnYXRlRXJyb3JzVG9FdmVudCA9IGFwcGx5QWdncmVnYXRlRXJyb3JzVG9FdmVudDtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWFnZ3JlZ2F0ZS1lcnJvcnMuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/aggregate-errors.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/anr.js":
/*!*************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/anr.js ***!
  \*************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst nodeStackTrace = __webpack_require__(/*! ./node-stack-trace.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/node-stack-trace.js\");\nconst stacktrace = __webpack_require__(/*! ./stacktrace.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/stacktrace.js\");\n\n/**\n * A node.js watchdog timer\n * @param pollInterval The interval that we expect to get polled at\n * @param anrThreshold The threshold for when we consider ANR\n * @param callback The callback to call for ANR\n * @returns An object with `poll` and `enabled` functions {@link WatchdogReturn}\n */\nfunction watchdogTimer(\n  createTimer,\n  pollInterval,\n  anrThreshold,\n  callback,\n) {\n  const timer = createTimer();\n  let triggered = false;\n  let enabled = true;\n\n  setInterval(() => {\n    const diffMs = timer.getTimeMs();\n\n    if (triggered === false && diffMs > pollInterval + anrThreshold) {\n      triggered = true;\n      if (enabled) {\n        callback();\n      }\n    }\n\n    if (diffMs < pollInterval + anrThreshold) {\n      triggered = false;\n    }\n  }, 20);\n\n  return {\n    poll: () => {\n      timer.reset();\n    },\n    enabled: (state) => {\n      enabled = state;\n    },\n  };\n}\n\n// types copied from inspector.d.ts\n\n/**\n * Converts Debugger.CallFrame to Sentry StackFrame\n */\nfunction callFrameToStackFrame(\n  frame,\n  url,\n  getModuleFromFilename,\n) {\n  const filename = url ? url.replace(/^file:\\/\\//, '') : undefined;\n\n  // CallFrame row/col are 0 based, whereas StackFrame are 1 based\n  const colno = frame.location.columnNumber ? frame.location.columnNumber + 1 : undefined;\n  const lineno = frame.location.lineNumber ? frame.location.lineNumber + 1 : undefined;\n\n  return {\n    filename,\n    module: getModuleFromFilename(filename),\n    function: frame.functionName || stacktrace.UNKNOWN_FUNCTION,\n    colno,\n    lineno,\n    in_app: filename ? nodeStackTrace.filenameIsInApp(filename) : undefined,\n  };\n}\n\nexports.callFrameToStackFrame = callFrameToStackFrame;\nexports.watchdogTimer = watchdogTimer;\n//# sourceMappingURL=anr.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9hbnIuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsdUJBQXVCLG1CQUFPLENBQUMsMklBQXVCO0FBQ3RELG1CQUFtQixtQkFBTyxDQUFDLCtIQUFpQjs7QUFFNUM7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLDJEQUEyRDtBQUMzRDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQSxHQUFHOztBQUVIO0FBQ0E7QUFDQTtBQUNBLEtBQUs7QUFDTDtBQUNBO0FBQ0EsS0FBSztBQUNMO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsNkJBQTZCO0FBQzdCLHFCQUFxQjtBQUNyQiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3V0aWxzL2Fuci5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3Qgbm9kZVN0YWNrVHJhY2UgPSByZXF1aXJlKCcuL25vZGUtc3RhY2stdHJhY2UuanMnKTtcbmNvbnN0IHN0YWNrdHJhY2UgPSByZXF1aXJlKCcuL3N0YWNrdHJhY2UuanMnKTtcblxuLyoqXG4gKiBBIG5vZGUuanMgd2F0Y2hkb2cgdGltZXJcbiAqIEBwYXJhbSBwb2xsSW50ZXJ2YWwgVGhlIGludGVydmFsIHRoYXQgd2UgZXhwZWN0IHRvIGdldCBwb2xsZWQgYXRcbiAqIEBwYXJhbSBhbnJUaHJlc2hvbGQgVGhlIHRocmVzaG9sZCBmb3Igd2hlbiB3ZSBjb25zaWRlciBBTlJcbiAqIEBwYXJhbSBjYWxsYmFjayBUaGUgY2FsbGJhY2sgdG8gY2FsbCBmb3IgQU5SXG4gKiBAcmV0dXJucyBBbiBvYmplY3Qgd2l0aCBgcG9sbGAgYW5kIGBlbmFibGVkYCBmdW5jdGlvbnMge0BsaW5rIFdhdGNoZG9nUmV0dXJufVxuICovXG5mdW5jdGlvbiB3YXRjaGRvZ1RpbWVyKFxuICBjcmVhdGVUaW1lcixcbiAgcG9sbEludGVydmFsLFxuICBhbnJUaHJlc2hvbGQsXG4gIGNhbGxiYWNrLFxuKSB7XG4gIGNvbnN0IHRpbWVyID0gY3JlYXRlVGltZXIoKTtcbiAgbGV0IHRyaWdnZXJlZCA9IGZhbHNlO1xuICBsZXQgZW5hYmxlZCA9IHRydWU7XG5cbiAgc2V0SW50ZXJ2YWwoKCkgPT4ge1xuICAgIGNvbnN0IGRpZmZNcyA9IHRpbWVyLmdldFRpbWVNcygpO1xuXG4gICAgaWYgKHRyaWdnZXJlZCA9PT0gZmFsc2UgJiYgZGlmZk1zID4gcG9sbEludGVydmFsICsgYW5yVGhyZXNob2xkKSB7XG4gICAgICB0cmlnZ2VyZWQgPSB0cnVlO1xuICAgICAgaWYgKGVuYWJsZWQpIHtcbiAgICAgICAgY2FsbGJhY2soKTtcbiAgICAgIH1cbiAgICB9XG5cbiAgICBpZiAoZGlmZk1zIDwgcG9sbEludGVydmFsICsgYW5yVGhyZXNob2xkKSB7XG4gICAgICB0cmlnZ2VyZWQgPSBmYWxzZTtcbiAgICB9XG4gIH0sIDIwKTtcblxuICByZXR1cm4ge1xuICAgIHBvbGw6ICgpID0+IHtcbiAgICAgIHRpbWVyLnJlc2V0KCk7XG4gICAgfSxcbiAgICBlbmFibGVkOiAoc3RhdGUpID0+IHtcbiAgICAgIGVuYWJsZWQgPSBzdGF0ZTtcbiAgICB9LFxuICB9O1xufVxuXG4vLyB0eXBlcyBjb3BpZWQgZnJvbSBpbnNwZWN0b3IuZC50c1xuXG4vKipcbiAqIENvbnZlcnRzIERlYnVnZ2VyLkNhbGxGcmFtZSB0byBTZW50cnkgU3RhY2tGcmFtZVxuICovXG5mdW5jdGlvbiBjYWxsRnJhbWVUb1N0YWNrRnJhbWUoXG4gIGZyYW1lLFxuICB1cmwsXG4gIGdldE1vZHVsZUZyb21GaWxlbmFtZSxcbikge1xuICBjb25zdCBmaWxlbmFtZSA9IHVybCA/IHVybC5yZXBsYWNlKC9eZmlsZTpcXC9cXC8vLCAnJykgOiB1bmRlZmluZWQ7XG5cbiAgLy8gQ2FsbEZyYW1lIHJvdy9jb2wgYXJlIDAgYmFzZWQsIHdoZXJlYXMgU3RhY2tGcmFtZSBhcmUgMSBiYXNlZFxuICBjb25zdCBjb2xubyA9IGZyYW1lLmxvY2F0aW9uLmNvbHVtbk51bWJlciA/IGZyYW1lLmxvY2F0aW9uLmNvbHVtbk51bWJlciArIDEgOiB1bmRlZmluZWQ7XG4gIGNvbnN0IGxpbmVubyA9IGZyYW1lLmxvY2F0aW9uLmxpbmVOdW1iZXIgPyBmcmFtZS5sb2NhdGlvbi5saW5lTnVtYmVyICsgMSA6IHVuZGVmaW5lZDtcblxuICByZXR1cm4ge1xuICAgIGZpbGVuYW1lLFxuICAgIG1vZHVsZTogZ2V0TW9kdWxlRnJvbUZpbGVuYW1lKGZpbGVuYW1lKSxcbiAgICBmdW5jdGlvbjogZnJhbWUuZnVuY3Rpb25OYW1lIHx8IHN0YWNrdHJhY2UuVU5LTk9XTl9GVU5DVElPTixcbiAgICBjb2xubyxcbiAgICBsaW5lbm8sXG4gICAgaW5fYXBwOiBmaWxlbmFtZSA/IG5vZGVTdGFja1RyYWNlLmZpbGVuYW1lSXNJbkFwcChmaWxlbmFtZSkgOiB1bmRlZmluZWQsXG4gIH07XG59XG5cbmV4cG9ydHMuY2FsbEZyYW1lVG9TdGFja0ZyYW1lID0gY2FsbEZyYW1lVG9TdGFja0ZyYW1lO1xuZXhwb3J0cy53YXRjaGRvZ1RpbWVyID0gd2F0Y2hkb2dUaW1lcjtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWFuci5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/anr.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/applyScopeDataToEvent.js":
/*!*******************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/applyScopeDataToEvent.js ***!
  \*******************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst dynamicSamplingContext = __webpack_require__(/*! ../tracing/dynamicSamplingContext.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/dynamicSamplingContext.js\");\nconst merge = __webpack_require__(/*! ./merge.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/merge.js\");\nconst spanUtils = __webpack_require__(/*! ./spanUtils.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanUtils.js\");\n\n/**\n * Applies data from the scope to the event and runs all event processors on it.\n */\nfunction applyScopeDataToEvent(event, data) {\n  const { fingerprint, span, breadcrumbs, sdkProcessingMetadata } = data;\n\n  // Apply general data\n  applyDataToEvent(event, data);\n\n  // We want to set the trace context for normal events only if there isn't already\n  // a trace context on the event. There is a product feature in place where we link\n  // errors with transaction and it relies on that.\n  if (span) {\n    applySpanToEvent(event, span);\n  }\n\n  applyFingerprintToEvent(event, fingerprint);\n  applyBreadcrumbsToEvent(event, breadcrumbs);\n  applySdkMetadataToEvent(event, sdkProcessingMetadata);\n}\n\n/** Merge data of two scopes together. */\nfunction mergeScopeData(data, mergeData) {\n  const {\n    extra,\n    tags,\n    user,\n    contexts,\n    level,\n    sdkProcessingMetadata,\n    breadcrumbs,\n    fingerprint,\n    eventProcessors,\n    attachments,\n    propagationContext,\n    transactionName,\n    span,\n  } = mergeData;\n\n  mergeAndOverwriteScopeData(data, 'extra', extra);\n  mergeAndOverwriteScopeData(data, 'tags', tags);\n  mergeAndOverwriteScopeData(data, 'user', user);\n  mergeAndOverwriteScopeData(data, 'contexts', contexts);\n\n  data.sdkProcessingMetadata = merge.merge(data.sdkProcessingMetadata, sdkProcessingMetadata, 2);\n\n  if (level) {\n    data.level = level;\n  }\n\n  if (transactionName) {\n    data.transactionName = transactionName;\n  }\n\n  if (span) {\n    data.span = span;\n  }\n\n  if (breadcrumbs.length) {\n    data.breadcrumbs = [...data.breadcrumbs, ...breadcrumbs];\n  }\n\n  if (fingerprint.length) {\n    data.fingerprint = [...data.fingerprint, ...fingerprint];\n  }\n\n  if (eventProcessors.length) {\n    data.eventProcessors = [...data.eventProcessors, ...eventProcessors];\n  }\n\n  if (attachments.length) {\n    data.attachments = [...data.attachments, ...attachments];\n  }\n\n  data.propagationContext = { ...data.propagationContext, ...propagationContext };\n}\n\n/**\n * Merges certain scope data. Undefined values will overwrite any existing values.\n * Exported only for tests.\n */\nfunction mergeAndOverwriteScopeData\n\n(data, prop, mergeVal) {\n  data[prop] = merge.merge(data[prop], mergeVal, 1);\n}\n\nfunction applyDataToEvent(event, data) {\n  const { extra, tags, user, contexts, level, transactionName } = data;\n\n  if (Object.keys(extra).length) {\n    event.extra = { ...extra, ...event.extra };\n  }\n\n  if (Object.keys(tags).length) {\n    event.tags = { ...tags, ...event.tags };\n  }\n\n  if (Object.keys(user).length) {\n    event.user = { ...user, ...event.user };\n  }\n\n  if (Object.keys(contexts).length) {\n    event.contexts = { ...contexts, ...event.contexts };\n  }\n\n  if (level) {\n    event.level = level;\n  }\n\n  // transaction events get their `transaction` from the root span name\n  if (transactionName && event.type !== 'transaction') {\n    event.transaction = transactionName;\n  }\n}\n\nfunction applyBreadcrumbsToEvent(event, breadcrumbs) {\n  const mergedBreadcrumbs = [...(event.breadcrumbs || []), ...breadcrumbs];\n  event.breadcrumbs = mergedBreadcrumbs.length ? mergedBreadcrumbs : undefined;\n}\n\nfunction applySdkMetadataToEvent(event, sdkProcessingMetadata) {\n  event.sdkProcessingMetadata = {\n    ...event.sdkProcessingMetadata,\n    ...sdkProcessingMetadata,\n  };\n}\n\nfunction applySpanToEvent(event, span) {\n  event.contexts = {\n    trace: spanUtils.spanToTraceContext(span),\n    ...event.contexts,\n  };\n\n  event.sdkProcessingMetadata = {\n    dynamicSamplingContext: dynamicSamplingContext.getDynamicSamplingContextFromSpan(span),\n    ...event.sdkProcessingMetadata,\n  };\n\n  const rootSpan = spanUtils.getRootSpan(span);\n  const transactionName = spanUtils.spanToJSON(rootSpan).description;\n  if (transactionName && !event.transaction && event.type === 'transaction') {\n    event.transaction = transactionName;\n  }\n}\n\n/**\n * Applies fingerprint from the scope to the event if there's one,\n * uses message if there's one instead or get rid of empty fingerprint\n */\nfunction applyFingerprintToEvent(event, fingerprint) {\n  // Make sure it's an array first and we actually have something in place\n  event.fingerprint = event.fingerprint\n    ? Array.isArray(event.fingerprint)\n      ? event.fingerprint\n      : [event.fingerprint]\n    : [];\n\n  // If we have something on the scope, then merge it with event\n  if (fingerprint) {\n    event.fingerprint = event.fingerprint.concat(fingerprint);\n  }\n\n  // If we have no data at all, remove empty array default\n  if (!event.fingerprint.length) {\n    delete event.fingerprint;\n  }\n}\n\nexports.applyScopeDataToEvent = applyScopeDataToEvent;\nexports.mergeAndOverwriteScopeData = mergeAndOverwriteScopeData;\nexports.mergeScopeData = mergeScopeData;\n//# sourceMappingURL=applyScopeDataToEvent.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9hcHBseVNjb3BlRGF0YVRvRXZlbnQuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsK0JBQStCLG1CQUFPLENBQUMsa0tBQXNDO0FBQzdFLGNBQWMsbUJBQU8sQ0FBQyxxSEFBWTtBQUNsQyxrQkFBa0IsbUJBQU8sQ0FBQyw2SEFBZ0I7O0FBRTFDO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsVUFBVSx3REFBd0Q7O0FBRWxFO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsSUFBSTs7QUFFSjtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUEsOEJBQThCO0FBQzlCOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0EsVUFBVSxzREFBc0Q7O0FBRWhFO0FBQ0Esb0JBQW9CO0FBQ3BCOztBQUVBO0FBQ0EsbUJBQW1CO0FBQ25COztBQUVBO0FBQ0EsbUJBQW1CO0FBQ25COztBQUVBO0FBQ0EsdUJBQXVCO0FBQ3ZCOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsNkJBQTZCO0FBQzdCLGtDQUFrQztBQUNsQyxzQkFBc0I7QUFDdEIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9hcHBseVNjb3BlRGF0YVRvRXZlbnQuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGR5bmFtaWNTYW1wbGluZ0NvbnRleHQgPSByZXF1aXJlKCcuLi90cmFjaW5nL2R5bmFtaWNTYW1wbGluZ0NvbnRleHQuanMnKTtcbmNvbnN0IG1lcmdlID0gcmVxdWlyZSgnLi9tZXJnZS5qcycpO1xuY29uc3Qgc3BhblV0aWxzID0gcmVxdWlyZSgnLi9zcGFuVXRpbHMuanMnKTtcblxuLyoqXG4gKiBBcHBsaWVzIGRhdGEgZnJvbSB0aGUgc2NvcGUgdG8gdGhlIGV2ZW50IGFuZCBydW5zIGFsbCBldmVudCBwcm9jZXNzb3JzIG9uIGl0LlxuICovXG5mdW5jdGlvbiBhcHBseVNjb3BlRGF0YVRvRXZlbnQoZXZlbnQsIGRhdGEpIHtcbiAgY29uc3QgeyBmaW5nZXJwcmludCwgc3BhbiwgYnJlYWRjcnVtYnMsIHNka1Byb2Nlc3NpbmdNZXRhZGF0YSB9ID0gZGF0YTtcblxuICAvLyBBcHBseSBnZW5lcmFsIGRhdGFcbiAgYXBwbHlEYXRhVG9FdmVudChldmVudCwgZGF0YSk7XG5cbiAgLy8gV2Ugd2FudCB0byBzZXQgdGhlIHRyYWNlIGNvbnRleHQgZm9yIG5vcm1hbCBldmVudHMgb25seSBpZiB0aGVyZSBpc24ndCBhbHJlYWR5XG4gIC8vIGEgdHJhY2UgY29udGV4dCBvbiB0aGUgZXZlbnQuIFRoZXJlIGlzIGEgcHJvZHVjdCBmZWF0dXJlIGluIHBsYWNlIHdoZXJlIHdlIGxpbmtcbiAgLy8gZXJyb3JzIHdpdGggdHJhbnNhY3Rpb24gYW5kIGl0IHJlbGllcyBvbiB0aGF0LlxuICBpZiAoc3Bhbikge1xuICAgIGFwcGx5U3BhblRvRXZlbnQoZXZlbnQsIHNwYW4pO1xuICB9XG5cbiAgYXBwbHlGaW5nZXJwcmludFRvRXZlbnQoZXZlbnQsIGZpbmdlcnByaW50KTtcbiAgYXBwbHlCcmVhZGNydW1ic1RvRXZlbnQoZXZlbnQsIGJyZWFkY3J1bWJzKTtcbiAgYXBwbHlTZGtNZXRhZGF0YVRvRXZlbnQoZXZlbnQsIHNka1Byb2Nlc3NpbmdNZXRhZGF0YSk7XG59XG5cbi8qKiBNZXJnZSBkYXRhIG9mIHR3byBzY29wZXMgdG9nZXRoZXIuICovXG5mdW5jdGlvbiBtZXJnZVNjb3BlRGF0YShkYXRhLCBtZXJnZURhdGEpIHtcbiAgY29uc3Qge1xuICAgIGV4dHJhLFxuICAgIHRhZ3MsXG4gICAgdXNlcixcbiAgICBjb250ZXh0cyxcbiAgICBsZXZlbCxcbiAgICBzZGtQcm9jZXNzaW5nTWV0YWRhdGEsXG4gICAgYnJlYWRjcnVtYnMsXG4gICAgZmluZ2VycHJpbnQsXG4gICAgZXZlbnRQcm9jZXNzb3JzLFxuICAgIGF0dGFjaG1lbnRzLFxuICAgIHByb3BhZ2F0aW9uQ29udGV4dCxcbiAgICB0cmFuc2FjdGlvbk5hbWUsXG4gICAgc3BhbixcbiAgfSA9IG1lcmdlRGF0YTtcblxuICBtZXJnZUFuZE92ZXJ3cml0ZVNjb3BlRGF0YShkYXRhLCAnZXh0cmEnLCBleHRyYSk7XG4gIG1lcmdlQW5kT3ZlcndyaXRlU2NvcGVEYXRhKGRhdGEsICd0YWdzJywgdGFncyk7XG4gIG1lcmdlQW5kT3ZlcndyaXRlU2NvcGVEYXRhKGRhdGEsICd1c2VyJywgdXNlcik7XG4gIG1lcmdlQW5kT3ZlcndyaXRlU2NvcGVEYXRhKGRhdGEsICdjb250ZXh0cycsIGNvbnRleHRzKTtcblxuICBkYXRhLnNka1Byb2Nlc3NpbmdNZXRhZGF0YSA9IG1lcmdlLm1lcmdlKGRhdGEuc2RrUHJvY2Vzc2luZ01ldGFkYXRhLCBzZGtQcm9jZXNzaW5nTWV0YWRhdGEsIDIpO1xuXG4gIGlmIChsZXZlbCkge1xuICAgIGRhdGEubGV2ZWwgPSBsZXZlbDtcbiAgfVxuXG4gIGlmICh0cmFuc2FjdGlvbk5hbWUpIHtcbiAgICBkYXRhLnRyYW5zYWN0aW9uTmFtZSA9IHRyYW5zYWN0aW9uTmFtZTtcbiAgfVxuXG4gIGlmIChzcGFuKSB7XG4gICAgZGF0YS5zcGFuID0gc3BhbjtcbiAgfVxuXG4gIGlmIChicmVhZGNydW1icy5sZW5ndGgpIHtcbiAgICBkYXRhLmJyZWFkY3J1bWJzID0gWy4uLmRhdGEuYnJlYWRjcnVtYnMsIC4uLmJyZWFkY3J1bWJzXTtcbiAgfVxuXG4gIGlmIChmaW5nZXJwcmludC5sZW5ndGgpIHtcbiAgICBkYXRhLmZpbmdlcnByaW50ID0gWy4uLmRhdGEuZmluZ2VycHJpbnQsIC4uLmZpbmdlcnByaW50XTtcbiAgfVxuXG4gIGlmIChldmVudFByb2Nlc3NvcnMubGVuZ3RoKSB7XG4gICAgZGF0YS5ldmVudFByb2Nlc3NvcnMgPSBbLi4uZGF0YS5ldmVudFByb2Nlc3NvcnMsIC4uLmV2ZW50UHJvY2Vzc29yc107XG4gIH1cblxuICBpZiAoYXR0YWNobWVudHMubGVuZ3RoKSB7XG4gICAgZGF0YS5hdHRhY2htZW50cyA9IFsuLi5kYXRhLmF0dGFjaG1lbnRzLCAuLi5hdHRhY2htZW50c107XG4gIH1cblxuICBkYXRhLnByb3BhZ2F0aW9uQ29udGV4dCA9IHsgLi4uZGF0YS5wcm9wYWdhdGlvbkNvbnRleHQsIC4uLnByb3BhZ2F0aW9uQ29udGV4dCB9O1xufVxuXG4vKipcbiAqIE1lcmdlcyBjZXJ0YWluIHNjb3BlIGRhdGEuIFVuZGVmaW5lZCB2YWx1ZXMgd2lsbCBvdmVyd3JpdGUgYW55IGV4aXN0aW5nIHZhbHVlcy5cbiAqIEV4cG9ydGVkIG9ubHkgZm9yIHRlc3RzLlxuICovXG5mdW5jdGlvbiBtZXJnZUFuZE92ZXJ3cml0ZVNjb3BlRGF0YVxuXG4oZGF0YSwgcHJvcCwgbWVyZ2VWYWwpIHtcbiAgZGF0YVtwcm9wXSA9IG1lcmdlLm1lcmdlKGRhdGFbcHJvcF0sIG1lcmdlVmFsLCAxKTtcbn1cblxuZnVuY3Rpb24gYXBwbHlEYXRhVG9FdmVudChldmVudCwgZGF0YSkge1xuICBjb25zdCB7IGV4dHJhLCB0YWdzLCB1c2VyLCBjb250ZXh0cywgbGV2ZWwsIHRyYW5zYWN0aW9uTmFtZSB9ID0gZGF0YTtcblxuICBpZiAoT2JqZWN0LmtleXMoZXh0cmEpLmxlbmd0aCkge1xuICAgIGV2ZW50LmV4dHJhID0geyAuLi5leHRyYSwgLi4uZXZlbnQuZXh0cmEgfTtcbiAgfVxuXG4gIGlmIChPYmplY3Qua2V5cyh0YWdzKS5sZW5ndGgpIHtcbiAgICBldmVudC50YWdzID0geyAuLi50YWdzLCAuLi5ldmVudC50YWdzIH07XG4gIH1cblxuICBpZiAoT2JqZWN0LmtleXModXNlcikubGVuZ3RoKSB7XG4gICAgZXZlbnQudXNlciA9IHsgLi4udXNlciwgLi4uZXZlbnQudXNlciB9O1xuICB9XG5cbiAgaWYgKE9iamVjdC5rZXlzKGNvbnRleHRzKS5sZW5ndGgpIHtcbiAgICBldmVudC5jb250ZXh0cyA9IHsgLi4uY29udGV4dHMsIC4uLmV2ZW50LmNvbnRleHRzIH07XG4gIH1cblxuICBpZiAobGV2ZWwpIHtcbiAgICBldmVudC5sZXZlbCA9IGxldmVsO1xuICB9XG5cbiAgLy8gdHJhbnNhY3Rpb24gZXZlbnRzIGdldCB0aGVpciBgdHJhbnNhY3Rpb25gIGZyb20gdGhlIHJvb3Qgc3BhbiBuYW1lXG4gIGlmICh0cmFuc2FjdGlvbk5hbWUgJiYgZXZlbnQudHlwZSAhPT0gJ3RyYW5zYWN0aW9uJykge1xuICAgIGV2ZW50LnRyYW5zYWN0aW9uID0gdHJhbnNhY3Rpb25OYW1lO1xuICB9XG59XG5cbmZ1bmN0aW9uIGFwcGx5QnJlYWRjcnVtYnNUb0V2ZW50KGV2ZW50LCBicmVhZGNydW1icykge1xuICBjb25zdCBtZXJnZWRCcmVhZGNydW1icyA9IFsuLi4oZXZlbnQuYnJlYWRjcnVtYnMgfHwgW10pLCAuLi5icmVhZGNydW1ic107XG4gIGV2ZW50LmJyZWFkY3J1bWJzID0gbWVyZ2VkQnJlYWRjcnVtYnMubGVuZ3RoID8gbWVyZ2VkQnJlYWRjcnVtYnMgOiB1bmRlZmluZWQ7XG59XG5cbmZ1bmN0aW9uIGFwcGx5U2RrTWV0YWRhdGFUb0V2ZW50KGV2ZW50LCBzZGtQcm9jZXNzaW5nTWV0YWRhdGEpIHtcbiAgZXZlbnQuc2RrUHJvY2Vzc2luZ01ldGFkYXRhID0ge1xuICAgIC4uLmV2ZW50LnNka1Byb2Nlc3NpbmdNZXRhZGF0YSxcbiAgICAuLi5zZGtQcm9jZXNzaW5nTWV0YWRhdGEsXG4gIH07XG59XG5cbmZ1bmN0aW9uIGFwcGx5U3BhblRvRXZlbnQoZXZlbnQsIHNwYW4pIHtcbiAgZXZlbnQuY29udGV4dHMgPSB7XG4gICAgdHJhY2U6IHNwYW5VdGlscy5zcGFuVG9UcmFjZUNvbnRleHQoc3BhbiksXG4gICAgLi4uZXZlbnQuY29udGV4dHMsXG4gIH07XG5cbiAgZXZlbnQuc2RrUHJvY2Vzc2luZ01ldGFkYXRhID0ge1xuICAgIGR5bmFtaWNTYW1wbGluZ0NvbnRleHQ6IGR5bmFtaWNTYW1wbGluZ0NvbnRleHQuZ2V0RHluYW1pY1NhbXBsaW5nQ29udGV4dEZyb21TcGFuKHNwYW4pLFxuICAgIC4uLmV2ZW50LnNka1Byb2Nlc3NpbmdNZXRhZGF0YSxcbiAgfTtcblxuICBjb25zdCByb290U3BhbiA9IHNwYW5VdGlscy5nZXRSb290U3BhbihzcGFuKTtcbiAgY29uc3QgdHJhbnNhY3Rpb25OYW1lID0gc3BhblV0aWxzLnNwYW5Ub0pTT04ocm9vdFNwYW4pLmRlc2NyaXB0aW9uO1xuICBpZiAodHJhbnNhY3Rpb25OYW1lICYmICFldmVudC50cmFuc2FjdGlvbiAmJiBldmVudC50eXBlID09PSAndHJhbnNhY3Rpb24nKSB7XG4gICAgZXZlbnQudHJhbnNhY3Rpb24gPSB0cmFuc2FjdGlvbk5hbWU7XG4gIH1cbn1cblxuLyoqXG4gKiBBcHBsaWVzIGZpbmdlcnByaW50IGZyb20gdGhlIHNjb3BlIHRvIHRoZSBldmVudCBpZiB0aGVyZSdzIG9uZSxcbiAqIHVzZXMgbWVzc2FnZSBpZiB0aGVyZSdzIG9uZSBpbnN0ZWFkIG9yIGdldCByaWQgb2YgZW1wdHkgZmluZ2VycHJpbnRcbiAqL1xuZnVuY3Rpb24gYXBwbHlGaW5nZXJwcmludFRvRXZlbnQoZXZlbnQsIGZpbmdlcnByaW50KSB7XG4gIC8vIE1ha2Ugc3VyZSBpdCdzIGFuIGFycmF5IGZpcnN0IGFuZCB3ZSBhY3R1YWxseSBoYXZlIHNvbWV0aGluZyBpbiBwbGFjZVxuICBldmVudC5maW5nZXJwcmludCA9IGV2ZW50LmZpbmdlcnByaW50XG4gICAgPyBBcnJheS5pc0FycmF5KGV2ZW50LmZpbmdlcnByaW50KVxuICAgICAgPyBldmVudC5maW5nZXJwcmludFxuICAgICAgOiBbZXZlbnQuZmluZ2VycHJpbnRdXG4gICAgOiBbXTtcblxuICAvLyBJZiB3ZSBoYXZlIHNvbWV0aGluZyBvbiB0aGUgc2NvcGUsIHRoZW4gbWVyZ2UgaXQgd2l0aCBldmVudFxuICBpZiAoZmluZ2VycHJpbnQpIHtcbiAgICBldmVudC5maW5nZXJwcmludCA9IGV2ZW50LmZpbmdlcnByaW50LmNvbmNhdChmaW5nZXJwcmludCk7XG4gIH1cblxuICAvLyBJZiB3ZSBoYXZlIG5vIGRhdGEgYXQgYWxsLCByZW1vdmUgZW1wdHkgYXJyYXkgZGVmYXVsdFxuICBpZiAoIWV2ZW50LmZpbmdlcnByaW50Lmxlbmd0aCkge1xuICAgIGRlbGV0ZSBldmVudC5maW5nZXJwcmludDtcbiAgfVxufVxuXG5leHBvcnRzLmFwcGx5U2NvcGVEYXRhVG9FdmVudCA9IGFwcGx5U2NvcGVEYXRhVG9FdmVudDtcbmV4cG9ydHMubWVyZ2VBbmRPdmVyd3JpdGVTY29wZURhdGEgPSBtZXJnZUFuZE92ZXJ3cml0ZVNjb3BlRGF0YTtcbmV4cG9ydHMubWVyZ2VTY29wZURhdGEgPSBtZXJnZVNjb3BlRGF0YTtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWFwcGx5U2NvcGVEYXRhVG9FdmVudC5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/applyScopeDataToEvent.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/baggage.js":
/*!*****************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/baggage.js ***!
  \*****************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst debugBuild = __webpack_require__(/*! ../debug-build.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst debugLogger = __webpack_require__(/*! ./debug-logger.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst is = __webpack_require__(/*! ./is.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js\");\n\nconst SENTRY_BAGGAGE_KEY_PREFIX = 'sentry-';\n\nconst SENTRY_BAGGAGE_KEY_PREFIX_REGEX = /^sentry-/;\n\n/**\n * Max length of a serialized baggage string\n *\n * https://www.w3.org/TR/baggage/#limits\n */\nconst MAX_BAGGAGE_STRING_LENGTH = 8192;\n\n/**\n * Takes a baggage header and turns it into Dynamic Sampling Context, by extracting all the \"sentry-\" prefixed values\n * from it.\n *\n * @param baggageHeader A very bread definition of a baggage header as it might appear in various frameworks.\n * @returns The Dynamic Sampling Context that was found on `baggageHeader`, if there was any, `undefined` otherwise.\n */\nfunction baggageHeaderToDynamicSamplingContext(\n  // Very liberal definition of what any incoming header might look like\n  baggageHeader,\n) {\n  const baggageObject = parseBaggageHeader(baggageHeader);\n\n  if (!baggageObject) {\n    return undefined;\n  }\n\n  // Read all \"sentry-\" prefixed values out of the baggage object and put it onto a dynamic sampling context object.\n  const dynamicSamplingContext = Object.entries(baggageObject).reduce((acc, [key, value]) => {\n    if (key.match(SENTRY_BAGGAGE_KEY_PREFIX_REGEX)) {\n      const nonPrefixedKey = key.slice(SENTRY_BAGGAGE_KEY_PREFIX.length);\n      acc[nonPrefixedKey] = value;\n    }\n    return acc;\n  }, {});\n\n  // Only return a dynamic sampling context object if there are keys in it.\n  // A keyless object means there were no sentry values on the header, which means that there is no DSC.\n  if (Object.keys(dynamicSamplingContext).length > 0) {\n    return dynamicSamplingContext ;\n  } else {\n    return undefined;\n  }\n}\n\n/**\n * Turns a Dynamic Sampling Object into a baggage header by prefixing all the keys on the object with \"sentry-\".\n *\n * @param dynamicSamplingContext The Dynamic Sampling Context to turn into a header. For convenience and compatibility\n * with the `getDynamicSamplingContext` method on the Transaction class ,this argument can also be `undefined`. If it is\n * `undefined` the function will return `undefined`.\n * @returns a baggage header, created from `dynamicSamplingContext`, or `undefined` either if `dynamicSamplingContext`\n * was `undefined`, or if `dynamicSamplingContext` didn't contain any values.\n */\nfunction dynamicSamplingContextToSentryBaggageHeader(\n  // this also takes undefined for convenience and bundle size in other places\n  dynamicSamplingContext,\n) {\n  if (!dynamicSamplingContext) {\n    return undefined;\n  }\n\n  // Prefix all DSC keys with \"sentry-\" and put them into a new object\n  const sentryPrefixedDSC = Object.entries(dynamicSamplingContext).reduce(\n    (acc, [dscKey, dscValue]) => {\n      if (dscValue) {\n        acc[`${SENTRY_BAGGAGE_KEY_PREFIX}${dscKey}`] = dscValue;\n      }\n      return acc;\n    },\n    {},\n  );\n\n  return objectToBaggageHeader(sentryPrefixedDSC);\n}\n\n/**\n * Take a baggage header and parse it into an object.\n */\nfunction parseBaggageHeader(\n  baggageHeader,\n) {\n  if (!baggageHeader || (!is.isString(baggageHeader) && !Array.isArray(baggageHeader))) {\n    return undefined;\n  }\n\n  if (Array.isArray(baggageHeader)) {\n    // Combine all baggage headers into one object containing the baggage values so we can later read the Sentry-DSC-values from it\n    return baggageHeader.reduce((acc, curr) => {\n      const currBaggageObject = baggageHeaderToObject(curr);\n      Object.entries(currBaggageObject).forEach(([key, value]) => {\n        acc[key] = value;\n      });\n      return acc;\n    }, {});\n  }\n\n  return baggageHeaderToObject(baggageHeader);\n}\n\n/**\n * Will parse a baggage header, which is a simple key-value map, into a flat object.\n *\n * @param baggageHeader The baggage header to parse.\n * @returns a flat object containing all the key-value pairs from `baggageHeader`.\n */\nfunction baggageHeaderToObject(baggageHeader) {\n  return baggageHeader\n    .split(',')\n    .map(baggageEntry =>\n      baggageEntry.split('=').map(keyOrValue => {\n        try {\n          return decodeURIComponent(keyOrValue.trim());\n        } catch {\n          // We ignore errors here, e.g. if the value cannot be URL decoded.\n          // This will then be skipped in the next step\n          return;\n        }\n      }),\n    )\n    .reduce((acc, [key, value]) => {\n      if (key && value) {\n        acc[key] = value;\n      }\n      return acc;\n    }, {});\n}\n\n/**\n * Turns a flat object (key-value pairs) into a baggage header, which is also just key-value pairs.\n *\n * @param object The object to turn into a baggage header.\n * @returns a baggage header string, or `undefined` if the object didn't have any values, since an empty baggage header\n * is not spec compliant.\n */\nfunction objectToBaggageHeader(object) {\n  if (Object.keys(object).length === 0) {\n    // An empty baggage header is not spec compliant: We return undefined.\n    return undefined;\n  }\n\n  return Object.entries(object).reduce((baggageHeader, [objectKey, objectValue], currentIndex) => {\n    const baggageEntry = `${encodeURIComponent(objectKey)}=${encodeURIComponent(objectValue)}`;\n    const newBaggageHeader = currentIndex === 0 ? baggageEntry : `${baggageHeader},${baggageEntry}`;\n    if (newBaggageHeader.length > MAX_BAGGAGE_STRING_LENGTH) {\n      debugBuild.DEBUG_BUILD &&\n        debugLogger.debug.warn(\n          `Not adding key: ${objectKey} with val: ${objectValue} to baggage header due to exceeding baggage size limits.`,\n        );\n      return baggageHeader;\n    } else {\n      return newBaggageHeader;\n    }\n  }, '');\n}\n\nexports.MAX_BAGGAGE_STRING_LENGTH = MAX_BAGGAGE_STRING_LENGTH;\nexports.SENTRY_BAGGAGE_KEY_PREFIX = SENTRY_BAGGAGE_KEY_PREFIX;\nexports.SENTRY_BAGGAGE_KEY_PREFIX_REGEX = SENTRY_BAGGAGE_KEY_PREFIX_REGEX;\nexports.baggageHeaderToDynamicSamplingContext = baggageHeaderToDynamicSamplingContext;\nexports.dynamicSamplingContextToSentryBaggageHeader = dynamicSamplingContextToSentryBaggageHeader;\nexports.objectToBaggageHeader = objectToBaggageHeader;\nexports.parseBaggageHeader = parseBaggageHeader;\n//# sourceMappingURL=baggage.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9iYWdnYWdlLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLG1CQUFtQixtQkFBTyxDQUFDLDRIQUFtQjtBQUM5QyxvQkFBb0IsbUJBQU8sQ0FBQyxtSUFBbUI7QUFDL0MsV0FBVyxtQkFBTyxDQUFDLCtHQUFTOztBQUU1Qjs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEdBQUcsSUFBSTs7QUFFUDtBQUNBO0FBQ0E7QUFDQTtBQUNBLElBQUk7QUFDSjtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQSxlQUFlLDBCQUEwQixFQUFFLE9BQU87QUFDbEQ7QUFDQTtBQUNBLEtBQUs7QUFDTCxNQUFNO0FBQ047O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsT0FBTztBQUNQO0FBQ0EsS0FBSyxJQUFJO0FBQ1Q7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFVBQVU7QUFDVjtBQUNBO0FBQ0E7QUFDQTtBQUNBLE9BQU87QUFDUDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxLQUFLLElBQUk7QUFDVDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQSw0QkFBNEIsOEJBQThCLEdBQUcsZ0NBQWdDO0FBQzdGLG9FQUFvRSxjQUFjLEdBQUcsYUFBYTtBQUNsRztBQUNBO0FBQ0E7QUFDQSw2QkFBNkIsV0FBVyxZQUFZLGFBQWE7QUFDakU7QUFDQTtBQUNBLE1BQU07QUFDTjtBQUNBO0FBQ0EsR0FBRztBQUNIOztBQUVBLGlDQUFpQztBQUNqQyxpQ0FBaUM7QUFDakMsdUNBQXVDO0FBQ3ZDLDZDQUE2QztBQUM3QyxtREFBbUQ7QUFDbkQsNkJBQTZCO0FBQzdCLDBCQUEwQjtBQUMxQiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3V0aWxzL2JhZ2dhZ2UuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGRlYnVnQnVpbGQgPSByZXF1aXJlKCcuLi9kZWJ1Zy1idWlsZC5qcycpO1xuY29uc3QgZGVidWdMb2dnZXIgPSByZXF1aXJlKCcuL2RlYnVnLWxvZ2dlci5qcycpO1xuY29uc3QgaXMgPSByZXF1aXJlKCcuL2lzLmpzJyk7XG5cbmNvbnN0IFNFTlRSWV9CQUdHQUdFX0tFWV9QUkVGSVggPSAnc2VudHJ5LSc7XG5cbmNvbnN0IFNFTlRSWV9CQUdHQUdFX0tFWV9QUkVGSVhfUkVHRVggPSAvXnNlbnRyeS0vO1xuXG4vKipcbiAqIE1heCBsZW5ndGggb2YgYSBzZXJpYWxpemVkIGJhZ2dhZ2Ugc3RyaW5nXG4gKlxuICogaHR0cHM6Ly93d3cudzMub3JnL1RSL2JhZ2dhZ2UvI2xpbWl0c1xuICovXG5jb25zdCBNQVhfQkFHR0FHRV9TVFJJTkdfTEVOR1RIID0gODE5MjtcblxuLyoqXG4gKiBUYWtlcyBhIGJhZ2dhZ2UgaGVhZGVyIGFuZCB0dXJucyBpdCBpbnRvIER5bmFtaWMgU2FtcGxpbmcgQ29udGV4dCwgYnkgZXh0cmFjdGluZyBhbGwgdGhlIFwic2VudHJ5LVwiIHByZWZpeGVkIHZhbHVlc1xuICogZnJvbSBpdC5cbiAqXG4gKiBAcGFyYW0gYmFnZ2FnZUhlYWRlciBBIHZlcnkgYnJlYWQgZGVmaW5pdGlvbiBvZiBhIGJhZ2dhZ2UgaGVhZGVyIGFzIGl0IG1pZ2h0IGFwcGVhciBpbiB2YXJpb3VzIGZyYW1ld29ya3MuXG4gKiBAcmV0dXJucyBUaGUgRHluYW1pYyBTYW1wbGluZyBDb250ZXh0IHRoYXQgd2FzIGZvdW5kIG9uIGBiYWdnYWdlSGVhZGVyYCwgaWYgdGhlcmUgd2FzIGFueSwgYHVuZGVmaW5lZGAgb3RoZXJ3aXNlLlxuICovXG5mdW5jdGlvbiBiYWdnYWdlSGVhZGVyVG9EeW5hbWljU2FtcGxpbmdDb250ZXh0KFxuICAvLyBWZXJ5IGxpYmVyYWwgZGVmaW5pdGlvbiBvZiB3aGF0IGFueSBpbmNvbWluZyBoZWFkZXIgbWlnaHQgbG9vayBsaWtlXG4gIGJhZ2dhZ2VIZWFkZXIsXG4pIHtcbiAgY29uc3QgYmFnZ2FnZU9iamVjdCA9IHBhcnNlQmFnZ2FnZUhlYWRlcihiYWdnYWdlSGVhZGVyKTtcblxuICBpZiAoIWJhZ2dhZ2VPYmplY3QpIHtcbiAgICByZXR1cm4gdW5kZWZpbmVkO1xuICB9XG5cbiAgLy8gUmVhZCBhbGwgXCJzZW50cnktXCIgcHJlZml4ZWQgdmFsdWVzIG91dCBvZiB0aGUgYmFnZ2FnZSBvYmplY3QgYW5kIHB1dCBpdCBvbnRvIGEgZHluYW1pYyBzYW1wbGluZyBjb250ZXh0IG9iamVjdC5cbiAgY29uc3QgZHluYW1pY1NhbXBsaW5nQ29udGV4dCA9IE9iamVjdC5lbnRyaWVzKGJhZ2dhZ2VPYmplY3QpLnJlZHVjZSgoYWNjLCBba2V5LCB2YWx1ZV0pID0+IHtcbiAgICBpZiAoa2V5Lm1hdGNoKFNFTlRSWV9CQUdHQUdFX0tFWV9QUkVGSVhfUkVHRVgpKSB7XG4gICAgICBjb25zdCBub25QcmVmaXhlZEtleSA9IGtleS5zbGljZShTRU5UUllfQkFHR0FHRV9LRVlfUFJFRklYLmxlbmd0aCk7XG4gICAgICBhY2Nbbm9uUHJlZml4ZWRLZXldID0gdmFsdWU7XG4gICAgfVxuICAgIHJldHVybiBhY2M7XG4gIH0sIHt9KTtcblxuICAvLyBPbmx5IHJldHVybiBhIGR5bmFtaWMgc2FtcGxpbmcgY29udGV4dCBvYmplY3QgaWYgdGhlcmUgYXJlIGtleXMgaW4gaXQuXG4gIC8vIEEga2V5bGVzcyBvYmplY3QgbWVhbnMgdGhlcmUgd2VyZSBubyBzZW50cnkgdmFsdWVzIG9uIHRoZSBoZWFkZXIsIHdoaWNoIG1lYW5zIHRoYXQgdGhlcmUgaXMgbm8gRFNDLlxuICBpZiAoT2JqZWN0LmtleXMoZHluYW1pY1NhbXBsaW5nQ29udGV4dCkubGVuZ3RoID4gMCkge1xuICAgIHJldHVybiBkeW5hbWljU2FtcGxpbmdDb250ZXh0IDtcbiAgfSBlbHNlIHtcbiAgICByZXR1cm4gdW5kZWZpbmVkO1xuICB9XG59XG5cbi8qKlxuICogVHVybnMgYSBEeW5hbWljIFNhbXBsaW5nIE9iamVjdCBpbnRvIGEgYmFnZ2FnZSBoZWFkZXIgYnkgcHJlZml4aW5nIGFsbCB0aGUga2V5cyBvbiB0aGUgb2JqZWN0IHdpdGggXCJzZW50cnktXCIuXG4gKlxuICogQHBhcmFtIGR5bmFtaWNTYW1wbGluZ0NvbnRleHQgVGhlIER5bmFtaWMgU2FtcGxpbmcgQ29udGV4dCB0byB0dXJuIGludG8gYSBoZWFkZXIuIEZvciBjb252ZW5pZW5jZSBhbmQgY29tcGF0aWJpbGl0eVxuICogd2l0aCB0aGUgYGdldER5bmFtaWNTYW1wbGluZ0NvbnRleHRgIG1ldGhvZCBvbiB0aGUgVHJhbnNhY3Rpb24gY2xhc3MgLHRoaXMgYXJndW1lbnQgY2FuIGFsc28gYmUgYHVuZGVmaW5lZGAuIElmIGl0IGlzXG4gKiBgdW5kZWZpbmVkYCB0aGUgZnVuY3Rpb24gd2lsbCByZXR1cm4gYHVuZGVmaW5lZGAuXG4gKiBAcmV0dXJucyBhIGJhZ2dhZ2UgaGVhZGVyLCBjcmVhdGVkIGZyb20gYGR5bmFtaWNTYW1wbGluZ0NvbnRleHRgLCBvciBgdW5kZWZpbmVkYCBlaXRoZXIgaWYgYGR5bmFtaWNTYW1wbGluZ0NvbnRleHRgXG4gKiB3YXMgYHVuZGVmaW5lZGAsIG9yIGlmIGBkeW5hbWljU2FtcGxpbmdDb250ZXh0YCBkaWRuJ3QgY29udGFpbiBhbnkgdmFsdWVzLlxuICovXG5mdW5jdGlvbiBkeW5hbWljU2FtcGxpbmdDb250ZXh0VG9TZW50cnlCYWdnYWdlSGVhZGVyKFxuICAvLyB0aGlzIGFsc28gdGFrZXMgdW5kZWZpbmVkIGZvciBjb252ZW5pZW5jZSBhbmQgYnVuZGxlIHNpemUgaW4gb3RoZXIgcGxhY2VzXG4gIGR5bmFtaWNTYW1wbGluZ0NvbnRleHQsXG4pIHtcbiAgaWYgKCFkeW5hbWljU2FtcGxpbmdDb250ZXh0KSB7XG4gICAgcmV0dXJuIHVuZGVmaW5lZDtcbiAgfVxuXG4gIC8vIFByZWZpeCBhbGwgRFNDIGtleXMgd2l0aCBcInNlbnRyeS1cIiBhbmQgcHV0IHRoZW0gaW50byBhIG5ldyBvYmplY3RcbiAgY29uc3Qgc2VudHJ5UHJlZml4ZWREU0MgPSBPYmplY3QuZW50cmllcyhkeW5hbWljU2FtcGxpbmdDb250ZXh0KS5yZWR1Y2UoXG4gICAgKGFjYywgW2RzY0tleSwgZHNjVmFsdWVdKSA9PiB7XG4gICAgICBpZiAoZHNjVmFsdWUpIHtcbiAgICAgICAgYWNjW2Ake1NFTlRSWV9CQUdHQUdFX0tFWV9QUkVGSVh9JHtkc2NLZXl9YF0gPSBkc2NWYWx1ZTtcbiAgICAgIH1cbiAgICAgIHJldHVybiBhY2M7XG4gICAgfSxcbiAgICB7fSxcbiAgKTtcblxuICByZXR1cm4gb2JqZWN0VG9CYWdnYWdlSGVhZGVyKHNlbnRyeVByZWZpeGVkRFNDKTtcbn1cblxuLyoqXG4gKiBUYWtlIGEgYmFnZ2FnZSBoZWFkZXIgYW5kIHBhcnNlIGl0IGludG8gYW4gb2JqZWN0LlxuICovXG5mdW5jdGlvbiBwYXJzZUJhZ2dhZ2VIZWFkZXIoXG4gIGJhZ2dhZ2VIZWFkZXIsXG4pIHtcbiAgaWYgKCFiYWdnYWdlSGVhZGVyIHx8ICghaXMuaXNTdHJpbmcoYmFnZ2FnZUhlYWRlcikgJiYgIUFycmF5LmlzQXJyYXkoYmFnZ2FnZUhlYWRlcikpKSB7XG4gICAgcmV0dXJuIHVuZGVmaW5lZDtcbiAgfVxuXG4gIGlmIChBcnJheS5pc0FycmF5KGJhZ2dhZ2VIZWFkZXIpKSB7XG4gICAgLy8gQ29tYmluZSBhbGwgYmFnZ2FnZSBoZWFkZXJzIGludG8gb25lIG9iamVjdCBjb250YWluaW5nIHRoZSBiYWdnYWdlIHZhbHVlcyBzbyB3ZSBjYW4gbGF0ZXIgcmVhZCB0aGUgU2VudHJ5LURTQy12YWx1ZXMgZnJvbSBpdFxuICAgIHJldHVybiBiYWdnYWdlSGVhZGVyLnJlZHVjZSgoYWNjLCBjdXJyKSA9PiB7XG4gICAgICBjb25zdCBjdXJyQmFnZ2FnZU9iamVjdCA9IGJhZ2dhZ2VIZWFkZXJUb09iamVjdChjdXJyKTtcbiAgICAgIE9iamVjdC5lbnRyaWVzKGN1cnJCYWdnYWdlT2JqZWN0KS5mb3JFYWNoKChba2V5LCB2YWx1ZV0pID0+IHtcbiAgICAgICAgYWNjW2tleV0gPSB2YWx1ZTtcbiAgICAgIH0pO1xuICAgICAgcmV0dXJuIGFjYztcbiAgICB9LCB7fSk7XG4gIH1cblxuICByZXR1cm4gYmFnZ2FnZUhlYWRlclRvT2JqZWN0KGJhZ2dhZ2VIZWFkZXIpO1xufVxuXG4vKipcbiAqIFdpbGwgcGFyc2UgYSBiYWdnYWdlIGhlYWRlciwgd2hpY2ggaXMgYSBzaW1wbGUga2V5LXZhbHVlIG1hcCwgaW50byBhIGZsYXQgb2JqZWN0LlxuICpcbiAqIEBwYXJhbSBiYWdnYWdlSGVhZGVyIFRoZSBiYWdnYWdlIGhlYWRlciB0byBwYXJzZS5cbiAqIEByZXR1cm5zIGEgZmxhdCBvYmplY3QgY29udGFpbmluZyBhbGwgdGhlIGtleS12YWx1ZSBwYWlycyBmcm9tIGBiYWdnYWdlSGVhZGVyYC5cbiAqL1xuZnVuY3Rpb24gYmFnZ2FnZUhlYWRlclRvT2JqZWN0KGJhZ2dhZ2VIZWFkZXIpIHtcbiAgcmV0dXJuIGJhZ2dhZ2VIZWFkZXJcbiAgICAuc3BsaXQoJywnKVxuICAgIC5tYXAoYmFnZ2FnZUVudHJ5ID0+XG4gICAgICBiYWdnYWdlRW50cnkuc3BsaXQoJz0nKS5tYXAoa2V5T3JWYWx1ZSA9PiB7XG4gICAgICAgIHRyeSB7XG4gICAgICAgICAgcmV0dXJuIGRlY29kZVVSSUNvbXBvbmVudChrZXlPclZhbHVlLnRyaW0oKSk7XG4gICAgICAgIH0gY2F0Y2gge1xuICAgICAgICAgIC8vIFdlIGlnbm9yZSBlcnJvcnMgaGVyZSwgZS5nLiBpZiB0aGUgdmFsdWUgY2Fubm90IGJlIFVSTCBkZWNvZGVkLlxuICAgICAgICAgIC8vIFRoaXMgd2lsbCB0aGVuIGJlIHNraXBwZWQgaW4gdGhlIG5leHQgc3RlcFxuICAgICAgICAgIHJldHVybjtcbiAgICAgICAgfVxuICAgICAgfSksXG4gICAgKVxuICAgIC5yZWR1Y2UoKGFjYywgW2tleSwgdmFsdWVdKSA9PiB7XG4gICAgICBpZiAoa2V5ICYmIHZhbHVlKSB7XG4gICAgICAgIGFjY1trZXldID0gdmFsdWU7XG4gICAgICB9XG4gICAgICByZXR1cm4gYWNjO1xuICAgIH0sIHt9KTtcbn1cblxuLyoqXG4gKiBUdXJucyBhIGZsYXQgb2JqZWN0IChrZXktdmFsdWUgcGFpcnMpIGludG8gYSBiYWdnYWdlIGhlYWRlciwgd2hpY2ggaXMgYWxzbyBqdXN0IGtleS12YWx1ZSBwYWlycy5cbiAqXG4gKiBAcGFyYW0gb2JqZWN0IFRoZSBvYmplY3QgdG8gdHVybiBpbnRvIGEgYmFnZ2FnZSBoZWFkZXIuXG4gKiBAcmV0dXJucyBhIGJhZ2dhZ2UgaGVhZGVyIHN0cmluZywgb3IgYHVuZGVmaW5lZGAgaWYgdGhlIG9iamVjdCBkaWRuJ3QgaGF2ZSBhbnkgdmFsdWVzLCBzaW5jZSBhbiBlbXB0eSBiYWdnYWdlIGhlYWRlclxuICogaXMgbm90IHNwZWMgY29tcGxpYW50LlxuICovXG5mdW5jdGlvbiBvYmplY3RUb0JhZ2dhZ2VIZWFkZXIob2JqZWN0KSB7XG4gIGlmIChPYmplY3Qua2V5cyhvYmplY3QpLmxlbmd0aCA9PT0gMCkge1xuICAgIC8vIEFuIGVtcHR5IGJhZ2dhZ2UgaGVhZGVyIGlzIG5vdCBzcGVjIGNvbXBsaWFudDogV2UgcmV0dXJuIHVuZGVmaW5lZC5cbiAgICByZXR1cm4gdW5kZWZpbmVkO1xuICB9XG5cbiAgcmV0dXJuIE9iamVjdC5lbnRyaWVzKG9iamVjdCkucmVkdWNlKChiYWdnYWdlSGVhZGVyLCBbb2JqZWN0S2V5LCBvYmplY3RWYWx1ZV0sIGN1cnJlbnRJbmRleCkgPT4ge1xuICAgIGNvbnN0IGJhZ2dhZ2VFbnRyeSA9IGAke2VuY29kZVVSSUNvbXBvbmVudChvYmplY3RLZXkpfT0ke2VuY29kZVVSSUNvbXBvbmVudChvYmplY3RWYWx1ZSl9YDtcbiAgICBjb25zdCBuZXdCYWdnYWdlSGVhZGVyID0gY3VycmVudEluZGV4ID09PSAwID8gYmFnZ2FnZUVudHJ5IDogYCR7YmFnZ2FnZUhlYWRlcn0sJHtiYWdnYWdlRW50cnl9YDtcbiAgICBpZiAobmV3QmFnZ2FnZUhlYWRlci5sZW5ndGggPiBNQVhfQkFHR0FHRV9TVFJJTkdfTEVOR1RIKSB7XG4gICAgICBkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEICYmXG4gICAgICAgIGRlYnVnTG9nZ2VyLmRlYnVnLndhcm4oXG4gICAgICAgICAgYE5vdCBhZGRpbmcga2V5OiAke29iamVjdEtleX0gd2l0aCB2YWw6ICR7b2JqZWN0VmFsdWV9IHRvIGJhZ2dhZ2UgaGVhZGVyIGR1ZSB0byBleGNlZWRpbmcgYmFnZ2FnZSBzaXplIGxpbWl0cy5gLFxuICAgICAgICApO1xuICAgICAgcmV0dXJuIGJhZ2dhZ2VIZWFkZXI7XG4gICAgfSBlbHNlIHtcbiAgICAgIHJldHVybiBuZXdCYWdnYWdlSGVhZGVyO1xuICAgIH1cbiAgfSwgJycpO1xufVxuXG5leHBvcnRzLk1BWF9CQUdHQUdFX1NUUklOR19MRU5HVEggPSBNQVhfQkFHR0FHRV9TVFJJTkdfTEVOR1RIO1xuZXhwb3J0cy5TRU5UUllfQkFHR0FHRV9LRVlfUFJFRklYID0gU0VOVFJZX0JBR0dBR0VfS0VZX1BSRUZJWDtcbmV4cG9ydHMuU0VOVFJZX0JBR0dBR0VfS0VZX1BSRUZJWF9SRUdFWCA9IFNFTlRSWV9CQUdHQUdFX0tFWV9QUkVGSVhfUkVHRVg7XG5leHBvcnRzLmJhZ2dhZ2VIZWFkZXJUb0R5bmFtaWNTYW1wbGluZ0NvbnRleHQgPSBiYWdnYWdlSGVhZGVyVG9EeW5hbWljU2FtcGxpbmdDb250ZXh0O1xuZXhwb3J0cy5keW5hbWljU2FtcGxpbmdDb250ZXh0VG9TZW50cnlCYWdnYWdlSGVhZGVyID0gZHluYW1pY1NhbXBsaW5nQ29udGV4dFRvU2VudHJ5QmFnZ2FnZUhlYWRlcjtcbmV4cG9ydHMub2JqZWN0VG9CYWdnYWdlSGVhZGVyID0gb2JqZWN0VG9CYWdnYWdlSGVhZGVyO1xuZXhwb3J0cy5wYXJzZUJhZ2dhZ2VIZWFkZXIgPSBwYXJzZUJhZ2dhZ2VIZWFkZXI7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1iYWdnYWdlLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/baggage.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/breadcrumb-log-level.js":
/*!******************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/breadcrumb-log-level.js ***!
  \******************************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n/**\n * Determine a breadcrumb's log level (only `warning` or `error`) based on an HTTP status code.\n */\nfunction getBreadcrumbLogLevelFromHttpStatusCode(statusCode) {\n  // NOTE: undefined defaults to 'info' in Sentry\n  if (statusCode === undefined) {\n    return undefined;\n  } else if (statusCode >= 400 && statusCode < 500) {\n    return 'warning';\n  } else if (statusCode >= 500) {\n    return 'error';\n  } else {\n    return undefined;\n  }\n}\n\nexports.getBreadcrumbLogLevelFromHttpStatusCode = getBreadcrumbLogLevelFromHttpStatusCode;\n//# sourceMappingURL=breadcrumb-log-level.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9icmVhZGNydW1iLWxvZy1sZXZlbC5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLElBQUk7QUFDSjtBQUNBLElBQUk7QUFDSjtBQUNBLElBQUk7QUFDSjtBQUNBO0FBQ0E7O0FBRUEsK0NBQStDO0FBQy9DIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvYnJlYWRjcnVtYi1sb2ctbGV2ZWwuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbi8qKlxuICogRGV0ZXJtaW5lIGEgYnJlYWRjcnVtYidzIGxvZyBsZXZlbCAob25seSBgd2FybmluZ2Agb3IgYGVycm9yYCkgYmFzZWQgb24gYW4gSFRUUCBzdGF0dXMgY29kZS5cbiAqL1xuZnVuY3Rpb24gZ2V0QnJlYWRjcnVtYkxvZ0xldmVsRnJvbUh0dHBTdGF0dXNDb2RlKHN0YXR1c0NvZGUpIHtcbiAgLy8gTk9URTogdW5kZWZpbmVkIGRlZmF1bHRzIHRvICdpbmZvJyBpbiBTZW50cnlcbiAgaWYgKHN0YXR1c0NvZGUgPT09IHVuZGVmaW5lZCkge1xuICAgIHJldHVybiB1bmRlZmluZWQ7XG4gIH0gZWxzZSBpZiAoc3RhdHVzQ29kZSA+PSA0MDAgJiYgc3RhdHVzQ29kZSA8IDUwMCkge1xuICAgIHJldHVybiAnd2FybmluZyc7XG4gIH0gZWxzZSBpZiAoc3RhdHVzQ29kZSA+PSA1MDApIHtcbiAgICByZXR1cm4gJ2Vycm9yJztcbiAgfSBlbHNlIHtcbiAgICByZXR1cm4gdW5kZWZpbmVkO1xuICB9XG59XG5cbmV4cG9ydHMuZ2V0QnJlYWRjcnVtYkxvZ0xldmVsRnJvbUh0dHBTdGF0dXNDb2RlID0gZ2V0QnJlYWRjcnVtYkxvZ0xldmVsRnJvbUh0dHBTdGF0dXNDb2RlO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9YnJlYWRjcnVtYi1sb2ctbGV2ZWwuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/breadcrumb-log-level.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/browser.js":
/*!*****************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/browser.js ***!
  \*****************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst is = __webpack_require__(/*! ./is.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js\");\nconst worldwide = __webpack_require__(/*! ./worldwide.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/worldwide.js\");\n\nconst WINDOW = worldwide.GLOBAL_OBJ ;\n\nconst DEFAULT_MAX_STRING_LENGTH = 80;\n\n/**\n * Given a child DOM element, returns a query-selector statement describing that\n * and its ancestors\n * e.g. [HTMLElement] => body > div > input#foo.btn[name=baz]\n * @returns generated DOM path\n */\nfunction htmlTreeAsString(\n  elem,\n  options = {},\n) {\n  if (!elem) {\n    return '<unknown>';\n  }\n\n  // try/catch both:\n  // - accessing event.target (see getsentry/raven-js#838, #768)\n  // - `htmlTreeAsString` because it's complex, and just accessing the DOM incorrectly\n  // - can throw an exception in some circumstances.\n  try {\n    let currentElem = elem ;\n    const MAX_TRAVERSE_HEIGHT = 5;\n    const out = [];\n    let height = 0;\n    let len = 0;\n    const separator = ' > ';\n    const sepLength = separator.length;\n    let nextStr;\n    const keyAttrs = Array.isArray(options) ? options : options.keyAttrs;\n    const maxStringLength = (!Array.isArray(options) && options.maxStringLength) || DEFAULT_MAX_STRING_LENGTH;\n\n    while (currentElem && height++ < MAX_TRAVERSE_HEIGHT) {\n      nextStr = _htmlElementAsString(currentElem, keyAttrs);\n      // bail out if\n      // - nextStr is the 'html' element\n      // - the length of the string that would be created exceeds maxStringLength\n      //   (ignore this limit if we are on the first iteration)\n      if (nextStr === 'html' || (height > 1 && len + out.length * sepLength + nextStr.length >= maxStringLength)) {\n        break;\n      }\n\n      out.push(nextStr);\n\n      len += nextStr.length;\n      currentElem = currentElem.parentNode;\n    }\n\n    return out.reverse().join(separator);\n  } catch {\n    return '<unknown>';\n  }\n}\n\n/**\n * Returns a simple, query-selector representation of a DOM element\n * e.g. [HTMLElement] => input#foo.btn[name=baz]\n * @returns generated DOM path\n */\nfunction _htmlElementAsString(el, keyAttrs) {\n  const elem = el\n\n;\n\n  const out = [];\n\n  if (!elem?.tagName) {\n    return '';\n  }\n\n  // @ts-expect-error WINDOW has HTMLElement\n  if (WINDOW.HTMLElement) {\n    // If using the component name annotation plugin, this value may be available on the DOM node\n    if (elem instanceof HTMLElement && elem.dataset) {\n      if (elem.dataset['sentryComponent']) {\n        return elem.dataset['sentryComponent'];\n      }\n      if (elem.dataset['sentryElement']) {\n        return elem.dataset['sentryElement'];\n      }\n    }\n  }\n\n  out.push(elem.tagName.toLowerCase());\n\n  // Pairs of attribute keys defined in `serializeAttribute` and their values on element.\n  const keyAttrPairs = keyAttrs?.length\n    ? keyAttrs.filter(keyAttr => elem.getAttribute(keyAttr)).map(keyAttr => [keyAttr, elem.getAttribute(keyAttr)])\n    : null;\n\n  if (keyAttrPairs?.length) {\n    keyAttrPairs.forEach(keyAttrPair => {\n      out.push(`[${keyAttrPair[0]}=\"${keyAttrPair[1]}\"]`);\n    });\n  } else {\n    if (elem.id) {\n      out.push(`#${elem.id}`);\n    }\n\n    const className = elem.className;\n    if (className && is.isString(className)) {\n      const classes = className.split(/\\s+/);\n      for (const c of classes) {\n        out.push(`.${c}`);\n      }\n    }\n  }\n  const allowedAttrs = ['aria-label', 'type', 'name', 'title', 'alt'];\n  for (const k of allowedAttrs) {\n    const attr = elem.getAttribute(k);\n    if (attr) {\n      out.push(`[${k}=\"${attr}\"]`);\n    }\n  }\n\n  return out.join('');\n}\n\n/**\n * A safe form of location.href\n */\nfunction getLocationHref() {\n  try {\n    return WINDOW.document.location.href;\n  } catch {\n    return '';\n  }\n}\n\n/**\n * Given a DOM element, traverses up the tree until it finds the first ancestor node\n * that has the `data-sentry-component` or `data-sentry-element` attribute with `data-sentry-component` taking\n * precedence. This attribute is added at build-time by projects that have the component name annotation plugin installed.\n *\n * @returns a string representation of the component for the provided DOM element, or `null` if not found\n */\nfunction getComponentName(elem) {\n  // @ts-expect-error WINDOW has HTMLElement\n  if (!WINDOW.HTMLElement) {\n    return null;\n  }\n\n  let currentElem = elem ;\n  const MAX_TRAVERSE_HEIGHT = 5;\n  for (let i = 0; i < MAX_TRAVERSE_HEIGHT; i++) {\n    if (!currentElem) {\n      return null;\n    }\n\n    if (currentElem instanceof HTMLElement) {\n      if (currentElem.dataset['sentryComponent']) {\n        return currentElem.dataset['sentryComponent'];\n      }\n      if (currentElem.dataset['sentryElement']) {\n        return currentElem.dataset['sentryElement'];\n      }\n    }\n\n    currentElem = currentElem.parentNode;\n  }\n\n  return null;\n}\n\nexports.getComponentName = getComponentName;\nexports.getLocationHref = getLocationHref;\nexports.htmlTreeAsString = htmlTreeAsString;\n//# sourceMappingURL=browser.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9icm93c2VyLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLFdBQVcsbUJBQU8sQ0FBQywrR0FBUztBQUM1QixrQkFBa0IsbUJBQU8sQ0FBQyw2SEFBZ0I7O0FBRTFDOztBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxjQUFjO0FBQ2Q7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQSxJQUFJO0FBQ0o7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLG1CQUFtQixlQUFlLElBQUksZUFBZTtBQUNyRCxLQUFLO0FBQ0wsSUFBSTtBQUNKO0FBQ0EsbUJBQW1CLFFBQVE7QUFDM0I7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQSxxQkFBcUIsRUFBRTtBQUN2QjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLG1CQUFtQixFQUFFLElBQUksS0FBSztBQUM5QjtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsSUFBSTtBQUNKO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLGtCQUFrQix5QkFBeUI7QUFDM0M7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBOztBQUVBLHdCQUF3QjtBQUN4Qix1QkFBdUI7QUFDdkIsd0JBQXdCO0FBQ3hCIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvYnJvd3Nlci5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgaXMgPSByZXF1aXJlKCcuL2lzLmpzJyk7XG5jb25zdCB3b3JsZHdpZGUgPSByZXF1aXJlKCcuL3dvcmxkd2lkZS5qcycpO1xuXG5jb25zdCBXSU5ET1cgPSB3b3JsZHdpZGUuR0xPQkFMX09CSiA7XG5cbmNvbnN0IERFRkFVTFRfTUFYX1NUUklOR19MRU5HVEggPSA4MDtcblxuLyoqXG4gKiBHaXZlbiBhIGNoaWxkIERPTSBlbGVtZW50LCByZXR1cm5zIGEgcXVlcnktc2VsZWN0b3Igc3RhdGVtZW50IGRlc2NyaWJpbmcgdGhhdFxuICogYW5kIGl0cyBhbmNlc3RvcnNcbiAqIGUuZy4gW0hUTUxFbGVtZW50XSA9PiBib2R5ID4gZGl2ID4gaW5wdXQjZm9vLmJ0bltuYW1lPWJhel1cbiAqIEByZXR1cm5zIGdlbmVyYXRlZCBET00gcGF0aFxuICovXG5mdW5jdGlvbiBodG1sVHJlZUFzU3RyaW5nKFxuICBlbGVtLFxuICBvcHRpb25zID0ge30sXG4pIHtcbiAgaWYgKCFlbGVtKSB7XG4gICAgcmV0dXJuICc8dW5rbm93bj4nO1xuICB9XG5cbiAgLy8gdHJ5L2NhdGNoIGJvdGg6XG4gIC8vIC0gYWNjZXNzaW5nIGV2ZW50LnRhcmdldCAoc2VlIGdldHNlbnRyeS9yYXZlbi1qcyM4MzgsICM3NjgpXG4gIC8vIC0gYGh0bWxUcmVlQXNTdHJpbmdgIGJlY2F1c2UgaXQncyBjb21wbGV4LCBhbmQganVzdCBhY2Nlc3NpbmcgdGhlIERPTSBpbmNvcnJlY3RseVxuICAvLyAtIGNhbiB0aHJvdyBhbiBleGNlcHRpb24gaW4gc29tZSBjaXJjdW1zdGFuY2VzLlxuICB0cnkge1xuICAgIGxldCBjdXJyZW50RWxlbSA9IGVsZW0gO1xuICAgIGNvbnN0IE1BWF9UUkFWRVJTRV9IRUlHSFQgPSA1O1xuICAgIGNvbnN0IG91dCA9IFtdO1xuICAgIGxldCBoZWlnaHQgPSAwO1xuICAgIGxldCBsZW4gPSAwO1xuICAgIGNvbnN0IHNlcGFyYXRvciA9ICcgPiAnO1xuICAgIGNvbnN0IHNlcExlbmd0aCA9IHNlcGFyYXRvci5sZW5ndGg7XG4gICAgbGV0IG5leHRTdHI7XG4gICAgY29uc3Qga2V5QXR0cnMgPSBBcnJheS5pc0FycmF5KG9wdGlvbnMpID8gb3B0aW9ucyA6IG9wdGlvbnMua2V5QXR0cnM7XG4gICAgY29uc3QgbWF4U3RyaW5nTGVuZ3RoID0gKCFBcnJheS5pc0FycmF5KG9wdGlvbnMpICYmIG9wdGlvbnMubWF4U3RyaW5nTGVuZ3RoKSB8fCBERUZBVUxUX01BWF9TVFJJTkdfTEVOR1RIO1xuXG4gICAgd2hpbGUgKGN1cnJlbnRFbGVtICYmIGhlaWdodCsrIDwgTUFYX1RSQVZFUlNFX0hFSUdIVCkge1xuICAgICAgbmV4dFN0ciA9IF9odG1sRWxlbWVudEFzU3RyaW5nKGN1cnJlbnRFbGVtLCBrZXlBdHRycyk7XG4gICAgICAvLyBiYWlsIG91dCBpZlxuICAgICAgLy8gLSBuZXh0U3RyIGlzIHRoZSAnaHRtbCcgZWxlbWVudFxuICAgICAgLy8gLSB0aGUgbGVuZ3RoIG9mIHRoZSBzdHJpbmcgdGhhdCB3b3VsZCBiZSBjcmVhdGVkIGV4Y2VlZHMgbWF4U3RyaW5nTGVuZ3RoXG4gICAgICAvLyAgIChpZ25vcmUgdGhpcyBsaW1pdCBpZiB3ZSBhcmUgb24gdGhlIGZpcnN0IGl0ZXJhdGlvbilcbiAgICAgIGlmIChuZXh0U3RyID09PSAnaHRtbCcgfHwgKGhlaWdodCA+IDEgJiYgbGVuICsgb3V0Lmxlbmd0aCAqIHNlcExlbmd0aCArIG5leHRTdHIubGVuZ3RoID49IG1heFN0cmluZ0xlbmd0aCkpIHtcbiAgICAgICAgYnJlYWs7XG4gICAgICB9XG5cbiAgICAgIG91dC5wdXNoKG5leHRTdHIpO1xuXG4gICAgICBsZW4gKz0gbmV4dFN0ci5sZW5ndGg7XG4gICAgICBjdXJyZW50RWxlbSA9IGN1cnJlbnRFbGVtLnBhcmVudE5vZGU7XG4gICAgfVxuXG4gICAgcmV0dXJuIG91dC5yZXZlcnNlKCkuam9pbihzZXBhcmF0b3IpO1xuICB9IGNhdGNoIHtcbiAgICByZXR1cm4gJzx1bmtub3duPic7XG4gIH1cbn1cblxuLyoqXG4gKiBSZXR1cm5zIGEgc2ltcGxlLCBxdWVyeS1zZWxlY3RvciByZXByZXNlbnRhdGlvbiBvZiBhIERPTSBlbGVtZW50XG4gKiBlLmcuIFtIVE1MRWxlbWVudF0gPT4gaW5wdXQjZm9vLmJ0bltuYW1lPWJhel1cbiAqIEByZXR1cm5zIGdlbmVyYXRlZCBET00gcGF0aFxuICovXG5mdW5jdGlvbiBfaHRtbEVsZW1lbnRBc1N0cmluZyhlbCwga2V5QXR0cnMpIHtcbiAgY29uc3QgZWxlbSA9IGVsXG5cbjtcblxuICBjb25zdCBvdXQgPSBbXTtcblxuICBpZiAoIWVsZW0/LnRhZ05hbWUpIHtcbiAgICByZXR1cm4gJyc7XG4gIH1cblxuICAvLyBAdHMtZXhwZWN0LWVycm9yIFdJTkRPVyBoYXMgSFRNTEVsZW1lbnRcbiAgaWYgKFdJTkRPVy5IVE1MRWxlbWVudCkge1xuICAgIC8vIElmIHVzaW5nIHRoZSBjb21wb25lbnQgbmFtZSBhbm5vdGF0aW9uIHBsdWdpbiwgdGhpcyB2YWx1ZSBtYXkgYmUgYXZhaWxhYmxlIG9uIHRoZSBET00gbm9kZVxuICAgIGlmIChlbGVtIGluc3RhbmNlb2YgSFRNTEVsZW1lbnQgJiYgZWxlbS5kYXRhc2V0KSB7XG4gICAgICBpZiAoZWxlbS5kYXRhc2V0WydzZW50cnlDb21wb25lbnQnXSkge1xuICAgICAgICByZXR1cm4gZWxlbS5kYXRhc2V0WydzZW50cnlDb21wb25lbnQnXTtcbiAgICAgIH1cbiAgICAgIGlmIChlbGVtLmRhdGFzZXRbJ3NlbnRyeUVsZW1lbnQnXSkge1xuICAgICAgICByZXR1cm4gZWxlbS5kYXRhc2V0WydzZW50cnlFbGVtZW50J107XG4gICAgICB9XG4gICAgfVxuICB9XG5cbiAgb3V0LnB1c2goZWxlbS50YWdOYW1lLnRvTG93ZXJDYXNlKCkpO1xuXG4gIC8vIFBhaXJzIG9mIGF0dHJpYnV0ZSBrZXlzIGRlZmluZWQgaW4gYHNlcmlhbGl6ZUF0dHJpYnV0ZWAgYW5kIHRoZWlyIHZhbHVlcyBvbiBlbGVtZW50LlxuICBjb25zdCBrZXlBdHRyUGFpcnMgPSBrZXlBdHRycz8ubGVuZ3RoXG4gICAgPyBrZXlBdHRycy5maWx0ZXIoa2V5QXR0ciA9PiBlbGVtLmdldEF0dHJpYnV0ZShrZXlBdHRyKSkubWFwKGtleUF0dHIgPT4gW2tleUF0dHIsIGVsZW0uZ2V0QXR0cmlidXRlKGtleUF0dHIpXSlcbiAgICA6IG51bGw7XG5cbiAgaWYgKGtleUF0dHJQYWlycz8ubGVuZ3RoKSB7XG4gICAga2V5QXR0clBhaXJzLmZvckVhY2goa2V5QXR0clBhaXIgPT4ge1xuICAgICAgb3V0LnB1c2goYFske2tleUF0dHJQYWlyWzBdfT1cIiR7a2V5QXR0clBhaXJbMV19XCJdYCk7XG4gICAgfSk7XG4gIH0gZWxzZSB7XG4gICAgaWYgKGVsZW0uaWQpIHtcbiAgICAgIG91dC5wdXNoKGAjJHtlbGVtLmlkfWApO1xuICAgIH1cblxuICAgIGNvbnN0IGNsYXNzTmFtZSA9IGVsZW0uY2xhc3NOYW1lO1xuICAgIGlmIChjbGFzc05hbWUgJiYgaXMuaXNTdHJpbmcoY2xhc3NOYW1lKSkge1xuICAgICAgY29uc3QgY2xhc3NlcyA9IGNsYXNzTmFtZS5zcGxpdCgvXFxzKy8pO1xuICAgICAgZm9yIChjb25zdCBjIG9mIGNsYXNzZXMpIHtcbiAgICAgICAgb3V0LnB1c2goYC4ke2N9YCk7XG4gICAgICB9XG4gICAgfVxuICB9XG4gIGNvbnN0IGFsbG93ZWRBdHRycyA9IFsnYXJpYS1sYWJlbCcsICd0eXBlJywgJ25hbWUnLCAndGl0bGUnLCAnYWx0J107XG4gIGZvciAoY29uc3QgayBvZiBhbGxvd2VkQXR0cnMpIHtcbiAgICBjb25zdCBhdHRyID0gZWxlbS5nZXRBdHRyaWJ1dGUoayk7XG4gICAgaWYgKGF0dHIpIHtcbiAgICAgIG91dC5wdXNoKGBbJHtrfT1cIiR7YXR0cn1cIl1gKTtcbiAgICB9XG4gIH1cblxuICByZXR1cm4gb3V0LmpvaW4oJycpO1xufVxuXG4vKipcbiAqIEEgc2FmZSBmb3JtIG9mIGxvY2F0aW9uLmhyZWZcbiAqL1xuZnVuY3Rpb24gZ2V0TG9jYXRpb25IcmVmKCkge1xuICB0cnkge1xuICAgIHJldHVybiBXSU5ET1cuZG9jdW1lbnQubG9jYXRpb24uaHJlZjtcbiAgfSBjYXRjaCB7XG4gICAgcmV0dXJuICcnO1xuICB9XG59XG5cbi8qKlxuICogR2l2ZW4gYSBET00gZWxlbWVudCwgdHJhdmVyc2VzIHVwIHRoZSB0cmVlIHVudGlsIGl0IGZpbmRzIHRoZSBmaXJzdCBhbmNlc3RvciBub2RlXG4gKiB0aGF0IGhhcyB0aGUgYGRhdGEtc2VudHJ5LWNvbXBvbmVudGAgb3IgYGRhdGEtc2VudHJ5LWVsZW1lbnRgIGF0dHJpYnV0ZSB3aXRoIGBkYXRhLXNlbnRyeS1jb21wb25lbnRgIHRha2luZ1xuICogcHJlY2VkZW5jZS4gVGhpcyBhdHRyaWJ1dGUgaXMgYWRkZWQgYXQgYnVpbGQtdGltZSBieSBwcm9qZWN0cyB0aGF0IGhhdmUgdGhlIGNvbXBvbmVudCBuYW1lIGFubm90YXRpb24gcGx1Z2luIGluc3RhbGxlZC5cbiAqXG4gKiBAcmV0dXJucyBhIHN0cmluZyByZXByZXNlbnRhdGlvbiBvZiB0aGUgY29tcG9uZW50IGZvciB0aGUgcHJvdmlkZWQgRE9NIGVsZW1lbnQsIG9yIGBudWxsYCBpZiBub3QgZm91bmRcbiAqL1xuZnVuY3Rpb24gZ2V0Q29tcG9uZW50TmFtZShlbGVtKSB7XG4gIC8vIEB0cy1leHBlY3QtZXJyb3IgV0lORE9XIGhhcyBIVE1MRWxlbWVudFxuICBpZiAoIVdJTkRPVy5IVE1MRWxlbWVudCkge1xuICAgIHJldHVybiBudWxsO1xuICB9XG5cbiAgbGV0IGN1cnJlbnRFbGVtID0gZWxlbSA7XG4gIGNvbnN0IE1BWF9UUkFWRVJTRV9IRUlHSFQgPSA1O1xuICBmb3IgKGxldCBpID0gMDsgaSA8IE1BWF9UUkFWRVJTRV9IRUlHSFQ7IGkrKykge1xuICAgIGlmICghY3VycmVudEVsZW0pIHtcbiAgICAgIHJldHVybiBudWxsO1xuICAgIH1cblxuICAgIGlmIChjdXJyZW50RWxlbSBpbnN0YW5jZW9mIEhUTUxFbGVtZW50KSB7XG4gICAgICBpZiAoY3VycmVudEVsZW0uZGF0YXNldFsnc2VudHJ5Q29tcG9uZW50J10pIHtcbiAgICAgICAgcmV0dXJuIGN1cnJlbnRFbGVtLmRhdGFzZXRbJ3NlbnRyeUNvbXBvbmVudCddO1xuICAgICAgfVxuICAgICAgaWYgKGN1cnJlbnRFbGVtLmRhdGFzZXRbJ3NlbnRyeUVsZW1lbnQnXSkge1xuICAgICAgICByZXR1cm4gY3VycmVudEVsZW0uZGF0YXNldFsnc2VudHJ5RWxlbWVudCddO1xuICAgICAgfVxuICAgIH1cblxuICAgIGN1cnJlbnRFbGVtID0gY3VycmVudEVsZW0ucGFyZW50Tm9kZTtcbiAgfVxuXG4gIHJldHVybiBudWxsO1xufVxuXG5leHBvcnRzLmdldENvbXBvbmVudE5hbWUgPSBnZXRDb21wb25lbnROYW1lO1xuZXhwb3J0cy5nZXRMb2NhdGlvbkhyZWYgPSBnZXRMb2NhdGlvbkhyZWY7XG5leHBvcnRzLmh0bWxUcmVlQXNTdHJpbmcgPSBodG1sVHJlZUFzU3RyaW5nO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9YnJvd3Nlci5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/browser.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/clientreport.js":
/*!**********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/clientreport.js ***!
  \**********************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst envelope = __webpack_require__(/*! ./envelope.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/envelope.js\");\nconst time = __webpack_require__(/*! ./time.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/time.js\");\n\n/**\n * Creates client report envelope\n * @param discarded_events An array of discard events\n * @param dsn A DSN that can be set on the header. Optional.\n */\nfunction createClientReportEnvelope(\n  discarded_events,\n  dsn,\n  timestamp,\n) {\n  const clientReportItem = [\n    { type: 'client_report' },\n    {\n      timestamp: timestamp || time.dateTimestampInSeconds(),\n      discarded_events,\n    },\n  ];\n  return envelope.createEnvelope(dsn ? { dsn } : {}, [clientReportItem]);\n}\n\nexports.createClientReportEnvelope = createClientReportEnvelope;\n//# sourceMappingURL=clientreport.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9jbGllbnRyZXBvcnQuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsaUJBQWlCLG1CQUFPLENBQUMsMkhBQWU7QUFDeEMsYUFBYSxtQkFBTyxDQUFDLG1IQUFXOztBQUVoQztBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsTUFBTSx1QkFBdUI7QUFDN0I7QUFDQTtBQUNBO0FBQ0EsS0FBSztBQUNMO0FBQ0EseUNBQXlDLE1BQU0sSUFBSTtBQUNuRDs7QUFFQSxrQ0FBa0M7QUFDbEMiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9jbGllbnRyZXBvcnQuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGVudmVsb3BlID0gcmVxdWlyZSgnLi9lbnZlbG9wZS5qcycpO1xuY29uc3QgdGltZSA9IHJlcXVpcmUoJy4vdGltZS5qcycpO1xuXG4vKipcbiAqIENyZWF0ZXMgY2xpZW50IHJlcG9ydCBlbnZlbG9wZVxuICogQHBhcmFtIGRpc2NhcmRlZF9ldmVudHMgQW4gYXJyYXkgb2YgZGlzY2FyZCBldmVudHNcbiAqIEBwYXJhbSBkc24gQSBEU04gdGhhdCBjYW4gYmUgc2V0IG9uIHRoZSBoZWFkZXIuIE9wdGlvbmFsLlxuICovXG5mdW5jdGlvbiBjcmVhdGVDbGllbnRSZXBvcnRFbnZlbG9wZShcbiAgZGlzY2FyZGVkX2V2ZW50cyxcbiAgZHNuLFxuICB0aW1lc3RhbXAsXG4pIHtcbiAgY29uc3QgY2xpZW50UmVwb3J0SXRlbSA9IFtcbiAgICB7IHR5cGU6ICdjbGllbnRfcmVwb3J0JyB9LFxuICAgIHtcbiAgICAgIHRpbWVzdGFtcDogdGltZXN0YW1wIHx8IHRpbWUuZGF0ZVRpbWVzdGFtcEluU2Vjb25kcygpLFxuICAgICAgZGlzY2FyZGVkX2V2ZW50cyxcbiAgICB9LFxuICBdO1xuICByZXR1cm4gZW52ZWxvcGUuY3JlYXRlRW52ZWxvcGUoZHNuID8geyBkc24gfSA6IHt9LCBbY2xpZW50UmVwb3J0SXRlbV0pO1xufVxuXG5leHBvcnRzLmNyZWF0ZUNsaWVudFJlcG9ydEVudmVsb3BlID0gY3JlYXRlQ2xpZW50UmVwb3J0RW52ZWxvcGU7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1jbGllbnRyZXBvcnQuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/clientreport.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/cookie.js":
/*!****************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/cookie.js ***!
  \****************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n/**\n * This code was originally copied from the 'cookie` module at v0.5.0 and was simplified for our use case.\n * https://github.com/jshttp/cookie/blob/a0c84147aab6266bdb3996cf4062e93907c0b0fc/index.js\n * It had the following license:\n *\n * (The MIT License)\n *\n * Copyright (c) 2012-2014 Roman Shtylman <shtylman@gmail.com>\n * Copyright (c) 2015 Douglas Christopher Wilson <doug@somethingdoug.com>\n *\n * Permission is hereby granted, free of charge, to any person obtaining\n * a copy of this software and associated documentation files (the\n * 'Software'), to deal in the Software without restriction, including\n * without limitation the rights to use, copy, modify, merge, publish,\n * distribute, sublicense, and/or sell copies of the Software, and to\n * permit persons to whom the Software is furnished to do so, subject to\n * the following conditions:\n *\n * The above copyright notice and this permission notice shall be\n * included in all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND,\n * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.\n * IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY\n * CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,\n * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE\n * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.\n */\n\n/**\n * Parses a cookie string\n */\nfunction parseCookie(str) {\n  const obj = {};\n  let index = 0;\n\n  while (index < str.length) {\n    const eqIdx = str.indexOf('=', index);\n\n    // no more cookie pairs\n    if (eqIdx === -1) {\n      break;\n    }\n\n    let endIdx = str.indexOf(';', index);\n\n    if (endIdx === -1) {\n      endIdx = str.length;\n    } else if (endIdx < eqIdx) {\n      // backtrack on prior semicolon\n      index = str.lastIndexOf(';', eqIdx - 1) + 1;\n      continue;\n    }\n\n    const key = str.slice(index, eqIdx).trim();\n\n    // only assign once\n    if (undefined === obj[key]) {\n      let val = str.slice(eqIdx + 1, endIdx).trim();\n\n      // quoted values\n      if (val.charCodeAt(0) === 0x22) {\n        val = val.slice(1, -1);\n      }\n\n      try {\n        obj[key] = val.indexOf('%') !== -1 ? decodeURIComponent(val) : val;\n      } catch {\n        obj[key] = val;\n      }\n    }\n\n    index = endIdx + 1;\n  }\n\n  return obj;\n}\n\nexports.parseCookie = parseCookie;\n//# sourceMappingURL=cookie.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9jb29raWUuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEU7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSwrQkFBK0I7O0FBRS9CO0FBQ0E7QUFDQSxNQUFNO0FBQ047QUFDQSxnQ0FBZ0M7QUFDaEM7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLFFBQVE7QUFDUjtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBOztBQUVBLG1CQUFtQjtBQUNuQiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3V0aWxzL2Nvb2tpZS5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuLyoqXG4gKiBUaGlzIGNvZGUgd2FzIG9yaWdpbmFsbHkgY29waWVkIGZyb20gdGhlICdjb29raWVgIG1vZHVsZSBhdCB2MC41LjAgYW5kIHdhcyBzaW1wbGlmaWVkIGZvciBvdXIgdXNlIGNhc2UuXG4gKiBodHRwczovL2dpdGh1Yi5jb20vanNodHRwL2Nvb2tpZS9ibG9iL2EwYzg0MTQ3YWFiNjI2NmJkYjM5OTZjZjQwNjJlOTM5MDdjMGIwZmMvaW5kZXguanNcbiAqIEl0IGhhZCB0aGUgZm9sbG93aW5nIGxpY2Vuc2U6XG4gKlxuICogKFRoZSBNSVQgTGljZW5zZSlcbiAqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMTItMjAxNCBSb21hbiBTaHR5bG1hbiA8c2h0eWxtYW5AZ21haWwuY29tPlxuICogQ29weXJpZ2h0IChjKSAyMDE1IERvdWdsYXMgQ2hyaXN0b3BoZXIgV2lsc29uIDxkb3VnQHNvbWV0aGluZ2RvdWcuY29tPlxuICpcbiAqIFBlcm1pc3Npb24gaXMgaGVyZWJ5IGdyYW50ZWQsIGZyZWUgb2YgY2hhcmdlLCB0byBhbnkgcGVyc29uIG9idGFpbmluZ1xuICogYSBjb3B5IG9mIHRoaXMgc29mdHdhcmUgYW5kIGFzc29jaWF0ZWQgZG9jdW1lbnRhdGlvbiBmaWxlcyAodGhlXG4gKiAnU29mdHdhcmUnKSwgdG8gZGVhbCBpbiB0aGUgU29mdHdhcmUgd2l0aG91dCByZXN0cmljdGlvbiwgaW5jbHVkaW5nXG4gKiB3aXRob3V0IGxpbWl0YXRpb24gdGhlIHJpZ2h0cyB0byB1c2UsIGNvcHksIG1vZGlmeSwgbWVyZ2UsIHB1Ymxpc2gsXG4gKiBkaXN0cmlidXRlLCBzdWJsaWNlbnNlLCBhbmQvb3Igc2VsbCBjb3BpZXMgb2YgdGhlIFNvZnR3YXJlLCBhbmQgdG9cbiAqIHBlcm1pdCBwZXJzb25zIHRvIHdob20gdGhlIFNvZnR3YXJlIGlzIGZ1cm5pc2hlZCB0byBkbyBzbywgc3ViamVjdCB0b1xuICogdGhlIGZvbGxvd2luZyBjb25kaXRpb25zOlxuICpcbiAqIFRoZSBhYm92ZSBjb3B5cmlnaHQgbm90aWNlIGFuZCB0aGlzIHBlcm1pc3Npb24gbm90aWNlIHNoYWxsIGJlXG4gKiBpbmNsdWRlZCBpbiBhbGwgY29waWVzIG9yIHN1YnN0YW50aWFsIHBvcnRpb25zIG9mIHRoZSBTb2Z0d2FyZS5cbiAqXG4gKiBUSEUgU09GVFdBUkUgSVMgUFJPVklERUQgJ0FTIElTJywgV0lUSE9VVCBXQVJSQU5UWSBPRiBBTlkgS0lORCxcbiAqIEVYUFJFU1MgT1IgSU1QTElFRCwgSU5DTFVESU5HIEJVVCBOT1QgTElNSVRFRCBUTyBUSEUgV0FSUkFOVElFUyBPRlxuICogTUVSQ0hBTlRBQklMSVRZLCBGSVRORVNTIEZPUiBBIFBBUlRJQ1VMQVIgUFVSUE9TRSBBTkQgTk9OSU5GUklOR0VNRU5ULlxuICogSU4gTk8gRVZFTlQgU0hBTEwgVEhFIEFVVEhPUlMgT1IgQ09QWVJJR0hUIEhPTERFUlMgQkUgTElBQkxFIEZPUiBBTllcbiAqIENMQUlNLCBEQU1BR0VTIE9SIE9USEVSIExJQUJJTElUWSwgV0hFVEhFUiBJTiBBTiBBQ1RJT04gT0YgQ09OVFJBQ1QsXG4gKiBUT1JUIE9SIE9USEVSV0lTRSwgQVJJU0lORyBGUk9NLCBPVVQgT0YgT1IgSU4gQ09OTkVDVElPTiBXSVRIIFRIRVxuICogU09GVFdBUkUgT1IgVEhFIFVTRSBPUiBPVEhFUiBERUFMSU5HUyBJTiBUSEUgU09GVFdBUkUuXG4gKi9cblxuLyoqXG4gKiBQYXJzZXMgYSBjb29raWUgc3RyaW5nXG4gKi9cbmZ1bmN0aW9uIHBhcnNlQ29va2llKHN0cikge1xuICBjb25zdCBvYmogPSB7fTtcbiAgbGV0IGluZGV4ID0gMDtcblxuICB3aGlsZSAoaW5kZXggPCBzdHIubGVuZ3RoKSB7XG4gICAgY29uc3QgZXFJZHggPSBzdHIuaW5kZXhPZignPScsIGluZGV4KTtcblxuICAgIC8vIG5vIG1vcmUgY29va2llIHBhaXJzXG4gICAgaWYgKGVxSWR4ID09PSAtMSkge1xuICAgICAgYnJlYWs7XG4gICAgfVxuXG4gICAgbGV0IGVuZElkeCA9IHN0ci5pbmRleE9mKCc7JywgaW5kZXgpO1xuXG4gICAgaWYgKGVuZElkeCA9PT0gLTEpIHtcbiAgICAgIGVuZElkeCA9IHN0ci5sZW5ndGg7XG4gICAgfSBlbHNlIGlmIChlbmRJZHggPCBlcUlkeCkge1xuICAgICAgLy8gYmFja3RyYWNrIG9uIHByaW9yIHNlbWljb2xvblxuICAgICAgaW5kZXggPSBzdHIubGFzdEluZGV4T2YoJzsnLCBlcUlkeCAtIDEpICsgMTtcbiAgICAgIGNvbnRpbnVlO1xuICAgIH1cblxuICAgIGNvbnN0IGtleSA9IHN0ci5zbGljZShpbmRleCwgZXFJZHgpLnRyaW0oKTtcblxuICAgIC8vIG9ubHkgYXNzaWduIG9uY2VcbiAgICBpZiAodW5kZWZpbmVkID09PSBvYmpba2V5XSkge1xuICAgICAgbGV0IHZhbCA9IHN0ci5zbGljZShlcUlkeCArIDEsIGVuZElkeCkudHJpbSgpO1xuXG4gICAgICAvLyBxdW90ZWQgdmFsdWVzXG4gICAgICBpZiAodmFsLmNoYXJDb2RlQXQoMCkgPT09IDB4MjIpIHtcbiAgICAgICAgdmFsID0gdmFsLnNsaWNlKDEsIC0xKTtcbiAgICAgIH1cblxuICAgICAgdHJ5IHtcbiAgICAgICAgb2JqW2tleV0gPSB2YWwuaW5kZXhPZignJScpICE9PSAtMSA/IGRlY29kZVVSSUNvbXBvbmVudCh2YWwpIDogdmFsO1xuICAgICAgfSBjYXRjaCB7XG4gICAgICAgIG9ialtrZXldID0gdmFsO1xuICAgICAgfVxuICAgIH1cblxuICAgIGluZGV4ID0gZW5kSWR4ICsgMTtcbiAgfVxuXG4gIHJldHVybiBvYmo7XG59XG5cbmV4cG9ydHMucGFyc2VDb29raWUgPSBwYXJzZUNvb2tpZTtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWNvb2tpZS5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/cookie.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debounce.js":
/*!******************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debounce.js ***!
  \******************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n/**\n * Heavily simplified debounce function based on lodash.debounce.\n *\n * This function takes a callback function (@param fun) and delays its invocation\n * by @param wait milliseconds. Optionally, a maxWait can be specified in @param options,\n * which ensures that the callback is invoked at least once after the specified max. wait time.\n *\n * @param func the function whose invocation is to be debounced\n * @param wait the minimum time until the function is invoked after it was called once\n * @param options the options object, which can contain the `maxWait` property\n *\n * @returns the debounced version of the function, which needs to be called at least once to start the\n *          debouncing process. Subsequent calls will reset the debouncing timer and, in case @paramfunc\n *          was already invoked in the meantime, return @param func's return value.\n *          The debounced function has two additional properties:\n *          - `flush`: Invokes the debounced function immediately and returns its return value\n *          - `cancel`: Cancels the debouncing process and resets the debouncing timer\n */\nfunction debounce(func, wait, options) {\n  let callbackReturnValue;\n\n  let timerId;\n  let maxTimerId;\n\n  const maxWait = options?.maxWait ? Math.max(options.maxWait, wait) : 0;\n  const setTimeoutImpl = options?.setTimeoutImpl || setTimeout;\n\n  function invokeFunc() {\n    cancelTimers();\n    callbackReturnValue = func();\n    return callbackReturnValue;\n  }\n\n  function cancelTimers() {\n    timerId !== undefined && clearTimeout(timerId);\n    maxTimerId !== undefined && clearTimeout(maxTimerId);\n    timerId = maxTimerId = undefined;\n  }\n\n  function flush() {\n    if (timerId !== undefined || maxTimerId !== undefined) {\n      return invokeFunc();\n    }\n    return callbackReturnValue;\n  }\n\n  function debounced() {\n    if (timerId) {\n      clearTimeout(timerId);\n    }\n    timerId = setTimeoutImpl(invokeFunc, wait);\n\n    if (maxWait && maxTimerId === undefined) {\n      maxTimerId = setTimeoutImpl(invokeFunc, maxWait);\n    }\n\n    return callbackReturnValue;\n  }\n\n  debounced.cancel = cancelTimers;\n  debounced.flush = flush;\n  return debounced;\n}\n\nexports.debounce = debounce;\n//# sourceMappingURL=debounce.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9kZWJvdW5jZS5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsZ0JBQWdCO0FBQ2hCIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvZGVib3VuY2UuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbi8qKlxuICogSGVhdmlseSBzaW1wbGlmaWVkIGRlYm91bmNlIGZ1bmN0aW9uIGJhc2VkIG9uIGxvZGFzaC5kZWJvdW5jZS5cbiAqXG4gKiBUaGlzIGZ1bmN0aW9uIHRha2VzIGEgY2FsbGJhY2sgZnVuY3Rpb24gKEBwYXJhbSBmdW4pIGFuZCBkZWxheXMgaXRzIGludm9jYXRpb25cbiAqIGJ5IEBwYXJhbSB3YWl0IG1pbGxpc2Vjb25kcy4gT3B0aW9uYWxseSwgYSBtYXhXYWl0IGNhbiBiZSBzcGVjaWZpZWQgaW4gQHBhcmFtIG9wdGlvbnMsXG4gKiB3aGljaCBlbnN1cmVzIHRoYXQgdGhlIGNhbGxiYWNrIGlzIGludm9rZWQgYXQgbGVhc3Qgb25jZSBhZnRlciB0aGUgc3BlY2lmaWVkIG1heC4gd2FpdCB0aW1lLlxuICpcbiAqIEBwYXJhbSBmdW5jIHRoZSBmdW5jdGlvbiB3aG9zZSBpbnZvY2F0aW9uIGlzIHRvIGJlIGRlYm91bmNlZFxuICogQHBhcmFtIHdhaXQgdGhlIG1pbmltdW0gdGltZSB1bnRpbCB0aGUgZnVuY3Rpb24gaXMgaW52b2tlZCBhZnRlciBpdCB3YXMgY2FsbGVkIG9uY2VcbiAqIEBwYXJhbSBvcHRpb25zIHRoZSBvcHRpb25zIG9iamVjdCwgd2hpY2ggY2FuIGNvbnRhaW4gdGhlIGBtYXhXYWl0YCBwcm9wZXJ0eVxuICpcbiAqIEByZXR1cm5zIHRoZSBkZWJvdW5jZWQgdmVyc2lvbiBvZiB0aGUgZnVuY3Rpb24sIHdoaWNoIG5lZWRzIHRvIGJlIGNhbGxlZCBhdCBsZWFzdCBvbmNlIHRvIHN0YXJ0IHRoZVxuICogICAgICAgICAgZGVib3VuY2luZyBwcm9jZXNzLiBTdWJzZXF1ZW50IGNhbGxzIHdpbGwgcmVzZXQgdGhlIGRlYm91bmNpbmcgdGltZXIgYW5kLCBpbiBjYXNlIEBwYXJhbWZ1bmNcbiAqICAgICAgICAgIHdhcyBhbHJlYWR5IGludm9rZWQgaW4gdGhlIG1lYW50aW1lLCByZXR1cm4gQHBhcmFtIGZ1bmMncyByZXR1cm4gdmFsdWUuXG4gKiAgICAgICAgICBUaGUgZGVib3VuY2VkIGZ1bmN0aW9uIGhhcyB0d28gYWRkaXRpb25hbCBwcm9wZXJ0aWVzOlxuICogICAgICAgICAgLSBgZmx1c2hgOiBJbnZva2VzIHRoZSBkZWJvdW5jZWQgZnVuY3Rpb24gaW1tZWRpYXRlbHkgYW5kIHJldHVybnMgaXRzIHJldHVybiB2YWx1ZVxuICogICAgICAgICAgLSBgY2FuY2VsYDogQ2FuY2VscyB0aGUgZGVib3VuY2luZyBwcm9jZXNzIGFuZCByZXNldHMgdGhlIGRlYm91bmNpbmcgdGltZXJcbiAqL1xuZnVuY3Rpb24gZGVib3VuY2UoZnVuYywgd2FpdCwgb3B0aW9ucykge1xuICBsZXQgY2FsbGJhY2tSZXR1cm5WYWx1ZTtcblxuICBsZXQgdGltZXJJZDtcbiAgbGV0IG1heFRpbWVySWQ7XG5cbiAgY29uc3QgbWF4V2FpdCA9IG9wdGlvbnM/Lm1heFdhaXQgPyBNYXRoLm1heChvcHRpb25zLm1heFdhaXQsIHdhaXQpIDogMDtcbiAgY29uc3Qgc2V0VGltZW91dEltcGwgPSBvcHRpb25zPy5zZXRUaW1lb3V0SW1wbCB8fCBzZXRUaW1lb3V0O1xuXG4gIGZ1bmN0aW9uIGludm9rZUZ1bmMoKSB7XG4gICAgY2FuY2VsVGltZXJzKCk7XG4gICAgY2FsbGJhY2tSZXR1cm5WYWx1ZSA9IGZ1bmMoKTtcbiAgICByZXR1cm4gY2FsbGJhY2tSZXR1cm5WYWx1ZTtcbiAgfVxuXG4gIGZ1bmN0aW9uIGNhbmNlbFRpbWVycygpIHtcbiAgICB0aW1lcklkICE9PSB1bmRlZmluZWQgJiYgY2xlYXJUaW1lb3V0KHRpbWVySWQpO1xuICAgIG1heFRpbWVySWQgIT09IHVuZGVmaW5lZCAmJiBjbGVhclRpbWVvdXQobWF4VGltZXJJZCk7XG4gICAgdGltZXJJZCA9IG1heFRpbWVySWQgPSB1bmRlZmluZWQ7XG4gIH1cblxuICBmdW5jdGlvbiBmbHVzaCgpIHtcbiAgICBpZiAodGltZXJJZCAhPT0gdW5kZWZpbmVkIHx8IG1heFRpbWVySWQgIT09IHVuZGVmaW5lZCkge1xuICAgICAgcmV0dXJuIGludm9rZUZ1bmMoKTtcbiAgICB9XG4gICAgcmV0dXJuIGNhbGxiYWNrUmV0dXJuVmFsdWU7XG4gIH1cblxuICBmdW5jdGlvbiBkZWJvdW5jZWQoKSB7XG4gICAgaWYgKHRpbWVySWQpIHtcbiAgICAgIGNsZWFyVGltZW91dCh0aW1lcklkKTtcbiAgICB9XG4gICAgdGltZXJJZCA9IHNldFRpbWVvdXRJbXBsKGludm9rZUZ1bmMsIHdhaXQpO1xuXG4gICAgaWYgKG1heFdhaXQgJiYgbWF4VGltZXJJZCA9PT0gdW5kZWZpbmVkKSB7XG4gICAgICBtYXhUaW1lcklkID0gc2V0VGltZW91dEltcGwoaW52b2tlRnVuYywgbWF4V2FpdCk7XG4gICAgfVxuXG4gICAgcmV0dXJuIGNhbGxiYWNrUmV0dXJuVmFsdWU7XG4gIH1cblxuICBkZWJvdW5jZWQuY2FuY2VsID0gY2FuY2VsVGltZXJzO1xuICBkZWJvdW5jZWQuZmx1c2ggPSBmbHVzaDtcbiAgcmV0dXJuIGRlYm91bmNlZDtcbn1cblxuZXhwb3J0cy5kZWJvdW5jZSA9IGRlYm91bmNlO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9ZGVib3VuY2UuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debounce.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-ids.js":
/*!*******************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-ids.js ***!
  \*******************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst worldwide = __webpack_require__(/*! ./worldwide.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/worldwide.js\");\n\nlet parsedStackResults;\nlet lastKeysCount;\nlet cachedFilenameDebugIds;\n\n/**\n * Returns a map of filenames to debug identifiers.\n */\nfunction getFilenameToDebugIdMap(stackParser) {\n  const debugIdMap = worldwide.GLOBAL_OBJ._sentryDebugIds;\n  if (!debugIdMap) {\n    return {};\n  }\n\n  const debugIdKeys = Object.keys(debugIdMap);\n\n  // If the count of registered globals hasn't changed since the last call, we\n  // can just return the cached result.\n  if (cachedFilenameDebugIds && debugIdKeys.length === lastKeysCount) {\n    return cachedFilenameDebugIds;\n  }\n\n  lastKeysCount = debugIdKeys.length;\n\n  // Build a map of filename -> debug_id.\n  cachedFilenameDebugIds = debugIdKeys.reduce((acc, stackKey) => {\n    if (!parsedStackResults) {\n      parsedStackResults = {};\n    }\n\n    const result = parsedStackResults[stackKey];\n\n    if (result) {\n      acc[result[0]] = result[1];\n    } else {\n      const parsedStack = stackParser(stackKey);\n\n      for (let i = parsedStack.length - 1; i >= 0; i--) {\n        const stackFrame = parsedStack[i];\n        const filename = stackFrame?.filename;\n        const debugId = debugIdMap[stackKey];\n\n        if (filename && debugId) {\n          acc[filename] = debugId;\n          parsedStackResults[stackKey] = [filename, debugId];\n          break;\n        }\n      }\n    }\n\n    return acc;\n  }, {});\n\n  return cachedFilenameDebugIds;\n}\n\n/**\n * Returns a list of debug images for the given resources.\n */\nfunction getDebugImagesForResources(\n  stackParser,\n  resource_paths,\n) {\n  const filenameDebugIdMap = getFilenameToDebugIdMap(stackParser);\n\n  if (!filenameDebugIdMap) {\n    return [];\n  }\n\n  const images = [];\n  for (const path of resource_paths) {\n    if (path && filenameDebugIdMap[path]) {\n      images.push({\n        type: 'sourcemap',\n        code_file: path,\n        debug_id: filenameDebugIdMap[path] ,\n      });\n    }\n  }\n\n  return images;\n}\n\nexports.getDebugImagesForResources = getDebugImagesForResources;\nexports.getFilenameToDebugIdMap = getFilenameToDebugIdMap;\n//# sourceMappingURL=debug-ids.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9kZWJ1Zy1pZHMuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsa0JBQWtCLG1CQUFPLENBQUMsNkhBQWdCOztBQUUxQztBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBLE1BQU07QUFDTjs7QUFFQSwyQ0FBMkMsUUFBUTtBQUNuRDtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQSxHQUFHLElBQUk7O0FBRVA7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLE9BQU87QUFDUDtBQUNBOztBQUVBO0FBQ0E7O0FBRUEsa0NBQWtDO0FBQ2xDLCtCQUErQjtBQUMvQiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3V0aWxzL2RlYnVnLWlkcy5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3Qgd29ybGR3aWRlID0gcmVxdWlyZSgnLi93b3JsZHdpZGUuanMnKTtcblxubGV0IHBhcnNlZFN0YWNrUmVzdWx0cztcbmxldCBsYXN0S2V5c0NvdW50O1xubGV0IGNhY2hlZEZpbGVuYW1lRGVidWdJZHM7XG5cbi8qKlxuICogUmV0dXJucyBhIG1hcCBvZiBmaWxlbmFtZXMgdG8gZGVidWcgaWRlbnRpZmllcnMuXG4gKi9cbmZ1bmN0aW9uIGdldEZpbGVuYW1lVG9EZWJ1Z0lkTWFwKHN0YWNrUGFyc2VyKSB7XG4gIGNvbnN0IGRlYnVnSWRNYXAgPSB3b3JsZHdpZGUuR0xPQkFMX09CSi5fc2VudHJ5RGVidWdJZHM7XG4gIGlmICghZGVidWdJZE1hcCkge1xuICAgIHJldHVybiB7fTtcbiAgfVxuXG4gIGNvbnN0IGRlYnVnSWRLZXlzID0gT2JqZWN0LmtleXMoZGVidWdJZE1hcCk7XG5cbiAgLy8gSWYgdGhlIGNvdW50IG9mIHJlZ2lzdGVyZWQgZ2xvYmFscyBoYXNuJ3QgY2hhbmdlZCBzaW5jZSB0aGUgbGFzdCBjYWxsLCB3ZVxuICAvLyBjYW4ganVzdCByZXR1cm4gdGhlIGNhY2hlZCByZXN1bHQuXG4gIGlmIChjYWNoZWRGaWxlbmFtZURlYnVnSWRzICYmIGRlYnVnSWRLZXlzLmxlbmd0aCA9PT0gbGFzdEtleXNDb3VudCkge1xuICAgIHJldHVybiBjYWNoZWRGaWxlbmFtZURlYnVnSWRzO1xuICB9XG5cbiAgbGFzdEtleXNDb3VudCA9IGRlYnVnSWRLZXlzLmxlbmd0aDtcblxuICAvLyBCdWlsZCBhIG1hcCBvZiBmaWxlbmFtZSAtPiBkZWJ1Z19pZC5cbiAgY2FjaGVkRmlsZW5hbWVEZWJ1Z0lkcyA9IGRlYnVnSWRLZXlzLnJlZHVjZSgoYWNjLCBzdGFja0tleSkgPT4ge1xuICAgIGlmICghcGFyc2VkU3RhY2tSZXN1bHRzKSB7XG4gICAgICBwYXJzZWRTdGFja1Jlc3VsdHMgPSB7fTtcbiAgICB9XG5cbiAgICBjb25zdCByZXN1bHQgPSBwYXJzZWRTdGFja1Jlc3VsdHNbc3RhY2tLZXldO1xuXG4gICAgaWYgKHJlc3VsdCkge1xuICAgICAgYWNjW3Jlc3VsdFswXV0gPSByZXN1bHRbMV07XG4gICAgfSBlbHNlIHtcbiAgICAgIGNvbnN0IHBhcnNlZFN0YWNrID0gc3RhY2tQYXJzZXIoc3RhY2tLZXkpO1xuXG4gICAgICBmb3IgKGxldCBpID0gcGFyc2VkU3RhY2subGVuZ3RoIC0gMTsgaSA+PSAwOyBpLS0pIHtcbiAgICAgICAgY29uc3Qgc3RhY2tGcmFtZSA9IHBhcnNlZFN0YWNrW2ldO1xuICAgICAgICBjb25zdCBmaWxlbmFtZSA9IHN0YWNrRnJhbWU/LmZpbGVuYW1lO1xuICAgICAgICBjb25zdCBkZWJ1Z0lkID0gZGVidWdJZE1hcFtzdGFja0tleV07XG5cbiAgICAgICAgaWYgKGZpbGVuYW1lICYmIGRlYnVnSWQpIHtcbiAgICAgICAgICBhY2NbZmlsZW5hbWVdID0gZGVidWdJZDtcbiAgICAgICAgICBwYXJzZWRTdGFja1Jlc3VsdHNbc3RhY2tLZXldID0gW2ZpbGVuYW1lLCBkZWJ1Z0lkXTtcbiAgICAgICAgICBicmVhaztcbiAgICAgICAgfVxuICAgICAgfVxuICAgIH1cblxuICAgIHJldHVybiBhY2M7XG4gIH0sIHt9KTtcblxuICByZXR1cm4gY2FjaGVkRmlsZW5hbWVEZWJ1Z0lkcztcbn1cblxuLyoqXG4gKiBSZXR1cm5zIGEgbGlzdCBvZiBkZWJ1ZyBpbWFnZXMgZm9yIHRoZSBnaXZlbiByZXNvdXJjZXMuXG4gKi9cbmZ1bmN0aW9uIGdldERlYnVnSW1hZ2VzRm9yUmVzb3VyY2VzKFxuICBzdGFja1BhcnNlcixcbiAgcmVzb3VyY2VfcGF0aHMsXG4pIHtcbiAgY29uc3QgZmlsZW5hbWVEZWJ1Z0lkTWFwID0gZ2V0RmlsZW5hbWVUb0RlYnVnSWRNYXAoc3RhY2tQYXJzZXIpO1xuXG4gIGlmICghZmlsZW5hbWVEZWJ1Z0lkTWFwKSB7XG4gICAgcmV0dXJuIFtdO1xuICB9XG5cbiAgY29uc3QgaW1hZ2VzID0gW107XG4gIGZvciAoY29uc3QgcGF0aCBvZiByZXNvdXJjZV9wYXRocykge1xuICAgIGlmIChwYXRoICYmIGZpbGVuYW1lRGVidWdJZE1hcFtwYXRoXSkge1xuICAgICAgaW1hZ2VzLnB1c2goe1xuICAgICAgICB0eXBlOiAnc291cmNlbWFwJyxcbiAgICAgICAgY29kZV9maWxlOiBwYXRoLFxuICAgICAgICBkZWJ1Z19pZDogZmlsZW5hbWVEZWJ1Z0lkTWFwW3BhdGhdICxcbiAgICAgIH0pO1xuICAgIH1cbiAgfVxuXG4gIHJldHVybiBpbWFnZXM7XG59XG5cbmV4cG9ydHMuZ2V0RGVidWdJbWFnZXNGb3JSZXNvdXJjZXMgPSBnZXREZWJ1Z0ltYWdlc0ZvclJlc291cmNlcztcbmV4cG9ydHMuZ2V0RmlsZW5hbWVUb0RlYnVnSWRNYXAgPSBnZXRGaWxlbmFtZVRvRGVidWdJZE1hcDtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWRlYnVnLWlkcy5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-ids.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js":
/*!**********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js ***!
  \**********************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst carrier = __webpack_require__(/*! ../carrier.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/carrier.js\");\nconst debugBuild = __webpack_require__(/*! ../debug-build.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst worldwide = __webpack_require__(/*! ./worldwide.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/worldwide.js\");\n\n/**\n * A Sentry Logger instance.\n *\n * @deprecated Use {@link debug} instead with the {@link SentryDebugLogger} type.\n */\n\nconst CONSOLE_LEVELS = [\n  'debug',\n  'info',\n  'warn',\n  'error',\n  'log',\n  'assert',\n  'trace',\n] ;\n\n/** Prefix for logging strings */\nconst PREFIX = 'Sentry Logger ';\n\n/** This may be mutated by the console instrumentation. */\nconst originalConsoleMethods\n\n = {};\n\n/**\n * Temporarily disable sentry console instrumentations.\n *\n * @param callback The function to run against the original `console` messages\n * @returns The results of the callback\n */\nfunction consoleSandbox(callback) {\n  if (!('console' in worldwide.GLOBAL_OBJ)) {\n    return callback();\n  }\n\n  const console = worldwide.GLOBAL_OBJ.console ;\n  const wrappedFuncs = {};\n\n  const wrappedLevels = Object.keys(originalConsoleMethods) ;\n\n  // Restore all wrapped console methods\n  wrappedLevels.forEach(level => {\n    const originalConsoleMethod = originalConsoleMethods[level];\n    wrappedFuncs[level] = console[level] ;\n    console[level] = originalConsoleMethod ;\n  });\n\n  try {\n    return callback();\n  } finally {\n    // Revert restoration to wrapped state\n    wrappedLevels.forEach(level => {\n      console[level] = wrappedFuncs[level] ;\n    });\n  }\n}\n\nfunction enable() {\n  _getLoggerSettings().enabled = true;\n}\n\nfunction disable() {\n  _getLoggerSettings().enabled = false;\n}\n\nfunction isEnabled() {\n  return _getLoggerSettings().enabled;\n}\n\nfunction log(...args) {\n  _maybeLog('log', ...args);\n}\n\nfunction info(...args) {\n  _maybeLog('info', ...args);\n}\n\nfunction warn(...args) {\n  _maybeLog('warn', ...args);\n}\n\nfunction error(...args) {\n  _maybeLog('error', ...args);\n}\n\nfunction _debug(...args) {\n  _maybeLog('debug', ...args);\n}\n\nfunction assert(...args) {\n  _maybeLog('assert', ...args);\n}\n\nfunction trace(...args) {\n  _maybeLog('trace', ...args);\n}\n\nfunction _maybeLog(level, ...args) {\n  if (!debugBuild.DEBUG_BUILD) {\n    return;\n  }\n\n  if (isEnabled()) {\n    consoleSandbox(() => {\n      worldwide.GLOBAL_OBJ.console[level](`${PREFIX}[${level}]:`, ...args);\n    });\n  }\n}\n\nfunction _getLoggerSettings() {\n  if (!debugBuild.DEBUG_BUILD) {\n    return { enabled: false };\n  }\n\n  return carrier.getGlobalSingleton('loggerSettings', () => ({ enabled: false }));\n}\n\n/**\n * This is a logger singleton which either logs things or no-ops if logging is not enabled.\n * The logger is a singleton on the carrier, to ensure that a consistent logger is used throughout the SDK.\n *\n * @deprecated Use {@link debug} instead.\n */\nconst logger = {\n  /** Enable logging. */\n  enable,\n  /** Disable logging. */\n  disable,\n  /** Check if logging is enabled. */\n  isEnabled,\n  /** Log a message. */\n  log,\n  /** Log level info */\n  info,\n  /** Log a warning. */\n  warn,\n  /** Log an error. */\n  error,\n  /** Log a debug message. */\n  debug: _debug,\n  /** Log an assertion. */\n  assert,\n  /** Log a trace. */\n  trace,\n  // eslint-disable-next-line deprecation/deprecation\n} ;\n\n/**\n * This is a logger singleton which either logs things or no-ops if logging is not enabled.\n */\nconst debug = {\n  /** Enable logging. */\n  enable,\n  /** Disable logging. */\n  disable,\n  /** Check if logging is enabled. */\n  isEnabled,\n  /** Log a message. */\n  log,\n  /** Log a warning. */\n  warn,\n  /** Log an error. */\n  error,\n} ;\n\nexports.CONSOLE_LEVELS = CONSOLE_LEVELS;\nexports.consoleSandbox = consoleSandbox;\nexports.debug = debug;\nexports.logger = logger;\nexports.originalConsoleMethods = originalConsoleMethods;\n//# sourceMappingURL=debug-logger.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9kZWJ1Zy1sb2dnZXIuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsZ0JBQWdCLG1CQUFPLENBQUMsb0hBQWU7QUFDdkMsbUJBQW1CLG1CQUFPLENBQUMsNEhBQW1CO0FBQzlDLGtCQUFrQixtQkFBTyxDQUFDLDZIQUFnQjs7QUFFMUM7QUFDQTtBQUNBO0FBQ0Esb0JBQW9CLGFBQWEsa0JBQWtCLHlCQUF5QjtBQUM1RTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEdBQUc7O0FBRUg7QUFDQTtBQUNBLElBQUk7QUFDSjtBQUNBO0FBQ0E7QUFDQSxLQUFLO0FBQ0w7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLDZDQUE2QyxPQUFPLEdBQUcsTUFBTTtBQUM3RCxLQUFLO0FBQ0w7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsYUFBYTtBQUNiOztBQUVBLCtEQUErRCxnQkFBZ0I7QUFDL0U7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQSxvQkFBb0IsYUFBYTtBQUNqQztBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSxzQkFBc0I7QUFDdEIsc0JBQXNCO0FBQ3RCLGFBQWE7QUFDYixjQUFjO0FBQ2QsOEJBQThCO0FBQzlCIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvZGVidWctbG9nZ2VyLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBjYXJyaWVyID0gcmVxdWlyZSgnLi4vY2Fycmllci5qcycpO1xuY29uc3QgZGVidWdCdWlsZCA9IHJlcXVpcmUoJy4uL2RlYnVnLWJ1aWxkLmpzJyk7XG5jb25zdCB3b3JsZHdpZGUgPSByZXF1aXJlKCcuL3dvcmxkd2lkZS5qcycpO1xuXG4vKipcbiAqIEEgU2VudHJ5IExvZ2dlciBpbnN0YW5jZS5cbiAqXG4gKiBAZGVwcmVjYXRlZCBVc2Uge0BsaW5rIGRlYnVnfSBpbnN0ZWFkIHdpdGggdGhlIHtAbGluayBTZW50cnlEZWJ1Z0xvZ2dlcn0gdHlwZS5cbiAqL1xuXG5jb25zdCBDT05TT0xFX0xFVkVMUyA9IFtcbiAgJ2RlYnVnJyxcbiAgJ2luZm8nLFxuICAnd2FybicsXG4gICdlcnJvcicsXG4gICdsb2cnLFxuICAnYXNzZXJ0JyxcbiAgJ3RyYWNlJyxcbl0gO1xuXG4vKiogUHJlZml4IGZvciBsb2dnaW5nIHN0cmluZ3MgKi9cbmNvbnN0IFBSRUZJWCA9ICdTZW50cnkgTG9nZ2VyICc7XG5cbi8qKiBUaGlzIG1heSBiZSBtdXRhdGVkIGJ5IHRoZSBjb25zb2xlIGluc3RydW1lbnRhdGlvbi4gKi9cbmNvbnN0IG9yaWdpbmFsQ29uc29sZU1ldGhvZHNcblxuID0ge307XG5cbi8qKlxuICogVGVtcG9yYXJpbHkgZGlzYWJsZSBzZW50cnkgY29uc29sZSBpbnN0cnVtZW50YXRpb25zLlxuICpcbiAqIEBwYXJhbSBjYWxsYmFjayBUaGUgZnVuY3Rpb24gdG8gcnVuIGFnYWluc3QgdGhlIG9yaWdpbmFsIGBjb25zb2xlYCBtZXNzYWdlc1xuICogQHJldHVybnMgVGhlIHJlc3VsdHMgb2YgdGhlIGNhbGxiYWNrXG4gKi9cbmZ1bmN0aW9uIGNvbnNvbGVTYW5kYm94KGNhbGxiYWNrKSB7XG4gIGlmICghKCdjb25zb2xlJyBpbiB3b3JsZHdpZGUuR0xPQkFMX09CSikpIHtcbiAgICByZXR1cm4gY2FsbGJhY2soKTtcbiAgfVxuXG4gIGNvbnN0IGNvbnNvbGUgPSB3b3JsZHdpZGUuR0xPQkFMX09CSi5jb25zb2xlIDtcbiAgY29uc3Qgd3JhcHBlZEZ1bmNzID0ge307XG5cbiAgY29uc3Qgd3JhcHBlZExldmVscyA9IE9iamVjdC5rZXlzKG9yaWdpbmFsQ29uc29sZU1ldGhvZHMpIDtcblxuICAvLyBSZXN0b3JlIGFsbCB3cmFwcGVkIGNvbnNvbGUgbWV0aG9kc1xuICB3cmFwcGVkTGV2ZWxzLmZvckVhY2gobGV2ZWwgPT4ge1xuICAgIGNvbnN0IG9yaWdpbmFsQ29uc29sZU1ldGhvZCA9IG9yaWdpbmFsQ29uc29sZU1ldGhvZHNbbGV2ZWxdO1xuICAgIHdyYXBwZWRGdW5jc1tsZXZlbF0gPSBjb25zb2xlW2xldmVsXSA7XG4gICAgY29uc29sZVtsZXZlbF0gPSBvcmlnaW5hbENvbnNvbGVNZXRob2QgO1xuICB9KTtcblxuICB0cnkge1xuICAgIHJldHVybiBjYWxsYmFjaygpO1xuICB9IGZpbmFsbHkge1xuICAgIC8vIFJldmVydCByZXN0b3JhdGlvbiB0byB3cmFwcGVkIHN0YXRlXG4gICAgd3JhcHBlZExldmVscy5mb3JFYWNoKGxldmVsID0+IHtcbiAgICAgIGNvbnNvbGVbbGV2ZWxdID0gd3JhcHBlZEZ1bmNzW2xldmVsXSA7XG4gICAgfSk7XG4gIH1cbn1cblxuZnVuY3Rpb24gZW5hYmxlKCkge1xuICBfZ2V0TG9nZ2VyU2V0dGluZ3MoKS5lbmFibGVkID0gdHJ1ZTtcbn1cblxuZnVuY3Rpb24gZGlzYWJsZSgpIHtcbiAgX2dldExvZ2dlclNldHRpbmdzKCkuZW5hYmxlZCA9IGZhbHNlO1xufVxuXG5mdW5jdGlvbiBpc0VuYWJsZWQoKSB7XG4gIHJldHVybiBfZ2V0TG9nZ2VyU2V0dGluZ3MoKS5lbmFibGVkO1xufVxuXG5mdW5jdGlvbiBsb2coLi4uYXJncykge1xuICBfbWF5YmVMb2coJ2xvZycsIC4uLmFyZ3MpO1xufVxuXG5mdW5jdGlvbiBpbmZvKC4uLmFyZ3MpIHtcbiAgX21heWJlTG9nKCdpbmZvJywgLi4uYXJncyk7XG59XG5cbmZ1bmN0aW9uIHdhcm4oLi4uYXJncykge1xuICBfbWF5YmVMb2coJ3dhcm4nLCAuLi5hcmdzKTtcbn1cblxuZnVuY3Rpb24gZXJyb3IoLi4uYXJncykge1xuICBfbWF5YmVMb2coJ2Vycm9yJywgLi4uYXJncyk7XG59XG5cbmZ1bmN0aW9uIF9kZWJ1ZyguLi5hcmdzKSB7XG4gIF9tYXliZUxvZygnZGVidWcnLCAuLi5hcmdzKTtcbn1cblxuZnVuY3Rpb24gYXNzZXJ0KC4uLmFyZ3MpIHtcbiAgX21heWJlTG9nKCdhc3NlcnQnLCAuLi5hcmdzKTtcbn1cblxuZnVuY3Rpb24gdHJhY2UoLi4uYXJncykge1xuICBfbWF5YmVMb2coJ3RyYWNlJywgLi4uYXJncyk7XG59XG5cbmZ1bmN0aW9uIF9tYXliZUxvZyhsZXZlbCwgLi4uYXJncykge1xuICBpZiAoIWRlYnVnQnVpbGQuREVCVUdfQlVJTEQpIHtcbiAgICByZXR1cm47XG4gIH1cblxuICBpZiAoaXNFbmFibGVkKCkpIHtcbiAgICBjb25zb2xlU2FuZGJveCgoKSA9PiB7XG4gICAgICB3b3JsZHdpZGUuR0xPQkFMX09CSi5jb25zb2xlW2xldmVsXShgJHtQUkVGSVh9WyR7bGV2ZWx9XTpgLCAuLi5hcmdzKTtcbiAgICB9KTtcbiAgfVxufVxuXG5mdW5jdGlvbiBfZ2V0TG9nZ2VyU2V0dGluZ3MoKSB7XG4gIGlmICghZGVidWdCdWlsZC5ERUJVR19CVUlMRCkge1xuICAgIHJldHVybiB7IGVuYWJsZWQ6IGZhbHNlIH07XG4gIH1cblxuICByZXR1cm4gY2Fycmllci5nZXRHbG9iYWxTaW5nbGV0b24oJ2xvZ2dlclNldHRpbmdzJywgKCkgPT4gKHsgZW5hYmxlZDogZmFsc2UgfSkpO1xufVxuXG4vKipcbiAqIFRoaXMgaXMgYSBsb2dnZXIgc2luZ2xldG9uIHdoaWNoIGVpdGhlciBsb2dzIHRoaW5ncyBvciBuby1vcHMgaWYgbG9nZ2luZyBpcyBub3QgZW5hYmxlZC5cbiAqIFRoZSBsb2dnZXIgaXMgYSBzaW5nbGV0b24gb24gdGhlIGNhcnJpZXIsIHRvIGVuc3VyZSB0aGF0IGEgY29uc2lzdGVudCBsb2dnZXIgaXMgdXNlZCB0aHJvdWdob3V0IHRoZSBTREsuXG4gKlxuICogQGRlcHJlY2F0ZWQgVXNlIHtAbGluayBkZWJ1Z30gaW5zdGVhZC5cbiAqL1xuY29uc3QgbG9nZ2VyID0ge1xuICAvKiogRW5hYmxlIGxvZ2dpbmcuICovXG4gIGVuYWJsZSxcbiAgLyoqIERpc2FibGUgbG9nZ2luZy4gKi9cbiAgZGlzYWJsZSxcbiAgLyoqIENoZWNrIGlmIGxvZ2dpbmcgaXMgZW5hYmxlZC4gKi9cbiAgaXNFbmFibGVkLFxuICAvKiogTG9nIGEgbWVzc2FnZS4gKi9cbiAgbG9nLFxuICAvKiogTG9nIGxldmVsIGluZm8gKi9cbiAgaW5mbyxcbiAgLyoqIExvZyBhIHdhcm5pbmcuICovXG4gIHdhcm4sXG4gIC8qKiBMb2cgYW4gZXJyb3IuICovXG4gIGVycm9yLFxuICAvKiogTG9nIGEgZGVidWcgbWVzc2FnZS4gKi9cbiAgZGVidWc6IF9kZWJ1ZyxcbiAgLyoqIExvZyBhbiBhc3NlcnRpb24uICovXG4gIGFzc2VydCxcbiAgLyoqIExvZyBhIHRyYWNlLiAqL1xuICB0cmFjZSxcbiAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIGRlcHJlY2F0aW9uL2RlcHJlY2F0aW9uXG59IDtcblxuLyoqXG4gKiBUaGlzIGlzIGEgbG9nZ2VyIHNpbmdsZXRvbiB3aGljaCBlaXRoZXIgbG9ncyB0aGluZ3Mgb3Igbm8tb3BzIGlmIGxvZ2dpbmcgaXMgbm90IGVuYWJsZWQuXG4gKi9cbmNvbnN0IGRlYnVnID0ge1xuICAvKiogRW5hYmxlIGxvZ2dpbmcuICovXG4gIGVuYWJsZSxcbiAgLyoqIERpc2FibGUgbG9nZ2luZy4gKi9cbiAgZGlzYWJsZSxcbiAgLyoqIENoZWNrIGlmIGxvZ2dpbmcgaXMgZW5hYmxlZC4gKi9cbiAgaXNFbmFibGVkLFxuICAvKiogTG9nIGEgbWVzc2FnZS4gKi9cbiAgbG9nLFxuICAvKiogTG9nIGEgd2FybmluZy4gKi9cbiAgd2FybixcbiAgLyoqIExvZyBhbiBlcnJvci4gKi9cbiAgZXJyb3IsXG59IDtcblxuZXhwb3J0cy5DT05TT0xFX0xFVkVMUyA9IENPTlNPTEVfTEVWRUxTO1xuZXhwb3J0cy5jb25zb2xlU2FuZGJveCA9IGNvbnNvbGVTYW5kYm94O1xuZXhwb3J0cy5kZWJ1ZyA9IGRlYnVnO1xuZXhwb3J0cy5sb2dnZXIgPSBsb2dnZXI7XG5leHBvcnRzLm9yaWdpbmFsQ29uc29sZU1ldGhvZHMgPSBvcmlnaW5hbENvbnNvbGVNZXRob2RzO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9ZGVidWctbG9nZ2VyLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/dsn.js":
/*!*************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/dsn.js ***!
  \*************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst debugBuild = __webpack_require__(/*! ../debug-build.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst debugLogger = __webpack_require__(/*! ./debug-logger.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\n\n/** Regular expression used to extract org ID from a DSN host. */\nconst ORG_ID_REGEX = /^o(\\d+)\\./;\n\n/** Regular expression used to parse a Dsn. */\nconst DSN_REGEX = /^(?:(\\w+):)\\/\\/(?:(\\w+)(?::(\\w+)?)?@)([\\w.-]+)(?::(\\d+))?\\/(.+)/;\n\nfunction isValidProtocol(protocol) {\n  return protocol === 'http' || protocol === 'https';\n}\n\n/**\n * Renders the string representation of this Dsn.\n *\n * By default, this will render the public representation without the password\n * component. To get the deprecated private representation, set `withPassword`\n * to true.\n *\n * @param withPassword When set to true, the password will be included.\n */\nfunction dsnToString(dsn, withPassword = false) {\n  const { host, path, pass, port, projectId, protocol, publicKey } = dsn;\n  return (\n    `${protocol}://${publicKey}${withPassword && pass ? `:${pass}` : ''}` +\n    `@${host}${port ? `:${port}` : ''}/${path ? `${path}/` : path}${projectId}`\n  );\n}\n\n/**\n * Parses a Dsn from a given string.\n *\n * @param str A Dsn as string\n * @returns Dsn as DsnComponents or undefined if @param str is not a valid DSN string\n */\nfunction dsnFromString(str) {\n  const match = DSN_REGEX.exec(str);\n\n  if (!match) {\n    // This should be logged to the console\n    debugLogger.consoleSandbox(() => {\n      // eslint-disable-next-line no-console\n      console.error(`Invalid Sentry Dsn: ${str}`);\n    });\n    return undefined;\n  }\n\n  const [protocol, publicKey, pass = '', host = '', port = '', lastPath = ''] = match.slice(1);\n  let path = '';\n  let projectId = lastPath;\n\n  const split = projectId.split('/');\n  if (split.length > 1) {\n    path = split.slice(0, -1).join('/');\n    projectId = split.pop() ;\n  }\n\n  if (projectId) {\n    const projectMatch = projectId.match(/^\\d+/);\n    if (projectMatch) {\n      projectId = projectMatch[0];\n    }\n  }\n\n  return dsnFromComponents({ host, pass, path, projectId, port, protocol: protocol , publicKey });\n}\n\nfunction dsnFromComponents(components) {\n  return {\n    protocol: components.protocol,\n    publicKey: components.publicKey || '',\n    pass: components.pass || '',\n    host: components.host,\n    port: components.port || '',\n    path: components.path || '',\n    projectId: components.projectId,\n  };\n}\n\nfunction validateDsn(dsn) {\n  if (!debugBuild.DEBUG_BUILD) {\n    return true;\n  }\n\n  const { port, projectId, protocol } = dsn;\n\n  const requiredComponents = ['protocol', 'publicKey', 'host', 'projectId'];\n  const hasMissingRequiredComponent = requiredComponents.find(component => {\n    if (!dsn[component]) {\n      debugLogger.debug.error(`Invalid Sentry Dsn: ${component} missing`);\n      return true;\n    }\n    return false;\n  });\n\n  if (hasMissingRequiredComponent) {\n    return false;\n  }\n\n  if (!projectId.match(/^\\d+$/)) {\n    debugLogger.debug.error(`Invalid Sentry Dsn: Invalid projectId ${projectId}`);\n    return false;\n  }\n\n  if (!isValidProtocol(protocol)) {\n    debugLogger.debug.error(`Invalid Sentry Dsn: Invalid protocol ${protocol}`);\n    return false;\n  }\n\n  if (port && isNaN(parseInt(port, 10))) {\n    debugLogger.debug.error(`Invalid Sentry Dsn: Invalid port ${port}`);\n    return false;\n  }\n\n  return true;\n}\n\n/**\n * Extract the org ID from a DSN host.\n *\n * @param host The host from a DSN\n * @returns The org ID if found, undefined otherwise\n */\nfunction extractOrgIdFromDsnHost(host) {\n  const match = host.match(ORG_ID_REGEX);\n\n  return match?.[1];\n}\n\n/**\n * Creates a valid Sentry Dsn object, identifying a Sentry instance and project.\n * @returns a valid DsnComponents object or `undefined` if @param from is an invalid DSN source\n */\nfunction makeDsn(from) {\n  const components = typeof from === 'string' ? dsnFromString(from) : dsnFromComponents(from);\n  if (!components || !validateDsn(components)) {\n    return undefined;\n  }\n  return components;\n}\n\nexports.dsnFromString = dsnFromString;\nexports.dsnToString = dsnToString;\nexports.extractOrgIdFromDsnHost = extractOrgIdFromDsnHost;\nexports.makeDsn = makeDsn;\n//# sourceMappingURL=dsn.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9kc24uanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsbUJBQW1CLG1CQUFPLENBQUMsNEhBQW1CO0FBQzlDLG9CQUFvQixtQkFBTyxDQUFDLG1JQUFtQjs7QUFFL0M7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFVBQVUseURBQXlEO0FBQ25FO0FBQ0EsT0FBTyxTQUFTLEtBQUssVUFBVSxFQUFFLDJCQUEyQixLQUFLLE9BQU87QUFDeEUsUUFBUSxLQUFLLEVBQUUsV0FBVyxLQUFLLE9BQU8sR0FBRyxVQUFVLEtBQUssVUFBVSxFQUFFLFVBQVU7QUFDOUU7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsMkNBQTJDLElBQUk7QUFDL0MsS0FBSztBQUNMO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLDZCQUE2QixtRUFBbUU7QUFDaEc7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSxVQUFVLDRCQUE0Qjs7QUFFdEM7QUFDQTtBQUNBO0FBQ0EscURBQXFELFdBQVc7QUFDaEU7QUFDQTtBQUNBO0FBQ0EsR0FBRzs7QUFFSDtBQUNBO0FBQ0E7O0FBRUE7QUFDQSxxRUFBcUUsVUFBVTtBQUMvRTtBQUNBOztBQUVBO0FBQ0Esb0VBQW9FLFNBQVM7QUFDN0U7QUFDQTs7QUFFQTtBQUNBLGdFQUFnRSxLQUFLO0FBQ3JFO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSxxQkFBcUI7QUFDckIsbUJBQW1CO0FBQ25CLCtCQUErQjtBQUMvQixlQUFlO0FBQ2YiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9kc24uanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGRlYnVnQnVpbGQgPSByZXF1aXJlKCcuLi9kZWJ1Zy1idWlsZC5qcycpO1xuY29uc3QgZGVidWdMb2dnZXIgPSByZXF1aXJlKCcuL2RlYnVnLWxvZ2dlci5qcycpO1xuXG4vKiogUmVndWxhciBleHByZXNzaW9uIHVzZWQgdG8gZXh0cmFjdCBvcmcgSUQgZnJvbSBhIERTTiBob3N0LiAqL1xuY29uc3QgT1JHX0lEX1JFR0VYID0gL15vKFxcZCspXFwuLztcblxuLyoqIFJlZ3VsYXIgZXhwcmVzc2lvbiB1c2VkIHRvIHBhcnNlIGEgRHNuLiAqL1xuY29uc3QgRFNOX1JFR0VYID0gL14oPzooXFx3Kyk6KVxcL1xcLyg/OihcXHcrKSg/OjooXFx3Kyk/KT9AKShbXFx3Li1dKykoPzo6KFxcZCspKT9cXC8oLispLztcblxuZnVuY3Rpb24gaXNWYWxpZFByb3RvY29sKHByb3RvY29sKSB7XG4gIHJldHVybiBwcm90b2NvbCA9PT0gJ2h0dHAnIHx8IHByb3RvY29sID09PSAnaHR0cHMnO1xufVxuXG4vKipcbiAqIFJlbmRlcnMgdGhlIHN0cmluZyByZXByZXNlbnRhdGlvbiBvZiB0aGlzIERzbi5cbiAqXG4gKiBCeSBkZWZhdWx0LCB0aGlzIHdpbGwgcmVuZGVyIHRoZSBwdWJsaWMgcmVwcmVzZW50YXRpb24gd2l0aG91dCB0aGUgcGFzc3dvcmRcbiAqIGNvbXBvbmVudC4gVG8gZ2V0IHRoZSBkZXByZWNhdGVkIHByaXZhdGUgcmVwcmVzZW50YXRpb24sIHNldCBgd2l0aFBhc3N3b3JkYFxuICogdG8gdHJ1ZS5cbiAqXG4gKiBAcGFyYW0gd2l0aFBhc3N3b3JkIFdoZW4gc2V0IHRvIHRydWUsIHRoZSBwYXNzd29yZCB3aWxsIGJlIGluY2x1ZGVkLlxuICovXG5mdW5jdGlvbiBkc25Ub1N0cmluZyhkc24sIHdpdGhQYXNzd29yZCA9IGZhbHNlKSB7XG4gIGNvbnN0IHsgaG9zdCwgcGF0aCwgcGFzcywgcG9ydCwgcHJvamVjdElkLCBwcm90b2NvbCwgcHVibGljS2V5IH0gPSBkc247XG4gIHJldHVybiAoXG4gICAgYCR7cHJvdG9jb2x9Oi8vJHtwdWJsaWNLZXl9JHt3aXRoUGFzc3dvcmQgJiYgcGFzcyA/IGA6JHtwYXNzfWAgOiAnJ31gICtcbiAgICBgQCR7aG9zdH0ke3BvcnQgPyBgOiR7cG9ydH1gIDogJyd9LyR7cGF0aCA/IGAke3BhdGh9L2AgOiBwYXRofSR7cHJvamVjdElkfWBcbiAgKTtcbn1cblxuLyoqXG4gKiBQYXJzZXMgYSBEc24gZnJvbSBhIGdpdmVuIHN0cmluZy5cbiAqXG4gKiBAcGFyYW0gc3RyIEEgRHNuIGFzIHN0cmluZ1xuICogQHJldHVybnMgRHNuIGFzIERzbkNvbXBvbmVudHMgb3IgdW5kZWZpbmVkIGlmIEBwYXJhbSBzdHIgaXMgbm90IGEgdmFsaWQgRFNOIHN0cmluZ1xuICovXG5mdW5jdGlvbiBkc25Gcm9tU3RyaW5nKHN0cikge1xuICBjb25zdCBtYXRjaCA9IERTTl9SRUdFWC5leGVjKHN0cik7XG5cbiAgaWYgKCFtYXRjaCkge1xuICAgIC8vIFRoaXMgc2hvdWxkIGJlIGxvZ2dlZCB0byB0aGUgY29uc29sZVxuICAgIGRlYnVnTG9nZ2VyLmNvbnNvbGVTYW5kYm94KCgpID0+IHtcbiAgICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBuby1jb25zb2xlXG4gICAgICBjb25zb2xlLmVycm9yKGBJbnZhbGlkIFNlbnRyeSBEc246ICR7c3RyfWApO1xuICAgIH0pO1xuICAgIHJldHVybiB1bmRlZmluZWQ7XG4gIH1cblxuICBjb25zdCBbcHJvdG9jb2wsIHB1YmxpY0tleSwgcGFzcyA9ICcnLCBob3N0ID0gJycsIHBvcnQgPSAnJywgbGFzdFBhdGggPSAnJ10gPSBtYXRjaC5zbGljZSgxKTtcbiAgbGV0IHBhdGggPSAnJztcbiAgbGV0IHByb2plY3RJZCA9IGxhc3RQYXRoO1xuXG4gIGNvbnN0IHNwbGl0ID0gcHJvamVjdElkLnNwbGl0KCcvJyk7XG4gIGlmIChzcGxpdC5sZW5ndGggPiAxKSB7XG4gICAgcGF0aCA9IHNwbGl0LnNsaWNlKDAsIC0xKS5qb2luKCcvJyk7XG4gICAgcHJvamVjdElkID0gc3BsaXQucG9wKCkgO1xuICB9XG5cbiAgaWYgKHByb2plY3RJZCkge1xuICAgIGNvbnN0IHByb2plY3RNYXRjaCA9IHByb2plY3RJZC5tYXRjaCgvXlxcZCsvKTtcbiAgICBpZiAocHJvamVjdE1hdGNoKSB7XG4gICAgICBwcm9qZWN0SWQgPSBwcm9qZWN0TWF0Y2hbMF07XG4gICAgfVxuICB9XG5cbiAgcmV0dXJuIGRzbkZyb21Db21wb25lbnRzKHsgaG9zdCwgcGFzcywgcGF0aCwgcHJvamVjdElkLCBwb3J0LCBwcm90b2NvbDogcHJvdG9jb2wgLCBwdWJsaWNLZXkgfSk7XG59XG5cbmZ1bmN0aW9uIGRzbkZyb21Db21wb25lbnRzKGNvbXBvbmVudHMpIHtcbiAgcmV0dXJuIHtcbiAgICBwcm90b2NvbDogY29tcG9uZW50cy5wcm90b2NvbCxcbiAgICBwdWJsaWNLZXk6IGNvbXBvbmVudHMucHVibGljS2V5IHx8ICcnLFxuICAgIHBhc3M6IGNvbXBvbmVudHMucGFzcyB8fCAnJyxcbiAgICBob3N0OiBjb21wb25lbnRzLmhvc3QsXG4gICAgcG9ydDogY29tcG9uZW50cy5wb3J0IHx8ICcnLFxuICAgIHBhdGg6IGNvbXBvbmVudHMucGF0aCB8fCAnJyxcbiAgICBwcm9qZWN0SWQ6IGNvbXBvbmVudHMucHJvamVjdElkLFxuICB9O1xufVxuXG5mdW5jdGlvbiB2YWxpZGF0ZURzbihkc24pIHtcbiAgaWYgKCFkZWJ1Z0J1aWxkLkRFQlVHX0JVSUxEKSB7XG4gICAgcmV0dXJuIHRydWU7XG4gIH1cblxuICBjb25zdCB7IHBvcnQsIHByb2plY3RJZCwgcHJvdG9jb2wgfSA9IGRzbjtcblxuICBjb25zdCByZXF1aXJlZENvbXBvbmVudHMgPSBbJ3Byb3RvY29sJywgJ3B1YmxpY0tleScsICdob3N0JywgJ3Byb2plY3RJZCddO1xuICBjb25zdCBoYXNNaXNzaW5nUmVxdWlyZWRDb21wb25lbnQgPSByZXF1aXJlZENvbXBvbmVudHMuZmluZChjb21wb25lbnQgPT4ge1xuICAgIGlmICghZHNuW2NvbXBvbmVudF0pIHtcbiAgICAgIGRlYnVnTG9nZ2VyLmRlYnVnLmVycm9yKGBJbnZhbGlkIFNlbnRyeSBEc246ICR7Y29tcG9uZW50fSBtaXNzaW5nYCk7XG4gICAgICByZXR1cm4gdHJ1ZTtcbiAgICB9XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9KTtcblxuICBpZiAoaGFzTWlzc2luZ1JlcXVpcmVkQ29tcG9uZW50KSB7XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG5cbiAgaWYgKCFwcm9qZWN0SWQubWF0Y2goL15cXGQrJC8pKSB7XG4gICAgZGVidWdMb2dnZXIuZGVidWcuZXJyb3IoYEludmFsaWQgU2VudHJ5IERzbjogSW52YWxpZCBwcm9qZWN0SWQgJHtwcm9qZWN0SWR9YCk7XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG5cbiAgaWYgKCFpc1ZhbGlkUHJvdG9jb2wocHJvdG9jb2wpKSB7XG4gICAgZGVidWdMb2dnZXIuZGVidWcuZXJyb3IoYEludmFsaWQgU2VudHJ5IERzbjogSW52YWxpZCBwcm90b2NvbCAke3Byb3RvY29sfWApO1xuICAgIHJldHVybiBmYWxzZTtcbiAgfVxuXG4gIGlmIChwb3J0ICYmIGlzTmFOKHBhcnNlSW50KHBvcnQsIDEwKSkpIHtcbiAgICBkZWJ1Z0xvZ2dlci5kZWJ1Zy5lcnJvcihgSW52YWxpZCBTZW50cnkgRHNuOiBJbnZhbGlkIHBvcnQgJHtwb3J0fWApO1xuICAgIHJldHVybiBmYWxzZTtcbiAgfVxuXG4gIHJldHVybiB0cnVlO1xufVxuXG4vKipcbiAqIEV4dHJhY3QgdGhlIG9yZyBJRCBmcm9tIGEgRFNOIGhvc3QuXG4gKlxuICogQHBhcmFtIGhvc3QgVGhlIGhvc3QgZnJvbSBhIERTTlxuICogQHJldHVybnMgVGhlIG9yZyBJRCBpZiBmb3VuZCwgdW5kZWZpbmVkIG90aGVyd2lzZVxuICovXG5mdW5jdGlvbiBleHRyYWN0T3JnSWRGcm9tRHNuSG9zdChob3N0KSB7XG4gIGNvbnN0IG1hdGNoID0gaG9zdC5tYXRjaChPUkdfSURfUkVHRVgpO1xuXG4gIHJldHVybiBtYXRjaD8uWzFdO1xufVxuXG4vKipcbiAqIENyZWF0ZXMgYSB2YWxpZCBTZW50cnkgRHNuIG9iamVjdCwgaWRlbnRpZnlpbmcgYSBTZW50cnkgaW5zdGFuY2UgYW5kIHByb2plY3QuXG4gKiBAcmV0dXJucyBhIHZhbGlkIERzbkNvbXBvbmVudHMgb2JqZWN0IG9yIGB1bmRlZmluZWRgIGlmIEBwYXJhbSBmcm9tIGlzIGFuIGludmFsaWQgRFNOIHNvdXJjZVxuICovXG5mdW5jdGlvbiBtYWtlRHNuKGZyb20pIHtcbiAgY29uc3QgY29tcG9uZW50cyA9IHR5cGVvZiBmcm9tID09PSAnc3RyaW5nJyA/IGRzbkZyb21TdHJpbmcoZnJvbSkgOiBkc25Gcm9tQ29tcG9uZW50cyhmcm9tKTtcbiAgaWYgKCFjb21wb25lbnRzIHx8ICF2YWxpZGF0ZURzbihjb21wb25lbnRzKSkge1xuICAgIHJldHVybiB1bmRlZmluZWQ7XG4gIH1cbiAgcmV0dXJuIGNvbXBvbmVudHM7XG59XG5cbmV4cG9ydHMuZHNuRnJvbVN0cmluZyA9IGRzbkZyb21TdHJpbmc7XG5leHBvcnRzLmRzblRvU3RyaW5nID0gZHNuVG9TdHJpbmc7XG5leHBvcnRzLmV4dHJhY3RPcmdJZEZyb21Ec25Ib3N0ID0gZXh0cmFjdE9yZ0lkRnJvbURzbkhvc3Q7XG5leHBvcnRzLm1ha2VEc24gPSBtYWtlRHNuO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9ZHNuLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/dsn.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/env.js":
/*!*************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/env.js ***!
  \*************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n/*\n * This module exists for optimizations in the build process through rollup and terser.  We define some global\n * constants, which can be overridden during build. By guarding certain pieces of code with functions that return these\n * constants, we can control whether or not they appear in the final bundle. (Any code guarded by a false condition will\n * never run, and will hence be dropped during treeshaking.) The two primary uses for this are stripping out calls to\n * `debug` and preventing node-related code from appearing in browser bundles.\n *\n * Attention:\n * This file should not be used to define constants/flags that are intended to be used for tree-shaking conducted by\n * users. These flags should live in their respective packages, as we identified user tooling (specifically webpack)\n * having issues tree-shaking these constants across package boundaries.\n * An example for this is the __SENTRY_DEBUG__ constant. It is declared in each package individually because we want\n * users to be able to shake away expressions that it guards.\n */\n\n/**\n * Figures out if we're building a browser bundle.\n *\n * @returns true if this is a browser bundle build.\n */\nfunction isBrowserBundle() {\n  return typeof __SENTRY_BROWSER_BUNDLE__ !== 'undefined' && !!__SENTRY_BROWSER_BUNDLE__;\n}\n\n/**\n * Get source of SDK.\n */\nfunction getSDKSource() {\n  // This comment is used to identify this line in the CDN bundle build step and replace this with \"return 'cdn';\"\n  /* __SENTRY_SDK_SOURCE__ */ return 'npm';\n}\n\nexports.getSDKSource = getSDKSource;\nexports.isBrowserBundle = isBrowserBundle;\n//# sourceMappingURL=env.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9lbnYuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEU7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsaUhBQWlIO0FBQ2pIO0FBQ0E7O0FBRUEsb0JBQW9CO0FBQ3BCLHVCQUF1QjtBQUN2QiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3V0aWxzL2Vudi5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuLypcbiAqIFRoaXMgbW9kdWxlIGV4aXN0cyBmb3Igb3B0aW1pemF0aW9ucyBpbiB0aGUgYnVpbGQgcHJvY2VzcyB0aHJvdWdoIHJvbGx1cCBhbmQgdGVyc2VyLiAgV2UgZGVmaW5lIHNvbWUgZ2xvYmFsXG4gKiBjb25zdGFudHMsIHdoaWNoIGNhbiBiZSBvdmVycmlkZGVuIGR1cmluZyBidWlsZC4gQnkgZ3VhcmRpbmcgY2VydGFpbiBwaWVjZXMgb2YgY29kZSB3aXRoIGZ1bmN0aW9ucyB0aGF0IHJldHVybiB0aGVzZVxuICogY29uc3RhbnRzLCB3ZSBjYW4gY29udHJvbCB3aGV0aGVyIG9yIG5vdCB0aGV5IGFwcGVhciBpbiB0aGUgZmluYWwgYnVuZGxlLiAoQW55IGNvZGUgZ3VhcmRlZCBieSBhIGZhbHNlIGNvbmRpdGlvbiB3aWxsXG4gKiBuZXZlciBydW4sIGFuZCB3aWxsIGhlbmNlIGJlIGRyb3BwZWQgZHVyaW5nIHRyZWVzaGFraW5nLikgVGhlIHR3byBwcmltYXJ5IHVzZXMgZm9yIHRoaXMgYXJlIHN0cmlwcGluZyBvdXQgY2FsbHMgdG9cbiAqIGBkZWJ1Z2AgYW5kIHByZXZlbnRpbmcgbm9kZS1yZWxhdGVkIGNvZGUgZnJvbSBhcHBlYXJpbmcgaW4gYnJvd3NlciBidW5kbGVzLlxuICpcbiAqIEF0dGVudGlvbjpcbiAqIFRoaXMgZmlsZSBzaG91bGQgbm90IGJlIHVzZWQgdG8gZGVmaW5lIGNvbnN0YW50cy9mbGFncyB0aGF0IGFyZSBpbnRlbmRlZCB0byBiZSB1c2VkIGZvciB0cmVlLXNoYWtpbmcgY29uZHVjdGVkIGJ5XG4gKiB1c2Vycy4gVGhlc2UgZmxhZ3Mgc2hvdWxkIGxpdmUgaW4gdGhlaXIgcmVzcGVjdGl2ZSBwYWNrYWdlcywgYXMgd2UgaWRlbnRpZmllZCB1c2VyIHRvb2xpbmcgKHNwZWNpZmljYWxseSB3ZWJwYWNrKVxuICogaGF2aW5nIGlzc3VlcyB0cmVlLXNoYWtpbmcgdGhlc2UgY29uc3RhbnRzIGFjcm9zcyBwYWNrYWdlIGJvdW5kYXJpZXMuXG4gKiBBbiBleGFtcGxlIGZvciB0aGlzIGlzIHRoZSBfX1NFTlRSWV9ERUJVR19fIGNvbnN0YW50LiBJdCBpcyBkZWNsYXJlZCBpbiBlYWNoIHBhY2thZ2UgaW5kaXZpZHVhbGx5IGJlY2F1c2Ugd2Ugd2FudFxuICogdXNlcnMgdG8gYmUgYWJsZSB0byBzaGFrZSBhd2F5IGV4cHJlc3Npb25zIHRoYXQgaXQgZ3VhcmRzLlxuICovXG5cbi8qKlxuICogRmlndXJlcyBvdXQgaWYgd2UncmUgYnVpbGRpbmcgYSBicm93c2VyIGJ1bmRsZS5cbiAqXG4gKiBAcmV0dXJucyB0cnVlIGlmIHRoaXMgaXMgYSBicm93c2VyIGJ1bmRsZSBidWlsZC5cbiAqL1xuZnVuY3Rpb24gaXNCcm93c2VyQnVuZGxlKCkge1xuICByZXR1cm4gdHlwZW9mIF9fU0VOVFJZX0JST1dTRVJfQlVORExFX18gIT09ICd1bmRlZmluZWQnICYmICEhX19TRU5UUllfQlJPV1NFUl9CVU5ETEVfXztcbn1cblxuLyoqXG4gKiBHZXQgc291cmNlIG9mIFNESy5cbiAqL1xuZnVuY3Rpb24gZ2V0U0RLU291cmNlKCkge1xuICAvLyBUaGlzIGNvbW1lbnQgaXMgdXNlZCB0byBpZGVudGlmeSB0aGlzIGxpbmUgaW4gdGhlIENETiBidW5kbGUgYnVpbGQgc3RlcCBhbmQgcmVwbGFjZSB0aGlzIHdpdGggXCJyZXR1cm4gJ2Nkbic7XCJcbiAgLyogX19TRU5UUllfU0RLX1NPVVJDRV9fICovIHJldHVybiAnbnBtJztcbn1cblxuZXhwb3J0cy5nZXRTREtTb3VyY2UgPSBnZXRTREtTb3VyY2U7XG5leHBvcnRzLmlzQnJvd3NlckJ1bmRsZSA9IGlzQnJvd3NlckJ1bmRsZTtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWVudi5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/env.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/envelope.js":
/*!******************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/envelope.js ***!
  \******************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst carrier = __webpack_require__(/*! ../carrier.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/carrier.js\");\nconst dsn = __webpack_require__(/*! ./dsn.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/dsn.js\");\nconst normalize = __webpack_require__(/*! ./normalize.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/normalize.js\");\nconst worldwide = __webpack_require__(/*! ./worldwide.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/worldwide.js\");\n\n/**\n * Creates an envelope.\n * Make sure to always explicitly provide the generic to this function\n * so that the envelope types resolve correctly.\n */\nfunction createEnvelope(headers, items = []) {\n  return [headers, items] ;\n}\n\n/**\n * Add an item to an envelope.\n * Make sure to always explicitly provide the generic to this function\n * so that the envelope types resolve correctly.\n */\nfunction addItemToEnvelope(envelope, newItem) {\n  const [headers, items] = envelope;\n  return [headers, [...items, newItem]] ;\n}\n\n/**\n * Convenience function to loop through the items and item types of an envelope.\n * (This function was mostly created because working with envelope types is painful at the moment)\n *\n * If the callback returns true, the rest of the items will be skipped.\n */\nfunction forEachEnvelopeItem(\n  envelope,\n  callback,\n) {\n  const envelopeItems = envelope[1];\n\n  for (const envelopeItem of envelopeItems) {\n    const envelopeItemType = envelopeItem[0].type;\n    const result = callback(envelopeItem, envelopeItemType);\n\n    if (result) {\n      return true;\n    }\n  }\n\n  return false;\n}\n\n/**\n * Returns true if the envelope contains any of the given envelope item types\n */\nfunction envelopeContainsItemType(envelope, types) {\n  return forEachEnvelopeItem(envelope, (_, type) => types.includes(type));\n}\n\n/**\n * Encode a string to UTF8 array.\n */\nfunction encodeUTF8(input) {\n  const carrier$1 = carrier.getSentryCarrier(worldwide.GLOBAL_OBJ);\n  return carrier$1.encodePolyfill ? carrier$1.encodePolyfill(input) : new TextEncoder().encode(input);\n}\n\n/**\n * Decode a UTF8 array to string.\n */\nfunction decodeUTF8(input) {\n  const carrier$1 = carrier.getSentryCarrier(worldwide.GLOBAL_OBJ);\n  return carrier$1.decodePolyfill ? carrier$1.decodePolyfill(input) : new TextDecoder().decode(input);\n}\n\n/**\n * Serializes an envelope.\n */\nfunction serializeEnvelope(envelope) {\n  const [envHeaders, items] = envelope;\n  // Initially we construct our envelope as a string and only convert to binary chunks if we encounter binary data\n  let parts = JSON.stringify(envHeaders);\n\n  function append(next) {\n    if (typeof parts === 'string') {\n      parts = typeof next === 'string' ? parts + next : [encodeUTF8(parts), next];\n    } else {\n      parts.push(typeof next === 'string' ? encodeUTF8(next) : next);\n    }\n  }\n\n  for (const item of items) {\n    const [itemHeaders, payload] = item;\n\n    append(`\\n${JSON.stringify(itemHeaders)}\\n`);\n\n    if (typeof payload === 'string' || payload instanceof Uint8Array) {\n      append(payload);\n    } else {\n      let stringifiedPayload;\n      try {\n        stringifiedPayload = JSON.stringify(payload);\n      } catch {\n        // In case, despite all our efforts to keep `payload` circular-dependency-free, `JSON.stringify()` still\n        // fails, we try again after normalizing it again with infinite normalization depth. This of course has a\n        // performance impact but in this case a performance hit is better than throwing.\n        stringifiedPayload = JSON.stringify(normalize.normalize(payload));\n      }\n      append(stringifiedPayload);\n    }\n  }\n\n  return typeof parts === 'string' ? parts : concatBuffers(parts);\n}\n\nfunction concatBuffers(buffers) {\n  const totalLength = buffers.reduce((acc, buf) => acc + buf.length, 0);\n\n  const merged = new Uint8Array(totalLength);\n  let offset = 0;\n  for (const buffer of buffers) {\n    merged.set(buffer, offset);\n    offset += buffer.length;\n  }\n\n  return merged;\n}\n\n/**\n * Parses an envelope\n */\nfunction parseEnvelope(env) {\n  let buffer = typeof env === 'string' ? encodeUTF8(env) : env;\n\n  function readBinary(length) {\n    const bin = buffer.subarray(0, length);\n    // Replace the buffer with the remaining data excluding trailing newline\n    buffer = buffer.subarray(length + 1);\n    return bin;\n  }\n\n  function readJson() {\n    let i = buffer.indexOf(0xa);\n    // If we couldn't find a newline, we must have found the end of the buffer\n    if (i < 0) {\n      i = buffer.length;\n    }\n\n    return JSON.parse(decodeUTF8(readBinary(i))) ;\n  }\n\n  const envelopeHeader = readJson();\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  const items = [];\n\n  while (buffer.length) {\n    const itemHeader = readJson();\n    const binaryLength = typeof itemHeader.length === 'number' ? itemHeader.length : undefined;\n\n    items.push([itemHeader, binaryLength ? readBinary(binaryLength) : readJson()]);\n  }\n\n  return [envelopeHeader, items];\n}\n\n/**\n * Creates envelope item for a single span\n */\nfunction createSpanEnvelopeItem(spanJson) {\n  const spanHeaders = {\n    type: 'span',\n  };\n\n  return [spanHeaders, spanJson];\n}\n\n/**\n * Creates attachment envelope items\n */\nfunction createAttachmentEnvelopeItem(attachment) {\n  const buffer = typeof attachment.data === 'string' ? encodeUTF8(attachment.data) : attachment.data;\n\n  return [\n    {\n      type: 'attachment',\n      length: buffer.length,\n      filename: attachment.filename,\n      content_type: attachment.contentType,\n      attachment_type: attachment.attachmentType,\n    },\n    buffer,\n  ];\n}\n\nconst ITEM_TYPE_TO_DATA_CATEGORY_MAP = {\n  session: 'session',\n  sessions: 'session',\n  attachment: 'attachment',\n  transaction: 'transaction',\n  event: 'error',\n  client_report: 'internal',\n  user_report: 'default',\n  profile: 'profile',\n  profile_chunk: 'profile',\n  replay_event: 'replay',\n  replay_recording: 'replay',\n  check_in: 'monitor',\n  feedback: 'feedback',\n  span: 'span',\n  raw_security: 'security',\n  log: 'log_item',\n};\n\n/**\n * Maps the type of an envelope item to a data category.\n */\nfunction envelopeItemTypeToDataCategory(type) {\n  return ITEM_TYPE_TO_DATA_CATEGORY_MAP[type];\n}\n\n/** Extracts the minimal SDK info from the metadata or an events */\nfunction getSdkMetadataForEnvelopeHeader(metadataOrEvent) {\n  if (!metadataOrEvent?.sdk) {\n    return;\n  }\n  const { name, version } = metadataOrEvent.sdk;\n  return { name, version };\n}\n\n/**\n * Creates event envelope headers, based on event, sdk info and tunnel\n * Note: This function was extracted from the core package to make it available in Replay\n */\nfunction createEventEnvelopeHeaders(\n  event,\n  sdkInfo,\n  tunnel,\n  dsn$1,\n) {\n  const dynamicSamplingContext = event.sdkProcessingMetadata?.dynamicSamplingContext;\n  return {\n    event_id: event.event_id ,\n    sent_at: new Date().toISOString(),\n    ...(sdkInfo && { sdk: sdkInfo }),\n    ...(!!tunnel && dsn$1 && { dsn: dsn.dsnToString(dsn$1) }),\n    ...(dynamicSamplingContext && {\n      trace: dynamicSamplingContext,\n    }),\n  };\n}\n\nexports.addItemToEnvelope = addItemToEnvelope;\nexports.createAttachmentEnvelopeItem = createAttachmentEnvelopeItem;\nexports.createEnvelope = createEnvelope;\nexports.createEventEnvelopeHeaders = createEventEnvelopeHeaders;\nexports.createSpanEnvelopeItem = createSpanEnvelopeItem;\nexports.envelopeContainsItemType = envelopeContainsItemType;\nexports.envelopeItemTypeToDataCategory = envelopeItemTypeToDataCategory;\nexports.forEachEnvelopeItem = forEachEnvelopeItem;\nexports.getSdkMetadataForEnvelopeHeader = getSdkMetadataForEnvelopeHeader;\nexports.parseEnvelope = parseEnvelope;\nexports.serializeEnvelope = serializeEnvelope;\n//# sourceMappingURL=envelope.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9lbnZlbG9wZS5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxnQkFBZ0IsbUJBQU8sQ0FBQyxvSEFBZTtBQUN2QyxZQUFZLG1CQUFPLENBQUMsaUhBQVU7QUFDOUIsa0JBQWtCLG1CQUFPLENBQUMsNkhBQWdCO0FBQzFDLGtCQUFrQixtQkFBTyxDQUFDLDZIQUFnQjs7QUFFMUM7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0EsTUFBTTtBQUNOO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBLGdCQUFnQiw0QkFBNEI7O0FBRTVDO0FBQ0E7QUFDQSxNQUFNO0FBQ047QUFDQTtBQUNBO0FBQ0EsUUFBUTtBQUNSO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEtBQUs7QUFDTDtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsVUFBVSxnQkFBZ0I7QUFDMUIsV0FBVztBQUNYOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxxQkFBcUIsY0FBYztBQUNuQywrQkFBK0IsNkJBQTZCO0FBQzVEO0FBQ0E7QUFDQSxLQUFLO0FBQ0w7QUFDQTs7QUFFQSx5QkFBeUI7QUFDekIsb0NBQW9DO0FBQ3BDLHNCQUFzQjtBQUN0QixrQ0FBa0M7QUFDbEMsOEJBQThCO0FBQzlCLGdDQUFnQztBQUNoQyxzQ0FBc0M7QUFDdEMsMkJBQTJCO0FBQzNCLHVDQUF1QztBQUN2QyxxQkFBcUI7QUFDckIseUJBQXlCO0FBQ3pCIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvZW52ZWxvcGUuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGNhcnJpZXIgPSByZXF1aXJlKCcuLi9jYXJyaWVyLmpzJyk7XG5jb25zdCBkc24gPSByZXF1aXJlKCcuL2Rzbi5qcycpO1xuY29uc3Qgbm9ybWFsaXplID0gcmVxdWlyZSgnLi9ub3JtYWxpemUuanMnKTtcbmNvbnN0IHdvcmxkd2lkZSA9IHJlcXVpcmUoJy4vd29ybGR3aWRlLmpzJyk7XG5cbi8qKlxuICogQ3JlYXRlcyBhbiBlbnZlbG9wZS5cbiAqIE1ha2Ugc3VyZSB0byBhbHdheXMgZXhwbGljaXRseSBwcm92aWRlIHRoZSBnZW5lcmljIHRvIHRoaXMgZnVuY3Rpb25cbiAqIHNvIHRoYXQgdGhlIGVudmVsb3BlIHR5cGVzIHJlc29sdmUgY29ycmVjdGx5LlxuICovXG5mdW5jdGlvbiBjcmVhdGVFbnZlbG9wZShoZWFkZXJzLCBpdGVtcyA9IFtdKSB7XG4gIHJldHVybiBbaGVhZGVycywgaXRlbXNdIDtcbn1cblxuLyoqXG4gKiBBZGQgYW4gaXRlbSB0byBhbiBlbnZlbG9wZS5cbiAqIE1ha2Ugc3VyZSB0byBhbHdheXMgZXhwbGljaXRseSBwcm92aWRlIHRoZSBnZW5lcmljIHRvIHRoaXMgZnVuY3Rpb25cbiAqIHNvIHRoYXQgdGhlIGVudmVsb3BlIHR5cGVzIHJlc29sdmUgY29ycmVjdGx5LlxuICovXG5mdW5jdGlvbiBhZGRJdGVtVG9FbnZlbG9wZShlbnZlbG9wZSwgbmV3SXRlbSkge1xuICBjb25zdCBbaGVhZGVycywgaXRlbXNdID0gZW52ZWxvcGU7XG4gIHJldHVybiBbaGVhZGVycywgWy4uLml0ZW1zLCBuZXdJdGVtXV0gO1xufVxuXG4vKipcbiAqIENvbnZlbmllbmNlIGZ1bmN0aW9uIHRvIGxvb3AgdGhyb3VnaCB0aGUgaXRlbXMgYW5kIGl0ZW0gdHlwZXMgb2YgYW4gZW52ZWxvcGUuXG4gKiAoVGhpcyBmdW5jdGlvbiB3YXMgbW9zdGx5IGNyZWF0ZWQgYmVjYXVzZSB3b3JraW5nIHdpdGggZW52ZWxvcGUgdHlwZXMgaXMgcGFpbmZ1bCBhdCB0aGUgbW9tZW50KVxuICpcbiAqIElmIHRoZSBjYWxsYmFjayByZXR1cm5zIHRydWUsIHRoZSByZXN0IG9mIHRoZSBpdGVtcyB3aWxsIGJlIHNraXBwZWQuXG4gKi9cbmZ1bmN0aW9uIGZvckVhY2hFbnZlbG9wZUl0ZW0oXG4gIGVudmVsb3BlLFxuICBjYWxsYmFjayxcbikge1xuICBjb25zdCBlbnZlbG9wZUl0ZW1zID0gZW52ZWxvcGVbMV07XG5cbiAgZm9yIChjb25zdCBlbnZlbG9wZUl0ZW0gb2YgZW52ZWxvcGVJdGVtcykge1xuICAgIGNvbnN0IGVudmVsb3BlSXRlbVR5cGUgPSBlbnZlbG9wZUl0ZW1bMF0udHlwZTtcbiAgICBjb25zdCByZXN1bHQgPSBjYWxsYmFjayhlbnZlbG9wZUl0ZW0sIGVudmVsb3BlSXRlbVR5cGUpO1xuXG4gICAgaWYgKHJlc3VsdCkge1xuICAgICAgcmV0dXJuIHRydWU7XG4gICAgfVxuICB9XG5cbiAgcmV0dXJuIGZhbHNlO1xufVxuXG4vKipcbiAqIFJldHVybnMgdHJ1ZSBpZiB0aGUgZW52ZWxvcGUgY29udGFpbnMgYW55IG9mIHRoZSBnaXZlbiBlbnZlbG9wZSBpdGVtIHR5cGVzXG4gKi9cbmZ1bmN0aW9uIGVudmVsb3BlQ29udGFpbnNJdGVtVHlwZShlbnZlbG9wZSwgdHlwZXMpIHtcbiAgcmV0dXJuIGZvckVhY2hFbnZlbG9wZUl0ZW0oZW52ZWxvcGUsIChfLCB0eXBlKSA9PiB0eXBlcy5pbmNsdWRlcyh0eXBlKSk7XG59XG5cbi8qKlxuICogRW5jb2RlIGEgc3RyaW5nIHRvIFVURjggYXJyYXkuXG4gKi9cbmZ1bmN0aW9uIGVuY29kZVVURjgoaW5wdXQpIHtcbiAgY29uc3QgY2FycmllciQxID0gY2Fycmllci5nZXRTZW50cnlDYXJyaWVyKHdvcmxkd2lkZS5HTE9CQUxfT0JKKTtcbiAgcmV0dXJuIGNhcnJpZXIkMS5lbmNvZGVQb2x5ZmlsbCA/IGNhcnJpZXIkMS5lbmNvZGVQb2x5ZmlsbChpbnB1dCkgOiBuZXcgVGV4dEVuY29kZXIoKS5lbmNvZGUoaW5wdXQpO1xufVxuXG4vKipcbiAqIERlY29kZSBhIFVURjggYXJyYXkgdG8gc3RyaW5nLlxuICovXG5mdW5jdGlvbiBkZWNvZGVVVEY4KGlucHV0KSB7XG4gIGNvbnN0IGNhcnJpZXIkMSA9IGNhcnJpZXIuZ2V0U2VudHJ5Q2Fycmllcih3b3JsZHdpZGUuR0xPQkFMX09CSik7XG4gIHJldHVybiBjYXJyaWVyJDEuZGVjb2RlUG9seWZpbGwgPyBjYXJyaWVyJDEuZGVjb2RlUG9seWZpbGwoaW5wdXQpIDogbmV3IFRleHREZWNvZGVyKCkuZGVjb2RlKGlucHV0KTtcbn1cblxuLyoqXG4gKiBTZXJpYWxpemVzIGFuIGVudmVsb3BlLlxuICovXG5mdW5jdGlvbiBzZXJpYWxpemVFbnZlbG9wZShlbnZlbG9wZSkge1xuICBjb25zdCBbZW52SGVhZGVycywgaXRlbXNdID0gZW52ZWxvcGU7XG4gIC8vIEluaXRpYWxseSB3ZSBjb25zdHJ1Y3Qgb3VyIGVudmVsb3BlIGFzIGEgc3RyaW5nIGFuZCBvbmx5IGNvbnZlcnQgdG8gYmluYXJ5IGNodW5rcyBpZiB3ZSBlbmNvdW50ZXIgYmluYXJ5IGRhdGFcbiAgbGV0IHBhcnRzID0gSlNPTi5zdHJpbmdpZnkoZW52SGVhZGVycyk7XG5cbiAgZnVuY3Rpb24gYXBwZW5kKG5leHQpIHtcbiAgICBpZiAodHlwZW9mIHBhcnRzID09PSAnc3RyaW5nJykge1xuICAgICAgcGFydHMgPSB0eXBlb2YgbmV4dCA9PT0gJ3N0cmluZycgPyBwYXJ0cyArIG5leHQgOiBbZW5jb2RlVVRGOChwYXJ0cyksIG5leHRdO1xuICAgIH0gZWxzZSB7XG4gICAgICBwYXJ0cy5wdXNoKHR5cGVvZiBuZXh0ID09PSAnc3RyaW5nJyA/IGVuY29kZVVURjgobmV4dCkgOiBuZXh0KTtcbiAgICB9XG4gIH1cblxuICBmb3IgKGNvbnN0IGl0ZW0gb2YgaXRlbXMpIHtcbiAgICBjb25zdCBbaXRlbUhlYWRlcnMsIHBheWxvYWRdID0gaXRlbTtcblxuICAgIGFwcGVuZChgXFxuJHtKU09OLnN0cmluZ2lmeShpdGVtSGVhZGVycyl9XFxuYCk7XG5cbiAgICBpZiAodHlwZW9mIHBheWxvYWQgPT09ICdzdHJpbmcnIHx8IHBheWxvYWQgaW5zdGFuY2VvZiBVaW50OEFycmF5KSB7XG4gICAgICBhcHBlbmQocGF5bG9hZCk7XG4gICAgfSBlbHNlIHtcbiAgICAgIGxldCBzdHJpbmdpZmllZFBheWxvYWQ7XG4gICAgICB0cnkge1xuICAgICAgICBzdHJpbmdpZmllZFBheWxvYWQgPSBKU09OLnN0cmluZ2lmeShwYXlsb2FkKTtcbiAgICAgIH0gY2F0Y2gge1xuICAgICAgICAvLyBJbiBjYXNlLCBkZXNwaXRlIGFsbCBvdXIgZWZmb3J0cyB0byBrZWVwIGBwYXlsb2FkYCBjaXJjdWxhci1kZXBlbmRlbmN5LWZyZWUsIGBKU09OLnN0cmluZ2lmeSgpYCBzdGlsbFxuICAgICAgICAvLyBmYWlscywgd2UgdHJ5IGFnYWluIGFmdGVyIG5vcm1hbGl6aW5nIGl0IGFnYWluIHdpdGggaW5maW5pdGUgbm9ybWFsaXphdGlvbiBkZXB0aC4gVGhpcyBvZiBjb3Vyc2UgaGFzIGFcbiAgICAgICAgLy8gcGVyZm9ybWFuY2UgaW1wYWN0IGJ1dCBpbiB0aGlzIGNhc2UgYSBwZXJmb3JtYW5jZSBoaXQgaXMgYmV0dGVyIHRoYW4gdGhyb3dpbmcuXG4gICAgICAgIHN0cmluZ2lmaWVkUGF5bG9hZCA9IEpTT04uc3RyaW5naWZ5KG5vcm1hbGl6ZS5ub3JtYWxpemUocGF5bG9hZCkpO1xuICAgICAgfVxuICAgICAgYXBwZW5kKHN0cmluZ2lmaWVkUGF5bG9hZCk7XG4gICAgfVxuICB9XG5cbiAgcmV0dXJuIHR5cGVvZiBwYXJ0cyA9PT0gJ3N0cmluZycgPyBwYXJ0cyA6IGNvbmNhdEJ1ZmZlcnMocGFydHMpO1xufVxuXG5mdW5jdGlvbiBjb25jYXRCdWZmZXJzKGJ1ZmZlcnMpIHtcbiAgY29uc3QgdG90YWxMZW5ndGggPSBidWZmZXJzLnJlZHVjZSgoYWNjLCBidWYpID0+IGFjYyArIGJ1Zi5sZW5ndGgsIDApO1xuXG4gIGNvbnN0IG1lcmdlZCA9IG5ldyBVaW50OEFycmF5KHRvdGFsTGVuZ3RoKTtcbiAgbGV0IG9mZnNldCA9IDA7XG4gIGZvciAoY29uc3QgYnVmZmVyIG9mIGJ1ZmZlcnMpIHtcbiAgICBtZXJnZWQuc2V0KGJ1ZmZlciwgb2Zmc2V0KTtcbiAgICBvZmZzZXQgKz0gYnVmZmVyLmxlbmd0aDtcbiAgfVxuXG4gIHJldHVybiBtZXJnZWQ7XG59XG5cbi8qKlxuICogUGFyc2VzIGFuIGVudmVsb3BlXG4gKi9cbmZ1bmN0aW9uIHBhcnNlRW52ZWxvcGUoZW52KSB7XG4gIGxldCBidWZmZXIgPSB0eXBlb2YgZW52ID09PSAnc3RyaW5nJyA/IGVuY29kZVVURjgoZW52KSA6IGVudjtcblxuICBmdW5jdGlvbiByZWFkQmluYXJ5KGxlbmd0aCkge1xuICAgIGNvbnN0IGJpbiA9IGJ1ZmZlci5zdWJhcnJheSgwLCBsZW5ndGgpO1xuICAgIC8vIFJlcGxhY2UgdGhlIGJ1ZmZlciB3aXRoIHRoZSByZW1haW5pbmcgZGF0YSBleGNsdWRpbmcgdHJhaWxpbmcgbmV3bGluZVxuICAgIGJ1ZmZlciA9IGJ1ZmZlci5zdWJhcnJheShsZW5ndGggKyAxKTtcbiAgICByZXR1cm4gYmluO1xuICB9XG5cbiAgZnVuY3Rpb24gcmVhZEpzb24oKSB7XG4gICAgbGV0IGkgPSBidWZmZXIuaW5kZXhPZigweGEpO1xuICAgIC8vIElmIHdlIGNvdWxkbid0IGZpbmQgYSBuZXdsaW5lLCB3ZSBtdXN0IGhhdmUgZm91bmQgdGhlIGVuZCBvZiB0aGUgYnVmZmVyXG4gICAgaWYgKGkgPCAwKSB7XG4gICAgICBpID0gYnVmZmVyLmxlbmd0aDtcbiAgICB9XG5cbiAgICByZXR1cm4gSlNPTi5wYXJzZShkZWNvZGVVVEY4KHJlYWRCaW5hcnkoaSkpKSA7XG4gIH1cblxuICBjb25zdCBlbnZlbG9wZUhlYWRlciA9IHJlYWRKc29uKCk7XG4gIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tZXhwbGljaXQtYW55XG4gIGNvbnN0IGl0ZW1zID0gW107XG5cbiAgd2hpbGUgKGJ1ZmZlci5sZW5ndGgpIHtcbiAgICBjb25zdCBpdGVtSGVhZGVyID0gcmVhZEpzb24oKTtcbiAgICBjb25zdCBiaW5hcnlMZW5ndGggPSB0eXBlb2YgaXRlbUhlYWRlci5sZW5ndGggPT09ICdudW1iZXInID8gaXRlbUhlYWRlci5sZW5ndGggOiB1bmRlZmluZWQ7XG5cbiAgICBpdGVtcy5wdXNoKFtpdGVtSGVhZGVyLCBiaW5hcnlMZW5ndGggPyByZWFkQmluYXJ5KGJpbmFyeUxlbmd0aCkgOiByZWFkSnNvbigpXSk7XG4gIH1cblxuICByZXR1cm4gW2VudmVsb3BlSGVhZGVyLCBpdGVtc107XG59XG5cbi8qKlxuICogQ3JlYXRlcyBlbnZlbG9wZSBpdGVtIGZvciBhIHNpbmdsZSBzcGFuXG4gKi9cbmZ1bmN0aW9uIGNyZWF0ZVNwYW5FbnZlbG9wZUl0ZW0oc3Bhbkpzb24pIHtcbiAgY29uc3Qgc3BhbkhlYWRlcnMgPSB7XG4gICAgdHlwZTogJ3NwYW4nLFxuICB9O1xuXG4gIHJldHVybiBbc3BhbkhlYWRlcnMsIHNwYW5Kc29uXTtcbn1cblxuLyoqXG4gKiBDcmVhdGVzIGF0dGFjaG1lbnQgZW52ZWxvcGUgaXRlbXNcbiAqL1xuZnVuY3Rpb24gY3JlYXRlQXR0YWNobWVudEVudmVsb3BlSXRlbShhdHRhY2htZW50KSB7XG4gIGNvbnN0IGJ1ZmZlciA9IHR5cGVvZiBhdHRhY2htZW50LmRhdGEgPT09ICdzdHJpbmcnID8gZW5jb2RlVVRGOChhdHRhY2htZW50LmRhdGEpIDogYXR0YWNobWVudC5kYXRhO1xuXG4gIHJldHVybiBbXG4gICAge1xuICAgICAgdHlwZTogJ2F0dGFjaG1lbnQnLFxuICAgICAgbGVuZ3RoOiBidWZmZXIubGVuZ3RoLFxuICAgICAgZmlsZW5hbWU6IGF0dGFjaG1lbnQuZmlsZW5hbWUsXG4gICAgICBjb250ZW50X3R5cGU6IGF0dGFjaG1lbnQuY29udGVudFR5cGUsXG4gICAgICBhdHRhY2htZW50X3R5cGU6IGF0dGFjaG1lbnQuYXR0YWNobWVudFR5cGUsXG4gICAgfSxcbiAgICBidWZmZXIsXG4gIF07XG59XG5cbmNvbnN0IElURU1fVFlQRV9UT19EQVRBX0NBVEVHT1JZX01BUCA9IHtcbiAgc2Vzc2lvbjogJ3Nlc3Npb24nLFxuICBzZXNzaW9uczogJ3Nlc3Npb24nLFxuICBhdHRhY2htZW50OiAnYXR0YWNobWVudCcsXG4gIHRyYW5zYWN0aW9uOiAndHJhbnNhY3Rpb24nLFxuICBldmVudDogJ2Vycm9yJyxcbiAgY2xpZW50X3JlcG9ydDogJ2ludGVybmFsJyxcbiAgdXNlcl9yZXBvcnQ6ICdkZWZhdWx0JyxcbiAgcHJvZmlsZTogJ3Byb2ZpbGUnLFxuICBwcm9maWxlX2NodW5rOiAncHJvZmlsZScsXG4gIHJlcGxheV9ldmVudDogJ3JlcGxheScsXG4gIHJlcGxheV9yZWNvcmRpbmc6ICdyZXBsYXknLFxuICBjaGVja19pbjogJ21vbml0b3InLFxuICBmZWVkYmFjazogJ2ZlZWRiYWNrJyxcbiAgc3BhbjogJ3NwYW4nLFxuICByYXdfc2VjdXJpdHk6ICdzZWN1cml0eScsXG4gIGxvZzogJ2xvZ19pdGVtJyxcbn07XG5cbi8qKlxuICogTWFwcyB0aGUgdHlwZSBvZiBhbiBlbnZlbG9wZSBpdGVtIHRvIGEgZGF0YSBjYXRlZ29yeS5cbiAqL1xuZnVuY3Rpb24gZW52ZWxvcGVJdGVtVHlwZVRvRGF0YUNhdGVnb3J5KHR5cGUpIHtcbiAgcmV0dXJuIElURU1fVFlQRV9UT19EQVRBX0NBVEVHT1JZX01BUFt0eXBlXTtcbn1cblxuLyoqIEV4dHJhY3RzIHRoZSBtaW5pbWFsIFNESyBpbmZvIGZyb20gdGhlIG1ldGFkYXRhIG9yIGFuIGV2ZW50cyAqL1xuZnVuY3Rpb24gZ2V0U2RrTWV0YWRhdGFGb3JFbnZlbG9wZUhlYWRlcihtZXRhZGF0YU9yRXZlbnQpIHtcbiAgaWYgKCFtZXRhZGF0YU9yRXZlbnQ/LnNkaykge1xuICAgIHJldHVybjtcbiAgfVxuICBjb25zdCB7IG5hbWUsIHZlcnNpb24gfSA9IG1ldGFkYXRhT3JFdmVudC5zZGs7XG4gIHJldHVybiB7IG5hbWUsIHZlcnNpb24gfTtcbn1cblxuLyoqXG4gKiBDcmVhdGVzIGV2ZW50IGVudmVsb3BlIGhlYWRlcnMsIGJhc2VkIG9uIGV2ZW50LCBzZGsgaW5mbyBhbmQgdHVubmVsXG4gKiBOb3RlOiBUaGlzIGZ1bmN0aW9uIHdhcyBleHRyYWN0ZWQgZnJvbSB0aGUgY29yZSBwYWNrYWdlIHRvIG1ha2UgaXQgYXZhaWxhYmxlIGluIFJlcGxheVxuICovXG5mdW5jdGlvbiBjcmVhdGVFdmVudEVudmVsb3BlSGVhZGVycyhcbiAgZXZlbnQsXG4gIHNka0luZm8sXG4gIHR1bm5lbCxcbiAgZHNuJDEsXG4pIHtcbiAgY29uc3QgZHluYW1pY1NhbXBsaW5nQ29udGV4dCA9IGV2ZW50LnNka1Byb2Nlc3NpbmdNZXRhZGF0YT8uZHluYW1pY1NhbXBsaW5nQ29udGV4dDtcbiAgcmV0dXJuIHtcbiAgICBldmVudF9pZDogZXZlbnQuZXZlbnRfaWQgLFxuICAgIHNlbnRfYXQ6IG5ldyBEYXRlKCkudG9JU09TdHJpbmcoKSxcbiAgICAuLi4oc2RrSW5mbyAmJiB7IHNkazogc2RrSW5mbyB9KSxcbiAgICAuLi4oISF0dW5uZWwgJiYgZHNuJDEgJiYgeyBkc246IGRzbi5kc25Ub1N0cmluZyhkc24kMSkgfSksXG4gICAgLi4uKGR5bmFtaWNTYW1wbGluZ0NvbnRleHQgJiYge1xuICAgICAgdHJhY2U6IGR5bmFtaWNTYW1wbGluZ0NvbnRleHQsXG4gICAgfSksXG4gIH07XG59XG5cbmV4cG9ydHMuYWRkSXRlbVRvRW52ZWxvcGUgPSBhZGRJdGVtVG9FbnZlbG9wZTtcbmV4cG9ydHMuY3JlYXRlQXR0YWNobWVudEVudmVsb3BlSXRlbSA9IGNyZWF0ZUF0dGFjaG1lbnRFbnZlbG9wZUl0ZW07XG5leHBvcnRzLmNyZWF0ZUVudmVsb3BlID0gY3JlYXRlRW52ZWxvcGU7XG5leHBvcnRzLmNyZWF0ZUV2ZW50RW52ZWxvcGVIZWFkZXJzID0gY3JlYXRlRXZlbnRFbnZlbG9wZUhlYWRlcnM7XG5leHBvcnRzLmNyZWF0ZVNwYW5FbnZlbG9wZUl0ZW0gPSBjcmVhdGVTcGFuRW52ZWxvcGVJdGVtO1xuZXhwb3J0cy5lbnZlbG9wZUNvbnRhaW5zSXRlbVR5cGUgPSBlbnZlbG9wZUNvbnRhaW5zSXRlbVR5cGU7XG5leHBvcnRzLmVudmVsb3BlSXRlbVR5cGVUb0RhdGFDYXRlZ29yeSA9IGVudmVsb3BlSXRlbVR5cGVUb0RhdGFDYXRlZ29yeTtcbmV4cG9ydHMuZm9yRWFjaEVudmVsb3BlSXRlbSA9IGZvckVhY2hFbnZlbG9wZUl0ZW07XG5leHBvcnRzLmdldFNka01ldGFkYXRhRm9yRW52ZWxvcGVIZWFkZXIgPSBnZXRTZGtNZXRhZGF0YUZvckVudmVsb3BlSGVhZGVyO1xuZXhwb3J0cy5wYXJzZUVudmVsb3BlID0gcGFyc2VFbnZlbG9wZTtcbmV4cG9ydHMuc2VyaWFsaXplRW52ZWxvcGUgPSBzZXJpYWxpemVFbnZlbG9wZTtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWVudmVsb3BlLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/envelope.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/error.js":
/*!***************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/error.js ***!
  \***************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n/**\n * An error emitted by Sentry SDKs and related utilities.\n * @deprecated This class is no longer used and will be removed in a future version. Use `Error` instead.\n */\nclass SentryError extends Error {\n\n   constructor(\n     message,\n    logLevel = 'warn',\n  ) {\n    super(message);this.message = message;\n    this.logLevel = logLevel;\n  }\n}\n\nexports.SentryError = SentryError;\n//# sourceMappingURL=error.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9lcnJvci5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsbUJBQW1CO0FBQ25CO0FBQ0E7QUFDQTs7QUFFQSxtQkFBbUI7QUFDbkIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9lcnJvci5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuLyoqXG4gKiBBbiBlcnJvciBlbWl0dGVkIGJ5IFNlbnRyeSBTREtzIGFuZCByZWxhdGVkIHV0aWxpdGllcy5cbiAqIEBkZXByZWNhdGVkIFRoaXMgY2xhc3MgaXMgbm8gbG9uZ2VyIHVzZWQgYW5kIHdpbGwgYmUgcmVtb3ZlZCBpbiBhIGZ1dHVyZSB2ZXJzaW9uLiBVc2UgYEVycm9yYCBpbnN0ZWFkLlxuICovXG5jbGFzcyBTZW50cnlFcnJvciBleHRlbmRzIEVycm9yIHtcblxuICAgY29uc3RydWN0b3IoXG4gICAgIG1lc3NhZ2UsXG4gICAgbG9nTGV2ZWwgPSAnd2FybicsXG4gICkge1xuICAgIHN1cGVyKG1lc3NhZ2UpO3RoaXMubWVzc2FnZSA9IG1lc3NhZ2U7XG4gICAgdGhpcy5sb2dMZXZlbCA9IGxvZ0xldmVsO1xuICB9XG59XG5cbmV4cG9ydHMuU2VudHJ5RXJyb3IgPSBTZW50cnlFcnJvcjtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWVycm9yLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/error.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/eventUtils.js":
/*!********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/eventUtils.js ***!
  \********************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n/**\n * Get a list of possible event messages from a Sentry event.\n */\nfunction getPossibleEventMessages(event) {\n  const possibleMessages = [];\n\n  if (event.message) {\n    possibleMessages.push(event.message);\n  }\n\n  try {\n    // @ts-expect-error Try catching to save bundle size\n    const lastException = event.exception.values[event.exception.values.length - 1];\n    if (lastException?.value) {\n      possibleMessages.push(lastException.value);\n      if (lastException.type) {\n        possibleMessages.push(`${lastException.type}: ${lastException.value}`);\n      }\n    }\n  } catch {\n    // ignore errors here\n  }\n\n  return possibleMessages;\n}\n\nexports.getPossibleEventMessages = getPossibleEventMessages;\n//# sourceMappingURL=eventUtils.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9ldmVudFV0aWxzLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGlDQUFpQyxtQkFBbUIsSUFBSSxvQkFBb0I7QUFDNUU7QUFDQTtBQUNBLElBQUk7QUFDSjtBQUNBOztBQUVBO0FBQ0E7O0FBRUEsZ0NBQWdDO0FBQ2hDIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvZXZlbnRVdGlscy5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuLyoqXG4gKiBHZXQgYSBsaXN0IG9mIHBvc3NpYmxlIGV2ZW50IG1lc3NhZ2VzIGZyb20gYSBTZW50cnkgZXZlbnQuXG4gKi9cbmZ1bmN0aW9uIGdldFBvc3NpYmxlRXZlbnRNZXNzYWdlcyhldmVudCkge1xuICBjb25zdCBwb3NzaWJsZU1lc3NhZ2VzID0gW107XG5cbiAgaWYgKGV2ZW50Lm1lc3NhZ2UpIHtcbiAgICBwb3NzaWJsZU1lc3NhZ2VzLnB1c2goZXZlbnQubWVzc2FnZSk7XG4gIH1cblxuICB0cnkge1xuICAgIC8vIEB0cy1leHBlY3QtZXJyb3IgVHJ5IGNhdGNoaW5nIHRvIHNhdmUgYnVuZGxlIHNpemVcbiAgICBjb25zdCBsYXN0RXhjZXB0aW9uID0gZXZlbnQuZXhjZXB0aW9uLnZhbHVlc1tldmVudC5leGNlcHRpb24udmFsdWVzLmxlbmd0aCAtIDFdO1xuICAgIGlmIChsYXN0RXhjZXB0aW9uPy52YWx1ZSkge1xuICAgICAgcG9zc2libGVNZXNzYWdlcy5wdXNoKGxhc3RFeGNlcHRpb24udmFsdWUpO1xuICAgICAgaWYgKGxhc3RFeGNlcHRpb24udHlwZSkge1xuICAgICAgICBwb3NzaWJsZU1lc3NhZ2VzLnB1c2goYCR7bGFzdEV4Y2VwdGlvbi50eXBlfTogJHtsYXN0RXhjZXB0aW9uLnZhbHVlfWApO1xuICAgICAgfVxuICAgIH1cbiAgfSBjYXRjaCB7XG4gICAgLy8gaWdub3JlIGVycm9ycyBoZXJlXG4gIH1cblxuICByZXR1cm4gcG9zc2libGVNZXNzYWdlcztcbn1cblxuZXhwb3J0cy5nZXRQb3NzaWJsZUV2ZW50TWVzc2FnZXMgPSBnZXRQb3NzaWJsZUV2ZW50TWVzc2FnZXM7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1ldmVudFV0aWxzLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/eventUtils.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/eventbuilder.js":
/*!**********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/eventbuilder.js ***!
  \**********************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst is = __webpack_require__(/*! ./is.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js\");\nconst misc = __webpack_require__(/*! ./misc.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/misc.js\");\nconst normalize = __webpack_require__(/*! ./normalize.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/normalize.js\");\nconst object = __webpack_require__(/*! ./object.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/object.js\");\n\n/**\n * Extracts stack frames from the error.stack string\n */\nfunction parseStackFrames(stackParser, error) {\n  return stackParser(error.stack || '', 1);\n}\n\n/**\n * Extracts stack frames from the error and builds a Sentry Exception\n */\nfunction exceptionFromError(stackParser, error) {\n  const exception = {\n    type: error.name || error.constructor.name,\n    value: error.message,\n  };\n\n  const frames = parseStackFrames(stackParser, error);\n  if (frames.length) {\n    exception.stacktrace = { frames };\n  }\n\n  return exception;\n}\n\n/** If a plain object has a property that is an `Error`, return this error. */\nfunction getErrorPropertyFromObject(obj) {\n  for (const prop in obj) {\n    if (Object.prototype.hasOwnProperty.call(obj, prop)) {\n      const value = obj[prop];\n      if (value instanceof Error) {\n        return value;\n      }\n    }\n  }\n\n  return undefined;\n}\n\nfunction getMessageForObject(exception) {\n  if ('name' in exception && typeof exception.name === 'string') {\n    let message = `'${exception.name}' captured as exception`;\n\n    if ('message' in exception && typeof exception.message === 'string') {\n      message += ` with message '${exception.message}'`;\n    }\n\n    return message;\n  } else if ('message' in exception && typeof exception.message === 'string') {\n    return exception.message;\n  }\n\n  const keys = object.extractExceptionKeysForMessage(exception);\n\n  // Some ErrorEvent instances do not have an `error` property, which is why they are not handled before\n  // We still want to try to get a decent message for these cases\n  if (is.isErrorEvent(exception)) {\n    return `Event \\`ErrorEvent\\` captured as exception with message \\`${exception.message}\\``;\n  }\n\n  const className = getObjectClassName(exception);\n\n  return `${\n    className && className !== 'Object' ? `'${className}'` : 'Object'\n  } captured as exception with keys: ${keys}`;\n}\n\nfunction getObjectClassName(obj) {\n  try {\n    const prototype = Object.getPrototypeOf(obj);\n    return prototype ? prototype.constructor.name : undefined;\n  } catch {\n    // ignore errors here\n  }\n}\n\nfunction getException(\n  client,\n  mechanism,\n  exception,\n  hint,\n) {\n  if (is.isError(exception)) {\n    return [exception, undefined];\n  }\n\n  // Mutate this!\n  mechanism.synthetic = true;\n\n  if (is.isPlainObject(exception)) {\n    const normalizeDepth = client?.getOptions().normalizeDepth;\n    const extras = { ['__serialized__']: normalize.normalizeToSize(exception , normalizeDepth) };\n\n    const errorFromProp = getErrorPropertyFromObject(exception);\n    if (errorFromProp) {\n      return [errorFromProp, extras];\n    }\n\n    const message = getMessageForObject(exception);\n    const ex = hint?.syntheticException || new Error(message);\n    ex.message = message;\n\n    return [ex, extras];\n  }\n\n  // This handles when someone does: `throw \"something awesome\";`\n  // We use synthesized Error here so we can extract a (rough) stack trace.\n  const ex = hint?.syntheticException || new Error(exception );\n  ex.message = `${exception}`;\n\n  return [ex, undefined];\n}\n\n/**\n * Builds and Event from a Exception\n * @hidden\n */\nfunction eventFromUnknownInput(\n  client,\n  stackParser,\n  exception,\n  hint,\n) {\n  const providedMechanism = hint?.data && (hint.data ).mechanism;\n  const mechanism = providedMechanism || {\n    handled: true,\n    type: 'generic',\n  };\n\n  const [ex, extras] = getException(client, mechanism, exception, hint);\n\n  const event = {\n    exception: {\n      values: [exceptionFromError(stackParser, ex)],\n    },\n  };\n\n  if (extras) {\n    event.extra = extras;\n  }\n\n  misc.addExceptionTypeValue(event, undefined, undefined);\n  misc.addExceptionMechanism(event, mechanism);\n\n  return {\n    ...event,\n    event_id: hint?.event_id,\n  };\n}\n\n/**\n * Builds and Event from a Message\n * @hidden\n */\nfunction eventFromMessage(\n  stackParser,\n  message,\n  level = 'info',\n  hint,\n  attachStacktrace,\n) {\n  const event = {\n    event_id: hint?.event_id,\n    level,\n  };\n\n  if (attachStacktrace && hint?.syntheticException) {\n    const frames = parseStackFrames(stackParser, hint.syntheticException);\n    if (frames.length) {\n      event.exception = {\n        values: [\n          {\n            value: message,\n            stacktrace: { frames },\n          },\n        ],\n      };\n      misc.addExceptionMechanism(event, { synthetic: true });\n    }\n  }\n\n  if (is.isParameterizedString(message)) {\n    const { __sentry_template_string__, __sentry_template_values__ } = message;\n\n    event.logentry = {\n      message: __sentry_template_string__,\n      params: __sentry_template_values__,\n    };\n    return event;\n  }\n\n  event.message = message;\n  return event;\n}\n\nexports.eventFromMessage = eventFromMessage;\nexports.eventFromUnknownInput = eventFromUnknownInput;\nexports.exceptionFromError = exceptionFromError;\nexports.parseStackFrames = parseStackFrames;\n//# sourceMappingURL=eventbuilder.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9ldmVudGJ1aWxkZXIuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsV0FBVyxtQkFBTyxDQUFDLCtHQUFTO0FBQzVCLGFBQWEsbUJBQU8sQ0FBQyxtSEFBVztBQUNoQyxrQkFBa0IsbUJBQU8sQ0FBQyw2SEFBZ0I7QUFDMUMsZUFBZSxtQkFBTyxDQUFDLHVIQUFhOztBQUVwQztBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsNkJBQTZCO0FBQzdCOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0Esc0JBQXNCLGVBQWU7O0FBRXJDO0FBQ0EsbUNBQW1DLGtCQUFrQjtBQUNyRDs7QUFFQTtBQUNBLElBQUk7QUFDSjtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBLHdFQUF3RSxrQkFBa0I7QUFDMUY7O0FBRUE7O0FBRUE7QUFDQSw4Q0FBOEMsVUFBVTtBQUN4RCxJQUFJLG1DQUFtQyxLQUFLO0FBQzVDOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsSUFBSTtBQUNKO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0EscUJBQXFCOztBQUVyQjtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQSxnRUFBZ0U7QUFDaEU7QUFDQTtBQUNBLGtCQUFrQixVQUFVOztBQUU1QjtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQSxLQUFLO0FBQ0w7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSwwQkFBMEIsUUFBUTtBQUNsQyxXQUFXO0FBQ1g7QUFDQTtBQUNBLDBDQUEwQyxpQkFBaUI7QUFDM0Q7QUFDQTs7QUFFQTtBQUNBLFlBQVkseURBQXlEOztBQUVyRTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBLHdCQUF3QjtBQUN4Qiw2QkFBNkI7QUFDN0IsMEJBQTBCO0FBQzFCLHdCQUF3QjtBQUN4QiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3V0aWxzL2V2ZW50YnVpbGRlci5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgaXMgPSByZXF1aXJlKCcuL2lzLmpzJyk7XG5jb25zdCBtaXNjID0gcmVxdWlyZSgnLi9taXNjLmpzJyk7XG5jb25zdCBub3JtYWxpemUgPSByZXF1aXJlKCcuL25vcm1hbGl6ZS5qcycpO1xuY29uc3Qgb2JqZWN0ID0gcmVxdWlyZSgnLi9vYmplY3QuanMnKTtcblxuLyoqXG4gKiBFeHRyYWN0cyBzdGFjayBmcmFtZXMgZnJvbSB0aGUgZXJyb3Iuc3RhY2sgc3RyaW5nXG4gKi9cbmZ1bmN0aW9uIHBhcnNlU3RhY2tGcmFtZXMoc3RhY2tQYXJzZXIsIGVycm9yKSB7XG4gIHJldHVybiBzdGFja1BhcnNlcihlcnJvci5zdGFjayB8fCAnJywgMSk7XG59XG5cbi8qKlxuICogRXh0cmFjdHMgc3RhY2sgZnJhbWVzIGZyb20gdGhlIGVycm9yIGFuZCBidWlsZHMgYSBTZW50cnkgRXhjZXB0aW9uXG4gKi9cbmZ1bmN0aW9uIGV4Y2VwdGlvbkZyb21FcnJvcihzdGFja1BhcnNlciwgZXJyb3IpIHtcbiAgY29uc3QgZXhjZXB0aW9uID0ge1xuICAgIHR5cGU6IGVycm9yLm5hbWUgfHwgZXJyb3IuY29uc3RydWN0b3IubmFtZSxcbiAgICB2YWx1ZTogZXJyb3IubWVzc2FnZSxcbiAgfTtcblxuICBjb25zdCBmcmFtZXMgPSBwYXJzZVN0YWNrRnJhbWVzKHN0YWNrUGFyc2VyLCBlcnJvcik7XG4gIGlmIChmcmFtZXMubGVuZ3RoKSB7XG4gICAgZXhjZXB0aW9uLnN0YWNrdHJhY2UgPSB7IGZyYW1lcyB9O1xuICB9XG5cbiAgcmV0dXJuIGV4Y2VwdGlvbjtcbn1cblxuLyoqIElmIGEgcGxhaW4gb2JqZWN0IGhhcyBhIHByb3BlcnR5IHRoYXQgaXMgYW4gYEVycm9yYCwgcmV0dXJuIHRoaXMgZXJyb3IuICovXG5mdW5jdGlvbiBnZXRFcnJvclByb3BlcnR5RnJvbU9iamVjdChvYmopIHtcbiAgZm9yIChjb25zdCBwcm9wIGluIG9iaikge1xuICAgIGlmIChPYmplY3QucHJvdG90eXBlLmhhc093blByb3BlcnR5LmNhbGwob2JqLCBwcm9wKSkge1xuICAgICAgY29uc3QgdmFsdWUgPSBvYmpbcHJvcF07XG4gICAgICBpZiAodmFsdWUgaW5zdGFuY2VvZiBFcnJvcikge1xuICAgICAgICByZXR1cm4gdmFsdWU7XG4gICAgICB9XG4gICAgfVxuICB9XG5cbiAgcmV0dXJuIHVuZGVmaW5lZDtcbn1cblxuZnVuY3Rpb24gZ2V0TWVzc2FnZUZvck9iamVjdChleGNlcHRpb24pIHtcbiAgaWYgKCduYW1lJyBpbiBleGNlcHRpb24gJiYgdHlwZW9mIGV4Y2VwdGlvbi5uYW1lID09PSAnc3RyaW5nJykge1xuICAgIGxldCBtZXNzYWdlID0gYCcke2V4Y2VwdGlvbi5uYW1lfScgY2FwdHVyZWQgYXMgZXhjZXB0aW9uYDtcblxuICAgIGlmICgnbWVzc2FnZScgaW4gZXhjZXB0aW9uICYmIHR5cGVvZiBleGNlcHRpb24ubWVzc2FnZSA9PT0gJ3N0cmluZycpIHtcbiAgICAgIG1lc3NhZ2UgKz0gYCB3aXRoIG1lc3NhZ2UgJyR7ZXhjZXB0aW9uLm1lc3NhZ2V9J2A7XG4gICAgfVxuXG4gICAgcmV0dXJuIG1lc3NhZ2U7XG4gIH0gZWxzZSBpZiAoJ21lc3NhZ2UnIGluIGV4Y2VwdGlvbiAmJiB0eXBlb2YgZXhjZXB0aW9uLm1lc3NhZ2UgPT09ICdzdHJpbmcnKSB7XG4gICAgcmV0dXJuIGV4Y2VwdGlvbi5tZXNzYWdlO1xuICB9XG5cbiAgY29uc3Qga2V5cyA9IG9iamVjdC5leHRyYWN0RXhjZXB0aW9uS2V5c0Zvck1lc3NhZ2UoZXhjZXB0aW9uKTtcblxuICAvLyBTb21lIEVycm9yRXZlbnQgaW5zdGFuY2VzIGRvIG5vdCBoYXZlIGFuIGBlcnJvcmAgcHJvcGVydHksIHdoaWNoIGlzIHdoeSB0aGV5IGFyZSBub3QgaGFuZGxlZCBiZWZvcmVcbiAgLy8gV2Ugc3RpbGwgd2FudCB0byB0cnkgdG8gZ2V0IGEgZGVjZW50IG1lc3NhZ2UgZm9yIHRoZXNlIGNhc2VzXG4gIGlmIChpcy5pc0Vycm9yRXZlbnQoZXhjZXB0aW9uKSkge1xuICAgIHJldHVybiBgRXZlbnQgXFxgRXJyb3JFdmVudFxcYCBjYXB0dXJlZCBhcyBleGNlcHRpb24gd2l0aCBtZXNzYWdlIFxcYCR7ZXhjZXB0aW9uLm1lc3NhZ2V9XFxgYDtcbiAgfVxuXG4gIGNvbnN0IGNsYXNzTmFtZSA9IGdldE9iamVjdENsYXNzTmFtZShleGNlcHRpb24pO1xuXG4gIHJldHVybiBgJHtcbiAgICBjbGFzc05hbWUgJiYgY2xhc3NOYW1lICE9PSAnT2JqZWN0JyA/IGAnJHtjbGFzc05hbWV9J2AgOiAnT2JqZWN0J1xuICB9IGNhcHR1cmVkIGFzIGV4Y2VwdGlvbiB3aXRoIGtleXM6ICR7a2V5c31gO1xufVxuXG5mdW5jdGlvbiBnZXRPYmplY3RDbGFzc05hbWUob2JqKSB7XG4gIHRyeSB7XG4gICAgY29uc3QgcHJvdG90eXBlID0gT2JqZWN0LmdldFByb3RvdHlwZU9mKG9iaik7XG4gICAgcmV0dXJuIHByb3RvdHlwZSA/IHByb3RvdHlwZS5jb25zdHJ1Y3Rvci5uYW1lIDogdW5kZWZpbmVkO1xuICB9IGNhdGNoIHtcbiAgICAvLyBpZ25vcmUgZXJyb3JzIGhlcmVcbiAgfVxufVxuXG5mdW5jdGlvbiBnZXRFeGNlcHRpb24oXG4gIGNsaWVudCxcbiAgbWVjaGFuaXNtLFxuICBleGNlcHRpb24sXG4gIGhpbnQsXG4pIHtcbiAgaWYgKGlzLmlzRXJyb3IoZXhjZXB0aW9uKSkge1xuICAgIHJldHVybiBbZXhjZXB0aW9uLCB1bmRlZmluZWRdO1xuICB9XG5cbiAgLy8gTXV0YXRlIHRoaXMhXG4gIG1lY2hhbmlzbS5zeW50aGV0aWMgPSB0cnVlO1xuXG4gIGlmIChpcy5pc1BsYWluT2JqZWN0KGV4Y2VwdGlvbikpIHtcbiAgICBjb25zdCBub3JtYWxpemVEZXB0aCA9IGNsaWVudD8uZ2V0T3B0aW9ucygpLm5vcm1hbGl6ZURlcHRoO1xuICAgIGNvbnN0IGV4dHJhcyA9IHsgWydfX3NlcmlhbGl6ZWRfXyddOiBub3JtYWxpemUubm9ybWFsaXplVG9TaXplKGV4Y2VwdGlvbiAsIG5vcm1hbGl6ZURlcHRoKSB9O1xuXG4gICAgY29uc3QgZXJyb3JGcm9tUHJvcCA9IGdldEVycm9yUHJvcGVydHlGcm9tT2JqZWN0KGV4Y2VwdGlvbik7XG4gICAgaWYgKGVycm9yRnJvbVByb3ApIHtcbiAgICAgIHJldHVybiBbZXJyb3JGcm9tUHJvcCwgZXh0cmFzXTtcbiAgICB9XG5cbiAgICBjb25zdCBtZXNzYWdlID0gZ2V0TWVzc2FnZUZvck9iamVjdChleGNlcHRpb24pO1xuICAgIGNvbnN0IGV4ID0gaGludD8uc3ludGhldGljRXhjZXB0aW9uIHx8IG5ldyBFcnJvcihtZXNzYWdlKTtcbiAgICBleC5tZXNzYWdlID0gbWVzc2FnZTtcblxuICAgIHJldHVybiBbZXgsIGV4dHJhc107XG4gIH1cblxuICAvLyBUaGlzIGhhbmRsZXMgd2hlbiBzb21lb25lIGRvZXM6IGB0aHJvdyBcInNvbWV0aGluZyBhd2Vzb21lXCI7YFxuICAvLyBXZSB1c2Ugc3ludGhlc2l6ZWQgRXJyb3IgaGVyZSBzbyB3ZSBjYW4gZXh0cmFjdCBhIChyb3VnaCkgc3RhY2sgdHJhY2UuXG4gIGNvbnN0IGV4ID0gaGludD8uc3ludGhldGljRXhjZXB0aW9uIHx8IG5ldyBFcnJvcihleGNlcHRpb24gKTtcbiAgZXgubWVzc2FnZSA9IGAke2V4Y2VwdGlvbn1gO1xuXG4gIHJldHVybiBbZXgsIHVuZGVmaW5lZF07XG59XG5cbi8qKlxuICogQnVpbGRzIGFuZCBFdmVudCBmcm9tIGEgRXhjZXB0aW9uXG4gKiBAaGlkZGVuXG4gKi9cbmZ1bmN0aW9uIGV2ZW50RnJvbVVua25vd25JbnB1dChcbiAgY2xpZW50LFxuICBzdGFja1BhcnNlcixcbiAgZXhjZXB0aW9uLFxuICBoaW50LFxuKSB7XG4gIGNvbnN0IHByb3ZpZGVkTWVjaGFuaXNtID0gaGludD8uZGF0YSAmJiAoaGludC5kYXRhICkubWVjaGFuaXNtO1xuICBjb25zdCBtZWNoYW5pc20gPSBwcm92aWRlZE1lY2hhbmlzbSB8fCB7XG4gICAgaGFuZGxlZDogdHJ1ZSxcbiAgICB0eXBlOiAnZ2VuZXJpYycsXG4gIH07XG5cbiAgY29uc3QgW2V4LCBleHRyYXNdID0gZ2V0RXhjZXB0aW9uKGNsaWVudCwgbWVjaGFuaXNtLCBleGNlcHRpb24sIGhpbnQpO1xuXG4gIGNvbnN0IGV2ZW50ID0ge1xuICAgIGV4Y2VwdGlvbjoge1xuICAgICAgdmFsdWVzOiBbZXhjZXB0aW9uRnJvbUVycm9yKHN0YWNrUGFyc2VyLCBleCldLFxuICAgIH0sXG4gIH07XG5cbiAgaWYgKGV4dHJhcykge1xuICAgIGV2ZW50LmV4dHJhID0gZXh0cmFzO1xuICB9XG5cbiAgbWlzYy5hZGRFeGNlcHRpb25UeXBlVmFsdWUoZXZlbnQsIHVuZGVmaW5lZCwgdW5kZWZpbmVkKTtcbiAgbWlzYy5hZGRFeGNlcHRpb25NZWNoYW5pc20oZXZlbnQsIG1lY2hhbmlzbSk7XG5cbiAgcmV0dXJuIHtcbiAgICAuLi5ldmVudCxcbiAgICBldmVudF9pZDogaGludD8uZXZlbnRfaWQsXG4gIH07XG59XG5cbi8qKlxuICogQnVpbGRzIGFuZCBFdmVudCBmcm9tIGEgTWVzc2FnZVxuICogQGhpZGRlblxuICovXG5mdW5jdGlvbiBldmVudEZyb21NZXNzYWdlKFxuICBzdGFja1BhcnNlcixcbiAgbWVzc2FnZSxcbiAgbGV2ZWwgPSAnaW5mbycsXG4gIGhpbnQsXG4gIGF0dGFjaFN0YWNrdHJhY2UsXG4pIHtcbiAgY29uc3QgZXZlbnQgPSB7XG4gICAgZXZlbnRfaWQ6IGhpbnQ/LmV2ZW50X2lkLFxuICAgIGxldmVsLFxuICB9O1xuXG4gIGlmIChhdHRhY2hTdGFja3RyYWNlICYmIGhpbnQ/LnN5bnRoZXRpY0V4Y2VwdGlvbikge1xuICAgIGNvbnN0IGZyYW1lcyA9IHBhcnNlU3RhY2tGcmFtZXMoc3RhY2tQYXJzZXIsIGhpbnQuc3ludGhldGljRXhjZXB0aW9uKTtcbiAgICBpZiAoZnJhbWVzLmxlbmd0aCkge1xuICAgICAgZXZlbnQuZXhjZXB0aW9uID0ge1xuICAgICAgICB2YWx1ZXM6IFtcbiAgICAgICAgICB7XG4gICAgICAgICAgICB2YWx1ZTogbWVzc2FnZSxcbiAgICAgICAgICAgIHN0YWNrdHJhY2U6IHsgZnJhbWVzIH0sXG4gICAgICAgICAgfSxcbiAgICAgICAgXSxcbiAgICAgIH07XG4gICAgICBtaXNjLmFkZEV4Y2VwdGlvbk1lY2hhbmlzbShldmVudCwgeyBzeW50aGV0aWM6IHRydWUgfSk7XG4gICAgfVxuICB9XG5cbiAgaWYgKGlzLmlzUGFyYW1ldGVyaXplZFN0cmluZyhtZXNzYWdlKSkge1xuICAgIGNvbnN0IHsgX19zZW50cnlfdGVtcGxhdGVfc3RyaW5nX18sIF9fc2VudHJ5X3RlbXBsYXRlX3ZhbHVlc19fIH0gPSBtZXNzYWdlO1xuXG4gICAgZXZlbnQubG9nZW50cnkgPSB7XG4gICAgICBtZXNzYWdlOiBfX3NlbnRyeV90ZW1wbGF0ZV9zdHJpbmdfXyxcbiAgICAgIHBhcmFtczogX19zZW50cnlfdGVtcGxhdGVfdmFsdWVzX18sXG4gICAgfTtcbiAgICByZXR1cm4gZXZlbnQ7XG4gIH1cblxuICBldmVudC5tZXNzYWdlID0gbWVzc2FnZTtcbiAgcmV0dXJuIGV2ZW50O1xufVxuXG5leHBvcnRzLmV2ZW50RnJvbU1lc3NhZ2UgPSBldmVudEZyb21NZXNzYWdlO1xuZXhwb3J0cy5ldmVudEZyb21Vbmtub3duSW5wdXQgPSBldmVudEZyb21Vbmtub3duSW5wdXQ7XG5leHBvcnRzLmV4Y2VwdGlvbkZyb21FcnJvciA9IGV4Y2VwdGlvbkZyb21FcnJvcjtcbmV4cG9ydHMucGFyc2VTdGFja0ZyYW1lcyA9IHBhcnNlU3RhY2tGcmFtZXM7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1ldmVudGJ1aWxkZXIuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/eventbuilder.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/featureFlags.js":
/*!**********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/featureFlags.js ***!
  \**********************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst currentScopes = __webpack_require__(/*! ../currentScopes.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst debugBuild = __webpack_require__(/*! ../debug-build.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst debugLogger = __webpack_require__(/*! ./debug-logger.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst spanUtils = __webpack_require__(/*! ./spanUtils.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanUtils.js\");\n\n/**\n * Ordered LRU cache for storing feature flags in the scope context. The name\n * of each flag in the buffer is unique, and the output of getAll() is ordered\n * from oldest to newest.\n */\n\n/**\n * Max size of the LRU flag buffer stored in Sentry scope and event contexts.\n */\nconst _INTERNAL_FLAG_BUFFER_SIZE = 100;\n\n/**\n * Max number of flag evaluations to record per span.\n */\nconst _INTERNAL_MAX_FLAGS_PER_SPAN = 10;\n\nconst SPAN_FLAG_ATTRIBUTE_PREFIX = 'flag.evaluation.';\n\n/**\n * Copies feature flags that are in current scope context to the event context\n */\nfunction _INTERNAL_copyFlagsFromScopeToEvent(event) {\n  const scope = currentScopes.getCurrentScope();\n  const flagContext = scope.getScopeData().contexts.flags;\n  const flagBuffer = flagContext ? flagContext.values : [];\n\n  if (!flagBuffer.length) {\n    return event;\n  }\n\n  if (event.contexts === undefined) {\n    event.contexts = {};\n  }\n  event.contexts.flags = { values: [...flagBuffer] };\n  return event;\n}\n\n/**\n * Inserts a flag into the current scope's context while maintaining ordered LRU properties.\n * Not thread-safe. After inserting:\n * - The flag buffer is sorted in order of recency, with the newest evaluation at the end.\n * - The names in the buffer are always unique.\n * - The length of the buffer never exceeds `maxSize`.\n *\n * @param name     Name of the feature flag to insert.\n * @param value    Value of the feature flag.\n * @param maxSize  Max number of flags the buffer should store. Default value should always be used in production.\n */\nfunction _INTERNAL_insertFlagToScope(\n  name,\n  value,\n  maxSize = _INTERNAL_FLAG_BUFFER_SIZE,\n) {\n  const scopeContexts = currentScopes.getCurrentScope().getScopeData().contexts;\n  if (!scopeContexts.flags) {\n    scopeContexts.flags = { values: [] };\n  }\n  const flags = scopeContexts.flags.values ;\n  _INTERNAL_insertToFlagBuffer(flags, name, value, maxSize);\n}\n\n/**\n * Exported for tests only. Currently only accepts boolean values (otherwise no-op).\n * Inserts a flag into a FeatureFlag array while maintaining the following properties:\n * - Flags are sorted in order of recency, with the newest evaluation at the end.\n * - The flag names are always unique.\n * - The length of the array never exceeds `maxSize`.\n *\n * @param flags      The buffer to insert the flag into.\n * @param name       Name of the feature flag to insert.\n * @param value      Value of the feature flag.\n * @param maxSize    Max number of flags the buffer should store. Default value should always be used in production.\n */\nfunction _INTERNAL_insertToFlagBuffer(\n  flags,\n  name,\n  value,\n  maxSize,\n) {\n  if (typeof value !== 'boolean') {\n    return;\n  }\n\n  if (flags.length > maxSize) {\n    debugBuild.DEBUG_BUILD && debugLogger.debug.error(`[Feature Flags] insertToFlagBuffer called on a buffer larger than maxSize=${maxSize}`);\n    return;\n  }\n\n  // Check if the flag is already in the buffer - O(n)\n  const index = flags.findIndex(f => f.flag === name);\n\n  if (index !== -1) {\n    // The flag was found, remove it from its current position - O(n)\n    flags.splice(index, 1);\n  }\n\n  if (flags.length === maxSize) {\n    // If at capacity, pop the earliest flag - O(n)\n    flags.shift();\n  }\n\n  // Push the flag to the end - O(1)\n  flags.push({\n    flag: name,\n    result: value,\n  });\n}\n\n/**\n * Records a feature flag evaluation for the active span. This is a no-op for non-boolean values.\n * The flag and its value is stored in span attributes with the `flag.evaluation` prefix. Once the\n * unique flags for a span reaches maxFlagsPerSpan, subsequent flags are dropped.\n *\n * @param name             Name of the feature flag.\n * @param value            Value of the feature flag. Non-boolean values are ignored.\n * @param maxFlagsPerSpan  Max number of flags a buffer should store. Default value should always be used in production.\n */\nfunction _INTERNAL_addFeatureFlagToActiveSpan(\n  name,\n  value,\n  maxFlagsPerSpan = _INTERNAL_MAX_FLAGS_PER_SPAN,\n) {\n  if (typeof value !== 'boolean') {\n    return;\n  }\n\n  const span = spanUtils.getActiveSpan();\n  if (!span) {\n    return;\n  }\n\n  const attributes = spanUtils.spanToJSON(span).data;\n\n  // If the flag already exists, always update it\n  if (`${SPAN_FLAG_ATTRIBUTE_PREFIX}${name}` in attributes) {\n    span.setAttribute(`${SPAN_FLAG_ATTRIBUTE_PREFIX}${name}`, value);\n    return;\n  }\n\n  // Else, add the flag to the span if we have not reached the max number of flags\n  const numOfAddedFlags = Object.keys(attributes).filter(key => key.startsWith(SPAN_FLAG_ATTRIBUTE_PREFIX)).length;\n  if (numOfAddedFlags < maxFlagsPerSpan) {\n    span.setAttribute(`${SPAN_FLAG_ATTRIBUTE_PREFIX}${name}`, value);\n  }\n}\n\nexports._INTERNAL_FLAG_BUFFER_SIZE = _INTERNAL_FLAG_BUFFER_SIZE;\nexports._INTERNAL_MAX_FLAGS_PER_SPAN = _INTERNAL_MAX_FLAGS_PER_SPAN;\nexports._INTERNAL_addFeatureFlagToActiveSpan = _INTERNAL_addFeatureFlagToActiveSpan;\nexports._INTERNAL_copyFlagsFromScopeToEvent = _INTERNAL_copyFlagsFromScopeToEvent;\nexports._INTERNAL_insertFlagToScope = _INTERNAL_insertFlagToScope;\nexports._INTERNAL_insertToFlagBuffer = _INTERNAL_insertToFlagBuffer;\n//# sourceMappingURL=featureFlags.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9mZWF0dXJlRmxhZ3MuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsc0JBQXNCLG1CQUFPLENBQUMsZ0lBQXFCO0FBQ25ELG1CQUFtQixtQkFBTyxDQUFDLDRIQUFtQjtBQUM5QyxvQkFBb0IsbUJBQU8sQ0FBQyxtSUFBbUI7QUFDL0Msa0JBQWtCLG1CQUFPLENBQUMsNkhBQWdCOztBQUUxQztBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQSwyQkFBMkI7QUFDM0I7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSw0QkFBNEI7QUFDNUI7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0EsbUlBQW1JLFFBQVE7QUFDM0k7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsR0FBRztBQUNIOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQSxTQUFTLDJCQUEyQixFQUFFLEtBQUs7QUFDM0MseUJBQXlCLDJCQUEyQixFQUFFLEtBQUs7QUFDM0Q7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQSx5QkFBeUIsMkJBQTJCLEVBQUUsS0FBSztBQUMzRDtBQUNBOztBQUVBLGtDQUFrQztBQUNsQyxvQ0FBb0M7QUFDcEMsNENBQTRDO0FBQzVDLDJDQUEyQztBQUMzQyxtQ0FBbUM7QUFDbkMsb0NBQW9DO0FBQ3BDIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvZmVhdHVyZUZsYWdzLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBjdXJyZW50U2NvcGVzID0gcmVxdWlyZSgnLi4vY3VycmVudFNjb3Blcy5qcycpO1xuY29uc3QgZGVidWdCdWlsZCA9IHJlcXVpcmUoJy4uL2RlYnVnLWJ1aWxkLmpzJyk7XG5jb25zdCBkZWJ1Z0xvZ2dlciA9IHJlcXVpcmUoJy4vZGVidWctbG9nZ2VyLmpzJyk7XG5jb25zdCBzcGFuVXRpbHMgPSByZXF1aXJlKCcuL3NwYW5VdGlscy5qcycpO1xuXG4vKipcbiAqIE9yZGVyZWQgTFJVIGNhY2hlIGZvciBzdG9yaW5nIGZlYXR1cmUgZmxhZ3MgaW4gdGhlIHNjb3BlIGNvbnRleHQuIFRoZSBuYW1lXG4gKiBvZiBlYWNoIGZsYWcgaW4gdGhlIGJ1ZmZlciBpcyB1bmlxdWUsIGFuZCB0aGUgb3V0cHV0IG9mIGdldEFsbCgpIGlzIG9yZGVyZWRcbiAqIGZyb20gb2xkZXN0IHRvIG5ld2VzdC5cbiAqL1xuXG4vKipcbiAqIE1heCBzaXplIG9mIHRoZSBMUlUgZmxhZyBidWZmZXIgc3RvcmVkIGluIFNlbnRyeSBzY29wZSBhbmQgZXZlbnQgY29udGV4dHMuXG4gKi9cbmNvbnN0IF9JTlRFUk5BTF9GTEFHX0JVRkZFUl9TSVpFID0gMTAwO1xuXG4vKipcbiAqIE1heCBudW1iZXIgb2YgZmxhZyBldmFsdWF0aW9ucyB0byByZWNvcmQgcGVyIHNwYW4uXG4gKi9cbmNvbnN0IF9JTlRFUk5BTF9NQVhfRkxBR1NfUEVSX1NQQU4gPSAxMDtcblxuY29uc3QgU1BBTl9GTEFHX0FUVFJJQlVURV9QUkVGSVggPSAnZmxhZy5ldmFsdWF0aW9uLic7XG5cbi8qKlxuICogQ29waWVzIGZlYXR1cmUgZmxhZ3MgdGhhdCBhcmUgaW4gY3VycmVudCBzY29wZSBjb250ZXh0IHRvIHRoZSBldmVudCBjb250ZXh0XG4gKi9cbmZ1bmN0aW9uIF9JTlRFUk5BTF9jb3B5RmxhZ3NGcm9tU2NvcGVUb0V2ZW50KGV2ZW50KSB7XG4gIGNvbnN0IHNjb3BlID0gY3VycmVudFNjb3Blcy5nZXRDdXJyZW50U2NvcGUoKTtcbiAgY29uc3QgZmxhZ0NvbnRleHQgPSBzY29wZS5nZXRTY29wZURhdGEoKS5jb250ZXh0cy5mbGFncztcbiAgY29uc3QgZmxhZ0J1ZmZlciA9IGZsYWdDb250ZXh0ID8gZmxhZ0NvbnRleHQudmFsdWVzIDogW107XG5cbiAgaWYgKCFmbGFnQnVmZmVyLmxlbmd0aCkge1xuICAgIHJldHVybiBldmVudDtcbiAgfVxuXG4gIGlmIChldmVudC5jb250ZXh0cyA9PT0gdW5kZWZpbmVkKSB7XG4gICAgZXZlbnQuY29udGV4dHMgPSB7fTtcbiAgfVxuICBldmVudC5jb250ZXh0cy5mbGFncyA9IHsgdmFsdWVzOiBbLi4uZmxhZ0J1ZmZlcl0gfTtcbiAgcmV0dXJuIGV2ZW50O1xufVxuXG4vKipcbiAqIEluc2VydHMgYSBmbGFnIGludG8gdGhlIGN1cnJlbnQgc2NvcGUncyBjb250ZXh0IHdoaWxlIG1haW50YWluaW5nIG9yZGVyZWQgTFJVIHByb3BlcnRpZXMuXG4gKiBOb3QgdGhyZWFkLXNhZmUuIEFmdGVyIGluc2VydGluZzpcbiAqIC0gVGhlIGZsYWcgYnVmZmVyIGlzIHNvcnRlZCBpbiBvcmRlciBvZiByZWNlbmN5LCB3aXRoIHRoZSBuZXdlc3QgZXZhbHVhdGlvbiBhdCB0aGUgZW5kLlxuICogLSBUaGUgbmFtZXMgaW4gdGhlIGJ1ZmZlciBhcmUgYWx3YXlzIHVuaXF1ZS5cbiAqIC0gVGhlIGxlbmd0aCBvZiB0aGUgYnVmZmVyIG5ldmVyIGV4Y2VlZHMgYG1heFNpemVgLlxuICpcbiAqIEBwYXJhbSBuYW1lICAgICBOYW1lIG9mIHRoZSBmZWF0dXJlIGZsYWcgdG8gaW5zZXJ0LlxuICogQHBhcmFtIHZhbHVlICAgIFZhbHVlIG9mIHRoZSBmZWF0dXJlIGZsYWcuXG4gKiBAcGFyYW0gbWF4U2l6ZSAgTWF4IG51bWJlciBvZiBmbGFncyB0aGUgYnVmZmVyIHNob3VsZCBzdG9yZS4gRGVmYXVsdCB2YWx1ZSBzaG91bGQgYWx3YXlzIGJlIHVzZWQgaW4gcHJvZHVjdGlvbi5cbiAqL1xuZnVuY3Rpb24gX0lOVEVSTkFMX2luc2VydEZsYWdUb1Njb3BlKFxuICBuYW1lLFxuICB2YWx1ZSxcbiAgbWF4U2l6ZSA9IF9JTlRFUk5BTF9GTEFHX0JVRkZFUl9TSVpFLFxuKSB7XG4gIGNvbnN0IHNjb3BlQ29udGV4dHMgPSBjdXJyZW50U2NvcGVzLmdldEN1cnJlbnRTY29wZSgpLmdldFNjb3BlRGF0YSgpLmNvbnRleHRzO1xuICBpZiAoIXNjb3BlQ29udGV4dHMuZmxhZ3MpIHtcbiAgICBzY29wZUNvbnRleHRzLmZsYWdzID0geyB2YWx1ZXM6IFtdIH07XG4gIH1cbiAgY29uc3QgZmxhZ3MgPSBzY29wZUNvbnRleHRzLmZsYWdzLnZhbHVlcyA7XG4gIF9JTlRFUk5BTF9pbnNlcnRUb0ZsYWdCdWZmZXIoZmxhZ3MsIG5hbWUsIHZhbHVlLCBtYXhTaXplKTtcbn1cblxuLyoqXG4gKiBFeHBvcnRlZCBmb3IgdGVzdHMgb25seS4gQ3VycmVudGx5IG9ubHkgYWNjZXB0cyBib29sZWFuIHZhbHVlcyAob3RoZXJ3aXNlIG5vLW9wKS5cbiAqIEluc2VydHMgYSBmbGFnIGludG8gYSBGZWF0dXJlRmxhZyBhcnJheSB3aGlsZSBtYWludGFpbmluZyB0aGUgZm9sbG93aW5nIHByb3BlcnRpZXM6XG4gKiAtIEZsYWdzIGFyZSBzb3J0ZWQgaW4gb3JkZXIgb2YgcmVjZW5jeSwgd2l0aCB0aGUgbmV3ZXN0IGV2YWx1YXRpb24gYXQgdGhlIGVuZC5cbiAqIC0gVGhlIGZsYWcgbmFtZXMgYXJlIGFsd2F5cyB1bmlxdWUuXG4gKiAtIFRoZSBsZW5ndGggb2YgdGhlIGFycmF5IG5ldmVyIGV4Y2VlZHMgYG1heFNpemVgLlxuICpcbiAqIEBwYXJhbSBmbGFncyAgICAgIFRoZSBidWZmZXIgdG8gaW5zZXJ0IHRoZSBmbGFnIGludG8uXG4gKiBAcGFyYW0gbmFtZSAgICAgICBOYW1lIG9mIHRoZSBmZWF0dXJlIGZsYWcgdG8gaW5zZXJ0LlxuICogQHBhcmFtIHZhbHVlICAgICAgVmFsdWUgb2YgdGhlIGZlYXR1cmUgZmxhZy5cbiAqIEBwYXJhbSBtYXhTaXplICAgIE1heCBudW1iZXIgb2YgZmxhZ3MgdGhlIGJ1ZmZlciBzaG91bGQgc3RvcmUuIERlZmF1bHQgdmFsdWUgc2hvdWxkIGFsd2F5cyBiZSB1c2VkIGluIHByb2R1Y3Rpb24uXG4gKi9cbmZ1bmN0aW9uIF9JTlRFUk5BTF9pbnNlcnRUb0ZsYWdCdWZmZXIoXG4gIGZsYWdzLFxuICBuYW1lLFxuICB2YWx1ZSxcbiAgbWF4U2l6ZSxcbikge1xuICBpZiAodHlwZW9mIHZhbHVlICE9PSAnYm9vbGVhbicpIHtcbiAgICByZXR1cm47XG4gIH1cblxuICBpZiAoZmxhZ3MubGVuZ3RoID4gbWF4U2l6ZSkge1xuICAgIGRlYnVnQnVpbGQuREVCVUdfQlVJTEQgJiYgZGVidWdMb2dnZXIuZGVidWcuZXJyb3IoYFtGZWF0dXJlIEZsYWdzXSBpbnNlcnRUb0ZsYWdCdWZmZXIgY2FsbGVkIG9uIGEgYnVmZmVyIGxhcmdlciB0aGFuIG1heFNpemU9JHttYXhTaXplfWApO1xuICAgIHJldHVybjtcbiAgfVxuXG4gIC8vIENoZWNrIGlmIHRoZSBmbGFnIGlzIGFscmVhZHkgaW4gdGhlIGJ1ZmZlciAtIE8obilcbiAgY29uc3QgaW5kZXggPSBmbGFncy5maW5kSW5kZXgoZiA9PiBmLmZsYWcgPT09IG5hbWUpO1xuXG4gIGlmIChpbmRleCAhPT0gLTEpIHtcbiAgICAvLyBUaGUgZmxhZyB3YXMgZm91bmQsIHJlbW92ZSBpdCBmcm9tIGl0cyBjdXJyZW50IHBvc2l0aW9uIC0gTyhuKVxuICAgIGZsYWdzLnNwbGljZShpbmRleCwgMSk7XG4gIH1cblxuICBpZiAoZmxhZ3MubGVuZ3RoID09PSBtYXhTaXplKSB7XG4gICAgLy8gSWYgYXQgY2FwYWNpdHksIHBvcCB0aGUgZWFybGllc3QgZmxhZyAtIE8obilcbiAgICBmbGFncy5zaGlmdCgpO1xuICB9XG5cbiAgLy8gUHVzaCB0aGUgZmxhZyB0byB0aGUgZW5kIC0gTygxKVxuICBmbGFncy5wdXNoKHtcbiAgICBmbGFnOiBuYW1lLFxuICAgIHJlc3VsdDogdmFsdWUsXG4gIH0pO1xufVxuXG4vKipcbiAqIFJlY29yZHMgYSBmZWF0dXJlIGZsYWcgZXZhbHVhdGlvbiBmb3IgdGhlIGFjdGl2ZSBzcGFuLiBUaGlzIGlzIGEgbm8tb3AgZm9yIG5vbi1ib29sZWFuIHZhbHVlcy5cbiAqIFRoZSBmbGFnIGFuZCBpdHMgdmFsdWUgaXMgc3RvcmVkIGluIHNwYW4gYXR0cmlidXRlcyB3aXRoIHRoZSBgZmxhZy5ldmFsdWF0aW9uYCBwcmVmaXguIE9uY2UgdGhlXG4gKiB1bmlxdWUgZmxhZ3MgZm9yIGEgc3BhbiByZWFjaGVzIG1heEZsYWdzUGVyU3Bhbiwgc3Vic2VxdWVudCBmbGFncyBhcmUgZHJvcHBlZC5cbiAqXG4gKiBAcGFyYW0gbmFtZSAgICAgICAgICAgICBOYW1lIG9mIHRoZSBmZWF0dXJlIGZsYWcuXG4gKiBAcGFyYW0gdmFsdWUgICAgICAgICAgICBWYWx1ZSBvZiB0aGUgZmVhdHVyZSBmbGFnLiBOb24tYm9vbGVhbiB2YWx1ZXMgYXJlIGlnbm9yZWQuXG4gKiBAcGFyYW0gbWF4RmxhZ3NQZXJTcGFuICBNYXggbnVtYmVyIG9mIGZsYWdzIGEgYnVmZmVyIHNob3VsZCBzdG9yZS4gRGVmYXVsdCB2YWx1ZSBzaG91bGQgYWx3YXlzIGJlIHVzZWQgaW4gcHJvZHVjdGlvbi5cbiAqL1xuZnVuY3Rpb24gX0lOVEVSTkFMX2FkZEZlYXR1cmVGbGFnVG9BY3RpdmVTcGFuKFxuICBuYW1lLFxuICB2YWx1ZSxcbiAgbWF4RmxhZ3NQZXJTcGFuID0gX0lOVEVSTkFMX01BWF9GTEFHU19QRVJfU1BBTixcbikge1xuICBpZiAodHlwZW9mIHZhbHVlICE9PSAnYm9vbGVhbicpIHtcbiAgICByZXR1cm47XG4gIH1cblxuICBjb25zdCBzcGFuID0gc3BhblV0aWxzLmdldEFjdGl2ZVNwYW4oKTtcbiAgaWYgKCFzcGFuKSB7XG4gICAgcmV0dXJuO1xuICB9XG5cbiAgY29uc3QgYXR0cmlidXRlcyA9IHNwYW5VdGlscy5zcGFuVG9KU09OKHNwYW4pLmRhdGE7XG5cbiAgLy8gSWYgdGhlIGZsYWcgYWxyZWFkeSBleGlzdHMsIGFsd2F5cyB1cGRhdGUgaXRcbiAgaWYgKGAke1NQQU5fRkxBR19BVFRSSUJVVEVfUFJFRklYfSR7bmFtZX1gIGluIGF0dHJpYnV0ZXMpIHtcbiAgICBzcGFuLnNldEF0dHJpYnV0ZShgJHtTUEFOX0ZMQUdfQVRUUklCVVRFX1BSRUZJWH0ke25hbWV9YCwgdmFsdWUpO1xuICAgIHJldHVybjtcbiAgfVxuXG4gIC8vIEVsc2UsIGFkZCB0aGUgZmxhZyB0byB0aGUgc3BhbiBpZiB3ZSBoYXZlIG5vdCByZWFjaGVkIHRoZSBtYXggbnVtYmVyIG9mIGZsYWdzXG4gIGNvbnN0IG51bU9mQWRkZWRGbGFncyA9IE9iamVjdC5rZXlzKGF0dHJpYnV0ZXMpLmZpbHRlcihrZXkgPT4ga2V5LnN0YXJ0c1dpdGgoU1BBTl9GTEFHX0FUVFJJQlVURV9QUkVGSVgpKS5sZW5ndGg7XG4gIGlmIChudW1PZkFkZGVkRmxhZ3MgPCBtYXhGbGFnc1BlclNwYW4pIHtcbiAgICBzcGFuLnNldEF0dHJpYnV0ZShgJHtTUEFOX0ZMQUdfQVRUUklCVVRFX1BSRUZJWH0ke25hbWV9YCwgdmFsdWUpO1xuICB9XG59XG5cbmV4cG9ydHMuX0lOVEVSTkFMX0ZMQUdfQlVGRkVSX1NJWkUgPSBfSU5URVJOQUxfRkxBR19CVUZGRVJfU0laRTtcbmV4cG9ydHMuX0lOVEVSTkFMX01BWF9GTEFHU19QRVJfU1BBTiA9IF9JTlRFUk5BTF9NQVhfRkxBR1NfUEVSX1NQQU47XG5leHBvcnRzLl9JTlRFUk5BTF9hZGRGZWF0dXJlRmxhZ1RvQWN0aXZlU3BhbiA9IF9JTlRFUk5BTF9hZGRGZWF0dXJlRmxhZ1RvQWN0aXZlU3BhbjtcbmV4cG9ydHMuX0lOVEVSTkFMX2NvcHlGbGFnc0Zyb21TY29wZVRvRXZlbnQgPSBfSU5URVJOQUxfY29weUZsYWdzRnJvbVNjb3BlVG9FdmVudDtcbmV4cG9ydHMuX0lOVEVSTkFMX2luc2VydEZsYWdUb1Njb3BlID0gX0lOVEVSTkFMX2luc2VydEZsYWdUb1Njb3BlO1xuZXhwb3J0cy5fSU5URVJOQUxfaW5zZXJ0VG9GbGFnQnVmZmVyID0gX0lOVEVSTkFMX2luc2VydFRvRmxhZ0J1ZmZlcjtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWZlYXR1cmVGbGFncy5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/featureFlags.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/flushIfServerless.js":
/*!***************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/flushIfServerless.js ***!
  \***************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst exports$1 = __webpack_require__(/*! ../exports.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/exports.js\");\nconst debugLogger = __webpack_require__(/*! ./debug-logger.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst vercelWaitUntil = __webpack_require__(/*! ./vercelWaitUntil.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/vercelWaitUntil.js\");\nconst worldwide = __webpack_require__(/*! ./worldwide.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/worldwide.js\");\n\nasync function flushWithTimeout(timeout) {\n  try {\n    debugLogger.debug.log('Flushing events...');\n    await exports$1.flush(timeout);\n    debugLogger.debug.log('Done flushing events');\n  } catch (e) {\n    debugLogger.debug.log('Error while flushing events:\\n', e);\n  }\n}\n\n/**\n *  Flushes the event queue with a timeout in serverless environments to ensure that events are sent to Sentry before the\n *  serverless function execution ends.\n *\n * The function is async, but in environments that support a `waitUntil` mechanism, it will run synchronously.\n *\n * This function is aware of the following serverless platforms:\n * - Cloudflare: If a Cloudflare context is provided, it will use `ctx.waitUntil()` to flush events (keeps the `this` context of `ctx`).\n *               If a `cloudflareWaitUntil` function is provided, it will use that to flush events (looses the `this` context of `ctx`).\n * - Vercel: It detects the Vercel environment and uses Vercel's `waitUntil` function.\n * - Other Serverless (AWS Lambda, Google Cloud, etc.): It detects the environment via environment variables\n *   and uses a regular `await flush()`.\n *\n *  @internal This function is supposed for internal Sentry SDK usage only.\n *  @hidden\n */\nasync function flushIfServerless(\n  params\n\n = {},\n) {\n  const { timeout = 2000 } = params;\n\n  if ('cloudflareWaitUntil' in params && typeof params?.cloudflareWaitUntil === 'function') {\n    params.cloudflareWaitUntil(flushWithTimeout(timeout));\n    return;\n  }\n\n  if ('cloudflareCtx' in params && typeof params.cloudflareCtx?.waitUntil === 'function') {\n    params.cloudflareCtx.waitUntil(flushWithTimeout(timeout));\n    return;\n  }\n\n  // @ts-expect-error This is not typed\n  if (worldwide.GLOBAL_OBJ[Symbol.for('@vercel/request-context')]) {\n    // Vercel has a waitUntil equivalent that works without execution context\n    vercelWaitUntil.vercelWaitUntil(flushWithTimeout(timeout));\n    return;\n  }\n\n  if (typeof process === 'undefined') {\n    return;\n  }\n\n  const isServerless =\n    !!process.env.FUNCTIONS_WORKER_RUNTIME || // Azure Functions\n    !!process.env.LAMBDA_TASK_ROOT || // AWS Lambda\n    !!process.env.K_SERVICE || // Google Cloud Run\n    !!process.env.CF_PAGES || // Cloudflare Pages\n    !!process.env.VERCEL ||\n    !!process.env.NETLIFY;\n\n  if (isServerless) {\n    // Use regular flush for environments without a generic waitUntil mechanism\n    await flushWithTimeout(timeout);\n  }\n}\n\nexports.flushIfServerless = flushIfServerless;\n//# sourceMappingURL=flushIfServerless.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9mbHVzaElmU2VydmVybGVzcy5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxrQkFBa0IsbUJBQU8sQ0FBQyxvSEFBZTtBQUN6QyxvQkFBb0IsbUJBQU8sQ0FBQyxtSUFBbUI7QUFDL0Msd0JBQXdCLG1CQUFPLENBQUMseUlBQXNCO0FBQ3RELGtCQUFrQixtQkFBTyxDQUFDLDZIQUFnQjs7QUFFMUM7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLElBQUk7QUFDSjtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLEtBQUs7QUFDTDtBQUNBLFVBQVUsaUJBQWlCOztBQUUzQjtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEseUJBQXlCO0FBQ3pCIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvZmx1c2hJZlNlcnZlcmxlc3MuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGV4cG9ydHMkMSA9IHJlcXVpcmUoJy4uL2V4cG9ydHMuanMnKTtcbmNvbnN0IGRlYnVnTG9nZ2VyID0gcmVxdWlyZSgnLi9kZWJ1Zy1sb2dnZXIuanMnKTtcbmNvbnN0IHZlcmNlbFdhaXRVbnRpbCA9IHJlcXVpcmUoJy4vdmVyY2VsV2FpdFVudGlsLmpzJyk7XG5jb25zdCB3b3JsZHdpZGUgPSByZXF1aXJlKCcuL3dvcmxkd2lkZS5qcycpO1xuXG5hc3luYyBmdW5jdGlvbiBmbHVzaFdpdGhUaW1lb3V0KHRpbWVvdXQpIHtcbiAgdHJ5IHtcbiAgICBkZWJ1Z0xvZ2dlci5kZWJ1Zy5sb2coJ0ZsdXNoaW5nIGV2ZW50cy4uLicpO1xuICAgIGF3YWl0IGV4cG9ydHMkMS5mbHVzaCh0aW1lb3V0KTtcbiAgICBkZWJ1Z0xvZ2dlci5kZWJ1Zy5sb2coJ0RvbmUgZmx1c2hpbmcgZXZlbnRzJyk7XG4gIH0gY2F0Y2ggKGUpIHtcbiAgICBkZWJ1Z0xvZ2dlci5kZWJ1Zy5sb2coJ0Vycm9yIHdoaWxlIGZsdXNoaW5nIGV2ZW50czpcXG4nLCBlKTtcbiAgfVxufVxuXG4vKipcbiAqICBGbHVzaGVzIHRoZSBldmVudCBxdWV1ZSB3aXRoIGEgdGltZW91dCBpbiBzZXJ2ZXJsZXNzIGVudmlyb25tZW50cyB0byBlbnN1cmUgdGhhdCBldmVudHMgYXJlIHNlbnQgdG8gU2VudHJ5IGJlZm9yZSB0aGVcbiAqICBzZXJ2ZXJsZXNzIGZ1bmN0aW9uIGV4ZWN1dGlvbiBlbmRzLlxuICpcbiAqIFRoZSBmdW5jdGlvbiBpcyBhc3luYywgYnV0IGluIGVudmlyb25tZW50cyB0aGF0IHN1cHBvcnQgYSBgd2FpdFVudGlsYCBtZWNoYW5pc20sIGl0IHdpbGwgcnVuIHN5bmNocm9ub3VzbHkuXG4gKlxuICogVGhpcyBmdW5jdGlvbiBpcyBhd2FyZSBvZiB0aGUgZm9sbG93aW5nIHNlcnZlcmxlc3MgcGxhdGZvcm1zOlxuICogLSBDbG91ZGZsYXJlOiBJZiBhIENsb3VkZmxhcmUgY29udGV4dCBpcyBwcm92aWRlZCwgaXQgd2lsbCB1c2UgYGN0eC53YWl0VW50aWwoKWAgdG8gZmx1c2ggZXZlbnRzIChrZWVwcyB0aGUgYHRoaXNgIGNvbnRleHQgb2YgYGN0eGApLlxuICogICAgICAgICAgICAgICBJZiBhIGBjbG91ZGZsYXJlV2FpdFVudGlsYCBmdW5jdGlvbiBpcyBwcm92aWRlZCwgaXQgd2lsbCB1c2UgdGhhdCB0byBmbHVzaCBldmVudHMgKGxvb3NlcyB0aGUgYHRoaXNgIGNvbnRleHQgb2YgYGN0eGApLlxuICogLSBWZXJjZWw6IEl0IGRldGVjdHMgdGhlIFZlcmNlbCBlbnZpcm9ubWVudCBhbmQgdXNlcyBWZXJjZWwncyBgd2FpdFVudGlsYCBmdW5jdGlvbi5cbiAqIC0gT3RoZXIgU2VydmVybGVzcyAoQVdTIExhbWJkYSwgR29vZ2xlIENsb3VkLCBldGMuKTogSXQgZGV0ZWN0cyB0aGUgZW52aXJvbm1lbnQgdmlhIGVudmlyb25tZW50IHZhcmlhYmxlc1xuICogICBhbmQgdXNlcyBhIHJlZ3VsYXIgYGF3YWl0IGZsdXNoKClgLlxuICpcbiAqICBAaW50ZXJuYWwgVGhpcyBmdW5jdGlvbiBpcyBzdXBwb3NlZCBmb3IgaW50ZXJuYWwgU2VudHJ5IFNESyB1c2FnZSBvbmx5LlxuICogIEBoaWRkZW5cbiAqL1xuYXN5bmMgZnVuY3Rpb24gZmx1c2hJZlNlcnZlcmxlc3MoXG4gIHBhcmFtc1xuXG4gPSB7fSxcbikge1xuICBjb25zdCB7IHRpbWVvdXQgPSAyMDAwIH0gPSBwYXJhbXM7XG5cbiAgaWYgKCdjbG91ZGZsYXJlV2FpdFVudGlsJyBpbiBwYXJhbXMgJiYgdHlwZW9mIHBhcmFtcz8uY2xvdWRmbGFyZVdhaXRVbnRpbCA9PT0gJ2Z1bmN0aW9uJykge1xuICAgIHBhcmFtcy5jbG91ZGZsYXJlV2FpdFVudGlsKGZsdXNoV2l0aFRpbWVvdXQodGltZW91dCkpO1xuICAgIHJldHVybjtcbiAgfVxuXG4gIGlmICgnY2xvdWRmbGFyZUN0eCcgaW4gcGFyYW1zICYmIHR5cGVvZiBwYXJhbXMuY2xvdWRmbGFyZUN0eD8ud2FpdFVudGlsID09PSAnZnVuY3Rpb24nKSB7XG4gICAgcGFyYW1zLmNsb3VkZmxhcmVDdHgud2FpdFVudGlsKGZsdXNoV2l0aFRpbWVvdXQodGltZW91dCkpO1xuICAgIHJldHVybjtcbiAgfVxuXG4gIC8vIEB0cy1leHBlY3QtZXJyb3IgVGhpcyBpcyBub3QgdHlwZWRcbiAgaWYgKHdvcmxkd2lkZS5HTE9CQUxfT0JKW1N5bWJvbC5mb3IoJ0B2ZXJjZWwvcmVxdWVzdC1jb250ZXh0JyldKSB7XG4gICAgLy8gVmVyY2VsIGhhcyBhIHdhaXRVbnRpbCBlcXVpdmFsZW50IHRoYXQgd29ya3Mgd2l0aG91dCBleGVjdXRpb24gY29udGV4dFxuICAgIHZlcmNlbFdhaXRVbnRpbC52ZXJjZWxXYWl0VW50aWwoZmx1c2hXaXRoVGltZW91dCh0aW1lb3V0KSk7XG4gICAgcmV0dXJuO1xuICB9XG5cbiAgaWYgKHR5cGVvZiBwcm9jZXNzID09PSAndW5kZWZpbmVkJykge1xuICAgIHJldHVybjtcbiAgfVxuXG4gIGNvbnN0IGlzU2VydmVybGVzcyA9XG4gICAgISFwcm9jZXNzLmVudi5GVU5DVElPTlNfV09SS0VSX1JVTlRJTUUgfHwgLy8gQXp1cmUgRnVuY3Rpb25zXG4gICAgISFwcm9jZXNzLmVudi5MQU1CREFfVEFTS19ST09UIHx8IC8vIEFXUyBMYW1iZGFcbiAgICAhIXByb2Nlc3MuZW52LktfU0VSVklDRSB8fCAvLyBHb29nbGUgQ2xvdWQgUnVuXG4gICAgISFwcm9jZXNzLmVudi5DRl9QQUdFUyB8fCAvLyBDbG91ZGZsYXJlIFBhZ2VzXG4gICAgISFwcm9jZXNzLmVudi5WRVJDRUwgfHxcbiAgICAhIXByb2Nlc3MuZW52Lk5FVExJRlk7XG5cbiAgaWYgKGlzU2VydmVybGVzcykge1xuICAgIC8vIFVzZSByZWd1bGFyIGZsdXNoIGZvciBlbnZpcm9ubWVudHMgd2l0aG91dCBhIGdlbmVyaWMgd2FpdFVudGlsIG1lY2hhbmlzbVxuICAgIGF3YWl0IGZsdXNoV2l0aFRpbWVvdXQodGltZW91dCk7XG4gIH1cbn1cblxuZXhwb3J0cy5mbHVzaElmU2VydmVybGVzcyA9IGZsdXNoSWZTZXJ2ZXJsZXNzO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9Zmx1c2hJZlNlcnZlcmxlc3MuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/flushIfServerless.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/gen-ai-attributes.js":
/*!***************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/gen-ai-attributes.js ***!
  \***************************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n/**\n * OpenAI Integration Telemetry Attributes\n * Based on OpenTelemetry Semantic Conventions for Generative AI\n * @see https://opentelemetry.io/docs/specs/semconv/gen-ai/\n */\n\n// =============================================================================\n// OPENTELEMETRY SEMANTIC CONVENTIONS FOR GENAI\n// =============================================================================\n\n/**\n * The Generative AI system being used\n * For OpenAI, this should always be \"openai\"\n */\nconst GEN_AI_SYSTEM_ATTRIBUTE = 'gen_ai.system';\n\n/**\n * The name of the model as requested\n * Examples: \"gpt-4\", \"gpt-3.5-turbo\"\n */\nconst GEN_AI_REQUEST_MODEL_ATTRIBUTE = 'gen_ai.request.model';\n\n/**\n * The temperature setting for the model request\n */\nconst GEN_AI_REQUEST_TEMPERATURE_ATTRIBUTE = 'gen_ai.request.temperature';\n\n/**\n * The frequency penalty setting for the model request\n */\nconst GEN_AI_REQUEST_FREQUENCY_PENALTY_ATTRIBUTE = 'gen_ai.request.frequency_penalty';\n\n/**\n * The presence penalty setting for the model request\n */\nconst GEN_AI_REQUEST_PRESENCE_PENALTY_ATTRIBUTE = 'gen_ai.request.presence_penalty';\n\n/**\n * The top_p (nucleus sampling) setting for the model request\n */\nconst GEN_AI_REQUEST_TOP_P_ATTRIBUTE = 'gen_ai.request.top_p';\n\n/**\n * Array of reasons why the model stopped generating tokens\n */\nconst GEN_AI_RESPONSE_FINISH_REASONS_ATTRIBUTE = 'gen_ai.response.finish_reasons';\n\n/**\n * The name of the model that generated the response\n */\nconst GEN_AI_RESPONSE_MODEL_ATTRIBUTE = 'gen_ai.response.model';\n\n/**\n * The unique identifier for the response\n */\nconst GEN_AI_RESPONSE_ID_ATTRIBUTE = 'gen_ai.response.id';\n\n/**\n * The number of tokens used in the prompt\n */\nconst GEN_AI_USAGE_INPUT_TOKENS_ATTRIBUTE = 'gen_ai.usage.input_tokens';\n\n/**\n * The number of tokens used in the response\n */\nconst GEN_AI_USAGE_OUTPUT_TOKENS_ATTRIBUTE = 'gen_ai.usage.output_tokens';\n\n/**\n * The total number of tokens used (input + output)\n */\nconst GEN_AI_USAGE_TOTAL_TOKENS_ATTRIBUTE = 'gen_ai.usage.total_tokens';\n\n/**\n * The operation name for OpenAI API calls\n */\nconst GEN_AI_OPERATION_NAME_ATTRIBUTE = 'gen_ai.operation.name';\n\n/**\n * The prompt messages sent to OpenAI (stringified JSON)\n * Only recorded when recordInputs is enabled\n */\nconst GEN_AI_REQUEST_MESSAGES_ATTRIBUTE = 'gen_ai.request.messages';\n\n/**\n * The response text from OpenAI (stringified JSON array)\n * Only recorded when recordOutputs is enabled\n */\nconst GEN_AI_RESPONSE_TEXT_ATTRIBUTE = 'gen_ai.response.text';\n\n// =============================================================================\n// OPENAI-SPECIFIC ATTRIBUTES\n// =============================================================================\n\n/**\n * The response ID from OpenAI\n */\nconst OPENAI_RESPONSE_ID_ATTRIBUTE = 'openai.response.id';\n\n/**\n * The response model from OpenAI\n */\nconst OPENAI_RESPONSE_MODEL_ATTRIBUTE = 'openai.response.model';\n\n/**\n * The response timestamp from OpenAI (ISO string)\n */\nconst OPENAI_RESPONSE_TIMESTAMP_ATTRIBUTE = 'openai.response.timestamp';\n\n/**\n * The number of completion tokens used (OpenAI specific)\n */\nconst OPENAI_USAGE_COMPLETION_TOKENS_ATTRIBUTE = 'openai.usage.completion_tokens';\n\n/**\n * The number of prompt tokens used (OpenAI specific)\n */\nconst OPENAI_USAGE_PROMPT_TOKENS_ATTRIBUTE = 'openai.usage.prompt_tokens';\n\n// =============================================================================\n// OPENAI OPERATIONS\n// =============================================================================\n\n/**\n * OpenAI API operations\n */\nconst OPENAI_OPERATIONS = {\n  CHAT: 'chat',\n} ;\n\nexports.GEN_AI_OPERATION_NAME_ATTRIBUTE = GEN_AI_OPERATION_NAME_ATTRIBUTE;\nexports.GEN_AI_REQUEST_FREQUENCY_PENALTY_ATTRIBUTE = GEN_AI_REQUEST_FREQUENCY_PENALTY_ATTRIBUTE;\nexports.GEN_AI_REQUEST_MESSAGES_ATTRIBUTE = GEN_AI_REQUEST_MESSAGES_ATTRIBUTE;\nexports.GEN_AI_REQUEST_MODEL_ATTRIBUTE = GEN_AI_REQUEST_MODEL_ATTRIBUTE;\nexports.GEN_AI_REQUEST_PRESENCE_PENALTY_ATTRIBUTE = GEN_AI_REQUEST_PRESENCE_PENALTY_ATTRIBUTE;\nexports.GEN_AI_REQUEST_TEMPERATURE_ATTRIBUTE = GEN_AI_REQUEST_TEMPERATURE_ATTRIBUTE;\nexports.GEN_AI_REQUEST_TOP_P_ATTRIBUTE = GEN_AI_REQUEST_TOP_P_ATTRIBUTE;\nexports.GEN_AI_RESPONSE_FINISH_REASONS_ATTRIBUTE = GEN_AI_RESPONSE_FINISH_REASONS_ATTRIBUTE;\nexports.GEN_AI_RESPONSE_ID_ATTRIBUTE = GEN_AI_RESPONSE_ID_ATTRIBUTE;\nexports.GEN_AI_RESPONSE_MODEL_ATTRIBUTE = GEN_AI_RESPONSE_MODEL_ATTRIBUTE;\nexports.GEN_AI_RESPONSE_TEXT_ATTRIBUTE = GEN_AI_RESPONSE_TEXT_ATTRIBUTE;\nexports.GEN_AI_SYSTEM_ATTRIBUTE = GEN_AI_SYSTEM_ATTRIBUTE;\nexports.GEN_AI_USAGE_INPUT_TOKENS_ATTRIBUTE = GEN_AI_USAGE_INPUT_TOKENS_ATTRIBUTE;\nexports.GEN_AI_USAGE_OUTPUT_TOKENS_ATTRIBUTE = GEN_AI_USAGE_OUTPUT_TOKENS_ATTRIBUTE;\nexports.GEN_AI_USAGE_TOTAL_TOKENS_ATTRIBUTE = GEN_AI_USAGE_TOTAL_TOKENS_ATTRIBUTE;\nexports.OPENAI_OPERATIONS = OPENAI_OPERATIONS;\nexports.OPENAI_RESPONSE_ID_ATTRIBUTE = OPENAI_RESPONSE_ID_ATTRIBUTE;\nexports.OPENAI_RESPONSE_MODEL_ATTRIBUTE = OPENAI_RESPONSE_MODEL_ATTRIBUTE;\nexports.OPENAI_RESPONSE_TIMESTAMP_ATTRIBUTE = OPENAI_RESPONSE_TIMESTAMP_ATTRIBUTE;\nexports.OPENAI_USAGE_COMPLETION_TOKENS_ATTRIBUTE = OPENAI_USAGE_COMPLETION_TOKENS_ATTRIBUTE;\nexports.OPENAI_USAGE_PROMPT_TOKENS_ATTRIBUTE = OPENAI_USAGE_PROMPT_TOKENS_ATTRIBUTE;\n//# sourceMappingURL=gen-ai-attributes.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9nZW4tYWktYXR0cmlidXRlcy5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLHVDQUF1QztBQUN2QyxrREFBa0Q7QUFDbEQseUNBQXlDO0FBQ3pDLHNDQUFzQztBQUN0QyxpREFBaUQ7QUFDakQsNENBQTRDO0FBQzVDLHNDQUFzQztBQUN0QyxnREFBZ0Q7QUFDaEQsb0NBQW9DO0FBQ3BDLHVDQUF1QztBQUN2QyxzQ0FBc0M7QUFDdEMsK0JBQStCO0FBQy9CLDJDQUEyQztBQUMzQyw0Q0FBNEM7QUFDNUMsMkNBQTJDO0FBQzNDLHlCQUF5QjtBQUN6QixvQ0FBb0M7QUFDcEMsdUNBQXVDO0FBQ3ZDLDJDQUEyQztBQUMzQyxnREFBZ0Q7QUFDaEQsNENBQTRDO0FBQzVDIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvZ2VuLWFpLWF0dHJpYnV0ZXMuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbi8qKlxuICogT3BlbkFJIEludGVncmF0aW9uIFRlbGVtZXRyeSBBdHRyaWJ1dGVzXG4gKiBCYXNlZCBvbiBPcGVuVGVsZW1ldHJ5IFNlbWFudGljIENvbnZlbnRpb25zIGZvciBHZW5lcmF0aXZlIEFJXG4gKiBAc2VlIGh0dHBzOi8vb3BlbnRlbGVtZXRyeS5pby9kb2NzL3NwZWNzL3NlbWNvbnYvZ2VuLWFpL1xuICovXG5cbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG4vLyBPUEVOVEVMRU1FVFJZIFNFTUFOVElDIENPTlZFTlRJT05TIEZPUiBHRU5BSVxuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cblxuLyoqXG4gKiBUaGUgR2VuZXJhdGl2ZSBBSSBzeXN0ZW0gYmVpbmcgdXNlZFxuICogRm9yIE9wZW5BSSwgdGhpcyBzaG91bGQgYWx3YXlzIGJlIFwib3BlbmFpXCJcbiAqL1xuY29uc3QgR0VOX0FJX1NZU1RFTV9BVFRSSUJVVEUgPSAnZ2VuX2FpLnN5c3RlbSc7XG5cbi8qKlxuICogVGhlIG5hbWUgb2YgdGhlIG1vZGVsIGFzIHJlcXVlc3RlZFxuICogRXhhbXBsZXM6IFwiZ3B0LTRcIiwgXCJncHQtMy41LXR1cmJvXCJcbiAqL1xuY29uc3QgR0VOX0FJX1JFUVVFU1RfTU9ERUxfQVRUUklCVVRFID0gJ2dlbl9haS5yZXF1ZXN0Lm1vZGVsJztcblxuLyoqXG4gKiBUaGUgdGVtcGVyYXR1cmUgc2V0dGluZyBmb3IgdGhlIG1vZGVsIHJlcXVlc3RcbiAqL1xuY29uc3QgR0VOX0FJX1JFUVVFU1RfVEVNUEVSQVRVUkVfQVRUUklCVVRFID0gJ2dlbl9haS5yZXF1ZXN0LnRlbXBlcmF0dXJlJztcblxuLyoqXG4gKiBUaGUgZnJlcXVlbmN5IHBlbmFsdHkgc2V0dGluZyBmb3IgdGhlIG1vZGVsIHJlcXVlc3RcbiAqL1xuY29uc3QgR0VOX0FJX1JFUVVFU1RfRlJFUVVFTkNZX1BFTkFMVFlfQVRUUklCVVRFID0gJ2dlbl9haS5yZXF1ZXN0LmZyZXF1ZW5jeV9wZW5hbHR5JztcblxuLyoqXG4gKiBUaGUgcHJlc2VuY2UgcGVuYWx0eSBzZXR0aW5nIGZvciB0aGUgbW9kZWwgcmVxdWVzdFxuICovXG5jb25zdCBHRU5fQUlfUkVRVUVTVF9QUkVTRU5DRV9QRU5BTFRZX0FUVFJJQlVURSA9ICdnZW5fYWkucmVxdWVzdC5wcmVzZW5jZV9wZW5hbHR5JztcblxuLyoqXG4gKiBUaGUgdG9wX3AgKG51Y2xldXMgc2FtcGxpbmcpIHNldHRpbmcgZm9yIHRoZSBtb2RlbCByZXF1ZXN0XG4gKi9cbmNvbnN0IEdFTl9BSV9SRVFVRVNUX1RPUF9QX0FUVFJJQlVURSA9ICdnZW5fYWkucmVxdWVzdC50b3BfcCc7XG5cbi8qKlxuICogQXJyYXkgb2YgcmVhc29ucyB3aHkgdGhlIG1vZGVsIHN0b3BwZWQgZ2VuZXJhdGluZyB0b2tlbnNcbiAqL1xuY29uc3QgR0VOX0FJX1JFU1BPTlNFX0ZJTklTSF9SRUFTT05TX0FUVFJJQlVURSA9ICdnZW5fYWkucmVzcG9uc2UuZmluaXNoX3JlYXNvbnMnO1xuXG4vKipcbiAqIFRoZSBuYW1lIG9mIHRoZSBtb2RlbCB0aGF0IGdlbmVyYXRlZCB0aGUgcmVzcG9uc2VcbiAqL1xuY29uc3QgR0VOX0FJX1JFU1BPTlNFX01PREVMX0FUVFJJQlVURSA9ICdnZW5fYWkucmVzcG9uc2UubW9kZWwnO1xuXG4vKipcbiAqIFRoZSB1bmlxdWUgaWRlbnRpZmllciBmb3IgdGhlIHJlc3BvbnNlXG4gKi9cbmNvbnN0IEdFTl9BSV9SRVNQT05TRV9JRF9BVFRSSUJVVEUgPSAnZ2VuX2FpLnJlc3BvbnNlLmlkJztcblxuLyoqXG4gKiBUaGUgbnVtYmVyIG9mIHRva2VucyB1c2VkIGluIHRoZSBwcm9tcHRcbiAqL1xuY29uc3QgR0VOX0FJX1VTQUdFX0lOUFVUX1RPS0VOU19BVFRSSUJVVEUgPSAnZ2VuX2FpLnVzYWdlLmlucHV0X3Rva2Vucyc7XG5cbi8qKlxuICogVGhlIG51bWJlciBvZiB0b2tlbnMgdXNlZCBpbiB0aGUgcmVzcG9uc2VcbiAqL1xuY29uc3QgR0VOX0FJX1VTQUdFX09VVFBVVF9UT0tFTlNfQVRUUklCVVRFID0gJ2dlbl9haS51c2FnZS5vdXRwdXRfdG9rZW5zJztcblxuLyoqXG4gKiBUaGUgdG90YWwgbnVtYmVyIG9mIHRva2VucyB1c2VkIChpbnB1dCArIG91dHB1dClcbiAqL1xuY29uc3QgR0VOX0FJX1VTQUdFX1RPVEFMX1RPS0VOU19BVFRSSUJVVEUgPSAnZ2VuX2FpLnVzYWdlLnRvdGFsX3Rva2Vucyc7XG5cbi8qKlxuICogVGhlIG9wZXJhdGlvbiBuYW1lIGZvciBPcGVuQUkgQVBJIGNhbGxzXG4gKi9cbmNvbnN0IEdFTl9BSV9PUEVSQVRJT05fTkFNRV9BVFRSSUJVVEUgPSAnZ2VuX2FpLm9wZXJhdGlvbi5uYW1lJztcblxuLyoqXG4gKiBUaGUgcHJvbXB0IG1lc3NhZ2VzIHNlbnQgdG8gT3BlbkFJIChzdHJpbmdpZmllZCBKU09OKVxuICogT25seSByZWNvcmRlZCB3aGVuIHJlY29yZElucHV0cyBpcyBlbmFibGVkXG4gKi9cbmNvbnN0IEdFTl9BSV9SRVFVRVNUX01FU1NBR0VTX0FUVFJJQlVURSA9ICdnZW5fYWkucmVxdWVzdC5tZXNzYWdlcyc7XG5cbi8qKlxuICogVGhlIHJlc3BvbnNlIHRleHQgZnJvbSBPcGVuQUkgKHN0cmluZ2lmaWVkIEpTT04gYXJyYXkpXG4gKiBPbmx5IHJlY29yZGVkIHdoZW4gcmVjb3JkT3V0cHV0cyBpcyBlbmFibGVkXG4gKi9cbmNvbnN0IEdFTl9BSV9SRVNQT05TRV9URVhUX0FUVFJJQlVURSA9ICdnZW5fYWkucmVzcG9uc2UudGV4dCc7XG5cbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG4vLyBPUEVOQUktU1BFQ0lGSUMgQVRUUklCVVRFU1xuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cblxuLyoqXG4gKiBUaGUgcmVzcG9uc2UgSUQgZnJvbSBPcGVuQUlcbiAqL1xuY29uc3QgT1BFTkFJX1JFU1BPTlNFX0lEX0FUVFJJQlVURSA9ICdvcGVuYWkucmVzcG9uc2UuaWQnO1xuXG4vKipcbiAqIFRoZSByZXNwb25zZSBtb2RlbCBmcm9tIE9wZW5BSVxuICovXG5jb25zdCBPUEVOQUlfUkVTUE9OU0VfTU9ERUxfQVRUUklCVVRFID0gJ29wZW5haS5yZXNwb25zZS5tb2RlbCc7XG5cbi8qKlxuICogVGhlIHJlc3BvbnNlIHRpbWVzdGFtcCBmcm9tIE9wZW5BSSAoSVNPIHN0cmluZylcbiAqL1xuY29uc3QgT1BFTkFJX1JFU1BPTlNFX1RJTUVTVEFNUF9BVFRSSUJVVEUgPSAnb3BlbmFpLnJlc3BvbnNlLnRpbWVzdGFtcCc7XG5cbi8qKlxuICogVGhlIG51bWJlciBvZiBjb21wbGV0aW9uIHRva2VucyB1c2VkIChPcGVuQUkgc3BlY2lmaWMpXG4gKi9cbmNvbnN0IE9QRU5BSV9VU0FHRV9DT01QTEVUSU9OX1RPS0VOU19BVFRSSUJVVEUgPSAnb3BlbmFpLnVzYWdlLmNvbXBsZXRpb25fdG9rZW5zJztcblxuLyoqXG4gKiBUaGUgbnVtYmVyIG9mIHByb21wdCB0b2tlbnMgdXNlZCAoT3BlbkFJIHNwZWNpZmljKVxuICovXG5jb25zdCBPUEVOQUlfVVNBR0VfUFJPTVBUX1RPS0VOU19BVFRSSUJVVEUgPSAnb3BlbmFpLnVzYWdlLnByb21wdF90b2tlbnMnO1xuXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuLy8gT1BFTkFJIE9QRVJBVElPTlNcbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG5cbi8qKlxuICogT3BlbkFJIEFQSSBvcGVyYXRpb25zXG4gKi9cbmNvbnN0IE9QRU5BSV9PUEVSQVRJT05TID0ge1xuICBDSEFUOiAnY2hhdCcsXG59IDtcblxuZXhwb3J0cy5HRU5fQUlfT1BFUkFUSU9OX05BTUVfQVRUUklCVVRFID0gR0VOX0FJX09QRVJBVElPTl9OQU1FX0FUVFJJQlVURTtcbmV4cG9ydHMuR0VOX0FJX1JFUVVFU1RfRlJFUVVFTkNZX1BFTkFMVFlfQVRUUklCVVRFID0gR0VOX0FJX1JFUVVFU1RfRlJFUVVFTkNZX1BFTkFMVFlfQVRUUklCVVRFO1xuZXhwb3J0cy5HRU5fQUlfUkVRVUVTVF9NRVNTQUdFU19BVFRSSUJVVEUgPSBHRU5fQUlfUkVRVUVTVF9NRVNTQUdFU19BVFRSSUJVVEU7XG5leHBvcnRzLkdFTl9BSV9SRVFVRVNUX01PREVMX0FUVFJJQlVURSA9IEdFTl9BSV9SRVFVRVNUX01PREVMX0FUVFJJQlVURTtcbmV4cG9ydHMuR0VOX0FJX1JFUVVFU1RfUFJFU0VOQ0VfUEVOQUxUWV9BVFRSSUJVVEUgPSBHRU5fQUlfUkVRVUVTVF9QUkVTRU5DRV9QRU5BTFRZX0FUVFJJQlVURTtcbmV4cG9ydHMuR0VOX0FJX1JFUVVFU1RfVEVNUEVSQVRVUkVfQVRUUklCVVRFID0gR0VOX0FJX1JFUVVFU1RfVEVNUEVSQVRVUkVfQVRUUklCVVRFO1xuZXhwb3J0cy5HRU5fQUlfUkVRVUVTVF9UT1BfUF9BVFRSSUJVVEUgPSBHRU5fQUlfUkVRVUVTVF9UT1BfUF9BVFRSSUJVVEU7XG5leHBvcnRzLkdFTl9BSV9SRVNQT05TRV9GSU5JU0hfUkVBU09OU19BVFRSSUJVVEUgPSBHRU5fQUlfUkVTUE9OU0VfRklOSVNIX1JFQVNPTlNfQVRUUklCVVRFO1xuZXhwb3J0cy5HRU5fQUlfUkVTUE9OU0VfSURfQVRUUklCVVRFID0gR0VOX0FJX1JFU1BPTlNFX0lEX0FUVFJJQlVURTtcbmV4cG9ydHMuR0VOX0FJX1JFU1BPTlNFX01PREVMX0FUVFJJQlVURSA9IEdFTl9BSV9SRVNQT05TRV9NT0RFTF9BVFRSSUJVVEU7XG5leHBvcnRzLkdFTl9BSV9SRVNQT05TRV9URVhUX0FUVFJJQlVURSA9IEdFTl9BSV9SRVNQT05TRV9URVhUX0FUVFJJQlVURTtcbmV4cG9ydHMuR0VOX0FJX1NZU1RFTV9BVFRSSUJVVEUgPSBHRU5fQUlfU1lTVEVNX0FUVFJJQlVURTtcbmV4cG9ydHMuR0VOX0FJX1VTQUdFX0lOUFVUX1RPS0VOU19BVFRSSUJVVEUgPSBHRU5fQUlfVVNBR0VfSU5QVVRfVE9LRU5TX0FUVFJJQlVURTtcbmV4cG9ydHMuR0VOX0FJX1VTQUdFX09VVFBVVF9UT0tFTlNfQVRUUklCVVRFID0gR0VOX0FJX1VTQUdFX09VVFBVVF9UT0tFTlNfQVRUUklCVVRFO1xuZXhwb3J0cy5HRU5fQUlfVVNBR0VfVE9UQUxfVE9LRU5TX0FUVFJJQlVURSA9IEdFTl9BSV9VU0FHRV9UT1RBTF9UT0tFTlNfQVRUUklCVVRFO1xuZXhwb3J0cy5PUEVOQUlfT1BFUkFUSU9OUyA9IE9QRU5BSV9PUEVSQVRJT05TO1xuZXhwb3J0cy5PUEVOQUlfUkVTUE9OU0VfSURfQVRUUklCVVRFID0gT1BFTkFJX1JFU1BPTlNFX0lEX0FUVFJJQlVURTtcbmV4cG9ydHMuT1BFTkFJX1JFU1BPTlNFX01PREVMX0FUVFJJQlVURSA9IE9QRU5BSV9SRVNQT05TRV9NT0RFTF9BVFRSSUJVVEU7XG5leHBvcnRzLk9QRU5BSV9SRVNQT05TRV9USU1FU1RBTVBfQVRUUklCVVRFID0gT1BFTkFJX1JFU1BPTlNFX1RJTUVTVEFNUF9BVFRSSUJVVEU7XG5leHBvcnRzLk9QRU5BSV9VU0FHRV9DT01QTEVUSU9OX1RPS0VOU19BVFRSSUJVVEUgPSBPUEVOQUlfVVNBR0VfQ09NUExFVElPTl9UT0tFTlNfQVRUUklCVVRFO1xuZXhwb3J0cy5PUEVOQUlfVVNBR0VfUFJPTVBUX1RPS0VOU19BVFRSSUJVVEUgPSBPUEVOQUlfVVNBR0VfUFJPTVBUX1RPS0VOU19BVFRSSUJVVEU7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1nZW4tYWktYXR0cmlidXRlcy5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/gen-ai-attributes.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/handleCallbackErrors.js":
/*!******************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/handleCallbackErrors.js ***!
  \******************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst is = __webpack_require__(/*! ./is.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js\");\n\n/**\n * Wrap a callback function with error handling.\n * If an error is thrown, it will be passed to the `onError` callback and re-thrown.\n *\n * If the return value of the function is a promise, it will be handled with `maybeHandlePromiseRejection`.\n *\n * If an `onFinally` callback is provided, this will be called when the callback has finished\n * - so if it returns a promise, once the promise resolved/rejected,\n * else once the callback has finished executing.\n * The `onFinally` callback will _always_ be called, no matter if an error was thrown or not.\n */\nfunction handleCallbackErrors\n\n(fn, onError, onFinally = () => {}) {\n  let maybePromiseResult;\n  try {\n    maybePromiseResult = fn();\n  } catch (e) {\n    onError(e);\n    onFinally();\n    throw e;\n  }\n\n  return maybeHandlePromiseRejection(maybePromiseResult, onError, onFinally);\n}\n\n/**\n * Maybe handle a promise rejection.\n * This expects to be given a value that _may_ be a promise, or any other value.\n * If it is a promise, and it rejects, it will call the `onError` callback.\n * Other than this, it will generally return the given value as-is.\n */\nfunction maybeHandlePromiseRejection(\n  value,\n  onError,\n  onFinally,\n) {\n  if (is.isThenable(value)) {\n    // @ts-expect-error - the isThenable check returns the \"wrong\" type here\n    return value.then(\n      res => {\n        onFinally();\n        return res;\n      },\n      e => {\n        onError(e);\n        onFinally();\n        throw e;\n      },\n    );\n  }\n\n  onFinally();\n  return value;\n}\n\nexports.handleCallbackErrors = handleCallbackErrors;\n//# sourceMappingURL=handleCallbackErrors.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9oYW5kbGVDYWxsYmFja0Vycm9ycy5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxXQUFXLG1CQUFPLENBQUMsK0dBQVM7O0FBRTVCO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSxrQ0FBa0M7QUFDbEM7QUFDQTtBQUNBO0FBQ0EsSUFBSTtBQUNKO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLE9BQU87QUFDUDtBQUNBO0FBQ0E7QUFDQTtBQUNBLE9BQU87QUFDUDtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQSw0QkFBNEI7QUFDNUIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9oYW5kbGVDYWxsYmFja0Vycm9ycy5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgaXMgPSByZXF1aXJlKCcuL2lzLmpzJyk7XG5cbi8qKlxuICogV3JhcCBhIGNhbGxiYWNrIGZ1bmN0aW9uIHdpdGggZXJyb3IgaGFuZGxpbmcuXG4gKiBJZiBhbiBlcnJvciBpcyB0aHJvd24sIGl0IHdpbGwgYmUgcGFzc2VkIHRvIHRoZSBgb25FcnJvcmAgY2FsbGJhY2sgYW5kIHJlLXRocm93bi5cbiAqXG4gKiBJZiB0aGUgcmV0dXJuIHZhbHVlIG9mIHRoZSBmdW5jdGlvbiBpcyBhIHByb21pc2UsIGl0IHdpbGwgYmUgaGFuZGxlZCB3aXRoIGBtYXliZUhhbmRsZVByb21pc2VSZWplY3Rpb25gLlxuICpcbiAqIElmIGFuIGBvbkZpbmFsbHlgIGNhbGxiYWNrIGlzIHByb3ZpZGVkLCB0aGlzIHdpbGwgYmUgY2FsbGVkIHdoZW4gdGhlIGNhbGxiYWNrIGhhcyBmaW5pc2hlZFxuICogLSBzbyBpZiBpdCByZXR1cm5zIGEgcHJvbWlzZSwgb25jZSB0aGUgcHJvbWlzZSByZXNvbHZlZC9yZWplY3RlZCxcbiAqIGVsc2Ugb25jZSB0aGUgY2FsbGJhY2sgaGFzIGZpbmlzaGVkIGV4ZWN1dGluZy5cbiAqIFRoZSBgb25GaW5hbGx5YCBjYWxsYmFjayB3aWxsIF9hbHdheXNfIGJlIGNhbGxlZCwgbm8gbWF0dGVyIGlmIGFuIGVycm9yIHdhcyB0aHJvd24gb3Igbm90LlxuICovXG5mdW5jdGlvbiBoYW5kbGVDYWxsYmFja0Vycm9yc1xuXG4oZm4sIG9uRXJyb3IsIG9uRmluYWxseSA9ICgpID0+IHt9KSB7XG4gIGxldCBtYXliZVByb21pc2VSZXN1bHQ7XG4gIHRyeSB7XG4gICAgbWF5YmVQcm9taXNlUmVzdWx0ID0gZm4oKTtcbiAgfSBjYXRjaCAoZSkge1xuICAgIG9uRXJyb3IoZSk7XG4gICAgb25GaW5hbGx5KCk7XG4gICAgdGhyb3cgZTtcbiAgfVxuXG4gIHJldHVybiBtYXliZUhhbmRsZVByb21pc2VSZWplY3Rpb24obWF5YmVQcm9taXNlUmVzdWx0LCBvbkVycm9yLCBvbkZpbmFsbHkpO1xufVxuXG4vKipcbiAqIE1heWJlIGhhbmRsZSBhIHByb21pc2UgcmVqZWN0aW9uLlxuICogVGhpcyBleHBlY3RzIHRvIGJlIGdpdmVuIGEgdmFsdWUgdGhhdCBfbWF5XyBiZSBhIHByb21pc2UsIG9yIGFueSBvdGhlciB2YWx1ZS5cbiAqIElmIGl0IGlzIGEgcHJvbWlzZSwgYW5kIGl0IHJlamVjdHMsIGl0IHdpbGwgY2FsbCB0aGUgYG9uRXJyb3JgIGNhbGxiYWNrLlxuICogT3RoZXIgdGhhbiB0aGlzLCBpdCB3aWxsIGdlbmVyYWxseSByZXR1cm4gdGhlIGdpdmVuIHZhbHVlIGFzLWlzLlxuICovXG5mdW5jdGlvbiBtYXliZUhhbmRsZVByb21pc2VSZWplY3Rpb24oXG4gIHZhbHVlLFxuICBvbkVycm9yLFxuICBvbkZpbmFsbHksXG4pIHtcbiAgaWYgKGlzLmlzVGhlbmFibGUodmFsdWUpKSB7XG4gICAgLy8gQHRzLWV4cGVjdC1lcnJvciAtIHRoZSBpc1RoZW5hYmxlIGNoZWNrIHJldHVybnMgdGhlIFwid3JvbmdcIiB0eXBlIGhlcmVcbiAgICByZXR1cm4gdmFsdWUudGhlbihcbiAgICAgIHJlcyA9PiB7XG4gICAgICAgIG9uRmluYWxseSgpO1xuICAgICAgICByZXR1cm4gcmVzO1xuICAgICAgfSxcbiAgICAgIGUgPT4ge1xuICAgICAgICBvbkVycm9yKGUpO1xuICAgICAgICBvbkZpbmFsbHkoKTtcbiAgICAgICAgdGhyb3cgZTtcbiAgICAgIH0sXG4gICAgKTtcbiAgfVxuXG4gIG9uRmluYWxseSgpO1xuICByZXR1cm4gdmFsdWU7XG59XG5cbmV4cG9ydHMuaGFuZGxlQ2FsbGJhY2tFcnJvcnMgPSBoYW5kbGVDYWxsYmFja0Vycm9ycztcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWhhbmRsZUNhbGxiYWNrRXJyb3JzLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/handleCallbackErrors.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/hasSpansEnabled.js":
/*!*************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/hasSpansEnabled.js ***!
  \*************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst currentScopes = __webpack_require__(/*! ../currentScopes.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\n\n// Treeshakable guard to remove all code related to tracing\n\n/**\n * Determines if span recording is currently enabled.\n *\n * Spans are recorded when at least one of `tracesSampleRate` and `tracesSampler`\n * is defined in the SDK config. This function does not make any assumption about\n * sampling decisions, it only checks if the SDK is configured to record spans.\n *\n * Important: This function only determines if span recording is enabled. Trace\n * continuation and propagation is separately controlled and not covered by this function.\n * If this function returns `false`, traces can still be propagated (which is what\n * we refer to by \"Tracing without Performance\")\n * @see https://develop.sentry.dev/sdk/telemetry/traces/tracing-without-performance/\n *\n * @param maybeOptions An SDK options object to be passed to this function.\n * If this option is not provided, the function will use the current client's options.\n */\nfunction hasSpansEnabled(\n  maybeOptions,\n) {\n  if (typeof __SENTRY_TRACING__ === 'boolean' && !__SENTRY_TRACING__) {\n    return false;\n  }\n\n  const options = maybeOptions || currentScopes.getClient()?.getOptions();\n  return (\n    !!options &&\n    // Note: This check is `!= null`, meaning \"nullish\". `0` is not \"nullish\", `undefined` and `null` are. (This comment was brought to you by 15 minutes of questioning life)\n    (options.tracesSampleRate != null || !!options.tracesSampler)\n  );\n}\n\n/**\n * @see JSDoc of `hasSpansEnabled`\n * @deprecated Use `hasSpansEnabled` instead, which is a more accurately named version of this function.\n * This function will be removed in the next major version of the SDK.\n */\n// TODO(v10): Remove this export\nconst hasTracingEnabled = hasSpansEnabled;\n\nexports.hasSpansEnabled = hasSpansEnabled;\nexports.hasTracingEnabled = hasTracingEnabled;\n//# sourceMappingURL=hasSpansEnabled.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9oYXNTcGFuc0VuYWJsZWQuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsc0JBQXNCLG1CQUFPLENBQUMsZ0lBQXFCOztBQUVuRDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSx1QkFBdUI7QUFDdkIseUJBQXlCO0FBQ3pCIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvaGFzU3BhbnNFbmFibGVkLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBjdXJyZW50U2NvcGVzID0gcmVxdWlyZSgnLi4vY3VycmVudFNjb3Blcy5qcycpO1xuXG4vLyBUcmVlc2hha2FibGUgZ3VhcmQgdG8gcmVtb3ZlIGFsbCBjb2RlIHJlbGF0ZWQgdG8gdHJhY2luZ1xuXG4vKipcbiAqIERldGVybWluZXMgaWYgc3BhbiByZWNvcmRpbmcgaXMgY3VycmVudGx5IGVuYWJsZWQuXG4gKlxuICogU3BhbnMgYXJlIHJlY29yZGVkIHdoZW4gYXQgbGVhc3Qgb25lIG9mIGB0cmFjZXNTYW1wbGVSYXRlYCBhbmQgYHRyYWNlc1NhbXBsZXJgXG4gKiBpcyBkZWZpbmVkIGluIHRoZSBTREsgY29uZmlnLiBUaGlzIGZ1bmN0aW9uIGRvZXMgbm90IG1ha2UgYW55IGFzc3VtcHRpb24gYWJvdXRcbiAqIHNhbXBsaW5nIGRlY2lzaW9ucywgaXQgb25seSBjaGVja3MgaWYgdGhlIFNESyBpcyBjb25maWd1cmVkIHRvIHJlY29yZCBzcGFucy5cbiAqXG4gKiBJbXBvcnRhbnQ6IFRoaXMgZnVuY3Rpb24gb25seSBkZXRlcm1pbmVzIGlmIHNwYW4gcmVjb3JkaW5nIGlzIGVuYWJsZWQuIFRyYWNlXG4gKiBjb250aW51YXRpb24gYW5kIHByb3BhZ2F0aW9uIGlzIHNlcGFyYXRlbHkgY29udHJvbGxlZCBhbmQgbm90IGNvdmVyZWQgYnkgdGhpcyBmdW5jdGlvbi5cbiAqIElmIHRoaXMgZnVuY3Rpb24gcmV0dXJucyBgZmFsc2VgLCB0cmFjZXMgY2FuIHN0aWxsIGJlIHByb3BhZ2F0ZWQgKHdoaWNoIGlzIHdoYXRcbiAqIHdlIHJlZmVyIHRvIGJ5IFwiVHJhY2luZyB3aXRob3V0IFBlcmZvcm1hbmNlXCIpXG4gKiBAc2VlIGh0dHBzOi8vZGV2ZWxvcC5zZW50cnkuZGV2L3Nkay90ZWxlbWV0cnkvdHJhY2VzL3RyYWNpbmctd2l0aG91dC1wZXJmb3JtYW5jZS9cbiAqXG4gKiBAcGFyYW0gbWF5YmVPcHRpb25zIEFuIFNESyBvcHRpb25zIG9iamVjdCB0byBiZSBwYXNzZWQgdG8gdGhpcyBmdW5jdGlvbi5cbiAqIElmIHRoaXMgb3B0aW9uIGlzIG5vdCBwcm92aWRlZCwgdGhlIGZ1bmN0aW9uIHdpbGwgdXNlIHRoZSBjdXJyZW50IGNsaWVudCdzIG9wdGlvbnMuXG4gKi9cbmZ1bmN0aW9uIGhhc1NwYW5zRW5hYmxlZChcbiAgbWF5YmVPcHRpb25zLFxuKSB7XG4gIGlmICh0eXBlb2YgX19TRU5UUllfVFJBQ0lOR19fID09PSAnYm9vbGVhbicgJiYgIV9fU0VOVFJZX1RSQUNJTkdfXykge1xuICAgIHJldHVybiBmYWxzZTtcbiAgfVxuXG4gIGNvbnN0IG9wdGlvbnMgPSBtYXliZU9wdGlvbnMgfHwgY3VycmVudFNjb3Blcy5nZXRDbGllbnQoKT8uZ2V0T3B0aW9ucygpO1xuICByZXR1cm4gKFxuICAgICEhb3B0aW9ucyAmJlxuICAgIC8vIE5vdGU6IFRoaXMgY2hlY2sgaXMgYCE9IG51bGxgLCBtZWFuaW5nIFwibnVsbGlzaFwiLiBgMGAgaXMgbm90IFwibnVsbGlzaFwiLCBgdW5kZWZpbmVkYCBhbmQgYG51bGxgIGFyZS4gKFRoaXMgY29tbWVudCB3YXMgYnJvdWdodCB0byB5b3UgYnkgMTUgbWludXRlcyBvZiBxdWVzdGlvbmluZyBsaWZlKVxuICAgIChvcHRpb25zLnRyYWNlc1NhbXBsZVJhdGUgIT0gbnVsbCB8fCAhIW9wdGlvbnMudHJhY2VzU2FtcGxlcilcbiAgKTtcbn1cblxuLyoqXG4gKiBAc2VlIEpTRG9jIG9mIGBoYXNTcGFuc0VuYWJsZWRgXG4gKiBAZGVwcmVjYXRlZCBVc2UgYGhhc1NwYW5zRW5hYmxlZGAgaW5zdGVhZCwgd2hpY2ggaXMgYSBtb3JlIGFjY3VyYXRlbHkgbmFtZWQgdmVyc2lvbiBvZiB0aGlzIGZ1bmN0aW9uLlxuICogVGhpcyBmdW5jdGlvbiB3aWxsIGJlIHJlbW92ZWQgaW4gdGhlIG5leHQgbWFqb3IgdmVyc2lvbiBvZiB0aGUgU0RLLlxuICovXG4vLyBUT0RPKHYxMCk6IFJlbW92ZSB0aGlzIGV4cG9ydFxuY29uc3QgaGFzVHJhY2luZ0VuYWJsZWQgPSBoYXNTcGFuc0VuYWJsZWQ7XG5cbmV4cG9ydHMuaGFzU3BhbnNFbmFibGVkID0gaGFzU3BhbnNFbmFibGVkO1xuZXhwb3J0cy5oYXNUcmFjaW5nRW5hYmxlZCA9IGhhc1RyYWNpbmdFbmFibGVkO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9aGFzU3BhbnNFbmFibGVkLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/hasSpansEnabled.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/ipAddress.js":
/*!*******************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/ipAddress.js ***!
  \*******************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n// By default, we want to infer the IP address, unless this is explicitly set to `null`\n// We do this after all other processing is done\n// If `ip_address` is explicitly set to `null` or a value, we leave it as is\n\n/**\n * @internal\n */\nfunction addAutoIpAddressToUser(objWithMaybeUser) {\n  if (objWithMaybeUser.user?.ip_address === undefined) {\n    objWithMaybeUser.user = {\n      ...objWithMaybeUser.user,\n      ip_address: '{{auto}}',\n    };\n  }\n}\n\n/**\n * @internal\n */\nfunction addAutoIpAddressToSession(session) {\n  if ('aggregates' in session) {\n    if (session.attrs?.['ip_address'] === undefined) {\n      session.attrs = {\n        ...session.attrs,\n        ip_address: '{{auto}}',\n      };\n    }\n  } else {\n    if (session.ipAddress === undefined) {\n      session.ipAddress = '{{auto}}';\n    }\n  }\n}\n\nexports.addAutoIpAddressToSession = addAutoIpAddressToSession;\nexports.addAutoIpAddressToUser = addAutoIpAddressToUser;\n//# sourceMappingURL=ipAddress.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9pcEFkZHJlc3MuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEU7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EscUJBQXFCLE1BQU07QUFDM0I7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSx1QkFBdUIsTUFBTTtBQUM3QjtBQUNBO0FBQ0EsSUFBSTtBQUNKO0FBQ0EsNkJBQTZCLE1BQU07QUFDbkM7QUFDQTtBQUNBOztBQUVBLGlDQUFpQztBQUNqQyw4QkFBOEI7QUFDOUIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9pcEFkZHJlc3MuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbi8vIEJ5IGRlZmF1bHQsIHdlIHdhbnQgdG8gaW5mZXIgdGhlIElQIGFkZHJlc3MsIHVubGVzcyB0aGlzIGlzIGV4cGxpY2l0bHkgc2V0IHRvIGBudWxsYFxuLy8gV2UgZG8gdGhpcyBhZnRlciBhbGwgb3RoZXIgcHJvY2Vzc2luZyBpcyBkb25lXG4vLyBJZiBgaXBfYWRkcmVzc2AgaXMgZXhwbGljaXRseSBzZXQgdG8gYG51bGxgIG9yIGEgdmFsdWUsIHdlIGxlYXZlIGl0IGFzIGlzXG5cbi8qKlxuICogQGludGVybmFsXG4gKi9cbmZ1bmN0aW9uIGFkZEF1dG9JcEFkZHJlc3NUb1VzZXIob2JqV2l0aE1heWJlVXNlcikge1xuICBpZiAob2JqV2l0aE1heWJlVXNlci51c2VyPy5pcF9hZGRyZXNzID09PSB1bmRlZmluZWQpIHtcbiAgICBvYmpXaXRoTWF5YmVVc2VyLnVzZXIgPSB7XG4gICAgICAuLi5vYmpXaXRoTWF5YmVVc2VyLnVzZXIsXG4gICAgICBpcF9hZGRyZXNzOiAne3thdXRvfX0nLFxuICAgIH07XG4gIH1cbn1cblxuLyoqXG4gKiBAaW50ZXJuYWxcbiAqL1xuZnVuY3Rpb24gYWRkQXV0b0lwQWRkcmVzc1RvU2Vzc2lvbihzZXNzaW9uKSB7XG4gIGlmICgnYWdncmVnYXRlcycgaW4gc2Vzc2lvbikge1xuICAgIGlmIChzZXNzaW9uLmF0dHJzPy5bJ2lwX2FkZHJlc3MnXSA9PT0gdW5kZWZpbmVkKSB7XG4gICAgICBzZXNzaW9uLmF0dHJzID0ge1xuICAgICAgICAuLi5zZXNzaW9uLmF0dHJzLFxuICAgICAgICBpcF9hZGRyZXNzOiAne3thdXRvfX0nLFxuICAgICAgfTtcbiAgICB9XG4gIH0gZWxzZSB7XG4gICAgaWYgKHNlc3Npb24uaXBBZGRyZXNzID09PSB1bmRlZmluZWQpIHtcbiAgICAgIHNlc3Npb24uaXBBZGRyZXNzID0gJ3t7YXV0b319JztcbiAgICB9XG4gIH1cbn1cblxuZXhwb3J0cy5hZGRBdXRvSXBBZGRyZXNzVG9TZXNzaW9uID0gYWRkQXV0b0lwQWRkcmVzc1RvU2Vzc2lvbjtcbmV4cG9ydHMuYWRkQXV0b0lwQWRkcmVzc1RvVXNlciA9IGFkZEF1dG9JcEFkZHJlc3NUb1VzZXI7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1pcEFkZHJlc3MuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/ipAddress.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js":
/*!************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js ***!
  \************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n// eslint-disable-next-line @typescript-eslint/unbound-method\nconst objectToString = Object.prototype.toString;\n\n/**\n * Checks whether given value's type is one of a few Error or Error-like\n * {@link isError}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isError(wat) {\n  switch (objectToString.call(wat)) {\n    case '[object Error]':\n    case '[object Exception]':\n    case '[object DOMException]':\n    case '[object WebAssembly.Exception]':\n      return true;\n    default:\n      return isInstanceOf(wat, Error);\n  }\n}\n/**\n * Checks whether given value is an instance of the given built-in class.\n *\n * @param wat The value to be checked\n * @param className\n * @returns A boolean representing the result.\n */\nfunction isBuiltin(wat, className) {\n  return objectToString.call(wat) === `[object ${className}]`;\n}\n\n/**\n * Checks whether given value's type is ErrorEvent\n * {@link isErrorEvent}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isErrorEvent(wat) {\n  return isBuiltin(wat, 'ErrorEvent');\n}\n\n/**\n * Checks whether given value's type is DOMError\n * {@link isDOMError}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isDOMError(wat) {\n  return isBuiltin(wat, 'DOMError');\n}\n\n/**\n * Checks whether given value's type is DOMException\n * {@link isDOMException}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isDOMException(wat) {\n  return isBuiltin(wat, 'DOMException');\n}\n\n/**\n * Checks whether given value's type is a string\n * {@link isString}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isString(wat) {\n  return isBuiltin(wat, 'String');\n}\n\n/**\n * Checks whether given string is parameterized\n * {@link isParameterizedString}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isParameterizedString(wat) {\n  return (\n    typeof wat === 'object' &&\n    wat !== null &&\n    '__sentry_template_string__' in wat &&\n    '__sentry_template_values__' in wat\n  );\n}\n\n/**\n * Checks whether given value is a primitive (undefined, null, number, boolean, string, bigint, symbol)\n * {@link isPrimitive}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isPrimitive(wat) {\n  return wat === null || isParameterizedString(wat) || (typeof wat !== 'object' && typeof wat !== 'function');\n}\n\n/**\n * Checks whether given value's type is an object literal, or a class instance.\n * {@link isPlainObject}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isPlainObject(wat) {\n  return isBuiltin(wat, 'Object');\n}\n\n/**\n * Checks whether given value's type is an Event instance\n * {@link isEvent}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isEvent(wat) {\n  return typeof Event !== 'undefined' && isInstanceOf(wat, Event);\n}\n\n/**\n * Checks whether given value's type is an Element instance\n * {@link isElement}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isElement(wat) {\n  return typeof Element !== 'undefined' && isInstanceOf(wat, Element);\n}\n\n/**\n * Checks whether given value's type is an regexp\n * {@link isRegExp}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isRegExp(wat) {\n  return isBuiltin(wat, 'RegExp');\n}\n\n/**\n * Checks whether given value has a then function.\n * @param wat A value to be checked.\n */\nfunction isThenable(wat) {\n  // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n  return Boolean(wat?.then && typeof wat.then === 'function');\n}\n\n/**\n * Checks whether given value's type is a SyntheticEvent\n * {@link isSyntheticEvent}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isSyntheticEvent(wat) {\n  return isPlainObject(wat) && 'nativeEvent' in wat && 'preventDefault' in wat && 'stopPropagation' in wat;\n}\n\n/**\n * Checks whether given value's type is an instance of provided constructor.\n * {@link isInstanceOf}.\n *\n * @param wat A value to be checked.\n * @param base A constructor to be used in a check.\n * @returns A boolean representing the result.\n */\nfunction isInstanceOf(wat, base) {\n  try {\n    return wat instanceof base;\n  } catch {\n    return false;\n  }\n}\n\n/**\n * Checks whether given value's type is a Vue ViewModel.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nfunction isVueViewModel(wat) {\n  // Not using Object.prototype.toString because in Vue 3 it would read the instance's Symbol(Symbol.toStringTag) property.\n  return !!(typeof wat === 'object' && wat !== null && ((wat ).__isVue || (wat )._isVue));\n}\n\n/**\n * Checks whether the given parameter is a Standard Web API Request instance.\n *\n * Returns false if Request is not available in the current runtime.\n */\nfunction isRequest(request) {\n  return typeof Request !== 'undefined' && isInstanceOf(request, Request);\n}\n\nexports.isDOMError = isDOMError;\nexports.isDOMException = isDOMException;\nexports.isElement = isElement;\nexports.isError = isError;\nexports.isErrorEvent = isErrorEvent;\nexports.isEvent = isEvent;\nexports.isInstanceOf = isInstanceOf;\nexports.isParameterizedString = isParameterizedString;\nexports.isPlainObject = isPlainObject;\nexports.isPrimitive = isPrimitive;\nexports.isRegExp = isRegExp;\nexports.isRequest = isRequest;\nexports.isString = isString;\nexports.isSyntheticEvent = isSyntheticEvent;\nexports.isThenable = isThenable;\nexports.isVueViewModel = isVueViewModel;\n//# sourceMappingURL=is.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9pcy5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RTtBQUNBOztBQUVBO0FBQ0E7QUFDQSxJQUFJLGNBQWM7QUFDbEI7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGlEQUFpRCxVQUFVO0FBQzNEOztBQUVBO0FBQ0E7QUFDQSxJQUFJLG1CQUFtQjtBQUN2QjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsSUFBSSxpQkFBaUI7QUFDckI7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLElBQUkscUJBQXFCO0FBQ3pCO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQSxJQUFJLGVBQWU7QUFDbkI7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLElBQUksNEJBQTRCO0FBQ2hDO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsSUFBSSxrQkFBa0I7QUFDdEI7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLElBQUksb0JBQW9CO0FBQ3hCO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQSxJQUFJLGNBQWM7QUFDbEI7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLElBQUksZ0JBQWdCO0FBQ3BCO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQSxJQUFJLGVBQWU7QUFDbkI7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsSUFBSSx1QkFBdUI7QUFDM0I7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLElBQUksbUJBQW1CO0FBQ3ZCO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxJQUFJO0FBQ0o7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsa0JBQWtCO0FBQ2xCLHNCQUFzQjtBQUN0QixpQkFBaUI7QUFDakIsZUFBZTtBQUNmLG9CQUFvQjtBQUNwQixlQUFlO0FBQ2Ysb0JBQW9CO0FBQ3BCLDZCQUE2QjtBQUM3QixxQkFBcUI7QUFDckIsbUJBQW1CO0FBQ25CLGdCQUFnQjtBQUNoQixpQkFBaUI7QUFDakIsZ0JBQWdCO0FBQ2hCLHdCQUF3QjtBQUN4QixrQkFBa0I7QUFDbEIsc0JBQXNCO0FBQ3RCIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvaXMuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbi8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvdW5ib3VuZC1tZXRob2RcbmNvbnN0IG9iamVjdFRvU3RyaW5nID0gT2JqZWN0LnByb3RvdHlwZS50b1N0cmluZztcblxuLyoqXG4gKiBDaGVja3Mgd2hldGhlciBnaXZlbiB2YWx1ZSdzIHR5cGUgaXMgb25lIG9mIGEgZmV3IEVycm9yIG9yIEVycm9yLWxpa2VcbiAqIHtAbGluayBpc0Vycm9yfS5cbiAqXG4gKiBAcGFyYW0gd2F0IEEgdmFsdWUgdG8gYmUgY2hlY2tlZC5cbiAqIEByZXR1cm5zIEEgYm9vbGVhbiByZXByZXNlbnRpbmcgdGhlIHJlc3VsdC5cbiAqL1xuZnVuY3Rpb24gaXNFcnJvcih3YXQpIHtcbiAgc3dpdGNoIChvYmplY3RUb1N0cmluZy5jYWxsKHdhdCkpIHtcbiAgICBjYXNlICdbb2JqZWN0IEVycm9yXSc6XG4gICAgY2FzZSAnW29iamVjdCBFeGNlcHRpb25dJzpcbiAgICBjYXNlICdbb2JqZWN0IERPTUV4Y2VwdGlvbl0nOlxuICAgIGNhc2UgJ1tvYmplY3QgV2ViQXNzZW1ibHkuRXhjZXB0aW9uXSc6XG4gICAgICByZXR1cm4gdHJ1ZTtcbiAgICBkZWZhdWx0OlxuICAgICAgcmV0dXJuIGlzSW5zdGFuY2VPZih3YXQsIEVycm9yKTtcbiAgfVxufVxuLyoqXG4gKiBDaGVja3Mgd2hldGhlciBnaXZlbiB2YWx1ZSBpcyBhbiBpbnN0YW5jZSBvZiB0aGUgZ2l2ZW4gYnVpbHQtaW4gY2xhc3MuXG4gKlxuICogQHBhcmFtIHdhdCBUaGUgdmFsdWUgdG8gYmUgY2hlY2tlZFxuICogQHBhcmFtIGNsYXNzTmFtZVxuICogQHJldHVybnMgQSBib29sZWFuIHJlcHJlc2VudGluZyB0aGUgcmVzdWx0LlxuICovXG5mdW5jdGlvbiBpc0J1aWx0aW4od2F0LCBjbGFzc05hbWUpIHtcbiAgcmV0dXJuIG9iamVjdFRvU3RyaW5nLmNhbGwod2F0KSA9PT0gYFtvYmplY3QgJHtjbGFzc05hbWV9XWA7XG59XG5cbi8qKlxuICogQ2hlY2tzIHdoZXRoZXIgZ2l2ZW4gdmFsdWUncyB0eXBlIGlzIEVycm9yRXZlbnRcbiAqIHtAbGluayBpc0Vycm9yRXZlbnR9LlxuICpcbiAqIEBwYXJhbSB3YXQgQSB2YWx1ZSB0byBiZSBjaGVja2VkLlxuICogQHJldHVybnMgQSBib29sZWFuIHJlcHJlc2VudGluZyB0aGUgcmVzdWx0LlxuICovXG5mdW5jdGlvbiBpc0Vycm9yRXZlbnQod2F0KSB7XG4gIHJldHVybiBpc0J1aWx0aW4od2F0LCAnRXJyb3JFdmVudCcpO1xufVxuXG4vKipcbiAqIENoZWNrcyB3aGV0aGVyIGdpdmVuIHZhbHVlJ3MgdHlwZSBpcyBET01FcnJvclxuICoge0BsaW5rIGlzRE9NRXJyb3J9LlxuICpcbiAqIEBwYXJhbSB3YXQgQSB2YWx1ZSB0byBiZSBjaGVja2VkLlxuICogQHJldHVybnMgQSBib29sZWFuIHJlcHJlc2VudGluZyB0aGUgcmVzdWx0LlxuICovXG5mdW5jdGlvbiBpc0RPTUVycm9yKHdhdCkge1xuICByZXR1cm4gaXNCdWlsdGluKHdhdCwgJ0RPTUVycm9yJyk7XG59XG5cbi8qKlxuICogQ2hlY2tzIHdoZXRoZXIgZ2l2ZW4gdmFsdWUncyB0eXBlIGlzIERPTUV4Y2VwdGlvblxuICoge0BsaW5rIGlzRE9NRXhjZXB0aW9ufS5cbiAqXG4gKiBAcGFyYW0gd2F0IEEgdmFsdWUgdG8gYmUgY2hlY2tlZC5cbiAqIEByZXR1cm5zIEEgYm9vbGVhbiByZXByZXNlbnRpbmcgdGhlIHJlc3VsdC5cbiAqL1xuZnVuY3Rpb24gaXNET01FeGNlcHRpb24od2F0KSB7XG4gIHJldHVybiBpc0J1aWx0aW4od2F0LCAnRE9NRXhjZXB0aW9uJyk7XG59XG5cbi8qKlxuICogQ2hlY2tzIHdoZXRoZXIgZ2l2ZW4gdmFsdWUncyB0eXBlIGlzIGEgc3RyaW5nXG4gKiB7QGxpbmsgaXNTdHJpbmd9LlxuICpcbiAqIEBwYXJhbSB3YXQgQSB2YWx1ZSB0byBiZSBjaGVja2VkLlxuICogQHJldHVybnMgQSBib29sZWFuIHJlcHJlc2VudGluZyB0aGUgcmVzdWx0LlxuICovXG5mdW5jdGlvbiBpc1N0cmluZyh3YXQpIHtcbiAgcmV0dXJuIGlzQnVpbHRpbih3YXQsICdTdHJpbmcnKTtcbn1cblxuLyoqXG4gKiBDaGVja3Mgd2hldGhlciBnaXZlbiBzdHJpbmcgaXMgcGFyYW1ldGVyaXplZFxuICoge0BsaW5rIGlzUGFyYW1ldGVyaXplZFN0cmluZ30uXG4gKlxuICogQHBhcmFtIHdhdCBBIHZhbHVlIHRvIGJlIGNoZWNrZWQuXG4gKiBAcmV0dXJucyBBIGJvb2xlYW4gcmVwcmVzZW50aW5nIHRoZSByZXN1bHQuXG4gKi9cbmZ1bmN0aW9uIGlzUGFyYW1ldGVyaXplZFN0cmluZyh3YXQpIHtcbiAgcmV0dXJuIChcbiAgICB0eXBlb2Ygd2F0ID09PSAnb2JqZWN0JyAmJlxuICAgIHdhdCAhPT0gbnVsbCAmJlxuICAgICdfX3NlbnRyeV90ZW1wbGF0ZV9zdHJpbmdfXycgaW4gd2F0ICYmXG4gICAgJ19fc2VudHJ5X3RlbXBsYXRlX3ZhbHVlc19fJyBpbiB3YXRcbiAgKTtcbn1cblxuLyoqXG4gKiBDaGVja3Mgd2hldGhlciBnaXZlbiB2YWx1ZSBpcyBhIHByaW1pdGl2ZSAodW5kZWZpbmVkLCBudWxsLCBudW1iZXIsIGJvb2xlYW4sIHN0cmluZywgYmlnaW50LCBzeW1ib2wpXG4gKiB7QGxpbmsgaXNQcmltaXRpdmV9LlxuICpcbiAqIEBwYXJhbSB3YXQgQSB2YWx1ZSB0byBiZSBjaGVja2VkLlxuICogQHJldHVybnMgQSBib29sZWFuIHJlcHJlc2VudGluZyB0aGUgcmVzdWx0LlxuICovXG5mdW5jdGlvbiBpc1ByaW1pdGl2ZSh3YXQpIHtcbiAgcmV0dXJuIHdhdCA9PT0gbnVsbCB8fCBpc1BhcmFtZXRlcml6ZWRTdHJpbmcod2F0KSB8fCAodHlwZW9mIHdhdCAhPT0gJ29iamVjdCcgJiYgdHlwZW9mIHdhdCAhPT0gJ2Z1bmN0aW9uJyk7XG59XG5cbi8qKlxuICogQ2hlY2tzIHdoZXRoZXIgZ2l2ZW4gdmFsdWUncyB0eXBlIGlzIGFuIG9iamVjdCBsaXRlcmFsLCBvciBhIGNsYXNzIGluc3RhbmNlLlxuICoge0BsaW5rIGlzUGxhaW5PYmplY3R9LlxuICpcbiAqIEBwYXJhbSB3YXQgQSB2YWx1ZSB0byBiZSBjaGVja2VkLlxuICogQHJldHVybnMgQSBib29sZWFuIHJlcHJlc2VudGluZyB0aGUgcmVzdWx0LlxuICovXG5mdW5jdGlvbiBpc1BsYWluT2JqZWN0KHdhdCkge1xuICByZXR1cm4gaXNCdWlsdGluKHdhdCwgJ09iamVjdCcpO1xufVxuXG4vKipcbiAqIENoZWNrcyB3aGV0aGVyIGdpdmVuIHZhbHVlJ3MgdHlwZSBpcyBhbiBFdmVudCBpbnN0YW5jZVxuICoge0BsaW5rIGlzRXZlbnR9LlxuICpcbiAqIEBwYXJhbSB3YXQgQSB2YWx1ZSB0byBiZSBjaGVja2VkLlxuICogQHJldHVybnMgQSBib29sZWFuIHJlcHJlc2VudGluZyB0aGUgcmVzdWx0LlxuICovXG5mdW5jdGlvbiBpc0V2ZW50KHdhdCkge1xuICByZXR1cm4gdHlwZW9mIEV2ZW50ICE9PSAndW5kZWZpbmVkJyAmJiBpc0luc3RhbmNlT2Yod2F0LCBFdmVudCk7XG59XG5cbi8qKlxuICogQ2hlY2tzIHdoZXRoZXIgZ2l2ZW4gdmFsdWUncyB0eXBlIGlzIGFuIEVsZW1lbnQgaW5zdGFuY2VcbiAqIHtAbGluayBpc0VsZW1lbnR9LlxuICpcbiAqIEBwYXJhbSB3YXQgQSB2YWx1ZSB0byBiZSBjaGVja2VkLlxuICogQHJldHVybnMgQSBib29sZWFuIHJlcHJlc2VudGluZyB0aGUgcmVzdWx0LlxuICovXG5mdW5jdGlvbiBpc0VsZW1lbnQod2F0KSB7XG4gIHJldHVybiB0eXBlb2YgRWxlbWVudCAhPT0gJ3VuZGVmaW5lZCcgJiYgaXNJbnN0YW5jZU9mKHdhdCwgRWxlbWVudCk7XG59XG5cbi8qKlxuICogQ2hlY2tzIHdoZXRoZXIgZ2l2ZW4gdmFsdWUncyB0eXBlIGlzIGFuIHJlZ2V4cFxuICoge0BsaW5rIGlzUmVnRXhwfS5cbiAqXG4gKiBAcGFyYW0gd2F0IEEgdmFsdWUgdG8gYmUgY2hlY2tlZC5cbiAqIEByZXR1cm5zIEEgYm9vbGVhbiByZXByZXNlbnRpbmcgdGhlIHJlc3VsdC5cbiAqL1xuZnVuY3Rpb24gaXNSZWdFeHAod2F0KSB7XG4gIHJldHVybiBpc0J1aWx0aW4od2F0LCAnUmVnRXhwJyk7XG59XG5cbi8qKlxuICogQ2hlY2tzIHdoZXRoZXIgZ2l2ZW4gdmFsdWUgaGFzIGEgdGhlbiBmdW5jdGlvbi5cbiAqIEBwYXJhbSB3YXQgQSB2YWx1ZSB0byBiZSBjaGVja2VkLlxuICovXG5mdW5jdGlvbiBpc1RoZW5hYmxlKHdhdCkge1xuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25vLXVuc2FmZS1tZW1iZXItYWNjZXNzXG4gIHJldHVybiBCb29sZWFuKHdhdD8udGhlbiAmJiB0eXBlb2Ygd2F0LnRoZW4gPT09ICdmdW5jdGlvbicpO1xufVxuXG4vKipcbiAqIENoZWNrcyB3aGV0aGVyIGdpdmVuIHZhbHVlJ3MgdHlwZSBpcyBhIFN5bnRoZXRpY0V2ZW50XG4gKiB7QGxpbmsgaXNTeW50aGV0aWNFdmVudH0uXG4gKlxuICogQHBhcmFtIHdhdCBBIHZhbHVlIHRvIGJlIGNoZWNrZWQuXG4gKiBAcmV0dXJucyBBIGJvb2xlYW4gcmVwcmVzZW50aW5nIHRoZSByZXN1bHQuXG4gKi9cbmZ1bmN0aW9uIGlzU3ludGhldGljRXZlbnQod2F0KSB7XG4gIHJldHVybiBpc1BsYWluT2JqZWN0KHdhdCkgJiYgJ25hdGl2ZUV2ZW50JyBpbiB3YXQgJiYgJ3ByZXZlbnREZWZhdWx0JyBpbiB3YXQgJiYgJ3N0b3BQcm9wYWdhdGlvbicgaW4gd2F0O1xufVxuXG4vKipcbiAqIENoZWNrcyB3aGV0aGVyIGdpdmVuIHZhbHVlJ3MgdHlwZSBpcyBhbiBpbnN0YW5jZSBvZiBwcm92aWRlZCBjb25zdHJ1Y3Rvci5cbiAqIHtAbGluayBpc0luc3RhbmNlT2Z9LlxuICpcbiAqIEBwYXJhbSB3YXQgQSB2YWx1ZSB0byBiZSBjaGVja2VkLlxuICogQHBhcmFtIGJhc2UgQSBjb25zdHJ1Y3RvciB0byBiZSB1c2VkIGluIGEgY2hlY2suXG4gKiBAcmV0dXJucyBBIGJvb2xlYW4gcmVwcmVzZW50aW5nIHRoZSByZXN1bHQuXG4gKi9cbmZ1bmN0aW9uIGlzSW5zdGFuY2VPZih3YXQsIGJhc2UpIHtcbiAgdHJ5IHtcbiAgICByZXR1cm4gd2F0IGluc3RhbmNlb2YgYmFzZTtcbiAgfSBjYXRjaCB7XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG59XG5cbi8qKlxuICogQ2hlY2tzIHdoZXRoZXIgZ2l2ZW4gdmFsdWUncyB0eXBlIGlzIGEgVnVlIFZpZXdNb2RlbC5cbiAqXG4gKiBAcGFyYW0gd2F0IEEgdmFsdWUgdG8gYmUgY2hlY2tlZC5cbiAqIEByZXR1cm5zIEEgYm9vbGVhbiByZXByZXNlbnRpbmcgdGhlIHJlc3VsdC5cbiAqL1xuZnVuY3Rpb24gaXNWdWVWaWV3TW9kZWwod2F0KSB7XG4gIC8vIE5vdCB1c2luZyBPYmplY3QucHJvdG90eXBlLnRvU3RyaW5nIGJlY2F1c2UgaW4gVnVlIDMgaXQgd291bGQgcmVhZCB0aGUgaW5zdGFuY2UncyBTeW1ib2woU3ltYm9sLnRvU3RyaW5nVGFnKSBwcm9wZXJ0eS5cbiAgcmV0dXJuICEhKHR5cGVvZiB3YXQgPT09ICdvYmplY3QnICYmIHdhdCAhPT0gbnVsbCAmJiAoKHdhdCApLl9faXNWdWUgfHwgKHdhdCApLl9pc1Z1ZSkpO1xufVxuXG4vKipcbiAqIENoZWNrcyB3aGV0aGVyIHRoZSBnaXZlbiBwYXJhbWV0ZXIgaXMgYSBTdGFuZGFyZCBXZWIgQVBJIFJlcXVlc3QgaW5zdGFuY2UuXG4gKlxuICogUmV0dXJucyBmYWxzZSBpZiBSZXF1ZXN0IGlzIG5vdCBhdmFpbGFibGUgaW4gdGhlIGN1cnJlbnQgcnVudGltZS5cbiAqL1xuZnVuY3Rpb24gaXNSZXF1ZXN0KHJlcXVlc3QpIHtcbiAgcmV0dXJuIHR5cGVvZiBSZXF1ZXN0ICE9PSAndW5kZWZpbmVkJyAmJiBpc0luc3RhbmNlT2YocmVxdWVzdCwgUmVxdWVzdCk7XG59XG5cbmV4cG9ydHMuaXNET01FcnJvciA9IGlzRE9NRXJyb3I7XG5leHBvcnRzLmlzRE9NRXhjZXB0aW9uID0gaXNET01FeGNlcHRpb247XG5leHBvcnRzLmlzRWxlbWVudCA9IGlzRWxlbWVudDtcbmV4cG9ydHMuaXNFcnJvciA9IGlzRXJyb3I7XG5leHBvcnRzLmlzRXJyb3JFdmVudCA9IGlzRXJyb3JFdmVudDtcbmV4cG9ydHMuaXNFdmVudCA9IGlzRXZlbnQ7XG5leHBvcnRzLmlzSW5zdGFuY2VPZiA9IGlzSW5zdGFuY2VPZjtcbmV4cG9ydHMuaXNQYXJhbWV0ZXJpemVkU3RyaW5nID0gaXNQYXJhbWV0ZXJpemVkU3RyaW5nO1xuZXhwb3J0cy5pc1BsYWluT2JqZWN0ID0gaXNQbGFpbk9iamVjdDtcbmV4cG9ydHMuaXNQcmltaXRpdmUgPSBpc1ByaW1pdGl2ZTtcbmV4cG9ydHMuaXNSZWdFeHAgPSBpc1JlZ0V4cDtcbmV4cG9ydHMuaXNSZXF1ZXN0ID0gaXNSZXF1ZXN0O1xuZXhwb3J0cy5pc1N0cmluZyA9IGlzU3RyaW5nO1xuZXhwb3J0cy5pc1N5bnRoZXRpY0V2ZW50ID0gaXNTeW50aGV0aWNFdmVudDtcbmV4cG9ydHMuaXNUaGVuYWJsZSA9IGlzVGhlbmFibGU7XG5leHBvcnRzLmlzVnVlVmlld01vZGVsID0gaXNWdWVWaWV3TW9kZWw7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1pcy5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/isBrowser.js":
/*!*******************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/isBrowser.js ***!
  \*******************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst node = __webpack_require__(/*! ./node.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/node.js\");\nconst worldwide = __webpack_require__(/*! ./worldwide.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/worldwide.js\");\n\n/**\n * Returns true if we are in the browser.\n */\nfunction isBrowser() {\n  // eslint-disable-next-line no-restricted-globals\n  return typeof window !== 'undefined' && (!node.isNodeEnv() || isElectronNodeRenderer());\n}\n\n// Electron renderers with nodeIntegration enabled are detected as Node.js so we specifically test for them\nfunction isElectronNodeRenderer() {\n  const process = (worldwide.GLOBAL_OBJ ).process;\n  return process?.type === 'renderer';\n}\n\nexports.isBrowser = isBrowser;\n//# sourceMappingURL=isBrowser.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9pc0Jyb3dzZXIuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsYUFBYSxtQkFBTyxDQUFDLG1IQUFXO0FBQ2hDLGtCQUFrQixtQkFBTyxDQUFDLDZIQUFnQjs7QUFFMUM7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSxpQkFBaUI7QUFDakIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9pc0Jyb3dzZXIuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IG5vZGUgPSByZXF1aXJlKCcuL25vZGUuanMnKTtcbmNvbnN0IHdvcmxkd2lkZSA9IHJlcXVpcmUoJy4vd29ybGR3aWRlLmpzJyk7XG5cbi8qKlxuICogUmV0dXJucyB0cnVlIGlmIHdlIGFyZSBpbiB0aGUgYnJvd3Nlci5cbiAqL1xuZnVuY3Rpb24gaXNCcm93c2VyKCkge1xuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgbm8tcmVzdHJpY3RlZC1nbG9iYWxzXG4gIHJldHVybiB0eXBlb2Ygd2luZG93ICE9PSAndW5kZWZpbmVkJyAmJiAoIW5vZGUuaXNOb2RlRW52KCkgfHwgaXNFbGVjdHJvbk5vZGVSZW5kZXJlcigpKTtcbn1cblxuLy8gRWxlY3Ryb24gcmVuZGVyZXJzIHdpdGggbm9kZUludGVncmF0aW9uIGVuYWJsZWQgYXJlIGRldGVjdGVkIGFzIE5vZGUuanMgc28gd2Ugc3BlY2lmaWNhbGx5IHRlc3QgZm9yIHRoZW1cbmZ1bmN0aW9uIGlzRWxlY3Ryb25Ob2RlUmVuZGVyZXIoKSB7XG4gIGNvbnN0IHByb2Nlc3MgPSAod29ybGR3aWRlLkdMT0JBTF9PQkogKS5wcm9jZXNzO1xuICByZXR1cm4gcHJvY2Vzcz8udHlwZSA9PT0gJ3JlbmRlcmVyJztcbn1cblxuZXhwb3J0cy5pc0Jyb3dzZXIgPSBpc0Jyb3dzZXI7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1pc0Jyb3dzZXIuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/isBrowser.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/isSentryRequestUrl.js":
/*!****************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/isSentryRequestUrl.js ***!
  \****************************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n/**\n * Checks whether given url points to Sentry server\n *\n * @param url url to verify\n */\nfunction isSentryRequestUrl(url, client) {\n  const dsn = client?.getDsn();\n  const tunnel = client?.getOptions().tunnel;\n  return checkDsn(url, dsn) || checkTunnel(url, tunnel);\n}\n\nfunction checkTunnel(url, tunnel) {\n  if (!tunnel) {\n    return false;\n  }\n\n  return removeTrailingSlash(url) === removeTrailingSlash(tunnel);\n}\n\nfunction checkDsn(url, dsn) {\n  return dsn ? url.includes(dsn.host) : false;\n}\n\nfunction removeTrailingSlash(str) {\n  return str[str.length - 1] === '/' ? str.slice(0, -1) : str;\n}\n\nexports.isSentryRequestUrl = isSentryRequestUrl;\n//# sourceMappingURL=isSentryRequestUrl.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9pc1NlbnRyeVJlcXVlc3RVcmwuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEU7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBLDBCQUEwQjtBQUMxQiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3V0aWxzL2lzU2VudHJ5UmVxdWVzdFVybC5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuLyoqXG4gKiBDaGVja3Mgd2hldGhlciBnaXZlbiB1cmwgcG9pbnRzIHRvIFNlbnRyeSBzZXJ2ZXJcbiAqXG4gKiBAcGFyYW0gdXJsIHVybCB0byB2ZXJpZnlcbiAqL1xuZnVuY3Rpb24gaXNTZW50cnlSZXF1ZXN0VXJsKHVybCwgY2xpZW50KSB7XG4gIGNvbnN0IGRzbiA9IGNsaWVudD8uZ2V0RHNuKCk7XG4gIGNvbnN0IHR1bm5lbCA9IGNsaWVudD8uZ2V0T3B0aW9ucygpLnR1bm5lbDtcbiAgcmV0dXJuIGNoZWNrRHNuKHVybCwgZHNuKSB8fCBjaGVja1R1bm5lbCh1cmwsIHR1bm5lbCk7XG59XG5cbmZ1bmN0aW9uIGNoZWNrVHVubmVsKHVybCwgdHVubmVsKSB7XG4gIGlmICghdHVubmVsKSB7XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG5cbiAgcmV0dXJuIHJlbW92ZVRyYWlsaW5nU2xhc2godXJsKSA9PT0gcmVtb3ZlVHJhaWxpbmdTbGFzaCh0dW5uZWwpO1xufVxuXG5mdW5jdGlvbiBjaGVja0Rzbih1cmwsIGRzbikge1xuICByZXR1cm4gZHNuID8gdXJsLmluY2x1ZGVzKGRzbi5ob3N0KSA6IGZhbHNlO1xufVxuXG5mdW5jdGlvbiByZW1vdmVUcmFpbGluZ1NsYXNoKHN0cikge1xuICByZXR1cm4gc3RyW3N0ci5sZW5ndGggLSAxXSA9PT0gJy8nID8gc3RyLnNsaWNlKDAsIC0xKSA6IHN0cjtcbn1cblxuZXhwb3J0cy5pc1NlbnRyeVJlcXVlc3RVcmwgPSBpc1NlbnRyeVJlcXVlc3RVcmw7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1pc1NlbnRyeVJlcXVlc3RVcmwuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/isSentryRequestUrl.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/lru.js":
/*!*************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/lru.js ***!
  \*************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n/** A simple Least Recently Used map */\nclass LRUMap {\n\n   constructor(  _maxSize) {this._maxSize = _maxSize;\n    this._cache = new Map();\n  }\n\n  /** Get the current size of the cache */\n   get size() {\n    return this._cache.size;\n  }\n\n  /** Get an entry or undefined if it was not in the cache. Re-inserts to update the recently used order */\n   get(key) {\n    const value = this._cache.get(key);\n    if (value === undefined) {\n      return undefined;\n    }\n    // Remove and re-insert to update the order\n    this._cache.delete(key);\n    this._cache.set(key, value);\n    return value;\n  }\n\n  /** Insert an entry and evict an older entry if we've reached maxSize */\n   set(key, value) {\n    if (this._cache.size >= this._maxSize) {\n      // keys() returns an iterator in insertion order so keys().next() gives us the oldest key\n      this._cache.delete(this._cache.keys().next().value);\n    }\n    this._cache.set(key, value);\n  }\n\n  /** Remove an entry and return the entry if it was in the cache */\n   remove(key) {\n    const value = this._cache.get(key);\n    if (value) {\n      this._cache.delete(key);\n    }\n    return value;\n  }\n\n  /** Clear all entries */\n   clear() {\n    this._cache.clear();\n  }\n\n  /** Get all the keys */\n   keys() {\n    return Array.from(this._cache.keys());\n  }\n\n  /** Get all the values */\n   values() {\n    const values = [];\n    this._cache.forEach(value => values.push(value));\n    return values;\n  }\n}\n\nexports.LRUMap = LRUMap;\n//# sourceMappingURL=lru.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9scnUuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEU7QUFDQTs7QUFFQSw0QkFBNEI7QUFDNUI7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSxjQUFjO0FBQ2QiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9scnUuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbi8qKiBBIHNpbXBsZSBMZWFzdCBSZWNlbnRseSBVc2VkIG1hcCAqL1xuY2xhc3MgTFJVTWFwIHtcblxuICAgY29uc3RydWN0b3IoICBfbWF4U2l6ZSkge3RoaXMuX21heFNpemUgPSBfbWF4U2l6ZTtcbiAgICB0aGlzLl9jYWNoZSA9IG5ldyBNYXAoKTtcbiAgfVxuXG4gIC8qKiBHZXQgdGhlIGN1cnJlbnQgc2l6ZSBvZiB0aGUgY2FjaGUgKi9cbiAgIGdldCBzaXplKCkge1xuICAgIHJldHVybiB0aGlzLl9jYWNoZS5zaXplO1xuICB9XG5cbiAgLyoqIEdldCBhbiBlbnRyeSBvciB1bmRlZmluZWQgaWYgaXQgd2FzIG5vdCBpbiB0aGUgY2FjaGUuIFJlLWluc2VydHMgdG8gdXBkYXRlIHRoZSByZWNlbnRseSB1c2VkIG9yZGVyICovXG4gICBnZXQoa2V5KSB7XG4gICAgY29uc3QgdmFsdWUgPSB0aGlzLl9jYWNoZS5nZXQoa2V5KTtcbiAgICBpZiAodmFsdWUgPT09IHVuZGVmaW5lZCkge1xuICAgICAgcmV0dXJuIHVuZGVmaW5lZDtcbiAgICB9XG4gICAgLy8gUmVtb3ZlIGFuZCByZS1pbnNlcnQgdG8gdXBkYXRlIHRoZSBvcmRlclxuICAgIHRoaXMuX2NhY2hlLmRlbGV0ZShrZXkpO1xuICAgIHRoaXMuX2NhY2hlLnNldChrZXksIHZhbHVlKTtcbiAgICByZXR1cm4gdmFsdWU7XG4gIH1cblxuICAvKiogSW5zZXJ0IGFuIGVudHJ5IGFuZCBldmljdCBhbiBvbGRlciBlbnRyeSBpZiB3ZSd2ZSByZWFjaGVkIG1heFNpemUgKi9cbiAgIHNldChrZXksIHZhbHVlKSB7XG4gICAgaWYgKHRoaXMuX2NhY2hlLnNpemUgPj0gdGhpcy5fbWF4U2l6ZSkge1xuICAgICAgLy8ga2V5cygpIHJldHVybnMgYW4gaXRlcmF0b3IgaW4gaW5zZXJ0aW9uIG9yZGVyIHNvIGtleXMoKS5uZXh0KCkgZ2l2ZXMgdXMgdGhlIG9sZGVzdCBrZXlcbiAgICAgIHRoaXMuX2NhY2hlLmRlbGV0ZSh0aGlzLl9jYWNoZS5rZXlzKCkubmV4dCgpLnZhbHVlKTtcbiAgICB9XG4gICAgdGhpcy5fY2FjaGUuc2V0KGtleSwgdmFsdWUpO1xuICB9XG5cbiAgLyoqIFJlbW92ZSBhbiBlbnRyeSBhbmQgcmV0dXJuIHRoZSBlbnRyeSBpZiBpdCB3YXMgaW4gdGhlIGNhY2hlICovXG4gICByZW1vdmUoa2V5KSB7XG4gICAgY29uc3QgdmFsdWUgPSB0aGlzLl9jYWNoZS5nZXQoa2V5KTtcbiAgICBpZiAodmFsdWUpIHtcbiAgICAgIHRoaXMuX2NhY2hlLmRlbGV0ZShrZXkpO1xuICAgIH1cbiAgICByZXR1cm4gdmFsdWU7XG4gIH1cblxuICAvKiogQ2xlYXIgYWxsIGVudHJpZXMgKi9cbiAgIGNsZWFyKCkge1xuICAgIHRoaXMuX2NhY2hlLmNsZWFyKCk7XG4gIH1cblxuICAvKiogR2V0IGFsbCB0aGUga2V5cyAqL1xuICAga2V5cygpIHtcbiAgICByZXR1cm4gQXJyYXkuZnJvbSh0aGlzLl9jYWNoZS5rZXlzKCkpO1xuICB9XG5cbiAgLyoqIEdldCBhbGwgdGhlIHZhbHVlcyAqL1xuICAgdmFsdWVzKCkge1xuICAgIGNvbnN0IHZhbHVlcyA9IFtdO1xuICAgIHRoaXMuX2NhY2hlLmZvckVhY2godmFsdWUgPT4gdmFsdWVzLnB1c2godmFsdWUpKTtcbiAgICByZXR1cm4gdmFsdWVzO1xuICB9XG59XG5cbmV4cG9ydHMuTFJVTWFwID0gTFJVTWFwO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9bHJ1LmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/lru.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/merge.js":
/*!***************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/merge.js ***!
  \***************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n/**\n * Shallow merge two objects.\n * Does not mutate the passed in objects.\n * Undefined/empty values in the merge object will overwrite existing values.\n *\n * By default, this merges 2 levels deep.\n */\nfunction merge(initialObj, mergeObj, levels = 2) {\n  // If the merge value is not an object, or we have no merge levels left,\n  // we just set the value to the merge value\n  if (!mergeObj || typeof mergeObj !== 'object' || levels <= 0) {\n    return mergeObj;\n  }\n\n  // If the merge object is an empty object, and the initial object is not undefined, we return the initial object\n  if (initialObj && Object.keys(mergeObj).length === 0) {\n    return initialObj;\n  }\n\n  // Clone object\n  const output = { ...initialObj };\n\n  // Merge values into output, resursively\n  for (const key in mergeObj) {\n    if (Object.prototype.hasOwnProperty.call(mergeObj, key)) {\n      output[key] = merge(output[key], mergeObj[key], levels - 1);\n    }\n  }\n\n  return output;\n}\n\nexports.merge = merge;\n//# sourceMappingURL=merge.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9tZXJnZS5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBLG1CQUFtQjs7QUFFbkI7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUEsYUFBYTtBQUNiIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvbWVyZ2UuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbi8qKlxuICogU2hhbGxvdyBtZXJnZSB0d28gb2JqZWN0cy5cbiAqIERvZXMgbm90IG11dGF0ZSB0aGUgcGFzc2VkIGluIG9iamVjdHMuXG4gKiBVbmRlZmluZWQvZW1wdHkgdmFsdWVzIGluIHRoZSBtZXJnZSBvYmplY3Qgd2lsbCBvdmVyd3JpdGUgZXhpc3RpbmcgdmFsdWVzLlxuICpcbiAqIEJ5IGRlZmF1bHQsIHRoaXMgbWVyZ2VzIDIgbGV2ZWxzIGRlZXAuXG4gKi9cbmZ1bmN0aW9uIG1lcmdlKGluaXRpYWxPYmosIG1lcmdlT2JqLCBsZXZlbHMgPSAyKSB7XG4gIC8vIElmIHRoZSBtZXJnZSB2YWx1ZSBpcyBub3QgYW4gb2JqZWN0LCBvciB3ZSBoYXZlIG5vIG1lcmdlIGxldmVscyBsZWZ0LFxuICAvLyB3ZSBqdXN0IHNldCB0aGUgdmFsdWUgdG8gdGhlIG1lcmdlIHZhbHVlXG4gIGlmICghbWVyZ2VPYmogfHwgdHlwZW9mIG1lcmdlT2JqICE9PSAnb2JqZWN0JyB8fCBsZXZlbHMgPD0gMCkge1xuICAgIHJldHVybiBtZXJnZU9iajtcbiAgfVxuXG4gIC8vIElmIHRoZSBtZXJnZSBvYmplY3QgaXMgYW4gZW1wdHkgb2JqZWN0LCBhbmQgdGhlIGluaXRpYWwgb2JqZWN0IGlzIG5vdCB1bmRlZmluZWQsIHdlIHJldHVybiB0aGUgaW5pdGlhbCBvYmplY3RcbiAgaWYgKGluaXRpYWxPYmogJiYgT2JqZWN0LmtleXMobWVyZ2VPYmopLmxlbmd0aCA9PT0gMCkge1xuICAgIHJldHVybiBpbml0aWFsT2JqO1xuICB9XG5cbiAgLy8gQ2xvbmUgb2JqZWN0XG4gIGNvbnN0IG91dHB1dCA9IHsgLi4uaW5pdGlhbE9iaiB9O1xuXG4gIC8vIE1lcmdlIHZhbHVlcyBpbnRvIG91dHB1dCwgcmVzdXJzaXZlbHlcbiAgZm9yIChjb25zdCBrZXkgaW4gbWVyZ2VPYmopIHtcbiAgICBpZiAoT2JqZWN0LnByb3RvdHlwZS5oYXNPd25Qcm9wZXJ0eS5jYWxsKG1lcmdlT2JqLCBrZXkpKSB7XG4gICAgICBvdXRwdXRba2V5XSA9IG1lcmdlKG91dHB1dFtrZXldLCBtZXJnZU9ialtrZXldLCBsZXZlbHMgLSAxKTtcbiAgICB9XG4gIH1cblxuICByZXR1cm4gb3V0cHV0O1xufVxuXG5leHBvcnRzLm1lcmdlID0gbWVyZ2U7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1tZXJnZS5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/merge.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/meta.js":
/*!**************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/meta.js ***!
  \**************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst traceData = __webpack_require__(/*! ./traceData.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/traceData.js\");\n\n/**\n * Returns a string of meta tags that represent the current trace data.\n *\n * You can use this to propagate a trace from your server-side rendered Html to the browser.\n * This function returns up to two meta tags, `sentry-trace` and `baggage`, depending on the\n * current trace data state.\n *\n * @example\n * Usage example:\n *\n * ```js\n * function renderHtml() {\n *   return `\n *     <head>\n *       ${getTraceMetaTags()}\n *     </head>\n *   `;\n * }\n * ```\n *\n */\nfunction getTraceMetaTags(traceData$1) {\n  return Object.entries(traceData$1 || traceData.getTraceData())\n    .map(([key, value]) => `<meta name=\"${key}\" content=\"${value}\"/>`)\n    .join('\\n');\n}\n\nexports.getTraceMetaTags = getTraceMetaTags;\n//# sourceMappingURL=meta.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9tZXRhLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLGtCQUFrQixtQkFBTyxDQUFDLDZIQUFnQjs7QUFFMUM7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFdBQVc7QUFDWDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsMENBQTBDLElBQUksYUFBYSxNQUFNO0FBQ2pFO0FBQ0E7O0FBRUEsd0JBQXdCO0FBQ3hCIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvbWV0YS5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgdHJhY2VEYXRhID0gcmVxdWlyZSgnLi90cmFjZURhdGEuanMnKTtcblxuLyoqXG4gKiBSZXR1cm5zIGEgc3RyaW5nIG9mIG1ldGEgdGFncyB0aGF0IHJlcHJlc2VudCB0aGUgY3VycmVudCB0cmFjZSBkYXRhLlxuICpcbiAqIFlvdSBjYW4gdXNlIHRoaXMgdG8gcHJvcGFnYXRlIGEgdHJhY2UgZnJvbSB5b3VyIHNlcnZlci1zaWRlIHJlbmRlcmVkIEh0bWwgdG8gdGhlIGJyb3dzZXIuXG4gKiBUaGlzIGZ1bmN0aW9uIHJldHVybnMgdXAgdG8gdHdvIG1ldGEgdGFncywgYHNlbnRyeS10cmFjZWAgYW5kIGBiYWdnYWdlYCwgZGVwZW5kaW5nIG9uIHRoZVxuICogY3VycmVudCB0cmFjZSBkYXRhIHN0YXRlLlxuICpcbiAqIEBleGFtcGxlXG4gKiBVc2FnZSBleGFtcGxlOlxuICpcbiAqIGBgYGpzXG4gKiBmdW5jdGlvbiByZW5kZXJIdG1sKCkge1xuICogICByZXR1cm4gYFxuICogICAgIDxoZWFkPlxuICogICAgICAgJHtnZXRUcmFjZU1ldGFUYWdzKCl9XG4gKiAgICAgPC9oZWFkPlxuICogICBgO1xuICogfVxuICogYGBgXG4gKlxuICovXG5mdW5jdGlvbiBnZXRUcmFjZU1ldGFUYWdzKHRyYWNlRGF0YSQxKSB7XG4gIHJldHVybiBPYmplY3QuZW50cmllcyh0cmFjZURhdGEkMSB8fCB0cmFjZURhdGEuZ2V0VHJhY2VEYXRhKCkpXG4gICAgLm1hcCgoW2tleSwgdmFsdWVdKSA9PiBgPG1ldGEgbmFtZT1cIiR7a2V5fVwiIGNvbnRlbnQ9XCIke3ZhbHVlfVwiLz5gKVxuICAgIC5qb2luKCdcXG4nKTtcbn1cblxuZXhwb3J0cy5nZXRUcmFjZU1ldGFUYWdzID0gZ2V0VHJhY2VNZXRhVGFncztcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPW1ldGEuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/meta.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/misc.js":
/*!**************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/misc.js ***!
  \**************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst object = __webpack_require__(/*! ./object.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/object.js\");\nconst string = __webpack_require__(/*! ./string.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/string.js\");\nconst worldwide = __webpack_require__(/*! ./worldwide.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/worldwide.js\");\n\nfunction getCrypto() {\n  const gbl = worldwide.GLOBAL_OBJ ;\n  return gbl.crypto || gbl.msCrypto;\n}\n\n/**\n * UUID4 generator\n * @param crypto Object that provides the crypto API.\n * @returns string Generated UUID4.\n */\nfunction uuid4(crypto = getCrypto()) {\n  let getRandomByte = () => Math.random() * 16;\n  try {\n    if (crypto?.randomUUID) {\n      return crypto.randomUUID().replace(/-/g, '');\n    }\n    if (crypto?.getRandomValues) {\n      getRandomByte = () => {\n        // crypto.getRandomValues might return undefined instead of the typed array\n        // in old Chromium versions (e.g. 23.0.1235.0 (151422))\n        // However, `typedArray` is still filled in-place.\n        // @see https://developer.mozilla.org/en-US/docs/Web/API/Crypto/getRandomValues#typedarray\n        const typedArray = new Uint8Array(1);\n        crypto.getRandomValues(typedArray);\n        // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n        return typedArray[0];\n      };\n    }\n  } catch {\n    // some runtimes can crash invoking crypto\n    // https://github.com/getsentry/sentry-javascript/issues/8935\n  }\n\n  // http://stackoverflow.com/questions/105034/how-to-create-a-guid-uuid-in-javascript/2117523#2117523\n  // Concatenating the following numbers as strings results in '10000000100040008000100000000000'\n  return (([1e7] ) + 1e3 + 4e3 + 8e3 + 1e11).replace(/[018]/g, c =>\n    // eslint-disable-next-line no-bitwise\n    ((c ) ^ ((getRandomByte() & 15) >> ((c ) / 4))).toString(16),\n  );\n}\n\nfunction getFirstException(event) {\n  return event.exception?.values?.[0];\n}\n\n/**\n * Extracts either message or type+value from an event that can be used for user-facing logs\n * @returns event's description\n */\nfunction getEventDescription(event) {\n  const { message, event_id: eventId } = event;\n  if (message) {\n    return message;\n  }\n\n  const firstException = getFirstException(event);\n  if (firstException) {\n    if (firstException.type && firstException.value) {\n      return `${firstException.type}: ${firstException.value}`;\n    }\n    return firstException.type || firstException.value || eventId || '<unknown>';\n  }\n  return eventId || '<unknown>';\n}\n\n/**\n * Adds exception values, type and value to an synthetic Exception.\n * @param event The event to modify.\n * @param value Value of the exception.\n * @param type Type of the exception.\n * @hidden\n */\nfunction addExceptionTypeValue(event, value, type) {\n  const exception = (event.exception = event.exception || {});\n  const values = (exception.values = exception.values || []);\n  const firstException = (values[0] = values[0] || {});\n  if (!firstException.value) {\n    firstException.value = value || '';\n  }\n  if (!firstException.type) {\n    firstException.type = type || 'Error';\n  }\n}\n\n/**\n * Adds exception mechanism data to a given event. Uses defaults if the second parameter is not passed.\n *\n * @param event The event to modify.\n * @param newMechanism Mechanism data to add to the event.\n * @hidden\n */\nfunction addExceptionMechanism(event, newMechanism) {\n  const firstException = getFirstException(event);\n  if (!firstException) {\n    return;\n  }\n\n  const defaultMechanism = { type: 'generic', handled: true };\n  const currentMechanism = firstException.mechanism;\n  firstException.mechanism = { ...defaultMechanism, ...currentMechanism, ...newMechanism };\n\n  if (newMechanism && 'data' in newMechanism) {\n    const mergedData = { ...currentMechanism?.data, ...newMechanism.data };\n    firstException.mechanism.data = mergedData;\n  }\n}\n\n// https://semver.org/#is-there-a-suggested-regular-expression-regex-to-check-a-semver-string\nconst SEMVER_REGEXP =\n  /^(0|[1-9]\\d*)\\.(0|[1-9]\\d*)\\.(0|[1-9]\\d*)(?:-((?:0|[1-9]\\d*|\\d*[a-zA-Z-][0-9a-zA-Z-]*)(?:\\.(?:0|[1-9]\\d*|\\d*[a-zA-Z-][0-9a-zA-Z-]*))*))?(?:\\+([0-9a-zA-Z-]+(?:\\.[0-9a-zA-Z-]+)*))?$/;\n\n/**\n * Represents Semantic Versioning object\n */\n\nfunction _parseInt(input) {\n  return parseInt(input || '', 10);\n}\n\n/**\n * Parses input into a SemVer interface\n * @param input string representation of a semver version\n */\nfunction parseSemver(input) {\n  const match = input.match(SEMVER_REGEXP) || [];\n  const major = _parseInt(match[1]);\n  const minor = _parseInt(match[2]);\n  const patch = _parseInt(match[3]);\n  return {\n    buildmetadata: match[5],\n    major: isNaN(major) ? undefined : major,\n    minor: isNaN(minor) ? undefined : minor,\n    patch: isNaN(patch) ? undefined : patch,\n    prerelease: match[4],\n  };\n}\n\n/**\n * This function adds context (pre/post/line) lines to the provided frame\n *\n * @param lines string[] containing all lines\n * @param frame StackFrame that will be mutated\n * @param linesOfContext number of context lines we want to add pre/post\n */\nfunction addContextToFrame(lines, frame, linesOfContext = 5) {\n  // When there is no line number in the frame, attaching context is nonsensical and will even break grouping\n  if (frame.lineno === undefined) {\n    return;\n  }\n\n  const maxLines = lines.length;\n  const sourceLine = Math.max(Math.min(maxLines - 1, frame.lineno - 1), 0);\n\n  frame.pre_context = lines\n    .slice(Math.max(0, sourceLine - linesOfContext), sourceLine)\n    .map((line) => string.snipLine(line, 0));\n\n  // We guard here to ensure this is not larger than the existing number of lines\n  const lineIndex = Math.min(maxLines - 1, sourceLine);\n\n  // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n  frame.context_line = string.snipLine(lines[lineIndex], frame.colno || 0);\n\n  frame.post_context = lines\n    .slice(Math.min(sourceLine + 1, maxLines), sourceLine + 1 + linesOfContext)\n    .map((line) => string.snipLine(line, 0));\n}\n\n/**\n * Checks whether or not we've already captured the given exception (note: not an identical exception - the very object\n * in question), and marks it captured if not.\n *\n * This is useful because it's possible for an error to get captured by more than one mechanism. After we intercept and\n * record an error, we rethrow it (assuming we've intercepted it before it's reached the top-level global handlers), so\n * that we don't interfere with whatever effects the error might have had were the SDK not there. At that point, because\n * the error has been rethrown, it's possible for it to bubble up to some other code we've instrumented. If it's not\n * caught after that, it will bubble all the way up to the global handlers (which of course we also instrument). This\n * function helps us ensure that even if we encounter the same error more than once, we only record it the first time we\n * see it.\n *\n * Note: It will ignore primitives (always return `false` and not mark them as seen), as properties can't be set on\n * them. {@link: Object.objectify} can be used on exceptions to convert any that are primitives into their equivalent\n * object wrapper forms so that this check will always work. However, because we need to flag the exact object which\n * will get rethrown, and because that rethrowing happens outside of the event processing pipeline, the objectification\n * must be done before the exception captured.\n *\n * @param A thrown exception to check or flag as having been seen\n * @returns `true` if the exception has already been captured, `false` if not (with the side effect of marking it seen)\n */\nfunction checkOrSetAlreadyCaught(exception) {\n  if (isAlreadyCaptured(exception)) {\n    return true;\n  }\n\n  try {\n    // set it this way rather than by assignment so that it's not ennumerable and therefore isn't recorded by the\n    // `ExtraErrorData` integration\n    object.addNonEnumerableProperty(exception , '__sentry_captured__', true);\n  } catch {\n    // `exception` is a primitive, so we can't mark it seen\n  }\n\n  return false;\n}\n\nfunction isAlreadyCaptured(exception) {\n  try {\n    return (exception ).__sentry_captured__;\n  } catch {} // eslint-disable-line no-empty\n}\n\nexports.addContextToFrame = addContextToFrame;\nexports.addExceptionMechanism = addExceptionMechanism;\nexports.addExceptionTypeValue = addExceptionTypeValue;\nexports.checkOrSetAlreadyCaught = checkOrSetAlreadyCaught;\nexports.getEventDescription = getEventDescription;\nexports.parseSemver = parseSemver;\nexports.uuid4 = uuid4;\n//# sourceMappingURL=misc.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9taXNjLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLGVBQWUsbUJBQU8sQ0FBQyx1SEFBYTtBQUNwQyxlQUFlLG1CQUFPLENBQUMsdUhBQWE7QUFDcEMsa0JBQWtCLG1CQUFPLENBQUMsNkhBQWdCOztBQUUxQztBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsSUFBSTtBQUNKO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFVBQVUsNkJBQTZCO0FBQ3ZDO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQSxnQkFBZ0Isb0JBQW9CLElBQUkscUJBQXFCO0FBQzdEO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLDREQUE0RDtBQUM1RDtBQUNBLHFEQUFxRDtBQUNyRDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsNkJBQTZCO0FBQzdCO0FBQ0EsK0JBQStCOztBQUUvQjtBQUNBLHlCQUF5QjtBQUN6QjtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsVUFBVSx5QkFBeUI7QUFDbkM7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLElBQUk7QUFDSjtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0EsSUFBSSxTQUFTO0FBQ2I7O0FBRUEseUJBQXlCO0FBQ3pCLDZCQUE2QjtBQUM3Qiw2QkFBNkI7QUFDN0IsK0JBQStCO0FBQy9CLDJCQUEyQjtBQUMzQixtQkFBbUI7QUFDbkIsYUFBYTtBQUNiIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvbWlzYy5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3Qgb2JqZWN0ID0gcmVxdWlyZSgnLi9vYmplY3QuanMnKTtcbmNvbnN0IHN0cmluZyA9IHJlcXVpcmUoJy4vc3RyaW5nLmpzJyk7XG5jb25zdCB3b3JsZHdpZGUgPSByZXF1aXJlKCcuL3dvcmxkd2lkZS5qcycpO1xuXG5mdW5jdGlvbiBnZXRDcnlwdG8oKSB7XG4gIGNvbnN0IGdibCA9IHdvcmxkd2lkZS5HTE9CQUxfT0JKIDtcbiAgcmV0dXJuIGdibC5jcnlwdG8gfHwgZ2JsLm1zQ3J5cHRvO1xufVxuXG4vKipcbiAqIFVVSUQ0IGdlbmVyYXRvclxuICogQHBhcmFtIGNyeXB0byBPYmplY3QgdGhhdCBwcm92aWRlcyB0aGUgY3J5cHRvIEFQSS5cbiAqIEByZXR1cm5zIHN0cmluZyBHZW5lcmF0ZWQgVVVJRDQuXG4gKi9cbmZ1bmN0aW9uIHV1aWQ0KGNyeXB0byA9IGdldENyeXB0bygpKSB7XG4gIGxldCBnZXRSYW5kb21CeXRlID0gKCkgPT4gTWF0aC5yYW5kb20oKSAqIDE2O1xuICB0cnkge1xuICAgIGlmIChjcnlwdG8/LnJhbmRvbVVVSUQpIHtcbiAgICAgIHJldHVybiBjcnlwdG8ucmFuZG9tVVVJRCgpLnJlcGxhY2UoLy0vZywgJycpO1xuICAgIH1cbiAgICBpZiAoY3J5cHRvPy5nZXRSYW5kb21WYWx1ZXMpIHtcbiAgICAgIGdldFJhbmRvbUJ5dGUgPSAoKSA9PiB7XG4gICAgICAgIC8vIGNyeXB0by5nZXRSYW5kb21WYWx1ZXMgbWlnaHQgcmV0dXJuIHVuZGVmaW5lZCBpbnN0ZWFkIG9mIHRoZSB0eXBlZCBhcnJheVxuICAgICAgICAvLyBpbiBvbGQgQ2hyb21pdW0gdmVyc2lvbnMgKGUuZy4gMjMuMC4xMjM1LjAgKDE1MTQyMikpXG4gICAgICAgIC8vIEhvd2V2ZXIsIGB0eXBlZEFycmF5YCBpcyBzdGlsbCBmaWxsZWQgaW4tcGxhY2UuXG4gICAgICAgIC8vIEBzZWUgaHR0cHM6Ly9kZXZlbG9wZXIubW96aWxsYS5vcmcvZW4tVVMvZG9jcy9XZWIvQVBJL0NyeXB0by9nZXRSYW5kb21WYWx1ZXMjdHlwZWRhcnJheVxuICAgICAgICBjb25zdCB0eXBlZEFycmF5ID0gbmV3IFVpbnQ4QXJyYXkoMSk7XG4gICAgICAgIGNyeXB0by5nZXRSYW5kb21WYWx1ZXModHlwZWRBcnJheSk7XG4gICAgICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tbm9uLW51bGwtYXNzZXJ0aW9uXG4gICAgICAgIHJldHVybiB0eXBlZEFycmF5WzBdO1xuICAgICAgfTtcbiAgICB9XG4gIH0gY2F0Y2gge1xuICAgIC8vIHNvbWUgcnVudGltZXMgY2FuIGNyYXNoIGludm9raW5nIGNyeXB0b1xuICAgIC8vIGh0dHBzOi8vZ2l0aHViLmNvbS9nZXRzZW50cnkvc2VudHJ5LWphdmFzY3JpcHQvaXNzdWVzLzg5MzVcbiAgfVxuXG4gIC8vIGh0dHA6Ly9zdGFja292ZXJmbG93LmNvbS9xdWVzdGlvbnMvMTA1MDM0L2hvdy10by1jcmVhdGUtYS1ndWlkLXV1aWQtaW4tamF2YXNjcmlwdC8yMTE3NTIzIzIxMTc1MjNcbiAgLy8gQ29uY2F0ZW5hdGluZyB0aGUgZm9sbG93aW5nIG51bWJlcnMgYXMgc3RyaW5ncyByZXN1bHRzIGluICcxMDAwMDAwMDEwMDA0MDAwODAwMDEwMDAwMDAwMDAwMCdcbiAgcmV0dXJuICgoWzFlN10gKSArIDFlMyArIDRlMyArIDhlMyArIDFlMTEpLnJlcGxhY2UoL1swMThdL2csIGMgPT5cbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgbm8tYml0d2lzZVxuICAgICgoYyApIF4gKChnZXRSYW5kb21CeXRlKCkgJiAxNSkgPj4gKChjICkgLyA0KSkpLnRvU3RyaW5nKDE2KSxcbiAgKTtcbn1cblxuZnVuY3Rpb24gZ2V0Rmlyc3RFeGNlcHRpb24oZXZlbnQpIHtcbiAgcmV0dXJuIGV2ZW50LmV4Y2VwdGlvbj8udmFsdWVzPy5bMF07XG59XG5cbi8qKlxuICogRXh0cmFjdHMgZWl0aGVyIG1lc3NhZ2Ugb3IgdHlwZSt2YWx1ZSBmcm9tIGFuIGV2ZW50IHRoYXQgY2FuIGJlIHVzZWQgZm9yIHVzZXItZmFjaW5nIGxvZ3NcbiAqIEByZXR1cm5zIGV2ZW50J3MgZGVzY3JpcHRpb25cbiAqL1xuZnVuY3Rpb24gZ2V0RXZlbnREZXNjcmlwdGlvbihldmVudCkge1xuICBjb25zdCB7IG1lc3NhZ2UsIGV2ZW50X2lkOiBldmVudElkIH0gPSBldmVudDtcbiAgaWYgKG1lc3NhZ2UpIHtcbiAgICByZXR1cm4gbWVzc2FnZTtcbiAgfVxuXG4gIGNvbnN0IGZpcnN0RXhjZXB0aW9uID0gZ2V0Rmlyc3RFeGNlcHRpb24oZXZlbnQpO1xuICBpZiAoZmlyc3RFeGNlcHRpb24pIHtcbiAgICBpZiAoZmlyc3RFeGNlcHRpb24udHlwZSAmJiBmaXJzdEV4Y2VwdGlvbi52YWx1ZSkge1xuICAgICAgcmV0dXJuIGAke2ZpcnN0RXhjZXB0aW9uLnR5cGV9OiAke2ZpcnN0RXhjZXB0aW9uLnZhbHVlfWA7XG4gICAgfVxuICAgIHJldHVybiBmaXJzdEV4Y2VwdGlvbi50eXBlIHx8IGZpcnN0RXhjZXB0aW9uLnZhbHVlIHx8IGV2ZW50SWQgfHwgJzx1bmtub3duPic7XG4gIH1cbiAgcmV0dXJuIGV2ZW50SWQgfHwgJzx1bmtub3duPic7XG59XG5cbi8qKlxuICogQWRkcyBleGNlcHRpb24gdmFsdWVzLCB0eXBlIGFuZCB2YWx1ZSB0byBhbiBzeW50aGV0aWMgRXhjZXB0aW9uLlxuICogQHBhcmFtIGV2ZW50IFRoZSBldmVudCB0byBtb2RpZnkuXG4gKiBAcGFyYW0gdmFsdWUgVmFsdWUgb2YgdGhlIGV4Y2VwdGlvbi5cbiAqIEBwYXJhbSB0eXBlIFR5cGUgb2YgdGhlIGV4Y2VwdGlvbi5cbiAqIEBoaWRkZW5cbiAqL1xuZnVuY3Rpb24gYWRkRXhjZXB0aW9uVHlwZVZhbHVlKGV2ZW50LCB2YWx1ZSwgdHlwZSkge1xuICBjb25zdCBleGNlcHRpb24gPSAoZXZlbnQuZXhjZXB0aW9uID0gZXZlbnQuZXhjZXB0aW9uIHx8IHt9KTtcbiAgY29uc3QgdmFsdWVzID0gKGV4Y2VwdGlvbi52YWx1ZXMgPSBleGNlcHRpb24udmFsdWVzIHx8IFtdKTtcbiAgY29uc3QgZmlyc3RFeGNlcHRpb24gPSAodmFsdWVzWzBdID0gdmFsdWVzWzBdIHx8IHt9KTtcbiAgaWYgKCFmaXJzdEV4Y2VwdGlvbi52YWx1ZSkge1xuICAgIGZpcnN0RXhjZXB0aW9uLnZhbHVlID0gdmFsdWUgfHwgJyc7XG4gIH1cbiAgaWYgKCFmaXJzdEV4Y2VwdGlvbi50eXBlKSB7XG4gICAgZmlyc3RFeGNlcHRpb24udHlwZSA9IHR5cGUgfHwgJ0Vycm9yJztcbiAgfVxufVxuXG4vKipcbiAqIEFkZHMgZXhjZXB0aW9uIG1lY2hhbmlzbSBkYXRhIHRvIGEgZ2l2ZW4gZXZlbnQuIFVzZXMgZGVmYXVsdHMgaWYgdGhlIHNlY29uZCBwYXJhbWV0ZXIgaXMgbm90IHBhc3NlZC5cbiAqXG4gKiBAcGFyYW0gZXZlbnQgVGhlIGV2ZW50IHRvIG1vZGlmeS5cbiAqIEBwYXJhbSBuZXdNZWNoYW5pc20gTWVjaGFuaXNtIGRhdGEgdG8gYWRkIHRvIHRoZSBldmVudC5cbiAqIEBoaWRkZW5cbiAqL1xuZnVuY3Rpb24gYWRkRXhjZXB0aW9uTWVjaGFuaXNtKGV2ZW50LCBuZXdNZWNoYW5pc20pIHtcbiAgY29uc3QgZmlyc3RFeGNlcHRpb24gPSBnZXRGaXJzdEV4Y2VwdGlvbihldmVudCk7XG4gIGlmICghZmlyc3RFeGNlcHRpb24pIHtcbiAgICByZXR1cm47XG4gIH1cblxuICBjb25zdCBkZWZhdWx0TWVjaGFuaXNtID0geyB0eXBlOiAnZ2VuZXJpYycsIGhhbmRsZWQ6IHRydWUgfTtcbiAgY29uc3QgY3VycmVudE1lY2hhbmlzbSA9IGZpcnN0RXhjZXB0aW9uLm1lY2hhbmlzbTtcbiAgZmlyc3RFeGNlcHRpb24ubWVjaGFuaXNtID0geyAuLi5kZWZhdWx0TWVjaGFuaXNtLCAuLi5jdXJyZW50TWVjaGFuaXNtLCAuLi5uZXdNZWNoYW5pc20gfTtcblxuICBpZiAobmV3TWVjaGFuaXNtICYmICdkYXRhJyBpbiBuZXdNZWNoYW5pc20pIHtcbiAgICBjb25zdCBtZXJnZWREYXRhID0geyAuLi5jdXJyZW50TWVjaGFuaXNtPy5kYXRhLCAuLi5uZXdNZWNoYW5pc20uZGF0YSB9O1xuICAgIGZpcnN0RXhjZXB0aW9uLm1lY2hhbmlzbS5kYXRhID0gbWVyZ2VkRGF0YTtcbiAgfVxufVxuXG4vLyBodHRwczovL3NlbXZlci5vcmcvI2lzLXRoZXJlLWEtc3VnZ2VzdGVkLXJlZ3VsYXItZXhwcmVzc2lvbi1yZWdleC10by1jaGVjay1hLXNlbXZlci1zdHJpbmdcbmNvbnN0IFNFTVZFUl9SRUdFWFAgPVxuICAvXigwfFsxLTldXFxkKilcXC4oMHxbMS05XVxcZCopXFwuKDB8WzEtOV1cXGQqKSg/Oi0oKD86MHxbMS05XVxcZCp8XFxkKlthLXpBLVotXVswLTlhLXpBLVotXSopKD86XFwuKD86MHxbMS05XVxcZCp8XFxkKlthLXpBLVotXVswLTlhLXpBLVotXSopKSopKT8oPzpcXCsoWzAtOWEtekEtWi1dKyg/OlxcLlswLTlhLXpBLVotXSspKikpPyQvO1xuXG4vKipcbiAqIFJlcHJlc2VudHMgU2VtYW50aWMgVmVyc2lvbmluZyBvYmplY3RcbiAqL1xuXG5mdW5jdGlvbiBfcGFyc2VJbnQoaW5wdXQpIHtcbiAgcmV0dXJuIHBhcnNlSW50KGlucHV0IHx8ICcnLCAxMCk7XG59XG5cbi8qKlxuICogUGFyc2VzIGlucHV0IGludG8gYSBTZW1WZXIgaW50ZXJmYWNlXG4gKiBAcGFyYW0gaW5wdXQgc3RyaW5nIHJlcHJlc2VudGF0aW9uIG9mIGEgc2VtdmVyIHZlcnNpb25cbiAqL1xuZnVuY3Rpb24gcGFyc2VTZW12ZXIoaW5wdXQpIHtcbiAgY29uc3QgbWF0Y2ggPSBpbnB1dC5tYXRjaChTRU1WRVJfUkVHRVhQKSB8fCBbXTtcbiAgY29uc3QgbWFqb3IgPSBfcGFyc2VJbnQobWF0Y2hbMV0pO1xuICBjb25zdCBtaW5vciA9IF9wYXJzZUludChtYXRjaFsyXSk7XG4gIGNvbnN0IHBhdGNoID0gX3BhcnNlSW50KG1hdGNoWzNdKTtcbiAgcmV0dXJuIHtcbiAgICBidWlsZG1ldGFkYXRhOiBtYXRjaFs1XSxcbiAgICBtYWpvcjogaXNOYU4obWFqb3IpID8gdW5kZWZpbmVkIDogbWFqb3IsXG4gICAgbWlub3I6IGlzTmFOKG1pbm9yKSA/IHVuZGVmaW5lZCA6IG1pbm9yLFxuICAgIHBhdGNoOiBpc05hTihwYXRjaCkgPyB1bmRlZmluZWQgOiBwYXRjaCxcbiAgICBwcmVyZWxlYXNlOiBtYXRjaFs0XSxcbiAgfTtcbn1cblxuLyoqXG4gKiBUaGlzIGZ1bmN0aW9uIGFkZHMgY29udGV4dCAocHJlL3Bvc3QvbGluZSkgbGluZXMgdG8gdGhlIHByb3ZpZGVkIGZyYW1lXG4gKlxuICogQHBhcmFtIGxpbmVzIHN0cmluZ1tdIGNvbnRhaW5pbmcgYWxsIGxpbmVzXG4gKiBAcGFyYW0gZnJhbWUgU3RhY2tGcmFtZSB0aGF0IHdpbGwgYmUgbXV0YXRlZFxuICogQHBhcmFtIGxpbmVzT2ZDb250ZXh0IG51bWJlciBvZiBjb250ZXh0IGxpbmVzIHdlIHdhbnQgdG8gYWRkIHByZS9wb3N0XG4gKi9cbmZ1bmN0aW9uIGFkZENvbnRleHRUb0ZyYW1lKGxpbmVzLCBmcmFtZSwgbGluZXNPZkNvbnRleHQgPSA1KSB7XG4gIC8vIFdoZW4gdGhlcmUgaXMgbm8gbGluZSBudW1iZXIgaW4gdGhlIGZyYW1lLCBhdHRhY2hpbmcgY29udGV4dCBpcyBub25zZW5zaWNhbCBhbmQgd2lsbCBldmVuIGJyZWFrIGdyb3VwaW5nXG4gIGlmIChmcmFtZS5saW5lbm8gPT09IHVuZGVmaW5lZCkge1xuICAgIHJldHVybjtcbiAgfVxuXG4gIGNvbnN0IG1heExpbmVzID0gbGluZXMubGVuZ3RoO1xuICBjb25zdCBzb3VyY2VMaW5lID0gTWF0aC5tYXgoTWF0aC5taW4obWF4TGluZXMgLSAxLCBmcmFtZS5saW5lbm8gLSAxKSwgMCk7XG5cbiAgZnJhbWUucHJlX2NvbnRleHQgPSBsaW5lc1xuICAgIC5zbGljZShNYXRoLm1heCgwLCBzb3VyY2VMaW5lIC0gbGluZXNPZkNvbnRleHQpLCBzb3VyY2VMaW5lKVxuICAgIC5tYXAoKGxpbmUpID0+IHN0cmluZy5zbmlwTGluZShsaW5lLCAwKSk7XG5cbiAgLy8gV2UgZ3VhcmQgaGVyZSB0byBlbnN1cmUgdGhpcyBpcyBub3QgbGFyZ2VyIHRoYW4gdGhlIGV4aXN0aW5nIG51bWJlciBvZiBsaW5lc1xuICBjb25zdCBsaW5lSW5kZXggPSBNYXRoLm1pbihtYXhMaW5lcyAtIDEsIHNvdXJjZUxpbmUpO1xuXG4gIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tbm9uLW51bGwtYXNzZXJ0aW9uXG4gIGZyYW1lLmNvbnRleHRfbGluZSA9IHN0cmluZy5zbmlwTGluZShsaW5lc1tsaW5lSW5kZXhdLCBmcmFtZS5jb2xubyB8fCAwKTtcblxuICBmcmFtZS5wb3N0X2NvbnRleHQgPSBsaW5lc1xuICAgIC5zbGljZShNYXRoLm1pbihzb3VyY2VMaW5lICsgMSwgbWF4TGluZXMpLCBzb3VyY2VMaW5lICsgMSArIGxpbmVzT2ZDb250ZXh0KVxuICAgIC5tYXAoKGxpbmUpID0+IHN0cmluZy5zbmlwTGluZShsaW5lLCAwKSk7XG59XG5cbi8qKlxuICogQ2hlY2tzIHdoZXRoZXIgb3Igbm90IHdlJ3ZlIGFscmVhZHkgY2FwdHVyZWQgdGhlIGdpdmVuIGV4Y2VwdGlvbiAobm90ZTogbm90IGFuIGlkZW50aWNhbCBleGNlcHRpb24gLSB0aGUgdmVyeSBvYmplY3RcbiAqIGluIHF1ZXN0aW9uKSwgYW5kIG1hcmtzIGl0IGNhcHR1cmVkIGlmIG5vdC5cbiAqXG4gKiBUaGlzIGlzIHVzZWZ1bCBiZWNhdXNlIGl0J3MgcG9zc2libGUgZm9yIGFuIGVycm9yIHRvIGdldCBjYXB0dXJlZCBieSBtb3JlIHRoYW4gb25lIG1lY2hhbmlzbS4gQWZ0ZXIgd2UgaW50ZXJjZXB0IGFuZFxuICogcmVjb3JkIGFuIGVycm9yLCB3ZSByZXRocm93IGl0IChhc3N1bWluZyB3ZSd2ZSBpbnRlcmNlcHRlZCBpdCBiZWZvcmUgaXQncyByZWFjaGVkIHRoZSB0b3AtbGV2ZWwgZ2xvYmFsIGhhbmRsZXJzKSwgc29cbiAqIHRoYXQgd2UgZG9uJ3QgaW50ZXJmZXJlIHdpdGggd2hhdGV2ZXIgZWZmZWN0cyB0aGUgZXJyb3IgbWlnaHQgaGF2ZSBoYWQgd2VyZSB0aGUgU0RLIG5vdCB0aGVyZS4gQXQgdGhhdCBwb2ludCwgYmVjYXVzZVxuICogdGhlIGVycm9yIGhhcyBiZWVuIHJldGhyb3duLCBpdCdzIHBvc3NpYmxlIGZvciBpdCB0byBidWJibGUgdXAgdG8gc29tZSBvdGhlciBjb2RlIHdlJ3ZlIGluc3RydW1lbnRlZC4gSWYgaXQncyBub3RcbiAqIGNhdWdodCBhZnRlciB0aGF0LCBpdCB3aWxsIGJ1YmJsZSBhbGwgdGhlIHdheSB1cCB0byB0aGUgZ2xvYmFsIGhhbmRsZXJzICh3aGljaCBvZiBjb3Vyc2Ugd2UgYWxzbyBpbnN0cnVtZW50KS4gVGhpc1xuICogZnVuY3Rpb24gaGVscHMgdXMgZW5zdXJlIHRoYXQgZXZlbiBpZiB3ZSBlbmNvdW50ZXIgdGhlIHNhbWUgZXJyb3IgbW9yZSB0aGFuIG9uY2UsIHdlIG9ubHkgcmVjb3JkIGl0IHRoZSBmaXJzdCB0aW1lIHdlXG4gKiBzZWUgaXQuXG4gKlxuICogTm90ZTogSXQgd2lsbCBpZ25vcmUgcHJpbWl0aXZlcyAoYWx3YXlzIHJldHVybiBgZmFsc2VgIGFuZCBub3QgbWFyayB0aGVtIGFzIHNlZW4pLCBhcyBwcm9wZXJ0aWVzIGNhbid0IGJlIHNldCBvblxuICogdGhlbS4ge0BsaW5rOiBPYmplY3Qub2JqZWN0aWZ5fSBjYW4gYmUgdXNlZCBvbiBleGNlcHRpb25zIHRvIGNvbnZlcnQgYW55IHRoYXQgYXJlIHByaW1pdGl2ZXMgaW50byB0aGVpciBlcXVpdmFsZW50XG4gKiBvYmplY3Qgd3JhcHBlciBmb3JtcyBzbyB0aGF0IHRoaXMgY2hlY2sgd2lsbCBhbHdheXMgd29yay4gSG93ZXZlciwgYmVjYXVzZSB3ZSBuZWVkIHRvIGZsYWcgdGhlIGV4YWN0IG9iamVjdCB3aGljaFxuICogd2lsbCBnZXQgcmV0aHJvd24sIGFuZCBiZWNhdXNlIHRoYXQgcmV0aHJvd2luZyBoYXBwZW5zIG91dHNpZGUgb2YgdGhlIGV2ZW50IHByb2Nlc3NpbmcgcGlwZWxpbmUsIHRoZSBvYmplY3RpZmljYXRpb25cbiAqIG11c3QgYmUgZG9uZSBiZWZvcmUgdGhlIGV4Y2VwdGlvbiBjYXB0dXJlZC5cbiAqXG4gKiBAcGFyYW0gQSB0aHJvd24gZXhjZXB0aW9uIHRvIGNoZWNrIG9yIGZsYWcgYXMgaGF2aW5nIGJlZW4gc2VlblxuICogQHJldHVybnMgYHRydWVgIGlmIHRoZSBleGNlcHRpb24gaGFzIGFscmVhZHkgYmVlbiBjYXB0dXJlZCwgYGZhbHNlYCBpZiBub3QgKHdpdGggdGhlIHNpZGUgZWZmZWN0IG9mIG1hcmtpbmcgaXQgc2VlbilcbiAqL1xuZnVuY3Rpb24gY2hlY2tPclNldEFscmVhZHlDYXVnaHQoZXhjZXB0aW9uKSB7XG4gIGlmIChpc0FscmVhZHlDYXB0dXJlZChleGNlcHRpb24pKSB7XG4gICAgcmV0dXJuIHRydWU7XG4gIH1cblxuICB0cnkge1xuICAgIC8vIHNldCBpdCB0aGlzIHdheSByYXRoZXIgdGhhbiBieSBhc3NpZ25tZW50IHNvIHRoYXQgaXQncyBub3QgZW5udW1lcmFibGUgYW5kIHRoZXJlZm9yZSBpc24ndCByZWNvcmRlZCBieSB0aGVcbiAgICAvLyBgRXh0cmFFcnJvckRhdGFgIGludGVncmF0aW9uXG4gICAgb2JqZWN0LmFkZE5vbkVudW1lcmFibGVQcm9wZXJ0eShleGNlcHRpb24gLCAnX19zZW50cnlfY2FwdHVyZWRfXycsIHRydWUpO1xuICB9IGNhdGNoIHtcbiAgICAvLyBgZXhjZXB0aW9uYCBpcyBhIHByaW1pdGl2ZSwgc28gd2UgY2FuJ3QgbWFyayBpdCBzZWVuXG4gIH1cblxuICByZXR1cm4gZmFsc2U7XG59XG5cbmZ1bmN0aW9uIGlzQWxyZWFkeUNhcHR1cmVkKGV4Y2VwdGlvbikge1xuICB0cnkge1xuICAgIHJldHVybiAoZXhjZXB0aW9uICkuX19zZW50cnlfY2FwdHVyZWRfXztcbiAgfSBjYXRjaCB7fSAvLyBlc2xpbnQtZGlzYWJsZS1saW5lIG5vLWVtcHR5XG59XG5cbmV4cG9ydHMuYWRkQ29udGV4dFRvRnJhbWUgPSBhZGRDb250ZXh0VG9GcmFtZTtcbmV4cG9ydHMuYWRkRXhjZXB0aW9uTWVjaGFuaXNtID0gYWRkRXhjZXB0aW9uTWVjaGFuaXNtO1xuZXhwb3J0cy5hZGRFeGNlcHRpb25UeXBlVmFsdWUgPSBhZGRFeGNlcHRpb25UeXBlVmFsdWU7XG5leHBvcnRzLmNoZWNrT3JTZXRBbHJlYWR5Q2F1Z2h0ID0gY2hlY2tPclNldEFscmVhZHlDYXVnaHQ7XG5leHBvcnRzLmdldEV2ZW50RGVzY3JpcHRpb24gPSBnZXRFdmVudERlc2NyaXB0aW9uO1xuZXhwb3J0cy5wYXJzZVNlbXZlciA9IHBhcnNlU2VtdmVyO1xuZXhwb3J0cy51dWlkNCA9IHV1aWQ0O1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9bWlzYy5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/misc.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/node-stack-trace.js":
/*!**************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/node-stack-trace.js ***!
  \**************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst stacktrace = __webpack_require__(/*! ./stacktrace.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/stacktrace.js\");\n\n/**\n * Does this filename look like it's part of the app code?\n */\nfunction filenameIsInApp(filename, isNative = false) {\n  const isInternal =\n    isNative ||\n    (filename &&\n      // It's not internal if it's an absolute linux path\n      !filename.startsWith('/') &&\n      // It's not internal if it's an absolute windows path\n      !filename.match(/^[A-Z]:/) &&\n      // It's not internal if the path is starting with a dot\n      !filename.startsWith('.') &&\n      // It's not internal if the frame has a protocol. In node, this is usually the case if the file got pre-processed with a bundler like webpack\n      !filename.match(/^[a-zA-Z]([a-zA-Z0-9.\\-+])*:\\/\\//)); // Schema from: https://stackoverflow.com/a/3641782\n\n  // in_app is all that's not an internal Node function or a module within node_modules\n  // note that isNative appears to return true even for node core libraries\n  // see https://github.com/getsentry/raven-node/issues/176\n\n  return !isInternal && filename !== undefined && !filename.includes('node_modules/');\n}\n\n/** Node Stack line parser */\nfunction node(getModule) {\n  const FILENAME_MATCH = /^\\s*[-]{4,}$/;\n  const FULL_MATCH = /at (?:async )?(?:(.+?)\\s+\\()?(?:(.+):(\\d+):(\\d+)?|([^)]+))\\)?/;\n\n  // eslint-disable-next-line complexity\n  return (line) => {\n    const lineMatch = line.match(FULL_MATCH);\n\n    if (lineMatch) {\n      let object;\n      let method;\n      let functionName;\n      let typeName;\n      let methodName;\n\n      if (lineMatch[1]) {\n        functionName = lineMatch[1];\n\n        let methodStart = functionName.lastIndexOf('.');\n        if (functionName[methodStart - 1] === '.') {\n          methodStart--;\n        }\n\n        if (methodStart > 0) {\n          object = functionName.slice(0, methodStart);\n          method = functionName.slice(methodStart + 1);\n          const objectEnd = object.indexOf('.Module');\n          if (objectEnd > 0) {\n            functionName = functionName.slice(objectEnd + 1);\n            object = object.slice(0, objectEnd);\n          }\n        }\n        typeName = undefined;\n      }\n\n      if (method) {\n        typeName = object;\n        methodName = method;\n      }\n\n      if (method === '<anonymous>') {\n        methodName = undefined;\n        functionName = undefined;\n      }\n\n      if (functionName === undefined) {\n        methodName = methodName || stacktrace.UNKNOWN_FUNCTION;\n        functionName = typeName ? `${typeName}.${methodName}` : methodName;\n      }\n\n      let filename = lineMatch[2]?.startsWith('file://') ? lineMatch[2].slice(7) : lineMatch[2];\n      const isNative = lineMatch[5] === 'native';\n\n      // If it's a Windows path, trim the leading slash so that `/C:/foo` becomes `C:/foo`\n      if (filename?.match(/\\/[A-Z]:/)) {\n        filename = filename.slice(1);\n      }\n\n      if (!filename && lineMatch[5] && !isNative) {\n        filename = lineMatch[5];\n      }\n\n      return {\n        filename: filename ? decodeURI(filename) : undefined,\n        module: getModule ? getModule(filename) : undefined,\n        function: functionName,\n        lineno: _parseIntOrUndefined(lineMatch[3]),\n        colno: _parseIntOrUndefined(lineMatch[4]),\n        in_app: filenameIsInApp(filename || '', isNative),\n      };\n    }\n\n    if (line.match(FILENAME_MATCH)) {\n      return {\n        filename: line,\n      };\n    }\n\n    return undefined;\n  };\n}\n\n/**\n * Node.js stack line parser\n *\n * This is in @sentry/core so it can be used from the Electron SDK in the browser for when `nodeIntegration == true`.\n * This allows it to be used without referencing or importing any node specific code which causes bundlers to complain\n */\nfunction nodeStackLineParser(getModule) {\n  return [90, node(getModule)];\n}\n\nfunction _parseIntOrUndefined(input) {\n  return parseInt(input || '', 10) || undefined;\n}\n\nexports.filenameIsInApp = filenameIsInApp;\nexports.node = node;\nexports.nodeStackLineParser = nodeStackLineParser;\n//# sourceMappingURL=node-stack-trace.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9ub2RlLXN0YWNrLXRyYWNlLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLG1CQUFtQixtQkFBTyxDQUFDLCtIQUFpQjs7QUFFNUM7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLDREQUE0RDs7QUFFNUQ7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLGtDQUFrQyxHQUFHO0FBQ3JDOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQSxxQ0FBcUMsU0FBUyxHQUFHLFdBQVc7QUFDNUQ7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUEsdUJBQXVCO0FBQ3ZCLFlBQVk7QUFDWiwyQkFBMkI7QUFDM0IiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9ub2RlLXN0YWNrLXRyYWNlLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBzdGFja3RyYWNlID0gcmVxdWlyZSgnLi9zdGFja3RyYWNlLmpzJyk7XG5cbi8qKlxuICogRG9lcyB0aGlzIGZpbGVuYW1lIGxvb2sgbGlrZSBpdCdzIHBhcnQgb2YgdGhlIGFwcCBjb2RlP1xuICovXG5mdW5jdGlvbiBmaWxlbmFtZUlzSW5BcHAoZmlsZW5hbWUsIGlzTmF0aXZlID0gZmFsc2UpIHtcbiAgY29uc3QgaXNJbnRlcm5hbCA9XG4gICAgaXNOYXRpdmUgfHxcbiAgICAoZmlsZW5hbWUgJiZcbiAgICAgIC8vIEl0J3Mgbm90IGludGVybmFsIGlmIGl0J3MgYW4gYWJzb2x1dGUgbGludXggcGF0aFxuICAgICAgIWZpbGVuYW1lLnN0YXJ0c1dpdGgoJy8nKSAmJlxuICAgICAgLy8gSXQncyBub3QgaW50ZXJuYWwgaWYgaXQncyBhbiBhYnNvbHV0ZSB3aW5kb3dzIHBhdGhcbiAgICAgICFmaWxlbmFtZS5tYXRjaCgvXltBLVpdOi8pICYmXG4gICAgICAvLyBJdCdzIG5vdCBpbnRlcm5hbCBpZiB0aGUgcGF0aCBpcyBzdGFydGluZyB3aXRoIGEgZG90XG4gICAgICAhZmlsZW5hbWUuc3RhcnRzV2l0aCgnLicpICYmXG4gICAgICAvLyBJdCdzIG5vdCBpbnRlcm5hbCBpZiB0aGUgZnJhbWUgaGFzIGEgcHJvdG9jb2wuIEluIG5vZGUsIHRoaXMgaXMgdXN1YWxseSB0aGUgY2FzZSBpZiB0aGUgZmlsZSBnb3QgcHJlLXByb2Nlc3NlZCB3aXRoIGEgYnVuZGxlciBsaWtlIHdlYnBhY2tcbiAgICAgICFmaWxlbmFtZS5tYXRjaCgvXlthLXpBLVpdKFthLXpBLVowLTkuXFwtK10pKjpcXC9cXC8vKSk7IC8vIFNjaGVtYSBmcm9tOiBodHRwczovL3N0YWNrb3ZlcmZsb3cuY29tL2EvMzY0MTc4MlxuXG4gIC8vIGluX2FwcCBpcyBhbGwgdGhhdCdzIG5vdCBhbiBpbnRlcm5hbCBOb2RlIGZ1bmN0aW9uIG9yIGEgbW9kdWxlIHdpdGhpbiBub2RlX21vZHVsZXNcbiAgLy8gbm90ZSB0aGF0IGlzTmF0aXZlIGFwcGVhcnMgdG8gcmV0dXJuIHRydWUgZXZlbiBmb3Igbm9kZSBjb3JlIGxpYnJhcmllc1xuICAvLyBzZWUgaHR0cHM6Ly9naXRodWIuY29tL2dldHNlbnRyeS9yYXZlbi1ub2RlL2lzc3Vlcy8xNzZcblxuICByZXR1cm4gIWlzSW50ZXJuYWwgJiYgZmlsZW5hbWUgIT09IHVuZGVmaW5lZCAmJiAhZmlsZW5hbWUuaW5jbHVkZXMoJ25vZGVfbW9kdWxlcy8nKTtcbn1cblxuLyoqIE5vZGUgU3RhY2sgbGluZSBwYXJzZXIgKi9cbmZ1bmN0aW9uIG5vZGUoZ2V0TW9kdWxlKSB7XG4gIGNvbnN0IEZJTEVOQU1FX01BVENIID0gL15cXHMqWy1dezQsfSQvO1xuICBjb25zdCBGVUxMX01BVENIID0gL2F0ICg/OmFzeW5jICk/KD86KC4rPylcXHMrXFwoKT8oPzooLispOihcXGQrKTooXFxkKyk/fChbXildKykpXFwpPy87XG5cbiAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIGNvbXBsZXhpdHlcbiAgcmV0dXJuIChsaW5lKSA9PiB7XG4gICAgY29uc3QgbGluZU1hdGNoID0gbGluZS5tYXRjaChGVUxMX01BVENIKTtcblxuICAgIGlmIChsaW5lTWF0Y2gpIHtcbiAgICAgIGxldCBvYmplY3Q7XG4gICAgICBsZXQgbWV0aG9kO1xuICAgICAgbGV0IGZ1bmN0aW9uTmFtZTtcbiAgICAgIGxldCB0eXBlTmFtZTtcbiAgICAgIGxldCBtZXRob2ROYW1lO1xuXG4gICAgICBpZiAobGluZU1hdGNoWzFdKSB7XG4gICAgICAgIGZ1bmN0aW9uTmFtZSA9IGxpbmVNYXRjaFsxXTtcblxuICAgICAgICBsZXQgbWV0aG9kU3RhcnQgPSBmdW5jdGlvbk5hbWUubGFzdEluZGV4T2YoJy4nKTtcbiAgICAgICAgaWYgKGZ1bmN0aW9uTmFtZVttZXRob2RTdGFydCAtIDFdID09PSAnLicpIHtcbiAgICAgICAgICBtZXRob2RTdGFydC0tO1xuICAgICAgICB9XG5cbiAgICAgICAgaWYgKG1ldGhvZFN0YXJ0ID4gMCkge1xuICAgICAgICAgIG9iamVjdCA9IGZ1bmN0aW9uTmFtZS5zbGljZSgwLCBtZXRob2RTdGFydCk7XG4gICAgICAgICAgbWV0aG9kID0gZnVuY3Rpb25OYW1lLnNsaWNlKG1ldGhvZFN0YXJ0ICsgMSk7XG4gICAgICAgICAgY29uc3Qgb2JqZWN0RW5kID0gb2JqZWN0LmluZGV4T2YoJy5Nb2R1bGUnKTtcbiAgICAgICAgICBpZiAob2JqZWN0RW5kID4gMCkge1xuICAgICAgICAgICAgZnVuY3Rpb25OYW1lID0gZnVuY3Rpb25OYW1lLnNsaWNlKG9iamVjdEVuZCArIDEpO1xuICAgICAgICAgICAgb2JqZWN0ID0gb2JqZWN0LnNsaWNlKDAsIG9iamVjdEVuZCk7XG4gICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICAgIHR5cGVOYW1lID0gdW5kZWZpbmVkO1xuICAgICAgfVxuXG4gICAgICBpZiAobWV0aG9kKSB7XG4gICAgICAgIHR5cGVOYW1lID0gb2JqZWN0O1xuICAgICAgICBtZXRob2ROYW1lID0gbWV0aG9kO1xuICAgICAgfVxuXG4gICAgICBpZiAobWV0aG9kID09PSAnPGFub255bW91cz4nKSB7XG4gICAgICAgIG1ldGhvZE5hbWUgPSB1bmRlZmluZWQ7XG4gICAgICAgIGZ1bmN0aW9uTmFtZSA9IHVuZGVmaW5lZDtcbiAgICAgIH1cblxuICAgICAgaWYgKGZ1bmN0aW9uTmFtZSA9PT0gdW5kZWZpbmVkKSB7XG4gICAgICAgIG1ldGhvZE5hbWUgPSBtZXRob2ROYW1lIHx8IHN0YWNrdHJhY2UuVU5LTk9XTl9GVU5DVElPTjtcbiAgICAgICAgZnVuY3Rpb25OYW1lID0gdHlwZU5hbWUgPyBgJHt0eXBlTmFtZX0uJHttZXRob2ROYW1lfWAgOiBtZXRob2ROYW1lO1xuICAgICAgfVxuXG4gICAgICBsZXQgZmlsZW5hbWUgPSBsaW5lTWF0Y2hbMl0/LnN0YXJ0c1dpdGgoJ2ZpbGU6Ly8nKSA/IGxpbmVNYXRjaFsyXS5zbGljZSg3KSA6IGxpbmVNYXRjaFsyXTtcbiAgICAgIGNvbnN0IGlzTmF0aXZlID0gbGluZU1hdGNoWzVdID09PSAnbmF0aXZlJztcblxuICAgICAgLy8gSWYgaXQncyBhIFdpbmRvd3MgcGF0aCwgdHJpbSB0aGUgbGVhZGluZyBzbGFzaCBzbyB0aGF0IGAvQzovZm9vYCBiZWNvbWVzIGBDOi9mb29gXG4gICAgICBpZiAoZmlsZW5hbWU/Lm1hdGNoKC9cXC9bQS1aXTovKSkge1xuICAgICAgICBmaWxlbmFtZSA9IGZpbGVuYW1lLnNsaWNlKDEpO1xuICAgICAgfVxuXG4gICAgICBpZiAoIWZpbGVuYW1lICYmIGxpbmVNYXRjaFs1XSAmJiAhaXNOYXRpdmUpIHtcbiAgICAgICAgZmlsZW5hbWUgPSBsaW5lTWF0Y2hbNV07XG4gICAgICB9XG5cbiAgICAgIHJldHVybiB7XG4gICAgICAgIGZpbGVuYW1lOiBmaWxlbmFtZSA/IGRlY29kZVVSSShmaWxlbmFtZSkgOiB1bmRlZmluZWQsXG4gICAgICAgIG1vZHVsZTogZ2V0TW9kdWxlID8gZ2V0TW9kdWxlKGZpbGVuYW1lKSA6IHVuZGVmaW5lZCxcbiAgICAgICAgZnVuY3Rpb246IGZ1bmN0aW9uTmFtZSxcbiAgICAgICAgbGluZW5vOiBfcGFyc2VJbnRPclVuZGVmaW5lZChsaW5lTWF0Y2hbM10pLFxuICAgICAgICBjb2xubzogX3BhcnNlSW50T3JVbmRlZmluZWQobGluZU1hdGNoWzRdKSxcbiAgICAgICAgaW5fYXBwOiBmaWxlbmFtZUlzSW5BcHAoZmlsZW5hbWUgfHwgJycsIGlzTmF0aXZlKSxcbiAgICAgIH07XG4gICAgfVxuXG4gICAgaWYgKGxpbmUubWF0Y2goRklMRU5BTUVfTUFUQ0gpKSB7XG4gICAgICByZXR1cm4ge1xuICAgICAgICBmaWxlbmFtZTogbGluZSxcbiAgICAgIH07XG4gICAgfVxuXG4gICAgcmV0dXJuIHVuZGVmaW5lZDtcbiAgfTtcbn1cblxuLyoqXG4gKiBOb2RlLmpzIHN0YWNrIGxpbmUgcGFyc2VyXG4gKlxuICogVGhpcyBpcyBpbiBAc2VudHJ5L2NvcmUgc28gaXQgY2FuIGJlIHVzZWQgZnJvbSB0aGUgRWxlY3Ryb24gU0RLIGluIHRoZSBicm93c2VyIGZvciB3aGVuIGBub2RlSW50ZWdyYXRpb24gPT0gdHJ1ZWAuXG4gKiBUaGlzIGFsbG93cyBpdCB0byBiZSB1c2VkIHdpdGhvdXQgcmVmZXJlbmNpbmcgb3IgaW1wb3J0aW5nIGFueSBub2RlIHNwZWNpZmljIGNvZGUgd2hpY2ggY2F1c2VzIGJ1bmRsZXJzIHRvIGNvbXBsYWluXG4gKi9cbmZ1bmN0aW9uIG5vZGVTdGFja0xpbmVQYXJzZXIoZ2V0TW9kdWxlKSB7XG4gIHJldHVybiBbOTAsIG5vZGUoZ2V0TW9kdWxlKV07XG59XG5cbmZ1bmN0aW9uIF9wYXJzZUludE9yVW5kZWZpbmVkKGlucHV0KSB7XG4gIHJldHVybiBwYXJzZUludChpbnB1dCB8fCAnJywgMTApIHx8IHVuZGVmaW5lZDtcbn1cblxuZXhwb3J0cy5maWxlbmFtZUlzSW5BcHAgPSBmaWxlbmFtZUlzSW5BcHA7XG5leHBvcnRzLm5vZGUgPSBub2RlO1xuZXhwb3J0cy5ub2RlU3RhY2tMaW5lUGFyc2VyID0gbm9kZVN0YWNrTGluZVBhcnNlcjtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPW5vZGUtc3RhY2stdHJhY2UuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/node-stack-trace.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/node.js":
/*!**************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/node.js ***!
  \**************************************************************************************************/
/***/ ((module, exports, __webpack_require__) => {
 
eval("/* module decorator */ module = __webpack_require__.nmd(module);\nObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst env = __webpack_require__(/*! ./env.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/env.js\");\n\n/**\n * NOTE: In order to avoid circular dependencies, if you add a function to this module and it needs to print something,\n * you must either a) use `console.log` rather than the `debug` singleton, or b) put your function elsewhere.\n */\n\n\n/**\n * Checks whether we're in the Node.js or Browser environment\n *\n * @returns Answer to given question\n */\nfunction isNodeEnv() {\n  // explicitly check for browser bundles as those can be optimized statically\n  // by terser/rollup.\n  return (\n    !env.isBrowserBundle() &&\n    Object.prototype.toString.call(typeof process !== 'undefined' ? process : 0) === '[object process]'\n  );\n}\n\n/**\n * Requires a module which is protected against bundler minification.\n *\n * @param request The module path to resolve\n */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction dynamicRequire(mod, request) {\n  // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n  return mod.require(request);\n}\n\n/**\n * Helper for dynamically loading module that should work with linked dependencies.\n * The problem is that we _should_ be using `require(require.resolve(moduleName, { paths: [cwd()] }))`\n * However it's _not possible_ to do that with Webpack, as it has to know all the dependencies during\n * build time. `require.resolve` is also not available in any other way, so we cannot create,\n * a fake helper like we do with `dynamicRequire`.\n *\n * We always prefer to use local package, thus the value is not returned early from each `try/catch` block.\n * That is to mimic the behavior of `require.resolve` exactly.\n *\n * @param moduleName module name to require\n * @param existingModule module to use for requiring\n * @returns possibly required module\n */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction loadModule(moduleName, existingModule = module) {\n  let mod;\n\n  try {\n    mod = dynamicRequire(existingModule, moduleName);\n  } catch {\n    // no-empty\n  }\n\n  if (!mod) {\n    try {\n      const { cwd } = dynamicRequire(existingModule, 'process');\n      mod = dynamicRequire(existingModule, `${cwd()}/node_modules/${moduleName}`) ;\n    } catch {\n      // no-empty\n    }\n  }\n\n  return mod;\n}\n\nexports.isNodeEnv = isNodeEnv;\nexports.loadModule = loadModule;\n//# sourceMappingURL=node.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9ub2RlLmpzIiwibWFwcGluZ3MiOiI7QUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxZQUFZLG1CQUFPLENBQUMsaUhBQVU7O0FBRTlCO0FBQ0E7QUFDQTtBQUNBOzs7QUFHQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsbUZBQW1GLGdCQUFnQjtBQUNuRztBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQSxJQUFJO0FBQ0o7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsY0FBYyxNQUFNO0FBQ3BCLDhDQUE4QyxNQUFNLGdCQUFnQixXQUFXO0FBQy9FLE1BQU07QUFDTjtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQSxpQkFBaUI7QUFDakIsa0JBQWtCO0FBQ2xCIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvbm9kZS5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgZW52ID0gcmVxdWlyZSgnLi9lbnYuanMnKTtcblxuLyoqXG4gKiBOT1RFOiBJbiBvcmRlciB0byBhdm9pZCBjaXJjdWxhciBkZXBlbmRlbmNpZXMsIGlmIHlvdSBhZGQgYSBmdW5jdGlvbiB0byB0aGlzIG1vZHVsZSBhbmQgaXQgbmVlZHMgdG8gcHJpbnQgc29tZXRoaW5nLFxuICogeW91IG11c3QgZWl0aGVyIGEpIHVzZSBgY29uc29sZS5sb2dgIHJhdGhlciB0aGFuIHRoZSBgZGVidWdgIHNpbmdsZXRvbiwgb3IgYikgcHV0IHlvdXIgZnVuY3Rpb24gZWxzZXdoZXJlLlxuICovXG5cblxuLyoqXG4gKiBDaGVja3Mgd2hldGhlciB3ZSdyZSBpbiB0aGUgTm9kZS5qcyBvciBCcm93c2VyIGVudmlyb25tZW50XG4gKlxuICogQHJldHVybnMgQW5zd2VyIHRvIGdpdmVuIHF1ZXN0aW9uXG4gKi9cbmZ1bmN0aW9uIGlzTm9kZUVudigpIHtcbiAgLy8gZXhwbGljaXRseSBjaGVjayBmb3IgYnJvd3NlciBidW5kbGVzIGFzIHRob3NlIGNhbiBiZSBvcHRpbWl6ZWQgc3RhdGljYWxseVxuICAvLyBieSB0ZXJzZXIvcm9sbHVwLlxuICByZXR1cm4gKFxuICAgICFlbnYuaXNCcm93c2VyQnVuZGxlKCkgJiZcbiAgICBPYmplY3QucHJvdG90eXBlLnRvU3RyaW5nLmNhbGwodHlwZW9mIHByb2Nlc3MgIT09ICd1bmRlZmluZWQnID8gcHJvY2VzcyA6IDApID09PSAnW29iamVjdCBwcm9jZXNzXSdcbiAgKTtcbn1cblxuLyoqXG4gKiBSZXF1aXJlcyBhIG1vZHVsZSB3aGljaCBpcyBwcm90ZWN0ZWQgYWdhaW5zdCBidW5kbGVyIG1pbmlmaWNhdGlvbi5cbiAqXG4gKiBAcGFyYW0gcmVxdWVzdCBUaGUgbW9kdWxlIHBhdGggdG8gcmVzb2x2ZVxuICovXG4vLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25vLWV4cGxpY2l0LWFueVxuZnVuY3Rpb24gZHluYW1pY1JlcXVpcmUobW9kLCByZXF1ZXN0KSB7XG4gIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tdW5zYWZlLW1lbWJlci1hY2Nlc3NcbiAgcmV0dXJuIG1vZC5yZXF1aXJlKHJlcXVlc3QpO1xufVxuXG4vKipcbiAqIEhlbHBlciBmb3IgZHluYW1pY2FsbHkgbG9hZGluZyBtb2R1bGUgdGhhdCBzaG91bGQgd29yayB3aXRoIGxpbmtlZCBkZXBlbmRlbmNpZXMuXG4gKiBUaGUgcHJvYmxlbSBpcyB0aGF0IHdlIF9zaG91bGRfIGJlIHVzaW5nIGByZXF1aXJlKHJlcXVpcmUucmVzb2x2ZShtb2R1bGVOYW1lLCB7IHBhdGhzOiBbY3dkKCldIH0pKWBcbiAqIEhvd2V2ZXIgaXQncyBfbm90IHBvc3NpYmxlXyB0byBkbyB0aGF0IHdpdGggV2VicGFjaywgYXMgaXQgaGFzIHRvIGtub3cgYWxsIHRoZSBkZXBlbmRlbmNpZXMgZHVyaW5nXG4gKiBidWlsZCB0aW1lLiBgcmVxdWlyZS5yZXNvbHZlYCBpcyBhbHNvIG5vdCBhdmFpbGFibGUgaW4gYW55IG90aGVyIHdheSwgc28gd2UgY2Fubm90IGNyZWF0ZSxcbiAqIGEgZmFrZSBoZWxwZXIgbGlrZSB3ZSBkbyB3aXRoIGBkeW5hbWljUmVxdWlyZWAuXG4gKlxuICogV2UgYWx3YXlzIHByZWZlciB0byB1c2UgbG9jYWwgcGFja2FnZSwgdGh1cyB0aGUgdmFsdWUgaXMgbm90IHJldHVybmVkIGVhcmx5IGZyb20gZWFjaCBgdHJ5L2NhdGNoYCBibG9jay5cbiAqIFRoYXQgaXMgdG8gbWltaWMgdGhlIGJlaGF2aW9yIG9mIGByZXF1aXJlLnJlc29sdmVgIGV4YWN0bHkuXG4gKlxuICogQHBhcmFtIG1vZHVsZU5hbWUgbW9kdWxlIG5hbWUgdG8gcmVxdWlyZVxuICogQHBhcmFtIGV4aXN0aW5nTW9kdWxlIG1vZHVsZSB0byB1c2UgZm9yIHJlcXVpcmluZ1xuICogQHJldHVybnMgcG9zc2libHkgcmVxdWlyZWQgbW9kdWxlXG4gKi9cbi8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tZXhwbGljaXQtYW55XG5mdW5jdGlvbiBsb2FkTW9kdWxlKG1vZHVsZU5hbWUsIGV4aXN0aW5nTW9kdWxlID0gbW9kdWxlKSB7XG4gIGxldCBtb2Q7XG5cbiAgdHJ5IHtcbiAgICBtb2QgPSBkeW5hbWljUmVxdWlyZShleGlzdGluZ01vZHVsZSwgbW9kdWxlTmFtZSk7XG4gIH0gY2F0Y2gge1xuICAgIC8vIG5vLWVtcHR5XG4gIH1cblxuICBpZiAoIW1vZCkge1xuICAgIHRyeSB7XG4gICAgICBjb25zdCB7IGN3ZCB9ID0gZHluYW1pY1JlcXVpcmUoZXhpc3RpbmdNb2R1bGUsICdwcm9jZXNzJyk7XG4gICAgICBtb2QgPSBkeW5hbWljUmVxdWlyZShleGlzdGluZ01vZHVsZSwgYCR7Y3dkKCl9L25vZGVfbW9kdWxlcy8ke21vZHVsZU5hbWV9YCkgO1xuICAgIH0gY2F0Y2gge1xuICAgICAgLy8gbm8tZW1wdHlcbiAgICB9XG4gIH1cblxuICByZXR1cm4gbW9kO1xufVxuXG5leHBvcnRzLmlzTm9kZUVudiA9IGlzTm9kZUVudjtcbmV4cG9ydHMubG9hZE1vZHVsZSA9IGxvYWRNb2R1bGU7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1ub2RlLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/node.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/normalize.js":
/*!*******************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/normalize.js ***!
  \*******************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst is = __webpack_require__(/*! ./is.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js\");\nconst object = __webpack_require__(/*! ./object.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/object.js\");\nconst stacktrace = __webpack_require__(/*! ./stacktrace.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/stacktrace.js\");\n\n/**\n * Recursively normalizes the given object.\n *\n * - Creates a copy to prevent original input mutation\n * - Skips non-enumerable properties\n * - When stringifying, calls `toJSON` if implemented\n * - Removes circular references\n * - Translates non-serializable values (`undefined`/`NaN`/functions) to serializable format\n * - Translates known global objects/classes to a string representations\n * - Takes care of `Error` object serialization\n * - Optionally limits depth of final output\n * - Optionally limits number of properties/elements included in any single object/array\n *\n * @param input The object to be normalized.\n * @param depth The max depth to which to normalize the object. (Anything deeper stringified whole.)\n * @param maxProperties The max number of elements or properties to be included in any single array or\n * object in the normalized output.\n * @returns A normalized version of the object, or `\"**non-serializable**\"` if any errors are thrown during normalization.\n */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction normalize(input, depth = 100, maxProperties = +Infinity) {\n  try {\n    // since we're at the outermost level, we don't provide a key\n    return visit('', input, depth, maxProperties);\n  } catch (err) {\n    return { ERROR: `**non-serializable** (${err})` };\n  }\n}\n\n/** JSDoc */\nfunction normalizeToSize(\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  object,\n  // Default Node.js REPL depth\n  depth = 3,\n  // 100kB, as 200kB is max payload size, so half sounds reasonable\n  maxSize = 100 * 1024,\n) {\n  const normalized = normalize(object, depth);\n\n  if (jsonSize(normalized) > maxSize) {\n    return normalizeToSize(object, depth - 1, maxSize);\n  }\n\n  return normalized ;\n}\n\n/**\n * Visits a node to perform normalization on it\n *\n * @param key The key corresponding to the given node\n * @param value The node to be visited\n * @param depth Optional number indicating the maximum recursion depth\n * @param maxProperties Optional maximum number of properties/elements included in any single object/array\n * @param memo Optional Memo class handling decycling\n */\nfunction visit(\n  key,\n  value,\n  depth = +Infinity,\n  maxProperties = +Infinity,\n  memo = memoBuilder(),\n) {\n  const [memoize, unmemoize] = memo;\n\n  // Get the simple cases out of the way first\n  if (\n    value == null || // this matches null and undefined -> eqeq not eqeqeq\n    ['boolean', 'string'].includes(typeof value) ||\n    (typeof value === 'number' && Number.isFinite(value))\n  ) {\n    return value ;\n  }\n\n  const stringified = stringifyValue(key, value);\n\n  // Anything we could potentially dig into more (objects or arrays) will have come back as `\"[object XXXX]\"`.\n  // Everything else will have already been serialized, so if we don't see that pattern, we're done.\n  if (!stringified.startsWith('[object ')) {\n    return stringified;\n  }\n\n  // From here on, we can assert that `value` is either an object or an array.\n\n  // Do not normalize objects that we know have already been normalized. As a general rule, the\n  // \"__sentry_skip_normalization__\" property should only be used sparingly and only should only be set on objects that\n  // have already been normalized.\n  if ((value )['__sentry_skip_normalization__']) {\n    return value ;\n  }\n\n  // We can set `__sentry_override_normalization_depth__` on an object to ensure that from there\n  // We keep a certain amount of depth.\n  // This should be used sparingly, e.g. we use it for the redux integration to ensure we get a certain amount of state.\n  const remainingDepth =\n    typeof (value )['__sentry_override_normalization_depth__'] === 'number'\n      ? ((value )['__sentry_override_normalization_depth__'] )\n      : depth;\n\n  // We're also done if we've reached the max depth\n  if (remainingDepth === 0) {\n    // At this point we know `serialized` is a string of the form `\"[object XXXX]\"`. Clean it up so it's just `\"[XXXX]\"`.\n    return stringified.replace('object ', '');\n  }\n\n  // If we've already visited this branch, bail out, as it's circular reference. If not, note that we're seeing it now.\n  if (memoize(value)) {\n    return '[Circular ~]';\n  }\n\n  // If the value has a `toJSON` method, we call it to extract more information\n  const valueWithToJSON = value ;\n  if (valueWithToJSON && typeof valueWithToJSON.toJSON === 'function') {\n    try {\n      const jsonValue = valueWithToJSON.toJSON();\n      // We need to normalize the return value of `.toJSON()` in case it has circular references\n      return visit('', jsonValue, remainingDepth - 1, maxProperties, memo);\n    } catch {\n      // pass (The built-in `toJSON` failed, but we can still try to do it ourselves)\n    }\n  }\n\n  // At this point we know we either have an object or an array, we haven't seen it before, and we're going to recurse\n  // because we haven't yet reached the max depth. Create an accumulator to hold the results of visiting each\n  // property/entry, and keep track of the number of items we add to it.\n  const normalized = (Array.isArray(value) ? [] : {}) ;\n  let numAdded = 0;\n\n  // Before we begin, convert`Error` and`Event` instances into plain objects, since some of each of their relevant\n  // properties are non-enumerable and otherwise would get missed.\n  const visitable = object.convertToPlainObject(value );\n\n  for (const visitKey in visitable) {\n    // Avoid iterating over fields in the prototype if they've somehow been exposed to enumeration.\n    if (!Object.prototype.hasOwnProperty.call(visitable, visitKey)) {\n      continue;\n    }\n\n    if (numAdded >= maxProperties) {\n      normalized[visitKey] = '[MaxProperties ~]';\n      break;\n    }\n\n    // Recursively visit all the child nodes\n    const visitValue = visitable[visitKey];\n    normalized[visitKey] = visit(visitKey, visitValue, remainingDepth - 1, maxProperties, memo);\n\n    numAdded++;\n  }\n\n  // Once we've visited all the branches, remove the parent from memo storage\n  unmemoize(value);\n\n  // Return accumulated values\n  return normalized;\n}\n\n/* eslint-disable complexity */\n/**\n * Stringify the given value. Handles various known special values and types.\n *\n * Not meant to be used on simple primitives which already have a string representation, as it will, for example, turn\n * the number 1231 into \"[Object Number]\", nor on `null`, as it will throw.\n *\n * @param value The value to stringify\n * @returns A stringified representation of the given value\n */\nfunction stringifyValue(\n  key,\n  // this type is a tiny bit of a cheat, since this function does handle NaN (which is technically a number), but for\n  // our internal use, it'll do\n  value,\n) {\n  try {\n    if (key === 'domain' && value && typeof value === 'object' && (value )._events) {\n      return '[Domain]';\n    }\n\n    if (key === 'domainEmitter') {\n      return '[DomainEmitter]';\n    }\n\n    // It's safe to use `global`, `window`, and `document` here in this manner, as we are asserting using `typeof` first\n    // which won't throw if they are not present.\n\n    if (typeof global !== 'undefined' && value === global) {\n      return '[Global]';\n    }\n\n    // eslint-disable-next-line no-restricted-globals\n    if (typeof window !== 'undefined' && value === window) {\n      return '[Window]';\n    }\n\n    // eslint-disable-next-line no-restricted-globals\n    if (typeof document !== 'undefined' && value === document) {\n      return '[Document]';\n    }\n\n    if (is.isVueViewModel(value)) {\n      return '[VueViewModel]';\n    }\n\n    // React's SyntheticEvent thingy\n    if (is.isSyntheticEvent(value)) {\n      return '[SyntheticEvent]';\n    }\n\n    if (typeof value === 'number' && !Number.isFinite(value)) {\n      return `[${value}]`;\n    }\n\n    if (typeof value === 'function') {\n      return `[Function: ${stacktrace.getFunctionName(value)}]`;\n    }\n\n    if (typeof value === 'symbol') {\n      return `[${String(value)}]`;\n    }\n\n    // stringified BigInts are indistinguishable from regular numbers, so we need to label them to avoid confusion\n    if (typeof value === 'bigint') {\n      return `[BigInt: ${String(value)}]`;\n    }\n\n    // Now that we've knocked out all the special cases and the primitives, all we have left are objects. Simply casting\n    // them to strings means that instances of classes which haven't defined their `toStringTag` will just come out as\n    // `\"[object Object]\"`. If we instead look at the constructor's name (which is the same as the name of the class),\n    // we can make sure that only plain objects come out that way.\n    const objName = getConstructorName(value);\n\n    // Handle HTML Elements\n    if (/^HTML(\\w*)Element$/.test(objName)) {\n      return `[HTMLElement: ${objName}]`;\n    }\n\n    return `[object ${objName}]`;\n  } catch (err) {\n    return `**non-serializable** (${err})`;\n  }\n}\n/* eslint-enable complexity */\n\nfunction getConstructorName(value) {\n  const prototype = Object.getPrototypeOf(value);\n\n  return prototype?.constructor ? prototype.constructor.name : 'null prototype';\n}\n\n/** Calculates bytes size of input string */\nfunction utf8Length(value) {\n  // eslint-disable-next-line no-bitwise\n  return ~-encodeURI(value).split(/%..|./).length;\n}\n\n/** Calculates bytes size of input object */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction jsonSize(value) {\n  return utf8Length(JSON.stringify(value));\n}\n\n/**\n * Normalizes URLs in exceptions and stacktraces to a base path so Sentry can fingerprint\n * across platforms and working directory.\n *\n * @param url The URL to be normalized.\n * @param basePath The application base path.\n * @returns The normalized URL.\n */\nfunction normalizeUrlToBase(url, basePath) {\n  const escapedBase = basePath\n    // Backslash to forward\n    .replace(/\\\\/g, '/')\n    // Escape RegExp special characters\n    .replace(/[|\\\\{}()[\\]^$+*?.]/g, '\\\\$&');\n\n  let newUrl = url;\n  try {\n    newUrl = decodeURI(url);\n  } catch {\n    // Sometime this breaks\n  }\n  return (\n    newUrl\n      .replace(/\\\\/g, '/')\n      .replace(/webpack:\\/?/g, '') // Remove intermediate base path\n      // eslint-disable-next-line @sentry-internal/sdk/no-regexp-constructor\n      .replace(new RegExp(`(file://)?/*${escapedBase}/*`, 'ig'), 'app:///')\n  );\n}\n\n/**\n * Helper to decycle json objects\n */\nfunction memoBuilder() {\n  const inner = new WeakSet();\n  function memoize(obj) {\n    if (inner.has(obj)) {\n      return true;\n    }\n    inner.add(obj);\n    return false;\n  }\n\n  function unmemoize(obj) {\n    inner.delete(obj);\n  }\n  return [memoize, unmemoize];\n}\n\nexports.normalize = normalize;\nexports.normalizeToSize = normalizeToSize;\nexports.normalizeUrlToBase = normalizeUrlToBase;\n//# sourceMappingURL=normalize.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9ub3JtYWxpemUuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsV0FBVyxtQkFBTyxDQUFDLCtHQUFTO0FBQzVCLGVBQWUsbUJBQU8sQ0FBQyx1SEFBYTtBQUNwQyxtQkFBbUIsbUJBQU8sQ0FBQywrSEFBaUI7O0FBRTVDO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLElBQUk7QUFDSixhQUFhLGdDQUFnQyxJQUFJO0FBQ2pEO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxNQUFNO0FBQ047QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBLG9EQUFvRDtBQUNwRDs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQSxpQkFBaUIsTUFBTTtBQUN2Qjs7QUFFQTtBQUNBLDJCQUEyQixrQ0FBa0M7QUFDN0Q7O0FBRUE7QUFDQSxpQkFBaUIsY0FBYztBQUMvQjs7QUFFQTtBQUNBO0FBQ0EseUJBQXlCLGNBQWM7QUFDdkM7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsOEJBQThCLFFBQVE7QUFDdEM7O0FBRUEsc0JBQXNCLFFBQVE7QUFDOUIsSUFBSTtBQUNKLG9DQUFvQyxJQUFJO0FBQ3hDO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0Esb0JBQW9COztBQUVwQjtBQUNBO0FBQ0E7QUFDQSxJQUFJO0FBQ0o7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSx5Q0FBeUMsWUFBWTtBQUNyRDtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLGlCQUFpQjtBQUNqQix1QkFBdUI7QUFDdkIsMEJBQTBCO0FBQzFCIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvbm9ybWFsaXplLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBpcyA9IHJlcXVpcmUoJy4vaXMuanMnKTtcbmNvbnN0IG9iamVjdCA9IHJlcXVpcmUoJy4vb2JqZWN0LmpzJyk7XG5jb25zdCBzdGFja3RyYWNlID0gcmVxdWlyZSgnLi9zdGFja3RyYWNlLmpzJyk7XG5cbi8qKlxuICogUmVjdXJzaXZlbHkgbm9ybWFsaXplcyB0aGUgZ2l2ZW4gb2JqZWN0LlxuICpcbiAqIC0gQ3JlYXRlcyBhIGNvcHkgdG8gcHJldmVudCBvcmlnaW5hbCBpbnB1dCBtdXRhdGlvblxuICogLSBTa2lwcyBub24tZW51bWVyYWJsZSBwcm9wZXJ0aWVzXG4gKiAtIFdoZW4gc3RyaW5naWZ5aW5nLCBjYWxscyBgdG9KU09OYCBpZiBpbXBsZW1lbnRlZFxuICogLSBSZW1vdmVzIGNpcmN1bGFyIHJlZmVyZW5jZXNcbiAqIC0gVHJhbnNsYXRlcyBub24tc2VyaWFsaXphYmxlIHZhbHVlcyAoYHVuZGVmaW5lZGAvYE5hTmAvZnVuY3Rpb25zKSB0byBzZXJpYWxpemFibGUgZm9ybWF0XG4gKiAtIFRyYW5zbGF0ZXMga25vd24gZ2xvYmFsIG9iamVjdHMvY2xhc3NlcyB0byBhIHN0cmluZyByZXByZXNlbnRhdGlvbnNcbiAqIC0gVGFrZXMgY2FyZSBvZiBgRXJyb3JgIG9iamVjdCBzZXJpYWxpemF0aW9uXG4gKiAtIE9wdGlvbmFsbHkgbGltaXRzIGRlcHRoIG9mIGZpbmFsIG91dHB1dFxuICogLSBPcHRpb25hbGx5IGxpbWl0cyBudW1iZXIgb2YgcHJvcGVydGllcy9lbGVtZW50cyBpbmNsdWRlZCBpbiBhbnkgc2luZ2xlIG9iamVjdC9hcnJheVxuICpcbiAqIEBwYXJhbSBpbnB1dCBUaGUgb2JqZWN0IHRvIGJlIG5vcm1hbGl6ZWQuXG4gKiBAcGFyYW0gZGVwdGggVGhlIG1heCBkZXB0aCB0byB3aGljaCB0byBub3JtYWxpemUgdGhlIG9iamVjdC4gKEFueXRoaW5nIGRlZXBlciBzdHJpbmdpZmllZCB3aG9sZS4pXG4gKiBAcGFyYW0gbWF4UHJvcGVydGllcyBUaGUgbWF4IG51bWJlciBvZiBlbGVtZW50cyBvciBwcm9wZXJ0aWVzIHRvIGJlIGluY2x1ZGVkIGluIGFueSBzaW5nbGUgYXJyYXkgb3JcbiAqIG9iamVjdCBpbiB0aGUgbm9ybWFsaXplZCBvdXRwdXQuXG4gKiBAcmV0dXJucyBBIG5vcm1hbGl6ZWQgdmVyc2lvbiBvZiB0aGUgb2JqZWN0LCBvciBgXCIqKm5vbi1zZXJpYWxpemFibGUqKlwiYCBpZiBhbnkgZXJyb3JzIGFyZSB0aHJvd24gZHVyaW5nIG5vcm1hbGl6YXRpb24uXG4gKi9cbi8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tZXhwbGljaXQtYW55XG5mdW5jdGlvbiBub3JtYWxpemUoaW5wdXQsIGRlcHRoID0gMTAwLCBtYXhQcm9wZXJ0aWVzID0gK0luZmluaXR5KSB7XG4gIHRyeSB7XG4gICAgLy8gc2luY2Ugd2UncmUgYXQgdGhlIG91dGVybW9zdCBsZXZlbCwgd2UgZG9uJ3QgcHJvdmlkZSBhIGtleVxuICAgIHJldHVybiB2aXNpdCgnJywgaW5wdXQsIGRlcHRoLCBtYXhQcm9wZXJ0aWVzKTtcbiAgfSBjYXRjaCAoZXJyKSB7XG4gICAgcmV0dXJuIHsgRVJST1I6IGAqKm5vbi1zZXJpYWxpemFibGUqKiAoJHtlcnJ9KWAgfTtcbiAgfVxufVxuXG4vKiogSlNEb2MgKi9cbmZ1bmN0aW9uIG5vcm1hbGl6ZVRvU2l6ZShcbiAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uby1leHBsaWNpdC1hbnlcbiAgb2JqZWN0LFxuICAvLyBEZWZhdWx0IE5vZGUuanMgUkVQTCBkZXB0aFxuICBkZXB0aCA9IDMsXG4gIC8vIDEwMGtCLCBhcyAyMDBrQiBpcyBtYXggcGF5bG9hZCBzaXplLCBzbyBoYWxmIHNvdW5kcyByZWFzb25hYmxlXG4gIG1heFNpemUgPSAxMDAgKiAxMDI0LFxuKSB7XG4gIGNvbnN0IG5vcm1hbGl6ZWQgPSBub3JtYWxpemUob2JqZWN0LCBkZXB0aCk7XG5cbiAgaWYgKGpzb25TaXplKG5vcm1hbGl6ZWQpID4gbWF4U2l6ZSkge1xuICAgIHJldHVybiBub3JtYWxpemVUb1NpemUob2JqZWN0LCBkZXB0aCAtIDEsIG1heFNpemUpO1xuICB9XG5cbiAgcmV0dXJuIG5vcm1hbGl6ZWQgO1xufVxuXG4vKipcbiAqIFZpc2l0cyBhIG5vZGUgdG8gcGVyZm9ybSBub3JtYWxpemF0aW9uIG9uIGl0XG4gKlxuICogQHBhcmFtIGtleSBUaGUga2V5IGNvcnJlc3BvbmRpbmcgdG8gdGhlIGdpdmVuIG5vZGVcbiAqIEBwYXJhbSB2YWx1ZSBUaGUgbm9kZSB0byBiZSB2aXNpdGVkXG4gKiBAcGFyYW0gZGVwdGggT3B0aW9uYWwgbnVtYmVyIGluZGljYXRpbmcgdGhlIG1heGltdW0gcmVjdXJzaW9uIGRlcHRoXG4gKiBAcGFyYW0gbWF4UHJvcGVydGllcyBPcHRpb25hbCBtYXhpbXVtIG51bWJlciBvZiBwcm9wZXJ0aWVzL2VsZW1lbnRzIGluY2x1ZGVkIGluIGFueSBzaW5nbGUgb2JqZWN0L2FycmF5XG4gKiBAcGFyYW0gbWVtbyBPcHRpb25hbCBNZW1vIGNsYXNzIGhhbmRsaW5nIGRlY3ljbGluZ1xuICovXG5mdW5jdGlvbiB2aXNpdChcbiAga2V5LFxuICB2YWx1ZSxcbiAgZGVwdGggPSArSW5maW5pdHksXG4gIG1heFByb3BlcnRpZXMgPSArSW5maW5pdHksXG4gIG1lbW8gPSBtZW1vQnVpbGRlcigpLFxuKSB7XG4gIGNvbnN0IFttZW1vaXplLCB1bm1lbW9pemVdID0gbWVtbztcblxuICAvLyBHZXQgdGhlIHNpbXBsZSBjYXNlcyBvdXQgb2YgdGhlIHdheSBmaXJzdFxuICBpZiAoXG4gICAgdmFsdWUgPT0gbnVsbCB8fCAvLyB0aGlzIG1hdGNoZXMgbnVsbCBhbmQgdW5kZWZpbmVkIC0+IGVxZXEgbm90IGVxZXFlcVxuICAgIFsnYm9vbGVhbicsICdzdHJpbmcnXS5pbmNsdWRlcyh0eXBlb2YgdmFsdWUpIHx8XG4gICAgKHR5cGVvZiB2YWx1ZSA9PT0gJ251bWJlcicgJiYgTnVtYmVyLmlzRmluaXRlKHZhbHVlKSlcbiAgKSB7XG4gICAgcmV0dXJuIHZhbHVlIDtcbiAgfVxuXG4gIGNvbnN0IHN0cmluZ2lmaWVkID0gc3RyaW5naWZ5VmFsdWUoa2V5LCB2YWx1ZSk7XG5cbiAgLy8gQW55dGhpbmcgd2UgY291bGQgcG90ZW50aWFsbHkgZGlnIGludG8gbW9yZSAob2JqZWN0cyBvciBhcnJheXMpIHdpbGwgaGF2ZSBjb21lIGJhY2sgYXMgYFwiW29iamVjdCBYWFhYXVwiYC5cbiAgLy8gRXZlcnl0aGluZyBlbHNlIHdpbGwgaGF2ZSBhbHJlYWR5IGJlZW4gc2VyaWFsaXplZCwgc28gaWYgd2UgZG9uJ3Qgc2VlIHRoYXQgcGF0dGVybiwgd2UncmUgZG9uZS5cbiAgaWYgKCFzdHJpbmdpZmllZC5zdGFydHNXaXRoKCdbb2JqZWN0ICcpKSB7XG4gICAgcmV0dXJuIHN0cmluZ2lmaWVkO1xuICB9XG5cbiAgLy8gRnJvbSBoZXJlIG9uLCB3ZSBjYW4gYXNzZXJ0IHRoYXQgYHZhbHVlYCBpcyBlaXRoZXIgYW4gb2JqZWN0IG9yIGFuIGFycmF5LlxuXG4gIC8vIERvIG5vdCBub3JtYWxpemUgb2JqZWN0cyB0aGF0IHdlIGtub3cgaGF2ZSBhbHJlYWR5IGJlZW4gbm9ybWFsaXplZC4gQXMgYSBnZW5lcmFsIHJ1bGUsIHRoZVxuICAvLyBcIl9fc2VudHJ5X3NraXBfbm9ybWFsaXphdGlvbl9fXCIgcHJvcGVydHkgc2hvdWxkIG9ubHkgYmUgdXNlZCBzcGFyaW5nbHkgYW5kIG9ubHkgc2hvdWxkIG9ubHkgYmUgc2V0IG9uIG9iamVjdHMgdGhhdFxuICAvLyBoYXZlIGFscmVhZHkgYmVlbiBub3JtYWxpemVkLlxuICBpZiAoKHZhbHVlIClbJ19fc2VudHJ5X3NraXBfbm9ybWFsaXphdGlvbl9fJ10pIHtcbiAgICByZXR1cm4gdmFsdWUgO1xuICB9XG5cbiAgLy8gV2UgY2FuIHNldCBgX19zZW50cnlfb3ZlcnJpZGVfbm9ybWFsaXphdGlvbl9kZXB0aF9fYCBvbiBhbiBvYmplY3QgdG8gZW5zdXJlIHRoYXQgZnJvbSB0aGVyZVxuICAvLyBXZSBrZWVwIGEgY2VydGFpbiBhbW91bnQgb2YgZGVwdGguXG4gIC8vIFRoaXMgc2hvdWxkIGJlIHVzZWQgc3BhcmluZ2x5LCBlLmcuIHdlIHVzZSBpdCBmb3IgdGhlIHJlZHV4IGludGVncmF0aW9uIHRvIGVuc3VyZSB3ZSBnZXQgYSBjZXJ0YWluIGFtb3VudCBvZiBzdGF0ZS5cbiAgY29uc3QgcmVtYWluaW5nRGVwdGggPVxuICAgIHR5cGVvZiAodmFsdWUgKVsnX19zZW50cnlfb3ZlcnJpZGVfbm9ybWFsaXphdGlvbl9kZXB0aF9fJ10gPT09ICdudW1iZXInXG4gICAgICA/ICgodmFsdWUgKVsnX19zZW50cnlfb3ZlcnJpZGVfbm9ybWFsaXphdGlvbl9kZXB0aF9fJ10gKVxuICAgICAgOiBkZXB0aDtcblxuICAvLyBXZSdyZSBhbHNvIGRvbmUgaWYgd2UndmUgcmVhY2hlZCB0aGUgbWF4IGRlcHRoXG4gIGlmIChyZW1haW5pbmdEZXB0aCA9PT0gMCkge1xuICAgIC8vIEF0IHRoaXMgcG9pbnQgd2Uga25vdyBgc2VyaWFsaXplZGAgaXMgYSBzdHJpbmcgb2YgdGhlIGZvcm0gYFwiW29iamVjdCBYWFhYXVwiYC4gQ2xlYW4gaXQgdXAgc28gaXQncyBqdXN0IGBcIltYWFhYXVwiYC5cbiAgICByZXR1cm4gc3RyaW5naWZpZWQucmVwbGFjZSgnb2JqZWN0ICcsICcnKTtcbiAgfVxuXG4gIC8vIElmIHdlJ3ZlIGFscmVhZHkgdmlzaXRlZCB0aGlzIGJyYW5jaCwgYmFpbCBvdXQsIGFzIGl0J3MgY2lyY3VsYXIgcmVmZXJlbmNlLiBJZiBub3QsIG5vdGUgdGhhdCB3ZSdyZSBzZWVpbmcgaXQgbm93LlxuICBpZiAobWVtb2l6ZSh2YWx1ZSkpIHtcbiAgICByZXR1cm4gJ1tDaXJjdWxhciB+XSc7XG4gIH1cblxuICAvLyBJZiB0aGUgdmFsdWUgaGFzIGEgYHRvSlNPTmAgbWV0aG9kLCB3ZSBjYWxsIGl0IHRvIGV4dHJhY3QgbW9yZSBpbmZvcm1hdGlvblxuICBjb25zdCB2YWx1ZVdpdGhUb0pTT04gPSB2YWx1ZSA7XG4gIGlmICh2YWx1ZVdpdGhUb0pTT04gJiYgdHlwZW9mIHZhbHVlV2l0aFRvSlNPTi50b0pTT04gPT09ICdmdW5jdGlvbicpIHtcbiAgICB0cnkge1xuICAgICAgY29uc3QganNvblZhbHVlID0gdmFsdWVXaXRoVG9KU09OLnRvSlNPTigpO1xuICAgICAgLy8gV2UgbmVlZCB0byBub3JtYWxpemUgdGhlIHJldHVybiB2YWx1ZSBvZiBgLnRvSlNPTigpYCBpbiBjYXNlIGl0IGhhcyBjaXJjdWxhciByZWZlcmVuY2VzXG4gICAgICByZXR1cm4gdmlzaXQoJycsIGpzb25WYWx1ZSwgcmVtYWluaW5nRGVwdGggLSAxLCBtYXhQcm9wZXJ0aWVzLCBtZW1vKTtcbiAgICB9IGNhdGNoIHtcbiAgICAgIC8vIHBhc3MgKFRoZSBidWlsdC1pbiBgdG9KU09OYCBmYWlsZWQsIGJ1dCB3ZSBjYW4gc3RpbGwgdHJ5IHRvIGRvIGl0IG91cnNlbHZlcylcbiAgICB9XG4gIH1cblxuICAvLyBBdCB0aGlzIHBvaW50IHdlIGtub3cgd2UgZWl0aGVyIGhhdmUgYW4gb2JqZWN0IG9yIGFuIGFycmF5LCB3ZSBoYXZlbid0IHNlZW4gaXQgYmVmb3JlLCBhbmQgd2UncmUgZ29pbmcgdG8gcmVjdXJzZVxuICAvLyBiZWNhdXNlIHdlIGhhdmVuJ3QgeWV0IHJlYWNoZWQgdGhlIG1heCBkZXB0aC4gQ3JlYXRlIGFuIGFjY3VtdWxhdG9yIHRvIGhvbGQgdGhlIHJlc3VsdHMgb2YgdmlzaXRpbmcgZWFjaFxuICAvLyBwcm9wZXJ0eS9lbnRyeSwgYW5kIGtlZXAgdHJhY2sgb2YgdGhlIG51bWJlciBvZiBpdGVtcyB3ZSBhZGQgdG8gaXQuXG4gIGNvbnN0IG5vcm1hbGl6ZWQgPSAoQXJyYXkuaXNBcnJheSh2YWx1ZSkgPyBbXSA6IHt9KSA7XG4gIGxldCBudW1BZGRlZCA9IDA7XG5cbiAgLy8gQmVmb3JlIHdlIGJlZ2luLCBjb252ZXJ0YEVycm9yYCBhbmRgRXZlbnRgIGluc3RhbmNlcyBpbnRvIHBsYWluIG9iamVjdHMsIHNpbmNlIHNvbWUgb2YgZWFjaCBvZiB0aGVpciByZWxldmFudFxuICAvLyBwcm9wZXJ0aWVzIGFyZSBub24tZW51bWVyYWJsZSBhbmQgb3RoZXJ3aXNlIHdvdWxkIGdldCBtaXNzZWQuXG4gIGNvbnN0IHZpc2l0YWJsZSA9IG9iamVjdC5jb252ZXJ0VG9QbGFpbk9iamVjdCh2YWx1ZSApO1xuXG4gIGZvciAoY29uc3QgdmlzaXRLZXkgaW4gdmlzaXRhYmxlKSB7XG4gICAgLy8gQXZvaWQgaXRlcmF0aW5nIG92ZXIgZmllbGRzIGluIHRoZSBwcm90b3R5cGUgaWYgdGhleSd2ZSBzb21laG93IGJlZW4gZXhwb3NlZCB0byBlbnVtZXJhdGlvbi5cbiAgICBpZiAoIU9iamVjdC5wcm90b3R5cGUuaGFzT3duUHJvcGVydHkuY2FsbCh2aXNpdGFibGUsIHZpc2l0S2V5KSkge1xuICAgICAgY29udGludWU7XG4gICAgfVxuXG4gICAgaWYgKG51bUFkZGVkID49IG1heFByb3BlcnRpZXMpIHtcbiAgICAgIG5vcm1hbGl6ZWRbdmlzaXRLZXldID0gJ1tNYXhQcm9wZXJ0aWVzIH5dJztcbiAgICAgIGJyZWFrO1xuICAgIH1cblxuICAgIC8vIFJlY3Vyc2l2ZWx5IHZpc2l0IGFsbCB0aGUgY2hpbGQgbm9kZXNcbiAgICBjb25zdCB2aXNpdFZhbHVlID0gdmlzaXRhYmxlW3Zpc2l0S2V5XTtcbiAgICBub3JtYWxpemVkW3Zpc2l0S2V5XSA9IHZpc2l0KHZpc2l0S2V5LCB2aXNpdFZhbHVlLCByZW1haW5pbmdEZXB0aCAtIDEsIG1heFByb3BlcnRpZXMsIG1lbW8pO1xuXG4gICAgbnVtQWRkZWQrKztcbiAgfVxuXG4gIC8vIE9uY2Ugd2UndmUgdmlzaXRlZCBhbGwgdGhlIGJyYW5jaGVzLCByZW1vdmUgdGhlIHBhcmVudCBmcm9tIG1lbW8gc3RvcmFnZVxuICB1bm1lbW9pemUodmFsdWUpO1xuXG4gIC8vIFJldHVybiBhY2N1bXVsYXRlZCB2YWx1ZXNcbiAgcmV0dXJuIG5vcm1hbGl6ZWQ7XG59XG5cbi8qIGVzbGludC1kaXNhYmxlIGNvbXBsZXhpdHkgKi9cbi8qKlxuICogU3RyaW5naWZ5IHRoZSBnaXZlbiB2YWx1ZS4gSGFuZGxlcyB2YXJpb3VzIGtub3duIHNwZWNpYWwgdmFsdWVzIGFuZCB0eXBlcy5cbiAqXG4gKiBOb3QgbWVhbnQgdG8gYmUgdXNlZCBvbiBzaW1wbGUgcHJpbWl0aXZlcyB3aGljaCBhbHJlYWR5IGhhdmUgYSBzdHJpbmcgcmVwcmVzZW50YXRpb24sIGFzIGl0IHdpbGwsIGZvciBleGFtcGxlLCB0dXJuXG4gKiB0aGUgbnVtYmVyIDEyMzEgaW50byBcIltPYmplY3QgTnVtYmVyXVwiLCBub3Igb24gYG51bGxgLCBhcyBpdCB3aWxsIHRocm93LlxuICpcbiAqIEBwYXJhbSB2YWx1ZSBUaGUgdmFsdWUgdG8gc3RyaW5naWZ5XG4gKiBAcmV0dXJucyBBIHN0cmluZ2lmaWVkIHJlcHJlc2VudGF0aW9uIG9mIHRoZSBnaXZlbiB2YWx1ZVxuICovXG5mdW5jdGlvbiBzdHJpbmdpZnlWYWx1ZShcbiAga2V5LFxuICAvLyB0aGlzIHR5cGUgaXMgYSB0aW55IGJpdCBvZiBhIGNoZWF0LCBzaW5jZSB0aGlzIGZ1bmN0aW9uIGRvZXMgaGFuZGxlIE5hTiAod2hpY2ggaXMgdGVjaG5pY2FsbHkgYSBudW1iZXIpLCBidXQgZm9yXG4gIC8vIG91ciBpbnRlcm5hbCB1c2UsIGl0J2xsIGRvXG4gIHZhbHVlLFxuKSB7XG4gIHRyeSB7XG4gICAgaWYgKGtleSA9PT0gJ2RvbWFpbicgJiYgdmFsdWUgJiYgdHlwZW9mIHZhbHVlID09PSAnb2JqZWN0JyAmJiAodmFsdWUgKS5fZXZlbnRzKSB7XG4gICAgICByZXR1cm4gJ1tEb21haW5dJztcbiAgICB9XG5cbiAgICBpZiAoa2V5ID09PSAnZG9tYWluRW1pdHRlcicpIHtcbiAgICAgIHJldHVybiAnW0RvbWFpbkVtaXR0ZXJdJztcbiAgICB9XG5cbiAgICAvLyBJdCdzIHNhZmUgdG8gdXNlIGBnbG9iYWxgLCBgd2luZG93YCwgYW5kIGBkb2N1bWVudGAgaGVyZSBpbiB0aGlzIG1hbm5lciwgYXMgd2UgYXJlIGFzc2VydGluZyB1c2luZyBgdHlwZW9mYCBmaXJzdFxuICAgIC8vIHdoaWNoIHdvbid0IHRocm93IGlmIHRoZXkgYXJlIG5vdCBwcmVzZW50LlxuXG4gICAgaWYgKHR5cGVvZiBnbG9iYWwgIT09ICd1bmRlZmluZWQnICYmIHZhbHVlID09PSBnbG9iYWwpIHtcbiAgICAgIHJldHVybiAnW0dsb2JhbF0nO1xuICAgIH1cblxuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBuby1yZXN0cmljdGVkLWdsb2JhbHNcbiAgICBpZiAodHlwZW9mIHdpbmRvdyAhPT0gJ3VuZGVmaW5lZCcgJiYgdmFsdWUgPT09IHdpbmRvdykge1xuICAgICAgcmV0dXJuICdbV2luZG93XSc7XG4gICAgfVxuXG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIG5vLXJlc3RyaWN0ZWQtZ2xvYmFsc1xuICAgIGlmICh0eXBlb2YgZG9jdW1lbnQgIT09ICd1bmRlZmluZWQnICYmIHZhbHVlID09PSBkb2N1bWVudCkge1xuICAgICAgcmV0dXJuICdbRG9jdW1lbnRdJztcbiAgICB9XG5cbiAgICBpZiAoaXMuaXNWdWVWaWV3TW9kZWwodmFsdWUpKSB7XG4gICAgICByZXR1cm4gJ1tWdWVWaWV3TW9kZWxdJztcbiAgICB9XG5cbiAgICAvLyBSZWFjdCdzIFN5bnRoZXRpY0V2ZW50IHRoaW5neVxuICAgIGlmIChpcy5pc1N5bnRoZXRpY0V2ZW50KHZhbHVlKSkge1xuICAgICAgcmV0dXJuICdbU3ludGhldGljRXZlbnRdJztcbiAgICB9XG5cbiAgICBpZiAodHlwZW9mIHZhbHVlID09PSAnbnVtYmVyJyAmJiAhTnVtYmVyLmlzRmluaXRlKHZhbHVlKSkge1xuICAgICAgcmV0dXJuIGBbJHt2YWx1ZX1dYDtcbiAgICB9XG5cbiAgICBpZiAodHlwZW9mIHZhbHVlID09PSAnZnVuY3Rpb24nKSB7XG4gICAgICByZXR1cm4gYFtGdW5jdGlvbjogJHtzdGFja3RyYWNlLmdldEZ1bmN0aW9uTmFtZSh2YWx1ZSl9XWA7XG4gICAgfVxuXG4gICAgaWYgKHR5cGVvZiB2YWx1ZSA9PT0gJ3N5bWJvbCcpIHtcbiAgICAgIHJldHVybiBgWyR7U3RyaW5nKHZhbHVlKX1dYDtcbiAgICB9XG5cbiAgICAvLyBzdHJpbmdpZmllZCBCaWdJbnRzIGFyZSBpbmRpc3Rpbmd1aXNoYWJsZSBmcm9tIHJlZ3VsYXIgbnVtYmVycywgc28gd2UgbmVlZCB0byBsYWJlbCB0aGVtIHRvIGF2b2lkIGNvbmZ1c2lvblxuICAgIGlmICh0eXBlb2YgdmFsdWUgPT09ICdiaWdpbnQnKSB7XG4gICAgICByZXR1cm4gYFtCaWdJbnQ6ICR7U3RyaW5nKHZhbHVlKX1dYDtcbiAgICB9XG5cbiAgICAvLyBOb3cgdGhhdCB3ZSd2ZSBrbm9ja2VkIG91dCBhbGwgdGhlIHNwZWNpYWwgY2FzZXMgYW5kIHRoZSBwcmltaXRpdmVzLCBhbGwgd2UgaGF2ZSBsZWZ0IGFyZSBvYmplY3RzLiBTaW1wbHkgY2FzdGluZ1xuICAgIC8vIHRoZW0gdG8gc3RyaW5ncyBtZWFucyB0aGF0IGluc3RhbmNlcyBvZiBjbGFzc2VzIHdoaWNoIGhhdmVuJ3QgZGVmaW5lZCB0aGVpciBgdG9TdHJpbmdUYWdgIHdpbGwganVzdCBjb21lIG91dCBhc1xuICAgIC8vIGBcIltvYmplY3QgT2JqZWN0XVwiYC4gSWYgd2UgaW5zdGVhZCBsb29rIGF0IHRoZSBjb25zdHJ1Y3RvcidzIG5hbWUgKHdoaWNoIGlzIHRoZSBzYW1lIGFzIHRoZSBuYW1lIG9mIHRoZSBjbGFzcyksXG4gICAgLy8gd2UgY2FuIG1ha2Ugc3VyZSB0aGF0IG9ubHkgcGxhaW4gb2JqZWN0cyBjb21lIG91dCB0aGF0IHdheS5cbiAgICBjb25zdCBvYmpOYW1lID0gZ2V0Q29uc3RydWN0b3JOYW1lKHZhbHVlKTtcblxuICAgIC8vIEhhbmRsZSBIVE1MIEVsZW1lbnRzXG4gICAgaWYgKC9eSFRNTChcXHcqKUVsZW1lbnQkLy50ZXN0KG9iak5hbWUpKSB7XG4gICAgICByZXR1cm4gYFtIVE1MRWxlbWVudDogJHtvYmpOYW1lfV1gO1xuICAgIH1cblxuICAgIHJldHVybiBgW29iamVjdCAke29iak5hbWV9XWA7XG4gIH0gY2F0Y2ggKGVycikge1xuICAgIHJldHVybiBgKipub24tc2VyaWFsaXphYmxlKiogKCR7ZXJyfSlgO1xuICB9XG59XG4vKiBlc2xpbnQtZW5hYmxlIGNvbXBsZXhpdHkgKi9cblxuZnVuY3Rpb24gZ2V0Q29uc3RydWN0b3JOYW1lKHZhbHVlKSB7XG4gIGNvbnN0IHByb3RvdHlwZSA9IE9iamVjdC5nZXRQcm90b3R5cGVPZih2YWx1ZSk7XG5cbiAgcmV0dXJuIHByb3RvdHlwZT8uY29uc3RydWN0b3IgPyBwcm90b3R5cGUuY29uc3RydWN0b3IubmFtZSA6ICdudWxsIHByb3RvdHlwZSc7XG59XG5cbi8qKiBDYWxjdWxhdGVzIGJ5dGVzIHNpemUgb2YgaW5wdXQgc3RyaW5nICovXG5mdW5jdGlvbiB1dGY4TGVuZ3RoKHZhbHVlKSB7XG4gIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBuby1iaXR3aXNlXG4gIHJldHVybiB+LWVuY29kZVVSSSh2YWx1ZSkuc3BsaXQoLyUuLnwuLykubGVuZ3RoO1xufVxuXG4vKiogQ2FsY3VsYXRlcyBieXRlcyBzaXplIG9mIGlucHV0IG9iamVjdCAqL1xuLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uby1leHBsaWNpdC1hbnlcbmZ1bmN0aW9uIGpzb25TaXplKHZhbHVlKSB7XG4gIHJldHVybiB1dGY4TGVuZ3RoKEpTT04uc3RyaW5naWZ5KHZhbHVlKSk7XG59XG5cbi8qKlxuICogTm9ybWFsaXplcyBVUkxzIGluIGV4Y2VwdGlvbnMgYW5kIHN0YWNrdHJhY2VzIHRvIGEgYmFzZSBwYXRoIHNvIFNlbnRyeSBjYW4gZmluZ2VycHJpbnRcbiAqIGFjcm9zcyBwbGF0Zm9ybXMgYW5kIHdvcmtpbmcgZGlyZWN0b3J5LlxuICpcbiAqIEBwYXJhbSB1cmwgVGhlIFVSTCB0byBiZSBub3JtYWxpemVkLlxuICogQHBhcmFtIGJhc2VQYXRoIFRoZSBhcHBsaWNhdGlvbiBiYXNlIHBhdGguXG4gKiBAcmV0dXJucyBUaGUgbm9ybWFsaXplZCBVUkwuXG4gKi9cbmZ1bmN0aW9uIG5vcm1hbGl6ZVVybFRvQmFzZSh1cmwsIGJhc2VQYXRoKSB7XG4gIGNvbnN0IGVzY2FwZWRCYXNlID0gYmFzZVBhdGhcbiAgICAvLyBCYWNrc2xhc2ggdG8gZm9yd2FyZFxuICAgIC5yZXBsYWNlKC9cXFxcL2csICcvJylcbiAgICAvLyBFc2NhcGUgUmVnRXhwIHNwZWNpYWwgY2hhcmFjdGVyc1xuICAgIC5yZXBsYWNlKC9bfFxcXFx7fSgpW1xcXV4kKyo/Ll0vZywgJ1xcXFwkJicpO1xuXG4gIGxldCBuZXdVcmwgPSB1cmw7XG4gIHRyeSB7XG4gICAgbmV3VXJsID0gZGVjb2RlVVJJKHVybCk7XG4gIH0gY2F0Y2gge1xuICAgIC8vIFNvbWV0aW1lIHRoaXMgYnJlYWtzXG4gIH1cbiAgcmV0dXJuIChcbiAgICBuZXdVcmxcbiAgICAgIC5yZXBsYWNlKC9cXFxcL2csICcvJylcbiAgICAgIC5yZXBsYWNlKC93ZWJwYWNrOlxcLz8vZywgJycpIC8vIFJlbW92ZSBpbnRlcm1lZGlhdGUgYmFzZSBwYXRoXG4gICAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHNlbnRyeS1pbnRlcm5hbC9zZGsvbm8tcmVnZXhwLWNvbnN0cnVjdG9yXG4gICAgICAucmVwbGFjZShuZXcgUmVnRXhwKGAoZmlsZTovLyk/Lyoke2VzY2FwZWRCYXNlfS8qYCwgJ2lnJyksICdhcHA6Ly8vJylcbiAgKTtcbn1cblxuLyoqXG4gKiBIZWxwZXIgdG8gZGVjeWNsZSBqc29uIG9iamVjdHNcbiAqL1xuZnVuY3Rpb24gbWVtb0J1aWxkZXIoKSB7XG4gIGNvbnN0IGlubmVyID0gbmV3IFdlYWtTZXQoKTtcbiAgZnVuY3Rpb24gbWVtb2l6ZShvYmopIHtcbiAgICBpZiAoaW5uZXIuaGFzKG9iaikpIHtcbiAgICAgIHJldHVybiB0cnVlO1xuICAgIH1cbiAgICBpbm5lci5hZGQob2JqKTtcbiAgICByZXR1cm4gZmFsc2U7XG4gIH1cblxuICBmdW5jdGlvbiB1bm1lbW9pemUob2JqKSB7XG4gICAgaW5uZXIuZGVsZXRlKG9iaik7XG4gIH1cbiAgcmV0dXJuIFttZW1vaXplLCB1bm1lbW9pemVdO1xufVxuXG5leHBvcnRzLm5vcm1hbGl6ZSA9IG5vcm1hbGl6ZTtcbmV4cG9ydHMubm9ybWFsaXplVG9TaXplID0gbm9ybWFsaXplVG9TaXplO1xuZXhwb3J0cy5ub3JtYWxpemVVcmxUb0Jhc2UgPSBub3JtYWxpemVVcmxUb0Jhc2U7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1ub3JtYWxpemUuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/normalize.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/object.js":
/*!****************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/object.js ***!
  \****************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst debugBuild = __webpack_require__(/*! ../debug-build.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst browser = __webpack_require__(/*! ./browser.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/browser.js\");\nconst debugLogger = __webpack_require__(/*! ./debug-logger.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst is = __webpack_require__(/*! ./is.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js\");\nconst string = __webpack_require__(/*! ./string.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/string.js\");\n\n/* eslint-disable @typescript-eslint/no-explicit-any */\n\n/**\n * Replace a method in an object with a wrapped version of itself.\n *\n * If the method on the passed object is not a function, the wrapper will not be applied.\n *\n * @param source An object that contains a method to be wrapped.\n * @param name The name of the method to be wrapped.\n * @param replacementFactory A higher-order function that takes the original version of the given method and returns a\n * wrapped version. Note: The function returned by `replacementFactory` needs to be a non-arrow function, in order to\n * preserve the correct value of `this`, and the original method must be called using `origMethod.call(this, <other\n * args>)` or `origMethod.apply(this, [<other args>])` (rather than being called directly), again to preserve `this`.\n * @returns void\n */\nfunction fill(source, name, replacementFactory) {\n  if (!(name in source)) {\n    return;\n  }\n\n  // explicitly casting to unknown because we don't know the type of the method initially at all\n  const original = source[name] ;\n\n  if (typeof original !== 'function') {\n    return;\n  }\n\n  const wrapped = replacementFactory(original) ;\n\n  // Make sure it's a function first, as we need to attach an empty prototype for `defineProperties` to work\n  // otherwise it'll throw \"TypeError: Object.defineProperties called on non-object\"\n  if (typeof wrapped === 'function') {\n    markFunctionWrapped(wrapped, original);\n  }\n\n  try {\n    source[name] = wrapped;\n  } catch {\n    debugBuild.DEBUG_BUILD && debugLogger.debug.log(`Failed to replace method \"${name}\" in object`, source);\n  }\n}\n\n/**\n * Defines a non-enumerable property on the given object.\n *\n * @param obj The object on which to set the property\n * @param name The name of the property to be set\n * @param value The value to which to set the property\n */\nfunction addNonEnumerableProperty(obj, name, value) {\n  try {\n    Object.defineProperty(obj, name, {\n      // enumerable: false, // the default, so we can save on bundle size by not explicitly setting it\n      value: value,\n      writable: true,\n      configurable: true,\n    });\n  } catch {\n    debugBuild.DEBUG_BUILD && debugLogger.debug.log(`Failed to add non-enumerable property \"${name}\" to object`, obj);\n  }\n}\n\n/**\n * Remembers the original function on the wrapped function and\n * patches up the prototype.\n *\n * @param wrapped the wrapper function\n * @param original the original function that gets wrapped\n */\nfunction markFunctionWrapped(wrapped, original) {\n  try {\n    const proto = original.prototype || {};\n    wrapped.prototype = original.prototype = proto;\n    addNonEnumerableProperty(wrapped, '__sentry_original__', original);\n  } catch {} // eslint-disable-line no-empty\n}\n\n/**\n * This extracts the original function if available.  See\n * `markFunctionWrapped` for more information.\n *\n * @param func the function to unwrap\n * @returns the unwrapped version of the function if available.\n */\n// eslint-disable-next-line @typescript-eslint/ban-types\nfunction getOriginalFunction(func) {\n  return func.__sentry_original__;\n}\n\n/**\n * Transforms any `Error` or `Event` into a plain object with all of their enumerable properties, and some of their\n * non-enumerable properties attached.\n *\n * @param value Initial source that we have to transform in order for it to be usable by the serializer\n * @returns An Event or Error turned into an object - or the value argument itself, when value is neither an Event nor\n *  an Error.\n */\nfunction convertToPlainObject(value)\n\n {\n  if (is.isError(value)) {\n    return {\n      message: value.message,\n      name: value.name,\n      stack: value.stack,\n      ...getOwnProperties(value),\n    };\n  } else if (is.isEvent(value)) {\n    const newObj\n\n = {\n      type: value.type,\n      target: serializeEventTarget(value.target),\n      currentTarget: serializeEventTarget(value.currentTarget),\n      ...getOwnProperties(value),\n    };\n\n    if (typeof CustomEvent !== 'undefined' && is.isInstanceOf(value, CustomEvent)) {\n      newObj.detail = value.detail;\n    }\n\n    return newObj;\n  } else {\n    return value;\n  }\n}\n\n/** Creates a string representation of the target of an `Event` object */\nfunction serializeEventTarget(target) {\n  try {\n    return is.isElement(target) ? browser.htmlTreeAsString(target) : Object.prototype.toString.call(target);\n  } catch {\n    return '<unknown>';\n  }\n}\n\n/** Filters out all but an object's own properties */\nfunction getOwnProperties(obj) {\n  if (typeof obj === 'object' && obj !== null) {\n    const extractedProps = {};\n    for (const property in obj) {\n      if (Object.prototype.hasOwnProperty.call(obj, property)) {\n        extractedProps[property] = (obj )[property];\n      }\n    }\n    return extractedProps;\n  } else {\n    return {};\n  }\n}\n\n/**\n * Given any captured exception, extract its keys and create a sorted\n * and truncated list that will be used inside the event message.\n * eg. `Non-error exception captured with keys: foo, bar, baz`\n */\nfunction extractExceptionKeysForMessage(exception, maxLength = 40) {\n  const keys = Object.keys(convertToPlainObject(exception));\n  keys.sort();\n\n  const firstKey = keys[0];\n\n  if (!firstKey) {\n    return '[object has no keys]';\n  }\n\n  if (firstKey.length >= maxLength) {\n    return string.truncate(firstKey, maxLength);\n  }\n\n  for (let includedKeys = keys.length; includedKeys > 0; includedKeys--) {\n    const serialized = keys.slice(0, includedKeys).join(', ');\n    if (serialized.length > maxLength) {\n      continue;\n    }\n    if (includedKeys === keys.length) {\n      return serialized;\n    }\n    return string.truncate(serialized, maxLength);\n  }\n\n  return '';\n}\n\n/**\n * Given any object, return a new object having removed all fields whose value was `undefined`.\n * Works recursively on objects and arrays.\n *\n * Attention: This function keeps circular references in the returned object.\n *\n * @deprecated This function is no longer used by the SDK and will be removed in a future major version.\n */\nfunction dropUndefinedKeys(inputValue) {\n  // This map keeps track of what already visited nodes map to.\n  // Our Set - based memoBuilder doesn't work here because we want to the output object to have the same circular\n  // references as the input object.\n  const memoizationMap = new Map();\n\n  // This function just proxies `_dropUndefinedKeys` to keep the `memoBuilder` out of this function's API\n  return _dropUndefinedKeys(inputValue, memoizationMap);\n}\n\nfunction _dropUndefinedKeys(inputValue, memoizationMap) {\n  // Early return for primitive values\n  if (inputValue === null || typeof inputValue !== 'object') {\n    return inputValue;\n  }\n\n  // Check memo map first for all object types\n  const memoVal = memoizationMap.get(inputValue);\n  if (memoVal !== undefined) {\n    return memoVal ;\n  }\n\n  // handle arrays\n  if (Array.isArray(inputValue)) {\n    const returnValue = [];\n    // Store mapping to handle circular references\n    memoizationMap.set(inputValue, returnValue);\n\n    inputValue.forEach(value => {\n      returnValue.push(_dropUndefinedKeys(value, memoizationMap));\n    });\n\n    return returnValue ;\n  }\n\n  if (isPojo(inputValue)) {\n    const returnValue = {};\n    // Store mapping to handle circular references\n    memoizationMap.set(inputValue, returnValue);\n\n    const keys = Object.keys(inputValue);\n\n    keys.forEach(key => {\n      const val = inputValue[key];\n      if (val !== undefined) {\n        returnValue[key] = _dropUndefinedKeys(val, memoizationMap);\n      }\n    });\n\n    return returnValue ;\n  }\n\n  // For other object types, return as is\n  return inputValue;\n}\n\nfunction isPojo(input) {\n  // Plain objects have Object as constructor or no constructor\n  const constructor = (input ).constructor;\n  return constructor === Object || constructor === undefined;\n}\n\n/**\n * Ensure that something is an object.\n *\n * Turns `undefined` and `null` into `String`s and all other primitives into instances of their respective wrapper\n * classes (String, Boolean, Number, etc.). Acts as the identity function on non-primitives.\n *\n * @param wat The subject of the objectification\n * @returns A version of `wat` which can safely be used with `Object` class methods\n */\nfunction objectify(wat) {\n  let objectified;\n  switch (true) {\n    // this will catch both undefined and null\n    case wat == undefined:\n      objectified = new String(wat);\n      break;\n\n    // Though symbols and bigints do have wrapper classes (`Symbol` and `BigInt`, respectively), for whatever reason\n    // those classes don't have constructors which can be used with the `new` keyword. We therefore need to cast each as\n    // an object in order to wrap it.\n    case typeof wat === 'symbol' || typeof wat === 'bigint':\n      objectified = Object(wat);\n      break;\n\n    // this will catch the remaining primitives: `String`, `Number`, and `Boolean`\n    case is.isPrimitive(wat):\n      // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n      objectified = new (wat ).constructor(wat);\n      break;\n\n    // by process of elimination, at this point we know that `wat` must already be an object\n    default:\n      objectified = wat;\n      break;\n  }\n  return objectified;\n}\n\nexports.addNonEnumerableProperty = addNonEnumerableProperty;\nexports.convertToPlainObject = convertToPlainObject;\nexports.dropUndefinedKeys = dropUndefinedKeys;\nexports.extractExceptionKeysForMessage = extractExceptionKeysForMessage;\nexports.fill = fill;\nexports.getOriginalFunction = getOriginalFunction;\nexports.markFunctionWrapped = markFunctionWrapped;\nexports.objectify = objectify;\n//# sourceMappingURL=object.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9vYmplY3QuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsbUJBQW1CLG1CQUFPLENBQUMsNEhBQW1CO0FBQzlDLGdCQUFnQixtQkFBTyxDQUFDLHlIQUFjO0FBQ3RDLG9CQUFvQixtQkFBTyxDQUFDLG1JQUFtQjtBQUMvQyxXQUFXLG1CQUFPLENBQUMsK0dBQVM7QUFDNUIsZUFBZSxtQkFBTyxDQUFDLHVIQUFhOztBQUVwQzs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLElBQUk7QUFDSixpRkFBaUYsS0FBSztBQUN0RjtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxLQUFLO0FBQ0wsSUFBSTtBQUNKLDhGQUE4RixLQUFLO0FBQ25HO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsSUFBSSxTQUFTO0FBQ2I7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLElBQUk7QUFDSjs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0EsSUFBSTtBQUNKO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLElBQUk7QUFDSjtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxJQUFJO0FBQ0o7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQSx1Q0FBdUMsa0JBQWtCO0FBQ3pEO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsS0FBSzs7QUFFTDtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxLQUFLOztBQUVMO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsZ0NBQWdDO0FBQ2hDLDRCQUE0QjtBQUM1Qix5QkFBeUI7QUFDekIsc0NBQXNDO0FBQ3RDLFlBQVk7QUFDWiwyQkFBMkI7QUFDM0IsMkJBQTJCO0FBQzNCLGlCQUFpQjtBQUNqQiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3V0aWxzL29iamVjdC5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgZGVidWdCdWlsZCA9IHJlcXVpcmUoJy4uL2RlYnVnLWJ1aWxkLmpzJyk7XG5jb25zdCBicm93c2VyID0gcmVxdWlyZSgnLi9icm93c2VyLmpzJyk7XG5jb25zdCBkZWJ1Z0xvZ2dlciA9IHJlcXVpcmUoJy4vZGVidWctbG9nZ2VyLmpzJyk7XG5jb25zdCBpcyA9IHJlcXVpcmUoJy4vaXMuanMnKTtcbmNvbnN0IHN0cmluZyA9IHJlcXVpcmUoJy4vc3RyaW5nLmpzJyk7XG5cbi8qIGVzbGludC1kaXNhYmxlIEB0eXBlc2NyaXB0LWVzbGludC9uby1leHBsaWNpdC1hbnkgKi9cblxuLyoqXG4gKiBSZXBsYWNlIGEgbWV0aG9kIGluIGFuIG9iamVjdCB3aXRoIGEgd3JhcHBlZCB2ZXJzaW9uIG9mIGl0c2VsZi5cbiAqXG4gKiBJZiB0aGUgbWV0aG9kIG9uIHRoZSBwYXNzZWQgb2JqZWN0IGlzIG5vdCBhIGZ1bmN0aW9uLCB0aGUgd3JhcHBlciB3aWxsIG5vdCBiZSBhcHBsaWVkLlxuICpcbiAqIEBwYXJhbSBzb3VyY2UgQW4gb2JqZWN0IHRoYXQgY29udGFpbnMgYSBtZXRob2QgdG8gYmUgd3JhcHBlZC5cbiAqIEBwYXJhbSBuYW1lIFRoZSBuYW1lIG9mIHRoZSBtZXRob2QgdG8gYmUgd3JhcHBlZC5cbiAqIEBwYXJhbSByZXBsYWNlbWVudEZhY3RvcnkgQSBoaWdoZXItb3JkZXIgZnVuY3Rpb24gdGhhdCB0YWtlcyB0aGUgb3JpZ2luYWwgdmVyc2lvbiBvZiB0aGUgZ2l2ZW4gbWV0aG9kIGFuZCByZXR1cm5zIGFcbiAqIHdyYXBwZWQgdmVyc2lvbi4gTm90ZTogVGhlIGZ1bmN0aW9uIHJldHVybmVkIGJ5IGByZXBsYWNlbWVudEZhY3RvcnlgIG5lZWRzIHRvIGJlIGEgbm9uLWFycm93IGZ1bmN0aW9uLCBpbiBvcmRlciB0b1xuICogcHJlc2VydmUgdGhlIGNvcnJlY3QgdmFsdWUgb2YgYHRoaXNgLCBhbmQgdGhlIG9yaWdpbmFsIG1ldGhvZCBtdXN0IGJlIGNhbGxlZCB1c2luZyBgb3JpZ01ldGhvZC5jYWxsKHRoaXMsIDxvdGhlclxuICogYXJncz4pYCBvciBgb3JpZ01ldGhvZC5hcHBseSh0aGlzLCBbPG90aGVyIGFyZ3M+XSlgIChyYXRoZXIgdGhhbiBiZWluZyBjYWxsZWQgZGlyZWN0bHkpLCBhZ2FpbiB0byBwcmVzZXJ2ZSBgdGhpc2AuXG4gKiBAcmV0dXJucyB2b2lkXG4gKi9cbmZ1bmN0aW9uIGZpbGwoc291cmNlLCBuYW1lLCByZXBsYWNlbWVudEZhY3RvcnkpIHtcbiAgaWYgKCEobmFtZSBpbiBzb3VyY2UpKSB7XG4gICAgcmV0dXJuO1xuICB9XG5cbiAgLy8gZXhwbGljaXRseSBjYXN0aW5nIHRvIHVua25vd24gYmVjYXVzZSB3ZSBkb24ndCBrbm93IHRoZSB0eXBlIG9mIHRoZSBtZXRob2QgaW5pdGlhbGx5IGF0IGFsbFxuICBjb25zdCBvcmlnaW5hbCA9IHNvdXJjZVtuYW1lXSA7XG5cbiAgaWYgKHR5cGVvZiBvcmlnaW5hbCAhPT0gJ2Z1bmN0aW9uJykge1xuICAgIHJldHVybjtcbiAgfVxuXG4gIGNvbnN0IHdyYXBwZWQgPSByZXBsYWNlbWVudEZhY3Rvcnkob3JpZ2luYWwpIDtcblxuICAvLyBNYWtlIHN1cmUgaXQncyBhIGZ1bmN0aW9uIGZpcnN0LCBhcyB3ZSBuZWVkIHRvIGF0dGFjaCBhbiBlbXB0eSBwcm90b3R5cGUgZm9yIGBkZWZpbmVQcm9wZXJ0aWVzYCB0byB3b3JrXG4gIC8vIG90aGVyd2lzZSBpdCdsbCB0aHJvdyBcIlR5cGVFcnJvcjogT2JqZWN0LmRlZmluZVByb3BlcnRpZXMgY2FsbGVkIG9uIG5vbi1vYmplY3RcIlxuICBpZiAodHlwZW9mIHdyYXBwZWQgPT09ICdmdW5jdGlvbicpIHtcbiAgICBtYXJrRnVuY3Rpb25XcmFwcGVkKHdyYXBwZWQsIG9yaWdpbmFsKTtcbiAgfVxuXG4gIHRyeSB7XG4gICAgc291cmNlW25hbWVdID0gd3JhcHBlZDtcbiAgfSBjYXRjaCB7XG4gICAgZGVidWdCdWlsZC5ERUJVR19CVUlMRCAmJiBkZWJ1Z0xvZ2dlci5kZWJ1Zy5sb2coYEZhaWxlZCB0byByZXBsYWNlIG1ldGhvZCBcIiR7bmFtZX1cIiBpbiBvYmplY3RgLCBzb3VyY2UpO1xuICB9XG59XG5cbi8qKlxuICogRGVmaW5lcyBhIG5vbi1lbnVtZXJhYmxlIHByb3BlcnR5IG9uIHRoZSBnaXZlbiBvYmplY3QuXG4gKlxuICogQHBhcmFtIG9iaiBUaGUgb2JqZWN0IG9uIHdoaWNoIHRvIHNldCB0aGUgcHJvcGVydHlcbiAqIEBwYXJhbSBuYW1lIFRoZSBuYW1lIG9mIHRoZSBwcm9wZXJ0eSB0byBiZSBzZXRcbiAqIEBwYXJhbSB2YWx1ZSBUaGUgdmFsdWUgdG8gd2hpY2ggdG8gc2V0IHRoZSBwcm9wZXJ0eVxuICovXG5mdW5jdGlvbiBhZGROb25FbnVtZXJhYmxlUHJvcGVydHkob2JqLCBuYW1lLCB2YWx1ZSkge1xuICB0cnkge1xuICAgIE9iamVjdC5kZWZpbmVQcm9wZXJ0eShvYmosIG5hbWUsIHtcbiAgICAgIC8vIGVudW1lcmFibGU6IGZhbHNlLCAvLyB0aGUgZGVmYXVsdCwgc28gd2UgY2FuIHNhdmUgb24gYnVuZGxlIHNpemUgYnkgbm90IGV4cGxpY2l0bHkgc2V0dGluZyBpdFxuICAgICAgdmFsdWU6IHZhbHVlLFxuICAgICAgd3JpdGFibGU6IHRydWUsXG4gICAgICBjb25maWd1cmFibGU6IHRydWUsXG4gICAgfSk7XG4gIH0gY2F0Y2gge1xuICAgIGRlYnVnQnVpbGQuREVCVUdfQlVJTEQgJiYgZGVidWdMb2dnZXIuZGVidWcubG9nKGBGYWlsZWQgdG8gYWRkIG5vbi1lbnVtZXJhYmxlIHByb3BlcnR5IFwiJHtuYW1lfVwiIHRvIG9iamVjdGAsIG9iaik7XG4gIH1cbn1cblxuLyoqXG4gKiBSZW1lbWJlcnMgdGhlIG9yaWdpbmFsIGZ1bmN0aW9uIG9uIHRoZSB3cmFwcGVkIGZ1bmN0aW9uIGFuZFxuICogcGF0Y2hlcyB1cCB0aGUgcHJvdG90eXBlLlxuICpcbiAqIEBwYXJhbSB3cmFwcGVkIHRoZSB3cmFwcGVyIGZ1bmN0aW9uXG4gKiBAcGFyYW0gb3JpZ2luYWwgdGhlIG9yaWdpbmFsIGZ1bmN0aW9uIHRoYXQgZ2V0cyB3cmFwcGVkXG4gKi9cbmZ1bmN0aW9uIG1hcmtGdW5jdGlvbldyYXBwZWQod3JhcHBlZCwgb3JpZ2luYWwpIHtcbiAgdHJ5IHtcbiAgICBjb25zdCBwcm90byA9IG9yaWdpbmFsLnByb3RvdHlwZSB8fCB7fTtcbiAgICB3cmFwcGVkLnByb3RvdHlwZSA9IG9yaWdpbmFsLnByb3RvdHlwZSA9IHByb3RvO1xuICAgIGFkZE5vbkVudW1lcmFibGVQcm9wZXJ0eSh3cmFwcGVkLCAnX19zZW50cnlfb3JpZ2luYWxfXycsIG9yaWdpbmFsKTtcbiAgfSBjYXRjaCB7fSAvLyBlc2xpbnQtZGlzYWJsZS1saW5lIG5vLWVtcHR5XG59XG5cbi8qKlxuICogVGhpcyBleHRyYWN0cyB0aGUgb3JpZ2luYWwgZnVuY3Rpb24gaWYgYXZhaWxhYmxlLiAgU2VlXG4gKiBgbWFya0Z1bmN0aW9uV3JhcHBlZGAgZm9yIG1vcmUgaW5mb3JtYXRpb24uXG4gKlxuICogQHBhcmFtIGZ1bmMgdGhlIGZ1bmN0aW9uIHRvIHVud3JhcFxuICogQHJldHVybnMgdGhlIHVud3JhcHBlZCB2ZXJzaW9uIG9mIHRoZSBmdW5jdGlvbiBpZiBhdmFpbGFibGUuXG4gKi9cbi8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvYmFuLXR5cGVzXG5mdW5jdGlvbiBnZXRPcmlnaW5hbEZ1bmN0aW9uKGZ1bmMpIHtcbiAgcmV0dXJuIGZ1bmMuX19zZW50cnlfb3JpZ2luYWxfXztcbn1cblxuLyoqXG4gKiBUcmFuc2Zvcm1zIGFueSBgRXJyb3JgIG9yIGBFdmVudGAgaW50byBhIHBsYWluIG9iamVjdCB3aXRoIGFsbCBvZiB0aGVpciBlbnVtZXJhYmxlIHByb3BlcnRpZXMsIGFuZCBzb21lIG9mIHRoZWlyXG4gKiBub24tZW51bWVyYWJsZSBwcm9wZXJ0aWVzIGF0dGFjaGVkLlxuICpcbiAqIEBwYXJhbSB2YWx1ZSBJbml0aWFsIHNvdXJjZSB0aGF0IHdlIGhhdmUgdG8gdHJhbnNmb3JtIGluIG9yZGVyIGZvciBpdCB0byBiZSB1c2FibGUgYnkgdGhlIHNlcmlhbGl6ZXJcbiAqIEByZXR1cm5zIEFuIEV2ZW50IG9yIEVycm9yIHR1cm5lZCBpbnRvIGFuIG9iamVjdCAtIG9yIHRoZSB2YWx1ZSBhcmd1bWVudCBpdHNlbGYsIHdoZW4gdmFsdWUgaXMgbmVpdGhlciBhbiBFdmVudCBub3JcbiAqICBhbiBFcnJvci5cbiAqL1xuZnVuY3Rpb24gY29udmVydFRvUGxhaW5PYmplY3QodmFsdWUpXG5cbiB7XG4gIGlmIChpcy5pc0Vycm9yKHZhbHVlKSkge1xuICAgIHJldHVybiB7XG4gICAgICBtZXNzYWdlOiB2YWx1ZS5tZXNzYWdlLFxuICAgICAgbmFtZTogdmFsdWUubmFtZSxcbiAgICAgIHN0YWNrOiB2YWx1ZS5zdGFjayxcbiAgICAgIC4uLmdldE93blByb3BlcnRpZXModmFsdWUpLFxuICAgIH07XG4gIH0gZWxzZSBpZiAoaXMuaXNFdmVudCh2YWx1ZSkpIHtcbiAgICBjb25zdCBuZXdPYmpcblxuID0ge1xuICAgICAgdHlwZTogdmFsdWUudHlwZSxcbiAgICAgIHRhcmdldDogc2VyaWFsaXplRXZlbnRUYXJnZXQodmFsdWUudGFyZ2V0KSxcbiAgICAgIGN1cnJlbnRUYXJnZXQ6IHNlcmlhbGl6ZUV2ZW50VGFyZ2V0KHZhbHVlLmN1cnJlbnRUYXJnZXQpLFxuICAgICAgLi4uZ2V0T3duUHJvcGVydGllcyh2YWx1ZSksXG4gICAgfTtcblxuICAgIGlmICh0eXBlb2YgQ3VzdG9tRXZlbnQgIT09ICd1bmRlZmluZWQnICYmIGlzLmlzSW5zdGFuY2VPZih2YWx1ZSwgQ3VzdG9tRXZlbnQpKSB7XG4gICAgICBuZXdPYmouZGV0YWlsID0gdmFsdWUuZGV0YWlsO1xuICAgIH1cblxuICAgIHJldHVybiBuZXdPYmo7XG4gIH0gZWxzZSB7XG4gICAgcmV0dXJuIHZhbHVlO1xuICB9XG59XG5cbi8qKiBDcmVhdGVzIGEgc3RyaW5nIHJlcHJlc2VudGF0aW9uIG9mIHRoZSB0YXJnZXQgb2YgYW4gYEV2ZW50YCBvYmplY3QgKi9cbmZ1bmN0aW9uIHNlcmlhbGl6ZUV2ZW50VGFyZ2V0KHRhcmdldCkge1xuICB0cnkge1xuICAgIHJldHVybiBpcy5pc0VsZW1lbnQodGFyZ2V0KSA/IGJyb3dzZXIuaHRtbFRyZWVBc1N0cmluZyh0YXJnZXQpIDogT2JqZWN0LnByb3RvdHlwZS50b1N0cmluZy5jYWxsKHRhcmdldCk7XG4gIH0gY2F0Y2gge1xuICAgIHJldHVybiAnPHVua25vd24+JztcbiAgfVxufVxuXG4vKiogRmlsdGVycyBvdXQgYWxsIGJ1dCBhbiBvYmplY3QncyBvd24gcHJvcGVydGllcyAqL1xuZnVuY3Rpb24gZ2V0T3duUHJvcGVydGllcyhvYmopIHtcbiAgaWYgKHR5cGVvZiBvYmogPT09ICdvYmplY3QnICYmIG9iaiAhPT0gbnVsbCkge1xuICAgIGNvbnN0IGV4dHJhY3RlZFByb3BzID0ge307XG4gICAgZm9yIChjb25zdCBwcm9wZXJ0eSBpbiBvYmopIHtcbiAgICAgIGlmIChPYmplY3QucHJvdG90eXBlLmhhc093blByb3BlcnR5LmNhbGwob2JqLCBwcm9wZXJ0eSkpIHtcbiAgICAgICAgZXh0cmFjdGVkUHJvcHNbcHJvcGVydHldID0gKG9iaiApW3Byb3BlcnR5XTtcbiAgICAgIH1cbiAgICB9XG4gICAgcmV0dXJuIGV4dHJhY3RlZFByb3BzO1xuICB9IGVsc2Uge1xuICAgIHJldHVybiB7fTtcbiAgfVxufVxuXG4vKipcbiAqIEdpdmVuIGFueSBjYXB0dXJlZCBleGNlcHRpb24sIGV4dHJhY3QgaXRzIGtleXMgYW5kIGNyZWF0ZSBhIHNvcnRlZFxuICogYW5kIHRydW5jYXRlZCBsaXN0IHRoYXQgd2lsbCBiZSB1c2VkIGluc2lkZSB0aGUgZXZlbnQgbWVzc2FnZS5cbiAqIGVnLiBgTm9uLWVycm9yIGV4Y2VwdGlvbiBjYXB0dXJlZCB3aXRoIGtleXM6IGZvbywgYmFyLCBiYXpgXG4gKi9cbmZ1bmN0aW9uIGV4dHJhY3RFeGNlcHRpb25LZXlzRm9yTWVzc2FnZShleGNlcHRpb24sIG1heExlbmd0aCA9IDQwKSB7XG4gIGNvbnN0IGtleXMgPSBPYmplY3Qua2V5cyhjb252ZXJ0VG9QbGFpbk9iamVjdChleGNlcHRpb24pKTtcbiAga2V5cy5zb3J0KCk7XG5cbiAgY29uc3QgZmlyc3RLZXkgPSBrZXlzWzBdO1xuXG4gIGlmICghZmlyc3RLZXkpIHtcbiAgICByZXR1cm4gJ1tvYmplY3QgaGFzIG5vIGtleXNdJztcbiAgfVxuXG4gIGlmIChmaXJzdEtleS5sZW5ndGggPj0gbWF4TGVuZ3RoKSB7XG4gICAgcmV0dXJuIHN0cmluZy50cnVuY2F0ZShmaXJzdEtleSwgbWF4TGVuZ3RoKTtcbiAgfVxuXG4gIGZvciAobGV0IGluY2x1ZGVkS2V5cyA9IGtleXMubGVuZ3RoOyBpbmNsdWRlZEtleXMgPiAwOyBpbmNsdWRlZEtleXMtLSkge1xuICAgIGNvbnN0IHNlcmlhbGl6ZWQgPSBrZXlzLnNsaWNlKDAsIGluY2x1ZGVkS2V5cykuam9pbignLCAnKTtcbiAgICBpZiAoc2VyaWFsaXplZC5sZW5ndGggPiBtYXhMZW5ndGgpIHtcbiAgICAgIGNvbnRpbnVlO1xuICAgIH1cbiAgICBpZiAoaW5jbHVkZWRLZXlzID09PSBrZXlzLmxlbmd0aCkge1xuICAgICAgcmV0dXJuIHNlcmlhbGl6ZWQ7XG4gICAgfVxuICAgIHJldHVybiBzdHJpbmcudHJ1bmNhdGUoc2VyaWFsaXplZCwgbWF4TGVuZ3RoKTtcbiAgfVxuXG4gIHJldHVybiAnJztcbn1cblxuLyoqXG4gKiBHaXZlbiBhbnkgb2JqZWN0LCByZXR1cm4gYSBuZXcgb2JqZWN0IGhhdmluZyByZW1vdmVkIGFsbCBmaWVsZHMgd2hvc2UgdmFsdWUgd2FzIGB1bmRlZmluZWRgLlxuICogV29ya3MgcmVjdXJzaXZlbHkgb24gb2JqZWN0cyBhbmQgYXJyYXlzLlxuICpcbiAqIEF0dGVudGlvbjogVGhpcyBmdW5jdGlvbiBrZWVwcyBjaXJjdWxhciByZWZlcmVuY2VzIGluIHRoZSByZXR1cm5lZCBvYmplY3QuXG4gKlxuICogQGRlcHJlY2F0ZWQgVGhpcyBmdW5jdGlvbiBpcyBubyBsb25nZXIgdXNlZCBieSB0aGUgU0RLIGFuZCB3aWxsIGJlIHJlbW92ZWQgaW4gYSBmdXR1cmUgbWFqb3IgdmVyc2lvbi5cbiAqL1xuZnVuY3Rpb24gZHJvcFVuZGVmaW5lZEtleXMoaW5wdXRWYWx1ZSkge1xuICAvLyBUaGlzIG1hcCBrZWVwcyB0cmFjayBvZiB3aGF0IGFscmVhZHkgdmlzaXRlZCBub2RlcyBtYXAgdG8uXG4gIC8vIE91ciBTZXQgLSBiYXNlZCBtZW1vQnVpbGRlciBkb2Vzbid0IHdvcmsgaGVyZSBiZWNhdXNlIHdlIHdhbnQgdG8gdGhlIG91dHB1dCBvYmplY3QgdG8gaGF2ZSB0aGUgc2FtZSBjaXJjdWxhclxuICAvLyByZWZlcmVuY2VzIGFzIHRoZSBpbnB1dCBvYmplY3QuXG4gIGNvbnN0IG1lbW9pemF0aW9uTWFwID0gbmV3IE1hcCgpO1xuXG4gIC8vIFRoaXMgZnVuY3Rpb24ganVzdCBwcm94aWVzIGBfZHJvcFVuZGVmaW5lZEtleXNgIHRvIGtlZXAgdGhlIGBtZW1vQnVpbGRlcmAgb3V0IG9mIHRoaXMgZnVuY3Rpb24ncyBBUElcbiAgcmV0dXJuIF9kcm9wVW5kZWZpbmVkS2V5cyhpbnB1dFZhbHVlLCBtZW1vaXphdGlvbk1hcCk7XG59XG5cbmZ1bmN0aW9uIF9kcm9wVW5kZWZpbmVkS2V5cyhpbnB1dFZhbHVlLCBtZW1vaXphdGlvbk1hcCkge1xuICAvLyBFYXJseSByZXR1cm4gZm9yIHByaW1pdGl2ZSB2YWx1ZXNcbiAgaWYgKGlucHV0VmFsdWUgPT09IG51bGwgfHwgdHlwZW9mIGlucHV0VmFsdWUgIT09ICdvYmplY3QnKSB7XG4gICAgcmV0dXJuIGlucHV0VmFsdWU7XG4gIH1cblxuICAvLyBDaGVjayBtZW1vIG1hcCBmaXJzdCBmb3IgYWxsIG9iamVjdCB0eXBlc1xuICBjb25zdCBtZW1vVmFsID0gbWVtb2l6YXRpb25NYXAuZ2V0KGlucHV0VmFsdWUpO1xuICBpZiAobWVtb1ZhbCAhPT0gdW5kZWZpbmVkKSB7XG4gICAgcmV0dXJuIG1lbW9WYWwgO1xuICB9XG5cbiAgLy8gaGFuZGxlIGFycmF5c1xuICBpZiAoQXJyYXkuaXNBcnJheShpbnB1dFZhbHVlKSkge1xuICAgIGNvbnN0IHJldHVyblZhbHVlID0gW107XG4gICAgLy8gU3RvcmUgbWFwcGluZyB0byBoYW5kbGUgY2lyY3VsYXIgcmVmZXJlbmNlc1xuICAgIG1lbW9pemF0aW9uTWFwLnNldChpbnB1dFZhbHVlLCByZXR1cm5WYWx1ZSk7XG5cbiAgICBpbnB1dFZhbHVlLmZvckVhY2godmFsdWUgPT4ge1xuICAgICAgcmV0dXJuVmFsdWUucHVzaChfZHJvcFVuZGVmaW5lZEtleXModmFsdWUsIG1lbW9pemF0aW9uTWFwKSk7XG4gICAgfSk7XG5cbiAgICByZXR1cm4gcmV0dXJuVmFsdWUgO1xuICB9XG5cbiAgaWYgKGlzUG9qbyhpbnB1dFZhbHVlKSkge1xuICAgIGNvbnN0IHJldHVyblZhbHVlID0ge307XG4gICAgLy8gU3RvcmUgbWFwcGluZyB0byBoYW5kbGUgY2lyY3VsYXIgcmVmZXJlbmNlc1xuICAgIG1lbW9pemF0aW9uTWFwLnNldChpbnB1dFZhbHVlLCByZXR1cm5WYWx1ZSk7XG5cbiAgICBjb25zdCBrZXlzID0gT2JqZWN0LmtleXMoaW5wdXRWYWx1ZSk7XG5cbiAgICBrZXlzLmZvckVhY2goa2V5ID0+IHtcbiAgICAgIGNvbnN0IHZhbCA9IGlucHV0VmFsdWVba2V5XTtcbiAgICAgIGlmICh2YWwgIT09IHVuZGVmaW5lZCkge1xuICAgICAgICByZXR1cm5WYWx1ZVtrZXldID0gX2Ryb3BVbmRlZmluZWRLZXlzKHZhbCwgbWVtb2l6YXRpb25NYXApO1xuICAgICAgfVxuICAgIH0pO1xuXG4gICAgcmV0dXJuIHJldHVyblZhbHVlIDtcbiAgfVxuXG4gIC8vIEZvciBvdGhlciBvYmplY3QgdHlwZXMsIHJldHVybiBhcyBpc1xuICByZXR1cm4gaW5wdXRWYWx1ZTtcbn1cblxuZnVuY3Rpb24gaXNQb2pvKGlucHV0KSB7XG4gIC8vIFBsYWluIG9iamVjdHMgaGF2ZSBPYmplY3QgYXMgY29uc3RydWN0b3Igb3Igbm8gY29uc3RydWN0b3JcbiAgY29uc3QgY29uc3RydWN0b3IgPSAoaW5wdXQgKS5jb25zdHJ1Y3RvcjtcbiAgcmV0dXJuIGNvbnN0cnVjdG9yID09PSBPYmplY3QgfHwgY29uc3RydWN0b3IgPT09IHVuZGVmaW5lZDtcbn1cblxuLyoqXG4gKiBFbnN1cmUgdGhhdCBzb21ldGhpbmcgaXMgYW4gb2JqZWN0LlxuICpcbiAqIFR1cm5zIGB1bmRlZmluZWRgIGFuZCBgbnVsbGAgaW50byBgU3RyaW5nYHMgYW5kIGFsbCBvdGhlciBwcmltaXRpdmVzIGludG8gaW5zdGFuY2VzIG9mIHRoZWlyIHJlc3BlY3RpdmUgd3JhcHBlclxuICogY2xhc3NlcyAoU3RyaW5nLCBCb29sZWFuLCBOdW1iZXIsIGV0Yy4pLiBBY3RzIGFzIHRoZSBpZGVudGl0eSBmdW5jdGlvbiBvbiBub24tcHJpbWl0aXZlcy5cbiAqXG4gKiBAcGFyYW0gd2F0IFRoZSBzdWJqZWN0IG9mIHRoZSBvYmplY3RpZmljYXRpb25cbiAqIEByZXR1cm5zIEEgdmVyc2lvbiBvZiBgd2F0YCB3aGljaCBjYW4gc2FmZWx5IGJlIHVzZWQgd2l0aCBgT2JqZWN0YCBjbGFzcyBtZXRob2RzXG4gKi9cbmZ1bmN0aW9uIG9iamVjdGlmeSh3YXQpIHtcbiAgbGV0IG9iamVjdGlmaWVkO1xuICBzd2l0Y2ggKHRydWUpIHtcbiAgICAvLyB0aGlzIHdpbGwgY2F0Y2ggYm90aCB1bmRlZmluZWQgYW5kIG51bGxcbiAgICBjYXNlIHdhdCA9PSB1bmRlZmluZWQ6XG4gICAgICBvYmplY3RpZmllZCA9IG5ldyBTdHJpbmcod2F0KTtcbiAgICAgIGJyZWFrO1xuXG4gICAgLy8gVGhvdWdoIHN5bWJvbHMgYW5kIGJpZ2ludHMgZG8gaGF2ZSB3cmFwcGVyIGNsYXNzZXMgKGBTeW1ib2xgIGFuZCBgQmlnSW50YCwgcmVzcGVjdGl2ZWx5KSwgZm9yIHdoYXRldmVyIHJlYXNvblxuICAgIC8vIHRob3NlIGNsYXNzZXMgZG9uJ3QgaGF2ZSBjb25zdHJ1Y3RvcnMgd2hpY2ggY2FuIGJlIHVzZWQgd2l0aCB0aGUgYG5ld2Aga2V5d29yZC4gV2UgdGhlcmVmb3JlIG5lZWQgdG8gY2FzdCBlYWNoIGFzXG4gICAgLy8gYW4gb2JqZWN0IGluIG9yZGVyIHRvIHdyYXAgaXQuXG4gICAgY2FzZSB0eXBlb2Ygd2F0ID09PSAnc3ltYm9sJyB8fCB0eXBlb2Ygd2F0ID09PSAnYmlnaW50JzpcbiAgICAgIG9iamVjdGlmaWVkID0gT2JqZWN0KHdhdCk7XG4gICAgICBicmVhaztcblxuICAgIC8vIHRoaXMgd2lsbCBjYXRjaCB0aGUgcmVtYWluaW5nIHByaW1pdGl2ZXM6IGBTdHJpbmdgLCBgTnVtYmVyYCwgYW5kIGBCb29sZWFuYFxuICAgIGNhc2UgaXMuaXNQcmltaXRpdmUod2F0KTpcbiAgICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tdW5zYWZlLW1lbWJlci1hY2Nlc3NcbiAgICAgIG9iamVjdGlmaWVkID0gbmV3ICh3YXQgKS5jb25zdHJ1Y3Rvcih3YXQpO1xuICAgICAgYnJlYWs7XG5cbiAgICAvLyBieSBwcm9jZXNzIG9mIGVsaW1pbmF0aW9uLCBhdCB0aGlzIHBvaW50IHdlIGtub3cgdGhhdCBgd2F0YCBtdXN0IGFscmVhZHkgYmUgYW4gb2JqZWN0XG4gICAgZGVmYXVsdDpcbiAgICAgIG9iamVjdGlmaWVkID0gd2F0O1xuICAgICAgYnJlYWs7XG4gIH1cbiAgcmV0dXJuIG9iamVjdGlmaWVkO1xufVxuXG5leHBvcnRzLmFkZE5vbkVudW1lcmFibGVQcm9wZXJ0eSA9IGFkZE5vbkVudW1lcmFibGVQcm9wZXJ0eTtcbmV4cG9ydHMuY29udmVydFRvUGxhaW5PYmplY3QgPSBjb252ZXJ0VG9QbGFpbk9iamVjdDtcbmV4cG9ydHMuZHJvcFVuZGVmaW5lZEtleXMgPSBkcm9wVW5kZWZpbmVkS2V5cztcbmV4cG9ydHMuZXh0cmFjdEV4Y2VwdGlvbktleXNGb3JNZXNzYWdlID0gZXh0cmFjdEV4Y2VwdGlvbktleXNGb3JNZXNzYWdlO1xuZXhwb3J0cy5maWxsID0gZmlsbDtcbmV4cG9ydHMuZ2V0T3JpZ2luYWxGdW5jdGlvbiA9IGdldE9yaWdpbmFsRnVuY3Rpb247XG5leHBvcnRzLm1hcmtGdW5jdGlvbldyYXBwZWQgPSBtYXJrRnVuY3Rpb25XcmFwcGVkO1xuZXhwb3J0cy5vYmplY3RpZnkgPSBvYmplY3RpZnk7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1vYmplY3QuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/object.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/openai/constants.js":
/*!**************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/openai/constants.js ***!
  \**************************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst OPENAI_INTEGRATION_NAME = 'OpenAI';\n\n// https://platform.openai.com/docs/quickstart?api-mode=responses\n// https://platform.openai.com/docs/quickstart?api-mode=chat\nconst INSTRUMENTED_METHODS = ['responses.create', 'chat.completions.create'] ;\n\nexports.INSTRUMENTED_METHODS = INSTRUMENTED_METHODS;\nexports.OPENAI_INTEGRATION_NAME = OPENAI_INTEGRATION_NAME;\n//# sourceMappingURL=constants.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9vcGVuYWkvY29uc3RhbnRzLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFOztBQUVBO0FBQ0E7QUFDQTs7QUFFQSw0QkFBNEI7QUFDNUIsK0JBQStCO0FBQy9CIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvb3BlbmFpL2NvbnN0YW50cy5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgT1BFTkFJX0lOVEVHUkFUSU9OX05BTUUgPSAnT3BlbkFJJztcblxuLy8gaHR0cHM6Ly9wbGF0Zm9ybS5vcGVuYWkuY29tL2RvY3MvcXVpY2tzdGFydD9hcGktbW9kZT1yZXNwb25zZXNcbi8vIGh0dHBzOi8vcGxhdGZvcm0ub3BlbmFpLmNvbS9kb2NzL3F1aWNrc3RhcnQ/YXBpLW1vZGU9Y2hhdFxuY29uc3QgSU5TVFJVTUVOVEVEX01FVEhPRFMgPSBbJ3Jlc3BvbnNlcy5jcmVhdGUnLCAnY2hhdC5jb21wbGV0aW9ucy5jcmVhdGUnXSA7XG5cbmV4cG9ydHMuSU5TVFJVTUVOVEVEX01FVEhPRFMgPSBJTlNUUlVNRU5URURfTUVUSE9EUztcbmV4cG9ydHMuT1BFTkFJX0lOVEVHUkFUSU9OX05BTUUgPSBPUEVOQUlfSU5URUdSQVRJT05fTkFNRTtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWNvbnN0YW50cy5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/openai/constants.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/openai/index.js":
/*!**********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/openai/index.js ***!
  \**********************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst currentScopes = __webpack_require__(/*! ../../currentScopes.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst exports$1 = __webpack_require__(/*! ../../exports.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/exports.js\");\nconst trace = __webpack_require__(/*! ../../tracing/trace.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/trace.js\");\nconst genAiAttributes = __webpack_require__(/*! ../gen-ai-attributes.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/gen-ai-attributes.js\");\nconst constants = __webpack_require__(/*! ./constants.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/openai/constants.js\");\nconst utils = __webpack_require__(/*! ./utils.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/openai/utils.js\");\n\n/**\n * Extract request attributes from method arguments\n */\nfunction extractRequestAttributes(args, methodPath) {\n  const attributes = {\n    [genAiAttributes.GEN_AI_SYSTEM_ATTRIBUTE]: 'openai',\n    [genAiAttributes.GEN_AI_OPERATION_NAME_ATTRIBUTE]: utils.getOperationName(methodPath),\n  };\n\n  if (args.length > 0 && typeof args[0] === 'object' && args[0] !== null) {\n    const params = args[0] ;\n\n    attributes[genAiAttributes.GEN_AI_REQUEST_MODEL_ATTRIBUTE] = params.model ?? 'unknown';\n    if ('temperature' in params) attributes[genAiAttributes.GEN_AI_REQUEST_TEMPERATURE_ATTRIBUTE] = params.temperature;\n    if ('top_p' in params) attributes[genAiAttributes.GEN_AI_REQUEST_TOP_P_ATTRIBUTE] = params.top_p;\n    if ('frequency_penalty' in params)\n      attributes[genAiAttributes.GEN_AI_REQUEST_FREQUENCY_PENALTY_ATTRIBUTE] = params.frequency_penalty;\n    if ('presence_penalty' in params) attributes[genAiAttributes.GEN_AI_REQUEST_PRESENCE_PENALTY_ATTRIBUTE] = params.presence_penalty;\n  } else {\n    attributes[genAiAttributes.GEN_AI_REQUEST_MODEL_ATTRIBUTE] = 'unknown';\n  }\n\n  return attributes;\n}\n\n/**\n * Helper function to set token usage attributes\n */\nfunction setTokenUsageAttributes(\n  span,\n  promptTokens,\n  completionTokens,\n  totalTokens,\n) {\n  if (promptTokens !== undefined) {\n    span.setAttributes({\n      [genAiAttributes.OPENAI_USAGE_PROMPT_TOKENS_ATTRIBUTE]: promptTokens,\n      [genAiAttributes.GEN_AI_USAGE_INPUT_TOKENS_ATTRIBUTE]: promptTokens,\n    });\n  }\n  if (completionTokens !== undefined) {\n    span.setAttributes({\n      [genAiAttributes.OPENAI_USAGE_COMPLETION_TOKENS_ATTRIBUTE]: completionTokens,\n      [genAiAttributes.GEN_AI_USAGE_OUTPUT_TOKENS_ATTRIBUTE]: completionTokens,\n    });\n  }\n  if (totalTokens !== undefined) {\n    span.setAttributes({\n      [genAiAttributes.GEN_AI_USAGE_TOTAL_TOKENS_ATTRIBUTE]: totalTokens,\n    });\n  }\n}\n\n/**\n * Helper function to set common response attributes (ID, model, timestamp)\n */\nfunction setCommonResponseAttributes(span, id, model, timestamp) {\n  if (id) {\n    span.setAttributes({\n      [genAiAttributes.OPENAI_RESPONSE_ID_ATTRIBUTE]: id,\n      [genAiAttributes.GEN_AI_RESPONSE_ID_ATTRIBUTE]: id,\n    });\n  }\n  if (model) {\n    span.setAttributes({\n      [genAiAttributes.OPENAI_RESPONSE_MODEL_ATTRIBUTE]: model,\n      [genAiAttributes.GEN_AI_RESPONSE_MODEL_ATTRIBUTE]: model,\n    });\n  }\n  if (timestamp) {\n    span.setAttributes({\n      [genAiAttributes.OPENAI_RESPONSE_TIMESTAMP_ATTRIBUTE]: new Date(timestamp * 1000).toISOString(),\n    });\n  }\n}\n\n/**\n * Add attributes for Chat Completion responses\n */\nfunction addChatCompletionAttributes(span, response) {\n  setCommonResponseAttributes(span, response.id, response.model, response.created);\n  if (response.usage) {\n    setTokenUsageAttributes(\n      span,\n      response.usage.prompt_tokens,\n      response.usage.completion_tokens,\n      response.usage.total_tokens,\n    );\n  }\n  if (Array.isArray(response.choices)) {\n    const finishReasons = response.choices\n      .map(choice => choice.finish_reason)\n      .filter((reason) => reason !== null);\n    if (finishReasons.length > 0) {\n      span.setAttributes({\n        [genAiAttributes.GEN_AI_RESPONSE_FINISH_REASONS_ATTRIBUTE]: JSON.stringify(finishReasons),\n      });\n    }\n  }\n}\n\n/**\n * Add attributes for Responses API responses\n */\nfunction addResponsesApiAttributes(span, response) {\n  setCommonResponseAttributes(span, response.id, response.model, response.created_at);\n  if (response.status) {\n    span.setAttributes({\n      [genAiAttributes.GEN_AI_RESPONSE_FINISH_REASONS_ATTRIBUTE]: JSON.stringify([response.status]),\n    });\n  }\n  if (response.usage) {\n    setTokenUsageAttributes(\n      span,\n      response.usage.input_tokens,\n      response.usage.output_tokens,\n      response.usage.total_tokens,\n    );\n  }\n}\n\n/**\n * Add response attributes to spans\n * This currently supports both Chat Completion and Responses API responses\n */\nfunction addResponseAttributes(span, result, recordOutputs) {\n  if (!result || typeof result !== 'object') return;\n\n  const response = result ;\n\n  if (utils.isChatCompletionResponse(response)) {\n    addChatCompletionAttributes(span, response);\n    if (recordOutputs && response.choices?.length) {\n      const responseTexts = response.choices.map(choice => choice.message?.content || '');\n      span.setAttributes({ [genAiAttributes.GEN_AI_RESPONSE_TEXT_ATTRIBUTE]: JSON.stringify(responseTexts) });\n    }\n  } else if (utils.isResponsesApiResponse(response)) {\n    addResponsesApiAttributes(span, response);\n    if (recordOutputs && response.output_text) {\n      span.setAttributes({ [genAiAttributes.GEN_AI_RESPONSE_TEXT_ATTRIBUTE]: response.output_text });\n    }\n  }\n}\n\n// Extract and record AI request inputs, if present. This is intentionally separate from response attributes.\nfunction addRequestAttributes(span, params) {\n  if ('messages' in params) {\n    span.setAttributes({ [genAiAttributes.GEN_AI_REQUEST_MESSAGES_ATTRIBUTE]: JSON.stringify(params.messages) });\n  }\n  if ('input' in params) {\n    span.setAttributes({ [genAiAttributes.GEN_AI_REQUEST_MESSAGES_ATTRIBUTE]: JSON.stringify(params.input) });\n  }\n}\n\nfunction getOptionsFromIntegration() {\n  const scope = currentScopes.getCurrentScope();\n  const client = scope.getClient();\n  const integration = client?.getIntegrationByName(constants.OPENAI_INTEGRATION_NAME) ;\n  const shouldRecordInputsAndOutputs = integration ? Boolean(client?.getOptions().sendDefaultPii) : false;\n\n  return {\n    recordInputs: integration?.options?.recordInputs ?? shouldRecordInputsAndOutputs,\n    recordOutputs: integration?.options?.recordOutputs ?? shouldRecordInputsAndOutputs,\n  };\n}\n\n/**\n * Instrument a method with Sentry spans\n * Following Sentry AI Agents Manual Instrumentation conventions\n * @see https://docs.sentry.io/platforms/javascript/guides/node/tracing/instrumentation/ai-agents-module/#manual-instrumentation\n */\nfunction instrumentMethod(\n  originalMethod,\n  methodPath,\n  context,\n  options,\n) {\n  return async function instrumentedMethod(...args) {\n    const finalOptions = options || getOptionsFromIntegration();\n    const requestAttributes = extractRequestAttributes(args, methodPath);\n    const model = (requestAttributes[genAiAttributes.GEN_AI_REQUEST_MODEL_ATTRIBUTE] ) || 'unknown';\n    const operationName = utils.getOperationName(methodPath);\n\n    return trace.startSpan(\n      {\n        name: `${operationName} ${model}`,\n        op: utils.getSpanOperation(methodPath),\n        attributes: requestAttributes ,\n      },\n      async (span) => {\n        try {\n          if (finalOptions.recordInputs && args[0] && typeof args[0] === 'object') {\n            addRequestAttributes(span, args[0] );\n          }\n\n          const result = await originalMethod.apply(context, args);\n          // TODO: Add streaming support\n          addResponseAttributes(span, result, finalOptions.recordOutputs);\n          return result;\n        } catch (error) {\n          exports$1.captureException(error);\n          throw error;\n        }\n      },\n    );\n  };\n}\n\n/**\n * Create a deep proxy for OpenAI client instrumentation\n */\nfunction createDeepProxy(target, currentPath = '', options) {\n  return new Proxy(target, {\n    get(obj, prop) {\n      const value = (obj )[prop];\n      const methodPath = utils.buildMethodPath(currentPath, String(prop));\n\n      if (typeof value === 'function' && utils.shouldInstrument(methodPath)) {\n        return instrumentMethod(value , methodPath, obj, options);\n      }\n\n      if (typeof value === 'function') {\n        // Bind non-instrumented functions to preserve the original `this` context,\n        // which is required for accessing private class fields (e.g. #baseURL) in OpenAI SDK v5.\n        return value.bind(obj);\n      }\n\n      if (value && typeof value === 'object') {\n        return createDeepProxy(value , methodPath, options);\n      }\n\n      return value;\n    },\n  });\n}\n\n/**\n * Instrument an OpenAI client with Sentry tracing\n * Can be used across Node.js, Cloudflare Workers, and Vercel Edge\n */\nfunction instrumentOpenAiClient(client, options) {\n  return createDeepProxy(client, '', options);\n}\n\nexports.instrumentOpenAiClient = instrumentOpenAiClient;\n//# sourceMappingURL=index.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9vcGVuYWkvaW5kZXguanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsc0JBQXNCLG1CQUFPLENBQUMsbUlBQXdCO0FBQ3RELGtCQUFrQixtQkFBTyxDQUFDLHVIQUFrQjtBQUM1QyxjQUFjLG1CQUFPLENBQUMsbUlBQXdCO0FBQzlDLHdCQUF3QixtQkFBTyxDQUFDLDhJQUF5QjtBQUN6RCxrQkFBa0IsbUJBQU8sQ0FBQyxvSUFBZ0I7QUFDMUMsY0FBYyxtQkFBTyxDQUFDLDRIQUFZOztBQUVsQztBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsSUFBSTtBQUNKO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEtBQUs7QUFDTDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsS0FBSztBQUNMO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsS0FBSztBQUNMO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEtBQUs7QUFDTDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsS0FBSztBQUNMO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsS0FBSztBQUNMO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLE9BQU87QUFDUDtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEtBQUs7QUFDTDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQSwyQkFBMkIsaUZBQWlGO0FBQzVHO0FBQ0EsSUFBSTtBQUNKO0FBQ0E7QUFDQSwyQkFBMkIsd0VBQXdFO0FBQ25HO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQSx5QkFBeUIsc0ZBQXNGO0FBQy9HO0FBQ0E7QUFDQSx5QkFBeUIsbUZBQW1GO0FBQzVHO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQSxpQkFBaUIsZUFBZSxFQUFFLE1BQU07QUFDeEM7QUFDQTtBQUNBLE9BQU87QUFDUDtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsVUFBVTtBQUNWO0FBQ0E7QUFDQTtBQUNBLE9BQU87QUFDUDtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQSxLQUFLO0FBQ0wsR0FBRztBQUNIOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLDhCQUE4QjtBQUM5QiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3V0aWxzL29wZW5haS9pbmRleC5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgY3VycmVudFNjb3BlcyA9IHJlcXVpcmUoJy4uLy4uL2N1cnJlbnRTY29wZXMuanMnKTtcbmNvbnN0IGV4cG9ydHMkMSA9IHJlcXVpcmUoJy4uLy4uL2V4cG9ydHMuanMnKTtcbmNvbnN0IHRyYWNlID0gcmVxdWlyZSgnLi4vLi4vdHJhY2luZy90cmFjZS5qcycpO1xuY29uc3QgZ2VuQWlBdHRyaWJ1dGVzID0gcmVxdWlyZSgnLi4vZ2VuLWFpLWF0dHJpYnV0ZXMuanMnKTtcbmNvbnN0IGNvbnN0YW50cyA9IHJlcXVpcmUoJy4vY29uc3RhbnRzLmpzJyk7XG5jb25zdCB1dGlscyA9IHJlcXVpcmUoJy4vdXRpbHMuanMnKTtcblxuLyoqXG4gKiBFeHRyYWN0IHJlcXVlc3QgYXR0cmlidXRlcyBmcm9tIG1ldGhvZCBhcmd1bWVudHNcbiAqL1xuZnVuY3Rpb24gZXh0cmFjdFJlcXVlc3RBdHRyaWJ1dGVzKGFyZ3MsIG1ldGhvZFBhdGgpIHtcbiAgY29uc3QgYXR0cmlidXRlcyA9IHtcbiAgICBbZ2VuQWlBdHRyaWJ1dGVzLkdFTl9BSV9TWVNURU1fQVRUUklCVVRFXTogJ29wZW5haScsXG4gICAgW2dlbkFpQXR0cmlidXRlcy5HRU5fQUlfT1BFUkFUSU9OX05BTUVfQVRUUklCVVRFXTogdXRpbHMuZ2V0T3BlcmF0aW9uTmFtZShtZXRob2RQYXRoKSxcbiAgfTtcblxuICBpZiAoYXJncy5sZW5ndGggPiAwICYmIHR5cGVvZiBhcmdzWzBdID09PSAnb2JqZWN0JyAmJiBhcmdzWzBdICE9PSBudWxsKSB7XG4gICAgY29uc3QgcGFyYW1zID0gYXJnc1swXSA7XG5cbiAgICBhdHRyaWJ1dGVzW2dlbkFpQXR0cmlidXRlcy5HRU5fQUlfUkVRVUVTVF9NT0RFTF9BVFRSSUJVVEVdID0gcGFyYW1zLm1vZGVsID8/ICd1bmtub3duJztcbiAgICBpZiAoJ3RlbXBlcmF0dXJlJyBpbiBwYXJhbXMpIGF0dHJpYnV0ZXNbZ2VuQWlBdHRyaWJ1dGVzLkdFTl9BSV9SRVFVRVNUX1RFTVBFUkFUVVJFX0FUVFJJQlVURV0gPSBwYXJhbXMudGVtcGVyYXR1cmU7XG4gICAgaWYgKCd0b3BfcCcgaW4gcGFyYW1zKSBhdHRyaWJ1dGVzW2dlbkFpQXR0cmlidXRlcy5HRU5fQUlfUkVRVUVTVF9UT1BfUF9BVFRSSUJVVEVdID0gcGFyYW1zLnRvcF9wO1xuICAgIGlmICgnZnJlcXVlbmN5X3BlbmFsdHknIGluIHBhcmFtcylcbiAgICAgIGF0dHJpYnV0ZXNbZ2VuQWlBdHRyaWJ1dGVzLkdFTl9BSV9SRVFVRVNUX0ZSRVFVRU5DWV9QRU5BTFRZX0FUVFJJQlVURV0gPSBwYXJhbXMuZnJlcXVlbmN5X3BlbmFsdHk7XG4gICAgaWYgKCdwcmVzZW5jZV9wZW5hbHR5JyBpbiBwYXJhbXMpIGF0dHJpYnV0ZXNbZ2VuQWlBdHRyaWJ1dGVzLkdFTl9BSV9SRVFVRVNUX1BSRVNFTkNFX1BFTkFMVFlfQVRUUklCVVRFXSA9IHBhcmFtcy5wcmVzZW5jZV9wZW5hbHR5O1xuICB9IGVsc2Uge1xuICAgIGF0dHJpYnV0ZXNbZ2VuQWlBdHRyaWJ1dGVzLkdFTl9BSV9SRVFVRVNUX01PREVMX0FUVFJJQlVURV0gPSAndW5rbm93bic7XG4gIH1cblxuICByZXR1cm4gYXR0cmlidXRlcztcbn1cblxuLyoqXG4gKiBIZWxwZXIgZnVuY3Rpb24gdG8gc2V0IHRva2VuIHVzYWdlIGF0dHJpYnV0ZXNcbiAqL1xuZnVuY3Rpb24gc2V0VG9rZW5Vc2FnZUF0dHJpYnV0ZXMoXG4gIHNwYW4sXG4gIHByb21wdFRva2VucyxcbiAgY29tcGxldGlvblRva2VucyxcbiAgdG90YWxUb2tlbnMsXG4pIHtcbiAgaWYgKHByb21wdFRva2VucyAhPT0gdW5kZWZpbmVkKSB7XG4gICAgc3Bhbi5zZXRBdHRyaWJ1dGVzKHtcbiAgICAgIFtnZW5BaUF0dHJpYnV0ZXMuT1BFTkFJX1VTQUdFX1BST01QVF9UT0tFTlNfQVRUUklCVVRFXTogcHJvbXB0VG9rZW5zLFxuICAgICAgW2dlbkFpQXR0cmlidXRlcy5HRU5fQUlfVVNBR0VfSU5QVVRfVE9LRU5TX0FUVFJJQlVURV06IHByb21wdFRva2VucyxcbiAgICB9KTtcbiAgfVxuICBpZiAoY29tcGxldGlvblRva2VucyAhPT0gdW5kZWZpbmVkKSB7XG4gICAgc3Bhbi5zZXRBdHRyaWJ1dGVzKHtcbiAgICAgIFtnZW5BaUF0dHJpYnV0ZXMuT1BFTkFJX1VTQUdFX0NPTVBMRVRJT05fVE9LRU5TX0FUVFJJQlVURV06IGNvbXBsZXRpb25Ub2tlbnMsXG4gICAgICBbZ2VuQWlBdHRyaWJ1dGVzLkdFTl9BSV9VU0FHRV9PVVRQVVRfVE9LRU5TX0FUVFJJQlVURV06IGNvbXBsZXRpb25Ub2tlbnMsXG4gICAgfSk7XG4gIH1cbiAgaWYgKHRvdGFsVG9rZW5zICE9PSB1bmRlZmluZWQpIHtcbiAgICBzcGFuLnNldEF0dHJpYnV0ZXMoe1xuICAgICAgW2dlbkFpQXR0cmlidXRlcy5HRU5fQUlfVVNBR0VfVE9UQUxfVE9LRU5TX0FUVFJJQlVURV06IHRvdGFsVG9rZW5zLFxuICAgIH0pO1xuICB9XG59XG5cbi8qKlxuICogSGVscGVyIGZ1bmN0aW9uIHRvIHNldCBjb21tb24gcmVzcG9uc2UgYXR0cmlidXRlcyAoSUQsIG1vZGVsLCB0aW1lc3RhbXApXG4gKi9cbmZ1bmN0aW9uIHNldENvbW1vblJlc3BvbnNlQXR0cmlidXRlcyhzcGFuLCBpZCwgbW9kZWwsIHRpbWVzdGFtcCkge1xuICBpZiAoaWQpIHtcbiAgICBzcGFuLnNldEF0dHJpYnV0ZXMoe1xuICAgICAgW2dlbkFpQXR0cmlidXRlcy5PUEVOQUlfUkVTUE9OU0VfSURfQVRUUklCVVRFXTogaWQsXG4gICAgICBbZ2VuQWlBdHRyaWJ1dGVzLkdFTl9BSV9SRVNQT05TRV9JRF9BVFRSSUJVVEVdOiBpZCxcbiAgICB9KTtcbiAgfVxuICBpZiAobW9kZWwpIHtcbiAgICBzcGFuLnNldEF0dHJpYnV0ZXMoe1xuICAgICAgW2dlbkFpQXR0cmlidXRlcy5PUEVOQUlfUkVTUE9OU0VfTU9ERUxfQVRUUklCVVRFXTogbW9kZWwsXG4gICAgICBbZ2VuQWlBdHRyaWJ1dGVzLkdFTl9BSV9SRVNQT05TRV9NT0RFTF9BVFRSSUJVVEVdOiBtb2RlbCxcbiAgICB9KTtcbiAgfVxuICBpZiAodGltZXN0YW1wKSB7XG4gICAgc3Bhbi5zZXRBdHRyaWJ1dGVzKHtcbiAgICAgIFtnZW5BaUF0dHJpYnV0ZXMuT1BFTkFJX1JFU1BPTlNFX1RJTUVTVEFNUF9BVFRSSUJVVEVdOiBuZXcgRGF0ZSh0aW1lc3RhbXAgKiAxMDAwKS50b0lTT1N0cmluZygpLFxuICAgIH0pO1xuICB9XG59XG5cbi8qKlxuICogQWRkIGF0dHJpYnV0ZXMgZm9yIENoYXQgQ29tcGxldGlvbiByZXNwb25zZXNcbiAqL1xuZnVuY3Rpb24gYWRkQ2hhdENvbXBsZXRpb25BdHRyaWJ1dGVzKHNwYW4sIHJlc3BvbnNlKSB7XG4gIHNldENvbW1vblJlc3BvbnNlQXR0cmlidXRlcyhzcGFuLCByZXNwb25zZS5pZCwgcmVzcG9uc2UubW9kZWwsIHJlc3BvbnNlLmNyZWF0ZWQpO1xuICBpZiAocmVzcG9uc2UudXNhZ2UpIHtcbiAgICBzZXRUb2tlblVzYWdlQXR0cmlidXRlcyhcbiAgICAgIHNwYW4sXG4gICAgICByZXNwb25zZS51c2FnZS5wcm9tcHRfdG9rZW5zLFxuICAgICAgcmVzcG9uc2UudXNhZ2UuY29tcGxldGlvbl90b2tlbnMsXG4gICAgICByZXNwb25zZS51c2FnZS50b3RhbF90b2tlbnMsXG4gICAgKTtcbiAgfVxuICBpZiAoQXJyYXkuaXNBcnJheShyZXNwb25zZS5jaG9pY2VzKSkge1xuICAgIGNvbnN0IGZpbmlzaFJlYXNvbnMgPSByZXNwb25zZS5jaG9pY2VzXG4gICAgICAubWFwKGNob2ljZSA9PiBjaG9pY2UuZmluaXNoX3JlYXNvbilcbiAgICAgIC5maWx0ZXIoKHJlYXNvbikgPT4gcmVhc29uICE9PSBudWxsKTtcbiAgICBpZiAoZmluaXNoUmVhc29ucy5sZW5ndGggPiAwKSB7XG4gICAgICBzcGFuLnNldEF0dHJpYnV0ZXMoe1xuICAgICAgICBbZ2VuQWlBdHRyaWJ1dGVzLkdFTl9BSV9SRVNQT05TRV9GSU5JU0hfUkVBU09OU19BVFRSSUJVVEVdOiBKU09OLnN0cmluZ2lmeShmaW5pc2hSZWFzb25zKSxcbiAgICAgIH0pO1xuICAgIH1cbiAgfVxufVxuXG4vKipcbiAqIEFkZCBhdHRyaWJ1dGVzIGZvciBSZXNwb25zZXMgQVBJIHJlc3BvbnNlc1xuICovXG5mdW5jdGlvbiBhZGRSZXNwb25zZXNBcGlBdHRyaWJ1dGVzKHNwYW4sIHJlc3BvbnNlKSB7XG4gIHNldENvbW1vblJlc3BvbnNlQXR0cmlidXRlcyhzcGFuLCByZXNwb25zZS5pZCwgcmVzcG9uc2UubW9kZWwsIHJlc3BvbnNlLmNyZWF0ZWRfYXQpO1xuICBpZiAocmVzcG9uc2Uuc3RhdHVzKSB7XG4gICAgc3Bhbi5zZXRBdHRyaWJ1dGVzKHtcbiAgICAgIFtnZW5BaUF0dHJpYnV0ZXMuR0VOX0FJX1JFU1BPTlNFX0ZJTklTSF9SRUFTT05TX0FUVFJJQlVURV06IEpTT04uc3RyaW5naWZ5KFtyZXNwb25zZS5zdGF0dXNdKSxcbiAgICB9KTtcbiAgfVxuICBpZiAocmVzcG9uc2UudXNhZ2UpIHtcbiAgICBzZXRUb2tlblVzYWdlQXR0cmlidXRlcyhcbiAgICAgIHNwYW4sXG4gICAgICByZXNwb25zZS51c2FnZS5pbnB1dF90b2tlbnMsXG4gICAgICByZXNwb25zZS51c2FnZS5vdXRwdXRfdG9rZW5zLFxuICAgICAgcmVzcG9uc2UudXNhZ2UudG90YWxfdG9rZW5zLFxuICAgICk7XG4gIH1cbn1cblxuLyoqXG4gKiBBZGQgcmVzcG9uc2UgYXR0cmlidXRlcyB0byBzcGFuc1xuICogVGhpcyBjdXJyZW50bHkgc3VwcG9ydHMgYm90aCBDaGF0IENvbXBsZXRpb24gYW5kIFJlc3BvbnNlcyBBUEkgcmVzcG9uc2VzXG4gKi9cbmZ1bmN0aW9uIGFkZFJlc3BvbnNlQXR0cmlidXRlcyhzcGFuLCByZXN1bHQsIHJlY29yZE91dHB1dHMpIHtcbiAgaWYgKCFyZXN1bHQgfHwgdHlwZW9mIHJlc3VsdCAhPT0gJ29iamVjdCcpIHJldHVybjtcblxuICBjb25zdCByZXNwb25zZSA9IHJlc3VsdCA7XG5cbiAgaWYgKHV0aWxzLmlzQ2hhdENvbXBsZXRpb25SZXNwb25zZShyZXNwb25zZSkpIHtcbiAgICBhZGRDaGF0Q29tcGxldGlvbkF0dHJpYnV0ZXMoc3BhbiwgcmVzcG9uc2UpO1xuICAgIGlmIChyZWNvcmRPdXRwdXRzICYmIHJlc3BvbnNlLmNob2ljZXM/Lmxlbmd0aCkge1xuICAgICAgY29uc3QgcmVzcG9uc2VUZXh0cyA9IHJlc3BvbnNlLmNob2ljZXMubWFwKGNob2ljZSA9PiBjaG9pY2UubWVzc2FnZT8uY29udGVudCB8fCAnJyk7XG4gICAgICBzcGFuLnNldEF0dHJpYnV0ZXMoeyBbZ2VuQWlBdHRyaWJ1dGVzLkdFTl9BSV9SRVNQT05TRV9URVhUX0FUVFJJQlVURV06IEpTT04uc3RyaW5naWZ5KHJlc3BvbnNlVGV4dHMpIH0pO1xuICAgIH1cbiAgfSBlbHNlIGlmICh1dGlscy5pc1Jlc3BvbnNlc0FwaVJlc3BvbnNlKHJlc3BvbnNlKSkge1xuICAgIGFkZFJlc3BvbnNlc0FwaUF0dHJpYnV0ZXMoc3BhbiwgcmVzcG9uc2UpO1xuICAgIGlmIChyZWNvcmRPdXRwdXRzICYmIHJlc3BvbnNlLm91dHB1dF90ZXh0KSB7XG4gICAgICBzcGFuLnNldEF0dHJpYnV0ZXMoeyBbZ2VuQWlBdHRyaWJ1dGVzLkdFTl9BSV9SRVNQT05TRV9URVhUX0FUVFJJQlVURV06IHJlc3BvbnNlLm91dHB1dF90ZXh0IH0pO1xuICAgIH1cbiAgfVxufVxuXG4vLyBFeHRyYWN0IGFuZCByZWNvcmQgQUkgcmVxdWVzdCBpbnB1dHMsIGlmIHByZXNlbnQuIFRoaXMgaXMgaW50ZW50aW9uYWxseSBzZXBhcmF0ZSBmcm9tIHJlc3BvbnNlIGF0dHJpYnV0ZXMuXG5mdW5jdGlvbiBhZGRSZXF1ZXN0QXR0cmlidXRlcyhzcGFuLCBwYXJhbXMpIHtcbiAgaWYgKCdtZXNzYWdlcycgaW4gcGFyYW1zKSB7XG4gICAgc3Bhbi5zZXRBdHRyaWJ1dGVzKHsgW2dlbkFpQXR0cmlidXRlcy5HRU5fQUlfUkVRVUVTVF9NRVNTQUdFU19BVFRSSUJVVEVdOiBKU09OLnN0cmluZ2lmeShwYXJhbXMubWVzc2FnZXMpIH0pO1xuICB9XG4gIGlmICgnaW5wdXQnIGluIHBhcmFtcykge1xuICAgIHNwYW4uc2V0QXR0cmlidXRlcyh7IFtnZW5BaUF0dHJpYnV0ZXMuR0VOX0FJX1JFUVVFU1RfTUVTU0FHRVNfQVRUUklCVVRFXTogSlNPTi5zdHJpbmdpZnkocGFyYW1zLmlucHV0KSB9KTtcbiAgfVxufVxuXG5mdW5jdGlvbiBnZXRPcHRpb25zRnJvbUludGVncmF0aW9uKCkge1xuICBjb25zdCBzY29wZSA9IGN1cnJlbnRTY29wZXMuZ2V0Q3VycmVudFNjb3BlKCk7XG4gIGNvbnN0IGNsaWVudCA9IHNjb3BlLmdldENsaWVudCgpO1xuICBjb25zdCBpbnRlZ3JhdGlvbiA9IGNsaWVudD8uZ2V0SW50ZWdyYXRpb25CeU5hbWUoY29uc3RhbnRzLk9QRU5BSV9JTlRFR1JBVElPTl9OQU1FKSA7XG4gIGNvbnN0IHNob3VsZFJlY29yZElucHV0c0FuZE91dHB1dHMgPSBpbnRlZ3JhdGlvbiA/IEJvb2xlYW4oY2xpZW50Py5nZXRPcHRpb25zKCkuc2VuZERlZmF1bHRQaWkpIDogZmFsc2U7XG5cbiAgcmV0dXJuIHtcbiAgICByZWNvcmRJbnB1dHM6IGludGVncmF0aW9uPy5vcHRpb25zPy5yZWNvcmRJbnB1dHMgPz8gc2hvdWxkUmVjb3JkSW5wdXRzQW5kT3V0cHV0cyxcbiAgICByZWNvcmRPdXRwdXRzOiBpbnRlZ3JhdGlvbj8ub3B0aW9ucz8ucmVjb3JkT3V0cHV0cyA/PyBzaG91bGRSZWNvcmRJbnB1dHNBbmRPdXRwdXRzLFxuICB9O1xufVxuXG4vKipcbiAqIEluc3RydW1lbnQgYSBtZXRob2Qgd2l0aCBTZW50cnkgc3BhbnNcbiAqIEZvbGxvd2luZyBTZW50cnkgQUkgQWdlbnRzIE1hbnVhbCBJbnN0cnVtZW50YXRpb24gY29udmVudGlvbnNcbiAqIEBzZWUgaHR0cHM6Ly9kb2NzLnNlbnRyeS5pby9wbGF0Zm9ybXMvamF2YXNjcmlwdC9ndWlkZXMvbm9kZS90cmFjaW5nL2luc3RydW1lbnRhdGlvbi9haS1hZ2VudHMtbW9kdWxlLyNtYW51YWwtaW5zdHJ1bWVudGF0aW9uXG4gKi9cbmZ1bmN0aW9uIGluc3RydW1lbnRNZXRob2QoXG4gIG9yaWdpbmFsTWV0aG9kLFxuICBtZXRob2RQYXRoLFxuICBjb250ZXh0LFxuICBvcHRpb25zLFxuKSB7XG4gIHJldHVybiBhc3luYyBmdW5jdGlvbiBpbnN0cnVtZW50ZWRNZXRob2QoLi4uYXJncykge1xuICAgIGNvbnN0IGZpbmFsT3B0aW9ucyA9IG9wdGlvbnMgfHwgZ2V0T3B0aW9uc0Zyb21JbnRlZ3JhdGlvbigpO1xuICAgIGNvbnN0IHJlcXVlc3RBdHRyaWJ1dGVzID0gZXh0cmFjdFJlcXVlc3RBdHRyaWJ1dGVzKGFyZ3MsIG1ldGhvZFBhdGgpO1xuICAgIGNvbnN0IG1vZGVsID0gKHJlcXVlc3RBdHRyaWJ1dGVzW2dlbkFpQXR0cmlidXRlcy5HRU5fQUlfUkVRVUVTVF9NT0RFTF9BVFRSSUJVVEVdICkgfHwgJ3Vua25vd24nO1xuICAgIGNvbnN0IG9wZXJhdGlvbk5hbWUgPSB1dGlscy5nZXRPcGVyYXRpb25OYW1lKG1ldGhvZFBhdGgpO1xuXG4gICAgcmV0dXJuIHRyYWNlLnN0YXJ0U3BhbihcbiAgICAgIHtcbiAgICAgICAgbmFtZTogYCR7b3BlcmF0aW9uTmFtZX0gJHttb2RlbH1gLFxuICAgICAgICBvcDogdXRpbHMuZ2V0U3Bhbk9wZXJhdGlvbihtZXRob2RQYXRoKSxcbiAgICAgICAgYXR0cmlidXRlczogcmVxdWVzdEF0dHJpYnV0ZXMgLFxuICAgICAgfSxcbiAgICAgIGFzeW5jIChzcGFuKSA9PiB7XG4gICAgICAgIHRyeSB7XG4gICAgICAgICAgaWYgKGZpbmFsT3B0aW9ucy5yZWNvcmRJbnB1dHMgJiYgYXJnc1swXSAmJiB0eXBlb2YgYXJnc1swXSA9PT0gJ29iamVjdCcpIHtcbiAgICAgICAgICAgIGFkZFJlcXVlc3RBdHRyaWJ1dGVzKHNwYW4sIGFyZ3NbMF0gKTtcbiAgICAgICAgICB9XG5cbiAgICAgICAgICBjb25zdCByZXN1bHQgPSBhd2FpdCBvcmlnaW5hbE1ldGhvZC5hcHBseShjb250ZXh0LCBhcmdzKTtcbiAgICAgICAgICAvLyBUT0RPOiBBZGQgc3RyZWFtaW5nIHN1cHBvcnRcbiAgICAgICAgICBhZGRSZXNwb25zZUF0dHJpYnV0ZXMoc3BhbiwgcmVzdWx0LCBmaW5hbE9wdGlvbnMucmVjb3JkT3V0cHV0cyk7XG4gICAgICAgICAgcmV0dXJuIHJlc3VsdDtcbiAgICAgICAgfSBjYXRjaCAoZXJyb3IpIHtcbiAgICAgICAgICBleHBvcnRzJDEuY2FwdHVyZUV4Y2VwdGlvbihlcnJvcik7XG4gICAgICAgICAgdGhyb3cgZXJyb3I7XG4gICAgICAgIH1cbiAgICAgIH0sXG4gICAgKTtcbiAgfTtcbn1cblxuLyoqXG4gKiBDcmVhdGUgYSBkZWVwIHByb3h5IGZvciBPcGVuQUkgY2xpZW50IGluc3RydW1lbnRhdGlvblxuICovXG5mdW5jdGlvbiBjcmVhdGVEZWVwUHJveHkodGFyZ2V0LCBjdXJyZW50UGF0aCA9ICcnLCBvcHRpb25zKSB7XG4gIHJldHVybiBuZXcgUHJveHkodGFyZ2V0LCB7XG4gICAgZ2V0KG9iaiwgcHJvcCkge1xuICAgICAgY29uc3QgdmFsdWUgPSAob2JqIClbcHJvcF07XG4gICAgICBjb25zdCBtZXRob2RQYXRoID0gdXRpbHMuYnVpbGRNZXRob2RQYXRoKGN1cnJlbnRQYXRoLCBTdHJpbmcocHJvcCkpO1xuXG4gICAgICBpZiAodHlwZW9mIHZhbHVlID09PSAnZnVuY3Rpb24nICYmIHV0aWxzLnNob3VsZEluc3RydW1lbnQobWV0aG9kUGF0aCkpIHtcbiAgICAgICAgcmV0dXJuIGluc3RydW1lbnRNZXRob2QodmFsdWUgLCBtZXRob2RQYXRoLCBvYmosIG9wdGlvbnMpO1xuICAgICAgfVxuXG4gICAgICBpZiAodHlwZW9mIHZhbHVlID09PSAnZnVuY3Rpb24nKSB7XG4gICAgICAgIC8vIEJpbmQgbm9uLWluc3RydW1lbnRlZCBmdW5jdGlvbnMgdG8gcHJlc2VydmUgdGhlIG9yaWdpbmFsIGB0aGlzYCBjb250ZXh0LFxuICAgICAgICAvLyB3aGljaCBpcyByZXF1aXJlZCBmb3IgYWNjZXNzaW5nIHByaXZhdGUgY2xhc3MgZmllbGRzIChlLmcuICNiYXNlVVJMKSBpbiBPcGVuQUkgU0RLIHY1LlxuICAgICAgICByZXR1cm4gdmFsdWUuYmluZChvYmopO1xuICAgICAgfVxuXG4gICAgICBpZiAodmFsdWUgJiYgdHlwZW9mIHZhbHVlID09PSAnb2JqZWN0Jykge1xuICAgICAgICByZXR1cm4gY3JlYXRlRGVlcFByb3h5KHZhbHVlICwgbWV0aG9kUGF0aCwgb3B0aW9ucyk7XG4gICAgICB9XG5cbiAgICAgIHJldHVybiB2YWx1ZTtcbiAgICB9LFxuICB9KTtcbn1cblxuLyoqXG4gKiBJbnN0cnVtZW50IGFuIE9wZW5BSSBjbGllbnQgd2l0aCBTZW50cnkgdHJhY2luZ1xuICogQ2FuIGJlIHVzZWQgYWNyb3NzIE5vZGUuanMsIENsb3VkZmxhcmUgV29ya2VycywgYW5kIFZlcmNlbCBFZGdlXG4gKi9cbmZ1bmN0aW9uIGluc3RydW1lbnRPcGVuQWlDbGllbnQoY2xpZW50LCBvcHRpb25zKSB7XG4gIHJldHVybiBjcmVhdGVEZWVwUHJveHkoY2xpZW50LCAnJywgb3B0aW9ucyk7XG59XG5cbmV4cG9ydHMuaW5zdHJ1bWVudE9wZW5BaUNsaWVudCA9IGluc3RydW1lbnRPcGVuQWlDbGllbnQ7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1pbmRleC5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/openai/index.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/openai/utils.js":
/*!**********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/openai/utils.js ***!
  \**********************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst genAiAttributes = __webpack_require__(/*! ../gen-ai-attributes.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/gen-ai-attributes.js\");\nconst constants = __webpack_require__(/*! ./constants.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/openai/constants.js\");\n\n/**\n * Maps OpenAI method paths to Sentry operation names\n */\nfunction getOperationName(methodPath) {\n  if (methodPath.includes('chat.completions')) {\n    return genAiAttributes.OPENAI_OPERATIONS.CHAT;\n  }\n  if (methodPath.includes('responses')) {\n    // The responses API is also a chat operation\n    return genAiAttributes.OPENAI_OPERATIONS.CHAT;\n  }\n  return methodPath.split('.').pop() || 'unknown';\n}\n\n/**\n * Get the span operation for OpenAI methods\n * Following Sentry's convention: \"gen_ai.{operation_name}\"\n */\nfunction getSpanOperation(methodPath) {\n  return `gen_ai.${getOperationName(methodPath)}`;\n}\n\n/**\n * Check if a method path should be instrumented\n */\nfunction shouldInstrument(methodPath) {\n  return constants.INSTRUMENTED_METHODS.includes(methodPath );\n}\n\n/**\n * Build method path from current traversal\n */\nfunction buildMethodPath(currentPath, prop) {\n  return currentPath ? `${currentPath}.${prop}` : prop;\n}\n\n/**\n * Check if response is a Chat Completion object\n */\nfunction isChatCompletionResponse(response) {\n  return (\n    response !== null &&\n    typeof response === 'object' &&\n    'object' in response &&\n    (response ).object === 'chat.completion'\n  );\n}\n\n/**\n * Check if response is a Responses API object\n */\nfunction isResponsesApiResponse(response) {\n  return (\n    response !== null &&\n    typeof response === 'object' &&\n    'object' in response &&\n    (response ).object === 'response'\n  );\n}\n\nexports.buildMethodPath = buildMethodPath;\nexports.getOperationName = getOperationName;\nexports.getSpanOperation = getSpanOperation;\nexports.isChatCompletionResponse = isChatCompletionResponse;\nexports.isResponsesApiResponse = isResponsesApiResponse;\nexports.shouldInstrument = shouldInstrument;\n//# sourceMappingURL=utils.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9vcGVuYWkvdXRpbHMuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsd0JBQXdCLG1CQUFPLENBQUMsOElBQXlCO0FBQ3pELGtCQUFrQixtQkFBTyxDQUFDLG9JQUFnQjs7QUFFMUM7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLDJDQUEyQyxlQUFlO0FBQzFEO0FBQ0E7QUFDQSxtQkFBbUIsNkJBQTZCO0FBQ2hEOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLDBCQUEwQixZQUFZLEdBQUcsS0FBSztBQUM5Qzs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsdUJBQXVCO0FBQ3ZCLHdCQUF3QjtBQUN4Qix3QkFBd0I7QUFDeEIsZ0NBQWdDO0FBQ2hDLDhCQUE4QjtBQUM5Qix3QkFBd0I7QUFDeEIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9vcGVuYWkvdXRpbHMuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGdlbkFpQXR0cmlidXRlcyA9IHJlcXVpcmUoJy4uL2dlbi1haS1hdHRyaWJ1dGVzLmpzJyk7XG5jb25zdCBjb25zdGFudHMgPSByZXF1aXJlKCcuL2NvbnN0YW50cy5qcycpO1xuXG4vKipcbiAqIE1hcHMgT3BlbkFJIG1ldGhvZCBwYXRocyB0byBTZW50cnkgb3BlcmF0aW9uIG5hbWVzXG4gKi9cbmZ1bmN0aW9uIGdldE9wZXJhdGlvbk5hbWUobWV0aG9kUGF0aCkge1xuICBpZiAobWV0aG9kUGF0aC5pbmNsdWRlcygnY2hhdC5jb21wbGV0aW9ucycpKSB7XG4gICAgcmV0dXJuIGdlbkFpQXR0cmlidXRlcy5PUEVOQUlfT1BFUkFUSU9OUy5DSEFUO1xuICB9XG4gIGlmIChtZXRob2RQYXRoLmluY2x1ZGVzKCdyZXNwb25zZXMnKSkge1xuICAgIC8vIFRoZSByZXNwb25zZXMgQVBJIGlzIGFsc28gYSBjaGF0IG9wZXJhdGlvblxuICAgIHJldHVybiBnZW5BaUF0dHJpYnV0ZXMuT1BFTkFJX09QRVJBVElPTlMuQ0hBVDtcbiAgfVxuICByZXR1cm4gbWV0aG9kUGF0aC5zcGxpdCgnLicpLnBvcCgpIHx8ICd1bmtub3duJztcbn1cblxuLyoqXG4gKiBHZXQgdGhlIHNwYW4gb3BlcmF0aW9uIGZvciBPcGVuQUkgbWV0aG9kc1xuICogRm9sbG93aW5nIFNlbnRyeSdzIGNvbnZlbnRpb246IFwiZ2VuX2FpLntvcGVyYXRpb25fbmFtZX1cIlxuICovXG5mdW5jdGlvbiBnZXRTcGFuT3BlcmF0aW9uKG1ldGhvZFBhdGgpIHtcbiAgcmV0dXJuIGBnZW5fYWkuJHtnZXRPcGVyYXRpb25OYW1lKG1ldGhvZFBhdGgpfWA7XG59XG5cbi8qKlxuICogQ2hlY2sgaWYgYSBtZXRob2QgcGF0aCBzaG91bGQgYmUgaW5zdHJ1bWVudGVkXG4gKi9cbmZ1bmN0aW9uIHNob3VsZEluc3RydW1lbnQobWV0aG9kUGF0aCkge1xuICByZXR1cm4gY29uc3RhbnRzLklOU1RSVU1FTlRFRF9NRVRIT0RTLmluY2x1ZGVzKG1ldGhvZFBhdGggKTtcbn1cblxuLyoqXG4gKiBCdWlsZCBtZXRob2QgcGF0aCBmcm9tIGN1cnJlbnQgdHJhdmVyc2FsXG4gKi9cbmZ1bmN0aW9uIGJ1aWxkTWV0aG9kUGF0aChjdXJyZW50UGF0aCwgcHJvcCkge1xuICByZXR1cm4gY3VycmVudFBhdGggPyBgJHtjdXJyZW50UGF0aH0uJHtwcm9wfWAgOiBwcm9wO1xufVxuXG4vKipcbiAqIENoZWNrIGlmIHJlc3BvbnNlIGlzIGEgQ2hhdCBDb21wbGV0aW9uIG9iamVjdFxuICovXG5mdW5jdGlvbiBpc0NoYXRDb21wbGV0aW9uUmVzcG9uc2UocmVzcG9uc2UpIHtcbiAgcmV0dXJuIChcbiAgICByZXNwb25zZSAhPT0gbnVsbCAmJlxuICAgIHR5cGVvZiByZXNwb25zZSA9PT0gJ29iamVjdCcgJiZcbiAgICAnb2JqZWN0JyBpbiByZXNwb25zZSAmJlxuICAgIChyZXNwb25zZSApLm9iamVjdCA9PT0gJ2NoYXQuY29tcGxldGlvbidcbiAgKTtcbn1cblxuLyoqXG4gKiBDaGVjayBpZiByZXNwb25zZSBpcyBhIFJlc3BvbnNlcyBBUEkgb2JqZWN0XG4gKi9cbmZ1bmN0aW9uIGlzUmVzcG9uc2VzQXBpUmVzcG9uc2UocmVzcG9uc2UpIHtcbiAgcmV0dXJuIChcbiAgICByZXNwb25zZSAhPT0gbnVsbCAmJlxuICAgIHR5cGVvZiByZXNwb25zZSA9PT0gJ29iamVjdCcgJiZcbiAgICAnb2JqZWN0JyBpbiByZXNwb25zZSAmJlxuICAgIChyZXNwb25zZSApLm9iamVjdCA9PT0gJ3Jlc3BvbnNlJ1xuICApO1xufVxuXG5leHBvcnRzLmJ1aWxkTWV0aG9kUGF0aCA9IGJ1aWxkTWV0aG9kUGF0aDtcbmV4cG9ydHMuZ2V0T3BlcmF0aW9uTmFtZSA9IGdldE9wZXJhdGlvbk5hbWU7XG5leHBvcnRzLmdldFNwYW5PcGVyYXRpb24gPSBnZXRTcGFuT3BlcmF0aW9uO1xuZXhwb3J0cy5pc0NoYXRDb21wbGV0aW9uUmVzcG9uc2UgPSBpc0NoYXRDb21wbGV0aW9uUmVzcG9uc2U7XG5leHBvcnRzLmlzUmVzcG9uc2VzQXBpUmVzcG9uc2UgPSBpc1Jlc3BvbnNlc0FwaVJlc3BvbnNlO1xuZXhwb3J0cy5zaG91bGRJbnN0cnVtZW50ID0gc2hvdWxkSW5zdHJ1bWVudDtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPXV0aWxzLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/openai/utils.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/parameterize.js":
/*!**********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/parameterize.js ***!
  \**********************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n/**\n * Tagged template function which returns parameterized representation of the message\n * For example: parameterize`This is a log statement with ${x} and ${y} params`, would return:\n * \"__sentry_template_string__\": 'This is a log statement with %s and %s params',\n * \"__sentry_template_values__\": ['first', 'second']\n *\n * @param strings An array of string values splitted between expressions\n * @param values Expressions extracted from template string\n *\n * @returns A `ParameterizedString` object that can be passed into `captureMessage` or Sentry.logger.X methods.\n */\nfunction parameterize(strings, ...values) {\n  const formatted = new String(String.raw(strings, ...values)) ;\n  formatted.__sentry_template_string__ = strings.join('\\x00').replace(/%/g, '%%').replace(/\\0/g, '%s');\n  formatted.__sentry_template_values__ = values;\n  return formatted;\n}\n\n/**\n * Tagged template function which returns parameterized representation of the message.\n *\n * @param strings An array of string values splitted between expressions\n * @param values Expressions extracted from template string\n * @returns A `ParameterizedString` object that can be passed into `captureMessage` or Sentry.logger.X methods.\n */\nconst fmt = parameterize;\n\nexports.fmt = fmt;\nexports.parameterize = parameterize;\n//# sourceMappingURL=parameterize.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9wYXJhbWV0ZXJpemUuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEU7QUFDQTtBQUNBLDREQUE0RCxHQUFHLE1BQU0sR0FBRztBQUN4RTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsV0FBVztBQUNYLG9CQUFvQjtBQUNwQiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3V0aWxzL3BhcmFtZXRlcml6ZS5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuLyoqXG4gKiBUYWdnZWQgdGVtcGxhdGUgZnVuY3Rpb24gd2hpY2ggcmV0dXJucyBwYXJhbWV0ZXJpemVkIHJlcHJlc2VudGF0aW9uIG9mIHRoZSBtZXNzYWdlXG4gKiBGb3IgZXhhbXBsZTogcGFyYW1ldGVyaXplYFRoaXMgaXMgYSBsb2cgc3RhdGVtZW50IHdpdGggJHt4fSBhbmQgJHt5fSBwYXJhbXNgLCB3b3VsZCByZXR1cm46XG4gKiBcIl9fc2VudHJ5X3RlbXBsYXRlX3N0cmluZ19fXCI6ICdUaGlzIGlzIGEgbG9nIHN0YXRlbWVudCB3aXRoICVzIGFuZCAlcyBwYXJhbXMnLFxuICogXCJfX3NlbnRyeV90ZW1wbGF0ZV92YWx1ZXNfX1wiOiBbJ2ZpcnN0JywgJ3NlY29uZCddXG4gKlxuICogQHBhcmFtIHN0cmluZ3MgQW4gYXJyYXkgb2Ygc3RyaW5nIHZhbHVlcyBzcGxpdHRlZCBiZXR3ZWVuIGV4cHJlc3Npb25zXG4gKiBAcGFyYW0gdmFsdWVzIEV4cHJlc3Npb25zIGV4dHJhY3RlZCBmcm9tIHRlbXBsYXRlIHN0cmluZ1xuICpcbiAqIEByZXR1cm5zIEEgYFBhcmFtZXRlcml6ZWRTdHJpbmdgIG9iamVjdCB0aGF0IGNhbiBiZSBwYXNzZWQgaW50byBgY2FwdHVyZU1lc3NhZ2VgIG9yIFNlbnRyeS5sb2dnZXIuWCBtZXRob2RzLlxuICovXG5mdW5jdGlvbiBwYXJhbWV0ZXJpemUoc3RyaW5ncywgLi4udmFsdWVzKSB7XG4gIGNvbnN0IGZvcm1hdHRlZCA9IG5ldyBTdHJpbmcoU3RyaW5nLnJhdyhzdHJpbmdzLCAuLi52YWx1ZXMpKSA7XG4gIGZvcm1hdHRlZC5fX3NlbnRyeV90ZW1wbGF0ZV9zdHJpbmdfXyA9IHN0cmluZ3Muam9pbignXFx4MDAnKS5yZXBsYWNlKC8lL2csICclJScpLnJlcGxhY2UoL1xcMC9nLCAnJXMnKTtcbiAgZm9ybWF0dGVkLl9fc2VudHJ5X3RlbXBsYXRlX3ZhbHVlc19fID0gdmFsdWVzO1xuICByZXR1cm4gZm9ybWF0dGVkO1xufVxuXG4vKipcbiAqIFRhZ2dlZCB0ZW1wbGF0ZSBmdW5jdGlvbiB3aGljaCByZXR1cm5zIHBhcmFtZXRlcml6ZWQgcmVwcmVzZW50YXRpb24gb2YgdGhlIG1lc3NhZ2UuXG4gKlxuICogQHBhcmFtIHN0cmluZ3MgQW4gYXJyYXkgb2Ygc3RyaW5nIHZhbHVlcyBzcGxpdHRlZCBiZXR3ZWVuIGV4cHJlc3Npb25zXG4gKiBAcGFyYW0gdmFsdWVzIEV4cHJlc3Npb25zIGV4dHJhY3RlZCBmcm9tIHRlbXBsYXRlIHN0cmluZ1xuICogQHJldHVybnMgQSBgUGFyYW1ldGVyaXplZFN0cmluZ2Agb2JqZWN0IHRoYXQgY2FuIGJlIHBhc3NlZCBpbnRvIGBjYXB0dXJlTWVzc2FnZWAgb3IgU2VudHJ5LmxvZ2dlci5YIG1ldGhvZHMuXG4gKi9cbmNvbnN0IGZtdCA9IHBhcmFtZXRlcml6ZTtcblxuZXhwb3J0cy5mbXQgPSBmbXQ7XG5leHBvcnRzLnBhcmFtZXRlcml6ZSA9IHBhcmFtZXRlcml6ZTtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPXBhcmFtZXRlcml6ZS5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/parameterize.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/parseSampleRate.js":
/*!*************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/parseSampleRate.js ***!
  \*************************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n/**\n * Parse a sample rate from a given value.\n * This will either return a boolean or number sample rate, if the sample rate is valid (between 0 and 1).\n * If a string is passed, we try to convert it to a number.\n *\n * Any invalid sample rate will return `undefined`.\n */\nfunction parseSampleRate(sampleRate) {\n  if (typeof sampleRate === 'boolean') {\n    return Number(sampleRate);\n  }\n\n  const rate = typeof sampleRate === 'string' ? parseFloat(sampleRate) : sampleRate;\n  if (typeof rate !== 'number' || isNaN(rate) || rate < 0 || rate > 1) {\n    return undefined;\n  }\n\n  return rate;\n}\n\nexports.parseSampleRate = parseSampleRate;\n//# sourceMappingURL=parseSampleRate.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9wYXJzZVNhbXBsZVJhdGUuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEU7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBLHVCQUF1QjtBQUN2QiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3V0aWxzL3BhcnNlU2FtcGxlUmF0ZS5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuLyoqXG4gKiBQYXJzZSBhIHNhbXBsZSByYXRlIGZyb20gYSBnaXZlbiB2YWx1ZS5cbiAqIFRoaXMgd2lsbCBlaXRoZXIgcmV0dXJuIGEgYm9vbGVhbiBvciBudW1iZXIgc2FtcGxlIHJhdGUsIGlmIHRoZSBzYW1wbGUgcmF0ZSBpcyB2YWxpZCAoYmV0d2VlbiAwIGFuZCAxKS5cbiAqIElmIGEgc3RyaW5nIGlzIHBhc3NlZCwgd2UgdHJ5IHRvIGNvbnZlcnQgaXQgdG8gYSBudW1iZXIuXG4gKlxuICogQW55IGludmFsaWQgc2FtcGxlIHJhdGUgd2lsbCByZXR1cm4gYHVuZGVmaW5lZGAuXG4gKi9cbmZ1bmN0aW9uIHBhcnNlU2FtcGxlUmF0ZShzYW1wbGVSYXRlKSB7XG4gIGlmICh0eXBlb2Ygc2FtcGxlUmF0ZSA9PT0gJ2Jvb2xlYW4nKSB7XG4gICAgcmV0dXJuIE51bWJlcihzYW1wbGVSYXRlKTtcbiAgfVxuXG4gIGNvbnN0IHJhdGUgPSB0eXBlb2Ygc2FtcGxlUmF0ZSA9PT0gJ3N0cmluZycgPyBwYXJzZUZsb2F0KHNhbXBsZVJhdGUpIDogc2FtcGxlUmF0ZTtcbiAgaWYgKHR5cGVvZiByYXRlICE9PSAnbnVtYmVyJyB8fCBpc05hTihyYXRlKSB8fCByYXRlIDwgMCB8fCByYXRlID4gMSkge1xuICAgIHJldHVybiB1bmRlZmluZWQ7XG4gIH1cblxuICByZXR1cm4gcmF0ZTtcbn1cblxuZXhwb3J0cy5wYXJzZVNhbXBsZVJhdGUgPSBwYXJzZVNhbXBsZVJhdGU7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1wYXJzZVNhbXBsZVJhdGUuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/parseSampleRate.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/path.js":
/*!**************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/path.js ***!
  \**************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n// Slightly modified (no IE8 support, ES6) and transcribed to TypeScript\n// https://github.com/calvinmetcalf/rollup-plugin-node-builtins/blob/63ab8aacd013767445ca299e468d9a60a95328d7/src/es6/path.js\n//\n// Copyright Joyent, Inc.and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n/** JSDoc */\nfunction normalizeArray(parts, allowAboveRoot) {\n  // if the path tries to go above the root, `up` ends up > 0\n  let up = 0;\n  for (let i = parts.length - 1; i >= 0; i--) {\n    const last = parts[i];\n    if (last === '.') {\n      parts.splice(i, 1);\n    } else if (last === '..') {\n      parts.splice(i, 1);\n      up++;\n    } else if (up) {\n      parts.splice(i, 1);\n      up--;\n    }\n  }\n\n  // if the path is allowed to go above the root, restore leading ..s\n  if (allowAboveRoot) {\n    for (; up--; up) {\n      parts.unshift('..');\n    }\n  }\n\n  return parts;\n}\n\n// Split a filename into [root, dir, basename, ext], unix version\n// 'root' is just a slash, or nothing.\nconst splitPathRe = /^(\\S+:\\\\|\\/?)([\\s\\S]*?)((?:\\.{1,2}|[^/\\\\]+?|)(\\.[^./\\\\]*|))(?:[/\\\\]*)$/;\n/** JSDoc */\nfunction splitPath(filename) {\n  // Truncate files names greater than 1024 characters to avoid regex dos\n  // https://github.com/getsentry/sentry-javascript/pull/8737#discussion_r1285719172\n  const truncated = filename.length > 1024 ? `<truncated>${filename.slice(-1024)}` : filename;\n  const parts = splitPathRe.exec(truncated);\n  return parts ? parts.slice(1) : [];\n}\n\n// path.resolve([from ...], to)\n// posix version\n/** JSDoc */\nfunction resolve(...args) {\n  let resolvedPath = '';\n  let resolvedAbsolute = false;\n\n  for (let i = args.length - 1; i >= -1 && !resolvedAbsolute; i--) {\n    const path = i >= 0 ? args[i] : '/';\n\n    // Skip empty entries\n    if (!path) {\n      continue;\n    }\n\n    resolvedPath = `${path}/${resolvedPath}`;\n    resolvedAbsolute = path.charAt(0) === '/';\n  }\n\n  // At this point the path should be resolved to a full absolute path, but\n  // handle relative paths to be safe (might happen when process.cwd() fails)\n\n  // Normalize the path\n  resolvedPath = normalizeArray(\n    resolvedPath.split('/').filter(p => !!p),\n    !resolvedAbsolute,\n  ).join('/');\n\n  return (resolvedAbsolute ? '/' : '') + resolvedPath || '.';\n}\n\n/** JSDoc */\nfunction trim(arr) {\n  let start = 0;\n  for (; start < arr.length; start++) {\n    if (arr[start] !== '') {\n      break;\n    }\n  }\n\n  let end = arr.length - 1;\n  for (; end >= 0; end--) {\n    if (arr[end] !== '') {\n      break;\n    }\n  }\n\n  if (start > end) {\n    return [];\n  }\n  return arr.slice(start, end - start + 1);\n}\n\n// path.relative(from, to)\n// posix version\n/** JSDoc */\nfunction relative(from, to) {\n  /* eslint-disable no-param-reassign */\n  from = resolve(from).slice(1);\n  to = resolve(to).slice(1);\n  /* eslint-enable no-param-reassign */\n\n  const fromParts = trim(from.split('/'));\n  const toParts = trim(to.split('/'));\n\n  const length = Math.min(fromParts.length, toParts.length);\n  let samePartsLength = length;\n  for (let i = 0; i < length; i++) {\n    if (fromParts[i] !== toParts[i]) {\n      samePartsLength = i;\n      break;\n    }\n  }\n\n  let outputParts = [];\n  for (let i = samePartsLength; i < fromParts.length; i++) {\n    outputParts.push('..');\n  }\n\n  outputParts = outputParts.concat(toParts.slice(samePartsLength));\n\n  return outputParts.join('/');\n}\n\n// path.normalize(path)\n// posix version\n/** JSDoc */\nfunction normalizePath(path) {\n  const isPathAbsolute = isAbsolute(path);\n  const trailingSlash = path.slice(-1) === '/';\n\n  // Normalize the path\n  let normalizedPath = normalizeArray(\n    path.split('/').filter(p => !!p),\n    !isPathAbsolute,\n  ).join('/');\n\n  if (!normalizedPath && !isPathAbsolute) {\n    normalizedPath = '.';\n  }\n  if (normalizedPath && trailingSlash) {\n    normalizedPath += '/';\n  }\n\n  return (isPathAbsolute ? '/' : '') + normalizedPath;\n}\n\n// posix version\n/** JSDoc */\nfunction isAbsolute(path) {\n  return path.charAt(0) === '/';\n}\n\n// posix version\n/** JSDoc */\nfunction join(...args) {\n  return normalizePath(args.join('/'));\n}\n\n/** JSDoc */\nfunction dirname(path) {\n  const result = splitPath(path);\n  const root = result[0] || '';\n  let dir = result[1];\n\n  if (!root && !dir) {\n    // No dirname whatsoever\n    return '.';\n  }\n\n  if (dir) {\n    // It has a dirname, strip trailing slash\n    dir = dir.slice(0, dir.length - 1);\n  }\n\n  return root + dir;\n}\n\n/** JSDoc */\nfunction basename(path, ext) {\n  let f = splitPath(path)[2] || '';\n  if (ext && f.slice(ext.length * -1) === ext) {\n    f = f.slice(0, f.length - ext.length);\n  }\n  return f;\n}\n\nexports.basename = basename;\nexports.dirname = dirname;\nexports.isAbsolute = isAbsolute;\nexports.join = join;\nexports.normalizePath = normalizePath;\nexports.relative = relative;\nexports.resolve = resolve;\n//# sourceMappingURL=path.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9wYXRoLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQSxpQ0FBaUMsUUFBUTtBQUN6QztBQUNBO0FBQ0E7QUFDQSxNQUFNO0FBQ047QUFDQTtBQUNBLE1BQU07QUFDTjtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsV0FBVyxNQUFNO0FBQ2pCO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQSxtREFBbUQsSUFBSTtBQUN2RDtBQUNBO0FBQ0E7QUFDQTtBQUNBLDJEQUEyRCxzQkFBc0I7QUFDakY7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSxnQ0FBZ0MsOEJBQThCO0FBQzlEOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLHNCQUFzQixLQUFLLEdBQUcsYUFBYTtBQUMzQztBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBLFNBQVMsb0JBQW9CO0FBQzdCO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0EsU0FBUyxVQUFVO0FBQ25CO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQSxrQkFBa0IsWUFBWTtBQUM5QjtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0EsZ0NBQWdDLHNCQUFzQjtBQUN0RDtBQUNBOztBQUVBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLGdCQUFnQjtBQUNoQixlQUFlO0FBQ2Ysa0JBQWtCO0FBQ2xCLFlBQVk7QUFDWixxQkFBcUI7QUFDckIsZ0JBQWdCO0FBQ2hCLGVBQWU7QUFDZiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3V0aWxzL3BhdGguanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbi8vIFNsaWdodGx5IG1vZGlmaWVkIChubyBJRTggc3VwcG9ydCwgRVM2KSBhbmQgdHJhbnNjcmliZWQgdG8gVHlwZVNjcmlwdFxuLy8gaHR0cHM6Ly9naXRodWIuY29tL2NhbHZpbm1ldGNhbGYvcm9sbHVwLXBsdWdpbi1ub2RlLWJ1aWx0aW5zL2Jsb2IvNjNhYjhhYWNkMDEzNzY3NDQ1Y2EyOTllNDY4ZDlhNjBhOTUzMjhkNy9zcmMvZXM2L3BhdGguanNcbi8vXG4vLyBDb3B5cmlnaHQgSm95ZW50LCBJbmMuYW5kIG90aGVyIE5vZGUgY29udHJpYnV0b3JzLlxuLy9cbi8vIFBlcm1pc3Npb24gaXMgaGVyZWJ5IGdyYW50ZWQsIGZyZWUgb2YgY2hhcmdlLCB0byBhbnkgcGVyc29uIG9idGFpbmluZyBhXG4vLyBjb3B5IG9mIHRoaXMgc29mdHdhcmUgYW5kIGFzc29jaWF0ZWQgZG9jdW1lbnRhdGlvbiBmaWxlcyAodGhlXG4vLyBcIlNvZnR3YXJlXCIpLCB0byBkZWFsIGluIHRoZSBTb2Z0d2FyZSB3aXRob3V0IHJlc3RyaWN0aW9uLCBpbmNsdWRpbmdcbi8vIHdpdGhvdXQgbGltaXRhdGlvbiB0aGUgcmlnaHRzIHRvIHVzZSwgY29weSwgbW9kaWZ5LCBtZXJnZSwgcHVibGlzaCxcbi8vIGRpc3RyaWJ1dGUsIHN1YmxpY2Vuc2UsIGFuZC9vciBzZWxsIGNvcGllcyBvZiB0aGUgU29mdHdhcmUsIGFuZCB0byBwZXJtaXRcbi8vIHBlcnNvbnMgdG8gd2hvbSB0aGUgU29mdHdhcmUgaXMgZnVybmlzaGVkIHRvIGRvIHNvLCBzdWJqZWN0IHRvIHRoZVxuLy8gZm9sbG93aW5nIGNvbmRpdGlvbnM6XG4vL1xuLy8gVGhlIGFib3ZlIGNvcHlyaWdodCBub3RpY2UgYW5kIHRoaXMgcGVybWlzc2lvbiBub3RpY2Ugc2hhbGwgYmUgaW5jbHVkZWRcbi8vIGluIGFsbCBjb3BpZXMgb3Igc3Vic3RhbnRpYWwgcG9ydGlvbnMgb2YgdGhlIFNvZnR3YXJlLlxuLy9cbi8vIFRIRSBTT0ZUV0FSRSBJUyBQUk9WSURFRCBcIkFTIElTXCIsIFdJVEhPVVQgV0FSUkFOVFkgT0YgQU5ZIEtJTkQsIEVYUFJFU1Ncbi8vIE9SIElNUExJRUQsIElOQ0xVRElORyBCVVQgTk9UIExJTUlURUQgVE8gVEhFIFdBUlJBTlRJRVMgT0Zcbi8vIE1FUkNIQU5UQUJJTElUWSwgRklUTkVTUyBGT1IgQSBQQVJUSUNVTEFSIFBVUlBPU0UgQU5EIE5PTklORlJJTkdFTUVOVC4gSU5cbi8vIE5PIEVWRU5UIFNIQUxMIFRIRSBBVVRIT1JTIE9SIENPUFlSSUdIVCBIT0xERVJTIEJFIExJQUJMRSBGT1IgQU5ZIENMQUlNLFxuLy8gREFNQUdFUyBPUiBPVEhFUiBMSUFCSUxJVFksIFdIRVRIRVIgSU4gQU4gQUNUSU9OIE9GIENPTlRSQUNULCBUT1JUIE9SXG4vLyBPVEhFUldJU0UsIEFSSVNJTkcgRlJPTSwgT1VUIE9GIE9SIElOIENPTk5FQ1RJT04gV0lUSCBUSEUgU09GVFdBUkUgT1IgVEhFXG4vLyBVU0UgT1IgT1RIRVIgREVBTElOR1MgSU4gVEhFIFNPRlRXQVJFLlxuXG4vKiogSlNEb2MgKi9cbmZ1bmN0aW9uIG5vcm1hbGl6ZUFycmF5KHBhcnRzLCBhbGxvd0Fib3ZlUm9vdCkge1xuICAvLyBpZiB0aGUgcGF0aCB0cmllcyB0byBnbyBhYm92ZSB0aGUgcm9vdCwgYHVwYCBlbmRzIHVwID4gMFxuICBsZXQgdXAgPSAwO1xuICBmb3IgKGxldCBpID0gcGFydHMubGVuZ3RoIC0gMTsgaSA+PSAwOyBpLS0pIHtcbiAgICBjb25zdCBsYXN0ID0gcGFydHNbaV07XG4gICAgaWYgKGxhc3QgPT09ICcuJykge1xuICAgICAgcGFydHMuc3BsaWNlKGksIDEpO1xuICAgIH0gZWxzZSBpZiAobGFzdCA9PT0gJy4uJykge1xuICAgICAgcGFydHMuc3BsaWNlKGksIDEpO1xuICAgICAgdXArKztcbiAgICB9IGVsc2UgaWYgKHVwKSB7XG4gICAgICBwYXJ0cy5zcGxpY2UoaSwgMSk7XG4gICAgICB1cC0tO1xuICAgIH1cbiAgfVxuXG4gIC8vIGlmIHRoZSBwYXRoIGlzIGFsbG93ZWQgdG8gZ28gYWJvdmUgdGhlIHJvb3QsIHJlc3RvcmUgbGVhZGluZyAuLnNcbiAgaWYgKGFsbG93QWJvdmVSb290KSB7XG4gICAgZm9yICg7IHVwLS07IHVwKSB7XG4gICAgICBwYXJ0cy51bnNoaWZ0KCcuLicpO1xuICAgIH1cbiAgfVxuXG4gIHJldHVybiBwYXJ0cztcbn1cblxuLy8gU3BsaXQgYSBmaWxlbmFtZSBpbnRvIFtyb290LCBkaXIsIGJhc2VuYW1lLCBleHRdLCB1bml4IHZlcnNpb25cbi8vICdyb290JyBpcyBqdXN0IGEgc2xhc2gsIG9yIG5vdGhpbmcuXG5jb25zdCBzcGxpdFBhdGhSZSA9IC9eKFxcUys6XFxcXHxcXC8/KShbXFxzXFxTXSo/KSgoPzpcXC57MSwyfXxbXi9cXFxcXSs/fCkoXFwuW14uL1xcXFxdKnwpKSg/OlsvXFxcXF0qKSQvO1xuLyoqIEpTRG9jICovXG5mdW5jdGlvbiBzcGxpdFBhdGgoZmlsZW5hbWUpIHtcbiAgLy8gVHJ1bmNhdGUgZmlsZXMgbmFtZXMgZ3JlYXRlciB0aGFuIDEwMjQgY2hhcmFjdGVycyB0byBhdm9pZCByZWdleCBkb3NcbiAgLy8gaHR0cHM6Ly9naXRodWIuY29tL2dldHNlbnRyeS9zZW50cnktamF2YXNjcmlwdC9wdWxsLzg3MzcjZGlzY3Vzc2lvbl9yMTI4NTcxOTE3MlxuICBjb25zdCB0cnVuY2F0ZWQgPSBmaWxlbmFtZS5sZW5ndGggPiAxMDI0ID8gYDx0cnVuY2F0ZWQ+JHtmaWxlbmFtZS5zbGljZSgtMTAyNCl9YCA6IGZpbGVuYW1lO1xuICBjb25zdCBwYXJ0cyA9IHNwbGl0UGF0aFJlLmV4ZWModHJ1bmNhdGVkKTtcbiAgcmV0dXJuIHBhcnRzID8gcGFydHMuc2xpY2UoMSkgOiBbXTtcbn1cblxuLy8gcGF0aC5yZXNvbHZlKFtmcm9tIC4uLl0sIHRvKVxuLy8gcG9zaXggdmVyc2lvblxuLyoqIEpTRG9jICovXG5mdW5jdGlvbiByZXNvbHZlKC4uLmFyZ3MpIHtcbiAgbGV0IHJlc29sdmVkUGF0aCA9ICcnO1xuICBsZXQgcmVzb2x2ZWRBYnNvbHV0ZSA9IGZhbHNlO1xuXG4gIGZvciAobGV0IGkgPSBhcmdzLmxlbmd0aCAtIDE7IGkgPj0gLTEgJiYgIXJlc29sdmVkQWJzb2x1dGU7IGktLSkge1xuICAgIGNvbnN0IHBhdGggPSBpID49IDAgPyBhcmdzW2ldIDogJy8nO1xuXG4gICAgLy8gU2tpcCBlbXB0eSBlbnRyaWVzXG4gICAgaWYgKCFwYXRoKSB7XG4gICAgICBjb250aW51ZTtcbiAgICB9XG5cbiAgICByZXNvbHZlZFBhdGggPSBgJHtwYXRofS8ke3Jlc29sdmVkUGF0aH1gO1xuICAgIHJlc29sdmVkQWJzb2x1dGUgPSBwYXRoLmNoYXJBdCgwKSA9PT0gJy8nO1xuICB9XG5cbiAgLy8gQXQgdGhpcyBwb2ludCB0aGUgcGF0aCBzaG91bGQgYmUgcmVzb2x2ZWQgdG8gYSBmdWxsIGFic29sdXRlIHBhdGgsIGJ1dFxuICAvLyBoYW5kbGUgcmVsYXRpdmUgcGF0aHMgdG8gYmUgc2FmZSAobWlnaHQgaGFwcGVuIHdoZW4gcHJvY2Vzcy5jd2QoKSBmYWlscylcblxuICAvLyBOb3JtYWxpemUgdGhlIHBhdGhcbiAgcmVzb2x2ZWRQYXRoID0gbm9ybWFsaXplQXJyYXkoXG4gICAgcmVzb2x2ZWRQYXRoLnNwbGl0KCcvJykuZmlsdGVyKHAgPT4gISFwKSxcbiAgICAhcmVzb2x2ZWRBYnNvbHV0ZSxcbiAgKS5qb2luKCcvJyk7XG5cbiAgcmV0dXJuIChyZXNvbHZlZEFic29sdXRlID8gJy8nIDogJycpICsgcmVzb2x2ZWRQYXRoIHx8ICcuJztcbn1cblxuLyoqIEpTRG9jICovXG5mdW5jdGlvbiB0cmltKGFycikge1xuICBsZXQgc3RhcnQgPSAwO1xuICBmb3IgKDsgc3RhcnQgPCBhcnIubGVuZ3RoOyBzdGFydCsrKSB7XG4gICAgaWYgKGFycltzdGFydF0gIT09ICcnKSB7XG4gICAgICBicmVhaztcbiAgICB9XG4gIH1cblxuICBsZXQgZW5kID0gYXJyLmxlbmd0aCAtIDE7XG4gIGZvciAoOyBlbmQgPj0gMDsgZW5kLS0pIHtcbiAgICBpZiAoYXJyW2VuZF0gIT09ICcnKSB7XG4gICAgICBicmVhaztcbiAgICB9XG4gIH1cblxuICBpZiAoc3RhcnQgPiBlbmQpIHtcbiAgICByZXR1cm4gW107XG4gIH1cbiAgcmV0dXJuIGFyci5zbGljZShzdGFydCwgZW5kIC0gc3RhcnQgKyAxKTtcbn1cblxuLy8gcGF0aC5yZWxhdGl2ZShmcm9tLCB0bylcbi8vIHBvc2l4IHZlcnNpb25cbi8qKiBKU0RvYyAqL1xuZnVuY3Rpb24gcmVsYXRpdmUoZnJvbSwgdG8pIHtcbiAgLyogZXNsaW50LWRpc2FibGUgbm8tcGFyYW0tcmVhc3NpZ24gKi9cbiAgZnJvbSA9IHJlc29sdmUoZnJvbSkuc2xpY2UoMSk7XG4gIHRvID0gcmVzb2x2ZSh0bykuc2xpY2UoMSk7XG4gIC8qIGVzbGludC1lbmFibGUgbm8tcGFyYW0tcmVhc3NpZ24gKi9cblxuICBjb25zdCBmcm9tUGFydHMgPSB0cmltKGZyb20uc3BsaXQoJy8nKSk7XG4gIGNvbnN0IHRvUGFydHMgPSB0cmltKHRvLnNwbGl0KCcvJykpO1xuXG4gIGNvbnN0IGxlbmd0aCA9IE1hdGgubWluKGZyb21QYXJ0cy5sZW5ndGgsIHRvUGFydHMubGVuZ3RoKTtcbiAgbGV0IHNhbWVQYXJ0c0xlbmd0aCA9IGxlbmd0aDtcbiAgZm9yIChsZXQgaSA9IDA7IGkgPCBsZW5ndGg7IGkrKykge1xuICAgIGlmIChmcm9tUGFydHNbaV0gIT09IHRvUGFydHNbaV0pIHtcbiAgICAgIHNhbWVQYXJ0c0xlbmd0aCA9IGk7XG4gICAgICBicmVhaztcbiAgICB9XG4gIH1cblxuICBsZXQgb3V0cHV0UGFydHMgPSBbXTtcbiAgZm9yIChsZXQgaSA9IHNhbWVQYXJ0c0xlbmd0aDsgaSA8IGZyb21QYXJ0cy5sZW5ndGg7IGkrKykge1xuICAgIG91dHB1dFBhcnRzLnB1c2goJy4uJyk7XG4gIH1cblxuICBvdXRwdXRQYXJ0cyA9IG91dHB1dFBhcnRzLmNvbmNhdCh0b1BhcnRzLnNsaWNlKHNhbWVQYXJ0c0xlbmd0aCkpO1xuXG4gIHJldHVybiBvdXRwdXRQYXJ0cy5qb2luKCcvJyk7XG59XG5cbi8vIHBhdGgubm9ybWFsaXplKHBhdGgpXG4vLyBwb3NpeCB2ZXJzaW9uXG4vKiogSlNEb2MgKi9cbmZ1bmN0aW9uIG5vcm1hbGl6ZVBhdGgocGF0aCkge1xuICBjb25zdCBpc1BhdGhBYnNvbHV0ZSA9IGlzQWJzb2x1dGUocGF0aCk7XG4gIGNvbnN0IHRyYWlsaW5nU2xhc2ggPSBwYXRoLnNsaWNlKC0xKSA9PT0gJy8nO1xuXG4gIC8vIE5vcm1hbGl6ZSB0aGUgcGF0aFxuICBsZXQgbm9ybWFsaXplZFBhdGggPSBub3JtYWxpemVBcnJheShcbiAgICBwYXRoLnNwbGl0KCcvJykuZmlsdGVyKHAgPT4gISFwKSxcbiAgICAhaXNQYXRoQWJzb2x1dGUsXG4gICkuam9pbignLycpO1xuXG4gIGlmICghbm9ybWFsaXplZFBhdGggJiYgIWlzUGF0aEFic29sdXRlKSB7XG4gICAgbm9ybWFsaXplZFBhdGggPSAnLic7XG4gIH1cbiAgaWYgKG5vcm1hbGl6ZWRQYXRoICYmIHRyYWlsaW5nU2xhc2gpIHtcbiAgICBub3JtYWxpemVkUGF0aCArPSAnLyc7XG4gIH1cblxuICByZXR1cm4gKGlzUGF0aEFic29sdXRlID8gJy8nIDogJycpICsgbm9ybWFsaXplZFBhdGg7XG59XG5cbi8vIHBvc2l4IHZlcnNpb25cbi8qKiBKU0RvYyAqL1xuZnVuY3Rpb24gaXNBYnNvbHV0ZShwYXRoKSB7XG4gIHJldHVybiBwYXRoLmNoYXJBdCgwKSA9PT0gJy8nO1xufVxuXG4vLyBwb3NpeCB2ZXJzaW9uXG4vKiogSlNEb2MgKi9cbmZ1bmN0aW9uIGpvaW4oLi4uYXJncykge1xuICByZXR1cm4gbm9ybWFsaXplUGF0aChhcmdzLmpvaW4oJy8nKSk7XG59XG5cbi8qKiBKU0RvYyAqL1xuZnVuY3Rpb24gZGlybmFtZShwYXRoKSB7XG4gIGNvbnN0IHJlc3VsdCA9IHNwbGl0UGF0aChwYXRoKTtcbiAgY29uc3Qgcm9vdCA9IHJlc3VsdFswXSB8fCAnJztcbiAgbGV0IGRpciA9IHJlc3VsdFsxXTtcblxuICBpZiAoIXJvb3QgJiYgIWRpcikge1xuICAgIC8vIE5vIGRpcm5hbWUgd2hhdHNvZXZlclxuICAgIHJldHVybiAnLic7XG4gIH1cblxuICBpZiAoZGlyKSB7XG4gICAgLy8gSXQgaGFzIGEgZGlybmFtZSwgc3RyaXAgdHJhaWxpbmcgc2xhc2hcbiAgICBkaXIgPSBkaXIuc2xpY2UoMCwgZGlyLmxlbmd0aCAtIDEpO1xuICB9XG5cbiAgcmV0dXJuIHJvb3QgKyBkaXI7XG59XG5cbi8qKiBKU0RvYyAqL1xuZnVuY3Rpb24gYmFzZW5hbWUocGF0aCwgZXh0KSB7XG4gIGxldCBmID0gc3BsaXRQYXRoKHBhdGgpWzJdIHx8ICcnO1xuICBpZiAoZXh0ICYmIGYuc2xpY2UoZXh0Lmxlbmd0aCAqIC0xKSA9PT0gZXh0KSB7XG4gICAgZiA9IGYuc2xpY2UoMCwgZi5sZW5ndGggLSBleHQubGVuZ3RoKTtcbiAgfVxuICByZXR1cm4gZjtcbn1cblxuZXhwb3J0cy5iYXNlbmFtZSA9IGJhc2VuYW1lO1xuZXhwb3J0cy5kaXJuYW1lID0gZGlybmFtZTtcbmV4cG9ydHMuaXNBYnNvbHV0ZSA9IGlzQWJzb2x1dGU7XG5leHBvcnRzLmpvaW4gPSBqb2luO1xuZXhwb3J0cy5ub3JtYWxpemVQYXRoID0gbm9ybWFsaXplUGF0aDtcbmV4cG9ydHMucmVsYXRpdmUgPSByZWxhdGl2ZTtcbmV4cG9ydHMucmVzb2x2ZSA9IHJlc29sdmU7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1wYXRoLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/path.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/prepareEvent.js":
/*!**********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/prepareEvent.js ***!
  \**********************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst constants = __webpack_require__(/*! ../constants.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/constants.js\");\nconst currentScopes = __webpack_require__(/*! ../currentScopes.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst eventProcessors = __webpack_require__(/*! ../eventProcessors.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/eventProcessors.js\");\nconst scope = __webpack_require__(/*! ../scope.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/scope.js\");\nconst applyScopeDataToEvent = __webpack_require__(/*! ./applyScopeDataToEvent.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/applyScopeDataToEvent.js\");\nconst debugIds = __webpack_require__(/*! ./debug-ids.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-ids.js\");\nconst misc = __webpack_require__(/*! ./misc.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/misc.js\");\nconst normalize = __webpack_require__(/*! ./normalize.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/normalize.js\");\nconst string = __webpack_require__(/*! ./string.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/string.js\");\nconst time = __webpack_require__(/*! ./time.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/time.js\");\n\n/**\n * This type makes sure that we get either a CaptureContext, OR an EventHint.\n * It does not allow mixing them, which could lead to unexpected outcomes, e.g. this is disallowed:\n * { user: { id: '123' }, mechanism: { handled: false } }\n */\n\n/**\n * Adds common information to events.\n *\n * The information includes release and environment from `options`,\n * breadcrumbs and context (extra, tags and user) from the scope.\n *\n * Information that is already present in the event is never overwritten. For\n * nested objects, such as the context, keys are merged.\n *\n * @param event The original event.\n * @param hint May contain additional information about the original exception.\n * @param scope A scope containing event metadata.\n * @returns A new event with more information.\n * @hidden\n */\nfunction prepareEvent(\n  options,\n  event,\n  hint,\n  scope,\n  client,\n  isolationScope,\n) {\n  const { normalizeDepth = 3, normalizeMaxBreadth = 1000 } = options;\n  const prepared = {\n    ...event,\n    event_id: event.event_id || hint.event_id || misc.uuid4(),\n    timestamp: event.timestamp || time.dateTimestampInSeconds(),\n  };\n  const integrations = hint.integrations || options.integrations.map(i => i.name);\n\n  applyClientOptions(prepared, options);\n  applyIntegrationsMetadata(prepared, integrations);\n\n  if (client) {\n    client.emit('applyFrameMetadata', event);\n  }\n\n  // Only put debug IDs onto frames for error events.\n  if (event.type === undefined) {\n    applyDebugIds(prepared, options.stackParser);\n  }\n\n  // If we have scope given to us, use it as the base for further modifications.\n  // This allows us to prevent unnecessary copying of data if `captureContext` is not provided.\n  const finalScope = getFinalScope(scope, hint.captureContext);\n\n  if (hint.mechanism) {\n    misc.addExceptionMechanism(prepared, hint.mechanism);\n  }\n\n  const clientEventProcessors = client ? client.getEventProcessors() : [];\n\n  // This should be the last thing called, since we want that\n  // {@link Scope.addEventProcessor} gets the finished prepared event.\n  // Merge scope data together\n  const data = currentScopes.getGlobalScope().getScopeData();\n\n  if (isolationScope) {\n    const isolationData = isolationScope.getScopeData();\n    applyScopeDataToEvent.mergeScopeData(data, isolationData);\n  }\n\n  if (finalScope) {\n    const finalScopeData = finalScope.getScopeData();\n    applyScopeDataToEvent.mergeScopeData(data, finalScopeData);\n  }\n\n  const attachments = [...(hint.attachments || []), ...data.attachments];\n  if (attachments.length) {\n    hint.attachments = attachments;\n  }\n\n  applyScopeDataToEvent.applyScopeDataToEvent(prepared, data);\n\n  const eventProcessors$1 = [\n    ...clientEventProcessors,\n    // Run scope event processors _after_ all other processors\n    ...data.eventProcessors,\n  ];\n\n  const result = eventProcessors.notifyEventProcessors(eventProcessors$1, prepared, hint);\n\n  return result.then(evt => {\n    if (evt) {\n      // We apply the debug_meta field only after all event processors have ran, so that if any event processors modified\n      // file names (e.g.the RewriteFrames integration) the filename -> debug ID relationship isn't destroyed.\n      // This should not cause any PII issues, since we're only moving data that is already on the event and not adding\n      // any new data\n      applyDebugMeta(evt);\n    }\n\n    if (typeof normalizeDepth === 'number' && normalizeDepth > 0) {\n      return normalizeEvent(evt, normalizeDepth, normalizeMaxBreadth);\n    }\n    return evt;\n  });\n}\n\n/**\n * Enhances event using the client configuration.\n * It takes care of all \"static\" values like environment, release and `dist`,\n * as well as truncating overly long values.\n *\n * Only exported for tests.\n *\n * @param event event instance to be enhanced\n */\nfunction applyClientOptions(event, options) {\n  const { environment, release, dist, maxValueLength = 250 } = options;\n\n  // empty strings do not make sense for environment, release, and dist\n  // so we handle them the same as if they were not provided\n  event.environment = event.environment || environment || constants.DEFAULT_ENVIRONMENT;\n\n  if (!event.release && release) {\n    event.release = release;\n  }\n\n  if (!event.dist && dist) {\n    event.dist = dist;\n  }\n\n  const request = event.request;\n  if (request?.url) {\n    request.url = string.truncate(request.url, maxValueLength);\n  }\n}\n\n/**\n * Puts debug IDs into the stack frames of an error event.\n */\nfunction applyDebugIds(event, stackParser) {\n  // Build a map of filename -> debug_id\n  const filenameDebugIdMap = debugIds.getFilenameToDebugIdMap(stackParser);\n\n  event.exception?.values?.forEach(exception => {\n    exception.stacktrace?.frames?.forEach(frame => {\n      if (frame.filename) {\n        frame.debug_id = filenameDebugIdMap[frame.filename];\n      }\n    });\n  });\n}\n\n/**\n * Moves debug IDs from the stack frames of an error event into the debug_meta field.\n */\nfunction applyDebugMeta(event) {\n  // Extract debug IDs and filenames from the stack frames on the event.\n  const filenameDebugIdMap = {};\n  event.exception?.values?.forEach(exception => {\n    exception.stacktrace?.frames?.forEach(frame => {\n      if (frame.debug_id) {\n        if (frame.abs_path) {\n          filenameDebugIdMap[frame.abs_path] = frame.debug_id;\n        } else if (frame.filename) {\n          filenameDebugIdMap[frame.filename] = frame.debug_id;\n        }\n        delete frame.debug_id;\n      }\n    });\n  });\n\n  if (Object.keys(filenameDebugIdMap).length === 0) {\n    return;\n  }\n\n  // Fill debug_meta information\n  event.debug_meta = event.debug_meta || {};\n  event.debug_meta.images = event.debug_meta.images || [];\n  const images = event.debug_meta.images;\n  Object.entries(filenameDebugIdMap).forEach(([filename, debug_id]) => {\n    images.push({\n      type: 'sourcemap',\n      code_file: filename,\n      debug_id,\n    });\n  });\n}\n\n/**\n * This function adds all used integrations to the SDK info in the event.\n * @param event The event that will be filled with all integrations.\n */\nfunction applyIntegrationsMetadata(event, integrationNames) {\n  if (integrationNames.length > 0) {\n    event.sdk = event.sdk || {};\n    event.sdk.integrations = [...(event.sdk.integrations || []), ...integrationNames];\n  }\n}\n\n/**\n * Applies `normalize` function on necessary `Event` attributes to make them safe for serialization.\n * Normalized keys:\n * - `breadcrumbs.data`\n * - `user`\n * - `contexts`\n * - `extra`\n * @param event Event\n * @returns Normalized event\n */\nfunction normalizeEvent(event, depth, maxBreadth) {\n  if (!event) {\n    return null;\n  }\n\n  const normalized = {\n    ...event,\n    ...(event.breadcrumbs && {\n      breadcrumbs: event.breadcrumbs.map(b => ({\n        ...b,\n        ...(b.data && {\n          data: normalize.normalize(b.data, depth, maxBreadth),\n        }),\n      })),\n    }),\n    ...(event.user && {\n      user: normalize.normalize(event.user, depth, maxBreadth),\n    }),\n    ...(event.contexts && {\n      contexts: normalize.normalize(event.contexts, depth, maxBreadth),\n    }),\n    ...(event.extra && {\n      extra: normalize.normalize(event.extra, depth, maxBreadth),\n    }),\n  };\n\n  // event.contexts.trace stores information about a Transaction. Similarly,\n  // event.spans[] stores information about child Spans. Given that a\n  // Transaction is conceptually a Span, normalization should apply to both\n  // Transactions and Spans consistently.\n  // For now the decision is to skip normalization of Transactions and Spans,\n  // so this block overwrites the normalized event to add back the original\n  // Transaction information prior to normalization.\n  if (event.contexts?.trace && normalized.contexts) {\n    normalized.contexts.trace = event.contexts.trace;\n\n    // event.contexts.trace.data may contain circular/dangerous data so we need to normalize it\n    if (event.contexts.trace.data) {\n      normalized.contexts.trace.data = normalize.normalize(event.contexts.trace.data, depth, maxBreadth);\n    }\n  }\n\n  // event.spans[].data may contain circular/dangerous data so we need to normalize it\n  if (event.spans) {\n    normalized.spans = event.spans.map(span => {\n      return {\n        ...span,\n        ...(span.data && {\n          data: normalize.normalize(span.data, depth, maxBreadth),\n        }),\n      };\n    });\n  }\n\n  // event.contexts.flags (FeatureFlagContext) stores context for our feature\n  // flag integrations. It has a greater nesting depth than our other typed\n  // Contexts, so we re-normalize with a fixed depth of 3 here. We do not want\n  // to skip this in case of conflicting, user-provided context.\n  if (event.contexts?.flags && normalized.contexts) {\n    normalized.contexts.flags = normalize.normalize(event.contexts.flags, 3, maxBreadth);\n  }\n\n  return normalized;\n}\n\nfunction getFinalScope(scope$1, captureContext) {\n  if (!captureContext) {\n    return scope$1;\n  }\n\n  const finalScope = scope$1 ? scope$1.clone() : new scope.Scope();\n  finalScope.update(captureContext);\n  return finalScope;\n}\n\n/**\n * Parse either an `EventHint` directly, or convert a `CaptureContext` to an `EventHint`.\n * This is used to allow to update method signatures that used to accept a `CaptureContext` but should now accept an `EventHint`.\n */\nfunction parseEventHintOrCaptureContext(\n  hint,\n) {\n  if (!hint) {\n    return undefined;\n  }\n\n  // If you pass a Scope or `() => Scope` as CaptureContext, we just return this as captureContext\n  if (hintIsScopeOrFunction(hint)) {\n    return { captureContext: hint };\n  }\n\n  if (hintIsScopeContext(hint)) {\n    return {\n      captureContext: hint,\n    };\n  }\n\n  return hint;\n}\n\nfunction hintIsScopeOrFunction(hint) {\n  return hint instanceof scope.Scope || typeof hint === 'function';\n}\n\nconst captureContextKeys = [\n  'user',\n  'level',\n  'extra',\n  'contexts',\n  'tags',\n  'fingerprint',\n  'propagationContext',\n] ;\n\nfunction hintIsScopeContext(hint) {\n  return Object.keys(hint).some(key => captureContextKeys.includes(key ));\n}\n\nexports.applyClientOptions = applyClientOptions;\nexports.applyDebugIds = applyDebugIds;\nexports.applyDebugMeta = applyDebugMeta;\nexports.parseEventHintOrCaptureContext = parseEventHintOrCaptureContext;\nexports.prepareEvent = prepareEvent;\n//# sourceMappingURL=prepareEvent.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9wcmVwYXJlRXZlbnQuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsa0JBQWtCLG1CQUFPLENBQUMsd0hBQWlCO0FBQzNDLHNCQUFzQixtQkFBTyxDQUFDLGdJQUFxQjtBQUNuRCx3QkFBd0IsbUJBQU8sQ0FBQyxvSUFBdUI7QUFDdkQsY0FBYyxtQkFBTyxDQUFDLGdIQUFhO0FBQ25DLDhCQUE4QixtQkFBTyxDQUFDLHFKQUE0QjtBQUNsRSxpQkFBaUIsbUJBQU8sQ0FBQyw2SEFBZ0I7QUFDekMsYUFBYSxtQkFBTyxDQUFDLG1IQUFXO0FBQ2hDLGtCQUFrQixtQkFBTyxDQUFDLDZIQUFnQjtBQUMxQyxlQUFlLG1CQUFPLENBQUMsdUhBQWE7QUFDcEMsYUFBYSxtQkFBTyxDQUFDLG1IQUFXOztBQUVoQztBQUNBO0FBQ0E7QUFDQSxLQUFLLFFBQVEsV0FBVyxlQUFlO0FBQ3ZDOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxVQUFVLGlEQUFpRDtBQUMzRDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBLE1BQU0sK0JBQStCO0FBQ3JDO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsR0FBRztBQUNIOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsVUFBVSxtREFBbUQ7O0FBRTdEO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxLQUFLO0FBQ0wsR0FBRztBQUNIOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxVQUFVO0FBQ1Y7QUFDQTtBQUNBO0FBQ0E7QUFDQSxLQUFLO0FBQ0wsR0FBRzs7QUFFSDtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsS0FBSztBQUNMLEdBQUc7QUFDSDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsU0FBUztBQUNULE9BQU87QUFDUCxLQUFLO0FBQ0w7QUFDQTtBQUNBLEtBQUs7QUFDTDtBQUNBO0FBQ0EsS0FBSztBQUNMO0FBQ0E7QUFDQSxLQUFLO0FBQ0w7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxTQUFTO0FBQ1Q7QUFDQSxLQUFLO0FBQ0w7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsYUFBYTtBQUNiOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQSwwQkFBMEI7QUFDMUIscUJBQXFCO0FBQ3JCLHNCQUFzQjtBQUN0QixzQ0FBc0M7QUFDdEMsb0JBQW9CO0FBQ3BCIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvcHJlcGFyZUV2ZW50LmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBjb25zdGFudHMgPSByZXF1aXJlKCcuLi9jb25zdGFudHMuanMnKTtcbmNvbnN0IGN1cnJlbnRTY29wZXMgPSByZXF1aXJlKCcuLi9jdXJyZW50U2NvcGVzLmpzJyk7XG5jb25zdCBldmVudFByb2Nlc3NvcnMgPSByZXF1aXJlKCcuLi9ldmVudFByb2Nlc3NvcnMuanMnKTtcbmNvbnN0IHNjb3BlID0gcmVxdWlyZSgnLi4vc2NvcGUuanMnKTtcbmNvbnN0IGFwcGx5U2NvcGVEYXRhVG9FdmVudCA9IHJlcXVpcmUoJy4vYXBwbHlTY29wZURhdGFUb0V2ZW50LmpzJyk7XG5jb25zdCBkZWJ1Z0lkcyA9IHJlcXVpcmUoJy4vZGVidWctaWRzLmpzJyk7XG5jb25zdCBtaXNjID0gcmVxdWlyZSgnLi9taXNjLmpzJyk7XG5jb25zdCBub3JtYWxpemUgPSByZXF1aXJlKCcuL25vcm1hbGl6ZS5qcycpO1xuY29uc3Qgc3RyaW5nID0gcmVxdWlyZSgnLi9zdHJpbmcuanMnKTtcbmNvbnN0IHRpbWUgPSByZXF1aXJlKCcuL3RpbWUuanMnKTtcblxuLyoqXG4gKiBUaGlzIHR5cGUgbWFrZXMgc3VyZSB0aGF0IHdlIGdldCBlaXRoZXIgYSBDYXB0dXJlQ29udGV4dCwgT1IgYW4gRXZlbnRIaW50LlxuICogSXQgZG9lcyBub3QgYWxsb3cgbWl4aW5nIHRoZW0sIHdoaWNoIGNvdWxkIGxlYWQgdG8gdW5leHBlY3RlZCBvdXRjb21lcywgZS5nLiB0aGlzIGlzIGRpc2FsbG93ZWQ6XG4gKiB7IHVzZXI6IHsgaWQ6ICcxMjMnIH0sIG1lY2hhbmlzbTogeyBoYW5kbGVkOiBmYWxzZSB9IH1cbiAqL1xuXG4vKipcbiAqIEFkZHMgY29tbW9uIGluZm9ybWF0aW9uIHRvIGV2ZW50cy5cbiAqXG4gKiBUaGUgaW5mb3JtYXRpb24gaW5jbHVkZXMgcmVsZWFzZSBhbmQgZW52aXJvbm1lbnQgZnJvbSBgb3B0aW9uc2AsXG4gKiBicmVhZGNydW1icyBhbmQgY29udGV4dCAoZXh0cmEsIHRhZ3MgYW5kIHVzZXIpIGZyb20gdGhlIHNjb3BlLlxuICpcbiAqIEluZm9ybWF0aW9uIHRoYXQgaXMgYWxyZWFkeSBwcmVzZW50IGluIHRoZSBldmVudCBpcyBuZXZlciBvdmVyd3JpdHRlbi4gRm9yXG4gKiBuZXN0ZWQgb2JqZWN0cywgc3VjaCBhcyB0aGUgY29udGV4dCwga2V5cyBhcmUgbWVyZ2VkLlxuICpcbiAqIEBwYXJhbSBldmVudCBUaGUgb3JpZ2luYWwgZXZlbnQuXG4gKiBAcGFyYW0gaGludCBNYXkgY29udGFpbiBhZGRpdGlvbmFsIGluZm9ybWF0aW9uIGFib3V0IHRoZSBvcmlnaW5hbCBleGNlcHRpb24uXG4gKiBAcGFyYW0gc2NvcGUgQSBzY29wZSBjb250YWluaW5nIGV2ZW50IG1ldGFkYXRhLlxuICogQHJldHVybnMgQSBuZXcgZXZlbnQgd2l0aCBtb3JlIGluZm9ybWF0aW9uLlxuICogQGhpZGRlblxuICovXG5mdW5jdGlvbiBwcmVwYXJlRXZlbnQoXG4gIG9wdGlvbnMsXG4gIGV2ZW50LFxuICBoaW50LFxuICBzY29wZSxcbiAgY2xpZW50LFxuICBpc29sYXRpb25TY29wZSxcbikge1xuICBjb25zdCB7IG5vcm1hbGl6ZURlcHRoID0gMywgbm9ybWFsaXplTWF4QnJlYWR0aCA9IDEwMDAgfSA9IG9wdGlvbnM7XG4gIGNvbnN0IHByZXBhcmVkID0ge1xuICAgIC4uLmV2ZW50LFxuICAgIGV2ZW50X2lkOiBldmVudC5ldmVudF9pZCB8fCBoaW50LmV2ZW50X2lkIHx8IG1pc2MudXVpZDQoKSxcbiAgICB0aW1lc3RhbXA6IGV2ZW50LnRpbWVzdGFtcCB8fCB0aW1lLmRhdGVUaW1lc3RhbXBJblNlY29uZHMoKSxcbiAgfTtcbiAgY29uc3QgaW50ZWdyYXRpb25zID0gaGludC5pbnRlZ3JhdGlvbnMgfHwgb3B0aW9ucy5pbnRlZ3JhdGlvbnMubWFwKGkgPT4gaS5uYW1lKTtcblxuICBhcHBseUNsaWVudE9wdGlvbnMocHJlcGFyZWQsIG9wdGlvbnMpO1xuICBhcHBseUludGVncmF0aW9uc01ldGFkYXRhKHByZXBhcmVkLCBpbnRlZ3JhdGlvbnMpO1xuXG4gIGlmIChjbGllbnQpIHtcbiAgICBjbGllbnQuZW1pdCgnYXBwbHlGcmFtZU1ldGFkYXRhJywgZXZlbnQpO1xuICB9XG5cbiAgLy8gT25seSBwdXQgZGVidWcgSURzIG9udG8gZnJhbWVzIGZvciBlcnJvciBldmVudHMuXG4gIGlmIChldmVudC50eXBlID09PSB1bmRlZmluZWQpIHtcbiAgICBhcHBseURlYnVnSWRzKHByZXBhcmVkLCBvcHRpb25zLnN0YWNrUGFyc2VyKTtcbiAgfVxuXG4gIC8vIElmIHdlIGhhdmUgc2NvcGUgZ2l2ZW4gdG8gdXMsIHVzZSBpdCBhcyB0aGUgYmFzZSBmb3IgZnVydGhlciBtb2RpZmljYXRpb25zLlxuICAvLyBUaGlzIGFsbG93cyB1cyB0byBwcmV2ZW50IHVubmVjZXNzYXJ5IGNvcHlpbmcgb2YgZGF0YSBpZiBgY2FwdHVyZUNvbnRleHRgIGlzIG5vdCBwcm92aWRlZC5cbiAgY29uc3QgZmluYWxTY29wZSA9IGdldEZpbmFsU2NvcGUoc2NvcGUsIGhpbnQuY2FwdHVyZUNvbnRleHQpO1xuXG4gIGlmIChoaW50Lm1lY2hhbmlzbSkge1xuICAgIG1pc2MuYWRkRXhjZXB0aW9uTWVjaGFuaXNtKHByZXBhcmVkLCBoaW50Lm1lY2hhbmlzbSk7XG4gIH1cblxuICBjb25zdCBjbGllbnRFdmVudFByb2Nlc3NvcnMgPSBjbGllbnQgPyBjbGllbnQuZ2V0RXZlbnRQcm9jZXNzb3JzKCkgOiBbXTtcblxuICAvLyBUaGlzIHNob3VsZCBiZSB0aGUgbGFzdCB0aGluZyBjYWxsZWQsIHNpbmNlIHdlIHdhbnQgdGhhdFxuICAvLyB7QGxpbmsgU2NvcGUuYWRkRXZlbnRQcm9jZXNzb3J9IGdldHMgdGhlIGZpbmlzaGVkIHByZXBhcmVkIGV2ZW50LlxuICAvLyBNZXJnZSBzY29wZSBkYXRhIHRvZ2V0aGVyXG4gIGNvbnN0IGRhdGEgPSBjdXJyZW50U2NvcGVzLmdldEdsb2JhbFNjb3BlKCkuZ2V0U2NvcGVEYXRhKCk7XG5cbiAgaWYgKGlzb2xhdGlvblNjb3BlKSB7XG4gICAgY29uc3QgaXNvbGF0aW9uRGF0YSA9IGlzb2xhdGlvblNjb3BlLmdldFNjb3BlRGF0YSgpO1xuICAgIGFwcGx5U2NvcGVEYXRhVG9FdmVudC5tZXJnZVNjb3BlRGF0YShkYXRhLCBpc29sYXRpb25EYXRhKTtcbiAgfVxuXG4gIGlmIChmaW5hbFNjb3BlKSB7XG4gICAgY29uc3QgZmluYWxTY29wZURhdGEgPSBmaW5hbFNjb3BlLmdldFNjb3BlRGF0YSgpO1xuICAgIGFwcGx5U2NvcGVEYXRhVG9FdmVudC5tZXJnZVNjb3BlRGF0YShkYXRhLCBmaW5hbFNjb3BlRGF0YSk7XG4gIH1cblxuICBjb25zdCBhdHRhY2htZW50cyA9IFsuLi4oaGludC5hdHRhY2htZW50cyB8fCBbXSksIC4uLmRhdGEuYXR0YWNobWVudHNdO1xuICBpZiAoYXR0YWNobWVudHMubGVuZ3RoKSB7XG4gICAgaGludC5hdHRhY2htZW50cyA9IGF0dGFjaG1lbnRzO1xuICB9XG5cbiAgYXBwbHlTY29wZURhdGFUb0V2ZW50LmFwcGx5U2NvcGVEYXRhVG9FdmVudChwcmVwYXJlZCwgZGF0YSk7XG5cbiAgY29uc3QgZXZlbnRQcm9jZXNzb3JzJDEgPSBbXG4gICAgLi4uY2xpZW50RXZlbnRQcm9jZXNzb3JzLFxuICAgIC8vIFJ1biBzY29wZSBldmVudCBwcm9jZXNzb3JzIF9hZnRlcl8gYWxsIG90aGVyIHByb2Nlc3NvcnNcbiAgICAuLi5kYXRhLmV2ZW50UHJvY2Vzc29ycyxcbiAgXTtcblxuICBjb25zdCByZXN1bHQgPSBldmVudFByb2Nlc3NvcnMubm90aWZ5RXZlbnRQcm9jZXNzb3JzKGV2ZW50UHJvY2Vzc29ycyQxLCBwcmVwYXJlZCwgaGludCk7XG5cbiAgcmV0dXJuIHJlc3VsdC50aGVuKGV2dCA9PiB7XG4gICAgaWYgKGV2dCkge1xuICAgICAgLy8gV2UgYXBwbHkgdGhlIGRlYnVnX21ldGEgZmllbGQgb25seSBhZnRlciBhbGwgZXZlbnQgcHJvY2Vzc29ycyBoYXZlIHJhbiwgc28gdGhhdCBpZiBhbnkgZXZlbnQgcHJvY2Vzc29ycyBtb2RpZmllZFxuICAgICAgLy8gZmlsZSBuYW1lcyAoZS5nLnRoZSBSZXdyaXRlRnJhbWVzIGludGVncmF0aW9uKSB0aGUgZmlsZW5hbWUgLT4gZGVidWcgSUQgcmVsYXRpb25zaGlwIGlzbid0IGRlc3Ryb3llZC5cbiAgICAgIC8vIFRoaXMgc2hvdWxkIG5vdCBjYXVzZSBhbnkgUElJIGlzc3Vlcywgc2luY2Ugd2UncmUgb25seSBtb3ZpbmcgZGF0YSB0aGF0IGlzIGFscmVhZHkgb24gdGhlIGV2ZW50IGFuZCBub3QgYWRkaW5nXG4gICAgICAvLyBhbnkgbmV3IGRhdGFcbiAgICAgIGFwcGx5RGVidWdNZXRhKGV2dCk7XG4gICAgfVxuXG4gICAgaWYgKHR5cGVvZiBub3JtYWxpemVEZXB0aCA9PT0gJ251bWJlcicgJiYgbm9ybWFsaXplRGVwdGggPiAwKSB7XG4gICAgICByZXR1cm4gbm9ybWFsaXplRXZlbnQoZXZ0LCBub3JtYWxpemVEZXB0aCwgbm9ybWFsaXplTWF4QnJlYWR0aCk7XG4gICAgfVxuICAgIHJldHVybiBldnQ7XG4gIH0pO1xufVxuXG4vKipcbiAqIEVuaGFuY2VzIGV2ZW50IHVzaW5nIHRoZSBjbGllbnQgY29uZmlndXJhdGlvbi5cbiAqIEl0IHRha2VzIGNhcmUgb2YgYWxsIFwic3RhdGljXCIgdmFsdWVzIGxpa2UgZW52aXJvbm1lbnQsIHJlbGVhc2UgYW5kIGBkaXN0YCxcbiAqIGFzIHdlbGwgYXMgdHJ1bmNhdGluZyBvdmVybHkgbG9uZyB2YWx1ZXMuXG4gKlxuICogT25seSBleHBvcnRlZCBmb3IgdGVzdHMuXG4gKlxuICogQHBhcmFtIGV2ZW50IGV2ZW50IGluc3RhbmNlIHRvIGJlIGVuaGFuY2VkXG4gKi9cbmZ1bmN0aW9uIGFwcGx5Q2xpZW50T3B0aW9ucyhldmVudCwgb3B0aW9ucykge1xuICBjb25zdCB7IGVudmlyb25tZW50LCByZWxlYXNlLCBkaXN0LCBtYXhWYWx1ZUxlbmd0aCA9IDI1MCB9ID0gb3B0aW9ucztcblxuICAvLyBlbXB0eSBzdHJpbmdzIGRvIG5vdCBtYWtlIHNlbnNlIGZvciBlbnZpcm9ubWVudCwgcmVsZWFzZSwgYW5kIGRpc3RcbiAgLy8gc28gd2UgaGFuZGxlIHRoZW0gdGhlIHNhbWUgYXMgaWYgdGhleSB3ZXJlIG5vdCBwcm92aWRlZFxuICBldmVudC5lbnZpcm9ubWVudCA9IGV2ZW50LmVudmlyb25tZW50IHx8IGVudmlyb25tZW50IHx8IGNvbnN0YW50cy5ERUZBVUxUX0VOVklST05NRU5UO1xuXG4gIGlmICghZXZlbnQucmVsZWFzZSAmJiByZWxlYXNlKSB7XG4gICAgZXZlbnQucmVsZWFzZSA9IHJlbGVhc2U7XG4gIH1cblxuICBpZiAoIWV2ZW50LmRpc3QgJiYgZGlzdCkge1xuICAgIGV2ZW50LmRpc3QgPSBkaXN0O1xuICB9XG5cbiAgY29uc3QgcmVxdWVzdCA9IGV2ZW50LnJlcXVlc3Q7XG4gIGlmIChyZXF1ZXN0Py51cmwpIHtcbiAgICByZXF1ZXN0LnVybCA9IHN0cmluZy50cnVuY2F0ZShyZXF1ZXN0LnVybCwgbWF4VmFsdWVMZW5ndGgpO1xuICB9XG59XG5cbi8qKlxuICogUHV0cyBkZWJ1ZyBJRHMgaW50byB0aGUgc3RhY2sgZnJhbWVzIG9mIGFuIGVycm9yIGV2ZW50LlxuICovXG5mdW5jdGlvbiBhcHBseURlYnVnSWRzKGV2ZW50LCBzdGFja1BhcnNlcikge1xuICAvLyBCdWlsZCBhIG1hcCBvZiBmaWxlbmFtZSAtPiBkZWJ1Z19pZFxuICBjb25zdCBmaWxlbmFtZURlYnVnSWRNYXAgPSBkZWJ1Z0lkcy5nZXRGaWxlbmFtZVRvRGVidWdJZE1hcChzdGFja1BhcnNlcik7XG5cbiAgZXZlbnQuZXhjZXB0aW9uPy52YWx1ZXM/LmZvckVhY2goZXhjZXB0aW9uID0+IHtcbiAgICBleGNlcHRpb24uc3RhY2t0cmFjZT8uZnJhbWVzPy5mb3JFYWNoKGZyYW1lID0+IHtcbiAgICAgIGlmIChmcmFtZS5maWxlbmFtZSkge1xuICAgICAgICBmcmFtZS5kZWJ1Z19pZCA9IGZpbGVuYW1lRGVidWdJZE1hcFtmcmFtZS5maWxlbmFtZV07XG4gICAgICB9XG4gICAgfSk7XG4gIH0pO1xufVxuXG4vKipcbiAqIE1vdmVzIGRlYnVnIElEcyBmcm9tIHRoZSBzdGFjayBmcmFtZXMgb2YgYW4gZXJyb3IgZXZlbnQgaW50byB0aGUgZGVidWdfbWV0YSBmaWVsZC5cbiAqL1xuZnVuY3Rpb24gYXBwbHlEZWJ1Z01ldGEoZXZlbnQpIHtcbiAgLy8gRXh0cmFjdCBkZWJ1ZyBJRHMgYW5kIGZpbGVuYW1lcyBmcm9tIHRoZSBzdGFjayBmcmFtZXMgb24gdGhlIGV2ZW50LlxuICBjb25zdCBmaWxlbmFtZURlYnVnSWRNYXAgPSB7fTtcbiAgZXZlbnQuZXhjZXB0aW9uPy52YWx1ZXM/LmZvckVhY2goZXhjZXB0aW9uID0+IHtcbiAgICBleGNlcHRpb24uc3RhY2t0cmFjZT8uZnJhbWVzPy5mb3JFYWNoKGZyYW1lID0+IHtcbiAgICAgIGlmIChmcmFtZS5kZWJ1Z19pZCkge1xuICAgICAgICBpZiAoZnJhbWUuYWJzX3BhdGgpIHtcbiAgICAgICAgICBmaWxlbmFtZURlYnVnSWRNYXBbZnJhbWUuYWJzX3BhdGhdID0gZnJhbWUuZGVidWdfaWQ7XG4gICAgICAgIH0gZWxzZSBpZiAoZnJhbWUuZmlsZW5hbWUpIHtcbiAgICAgICAgICBmaWxlbmFtZURlYnVnSWRNYXBbZnJhbWUuZmlsZW5hbWVdID0gZnJhbWUuZGVidWdfaWQ7XG4gICAgICAgIH1cbiAgICAgICAgZGVsZXRlIGZyYW1lLmRlYnVnX2lkO1xuICAgICAgfVxuICAgIH0pO1xuICB9KTtcblxuICBpZiAoT2JqZWN0LmtleXMoZmlsZW5hbWVEZWJ1Z0lkTWFwKS5sZW5ndGggPT09IDApIHtcbiAgICByZXR1cm47XG4gIH1cblxuICAvLyBGaWxsIGRlYnVnX21ldGEgaW5mb3JtYXRpb25cbiAgZXZlbnQuZGVidWdfbWV0YSA9IGV2ZW50LmRlYnVnX21ldGEgfHwge307XG4gIGV2ZW50LmRlYnVnX21ldGEuaW1hZ2VzID0gZXZlbnQuZGVidWdfbWV0YS5pbWFnZXMgfHwgW107XG4gIGNvbnN0IGltYWdlcyA9IGV2ZW50LmRlYnVnX21ldGEuaW1hZ2VzO1xuICBPYmplY3QuZW50cmllcyhmaWxlbmFtZURlYnVnSWRNYXApLmZvckVhY2goKFtmaWxlbmFtZSwgZGVidWdfaWRdKSA9PiB7XG4gICAgaW1hZ2VzLnB1c2goe1xuICAgICAgdHlwZTogJ3NvdXJjZW1hcCcsXG4gICAgICBjb2RlX2ZpbGU6IGZpbGVuYW1lLFxuICAgICAgZGVidWdfaWQsXG4gICAgfSk7XG4gIH0pO1xufVxuXG4vKipcbiAqIFRoaXMgZnVuY3Rpb24gYWRkcyBhbGwgdXNlZCBpbnRlZ3JhdGlvbnMgdG8gdGhlIFNESyBpbmZvIGluIHRoZSBldmVudC5cbiAqIEBwYXJhbSBldmVudCBUaGUgZXZlbnQgdGhhdCB3aWxsIGJlIGZpbGxlZCB3aXRoIGFsbCBpbnRlZ3JhdGlvbnMuXG4gKi9cbmZ1bmN0aW9uIGFwcGx5SW50ZWdyYXRpb25zTWV0YWRhdGEoZXZlbnQsIGludGVncmF0aW9uTmFtZXMpIHtcbiAgaWYgKGludGVncmF0aW9uTmFtZXMubGVuZ3RoID4gMCkge1xuICAgIGV2ZW50LnNkayA9IGV2ZW50LnNkayB8fCB7fTtcbiAgICBldmVudC5zZGsuaW50ZWdyYXRpb25zID0gWy4uLihldmVudC5zZGsuaW50ZWdyYXRpb25zIHx8IFtdKSwgLi4uaW50ZWdyYXRpb25OYW1lc107XG4gIH1cbn1cblxuLyoqXG4gKiBBcHBsaWVzIGBub3JtYWxpemVgIGZ1bmN0aW9uIG9uIG5lY2Vzc2FyeSBgRXZlbnRgIGF0dHJpYnV0ZXMgdG8gbWFrZSB0aGVtIHNhZmUgZm9yIHNlcmlhbGl6YXRpb24uXG4gKiBOb3JtYWxpemVkIGtleXM6XG4gKiAtIGBicmVhZGNydW1icy5kYXRhYFxuICogLSBgdXNlcmBcbiAqIC0gYGNvbnRleHRzYFxuICogLSBgZXh0cmFgXG4gKiBAcGFyYW0gZXZlbnQgRXZlbnRcbiAqIEByZXR1cm5zIE5vcm1hbGl6ZWQgZXZlbnRcbiAqL1xuZnVuY3Rpb24gbm9ybWFsaXplRXZlbnQoZXZlbnQsIGRlcHRoLCBtYXhCcmVhZHRoKSB7XG4gIGlmICghZXZlbnQpIHtcbiAgICByZXR1cm4gbnVsbDtcbiAgfVxuXG4gIGNvbnN0IG5vcm1hbGl6ZWQgPSB7XG4gICAgLi4uZXZlbnQsXG4gICAgLi4uKGV2ZW50LmJyZWFkY3J1bWJzICYmIHtcbiAgICAgIGJyZWFkY3J1bWJzOiBldmVudC5icmVhZGNydW1icy5tYXAoYiA9PiAoe1xuICAgICAgICAuLi5iLFxuICAgICAgICAuLi4oYi5kYXRhICYmIHtcbiAgICAgICAgICBkYXRhOiBub3JtYWxpemUubm9ybWFsaXplKGIuZGF0YSwgZGVwdGgsIG1heEJyZWFkdGgpLFxuICAgICAgICB9KSxcbiAgICAgIH0pKSxcbiAgICB9KSxcbiAgICAuLi4oZXZlbnQudXNlciAmJiB7XG4gICAgICB1c2VyOiBub3JtYWxpemUubm9ybWFsaXplKGV2ZW50LnVzZXIsIGRlcHRoLCBtYXhCcmVhZHRoKSxcbiAgICB9KSxcbiAgICAuLi4oZXZlbnQuY29udGV4dHMgJiYge1xuICAgICAgY29udGV4dHM6IG5vcm1hbGl6ZS5ub3JtYWxpemUoZXZlbnQuY29udGV4dHMsIGRlcHRoLCBtYXhCcmVhZHRoKSxcbiAgICB9KSxcbiAgICAuLi4oZXZlbnQuZXh0cmEgJiYge1xuICAgICAgZXh0cmE6IG5vcm1hbGl6ZS5ub3JtYWxpemUoZXZlbnQuZXh0cmEsIGRlcHRoLCBtYXhCcmVhZHRoKSxcbiAgICB9KSxcbiAgfTtcblxuICAvLyBldmVudC5jb250ZXh0cy50cmFjZSBzdG9yZXMgaW5mb3JtYXRpb24gYWJvdXQgYSBUcmFuc2FjdGlvbi4gU2ltaWxhcmx5LFxuICAvLyBldmVudC5zcGFuc1tdIHN0b3JlcyBpbmZvcm1hdGlvbiBhYm91dCBjaGlsZCBTcGFucy4gR2l2ZW4gdGhhdCBhXG4gIC8vIFRyYW5zYWN0aW9uIGlzIGNvbmNlcHR1YWxseSBhIFNwYW4sIG5vcm1hbGl6YXRpb24gc2hvdWxkIGFwcGx5IHRvIGJvdGhcbiAgLy8gVHJhbnNhY3Rpb25zIGFuZCBTcGFucyBjb25zaXN0ZW50bHkuXG4gIC8vIEZvciBub3cgdGhlIGRlY2lzaW9uIGlzIHRvIHNraXAgbm9ybWFsaXphdGlvbiBvZiBUcmFuc2FjdGlvbnMgYW5kIFNwYW5zLFxuICAvLyBzbyB0aGlzIGJsb2NrIG92ZXJ3cml0ZXMgdGhlIG5vcm1hbGl6ZWQgZXZlbnQgdG8gYWRkIGJhY2sgdGhlIG9yaWdpbmFsXG4gIC8vIFRyYW5zYWN0aW9uIGluZm9ybWF0aW9uIHByaW9yIHRvIG5vcm1hbGl6YXRpb24uXG4gIGlmIChldmVudC5jb250ZXh0cz8udHJhY2UgJiYgbm9ybWFsaXplZC5jb250ZXh0cykge1xuICAgIG5vcm1hbGl6ZWQuY29udGV4dHMudHJhY2UgPSBldmVudC5jb250ZXh0cy50cmFjZTtcblxuICAgIC8vIGV2ZW50LmNvbnRleHRzLnRyYWNlLmRhdGEgbWF5IGNvbnRhaW4gY2lyY3VsYXIvZGFuZ2Vyb3VzIGRhdGEgc28gd2UgbmVlZCB0byBub3JtYWxpemUgaXRcbiAgICBpZiAoZXZlbnQuY29udGV4dHMudHJhY2UuZGF0YSkge1xuICAgICAgbm9ybWFsaXplZC5jb250ZXh0cy50cmFjZS5kYXRhID0gbm9ybWFsaXplLm5vcm1hbGl6ZShldmVudC5jb250ZXh0cy50cmFjZS5kYXRhLCBkZXB0aCwgbWF4QnJlYWR0aCk7XG4gICAgfVxuICB9XG5cbiAgLy8gZXZlbnQuc3BhbnNbXS5kYXRhIG1heSBjb250YWluIGNpcmN1bGFyL2Rhbmdlcm91cyBkYXRhIHNvIHdlIG5lZWQgdG8gbm9ybWFsaXplIGl0XG4gIGlmIChldmVudC5zcGFucykge1xuICAgIG5vcm1hbGl6ZWQuc3BhbnMgPSBldmVudC5zcGFucy5tYXAoc3BhbiA9PiB7XG4gICAgICByZXR1cm4ge1xuICAgICAgICAuLi5zcGFuLFxuICAgICAgICAuLi4oc3Bhbi5kYXRhICYmIHtcbiAgICAgICAgICBkYXRhOiBub3JtYWxpemUubm9ybWFsaXplKHNwYW4uZGF0YSwgZGVwdGgsIG1heEJyZWFkdGgpLFxuICAgICAgICB9KSxcbiAgICAgIH07XG4gICAgfSk7XG4gIH1cblxuICAvLyBldmVudC5jb250ZXh0cy5mbGFncyAoRmVhdHVyZUZsYWdDb250ZXh0KSBzdG9yZXMgY29udGV4dCBmb3Igb3VyIGZlYXR1cmVcbiAgLy8gZmxhZyBpbnRlZ3JhdGlvbnMuIEl0IGhhcyBhIGdyZWF0ZXIgbmVzdGluZyBkZXB0aCB0aGFuIG91ciBvdGhlciB0eXBlZFxuICAvLyBDb250ZXh0cywgc28gd2UgcmUtbm9ybWFsaXplIHdpdGggYSBmaXhlZCBkZXB0aCBvZiAzIGhlcmUuIFdlIGRvIG5vdCB3YW50XG4gIC8vIHRvIHNraXAgdGhpcyBpbiBjYXNlIG9mIGNvbmZsaWN0aW5nLCB1c2VyLXByb3ZpZGVkIGNvbnRleHQuXG4gIGlmIChldmVudC5jb250ZXh0cz8uZmxhZ3MgJiYgbm9ybWFsaXplZC5jb250ZXh0cykge1xuICAgIG5vcm1hbGl6ZWQuY29udGV4dHMuZmxhZ3MgPSBub3JtYWxpemUubm9ybWFsaXplKGV2ZW50LmNvbnRleHRzLmZsYWdzLCAzLCBtYXhCcmVhZHRoKTtcbiAgfVxuXG4gIHJldHVybiBub3JtYWxpemVkO1xufVxuXG5mdW5jdGlvbiBnZXRGaW5hbFNjb3BlKHNjb3BlJDEsIGNhcHR1cmVDb250ZXh0KSB7XG4gIGlmICghY2FwdHVyZUNvbnRleHQpIHtcbiAgICByZXR1cm4gc2NvcGUkMTtcbiAgfVxuXG4gIGNvbnN0IGZpbmFsU2NvcGUgPSBzY29wZSQxID8gc2NvcGUkMS5jbG9uZSgpIDogbmV3IHNjb3BlLlNjb3BlKCk7XG4gIGZpbmFsU2NvcGUudXBkYXRlKGNhcHR1cmVDb250ZXh0KTtcbiAgcmV0dXJuIGZpbmFsU2NvcGU7XG59XG5cbi8qKlxuICogUGFyc2UgZWl0aGVyIGFuIGBFdmVudEhpbnRgIGRpcmVjdGx5LCBvciBjb252ZXJ0IGEgYENhcHR1cmVDb250ZXh0YCB0byBhbiBgRXZlbnRIaW50YC5cbiAqIFRoaXMgaXMgdXNlZCB0byBhbGxvdyB0byB1cGRhdGUgbWV0aG9kIHNpZ25hdHVyZXMgdGhhdCB1c2VkIHRvIGFjY2VwdCBhIGBDYXB0dXJlQ29udGV4dGAgYnV0IHNob3VsZCBub3cgYWNjZXB0IGFuIGBFdmVudEhpbnRgLlxuICovXG5mdW5jdGlvbiBwYXJzZUV2ZW50SGludE9yQ2FwdHVyZUNvbnRleHQoXG4gIGhpbnQsXG4pIHtcbiAgaWYgKCFoaW50KSB7XG4gICAgcmV0dXJuIHVuZGVmaW5lZDtcbiAgfVxuXG4gIC8vIElmIHlvdSBwYXNzIGEgU2NvcGUgb3IgYCgpID0+IFNjb3BlYCBhcyBDYXB0dXJlQ29udGV4dCwgd2UganVzdCByZXR1cm4gdGhpcyBhcyBjYXB0dXJlQ29udGV4dFxuICBpZiAoaGludElzU2NvcGVPckZ1bmN0aW9uKGhpbnQpKSB7XG4gICAgcmV0dXJuIHsgY2FwdHVyZUNvbnRleHQ6IGhpbnQgfTtcbiAgfVxuXG4gIGlmIChoaW50SXNTY29wZUNvbnRleHQoaGludCkpIHtcbiAgICByZXR1cm4ge1xuICAgICAgY2FwdHVyZUNvbnRleHQ6IGhpbnQsXG4gICAgfTtcbiAgfVxuXG4gIHJldHVybiBoaW50O1xufVxuXG5mdW5jdGlvbiBoaW50SXNTY29wZU9yRnVuY3Rpb24oaGludCkge1xuICByZXR1cm4gaGludCBpbnN0YW5jZW9mIHNjb3BlLlNjb3BlIHx8IHR5cGVvZiBoaW50ID09PSAnZnVuY3Rpb24nO1xufVxuXG5jb25zdCBjYXB0dXJlQ29udGV4dEtleXMgPSBbXG4gICd1c2VyJyxcbiAgJ2xldmVsJyxcbiAgJ2V4dHJhJyxcbiAgJ2NvbnRleHRzJyxcbiAgJ3RhZ3MnLFxuICAnZmluZ2VycHJpbnQnLFxuICAncHJvcGFnYXRpb25Db250ZXh0Jyxcbl0gO1xuXG5mdW5jdGlvbiBoaW50SXNTY29wZUNvbnRleHQoaGludCkge1xuICByZXR1cm4gT2JqZWN0LmtleXMoaGludCkuc29tZShrZXkgPT4gY2FwdHVyZUNvbnRleHRLZXlzLmluY2x1ZGVzKGtleSApKTtcbn1cblxuZXhwb3J0cy5hcHBseUNsaWVudE9wdGlvbnMgPSBhcHBseUNsaWVudE9wdGlvbnM7XG5leHBvcnRzLmFwcGx5RGVidWdJZHMgPSBhcHBseURlYnVnSWRzO1xuZXhwb3J0cy5hcHBseURlYnVnTWV0YSA9IGFwcGx5RGVidWdNZXRhO1xuZXhwb3J0cy5wYXJzZUV2ZW50SGludE9yQ2FwdHVyZUNvbnRleHQgPSBwYXJzZUV2ZW50SGludE9yQ2FwdHVyZUNvbnRleHQ7XG5leHBvcnRzLnByZXBhcmVFdmVudCA9IHByZXBhcmVFdmVudDtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPXByZXBhcmVFdmVudC5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/prepareEvent.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/promisebuffer.js":
/*!***********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/promisebuffer.js ***!
  \***********************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst syncpromise = __webpack_require__(/*! ./syncpromise.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/syncpromise.js\");\n\nconst SENTRY_BUFFER_FULL_ERROR = Symbol.for('SentryBufferFullError');\n\n/**\n * Creates an new PromiseBuffer object with the specified limit\n * @param limit max number of promises that can be stored in the buffer\n */\nfunction makePromiseBuffer(limit) {\n  const buffer = [];\n\n  function isReady() {\n    return limit === undefined || buffer.length < limit;\n  }\n\n  /**\n   * Remove a promise from the queue.\n   *\n   * @param task Can be any PromiseLike<T>\n   * @returns Removed promise.\n   */\n  function remove(task) {\n    return buffer.splice(buffer.indexOf(task), 1)[0] || Promise.resolve(undefined);\n  }\n\n  /**\n   * Add a promise (representing an in-flight action) to the queue, and set it to remove itself on fulfillment.\n   *\n   * @param taskProducer A function producing any PromiseLike<T>; In previous versions this used to be `task:\n   *        PromiseLike<T>`, but under that model, Promises were instantly created on the call-site and their executor\n   *        functions therefore ran immediately. Thus, even if the buffer was full, the action still happened. By\n   *        requiring the promise to be wrapped in a function, we can defer promise creation until after the buffer\n   *        limit check.\n   * @returns The original promise.\n   */\n  function add(taskProducer) {\n    if (!isReady()) {\n      return syncpromise.rejectedSyncPromise(SENTRY_BUFFER_FULL_ERROR);\n    }\n\n    // start the task and add its promise to the queue\n    const task = taskProducer();\n    if (buffer.indexOf(task) === -1) {\n      buffer.push(task);\n    }\n    void task\n      .then(() => remove(task))\n      // Use `then(null, rejectionHandler)` rather than `catch(rejectionHandler)` so that we can use `PromiseLike`\n      // rather than `Promise`. `PromiseLike` doesn't have a `.catch` method, making its polyfill smaller. (ES5 didn't\n      // have promises, so TS has to polyfill when down-compiling.)\n      .then(null, () =>\n        remove(task).then(null, () => {\n          // We have to add another catch here because `remove()` starts a new promise chain.\n        }),\n      );\n    return task;\n  }\n\n  /**\n   * Wait for all promises in the queue to resolve or for timeout to expire, whichever comes first.\n   *\n   * @param timeout The time, in ms, after which to resolve to `false` if the queue is still non-empty. Passing `0` (or\n   * not passing anything) will make the promise wait as long as it takes for the queue to drain before resolving to\n   * `true`.\n   * @returns A promise which will resolve to `true` if the queue is already empty or drains before the timeout, and\n   * `false` otherwise\n   */\n  function drain(timeout) {\n    return new syncpromise.SyncPromise((resolve, reject) => {\n      let counter = buffer.length;\n\n      if (!counter) {\n        return resolve(true);\n      }\n\n      // wait for `timeout` ms and then resolve to `false` (if not cancelled first)\n      const capturedSetTimeout = setTimeout(() => {\n        if (timeout && timeout > 0) {\n          resolve(false);\n        }\n      }, timeout);\n\n      // if all promises resolve in time, cancel the timer and resolve to `true`\n      buffer.forEach(item => {\n        void syncpromise.resolvedSyncPromise(item).then(() => {\n          if (!--counter) {\n            clearTimeout(capturedSetTimeout);\n            resolve(true);\n          }\n        }, reject);\n      });\n    });\n  }\n\n  return {\n    $: buffer,\n    add,\n    drain,\n  };\n}\n\nexports.SENTRY_BUFFER_FULL_ERROR = SENTRY_BUFFER_FULL_ERROR;\nexports.makePromiseBuffer = makePromiseBuffer;\n//# sourceMappingURL=promisebuffer.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9wcm9taXNlYnVmZmVyLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLG9CQUFvQixtQkFBTyxDQUFDLGlJQUFrQjs7QUFFOUM7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0Esa0VBQWtFO0FBQ2xFO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsU0FBUztBQUNUO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxPQUFPOztBQUVQO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsU0FBUztBQUNULE9BQU87QUFDUCxLQUFLO0FBQ0w7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLGdDQUFnQztBQUNoQyx5QkFBeUI7QUFDekIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9wcm9taXNlYnVmZmVyLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBzeW5jcHJvbWlzZSA9IHJlcXVpcmUoJy4vc3luY3Byb21pc2UuanMnKTtcblxuY29uc3QgU0VOVFJZX0JVRkZFUl9GVUxMX0VSUk9SID0gU3ltYm9sLmZvcignU2VudHJ5QnVmZmVyRnVsbEVycm9yJyk7XG5cbi8qKlxuICogQ3JlYXRlcyBhbiBuZXcgUHJvbWlzZUJ1ZmZlciBvYmplY3Qgd2l0aCB0aGUgc3BlY2lmaWVkIGxpbWl0XG4gKiBAcGFyYW0gbGltaXQgbWF4IG51bWJlciBvZiBwcm9taXNlcyB0aGF0IGNhbiBiZSBzdG9yZWQgaW4gdGhlIGJ1ZmZlclxuICovXG5mdW5jdGlvbiBtYWtlUHJvbWlzZUJ1ZmZlcihsaW1pdCkge1xuICBjb25zdCBidWZmZXIgPSBbXTtcblxuICBmdW5jdGlvbiBpc1JlYWR5KCkge1xuICAgIHJldHVybiBsaW1pdCA9PT0gdW5kZWZpbmVkIHx8IGJ1ZmZlci5sZW5ndGggPCBsaW1pdDtcbiAgfVxuXG4gIC8qKlxuICAgKiBSZW1vdmUgYSBwcm9taXNlIGZyb20gdGhlIHF1ZXVlLlxuICAgKlxuICAgKiBAcGFyYW0gdGFzayBDYW4gYmUgYW55IFByb21pc2VMaWtlPFQ+XG4gICAqIEByZXR1cm5zIFJlbW92ZWQgcHJvbWlzZS5cbiAgICovXG4gIGZ1bmN0aW9uIHJlbW92ZSh0YXNrKSB7XG4gICAgcmV0dXJuIGJ1ZmZlci5zcGxpY2UoYnVmZmVyLmluZGV4T2YodGFzayksIDEpWzBdIHx8IFByb21pc2UucmVzb2x2ZSh1bmRlZmluZWQpO1xuICB9XG5cbiAgLyoqXG4gICAqIEFkZCBhIHByb21pc2UgKHJlcHJlc2VudGluZyBhbiBpbi1mbGlnaHQgYWN0aW9uKSB0byB0aGUgcXVldWUsIGFuZCBzZXQgaXQgdG8gcmVtb3ZlIGl0c2VsZiBvbiBmdWxmaWxsbWVudC5cbiAgICpcbiAgICogQHBhcmFtIHRhc2tQcm9kdWNlciBBIGZ1bmN0aW9uIHByb2R1Y2luZyBhbnkgUHJvbWlzZUxpa2U8VD47IEluIHByZXZpb3VzIHZlcnNpb25zIHRoaXMgdXNlZCB0byBiZSBgdGFzazpcbiAgICogICAgICAgIFByb21pc2VMaWtlPFQ+YCwgYnV0IHVuZGVyIHRoYXQgbW9kZWwsIFByb21pc2VzIHdlcmUgaW5zdGFudGx5IGNyZWF0ZWQgb24gdGhlIGNhbGwtc2l0ZSBhbmQgdGhlaXIgZXhlY3V0b3JcbiAgICogICAgICAgIGZ1bmN0aW9ucyB0aGVyZWZvcmUgcmFuIGltbWVkaWF0ZWx5LiBUaHVzLCBldmVuIGlmIHRoZSBidWZmZXIgd2FzIGZ1bGwsIHRoZSBhY3Rpb24gc3RpbGwgaGFwcGVuZWQuIEJ5XG4gICAqICAgICAgICByZXF1aXJpbmcgdGhlIHByb21pc2UgdG8gYmUgd3JhcHBlZCBpbiBhIGZ1bmN0aW9uLCB3ZSBjYW4gZGVmZXIgcHJvbWlzZSBjcmVhdGlvbiB1bnRpbCBhZnRlciB0aGUgYnVmZmVyXG4gICAqICAgICAgICBsaW1pdCBjaGVjay5cbiAgICogQHJldHVybnMgVGhlIG9yaWdpbmFsIHByb21pc2UuXG4gICAqL1xuICBmdW5jdGlvbiBhZGQodGFza1Byb2R1Y2VyKSB7XG4gICAgaWYgKCFpc1JlYWR5KCkpIHtcbiAgICAgIHJldHVybiBzeW5jcHJvbWlzZS5yZWplY3RlZFN5bmNQcm9taXNlKFNFTlRSWV9CVUZGRVJfRlVMTF9FUlJPUik7XG4gICAgfVxuXG4gICAgLy8gc3RhcnQgdGhlIHRhc2sgYW5kIGFkZCBpdHMgcHJvbWlzZSB0byB0aGUgcXVldWVcbiAgICBjb25zdCB0YXNrID0gdGFza1Byb2R1Y2VyKCk7XG4gICAgaWYgKGJ1ZmZlci5pbmRleE9mKHRhc2spID09PSAtMSkge1xuICAgICAgYnVmZmVyLnB1c2godGFzayk7XG4gICAgfVxuICAgIHZvaWQgdGFza1xuICAgICAgLnRoZW4oKCkgPT4gcmVtb3ZlKHRhc2spKVxuICAgICAgLy8gVXNlIGB0aGVuKG51bGwsIHJlamVjdGlvbkhhbmRsZXIpYCByYXRoZXIgdGhhbiBgY2F0Y2gocmVqZWN0aW9uSGFuZGxlcilgIHNvIHRoYXQgd2UgY2FuIHVzZSBgUHJvbWlzZUxpa2VgXG4gICAgICAvLyByYXRoZXIgdGhhbiBgUHJvbWlzZWAuIGBQcm9taXNlTGlrZWAgZG9lc24ndCBoYXZlIGEgYC5jYXRjaGAgbWV0aG9kLCBtYWtpbmcgaXRzIHBvbHlmaWxsIHNtYWxsZXIuIChFUzUgZGlkbid0XG4gICAgICAvLyBoYXZlIHByb21pc2VzLCBzbyBUUyBoYXMgdG8gcG9seWZpbGwgd2hlbiBkb3duLWNvbXBpbGluZy4pXG4gICAgICAudGhlbihudWxsLCAoKSA9PlxuICAgICAgICByZW1vdmUodGFzaykudGhlbihudWxsLCAoKSA9PiB7XG4gICAgICAgICAgLy8gV2UgaGF2ZSB0byBhZGQgYW5vdGhlciBjYXRjaCBoZXJlIGJlY2F1c2UgYHJlbW92ZSgpYCBzdGFydHMgYSBuZXcgcHJvbWlzZSBjaGFpbi5cbiAgICAgICAgfSksXG4gICAgICApO1xuICAgIHJldHVybiB0YXNrO1xuICB9XG5cbiAgLyoqXG4gICAqIFdhaXQgZm9yIGFsbCBwcm9taXNlcyBpbiB0aGUgcXVldWUgdG8gcmVzb2x2ZSBvciBmb3IgdGltZW91dCB0byBleHBpcmUsIHdoaWNoZXZlciBjb21lcyBmaXJzdC5cbiAgICpcbiAgICogQHBhcmFtIHRpbWVvdXQgVGhlIHRpbWUsIGluIG1zLCBhZnRlciB3aGljaCB0byByZXNvbHZlIHRvIGBmYWxzZWAgaWYgdGhlIHF1ZXVlIGlzIHN0aWxsIG5vbi1lbXB0eS4gUGFzc2luZyBgMGAgKG9yXG4gICAqIG5vdCBwYXNzaW5nIGFueXRoaW5nKSB3aWxsIG1ha2UgdGhlIHByb21pc2Ugd2FpdCBhcyBsb25nIGFzIGl0IHRha2VzIGZvciB0aGUgcXVldWUgdG8gZHJhaW4gYmVmb3JlIHJlc29sdmluZyB0b1xuICAgKiBgdHJ1ZWAuXG4gICAqIEByZXR1cm5zIEEgcHJvbWlzZSB3aGljaCB3aWxsIHJlc29sdmUgdG8gYHRydWVgIGlmIHRoZSBxdWV1ZSBpcyBhbHJlYWR5IGVtcHR5IG9yIGRyYWlucyBiZWZvcmUgdGhlIHRpbWVvdXQsIGFuZFxuICAgKiBgZmFsc2VgIG90aGVyd2lzZVxuICAgKi9cbiAgZnVuY3Rpb24gZHJhaW4odGltZW91dCkge1xuICAgIHJldHVybiBuZXcgc3luY3Byb21pc2UuU3luY1Byb21pc2UoKHJlc29sdmUsIHJlamVjdCkgPT4ge1xuICAgICAgbGV0IGNvdW50ZXIgPSBidWZmZXIubGVuZ3RoO1xuXG4gICAgICBpZiAoIWNvdW50ZXIpIHtcbiAgICAgICAgcmV0dXJuIHJlc29sdmUodHJ1ZSk7XG4gICAgICB9XG5cbiAgICAgIC8vIHdhaXQgZm9yIGB0aW1lb3V0YCBtcyBhbmQgdGhlbiByZXNvbHZlIHRvIGBmYWxzZWAgKGlmIG5vdCBjYW5jZWxsZWQgZmlyc3QpXG4gICAgICBjb25zdCBjYXB0dXJlZFNldFRpbWVvdXQgPSBzZXRUaW1lb3V0KCgpID0+IHtcbiAgICAgICAgaWYgKHRpbWVvdXQgJiYgdGltZW91dCA+IDApIHtcbiAgICAgICAgICByZXNvbHZlKGZhbHNlKTtcbiAgICAgICAgfVxuICAgICAgfSwgdGltZW91dCk7XG5cbiAgICAgIC8vIGlmIGFsbCBwcm9taXNlcyByZXNvbHZlIGluIHRpbWUsIGNhbmNlbCB0aGUgdGltZXIgYW5kIHJlc29sdmUgdG8gYHRydWVgXG4gICAgICBidWZmZXIuZm9yRWFjaChpdGVtID0+IHtcbiAgICAgICAgdm9pZCBzeW5jcHJvbWlzZS5yZXNvbHZlZFN5bmNQcm9taXNlKGl0ZW0pLnRoZW4oKCkgPT4ge1xuICAgICAgICAgIGlmICghLS1jb3VudGVyKSB7XG4gICAgICAgICAgICBjbGVhclRpbWVvdXQoY2FwdHVyZWRTZXRUaW1lb3V0KTtcbiAgICAgICAgICAgIHJlc29sdmUodHJ1ZSk7XG4gICAgICAgICAgfVxuICAgICAgICB9LCByZWplY3QpO1xuICAgICAgfSk7XG4gICAgfSk7XG4gIH1cblxuICByZXR1cm4ge1xuICAgICQ6IGJ1ZmZlcixcbiAgICBhZGQsXG4gICAgZHJhaW4sXG4gIH07XG59XG5cbmV4cG9ydHMuU0VOVFJZX0JVRkZFUl9GVUxMX0VSUk9SID0gU0VOVFJZX0JVRkZFUl9GVUxMX0VSUk9SO1xuZXhwb3J0cy5tYWtlUHJvbWlzZUJ1ZmZlciA9IG1ha2VQcm9taXNlQnVmZmVyO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9cHJvbWlzZWJ1ZmZlci5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/promisebuffer.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/propagationContext.js":
/*!****************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/propagationContext.js ***!
  \****************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst misc = __webpack_require__(/*! ./misc.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/misc.js\");\n\n/**\n * Generate a random, valid trace ID.\n */\nfunction generateTraceId() {\n  return misc.uuid4();\n}\n\n/**\n * Generate a random, valid span ID.\n */\nfunction generateSpanId() {\n  return misc.uuid4().substring(16);\n}\n\nexports.generateSpanId = generateSpanId;\nexports.generateTraceId = generateTraceId;\n//# sourceMappingURL=propagationContext.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9wcm9wYWdhdGlvbkNvbnRleHQuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsYUFBYSxtQkFBTyxDQUFDLG1IQUFXOztBQUVoQztBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLHNCQUFzQjtBQUN0Qix1QkFBdUI7QUFDdkIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9wcm9wYWdhdGlvbkNvbnRleHQuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IG1pc2MgPSByZXF1aXJlKCcuL21pc2MuanMnKTtcblxuLyoqXG4gKiBHZW5lcmF0ZSBhIHJhbmRvbSwgdmFsaWQgdHJhY2UgSUQuXG4gKi9cbmZ1bmN0aW9uIGdlbmVyYXRlVHJhY2VJZCgpIHtcbiAgcmV0dXJuIG1pc2MudXVpZDQoKTtcbn1cblxuLyoqXG4gKiBHZW5lcmF0ZSBhIHJhbmRvbSwgdmFsaWQgc3BhbiBJRC5cbiAqL1xuZnVuY3Rpb24gZ2VuZXJhdGVTcGFuSWQoKSB7XG4gIHJldHVybiBtaXNjLnV1aWQ0KCkuc3Vic3RyaW5nKDE2KTtcbn1cblxuZXhwb3J0cy5nZW5lcmF0ZVNwYW5JZCA9IGdlbmVyYXRlU3BhbklkO1xuZXhwb3J0cy5nZW5lcmF0ZVRyYWNlSWQgPSBnZW5lcmF0ZVRyYWNlSWQ7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1wcm9wYWdhdGlvbkNvbnRleHQuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/propagationContext.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/ratelimit.js":
/*!*******************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/ratelimit.js ***!
  \*******************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n// Intentionally keeping the key broad, as we don't know for sure what rate limit headers get returned from backend\n\nconst DEFAULT_RETRY_AFTER = 60 * 1000; // 60 seconds\n\n/**\n * Extracts Retry-After value from the request header or returns default value\n * @param header string representation of 'Retry-After' header\n * @param now current unix timestamp\n *\n */\nfunction parseRetryAfterHeader(header, now = Date.now()) {\n  const headerDelay = parseInt(`${header}`, 10);\n  if (!isNaN(headerDelay)) {\n    return headerDelay * 1000;\n  }\n\n  const headerDate = Date.parse(`${header}`);\n  if (!isNaN(headerDate)) {\n    return headerDate - now;\n  }\n\n  return DEFAULT_RETRY_AFTER;\n}\n\n/**\n * Gets the time that the given category is disabled until for rate limiting.\n * In case no category-specific limit is set but a general rate limit across all categories is active,\n * that time is returned.\n *\n * @return the time in ms that the category is disabled until or 0 if there's no active rate limit.\n */\nfunction disabledUntil(limits, dataCategory) {\n  return limits[dataCategory] || limits.all || 0;\n}\n\n/**\n * Checks if a category is rate limited\n */\nfunction isRateLimited(limits, dataCategory, now = Date.now()) {\n  return disabledUntil(limits, dataCategory) > now;\n}\n\n/**\n * Update ratelimits from incoming headers.\n *\n * @return the updated RateLimits object.\n */\nfunction updateRateLimits(\n  limits,\n  { statusCode, headers },\n  now = Date.now(),\n) {\n  const updatedRateLimits = {\n    ...limits,\n  };\n\n  // \"The name is case-insensitive.\"\n  // https://developer.mozilla.org/en-US/docs/Web/API/Headers/get\n  const rateLimitHeader = headers?.['x-sentry-rate-limits'];\n  const retryAfterHeader = headers?.['retry-after'];\n\n  if (rateLimitHeader) {\n    /**\n     * rate limit headers are of the form\n     *     <header>,<header>,..\n     * where each <header> is of the form\n     *     <retry_after>: <categories>: <scope>: <reason_code>: <namespaces>\n     * where\n     *     <retry_after> is a delay in seconds\n     *     <categories> is the event type(s) (error, transaction, etc) being rate limited and is of the form\n     *         <category>;<category>;...\n     *     <scope> is what's being limited (org, project, or key) - ignored by SDK\n     *     <reason_code> is an arbitrary string like \"org_quota\" - ignored by SDK\n     *     <namespaces> Semicolon-separated list of metric namespace identifiers. Defines which namespace(s) will be affected.\n     *         Only present if rate limit applies to the metric_bucket data category.\n     */\n    for (const limit of rateLimitHeader.trim().split(',')) {\n      const [retryAfter, categories, , , namespaces] = limit.split(':', 5) ;\n      const headerDelay = parseInt(retryAfter, 10);\n      const delay = (!isNaN(headerDelay) ? headerDelay : 60) * 1000; // 60sec default\n      if (!categories) {\n        updatedRateLimits.all = now + delay;\n      } else {\n        for (const category of categories.split(';')) {\n          if (category === 'metric_bucket') {\n            // namespaces will be present when category === 'metric_bucket'\n            if (!namespaces || namespaces.split(';').includes('custom')) {\n              updatedRateLimits[category] = now + delay;\n            }\n          } else {\n            updatedRateLimits[category] = now + delay;\n          }\n        }\n      }\n    }\n  } else if (retryAfterHeader) {\n    updatedRateLimits.all = now + parseRetryAfterHeader(retryAfterHeader, now);\n  } else if (statusCode === 429) {\n    updatedRateLimits.all = now + 60 * 1000;\n  }\n\n  return updatedRateLimits;\n}\n\nexports.DEFAULT_RETRY_AFTER = DEFAULT_RETRY_AFTER;\nexports.disabledUntil = disabledUntil;\nexports.isRateLimited = isRateLimited;\nexports.parseRetryAfterHeader = parseRetryAfterHeader;\nexports.updateRateLimits = updateRateLimits;\n//# sourceMappingURL=ratelimit.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9yYXRlbGltaXQuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEU7O0FBRUEsdUNBQXVDOztBQUV2QztBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGtDQUFrQyxPQUFPO0FBQ3pDO0FBQ0E7QUFDQTs7QUFFQSxtQ0FBbUMsT0FBTztBQUMxQztBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxJQUFJLHFCQUFxQjtBQUN6QjtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLDBCQUEwQixXQUFXO0FBQ3JDO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxxRUFBcUU7QUFDckU7QUFDQTtBQUNBLFFBQVE7QUFDUixrREFBa0Q7QUFDbEQ7QUFDQTtBQUNBLGtEQUFrRDtBQUNsRDtBQUNBO0FBQ0EsWUFBWTtBQUNaO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxJQUFJO0FBQ0o7QUFDQSxJQUFJO0FBQ0o7QUFDQTs7QUFFQTtBQUNBOztBQUVBLDJCQUEyQjtBQUMzQixxQkFBcUI7QUFDckIscUJBQXFCO0FBQ3JCLDZCQUE2QjtBQUM3Qix3QkFBd0I7QUFDeEIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9yYXRlbGltaXQuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbi8vIEludGVudGlvbmFsbHkga2VlcGluZyB0aGUga2V5IGJyb2FkLCBhcyB3ZSBkb24ndCBrbm93IGZvciBzdXJlIHdoYXQgcmF0ZSBsaW1pdCBoZWFkZXJzIGdldCByZXR1cm5lZCBmcm9tIGJhY2tlbmRcblxuY29uc3QgREVGQVVMVF9SRVRSWV9BRlRFUiA9IDYwICogMTAwMDsgLy8gNjAgc2Vjb25kc1xuXG4vKipcbiAqIEV4dHJhY3RzIFJldHJ5LUFmdGVyIHZhbHVlIGZyb20gdGhlIHJlcXVlc3QgaGVhZGVyIG9yIHJldHVybnMgZGVmYXVsdCB2YWx1ZVxuICogQHBhcmFtIGhlYWRlciBzdHJpbmcgcmVwcmVzZW50YXRpb24gb2YgJ1JldHJ5LUFmdGVyJyBoZWFkZXJcbiAqIEBwYXJhbSBub3cgY3VycmVudCB1bml4IHRpbWVzdGFtcFxuICpcbiAqL1xuZnVuY3Rpb24gcGFyc2VSZXRyeUFmdGVySGVhZGVyKGhlYWRlciwgbm93ID0gRGF0ZS5ub3coKSkge1xuICBjb25zdCBoZWFkZXJEZWxheSA9IHBhcnNlSW50KGAke2hlYWRlcn1gLCAxMCk7XG4gIGlmICghaXNOYU4oaGVhZGVyRGVsYXkpKSB7XG4gICAgcmV0dXJuIGhlYWRlckRlbGF5ICogMTAwMDtcbiAgfVxuXG4gIGNvbnN0IGhlYWRlckRhdGUgPSBEYXRlLnBhcnNlKGAke2hlYWRlcn1gKTtcbiAgaWYgKCFpc05hTihoZWFkZXJEYXRlKSkge1xuICAgIHJldHVybiBoZWFkZXJEYXRlIC0gbm93O1xuICB9XG5cbiAgcmV0dXJuIERFRkFVTFRfUkVUUllfQUZURVI7XG59XG5cbi8qKlxuICogR2V0cyB0aGUgdGltZSB0aGF0IHRoZSBnaXZlbiBjYXRlZ29yeSBpcyBkaXNhYmxlZCB1bnRpbCBmb3IgcmF0ZSBsaW1pdGluZy5cbiAqIEluIGNhc2Ugbm8gY2F0ZWdvcnktc3BlY2lmaWMgbGltaXQgaXMgc2V0IGJ1dCBhIGdlbmVyYWwgcmF0ZSBsaW1pdCBhY3Jvc3MgYWxsIGNhdGVnb3JpZXMgaXMgYWN0aXZlLFxuICogdGhhdCB0aW1lIGlzIHJldHVybmVkLlxuICpcbiAqIEByZXR1cm4gdGhlIHRpbWUgaW4gbXMgdGhhdCB0aGUgY2F0ZWdvcnkgaXMgZGlzYWJsZWQgdW50aWwgb3IgMCBpZiB0aGVyZSdzIG5vIGFjdGl2ZSByYXRlIGxpbWl0LlxuICovXG5mdW5jdGlvbiBkaXNhYmxlZFVudGlsKGxpbWl0cywgZGF0YUNhdGVnb3J5KSB7XG4gIHJldHVybiBsaW1pdHNbZGF0YUNhdGVnb3J5XSB8fCBsaW1pdHMuYWxsIHx8IDA7XG59XG5cbi8qKlxuICogQ2hlY2tzIGlmIGEgY2F0ZWdvcnkgaXMgcmF0ZSBsaW1pdGVkXG4gKi9cbmZ1bmN0aW9uIGlzUmF0ZUxpbWl0ZWQobGltaXRzLCBkYXRhQ2F0ZWdvcnksIG5vdyA9IERhdGUubm93KCkpIHtcbiAgcmV0dXJuIGRpc2FibGVkVW50aWwobGltaXRzLCBkYXRhQ2F0ZWdvcnkpID4gbm93O1xufVxuXG4vKipcbiAqIFVwZGF0ZSByYXRlbGltaXRzIGZyb20gaW5jb21pbmcgaGVhZGVycy5cbiAqXG4gKiBAcmV0dXJuIHRoZSB1cGRhdGVkIFJhdGVMaW1pdHMgb2JqZWN0LlxuICovXG5mdW5jdGlvbiB1cGRhdGVSYXRlTGltaXRzKFxuICBsaW1pdHMsXG4gIHsgc3RhdHVzQ29kZSwgaGVhZGVycyB9LFxuICBub3cgPSBEYXRlLm5vdygpLFxuKSB7XG4gIGNvbnN0IHVwZGF0ZWRSYXRlTGltaXRzID0ge1xuICAgIC4uLmxpbWl0cyxcbiAgfTtcblxuICAvLyBcIlRoZSBuYW1lIGlzIGNhc2UtaW5zZW5zaXRpdmUuXCJcbiAgLy8gaHR0cHM6Ly9kZXZlbG9wZXIubW96aWxsYS5vcmcvZW4tVVMvZG9jcy9XZWIvQVBJL0hlYWRlcnMvZ2V0XG4gIGNvbnN0IHJhdGVMaW1pdEhlYWRlciA9IGhlYWRlcnM/LlsneC1zZW50cnktcmF0ZS1saW1pdHMnXTtcbiAgY29uc3QgcmV0cnlBZnRlckhlYWRlciA9IGhlYWRlcnM/LlsncmV0cnktYWZ0ZXInXTtcblxuICBpZiAocmF0ZUxpbWl0SGVhZGVyKSB7XG4gICAgLyoqXG4gICAgICogcmF0ZSBsaW1pdCBoZWFkZXJzIGFyZSBvZiB0aGUgZm9ybVxuICAgICAqICAgICA8aGVhZGVyPiw8aGVhZGVyPiwuLlxuICAgICAqIHdoZXJlIGVhY2ggPGhlYWRlcj4gaXMgb2YgdGhlIGZvcm1cbiAgICAgKiAgICAgPHJldHJ5X2FmdGVyPjogPGNhdGVnb3JpZXM+OiA8c2NvcGU+OiA8cmVhc29uX2NvZGU+OiA8bmFtZXNwYWNlcz5cbiAgICAgKiB3aGVyZVxuICAgICAqICAgICA8cmV0cnlfYWZ0ZXI+IGlzIGEgZGVsYXkgaW4gc2Vjb25kc1xuICAgICAqICAgICA8Y2F0ZWdvcmllcz4gaXMgdGhlIGV2ZW50IHR5cGUocykgKGVycm9yLCB0cmFuc2FjdGlvbiwgZXRjKSBiZWluZyByYXRlIGxpbWl0ZWQgYW5kIGlzIG9mIHRoZSBmb3JtXG4gICAgICogICAgICAgICA8Y2F0ZWdvcnk+OzxjYXRlZ29yeT47Li4uXG4gICAgICogICAgIDxzY29wZT4gaXMgd2hhdCdzIGJlaW5nIGxpbWl0ZWQgKG9yZywgcHJvamVjdCwgb3Iga2V5KSAtIGlnbm9yZWQgYnkgU0RLXG4gICAgICogICAgIDxyZWFzb25fY29kZT4gaXMgYW4gYXJiaXRyYXJ5IHN0cmluZyBsaWtlIFwib3JnX3F1b3RhXCIgLSBpZ25vcmVkIGJ5IFNES1xuICAgICAqICAgICA8bmFtZXNwYWNlcz4gU2VtaWNvbG9uLXNlcGFyYXRlZCBsaXN0IG9mIG1ldHJpYyBuYW1lc3BhY2UgaWRlbnRpZmllcnMuIERlZmluZXMgd2hpY2ggbmFtZXNwYWNlKHMpIHdpbGwgYmUgYWZmZWN0ZWQuXG4gICAgICogICAgICAgICBPbmx5IHByZXNlbnQgaWYgcmF0ZSBsaW1pdCBhcHBsaWVzIHRvIHRoZSBtZXRyaWNfYnVja2V0IGRhdGEgY2F0ZWdvcnkuXG4gICAgICovXG4gICAgZm9yIChjb25zdCBsaW1pdCBvZiByYXRlTGltaXRIZWFkZXIudHJpbSgpLnNwbGl0KCcsJykpIHtcbiAgICAgIGNvbnN0IFtyZXRyeUFmdGVyLCBjYXRlZ29yaWVzLCAsICwgbmFtZXNwYWNlc10gPSBsaW1pdC5zcGxpdCgnOicsIDUpIDtcbiAgICAgIGNvbnN0IGhlYWRlckRlbGF5ID0gcGFyc2VJbnQocmV0cnlBZnRlciwgMTApO1xuICAgICAgY29uc3QgZGVsYXkgPSAoIWlzTmFOKGhlYWRlckRlbGF5KSA/IGhlYWRlckRlbGF5IDogNjApICogMTAwMDsgLy8gNjBzZWMgZGVmYXVsdFxuICAgICAgaWYgKCFjYXRlZ29yaWVzKSB7XG4gICAgICAgIHVwZGF0ZWRSYXRlTGltaXRzLmFsbCA9IG5vdyArIGRlbGF5O1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgZm9yIChjb25zdCBjYXRlZ29yeSBvZiBjYXRlZ29yaWVzLnNwbGl0KCc7JykpIHtcbiAgICAgICAgICBpZiAoY2F0ZWdvcnkgPT09ICdtZXRyaWNfYnVja2V0Jykge1xuICAgICAgICAgICAgLy8gbmFtZXNwYWNlcyB3aWxsIGJlIHByZXNlbnQgd2hlbiBjYXRlZ29yeSA9PT0gJ21ldHJpY19idWNrZXQnXG4gICAgICAgICAgICBpZiAoIW5hbWVzcGFjZXMgfHwgbmFtZXNwYWNlcy5zcGxpdCgnOycpLmluY2x1ZGVzKCdjdXN0b20nKSkge1xuICAgICAgICAgICAgICB1cGRhdGVkUmF0ZUxpbWl0c1tjYXRlZ29yeV0gPSBub3cgKyBkZWxheTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgdXBkYXRlZFJhdGVMaW1pdHNbY2F0ZWdvcnldID0gbm93ICsgZGVsYXk7XG4gICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICB9XG4gICAgfVxuICB9IGVsc2UgaWYgKHJldHJ5QWZ0ZXJIZWFkZXIpIHtcbiAgICB1cGRhdGVkUmF0ZUxpbWl0cy5hbGwgPSBub3cgKyBwYXJzZVJldHJ5QWZ0ZXJIZWFkZXIocmV0cnlBZnRlckhlYWRlciwgbm93KTtcbiAgfSBlbHNlIGlmIChzdGF0dXNDb2RlID09PSA0MjkpIHtcbiAgICB1cGRhdGVkUmF0ZUxpbWl0cy5hbGwgPSBub3cgKyA2MCAqIDEwMDA7XG4gIH1cblxuICByZXR1cm4gdXBkYXRlZFJhdGVMaW1pdHM7XG59XG5cbmV4cG9ydHMuREVGQVVMVF9SRVRSWV9BRlRFUiA9IERFRkFVTFRfUkVUUllfQUZURVI7XG5leHBvcnRzLmRpc2FibGVkVW50aWwgPSBkaXNhYmxlZFVudGlsO1xuZXhwb3J0cy5pc1JhdGVMaW1pdGVkID0gaXNSYXRlTGltaXRlZDtcbmV4cG9ydHMucGFyc2VSZXRyeUFmdGVySGVhZGVyID0gcGFyc2VSZXRyeUFmdGVySGVhZGVyO1xuZXhwb3J0cy51cGRhdGVSYXRlTGltaXRzID0gdXBkYXRlUmF0ZUxpbWl0cztcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPXJhdGVsaW1pdC5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/ratelimit.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/request.js":
/*!*****************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/request.js ***!
  \*****************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n/**\n * Transforms a `Headers` object that implements the `Web Fetch API` (https://developer.mozilla.org/en-US/docs/Web/API/Headers) into a simple key-value dict.\n * The header keys will be lower case: e.g. A \"Content-Type\" header will be stored as \"content-type\".\n */\nfunction winterCGHeadersToDict(winterCGHeaders) {\n  const headers = {};\n  try {\n    winterCGHeaders.forEach((value, key) => {\n      if (typeof value === 'string') {\n        // We check that value is a string even though it might be redundant to make sure prototype pollution is not possible.\n        headers[key] = value;\n      }\n    });\n  } catch {\n    // just return the empty headers\n  }\n\n  return headers;\n}\n\n/**\n * Convert common request headers to a simple dictionary.\n */\nfunction headersToDict(reqHeaders) {\n  const headers = Object.create(null);\n\n  try {\n    Object.entries(reqHeaders).forEach(([key, value]) => {\n      if (typeof value === 'string') {\n        headers[key] = value;\n      }\n    });\n  } catch {\n    // just return the empty headers\n  }\n\n  return headers;\n}\n\n/**\n * Converts a `Request` object that implements the `Web Fetch API` (https://developer.mozilla.org/en-US/docs/Web/API/Headers) into the format that the `RequestData` integration understands.\n */\nfunction winterCGRequestToRequestData(req) {\n  const headers = winterCGHeadersToDict(req.headers);\n\n  return {\n    method: req.method,\n    url: req.url,\n    query_string: extractQueryParamsFromUrl(req.url),\n    headers,\n    // TODO: Can we extract body data from the request?\n  };\n}\n\n/**\n * Convert a HTTP request object to RequestEventData to be passed as normalizedRequest.\n * Instead of allowing `PolymorphicRequest` to be passed,\n * we want to be more specific and generally require a http.IncomingMessage-like object.\n */\nfunction httpRequestToRequestData(request\n\n) {\n  const headers = request.headers || {};\n\n  // Check for x-forwarded-host first, then fall back to host header\n  const forwardedHost = typeof headers['x-forwarded-host'] === 'string' ? headers['x-forwarded-host'] : undefined;\n  const host = forwardedHost || (typeof headers.host === 'string' ? headers.host : undefined);\n\n  // Check for x-forwarded-proto first, then fall back to existing protocol detection\n  const forwardedProto = typeof headers['x-forwarded-proto'] === 'string' ? headers['x-forwarded-proto'] : undefined;\n  const protocol = forwardedProto || request.protocol || (request.socket?.encrypted ? 'https' : 'http');\n\n  const url = request.url || '';\n\n  const absoluteUrl = getAbsoluteUrl({\n    url,\n    host,\n    protocol,\n  });\n\n  // This is non-standard, but may be sometimes set\n  // It may be overwritten later by our own body handling\n  const data = (request ).body || undefined;\n\n  // This is non-standard, but may be set on e.g. Next.js or Express requests\n  const cookies = (request ).cookies;\n\n  return {\n    url: absoluteUrl,\n    method: request.method,\n    query_string: extractQueryParamsFromUrl(url),\n    headers: headersToDict(headers),\n    cookies,\n    data,\n  };\n}\n\nfunction getAbsoluteUrl({\n  url,\n  protocol,\n  host,\n}\n\n) {\n  if (url?.startsWith('http')) {\n    return url;\n  }\n\n  if (url && host) {\n    return `${protocol}://${host}${url}`;\n  }\n\n  return undefined;\n}\n\n/** Extract the query params from an URL. */\nfunction extractQueryParamsFromUrl(url) {\n  // url is path and query string\n  if (!url) {\n    return;\n  }\n\n  try {\n    // The `URL` constructor can't handle internal URLs of the form `/some/path/here`, so stick a dummy protocol and\n    // hostname as the base. Since the point here is just to grab the query string, it doesn't matter what we use.\n    const queryParams = new URL(url, 'http://s.io').search.slice(1);\n    return queryParams.length ? queryParams : undefined;\n  } catch {\n    return undefined;\n  }\n}\n\nexports.extractQueryParamsFromUrl = extractQueryParamsFromUrl;\nexports.headersToDict = headersToDict;\nexports.httpRequestToRequestData = httpRequestToRequestData;\nexports.winterCGHeadersToDict = winterCGHeadersToDict;\nexports.winterCGRequestToRequestData = winterCGRequestToRequestData;\n//# sourceMappingURL=request.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9yZXF1ZXN0LmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEtBQUs7QUFDTCxJQUFJO0FBQ0o7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEtBQUs7QUFDTCxJQUFJO0FBQ0o7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsR0FBRzs7QUFFSDtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBLGNBQWMsU0FBUyxLQUFLLEtBQUssRUFBRSxJQUFJO0FBQ3ZDOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxJQUFJO0FBQ0o7QUFDQTtBQUNBOztBQUVBLGlDQUFpQztBQUNqQyxxQkFBcUI7QUFDckIsZ0NBQWdDO0FBQ2hDLDZCQUE2QjtBQUM3QixvQ0FBb0M7QUFDcEMiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9yZXF1ZXN0LmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG4vKipcbiAqIFRyYW5zZm9ybXMgYSBgSGVhZGVyc2Agb2JqZWN0IHRoYXQgaW1wbGVtZW50cyB0aGUgYFdlYiBGZXRjaCBBUElgIChodHRwczovL2RldmVsb3Blci5tb3ppbGxhLm9yZy9lbi1VUy9kb2NzL1dlYi9BUEkvSGVhZGVycykgaW50byBhIHNpbXBsZSBrZXktdmFsdWUgZGljdC5cbiAqIFRoZSBoZWFkZXIga2V5cyB3aWxsIGJlIGxvd2VyIGNhc2U6IGUuZy4gQSBcIkNvbnRlbnQtVHlwZVwiIGhlYWRlciB3aWxsIGJlIHN0b3JlZCBhcyBcImNvbnRlbnQtdHlwZVwiLlxuICovXG5mdW5jdGlvbiB3aW50ZXJDR0hlYWRlcnNUb0RpY3Qod2ludGVyQ0dIZWFkZXJzKSB7XG4gIGNvbnN0IGhlYWRlcnMgPSB7fTtcbiAgdHJ5IHtcbiAgICB3aW50ZXJDR0hlYWRlcnMuZm9yRWFjaCgodmFsdWUsIGtleSkgPT4ge1xuICAgICAgaWYgKHR5cGVvZiB2YWx1ZSA9PT0gJ3N0cmluZycpIHtcbiAgICAgICAgLy8gV2UgY2hlY2sgdGhhdCB2YWx1ZSBpcyBhIHN0cmluZyBldmVuIHRob3VnaCBpdCBtaWdodCBiZSByZWR1bmRhbnQgdG8gbWFrZSBzdXJlIHByb3RvdHlwZSBwb2xsdXRpb24gaXMgbm90IHBvc3NpYmxlLlxuICAgICAgICBoZWFkZXJzW2tleV0gPSB2YWx1ZTtcbiAgICAgIH1cbiAgICB9KTtcbiAgfSBjYXRjaCB7XG4gICAgLy8ganVzdCByZXR1cm4gdGhlIGVtcHR5IGhlYWRlcnNcbiAgfVxuXG4gIHJldHVybiBoZWFkZXJzO1xufVxuXG4vKipcbiAqIENvbnZlcnQgY29tbW9uIHJlcXVlc3QgaGVhZGVycyB0byBhIHNpbXBsZSBkaWN0aW9uYXJ5LlxuICovXG5mdW5jdGlvbiBoZWFkZXJzVG9EaWN0KHJlcUhlYWRlcnMpIHtcbiAgY29uc3QgaGVhZGVycyA9IE9iamVjdC5jcmVhdGUobnVsbCk7XG5cbiAgdHJ5IHtcbiAgICBPYmplY3QuZW50cmllcyhyZXFIZWFkZXJzKS5mb3JFYWNoKChba2V5LCB2YWx1ZV0pID0+IHtcbiAgICAgIGlmICh0eXBlb2YgdmFsdWUgPT09ICdzdHJpbmcnKSB7XG4gICAgICAgIGhlYWRlcnNba2V5XSA9IHZhbHVlO1xuICAgICAgfVxuICAgIH0pO1xuICB9IGNhdGNoIHtcbiAgICAvLyBqdXN0IHJldHVybiB0aGUgZW1wdHkgaGVhZGVyc1xuICB9XG5cbiAgcmV0dXJuIGhlYWRlcnM7XG59XG5cbi8qKlxuICogQ29udmVydHMgYSBgUmVxdWVzdGAgb2JqZWN0IHRoYXQgaW1wbGVtZW50cyB0aGUgYFdlYiBGZXRjaCBBUElgIChodHRwczovL2RldmVsb3Blci5tb3ppbGxhLm9yZy9lbi1VUy9kb2NzL1dlYi9BUEkvSGVhZGVycykgaW50byB0aGUgZm9ybWF0IHRoYXQgdGhlIGBSZXF1ZXN0RGF0YWAgaW50ZWdyYXRpb24gdW5kZXJzdGFuZHMuXG4gKi9cbmZ1bmN0aW9uIHdpbnRlckNHUmVxdWVzdFRvUmVxdWVzdERhdGEocmVxKSB7XG4gIGNvbnN0IGhlYWRlcnMgPSB3aW50ZXJDR0hlYWRlcnNUb0RpY3QocmVxLmhlYWRlcnMpO1xuXG4gIHJldHVybiB7XG4gICAgbWV0aG9kOiByZXEubWV0aG9kLFxuICAgIHVybDogcmVxLnVybCxcbiAgICBxdWVyeV9zdHJpbmc6IGV4dHJhY3RRdWVyeVBhcmFtc0Zyb21VcmwocmVxLnVybCksXG4gICAgaGVhZGVycyxcbiAgICAvLyBUT0RPOiBDYW4gd2UgZXh0cmFjdCBib2R5IGRhdGEgZnJvbSB0aGUgcmVxdWVzdD9cbiAgfTtcbn1cblxuLyoqXG4gKiBDb252ZXJ0IGEgSFRUUCByZXF1ZXN0IG9iamVjdCB0byBSZXF1ZXN0RXZlbnREYXRhIHRvIGJlIHBhc3NlZCBhcyBub3JtYWxpemVkUmVxdWVzdC5cbiAqIEluc3RlYWQgb2YgYWxsb3dpbmcgYFBvbHltb3JwaGljUmVxdWVzdGAgdG8gYmUgcGFzc2VkLFxuICogd2Ugd2FudCB0byBiZSBtb3JlIHNwZWNpZmljIGFuZCBnZW5lcmFsbHkgcmVxdWlyZSBhIGh0dHAuSW5jb21pbmdNZXNzYWdlLWxpa2Ugb2JqZWN0LlxuICovXG5mdW5jdGlvbiBodHRwUmVxdWVzdFRvUmVxdWVzdERhdGEocmVxdWVzdFxuXG4pIHtcbiAgY29uc3QgaGVhZGVycyA9IHJlcXVlc3QuaGVhZGVycyB8fCB7fTtcblxuICAvLyBDaGVjayBmb3IgeC1mb3J3YXJkZWQtaG9zdCBmaXJzdCwgdGhlbiBmYWxsIGJhY2sgdG8gaG9zdCBoZWFkZXJcbiAgY29uc3QgZm9yd2FyZGVkSG9zdCA9IHR5cGVvZiBoZWFkZXJzWyd4LWZvcndhcmRlZC1ob3N0J10gPT09ICdzdHJpbmcnID8gaGVhZGVyc1sneC1mb3J3YXJkZWQtaG9zdCddIDogdW5kZWZpbmVkO1xuICBjb25zdCBob3N0ID0gZm9yd2FyZGVkSG9zdCB8fCAodHlwZW9mIGhlYWRlcnMuaG9zdCA9PT0gJ3N0cmluZycgPyBoZWFkZXJzLmhvc3QgOiB1bmRlZmluZWQpO1xuXG4gIC8vIENoZWNrIGZvciB4LWZvcndhcmRlZC1wcm90byBmaXJzdCwgdGhlbiBmYWxsIGJhY2sgdG8gZXhpc3RpbmcgcHJvdG9jb2wgZGV0ZWN0aW9uXG4gIGNvbnN0IGZvcndhcmRlZFByb3RvID0gdHlwZW9mIGhlYWRlcnNbJ3gtZm9yd2FyZGVkLXByb3RvJ10gPT09ICdzdHJpbmcnID8gaGVhZGVyc1sneC1mb3J3YXJkZWQtcHJvdG8nXSA6IHVuZGVmaW5lZDtcbiAgY29uc3QgcHJvdG9jb2wgPSBmb3J3YXJkZWRQcm90byB8fCByZXF1ZXN0LnByb3RvY29sIHx8IChyZXF1ZXN0LnNvY2tldD8uZW5jcnlwdGVkID8gJ2h0dHBzJyA6ICdodHRwJyk7XG5cbiAgY29uc3QgdXJsID0gcmVxdWVzdC51cmwgfHwgJyc7XG5cbiAgY29uc3QgYWJzb2x1dGVVcmwgPSBnZXRBYnNvbHV0ZVVybCh7XG4gICAgdXJsLFxuICAgIGhvc3QsXG4gICAgcHJvdG9jb2wsXG4gIH0pO1xuXG4gIC8vIFRoaXMgaXMgbm9uLXN0YW5kYXJkLCBidXQgbWF5IGJlIHNvbWV0aW1lcyBzZXRcbiAgLy8gSXQgbWF5IGJlIG92ZXJ3cml0dGVuIGxhdGVyIGJ5IG91ciBvd24gYm9keSBoYW5kbGluZ1xuICBjb25zdCBkYXRhID0gKHJlcXVlc3QgKS5ib2R5IHx8IHVuZGVmaW5lZDtcblxuICAvLyBUaGlzIGlzIG5vbi1zdGFuZGFyZCwgYnV0IG1heSBiZSBzZXQgb24gZS5nLiBOZXh0LmpzIG9yIEV4cHJlc3MgcmVxdWVzdHNcbiAgY29uc3QgY29va2llcyA9IChyZXF1ZXN0ICkuY29va2llcztcblxuICByZXR1cm4ge1xuICAgIHVybDogYWJzb2x1dGVVcmwsXG4gICAgbWV0aG9kOiByZXF1ZXN0Lm1ldGhvZCxcbiAgICBxdWVyeV9zdHJpbmc6IGV4dHJhY3RRdWVyeVBhcmFtc0Zyb21VcmwodXJsKSxcbiAgICBoZWFkZXJzOiBoZWFkZXJzVG9EaWN0KGhlYWRlcnMpLFxuICAgIGNvb2tpZXMsXG4gICAgZGF0YSxcbiAgfTtcbn1cblxuZnVuY3Rpb24gZ2V0QWJzb2x1dGVVcmwoe1xuICB1cmwsXG4gIHByb3RvY29sLFxuICBob3N0LFxufVxuXG4pIHtcbiAgaWYgKHVybD8uc3RhcnRzV2l0aCgnaHR0cCcpKSB7XG4gICAgcmV0dXJuIHVybDtcbiAgfVxuXG4gIGlmICh1cmwgJiYgaG9zdCkge1xuICAgIHJldHVybiBgJHtwcm90b2NvbH06Ly8ke2hvc3R9JHt1cmx9YDtcbiAgfVxuXG4gIHJldHVybiB1bmRlZmluZWQ7XG59XG5cbi8qKiBFeHRyYWN0IHRoZSBxdWVyeSBwYXJhbXMgZnJvbSBhbiBVUkwuICovXG5mdW5jdGlvbiBleHRyYWN0UXVlcnlQYXJhbXNGcm9tVXJsKHVybCkge1xuICAvLyB1cmwgaXMgcGF0aCBhbmQgcXVlcnkgc3RyaW5nXG4gIGlmICghdXJsKSB7XG4gICAgcmV0dXJuO1xuICB9XG5cbiAgdHJ5IHtcbiAgICAvLyBUaGUgYFVSTGAgY29uc3RydWN0b3IgY2FuJ3QgaGFuZGxlIGludGVybmFsIFVSTHMgb2YgdGhlIGZvcm0gYC9zb21lL3BhdGgvaGVyZWAsIHNvIHN0aWNrIGEgZHVtbXkgcHJvdG9jb2wgYW5kXG4gICAgLy8gaG9zdG5hbWUgYXMgdGhlIGJhc2UuIFNpbmNlIHRoZSBwb2ludCBoZXJlIGlzIGp1c3QgdG8gZ3JhYiB0aGUgcXVlcnkgc3RyaW5nLCBpdCBkb2Vzbid0IG1hdHRlciB3aGF0IHdlIHVzZS5cbiAgICBjb25zdCBxdWVyeVBhcmFtcyA9IG5ldyBVUkwodXJsLCAnaHR0cDovL3MuaW8nKS5zZWFyY2guc2xpY2UoMSk7XG4gICAgcmV0dXJuIHF1ZXJ5UGFyYW1zLmxlbmd0aCA/IHF1ZXJ5UGFyYW1zIDogdW5kZWZpbmVkO1xuICB9IGNhdGNoIHtcbiAgICByZXR1cm4gdW5kZWZpbmVkO1xuICB9XG59XG5cbmV4cG9ydHMuZXh0cmFjdFF1ZXJ5UGFyYW1zRnJvbVVybCA9IGV4dHJhY3RRdWVyeVBhcmFtc0Zyb21Vcmw7XG5leHBvcnRzLmhlYWRlcnNUb0RpY3QgPSBoZWFkZXJzVG9EaWN0O1xuZXhwb3J0cy5odHRwUmVxdWVzdFRvUmVxdWVzdERhdGEgPSBodHRwUmVxdWVzdFRvUmVxdWVzdERhdGE7XG5leHBvcnRzLndpbnRlckNHSGVhZGVyc1RvRGljdCA9IHdpbnRlckNHSGVhZGVyc1RvRGljdDtcbmV4cG9ydHMud2ludGVyQ0dSZXF1ZXN0VG9SZXF1ZXN0RGF0YSA9IHdpbnRlckNHUmVxdWVzdFRvUmVxdWVzdERhdGE7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1yZXF1ZXN0LmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/request.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/sdkMetadata.js":
/*!*********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/sdkMetadata.js ***!
  \*********************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst version = __webpack_require__(/*! ./version.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/version.js\");\n\n/**\n * A builder for the SDK metadata in the options for the SDK initialization.\n *\n * Note: This function is identical to `buildMetadata` in Remix and NextJS and SvelteKit.\n * We don't extract it for bundle size reasons.\n * @see https://github.com/getsentry/sentry-javascript/pull/7404\n * @see https://github.com/getsentry/sentry-javascript/pull/4196\n *\n * If you make changes to this function consider updating the others as well.\n *\n * @param options SDK options object that gets mutated\n * @param names list of package names\n */\nfunction applySdkMetadata(options, name, names = [name], source = 'npm') {\n  const metadata = options._metadata || {};\n\n  if (!metadata.sdk) {\n    metadata.sdk = {\n      name: `sentry.javascript.${name}`,\n      packages: names.map(name => ({\n        name: `${source}:@sentry/${name}`,\n        version: version.SDK_VERSION,\n      })),\n      version: version.SDK_VERSION,\n    };\n  }\n\n  options._metadata = metadata;\n}\n\nexports.applySdkMetadata = applySdkMetadata;\n//# sourceMappingURL=sdkMetadata.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9zZGtNZXRhZGF0YS5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxnQkFBZ0IsbUJBQU8sQ0FBQyx5SEFBYzs7QUFFdEM7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQSxpQ0FBaUMsS0FBSztBQUN0QztBQUNBLGlCQUFpQixPQUFPLFdBQVcsS0FBSztBQUN4QztBQUNBLE9BQU87QUFDUDtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQSx3QkFBd0I7QUFDeEIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9zZGtNZXRhZGF0YS5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgdmVyc2lvbiA9IHJlcXVpcmUoJy4vdmVyc2lvbi5qcycpO1xuXG4vKipcbiAqIEEgYnVpbGRlciBmb3IgdGhlIFNESyBtZXRhZGF0YSBpbiB0aGUgb3B0aW9ucyBmb3IgdGhlIFNESyBpbml0aWFsaXphdGlvbi5cbiAqXG4gKiBOb3RlOiBUaGlzIGZ1bmN0aW9uIGlzIGlkZW50aWNhbCB0byBgYnVpbGRNZXRhZGF0YWAgaW4gUmVtaXggYW5kIE5leHRKUyBhbmQgU3ZlbHRlS2l0LlxuICogV2UgZG9uJ3QgZXh0cmFjdCBpdCBmb3IgYnVuZGxlIHNpemUgcmVhc29ucy5cbiAqIEBzZWUgaHR0cHM6Ly9naXRodWIuY29tL2dldHNlbnRyeS9zZW50cnktamF2YXNjcmlwdC9wdWxsLzc0MDRcbiAqIEBzZWUgaHR0cHM6Ly9naXRodWIuY29tL2dldHNlbnRyeS9zZW50cnktamF2YXNjcmlwdC9wdWxsLzQxOTZcbiAqXG4gKiBJZiB5b3UgbWFrZSBjaGFuZ2VzIHRvIHRoaXMgZnVuY3Rpb24gY29uc2lkZXIgdXBkYXRpbmcgdGhlIG90aGVycyBhcyB3ZWxsLlxuICpcbiAqIEBwYXJhbSBvcHRpb25zIFNESyBvcHRpb25zIG9iamVjdCB0aGF0IGdldHMgbXV0YXRlZFxuICogQHBhcmFtIG5hbWVzIGxpc3Qgb2YgcGFja2FnZSBuYW1lc1xuICovXG5mdW5jdGlvbiBhcHBseVNka01ldGFkYXRhKG9wdGlvbnMsIG5hbWUsIG5hbWVzID0gW25hbWVdLCBzb3VyY2UgPSAnbnBtJykge1xuICBjb25zdCBtZXRhZGF0YSA9IG9wdGlvbnMuX21ldGFkYXRhIHx8IHt9O1xuXG4gIGlmICghbWV0YWRhdGEuc2RrKSB7XG4gICAgbWV0YWRhdGEuc2RrID0ge1xuICAgICAgbmFtZTogYHNlbnRyeS5qYXZhc2NyaXB0LiR7bmFtZX1gLFxuICAgICAgcGFja2FnZXM6IG5hbWVzLm1hcChuYW1lID0+ICh7XG4gICAgICAgIG5hbWU6IGAke3NvdXJjZX06QHNlbnRyeS8ke25hbWV9YCxcbiAgICAgICAgdmVyc2lvbjogdmVyc2lvbi5TREtfVkVSU0lPTixcbiAgICAgIH0pKSxcbiAgICAgIHZlcnNpb246IHZlcnNpb24uU0RLX1ZFUlNJT04sXG4gICAgfTtcbiAgfVxuXG4gIG9wdGlvbnMuX21ldGFkYXRhID0gbWV0YWRhdGE7XG59XG5cbmV4cG9ydHMuYXBwbHlTZGtNZXRhZGF0YSA9IGFwcGx5U2RrTWV0YWRhdGE7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1zZGtNZXRhZGF0YS5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/sdkMetadata.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/severity.js":
/*!******************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/severity.js ***!
  \******************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n/**\n * Converts a string-based level into a `SeverityLevel`, normalizing it along the way.\n *\n * @param level String representation of desired `SeverityLevel`.\n * @returns The `SeverityLevel` corresponding to the given string, or 'log' if the string isn't a valid level.\n */\nfunction severityLevelFromString(level) {\n  return (\n    level === 'warn' ? 'warning' : ['fatal', 'error', 'warning', 'log', 'info', 'debug'].includes(level) ? level : 'log'\n  ) ;\n}\n\nexports.severityLevelFromString = severityLevelFromString;\n//# sourceMappingURL=severity.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9zZXZlcml0eS5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLCtCQUErQjtBQUMvQiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3V0aWxzL3NldmVyaXR5LmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG4vKipcbiAqIENvbnZlcnRzIGEgc3RyaW5nLWJhc2VkIGxldmVsIGludG8gYSBgU2V2ZXJpdHlMZXZlbGAsIG5vcm1hbGl6aW5nIGl0IGFsb25nIHRoZSB3YXkuXG4gKlxuICogQHBhcmFtIGxldmVsIFN0cmluZyByZXByZXNlbnRhdGlvbiBvZiBkZXNpcmVkIGBTZXZlcml0eUxldmVsYC5cbiAqIEByZXR1cm5zIFRoZSBgU2V2ZXJpdHlMZXZlbGAgY29ycmVzcG9uZGluZyB0byB0aGUgZ2l2ZW4gc3RyaW5nLCBvciAnbG9nJyBpZiB0aGUgc3RyaW5nIGlzbid0IGEgdmFsaWQgbGV2ZWwuXG4gKi9cbmZ1bmN0aW9uIHNldmVyaXR5TGV2ZWxGcm9tU3RyaW5nKGxldmVsKSB7XG4gIHJldHVybiAoXG4gICAgbGV2ZWwgPT09ICd3YXJuJyA/ICd3YXJuaW5nJyA6IFsnZmF0YWwnLCAnZXJyb3InLCAnd2FybmluZycsICdsb2cnLCAnaW5mbycsICdkZWJ1ZyddLmluY2x1ZGVzKGxldmVsKSA/IGxldmVsIDogJ2xvZydcbiAgKSA7XG59XG5cbmV4cG9ydHMuc2V2ZXJpdHlMZXZlbEZyb21TdHJpbmcgPSBzZXZlcml0eUxldmVsRnJvbVN0cmluZztcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPXNldmVyaXR5LmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/severity.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanOnScope.js":
/*!*********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanOnScope.js ***!
  \*********************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst object = __webpack_require__(/*! ./object.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/object.js\");\n\nconst SCOPE_SPAN_FIELD = '_sentrySpan';\n\n/**\n * Set the active span for a given scope.\n * NOTE: This should NOT be used directly, but is only used internally by the trace methods.\n */\nfunction _setSpanForScope(scope, span) {\n  if (span) {\n    object.addNonEnumerableProperty(scope , SCOPE_SPAN_FIELD, span);\n  } else {\n    // eslint-disable-next-line @typescript-eslint/no-dynamic-delete\n    delete (scope )[SCOPE_SPAN_FIELD];\n  }\n}\n\n/**\n * Get the active span for a given scope.\n * NOTE: This should NOT be used directly, but is only used internally by the trace methods.\n */\nfunction _getSpanForScope(scope) {\n  return scope[SCOPE_SPAN_FIELD];\n}\n\nexports._getSpanForScope = _getSpanForScope;\nexports._setSpanForScope = _setSpanForScope;\n//# sourceMappingURL=spanOnScope.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9zcGFuT25TY29wZS5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxlQUFlLG1CQUFPLENBQUMsdUhBQWE7O0FBRXBDOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsSUFBSTtBQUNKO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLHdCQUF3QjtBQUN4Qix3QkFBd0I7QUFDeEIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9zcGFuT25TY29wZS5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3Qgb2JqZWN0ID0gcmVxdWlyZSgnLi9vYmplY3QuanMnKTtcblxuY29uc3QgU0NPUEVfU1BBTl9GSUVMRCA9ICdfc2VudHJ5U3Bhbic7XG5cbi8qKlxuICogU2V0IHRoZSBhY3RpdmUgc3BhbiBmb3IgYSBnaXZlbiBzY29wZS5cbiAqIE5PVEU6IFRoaXMgc2hvdWxkIE5PVCBiZSB1c2VkIGRpcmVjdGx5LCBidXQgaXMgb25seSB1c2VkIGludGVybmFsbHkgYnkgdGhlIHRyYWNlIG1ldGhvZHMuXG4gKi9cbmZ1bmN0aW9uIF9zZXRTcGFuRm9yU2NvcGUoc2NvcGUsIHNwYW4pIHtcbiAgaWYgKHNwYW4pIHtcbiAgICBvYmplY3QuYWRkTm9uRW51bWVyYWJsZVByb3BlcnR5KHNjb3BlICwgU0NPUEVfU1BBTl9GSUVMRCwgc3Bhbik7XG4gIH0gZWxzZSB7XG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uby1keW5hbWljLWRlbGV0ZVxuICAgIGRlbGV0ZSAoc2NvcGUgKVtTQ09QRV9TUEFOX0ZJRUxEXTtcbiAgfVxufVxuXG4vKipcbiAqIEdldCB0aGUgYWN0aXZlIHNwYW4gZm9yIGEgZ2l2ZW4gc2NvcGUuXG4gKiBOT1RFOiBUaGlzIHNob3VsZCBOT1QgYmUgdXNlZCBkaXJlY3RseSwgYnV0IGlzIG9ubHkgdXNlZCBpbnRlcm5hbGx5IGJ5IHRoZSB0cmFjZSBtZXRob2RzLlxuICovXG5mdW5jdGlvbiBfZ2V0U3BhbkZvclNjb3BlKHNjb3BlKSB7XG4gIHJldHVybiBzY29wZVtTQ09QRV9TUEFOX0ZJRUxEXTtcbn1cblxuZXhwb3J0cy5fZ2V0U3BhbkZvclNjb3BlID0gX2dldFNwYW5Gb3JTY29wZTtcbmV4cG9ydHMuX3NldFNwYW5Gb3JTY29wZSA9IF9zZXRTcGFuRm9yU2NvcGU7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1zcGFuT25TY29wZS5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanOnScope.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanUtils.js":
/*!*******************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanUtils.js ***!
  \*******************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst index = __webpack_require__(/*! ../asyncContext/index.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/asyncContext/index.js\");\nconst carrier = __webpack_require__(/*! ../carrier.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/carrier.js\");\nconst currentScopes = __webpack_require__(/*! ../currentScopes.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst semanticAttributes = __webpack_require__(/*! ../semanticAttributes.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/semanticAttributes.js\");\nconst spanstatus = __webpack_require__(/*! ../tracing/spanstatus.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/spanstatus.js\");\nconst utils = __webpack_require__(/*! ../tracing/utils.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/utils.js\");\nconst object = __webpack_require__(/*! ./object.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/object.js\");\nconst propagationContext = __webpack_require__(/*! ./propagationContext.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/propagationContext.js\");\nconst time = __webpack_require__(/*! ./time.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/time.js\");\nconst tracing = __webpack_require__(/*! ./tracing.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/tracing.js\");\nconst debugLogger = __webpack_require__(/*! ./debug-logger.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst spanOnScope = __webpack_require__(/*! ./spanOnScope.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanOnScope.js\");\n\n// These are aligned with OpenTelemetry trace flags\nconst TRACE_FLAG_NONE = 0x0;\nconst TRACE_FLAG_SAMPLED = 0x1;\n\nlet hasShownSpanDropWarning = false;\n\n/**\n * Convert a span to a trace context, which can be sent as the `trace` context in an event.\n * By default, this will only include trace_id, span_id & parent_span_id.\n * If `includeAllData` is true, it will also include data, op, status & origin.\n */\nfunction spanToTransactionTraceContext(span) {\n  const { spanId: span_id, traceId: trace_id } = span.spanContext();\n  const { data, op, parent_span_id, status, origin, links } = spanToJSON(span);\n\n  return {\n    parent_span_id,\n    span_id,\n    trace_id,\n    data,\n    op,\n    status,\n    origin,\n    links,\n  };\n}\n\n/**\n * Convert a span to a trace context, which can be sent as the `trace` context in a non-transaction event.\n */\nfunction spanToTraceContext(span) {\n  const { spanId, traceId: trace_id, isRemote } = span.spanContext();\n\n  // If the span is remote, we use a random/virtual span as span_id to the trace context,\n  // and the remote span as parent_span_id\n  const parent_span_id = isRemote ? spanId : spanToJSON(span).parent_span_id;\n  const scope = utils.getCapturedScopesOnSpan(span).scope;\n\n  const span_id = isRemote ? scope?.getPropagationContext().propagationSpanId || propagationContext.generateSpanId() : spanId;\n\n  return {\n    parent_span_id,\n    span_id,\n    trace_id,\n  };\n}\n\n/**\n * Convert a Span to a Sentry trace header.\n */\nfunction spanToTraceHeader(span) {\n  const { traceId, spanId } = span.spanContext();\n  const sampled = spanIsSampled(span);\n  return tracing.generateSentryTraceHeader(traceId, spanId, sampled);\n}\n\n/**\n *  Converts the span links array to a flattened version to be sent within an envelope.\n *\n *  If the links array is empty, it returns `undefined` so the empty value can be dropped before it's sent.\n */\nfunction convertSpanLinksForEnvelope(links) {\n  if (links && links.length > 0) {\n    return links.map(({ context: { spanId, traceId, traceFlags, ...restContext }, attributes }) => ({\n      span_id: spanId,\n      trace_id: traceId,\n      sampled: traceFlags === TRACE_FLAG_SAMPLED,\n      attributes,\n      ...restContext,\n    }));\n  } else {\n    return undefined;\n  }\n}\n\n/**\n * Convert a span time input into a timestamp in seconds.\n */\nfunction spanTimeInputToSeconds(input) {\n  if (typeof input === 'number') {\n    return ensureTimestampInSeconds(input);\n  }\n\n  if (Array.isArray(input)) {\n    // See {@link HrTime} for the array-based time format\n    return input[0] + input[1] / 1e9;\n  }\n\n  if (input instanceof Date) {\n    return ensureTimestampInSeconds(input.getTime());\n  }\n\n  return time.timestampInSeconds();\n}\n\n/**\n * Converts a timestamp to second, if it was in milliseconds, or keeps it as second.\n */\nfunction ensureTimestampInSeconds(timestamp) {\n  const isMs = timestamp > 9999999999;\n  return isMs ? timestamp / 1000 : timestamp;\n}\n\n/**\n * Convert a span to a JSON representation.\n */\n// Note: Because of this, we currently have a circular type dependency (which we opted out of in package.json).\n// This is not avoidable as we need `spanToJSON` in `spanUtils.ts`, which in turn is needed by `span.ts` for backwards compatibility.\n// And `spanToJSON` needs the Span class from `span.ts` to check here.\nfunction spanToJSON(span) {\n  if (spanIsSentrySpan(span)) {\n    return span.getSpanJSON();\n  }\n\n  const { spanId: span_id, traceId: trace_id } = span.spanContext();\n\n  // Handle a span from @opentelemetry/sdk-base-trace's `Span` class\n  if (spanIsOpenTelemetrySdkTraceBaseSpan(span)) {\n    const { attributes, startTime, name, endTime, status, links } = span;\n\n    // In preparation for the next major of OpenTelemetry, we want to support\n    // looking up the parent span id according to the new API\n    // In OTel v1, the parent span id is accessed as `parentSpanId`\n    // In OTel v2, the parent span id is accessed as `spanId` on the `parentSpanContext`\n    const parentSpanId =\n      'parentSpanId' in span\n        ? span.parentSpanId\n        : 'parentSpanContext' in span\n          ? (span.parentSpanContext )?.spanId\n          : undefined;\n\n    return {\n      span_id,\n      trace_id,\n      data: attributes,\n      description: name,\n      parent_span_id: parentSpanId,\n      start_timestamp: spanTimeInputToSeconds(startTime),\n      // This is [0,0] by default in OTEL, in which case we want to interpret this as no end time\n      timestamp: spanTimeInputToSeconds(endTime) || undefined,\n      status: getStatusMessage(status),\n      op: attributes[semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_OP],\n      origin: attributes[semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_ORIGIN] ,\n      links: convertSpanLinksForEnvelope(links),\n    };\n  }\n\n  // Finally, at least we have `spanContext()`....\n  // This should not actually happen in reality, but we need to handle it for type safety.\n  return {\n    span_id,\n    trace_id,\n    start_timestamp: 0,\n    data: {},\n  };\n}\n\nfunction spanIsOpenTelemetrySdkTraceBaseSpan(span) {\n  const castSpan = span ;\n  return !!castSpan.attributes && !!castSpan.startTime && !!castSpan.name && !!castSpan.endTime && !!castSpan.status;\n}\n\n/** Exported only for tests. */\n\n/**\n * Sadly, due to circular dependency checks we cannot actually import the Span class here and check for instanceof.\n * :( So instead we approximate this by checking if it has the `getSpanJSON` method.\n */\nfunction spanIsSentrySpan(span) {\n  return typeof (span ).getSpanJSON === 'function';\n}\n\n/**\n * Returns true if a span is sampled.\n * In most cases, you should just use `span.isRecording()` instead.\n * However, this has a slightly different semantic, as it also returns false if the span is finished.\n * So in the case where this distinction is important, use this method.\n */\nfunction spanIsSampled(span) {\n  // We align our trace flags with the ones OpenTelemetry use\n  // So we also check for sampled the same way they do.\n  const { traceFlags } = span.spanContext();\n  return traceFlags === TRACE_FLAG_SAMPLED;\n}\n\n/** Get the status message to use for a JSON representation of a span. */\nfunction getStatusMessage(status) {\n  if (!status || status.code === spanstatus.SPAN_STATUS_UNSET) {\n    return undefined;\n  }\n\n  if (status.code === spanstatus.SPAN_STATUS_OK) {\n    return 'ok';\n  }\n\n  return status.message || 'unknown_error';\n}\n\nconst CHILD_SPANS_FIELD = '_sentryChildSpans';\nconst ROOT_SPAN_FIELD = '_sentryRootSpan';\n\n/**\n * Adds an opaque child span reference to a span.\n */\nfunction addChildSpanToSpan(span, childSpan) {\n  // We store the root span reference on the child span\n  // We need this for `getRootSpan()` to work\n  const rootSpan = span[ROOT_SPAN_FIELD] || span;\n  object.addNonEnumerableProperty(childSpan , ROOT_SPAN_FIELD, rootSpan);\n\n  // We store a list of child spans on the parent span\n  // We need this for `getSpanDescendants()` to work\n  if (span[CHILD_SPANS_FIELD]) {\n    span[CHILD_SPANS_FIELD].add(childSpan);\n  } else {\n    object.addNonEnumerableProperty(span, CHILD_SPANS_FIELD, new Set([childSpan]));\n  }\n}\n\n/** This is only used internally by Idle Spans. */\nfunction removeChildSpanFromSpan(span, childSpan) {\n  if (span[CHILD_SPANS_FIELD]) {\n    span[CHILD_SPANS_FIELD].delete(childSpan);\n  }\n}\n\n/**\n * Returns an array of the given span and all of its descendants.\n */\nfunction getSpanDescendants(span) {\n  const resultSet = new Set();\n\n  function addSpanChildren(span) {\n    // This exit condition is required to not infinitely loop in case of a circular dependency.\n    if (resultSet.has(span)) {\n      return;\n      // We want to ignore unsampled spans (e.g. non recording spans)\n    } else if (spanIsSampled(span)) {\n      resultSet.add(span);\n      const childSpans = span[CHILD_SPANS_FIELD] ? Array.from(span[CHILD_SPANS_FIELD]) : [];\n      for (const childSpan of childSpans) {\n        addSpanChildren(childSpan);\n      }\n    }\n  }\n\n  addSpanChildren(span);\n\n  return Array.from(resultSet);\n}\n\n/**\n * Returns the root span of a given span.\n */\nfunction getRootSpan(span) {\n  return span[ROOT_SPAN_FIELD] || span;\n}\n\n/**\n * Returns the currently active span.\n */\nfunction getActiveSpan() {\n  const carrier$1 = carrier.getMainCarrier();\n  const acs = index.getAsyncContextStrategy(carrier$1);\n  if (acs.getActiveSpan) {\n    return acs.getActiveSpan();\n  }\n\n  return spanOnScope._getSpanForScope(currentScopes.getCurrentScope());\n}\n\n/**\n * Logs a warning once if `beforeSendSpan` is used to drop spans.\n */\nfunction showSpanDropWarning() {\n  if (!hasShownSpanDropWarning) {\n    debugLogger.consoleSandbox(() => {\n      // eslint-disable-next-line no-console\n      console.warn(\n        '[Sentry] Returning null from `beforeSendSpan` is disallowed. To drop certain spans, configure the respective integrations directly.',\n      );\n    });\n    hasShownSpanDropWarning = true;\n  }\n}\n\n/**\n * Updates the name of the given span and ensures that the span name is not\n * overwritten by the Sentry SDK.\n *\n * Use this function instead of `span.updateName()` if you want to make sure that\n * your name is kept. For some spans, for example root `http.server` spans the\n * Sentry SDK would otherwise overwrite the span name with a high-quality name\n * it infers when the span ends.\n *\n * Use this function in server code or when your span is started on the server\n * and on the client (browser). If you only update a span name on the client,\n * you can also use `span.updateName()` the SDK does not overwrite the name.\n *\n * @param span - The span to update the name of.\n * @param name - The name to set on the span.\n */\nfunction updateSpanName(span, name) {\n  span.updateName(name);\n  span.setAttributes({\n    [semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_SOURCE]: 'custom',\n    [semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_CUSTOM_SPAN_NAME]: name,\n  });\n}\n\nexports.TRACE_FLAG_NONE = TRACE_FLAG_NONE;\nexports.TRACE_FLAG_SAMPLED = TRACE_FLAG_SAMPLED;\nexports.addChildSpanToSpan = addChildSpanToSpan;\nexports.convertSpanLinksForEnvelope = convertSpanLinksForEnvelope;\nexports.getActiveSpan = getActiveSpan;\nexports.getRootSpan = getRootSpan;\nexports.getSpanDescendants = getSpanDescendants;\nexports.getStatusMessage = getStatusMessage;\nexports.removeChildSpanFromSpan = removeChildSpanFromSpan;\nexports.showSpanDropWarning = showSpanDropWarning;\nexports.spanIsSampled = spanIsSampled;\nexports.spanTimeInputToSeconds = spanTimeInputToSeconds;\nexports.spanToJSON = spanToJSON;\nexports.spanToTraceContext = spanToTraceContext;\nexports.spanToTraceHeader = spanToTraceHeader;\nexports.spanToTransactionTraceContext = spanToTransactionTraceContext;\nexports.updateSpanName = updateSpanName;\n//# sourceMappingURL=spanUtils.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9zcGFuVXRpbHMuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsY0FBYyxtQkFBTyxDQUFDLDBJQUEwQjtBQUNoRCxnQkFBZ0IsbUJBQU8sQ0FBQyxvSEFBZTtBQUN2QyxzQkFBc0IsbUJBQU8sQ0FBQyxnSUFBcUI7QUFDbkQsMkJBQTJCLG1CQUFPLENBQUMsMElBQTBCO0FBQzdELG1CQUFtQixtQkFBTyxDQUFDLDBJQUEwQjtBQUNyRCxjQUFjLG1CQUFPLENBQUMsZ0lBQXFCO0FBQzNDLGVBQWUsbUJBQU8sQ0FBQyx1SEFBYTtBQUNwQywyQkFBMkIsbUJBQU8sQ0FBQywrSUFBeUI7QUFDNUQsYUFBYSxtQkFBTyxDQUFDLG1IQUFXO0FBQ2hDLGdCQUFnQixtQkFBTyxDQUFDLHlIQUFjO0FBQ3RDLG9CQUFvQixtQkFBTyxDQUFDLG1JQUFtQjtBQUMvQyxvQkFBb0IsbUJBQU8sQ0FBQyxpSUFBa0I7O0FBRTlDO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxVQUFVLHFDQUFxQztBQUMvQyxVQUFVLGtEQUFrRDs7QUFFNUQ7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFVBQVUsc0NBQXNDOztBQUVoRDtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQSxVQUFVLGtCQUFrQjtBQUM1QjtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSx3QkFBd0IsV0FBVyw2Q0FBNkMsY0FBYztBQUM5RjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsS0FBSztBQUNMLElBQUk7QUFDSjtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQSxZQUFZLGNBQWM7QUFDMUI7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSxVQUFVLHFDQUFxQzs7QUFFL0M7QUFDQTtBQUNBLFlBQVksc0RBQXNEOztBQUVsRTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsWUFBWTtBQUNaO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsVUFBVSxhQUFhO0FBQ3ZCO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQSxJQUFJO0FBQ0o7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxNQUFNO0FBQ047QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxLQUFLO0FBQ0w7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEdBQUc7QUFDSDs7QUFFQSx1QkFBdUI7QUFDdkIsMEJBQTBCO0FBQzFCLDBCQUEwQjtBQUMxQixtQ0FBbUM7QUFDbkMscUJBQXFCO0FBQ3JCLG1CQUFtQjtBQUNuQiwwQkFBMEI7QUFDMUIsd0JBQXdCO0FBQ3hCLCtCQUErQjtBQUMvQiwyQkFBMkI7QUFDM0IscUJBQXFCO0FBQ3JCLDhCQUE4QjtBQUM5QixrQkFBa0I7QUFDbEIsMEJBQTBCO0FBQzFCLHlCQUF5QjtBQUN6QixxQ0FBcUM7QUFDckMsc0JBQXNCO0FBQ3RCIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvc3BhblV0aWxzLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBpbmRleCA9IHJlcXVpcmUoJy4uL2FzeW5jQ29udGV4dC9pbmRleC5qcycpO1xuY29uc3QgY2FycmllciA9IHJlcXVpcmUoJy4uL2NhcnJpZXIuanMnKTtcbmNvbnN0IGN1cnJlbnRTY29wZXMgPSByZXF1aXJlKCcuLi9jdXJyZW50U2NvcGVzLmpzJyk7XG5jb25zdCBzZW1hbnRpY0F0dHJpYnV0ZXMgPSByZXF1aXJlKCcuLi9zZW1hbnRpY0F0dHJpYnV0ZXMuanMnKTtcbmNvbnN0IHNwYW5zdGF0dXMgPSByZXF1aXJlKCcuLi90cmFjaW5nL3NwYW5zdGF0dXMuanMnKTtcbmNvbnN0IHV0aWxzID0gcmVxdWlyZSgnLi4vdHJhY2luZy91dGlscy5qcycpO1xuY29uc3Qgb2JqZWN0ID0gcmVxdWlyZSgnLi9vYmplY3QuanMnKTtcbmNvbnN0IHByb3BhZ2F0aW9uQ29udGV4dCA9IHJlcXVpcmUoJy4vcHJvcGFnYXRpb25Db250ZXh0LmpzJyk7XG5jb25zdCB0aW1lID0gcmVxdWlyZSgnLi90aW1lLmpzJyk7XG5jb25zdCB0cmFjaW5nID0gcmVxdWlyZSgnLi90cmFjaW5nLmpzJyk7XG5jb25zdCBkZWJ1Z0xvZ2dlciA9IHJlcXVpcmUoJy4vZGVidWctbG9nZ2VyLmpzJyk7XG5jb25zdCBzcGFuT25TY29wZSA9IHJlcXVpcmUoJy4vc3Bhbk9uU2NvcGUuanMnKTtcblxuLy8gVGhlc2UgYXJlIGFsaWduZWQgd2l0aCBPcGVuVGVsZW1ldHJ5IHRyYWNlIGZsYWdzXG5jb25zdCBUUkFDRV9GTEFHX05PTkUgPSAweDA7XG5jb25zdCBUUkFDRV9GTEFHX1NBTVBMRUQgPSAweDE7XG5cbmxldCBoYXNTaG93blNwYW5Ecm9wV2FybmluZyA9IGZhbHNlO1xuXG4vKipcbiAqIENvbnZlcnQgYSBzcGFuIHRvIGEgdHJhY2UgY29udGV4dCwgd2hpY2ggY2FuIGJlIHNlbnQgYXMgdGhlIGB0cmFjZWAgY29udGV4dCBpbiBhbiBldmVudC5cbiAqIEJ5IGRlZmF1bHQsIHRoaXMgd2lsbCBvbmx5IGluY2x1ZGUgdHJhY2VfaWQsIHNwYW5faWQgJiBwYXJlbnRfc3Bhbl9pZC5cbiAqIElmIGBpbmNsdWRlQWxsRGF0YWAgaXMgdHJ1ZSwgaXQgd2lsbCBhbHNvIGluY2x1ZGUgZGF0YSwgb3AsIHN0YXR1cyAmIG9yaWdpbi5cbiAqL1xuZnVuY3Rpb24gc3BhblRvVHJhbnNhY3Rpb25UcmFjZUNvbnRleHQoc3Bhbikge1xuICBjb25zdCB7IHNwYW5JZDogc3Bhbl9pZCwgdHJhY2VJZDogdHJhY2VfaWQgfSA9IHNwYW4uc3BhbkNvbnRleHQoKTtcbiAgY29uc3QgeyBkYXRhLCBvcCwgcGFyZW50X3NwYW5faWQsIHN0YXR1cywgb3JpZ2luLCBsaW5rcyB9ID0gc3BhblRvSlNPTihzcGFuKTtcblxuICByZXR1cm4ge1xuICAgIHBhcmVudF9zcGFuX2lkLFxuICAgIHNwYW5faWQsXG4gICAgdHJhY2VfaWQsXG4gICAgZGF0YSxcbiAgICBvcCxcbiAgICBzdGF0dXMsXG4gICAgb3JpZ2luLFxuICAgIGxpbmtzLFxuICB9O1xufVxuXG4vKipcbiAqIENvbnZlcnQgYSBzcGFuIHRvIGEgdHJhY2UgY29udGV4dCwgd2hpY2ggY2FuIGJlIHNlbnQgYXMgdGhlIGB0cmFjZWAgY29udGV4dCBpbiBhIG5vbi10cmFuc2FjdGlvbiBldmVudC5cbiAqL1xuZnVuY3Rpb24gc3BhblRvVHJhY2VDb250ZXh0KHNwYW4pIHtcbiAgY29uc3QgeyBzcGFuSWQsIHRyYWNlSWQ6IHRyYWNlX2lkLCBpc1JlbW90ZSB9ID0gc3Bhbi5zcGFuQ29udGV4dCgpO1xuXG4gIC8vIElmIHRoZSBzcGFuIGlzIHJlbW90ZSwgd2UgdXNlIGEgcmFuZG9tL3ZpcnR1YWwgc3BhbiBhcyBzcGFuX2lkIHRvIHRoZSB0cmFjZSBjb250ZXh0LFxuICAvLyBhbmQgdGhlIHJlbW90ZSBzcGFuIGFzIHBhcmVudF9zcGFuX2lkXG4gIGNvbnN0IHBhcmVudF9zcGFuX2lkID0gaXNSZW1vdGUgPyBzcGFuSWQgOiBzcGFuVG9KU09OKHNwYW4pLnBhcmVudF9zcGFuX2lkO1xuICBjb25zdCBzY29wZSA9IHV0aWxzLmdldENhcHR1cmVkU2NvcGVzT25TcGFuKHNwYW4pLnNjb3BlO1xuXG4gIGNvbnN0IHNwYW5faWQgPSBpc1JlbW90ZSA/IHNjb3BlPy5nZXRQcm9wYWdhdGlvbkNvbnRleHQoKS5wcm9wYWdhdGlvblNwYW5JZCB8fCBwcm9wYWdhdGlvbkNvbnRleHQuZ2VuZXJhdGVTcGFuSWQoKSA6IHNwYW5JZDtcblxuICByZXR1cm4ge1xuICAgIHBhcmVudF9zcGFuX2lkLFxuICAgIHNwYW5faWQsXG4gICAgdHJhY2VfaWQsXG4gIH07XG59XG5cbi8qKlxuICogQ29udmVydCBhIFNwYW4gdG8gYSBTZW50cnkgdHJhY2UgaGVhZGVyLlxuICovXG5mdW5jdGlvbiBzcGFuVG9UcmFjZUhlYWRlcihzcGFuKSB7XG4gIGNvbnN0IHsgdHJhY2VJZCwgc3BhbklkIH0gPSBzcGFuLnNwYW5Db250ZXh0KCk7XG4gIGNvbnN0IHNhbXBsZWQgPSBzcGFuSXNTYW1wbGVkKHNwYW4pO1xuICByZXR1cm4gdHJhY2luZy5nZW5lcmF0ZVNlbnRyeVRyYWNlSGVhZGVyKHRyYWNlSWQsIHNwYW5JZCwgc2FtcGxlZCk7XG59XG5cbi8qKlxuICogIENvbnZlcnRzIHRoZSBzcGFuIGxpbmtzIGFycmF5IHRvIGEgZmxhdHRlbmVkIHZlcnNpb24gdG8gYmUgc2VudCB3aXRoaW4gYW4gZW52ZWxvcGUuXG4gKlxuICogIElmIHRoZSBsaW5rcyBhcnJheSBpcyBlbXB0eSwgaXQgcmV0dXJucyBgdW5kZWZpbmVkYCBzbyB0aGUgZW1wdHkgdmFsdWUgY2FuIGJlIGRyb3BwZWQgYmVmb3JlIGl0J3Mgc2VudC5cbiAqL1xuZnVuY3Rpb24gY29udmVydFNwYW5MaW5rc0ZvckVudmVsb3BlKGxpbmtzKSB7XG4gIGlmIChsaW5rcyAmJiBsaW5rcy5sZW5ndGggPiAwKSB7XG4gICAgcmV0dXJuIGxpbmtzLm1hcCgoeyBjb250ZXh0OiB7IHNwYW5JZCwgdHJhY2VJZCwgdHJhY2VGbGFncywgLi4ucmVzdENvbnRleHQgfSwgYXR0cmlidXRlcyB9KSA9PiAoe1xuICAgICAgc3Bhbl9pZDogc3BhbklkLFxuICAgICAgdHJhY2VfaWQ6IHRyYWNlSWQsXG4gICAgICBzYW1wbGVkOiB0cmFjZUZsYWdzID09PSBUUkFDRV9GTEFHX1NBTVBMRUQsXG4gICAgICBhdHRyaWJ1dGVzLFxuICAgICAgLi4ucmVzdENvbnRleHQsXG4gICAgfSkpO1xuICB9IGVsc2Uge1xuICAgIHJldHVybiB1bmRlZmluZWQ7XG4gIH1cbn1cblxuLyoqXG4gKiBDb252ZXJ0IGEgc3BhbiB0aW1lIGlucHV0IGludG8gYSB0aW1lc3RhbXAgaW4gc2Vjb25kcy5cbiAqL1xuZnVuY3Rpb24gc3BhblRpbWVJbnB1dFRvU2Vjb25kcyhpbnB1dCkge1xuICBpZiAodHlwZW9mIGlucHV0ID09PSAnbnVtYmVyJykge1xuICAgIHJldHVybiBlbnN1cmVUaW1lc3RhbXBJblNlY29uZHMoaW5wdXQpO1xuICB9XG5cbiAgaWYgKEFycmF5LmlzQXJyYXkoaW5wdXQpKSB7XG4gICAgLy8gU2VlIHtAbGluayBIclRpbWV9IGZvciB0aGUgYXJyYXktYmFzZWQgdGltZSBmb3JtYXRcbiAgICByZXR1cm4gaW5wdXRbMF0gKyBpbnB1dFsxXSAvIDFlOTtcbiAgfVxuXG4gIGlmIChpbnB1dCBpbnN0YW5jZW9mIERhdGUpIHtcbiAgICByZXR1cm4gZW5zdXJlVGltZXN0YW1wSW5TZWNvbmRzKGlucHV0LmdldFRpbWUoKSk7XG4gIH1cblxuICByZXR1cm4gdGltZS50aW1lc3RhbXBJblNlY29uZHMoKTtcbn1cblxuLyoqXG4gKiBDb252ZXJ0cyBhIHRpbWVzdGFtcCB0byBzZWNvbmQsIGlmIGl0IHdhcyBpbiBtaWxsaXNlY29uZHMsIG9yIGtlZXBzIGl0IGFzIHNlY29uZC5cbiAqL1xuZnVuY3Rpb24gZW5zdXJlVGltZXN0YW1wSW5TZWNvbmRzKHRpbWVzdGFtcCkge1xuICBjb25zdCBpc01zID0gdGltZXN0YW1wID4gOTk5OTk5OTk5OTtcbiAgcmV0dXJuIGlzTXMgPyB0aW1lc3RhbXAgLyAxMDAwIDogdGltZXN0YW1wO1xufVxuXG4vKipcbiAqIENvbnZlcnQgYSBzcGFuIHRvIGEgSlNPTiByZXByZXNlbnRhdGlvbi5cbiAqL1xuLy8gTm90ZTogQmVjYXVzZSBvZiB0aGlzLCB3ZSBjdXJyZW50bHkgaGF2ZSBhIGNpcmN1bGFyIHR5cGUgZGVwZW5kZW5jeSAod2hpY2ggd2Ugb3B0ZWQgb3V0IG9mIGluIHBhY2thZ2UuanNvbikuXG4vLyBUaGlzIGlzIG5vdCBhdm9pZGFibGUgYXMgd2UgbmVlZCBgc3BhblRvSlNPTmAgaW4gYHNwYW5VdGlscy50c2AsIHdoaWNoIGluIHR1cm4gaXMgbmVlZGVkIGJ5IGBzcGFuLnRzYCBmb3IgYmFja3dhcmRzIGNvbXBhdGliaWxpdHkuXG4vLyBBbmQgYHNwYW5Ub0pTT05gIG5lZWRzIHRoZSBTcGFuIGNsYXNzIGZyb20gYHNwYW4udHNgIHRvIGNoZWNrIGhlcmUuXG5mdW5jdGlvbiBzcGFuVG9KU09OKHNwYW4pIHtcbiAgaWYgKHNwYW5Jc1NlbnRyeVNwYW4oc3BhbikpIHtcbiAgICByZXR1cm4gc3Bhbi5nZXRTcGFuSlNPTigpO1xuICB9XG5cbiAgY29uc3QgeyBzcGFuSWQ6IHNwYW5faWQsIHRyYWNlSWQ6IHRyYWNlX2lkIH0gPSBzcGFuLnNwYW5Db250ZXh0KCk7XG5cbiAgLy8gSGFuZGxlIGEgc3BhbiBmcm9tIEBvcGVudGVsZW1ldHJ5L3Nkay1iYXNlLXRyYWNlJ3MgYFNwYW5gIGNsYXNzXG4gIGlmIChzcGFuSXNPcGVuVGVsZW1ldHJ5U2RrVHJhY2VCYXNlU3BhbihzcGFuKSkge1xuICAgIGNvbnN0IHsgYXR0cmlidXRlcywgc3RhcnRUaW1lLCBuYW1lLCBlbmRUaW1lLCBzdGF0dXMsIGxpbmtzIH0gPSBzcGFuO1xuXG4gICAgLy8gSW4gcHJlcGFyYXRpb24gZm9yIHRoZSBuZXh0IG1ham9yIG9mIE9wZW5UZWxlbWV0cnksIHdlIHdhbnQgdG8gc3VwcG9ydFxuICAgIC8vIGxvb2tpbmcgdXAgdGhlIHBhcmVudCBzcGFuIGlkIGFjY29yZGluZyB0byB0aGUgbmV3IEFQSVxuICAgIC8vIEluIE9UZWwgdjEsIHRoZSBwYXJlbnQgc3BhbiBpZCBpcyBhY2Nlc3NlZCBhcyBgcGFyZW50U3BhbklkYFxuICAgIC8vIEluIE9UZWwgdjIsIHRoZSBwYXJlbnQgc3BhbiBpZCBpcyBhY2Nlc3NlZCBhcyBgc3BhbklkYCBvbiB0aGUgYHBhcmVudFNwYW5Db250ZXh0YFxuICAgIGNvbnN0IHBhcmVudFNwYW5JZCA9XG4gICAgICAncGFyZW50U3BhbklkJyBpbiBzcGFuXG4gICAgICAgID8gc3Bhbi5wYXJlbnRTcGFuSWRcbiAgICAgICAgOiAncGFyZW50U3BhbkNvbnRleHQnIGluIHNwYW5cbiAgICAgICAgICA/IChzcGFuLnBhcmVudFNwYW5Db250ZXh0ICk/LnNwYW5JZFxuICAgICAgICAgIDogdW5kZWZpbmVkO1xuXG4gICAgcmV0dXJuIHtcbiAgICAgIHNwYW5faWQsXG4gICAgICB0cmFjZV9pZCxcbiAgICAgIGRhdGE6IGF0dHJpYnV0ZXMsXG4gICAgICBkZXNjcmlwdGlvbjogbmFtZSxcbiAgICAgIHBhcmVudF9zcGFuX2lkOiBwYXJlbnRTcGFuSWQsXG4gICAgICBzdGFydF90aW1lc3RhbXA6IHNwYW5UaW1lSW5wdXRUb1NlY29uZHMoc3RhcnRUaW1lKSxcbiAgICAgIC8vIFRoaXMgaXMgWzAsMF0gYnkgZGVmYXVsdCBpbiBPVEVMLCBpbiB3aGljaCBjYXNlIHdlIHdhbnQgdG8gaW50ZXJwcmV0IHRoaXMgYXMgbm8gZW5kIHRpbWVcbiAgICAgIHRpbWVzdGFtcDogc3BhblRpbWVJbnB1dFRvU2Vjb25kcyhlbmRUaW1lKSB8fCB1bmRlZmluZWQsXG4gICAgICBzdGF0dXM6IGdldFN0YXR1c01lc3NhZ2Uoc3RhdHVzKSxcbiAgICAgIG9wOiBhdHRyaWJ1dGVzW3NlbWFudGljQXR0cmlidXRlcy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX09QXSxcbiAgICAgIG9yaWdpbjogYXR0cmlidXRlc1tzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9PUklHSU5dICxcbiAgICAgIGxpbmtzOiBjb252ZXJ0U3BhbkxpbmtzRm9yRW52ZWxvcGUobGlua3MpLFxuICAgIH07XG4gIH1cblxuICAvLyBGaW5hbGx5LCBhdCBsZWFzdCB3ZSBoYXZlIGBzcGFuQ29udGV4dCgpYC4uLi5cbiAgLy8gVGhpcyBzaG91bGQgbm90IGFjdHVhbGx5IGhhcHBlbiBpbiByZWFsaXR5LCBidXQgd2UgbmVlZCB0byBoYW5kbGUgaXQgZm9yIHR5cGUgc2FmZXR5LlxuICByZXR1cm4ge1xuICAgIHNwYW5faWQsXG4gICAgdHJhY2VfaWQsXG4gICAgc3RhcnRfdGltZXN0YW1wOiAwLFxuICAgIGRhdGE6IHt9LFxuICB9O1xufVxuXG5mdW5jdGlvbiBzcGFuSXNPcGVuVGVsZW1ldHJ5U2RrVHJhY2VCYXNlU3BhbihzcGFuKSB7XG4gIGNvbnN0IGNhc3RTcGFuID0gc3BhbiA7XG4gIHJldHVybiAhIWNhc3RTcGFuLmF0dHJpYnV0ZXMgJiYgISFjYXN0U3Bhbi5zdGFydFRpbWUgJiYgISFjYXN0U3Bhbi5uYW1lICYmICEhY2FzdFNwYW4uZW5kVGltZSAmJiAhIWNhc3RTcGFuLnN0YXR1cztcbn1cblxuLyoqIEV4cG9ydGVkIG9ubHkgZm9yIHRlc3RzLiAqL1xuXG4vKipcbiAqIFNhZGx5LCBkdWUgdG8gY2lyY3VsYXIgZGVwZW5kZW5jeSBjaGVja3Mgd2UgY2Fubm90IGFjdHVhbGx5IGltcG9ydCB0aGUgU3BhbiBjbGFzcyBoZXJlIGFuZCBjaGVjayBmb3IgaW5zdGFuY2VvZi5cbiAqIDooIFNvIGluc3RlYWQgd2UgYXBwcm94aW1hdGUgdGhpcyBieSBjaGVja2luZyBpZiBpdCBoYXMgdGhlIGBnZXRTcGFuSlNPTmAgbWV0aG9kLlxuICovXG5mdW5jdGlvbiBzcGFuSXNTZW50cnlTcGFuKHNwYW4pIHtcbiAgcmV0dXJuIHR5cGVvZiAoc3BhbiApLmdldFNwYW5KU09OID09PSAnZnVuY3Rpb24nO1xufVxuXG4vKipcbiAqIFJldHVybnMgdHJ1ZSBpZiBhIHNwYW4gaXMgc2FtcGxlZC5cbiAqIEluIG1vc3QgY2FzZXMsIHlvdSBzaG91bGQganVzdCB1c2UgYHNwYW4uaXNSZWNvcmRpbmcoKWAgaW5zdGVhZC5cbiAqIEhvd2V2ZXIsIHRoaXMgaGFzIGEgc2xpZ2h0bHkgZGlmZmVyZW50IHNlbWFudGljLCBhcyBpdCBhbHNvIHJldHVybnMgZmFsc2UgaWYgdGhlIHNwYW4gaXMgZmluaXNoZWQuXG4gKiBTbyBpbiB0aGUgY2FzZSB3aGVyZSB0aGlzIGRpc3RpbmN0aW9uIGlzIGltcG9ydGFudCwgdXNlIHRoaXMgbWV0aG9kLlxuICovXG5mdW5jdGlvbiBzcGFuSXNTYW1wbGVkKHNwYW4pIHtcbiAgLy8gV2UgYWxpZ24gb3VyIHRyYWNlIGZsYWdzIHdpdGggdGhlIG9uZXMgT3BlblRlbGVtZXRyeSB1c2VcbiAgLy8gU28gd2UgYWxzbyBjaGVjayBmb3Igc2FtcGxlZCB0aGUgc2FtZSB3YXkgdGhleSBkby5cbiAgY29uc3QgeyB0cmFjZUZsYWdzIH0gPSBzcGFuLnNwYW5Db250ZXh0KCk7XG4gIHJldHVybiB0cmFjZUZsYWdzID09PSBUUkFDRV9GTEFHX1NBTVBMRUQ7XG59XG5cbi8qKiBHZXQgdGhlIHN0YXR1cyBtZXNzYWdlIHRvIHVzZSBmb3IgYSBKU09OIHJlcHJlc2VudGF0aW9uIG9mIGEgc3Bhbi4gKi9cbmZ1bmN0aW9uIGdldFN0YXR1c01lc3NhZ2Uoc3RhdHVzKSB7XG4gIGlmICghc3RhdHVzIHx8IHN0YXR1cy5jb2RlID09PSBzcGFuc3RhdHVzLlNQQU5fU1RBVFVTX1VOU0VUKSB7XG4gICAgcmV0dXJuIHVuZGVmaW5lZDtcbiAgfVxuXG4gIGlmIChzdGF0dXMuY29kZSA9PT0gc3BhbnN0YXR1cy5TUEFOX1NUQVRVU19PSykge1xuICAgIHJldHVybiAnb2snO1xuICB9XG5cbiAgcmV0dXJuIHN0YXR1cy5tZXNzYWdlIHx8ICd1bmtub3duX2Vycm9yJztcbn1cblxuY29uc3QgQ0hJTERfU1BBTlNfRklFTEQgPSAnX3NlbnRyeUNoaWxkU3BhbnMnO1xuY29uc3QgUk9PVF9TUEFOX0ZJRUxEID0gJ19zZW50cnlSb290U3Bhbic7XG5cbi8qKlxuICogQWRkcyBhbiBvcGFxdWUgY2hpbGQgc3BhbiByZWZlcmVuY2UgdG8gYSBzcGFuLlxuICovXG5mdW5jdGlvbiBhZGRDaGlsZFNwYW5Ub1NwYW4oc3BhbiwgY2hpbGRTcGFuKSB7XG4gIC8vIFdlIHN0b3JlIHRoZSByb290IHNwYW4gcmVmZXJlbmNlIG9uIHRoZSBjaGlsZCBzcGFuXG4gIC8vIFdlIG5lZWQgdGhpcyBmb3IgYGdldFJvb3RTcGFuKClgIHRvIHdvcmtcbiAgY29uc3Qgcm9vdFNwYW4gPSBzcGFuW1JPT1RfU1BBTl9GSUVMRF0gfHwgc3BhbjtcbiAgb2JqZWN0LmFkZE5vbkVudW1lcmFibGVQcm9wZXJ0eShjaGlsZFNwYW4gLCBST09UX1NQQU5fRklFTEQsIHJvb3RTcGFuKTtcblxuICAvLyBXZSBzdG9yZSBhIGxpc3Qgb2YgY2hpbGQgc3BhbnMgb24gdGhlIHBhcmVudCBzcGFuXG4gIC8vIFdlIG5lZWQgdGhpcyBmb3IgYGdldFNwYW5EZXNjZW5kYW50cygpYCB0byB3b3JrXG4gIGlmIChzcGFuW0NISUxEX1NQQU5TX0ZJRUxEXSkge1xuICAgIHNwYW5bQ0hJTERfU1BBTlNfRklFTERdLmFkZChjaGlsZFNwYW4pO1xuICB9IGVsc2Uge1xuICAgIG9iamVjdC5hZGROb25FbnVtZXJhYmxlUHJvcGVydHkoc3BhbiwgQ0hJTERfU1BBTlNfRklFTEQsIG5ldyBTZXQoW2NoaWxkU3Bhbl0pKTtcbiAgfVxufVxuXG4vKiogVGhpcyBpcyBvbmx5IHVzZWQgaW50ZXJuYWxseSBieSBJZGxlIFNwYW5zLiAqL1xuZnVuY3Rpb24gcmVtb3ZlQ2hpbGRTcGFuRnJvbVNwYW4oc3BhbiwgY2hpbGRTcGFuKSB7XG4gIGlmIChzcGFuW0NISUxEX1NQQU5TX0ZJRUxEXSkge1xuICAgIHNwYW5bQ0hJTERfU1BBTlNfRklFTERdLmRlbGV0ZShjaGlsZFNwYW4pO1xuICB9XG59XG5cbi8qKlxuICogUmV0dXJucyBhbiBhcnJheSBvZiB0aGUgZ2l2ZW4gc3BhbiBhbmQgYWxsIG9mIGl0cyBkZXNjZW5kYW50cy5cbiAqL1xuZnVuY3Rpb24gZ2V0U3BhbkRlc2NlbmRhbnRzKHNwYW4pIHtcbiAgY29uc3QgcmVzdWx0U2V0ID0gbmV3IFNldCgpO1xuXG4gIGZ1bmN0aW9uIGFkZFNwYW5DaGlsZHJlbihzcGFuKSB7XG4gICAgLy8gVGhpcyBleGl0IGNvbmRpdGlvbiBpcyByZXF1aXJlZCB0byBub3QgaW5maW5pdGVseSBsb29wIGluIGNhc2Ugb2YgYSBjaXJjdWxhciBkZXBlbmRlbmN5LlxuICAgIGlmIChyZXN1bHRTZXQuaGFzKHNwYW4pKSB7XG4gICAgICByZXR1cm47XG4gICAgICAvLyBXZSB3YW50IHRvIGlnbm9yZSB1bnNhbXBsZWQgc3BhbnMgKGUuZy4gbm9uIHJlY29yZGluZyBzcGFucylcbiAgICB9IGVsc2UgaWYgKHNwYW5Jc1NhbXBsZWQoc3BhbikpIHtcbiAgICAgIHJlc3VsdFNldC5hZGQoc3Bhbik7XG4gICAgICBjb25zdCBjaGlsZFNwYW5zID0gc3BhbltDSElMRF9TUEFOU19GSUVMRF0gPyBBcnJheS5mcm9tKHNwYW5bQ0hJTERfU1BBTlNfRklFTERdKSA6IFtdO1xuICAgICAgZm9yIChjb25zdCBjaGlsZFNwYW4gb2YgY2hpbGRTcGFucykge1xuICAgICAgICBhZGRTcGFuQ2hpbGRyZW4oY2hpbGRTcGFuKTtcbiAgICAgIH1cbiAgICB9XG4gIH1cblxuICBhZGRTcGFuQ2hpbGRyZW4oc3Bhbik7XG5cbiAgcmV0dXJuIEFycmF5LmZyb20ocmVzdWx0U2V0KTtcbn1cblxuLyoqXG4gKiBSZXR1cm5zIHRoZSByb290IHNwYW4gb2YgYSBnaXZlbiBzcGFuLlxuICovXG5mdW5jdGlvbiBnZXRSb290U3BhbihzcGFuKSB7XG4gIHJldHVybiBzcGFuW1JPT1RfU1BBTl9GSUVMRF0gfHwgc3Bhbjtcbn1cblxuLyoqXG4gKiBSZXR1cm5zIHRoZSBjdXJyZW50bHkgYWN0aXZlIHNwYW4uXG4gKi9cbmZ1bmN0aW9uIGdldEFjdGl2ZVNwYW4oKSB7XG4gIGNvbnN0IGNhcnJpZXIkMSA9IGNhcnJpZXIuZ2V0TWFpbkNhcnJpZXIoKTtcbiAgY29uc3QgYWNzID0gaW5kZXguZ2V0QXN5bmNDb250ZXh0U3RyYXRlZ3koY2FycmllciQxKTtcbiAgaWYgKGFjcy5nZXRBY3RpdmVTcGFuKSB7XG4gICAgcmV0dXJuIGFjcy5nZXRBY3RpdmVTcGFuKCk7XG4gIH1cblxuICByZXR1cm4gc3Bhbk9uU2NvcGUuX2dldFNwYW5Gb3JTY29wZShjdXJyZW50U2NvcGVzLmdldEN1cnJlbnRTY29wZSgpKTtcbn1cblxuLyoqXG4gKiBMb2dzIGEgd2FybmluZyBvbmNlIGlmIGBiZWZvcmVTZW5kU3BhbmAgaXMgdXNlZCB0byBkcm9wIHNwYW5zLlxuICovXG5mdW5jdGlvbiBzaG93U3BhbkRyb3BXYXJuaW5nKCkge1xuICBpZiAoIWhhc1Nob3duU3BhbkRyb3BXYXJuaW5nKSB7XG4gICAgZGVidWdMb2dnZXIuY29uc29sZVNhbmRib3goKCkgPT4ge1xuICAgICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIG5vLWNvbnNvbGVcbiAgICAgIGNvbnNvbGUud2FybihcbiAgICAgICAgJ1tTZW50cnldIFJldHVybmluZyBudWxsIGZyb20gYGJlZm9yZVNlbmRTcGFuYCBpcyBkaXNhbGxvd2VkLiBUbyBkcm9wIGNlcnRhaW4gc3BhbnMsIGNvbmZpZ3VyZSB0aGUgcmVzcGVjdGl2ZSBpbnRlZ3JhdGlvbnMgZGlyZWN0bHkuJyxcbiAgICAgICk7XG4gICAgfSk7XG4gICAgaGFzU2hvd25TcGFuRHJvcFdhcm5pbmcgPSB0cnVlO1xuICB9XG59XG5cbi8qKlxuICogVXBkYXRlcyB0aGUgbmFtZSBvZiB0aGUgZ2l2ZW4gc3BhbiBhbmQgZW5zdXJlcyB0aGF0IHRoZSBzcGFuIG5hbWUgaXMgbm90XG4gKiBvdmVyd3JpdHRlbiBieSB0aGUgU2VudHJ5IFNESy5cbiAqXG4gKiBVc2UgdGhpcyBmdW5jdGlvbiBpbnN0ZWFkIG9mIGBzcGFuLnVwZGF0ZU5hbWUoKWAgaWYgeW91IHdhbnQgdG8gbWFrZSBzdXJlIHRoYXRcbiAqIHlvdXIgbmFtZSBpcyBrZXB0LiBGb3Igc29tZSBzcGFucywgZm9yIGV4YW1wbGUgcm9vdCBgaHR0cC5zZXJ2ZXJgIHNwYW5zIHRoZVxuICogU2VudHJ5IFNESyB3b3VsZCBvdGhlcndpc2Ugb3ZlcndyaXRlIHRoZSBzcGFuIG5hbWUgd2l0aCBhIGhpZ2gtcXVhbGl0eSBuYW1lXG4gKiBpdCBpbmZlcnMgd2hlbiB0aGUgc3BhbiBlbmRzLlxuICpcbiAqIFVzZSB0aGlzIGZ1bmN0aW9uIGluIHNlcnZlciBjb2RlIG9yIHdoZW4geW91ciBzcGFuIGlzIHN0YXJ0ZWQgb24gdGhlIHNlcnZlclxuICogYW5kIG9uIHRoZSBjbGllbnQgKGJyb3dzZXIpLiBJZiB5b3Ugb25seSB1cGRhdGUgYSBzcGFuIG5hbWUgb24gdGhlIGNsaWVudCxcbiAqIHlvdSBjYW4gYWxzbyB1c2UgYHNwYW4udXBkYXRlTmFtZSgpYCB0aGUgU0RLIGRvZXMgbm90IG92ZXJ3cml0ZSB0aGUgbmFtZS5cbiAqXG4gKiBAcGFyYW0gc3BhbiAtIFRoZSBzcGFuIHRvIHVwZGF0ZSB0aGUgbmFtZSBvZi5cbiAqIEBwYXJhbSBuYW1lIC0gVGhlIG5hbWUgdG8gc2V0IG9uIHRoZSBzcGFuLlxuICovXG5mdW5jdGlvbiB1cGRhdGVTcGFuTmFtZShzcGFuLCBuYW1lKSB7XG4gIHNwYW4udXBkYXRlTmFtZShuYW1lKTtcbiAgc3Bhbi5zZXRBdHRyaWJ1dGVzKHtcbiAgICBbc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfU09VUkNFXTogJ2N1c3RvbScsXG4gICAgW3NlbWFudGljQXR0cmlidXRlcy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX0NVU1RPTV9TUEFOX05BTUVdOiBuYW1lLFxuICB9KTtcbn1cblxuZXhwb3J0cy5UUkFDRV9GTEFHX05PTkUgPSBUUkFDRV9GTEFHX05PTkU7XG5leHBvcnRzLlRSQUNFX0ZMQUdfU0FNUExFRCA9IFRSQUNFX0ZMQUdfU0FNUExFRDtcbmV4cG9ydHMuYWRkQ2hpbGRTcGFuVG9TcGFuID0gYWRkQ2hpbGRTcGFuVG9TcGFuO1xuZXhwb3J0cy5jb252ZXJ0U3BhbkxpbmtzRm9yRW52ZWxvcGUgPSBjb252ZXJ0U3BhbkxpbmtzRm9yRW52ZWxvcGU7XG5leHBvcnRzLmdldEFjdGl2ZVNwYW4gPSBnZXRBY3RpdmVTcGFuO1xuZXhwb3J0cy5nZXRSb290U3BhbiA9IGdldFJvb3RTcGFuO1xuZXhwb3J0cy5nZXRTcGFuRGVzY2VuZGFudHMgPSBnZXRTcGFuRGVzY2VuZGFudHM7XG5leHBvcnRzLmdldFN0YXR1c01lc3NhZ2UgPSBnZXRTdGF0dXNNZXNzYWdlO1xuZXhwb3J0cy5yZW1vdmVDaGlsZFNwYW5Gcm9tU3BhbiA9IHJlbW92ZUNoaWxkU3BhbkZyb21TcGFuO1xuZXhwb3J0cy5zaG93U3BhbkRyb3BXYXJuaW5nID0gc2hvd1NwYW5Ecm9wV2FybmluZztcbmV4cG9ydHMuc3BhbklzU2FtcGxlZCA9IHNwYW5Jc1NhbXBsZWQ7XG5leHBvcnRzLnNwYW5UaW1lSW5wdXRUb1NlY29uZHMgPSBzcGFuVGltZUlucHV0VG9TZWNvbmRzO1xuZXhwb3J0cy5zcGFuVG9KU09OID0gc3BhblRvSlNPTjtcbmV4cG9ydHMuc3BhblRvVHJhY2VDb250ZXh0ID0gc3BhblRvVHJhY2VDb250ZXh0O1xuZXhwb3J0cy5zcGFuVG9UcmFjZUhlYWRlciA9IHNwYW5Ub1RyYWNlSGVhZGVyO1xuZXhwb3J0cy5zcGFuVG9UcmFuc2FjdGlvblRyYWNlQ29udGV4dCA9IHNwYW5Ub1RyYW5zYWN0aW9uVHJhY2VDb250ZXh0O1xuZXhwb3J0cy51cGRhdGVTcGFuTmFtZSA9IHVwZGF0ZVNwYW5OYW1lO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9c3BhblV0aWxzLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanUtils.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/stacktrace.js":
/*!********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/stacktrace.js ***!
  \********************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst STACKTRACE_FRAME_LIMIT = 50;\nconst UNKNOWN_FUNCTION = '?';\n// Used to sanitize webpack (error: *) wrapped stack errors\nconst WEBPACK_ERROR_REGEXP = /\\(error: (.*)\\)/;\nconst STRIP_FRAME_REGEXP = /captureMessage|captureException/;\n\n/**\n * Creates a stack parser with the supplied line parsers\n *\n * StackFrames are returned in the correct order for Sentry Exception\n * frames and with Sentry SDK internal frames removed from the top and bottom\n *\n */\nfunction createStackParser(...parsers) {\n  const sortedParsers = parsers.sort((a, b) => a[0] - b[0]).map(p => p[1]);\n\n  return (stack, skipFirstLines = 0, framesToPop = 0) => {\n    const frames = [];\n    const lines = stack.split('\\n');\n\n    for (let i = skipFirstLines; i < lines.length; i++) {\n      const line = lines[i] ;\n      // Ignore lines over 1kb as they are unlikely to be stack frames.\n      // Many of the regular expressions use backtracking which results in run time that increases exponentially with\n      // input size. Huge strings can result in hangs/Denial of Service:\n      // https://github.com/getsentry/sentry-javascript/issues/2286\n      if (line.length > 1024) {\n        continue;\n      }\n\n      // https://github.com/getsentry/sentry-javascript/issues/5459\n      // Remove webpack (error: *) wrappers\n      const cleanedLine = WEBPACK_ERROR_REGEXP.test(line) ? line.replace(WEBPACK_ERROR_REGEXP, '$1') : line;\n\n      // https://github.com/getsentry/sentry-javascript/issues/7813\n      // Skip Error: lines\n      if (cleanedLine.match(/\\S*Error: /)) {\n        continue;\n      }\n\n      for (const parser of sortedParsers) {\n        const frame = parser(cleanedLine);\n\n        if (frame) {\n          frames.push(frame);\n          break;\n        }\n      }\n\n      if (frames.length >= STACKTRACE_FRAME_LIMIT + framesToPop) {\n        break;\n      }\n    }\n\n    return stripSentryFramesAndReverse(frames.slice(framesToPop));\n  };\n}\n\n/**\n * Gets a stack parser implementation from Options.stackParser\n * @see Options\n *\n * If options contains an array of line parsers, it is converted into a parser\n */\nfunction stackParserFromStackParserOptions(stackParser) {\n  if (Array.isArray(stackParser)) {\n    return createStackParser(...stackParser);\n  }\n  return stackParser;\n}\n\n/**\n * Removes Sentry frames from the top and bottom of the stack if present and enforces a limit of max number of frames.\n * Assumes stack input is ordered from top to bottom and returns the reverse representation so call site of the\n * function that caused the crash is the last frame in the array.\n * @hidden\n */\nfunction stripSentryFramesAndReverse(stack) {\n  if (!stack.length) {\n    return [];\n  }\n\n  const localStack = Array.from(stack);\n\n  // If stack starts with one of our API calls, remove it (starts, meaning it's the top of the stack - aka last call)\n  if (/sentryWrapped/.test(getLastStackFrame(localStack).function || '')) {\n    localStack.pop();\n  }\n\n  // Reversing in the middle of the procedure allows us to just pop the values off the stack\n  localStack.reverse();\n\n  // If stack ends with one of our internal API calls, remove it (ends, meaning it's the bottom of the stack - aka top-most call)\n  if (STRIP_FRAME_REGEXP.test(getLastStackFrame(localStack).function || '')) {\n    localStack.pop();\n\n    // When using synthetic events, we will have a 2 levels deep stack, as `new Error('Sentry syntheticException')`\n    // is produced within the scope itself, making it:\n    //\n    //   Sentry.captureException()\n    //   scope.captureException()\n    //\n    // instead of just the top `Sentry` call itself.\n    // This forces us to possibly strip an additional frame in the exact same was as above.\n    if (STRIP_FRAME_REGEXP.test(getLastStackFrame(localStack).function || '')) {\n      localStack.pop();\n    }\n  }\n\n  return localStack.slice(0, STACKTRACE_FRAME_LIMIT).map(frame => ({\n    ...frame,\n    filename: frame.filename || getLastStackFrame(localStack).filename,\n    function: frame.function || UNKNOWN_FUNCTION,\n  }));\n}\n\nfunction getLastStackFrame(arr) {\n  return arr[arr.length - 1] || {};\n}\n\nconst defaultFunctionName = '<anonymous>';\n\n/**\n * Safely extract function name from itself\n */\nfunction getFunctionName(fn) {\n  try {\n    if (!fn || typeof fn !== 'function') {\n      return defaultFunctionName;\n    }\n    return fn.name || defaultFunctionName;\n  } catch {\n    // Just accessing custom props in some Selenium environments\n    // can cause a \"Permission denied\" exception (see raven-js#495).\n    return defaultFunctionName;\n  }\n}\n\n/**\n * Get's stack frames from an event without needing to check for undefined properties.\n */\nfunction getFramesFromEvent(event) {\n  const exception = event.exception;\n\n  if (exception) {\n    const frames = [];\n    try {\n      // @ts-expect-error Object could be undefined\n      exception.values.forEach(value => {\n        // @ts-expect-error Value could be undefined\n        if (value.stacktrace.frames) {\n          // @ts-expect-error Value could be undefined\n          frames.push(...value.stacktrace.frames);\n        }\n      });\n      return frames;\n    } catch {\n      return undefined;\n    }\n  }\n  return undefined;\n}\n\nexports.UNKNOWN_FUNCTION = UNKNOWN_FUNCTION;\nexports.createStackParser = createStackParser;\nexports.getFramesFromEvent = getFramesFromEvent;\nexports.getFunctionName = getFunctionName;\nexports.stackParserFromStackParserOptions = stackParserFromStackParserOptions;\nexports.stripSentryFramesAndReverse = stripSentryFramesAndReverse;\n//# sourceMappingURL=stacktrace.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9zdGFja3RyYWNlLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQSxpQ0FBaUMsa0JBQWtCO0FBQ25EO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsR0FBRztBQUNIOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxJQUFJO0FBQ0o7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsT0FBTztBQUNQO0FBQ0EsTUFBTTtBQUNOO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsd0JBQXdCO0FBQ3hCLHlCQUF5QjtBQUN6QiwwQkFBMEI7QUFDMUIsdUJBQXVCO0FBQ3ZCLHlDQUF5QztBQUN6QyxtQ0FBbUM7QUFDbkMiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9zdGFja3RyYWNlLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBTVEFDS1RSQUNFX0ZSQU1FX0xJTUlUID0gNTA7XG5jb25zdCBVTktOT1dOX0ZVTkNUSU9OID0gJz8nO1xuLy8gVXNlZCB0byBzYW5pdGl6ZSB3ZWJwYWNrIChlcnJvcjogKikgd3JhcHBlZCBzdGFjayBlcnJvcnNcbmNvbnN0IFdFQlBBQ0tfRVJST1JfUkVHRVhQID0gL1xcKGVycm9yOiAoLiopXFwpLztcbmNvbnN0IFNUUklQX0ZSQU1FX1JFR0VYUCA9IC9jYXB0dXJlTWVzc2FnZXxjYXB0dXJlRXhjZXB0aW9uLztcblxuLyoqXG4gKiBDcmVhdGVzIGEgc3RhY2sgcGFyc2VyIHdpdGggdGhlIHN1cHBsaWVkIGxpbmUgcGFyc2Vyc1xuICpcbiAqIFN0YWNrRnJhbWVzIGFyZSByZXR1cm5lZCBpbiB0aGUgY29ycmVjdCBvcmRlciBmb3IgU2VudHJ5IEV4Y2VwdGlvblxuICogZnJhbWVzIGFuZCB3aXRoIFNlbnRyeSBTREsgaW50ZXJuYWwgZnJhbWVzIHJlbW92ZWQgZnJvbSB0aGUgdG9wIGFuZCBib3R0b21cbiAqXG4gKi9cbmZ1bmN0aW9uIGNyZWF0ZVN0YWNrUGFyc2VyKC4uLnBhcnNlcnMpIHtcbiAgY29uc3Qgc29ydGVkUGFyc2VycyA9IHBhcnNlcnMuc29ydCgoYSwgYikgPT4gYVswXSAtIGJbMF0pLm1hcChwID0+IHBbMV0pO1xuXG4gIHJldHVybiAoc3RhY2ssIHNraXBGaXJzdExpbmVzID0gMCwgZnJhbWVzVG9Qb3AgPSAwKSA9PiB7XG4gICAgY29uc3QgZnJhbWVzID0gW107XG4gICAgY29uc3QgbGluZXMgPSBzdGFjay5zcGxpdCgnXFxuJyk7XG5cbiAgICBmb3IgKGxldCBpID0gc2tpcEZpcnN0TGluZXM7IGkgPCBsaW5lcy5sZW5ndGg7IGkrKykge1xuICAgICAgY29uc3QgbGluZSA9IGxpbmVzW2ldIDtcbiAgICAgIC8vIElnbm9yZSBsaW5lcyBvdmVyIDFrYiBhcyB0aGV5IGFyZSB1bmxpa2VseSB0byBiZSBzdGFjayBmcmFtZXMuXG4gICAgICAvLyBNYW55IG9mIHRoZSByZWd1bGFyIGV4cHJlc3Npb25zIHVzZSBiYWNrdHJhY2tpbmcgd2hpY2ggcmVzdWx0cyBpbiBydW4gdGltZSB0aGF0IGluY3JlYXNlcyBleHBvbmVudGlhbGx5IHdpdGhcbiAgICAgIC8vIGlucHV0IHNpemUuIEh1Z2Ugc3RyaW5ncyBjYW4gcmVzdWx0IGluIGhhbmdzL0RlbmlhbCBvZiBTZXJ2aWNlOlxuICAgICAgLy8gaHR0cHM6Ly9naXRodWIuY29tL2dldHNlbnRyeS9zZW50cnktamF2YXNjcmlwdC9pc3N1ZXMvMjI4NlxuICAgICAgaWYgKGxpbmUubGVuZ3RoID4gMTAyNCkge1xuICAgICAgICBjb250aW51ZTtcbiAgICAgIH1cblxuICAgICAgLy8gaHR0cHM6Ly9naXRodWIuY29tL2dldHNlbnRyeS9zZW50cnktamF2YXNjcmlwdC9pc3N1ZXMvNTQ1OVxuICAgICAgLy8gUmVtb3ZlIHdlYnBhY2sgKGVycm9yOiAqKSB3cmFwcGVyc1xuICAgICAgY29uc3QgY2xlYW5lZExpbmUgPSBXRUJQQUNLX0VSUk9SX1JFR0VYUC50ZXN0KGxpbmUpID8gbGluZS5yZXBsYWNlKFdFQlBBQ0tfRVJST1JfUkVHRVhQLCAnJDEnKSA6IGxpbmU7XG5cbiAgICAgIC8vIGh0dHBzOi8vZ2l0aHViLmNvbS9nZXRzZW50cnkvc2VudHJ5LWphdmFzY3JpcHQvaXNzdWVzLzc4MTNcbiAgICAgIC8vIFNraXAgRXJyb3I6IGxpbmVzXG4gICAgICBpZiAoY2xlYW5lZExpbmUubWF0Y2goL1xcUypFcnJvcjogLykpIHtcbiAgICAgICAgY29udGludWU7XG4gICAgICB9XG5cbiAgICAgIGZvciAoY29uc3QgcGFyc2VyIG9mIHNvcnRlZFBhcnNlcnMpIHtcbiAgICAgICAgY29uc3QgZnJhbWUgPSBwYXJzZXIoY2xlYW5lZExpbmUpO1xuXG4gICAgICAgIGlmIChmcmFtZSkge1xuICAgICAgICAgIGZyYW1lcy5wdXNoKGZyYW1lKTtcbiAgICAgICAgICBicmVhaztcbiAgICAgICAgfVxuICAgICAgfVxuXG4gICAgICBpZiAoZnJhbWVzLmxlbmd0aCA+PSBTVEFDS1RSQUNFX0ZSQU1FX0xJTUlUICsgZnJhbWVzVG9Qb3ApIHtcbiAgICAgICAgYnJlYWs7XG4gICAgICB9XG4gICAgfVxuXG4gICAgcmV0dXJuIHN0cmlwU2VudHJ5RnJhbWVzQW5kUmV2ZXJzZShmcmFtZXMuc2xpY2UoZnJhbWVzVG9Qb3ApKTtcbiAgfTtcbn1cblxuLyoqXG4gKiBHZXRzIGEgc3RhY2sgcGFyc2VyIGltcGxlbWVudGF0aW9uIGZyb20gT3B0aW9ucy5zdGFja1BhcnNlclxuICogQHNlZSBPcHRpb25zXG4gKlxuICogSWYgb3B0aW9ucyBjb250YWlucyBhbiBhcnJheSBvZiBsaW5lIHBhcnNlcnMsIGl0IGlzIGNvbnZlcnRlZCBpbnRvIGEgcGFyc2VyXG4gKi9cbmZ1bmN0aW9uIHN0YWNrUGFyc2VyRnJvbVN0YWNrUGFyc2VyT3B0aW9ucyhzdGFja1BhcnNlcikge1xuICBpZiAoQXJyYXkuaXNBcnJheShzdGFja1BhcnNlcikpIHtcbiAgICByZXR1cm4gY3JlYXRlU3RhY2tQYXJzZXIoLi4uc3RhY2tQYXJzZXIpO1xuICB9XG4gIHJldHVybiBzdGFja1BhcnNlcjtcbn1cblxuLyoqXG4gKiBSZW1vdmVzIFNlbnRyeSBmcmFtZXMgZnJvbSB0aGUgdG9wIGFuZCBib3R0b20gb2YgdGhlIHN0YWNrIGlmIHByZXNlbnQgYW5kIGVuZm9yY2VzIGEgbGltaXQgb2YgbWF4IG51bWJlciBvZiBmcmFtZXMuXG4gKiBBc3N1bWVzIHN0YWNrIGlucHV0IGlzIG9yZGVyZWQgZnJvbSB0b3AgdG8gYm90dG9tIGFuZCByZXR1cm5zIHRoZSByZXZlcnNlIHJlcHJlc2VudGF0aW9uIHNvIGNhbGwgc2l0ZSBvZiB0aGVcbiAqIGZ1bmN0aW9uIHRoYXQgY2F1c2VkIHRoZSBjcmFzaCBpcyB0aGUgbGFzdCBmcmFtZSBpbiB0aGUgYXJyYXkuXG4gKiBAaGlkZGVuXG4gKi9cbmZ1bmN0aW9uIHN0cmlwU2VudHJ5RnJhbWVzQW5kUmV2ZXJzZShzdGFjaykge1xuICBpZiAoIXN0YWNrLmxlbmd0aCkge1xuICAgIHJldHVybiBbXTtcbiAgfVxuXG4gIGNvbnN0IGxvY2FsU3RhY2sgPSBBcnJheS5mcm9tKHN0YWNrKTtcblxuICAvLyBJZiBzdGFjayBzdGFydHMgd2l0aCBvbmUgb2Ygb3VyIEFQSSBjYWxscywgcmVtb3ZlIGl0IChzdGFydHMsIG1lYW5pbmcgaXQncyB0aGUgdG9wIG9mIHRoZSBzdGFjayAtIGFrYSBsYXN0IGNhbGwpXG4gIGlmICgvc2VudHJ5V3JhcHBlZC8udGVzdChnZXRMYXN0U3RhY2tGcmFtZShsb2NhbFN0YWNrKS5mdW5jdGlvbiB8fCAnJykpIHtcbiAgICBsb2NhbFN0YWNrLnBvcCgpO1xuICB9XG5cbiAgLy8gUmV2ZXJzaW5nIGluIHRoZSBtaWRkbGUgb2YgdGhlIHByb2NlZHVyZSBhbGxvd3MgdXMgdG8ganVzdCBwb3AgdGhlIHZhbHVlcyBvZmYgdGhlIHN0YWNrXG4gIGxvY2FsU3RhY2sucmV2ZXJzZSgpO1xuXG4gIC8vIElmIHN0YWNrIGVuZHMgd2l0aCBvbmUgb2Ygb3VyIGludGVybmFsIEFQSSBjYWxscywgcmVtb3ZlIGl0IChlbmRzLCBtZWFuaW5nIGl0J3MgdGhlIGJvdHRvbSBvZiB0aGUgc3RhY2sgLSBha2EgdG9wLW1vc3QgY2FsbClcbiAgaWYgKFNUUklQX0ZSQU1FX1JFR0VYUC50ZXN0KGdldExhc3RTdGFja0ZyYW1lKGxvY2FsU3RhY2spLmZ1bmN0aW9uIHx8ICcnKSkge1xuICAgIGxvY2FsU3RhY2sucG9wKCk7XG5cbiAgICAvLyBXaGVuIHVzaW5nIHN5bnRoZXRpYyBldmVudHMsIHdlIHdpbGwgaGF2ZSBhIDIgbGV2ZWxzIGRlZXAgc3RhY2ssIGFzIGBuZXcgRXJyb3IoJ1NlbnRyeSBzeW50aGV0aWNFeGNlcHRpb24nKWBcbiAgICAvLyBpcyBwcm9kdWNlZCB3aXRoaW4gdGhlIHNjb3BlIGl0c2VsZiwgbWFraW5nIGl0OlxuICAgIC8vXG4gICAgLy8gICBTZW50cnkuY2FwdHVyZUV4Y2VwdGlvbigpXG4gICAgLy8gICBzY29wZS5jYXB0dXJlRXhjZXB0aW9uKClcbiAgICAvL1xuICAgIC8vIGluc3RlYWQgb2YganVzdCB0aGUgdG9wIGBTZW50cnlgIGNhbGwgaXRzZWxmLlxuICAgIC8vIFRoaXMgZm9yY2VzIHVzIHRvIHBvc3NpYmx5IHN0cmlwIGFuIGFkZGl0aW9uYWwgZnJhbWUgaW4gdGhlIGV4YWN0IHNhbWUgd2FzIGFzIGFib3ZlLlxuICAgIGlmIChTVFJJUF9GUkFNRV9SRUdFWFAudGVzdChnZXRMYXN0U3RhY2tGcmFtZShsb2NhbFN0YWNrKS5mdW5jdGlvbiB8fCAnJykpIHtcbiAgICAgIGxvY2FsU3RhY2sucG9wKCk7XG4gICAgfVxuICB9XG5cbiAgcmV0dXJuIGxvY2FsU3RhY2suc2xpY2UoMCwgU1RBQ0tUUkFDRV9GUkFNRV9MSU1JVCkubWFwKGZyYW1lID0+ICh7XG4gICAgLi4uZnJhbWUsXG4gICAgZmlsZW5hbWU6IGZyYW1lLmZpbGVuYW1lIHx8IGdldExhc3RTdGFja0ZyYW1lKGxvY2FsU3RhY2spLmZpbGVuYW1lLFxuICAgIGZ1bmN0aW9uOiBmcmFtZS5mdW5jdGlvbiB8fCBVTktOT1dOX0ZVTkNUSU9OLFxuICB9KSk7XG59XG5cbmZ1bmN0aW9uIGdldExhc3RTdGFja0ZyYW1lKGFycikge1xuICByZXR1cm4gYXJyW2Fyci5sZW5ndGggLSAxXSB8fCB7fTtcbn1cblxuY29uc3QgZGVmYXVsdEZ1bmN0aW9uTmFtZSA9ICc8YW5vbnltb3VzPic7XG5cbi8qKlxuICogU2FmZWx5IGV4dHJhY3QgZnVuY3Rpb24gbmFtZSBmcm9tIGl0c2VsZlxuICovXG5mdW5jdGlvbiBnZXRGdW5jdGlvbk5hbWUoZm4pIHtcbiAgdHJ5IHtcbiAgICBpZiAoIWZuIHx8IHR5cGVvZiBmbiAhPT0gJ2Z1bmN0aW9uJykge1xuICAgICAgcmV0dXJuIGRlZmF1bHRGdW5jdGlvbk5hbWU7XG4gICAgfVxuICAgIHJldHVybiBmbi5uYW1lIHx8IGRlZmF1bHRGdW5jdGlvbk5hbWU7XG4gIH0gY2F0Y2gge1xuICAgIC8vIEp1c3QgYWNjZXNzaW5nIGN1c3RvbSBwcm9wcyBpbiBzb21lIFNlbGVuaXVtIGVudmlyb25tZW50c1xuICAgIC8vIGNhbiBjYXVzZSBhIFwiUGVybWlzc2lvbiBkZW5pZWRcIiBleGNlcHRpb24gKHNlZSByYXZlbi1qcyM0OTUpLlxuICAgIHJldHVybiBkZWZhdWx0RnVuY3Rpb25OYW1lO1xuICB9XG59XG5cbi8qKlxuICogR2V0J3Mgc3RhY2sgZnJhbWVzIGZyb20gYW4gZXZlbnQgd2l0aG91dCBuZWVkaW5nIHRvIGNoZWNrIGZvciB1bmRlZmluZWQgcHJvcGVydGllcy5cbiAqL1xuZnVuY3Rpb24gZ2V0RnJhbWVzRnJvbUV2ZW50KGV2ZW50KSB7XG4gIGNvbnN0IGV4Y2VwdGlvbiA9IGV2ZW50LmV4Y2VwdGlvbjtcblxuICBpZiAoZXhjZXB0aW9uKSB7XG4gICAgY29uc3QgZnJhbWVzID0gW107XG4gICAgdHJ5IHtcbiAgICAgIC8vIEB0cy1leHBlY3QtZXJyb3IgT2JqZWN0IGNvdWxkIGJlIHVuZGVmaW5lZFxuICAgICAgZXhjZXB0aW9uLnZhbHVlcy5mb3JFYWNoKHZhbHVlID0+IHtcbiAgICAgICAgLy8gQHRzLWV4cGVjdC1lcnJvciBWYWx1ZSBjb3VsZCBiZSB1bmRlZmluZWRcbiAgICAgICAgaWYgKHZhbHVlLnN0YWNrdHJhY2UuZnJhbWVzKSB7XG4gICAgICAgICAgLy8gQHRzLWV4cGVjdC1lcnJvciBWYWx1ZSBjb3VsZCBiZSB1bmRlZmluZWRcbiAgICAgICAgICBmcmFtZXMucHVzaCguLi52YWx1ZS5zdGFja3RyYWNlLmZyYW1lcyk7XG4gICAgICAgIH1cbiAgICAgIH0pO1xuICAgICAgcmV0dXJuIGZyYW1lcztcbiAgICB9IGNhdGNoIHtcbiAgICAgIHJldHVybiB1bmRlZmluZWQ7XG4gICAgfVxuICB9XG4gIHJldHVybiB1bmRlZmluZWQ7XG59XG5cbmV4cG9ydHMuVU5LTk9XTl9GVU5DVElPTiA9IFVOS05PV05fRlVOQ1RJT047XG5leHBvcnRzLmNyZWF0ZVN0YWNrUGFyc2VyID0gY3JlYXRlU3RhY2tQYXJzZXI7XG5leHBvcnRzLmdldEZyYW1lc0Zyb21FdmVudCA9IGdldEZyYW1lc0Zyb21FdmVudDtcbmV4cG9ydHMuZ2V0RnVuY3Rpb25OYW1lID0gZ2V0RnVuY3Rpb25OYW1lO1xuZXhwb3J0cy5zdGFja1BhcnNlckZyb21TdGFja1BhcnNlck9wdGlvbnMgPSBzdGFja1BhcnNlckZyb21TdGFja1BhcnNlck9wdGlvbnM7XG5leHBvcnRzLnN0cmlwU2VudHJ5RnJhbWVzQW5kUmV2ZXJzZSA9IHN0cmlwU2VudHJ5RnJhbWVzQW5kUmV2ZXJzZTtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPXN0YWNrdHJhY2UuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/stacktrace.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/string.js":
/*!****************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/string.js ***!
  \****************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst is = __webpack_require__(/*! ./is.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js\");\n\n/**\n * Truncates given string to the maximum characters count\n *\n * @param str An object that contains serializable values\n * @param max Maximum number of characters in truncated string (0 = unlimited)\n * @returns string Encoded\n */\nfunction truncate(str, max = 0) {\n  if (typeof str !== 'string' || max === 0) {\n    return str;\n  }\n  return str.length <= max ? str : `${str.slice(0, max)}...`;\n}\n\n/**\n * This is basically just `trim_line` from\n * https://github.com/getsentry/sentry/blob/master/src/sentry/lang/javascript/processor.py#L67\n *\n * @param str An object that contains serializable values\n * @param max Maximum number of characters in truncated string\n * @returns string Encoded\n */\nfunction snipLine(line, colno) {\n  let newLine = line;\n  const lineLength = newLine.length;\n  if (lineLength <= 150) {\n    return newLine;\n  }\n  if (colno > lineLength) {\n    // eslint-disable-next-line no-param-reassign\n    colno = lineLength;\n  }\n\n  let start = Math.max(colno - 60, 0);\n  if (start < 5) {\n    start = 0;\n  }\n\n  let end = Math.min(start + 140, lineLength);\n  if (end > lineLength - 5) {\n    end = lineLength;\n  }\n  if (end === lineLength) {\n    start = Math.max(end - 140, 0);\n  }\n\n  newLine = newLine.slice(start, end);\n  if (start > 0) {\n    newLine = `'{snip} ${newLine}`;\n  }\n  if (end < lineLength) {\n    newLine += ' {snip}';\n  }\n\n  return newLine;\n}\n\n/**\n * Join values in array\n * @param input array of values to be joined together\n * @param delimiter string to be placed in-between values\n * @returns Joined values\n */\nfunction safeJoin(input, delimiter) {\n  if (!Array.isArray(input)) {\n    return '';\n  }\n\n  const output = [];\n  // eslint-disable-next-line @typescript-eslint/prefer-for-of\n  for (let i = 0; i < input.length; i++) {\n    const value = input[i];\n    try {\n      // This is a hack to fix a Vue3-specific bug that causes an infinite loop of\n      // console warnings. This happens when a Vue template is rendered with\n      // an undeclared variable, which we try to stringify, ultimately causing\n      // Vue to issue another warning which repeats indefinitely.\n      // see: https://github.com/getsentry/sentry-javascript/pull/8981\n      if (is.isVueViewModel(value)) {\n        output.push('[VueViewModel]');\n      } else {\n        output.push(String(value));\n      }\n    } catch {\n      output.push('[value cannot be serialized]');\n    }\n  }\n\n  return output.join(delimiter);\n}\n\n/**\n * Checks if the given value matches a regex or string\n *\n * @param value The string to test\n * @param pattern Either a regex or a string against which `value` will be matched\n * @param requireExactStringMatch If true, `value` must match `pattern` exactly. If false, `value` will match\n * `pattern` if it contains `pattern`. Only applies to string-type patterns.\n */\nfunction isMatchingPattern(\n  value,\n  pattern,\n  requireExactStringMatch = false,\n) {\n  if (!is.isString(value)) {\n    return false;\n  }\n\n  if (is.isRegExp(pattern)) {\n    return pattern.test(value);\n  }\n  if (is.isString(pattern)) {\n    return requireExactStringMatch ? value === pattern : value.includes(pattern);\n  }\n\n  return false;\n}\n\n/**\n * Test the given string against an array of strings and regexes. By default, string matching is done on a\n * substring-inclusion basis rather than a strict equality basis\n *\n * @param testString The string to test\n * @param patterns The patterns against which to test the string\n * @param requireExactStringMatch If true, `testString` must match one of the given string patterns exactly in order to\n * count. If false, `testString` will match a string pattern if it contains that pattern.\n * @returns\n */\nfunction stringMatchesSomePattern(\n  testString,\n  patterns = [],\n  requireExactStringMatch = false,\n) {\n  return patterns.some(pattern => isMatchingPattern(testString, pattern, requireExactStringMatch));\n}\n\nexports.isMatchingPattern = isMatchingPattern;\nexports.safeJoin = safeJoin;\nexports.snipLine = snipLine;\nexports.stringMatchesSomePattern = stringMatchesSomePattern;\nexports.truncate = truncate;\n//# sourceMappingURL=string.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9zdHJpbmcuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsV0FBVyxtQkFBTyxDQUFDLCtHQUFTOztBQUU1QjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0Esc0NBQXNDLGtCQUFrQjtBQUN4RDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLGlCQUFpQixNQUFNLEVBQUUsUUFBUTtBQUNqQztBQUNBO0FBQ0Esa0JBQWtCLEtBQUs7QUFDdkI7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0Esa0JBQWtCLGtCQUFrQjtBQUNwQztBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxRQUFRO0FBQ1I7QUFDQTtBQUNBLE1BQU07QUFDTjtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLHlCQUF5QjtBQUN6QixnQkFBZ0I7QUFDaEIsZ0JBQWdCO0FBQ2hCLGdDQUFnQztBQUNoQyxnQkFBZ0I7QUFDaEIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9zdHJpbmcuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGlzID0gcmVxdWlyZSgnLi9pcy5qcycpO1xuXG4vKipcbiAqIFRydW5jYXRlcyBnaXZlbiBzdHJpbmcgdG8gdGhlIG1heGltdW0gY2hhcmFjdGVycyBjb3VudFxuICpcbiAqIEBwYXJhbSBzdHIgQW4gb2JqZWN0IHRoYXQgY29udGFpbnMgc2VyaWFsaXphYmxlIHZhbHVlc1xuICogQHBhcmFtIG1heCBNYXhpbXVtIG51bWJlciBvZiBjaGFyYWN0ZXJzIGluIHRydW5jYXRlZCBzdHJpbmcgKDAgPSB1bmxpbWl0ZWQpXG4gKiBAcmV0dXJucyBzdHJpbmcgRW5jb2RlZFxuICovXG5mdW5jdGlvbiB0cnVuY2F0ZShzdHIsIG1heCA9IDApIHtcbiAgaWYgKHR5cGVvZiBzdHIgIT09ICdzdHJpbmcnIHx8IG1heCA9PT0gMCkge1xuICAgIHJldHVybiBzdHI7XG4gIH1cbiAgcmV0dXJuIHN0ci5sZW5ndGggPD0gbWF4ID8gc3RyIDogYCR7c3RyLnNsaWNlKDAsIG1heCl9Li4uYDtcbn1cblxuLyoqXG4gKiBUaGlzIGlzIGJhc2ljYWxseSBqdXN0IGB0cmltX2xpbmVgIGZyb21cbiAqIGh0dHBzOi8vZ2l0aHViLmNvbS9nZXRzZW50cnkvc2VudHJ5L2Jsb2IvbWFzdGVyL3NyYy9zZW50cnkvbGFuZy9qYXZhc2NyaXB0L3Byb2Nlc3Nvci5weSNMNjdcbiAqXG4gKiBAcGFyYW0gc3RyIEFuIG9iamVjdCB0aGF0IGNvbnRhaW5zIHNlcmlhbGl6YWJsZSB2YWx1ZXNcbiAqIEBwYXJhbSBtYXggTWF4aW11bSBudW1iZXIgb2YgY2hhcmFjdGVycyBpbiB0cnVuY2F0ZWQgc3RyaW5nXG4gKiBAcmV0dXJucyBzdHJpbmcgRW5jb2RlZFxuICovXG5mdW5jdGlvbiBzbmlwTGluZShsaW5lLCBjb2xubykge1xuICBsZXQgbmV3TGluZSA9IGxpbmU7XG4gIGNvbnN0IGxpbmVMZW5ndGggPSBuZXdMaW5lLmxlbmd0aDtcbiAgaWYgKGxpbmVMZW5ndGggPD0gMTUwKSB7XG4gICAgcmV0dXJuIG5ld0xpbmU7XG4gIH1cbiAgaWYgKGNvbG5vID4gbGluZUxlbmd0aCkge1xuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBuby1wYXJhbS1yZWFzc2lnblxuICAgIGNvbG5vID0gbGluZUxlbmd0aDtcbiAgfVxuXG4gIGxldCBzdGFydCA9IE1hdGgubWF4KGNvbG5vIC0gNjAsIDApO1xuICBpZiAoc3RhcnQgPCA1KSB7XG4gICAgc3RhcnQgPSAwO1xuICB9XG5cbiAgbGV0IGVuZCA9IE1hdGgubWluKHN0YXJ0ICsgMTQwLCBsaW5lTGVuZ3RoKTtcbiAgaWYgKGVuZCA+IGxpbmVMZW5ndGggLSA1KSB7XG4gICAgZW5kID0gbGluZUxlbmd0aDtcbiAgfVxuICBpZiAoZW5kID09PSBsaW5lTGVuZ3RoKSB7XG4gICAgc3RhcnQgPSBNYXRoLm1heChlbmQgLSAxNDAsIDApO1xuICB9XG5cbiAgbmV3TGluZSA9IG5ld0xpbmUuc2xpY2Uoc3RhcnQsIGVuZCk7XG4gIGlmIChzdGFydCA+IDApIHtcbiAgICBuZXdMaW5lID0gYCd7c25pcH0gJHtuZXdMaW5lfWA7XG4gIH1cbiAgaWYgKGVuZCA8IGxpbmVMZW5ndGgpIHtcbiAgICBuZXdMaW5lICs9ICcge3NuaXB9JztcbiAgfVxuXG4gIHJldHVybiBuZXdMaW5lO1xufVxuXG4vKipcbiAqIEpvaW4gdmFsdWVzIGluIGFycmF5XG4gKiBAcGFyYW0gaW5wdXQgYXJyYXkgb2YgdmFsdWVzIHRvIGJlIGpvaW5lZCB0b2dldGhlclxuICogQHBhcmFtIGRlbGltaXRlciBzdHJpbmcgdG8gYmUgcGxhY2VkIGluLWJldHdlZW4gdmFsdWVzXG4gKiBAcmV0dXJucyBKb2luZWQgdmFsdWVzXG4gKi9cbmZ1bmN0aW9uIHNhZmVKb2luKGlucHV0LCBkZWxpbWl0ZXIpIHtcbiAgaWYgKCFBcnJheS5pc0FycmF5KGlucHV0KSkge1xuICAgIHJldHVybiAnJztcbiAgfVxuXG4gIGNvbnN0IG91dHB1dCA9IFtdO1xuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L3ByZWZlci1mb3Itb2ZcbiAgZm9yIChsZXQgaSA9IDA7IGkgPCBpbnB1dC5sZW5ndGg7IGkrKykge1xuICAgIGNvbnN0IHZhbHVlID0gaW5wdXRbaV07XG4gICAgdHJ5IHtcbiAgICAgIC8vIFRoaXMgaXMgYSBoYWNrIHRvIGZpeCBhIFZ1ZTMtc3BlY2lmaWMgYnVnIHRoYXQgY2F1c2VzIGFuIGluZmluaXRlIGxvb3Agb2ZcbiAgICAgIC8vIGNvbnNvbGUgd2FybmluZ3MuIFRoaXMgaGFwcGVucyB3aGVuIGEgVnVlIHRlbXBsYXRlIGlzIHJlbmRlcmVkIHdpdGhcbiAgICAgIC8vIGFuIHVuZGVjbGFyZWQgdmFyaWFibGUsIHdoaWNoIHdlIHRyeSB0byBzdHJpbmdpZnksIHVsdGltYXRlbHkgY2F1c2luZ1xuICAgICAgLy8gVnVlIHRvIGlzc3VlIGFub3RoZXIgd2FybmluZyB3aGljaCByZXBlYXRzIGluZGVmaW5pdGVseS5cbiAgICAgIC8vIHNlZTogaHR0cHM6Ly9naXRodWIuY29tL2dldHNlbnRyeS9zZW50cnktamF2YXNjcmlwdC9wdWxsLzg5ODFcbiAgICAgIGlmIChpcy5pc1Z1ZVZpZXdNb2RlbCh2YWx1ZSkpIHtcbiAgICAgICAgb3V0cHV0LnB1c2goJ1tWdWVWaWV3TW9kZWxdJyk7XG4gICAgICB9IGVsc2Uge1xuICAgICAgICBvdXRwdXQucHVzaChTdHJpbmcodmFsdWUpKTtcbiAgICAgIH1cbiAgICB9IGNhdGNoIHtcbiAgICAgIG91dHB1dC5wdXNoKCdbdmFsdWUgY2Fubm90IGJlIHNlcmlhbGl6ZWRdJyk7XG4gICAgfVxuICB9XG5cbiAgcmV0dXJuIG91dHB1dC5qb2luKGRlbGltaXRlcik7XG59XG5cbi8qKlxuICogQ2hlY2tzIGlmIHRoZSBnaXZlbiB2YWx1ZSBtYXRjaGVzIGEgcmVnZXggb3Igc3RyaW5nXG4gKlxuICogQHBhcmFtIHZhbHVlIFRoZSBzdHJpbmcgdG8gdGVzdFxuICogQHBhcmFtIHBhdHRlcm4gRWl0aGVyIGEgcmVnZXggb3IgYSBzdHJpbmcgYWdhaW5zdCB3aGljaCBgdmFsdWVgIHdpbGwgYmUgbWF0Y2hlZFxuICogQHBhcmFtIHJlcXVpcmVFeGFjdFN0cmluZ01hdGNoIElmIHRydWUsIGB2YWx1ZWAgbXVzdCBtYXRjaCBgcGF0dGVybmAgZXhhY3RseS4gSWYgZmFsc2UsIGB2YWx1ZWAgd2lsbCBtYXRjaFxuICogYHBhdHRlcm5gIGlmIGl0IGNvbnRhaW5zIGBwYXR0ZXJuYC4gT25seSBhcHBsaWVzIHRvIHN0cmluZy10eXBlIHBhdHRlcm5zLlxuICovXG5mdW5jdGlvbiBpc01hdGNoaW5nUGF0dGVybihcbiAgdmFsdWUsXG4gIHBhdHRlcm4sXG4gIHJlcXVpcmVFeGFjdFN0cmluZ01hdGNoID0gZmFsc2UsXG4pIHtcbiAgaWYgKCFpcy5pc1N0cmluZyh2YWx1ZSkpIHtcbiAgICByZXR1cm4gZmFsc2U7XG4gIH1cblxuICBpZiAoaXMuaXNSZWdFeHAocGF0dGVybikpIHtcbiAgICByZXR1cm4gcGF0dGVybi50ZXN0KHZhbHVlKTtcbiAgfVxuICBpZiAoaXMuaXNTdHJpbmcocGF0dGVybikpIHtcbiAgICByZXR1cm4gcmVxdWlyZUV4YWN0U3RyaW5nTWF0Y2ggPyB2YWx1ZSA9PT0gcGF0dGVybiA6IHZhbHVlLmluY2x1ZGVzKHBhdHRlcm4pO1xuICB9XG5cbiAgcmV0dXJuIGZhbHNlO1xufVxuXG4vKipcbiAqIFRlc3QgdGhlIGdpdmVuIHN0cmluZyBhZ2FpbnN0IGFuIGFycmF5IG9mIHN0cmluZ3MgYW5kIHJlZ2V4ZXMuIEJ5IGRlZmF1bHQsIHN0cmluZyBtYXRjaGluZyBpcyBkb25lIG9uIGFcbiAqIHN1YnN0cmluZy1pbmNsdXNpb24gYmFzaXMgcmF0aGVyIHRoYW4gYSBzdHJpY3QgZXF1YWxpdHkgYmFzaXNcbiAqXG4gKiBAcGFyYW0gdGVzdFN0cmluZyBUaGUgc3RyaW5nIHRvIHRlc3RcbiAqIEBwYXJhbSBwYXR0ZXJucyBUaGUgcGF0dGVybnMgYWdhaW5zdCB3aGljaCB0byB0ZXN0IHRoZSBzdHJpbmdcbiAqIEBwYXJhbSByZXF1aXJlRXhhY3RTdHJpbmdNYXRjaCBJZiB0cnVlLCBgdGVzdFN0cmluZ2AgbXVzdCBtYXRjaCBvbmUgb2YgdGhlIGdpdmVuIHN0cmluZyBwYXR0ZXJucyBleGFjdGx5IGluIG9yZGVyIHRvXG4gKiBjb3VudC4gSWYgZmFsc2UsIGB0ZXN0U3RyaW5nYCB3aWxsIG1hdGNoIGEgc3RyaW5nIHBhdHRlcm4gaWYgaXQgY29udGFpbnMgdGhhdCBwYXR0ZXJuLlxuICogQHJldHVybnNcbiAqL1xuZnVuY3Rpb24gc3RyaW5nTWF0Y2hlc1NvbWVQYXR0ZXJuKFxuICB0ZXN0U3RyaW5nLFxuICBwYXR0ZXJucyA9IFtdLFxuICByZXF1aXJlRXhhY3RTdHJpbmdNYXRjaCA9IGZhbHNlLFxuKSB7XG4gIHJldHVybiBwYXR0ZXJucy5zb21lKHBhdHRlcm4gPT4gaXNNYXRjaGluZ1BhdHRlcm4odGVzdFN0cmluZywgcGF0dGVybiwgcmVxdWlyZUV4YWN0U3RyaW5nTWF0Y2gpKTtcbn1cblxuZXhwb3J0cy5pc01hdGNoaW5nUGF0dGVybiA9IGlzTWF0Y2hpbmdQYXR0ZXJuO1xuZXhwb3J0cy5zYWZlSm9pbiA9IHNhZmVKb2luO1xuZXhwb3J0cy5zbmlwTGluZSA9IHNuaXBMaW5lO1xuZXhwb3J0cy5zdHJpbmdNYXRjaGVzU29tZVBhdHRlcm4gPSBzdHJpbmdNYXRjaGVzU29tZVBhdHRlcm47XG5leHBvcnRzLnRydW5jYXRlID0gdHJ1bmNhdGU7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1zdHJpbmcuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/string.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/supports.js":
/*!******************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/supports.js ***!
  \******************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst debugBuild = __webpack_require__(/*! ../debug-build.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/debug-build.js\");\nconst debugLogger = __webpack_require__(/*! ./debug-logger.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst worldwide = __webpack_require__(/*! ./worldwide.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/worldwide.js\");\n\nconst WINDOW = worldwide.GLOBAL_OBJ ;\n\n/**\n * Tells whether current environment supports ErrorEvent objects\n * {@link supportsErrorEvent}.\n *\n * @returns Answer to the given question.\n */\nfunction supportsErrorEvent() {\n  try {\n    new ErrorEvent('');\n    return true;\n  } catch {\n    return false;\n  }\n}\n\n/**\n * Tells whether current environment supports DOMError objects\n * {@link supportsDOMError}.\n *\n * @returns Answer to the given question.\n */\nfunction supportsDOMError() {\n  try {\n    // Chrome: VM89:1 Uncaught TypeError: Failed to construct 'DOMError':\n    // 1 argument required, but only 0 present.\n    // @ts-expect-error It really needs 1 argument, not 0.\n    new DOMError('');\n    return true;\n  } catch {\n    return false;\n  }\n}\n\n/**\n * Tells whether current environment supports DOMException objects\n * {@link supportsDOMException}.\n *\n * @returns Answer to the given question.\n */\nfunction supportsDOMException() {\n  try {\n    new DOMException('');\n    return true;\n  } catch {\n    return false;\n  }\n}\n\n/**\n * Tells whether current environment supports History API\n * {@link supportsHistory}.\n *\n * @returns Answer to the given question.\n */\nfunction supportsHistory() {\n  return 'history' in WINDOW && !!WINDOW.history;\n}\n\n/**\n * Tells whether current environment supports Fetch API\n * {@link supportsFetch}.\n *\n * @returns Answer to the given question.\n * @deprecated This is no longer used and will be removed in a future major version.\n */\nconst supportsFetch = _isFetchSupported;\n\nfunction _isFetchSupported() {\n  if (!('fetch' in WINDOW)) {\n    return false;\n  }\n\n  try {\n    new Headers();\n    new Request('http://www.example.com');\n    new Response();\n    return true;\n  } catch {\n    return false;\n  }\n}\n\n/**\n * isNative checks if the given function is a native implementation\n */\n// eslint-disable-next-line @typescript-eslint/ban-types\nfunction isNativeFunction(func) {\n  return func && /^function\\s+\\w+\\(\\)\\s+\\{\\s+\\[native code\\]\\s+\\}$/.test(func.toString());\n}\n\n/**\n * Tells whether current environment supports Fetch API natively\n * {@link supportsNativeFetch}.\n *\n * @returns true if `window.fetch` is natively implemented, false otherwise\n */\nfunction supportsNativeFetch() {\n  if (typeof EdgeRuntime === 'string') {\n    return true;\n  }\n\n  if (!_isFetchSupported()) {\n    return false;\n  }\n\n  // Fast path to avoid DOM I/O\n  // eslint-disable-next-line @typescript-eslint/unbound-method\n  if (isNativeFunction(WINDOW.fetch)) {\n    return true;\n  }\n\n  // window.fetch is implemented, but is polyfilled or already wrapped (e.g: by a chrome extension)\n  // so create a \"pure\" iframe to see if that has native fetch\n  let result = false;\n  const doc = WINDOW.document;\n  // eslint-disable-next-line deprecation/deprecation\n  if (doc && typeof (doc.createElement ) === 'function') {\n    try {\n      const sandbox = doc.createElement('iframe');\n      sandbox.hidden = true;\n      doc.head.appendChild(sandbox);\n      if (sandbox.contentWindow?.fetch) {\n        // eslint-disable-next-line @typescript-eslint/unbound-method\n        result = isNativeFunction(sandbox.contentWindow.fetch);\n      }\n      doc.head.removeChild(sandbox);\n    } catch (err) {\n      debugBuild.DEBUG_BUILD && debugLogger.debug.warn('Could not create sandbox iframe for pure fetch check, bailing to window.fetch: ', err);\n    }\n  }\n\n  return result;\n}\n\n/**\n * Tells whether current environment supports ReportingObserver API\n * {@link supportsReportingObserver}.\n *\n * @returns Answer to the given question.\n */\nfunction supportsReportingObserver() {\n  return 'ReportingObserver' in WINDOW;\n}\n\n/**\n * Tells whether current environment supports Referrer Policy API\n * {@link supportsReferrerPolicy}.\n *\n * @returns Answer to the given question.\n * @deprecated This is no longer used and will be removed in a future major version.\n */\nfunction supportsReferrerPolicy() {\n  // Despite all stars in the sky saying that Edge supports old draft syntax, aka 'never', 'always', 'origin' and 'default'\n  // (see https://caniuse.com/#feat=referrer-policy),\n  // it doesn't. And it throws an exception instead of ignoring this parameter...\n  // REF: https://github.com/getsentry/raven-js/issues/1233\n\n  if (!_isFetchSupported()) {\n    return false;\n  }\n\n  try {\n    new Request('_', {\n      referrerPolicy: 'origin' ,\n    });\n    return true;\n  } catch {\n    return false;\n  }\n}\n\nexports.isNativeFunction = isNativeFunction;\nexports.supportsDOMError = supportsDOMError;\nexports.supportsDOMException = supportsDOMException;\nexports.supportsErrorEvent = supportsErrorEvent;\nexports.supportsFetch = supportsFetch;\nexports.supportsHistory = supportsHistory;\nexports.supportsNativeFetch = supportsNativeFetch;\nexports.supportsReferrerPolicy = supportsReferrerPolicy;\nexports.supportsReportingObserver = supportsReportingObserver;\n//# sourceMappingURL=supports.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9zdXBwb3J0cy5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxtQkFBbUIsbUJBQU8sQ0FBQyw0SEFBbUI7QUFDOUMsb0JBQW9CLG1CQUFPLENBQUMsbUlBQW1CO0FBQy9DLGtCQUFrQixtQkFBTyxDQUFDLDZIQUFnQjs7QUFFMUM7O0FBRUE7QUFDQTtBQUNBLElBQUkseUJBQXlCO0FBQzdCO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsSUFBSTtBQUNKO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsSUFBSSx1QkFBdUI7QUFDM0I7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxJQUFJO0FBQ0o7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQSxJQUFJLDJCQUEyQjtBQUMvQjtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLElBQUk7QUFDSjtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLElBQUksc0JBQXNCO0FBQzFCO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsSUFBSSxvQkFBb0I7QUFDeEI7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsSUFBSTtBQUNKO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsMENBQTBDLHVCQUF1QjtBQUNqRTs7QUFFQTtBQUNBO0FBQ0EsSUFBSSwwQkFBMEI7QUFDOUI7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsTUFBTTtBQUNOO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQSxJQUFJLGdDQUFnQztBQUNwQztBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLElBQUksNkJBQTZCO0FBQ2pDO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0EsS0FBSztBQUNMO0FBQ0EsSUFBSTtBQUNKO0FBQ0E7QUFDQTs7QUFFQSx3QkFBd0I7QUFDeEIsd0JBQXdCO0FBQ3hCLDRCQUE0QjtBQUM1QiwwQkFBMEI7QUFDMUIscUJBQXFCO0FBQ3JCLHVCQUF1QjtBQUN2QiwyQkFBMkI7QUFDM0IsOEJBQThCO0FBQzlCLGlDQUFpQztBQUNqQyIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3V0aWxzL3N1cHBvcnRzLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBkZWJ1Z0J1aWxkID0gcmVxdWlyZSgnLi4vZGVidWctYnVpbGQuanMnKTtcbmNvbnN0IGRlYnVnTG9nZ2VyID0gcmVxdWlyZSgnLi9kZWJ1Zy1sb2dnZXIuanMnKTtcbmNvbnN0IHdvcmxkd2lkZSA9IHJlcXVpcmUoJy4vd29ybGR3aWRlLmpzJyk7XG5cbmNvbnN0IFdJTkRPVyA9IHdvcmxkd2lkZS5HTE9CQUxfT0JKIDtcblxuLyoqXG4gKiBUZWxscyB3aGV0aGVyIGN1cnJlbnQgZW52aXJvbm1lbnQgc3VwcG9ydHMgRXJyb3JFdmVudCBvYmplY3RzXG4gKiB7QGxpbmsgc3VwcG9ydHNFcnJvckV2ZW50fS5cbiAqXG4gKiBAcmV0dXJucyBBbnN3ZXIgdG8gdGhlIGdpdmVuIHF1ZXN0aW9uLlxuICovXG5mdW5jdGlvbiBzdXBwb3J0c0Vycm9yRXZlbnQoKSB7XG4gIHRyeSB7XG4gICAgbmV3IEVycm9yRXZlbnQoJycpO1xuICAgIHJldHVybiB0cnVlO1xuICB9IGNhdGNoIHtcbiAgICByZXR1cm4gZmFsc2U7XG4gIH1cbn1cblxuLyoqXG4gKiBUZWxscyB3aGV0aGVyIGN1cnJlbnQgZW52aXJvbm1lbnQgc3VwcG9ydHMgRE9NRXJyb3Igb2JqZWN0c1xuICoge0BsaW5rIHN1cHBvcnRzRE9NRXJyb3J9LlxuICpcbiAqIEByZXR1cm5zIEFuc3dlciB0byB0aGUgZ2l2ZW4gcXVlc3Rpb24uXG4gKi9cbmZ1bmN0aW9uIHN1cHBvcnRzRE9NRXJyb3IoKSB7XG4gIHRyeSB7XG4gICAgLy8gQ2hyb21lOiBWTTg5OjEgVW5jYXVnaHQgVHlwZUVycm9yOiBGYWlsZWQgdG8gY29uc3RydWN0ICdET01FcnJvcic6XG4gICAgLy8gMSBhcmd1bWVudCByZXF1aXJlZCwgYnV0IG9ubHkgMCBwcmVzZW50LlxuICAgIC8vIEB0cy1leHBlY3QtZXJyb3IgSXQgcmVhbGx5IG5lZWRzIDEgYXJndW1lbnQsIG5vdCAwLlxuICAgIG5ldyBET01FcnJvcignJyk7XG4gICAgcmV0dXJuIHRydWU7XG4gIH0gY2F0Y2gge1xuICAgIHJldHVybiBmYWxzZTtcbiAgfVxufVxuXG4vKipcbiAqIFRlbGxzIHdoZXRoZXIgY3VycmVudCBlbnZpcm9ubWVudCBzdXBwb3J0cyBET01FeGNlcHRpb24gb2JqZWN0c1xuICoge0BsaW5rIHN1cHBvcnRzRE9NRXhjZXB0aW9ufS5cbiAqXG4gKiBAcmV0dXJucyBBbnN3ZXIgdG8gdGhlIGdpdmVuIHF1ZXN0aW9uLlxuICovXG5mdW5jdGlvbiBzdXBwb3J0c0RPTUV4Y2VwdGlvbigpIHtcbiAgdHJ5IHtcbiAgICBuZXcgRE9NRXhjZXB0aW9uKCcnKTtcbiAgICByZXR1cm4gdHJ1ZTtcbiAgfSBjYXRjaCB7XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG59XG5cbi8qKlxuICogVGVsbHMgd2hldGhlciBjdXJyZW50IGVudmlyb25tZW50IHN1cHBvcnRzIEhpc3RvcnkgQVBJXG4gKiB7QGxpbmsgc3VwcG9ydHNIaXN0b3J5fS5cbiAqXG4gKiBAcmV0dXJucyBBbnN3ZXIgdG8gdGhlIGdpdmVuIHF1ZXN0aW9uLlxuICovXG5mdW5jdGlvbiBzdXBwb3J0c0hpc3RvcnkoKSB7XG4gIHJldHVybiAnaGlzdG9yeScgaW4gV0lORE9XICYmICEhV0lORE9XLmhpc3Rvcnk7XG59XG5cbi8qKlxuICogVGVsbHMgd2hldGhlciBjdXJyZW50IGVudmlyb25tZW50IHN1cHBvcnRzIEZldGNoIEFQSVxuICoge0BsaW5rIHN1cHBvcnRzRmV0Y2h9LlxuICpcbiAqIEByZXR1cm5zIEFuc3dlciB0byB0aGUgZ2l2ZW4gcXVlc3Rpb24uXG4gKiBAZGVwcmVjYXRlZCBUaGlzIGlzIG5vIGxvbmdlciB1c2VkIGFuZCB3aWxsIGJlIHJlbW92ZWQgaW4gYSBmdXR1cmUgbWFqb3IgdmVyc2lvbi5cbiAqL1xuY29uc3Qgc3VwcG9ydHNGZXRjaCA9IF9pc0ZldGNoU3VwcG9ydGVkO1xuXG5mdW5jdGlvbiBfaXNGZXRjaFN1cHBvcnRlZCgpIHtcbiAgaWYgKCEoJ2ZldGNoJyBpbiBXSU5ET1cpKSB7XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG5cbiAgdHJ5IHtcbiAgICBuZXcgSGVhZGVycygpO1xuICAgIG5ldyBSZXF1ZXN0KCdodHRwOi8vd3d3LmV4YW1wbGUuY29tJyk7XG4gICAgbmV3IFJlc3BvbnNlKCk7XG4gICAgcmV0dXJuIHRydWU7XG4gIH0gY2F0Y2gge1xuICAgIHJldHVybiBmYWxzZTtcbiAgfVxufVxuXG4vKipcbiAqIGlzTmF0aXZlIGNoZWNrcyBpZiB0aGUgZ2l2ZW4gZnVuY3Rpb24gaXMgYSBuYXRpdmUgaW1wbGVtZW50YXRpb25cbiAqL1xuLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9iYW4tdHlwZXNcbmZ1bmN0aW9uIGlzTmF0aXZlRnVuY3Rpb24oZnVuYykge1xuICByZXR1cm4gZnVuYyAmJiAvXmZ1bmN0aW9uXFxzK1xcdytcXChcXClcXHMrXFx7XFxzK1xcW25hdGl2ZSBjb2RlXFxdXFxzK1xcfSQvLnRlc3QoZnVuYy50b1N0cmluZygpKTtcbn1cblxuLyoqXG4gKiBUZWxscyB3aGV0aGVyIGN1cnJlbnQgZW52aXJvbm1lbnQgc3VwcG9ydHMgRmV0Y2ggQVBJIG5hdGl2ZWx5XG4gKiB7QGxpbmsgc3VwcG9ydHNOYXRpdmVGZXRjaH0uXG4gKlxuICogQHJldHVybnMgdHJ1ZSBpZiBgd2luZG93LmZldGNoYCBpcyBuYXRpdmVseSBpbXBsZW1lbnRlZCwgZmFsc2Ugb3RoZXJ3aXNlXG4gKi9cbmZ1bmN0aW9uIHN1cHBvcnRzTmF0aXZlRmV0Y2goKSB7XG4gIGlmICh0eXBlb2YgRWRnZVJ1bnRpbWUgPT09ICdzdHJpbmcnKSB7XG4gICAgcmV0dXJuIHRydWU7XG4gIH1cblxuICBpZiAoIV9pc0ZldGNoU3VwcG9ydGVkKCkpIHtcbiAgICByZXR1cm4gZmFsc2U7XG4gIH1cblxuICAvLyBGYXN0IHBhdGggdG8gYXZvaWQgRE9NIEkvT1xuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L3VuYm91bmQtbWV0aG9kXG4gIGlmIChpc05hdGl2ZUZ1bmN0aW9uKFdJTkRPVy5mZXRjaCkpIHtcbiAgICByZXR1cm4gdHJ1ZTtcbiAgfVxuXG4gIC8vIHdpbmRvdy5mZXRjaCBpcyBpbXBsZW1lbnRlZCwgYnV0IGlzIHBvbHlmaWxsZWQgb3IgYWxyZWFkeSB3cmFwcGVkIChlLmc6IGJ5IGEgY2hyb21lIGV4dGVuc2lvbilcbiAgLy8gc28gY3JlYXRlIGEgXCJwdXJlXCIgaWZyYW1lIHRvIHNlZSBpZiB0aGF0IGhhcyBuYXRpdmUgZmV0Y2hcbiAgbGV0IHJlc3VsdCA9IGZhbHNlO1xuICBjb25zdCBkb2MgPSBXSU5ET1cuZG9jdW1lbnQ7XG4gIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBkZXByZWNhdGlvbi9kZXByZWNhdGlvblxuICBpZiAoZG9jICYmIHR5cGVvZiAoZG9jLmNyZWF0ZUVsZW1lbnQgKSA9PT0gJ2Z1bmN0aW9uJykge1xuICAgIHRyeSB7XG4gICAgICBjb25zdCBzYW5kYm94ID0gZG9jLmNyZWF0ZUVsZW1lbnQoJ2lmcmFtZScpO1xuICAgICAgc2FuZGJveC5oaWRkZW4gPSB0cnVlO1xuICAgICAgZG9jLmhlYWQuYXBwZW5kQ2hpbGQoc2FuZGJveCk7XG4gICAgICBpZiAoc2FuZGJveC5jb250ZW50V2luZG93Py5mZXRjaCkge1xuICAgICAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L3VuYm91bmQtbWV0aG9kXG4gICAgICAgIHJlc3VsdCA9IGlzTmF0aXZlRnVuY3Rpb24oc2FuZGJveC5jb250ZW50V2luZG93LmZldGNoKTtcbiAgICAgIH1cbiAgICAgIGRvYy5oZWFkLnJlbW92ZUNoaWxkKHNhbmRib3gpO1xuICAgIH0gY2F0Y2ggKGVycikge1xuICAgICAgZGVidWdCdWlsZC5ERUJVR19CVUlMRCAmJiBkZWJ1Z0xvZ2dlci5kZWJ1Zy53YXJuKCdDb3VsZCBub3QgY3JlYXRlIHNhbmRib3ggaWZyYW1lIGZvciBwdXJlIGZldGNoIGNoZWNrLCBiYWlsaW5nIHRvIHdpbmRvdy5mZXRjaDogJywgZXJyKTtcbiAgICB9XG4gIH1cblxuICByZXR1cm4gcmVzdWx0O1xufVxuXG4vKipcbiAqIFRlbGxzIHdoZXRoZXIgY3VycmVudCBlbnZpcm9ubWVudCBzdXBwb3J0cyBSZXBvcnRpbmdPYnNlcnZlciBBUElcbiAqIHtAbGluayBzdXBwb3J0c1JlcG9ydGluZ09ic2VydmVyfS5cbiAqXG4gKiBAcmV0dXJucyBBbnN3ZXIgdG8gdGhlIGdpdmVuIHF1ZXN0aW9uLlxuICovXG5mdW5jdGlvbiBzdXBwb3J0c1JlcG9ydGluZ09ic2VydmVyKCkge1xuICByZXR1cm4gJ1JlcG9ydGluZ09ic2VydmVyJyBpbiBXSU5ET1c7XG59XG5cbi8qKlxuICogVGVsbHMgd2hldGhlciBjdXJyZW50IGVudmlyb25tZW50IHN1cHBvcnRzIFJlZmVycmVyIFBvbGljeSBBUElcbiAqIHtAbGluayBzdXBwb3J0c1JlZmVycmVyUG9saWN5fS5cbiAqXG4gKiBAcmV0dXJucyBBbnN3ZXIgdG8gdGhlIGdpdmVuIHF1ZXN0aW9uLlxuICogQGRlcHJlY2F0ZWQgVGhpcyBpcyBubyBsb25nZXIgdXNlZCBhbmQgd2lsbCBiZSByZW1vdmVkIGluIGEgZnV0dXJlIG1ham9yIHZlcnNpb24uXG4gKi9cbmZ1bmN0aW9uIHN1cHBvcnRzUmVmZXJyZXJQb2xpY3koKSB7XG4gIC8vIERlc3BpdGUgYWxsIHN0YXJzIGluIHRoZSBza3kgc2F5aW5nIHRoYXQgRWRnZSBzdXBwb3J0cyBvbGQgZHJhZnQgc3ludGF4LCBha2EgJ25ldmVyJywgJ2Fsd2F5cycsICdvcmlnaW4nIGFuZCAnZGVmYXVsdCdcbiAgLy8gKHNlZSBodHRwczovL2Nhbml1c2UuY29tLyNmZWF0PXJlZmVycmVyLXBvbGljeSksXG4gIC8vIGl0IGRvZXNuJ3QuIEFuZCBpdCB0aHJvd3MgYW4gZXhjZXB0aW9uIGluc3RlYWQgb2YgaWdub3JpbmcgdGhpcyBwYXJhbWV0ZXIuLi5cbiAgLy8gUkVGOiBodHRwczovL2dpdGh1Yi5jb20vZ2V0c2VudHJ5L3JhdmVuLWpzL2lzc3Vlcy8xMjMzXG5cbiAgaWYgKCFfaXNGZXRjaFN1cHBvcnRlZCgpKSB7XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG5cbiAgdHJ5IHtcbiAgICBuZXcgUmVxdWVzdCgnXycsIHtcbiAgICAgIHJlZmVycmVyUG9saWN5OiAnb3JpZ2luJyAsXG4gICAgfSk7XG4gICAgcmV0dXJuIHRydWU7XG4gIH0gY2F0Y2gge1xuICAgIHJldHVybiBmYWxzZTtcbiAgfVxufVxuXG5leHBvcnRzLmlzTmF0aXZlRnVuY3Rpb24gPSBpc05hdGl2ZUZ1bmN0aW9uO1xuZXhwb3J0cy5zdXBwb3J0c0RPTUVycm9yID0gc3VwcG9ydHNET01FcnJvcjtcbmV4cG9ydHMuc3VwcG9ydHNET01FeGNlcHRpb24gPSBzdXBwb3J0c0RPTUV4Y2VwdGlvbjtcbmV4cG9ydHMuc3VwcG9ydHNFcnJvckV2ZW50ID0gc3VwcG9ydHNFcnJvckV2ZW50O1xuZXhwb3J0cy5zdXBwb3J0c0ZldGNoID0gc3VwcG9ydHNGZXRjaDtcbmV4cG9ydHMuc3VwcG9ydHNIaXN0b3J5ID0gc3VwcG9ydHNIaXN0b3J5O1xuZXhwb3J0cy5zdXBwb3J0c05hdGl2ZUZldGNoID0gc3VwcG9ydHNOYXRpdmVGZXRjaDtcbmV4cG9ydHMuc3VwcG9ydHNSZWZlcnJlclBvbGljeSA9IHN1cHBvcnRzUmVmZXJyZXJQb2xpY3k7XG5leHBvcnRzLnN1cHBvcnRzUmVwb3J0aW5nT2JzZXJ2ZXIgPSBzdXBwb3J0c1JlcG9ydGluZ09ic2VydmVyO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9c3VwcG9ydHMuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/supports.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/syncpromise.js":
/*!*********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/syncpromise.js ***!
  \*********************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst is = __webpack_require__(/*! ./is.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/is.js\");\n\n/* eslint-disable @typescript-eslint/no-explicit-any */\n\n/** SyncPromise internal states */\nconst STATE_PENDING = 0;\nconst STATE_RESOLVED = 1;\nconst STATE_REJECTED = 2;\n\n/**\n * Creates a resolved sync promise.\n *\n * @param value the value to resolve the promise with\n * @returns the resolved sync promise\n */\nfunction resolvedSyncPromise(value) {\n  return new SyncPromise(resolve => {\n    resolve(value);\n  });\n}\n\n/**\n * Creates a rejected sync promise.\n *\n * @param value the value to reject the promise with\n * @returns the rejected sync promise\n */\nfunction rejectedSyncPromise(reason) {\n  return new SyncPromise((_, reject) => {\n    reject(reason);\n  });\n}\n\n/**\n * Thenable class that behaves like a Promise and follows it's interface\n * but is not async internally\n */\nclass SyncPromise {\n\n   constructor(executor) {\n    this._state = STATE_PENDING;\n    this._handlers = [];\n\n    this._runExecutor(executor);\n  }\n\n  /** @inheritdoc */\n   then(\n    onfulfilled,\n    onrejected,\n  ) {\n    return new SyncPromise((resolve, reject) => {\n      this._handlers.push([\n        false,\n        result => {\n          if (!onfulfilled) {\n            // TODO: ¯\\_(ツ)_/¯\n            // TODO: FIXME\n            resolve(result );\n          } else {\n            try {\n              resolve(onfulfilled(result));\n            } catch (e) {\n              reject(e);\n            }\n          }\n        },\n        reason => {\n          if (!onrejected) {\n            reject(reason);\n          } else {\n            try {\n              resolve(onrejected(reason));\n            } catch (e) {\n              reject(e);\n            }\n          }\n        },\n      ]);\n      this._executeHandlers();\n    });\n  }\n\n  /** @inheritdoc */\n   catch(\n    onrejected,\n  ) {\n    return this.then(val => val, onrejected);\n  }\n\n  /** @inheritdoc */\n   finally(onfinally) {\n    return new SyncPromise((resolve, reject) => {\n      let val;\n      let isRejected;\n\n      return this.then(\n        value => {\n          isRejected = false;\n          val = value;\n          if (onfinally) {\n            onfinally();\n          }\n        },\n        reason => {\n          isRejected = true;\n          val = reason;\n          if (onfinally) {\n            onfinally();\n          }\n        },\n      ).then(() => {\n        if (isRejected) {\n          reject(val);\n          return;\n        }\n\n        resolve(val );\n      });\n    });\n  }\n\n  /** Excute the resolve/reject handlers. */\n   _executeHandlers() {\n    if (this._state === STATE_PENDING) {\n      return;\n    }\n\n    const cachedHandlers = this._handlers.slice();\n    this._handlers = [];\n\n    cachedHandlers.forEach(handler => {\n      if (handler[0]) {\n        return;\n      }\n\n      if (this._state === STATE_RESOLVED) {\n        handler[1](this._value );\n      }\n\n      if (this._state === STATE_REJECTED) {\n        handler[2](this._value);\n      }\n\n      handler[0] = true;\n    });\n  }\n\n  /** Run the executor for the SyncPromise. */\n   _runExecutor(executor) {\n    const setResult = (state, value) => {\n      if (this._state !== STATE_PENDING) {\n        return;\n      }\n\n      if (is.isThenable(value)) {\n        void (value ).then(resolve, reject);\n        return;\n      }\n\n      this._state = state;\n      this._value = value;\n\n      this._executeHandlers();\n    };\n\n    const resolve = (value) => {\n      setResult(STATE_RESOLVED, value);\n    };\n\n    const reject = (reason) => {\n      setResult(STATE_REJECTED, reason);\n    };\n\n    try {\n      executor(resolve, reject);\n    } catch (e) {\n      reject(e);\n    }\n  }\n}\n\nexports.SyncPromise = SyncPromise;\nexports.rejectedSyncPromise = rejectedSyncPromise;\nexports.resolvedSyncPromise = resolvedSyncPromise;\n//# sourceMappingURL=syncpromise.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9zeW5jcHJvbWlzZS5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RSxXQUFXLG1CQUFPLENBQUMsK0dBQVM7O0FBRTVCOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEdBQUc7QUFDSDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxHQUFHO0FBQ0g7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFlBQVk7QUFDWjtBQUNBO0FBQ0EsY0FBYztBQUNkO0FBQ0E7QUFDQTtBQUNBLFNBQVM7QUFDVDtBQUNBO0FBQ0E7QUFDQSxZQUFZO0FBQ1o7QUFDQTtBQUNBLGNBQWM7QUFDZDtBQUNBO0FBQ0E7QUFDQSxTQUFTO0FBQ1Q7QUFDQTtBQUNBLEtBQUs7QUFDTDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFNBQVM7QUFDVDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxTQUFTO0FBQ1Q7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBLE9BQU87QUFDUCxLQUFLO0FBQ0w7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQSxLQUFLO0FBQ0w7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQSxNQUFNO0FBQ047QUFDQTtBQUNBO0FBQ0E7O0FBRUEsbUJBQW1CO0FBQ25CLDJCQUEyQjtBQUMzQiwyQkFBMkI7QUFDM0IiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy9zeW5jcHJvbWlzZS5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3QgaXMgPSByZXF1aXJlKCcuL2lzLmpzJyk7XG5cbi8qIGVzbGludC1kaXNhYmxlIEB0eXBlc2NyaXB0LWVzbGludC9uby1leHBsaWNpdC1hbnkgKi9cblxuLyoqIFN5bmNQcm9taXNlIGludGVybmFsIHN0YXRlcyAqL1xuY29uc3QgU1RBVEVfUEVORElORyA9IDA7XG5jb25zdCBTVEFURV9SRVNPTFZFRCA9IDE7XG5jb25zdCBTVEFURV9SRUpFQ1RFRCA9IDI7XG5cbi8qKlxuICogQ3JlYXRlcyBhIHJlc29sdmVkIHN5bmMgcHJvbWlzZS5cbiAqXG4gKiBAcGFyYW0gdmFsdWUgdGhlIHZhbHVlIHRvIHJlc29sdmUgdGhlIHByb21pc2Ugd2l0aFxuICogQHJldHVybnMgdGhlIHJlc29sdmVkIHN5bmMgcHJvbWlzZVxuICovXG5mdW5jdGlvbiByZXNvbHZlZFN5bmNQcm9taXNlKHZhbHVlKSB7XG4gIHJldHVybiBuZXcgU3luY1Byb21pc2UocmVzb2x2ZSA9PiB7XG4gICAgcmVzb2x2ZSh2YWx1ZSk7XG4gIH0pO1xufVxuXG4vKipcbiAqIENyZWF0ZXMgYSByZWplY3RlZCBzeW5jIHByb21pc2UuXG4gKlxuICogQHBhcmFtIHZhbHVlIHRoZSB2YWx1ZSB0byByZWplY3QgdGhlIHByb21pc2Ugd2l0aFxuICogQHJldHVybnMgdGhlIHJlamVjdGVkIHN5bmMgcHJvbWlzZVxuICovXG5mdW5jdGlvbiByZWplY3RlZFN5bmNQcm9taXNlKHJlYXNvbikge1xuICByZXR1cm4gbmV3IFN5bmNQcm9taXNlKChfLCByZWplY3QpID0+IHtcbiAgICByZWplY3QocmVhc29uKTtcbiAgfSk7XG59XG5cbi8qKlxuICogVGhlbmFibGUgY2xhc3MgdGhhdCBiZWhhdmVzIGxpa2UgYSBQcm9taXNlIGFuZCBmb2xsb3dzIGl0J3MgaW50ZXJmYWNlXG4gKiBidXQgaXMgbm90IGFzeW5jIGludGVybmFsbHlcbiAqL1xuY2xhc3MgU3luY1Byb21pc2Uge1xuXG4gICBjb25zdHJ1Y3RvcihleGVjdXRvcikge1xuICAgIHRoaXMuX3N0YXRlID0gU1RBVEVfUEVORElORztcbiAgICB0aGlzLl9oYW5kbGVycyA9IFtdO1xuXG4gICAgdGhpcy5fcnVuRXhlY3V0b3IoZXhlY3V0b3IpO1xuICB9XG5cbiAgLyoqIEBpbmhlcml0ZG9jICovXG4gICB0aGVuKFxuICAgIG9uZnVsZmlsbGVkLFxuICAgIG9ucmVqZWN0ZWQsXG4gICkge1xuICAgIHJldHVybiBuZXcgU3luY1Byb21pc2UoKHJlc29sdmUsIHJlamVjdCkgPT4ge1xuICAgICAgdGhpcy5faGFuZGxlcnMucHVzaChbXG4gICAgICAgIGZhbHNlLFxuICAgICAgICByZXN1bHQgPT4ge1xuICAgICAgICAgIGlmICghb25mdWxmaWxsZWQpIHtcbiAgICAgICAgICAgIC8vIFRPRE86IMKvXFxfKOODhClfL8KvXG4gICAgICAgICAgICAvLyBUT0RPOiBGSVhNRVxuICAgICAgICAgICAgcmVzb2x2ZShyZXN1bHQgKTtcbiAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgdHJ5IHtcbiAgICAgICAgICAgICAgcmVzb2x2ZShvbmZ1bGZpbGxlZChyZXN1bHQpKTtcbiAgICAgICAgICAgIH0gY2F0Y2ggKGUpIHtcbiAgICAgICAgICAgICAgcmVqZWN0KGUpO1xuICAgICAgICAgICAgfVxuICAgICAgICAgIH1cbiAgICAgICAgfSxcbiAgICAgICAgcmVhc29uID0+IHtcbiAgICAgICAgICBpZiAoIW9ucmVqZWN0ZWQpIHtcbiAgICAgICAgICAgIHJlamVjdChyZWFzb24pO1xuICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICB0cnkge1xuICAgICAgICAgICAgICByZXNvbHZlKG9ucmVqZWN0ZWQocmVhc29uKSk7XG4gICAgICAgICAgICB9IGNhdGNoIChlKSB7XG4gICAgICAgICAgICAgIHJlamVjdChlKTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgICB9XG4gICAgICAgIH0sXG4gICAgICBdKTtcbiAgICAgIHRoaXMuX2V4ZWN1dGVIYW5kbGVycygpO1xuICAgIH0pO1xuICB9XG5cbiAgLyoqIEBpbmhlcml0ZG9jICovXG4gICBjYXRjaChcbiAgICBvbnJlamVjdGVkLFxuICApIHtcbiAgICByZXR1cm4gdGhpcy50aGVuKHZhbCA9PiB2YWwsIG9ucmVqZWN0ZWQpO1xuICB9XG5cbiAgLyoqIEBpbmhlcml0ZG9jICovXG4gICBmaW5hbGx5KG9uZmluYWxseSkge1xuICAgIHJldHVybiBuZXcgU3luY1Byb21pc2UoKHJlc29sdmUsIHJlamVjdCkgPT4ge1xuICAgICAgbGV0IHZhbDtcbiAgICAgIGxldCBpc1JlamVjdGVkO1xuXG4gICAgICByZXR1cm4gdGhpcy50aGVuKFxuICAgICAgICB2YWx1ZSA9PiB7XG4gICAgICAgICAgaXNSZWplY3RlZCA9IGZhbHNlO1xuICAgICAgICAgIHZhbCA9IHZhbHVlO1xuICAgICAgICAgIGlmIChvbmZpbmFsbHkpIHtcbiAgICAgICAgICAgIG9uZmluYWxseSgpO1xuICAgICAgICAgIH1cbiAgICAgICAgfSxcbiAgICAgICAgcmVhc29uID0+IHtcbiAgICAgICAgICBpc1JlamVjdGVkID0gdHJ1ZTtcbiAgICAgICAgICB2YWwgPSByZWFzb247XG4gICAgICAgICAgaWYgKG9uZmluYWxseSkge1xuICAgICAgICAgICAgb25maW5hbGx5KCk7XG4gICAgICAgICAgfVxuICAgICAgICB9LFxuICAgICAgKS50aGVuKCgpID0+IHtcbiAgICAgICAgaWYgKGlzUmVqZWN0ZWQpIHtcbiAgICAgICAgICByZWplY3QodmFsKTtcbiAgICAgICAgICByZXR1cm47XG4gICAgICAgIH1cblxuICAgICAgICByZXNvbHZlKHZhbCApO1xuICAgICAgfSk7XG4gICAgfSk7XG4gIH1cblxuICAvKiogRXhjdXRlIHRoZSByZXNvbHZlL3JlamVjdCBoYW5kbGVycy4gKi9cbiAgIF9leGVjdXRlSGFuZGxlcnMoKSB7XG4gICAgaWYgKHRoaXMuX3N0YXRlID09PSBTVEFURV9QRU5ESU5HKSB7XG4gICAgICByZXR1cm47XG4gICAgfVxuXG4gICAgY29uc3QgY2FjaGVkSGFuZGxlcnMgPSB0aGlzLl9oYW5kbGVycy5zbGljZSgpO1xuICAgIHRoaXMuX2hhbmRsZXJzID0gW107XG5cbiAgICBjYWNoZWRIYW5kbGVycy5mb3JFYWNoKGhhbmRsZXIgPT4ge1xuICAgICAgaWYgKGhhbmRsZXJbMF0pIHtcbiAgICAgICAgcmV0dXJuO1xuICAgICAgfVxuXG4gICAgICBpZiAodGhpcy5fc3RhdGUgPT09IFNUQVRFX1JFU09MVkVEKSB7XG4gICAgICAgIGhhbmRsZXJbMV0odGhpcy5fdmFsdWUgKTtcbiAgICAgIH1cblxuICAgICAgaWYgKHRoaXMuX3N0YXRlID09PSBTVEFURV9SRUpFQ1RFRCkge1xuICAgICAgICBoYW5kbGVyWzJdKHRoaXMuX3ZhbHVlKTtcbiAgICAgIH1cblxuICAgICAgaGFuZGxlclswXSA9IHRydWU7XG4gICAgfSk7XG4gIH1cblxuICAvKiogUnVuIHRoZSBleGVjdXRvciBmb3IgdGhlIFN5bmNQcm9taXNlLiAqL1xuICAgX3J1bkV4ZWN1dG9yKGV4ZWN1dG9yKSB7XG4gICAgY29uc3Qgc2V0UmVzdWx0ID0gKHN0YXRlLCB2YWx1ZSkgPT4ge1xuICAgICAgaWYgKHRoaXMuX3N0YXRlICE9PSBTVEFURV9QRU5ESU5HKSB7XG4gICAgICAgIHJldHVybjtcbiAgICAgIH1cblxuICAgICAgaWYgKGlzLmlzVGhlbmFibGUodmFsdWUpKSB7XG4gICAgICAgIHZvaWQgKHZhbHVlICkudGhlbihyZXNvbHZlLCByZWplY3QpO1xuICAgICAgICByZXR1cm47XG4gICAgICB9XG5cbiAgICAgIHRoaXMuX3N0YXRlID0gc3RhdGU7XG4gICAgICB0aGlzLl92YWx1ZSA9IHZhbHVlO1xuXG4gICAgICB0aGlzLl9leGVjdXRlSGFuZGxlcnMoKTtcbiAgICB9O1xuXG4gICAgY29uc3QgcmVzb2x2ZSA9ICh2YWx1ZSkgPT4ge1xuICAgICAgc2V0UmVzdWx0KFNUQVRFX1JFU09MVkVELCB2YWx1ZSk7XG4gICAgfTtcblxuICAgIGNvbnN0IHJlamVjdCA9IChyZWFzb24pID0+IHtcbiAgICAgIHNldFJlc3VsdChTVEFURV9SRUpFQ1RFRCwgcmVhc29uKTtcbiAgICB9O1xuXG4gICAgdHJ5IHtcbiAgICAgIGV4ZWN1dG9yKHJlc29sdmUsIHJlamVjdCk7XG4gICAgfSBjYXRjaCAoZSkge1xuICAgICAgcmVqZWN0KGUpO1xuICAgIH1cbiAgfVxufVxuXG5leHBvcnRzLlN5bmNQcm9taXNlID0gU3luY1Byb21pc2U7XG5leHBvcnRzLnJlamVjdGVkU3luY1Byb21pc2UgPSByZWplY3RlZFN5bmNQcm9taXNlO1xuZXhwb3J0cy5yZXNvbHZlZFN5bmNQcm9taXNlID0gcmVzb2x2ZWRTeW5jUHJvbWlzZTtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPXN5bmNwcm9taXNlLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/syncpromise.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/time.js":
/*!**************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/time.js ***!
  \**************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst worldwide = __webpack_require__(/*! ./worldwide.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/worldwide.js\");\n\nconst ONE_SECOND_IN_MS = 1000;\n\n/**\n * A partial definition of the [Performance Web API]{@link https://developer.mozilla.org/en-US/docs/Web/API/Performance}\n * for accessing a high-resolution monotonic clock.\n */\n\n/**\n * Returns a timestamp in seconds since the UNIX epoch using the Date API.\n */\nfunction dateTimestampInSeconds() {\n  return Date.now() / ONE_SECOND_IN_MS;\n}\n\n/**\n * Returns a wrapper around the native Performance API browser implementation, or undefined for browsers that do not\n * support the API.\n *\n * Wrapping the native API works around differences in behavior from different browsers.\n */\nfunction createUnixTimestampInSecondsFunc() {\n  const { performance } = worldwide.GLOBAL_OBJ ;\n  // Some browser and environments don't have a performance or timeOrigin, so we fallback to\n  // using Date.now() to compute the starting time.\n  if (!performance?.now || !performance.timeOrigin) {\n    return dateTimestampInSeconds;\n  }\n\n  const timeOrigin = performance.timeOrigin;\n\n  // performance.now() is a monotonic clock, which means it starts at 0 when the process begins. To get the current\n  // wall clock time (actual UNIX timestamp), we need to add the starting time origin and the current time elapsed.\n  //\n  // TODO: This does not account for the case where the monotonic clock that powers performance.now() drifts from the\n  // wall clock time, which causes the returned timestamp to be inaccurate. We should investigate how to detect and\n  // correct for this.\n  // See: https://github.com/getsentry/sentry-javascript/issues/2590\n  // See: https://github.com/mdn/content/issues/4713\n  // See: https://dev.to/noamr/when-a-millisecond-is-not-a-millisecond-3h6\n  return () => {\n    return (timeOrigin + performance.now()) / ONE_SECOND_IN_MS;\n  };\n}\n\nlet _cachedTimestampInSeconds;\n\n/**\n * Returns a timestamp in seconds since the UNIX epoch using either the Performance or Date APIs, depending on the\n * availability of the Performance API.\n *\n * BUG: Note that because of how browsers implement the Performance API, the clock might stop when the computer is\n * asleep. This creates a skew between `dateTimestampInSeconds` and `timestampInSeconds`. The\n * skew can grow to arbitrary amounts like days, weeks or months.\n * See https://github.com/getsentry/sentry-javascript/issues/2590.\n */\nfunction timestampInSeconds() {\n  // We store this in a closure so that we don't have to create a new function every time this is called.\n  const func = _cachedTimestampInSeconds ?? (_cachedTimestampInSeconds = createUnixTimestampInSecondsFunc());\n  return func();\n}\n\n/**\n * Cached result of getBrowserTimeOrigin.\n */\nlet cachedTimeOrigin;\n\n/**\n * Gets the time origin and the mode used to determine it.\n */\nfunction getBrowserTimeOrigin() {\n  // Unfortunately browsers may report an inaccurate time origin data, through either performance.timeOrigin or\n  // performance.timing.navigationStart, which results in poor results in performance data. We only treat time origin\n  // data as reliable if they are within a reasonable threshold of the current time.\n\n  const { performance } = worldwide.GLOBAL_OBJ ;\n  if (!performance?.now) {\n    return [undefined, 'none'];\n  }\n\n  const threshold = 3600 * 1000;\n  const performanceNow = performance.now();\n  const dateNow = Date.now();\n\n  // if timeOrigin isn't available set delta to threshold so it isn't used\n  const timeOriginDelta = performance.timeOrigin\n    ? Math.abs(performance.timeOrigin + performanceNow - dateNow)\n    : threshold;\n  const timeOriginIsReliable = timeOriginDelta < threshold;\n\n  // While performance.timing.navigationStart is deprecated in favor of performance.timeOrigin, performance.timeOrigin\n  // is not as widely supported. Namely, performance.timeOrigin is undefined in Safari as of writing.\n  // Also as of writing, performance.timing is not available in Web Workers in mainstream browsers, so it is not always\n  // a valid fallback. In the absence of an initial time provided by the browser, fallback to the current time from the\n  // Date API.\n  // eslint-disable-next-line deprecation/deprecation\n  const navigationStart = performance.timing?.navigationStart;\n  const hasNavigationStart = typeof navigationStart === 'number';\n  // if navigationStart isn't available set delta to threshold so it isn't used\n  const navigationStartDelta = hasNavigationStart ? Math.abs(navigationStart + performanceNow - dateNow) : threshold;\n  const navigationStartIsReliable = navigationStartDelta < threshold;\n\n  if (timeOriginIsReliable || navigationStartIsReliable) {\n    // Use the more reliable time origin\n    if (timeOriginDelta <= navigationStartDelta) {\n      return [performance.timeOrigin, 'timeOrigin'];\n    } else {\n      return [navigationStart, 'navigationStart'];\n    }\n  }\n\n  // Either both timeOrigin and navigationStart are skewed or neither is available, fallback to Date.\n  return [dateNow, 'dateNow'];\n}\n\n/**\n * The number of milliseconds since the UNIX epoch. This value is only usable in a browser, and only when the\n * performance API is available.\n */\nfunction browserPerformanceTimeOrigin() {\n  if (!cachedTimeOrigin) {\n    cachedTimeOrigin = getBrowserTimeOrigin();\n  }\n\n  return cachedTimeOrigin[0];\n}\n\nexports.browserPerformanceTimeOrigin = browserPerformanceTimeOrigin;\nexports.dateTimestampInSeconds = dateTimestampInSeconds;\nexports.timestampInSeconds = timestampInSeconds;\n//# sourceMappingURL=time.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy90aW1lLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLGtCQUFrQixtQkFBTyxDQUFDLDZIQUFnQjs7QUFFMUM7O0FBRUE7QUFDQSxxREFBcUQ7QUFDckQ7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxVQUFVLGNBQWM7QUFDeEI7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLFVBQVUsY0FBYztBQUN4QjtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLE1BQU07QUFDTjtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQSxvQ0FBb0M7QUFDcEMsOEJBQThCO0FBQzlCLDBCQUEwQjtBQUMxQiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3V0aWxzL3RpbWUuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IHdvcmxkd2lkZSA9IHJlcXVpcmUoJy4vd29ybGR3aWRlLmpzJyk7XG5cbmNvbnN0IE9ORV9TRUNPTkRfSU5fTVMgPSAxMDAwO1xuXG4vKipcbiAqIEEgcGFydGlhbCBkZWZpbml0aW9uIG9mIHRoZSBbUGVyZm9ybWFuY2UgV2ViIEFQSV17QGxpbmsgaHR0cHM6Ly9kZXZlbG9wZXIubW96aWxsYS5vcmcvZW4tVVMvZG9jcy9XZWIvQVBJL1BlcmZvcm1hbmNlfVxuICogZm9yIGFjY2Vzc2luZyBhIGhpZ2gtcmVzb2x1dGlvbiBtb25vdG9uaWMgY2xvY2suXG4gKi9cblxuLyoqXG4gKiBSZXR1cm5zIGEgdGltZXN0YW1wIGluIHNlY29uZHMgc2luY2UgdGhlIFVOSVggZXBvY2ggdXNpbmcgdGhlIERhdGUgQVBJLlxuICovXG5mdW5jdGlvbiBkYXRlVGltZXN0YW1wSW5TZWNvbmRzKCkge1xuICByZXR1cm4gRGF0ZS5ub3coKSAvIE9ORV9TRUNPTkRfSU5fTVM7XG59XG5cbi8qKlxuICogUmV0dXJucyBhIHdyYXBwZXIgYXJvdW5kIHRoZSBuYXRpdmUgUGVyZm9ybWFuY2UgQVBJIGJyb3dzZXIgaW1wbGVtZW50YXRpb24sIG9yIHVuZGVmaW5lZCBmb3IgYnJvd3NlcnMgdGhhdCBkbyBub3RcbiAqIHN1cHBvcnQgdGhlIEFQSS5cbiAqXG4gKiBXcmFwcGluZyB0aGUgbmF0aXZlIEFQSSB3b3JrcyBhcm91bmQgZGlmZmVyZW5jZXMgaW4gYmVoYXZpb3IgZnJvbSBkaWZmZXJlbnQgYnJvd3NlcnMuXG4gKi9cbmZ1bmN0aW9uIGNyZWF0ZVVuaXhUaW1lc3RhbXBJblNlY29uZHNGdW5jKCkge1xuICBjb25zdCB7IHBlcmZvcm1hbmNlIH0gPSB3b3JsZHdpZGUuR0xPQkFMX09CSiA7XG4gIC8vIFNvbWUgYnJvd3NlciBhbmQgZW52aXJvbm1lbnRzIGRvbid0IGhhdmUgYSBwZXJmb3JtYW5jZSBvciB0aW1lT3JpZ2luLCBzbyB3ZSBmYWxsYmFjayB0b1xuICAvLyB1c2luZyBEYXRlLm5vdygpIHRvIGNvbXB1dGUgdGhlIHN0YXJ0aW5nIHRpbWUuXG4gIGlmICghcGVyZm9ybWFuY2U/Lm5vdyB8fCAhcGVyZm9ybWFuY2UudGltZU9yaWdpbikge1xuICAgIHJldHVybiBkYXRlVGltZXN0YW1wSW5TZWNvbmRzO1xuICB9XG5cbiAgY29uc3QgdGltZU9yaWdpbiA9IHBlcmZvcm1hbmNlLnRpbWVPcmlnaW47XG5cbiAgLy8gcGVyZm9ybWFuY2Uubm93KCkgaXMgYSBtb25vdG9uaWMgY2xvY2ssIHdoaWNoIG1lYW5zIGl0IHN0YXJ0cyBhdCAwIHdoZW4gdGhlIHByb2Nlc3MgYmVnaW5zLiBUbyBnZXQgdGhlIGN1cnJlbnRcbiAgLy8gd2FsbCBjbG9jayB0aW1lIChhY3R1YWwgVU5JWCB0aW1lc3RhbXApLCB3ZSBuZWVkIHRvIGFkZCB0aGUgc3RhcnRpbmcgdGltZSBvcmlnaW4gYW5kIHRoZSBjdXJyZW50IHRpbWUgZWxhcHNlZC5cbiAgLy9cbiAgLy8gVE9ETzogVGhpcyBkb2VzIG5vdCBhY2NvdW50IGZvciB0aGUgY2FzZSB3aGVyZSB0aGUgbW9ub3RvbmljIGNsb2NrIHRoYXQgcG93ZXJzIHBlcmZvcm1hbmNlLm5vdygpIGRyaWZ0cyBmcm9tIHRoZVxuICAvLyB3YWxsIGNsb2NrIHRpbWUsIHdoaWNoIGNhdXNlcyB0aGUgcmV0dXJuZWQgdGltZXN0YW1wIHRvIGJlIGluYWNjdXJhdGUuIFdlIHNob3VsZCBpbnZlc3RpZ2F0ZSBob3cgdG8gZGV0ZWN0IGFuZFxuICAvLyBjb3JyZWN0IGZvciB0aGlzLlxuICAvLyBTZWU6IGh0dHBzOi8vZ2l0aHViLmNvbS9nZXRzZW50cnkvc2VudHJ5LWphdmFzY3JpcHQvaXNzdWVzLzI1OTBcbiAgLy8gU2VlOiBodHRwczovL2dpdGh1Yi5jb20vbWRuL2NvbnRlbnQvaXNzdWVzLzQ3MTNcbiAgLy8gU2VlOiBodHRwczovL2Rldi50by9ub2Ftci93aGVuLWEtbWlsbGlzZWNvbmQtaXMtbm90LWEtbWlsbGlzZWNvbmQtM2g2XG4gIHJldHVybiAoKSA9PiB7XG4gICAgcmV0dXJuICh0aW1lT3JpZ2luICsgcGVyZm9ybWFuY2Uubm93KCkpIC8gT05FX1NFQ09ORF9JTl9NUztcbiAgfTtcbn1cblxubGV0IF9jYWNoZWRUaW1lc3RhbXBJblNlY29uZHM7XG5cbi8qKlxuICogUmV0dXJucyBhIHRpbWVzdGFtcCBpbiBzZWNvbmRzIHNpbmNlIHRoZSBVTklYIGVwb2NoIHVzaW5nIGVpdGhlciB0aGUgUGVyZm9ybWFuY2Ugb3IgRGF0ZSBBUElzLCBkZXBlbmRpbmcgb24gdGhlXG4gKiBhdmFpbGFiaWxpdHkgb2YgdGhlIFBlcmZvcm1hbmNlIEFQSS5cbiAqXG4gKiBCVUc6IE5vdGUgdGhhdCBiZWNhdXNlIG9mIGhvdyBicm93c2VycyBpbXBsZW1lbnQgdGhlIFBlcmZvcm1hbmNlIEFQSSwgdGhlIGNsb2NrIG1pZ2h0IHN0b3Agd2hlbiB0aGUgY29tcHV0ZXIgaXNcbiAqIGFzbGVlcC4gVGhpcyBjcmVhdGVzIGEgc2tldyBiZXR3ZWVuIGBkYXRlVGltZXN0YW1wSW5TZWNvbmRzYCBhbmQgYHRpbWVzdGFtcEluU2Vjb25kc2AuIFRoZVxuICogc2tldyBjYW4gZ3JvdyB0byBhcmJpdHJhcnkgYW1vdW50cyBsaWtlIGRheXMsIHdlZWtzIG9yIG1vbnRocy5cbiAqIFNlZSBodHRwczovL2dpdGh1Yi5jb20vZ2V0c2VudHJ5L3NlbnRyeS1qYXZhc2NyaXB0L2lzc3Vlcy8yNTkwLlxuICovXG5mdW5jdGlvbiB0aW1lc3RhbXBJblNlY29uZHMoKSB7XG4gIC8vIFdlIHN0b3JlIHRoaXMgaW4gYSBjbG9zdXJlIHNvIHRoYXQgd2UgZG9uJ3QgaGF2ZSB0byBjcmVhdGUgYSBuZXcgZnVuY3Rpb24gZXZlcnkgdGltZSB0aGlzIGlzIGNhbGxlZC5cbiAgY29uc3QgZnVuYyA9IF9jYWNoZWRUaW1lc3RhbXBJblNlY29uZHMgPz8gKF9jYWNoZWRUaW1lc3RhbXBJblNlY29uZHMgPSBjcmVhdGVVbml4VGltZXN0YW1wSW5TZWNvbmRzRnVuYygpKTtcbiAgcmV0dXJuIGZ1bmMoKTtcbn1cblxuLyoqXG4gKiBDYWNoZWQgcmVzdWx0IG9mIGdldEJyb3dzZXJUaW1lT3JpZ2luLlxuICovXG5sZXQgY2FjaGVkVGltZU9yaWdpbjtcblxuLyoqXG4gKiBHZXRzIHRoZSB0aW1lIG9yaWdpbiBhbmQgdGhlIG1vZGUgdXNlZCB0byBkZXRlcm1pbmUgaXQuXG4gKi9cbmZ1bmN0aW9uIGdldEJyb3dzZXJUaW1lT3JpZ2luKCkge1xuICAvLyBVbmZvcnR1bmF0ZWx5IGJyb3dzZXJzIG1heSByZXBvcnQgYW4gaW5hY2N1cmF0ZSB0aW1lIG9yaWdpbiBkYXRhLCB0aHJvdWdoIGVpdGhlciBwZXJmb3JtYW5jZS50aW1lT3JpZ2luIG9yXG4gIC8vIHBlcmZvcm1hbmNlLnRpbWluZy5uYXZpZ2F0aW9uU3RhcnQsIHdoaWNoIHJlc3VsdHMgaW4gcG9vciByZXN1bHRzIGluIHBlcmZvcm1hbmNlIGRhdGEuIFdlIG9ubHkgdHJlYXQgdGltZSBvcmlnaW5cbiAgLy8gZGF0YSBhcyByZWxpYWJsZSBpZiB0aGV5IGFyZSB3aXRoaW4gYSByZWFzb25hYmxlIHRocmVzaG9sZCBvZiB0aGUgY3VycmVudCB0aW1lLlxuXG4gIGNvbnN0IHsgcGVyZm9ybWFuY2UgfSA9IHdvcmxkd2lkZS5HTE9CQUxfT0JKIDtcbiAgaWYgKCFwZXJmb3JtYW5jZT8ubm93KSB7XG4gICAgcmV0dXJuIFt1bmRlZmluZWQsICdub25lJ107XG4gIH1cblxuICBjb25zdCB0aHJlc2hvbGQgPSAzNjAwICogMTAwMDtcbiAgY29uc3QgcGVyZm9ybWFuY2VOb3cgPSBwZXJmb3JtYW5jZS5ub3coKTtcbiAgY29uc3QgZGF0ZU5vdyA9IERhdGUubm93KCk7XG5cbiAgLy8gaWYgdGltZU9yaWdpbiBpc24ndCBhdmFpbGFibGUgc2V0IGRlbHRhIHRvIHRocmVzaG9sZCBzbyBpdCBpc24ndCB1c2VkXG4gIGNvbnN0IHRpbWVPcmlnaW5EZWx0YSA9IHBlcmZvcm1hbmNlLnRpbWVPcmlnaW5cbiAgICA/IE1hdGguYWJzKHBlcmZvcm1hbmNlLnRpbWVPcmlnaW4gKyBwZXJmb3JtYW5jZU5vdyAtIGRhdGVOb3cpXG4gICAgOiB0aHJlc2hvbGQ7XG4gIGNvbnN0IHRpbWVPcmlnaW5Jc1JlbGlhYmxlID0gdGltZU9yaWdpbkRlbHRhIDwgdGhyZXNob2xkO1xuXG4gIC8vIFdoaWxlIHBlcmZvcm1hbmNlLnRpbWluZy5uYXZpZ2F0aW9uU3RhcnQgaXMgZGVwcmVjYXRlZCBpbiBmYXZvciBvZiBwZXJmb3JtYW5jZS50aW1lT3JpZ2luLCBwZXJmb3JtYW5jZS50aW1lT3JpZ2luXG4gIC8vIGlzIG5vdCBhcyB3aWRlbHkgc3VwcG9ydGVkLiBOYW1lbHksIHBlcmZvcm1hbmNlLnRpbWVPcmlnaW4gaXMgdW5kZWZpbmVkIGluIFNhZmFyaSBhcyBvZiB3cml0aW5nLlxuICAvLyBBbHNvIGFzIG9mIHdyaXRpbmcsIHBlcmZvcm1hbmNlLnRpbWluZyBpcyBub3QgYXZhaWxhYmxlIGluIFdlYiBXb3JrZXJzIGluIG1haW5zdHJlYW0gYnJvd3NlcnMsIHNvIGl0IGlzIG5vdCBhbHdheXNcbiAgLy8gYSB2YWxpZCBmYWxsYmFjay4gSW4gdGhlIGFic2VuY2Ugb2YgYW4gaW5pdGlhbCB0aW1lIHByb3ZpZGVkIGJ5IHRoZSBicm93c2VyLCBmYWxsYmFjayB0byB0aGUgY3VycmVudCB0aW1lIGZyb20gdGhlXG4gIC8vIERhdGUgQVBJLlxuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgZGVwcmVjYXRpb24vZGVwcmVjYXRpb25cbiAgY29uc3QgbmF2aWdhdGlvblN0YXJ0ID0gcGVyZm9ybWFuY2UudGltaW5nPy5uYXZpZ2F0aW9uU3RhcnQ7XG4gIGNvbnN0IGhhc05hdmlnYXRpb25TdGFydCA9IHR5cGVvZiBuYXZpZ2F0aW9uU3RhcnQgPT09ICdudW1iZXInO1xuICAvLyBpZiBuYXZpZ2F0aW9uU3RhcnQgaXNuJ3QgYXZhaWxhYmxlIHNldCBkZWx0YSB0byB0aHJlc2hvbGQgc28gaXQgaXNuJ3QgdXNlZFxuICBjb25zdCBuYXZpZ2F0aW9uU3RhcnREZWx0YSA9IGhhc05hdmlnYXRpb25TdGFydCA/IE1hdGguYWJzKG5hdmlnYXRpb25TdGFydCArIHBlcmZvcm1hbmNlTm93IC0gZGF0ZU5vdykgOiB0aHJlc2hvbGQ7XG4gIGNvbnN0IG5hdmlnYXRpb25TdGFydElzUmVsaWFibGUgPSBuYXZpZ2F0aW9uU3RhcnREZWx0YSA8IHRocmVzaG9sZDtcblxuICBpZiAodGltZU9yaWdpbklzUmVsaWFibGUgfHwgbmF2aWdhdGlvblN0YXJ0SXNSZWxpYWJsZSkge1xuICAgIC8vIFVzZSB0aGUgbW9yZSByZWxpYWJsZSB0aW1lIG9yaWdpblxuICAgIGlmICh0aW1lT3JpZ2luRGVsdGEgPD0gbmF2aWdhdGlvblN0YXJ0RGVsdGEpIHtcbiAgICAgIHJldHVybiBbcGVyZm9ybWFuY2UudGltZU9yaWdpbiwgJ3RpbWVPcmlnaW4nXTtcbiAgICB9IGVsc2Uge1xuICAgICAgcmV0dXJuIFtuYXZpZ2F0aW9uU3RhcnQsICduYXZpZ2F0aW9uU3RhcnQnXTtcbiAgICB9XG4gIH1cblxuICAvLyBFaXRoZXIgYm90aCB0aW1lT3JpZ2luIGFuZCBuYXZpZ2F0aW9uU3RhcnQgYXJlIHNrZXdlZCBvciBuZWl0aGVyIGlzIGF2YWlsYWJsZSwgZmFsbGJhY2sgdG8gRGF0ZS5cbiAgcmV0dXJuIFtkYXRlTm93LCAnZGF0ZU5vdyddO1xufVxuXG4vKipcbiAqIFRoZSBudW1iZXIgb2YgbWlsbGlzZWNvbmRzIHNpbmNlIHRoZSBVTklYIGVwb2NoLiBUaGlzIHZhbHVlIGlzIG9ubHkgdXNhYmxlIGluIGEgYnJvd3NlciwgYW5kIG9ubHkgd2hlbiB0aGVcbiAqIHBlcmZvcm1hbmNlIEFQSSBpcyBhdmFpbGFibGUuXG4gKi9cbmZ1bmN0aW9uIGJyb3dzZXJQZXJmb3JtYW5jZVRpbWVPcmlnaW4oKSB7XG4gIGlmICghY2FjaGVkVGltZU9yaWdpbikge1xuICAgIGNhY2hlZFRpbWVPcmlnaW4gPSBnZXRCcm93c2VyVGltZU9yaWdpbigpO1xuICB9XG5cbiAgcmV0dXJuIGNhY2hlZFRpbWVPcmlnaW5bMF07XG59XG5cbmV4cG9ydHMuYnJvd3NlclBlcmZvcm1hbmNlVGltZU9yaWdpbiA9IGJyb3dzZXJQZXJmb3JtYW5jZVRpbWVPcmlnaW47XG5leHBvcnRzLmRhdGVUaW1lc3RhbXBJblNlY29uZHMgPSBkYXRlVGltZXN0YW1wSW5TZWNvbmRzO1xuZXhwb3J0cy50aW1lc3RhbXBJblNlY29uZHMgPSB0aW1lc3RhbXBJblNlY29uZHM7XG4vLyMgc291cmNlTWFwcGluZ1VSTD10aW1lLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/time.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/traceData.js":
/*!*******************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/traceData.js ***!
  \*******************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst index = __webpack_require__(/*! ../asyncContext/index.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/asyncContext/index.js\");\nconst carrier = __webpack_require__(/*! ../carrier.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/carrier.js\");\nconst currentScopes = __webpack_require__(/*! ../currentScopes.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/currentScopes.js\");\nconst exports$1 = __webpack_require__(/*! ../exports.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/exports.js\");\nconst debugLogger = __webpack_require__(/*! ./debug-logger.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/debug-logger.js\");\nconst spanUtils = __webpack_require__(/*! ./spanUtils.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanUtils.js\");\nconst dynamicSamplingContext = __webpack_require__(/*! ../tracing/dynamicSamplingContext.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/tracing/dynamicSamplingContext.js\");\nconst tracing = __webpack_require__(/*! ./tracing.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/tracing.js\");\nconst baggage = __webpack_require__(/*! ./baggage.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/baggage.js\");\n\n/**\n * Extracts trace propagation data from the current span or from the client's scope (via transaction or propagation\n * context) and serializes it to `sentry-trace` and `baggage` values to strings. These values can be used to propagate\n * a trace via our tracing Http headers or Html `<meta>` tags.\n *\n * This function also applies some validation to the generated sentry-trace and baggage values to ensure that\n * only valid strings are returned.\n *\n * @returns an object with the tracing data values. The object keys are the name of the tracing key to be used as header\n * or meta tag name.\n */\nfunction getTraceData(options = {}) {\n  const client = options.client || currentScopes.getClient();\n  if (!exports$1.isEnabled() || !client) {\n    return {};\n  }\n\n  const carrier$1 = carrier.getMainCarrier();\n  const acs = index.getAsyncContextStrategy(carrier$1);\n  if (acs.getTraceData) {\n    return acs.getTraceData(options);\n  }\n\n  const scope = options.scope || currentScopes.getCurrentScope();\n  const span = options.span || spanUtils.getActiveSpan();\n  const sentryTrace = span ? spanUtils.spanToTraceHeader(span) : scopeToTraceHeader(scope);\n  const dsc = span ? dynamicSamplingContext.getDynamicSamplingContextFromSpan(span) : dynamicSamplingContext.getDynamicSamplingContextFromScope(client, scope);\n  const baggage$1 = baggage.dynamicSamplingContextToSentryBaggageHeader(dsc);\n\n  const isValidSentryTraceHeader = tracing.TRACEPARENT_REGEXP.test(sentryTrace);\n  if (!isValidSentryTraceHeader) {\n    debugLogger.debug.warn('Invalid sentry-trace data. Cannot generate trace data');\n    return {};\n  }\n\n  return {\n    'sentry-trace': sentryTrace,\n    baggage: baggage$1,\n  };\n}\n\n/**\n * Get a sentry-trace header value for the given scope.\n */\nfunction scopeToTraceHeader(scope) {\n  const { traceId, sampled, propagationSpanId } = scope.getPropagationContext();\n  return tracing.generateSentryTraceHeader(traceId, propagationSpanId, sampled);\n}\n\nexports.getTraceData = getTraceData;\n//# sourceMappingURL=traceData.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy90cmFjZURhdGEuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsY0FBYyxtQkFBTyxDQUFDLDBJQUEwQjtBQUNoRCxnQkFBZ0IsbUJBQU8sQ0FBQyxvSEFBZTtBQUN2QyxzQkFBc0IsbUJBQU8sQ0FBQyxnSUFBcUI7QUFDbkQsa0JBQWtCLG1CQUFPLENBQUMsb0hBQWU7QUFDekMsb0JBQW9CLG1CQUFPLENBQUMsbUlBQW1CO0FBQy9DLGtCQUFrQixtQkFBTyxDQUFDLDZIQUFnQjtBQUMxQywrQkFBK0IsbUJBQU8sQ0FBQyxrS0FBc0M7QUFDN0UsZ0JBQWdCLG1CQUFPLENBQUMseUhBQWM7QUFDdEMsZ0JBQWdCLG1CQUFPLENBQUMseUhBQWM7O0FBRXRDO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxrQ0FBa0M7QUFDbEM7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLFVBQVUsc0NBQXNDO0FBQ2hEO0FBQ0E7O0FBRUEsb0JBQW9CO0FBQ3BCIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvdHJhY2VEYXRhLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBpbmRleCA9IHJlcXVpcmUoJy4uL2FzeW5jQ29udGV4dC9pbmRleC5qcycpO1xuY29uc3QgY2FycmllciA9IHJlcXVpcmUoJy4uL2NhcnJpZXIuanMnKTtcbmNvbnN0IGN1cnJlbnRTY29wZXMgPSByZXF1aXJlKCcuLi9jdXJyZW50U2NvcGVzLmpzJyk7XG5jb25zdCBleHBvcnRzJDEgPSByZXF1aXJlKCcuLi9leHBvcnRzLmpzJyk7XG5jb25zdCBkZWJ1Z0xvZ2dlciA9IHJlcXVpcmUoJy4vZGVidWctbG9nZ2VyLmpzJyk7XG5jb25zdCBzcGFuVXRpbHMgPSByZXF1aXJlKCcuL3NwYW5VdGlscy5qcycpO1xuY29uc3QgZHluYW1pY1NhbXBsaW5nQ29udGV4dCA9IHJlcXVpcmUoJy4uL3RyYWNpbmcvZHluYW1pY1NhbXBsaW5nQ29udGV4dC5qcycpO1xuY29uc3QgdHJhY2luZyA9IHJlcXVpcmUoJy4vdHJhY2luZy5qcycpO1xuY29uc3QgYmFnZ2FnZSA9IHJlcXVpcmUoJy4vYmFnZ2FnZS5qcycpO1xuXG4vKipcbiAqIEV4dHJhY3RzIHRyYWNlIHByb3BhZ2F0aW9uIGRhdGEgZnJvbSB0aGUgY3VycmVudCBzcGFuIG9yIGZyb20gdGhlIGNsaWVudCdzIHNjb3BlICh2aWEgdHJhbnNhY3Rpb24gb3IgcHJvcGFnYXRpb25cbiAqIGNvbnRleHQpIGFuZCBzZXJpYWxpemVzIGl0IHRvIGBzZW50cnktdHJhY2VgIGFuZCBgYmFnZ2FnZWAgdmFsdWVzIHRvIHN0cmluZ3MuIFRoZXNlIHZhbHVlcyBjYW4gYmUgdXNlZCB0byBwcm9wYWdhdGVcbiAqIGEgdHJhY2UgdmlhIG91ciB0cmFjaW5nIEh0dHAgaGVhZGVycyBvciBIdG1sIGA8bWV0YT5gIHRhZ3MuXG4gKlxuICogVGhpcyBmdW5jdGlvbiBhbHNvIGFwcGxpZXMgc29tZSB2YWxpZGF0aW9uIHRvIHRoZSBnZW5lcmF0ZWQgc2VudHJ5LXRyYWNlIGFuZCBiYWdnYWdlIHZhbHVlcyB0byBlbnN1cmUgdGhhdFxuICogb25seSB2YWxpZCBzdHJpbmdzIGFyZSByZXR1cm5lZC5cbiAqXG4gKiBAcmV0dXJucyBhbiBvYmplY3Qgd2l0aCB0aGUgdHJhY2luZyBkYXRhIHZhbHVlcy4gVGhlIG9iamVjdCBrZXlzIGFyZSB0aGUgbmFtZSBvZiB0aGUgdHJhY2luZyBrZXkgdG8gYmUgdXNlZCBhcyBoZWFkZXJcbiAqIG9yIG1ldGEgdGFnIG5hbWUuXG4gKi9cbmZ1bmN0aW9uIGdldFRyYWNlRGF0YShvcHRpb25zID0ge30pIHtcbiAgY29uc3QgY2xpZW50ID0gb3B0aW9ucy5jbGllbnQgfHwgY3VycmVudFNjb3Blcy5nZXRDbGllbnQoKTtcbiAgaWYgKCFleHBvcnRzJDEuaXNFbmFibGVkKCkgfHwgIWNsaWVudCkge1xuICAgIHJldHVybiB7fTtcbiAgfVxuXG4gIGNvbnN0IGNhcnJpZXIkMSA9IGNhcnJpZXIuZ2V0TWFpbkNhcnJpZXIoKTtcbiAgY29uc3QgYWNzID0gaW5kZXguZ2V0QXN5bmNDb250ZXh0U3RyYXRlZ3koY2FycmllciQxKTtcbiAgaWYgKGFjcy5nZXRUcmFjZURhdGEpIHtcbiAgICByZXR1cm4gYWNzLmdldFRyYWNlRGF0YShvcHRpb25zKTtcbiAgfVxuXG4gIGNvbnN0IHNjb3BlID0gb3B0aW9ucy5zY29wZSB8fCBjdXJyZW50U2NvcGVzLmdldEN1cnJlbnRTY29wZSgpO1xuICBjb25zdCBzcGFuID0gb3B0aW9ucy5zcGFuIHx8IHNwYW5VdGlscy5nZXRBY3RpdmVTcGFuKCk7XG4gIGNvbnN0IHNlbnRyeVRyYWNlID0gc3BhbiA/IHNwYW5VdGlscy5zcGFuVG9UcmFjZUhlYWRlcihzcGFuKSA6IHNjb3BlVG9UcmFjZUhlYWRlcihzY29wZSk7XG4gIGNvbnN0IGRzYyA9IHNwYW4gPyBkeW5hbWljU2FtcGxpbmdDb250ZXh0LmdldER5bmFtaWNTYW1wbGluZ0NvbnRleHRGcm9tU3BhbihzcGFuKSA6IGR5bmFtaWNTYW1wbGluZ0NvbnRleHQuZ2V0RHluYW1pY1NhbXBsaW5nQ29udGV4dEZyb21TY29wZShjbGllbnQsIHNjb3BlKTtcbiAgY29uc3QgYmFnZ2FnZSQxID0gYmFnZ2FnZS5keW5hbWljU2FtcGxpbmdDb250ZXh0VG9TZW50cnlCYWdnYWdlSGVhZGVyKGRzYyk7XG5cbiAgY29uc3QgaXNWYWxpZFNlbnRyeVRyYWNlSGVhZGVyID0gdHJhY2luZy5UUkFDRVBBUkVOVF9SRUdFWFAudGVzdChzZW50cnlUcmFjZSk7XG4gIGlmICghaXNWYWxpZFNlbnRyeVRyYWNlSGVhZGVyKSB7XG4gICAgZGVidWdMb2dnZXIuZGVidWcud2FybignSW52YWxpZCBzZW50cnktdHJhY2UgZGF0YS4gQ2Fubm90IGdlbmVyYXRlIHRyYWNlIGRhdGEnKTtcbiAgICByZXR1cm4ge307XG4gIH1cblxuICByZXR1cm4ge1xuICAgICdzZW50cnktdHJhY2UnOiBzZW50cnlUcmFjZSxcbiAgICBiYWdnYWdlOiBiYWdnYWdlJDEsXG4gIH07XG59XG5cbi8qKlxuICogR2V0IGEgc2VudHJ5LXRyYWNlIGhlYWRlciB2YWx1ZSBmb3IgdGhlIGdpdmVuIHNjb3BlLlxuICovXG5mdW5jdGlvbiBzY29wZVRvVHJhY2VIZWFkZXIoc2NvcGUpIHtcbiAgY29uc3QgeyB0cmFjZUlkLCBzYW1wbGVkLCBwcm9wYWdhdGlvblNwYW5JZCB9ID0gc2NvcGUuZ2V0UHJvcGFnYXRpb25Db250ZXh0KCk7XG4gIHJldHVybiB0cmFjaW5nLmdlbmVyYXRlU2VudHJ5VHJhY2VIZWFkZXIodHJhY2VJZCwgcHJvcGFnYXRpb25TcGFuSWQsIHNhbXBsZWQpO1xufVxuXG5leHBvcnRzLmdldFRyYWNlRGF0YSA9IGdldFRyYWNlRGF0YTtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPXRyYWNlRGF0YS5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/traceData.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/tracing.js":
/*!*****************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/tracing.js ***!
  \*****************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst baggage = __webpack_require__(/*! ./baggage.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/baggage.js\");\nconst parseSampleRate = __webpack_require__(/*! ./parseSampleRate.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/parseSampleRate.js\");\nconst propagationContext = __webpack_require__(/*! ./propagationContext.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/propagationContext.js\");\n\n// eslint-disable-next-line @sentry-internal/sdk/no-regexp-constructor -- RegExp is used for readability here\nconst TRACEPARENT_REGEXP = new RegExp(\n  '^[ \\\\t]*' + // whitespace\n    '([0-9a-f]{32})?' + // trace_id\n    '-?([0-9a-f]{16})?' + // span_id\n    '-?([01])?' + // sampled\n    '[ \\\\t]*$', // whitespace\n);\n\n/**\n * Extract transaction context data from a `sentry-trace` header.\n *\n * @param traceparent Traceparent string\n *\n * @returns Object containing data from the header, or undefined if traceparent string is malformed\n */\nfunction extractTraceparentData(traceparent) {\n  if (!traceparent) {\n    return undefined;\n  }\n\n  const matches = traceparent.match(TRACEPARENT_REGEXP);\n  if (!matches) {\n    return undefined;\n  }\n\n  let parentSampled;\n  if (matches[3] === '1') {\n    parentSampled = true;\n  } else if (matches[3] === '0') {\n    parentSampled = false;\n  }\n\n  return {\n    traceId: matches[1],\n    parentSampled,\n    parentSpanId: matches[2],\n  };\n}\n\n/**\n * Create a propagation context from incoming headers or\n * creates a minimal new one if the headers are undefined.\n */\nfunction propagationContextFromHeaders(\n  sentryTrace,\n  baggage$1,\n) {\n  const traceparentData = extractTraceparentData(sentryTrace);\n  const dynamicSamplingContext = baggage.baggageHeaderToDynamicSamplingContext(baggage$1);\n\n  if (!traceparentData?.traceId) {\n    return {\n      traceId: propagationContext.generateTraceId(),\n      sampleRand: Math.random(),\n    };\n  }\n\n  const sampleRand = getSampleRandFromTraceparentAndDsc(traceparentData, dynamicSamplingContext);\n\n  // The sample_rand on the DSC needs to be generated based on traceparent + baggage.\n  if (dynamicSamplingContext) {\n    dynamicSamplingContext.sample_rand = sampleRand.toString();\n  }\n\n  const { traceId, parentSpanId, parentSampled } = traceparentData;\n\n  return {\n    traceId,\n    parentSpanId,\n    sampled: parentSampled,\n    dsc: dynamicSamplingContext || {}, // If we have traceparent data but no DSC it means we are not head of trace and we must freeze it\n    sampleRand,\n  };\n}\n\n/**\n * Create sentry-trace header from span context values.\n */\nfunction generateSentryTraceHeader(\n  traceId = propagationContext.generateTraceId(),\n  spanId = propagationContext.generateSpanId(),\n  sampled,\n) {\n  let sampledString = '';\n  if (sampled !== undefined) {\n    sampledString = sampled ? '-1' : '-0';\n  }\n  return `${traceId}-${spanId}${sampledString}`;\n}\n\n/**\n * Given any combination of an incoming trace, generate a sample rand based on its defined semantics.\n *\n * Read more: https://develop.sentry.dev/sdk/telemetry/traces/#propagated-random-value\n */\nfunction getSampleRandFromTraceparentAndDsc(\n  traceparentData,\n  dsc,\n) {\n  // When there is an incoming sample rand use it.\n  const parsedSampleRand = parseSampleRate.parseSampleRate(dsc?.sample_rand);\n  if (parsedSampleRand !== undefined) {\n    return parsedSampleRand;\n  }\n\n  // Otherwise, if there is an incoming sampling decision + sample rate, generate a sample rand that would lead to the same sampling decision.\n  const parsedSampleRate = parseSampleRate.parseSampleRate(dsc?.sample_rate);\n  if (parsedSampleRate && traceparentData?.parentSampled !== undefined) {\n    return traceparentData.parentSampled\n      ? // Returns a sample rand with positive sampling decision [0, sampleRate)\n        Math.random() * parsedSampleRate\n      : // Returns a sample rand with negative sampling decision [sampleRate, 1)\n        parsedSampleRate + Math.random() * (1 - parsedSampleRate);\n  } else {\n    // If nothing applies, return a random sample rand.\n    return Math.random();\n  }\n}\n\nexports.TRACEPARENT_REGEXP = TRACEPARENT_REGEXP;\nexports.extractTraceparentData = extractTraceparentData;\nexports.generateSentryTraceHeader = generateSentryTraceHeader;\nexports.propagationContextFromHeaders = propagationContextFromHeaders;\n//# sourceMappingURL=tracing.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy90cmFjaW5nLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLGdCQUFnQixtQkFBTyxDQUFDLHlIQUFjO0FBQ3RDLHdCQUF3QixtQkFBTyxDQUFDLHlJQUFzQjtBQUN0RCwyQkFBMkIsbUJBQU8sQ0FBQywrSUFBeUI7O0FBRTVEO0FBQ0E7QUFDQTtBQUNBLGVBQWUsR0FBRztBQUNsQixpQkFBaUIsR0FBRztBQUNwQjtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQSxJQUFJO0FBQ0o7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLFVBQVUsdUNBQXVDOztBQUVqRDtBQUNBO0FBQ0E7QUFDQTtBQUNBLHFDQUFxQztBQUNyQztBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsWUFBWSxRQUFRLEdBQUcsT0FBTyxFQUFFLGNBQWM7QUFDOUM7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsSUFBSTtBQUNKO0FBQ0E7QUFDQTtBQUNBOztBQUVBLDBCQUEwQjtBQUMxQiw4QkFBOEI7QUFDOUIsaUNBQWlDO0FBQ2pDLHFDQUFxQztBQUNyQyIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3V0aWxzL3RyYWNpbmcuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbmNvbnN0IGJhZ2dhZ2UgPSByZXF1aXJlKCcuL2JhZ2dhZ2UuanMnKTtcbmNvbnN0IHBhcnNlU2FtcGxlUmF0ZSA9IHJlcXVpcmUoJy4vcGFyc2VTYW1wbGVSYXRlLmpzJyk7XG5jb25zdCBwcm9wYWdhdGlvbkNvbnRleHQgPSByZXF1aXJlKCcuL3Byb3BhZ2F0aW9uQ29udGV4dC5qcycpO1xuXG4vLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHNlbnRyeS1pbnRlcm5hbC9zZGsvbm8tcmVnZXhwLWNvbnN0cnVjdG9yIC0tIFJlZ0V4cCBpcyB1c2VkIGZvciByZWFkYWJpbGl0eSBoZXJlXG5jb25zdCBUUkFDRVBBUkVOVF9SRUdFWFAgPSBuZXcgUmVnRXhwKFxuICAnXlsgXFxcXHRdKicgKyAvLyB3aGl0ZXNwYWNlXG4gICAgJyhbMC05YS1mXXszMn0pPycgKyAvLyB0cmFjZV9pZFxuICAgICctPyhbMC05YS1mXXsxNn0pPycgKyAvLyBzcGFuX2lkXG4gICAgJy0/KFswMV0pPycgKyAvLyBzYW1wbGVkXG4gICAgJ1sgXFxcXHRdKiQnLCAvLyB3aGl0ZXNwYWNlXG4pO1xuXG4vKipcbiAqIEV4dHJhY3QgdHJhbnNhY3Rpb24gY29udGV4dCBkYXRhIGZyb20gYSBgc2VudHJ5LXRyYWNlYCBoZWFkZXIuXG4gKlxuICogQHBhcmFtIHRyYWNlcGFyZW50IFRyYWNlcGFyZW50IHN0cmluZ1xuICpcbiAqIEByZXR1cm5zIE9iamVjdCBjb250YWluaW5nIGRhdGEgZnJvbSB0aGUgaGVhZGVyLCBvciB1bmRlZmluZWQgaWYgdHJhY2VwYXJlbnQgc3RyaW5nIGlzIG1hbGZvcm1lZFxuICovXG5mdW5jdGlvbiBleHRyYWN0VHJhY2VwYXJlbnREYXRhKHRyYWNlcGFyZW50KSB7XG4gIGlmICghdHJhY2VwYXJlbnQpIHtcbiAgICByZXR1cm4gdW5kZWZpbmVkO1xuICB9XG5cbiAgY29uc3QgbWF0Y2hlcyA9IHRyYWNlcGFyZW50Lm1hdGNoKFRSQUNFUEFSRU5UX1JFR0VYUCk7XG4gIGlmICghbWF0Y2hlcykge1xuICAgIHJldHVybiB1bmRlZmluZWQ7XG4gIH1cblxuICBsZXQgcGFyZW50U2FtcGxlZDtcbiAgaWYgKG1hdGNoZXNbM10gPT09ICcxJykge1xuICAgIHBhcmVudFNhbXBsZWQgPSB0cnVlO1xuICB9IGVsc2UgaWYgKG1hdGNoZXNbM10gPT09ICcwJykge1xuICAgIHBhcmVudFNhbXBsZWQgPSBmYWxzZTtcbiAgfVxuXG4gIHJldHVybiB7XG4gICAgdHJhY2VJZDogbWF0Y2hlc1sxXSxcbiAgICBwYXJlbnRTYW1wbGVkLFxuICAgIHBhcmVudFNwYW5JZDogbWF0Y2hlc1syXSxcbiAgfTtcbn1cblxuLyoqXG4gKiBDcmVhdGUgYSBwcm9wYWdhdGlvbiBjb250ZXh0IGZyb20gaW5jb21pbmcgaGVhZGVycyBvclxuICogY3JlYXRlcyBhIG1pbmltYWwgbmV3IG9uZSBpZiB0aGUgaGVhZGVycyBhcmUgdW5kZWZpbmVkLlxuICovXG5mdW5jdGlvbiBwcm9wYWdhdGlvbkNvbnRleHRGcm9tSGVhZGVycyhcbiAgc2VudHJ5VHJhY2UsXG4gIGJhZ2dhZ2UkMSxcbikge1xuICBjb25zdCB0cmFjZXBhcmVudERhdGEgPSBleHRyYWN0VHJhY2VwYXJlbnREYXRhKHNlbnRyeVRyYWNlKTtcbiAgY29uc3QgZHluYW1pY1NhbXBsaW5nQ29udGV4dCA9IGJhZ2dhZ2UuYmFnZ2FnZUhlYWRlclRvRHluYW1pY1NhbXBsaW5nQ29udGV4dChiYWdnYWdlJDEpO1xuXG4gIGlmICghdHJhY2VwYXJlbnREYXRhPy50cmFjZUlkKSB7XG4gICAgcmV0dXJuIHtcbiAgICAgIHRyYWNlSWQ6IHByb3BhZ2F0aW9uQ29udGV4dC5nZW5lcmF0ZVRyYWNlSWQoKSxcbiAgICAgIHNhbXBsZVJhbmQ6IE1hdGgucmFuZG9tKCksXG4gICAgfTtcbiAgfVxuXG4gIGNvbnN0IHNhbXBsZVJhbmQgPSBnZXRTYW1wbGVSYW5kRnJvbVRyYWNlcGFyZW50QW5kRHNjKHRyYWNlcGFyZW50RGF0YSwgZHluYW1pY1NhbXBsaW5nQ29udGV4dCk7XG5cbiAgLy8gVGhlIHNhbXBsZV9yYW5kIG9uIHRoZSBEU0MgbmVlZHMgdG8gYmUgZ2VuZXJhdGVkIGJhc2VkIG9uIHRyYWNlcGFyZW50ICsgYmFnZ2FnZS5cbiAgaWYgKGR5bmFtaWNTYW1wbGluZ0NvbnRleHQpIHtcbiAgICBkeW5hbWljU2FtcGxpbmdDb250ZXh0LnNhbXBsZV9yYW5kID0gc2FtcGxlUmFuZC50b1N0cmluZygpO1xuICB9XG5cbiAgY29uc3QgeyB0cmFjZUlkLCBwYXJlbnRTcGFuSWQsIHBhcmVudFNhbXBsZWQgfSA9IHRyYWNlcGFyZW50RGF0YTtcblxuICByZXR1cm4ge1xuICAgIHRyYWNlSWQsXG4gICAgcGFyZW50U3BhbklkLFxuICAgIHNhbXBsZWQ6IHBhcmVudFNhbXBsZWQsXG4gICAgZHNjOiBkeW5hbWljU2FtcGxpbmdDb250ZXh0IHx8IHt9LCAvLyBJZiB3ZSBoYXZlIHRyYWNlcGFyZW50IGRhdGEgYnV0IG5vIERTQyBpdCBtZWFucyB3ZSBhcmUgbm90IGhlYWQgb2YgdHJhY2UgYW5kIHdlIG11c3QgZnJlZXplIGl0XG4gICAgc2FtcGxlUmFuZCxcbiAgfTtcbn1cblxuLyoqXG4gKiBDcmVhdGUgc2VudHJ5LXRyYWNlIGhlYWRlciBmcm9tIHNwYW4gY29udGV4dCB2YWx1ZXMuXG4gKi9cbmZ1bmN0aW9uIGdlbmVyYXRlU2VudHJ5VHJhY2VIZWFkZXIoXG4gIHRyYWNlSWQgPSBwcm9wYWdhdGlvbkNvbnRleHQuZ2VuZXJhdGVUcmFjZUlkKCksXG4gIHNwYW5JZCA9IHByb3BhZ2F0aW9uQ29udGV4dC5nZW5lcmF0ZVNwYW5JZCgpLFxuICBzYW1wbGVkLFxuKSB7XG4gIGxldCBzYW1wbGVkU3RyaW5nID0gJyc7XG4gIGlmIChzYW1wbGVkICE9PSB1bmRlZmluZWQpIHtcbiAgICBzYW1wbGVkU3RyaW5nID0gc2FtcGxlZCA/ICctMScgOiAnLTAnO1xuICB9XG4gIHJldHVybiBgJHt0cmFjZUlkfS0ke3NwYW5JZH0ke3NhbXBsZWRTdHJpbmd9YDtcbn1cblxuLyoqXG4gKiBHaXZlbiBhbnkgY29tYmluYXRpb24gb2YgYW4gaW5jb21pbmcgdHJhY2UsIGdlbmVyYXRlIGEgc2FtcGxlIHJhbmQgYmFzZWQgb24gaXRzIGRlZmluZWQgc2VtYW50aWNzLlxuICpcbiAqIFJlYWQgbW9yZTogaHR0cHM6Ly9kZXZlbG9wLnNlbnRyeS5kZXYvc2RrL3RlbGVtZXRyeS90cmFjZXMvI3Byb3BhZ2F0ZWQtcmFuZG9tLXZhbHVlXG4gKi9cbmZ1bmN0aW9uIGdldFNhbXBsZVJhbmRGcm9tVHJhY2VwYXJlbnRBbmREc2MoXG4gIHRyYWNlcGFyZW50RGF0YSxcbiAgZHNjLFxuKSB7XG4gIC8vIFdoZW4gdGhlcmUgaXMgYW4gaW5jb21pbmcgc2FtcGxlIHJhbmQgdXNlIGl0LlxuICBjb25zdCBwYXJzZWRTYW1wbGVSYW5kID0gcGFyc2VTYW1wbGVSYXRlLnBhcnNlU2FtcGxlUmF0ZShkc2M/LnNhbXBsZV9yYW5kKTtcbiAgaWYgKHBhcnNlZFNhbXBsZVJhbmQgIT09IHVuZGVmaW5lZCkge1xuICAgIHJldHVybiBwYXJzZWRTYW1wbGVSYW5kO1xuICB9XG5cbiAgLy8gT3RoZXJ3aXNlLCBpZiB0aGVyZSBpcyBhbiBpbmNvbWluZyBzYW1wbGluZyBkZWNpc2lvbiArIHNhbXBsZSByYXRlLCBnZW5lcmF0ZSBhIHNhbXBsZSByYW5kIHRoYXQgd291bGQgbGVhZCB0byB0aGUgc2FtZSBzYW1wbGluZyBkZWNpc2lvbi5cbiAgY29uc3QgcGFyc2VkU2FtcGxlUmF0ZSA9IHBhcnNlU2FtcGxlUmF0ZS5wYXJzZVNhbXBsZVJhdGUoZHNjPy5zYW1wbGVfcmF0ZSk7XG4gIGlmIChwYXJzZWRTYW1wbGVSYXRlICYmIHRyYWNlcGFyZW50RGF0YT8ucGFyZW50U2FtcGxlZCAhPT0gdW5kZWZpbmVkKSB7XG4gICAgcmV0dXJuIHRyYWNlcGFyZW50RGF0YS5wYXJlbnRTYW1wbGVkXG4gICAgICA/IC8vIFJldHVybnMgYSBzYW1wbGUgcmFuZCB3aXRoIHBvc2l0aXZlIHNhbXBsaW5nIGRlY2lzaW9uIFswLCBzYW1wbGVSYXRlKVxuICAgICAgICBNYXRoLnJhbmRvbSgpICogcGFyc2VkU2FtcGxlUmF0ZVxuICAgICAgOiAvLyBSZXR1cm5zIGEgc2FtcGxlIHJhbmQgd2l0aCBuZWdhdGl2ZSBzYW1wbGluZyBkZWNpc2lvbiBbc2FtcGxlUmF0ZSwgMSlcbiAgICAgICAgcGFyc2VkU2FtcGxlUmF0ZSArIE1hdGgucmFuZG9tKCkgKiAoMSAtIHBhcnNlZFNhbXBsZVJhdGUpO1xuICB9IGVsc2Uge1xuICAgIC8vIElmIG5vdGhpbmcgYXBwbGllcywgcmV0dXJuIGEgcmFuZG9tIHNhbXBsZSByYW5kLlxuICAgIHJldHVybiBNYXRoLnJhbmRvbSgpO1xuICB9XG59XG5cbmV4cG9ydHMuVFJBQ0VQQVJFTlRfUkVHRVhQID0gVFJBQ0VQQVJFTlRfUkVHRVhQO1xuZXhwb3J0cy5leHRyYWN0VHJhY2VwYXJlbnREYXRhID0gZXh0cmFjdFRyYWNlcGFyZW50RGF0YTtcbmV4cG9ydHMuZ2VuZXJhdGVTZW50cnlUcmFjZUhlYWRlciA9IGdlbmVyYXRlU2VudHJ5VHJhY2VIZWFkZXI7XG5leHBvcnRzLnByb3BhZ2F0aW9uQ29udGV4dEZyb21IZWFkZXJzID0gcHJvcGFnYXRpb25Db250ZXh0RnJvbUhlYWRlcnM7XG4vLyMgc291cmNlTWFwcGluZ1VSTD10cmFjaW5nLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/tracing.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/transactionEvent.js":
/*!**************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/transactionEvent.js ***!
  \**************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst semanticAttributes = __webpack_require__(/*! ../semanticAttributes.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/semanticAttributes.js\");\n\n/**\n * Converts a transaction event to a span JSON object.\n */\nfunction convertTransactionEventToSpanJson(event) {\n  const { trace_id, parent_span_id, span_id, status, origin, data, op } = event.contexts?.trace ?? {};\n\n  return {\n    data: data ?? {},\n    description: event.transaction,\n    op,\n    parent_span_id,\n    span_id: span_id ?? '',\n    start_timestamp: event.start_timestamp ?? 0,\n    status,\n    timestamp: event.timestamp,\n    trace_id: trace_id ?? '',\n    origin,\n    profile_id: data?.[semanticAttributes.SEMANTIC_ATTRIBUTE_PROFILE_ID] ,\n    exclusive_time: data?.[semanticAttributes.SEMANTIC_ATTRIBUTE_EXCLUSIVE_TIME] ,\n    measurements: event.measurements,\n    is_segment: true,\n  };\n}\n\n/**\n * Converts a span JSON object to a transaction event.\n */\nfunction convertSpanJsonToTransactionEvent(span) {\n  return {\n    type: 'transaction',\n    timestamp: span.timestamp,\n    start_timestamp: span.start_timestamp,\n    transaction: span.description,\n    contexts: {\n      trace: {\n        trace_id: span.trace_id,\n        span_id: span.span_id,\n        parent_span_id: span.parent_span_id,\n        op: span.op,\n        status: span.status,\n        origin: span.origin,\n        data: {\n          ...span.data,\n          ...(span.profile_id && { [semanticAttributes.SEMANTIC_ATTRIBUTE_PROFILE_ID]: span.profile_id }),\n          ...(span.exclusive_time && { [semanticAttributes.SEMANTIC_ATTRIBUTE_EXCLUSIVE_TIME]: span.exclusive_time }),\n        },\n      },\n    },\n    measurements: span.measurements,\n  };\n}\n\nexports.convertSpanJsonToTransactionEvent = convertSpanJsonToTransactionEvent;\nexports.convertTransactionEventToSpanJson = convertTransactionEventToSpanJson;\n//# sourceMappingURL=transactionEvent.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy90cmFuc2FjdGlvbkV2ZW50LmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFLDJCQUEyQixtQkFBTyxDQUFDLDBJQUEwQjs7QUFFN0Q7QUFDQTtBQUNBO0FBQ0E7QUFDQSxVQUFVLDhEQUE4RDs7QUFFeEU7QUFDQSxvQkFBb0I7QUFDcEI7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsbUNBQW1DLHFFQUFxRTtBQUN4Ryx1Q0FBdUMsNkVBQTZFO0FBQ3BILFNBQVM7QUFDVCxPQUFPO0FBQ1AsS0FBSztBQUNMO0FBQ0E7QUFDQTs7QUFFQSx5Q0FBeUM7QUFDekMseUNBQXlDO0FBQ3pDIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvdHJhbnNhY3Rpb25FdmVudC5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuY29uc3Qgc2VtYW50aWNBdHRyaWJ1dGVzID0gcmVxdWlyZSgnLi4vc2VtYW50aWNBdHRyaWJ1dGVzLmpzJyk7XG5cbi8qKlxuICogQ29udmVydHMgYSB0cmFuc2FjdGlvbiBldmVudCB0byBhIHNwYW4gSlNPTiBvYmplY3QuXG4gKi9cbmZ1bmN0aW9uIGNvbnZlcnRUcmFuc2FjdGlvbkV2ZW50VG9TcGFuSnNvbihldmVudCkge1xuICBjb25zdCB7IHRyYWNlX2lkLCBwYXJlbnRfc3Bhbl9pZCwgc3Bhbl9pZCwgc3RhdHVzLCBvcmlnaW4sIGRhdGEsIG9wIH0gPSBldmVudC5jb250ZXh0cz8udHJhY2UgPz8ge307XG5cbiAgcmV0dXJuIHtcbiAgICBkYXRhOiBkYXRhID8/IHt9LFxuICAgIGRlc2NyaXB0aW9uOiBldmVudC50cmFuc2FjdGlvbixcbiAgICBvcCxcbiAgICBwYXJlbnRfc3Bhbl9pZCxcbiAgICBzcGFuX2lkOiBzcGFuX2lkID8/ICcnLFxuICAgIHN0YXJ0X3RpbWVzdGFtcDogZXZlbnQuc3RhcnRfdGltZXN0YW1wID8/IDAsXG4gICAgc3RhdHVzLFxuICAgIHRpbWVzdGFtcDogZXZlbnQudGltZXN0YW1wLFxuICAgIHRyYWNlX2lkOiB0cmFjZV9pZCA/PyAnJyxcbiAgICBvcmlnaW4sXG4gICAgcHJvZmlsZV9pZDogZGF0YT8uW3NlbWFudGljQXR0cmlidXRlcy5TRU1BTlRJQ19BVFRSSUJVVEVfUFJPRklMRV9JRF0gLFxuICAgIGV4Y2x1c2l2ZV90aW1lOiBkYXRhPy5bc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9FWENMVVNJVkVfVElNRV0gLFxuICAgIG1lYXN1cmVtZW50czogZXZlbnQubWVhc3VyZW1lbnRzLFxuICAgIGlzX3NlZ21lbnQ6IHRydWUsXG4gIH07XG59XG5cbi8qKlxuICogQ29udmVydHMgYSBzcGFuIEpTT04gb2JqZWN0IHRvIGEgdHJhbnNhY3Rpb24gZXZlbnQuXG4gKi9cbmZ1bmN0aW9uIGNvbnZlcnRTcGFuSnNvblRvVHJhbnNhY3Rpb25FdmVudChzcGFuKSB7XG4gIHJldHVybiB7XG4gICAgdHlwZTogJ3RyYW5zYWN0aW9uJyxcbiAgICB0aW1lc3RhbXA6IHNwYW4udGltZXN0YW1wLFxuICAgIHN0YXJ0X3RpbWVzdGFtcDogc3Bhbi5zdGFydF90aW1lc3RhbXAsXG4gICAgdHJhbnNhY3Rpb246IHNwYW4uZGVzY3JpcHRpb24sXG4gICAgY29udGV4dHM6IHtcbiAgICAgIHRyYWNlOiB7XG4gICAgICAgIHRyYWNlX2lkOiBzcGFuLnRyYWNlX2lkLFxuICAgICAgICBzcGFuX2lkOiBzcGFuLnNwYW5faWQsXG4gICAgICAgIHBhcmVudF9zcGFuX2lkOiBzcGFuLnBhcmVudF9zcGFuX2lkLFxuICAgICAgICBvcDogc3Bhbi5vcCxcbiAgICAgICAgc3RhdHVzOiBzcGFuLnN0YXR1cyxcbiAgICAgICAgb3JpZ2luOiBzcGFuLm9yaWdpbixcbiAgICAgICAgZGF0YToge1xuICAgICAgICAgIC4uLnNwYW4uZGF0YSxcbiAgICAgICAgICAuLi4oc3Bhbi5wcm9maWxlX2lkICYmIHsgW3NlbWFudGljQXR0cmlidXRlcy5TRU1BTlRJQ19BVFRSSUJVVEVfUFJPRklMRV9JRF06IHNwYW4ucHJvZmlsZV9pZCB9KSxcbiAgICAgICAgICAuLi4oc3Bhbi5leGNsdXNpdmVfdGltZSAmJiB7IFtzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX0VYQ0xVU0lWRV9USU1FXTogc3Bhbi5leGNsdXNpdmVfdGltZSB9KSxcbiAgICAgICAgfSxcbiAgICAgIH0sXG4gICAgfSxcbiAgICBtZWFzdXJlbWVudHM6IHNwYW4ubWVhc3VyZW1lbnRzLFxuICB9O1xufVxuXG5leHBvcnRzLmNvbnZlcnRTcGFuSnNvblRvVHJhbnNhY3Rpb25FdmVudCA9IGNvbnZlcnRTcGFuSnNvblRvVHJhbnNhY3Rpb25FdmVudDtcbmV4cG9ydHMuY29udmVydFRyYW5zYWN0aW9uRXZlbnRUb1NwYW5Kc29uID0gY29udmVydFRyYW5zYWN0aW9uRXZlbnRUb1NwYW5Kc29uO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9dHJhbnNhY3Rpb25FdmVudC5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/transactionEvent.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/url.js":
/*!*************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/url.js ***!
  \*************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst semanticAttributes = __webpack_require__(/*! ../semanticAttributes.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/semanticAttributes.js\");\n\n// Curious about `thismessage:/`? See: https://www.rfc-editor.org/rfc/rfc2557.html\n//  > When the methods above do not yield an absolute URI, a base URL\n//  > of \"thismessage:/\" MUST be employed. This base URL has been\n//  > defined for the sole purpose of resolving relative references\n//  > within a multipart/related structure when no other base URI is\n//  > specified.\n//\n// We need to provide a base URL to `parseStringToURLObject` because the fetch API gives us a\n// relative URL sometimes.\n//\n// This is the only case where we need to provide a base URL to `parseStringToURLObject`\n// because the relative URL is not valid on its own.\nconst DEFAULT_BASE_URL = 'thismessage:/';\n\n/**\n * Checks if the URL object is relative\n *\n * @param url - The URL object to check\n * @returns True if the URL object is relative, false otherwise\n */\nfunction isURLObjectRelative(url) {\n  return 'isRelative' in url;\n}\n\n/**\n * Parses string to a URL object\n *\n * @param url - The URL to parse\n * @returns The parsed URL object or undefined if the URL is invalid\n */\nfunction parseStringToURLObject(url, urlBase) {\n  const isRelative = url.indexOf('://') <= 0 && url.indexOf('//') !== 0;\n  const base = urlBase ?? (isRelative ? DEFAULT_BASE_URL : undefined);\n  try {\n    // Use `canParse` to short-circuit the URL constructor if it's not a valid URL\n    // This is faster than trying to construct the URL and catching the error\n    // Node 20+, Chrome 120+, Firefox 115+, Safari 17+\n    if ('canParse' in URL && !(URL ).canParse(url, base)) {\n      return undefined;\n    }\n\n    const fullUrlObject = new URL(url, base);\n    if (isRelative) {\n      // Because we used a fake base URL, we need to return a relative URL object.\n      // We cannot return anything about the origin, host, etc. because it will refer to the fake base URL.\n      return {\n        isRelative,\n        pathname: fullUrlObject.pathname,\n        search: fullUrlObject.search,\n        hash: fullUrlObject.hash,\n      };\n    }\n    return fullUrlObject;\n  } catch {\n    // empty body\n  }\n\n  return undefined;\n}\n\n/**\n * Takes a URL object and returns a sanitized string which is safe to use as span name\n * see: https://develop.sentry.dev/sdk/data-handling/#structuring-data\n */\nfunction getSanitizedUrlStringFromUrlObject(url) {\n  if (isURLObjectRelative(url)) {\n    return url.pathname;\n  }\n\n  const newUrl = new URL(url);\n  newUrl.search = '';\n  newUrl.hash = '';\n  if (['80', '443'].includes(newUrl.port)) {\n    newUrl.port = '';\n  }\n  if (newUrl.password) {\n    newUrl.password = '%filtered%';\n  }\n  if (newUrl.username) {\n    newUrl.username = '%filtered%';\n  }\n\n  return newUrl.toString();\n}\n\nfunction getHttpSpanNameFromUrlObject(\n  urlObject,\n  kind,\n  request,\n  routeName,\n) {\n  const method = request?.method?.toUpperCase() ?? 'GET';\n  const route = routeName\n    ? routeName\n    : urlObject\n      ? kind === 'client'\n        ? getSanitizedUrlStringFromUrlObject(urlObject)\n        : urlObject.pathname\n      : '/';\n\n  return `${method} ${route}`;\n}\n\n/**\n * Takes a parsed URL object and returns a set of attributes for the span\n * that represents the HTTP request for that url. This is used for both server\n * and client http spans.\n *\n * Follows https://opentelemetry.io/docs/specs/semconv/http/.\n *\n * @param urlObject - see {@link parseStringToURLObject}\n * @param kind - The type of HTTP operation (server or client)\n * @param spanOrigin - The origin of the span\n * @param request - The request object, see {@link PartialRequest}\n * @param routeName - The name of the route, must be low cardinality\n * @returns The span name and attributes for the HTTP operation\n */\nfunction getHttpSpanDetailsFromUrlObject(\n  urlObject,\n  kind,\n  spanOrigin,\n  request,\n  routeName,\n) {\n  const attributes = {\n    [semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_ORIGIN]: spanOrigin,\n    [semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_SOURCE]: 'url',\n  };\n\n  if (routeName) {\n    // This is based on https://opentelemetry.io/docs/specs/semconv/http/http-spans/#name\n    attributes[kind === 'server' ? 'http.route' : 'url.template'] = routeName;\n    attributes[semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_SOURCE] = 'route';\n  }\n\n  if (request?.method) {\n    attributes[semanticAttributes.SEMANTIC_ATTRIBUTE_HTTP_REQUEST_METHOD] = request.method.toUpperCase();\n  }\n\n  if (urlObject) {\n    if (urlObject.search) {\n      attributes['url.query'] = urlObject.search;\n    }\n    if (urlObject.hash) {\n      attributes['url.fragment'] = urlObject.hash;\n    }\n    if (urlObject.pathname) {\n      attributes['url.path'] = urlObject.pathname;\n      if (urlObject.pathname === '/') {\n        attributes[semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_SOURCE] = 'route';\n      }\n    }\n\n    if (!isURLObjectRelative(urlObject)) {\n      attributes[semanticAttributes.SEMANTIC_ATTRIBUTE_URL_FULL] = urlObject.href;\n      if (urlObject.port) {\n        attributes['url.port'] = urlObject.port;\n      }\n      if (urlObject.protocol) {\n        attributes['url.scheme'] = urlObject.protocol;\n      }\n      if (urlObject.hostname) {\n        attributes[kind === 'server' ? 'server.address' : 'url.domain'] = urlObject.hostname;\n      }\n    }\n  }\n\n  return [getHttpSpanNameFromUrlObject(urlObject, kind, request, routeName), attributes];\n}\n\n/**\n * Parses string form of URL into an object\n * // borrowed from https://tools.ietf.org/html/rfc3986#appendix-B\n * // intentionally using regex and not <a/> href parsing trick because React Native and other\n * // environments where DOM might not be available\n * @returns parsed URL object\n */\nfunction parseUrl(url) {\n  if (!url) {\n    return {};\n  }\n\n  const match = url.match(/^(([^:/?#]+):)?(\\/\\/([^/?#]*))?([^?#]*)(\\?([^#]*))?(#(.*))?$/);\n\n  if (!match) {\n    return {};\n  }\n\n  // coerce to undefined values to empty string so we don't get 'undefined'\n  const query = match[6] || '';\n  const fragment = match[8] || '';\n  return {\n    host: match[4],\n    path: match[5],\n    protocol: match[2],\n    search: query,\n    hash: fragment,\n    relative: match[5] + query + fragment, // everything minus origin\n  };\n}\n\n/**\n * Strip the query string and fragment off of a given URL or path (if present)\n *\n * @param urlPath Full URL or path, including possible query string and/or fragment\n * @returns URL or path without query string or fragment\n */\nfunction stripUrlQueryAndFragment(urlPath) {\n  return (urlPath.split(/[?#]/, 1) )[0];\n}\n\n/**\n * Takes a URL object and returns a sanitized string which is safe to use as span name\n * see: https://develop.sentry.dev/sdk/data-handling/#structuring-data\n */\nfunction getSanitizedUrlString(url) {\n  const { protocol, host, path } = url;\n\n  const filteredHost =\n    host\n      // Always filter out authority\n      ?.replace(/^.*@/, '[filtered]:[filtered]@')\n      // Don't show standard :80 (http) and :443 (https) ports to reduce the noise\n      // TODO: Use new URL global if it exists\n      .replace(/(:80)$/, '')\n      .replace(/(:443)$/, '') || '';\n\n  return `${protocol ? `${protocol}://` : ''}${filteredHost}${path}`;\n}\n\nexports.getHttpSpanDetailsFromUrlObject = getHttpSpanDetailsFromUrlObject;\nexports.getSanitizedUrlString = getSanitizedUrlString;\nexports.getSanitizedUrlStringFromUrlObject = getSanitizedUrlStringFromUrlObject;\nexports.isURLObjectRelative = isURLObjectRelative;\nexports.parseStringToURLObject = parseStringToURLObject;\nexports.parseUrl = parseUrl;\nexports.stripUrlQueryAndFragment = stripUrlQueryAndFragment;\n//# sourceMappingURL=url.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy91cmwuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsMkJBQTJCLG1CQUFPLENBQUMsMElBQTBCOztBQUU3RDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsSUFBSTtBQUNKO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsWUFBWSxRQUFRLEVBQUUsTUFBTTtBQUM1Qjs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLDJCQUEyQjtBQUMzQjtBQUNBO0FBQ0EsNkNBQTZDO0FBQzdDO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxVQUFVLHVCQUF1Qjs7QUFFakM7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSxZQUFZLGNBQWMsU0FBUyxVQUFVLEVBQUUsYUFBYSxFQUFFLEtBQUs7QUFDbkU7O0FBRUEsdUNBQXVDO0FBQ3ZDLDZCQUE2QjtBQUM3QiwwQ0FBMEM7QUFDMUMsMkJBQTJCO0FBQzNCLDhCQUE4QjtBQUM5QixnQkFBZ0I7QUFDaEIsZ0NBQWdDO0FBQ2hDIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvdXJsLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBzZW1hbnRpY0F0dHJpYnV0ZXMgPSByZXF1aXJlKCcuLi9zZW1hbnRpY0F0dHJpYnV0ZXMuanMnKTtcblxuLy8gQ3VyaW91cyBhYm91dCBgdGhpc21lc3NhZ2U6L2A/IFNlZTogaHR0cHM6Ly93d3cucmZjLWVkaXRvci5vcmcvcmZjL3JmYzI1NTcuaHRtbFxuLy8gID4gV2hlbiB0aGUgbWV0aG9kcyBhYm92ZSBkbyBub3QgeWllbGQgYW4gYWJzb2x1dGUgVVJJLCBhIGJhc2UgVVJMXG4vLyAgPiBvZiBcInRoaXNtZXNzYWdlOi9cIiBNVVNUIGJlIGVtcGxveWVkLiBUaGlzIGJhc2UgVVJMIGhhcyBiZWVuXG4vLyAgPiBkZWZpbmVkIGZvciB0aGUgc29sZSBwdXJwb3NlIG9mIHJlc29sdmluZyByZWxhdGl2ZSByZWZlcmVuY2VzXG4vLyAgPiB3aXRoaW4gYSBtdWx0aXBhcnQvcmVsYXRlZCBzdHJ1Y3R1cmUgd2hlbiBubyBvdGhlciBiYXNlIFVSSSBpc1xuLy8gID4gc3BlY2lmaWVkLlxuLy9cbi8vIFdlIG5lZWQgdG8gcHJvdmlkZSBhIGJhc2UgVVJMIHRvIGBwYXJzZVN0cmluZ1RvVVJMT2JqZWN0YCBiZWNhdXNlIHRoZSBmZXRjaCBBUEkgZ2l2ZXMgdXMgYVxuLy8gcmVsYXRpdmUgVVJMIHNvbWV0aW1lcy5cbi8vXG4vLyBUaGlzIGlzIHRoZSBvbmx5IGNhc2Ugd2hlcmUgd2UgbmVlZCB0byBwcm92aWRlIGEgYmFzZSBVUkwgdG8gYHBhcnNlU3RyaW5nVG9VUkxPYmplY3RgXG4vLyBiZWNhdXNlIHRoZSByZWxhdGl2ZSBVUkwgaXMgbm90IHZhbGlkIG9uIGl0cyBvd24uXG5jb25zdCBERUZBVUxUX0JBU0VfVVJMID0gJ3RoaXNtZXNzYWdlOi8nO1xuXG4vKipcbiAqIENoZWNrcyBpZiB0aGUgVVJMIG9iamVjdCBpcyByZWxhdGl2ZVxuICpcbiAqIEBwYXJhbSB1cmwgLSBUaGUgVVJMIG9iamVjdCB0byBjaGVja1xuICogQHJldHVybnMgVHJ1ZSBpZiB0aGUgVVJMIG9iamVjdCBpcyByZWxhdGl2ZSwgZmFsc2Ugb3RoZXJ3aXNlXG4gKi9cbmZ1bmN0aW9uIGlzVVJMT2JqZWN0UmVsYXRpdmUodXJsKSB7XG4gIHJldHVybiAnaXNSZWxhdGl2ZScgaW4gdXJsO1xufVxuXG4vKipcbiAqIFBhcnNlcyBzdHJpbmcgdG8gYSBVUkwgb2JqZWN0XG4gKlxuICogQHBhcmFtIHVybCAtIFRoZSBVUkwgdG8gcGFyc2VcbiAqIEByZXR1cm5zIFRoZSBwYXJzZWQgVVJMIG9iamVjdCBvciB1bmRlZmluZWQgaWYgdGhlIFVSTCBpcyBpbnZhbGlkXG4gKi9cbmZ1bmN0aW9uIHBhcnNlU3RyaW5nVG9VUkxPYmplY3QodXJsLCB1cmxCYXNlKSB7XG4gIGNvbnN0IGlzUmVsYXRpdmUgPSB1cmwuaW5kZXhPZignOi8vJykgPD0gMCAmJiB1cmwuaW5kZXhPZignLy8nKSAhPT0gMDtcbiAgY29uc3QgYmFzZSA9IHVybEJhc2UgPz8gKGlzUmVsYXRpdmUgPyBERUZBVUxUX0JBU0VfVVJMIDogdW5kZWZpbmVkKTtcbiAgdHJ5IHtcbiAgICAvLyBVc2UgYGNhblBhcnNlYCB0byBzaG9ydC1jaXJjdWl0IHRoZSBVUkwgY29uc3RydWN0b3IgaWYgaXQncyBub3QgYSB2YWxpZCBVUkxcbiAgICAvLyBUaGlzIGlzIGZhc3RlciB0aGFuIHRyeWluZyB0byBjb25zdHJ1Y3QgdGhlIFVSTCBhbmQgY2F0Y2hpbmcgdGhlIGVycm9yXG4gICAgLy8gTm9kZSAyMCssIENocm9tZSAxMjArLCBGaXJlZm94IDExNSssIFNhZmFyaSAxNytcbiAgICBpZiAoJ2NhblBhcnNlJyBpbiBVUkwgJiYgIShVUkwgKS5jYW5QYXJzZSh1cmwsIGJhc2UpKSB7XG4gICAgICByZXR1cm4gdW5kZWZpbmVkO1xuICAgIH1cblxuICAgIGNvbnN0IGZ1bGxVcmxPYmplY3QgPSBuZXcgVVJMKHVybCwgYmFzZSk7XG4gICAgaWYgKGlzUmVsYXRpdmUpIHtcbiAgICAgIC8vIEJlY2F1c2Ugd2UgdXNlZCBhIGZha2UgYmFzZSBVUkwsIHdlIG5lZWQgdG8gcmV0dXJuIGEgcmVsYXRpdmUgVVJMIG9iamVjdC5cbiAgICAgIC8vIFdlIGNhbm5vdCByZXR1cm4gYW55dGhpbmcgYWJvdXQgdGhlIG9yaWdpbiwgaG9zdCwgZXRjLiBiZWNhdXNlIGl0IHdpbGwgcmVmZXIgdG8gdGhlIGZha2UgYmFzZSBVUkwuXG4gICAgICByZXR1cm4ge1xuICAgICAgICBpc1JlbGF0aXZlLFxuICAgICAgICBwYXRobmFtZTogZnVsbFVybE9iamVjdC5wYXRobmFtZSxcbiAgICAgICAgc2VhcmNoOiBmdWxsVXJsT2JqZWN0LnNlYXJjaCxcbiAgICAgICAgaGFzaDogZnVsbFVybE9iamVjdC5oYXNoLFxuICAgICAgfTtcbiAgICB9XG4gICAgcmV0dXJuIGZ1bGxVcmxPYmplY3Q7XG4gIH0gY2F0Y2gge1xuICAgIC8vIGVtcHR5IGJvZHlcbiAgfVxuXG4gIHJldHVybiB1bmRlZmluZWQ7XG59XG5cbi8qKlxuICogVGFrZXMgYSBVUkwgb2JqZWN0IGFuZCByZXR1cm5zIGEgc2FuaXRpemVkIHN0cmluZyB3aGljaCBpcyBzYWZlIHRvIHVzZSBhcyBzcGFuIG5hbWVcbiAqIHNlZTogaHR0cHM6Ly9kZXZlbG9wLnNlbnRyeS5kZXYvc2RrL2RhdGEtaGFuZGxpbmcvI3N0cnVjdHVyaW5nLWRhdGFcbiAqL1xuZnVuY3Rpb24gZ2V0U2FuaXRpemVkVXJsU3RyaW5nRnJvbVVybE9iamVjdCh1cmwpIHtcbiAgaWYgKGlzVVJMT2JqZWN0UmVsYXRpdmUodXJsKSkge1xuICAgIHJldHVybiB1cmwucGF0aG5hbWU7XG4gIH1cblxuICBjb25zdCBuZXdVcmwgPSBuZXcgVVJMKHVybCk7XG4gIG5ld1VybC5zZWFyY2ggPSAnJztcbiAgbmV3VXJsLmhhc2ggPSAnJztcbiAgaWYgKFsnODAnLCAnNDQzJ10uaW5jbHVkZXMobmV3VXJsLnBvcnQpKSB7XG4gICAgbmV3VXJsLnBvcnQgPSAnJztcbiAgfVxuICBpZiAobmV3VXJsLnBhc3N3b3JkKSB7XG4gICAgbmV3VXJsLnBhc3N3b3JkID0gJyVmaWx0ZXJlZCUnO1xuICB9XG4gIGlmIChuZXdVcmwudXNlcm5hbWUpIHtcbiAgICBuZXdVcmwudXNlcm5hbWUgPSAnJWZpbHRlcmVkJSc7XG4gIH1cblxuICByZXR1cm4gbmV3VXJsLnRvU3RyaW5nKCk7XG59XG5cbmZ1bmN0aW9uIGdldEh0dHBTcGFuTmFtZUZyb21VcmxPYmplY3QoXG4gIHVybE9iamVjdCxcbiAga2luZCxcbiAgcmVxdWVzdCxcbiAgcm91dGVOYW1lLFxuKSB7XG4gIGNvbnN0IG1ldGhvZCA9IHJlcXVlc3Q/Lm1ldGhvZD8udG9VcHBlckNhc2UoKSA/PyAnR0VUJztcbiAgY29uc3Qgcm91dGUgPSByb3V0ZU5hbWVcbiAgICA/IHJvdXRlTmFtZVxuICAgIDogdXJsT2JqZWN0XG4gICAgICA/IGtpbmQgPT09ICdjbGllbnQnXG4gICAgICAgID8gZ2V0U2FuaXRpemVkVXJsU3RyaW5nRnJvbVVybE9iamVjdCh1cmxPYmplY3QpXG4gICAgICAgIDogdXJsT2JqZWN0LnBhdGhuYW1lXG4gICAgICA6ICcvJztcblxuICByZXR1cm4gYCR7bWV0aG9kfSAke3JvdXRlfWA7XG59XG5cbi8qKlxuICogVGFrZXMgYSBwYXJzZWQgVVJMIG9iamVjdCBhbmQgcmV0dXJucyBhIHNldCBvZiBhdHRyaWJ1dGVzIGZvciB0aGUgc3BhblxuICogdGhhdCByZXByZXNlbnRzIHRoZSBIVFRQIHJlcXVlc3QgZm9yIHRoYXQgdXJsLiBUaGlzIGlzIHVzZWQgZm9yIGJvdGggc2VydmVyXG4gKiBhbmQgY2xpZW50IGh0dHAgc3BhbnMuXG4gKlxuICogRm9sbG93cyBodHRwczovL29wZW50ZWxlbWV0cnkuaW8vZG9jcy9zcGVjcy9zZW1jb252L2h0dHAvLlxuICpcbiAqIEBwYXJhbSB1cmxPYmplY3QgLSBzZWUge0BsaW5rIHBhcnNlU3RyaW5nVG9VUkxPYmplY3R9XG4gKiBAcGFyYW0ga2luZCAtIFRoZSB0eXBlIG9mIEhUVFAgb3BlcmF0aW9uIChzZXJ2ZXIgb3IgY2xpZW50KVxuICogQHBhcmFtIHNwYW5PcmlnaW4gLSBUaGUgb3JpZ2luIG9mIHRoZSBzcGFuXG4gKiBAcGFyYW0gcmVxdWVzdCAtIFRoZSByZXF1ZXN0IG9iamVjdCwgc2VlIHtAbGluayBQYXJ0aWFsUmVxdWVzdH1cbiAqIEBwYXJhbSByb3V0ZU5hbWUgLSBUaGUgbmFtZSBvZiB0aGUgcm91dGUsIG11c3QgYmUgbG93IGNhcmRpbmFsaXR5XG4gKiBAcmV0dXJucyBUaGUgc3BhbiBuYW1lIGFuZCBhdHRyaWJ1dGVzIGZvciB0aGUgSFRUUCBvcGVyYXRpb25cbiAqL1xuZnVuY3Rpb24gZ2V0SHR0cFNwYW5EZXRhaWxzRnJvbVVybE9iamVjdChcbiAgdXJsT2JqZWN0LFxuICBraW5kLFxuICBzcGFuT3JpZ2luLFxuICByZXF1ZXN0LFxuICByb3V0ZU5hbWUsXG4pIHtcbiAgY29uc3QgYXR0cmlidXRlcyA9IHtcbiAgICBbc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfT1JJR0lOXTogc3Bhbk9yaWdpbixcbiAgICBbc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfU09VUkNFXTogJ3VybCcsXG4gIH07XG5cbiAgaWYgKHJvdXRlTmFtZSkge1xuICAgIC8vIFRoaXMgaXMgYmFzZWQgb24gaHR0cHM6Ly9vcGVudGVsZW1ldHJ5LmlvL2RvY3Mvc3BlY3Mvc2VtY29udi9odHRwL2h0dHAtc3BhbnMvI25hbWVcbiAgICBhdHRyaWJ1dGVzW2tpbmQgPT09ICdzZXJ2ZXInID8gJ2h0dHAucm91dGUnIDogJ3VybC50ZW1wbGF0ZSddID0gcm91dGVOYW1lO1xuICAgIGF0dHJpYnV0ZXNbc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfU09VUkNFXSA9ICdyb3V0ZSc7XG4gIH1cblxuICBpZiAocmVxdWVzdD8ubWV0aG9kKSB7XG4gICAgYXR0cmlidXRlc1tzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX0hUVFBfUkVRVUVTVF9NRVRIT0RdID0gcmVxdWVzdC5tZXRob2QudG9VcHBlckNhc2UoKTtcbiAgfVxuXG4gIGlmICh1cmxPYmplY3QpIHtcbiAgICBpZiAodXJsT2JqZWN0LnNlYXJjaCkge1xuICAgICAgYXR0cmlidXRlc1sndXJsLnF1ZXJ5J10gPSB1cmxPYmplY3Quc2VhcmNoO1xuICAgIH1cbiAgICBpZiAodXJsT2JqZWN0Lmhhc2gpIHtcbiAgICAgIGF0dHJpYnV0ZXNbJ3VybC5mcmFnbWVudCddID0gdXJsT2JqZWN0Lmhhc2g7XG4gICAgfVxuICAgIGlmICh1cmxPYmplY3QucGF0aG5hbWUpIHtcbiAgICAgIGF0dHJpYnV0ZXNbJ3VybC5wYXRoJ10gPSB1cmxPYmplY3QucGF0aG5hbWU7XG4gICAgICBpZiAodXJsT2JqZWN0LnBhdGhuYW1lID09PSAnLycpIHtcbiAgICAgICAgYXR0cmlidXRlc1tzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9TT1VSQ0VdID0gJ3JvdXRlJztcbiAgICAgIH1cbiAgICB9XG5cbiAgICBpZiAoIWlzVVJMT2JqZWN0UmVsYXRpdmUodXJsT2JqZWN0KSkge1xuICAgICAgYXR0cmlidXRlc1tzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX1VSTF9GVUxMXSA9IHVybE9iamVjdC5ocmVmO1xuICAgICAgaWYgKHVybE9iamVjdC5wb3J0KSB7XG4gICAgICAgIGF0dHJpYnV0ZXNbJ3VybC5wb3J0J10gPSB1cmxPYmplY3QucG9ydDtcbiAgICAgIH1cbiAgICAgIGlmICh1cmxPYmplY3QucHJvdG9jb2wpIHtcbiAgICAgICAgYXR0cmlidXRlc1sndXJsLnNjaGVtZSddID0gdXJsT2JqZWN0LnByb3RvY29sO1xuICAgICAgfVxuICAgICAgaWYgKHVybE9iamVjdC5ob3N0bmFtZSkge1xuICAgICAgICBhdHRyaWJ1dGVzW2tpbmQgPT09ICdzZXJ2ZXInID8gJ3NlcnZlci5hZGRyZXNzJyA6ICd1cmwuZG9tYWluJ10gPSB1cmxPYmplY3QuaG9zdG5hbWU7XG4gICAgICB9XG4gICAgfVxuICB9XG5cbiAgcmV0dXJuIFtnZXRIdHRwU3Bhbk5hbWVGcm9tVXJsT2JqZWN0KHVybE9iamVjdCwga2luZCwgcmVxdWVzdCwgcm91dGVOYW1lKSwgYXR0cmlidXRlc107XG59XG5cbi8qKlxuICogUGFyc2VzIHN0cmluZyBmb3JtIG9mIFVSTCBpbnRvIGFuIG9iamVjdFxuICogLy8gYm9ycm93ZWQgZnJvbSBodHRwczovL3Rvb2xzLmlldGYub3JnL2h0bWwvcmZjMzk4NiNhcHBlbmRpeC1CXG4gKiAvLyBpbnRlbnRpb25hbGx5IHVzaW5nIHJlZ2V4IGFuZCBub3QgPGEvPiBocmVmIHBhcnNpbmcgdHJpY2sgYmVjYXVzZSBSZWFjdCBOYXRpdmUgYW5kIG90aGVyXG4gKiAvLyBlbnZpcm9ubWVudHMgd2hlcmUgRE9NIG1pZ2h0IG5vdCBiZSBhdmFpbGFibGVcbiAqIEByZXR1cm5zIHBhcnNlZCBVUkwgb2JqZWN0XG4gKi9cbmZ1bmN0aW9uIHBhcnNlVXJsKHVybCkge1xuICBpZiAoIXVybCkge1xuICAgIHJldHVybiB7fTtcbiAgfVxuXG4gIGNvbnN0IG1hdGNoID0gdXJsLm1hdGNoKC9eKChbXjovPyNdKyk6KT8oXFwvXFwvKFteLz8jXSopKT8oW14/I10qKShcXD8oW14jXSopKT8oIyguKikpPyQvKTtcblxuICBpZiAoIW1hdGNoKSB7XG4gICAgcmV0dXJuIHt9O1xuICB9XG5cbiAgLy8gY29lcmNlIHRvIHVuZGVmaW5lZCB2YWx1ZXMgdG8gZW1wdHkgc3RyaW5nIHNvIHdlIGRvbid0IGdldCAndW5kZWZpbmVkJ1xuICBjb25zdCBxdWVyeSA9IG1hdGNoWzZdIHx8ICcnO1xuICBjb25zdCBmcmFnbWVudCA9IG1hdGNoWzhdIHx8ICcnO1xuICByZXR1cm4ge1xuICAgIGhvc3Q6IG1hdGNoWzRdLFxuICAgIHBhdGg6IG1hdGNoWzVdLFxuICAgIHByb3RvY29sOiBtYXRjaFsyXSxcbiAgICBzZWFyY2g6IHF1ZXJ5LFxuICAgIGhhc2g6IGZyYWdtZW50LFxuICAgIHJlbGF0aXZlOiBtYXRjaFs1XSArIHF1ZXJ5ICsgZnJhZ21lbnQsIC8vIGV2ZXJ5dGhpbmcgbWludXMgb3JpZ2luXG4gIH07XG59XG5cbi8qKlxuICogU3RyaXAgdGhlIHF1ZXJ5IHN0cmluZyBhbmQgZnJhZ21lbnQgb2ZmIG9mIGEgZ2l2ZW4gVVJMIG9yIHBhdGggKGlmIHByZXNlbnQpXG4gKlxuICogQHBhcmFtIHVybFBhdGggRnVsbCBVUkwgb3IgcGF0aCwgaW5jbHVkaW5nIHBvc3NpYmxlIHF1ZXJ5IHN0cmluZyBhbmQvb3IgZnJhZ21lbnRcbiAqIEByZXR1cm5zIFVSTCBvciBwYXRoIHdpdGhvdXQgcXVlcnkgc3RyaW5nIG9yIGZyYWdtZW50XG4gKi9cbmZ1bmN0aW9uIHN0cmlwVXJsUXVlcnlBbmRGcmFnbWVudCh1cmxQYXRoKSB7XG4gIHJldHVybiAodXJsUGF0aC5zcGxpdCgvWz8jXS8sIDEpIClbMF07XG59XG5cbi8qKlxuICogVGFrZXMgYSBVUkwgb2JqZWN0IGFuZCByZXR1cm5zIGEgc2FuaXRpemVkIHN0cmluZyB3aGljaCBpcyBzYWZlIHRvIHVzZSBhcyBzcGFuIG5hbWVcbiAqIHNlZTogaHR0cHM6Ly9kZXZlbG9wLnNlbnRyeS5kZXYvc2RrL2RhdGEtaGFuZGxpbmcvI3N0cnVjdHVyaW5nLWRhdGFcbiAqL1xuZnVuY3Rpb24gZ2V0U2FuaXRpemVkVXJsU3RyaW5nKHVybCkge1xuICBjb25zdCB7IHByb3RvY29sLCBob3N0LCBwYXRoIH0gPSB1cmw7XG5cbiAgY29uc3QgZmlsdGVyZWRIb3N0ID1cbiAgICBob3N0XG4gICAgICAvLyBBbHdheXMgZmlsdGVyIG91dCBhdXRob3JpdHlcbiAgICAgID8ucmVwbGFjZSgvXi4qQC8sICdbZmlsdGVyZWRdOltmaWx0ZXJlZF1AJylcbiAgICAgIC8vIERvbid0IHNob3cgc3RhbmRhcmQgOjgwIChodHRwKSBhbmQgOjQ0MyAoaHR0cHMpIHBvcnRzIHRvIHJlZHVjZSB0aGUgbm9pc2VcbiAgICAgIC8vIFRPRE86IFVzZSBuZXcgVVJMIGdsb2JhbCBpZiBpdCBleGlzdHNcbiAgICAgIC5yZXBsYWNlKC8oOjgwKSQvLCAnJylcbiAgICAgIC5yZXBsYWNlKC8oOjQ0MykkLywgJycpIHx8ICcnO1xuXG4gIHJldHVybiBgJHtwcm90b2NvbCA/IGAke3Byb3RvY29sfTovL2AgOiAnJ30ke2ZpbHRlcmVkSG9zdH0ke3BhdGh9YDtcbn1cblxuZXhwb3J0cy5nZXRIdHRwU3BhbkRldGFpbHNGcm9tVXJsT2JqZWN0ID0gZ2V0SHR0cFNwYW5EZXRhaWxzRnJvbVVybE9iamVjdDtcbmV4cG9ydHMuZ2V0U2FuaXRpemVkVXJsU3RyaW5nID0gZ2V0U2FuaXRpemVkVXJsU3RyaW5nO1xuZXhwb3J0cy5nZXRTYW5pdGl6ZWRVcmxTdHJpbmdGcm9tVXJsT2JqZWN0ID0gZ2V0U2FuaXRpemVkVXJsU3RyaW5nRnJvbVVybE9iamVjdDtcbmV4cG9ydHMuaXNVUkxPYmplY3RSZWxhdGl2ZSA9IGlzVVJMT2JqZWN0UmVsYXRpdmU7XG5leHBvcnRzLnBhcnNlU3RyaW5nVG9VUkxPYmplY3QgPSBwYXJzZVN0cmluZ1RvVVJMT2JqZWN0O1xuZXhwb3J0cy5wYXJzZVVybCA9IHBhcnNlVXJsO1xuZXhwb3J0cy5zdHJpcFVybFF1ZXJ5QW5kRnJhZ21lbnQgPSBzdHJpcFVybFF1ZXJ5QW5kRnJhZ21lbnQ7XG4vLyMgc291cmNlTWFwcGluZ1VSTD11cmwuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/url.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/vercel-ai-attributes.js":
/*!******************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/vercel-ai-attributes.js ***!
  \******************************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n/* eslint-disable max-lines */\n/**\n * AI SDK Telemetry Attributes\n * Based on https://ai-sdk.dev/docs/ai-sdk-core/telemetry#collected-data\n */\n\n\n// =============================================================================\n// SHARED ATTRIBUTES\n// =============================================================================\n\n/**\n * `generateText` function - `ai.generateText` span\n * `streamText` function - `ai.streamText` span\n *\n * The prompt that was used when calling the function\n * @see https://ai-sdk.dev/docs/ai-sdk-core/telemetry#generatetext-function\n * @see https://ai-sdk.dev/docs/ai-sdk-core/telemetry#streamtext-function\n */\nconst AI_PROMPT_ATTRIBUTE = 'ai.prompt';\n\n/**\n * `generateObject` function - `ai.generateObject` span\n * `streamObject` function - `ai.streamObject` span\n *\n * The object that was generated (stringified JSON)\n * @see https://ai-sdk.dev/docs/ai-sdk-core/telemetry#generateobject-function\n * @see https://ai-sdk.dev/docs/ai-sdk-core/telemetry#streamobject-function\n */\nconst AI_RESPONSE_OBJECT_ATTRIBUTE = 'ai.response.object';\n\n// =============================================================================\n// GENERATETEXT FUNCTION - UNIQUE ATTRIBUTES\n// =============================================================================\n\n/**\n * `generateText` function - `ai.generateText` span\n *\n * The text that was generated\n * @see https://ai-sdk.dev/docs/ai-sdk-core/telemetry#generatetext-function\n */\nconst AI_RESPONSE_TEXT_ATTRIBUTE = 'ai.response.text';\n\n/**\n * `generateText` function - `ai.generateText` span\n *\n * The tool calls that were made as part of the generation (stringified JSON)\n * @see https://ai-sdk.dev/docs/ai-sdk-core/telemetry#generatetext-function\n */\nconst AI_RESPONSE_TOOL_CALLS_ATTRIBUTE = 'ai.response.toolCalls';\n\n/**\n * `generateText` function - `ai.generateText.doGenerate` span\n *\n * The messages that were passed into the provider\n * @see https://ai-sdk.dev/docs/ai-sdk-core/telemetry#generatetext-function\n */\nconst AI_PROMPT_MESSAGES_ATTRIBUTE = 'ai.prompt.messages';\n\n/**\n * `generateText` function - `ai.generateText.doGenerate` span\n *\n * Array of stringified tool definitions\n * @see https://ai-sdk.dev/docs/ai-sdk-core/telemetry#generatetext-function\n */\nconst AI_PROMPT_TOOLS_ATTRIBUTE = 'ai.prompt.tools';\n\n/**\n * Basic LLM span information\n * Multiple spans\n *\n * The id of the model\n * @see https://ai-sdk.dev/docs/ai-sdk-core/telemetry#basic-llm-span-information\n */\nconst AI_MODEL_ID_ATTRIBUTE = 'ai.model.id';\n\n/**\n * Basic LLM span information\n * Multiple spans\n *\n * The provider of the model\n * @see https://ai-sdk.dev/docs/ai-sdk-core/telemetry#basic-llm-span-information\n */\nconst AI_MODEL_PROVIDER_ATTRIBUTE = 'ai.model.provider';\n\n/**\n * Basic LLM span information\n * Multiple spans\n *\n * Provider specific metadata returned with the generation response\n * @see https://ai-sdk.dev/docs/ai-sdk-core/telemetry#basic-llm-span-information\n */\nconst AI_RESPONSE_PROVIDER_METADATA_ATTRIBUTE = 'ai.response.providerMetadata';\n\n/**\n * Basic LLM span information\n * Multiple spans\n *\n * The functionId that was set through `telemetry.functionId`\n * @see https://ai-sdk.dev/docs/ai-sdk-core/telemetry#basic-llm-span-information\n */\nconst AI_TELEMETRY_FUNCTION_ID_ATTRIBUTE = 'ai.telemetry.functionId';\n\n/**\n * Basic LLM span information\n * Multiple spans\n *\n * The number of completion tokens that were used\n * @see https://ai-sdk.dev/docs/ai-sdk-core/telemetry#basic-llm-span-information\n */\nconst AI_USAGE_COMPLETION_TOKENS_ATTRIBUTE = 'ai.usage.completionTokens';\n\n/**\n * Basic LLM span information\n * Multiple spans\n *\n * The number of prompt tokens that were used\n * @see https://ai-sdk.dev/docs/ai-sdk-core/telemetry#basic-llm-span-information\n */\nconst AI_USAGE_PROMPT_TOKENS_ATTRIBUTE = 'ai.usage.promptTokens';\n\n/**\n * Semantic Conventions for GenAI operations\n * Individual LLM call spans\n *\n * The model that was used to generate the response\n * @see https://ai-sdk.dev/docs/ai-sdk-core/telemetry#call-llm-span-information\n */\nconst GEN_AI_RESPONSE_MODEL_ATTRIBUTE = 'gen_ai.response.model';\n\n/**\n * Semantic Conventions for GenAI operations\n * Individual LLM call spans\n *\n * The number of prompt tokens that were used\n * @see https://ai-sdk.dev/docs/ai-sdk-core/telemetry#call-llm-span-information\n */\nconst GEN_AI_USAGE_INPUT_TOKENS_ATTRIBUTE = 'gen_ai.usage.input_tokens';\n\n/**\n * Semantic Conventions for GenAI operations\n * Individual LLM call spans\n *\n * The number of completion tokens that were used\n * @see https://ai-sdk.dev/docs/ai-sdk-core/telemetry#call-llm-span-information\n */\nconst GEN_AI_USAGE_OUTPUT_TOKENS_ATTRIBUTE = 'gen_ai.usage.output_tokens';\n\n// =============================================================================\n// TOOL CALL SPANS\n// =============================================================================\n\n/**\n * Tool call spans\n * `ai.toolCall` span\n *\n * The name of the tool\n * @see https://ai-sdk.dev/docs/ai-sdk-core/telemetry#tool-call-spans\n */\nconst AI_TOOL_CALL_NAME_ATTRIBUTE = 'ai.toolCall.name';\n\n/**\n * Tool call spans\n * `ai.toolCall` span\n *\n * The id of the tool call\n * @see https://ai-sdk.dev/docs/ai-sdk-core/telemetry#tool-call-spans\n */\nconst AI_TOOL_CALL_ID_ATTRIBUTE = 'ai.toolCall.id';\n\n/**\n * Tool call spans\n * `ai.toolCall` span\n *\n * The parameters of the tool call\n * @see https://ai-sdk.dev/docs/ai-sdk-core/telemetry#tool-call-spans\n */\nconst AI_TOOL_CALL_ARGS_ATTRIBUTE = 'ai.toolCall.args';\n\n/**\n * Tool call spans\n * `ai.toolCall` span\n *\n * The result of the tool call\n * @see https://ai-sdk.dev/docs/ai-sdk-core/telemetry#tool-call-spans\n */\nconst AI_TOOL_CALL_RESULT_ATTRIBUTE = 'ai.toolCall.result';\n\n// =============================================================================\n// PROVIDER METADATA\n// =============================================================================\n\n/**\n * OpenAI Provider Metadata\n * @see https://ai-sdk.dev/providers/ai-sdk-providers/openai\n * @see https://github.com/vercel/ai/blob/65e042afde6aad4da9d7a62526ece839eb34f9a5/packages/openai/src/openai-chat-language-model.ts#L397-L416\n * @see https://github.com/vercel/ai/blob/65e042afde6aad4da9d7a62526ece839eb34f9a5/packages/openai/src/responses/openai-responses-language-model.ts#L377C7-L384\n */\n\nexports.AI_MODEL_ID_ATTRIBUTE = AI_MODEL_ID_ATTRIBUTE;\nexports.AI_MODEL_PROVIDER_ATTRIBUTE = AI_MODEL_PROVIDER_ATTRIBUTE;\nexports.AI_PROMPT_ATTRIBUTE = AI_PROMPT_ATTRIBUTE;\nexports.AI_PROMPT_MESSAGES_ATTRIBUTE = AI_PROMPT_MESSAGES_ATTRIBUTE;\nexports.AI_PROMPT_TOOLS_ATTRIBUTE = AI_PROMPT_TOOLS_ATTRIBUTE;\nexports.AI_RESPONSE_OBJECT_ATTRIBUTE = AI_RESPONSE_OBJECT_ATTRIBUTE;\nexports.AI_RESPONSE_PROVIDER_METADATA_ATTRIBUTE = AI_RESPONSE_PROVIDER_METADATA_ATTRIBUTE;\nexports.AI_RESPONSE_TEXT_ATTRIBUTE = AI_RESPONSE_TEXT_ATTRIBUTE;\nexports.AI_RESPONSE_TOOL_CALLS_ATTRIBUTE = AI_RESPONSE_TOOL_CALLS_ATTRIBUTE;\nexports.AI_TELEMETRY_FUNCTION_ID_ATTRIBUTE = AI_TELEMETRY_FUNCTION_ID_ATTRIBUTE;\nexports.AI_TOOL_CALL_ARGS_ATTRIBUTE = AI_TOOL_CALL_ARGS_ATTRIBUTE;\nexports.AI_TOOL_CALL_ID_ATTRIBUTE = AI_TOOL_CALL_ID_ATTRIBUTE;\nexports.AI_TOOL_CALL_NAME_ATTRIBUTE = AI_TOOL_CALL_NAME_ATTRIBUTE;\nexports.AI_TOOL_CALL_RESULT_ATTRIBUTE = AI_TOOL_CALL_RESULT_ATTRIBUTE;\nexports.AI_USAGE_COMPLETION_TOKENS_ATTRIBUTE = AI_USAGE_COMPLETION_TOKENS_ATTRIBUTE;\nexports.AI_USAGE_PROMPT_TOKENS_ATTRIBUTE = AI_USAGE_PROMPT_TOKENS_ATTRIBUTE;\nexports.GEN_AI_RESPONSE_MODEL_ATTRIBUTE = GEN_AI_RESPONSE_MODEL_ATTRIBUTE;\nexports.GEN_AI_USAGE_INPUT_TOKENS_ATTRIBUTE = GEN_AI_USAGE_INPUT_TOKENS_ATTRIBUTE;\nexports.GEN_AI_USAGE_OUTPUT_TOKENS_ATTRIBUTE = GEN_AI_USAGE_OUTPUT_TOKENS_ATTRIBUTE;\n//# sourceMappingURL=vercel-ai-attributes.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy92ZXJjZWwtYWktYXR0cmlidXRlcy5qcyIsIm1hcHBpbmdzIjoiQUFBQSxxREFBcUQsaUJBQWlCOztBQUV0RTtBQUNBO0FBQ0E7QUFDQTtBQUNBOzs7QUFHQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQSw2QkFBNkI7QUFDN0IsbUNBQW1DO0FBQ25DLDJCQUEyQjtBQUMzQixvQ0FBb0M7QUFDcEMsaUNBQWlDO0FBQ2pDLG9DQUFvQztBQUNwQywrQ0FBK0M7QUFDL0Msa0NBQWtDO0FBQ2xDLHdDQUF3QztBQUN4QywwQ0FBMEM7QUFDMUMsbUNBQW1DO0FBQ25DLGlDQUFpQztBQUNqQyxtQ0FBbUM7QUFDbkMscUNBQXFDO0FBQ3JDLDRDQUE0QztBQUM1Qyx3Q0FBd0M7QUFDeEMsdUNBQXVDO0FBQ3ZDLDJDQUEyQztBQUMzQyw0Q0FBNEM7QUFDNUMiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy92ZXJjZWwtYWktYXR0cmlidXRlcy5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuLyogZXNsaW50LWRpc2FibGUgbWF4LWxpbmVzICovXG4vKipcbiAqIEFJIFNESyBUZWxlbWV0cnkgQXR0cmlidXRlc1xuICogQmFzZWQgb24gaHR0cHM6Ly9haS1zZGsuZGV2L2RvY3MvYWktc2RrLWNvcmUvdGVsZW1ldHJ5I2NvbGxlY3RlZC1kYXRhXG4gKi9cblxuXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuLy8gU0hBUkVEIEFUVFJJQlVURVNcbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG5cbi8qKlxuICogYGdlbmVyYXRlVGV4dGAgZnVuY3Rpb24gLSBgYWkuZ2VuZXJhdGVUZXh0YCBzcGFuXG4gKiBgc3RyZWFtVGV4dGAgZnVuY3Rpb24gLSBgYWkuc3RyZWFtVGV4dGAgc3BhblxuICpcbiAqIFRoZSBwcm9tcHQgdGhhdCB3YXMgdXNlZCB3aGVuIGNhbGxpbmcgdGhlIGZ1bmN0aW9uXG4gKiBAc2VlIGh0dHBzOi8vYWktc2RrLmRldi9kb2NzL2FpLXNkay1jb3JlL3RlbGVtZXRyeSNnZW5lcmF0ZXRleHQtZnVuY3Rpb25cbiAqIEBzZWUgaHR0cHM6Ly9haS1zZGsuZGV2L2RvY3MvYWktc2RrLWNvcmUvdGVsZW1ldHJ5I3N0cmVhbXRleHQtZnVuY3Rpb25cbiAqL1xuY29uc3QgQUlfUFJPTVBUX0FUVFJJQlVURSA9ICdhaS5wcm9tcHQnO1xuXG4vKipcbiAqIGBnZW5lcmF0ZU9iamVjdGAgZnVuY3Rpb24gLSBgYWkuZ2VuZXJhdGVPYmplY3RgIHNwYW5cbiAqIGBzdHJlYW1PYmplY3RgIGZ1bmN0aW9uIC0gYGFpLnN0cmVhbU9iamVjdGAgc3BhblxuICpcbiAqIFRoZSBvYmplY3QgdGhhdCB3YXMgZ2VuZXJhdGVkIChzdHJpbmdpZmllZCBKU09OKVxuICogQHNlZSBodHRwczovL2FpLXNkay5kZXYvZG9jcy9haS1zZGstY29yZS90ZWxlbWV0cnkjZ2VuZXJhdGVvYmplY3QtZnVuY3Rpb25cbiAqIEBzZWUgaHR0cHM6Ly9haS1zZGsuZGV2L2RvY3MvYWktc2RrLWNvcmUvdGVsZW1ldHJ5I3N0cmVhbW9iamVjdC1mdW5jdGlvblxuICovXG5jb25zdCBBSV9SRVNQT05TRV9PQkpFQ1RfQVRUUklCVVRFID0gJ2FpLnJlc3BvbnNlLm9iamVjdCc7XG5cbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG4vLyBHRU5FUkFURVRFWFQgRlVOQ1RJT04gLSBVTklRVUUgQVRUUklCVVRFU1xuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cblxuLyoqXG4gKiBgZ2VuZXJhdGVUZXh0YCBmdW5jdGlvbiAtIGBhaS5nZW5lcmF0ZVRleHRgIHNwYW5cbiAqXG4gKiBUaGUgdGV4dCB0aGF0IHdhcyBnZW5lcmF0ZWRcbiAqIEBzZWUgaHR0cHM6Ly9haS1zZGsuZGV2L2RvY3MvYWktc2RrLWNvcmUvdGVsZW1ldHJ5I2dlbmVyYXRldGV4dC1mdW5jdGlvblxuICovXG5jb25zdCBBSV9SRVNQT05TRV9URVhUX0FUVFJJQlVURSA9ICdhaS5yZXNwb25zZS50ZXh0JztcblxuLyoqXG4gKiBgZ2VuZXJhdGVUZXh0YCBmdW5jdGlvbiAtIGBhaS5nZW5lcmF0ZVRleHRgIHNwYW5cbiAqXG4gKiBUaGUgdG9vbCBjYWxscyB0aGF0IHdlcmUgbWFkZSBhcyBwYXJ0IG9mIHRoZSBnZW5lcmF0aW9uIChzdHJpbmdpZmllZCBKU09OKVxuICogQHNlZSBodHRwczovL2FpLXNkay5kZXYvZG9jcy9haS1zZGstY29yZS90ZWxlbWV0cnkjZ2VuZXJhdGV0ZXh0LWZ1bmN0aW9uXG4gKi9cbmNvbnN0IEFJX1JFU1BPTlNFX1RPT0xfQ0FMTFNfQVRUUklCVVRFID0gJ2FpLnJlc3BvbnNlLnRvb2xDYWxscyc7XG5cbi8qKlxuICogYGdlbmVyYXRlVGV4dGAgZnVuY3Rpb24gLSBgYWkuZ2VuZXJhdGVUZXh0LmRvR2VuZXJhdGVgIHNwYW5cbiAqXG4gKiBUaGUgbWVzc2FnZXMgdGhhdCB3ZXJlIHBhc3NlZCBpbnRvIHRoZSBwcm92aWRlclxuICogQHNlZSBodHRwczovL2FpLXNkay5kZXYvZG9jcy9haS1zZGstY29yZS90ZWxlbWV0cnkjZ2VuZXJhdGV0ZXh0LWZ1bmN0aW9uXG4gKi9cbmNvbnN0IEFJX1BST01QVF9NRVNTQUdFU19BVFRSSUJVVEUgPSAnYWkucHJvbXB0Lm1lc3NhZ2VzJztcblxuLyoqXG4gKiBgZ2VuZXJhdGVUZXh0YCBmdW5jdGlvbiAtIGBhaS5nZW5lcmF0ZVRleHQuZG9HZW5lcmF0ZWAgc3BhblxuICpcbiAqIEFycmF5IG9mIHN0cmluZ2lmaWVkIHRvb2wgZGVmaW5pdGlvbnNcbiAqIEBzZWUgaHR0cHM6Ly9haS1zZGsuZGV2L2RvY3MvYWktc2RrLWNvcmUvdGVsZW1ldHJ5I2dlbmVyYXRldGV4dC1mdW5jdGlvblxuICovXG5jb25zdCBBSV9QUk9NUFRfVE9PTFNfQVRUUklCVVRFID0gJ2FpLnByb21wdC50b29scyc7XG5cbi8qKlxuICogQmFzaWMgTExNIHNwYW4gaW5mb3JtYXRpb25cbiAqIE11bHRpcGxlIHNwYW5zXG4gKlxuICogVGhlIGlkIG9mIHRoZSBtb2RlbFxuICogQHNlZSBodHRwczovL2FpLXNkay5kZXYvZG9jcy9haS1zZGstY29yZS90ZWxlbWV0cnkjYmFzaWMtbGxtLXNwYW4taW5mb3JtYXRpb25cbiAqL1xuY29uc3QgQUlfTU9ERUxfSURfQVRUUklCVVRFID0gJ2FpLm1vZGVsLmlkJztcblxuLyoqXG4gKiBCYXNpYyBMTE0gc3BhbiBpbmZvcm1hdGlvblxuICogTXVsdGlwbGUgc3BhbnNcbiAqXG4gKiBUaGUgcHJvdmlkZXIgb2YgdGhlIG1vZGVsXG4gKiBAc2VlIGh0dHBzOi8vYWktc2RrLmRldi9kb2NzL2FpLXNkay1jb3JlL3RlbGVtZXRyeSNiYXNpYy1sbG0tc3Bhbi1pbmZvcm1hdGlvblxuICovXG5jb25zdCBBSV9NT0RFTF9QUk9WSURFUl9BVFRSSUJVVEUgPSAnYWkubW9kZWwucHJvdmlkZXInO1xuXG4vKipcbiAqIEJhc2ljIExMTSBzcGFuIGluZm9ybWF0aW9uXG4gKiBNdWx0aXBsZSBzcGFuc1xuICpcbiAqIFByb3ZpZGVyIHNwZWNpZmljIG1ldGFkYXRhIHJldHVybmVkIHdpdGggdGhlIGdlbmVyYXRpb24gcmVzcG9uc2VcbiAqIEBzZWUgaHR0cHM6Ly9haS1zZGsuZGV2L2RvY3MvYWktc2RrLWNvcmUvdGVsZW1ldHJ5I2Jhc2ljLWxsbS1zcGFuLWluZm9ybWF0aW9uXG4gKi9cbmNvbnN0IEFJX1JFU1BPTlNFX1BST1ZJREVSX01FVEFEQVRBX0FUVFJJQlVURSA9ICdhaS5yZXNwb25zZS5wcm92aWRlck1ldGFkYXRhJztcblxuLyoqXG4gKiBCYXNpYyBMTE0gc3BhbiBpbmZvcm1hdGlvblxuICogTXVsdGlwbGUgc3BhbnNcbiAqXG4gKiBUaGUgZnVuY3Rpb25JZCB0aGF0IHdhcyBzZXQgdGhyb3VnaCBgdGVsZW1ldHJ5LmZ1bmN0aW9uSWRgXG4gKiBAc2VlIGh0dHBzOi8vYWktc2RrLmRldi9kb2NzL2FpLXNkay1jb3JlL3RlbGVtZXRyeSNiYXNpYy1sbG0tc3Bhbi1pbmZvcm1hdGlvblxuICovXG5jb25zdCBBSV9URUxFTUVUUllfRlVOQ1RJT05fSURfQVRUUklCVVRFID0gJ2FpLnRlbGVtZXRyeS5mdW5jdGlvbklkJztcblxuLyoqXG4gKiBCYXNpYyBMTE0gc3BhbiBpbmZvcm1hdGlvblxuICogTXVsdGlwbGUgc3BhbnNcbiAqXG4gKiBUaGUgbnVtYmVyIG9mIGNvbXBsZXRpb24gdG9rZW5zIHRoYXQgd2VyZSB1c2VkXG4gKiBAc2VlIGh0dHBzOi8vYWktc2RrLmRldi9kb2NzL2FpLXNkay1jb3JlL3RlbGVtZXRyeSNiYXNpYy1sbG0tc3Bhbi1pbmZvcm1hdGlvblxuICovXG5jb25zdCBBSV9VU0FHRV9DT01QTEVUSU9OX1RPS0VOU19BVFRSSUJVVEUgPSAnYWkudXNhZ2UuY29tcGxldGlvblRva2Vucyc7XG5cbi8qKlxuICogQmFzaWMgTExNIHNwYW4gaW5mb3JtYXRpb25cbiAqIE11bHRpcGxlIHNwYW5zXG4gKlxuICogVGhlIG51bWJlciBvZiBwcm9tcHQgdG9rZW5zIHRoYXQgd2VyZSB1c2VkXG4gKiBAc2VlIGh0dHBzOi8vYWktc2RrLmRldi9kb2NzL2FpLXNkay1jb3JlL3RlbGVtZXRyeSNiYXNpYy1sbG0tc3Bhbi1pbmZvcm1hdGlvblxuICovXG5jb25zdCBBSV9VU0FHRV9QUk9NUFRfVE9LRU5TX0FUVFJJQlVURSA9ICdhaS51c2FnZS5wcm9tcHRUb2tlbnMnO1xuXG4vKipcbiAqIFNlbWFudGljIENvbnZlbnRpb25zIGZvciBHZW5BSSBvcGVyYXRpb25zXG4gKiBJbmRpdmlkdWFsIExMTSBjYWxsIHNwYW5zXG4gKlxuICogVGhlIG1vZGVsIHRoYXQgd2FzIHVzZWQgdG8gZ2VuZXJhdGUgdGhlIHJlc3BvbnNlXG4gKiBAc2VlIGh0dHBzOi8vYWktc2RrLmRldi9kb2NzL2FpLXNkay1jb3JlL3RlbGVtZXRyeSNjYWxsLWxsbS1zcGFuLWluZm9ybWF0aW9uXG4gKi9cbmNvbnN0IEdFTl9BSV9SRVNQT05TRV9NT0RFTF9BVFRSSUJVVEUgPSAnZ2VuX2FpLnJlc3BvbnNlLm1vZGVsJztcblxuLyoqXG4gKiBTZW1hbnRpYyBDb252ZW50aW9ucyBmb3IgR2VuQUkgb3BlcmF0aW9uc1xuICogSW5kaXZpZHVhbCBMTE0gY2FsbCBzcGFuc1xuICpcbiAqIFRoZSBudW1iZXIgb2YgcHJvbXB0IHRva2VucyB0aGF0IHdlcmUgdXNlZFxuICogQHNlZSBodHRwczovL2FpLXNkay5kZXYvZG9jcy9haS1zZGstY29yZS90ZWxlbWV0cnkjY2FsbC1sbG0tc3Bhbi1pbmZvcm1hdGlvblxuICovXG5jb25zdCBHRU5fQUlfVVNBR0VfSU5QVVRfVE9LRU5TX0FUVFJJQlVURSA9ICdnZW5fYWkudXNhZ2UuaW5wdXRfdG9rZW5zJztcblxuLyoqXG4gKiBTZW1hbnRpYyBDb252ZW50aW9ucyBmb3IgR2VuQUkgb3BlcmF0aW9uc1xuICogSW5kaXZpZHVhbCBMTE0gY2FsbCBzcGFuc1xuICpcbiAqIFRoZSBudW1iZXIgb2YgY29tcGxldGlvbiB0b2tlbnMgdGhhdCB3ZXJlIHVzZWRcbiAqIEBzZWUgaHR0cHM6Ly9haS1zZGsuZGV2L2RvY3MvYWktc2RrLWNvcmUvdGVsZW1ldHJ5I2NhbGwtbGxtLXNwYW4taW5mb3JtYXRpb25cbiAqL1xuY29uc3QgR0VOX0FJX1VTQUdFX09VVFBVVF9UT0tFTlNfQVRUUklCVVRFID0gJ2dlbl9haS51c2FnZS5vdXRwdXRfdG9rZW5zJztcblxuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cbi8vIFRPT0wgQ0FMTCBTUEFOU1xuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cblxuLyoqXG4gKiBUb29sIGNhbGwgc3BhbnNcbiAqIGBhaS50b29sQ2FsbGAgc3BhblxuICpcbiAqIFRoZSBuYW1lIG9mIHRoZSB0b29sXG4gKiBAc2VlIGh0dHBzOi8vYWktc2RrLmRldi9kb2NzL2FpLXNkay1jb3JlL3RlbGVtZXRyeSN0b29sLWNhbGwtc3BhbnNcbiAqL1xuY29uc3QgQUlfVE9PTF9DQUxMX05BTUVfQVRUUklCVVRFID0gJ2FpLnRvb2xDYWxsLm5hbWUnO1xuXG4vKipcbiAqIFRvb2wgY2FsbCBzcGFuc1xuICogYGFpLnRvb2xDYWxsYCBzcGFuXG4gKlxuICogVGhlIGlkIG9mIHRoZSB0b29sIGNhbGxcbiAqIEBzZWUgaHR0cHM6Ly9haS1zZGsuZGV2L2RvY3MvYWktc2RrLWNvcmUvdGVsZW1ldHJ5I3Rvb2wtY2FsbC1zcGFuc1xuICovXG5jb25zdCBBSV9UT09MX0NBTExfSURfQVRUUklCVVRFID0gJ2FpLnRvb2xDYWxsLmlkJztcblxuLyoqXG4gKiBUb29sIGNhbGwgc3BhbnNcbiAqIGBhaS50b29sQ2FsbGAgc3BhblxuICpcbiAqIFRoZSBwYXJhbWV0ZXJzIG9mIHRoZSB0b29sIGNhbGxcbiAqIEBzZWUgaHR0cHM6Ly9haS1zZGsuZGV2L2RvY3MvYWktc2RrLWNvcmUvdGVsZW1ldHJ5I3Rvb2wtY2FsbC1zcGFuc1xuICovXG5jb25zdCBBSV9UT09MX0NBTExfQVJHU19BVFRSSUJVVEUgPSAnYWkudG9vbENhbGwuYXJncyc7XG5cbi8qKlxuICogVG9vbCBjYWxsIHNwYW5zXG4gKiBgYWkudG9vbENhbGxgIHNwYW5cbiAqXG4gKiBUaGUgcmVzdWx0IG9mIHRoZSB0b29sIGNhbGxcbiAqIEBzZWUgaHR0cHM6Ly9haS1zZGsuZGV2L2RvY3MvYWktc2RrLWNvcmUvdGVsZW1ldHJ5I3Rvb2wtY2FsbC1zcGFuc1xuICovXG5jb25zdCBBSV9UT09MX0NBTExfUkVTVUxUX0FUVFJJQlVURSA9ICdhaS50b29sQ2FsbC5yZXN1bHQnO1xuXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuLy8gUFJPVklERVIgTUVUQURBVEFcbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG5cbi8qKlxuICogT3BlbkFJIFByb3ZpZGVyIE1ldGFkYXRhXG4gKiBAc2VlIGh0dHBzOi8vYWktc2RrLmRldi9wcm92aWRlcnMvYWktc2RrLXByb3ZpZGVycy9vcGVuYWlcbiAqIEBzZWUgaHR0cHM6Ly9naXRodWIuY29tL3ZlcmNlbC9haS9ibG9iLzY1ZTA0MmFmZGU2YWFkNGRhOWQ3YTYyNTI2ZWNlODM5ZWIzNGY5YTUvcGFja2FnZXMvb3BlbmFpL3NyYy9vcGVuYWktY2hhdC1sYW5ndWFnZS1tb2RlbC50cyNMMzk3LUw0MTZcbiAqIEBzZWUgaHR0cHM6Ly9naXRodWIuY29tL3ZlcmNlbC9haS9ibG9iLzY1ZTA0MmFmZGU2YWFkNGRhOWQ3YTYyNTI2ZWNlODM5ZWIzNGY5YTUvcGFja2FnZXMvb3BlbmFpL3NyYy9yZXNwb25zZXMvb3BlbmFpLXJlc3BvbnNlcy1sYW5ndWFnZS1tb2RlbC50cyNMMzc3QzctTDM4NFxuICovXG5cbmV4cG9ydHMuQUlfTU9ERUxfSURfQVRUUklCVVRFID0gQUlfTU9ERUxfSURfQVRUUklCVVRFO1xuZXhwb3J0cy5BSV9NT0RFTF9QUk9WSURFUl9BVFRSSUJVVEUgPSBBSV9NT0RFTF9QUk9WSURFUl9BVFRSSUJVVEU7XG5leHBvcnRzLkFJX1BST01QVF9BVFRSSUJVVEUgPSBBSV9QUk9NUFRfQVRUUklCVVRFO1xuZXhwb3J0cy5BSV9QUk9NUFRfTUVTU0FHRVNfQVRUUklCVVRFID0gQUlfUFJPTVBUX01FU1NBR0VTX0FUVFJJQlVURTtcbmV4cG9ydHMuQUlfUFJPTVBUX1RPT0xTX0FUVFJJQlVURSA9IEFJX1BST01QVF9UT09MU19BVFRSSUJVVEU7XG5leHBvcnRzLkFJX1JFU1BPTlNFX09CSkVDVF9BVFRSSUJVVEUgPSBBSV9SRVNQT05TRV9PQkpFQ1RfQVRUUklCVVRFO1xuZXhwb3J0cy5BSV9SRVNQT05TRV9QUk9WSURFUl9NRVRBREFUQV9BVFRSSUJVVEUgPSBBSV9SRVNQT05TRV9QUk9WSURFUl9NRVRBREFUQV9BVFRSSUJVVEU7XG5leHBvcnRzLkFJX1JFU1BPTlNFX1RFWFRfQVRUUklCVVRFID0gQUlfUkVTUE9OU0VfVEVYVF9BVFRSSUJVVEU7XG5leHBvcnRzLkFJX1JFU1BPTlNFX1RPT0xfQ0FMTFNfQVRUUklCVVRFID0gQUlfUkVTUE9OU0VfVE9PTF9DQUxMU19BVFRSSUJVVEU7XG5leHBvcnRzLkFJX1RFTEVNRVRSWV9GVU5DVElPTl9JRF9BVFRSSUJVVEUgPSBBSV9URUxFTUVUUllfRlVOQ1RJT05fSURfQVRUUklCVVRFO1xuZXhwb3J0cy5BSV9UT09MX0NBTExfQVJHU19BVFRSSUJVVEUgPSBBSV9UT09MX0NBTExfQVJHU19BVFRSSUJVVEU7XG5leHBvcnRzLkFJX1RPT0xfQ0FMTF9JRF9BVFRSSUJVVEUgPSBBSV9UT09MX0NBTExfSURfQVRUUklCVVRFO1xuZXhwb3J0cy5BSV9UT09MX0NBTExfTkFNRV9BVFRSSUJVVEUgPSBBSV9UT09MX0NBTExfTkFNRV9BVFRSSUJVVEU7XG5leHBvcnRzLkFJX1RPT0xfQ0FMTF9SRVNVTFRfQVRUUklCVVRFID0gQUlfVE9PTF9DQUxMX1JFU1VMVF9BVFRSSUJVVEU7XG5leHBvcnRzLkFJX1VTQUdFX0NPTVBMRVRJT05fVE9LRU5TX0FUVFJJQlVURSA9IEFJX1VTQUdFX0NPTVBMRVRJT05fVE9LRU5TX0FUVFJJQlVURTtcbmV4cG9ydHMuQUlfVVNBR0VfUFJPTVBUX1RPS0VOU19BVFRSSUJVVEUgPSBBSV9VU0FHRV9QUk9NUFRfVE9LRU5TX0FUVFJJQlVURTtcbmV4cG9ydHMuR0VOX0FJX1JFU1BPTlNFX01PREVMX0FUVFJJQlVURSA9IEdFTl9BSV9SRVNQT05TRV9NT0RFTF9BVFRSSUJVVEU7XG5leHBvcnRzLkdFTl9BSV9VU0FHRV9JTlBVVF9UT0tFTlNfQVRUUklCVVRFID0gR0VOX0FJX1VTQUdFX0lOUFVUX1RPS0VOU19BVFRSSUJVVEU7XG5leHBvcnRzLkdFTl9BSV9VU0FHRV9PVVRQVVRfVE9LRU5TX0FUVFJJQlVURSA9IEdFTl9BSV9VU0FHRV9PVVRQVVRfVE9LRU5TX0FUVFJJQlVURTtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPXZlcmNlbC1haS1hdHRyaWJ1dGVzLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/vercel-ai-attributes.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/vercel-ai.js":
/*!*******************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/vercel-ai.js ***!
  \*******************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst semanticAttributes = __webpack_require__(/*! ../semanticAttributes.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/semanticAttributes.js\");\nconst spanUtils = __webpack_require__(/*! ./spanUtils.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/spanUtils.js\");\nconst vercelAiAttributes = __webpack_require__(/*! ./vercel-ai-attributes.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/vercel-ai-attributes.js\");\n\nfunction addOriginToSpan(span, origin) {\n  span.setAttribute(semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_ORIGIN, origin);\n}\n\n/**\n * Post-process spans emitted by the Vercel AI SDK.\n * This is supposed to be used in `client.on('spanStart', ...)\n */\nfunction onVercelAiSpanStart(span) {\n  const { data: attributes, description: name } = spanUtils.spanToJSON(span);\n\n  if (!name) {\n    return;\n  }\n\n  // Tool call spans\n  // https://ai-sdk.dev/docs/ai-sdk-core/telemetry#tool-call-spans\n  if (attributes[vercelAiAttributes.AI_TOOL_CALL_NAME_ATTRIBUTE] && attributes[vercelAiAttributes.AI_TOOL_CALL_ID_ATTRIBUTE] && name === 'ai.toolCall') {\n    processToolCallSpan(span, attributes);\n    return;\n  }\n\n  // The AI and Provider must be defined for generate, stream, and embed spans.\n  // The id of the model\n  const aiModelId = attributes[vercelAiAttributes.AI_MODEL_ID_ATTRIBUTE];\n  // the provider of the model\n  const aiModelProvider = attributes[vercelAiAttributes.AI_MODEL_PROVIDER_ATTRIBUTE];\n  if (typeof aiModelId !== 'string' || typeof aiModelProvider !== 'string' || !aiModelId || !aiModelProvider) {\n    return;\n  }\n\n  processGenerateSpan(span, name, attributes);\n}\n\nfunction vercelAiEventProcessor(event) {\n  if (event.type === 'transaction' && event.spans) {\n    for (const span of event.spans) {\n      // this mutates spans in-place\n      processEndedVercelAiSpan(span);\n    }\n  }\n  return event;\n}\n/**\n * Post-process spans emitted by the Vercel AI SDK.\n */\nfunction processEndedVercelAiSpan(span) {\n  const { data: attributes, origin } = span;\n\n  if (origin !== 'auto.vercelai.otel') {\n    return;\n  }\n\n  renameAttributeKey(attributes, vercelAiAttributes.AI_USAGE_COMPLETION_TOKENS_ATTRIBUTE, vercelAiAttributes.GEN_AI_USAGE_OUTPUT_TOKENS_ATTRIBUTE);\n  renameAttributeKey(attributes, vercelAiAttributes.AI_USAGE_PROMPT_TOKENS_ATTRIBUTE, vercelAiAttributes.GEN_AI_USAGE_INPUT_TOKENS_ATTRIBUTE);\n\n  if (\n    typeof attributes[vercelAiAttributes.GEN_AI_USAGE_OUTPUT_TOKENS_ATTRIBUTE] === 'number' &&\n    typeof attributes[vercelAiAttributes.GEN_AI_USAGE_INPUT_TOKENS_ATTRIBUTE] === 'number'\n  ) {\n    attributes['gen_ai.usage.total_tokens'] =\n      attributes[vercelAiAttributes.GEN_AI_USAGE_OUTPUT_TOKENS_ATTRIBUTE] + attributes[vercelAiAttributes.GEN_AI_USAGE_INPUT_TOKENS_ATTRIBUTE];\n  }\n\n  // Rename AI SDK attributes to standardized gen_ai attributes\n  renameAttributeKey(attributes, vercelAiAttributes.AI_PROMPT_MESSAGES_ATTRIBUTE, 'gen_ai.request.messages');\n  renameAttributeKey(attributes, vercelAiAttributes.AI_RESPONSE_TEXT_ATTRIBUTE, 'gen_ai.response.text');\n  renameAttributeKey(attributes, vercelAiAttributes.AI_RESPONSE_TOOL_CALLS_ATTRIBUTE, 'gen_ai.response.tool_calls');\n  renameAttributeKey(attributes, vercelAiAttributes.AI_RESPONSE_OBJECT_ATTRIBUTE, 'gen_ai.response.object');\n  renameAttributeKey(attributes, vercelAiAttributes.AI_PROMPT_TOOLS_ATTRIBUTE, 'gen_ai.request.available_tools');\n\n  renameAttributeKey(attributes, vercelAiAttributes.AI_TOOL_CALL_ARGS_ATTRIBUTE, 'gen_ai.tool.input');\n  renameAttributeKey(attributes, vercelAiAttributes.AI_TOOL_CALL_RESULT_ATTRIBUTE, 'gen_ai.tool.output');\n\n  addProviderMetadataToAttributes(attributes);\n\n  // Change attributes namespaced with `ai.X` to `vercel.ai.X`\n  for (const key of Object.keys(attributes)) {\n    if (key.startsWith('ai.')) {\n      renameAttributeKey(attributes, key, `vercel.${key}`);\n    }\n  }\n}\n\n/**\n * Renames an attribute key in the provided attributes object if the old key exists.\n * This function safely handles null and undefined values.\n */\nfunction renameAttributeKey(attributes, oldKey, newKey) {\n  if (attributes[oldKey] != null) {\n    attributes[newKey] = attributes[oldKey];\n    // eslint-disable-next-line @typescript-eslint/no-dynamic-delete\n    delete attributes[oldKey];\n  }\n}\n\nfunction processToolCallSpan(span, attributes) {\n  addOriginToSpan(span, 'auto.vercelai.otel');\n  span.setAttribute(semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_OP, 'gen_ai.execute_tool');\n  renameAttributeKey(attributes, vercelAiAttributes.AI_TOOL_CALL_NAME_ATTRIBUTE, 'gen_ai.tool.name');\n  renameAttributeKey(attributes, vercelAiAttributes.AI_TOOL_CALL_ID_ATTRIBUTE, 'gen_ai.tool.call.id');\n  // https://opentelemetry.io/docs/specs/semconv/registry/attributes/gen-ai/#gen-ai-tool-type\n  if (!attributes['gen_ai.tool.type']) {\n    span.setAttribute('gen_ai.tool.type', 'function');\n  }\n  const toolName = attributes['gen_ai.tool.name'];\n  if (toolName) {\n    span.updateName(`execute_tool ${toolName}`);\n  }\n}\n\nfunction processGenerateSpan(span, name, attributes) {\n  addOriginToSpan(span, 'auto.vercelai.otel');\n\n  const nameWthoutAi = name.replace('ai.', '');\n  span.setAttribute('ai.pipeline.name', nameWthoutAi);\n  span.updateName(nameWthoutAi);\n\n  // If a Telemetry name is set and it is a pipeline span, use that as the operation name\n  const functionId = attributes[vercelAiAttributes.AI_TELEMETRY_FUNCTION_ID_ATTRIBUTE];\n  if (functionId && typeof functionId === 'string' && name.split('.').length - 1 === 1) {\n    span.updateName(`${nameWthoutAi} ${functionId}`);\n    span.setAttribute('gen_ai.function_id', functionId);\n  }\n\n  if (attributes[vercelAiAttributes.AI_PROMPT_ATTRIBUTE]) {\n    span.setAttribute('gen_ai.prompt', attributes[vercelAiAttributes.AI_PROMPT_ATTRIBUTE]);\n  }\n  if (attributes[vercelAiAttributes.AI_MODEL_ID_ATTRIBUTE] && !attributes[vercelAiAttributes.GEN_AI_RESPONSE_MODEL_ATTRIBUTE]) {\n    span.setAttribute(vercelAiAttributes.GEN_AI_RESPONSE_MODEL_ATTRIBUTE, attributes[vercelAiAttributes.AI_MODEL_ID_ATTRIBUTE]);\n  }\n  span.setAttribute('ai.streaming', name.includes('stream'));\n\n  // Generate Spans\n  if (name === 'ai.generateText') {\n    span.setAttribute(semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_OP, 'gen_ai.invoke_agent');\n    return;\n  }\n\n  if (name === 'ai.generateText.doGenerate') {\n    span.setAttribute(semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_OP, 'gen_ai.generate_text');\n    span.updateName(`generate_text ${attributes[vercelAiAttributes.AI_MODEL_ID_ATTRIBUTE]}`);\n    return;\n  }\n\n  if (name === 'ai.streamText') {\n    span.setAttribute(semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_OP, 'gen_ai.invoke_agent');\n    return;\n  }\n\n  if (name === 'ai.streamText.doStream') {\n    span.setAttribute(semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_OP, 'gen_ai.stream_text');\n    span.updateName(`stream_text ${attributes[vercelAiAttributes.AI_MODEL_ID_ATTRIBUTE]}`);\n    return;\n  }\n\n  if (name === 'ai.generateObject') {\n    span.setAttribute(semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_OP, 'gen_ai.invoke_agent');\n    return;\n  }\n\n  if (name === 'ai.generateObject.doGenerate') {\n    span.setAttribute(semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_OP, 'gen_ai.generate_object');\n    span.updateName(`generate_object ${attributes[vercelAiAttributes.AI_MODEL_ID_ATTRIBUTE]}`);\n    return;\n  }\n\n  if (name === 'ai.streamObject') {\n    span.setAttribute(semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_OP, 'gen_ai.invoke_agent');\n    return;\n  }\n\n  if (name === 'ai.streamObject.doStream') {\n    span.setAttribute(semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_OP, 'gen_ai.stream_object');\n    span.updateName(`stream_object ${attributes[vercelAiAttributes.AI_MODEL_ID_ATTRIBUTE]}`);\n    return;\n  }\n\n  if (name === 'ai.embed') {\n    span.setAttribute(semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_OP, 'gen_ai.invoke_agent');\n    return;\n  }\n\n  if (name === 'ai.embed.doEmbed') {\n    span.setAttribute(semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_OP, 'gen_ai.embed');\n    span.updateName(`embed ${attributes[vercelAiAttributes.AI_MODEL_ID_ATTRIBUTE]}`);\n    return;\n  }\n\n  if (name === 'ai.embedMany') {\n    span.setAttribute(semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_OP, 'gen_ai.invoke_agent');\n    return;\n  }\n\n  if (name === 'ai.embedMany.doEmbed') {\n    span.setAttribute(semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_OP, 'gen_ai.embed_many');\n    span.updateName(`embed_many ${attributes[vercelAiAttributes.AI_MODEL_ID_ATTRIBUTE]}`);\n    return;\n  }\n\n  if (name.startsWith('ai.stream')) {\n    span.setAttribute(semanticAttributes.SEMANTIC_ATTRIBUTE_SENTRY_OP, 'ai.run');\n    return;\n  }\n}\n\n/**\n * Add event processors to the given client to process Vercel AI spans.\n */\nfunction addVercelAiProcessors(client) {\n  client.on('spanStart', onVercelAiSpanStart);\n  // Note: We cannot do this on `spanEnd`, because the span cannot be mutated anymore at this point\n  client.addEventProcessor(Object.assign(vercelAiEventProcessor, { id: 'VercelAiEventProcessor' }));\n}\n\nfunction addProviderMetadataToAttributes(attributes) {\n  const providerMetadata = attributes[vercelAiAttributes.AI_RESPONSE_PROVIDER_METADATA_ATTRIBUTE] ;\n  if (providerMetadata) {\n    try {\n      const providerMetadataObject = JSON.parse(providerMetadata) ;\n      if (providerMetadataObject.openai) {\n        setAttributeIfDefined(\n          attributes,\n          'gen_ai.usage.input_tokens.cached',\n          providerMetadataObject.openai.cachedPromptTokens,\n        );\n        setAttributeIfDefined(\n          attributes,\n          'gen_ai.usage.output_tokens.reasoning',\n          providerMetadataObject.openai.reasoningTokens,\n        );\n        setAttributeIfDefined(\n          attributes,\n          'gen_ai.usage.output_tokens.prediction_accepted',\n          providerMetadataObject.openai.acceptedPredictionTokens,\n        );\n        setAttributeIfDefined(\n          attributes,\n          'gen_ai.usage.output_tokens.prediction_rejected',\n          providerMetadataObject.openai.rejectedPredictionTokens,\n        );\n        setAttributeIfDefined(attributes, 'gen_ai.conversation.id', providerMetadataObject.openai.responseId);\n      }\n\n      if (providerMetadataObject.anthropic) {\n        setAttributeIfDefined(\n          attributes,\n          'gen_ai.usage.input_tokens.cached',\n          providerMetadataObject.anthropic.cacheReadInputTokens,\n        );\n        setAttributeIfDefined(\n          attributes,\n          'gen_ai.usage.input_tokens.cache_write',\n          providerMetadataObject.anthropic.cacheCreationInputTokens,\n        );\n      }\n\n      if (providerMetadataObject.bedrock?.usage) {\n        setAttributeIfDefined(\n          attributes,\n          'gen_ai.usage.input_tokens.cached',\n          providerMetadataObject.bedrock.usage.cacheReadInputTokens,\n        );\n        setAttributeIfDefined(\n          attributes,\n          'gen_ai.usage.input_tokens.cache_write',\n          providerMetadataObject.bedrock.usage.cacheWriteInputTokens,\n        );\n      }\n\n      if (providerMetadataObject.deepseek) {\n        setAttributeIfDefined(\n          attributes,\n          'gen_ai.usage.input_tokens.cached',\n          providerMetadataObject.deepseek.promptCacheHitTokens,\n        );\n        setAttributeIfDefined(\n          attributes,\n          'gen_ai.usage.input_tokens.cache_miss',\n          providerMetadataObject.deepseek.promptCacheMissTokens,\n        );\n      }\n    } catch {\n      // Ignore\n    }\n  }\n}\n\n/**\n * Sets an attribute only if the value is not null or undefined.\n */\nfunction setAttributeIfDefined(attributes, key, value) {\n  if (value != null) {\n    attributes[key] = value;\n  }\n}\n\nexports.addVercelAiProcessors = addVercelAiProcessors;\n//# sourceMappingURL=vercel-ai.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy92ZXJjZWwtYWkuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsMkJBQTJCLG1CQUFPLENBQUMsMElBQTBCO0FBQzdELGtCQUFrQixtQkFBTyxDQUFDLDZIQUFnQjtBQUMxQywyQkFBMkIsbUJBQU8sQ0FBQyxtSkFBMkI7O0FBRTlEO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsVUFBVSxzQ0FBc0M7O0FBRWhEO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsVUFBVSwyQkFBMkI7O0FBRXJDO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBLG9EQUFvRCxJQUFJO0FBQ3hEO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxvQ0FBb0MsU0FBUztBQUM3QztBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBLHVCQUF1QixjQUFjLEVBQUUsV0FBVztBQUNsRDtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLHFDQUFxQyxxREFBcUQ7QUFDMUY7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsbUNBQW1DLHFEQUFxRDtBQUN4RjtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQSx1Q0FBdUMscURBQXFEO0FBQzVGO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBLHFDQUFxQyxxREFBcUQ7QUFDMUY7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0EsNkJBQTZCLHFEQUFxRDtBQUNsRjtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQSxrQ0FBa0MscURBQXFEO0FBQ3ZGO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxtRUFBbUUsOEJBQThCO0FBQ2pHOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsTUFBTTtBQUNOO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsNkJBQTZCO0FBQzdCIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvdmVyY2VsLWFpLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCBzZW1hbnRpY0F0dHJpYnV0ZXMgPSByZXF1aXJlKCcuLi9zZW1hbnRpY0F0dHJpYnV0ZXMuanMnKTtcbmNvbnN0IHNwYW5VdGlscyA9IHJlcXVpcmUoJy4vc3BhblV0aWxzLmpzJyk7XG5jb25zdCB2ZXJjZWxBaUF0dHJpYnV0ZXMgPSByZXF1aXJlKCcuL3ZlcmNlbC1haS1hdHRyaWJ1dGVzLmpzJyk7XG5cbmZ1bmN0aW9uIGFkZE9yaWdpblRvU3BhbihzcGFuLCBvcmlnaW4pIHtcbiAgc3Bhbi5zZXRBdHRyaWJ1dGUoc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfT1JJR0lOLCBvcmlnaW4pO1xufVxuXG4vKipcbiAqIFBvc3QtcHJvY2VzcyBzcGFucyBlbWl0dGVkIGJ5IHRoZSBWZXJjZWwgQUkgU0RLLlxuICogVGhpcyBpcyBzdXBwb3NlZCB0byBiZSB1c2VkIGluIGBjbGllbnQub24oJ3NwYW5TdGFydCcsIC4uLilcbiAqL1xuZnVuY3Rpb24gb25WZXJjZWxBaVNwYW5TdGFydChzcGFuKSB7XG4gIGNvbnN0IHsgZGF0YTogYXR0cmlidXRlcywgZGVzY3JpcHRpb246IG5hbWUgfSA9IHNwYW5VdGlscy5zcGFuVG9KU09OKHNwYW4pO1xuXG4gIGlmICghbmFtZSkge1xuICAgIHJldHVybjtcbiAgfVxuXG4gIC8vIFRvb2wgY2FsbCBzcGFuc1xuICAvLyBodHRwczovL2FpLXNkay5kZXYvZG9jcy9haS1zZGstY29yZS90ZWxlbWV0cnkjdG9vbC1jYWxsLXNwYW5zXG4gIGlmIChhdHRyaWJ1dGVzW3ZlcmNlbEFpQXR0cmlidXRlcy5BSV9UT09MX0NBTExfTkFNRV9BVFRSSUJVVEVdICYmIGF0dHJpYnV0ZXNbdmVyY2VsQWlBdHRyaWJ1dGVzLkFJX1RPT0xfQ0FMTF9JRF9BVFRSSUJVVEVdICYmIG5hbWUgPT09ICdhaS50b29sQ2FsbCcpIHtcbiAgICBwcm9jZXNzVG9vbENhbGxTcGFuKHNwYW4sIGF0dHJpYnV0ZXMpO1xuICAgIHJldHVybjtcbiAgfVxuXG4gIC8vIFRoZSBBSSBhbmQgUHJvdmlkZXIgbXVzdCBiZSBkZWZpbmVkIGZvciBnZW5lcmF0ZSwgc3RyZWFtLCBhbmQgZW1iZWQgc3BhbnMuXG4gIC8vIFRoZSBpZCBvZiB0aGUgbW9kZWxcbiAgY29uc3QgYWlNb2RlbElkID0gYXR0cmlidXRlc1t2ZXJjZWxBaUF0dHJpYnV0ZXMuQUlfTU9ERUxfSURfQVRUUklCVVRFXTtcbiAgLy8gdGhlIHByb3ZpZGVyIG9mIHRoZSBtb2RlbFxuICBjb25zdCBhaU1vZGVsUHJvdmlkZXIgPSBhdHRyaWJ1dGVzW3ZlcmNlbEFpQXR0cmlidXRlcy5BSV9NT0RFTF9QUk9WSURFUl9BVFRSSUJVVEVdO1xuICBpZiAodHlwZW9mIGFpTW9kZWxJZCAhPT0gJ3N0cmluZycgfHwgdHlwZW9mIGFpTW9kZWxQcm92aWRlciAhPT0gJ3N0cmluZycgfHwgIWFpTW9kZWxJZCB8fCAhYWlNb2RlbFByb3ZpZGVyKSB7XG4gICAgcmV0dXJuO1xuICB9XG5cbiAgcHJvY2Vzc0dlbmVyYXRlU3BhbihzcGFuLCBuYW1lLCBhdHRyaWJ1dGVzKTtcbn1cblxuZnVuY3Rpb24gdmVyY2VsQWlFdmVudFByb2Nlc3NvcihldmVudCkge1xuICBpZiAoZXZlbnQudHlwZSA9PT0gJ3RyYW5zYWN0aW9uJyAmJiBldmVudC5zcGFucykge1xuICAgIGZvciAoY29uc3Qgc3BhbiBvZiBldmVudC5zcGFucykge1xuICAgICAgLy8gdGhpcyBtdXRhdGVzIHNwYW5zIGluLXBsYWNlXG4gICAgICBwcm9jZXNzRW5kZWRWZXJjZWxBaVNwYW4oc3Bhbik7XG4gICAgfVxuICB9XG4gIHJldHVybiBldmVudDtcbn1cbi8qKlxuICogUG9zdC1wcm9jZXNzIHNwYW5zIGVtaXR0ZWQgYnkgdGhlIFZlcmNlbCBBSSBTREsuXG4gKi9cbmZ1bmN0aW9uIHByb2Nlc3NFbmRlZFZlcmNlbEFpU3BhbihzcGFuKSB7XG4gIGNvbnN0IHsgZGF0YTogYXR0cmlidXRlcywgb3JpZ2luIH0gPSBzcGFuO1xuXG4gIGlmIChvcmlnaW4gIT09ICdhdXRvLnZlcmNlbGFpLm90ZWwnKSB7XG4gICAgcmV0dXJuO1xuICB9XG5cbiAgcmVuYW1lQXR0cmlidXRlS2V5KGF0dHJpYnV0ZXMsIHZlcmNlbEFpQXR0cmlidXRlcy5BSV9VU0FHRV9DT01QTEVUSU9OX1RPS0VOU19BVFRSSUJVVEUsIHZlcmNlbEFpQXR0cmlidXRlcy5HRU5fQUlfVVNBR0VfT1VUUFVUX1RPS0VOU19BVFRSSUJVVEUpO1xuICByZW5hbWVBdHRyaWJ1dGVLZXkoYXR0cmlidXRlcywgdmVyY2VsQWlBdHRyaWJ1dGVzLkFJX1VTQUdFX1BST01QVF9UT0tFTlNfQVRUUklCVVRFLCB2ZXJjZWxBaUF0dHJpYnV0ZXMuR0VOX0FJX1VTQUdFX0lOUFVUX1RPS0VOU19BVFRSSUJVVEUpO1xuXG4gIGlmIChcbiAgICB0eXBlb2YgYXR0cmlidXRlc1t2ZXJjZWxBaUF0dHJpYnV0ZXMuR0VOX0FJX1VTQUdFX09VVFBVVF9UT0tFTlNfQVRUUklCVVRFXSA9PT0gJ251bWJlcicgJiZcbiAgICB0eXBlb2YgYXR0cmlidXRlc1t2ZXJjZWxBaUF0dHJpYnV0ZXMuR0VOX0FJX1VTQUdFX0lOUFVUX1RPS0VOU19BVFRSSUJVVEVdID09PSAnbnVtYmVyJ1xuICApIHtcbiAgICBhdHRyaWJ1dGVzWydnZW5fYWkudXNhZ2UudG90YWxfdG9rZW5zJ10gPVxuICAgICAgYXR0cmlidXRlc1t2ZXJjZWxBaUF0dHJpYnV0ZXMuR0VOX0FJX1VTQUdFX09VVFBVVF9UT0tFTlNfQVRUUklCVVRFXSArIGF0dHJpYnV0ZXNbdmVyY2VsQWlBdHRyaWJ1dGVzLkdFTl9BSV9VU0FHRV9JTlBVVF9UT0tFTlNfQVRUUklCVVRFXTtcbiAgfVxuXG4gIC8vIFJlbmFtZSBBSSBTREsgYXR0cmlidXRlcyB0byBzdGFuZGFyZGl6ZWQgZ2VuX2FpIGF0dHJpYnV0ZXNcbiAgcmVuYW1lQXR0cmlidXRlS2V5KGF0dHJpYnV0ZXMsIHZlcmNlbEFpQXR0cmlidXRlcy5BSV9QUk9NUFRfTUVTU0FHRVNfQVRUUklCVVRFLCAnZ2VuX2FpLnJlcXVlc3QubWVzc2FnZXMnKTtcbiAgcmVuYW1lQXR0cmlidXRlS2V5KGF0dHJpYnV0ZXMsIHZlcmNlbEFpQXR0cmlidXRlcy5BSV9SRVNQT05TRV9URVhUX0FUVFJJQlVURSwgJ2dlbl9haS5yZXNwb25zZS50ZXh0Jyk7XG4gIHJlbmFtZUF0dHJpYnV0ZUtleShhdHRyaWJ1dGVzLCB2ZXJjZWxBaUF0dHJpYnV0ZXMuQUlfUkVTUE9OU0VfVE9PTF9DQUxMU19BVFRSSUJVVEUsICdnZW5fYWkucmVzcG9uc2UudG9vbF9jYWxscycpO1xuICByZW5hbWVBdHRyaWJ1dGVLZXkoYXR0cmlidXRlcywgdmVyY2VsQWlBdHRyaWJ1dGVzLkFJX1JFU1BPTlNFX09CSkVDVF9BVFRSSUJVVEUsICdnZW5fYWkucmVzcG9uc2Uub2JqZWN0Jyk7XG4gIHJlbmFtZUF0dHJpYnV0ZUtleShhdHRyaWJ1dGVzLCB2ZXJjZWxBaUF0dHJpYnV0ZXMuQUlfUFJPTVBUX1RPT0xTX0FUVFJJQlVURSwgJ2dlbl9haS5yZXF1ZXN0LmF2YWlsYWJsZV90b29scycpO1xuXG4gIHJlbmFtZUF0dHJpYnV0ZUtleShhdHRyaWJ1dGVzLCB2ZXJjZWxBaUF0dHJpYnV0ZXMuQUlfVE9PTF9DQUxMX0FSR1NfQVRUUklCVVRFLCAnZ2VuX2FpLnRvb2wuaW5wdXQnKTtcbiAgcmVuYW1lQXR0cmlidXRlS2V5KGF0dHJpYnV0ZXMsIHZlcmNlbEFpQXR0cmlidXRlcy5BSV9UT09MX0NBTExfUkVTVUxUX0FUVFJJQlVURSwgJ2dlbl9haS50b29sLm91dHB1dCcpO1xuXG4gIGFkZFByb3ZpZGVyTWV0YWRhdGFUb0F0dHJpYnV0ZXMoYXR0cmlidXRlcyk7XG5cbiAgLy8gQ2hhbmdlIGF0dHJpYnV0ZXMgbmFtZXNwYWNlZCB3aXRoIGBhaS5YYCB0byBgdmVyY2VsLmFpLlhgXG4gIGZvciAoY29uc3Qga2V5IG9mIE9iamVjdC5rZXlzKGF0dHJpYnV0ZXMpKSB7XG4gICAgaWYgKGtleS5zdGFydHNXaXRoKCdhaS4nKSkge1xuICAgICAgcmVuYW1lQXR0cmlidXRlS2V5KGF0dHJpYnV0ZXMsIGtleSwgYHZlcmNlbC4ke2tleX1gKTtcbiAgICB9XG4gIH1cbn1cblxuLyoqXG4gKiBSZW5hbWVzIGFuIGF0dHJpYnV0ZSBrZXkgaW4gdGhlIHByb3ZpZGVkIGF0dHJpYnV0ZXMgb2JqZWN0IGlmIHRoZSBvbGQga2V5IGV4aXN0cy5cbiAqIFRoaXMgZnVuY3Rpb24gc2FmZWx5IGhhbmRsZXMgbnVsbCBhbmQgdW5kZWZpbmVkIHZhbHVlcy5cbiAqL1xuZnVuY3Rpb24gcmVuYW1lQXR0cmlidXRlS2V5KGF0dHJpYnV0ZXMsIG9sZEtleSwgbmV3S2V5KSB7XG4gIGlmIChhdHRyaWJ1dGVzW29sZEtleV0gIT0gbnVsbCkge1xuICAgIGF0dHJpYnV0ZXNbbmV3S2V5XSA9IGF0dHJpYnV0ZXNbb2xkS2V5XTtcbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25vLWR5bmFtaWMtZGVsZXRlXG4gICAgZGVsZXRlIGF0dHJpYnV0ZXNbb2xkS2V5XTtcbiAgfVxufVxuXG5mdW5jdGlvbiBwcm9jZXNzVG9vbENhbGxTcGFuKHNwYW4sIGF0dHJpYnV0ZXMpIHtcbiAgYWRkT3JpZ2luVG9TcGFuKHNwYW4sICdhdXRvLnZlcmNlbGFpLm90ZWwnKTtcbiAgc3Bhbi5zZXRBdHRyaWJ1dGUoc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfT1AsICdnZW5fYWkuZXhlY3V0ZV90b29sJyk7XG4gIHJlbmFtZUF0dHJpYnV0ZUtleShhdHRyaWJ1dGVzLCB2ZXJjZWxBaUF0dHJpYnV0ZXMuQUlfVE9PTF9DQUxMX05BTUVfQVRUUklCVVRFLCAnZ2VuX2FpLnRvb2wubmFtZScpO1xuICByZW5hbWVBdHRyaWJ1dGVLZXkoYXR0cmlidXRlcywgdmVyY2VsQWlBdHRyaWJ1dGVzLkFJX1RPT0xfQ0FMTF9JRF9BVFRSSUJVVEUsICdnZW5fYWkudG9vbC5jYWxsLmlkJyk7XG4gIC8vIGh0dHBzOi8vb3BlbnRlbGVtZXRyeS5pby9kb2NzL3NwZWNzL3NlbWNvbnYvcmVnaXN0cnkvYXR0cmlidXRlcy9nZW4tYWkvI2dlbi1haS10b29sLXR5cGVcbiAgaWYgKCFhdHRyaWJ1dGVzWydnZW5fYWkudG9vbC50eXBlJ10pIHtcbiAgICBzcGFuLnNldEF0dHJpYnV0ZSgnZ2VuX2FpLnRvb2wudHlwZScsICdmdW5jdGlvbicpO1xuICB9XG4gIGNvbnN0IHRvb2xOYW1lID0gYXR0cmlidXRlc1snZ2VuX2FpLnRvb2wubmFtZSddO1xuICBpZiAodG9vbE5hbWUpIHtcbiAgICBzcGFuLnVwZGF0ZU5hbWUoYGV4ZWN1dGVfdG9vbCAke3Rvb2xOYW1lfWApO1xuICB9XG59XG5cbmZ1bmN0aW9uIHByb2Nlc3NHZW5lcmF0ZVNwYW4oc3BhbiwgbmFtZSwgYXR0cmlidXRlcykge1xuICBhZGRPcmlnaW5Ub1NwYW4oc3BhbiwgJ2F1dG8udmVyY2VsYWkub3RlbCcpO1xuXG4gIGNvbnN0IG5hbWVXdGhvdXRBaSA9IG5hbWUucmVwbGFjZSgnYWkuJywgJycpO1xuICBzcGFuLnNldEF0dHJpYnV0ZSgnYWkucGlwZWxpbmUubmFtZScsIG5hbWVXdGhvdXRBaSk7XG4gIHNwYW4udXBkYXRlTmFtZShuYW1lV3Rob3V0QWkpO1xuXG4gIC8vIElmIGEgVGVsZW1ldHJ5IG5hbWUgaXMgc2V0IGFuZCBpdCBpcyBhIHBpcGVsaW5lIHNwYW4sIHVzZSB0aGF0IGFzIHRoZSBvcGVyYXRpb24gbmFtZVxuICBjb25zdCBmdW5jdGlvbklkID0gYXR0cmlidXRlc1t2ZXJjZWxBaUF0dHJpYnV0ZXMuQUlfVEVMRU1FVFJZX0ZVTkNUSU9OX0lEX0FUVFJJQlVURV07XG4gIGlmIChmdW5jdGlvbklkICYmIHR5cGVvZiBmdW5jdGlvbklkID09PSAnc3RyaW5nJyAmJiBuYW1lLnNwbGl0KCcuJykubGVuZ3RoIC0gMSA9PT0gMSkge1xuICAgIHNwYW4udXBkYXRlTmFtZShgJHtuYW1lV3Rob3V0QWl9ICR7ZnVuY3Rpb25JZH1gKTtcbiAgICBzcGFuLnNldEF0dHJpYnV0ZSgnZ2VuX2FpLmZ1bmN0aW9uX2lkJywgZnVuY3Rpb25JZCk7XG4gIH1cblxuICBpZiAoYXR0cmlidXRlc1t2ZXJjZWxBaUF0dHJpYnV0ZXMuQUlfUFJPTVBUX0FUVFJJQlVURV0pIHtcbiAgICBzcGFuLnNldEF0dHJpYnV0ZSgnZ2VuX2FpLnByb21wdCcsIGF0dHJpYnV0ZXNbdmVyY2VsQWlBdHRyaWJ1dGVzLkFJX1BST01QVF9BVFRSSUJVVEVdKTtcbiAgfVxuICBpZiAoYXR0cmlidXRlc1t2ZXJjZWxBaUF0dHJpYnV0ZXMuQUlfTU9ERUxfSURfQVRUUklCVVRFXSAmJiAhYXR0cmlidXRlc1t2ZXJjZWxBaUF0dHJpYnV0ZXMuR0VOX0FJX1JFU1BPTlNFX01PREVMX0FUVFJJQlVURV0pIHtcbiAgICBzcGFuLnNldEF0dHJpYnV0ZSh2ZXJjZWxBaUF0dHJpYnV0ZXMuR0VOX0FJX1JFU1BPTlNFX01PREVMX0FUVFJJQlVURSwgYXR0cmlidXRlc1t2ZXJjZWxBaUF0dHJpYnV0ZXMuQUlfTU9ERUxfSURfQVRUUklCVVRFXSk7XG4gIH1cbiAgc3Bhbi5zZXRBdHRyaWJ1dGUoJ2FpLnN0cmVhbWluZycsIG5hbWUuaW5jbHVkZXMoJ3N0cmVhbScpKTtcblxuICAvLyBHZW5lcmF0ZSBTcGFuc1xuICBpZiAobmFtZSA9PT0gJ2FpLmdlbmVyYXRlVGV4dCcpIHtcbiAgICBzcGFuLnNldEF0dHJpYnV0ZShzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9PUCwgJ2dlbl9haS5pbnZva2VfYWdlbnQnKTtcbiAgICByZXR1cm47XG4gIH1cblxuICBpZiAobmFtZSA9PT0gJ2FpLmdlbmVyYXRlVGV4dC5kb0dlbmVyYXRlJykge1xuICAgIHNwYW4uc2V0QXR0cmlidXRlKHNlbWFudGljQXR0cmlidXRlcy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX09QLCAnZ2VuX2FpLmdlbmVyYXRlX3RleHQnKTtcbiAgICBzcGFuLnVwZGF0ZU5hbWUoYGdlbmVyYXRlX3RleHQgJHthdHRyaWJ1dGVzW3ZlcmNlbEFpQXR0cmlidXRlcy5BSV9NT0RFTF9JRF9BVFRSSUJVVEVdfWApO1xuICAgIHJldHVybjtcbiAgfVxuXG4gIGlmIChuYW1lID09PSAnYWkuc3RyZWFtVGV4dCcpIHtcbiAgICBzcGFuLnNldEF0dHJpYnV0ZShzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9PUCwgJ2dlbl9haS5pbnZva2VfYWdlbnQnKTtcbiAgICByZXR1cm47XG4gIH1cblxuICBpZiAobmFtZSA9PT0gJ2FpLnN0cmVhbVRleHQuZG9TdHJlYW0nKSB7XG4gICAgc3Bhbi5zZXRBdHRyaWJ1dGUoc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfT1AsICdnZW5fYWkuc3RyZWFtX3RleHQnKTtcbiAgICBzcGFuLnVwZGF0ZU5hbWUoYHN0cmVhbV90ZXh0ICR7YXR0cmlidXRlc1t2ZXJjZWxBaUF0dHJpYnV0ZXMuQUlfTU9ERUxfSURfQVRUUklCVVRFXX1gKTtcbiAgICByZXR1cm47XG4gIH1cblxuICBpZiAobmFtZSA9PT0gJ2FpLmdlbmVyYXRlT2JqZWN0Jykge1xuICAgIHNwYW4uc2V0QXR0cmlidXRlKHNlbWFudGljQXR0cmlidXRlcy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX09QLCAnZ2VuX2FpLmludm9rZV9hZ2VudCcpO1xuICAgIHJldHVybjtcbiAgfVxuXG4gIGlmIChuYW1lID09PSAnYWkuZ2VuZXJhdGVPYmplY3QuZG9HZW5lcmF0ZScpIHtcbiAgICBzcGFuLnNldEF0dHJpYnV0ZShzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9PUCwgJ2dlbl9haS5nZW5lcmF0ZV9vYmplY3QnKTtcbiAgICBzcGFuLnVwZGF0ZU5hbWUoYGdlbmVyYXRlX29iamVjdCAke2F0dHJpYnV0ZXNbdmVyY2VsQWlBdHRyaWJ1dGVzLkFJX01PREVMX0lEX0FUVFJJQlVURV19YCk7XG4gICAgcmV0dXJuO1xuICB9XG5cbiAgaWYgKG5hbWUgPT09ICdhaS5zdHJlYW1PYmplY3QnKSB7XG4gICAgc3Bhbi5zZXRBdHRyaWJ1dGUoc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfT1AsICdnZW5fYWkuaW52b2tlX2FnZW50Jyk7XG4gICAgcmV0dXJuO1xuICB9XG5cbiAgaWYgKG5hbWUgPT09ICdhaS5zdHJlYW1PYmplY3QuZG9TdHJlYW0nKSB7XG4gICAgc3Bhbi5zZXRBdHRyaWJ1dGUoc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfT1AsICdnZW5fYWkuc3RyZWFtX29iamVjdCcpO1xuICAgIHNwYW4udXBkYXRlTmFtZShgc3RyZWFtX29iamVjdCAke2F0dHJpYnV0ZXNbdmVyY2VsQWlBdHRyaWJ1dGVzLkFJX01PREVMX0lEX0FUVFJJQlVURV19YCk7XG4gICAgcmV0dXJuO1xuICB9XG5cbiAgaWYgKG5hbWUgPT09ICdhaS5lbWJlZCcpIHtcbiAgICBzcGFuLnNldEF0dHJpYnV0ZShzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9PUCwgJ2dlbl9haS5pbnZva2VfYWdlbnQnKTtcbiAgICByZXR1cm47XG4gIH1cblxuICBpZiAobmFtZSA9PT0gJ2FpLmVtYmVkLmRvRW1iZWQnKSB7XG4gICAgc3Bhbi5zZXRBdHRyaWJ1dGUoc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfT1AsICdnZW5fYWkuZW1iZWQnKTtcbiAgICBzcGFuLnVwZGF0ZU5hbWUoYGVtYmVkICR7YXR0cmlidXRlc1t2ZXJjZWxBaUF0dHJpYnV0ZXMuQUlfTU9ERUxfSURfQVRUUklCVVRFXX1gKTtcbiAgICByZXR1cm47XG4gIH1cblxuICBpZiAobmFtZSA9PT0gJ2FpLmVtYmVkTWFueScpIHtcbiAgICBzcGFuLnNldEF0dHJpYnV0ZShzZW1hbnRpY0F0dHJpYnV0ZXMuU0VNQU5USUNfQVRUUklCVVRFX1NFTlRSWV9PUCwgJ2dlbl9haS5pbnZva2VfYWdlbnQnKTtcbiAgICByZXR1cm47XG4gIH1cblxuICBpZiAobmFtZSA9PT0gJ2FpLmVtYmVkTWFueS5kb0VtYmVkJykge1xuICAgIHNwYW4uc2V0QXR0cmlidXRlKHNlbWFudGljQXR0cmlidXRlcy5TRU1BTlRJQ19BVFRSSUJVVEVfU0VOVFJZX09QLCAnZ2VuX2FpLmVtYmVkX21hbnknKTtcbiAgICBzcGFuLnVwZGF0ZU5hbWUoYGVtYmVkX21hbnkgJHthdHRyaWJ1dGVzW3ZlcmNlbEFpQXR0cmlidXRlcy5BSV9NT0RFTF9JRF9BVFRSSUJVVEVdfWApO1xuICAgIHJldHVybjtcbiAgfVxuXG4gIGlmIChuYW1lLnN0YXJ0c1dpdGgoJ2FpLnN0cmVhbScpKSB7XG4gICAgc3Bhbi5zZXRBdHRyaWJ1dGUoc2VtYW50aWNBdHRyaWJ1dGVzLlNFTUFOVElDX0FUVFJJQlVURV9TRU5UUllfT1AsICdhaS5ydW4nKTtcbiAgICByZXR1cm47XG4gIH1cbn1cblxuLyoqXG4gKiBBZGQgZXZlbnQgcHJvY2Vzc29ycyB0byB0aGUgZ2l2ZW4gY2xpZW50IHRvIHByb2Nlc3MgVmVyY2VsIEFJIHNwYW5zLlxuICovXG5mdW5jdGlvbiBhZGRWZXJjZWxBaVByb2Nlc3NvcnMoY2xpZW50KSB7XG4gIGNsaWVudC5vbignc3BhblN0YXJ0Jywgb25WZXJjZWxBaVNwYW5TdGFydCk7XG4gIC8vIE5vdGU6IFdlIGNhbm5vdCBkbyB0aGlzIG9uIGBzcGFuRW5kYCwgYmVjYXVzZSB0aGUgc3BhbiBjYW5ub3QgYmUgbXV0YXRlZCBhbnltb3JlIGF0IHRoaXMgcG9pbnRcbiAgY2xpZW50LmFkZEV2ZW50UHJvY2Vzc29yKE9iamVjdC5hc3NpZ24odmVyY2VsQWlFdmVudFByb2Nlc3NvciwgeyBpZDogJ1ZlcmNlbEFpRXZlbnRQcm9jZXNzb3InIH0pKTtcbn1cblxuZnVuY3Rpb24gYWRkUHJvdmlkZXJNZXRhZGF0YVRvQXR0cmlidXRlcyhhdHRyaWJ1dGVzKSB7XG4gIGNvbnN0IHByb3ZpZGVyTWV0YWRhdGEgPSBhdHRyaWJ1dGVzW3ZlcmNlbEFpQXR0cmlidXRlcy5BSV9SRVNQT05TRV9QUk9WSURFUl9NRVRBREFUQV9BVFRSSUJVVEVdIDtcbiAgaWYgKHByb3ZpZGVyTWV0YWRhdGEpIHtcbiAgICB0cnkge1xuICAgICAgY29uc3QgcHJvdmlkZXJNZXRhZGF0YU9iamVjdCA9IEpTT04ucGFyc2UocHJvdmlkZXJNZXRhZGF0YSkgO1xuICAgICAgaWYgKHByb3ZpZGVyTWV0YWRhdGFPYmplY3Qub3BlbmFpKSB7XG4gICAgICAgIHNldEF0dHJpYnV0ZUlmRGVmaW5lZChcbiAgICAgICAgICBhdHRyaWJ1dGVzLFxuICAgICAgICAgICdnZW5fYWkudXNhZ2UuaW5wdXRfdG9rZW5zLmNhY2hlZCcsXG4gICAgICAgICAgcHJvdmlkZXJNZXRhZGF0YU9iamVjdC5vcGVuYWkuY2FjaGVkUHJvbXB0VG9rZW5zLFxuICAgICAgICApO1xuICAgICAgICBzZXRBdHRyaWJ1dGVJZkRlZmluZWQoXG4gICAgICAgICAgYXR0cmlidXRlcyxcbiAgICAgICAgICAnZ2VuX2FpLnVzYWdlLm91dHB1dF90b2tlbnMucmVhc29uaW5nJyxcbiAgICAgICAgICBwcm92aWRlck1ldGFkYXRhT2JqZWN0Lm9wZW5haS5yZWFzb25pbmdUb2tlbnMsXG4gICAgICAgICk7XG4gICAgICAgIHNldEF0dHJpYnV0ZUlmRGVmaW5lZChcbiAgICAgICAgICBhdHRyaWJ1dGVzLFxuICAgICAgICAgICdnZW5fYWkudXNhZ2Uub3V0cHV0X3Rva2Vucy5wcmVkaWN0aW9uX2FjY2VwdGVkJyxcbiAgICAgICAgICBwcm92aWRlck1ldGFkYXRhT2JqZWN0Lm9wZW5haS5hY2NlcHRlZFByZWRpY3Rpb25Ub2tlbnMsXG4gICAgICAgICk7XG4gICAgICAgIHNldEF0dHJpYnV0ZUlmRGVmaW5lZChcbiAgICAgICAgICBhdHRyaWJ1dGVzLFxuICAgICAgICAgICdnZW5fYWkudXNhZ2Uub3V0cHV0X3Rva2Vucy5wcmVkaWN0aW9uX3JlamVjdGVkJyxcbiAgICAgICAgICBwcm92aWRlck1ldGFkYXRhT2JqZWN0Lm9wZW5haS5yZWplY3RlZFByZWRpY3Rpb25Ub2tlbnMsXG4gICAgICAgICk7XG4gICAgICAgIHNldEF0dHJpYnV0ZUlmRGVmaW5lZChhdHRyaWJ1dGVzLCAnZ2VuX2FpLmNvbnZlcnNhdGlvbi5pZCcsIHByb3ZpZGVyTWV0YWRhdGFPYmplY3Qub3BlbmFpLnJlc3BvbnNlSWQpO1xuICAgICAgfVxuXG4gICAgICBpZiAocHJvdmlkZXJNZXRhZGF0YU9iamVjdC5hbnRocm9waWMpIHtcbiAgICAgICAgc2V0QXR0cmlidXRlSWZEZWZpbmVkKFxuICAgICAgICAgIGF0dHJpYnV0ZXMsXG4gICAgICAgICAgJ2dlbl9haS51c2FnZS5pbnB1dF90b2tlbnMuY2FjaGVkJyxcbiAgICAgICAgICBwcm92aWRlck1ldGFkYXRhT2JqZWN0LmFudGhyb3BpYy5jYWNoZVJlYWRJbnB1dFRva2VucyxcbiAgICAgICAgKTtcbiAgICAgICAgc2V0QXR0cmlidXRlSWZEZWZpbmVkKFxuICAgICAgICAgIGF0dHJpYnV0ZXMsXG4gICAgICAgICAgJ2dlbl9haS51c2FnZS5pbnB1dF90b2tlbnMuY2FjaGVfd3JpdGUnLFxuICAgICAgICAgIHByb3ZpZGVyTWV0YWRhdGFPYmplY3QuYW50aHJvcGljLmNhY2hlQ3JlYXRpb25JbnB1dFRva2VucyxcbiAgICAgICAgKTtcbiAgICAgIH1cblxuICAgICAgaWYgKHByb3ZpZGVyTWV0YWRhdGFPYmplY3QuYmVkcm9jaz8udXNhZ2UpIHtcbiAgICAgICAgc2V0QXR0cmlidXRlSWZEZWZpbmVkKFxuICAgICAgICAgIGF0dHJpYnV0ZXMsXG4gICAgICAgICAgJ2dlbl9haS51c2FnZS5pbnB1dF90b2tlbnMuY2FjaGVkJyxcbiAgICAgICAgICBwcm92aWRlck1ldGFkYXRhT2JqZWN0LmJlZHJvY2sudXNhZ2UuY2FjaGVSZWFkSW5wdXRUb2tlbnMsXG4gICAgICAgICk7XG4gICAgICAgIHNldEF0dHJpYnV0ZUlmRGVmaW5lZChcbiAgICAgICAgICBhdHRyaWJ1dGVzLFxuICAgICAgICAgICdnZW5fYWkudXNhZ2UuaW5wdXRfdG9rZW5zLmNhY2hlX3dyaXRlJyxcbiAgICAgICAgICBwcm92aWRlck1ldGFkYXRhT2JqZWN0LmJlZHJvY2sudXNhZ2UuY2FjaGVXcml0ZUlucHV0VG9rZW5zLFxuICAgICAgICApO1xuICAgICAgfVxuXG4gICAgICBpZiAocHJvdmlkZXJNZXRhZGF0YU9iamVjdC5kZWVwc2Vlaykge1xuICAgICAgICBzZXRBdHRyaWJ1dGVJZkRlZmluZWQoXG4gICAgICAgICAgYXR0cmlidXRlcyxcbiAgICAgICAgICAnZ2VuX2FpLnVzYWdlLmlucHV0X3Rva2Vucy5jYWNoZWQnLFxuICAgICAgICAgIHByb3ZpZGVyTWV0YWRhdGFPYmplY3QuZGVlcHNlZWsucHJvbXB0Q2FjaGVIaXRUb2tlbnMsXG4gICAgICAgICk7XG4gICAgICAgIHNldEF0dHJpYnV0ZUlmRGVmaW5lZChcbiAgICAgICAgICBhdHRyaWJ1dGVzLFxuICAgICAgICAgICdnZW5fYWkudXNhZ2UuaW5wdXRfdG9rZW5zLmNhY2hlX21pc3MnLFxuICAgICAgICAgIHByb3ZpZGVyTWV0YWRhdGFPYmplY3QuZGVlcHNlZWsucHJvbXB0Q2FjaGVNaXNzVG9rZW5zLFxuICAgICAgICApO1xuICAgICAgfVxuICAgIH0gY2F0Y2gge1xuICAgICAgLy8gSWdub3JlXG4gICAgfVxuICB9XG59XG5cbi8qKlxuICogU2V0cyBhbiBhdHRyaWJ1dGUgb25seSBpZiB0aGUgdmFsdWUgaXMgbm90IG51bGwgb3IgdW5kZWZpbmVkLlxuICovXG5mdW5jdGlvbiBzZXRBdHRyaWJ1dGVJZkRlZmluZWQoYXR0cmlidXRlcywga2V5LCB2YWx1ZSkge1xuICBpZiAodmFsdWUgIT0gbnVsbCkge1xuICAgIGF0dHJpYnV0ZXNba2V5XSA9IHZhbHVlO1xuICB9XG59XG5cbmV4cG9ydHMuYWRkVmVyY2VsQWlQcm9jZXNzb3JzID0gYWRkVmVyY2VsQWlQcm9jZXNzb3JzO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9dmVyY2VsLWFpLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/vercel-ai.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/vercelWaitUntil.js":
/*!*************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/vercelWaitUntil.js ***!
  \*************************************************************************************************************/
/***/ ((__unused_webpack_module, exports, __webpack_require__) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\nconst worldwide = __webpack_require__(/*! ./worldwide.js */ \"(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/worldwide.js\");\n\n/**\n * Function that delays closing of a Vercel lambda until the provided promise is resolved.\n *\n * Vendored from https://www.npmjs.com/package/@vercel/functions\n */\nfunction vercelWaitUntil(task) {\n  const vercelRequestContextGlobal =\n    // @ts-expect-error This is not typed\n    worldwide.GLOBAL_OBJ[Symbol.for('@vercel/request-context')];\n\n  const ctx = vercelRequestContextGlobal?.get?.();\n\n  if (ctx?.waitUntil) {\n    ctx.waitUntil(task);\n  }\n}\n\nexports.vercelWaitUntil = vercelWaitUntil;\n//# sourceMappingURL=vercelWaitUntil.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy92ZXJjZWxXYWl0VW50aWwuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEUsa0JBQWtCLG1CQUFPLENBQUMsNkhBQWdCOztBQUUxQztBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUEsdUJBQXVCO0FBQ3ZCIiwic291cmNlcyI6WyIvaG9tZS9vbWFyL0RvY3VtZW50cy9ydWxlSVEvZnJvbnRlbmQvbm9kZV9tb2R1bGVzLy5wbnBtL0BzZW50cnkrY29yZUA5LjQ2LjAvbm9kZV9tb2R1bGVzL0BzZW50cnkvY29yZS9idWlsZC9janMvdXRpbHMvdmVyY2VsV2FpdFVudGlsLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5kZWZpbmVQcm9wZXJ0eShleHBvcnRzLCBTeW1ib2wudG9TdHJpbmdUYWcsIHsgdmFsdWU6ICdNb2R1bGUnIH0pO1xuXG5jb25zdCB3b3JsZHdpZGUgPSByZXF1aXJlKCcuL3dvcmxkd2lkZS5qcycpO1xuXG4vKipcbiAqIEZ1bmN0aW9uIHRoYXQgZGVsYXlzIGNsb3Npbmcgb2YgYSBWZXJjZWwgbGFtYmRhIHVudGlsIHRoZSBwcm92aWRlZCBwcm9taXNlIGlzIHJlc29sdmVkLlxuICpcbiAqIFZlbmRvcmVkIGZyb20gaHR0cHM6Ly93d3cubnBtanMuY29tL3BhY2thZ2UvQHZlcmNlbC9mdW5jdGlvbnNcbiAqL1xuZnVuY3Rpb24gdmVyY2VsV2FpdFVudGlsKHRhc2spIHtcbiAgY29uc3QgdmVyY2VsUmVxdWVzdENvbnRleHRHbG9iYWwgPVxuICAgIC8vIEB0cy1leHBlY3QtZXJyb3IgVGhpcyBpcyBub3QgdHlwZWRcbiAgICB3b3JsZHdpZGUuR0xPQkFMX09CSltTeW1ib2wuZm9yKCdAdmVyY2VsL3JlcXVlc3QtY29udGV4dCcpXTtcblxuICBjb25zdCBjdHggPSB2ZXJjZWxSZXF1ZXN0Q29udGV4dEdsb2JhbD8uZ2V0Py4oKTtcblxuICBpZiAoY3R4Py53YWl0VW50aWwpIHtcbiAgICBjdHgud2FpdFVudGlsKHRhc2spO1xuICB9XG59XG5cbmV4cG9ydHMudmVyY2VsV2FpdFVudGlsID0gdmVyY2VsV2FpdFVudGlsO1xuLy8jIHNvdXJjZU1hcHBpbmdVUkw9dmVyY2VsV2FpdFVudGlsLmpzLm1hcFxuIl0sIm5hbWVzIjpbXSwiaWdub3JlTGlzdCI6WzBdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/vercelWaitUntil.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/version.js":
/*!*****************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/version.js ***!
  \*****************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n// This is a magic string replaced by rollup\n\nconst SDK_VERSION = \"9.46.0\" ;\n\nexports.SDK_VERSION = SDK_VERSION;\n//# sourceMappingURL=version.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy92ZXJzaW9uLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFOztBQUVBOztBQUVBLG1CQUFtQjtBQUNuQiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3V0aWxzL3ZlcnNpb24uanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbi8vIFRoaXMgaXMgYSBtYWdpYyBzdHJpbmcgcmVwbGFjZWQgYnkgcm9sbHVwXG5cbmNvbnN0IFNES19WRVJTSU9OID0gXCI5LjQ2LjBcIiA7XG5cbmV4cG9ydHMuU0RLX1ZFUlNJT04gPSBTREtfVkVSU0lPTjtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPXZlcnNpb24uanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/version.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/worldwide.js":
/*!*******************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/worldwide.js ***!
  \*******************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n/** Internal global with common properties and Sentry extensions  */\n\n/** Get's the global object for the current JavaScript runtime */\nconst GLOBAL_OBJ = globalThis ;\n\nexports.GLOBAL_OBJ = GLOBAL_OBJ;\n//# sourceMappingURL=worldwide.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy93b3JsZHdpZGUuanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEU7O0FBRUE7QUFDQTs7QUFFQSxrQkFBa0I7QUFDbEIiLCJzb3VyY2VzIjpbIi9ob21lL29tYXIvRG9jdW1lbnRzL3J1bGVJUS9mcm9udGVuZC9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy91dGlscy93b3JsZHdpZGUuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbi8qKiBJbnRlcm5hbCBnbG9iYWwgd2l0aCBjb21tb24gcHJvcGVydGllcyBhbmQgU2VudHJ5IGV4dGVuc2lvbnMgICovXG5cbi8qKiBHZXQncyB0aGUgZ2xvYmFsIG9iamVjdCBmb3IgdGhlIGN1cnJlbnQgSmF2YVNjcmlwdCBydW50aW1lICovXG5jb25zdCBHTE9CQUxfT0JKID0gZ2xvYmFsVGhpcyA7XG5cbmV4cG9ydHMuR0xPQkFMX09CSiA9IEdMT0JBTF9PQko7XG4vLyMgc291cmNlTWFwcGluZ1VSTD13b3JsZHdpZGUuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/utils/worldwide.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/vendor/escapeStringForRegex.js":
/*!*******************************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/vendor/escapeStringForRegex.js ***!
  \*******************************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n// Based on https://github.com/sindresorhus/escape-string-regexp but with modifications to:\n//   a) reduce the size by skipping the runtime type - checking\n//   b) ensure it gets down - compiled for old versions of Node(the published package only supports Node 14+).\n//\n// MIT License\n//\n// Copyright (c) Sindre Sorhus <sindresorhus@gmail.com> (https://sindresorhus.com)\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated\n// documentation files(the \"Software\"), to deal in the Software without restriction, including without limitation\n// the rights to use, copy, modify, merge, publish, distribute, sublicense, and / or sell copies of the Software, and\n// to permit persons to whom the Software is furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in all copies or substantial portions of\n// the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO\n// THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,\n// TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS\n// IN THE SOFTWARE.\n\n/**\n * Given a string, escape characters which have meaning in the regex grammar, such that the result is safe to feed to\n * `new RegExp()`.\n *\n * @param regexString The string to escape\n * @returns An version of the string with all special regex characters escaped\n */\nfunction escapeStringForRegex(regexString) {\n  // escape the hyphen separately so we can also replace it with a unicode literal hyphen, to avoid the problems\n  // discussed in https://github.com/sindresorhus/escape-string-regexp/issues/20.\n  return regexString.replace(/[|\\\\{}()[\\]^$+*?.]/g, '\\\\$&').replace(/-/g, '\\\\x2d');\n}\n\nexports.escapeStringForRegex = escapeStringForRegex;\n//# sourceMappingURL=escapeStringForRegex.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy92ZW5kb3IvZXNjYXBlU3RyaW5nRm9yUmVnZXguanMiLCJtYXBwaW5ncyI6IkFBQUEscURBQXFELGlCQUFpQjs7QUFFdEU7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0Esb0NBQW9DO0FBQ3BDOztBQUVBLDRCQUE0QjtBQUM1QiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3ZlbmRvci9lc2NhcGVTdHJpbmdGb3JSZWdleC5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuZGVmaW5lUHJvcGVydHkoZXhwb3J0cywgU3ltYm9sLnRvU3RyaW5nVGFnLCB7IHZhbHVlOiAnTW9kdWxlJyB9KTtcblxuLy8gQmFzZWQgb24gaHR0cHM6Ly9naXRodWIuY29tL3NpbmRyZXNvcmh1cy9lc2NhcGUtc3RyaW5nLXJlZ2V4cCBidXQgd2l0aCBtb2RpZmljYXRpb25zIHRvOlxuLy8gICBhKSByZWR1Y2UgdGhlIHNpemUgYnkgc2tpcHBpbmcgdGhlIHJ1bnRpbWUgdHlwZSAtIGNoZWNraW5nXG4vLyAgIGIpIGVuc3VyZSBpdCBnZXRzIGRvd24gLSBjb21waWxlZCBmb3Igb2xkIHZlcnNpb25zIG9mIE5vZGUodGhlIHB1Ymxpc2hlZCBwYWNrYWdlIG9ubHkgc3VwcG9ydHMgTm9kZSAxNCspLlxuLy9cbi8vIE1JVCBMaWNlbnNlXG4vL1xuLy8gQ29weXJpZ2h0IChjKSBTaW5kcmUgU29yaHVzIDxzaW5kcmVzb3JodXNAZ21haWwuY29tPiAoaHR0cHM6Ly9zaW5kcmVzb3JodXMuY29tKVxuLy9cbi8vIFBlcm1pc3Npb24gaXMgaGVyZWJ5IGdyYW50ZWQsIGZyZWUgb2YgY2hhcmdlLCB0byBhbnkgcGVyc29uIG9idGFpbmluZyBhIGNvcHkgb2YgdGhpcyBzb2Z0d2FyZSBhbmQgYXNzb2NpYXRlZFxuLy8gZG9jdW1lbnRhdGlvbiBmaWxlcyh0aGUgXCJTb2Z0d2FyZVwiKSwgdG8gZGVhbCBpbiB0aGUgU29mdHdhcmUgd2l0aG91dCByZXN0cmljdGlvbiwgaW5jbHVkaW5nIHdpdGhvdXQgbGltaXRhdGlvblxuLy8gdGhlIHJpZ2h0cyB0byB1c2UsIGNvcHksIG1vZGlmeSwgbWVyZ2UsIHB1Ymxpc2gsIGRpc3RyaWJ1dGUsIHN1YmxpY2Vuc2UsIGFuZCAvIG9yIHNlbGwgY29waWVzIG9mIHRoZSBTb2Z0d2FyZSwgYW5kXG4vLyB0byBwZXJtaXQgcGVyc29ucyB0byB3aG9tIHRoZSBTb2Z0d2FyZSBpcyBmdXJuaXNoZWQgdG8gZG8gc28sIHN1YmplY3QgdG8gdGhlIGZvbGxvd2luZyBjb25kaXRpb25zOlxuLy9cbi8vIFRoZSBhYm92ZSBjb3B5cmlnaHQgbm90aWNlIGFuZCB0aGlzIHBlcm1pc3Npb24gbm90aWNlIHNoYWxsIGJlIGluY2x1ZGVkIGluIGFsbCBjb3BpZXMgb3Igc3Vic3RhbnRpYWwgcG9ydGlvbnMgb2Zcbi8vIHRoZSBTb2Z0d2FyZS5cbi8vXG4vLyBUSEUgU09GVFdBUkUgSVMgUFJPVklERUQgXCJBUyBJU1wiLCBXSVRIT1VUIFdBUlJBTlRZIE9GIEFOWSBLSU5ELCBFWFBSRVNTIE9SIElNUExJRUQsIElOQ0xVRElORyBCVVQgTk9UIExJTUlURUQgVE9cbi8vIFRIRSBXQVJSQU5USUVTIE9GIE1FUkNIQU5UQUJJTElUWSwgRklUTkVTUyBGT1IgQSBQQVJUSUNVTEFSIFBVUlBPU0UgQU5EIE5PTklORlJJTkdFTUVOVC5JTiBOTyBFVkVOVCBTSEFMTCBUSEVcbi8vIEFVVEhPUlMgT1IgQ09QWVJJR0hUIEhPTERFUlMgQkUgTElBQkxFIEZPUiBBTlkgQ0xBSU0sIERBTUFHRVMgT1IgT1RIRVIgTElBQklMSVRZLCBXSEVUSEVSIElOIEFOIEFDVElPTiBPRiBDT05UUkFDVCxcbi8vIFRPUlQgT1IgT1RIRVJXSVNFLCBBUklTSU5HIEZST00sIE9VVCBPRiBPUiBJTiBDT05ORUNUSU9OIFdJVEggVEhFIFNPRlRXQVJFIE9SIFRIRSBVU0UgT1IgT1RIRVIgREVBTElOR1Ncbi8vIElOIFRIRSBTT0ZUV0FSRS5cblxuLyoqXG4gKiBHaXZlbiBhIHN0cmluZywgZXNjYXBlIGNoYXJhY3RlcnMgd2hpY2ggaGF2ZSBtZWFuaW5nIGluIHRoZSByZWdleCBncmFtbWFyLCBzdWNoIHRoYXQgdGhlIHJlc3VsdCBpcyBzYWZlIHRvIGZlZWQgdG9cbiAqIGBuZXcgUmVnRXhwKClgLlxuICpcbiAqIEBwYXJhbSByZWdleFN0cmluZyBUaGUgc3RyaW5nIHRvIGVzY2FwZVxuICogQHJldHVybnMgQW4gdmVyc2lvbiBvZiB0aGUgc3RyaW5nIHdpdGggYWxsIHNwZWNpYWwgcmVnZXggY2hhcmFjdGVycyBlc2NhcGVkXG4gKi9cbmZ1bmN0aW9uIGVzY2FwZVN0cmluZ0ZvclJlZ2V4KHJlZ2V4U3RyaW5nKSB7XG4gIC8vIGVzY2FwZSB0aGUgaHlwaGVuIHNlcGFyYXRlbHkgc28gd2UgY2FuIGFsc28gcmVwbGFjZSBpdCB3aXRoIGEgdW5pY29kZSBsaXRlcmFsIGh5cGhlbiwgdG8gYXZvaWQgdGhlIHByb2JsZW1zXG4gIC8vIGRpc2N1c3NlZCBpbiBodHRwczovL2dpdGh1Yi5jb20vc2luZHJlc29yaHVzL2VzY2FwZS1zdHJpbmctcmVnZXhwL2lzc3Vlcy8yMC5cbiAgcmV0dXJuIHJlZ2V4U3RyaW5nLnJlcGxhY2UoL1t8XFxcXHt9KClbXFxdXiQrKj8uXS9nLCAnXFxcXCQmJykucmVwbGFjZSgvLS9nLCAnXFxcXHgyZCcpO1xufVxuXG5leHBvcnRzLmVzY2FwZVN0cmluZ0ZvclJlZ2V4ID0gZXNjYXBlU3RyaW5nRm9yUmVnZXg7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1lc2NhcGVTdHJpbmdGb3JSZWdleC5qcy5tYXBcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOlswXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/vendor/escapeStringForRegex.js\n");
 
/***/ }),
 
/***/ "(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/vendor/getIpAddress.js":
/*!***********************************************************************************************************!*\
  !*** ./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/vendor/getIpAddress.js ***!
  \***********************************************************************************************************/
/***/ ((__unused_webpack_module, exports) => {
 
eval("Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\n// Vendored / modified from @sergiodxa/remix-utils\n\n// https://github.com/sergiodxa/remix-utils/blob/02af80e12829a53696bfa8f3c2363975cf59f55e/src/server/get-client-ip-address.ts\n// MIT License\n\n// Copyright (c) 2021 Sergio Xalambrí\n\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the \"Software\"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n\n// The above copyright notice and this permission notice shall be included in all\n// copies or substantial portions of the Software.\n\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n// SOFTWARE.\n\n// The headers to check, in priority order\nconst ipHeaderNames = [\n  'X-Client-IP',\n  'X-Forwarded-For',\n  'Fly-Client-IP',\n  'CF-Connecting-IP',\n  'Fastly-Client-Ip',\n  'True-Client-Ip',\n  'X-Real-IP',\n  'X-Cluster-Client-IP',\n  'X-Forwarded',\n  'Forwarded-For',\n  'Forwarded',\n  'X-Vercel-Forwarded-For',\n];\n\n/**\n * Get the IP address of the client sending a request.\n *\n * It receives a Request headers object and use it to get the\n * IP address from one of the following headers in order.\n *\n * If the IP address is valid, it will be returned. Otherwise, null will be\n * returned.\n *\n * If the header values contains more than one IP address, the first valid one\n * will be returned.\n */\nfunction getClientIPAddress(headers) {\n  // This will end up being Array<string | string[] | undefined | null> because of the various possible values a header\n  // can take\n  const headerValues = ipHeaderNames.map((headerName) => {\n    const rawValue = headers[headerName];\n    const value = Array.isArray(rawValue) ? rawValue.join(';') : rawValue;\n\n    if (headerName === 'Forwarded') {\n      return parseForwardedHeader(value);\n    }\n\n    return value?.split(',').map((v) => v.trim());\n  });\n\n  // Flatten the array and filter out any falsy entries\n  const flattenedHeaderValues = headerValues.reduce((acc, val) => {\n    if (!val) {\n      return acc;\n    }\n\n    return acc.concat(val);\n  }, []);\n\n  // Find the first value which is a valid IP address, if any\n  const ipAddress = flattenedHeaderValues.find(ip => ip !== null && isIP(ip));\n\n  return ipAddress || null;\n}\n\nfunction parseForwardedHeader(value) {\n  if (!value) {\n    return null;\n  }\n\n  for (const part of value.split(';')) {\n    if (part.startsWith('for=')) {\n      return part.slice(4);\n    }\n  }\n\n  return null;\n}\n\n//\n/**\n * Custom method instead of importing this from `net` package, as this only exists in node\n * Accepts:\n * 127.0.0.1\n * 192.168.1.1\n * 192.168.1.255\n * 255.255.255.255\n * 10.1.1.1\n * 0.0.0.0\n * 2b01:cb19:8350:ed00:d0dd:fa5b:de31:8be5\n *\n * Rejects:\n * 1.1.1.01\n * 30.168.1.255.1\n * 127.1\n * 192.168.1.256\n * -1.2.3.4\n * 1.1.1.1.\n * 3...3\n * 192.168.1.099\n */\nfunction isIP(str) {\n  const regex =\n    /(?:^(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)(?:\\.(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)){3}$)|(?:^(?:(?:[a-fA-F\\d]{1,4}:){7}(?:[a-fA-F\\d]{1,4}|:)|(?:[a-fA-F\\d]{1,4}:){6}(?:(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)(?:\\\\.(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)){3}|:[a-fA-F\\d]{1,4}|:)|(?:[a-fA-F\\d]{1,4}:){5}(?::(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)(?:\\\\.(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)){3}|(?::[a-fA-F\\d]{1,4}){1,2}|:)|(?:[a-fA-F\\d]{1,4}:){4}(?:(?::[a-fA-F\\d]{1,4}){0,1}:(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)(?:\\\\.(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)){3}|(?::[a-fA-F\\d]{1,4}){1,3}|:)|(?:[a-fA-F\\d]{1,4}:){3}(?:(?::[a-fA-F\\d]{1,4}){0,2}:(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)(?:\\\\.(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)){3}|(?::[a-fA-F\\d]{1,4}){1,4}|:)|(?:[a-fA-F\\d]{1,4}:){2}(?:(?::[a-fA-F\\d]{1,4}){0,3}:(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)(?:\\\\.(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)){3}|(?::[a-fA-F\\d]{1,4}){1,5}|:)|(?:[a-fA-F\\d]{1,4}:){1}(?:(?::[a-fA-F\\d]{1,4}){0,4}:(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)(?:\\\\.(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)){3}|(?::[a-fA-F\\d]{1,4}){1,6}|:)|(?::(?:(?::[a-fA-F\\d]{1,4}){0,5}:(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)(?:\\\\.(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)){3}|(?::[a-fA-F\\d]{1,4}){1,7}|:)))(?:%[0-9a-zA-Z]{1,})?$)/;\n  return regex.test(str);\n}\n\nexports.getClientIPAddress = getClientIPAddress;\nexports.ipHeaderNames = ipHeaderNames;\n//# sourceMappingURL=getIpAddress.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvLnBucG0vQHNlbnRyeStjb3JlQDkuNDYuMC9ub2RlX21vZHVsZXMvQHNlbnRyeS9jb3JlL2J1aWxkL2Nqcy92ZW5kb3IvZ2V0SXBBZGRyZXNzLmpzIiwibWFwcGluZ3MiOiJBQUFBLHFEQUFxRCxpQkFBaUI7O0FBRXRFOztBQUVBO0FBQ0E7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSw0REFBNEQ7O0FBRTVEO0FBQ0E7QUFDQTs7QUFFQTtBQUNBLEdBQUc7O0FBRUg7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBLEdBQUc7O0FBRUg7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBOztBQUVBLG1DQUFtQztBQUNuQztBQUNBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLDBGQUEwRixFQUFFLHdCQUF3QixJQUFJLEdBQUcsRUFBRSxjQUFjLElBQUksa0JBQWtCLElBQUksR0FBRyxFQUFFLHFGQUFxRixFQUFFLGFBQWEsSUFBSSxrQkFBa0IsSUFBSSxHQUFHLEVBQUUsc0ZBQXNGLEVBQUUsZ0JBQWdCLElBQUksRUFBRSxJQUFJLGtCQUFrQixJQUFJLEdBQUcsRUFBRSxrQkFBa0IsSUFBSSxFQUFFLElBQUksbUZBQW1GLEVBQUUsZ0JBQWdCLElBQUksRUFBRSxJQUFJLGtCQUFrQixJQUFJLEdBQUcsRUFBRSxrQkFBa0IsSUFBSSxFQUFFLElBQUksbUZBQW1GLEVBQUUsZ0JBQWdCLElBQUksRUFBRSxJQUFJLGtCQUFrQixJQUFJLEdBQUcsRUFBRSxrQkFBa0IsSUFBSSxFQUFFLElBQUksbUZBQW1GLEVBQUUsZ0JBQWdCLElBQUksRUFBRSxJQUFJLGtCQUFrQixJQUFJLEdBQUcsRUFBRSxrQkFBa0IsSUFBSSxFQUFFLElBQUksbUZBQW1GLEVBQUUsZ0JBQWdCLElBQUksRUFBRSxJQUFJLDBCQUEwQixJQUFJLEVBQUUsSUFBSSxtRkFBbUYsRUFBRSxnQkFBZ0IsSUFBSSxFQUFFLElBQUkscUJBQXFCLEdBQUc7QUFDbHVDO0FBQ0E7O0FBRUEsMEJBQTBCO0FBQzFCLHFCQUFxQjtBQUNyQiIsInNvdXJjZXMiOlsiL2hvbWUvb21hci9Eb2N1bWVudHMvcnVsZUlRL2Zyb250ZW5kL25vZGVfbW9kdWxlcy8ucG5wbS9Ac2VudHJ5K2NvcmVAOS40Ni4wL25vZGVfbW9kdWxlcy9Ac2VudHJ5L2NvcmUvYnVpbGQvY2pzL3ZlbmRvci9nZXRJcEFkZHJlc3MuanMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0LmRlZmluZVByb3BlcnR5KGV4cG9ydHMsIFN5bWJvbC50b1N0cmluZ1RhZywgeyB2YWx1ZTogJ01vZHVsZScgfSk7XG5cbi8vIFZlbmRvcmVkIC8gbW9kaWZpZWQgZnJvbSBAc2VyZ2lvZHhhL3JlbWl4LXV0aWxzXG5cbi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9zZXJnaW9keGEvcmVtaXgtdXRpbHMvYmxvYi8wMmFmODBlMTI4MjlhNTM2OTZiZmE4ZjNjMjM2Mzk3NWNmNTlmNTVlL3NyYy9zZXJ2ZXIvZ2V0LWNsaWVudC1pcC1hZGRyZXNzLnRzXG4vLyBNSVQgTGljZW5zZVxuXG4vLyBDb3B5cmlnaHQgKGMpIDIwMjEgU2VyZ2lvIFhhbGFtYnLDrVxuXG4vLyBQZXJtaXNzaW9uIGlzIGhlcmVieSBncmFudGVkLCBmcmVlIG9mIGNoYXJnZSwgdG8gYW55IHBlcnNvbiBvYnRhaW5pbmcgYSBjb3B5XG4vLyBvZiB0aGlzIHNvZnR3YXJlIGFuZCBhc3NvY2lhdGVkIGRvY3VtZW50YXRpb24gZmlsZXMgKHRoZSBcIlNvZnR3YXJlXCIpLCB0byBkZWFsXG4vLyBpbiB0aGUgU29mdHdhcmUgd2l0aG91dCByZXN0cmljdGlvbiwgaW5jbHVkaW5nIHdpdGhvdXQgbGltaXRhdGlvbiB0aGUgcmlnaHRzXG4vLyB0byB1c2UsIGNvcHksIG1vZGlmeSwgbWVyZ2UsIHB1Ymxpc2gsIGRpc3RyaWJ1dGUsIHN1YmxpY2Vuc2UsIGFuZC9vciBzZWxsXG4vLyBjb3BpZXMgb2YgdGhlIFNvZnR3YXJlLCBhbmQgdG8gcGVybWl0IHBlcnNvbnMgdG8gd2hvbSB0aGUgU29mdHdhcmUgaXNcbi8vIGZ1cm5pc2hlZCB0byBkbyBzbywgc3ViamVjdCB0byB0aGUgZm9sbG93aW5nIGNvbmRpdGlvbnM6XG5cbi8vIFRoZSBhYm92ZSBjb3B5cmlnaHQgbm90aWNlIGFuZCB0aGlzIHBlcm1pc3Npb24gbm90aWNlIHNoYWxsIGJlIGluY2x1ZGVkIGluIGFsbFxuLy8gY29waWVzIG9yIHN1YnN0YW50aWFsIHBvcnRpb25zIG9mIHRoZSBTb2Z0d2FyZS5cblxuLy8gVEhFIFNPRlRXQVJFIElTIFBST1ZJREVEIFwiQVMgSVNcIiwgV0lUSE9VVCBXQVJSQU5UWSBPRiBBTlkgS0lORCwgRVhQUkVTUyBPUlxuLy8gSU1QTElFRCwgSU5DTFVESU5HIEJVVCBOT1QgTElNSVRFRCBUTyBUSEUgV0FSUkFOVElFUyBPRiBNRVJDSEFOVEFCSUxJVFksXG4vLyBGSVRORVNTIEZPUiBBIFBBUlRJQ1VMQVIgUFVSUE9TRSBBTkQgTk9OSU5GUklOR0VNRU5ULiBJTiBOTyBFVkVOVCBTSEFMTCBUSEVcbi8vIEFVVEhPUlMgT1IgQ09QWVJJR0hUIEhPTERFUlMgQkUgTElBQkxFIEZPUiBBTlkgQ0xBSU0sIERBTUFHRVMgT1IgT1RIRVJcbi8vIExJQUJJTElUWSwgV0hFVEhFUiBJTiBBTiBBQ1RJT04gT0YgQ09OVFJBQ1QsIFRPUlQgT1IgT1RIRVJXSVNFLCBBUklTSU5HIEZST00sXG4vLyBPVVQgT0YgT1IgSU4gQ09OTkVDVElPTiBXSVRIIFRIRSBTT0ZUV0FSRSBPUiBUSEUgVVNFIE9SIE9USEVSIERFQUxJTkdTIElOIFRIRVxuLy8gU09GVFdBUkUuXG5cbi8vIFRoZSBoZWFkZXJzIHRvIGNoZWNrLCBpbiBwcmlvcml0eSBvcmRlclxuY29uc3QgaXBIZWFkZXJOYW1lcyA9IFtcbiAgJ1gtQ2xpZW50LUlQJyxcbiAgJ1gtRm9yd2FyZGVkLUZvcicsXG4gICdGbHktQ2xpZW50LUlQJyxcbiAgJ0NGLUNvbm5lY3RpbmctSVAnLFxuICAnRmFzdGx5LUNsaWVudC1JcCcsXG4gICdUcnVlLUNsaWVudC1JcCcsXG4gICdYLVJlYWwtSVAnLFxuICAnWC1DbHVzdGVyLUNsaWVudC1JUCcsXG4gICdYLUZvcndhcmRlZCcsXG4gICdGb3J3YXJkZWQtRm9yJyxcbiAgJ0ZvcndhcmRlZCcsXG4gICdYLVZlcmNlbC1Gb3J3YXJkZWQtRm9yJyxcbl07XG5cbi8qKlxuICogR2V0IHRoZSBJUCBhZGRyZXNzIG9mIHRoZSBjbGllbnQgc2VuZGluZyBhIHJlcXVlc3QuXG4gKlxuICogSXQgcmVjZWl2ZXMgYSBSZXF1ZXN0IGhlYWRlcnMgb2JqZWN0IGFuZCB1c2UgaXQgdG8gZ2V0IHRoZVxuICogSVAgYWRkcmVzcyBmcm9tIG9uZSBvZiB0aGUgZm9sbG93aW5nIGhlYWRlcnMgaW4gb3JkZXIuXG4gKlxuICogSWYgdGhlIElQIGFkZHJlc3MgaXMgdmFsaWQsIGl0IHdpbGwgYmUgcmV0dXJuZWQuIE90aGVyd2lzZSwgbnVsbCB3aWxsIGJlXG4gKiByZXR1cm5lZC5cbiAqXG4gKiBJZiB0aGUgaGVhZGVyIHZhbHVlcyBjb250YWlucyBtb3JlIHRoYW4gb25lIElQIGFkZHJlc3MsIHRoZSBmaXJzdCB2YWxpZCBvbmVcbiAqIHdpbGwgYmUgcmV0dXJuZWQuXG4gKi9cbmZ1bmN0aW9uIGdldENsaWVudElQQWRkcmVzcyhoZWFkZXJzKSB7XG4gIC8vIFRoaXMgd2lsbCBlbmQgdXAgYmVpbmcgQXJyYXk8c3RyaW5nIHwgc3RyaW5nW10gfCB1bmRlZmluZWQgfCBudWxsPiBiZWNhdXNlIG9mIHRoZSB2YXJpb3VzIHBvc3NpYmxlIHZhbHVlcyBhIGhlYWRlclxuICAvLyBjYW4gdGFrZVxuICBjb25zdCBoZWFkZXJWYWx1ZXMgPSBpcEhlYWRlck5hbWVzLm1hcCgoaGVhZGVyTmFtZSkgPT4ge1xuICAgIGNvbnN0IHJhd1ZhbHVlID0gaGVhZGVyc1toZWFkZXJOYW1lXTtcbiAgICBjb25zdCB2YWx1ZSA9IEFycmF5LmlzQXJyYXkocmF3VmFsdWUpID8gcmF3VmFsdWUuam9pbignOycpIDogcmF3VmFsdWU7XG5cbiAgICBpZiAoaGVhZGVyTmFtZSA9PT0gJ0ZvcndhcmRlZCcpIHtcbiAgICAgIHJldHVybiBwYXJzZUZvcndhcmRlZEhlYWRlcih2YWx1ZSk7XG4gICAgfVxuXG4gICAgcmV0dXJuIHZhbHVlPy5zcGxpdCgnLCcpLm1hcCgodikgPT4gdi50cmltKCkpO1xuICB9KTtcblxuICAvLyBGbGF0dGVuIHRoZSBhcnJheSBhbmQgZmlsdGVyIG91dCBhbnkgZmFsc3kgZW50cmllc1xuICBjb25zdCBmbGF0dGVuZWRIZWFkZXJWYWx1ZXMgPSBoZWFkZXJWYWx1ZXMucmVkdWNlKChhY2MsIHZhbCkgPT4ge1xuICAgIGlmICghdmFsKSB7XG4gICAgICByZXR1cm4gYWNjO1xuICAgIH1cblxuICAgIHJldHVybiBhY2MuY29uY2F0KHZhbCk7XG4gIH0sIFtdKTtcblxuICAvLyBGaW5kIHRoZSBmaXJzdCB2YWx1ZSB3aGljaCBpcyBhIHZhbGlkIElQIGFkZHJlc3MsIGlmIGFueVxuICBjb25zdCBpcEFkZHJlc3MgPSBmbGF0dGVuZWRIZWFkZXJWYWx1ZXMuZmluZChpcCA9PiBpcCAhPT0gbnVsbCAmJiBpc0lQKGlwKSk7XG5cbiAgcmV0dXJuIGlwQWRkcmVzcyB8fCBudWxsO1xufVxuXG5mdW5jdGlvbiBwYXJzZUZvcndhcmRlZEhlYWRlcih2YWx1ZSkge1xuICBpZiAoIXZhbHVlKSB7XG4gICAgcmV0dXJuIG51bGw7XG4gIH1cblxuICBmb3IgKGNvbnN0IHBhcnQgb2YgdmFsdWUuc3BsaXQoJzsnKSkge1xuICAgIGlmIChwYXJ0LnN0YXJ0c1dpdGgoJ2Zvcj0nKSkge1xuICAgICAgcmV0dXJuIHBhcnQuc2xpY2UoNCk7XG4gICAgfVxuICB9XG5cbiAgcmV0dXJuIG51bGw7XG59XG5cbi8vXG4vKipcbiAqIEN1c3RvbSBtZXRob2QgaW5zdGVhZCBvZiBpbXBvcnRpbmcgdGhpcyBmcm9tIGBuZXRgIHBhY2thZ2UsIGFzIHRoaXMgb25seSBleGlzdHMgaW4gbm9kZVxuICogQWNjZXB0czpcbiAqIDEyNy4wLjAuMVxuICogMTkyLjE2OC4xLjFcbiAqIDE5Mi4xNjguMS4yNTVcbiAqIDI1NS4yNTUuMjU1LjI1NVxuICogMTAuMS4xLjFcbiAqIDAuMC4wLjBcbiAqIDJiMDE6Y2IxOTo4MzUwOmVkMDA6ZDBkZDpmYTViOmRlMzE6OGJlNVxuICpcbiAqIFJlamVjdHM6XG4gKiAxLjEuMS4wMVxuICogMzAuMTY4LjEuMjU1LjFcbiAqIDEyNy4xXG4gKiAxOTIuMTY4LjEuMjU2XG4gKiAtMS4yLjMuNFxuICogMS4xLjEuMS5cbiAqIDMuLi4zXG4gKiAxOTIuMTY4LjEuMDk5XG4gKi9cbmZ1bmN0aW9uIGlzSVAoc3RyKSB7XG4gIGNvbnN0IHJlZ2V4ID1cbiAgICAvKD86Xig/OjI1WzAtNV18MlswLTRdXFxkfDFcXGRcXGR8WzEtOV1cXGR8XFxkKSg/OlxcLig/OjI1WzAtNV18MlswLTRdXFxkfDFcXGRcXGR8WzEtOV1cXGR8XFxkKSl7M30kKXwoPzpeKD86KD86W2EtZkEtRlxcZF17MSw0fTopezd9KD86W2EtZkEtRlxcZF17MSw0fXw6KXwoPzpbYS1mQS1GXFxkXXsxLDR9Oil7Nn0oPzooPzoyNVswLTVdfDJbMC00XVxcZHwxXFxkXFxkfFsxLTldXFxkfFxcZCkoPzpcXFxcLig/OjI1WzAtNV18MlswLTRdXFxkfDFcXGRcXGR8WzEtOV1cXGR8XFxkKSl7M318OlthLWZBLUZcXGRdezEsNH18Oil8KD86W2EtZkEtRlxcZF17MSw0fTopezV9KD86Oig/OjI1WzAtNV18MlswLTRdXFxkfDFcXGRcXGR8WzEtOV1cXGR8XFxkKSg/OlxcXFwuKD86MjVbMC01XXwyWzAtNF1cXGR8MVxcZFxcZHxbMS05XVxcZHxcXGQpKXszfXwoPzo6W2EtZkEtRlxcZF17MSw0fSl7MSwyfXw6KXwoPzpbYS1mQS1GXFxkXXsxLDR9Oil7NH0oPzooPzo6W2EtZkEtRlxcZF17MSw0fSl7MCwxfTooPzoyNVswLTVdfDJbMC00XVxcZHwxXFxkXFxkfFsxLTldXFxkfFxcZCkoPzpcXFxcLig/OjI1WzAtNV18MlswLTRdXFxkfDFcXGRcXGR8WzEtOV1cXGR8XFxkKSl7M318KD86OlthLWZBLUZcXGRdezEsNH0pezEsM318Oil8KD86W2EtZkEtRlxcZF17MSw0fTopezN9KD86KD86OlthLWZBLUZcXGRdezEsNH0pezAsMn06KD86MjVbMC01XXwyWzAtNF1cXGR8MVxcZFxcZHxbMS05XVxcZHxcXGQpKD86XFxcXC4oPzoyNVswLTVdfDJbMC00XVxcZHwxXFxkXFxkfFsxLTldXFxkfFxcZCkpezN9fCg/OjpbYS1mQS1GXFxkXXsxLDR9KXsxLDR9fDopfCg/OlthLWZBLUZcXGRdezEsNH06KXsyfSg/Oig/OjpbYS1mQS1GXFxkXXsxLDR9KXswLDN9Oig/OjI1WzAtNV18MlswLTRdXFxkfDFcXGRcXGR8WzEtOV1cXGR8XFxkKSg/OlxcXFwuKD86MjVbMC01XXwyWzAtNF1cXGR8MVxcZFxcZHxbMS05XVxcZHxcXGQpKXszfXwoPzo6W2EtZkEtRlxcZF17MSw0fSl7MSw1fXw6KXwoPzpbYS1mQS1GXFxkXXsxLDR9Oil7MX0oPzooPzo6W2EtZkEtRlxcZF17MSw0fSl7MCw0fTooPzoyNVswLTVdfDJbMC00XVxcZHwxXFxkXFxkfFsxLTldXFxkfFxcZCkoPzpcXFxcLig/OjI1WzAtNV18MlswLTRdXFxkfDFcXGRcXGR8WzEtOV1cXGR8XFxkKSl7M318KD86OlthLWZBLUZcXGRdezEsNH0pezEsNn18Oil8KD86Oig/Oig/OjpbYS1mQS1GXFxkXXsxLDR9KXswLDV9Oig/OjI1WzAtNV18MlswLTRdXFxkfDFcXGRcXGR8WzEtOV1cXGR8XFxkKSg/OlxcXFwuKD86MjVbMC01XXwyWzAtNF1cXGR8MVxcZFxcZHxbMS05XVxcZHxcXGQpKXszfXwoPzo6W2EtZkEtRlxcZF17MSw0fSl7MSw3fXw6KSkpKD86JVswLTlhLXpBLVpdezEsfSk/JCkvO1xuICByZXR1cm4gcmVnZXgudGVzdChzdHIpO1xufVxuXG5leHBvcnRzLmdldENsaWVudElQQWRkcmVzcyA9IGdldENsaWVudElQQWRkcmVzcztcbmV4cG9ydHMuaXBIZWFkZXJOYW1lcyA9IGlwSGVhZGVyTmFtZXM7XG4vLyMgc291cmNlTWFwcGluZ1VSTD1nZXRJcEFkZHJlc3MuanMubWFwXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbMF0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/.pnpm/@sentry+core@9.46.0/node_modules/@sentry/core/build/cjs/vendor/getIpAddress.js\n");
 
/***/ })
 
};
;